
/* CSS Document */


/* ------------------------------------------ */
/*             TABLE OF CONTENTS
/* ------------------------------------------ */
/*   01 - Click Top  */
/*   02 - Global stlye  */
/*   03 - Header  */
/*   04 - Theme Menu */
/*   05 - Theme Banner */
/*   06 - Service We offer */
/*   07 - Service We offer Two  */
/*   08 - About Company  */
/*   09 - Company Information  */
/*   10 - Recent Project  */
/*   11 - Client Slider  */
/*   12 - Our Team  */
/*   13 - Latest News  */
/*   14 - Contact Us  */
/*   15 - News-subscribe  */
/*   16 - Footer  */
/*   17 - Inner Banner  */
/*   18 - Service details Page  */
/*   19 - Blog Page  */
/*   20 - Blog Details Page */
/*   21 - Shop Page  */
/*   22 - Shop Details  */
/*   23 - Contact Us  */



/**
* Importing necessary  Styles.
**/

@import url('https://fonts.googleapis.com/css?family=Raleway:300,500,700,800,900|Roboto:300,400,500,700');
/*----bootstrap css ----- */
@import url('../vendor/bootstrap/bootstrap.css');
/*----bootstrap Select ----- */
@import url('../vendor/bootstrap-select/dist/css/bootstrap-select.css');
/*----revolution-slider---*/
@import url('../vendor/revolution/settings.css');
@import url('../vendor/revolution/layers.css');
@import url('../vendor/revolution/navigation.css');
/*----font awesome -------*/
@import url('../fonts/font-awesome/css/font-awesome.min.css');
/*-----flaticon ----------*/
@import url('../fonts/icon/font/flaticon.css');
/*----owl-carousel css----*/
@import url('../vendor/owl-carousel/owl.carousel.css');
@import url('../vendor/owl-carousel/owl.theme.css');
/*-------- animated css ------*/
@import url('../vendor/WOW-master/css/libs/animate.css');
/*-------- hover ------*/
@import url('../vendor/hover.css');
/*-------fancy box --------*/
@import url('../vendor/fancy-box/jquery.fancybox.css');


/*________________Preloader_______________ */
.call-link {
  color: white;          /* default color */
  text-decoration: none; /* remove underline */
  font-weight:lighter;
}

.call-link:hover {
  color: grey;           /* on hover */
}

#loader-wrapper {
    position: fixed;
    top: 0;
    left: 0;
    background: #fff;
    width: 100%;
    height: 100%;
    z-index: 999999999;
    overflow: hidden;
}
#loader {
    display: block;
    position: relative;
    left: 50%;
    top: 50%;
    width: 64px;
    height: 64px;
    background: url(../images/1.gif) no-repeat center;
    margin: -32px 0 0 -32px;
    overflow: hidden;
}

/*==================== Click Top ====================*/
.scroll-top {
  width:45px;
  height:45px;
  position: fixed;
  bottom: 52px;
  right: 80px;
  z-index: 99;
  text-align: center;
  color:#000;
  font-size: 20px;
  display: none;
}
.scroll-top:hover {
  color:#fff;
}
.scroll-top:after {
  position: absolute;
  z-index: -1;
  content: '';
  top: 100%;
  left: 5%;
  height: 10px;
  width: 90%;
  opacity: 1;
  background: -webkit-radial-gradient(center, ellipse, rgba(0, 0, 0, 0.25) 0%, rgba(0, 0, 0, 0) 80%);
  background: radial-gradient(ellipse at center, rgba(0, 0, 0, 0.25) 0%, rgba(0, 0, 0, 0) 80%);
}
/*______________________ Global stlye ___________________*/

 @font-face {
  font-family: 'font-awesome';
  src: url('../fonts/font-awesome/fonts/fontawesome-webfont.ttf');
  src: url('../fonts/font-awesome/fonts/fontawesome-webfont.eot'), /* IE9 Compat Modes */
       url('../fonts/font-awesome/fonts/fontawesome-webfont.woff2') format('woff2'), /* Super Modern Browsers */
       url('../fonts/font-awesome/fonts/fontawesome-webfont.woff') format('woff'), /* Pretty Modern Browsers */
       url('../fonts/font-awesome/fonts/fontawesome-webfont.svg') format('svg'); /* Legacy iOS */
 }

 body {
  font-family: 'Roboto', sans-serif;
  font-weight: normal;
  color:#6c6c6c;
  font-size: 18px;
  position: relative;
 }

 body .main-page-wrapper {
   overflow-x:hidden;
   position: relative;
 }

 h1,h2,h3,h4,h5,h6,p,ul { margin:0;padding: 0;}
 h1,h2,h3,h4,h5,h6 {color:#262626;}
 h1 {font-size: 55px; font-weight: 900; font-family: 'Raleway', sans-serif;}
 h2 {font-size: 26px; font-weight: 800; font-family: 'Raleway', sans-serif; text-transform: uppercase;}
 h3 {font-size: 20px; font-weight: 700; font-family: 'Raleway', sans-serif;}
 h4 {font-size: 18px;font-weight: normal;}
 h5 {font-size: 16px;font-weight: normal;}
 h6 {font-size: 14px;font-weight: normal;}
 p {line-height: 30px; font-weight: 300;}
 ul {list-style-type: none;}
 a {text-decoration: none; display: inline-block; font-weight: 700;}
 a:hover,a:focus,a:visited {text-decoration: none; outline: none;}
 img {max-width: 100%; display: block;}

 button {border:none;outline: none;box-shadow: none;display: block; padding: 0;}
 input,textarea {outline: none; box-shadow: none;-webkit-transition: all 0.3s ease-in-out;-o-transition: all 0.3s ease-in-out;transition: all 0.3s ease-in-out;}


 .clear-fix { clear:both;}
 .clear-fix:after {
  display: table;
  content: '';
  clear: both;
 }
.tran3s,.header-style-one .main-menu .navbar-nav > li  a,
.recent-project .title-wrapper .nav-list-wrapper .nav li a,
.owl-theme .owl-nav [class*=owl-],.owl-theme .owl-dots .owl-dot span,
.our-team .team-member .single-member .name a h4,
.service-offer.service-style-two .service-single-content .img a h3,
.service-details-page .service-details-content .work-progress .panel-group .panel-heading a:before,
.main-menu .navbar-nav>li.dropdown-holder .sub-menu li a {
  -webkit-transition: all .3s ease-in-out;
     -moz-transition: all .3s ease-in-out;
      -ms-transition: all .3s ease-in-out;
       -o-transition: all .3s ease-in-out;
          transition: all .3s ease-in-out;
 }
.tran4s,.our-project .gallery-item-wrapper .single-project-item .opacity {
  -webkit-transition: all .4s ease-in-out;
     -moz-transition: all .4s ease-in-out;
      -ms-transition: all .4s ease-in-out;
       -o-transition: all .4s ease-in-out;
          transition: all .4s ease-in-out;
 }
.float-left {float:left;}
.float-right {float:right;}
.round-border {
  border-radius: 50%;
  -moz-border-radius: 50%;
  -webkit-border-radius: 50%;
  -o-border-radius: 50%;
  -ms-border-radius: 50%;
}


.fancybox-skin {
  padding: 8px !important;
  background: #eeeeee;
  border-radius: 2px;
}
.p-color,.header-style-one .right-side .header-top-area .single-content .ficon:before,
.header-style-one .main-menu .navbar-nav > li:hover> a,.company-info .right-side .single-box h4,
.header-style-one .main-menu .navbar-nav > li.current-page-item> a,
.client-slider .client-slider-wrapper .name ul li,footer .footer-link ul li a:hover,
.our-team .team-member .single-member:hover .name a h4,footer .footer-address ul li span:before,
.theme-sidebar .sidebar-category ul li a i,.blog-details-page .post-meta-content .share-option ul li a:hover,
.single-blog-page .blog-post-container .single-blog-post:hover .post-text h4 a,
.shop-item-wrapper .single-item>div> ul li,.shop-item-wrapper .single-item:hover>div>a.item-name,
.theme-sidebar .sidebar-latest-item .single-post .text ul li,
.shop-details-wrapper .product-history .product-info ul li .fa,
.shop-details-wrapper .related-product .item ul li,.main-menu .navbar-nav>li.dropdown-holder .sub-menu li a:hover {
  color:#fac800;
}
.p-color-bg,.header-style-one .right-side .header-top-area ul li a:hover,
.owl-theme .owl-dots .owl-dot span:hover,.owl-theme .owl-dots .owl-dot.active span,
.owl-theme .owl-dots .owl-dot:hover span,.header-style-two .top-header ul li a:hover,
.our-project .gallery-menu-wrapper ul li:hover,.our-project .gallery-menu-wrapper ul li.active,
.our-project .gallery-item-wrapper .single-project-item .opacity>div ul li a:hover,
.single-blog-page .blog-post-container .more-page-button ul li.active a,
.blog-details-page .post-meta-content .comment-box-wrapper .comment button:hover,
.shop-item-wrapper .more-page-button ul li.active a {
  background: #fac800;
}
/*============================ Header Style One ======================*/
.header-style-one {
  position: absolute;
  width: 100%;
  top:0;
  left: 0;
  right: 0;
  z-index: 999;
  padding-top: 36px;
}
.header-style-one .logo {
  margin-top: 13px;
}
.header-style-one .right-side {
  width: 65%;
}
.header-style-one .right-side .header-top-area {
  margin-bottom: 10px;
}
.header-style-one .right-side .header-top-area .single-content {
  margin-left: 32px;
  position: relative;
}
.header-style-one .right-side .header-top-area ul li {
  display: inline-block;
  margin: 0 2px;
}
.header-style-one .right-side .header-top-area ul li a {
  width: 36px;
  height: 36px;
  line-height: 34px;
  border:2px solid #fff;
  color:#fff;
  font-size: 16px;
  text-align: center;
}
.header-style-one .right-side .header-top-area ul li a:hover {
  border-color: #fac800;
  color:#262626;
}
.header-style-one .right-side .header-top-area .single-content p {
  font-size: 20px;
  font-weight: 500;
  color:#fff;
  line-height: 15px;
  margin-bottom: 5px;
}
.header-style-one .right-side .header-top-area .single-content span {
  font-weight: 300;
  color:#b5b5b5;
}
.header-style-one .right-side .header-top-area .single-content .ficon:before {
  font-size: 35px;
  position: absolute;
  top:-6px;
  left:0;
}
.header-style-one .right-side .header-top-area .single-content.bar-fix {
  padding-left: 50px;
}
/*=========================== Header Style Two =======================*/
.header-style-two {
  position: relative;
}
.header-style-two .top-header {
  background: #2b2b2b;
}
.header-style-two .top-header p {
  color:#fff;
  line-height: 45px;
}
.header-style-two .top-header p b {
  font-weight: 500;
}
.header-style-two .top-header ul li {
  float:left;
}
.header-style-two .top-header ul li a {
  line-height: 45px;
  text-align: center;
  width: 45px;
  font-size: 16px;
  border-left:1px solid #3e3e3e;
  color:#b0b0b0;
}
.header-style-two .top-header ul li:last-child a {
  border-right:1px solid #3e3e3e;
}
.header-style-two .top-header ul li a:hover {
  border-color: #fac800;
  color:#2b2b2b;
}
.header-style-two .bottom-header {
  padding: 33px 0 58px 0;
}
.header-style-two .bottom-header ul li {
  display: inline-block;
  position: relative;
  margin-left: 50px;
  margin-top: 12px;
  vertical-align: bottom;
}
.header-style-two .bottom-header ul li p {
  font-size: 20px;
  font-weight: 500;
  color:#262626;
  line-height: 15px;
  margin-bottom: 5px;
}
.header-style-two .bottom-header ul li span {
  font-weight: 300;
  color:#868686;
}
.header-style-two .bottom-header ul li .ficon:before {
  font-size: 35px;
  position: absolute;
  top:-6px;
  left:0;
  color:#262626;
}
.header-style-two .bottom-header ul li.bar-fix {
  padding-left: 50px;
  margin-left: 26px;
}
.header-style-two .bottom-header ul li form {
  width: 250px;
  height: 48px;
  position: relative;
}
.header-style-two .bottom-header ul li form input {
  width: 100%;
  height: 100%;
  background: #fff;
  border: 1px solid #e4e4e4;
  font-size: 17px;
  font-weight: 300;
  padding: 0 40px 0 20px;
}
.header-style-two .bottom-header ul li form button {
  width: 40px;
  height: 100%;
  background: transparent;
  text-align: left;
  position: absolute;
  top:0;
  right: 0;
  font-weight: normal;
}
.header-style-two .bottom-header ul li form input:focus {
  border-color: #fac800;
}
/*========================== Theme Menu Style One ========================*/
.main-menu .navbar {
  border-radius: 0;
  margin: 0;
  border:none;
}
.navbar-collapse {
  padding: 0;
}
.header-style-one .main-menu .navbar-nav > li {
  margin: 0 5px;
}
.header-style-one .main-menu .navbar-nav > li> a {
  font-size: 20px;
  color:#fff;
  background: transparent !important;
  padding: 10px 12px 25px 12px;
  font-weight: normal;
}
.header-style-one .main-menu .navbar-nav > li> a>i {
  font-size: 16px;
  vertical-align: middle;
}
.header-style-one .main-menu .navbar-nav > li:last-child> a {
  padding-right: 0;
}
.header-style-one .main-menu .navbar-nav > li:last-child {
  margin-right: 0;
}
.main-menu .navbar-nav > li> .fa {
  display: none;
  position: absolute;
  width: 45px;
  line-height: 42px;
  top:0;
  right: 0;
  cursor:pointer;
  font-size: 22px;
  text-align: center;
}
.main-menu .navbar-toggle {
  float:left;
  padding-left: 0;
}
.main-menu .navbar-toggle .icon-bar {
  background: #fff;
}
/*======================= Theme Menu style Two =======================*/
.theme-menu-two {
  position: absolute;
  width: 100%;
  left: 0;
  right: 0;
  bottom: -33px;
  z-index: 99;
}
.theme-menu-two .main-menu {
  background: #1f54a3;
}
.theme-menu-two .main-menu .navbar-nav > li> a {
  font-size: 20px;
  color:#fff;
  background: transparent !important;
  padding: 0 20px;
  font-weight: normal;
  line-height: 65px;
  position: relative;
}
.theme-menu-two .main-menu .navbar-nav > li> a:before {
  content: '';
  width: 1px;
  height: 25px;
  background: #2d63b2;
  position: absolute;
  top:20px;
  right: 0;
}
.theme-menu-two .main-menu .navbar-nav > li:last-child> a:before {
  display:none;
}
.theme-menu-two .main-menu .navbar-nav > li> a>i {
  font-size: 16px;
  vertical-align: middle;
}
.theme-menu-two .main-menu .navbar-nav > li> .fa {
  color:#fff;
}
.theme-menu-two .main-menu {
  padding-left: 25px;
  position: relative;
}
.theme-menu-two .main-menu .request-quote {
  width: 240px;
  line-height: 65px;
  text-align: center;
  font-weight: 500;
  font-size: 20px;
  color:#2b2b2b;
  position: absolute;
  top:0;
  right: 0;
}
.theme-menu-two .main-menu .request-quote i {
  font-size: 16px;
  vertical-align: middle;
}
/*=================== Sub Menu ==============*/
.main-menu .navbar-nav>li.dropdown-holder .sub-menu {
  position: absolute;
  left: -12px;
  top:130%;
  width:220px;
  background: #fff;
  opacity: 0;
  visibility: hidden;
  -webkit-transition: top .6s ease;
     -moz-transition: top .6s ease;
      -ms-transition: top .6s ease;
       -o-transition: top .6s ease;
          transition: top .6s ease;
  -webkit-box-shadow: 0px 13px 25px -12px rgba(0,0,0,0.25);
  -moz-box-shadow: 0px 13px 25px -12px rgba(0,0,0,0.25);
  box-shadow: 0px 13px 25px -12px rgba(0,0,0,0.25);
}
.theme-menu-two .main-menu .navbar-nav>li.dropdown-holder .sub-menu {
  left: 0;
}
.main-menu .navbar-nav>li.dropdown-holder:hover .sub-menu {
  opacity: 1;
  visibility: visible;
  top:100%;
}
.main-menu .navbar-nav>li.dropdown-holder .sub-menu li a {
  line-height: 40px;
  font-size: 16px;
  color:#76808a;
  padding-left: 20px;
  display: block;
  border-bottom: 1px solid #ededed;
  position: relative;
  z-index: 1;
  letter-spacing: 0.5px;
  font-weight: normal;
}
.main-menu .navbar-nav>li.dropdown-holder .sub-menu li:last-child a {
  border:none;
}
/*=================== Banner One ================*/
#banner {
  margin-bottom: 70px;
}
#banner h1 {
  text-transform: uppercase;
  line-height: 70px;
  color:#fff;
  text-align: center;
}
#banner h3 {
  font-size: 24px;
  font-weight: 500;
  text-transform: uppercase;
  color:#fff;
}
#banner .contact-button {
  width: 170px;
  line-height: 55px;
  text-align: center;
  text-transform: uppercase;
  font-size: 17px;
  color:#232323;
}
#banner .contact-button:hover {
  color:#fff;
}
#banner .service-button {
  width: 170px;
  line-height: 51px;
  border:2px solid #fff;
  text-align: center;
  text-transform: uppercase;
  font-size: 17px;
  color:#fff;
}
#banner #main-banner-slider-two h1 {
  text-align: left;
  text-transform: none;
}
#banner #main-banner-slider-two h3 {
  text-align: left;
  line-height: 38px;
  font-weight: 300;
  text-transform: none;
}
/*====================== Service We offer ================*/
.theme-title-style {
  position: relative;
  padding-left: 17px;
  line-height: 55px;
}
.theme-title-style:before {
  content: '';
  width: 202px;
  height: 100%;
  border:3px solid rgba(250,200,0,0.3);
  position: absolute;
  top:0;
  left:0;
  z-index: 1;
}
.service-offer {
  border-bottom: 1px solid #efefef;
  padding-bottom: 50px;
  margin-bottom: 80px;
}
.service-offer.fix {
  border:none;
  padding-bottom: 0;
}
.service-offer .container {
  position: relative;
}
.service-offer .container>p {
  margin: 16px 0 66px 0;
  font-size: 20px;
}
.service-offer .service-single-content {
  margin-bottom: 42px;
}
.service-offer .service-single-content .img {
  position: relative;
  overflow: hidden;
  background: #000;
}
.service-offer .service-single-content .img img {
  width: 100%;
  -webkit-transition: all .5s ease-in-out;
     -moz-transition: all .5s ease-in-out;
      -ms-transition: all .5s ease-in-out;
       -o-transition: all .5s ease-in-out;
          transition: all .5s ease-in-out;
}
.service-offer .service-single-content:hover .img img {
  opacity: 0.5;
  -webkit-transform: scale3D(1.1,1.1,1);
     -moz-transform: scale3D(1.1,1.1,1);
      -ms-transform: scale3D(1.1,1.1,1);
       -o-transform: scale3D(1.1,1.1,1);
          transform: scale3D(1.1,1.1,1);
}
.service-offer .service-single-content .img a {
  position: absolute;
  width: 100%;
  left:0;
  bottom: 0;
  padding: 17px 18px 17px 30px;
  background: rgba(31,84,163,0.9);
}
.service-offer .service-single-content .img a h3 {
  display: inline-block;
  color:#fff;
  text-transform: uppercase;
  margin-top: 12px;
}
.service-offer .service-single-content .img a span {
  display: block;
  width: 45px;
  height: 45px;
  line-height: 45px;
  text-align: center;
  float:right;
  font-size: 35px;
  color:#232323;
}
.service-offer .all-service-button {
  width: 170px;
  line-height: 46px;
  border:2px solid #dddddd;
  text-align: center;
  text-transform: uppercase;
  font-size: 16px;
  color:#595656;
  position: absolute;
  top:47px;
  right: 0;
}
.service-offer .all-service-button:hover {
  color:#fff;
}
/*====================== Service We offer Two ================*/
.service-offer.service-style-two {
  margin: 105px 0 0 0;
  border: none;
}
.service-offer.service-style-two .service-single-content .img a {
  background: transparent;
}
.service-offer.service-style-two .service-single-content .img a h3 {
  opacity: 0;
}
.service-offer.service-style-two .service-single-content .text a {
  display: block;
  margin: 30px 0 13px 0;
}
.service-offer.service-style-two .service-single-content .text a h4 {
  font-size: 20px;
  font-weight: 500;
  color:#262626;
}
.service-offer.service-style-two .service-single-content:hover .img a {
  background: rgba(31,84,163,0.9);
}
.service-offer.service-style-two .service-single-content:hover .img a h3 {
  opacity: 1;
}
.service-offer.service-style-two .service-single-content {
  margin-bottom: 60px;
}
/*===================== About Company =================*/
.about-company .left-side {
  text-align: right;
}
.about-company .left-side h4 {
  font-weight: 300;
  font-size: 44px;
  line-height: 51px;
}
.about-company .left-side a {
  width: 140px;
  line-height: 48px;
  border:1px solid #efefef;
  font-size: 16px;
  color:#2c2c2c;
  text-align: center;
  text-transform: uppercase;
  margin-top: 29px;
}
.about-company .left-side h4 .highlight-yellow {
  color: #FFD700; /* golden yellow */
  font-weight: 600; /* optional: makes it stand out */
}
.about-company .left-side a:hover {
  color:#fff;
}
.about-company .right-side {
  padding: 0 65px 0 50px;
}
.about-company .right-side h4 {
  font-weight: 300;
  font-size: 32px;
  line-height: 45px;
  margin: -8px 0 28px 0;
}
.about-company .right-side h4 span {
  font-weight: 500;
}
.about-company .right-side h5 {
  font-size: 20px;
  color:#262626;
  line-height: 30px;
  margin-bottom: 25px;
}
.about-company .single-box {
  text-align: center;
  margin-top: 50px;
}
.about-company .single-box p {
  font-size: 20px;
  font-family: 'Raleway', sans-serif;
  margin-top: -9px;
}
.about-company .single-box .number {
  font-size: 60px;
  color:#262626;
}
.about-company.about-us-page-fix .right-side {
  padding: 0;
}
.about-company.about-us-page-fix .left-half {
  width: 45.50%;
}
.about-company.about-us-page-fix .right-half {
  width: 54.50%;
  padding-left: 55px;
}
.about-company.about-us-page-fix .left-half .img-wrapper {
  margin-right: -5px;
  margin-left: -5px;
}
.about-company.about-us-page-fix .left-half .img-wrapper .single-img {
  width: 50%;
  padding-left: 5px;
  padding-right: 5px;
}
.about-company.about-us-page-fix .left-half .img-wrapper .single-img img {
  margin-bottom: 8px;
}
.about-company.about-us-page-fix .single-box {
  border:1px solid #e7e7e7;
  padding-bottom: 12px;
}
/*==================== Company Information ================*/
.company-info {
  background: url(../images/home/1.jpg) no-repeat center;
  background-size: cover;
  background-attachment: fixed;
  margin: 110px 0 0 0;
}
.company-info .opacity {
  height: 100%;
  background: rgba(19,68,141,0.9);
  padding: 75px 0 75px 0;
}
.company-info .left-side {
  text-align: right;
  padding-right: 30px;
}
.company-info .left-side h4 {
  font-size: 40px;
  color:#fff;
  line-height: 45px;
}
.company-info .left-side a {
  width: 154px;
  line-height: 50px;
  text-align: center;
  font-size: 18px;
  color:#232323;
  font-weight: 500;
  margin-top: 36px;
}
.company-info .right-side .single-box {
  text-align: center;
  margin-top: 11px;
}
.company-info .right-side .single-box .icon {
  background: url(../images/home/shape.png) no-repeat center;
  width: 109px;
  height: 125px;
  margin: 0 auto;
  text-align: center;
}
.company-info .right-side .single-box .icon span:before {
  color:#fff;
  font-size: 52px;
  line-height: 125px;
}
.company-info .right-side .single-box h4 {
  font-weight: 500;
  font-size: 30px;
  margin:19px 0 10px 0;
}
.company-info .right-side .single-box p {
  font-weight: normal;
  font-size: 22px;
  color:#fff;
}
/*========================= Recent Project ==================*/
.recent-project {
  background: #282828;
  padding: 90px 0 95px 0;
}
.recent-project .title-wrapper h2 {
  color:#fff;
}
.recent-project .title-wrapper .nav-list-wrapper {
  width: 51%;
  margin-right: 145px;
  padding-top: 12px;
}
.recent-project .title-wrapper .nav-list-wrapper .nav {
  border:none;
}
.recent-project .title-wrapper .nav-list-wrapper .nav li {
  margin: 0;
  border:0;
  border-radius: 0;
  background: transparent;
}
.recent-project .title-wrapper .nav-list-wrapper .nav li a {
  font-weight: 300;
  color:#8d8d8d;
  border-radius: 0;
  border:1px solid #4a4a4a;
  border-right: none;
  margin:0;
  line-height: 40px;
  padding: 0 15px; 
}
.recent-project .title-wrapper .nav-list-wrapper .nav li:last-child a {
  border-right:1px solid #4a4a4a;
}
.recent-project .title-wrapper .nav-list-wrapper .nav > li:hover > a,
.recent-project .title-wrapper .nav-list-wrapper .nav > li.active > a, 
.recent-project .title-wrapper .nav-list-wrapper .nav > li.active > a:hover, 
.recent-project .title-wrapper .nav-list-wrapper .nav > li.active > a:focus {
  background-color: #4a4a4a;
  color:#fff;
}
.recent-project .tab-wrapper {
  margin-top: 60px;
}
.tab-content > .tab-pane {
  display: block;
  height: 0;
  visibility: hidden;
}
.tab-content > .active {
  height: auto;
  visibility: visible;
}
.recent-project .project-img-slider .item {
  margin-right: 15px;
  margin-left: 15px;
}
.recent-project .project-img-slider .item img {
  width: 100%;
}
.recent-project .project-img-slider .item .img {
  position: relative;
}
.recent-project .project-img-slider .item .img .opacity {
  position: absolute;
  width: 100%;
  height: 100%;
  top:0;
  left: 0;
  background: rgba(250,200,0,0.8);
  opacity: 0;
  -webkit-transform: scale(0.3);
     -moz-transform: scale(0.3);
      -ms-transform: scale(0.3);
       -o-transform: scale(0.3);
          transform: scale(0.3);
}
.recent-project .project-img-slider .item .img .opacity a {
  display: table;
  width: 100%;
  height: 100%;
  text-align: center;
  font-size: 45px;
  font-weight: 300;
  color:#fff;
}
.recent-project .project-img-slider .item .img .opacity a span {
  display: table-cell;
  vertical-align: middle;
}
.recent-project .project-img-slider .item .img:hover .opacity {
  opacity: 1;
  -webkit-transform: scale(1);
     -moz-transform: scale(1);
      -ms-transform: scale(1);
       -o-transform: scale(1);
          transform: scale(1);
}
.owl-theme .owl-nav [class*=owl-] {
  position: relative;
  padding: 0;
  width:40px;
  height:38px;
  color:#999999;
  border:1px solid #999999;
  margin: 0;
  background: transparent;
  text-align: center;
  border-radius: 0;
}
.owl-theme .owl-nav [class*=owl-]:hover {
  background: #fac800;
  border-color: #fac800;
  color:#000;
}
.owl-carousel .owl-controls .owl-nav .owl-prev {
  border-right: 1px solid #999999;
}
.owl-carousel .owl-controls .owl-nav .owl-next {
  border-left: 1px solid #999999;
}
.owl-carousel .owl-controls .owl-nav .owl-prev:before,
.owl-carousel .owl-controls .owl-nav .owl-next:before {
  position: absolute;
  font-family: 'font-awesome';
  width:100%;
  line-height: 36px;
  top:0;
  left:0;
  font-size: 24px;
}
.owl-carousel .owl-controls .owl-nav .owl-prev:before {
  content: '';
}
.owl-carousel .owl-controls .owl-nav .owl-next:before {
  content: '';
}
.owl-theme .owl-nav {
  margin: 0;
}
.owl-carousel .owl-controls {
  position: absolute;
  top:0;
  right: 15px;
}
.recent-project .owl-carousel .owl-controls  {
  top:-101px;
}
/*======================= Client Slider =================*/
.client-slider {
  margin: 80px 0 1px 0;
}
.client-slider .container {
  border-bottom: 1px solid #efefef;
  padding-bottom: 60px;
}
.client-slider h4 {
  font-weight: 300;
  font-size: 36px;
  line-height: 45px;
  text-align: right;
}
.client-slider .client-slider-wrapper {
  padding-left: 30px;
}
.client-slider .client-slider-wrapper img {
  width: 70px;
  height: 70px;
}
.client-slider .client-slider-wrapper .name {
  padding-left: 25px;
}
.client-slider .client-slider-wrapper .name h5 {
  font-weight: 500;
  font-size: 22px;
  margin: 5px 0 3px 0;
}
.client-slider .client-slider-wrapper .name span {
  font-weight: 300;
  color:#c2c2c2;
}
.client-slider .client-slider-wrapper .name ul li {
  display: inline-block;
  margin-right: 2px;
  font-size: 16px;
  margin-top: 5px;
}
.client-slider .client-slider-wrapper p {
  font-size: 20px;
  line-height: 34px;
  position: relative;
  padding: 15px 0 0 95px;
  color:#474646;
}
.client-slider .client-slider-wrapper p:before {
  content: '';
  font-family: 'font-awesome';
  color:#eeeeee;
  font-size: 55px;
  position: absolute;
  left:3px;
  top:36px;
}
.owl-theme .owl-dots .owl-dot span {
  width: 12px;
  height: 12px;
  margin: 0 4px;
  background: transparent;
  border:2px solid #eeeeee;
}
.client-slider .owl-theme .owl-dots .owl-dot span:hover,
.owl-theme .owl-dots .owl-dot.active span,
.owl-theme .owl-dots .owl-dot:hover span {
  border-color: #fac800;
  width: 12px;
  height: 12px;
}
.client-slider .owl-carousel .owl-controls {
  left: -87px;
  bottom: 10px;
  right: auto;
  top:auto;
}
/*====================== Our Team ==================*/
.our-team .left-side {
  text-align: right;
}
.our-team .left-side h4 {
  font-weight: 300;
  font-size: 36px;
  line-height: 45px;
  letter-spacing: -1px;
  margin-top: -9px;
}
.our-team .left-side a {
  width: 172px;
  line-height: 50px;
  text-align: center;
  font-size: 16px;
  text-transform: uppercase;
  color:#fff;
  margin-top: 35px;
  background: #205096;
}
.our-team .wrapper {
  padding-left: 30px;
}
.our-team .wrapper [class*="col-"] {
  padding-left: 21px;
  padding-right: 21px;
}
.our-team .wrapper .row {
  margin-right: -21px;
  margin-left: -21px;
}
.our-team .team-member .single-member .name a {
  display: block;
  margin: 24px 0 4px 0;
}
.our-team .team-member .single-member .name a h4 {
  font-size: 22px;
  font-weight: 500;
}
.our-team .team-member .single-member .name span {
  font-weight: 300;
  color:#c2c2c2;
}
.our-team .team-member .single-member .img {
  position: relative;
  overflow: hidden;
}
.our-team .team-member .single-member .img .opacity {
  background: rgba(31,83,164,0.9);
  position: absolute;
  bottom: -69px;
  width: 100%;
  left:0;
  padding: 17px 0;
  opacity: 0;
  visibility: hidden;
}
.our-team .team-member .single-member .img .opacity ul {
  text-align: center;
}
.our-team .team-member .single-member .img .opacity ul li {
  display: inline-block;
}
.our-team .team-member .single-member .img .opacity ul li a {
  width: 35px;
  height: 35px;
  border:2px solid #fff;
  line-height: 31px;
  text-align: center;
  color:#fff;
  font-size: 16px;
  margin: 0 2px;
}
.our-team .team-member .single-member .img .opacity ul li a:hover {
  background: #fac800;
  border-color:#fac800;
  color:#000;
}
.our-team .team-member .single-member:hover .img .opacity {
  opacity: 1;
  visibility: visible;
  bottom: 0;
}
.our-team.team-single-page .team-member .single-member {
  border-bottom: 1px solid #f0f0f0;
  margin-bottom: 70px;
  padding-bottom: 17px;
}
/*====================== Latest News ===================*/
.latest-news {
  background: url(../images/news/1.jpg) no-repeat center;
  background-size: cover;
  background-attachment: fixed;
  margin:95px 0 98px 0;
}
.latest-news .container {
  position: relative;
}
.latest-news .opacity {
  height: 100%;
  background: rgba(36,36,36,0.95);
  padding: 95px 0 85px 0;
}
.latest-news .opacity .theme-title-style {
  color:#fff;
}
.latest-news .opacity .theme-title-style:before {
  width: 169px;
}
.latest-news .single-news .img {
  position: relative;
}
.latest-news .single-news .img .overlay {
  position: absolute;
  width: 100%;
  height: 100%;
  top:0;
  left: 0;
  background: rgba(250,200,0,0.8);
  opacity: 0;
  -webkit-transform: scale(0.3);
     -moz-transform: scale(0.3);
      -ms-transform: scale(0.3);
       -o-transform: scale(0.3);
          transform: scale(0.3);
}
.latest-news .single-news .img .overlay a {
  display: table;
  width: 100%;
  height: 100%;
  text-align: center;
  font-size: 45px;
  font-weight: 300;
  color:#fff;
}
.latest-news .single-news .img .overlay a span {
  display: table-cell;
  vertical-align: middle;
}
.latest-news .single-news:hover .img .overlay {
  opacity: 1;
  -webkit-transform: scale(1);
     -moz-transform: scale(1);
      -ms-transform: scale(1);
       -o-transform: scale(1);
          transform: scale(1);
}
.latest-news .single-news .post span {
  font-weight: 300;
  display: block;
  margin: 30px 0 12px 0;
}
.latest-news .single-news .post a {
  font-weight: normal;
  font-size: 24px;
  line-height: 31px;
  color:#fff;
  display: block;
  margin-bottom: 10px;
}
.latest-news .row {
  margin: 50px -30px 0 -30px;
}
.latest-news .news-slider .item {
  margin-right: 30px;
  margin-left: 30px;
}
.latest-news .owl-carousel .owl-controls  {
  top:-89px;
  right: 30px;
}
/*=================== Contact Us =================*/
.any-question-wrapper {
  padding-right: 25px;
}
.any-question-wrapper h4 {
  font-size: 36px;
  line-height: 45px;
}
.any-question-wrapper>span {
  font-size: 20px;
  font-weight: 300;
  display: block;
  margin: 25px 0 35px 0;
}
.any-question-wrapper p b {
  font-weight: 500;
  color:#25292f;
}
.any-question-wrapper p a {
  font-weight: 500;
}
.any-question-wrapper p span {
  font-weight: normal;
  color:#292929;
}
.any-question-wrapper p {
  margin-bottom: 20px;
}
.contact-us-form h4 {
  font-size: 36px;
  line-height: 45px;
  margin-bottom: 35px;
}
.contact-us-form form {
  background: #f7f7f7;
  border:1px solid #f2f2f2;
  padding: 35px 35px 25px 35px;
}
.contact-us-form form .row {
  margin-left: -8px;
  margin-right: -8px;
}
.contact-us-form form .row [class*="col-"] {
  padding-left: 8px;
  padding-right: 8px;
}
.contact-us-form form input,
.contact-us-form form textarea {
  width: 100%;
  max-width: 100%;
  font-size: 17px;
  font-weight: 300;
  padding: 0 15px 0 25px;
  background: #fff;
  margin-bottom: 15px;
  border:1px solid transparent;
}
.contact-us-form form input {
  height: 55px;
}
.contact-us-form form textarea {
  min-height: 146px;
  padding: 25px 15px 15px 25px;
}
.contact-us-form form input:focus,
.contact-us-form form textarea:focus {
  border-color:#fac800;
}
.contact-us-form form button {
  width: 112px;
  line-height: 50px;
  font-weight: 500;
  font-size: 17px;
  color:#fff;
}
/*====================== Our Partners ================*/
/* Partner Section */
.our-partners {
 padding: 10px 0 50px 0;      /* reduce top/bottom space */
  text-align: center;
}

/* Each logo box */
.our-partners .item {
  margin: 10px 15px;    /* less gap between logos */
  display: inline-block;
  vertical-align: middle;
}

/* Logo images */
.our-partners .item img {
  display: block;
  margin: 0 auto;
  height: auto;
  max-width: 100%;  /* responsive, but keeps natural size */
}

/* Mobile layout */
@media (max-width: 768px) {
  .our-partners .item {
    width: 48%;          /* 2 logos per row */
    margin: 10px 1%;     /* spacing between */
  }
}

@media (max-width: 480px) {
  .our-partners .item {
    width: 100%;         /* 1 logo per row on very small screens */
    margin: 10px 0;
  }
}

/*======================= News-subscribe =================*/
.news-subscribe {
  background: #282828;
  border-bottom: 1px solid #2f2f2f;
  padding: 65px 0 70px 0;
}
.news-subscribe input {
  height: 65px;
  border: 1px solid transparent;
  background: #fff;
  font-size: 17px;
  font-weight: 300;
  padding: 0 20px 0 32px;
  width: 100%;
}
.news-subscribe .single-input {
  width: 40%;
}
.news-subscribe .single-input.fix {
  padding: 0 25px;
}
.news-subscribe form button {
  width: 20%;
  line-height: 65px;
  font-weight: 700;
  font-size: 17px;
  color:#202020;
  text-transform: uppercase;
}
.news-subscribe input:focus {
  border-color: #fac800;
}
.news-subscribe h4 {
  font-size: 36px;
  font-weight: 300;
  color:#fff;
  margin-bottom: 40px;
}
/*========================= Footer ================*/
footer {
  background: #282828;
  padding: 58px 0 0 0;
}
footer .top-footer h4 {
  font-size: 28px;
  font-weight: 700;
  color:#fff;
  margin-bottom: 30px;
}
footer .footer-logo {
  width: 25%;
   

}
footer .footer-logo .logo {
  margin-top: -15px;
}
footer .footer-logo p {
  font-size: 17px;
  color:#fff;
  margin: 20px 0 30px 0;
}
footer .footer-logo ul li {
  display: inline-block;
  margin-right: 2px;
}
footer .footer-logo ul li a {
  width: 35px;
  line-height: 33px;
  border:1px solid #373737;
  text-align: center;
  color:#939393;
  font-size: 16px;
}
footer .footer-logo ul li a:hover {
  background: #fac800;
  border-color:#fac800;
  color:#202020;
}
footer .footer-link {
  width: 26%;
  padding-left: 75px;
}
footer .footer-link ul li {
  line-height: 38px;
}
footer .footer-link ul li a {
  font-weight: 300;
  font-size: 17px;
  color:#fff;
}
footer .footer-link ul li i {
  margin-right: 10px;
}
footer .footer-link ul {
  display: inline-block;
  vertical-align: top;
}
footer .footer-link ul:nth-child(2) {
  margin-right: 35px;
}
footer .footer-twitter-feed {
  width: 25%;
  padding-left: 55px;
}
footer .footer-twitter-feed ul li {
  padding-left: 29px;
  margin-bottom: 20px;
  position: relative;
}
footer .footer-twitter-feed ul li a {
  font-size: 17px;
  font-weight: 300;
  color:#c4c4c4;
  line-height: 25px;
  display: block;
  margin-bottom: 4px;
}
footer .footer-twitter-feed ul li a b {
  font-weight: 500;
  color:#fff;
}
footer .footer-twitter-feed ul li span {
  font-weight: 300;
  font-size: 17px;
}
footer .footer-twitter-feed ul li .fa {
  position: absolute;
  top:5px;
  left:0;
  color:#07b2f9;
}
footer .footer-address {
  width: 24%;
  padding-left: 55px;
}
footer .footer-address ul li {
  line-height: 28px;
  font-size: 17px;
  font-weight: 300;
  color:#fff;
  margin-bottom: 16px;
  position: relative;
  padding-left: 38px;
}
footer .footer-address ul li span {
  position: absolute;
  top:1px;
  left:0;
}
footer .footer-address ul li span:before {
  font-size: 20px;
  padding-left: 2px;
}
footer .footer-address ul li span.flaticon-map-solid:before {
  font-size: 25px;
}
footer .bottom-footer {
  background: #252525;
  text-align: center;
  padding: 12px 0;
  margin-top: 37px;
}
footer .bottom-footer p {
  color:#a5a0a0;
}
footer .bottom-footer p a {
  font-weight: 300;
}
/*========================= Inner Banner ====================*/
.inner-banner {
  background: url(../images/inner-page/1.jpg) no-repeat center;
  background-size: cover;
}
.inner-banner .opacity {
  height: 100%;
  background: rgba(9,9,9,0.8);
  text-align: center;
  padding: 117px 0 97px 0;
}
.inner-banner .opacity h2 {
  font-size: 60px;
  font-weight: 900;
  color:#fff;
  text-transform: uppercase;
}
.page-navigation {
  background: #f7f7f7;
  margin-bottom: 85px;
}
.page-navigation ul li {
  display: inline-block;
  margin-right: 3px;
  font-weight: 300;
  color:#262626;
  font-size: 17px;
}
.page-navigation ul li a {
  font-weight: 300;
  color:#262626;
  line-height: 60px;
  font-size: 17px;
}
.page-navigation ul li:last-child {
  font-weight: 500;
  color:#262626;
}
.page-navigation .share {
  width: 136px;
  text-align: center;
  line-height: 60px;
  font-weight: 500;
  color:#262626;
  border-right:1px solid #eaeaea;
  border-left:1px solid #eaeaea;
}
.page-navigation .share i {
  margin-right: 3px;
}
.page-navigation .share:hover {
  color:#fff;
}
/*==================== Our Project ================*/
.our-project .gallery-menu-wrapper {
  text-align: center;
}
.our-project .gallery-menu-wrapper ul {
  display: inline-block;
  border:1px solid #f0f0f0;
  margin-bottom: 47px;
}
.our-project .gallery-menu-wrapper ul li {
  float: left;
  line-height: 53px;
  font-weight: 500;
  color:#262626;
  padding: 0 22px;
  border-right: 1px solid #f0f0f0;
  cursor: pointer;
}
.our-project .gallery-menu-wrapper ul li:last-child {
  border:none;
}
.our-project .gallery-item-wrapper {
  margin-bottom: 130px;
}
.our-project .gallery-item-wrapper .mix {
  display: none;
}
.our-project .gallery-item-wrapper .single-project-item {
  position: relative;
  margin-bottom: 30px;
}
.our-project .gallery-item-wrapper .single-project-item .opacity {
  position: absolute;
  width: 100%;
  height: 100%;
  left:0;
  top:0;
  text-align: center;
  background: rgba(8,71,130,0.9);
  opacity: 0;
  visibility: visible;
  -webkit-transform: scale(0.3);
     -moz-transform: scale(0.3);
      -ms-transform: scale(0.3);
       -o-transform: scale(0.3);
          transform: scale(0.3);
}
.our-project .gallery-item-wrapper .single-project-item:hover .opacity {
  opacity: 1;
  visibility: visible;
  -webkit-transform: scale(1);
     -moz-transform: scale(1);
      -ms-transform: scale(1);
       -o-transform: scale(1);
          transform: scale(1);
}
.our-project .gallery-item-wrapper .single-project-item .opacity>div {
  display: table;
  width: 100%;
  height: 100%;
}
.our-project .gallery-item-wrapper .single-project-item .opacity>div>div {
  display: table-cell;
  vertical-align: middle;
}
.our-project .gallery-item-wrapper .single-project-item .opacity>div h4 {
  font-weight: 700;
  font-size: 24px;
  color:#fff;
  margin-bottom: 30px;
}
.our-project .gallery-item-wrapper .single-project-item .opacity>div ul li {
  display: inline-block;
}
.our-project .gallery-item-wrapper .single-project-item .opacity>div ul li a {
  display: block;
  width: 36px;
  height: 36px;
  line-height: 36px;
  color:#fff;
  font-size: 15px;
  border: 2px solid #fff;
}
.our-project .gallery-item-wrapper .single-project-item .opacity>div ul li a:hover {
  border-color:#fac800;
  color: #2c2c2c;
}
/*========================= Service details Page ======================*/
.service-details-page .service-sidebar {
  width: 24%;
}
.service-details-page .service-sidebar .service-page-list li {
  display: block;
  margin-bottom: 10px;
}
.service-details-page .service-sidebar .service-page-list li a {
  font-weight: 500;
  color:#76808a;
  display: block;
  padding: 0 0 0 30px;
  line-height: 55px;
  background: #f5f5f5;
  border:1px solid #f0efef;
  position: relative;
}
.service-details-page .service-sidebar .service-page-list li a:hover,
.service-details-page .service-sidebar .service-page-list li.active a {
  color:#262626;
  background: #fff;
  border-color:#fac800;
}
.service-details-page .service-sidebar .service-page-list li a:before {
  content: '';
  font-family: 'font-awesome';
  position: absolute;
  line-height: 55px;
  top:0;
  right: 30px;
}
.service-details-page .service-sidebar .broucher-download h4 {
  font-size: 24px;
  font-weight: 700;
  margin: 63px 0 12px 0;
}
.service-details-page .service-sidebar .broucher-download p {
  font-size: 17px;
  line-height: 28px;
}
.service-details-page .service-sidebar .broucher-download a {
  font-weight: 500;
  color:#76808a;
  display: block;
  padding: 0 0 0 25px;
  line-height: 65px;
  background: #f5f5f5;
  border:1px solid #f0efef;
  position: relative;
  margin-top: 18px;
  margin-bottom: 35px;
}
.service-details-page .service-sidebar .broucher-download a i {
  margin-right: 10px;
}
.service-details-page .service-sidebar .broucher-download a:hover {
  color:#262626;
  background: #fff;
  border-color:#fac800;
}
.sidebar-contact-box {
  border:1px solid #f0efef;
  text-align: center;
  padding: 15px 0 33px 0;
}
.sidebar-contact-box p {
  line-height: 30px;
  font-size: 20px;
}
.sidebar-contact-box b {
  font-weight: 500;
  font-size: 24px;
  color:#262626;
  display: block;
  margin: 2px 0 4px 0;
}
.service-details-page {
  margin-bottom: 48px;
}
.service-details-page .service-details-content {
  width: 76%;
  padding-left: 55px;
}
.service-details-page .service-details-content .img-wrapper {
  margin: 0 -3px 50px -3px;
}
.service-details-page .service-details-content .img-wrapper .img {
  width: 50%;
  padding: 0 3px;
}
.service-details-page .service-details-content .work-strategy {
  margin-top: 55px;
  border-bottom: 1px solid #eaeaea;
  padding-bottom: 65px;
  margin-bottom: 47px;
}
.service-details-page .service-details-content .work-strategy img {
  width: 34%;
}
.service-details-page .service-details-content .work-strategy .text {
  width: 66%;
  padding-left: 47px;
}
.service-details-page .service-details-content .work-strategy .text h4 {
  font-size: 24px;
  font-weight: 700;
  text-transform: uppercase;
  margin-bottom: 20px;
}
.service-details-page .service-details-content .work-progress h4 {
  font-size: 24px;
  font-weight: 700;
  text-transform: uppercase;
}
.service-details-page .service-details-content .work-progress>p {
  font-style: italic;
  font-size: 20px;
  margin: 20px 0 50px 0;
}
.service-details-page .service-details-content .work-progress .panel-group {
  border:none;
  border-radius: 0;
  background: #f5f5f5;
}
.service-details-page .service-details-content .work-progress .panel-group .panel {
  border-radius: 0;
  background: transparent;
  margin: 0;
  box-shadow: none;
  border-bottom: 1px solid #e9e9e9;
}
.service-details-page .service-details-content .work-progress .panel-group .panel-heading {
  padding: 0;
}
.service-details-page .service-details-content .work-progress .panel-group .panel-heading a {
  font-size: 20px;
  font-weight: 500;
  color:#262626;
  display: block;
  padding: 24px 65px 24px 30px;
  position: relative;
}
.service-details-page .service-details-content .work-progress .panel-group .panel-heading a:before {
  content: '+';
  width: 30px;
  height: 30px;
  line-height: 30px;
  text-align: center;
  background: #fff;
  color:#7e7e7e;
  font-weight: normal;
  font-size: 24px;
  position: absolute;
  top:50%;
  right: 30px;
  margin-top: -15px;
}
.service-details-page .service-details-content .work-progress .panel-group .panel-heading.active-panel a:before {
  content: '-';
  background: #1f54a3;
  color:#fff;
}
.service-details-page .service-details-content .work-progress .panel-group .panel-body p {
  line-height: 32px;
}
.service-details-page .service-details-content .work-progress .panel-group .panel-body {
  border:none;
  padding: 0 30px 25px 30px;
}
/*====================== Blog Page ====================*/
.theme-sidebar {
  width: 27.40%;
}
.theme-sidebar form {
  height: 60px;
  position: relative;
  margin-bottom: 58px;
}
.theme-sidebar form input {
  width: 100%;
  height: 100%;
  border: 1px solid #eaeaea;
  padding: 0 67px 0 25px;
  font-size: 17px;
  font-weight: 300;
}
.theme-sidebar form button {
  height: 100%;
  width: 65px;
  position: absolute;
  top:0;
  right: 0;
  background: #262626;
  color:#fff;
}
.theme-sidebar h4 {
  font-size: 30px;
  font-weight: 500;
  margin-bottom: 13px;
}
.theme-sidebar .sidebar-category ul li a {
  display: block;
  font-weight: 300;
  font-size: 17px;
  color: #8d8d8d;
  line-height: 60px;
  border-bottom: 1px solid #eaeaea;
}
.theme-sidebar .sidebar-category ul li a:hover,
.theme-sidebar .sidebar-category ul li.active a {
  font-weight: 500;
  color:#25292f;
}
.theme-sidebar .sidebar-category ul li a i {
  margin-right: 15px;
}
.theme-sidebar .sidebar-recentNews {
  margin: 55px 0 65px 0;
}
.theme-sidebar .sidebar-recentNews .single-post .text {
  padding-left: 25px;
  width: 75%;
}
.theme-sidebar .sidebar-recentNews .single-post .text a {
  display: block;
  font-weight: 500;
  color: #25292f;
  line-height: 26px;
  font-size: 17px;
  margin: -6px 0 2px 0;
}
.theme-sidebar .sidebar-recentNews .single-post .text i {
  font-size: 16px;
}
.theme-sidebar .sidebar-recentNews .single-post {
  margin-top: 30px;
}
.theme-sidebar .sidebar-latest-item .single-post .text b {
  font-size: 24px;
  font-weight: 700;
  display: block;
  margin:-1px 0 -2px 0;
}
.theme-sidebar .sidebar-latest-item .single-post .text ul li {
  display: inline-block;
}
.theme-sidebar .sidebar-latest-item .single-post .text ul li i {
  font-size: 14px;
}
.theme-sidebar .sidebar-latest-item .single-post .text ul li:last-child {
  color:#dadada;
}
.theme-sidebar .sidebar-keyword ul li {
  display: inline-block;
  margin: 12px 5px 0 0;
}
.theme-sidebar .sidebar-keyword ul li a {
  font-weight: 300;
  font-size: 16px;
  color:#9e9e9e;
  line-height: 36px;
  border: 1px solid #eaeaea;
  padding: 0 15px;
}
.theme-sidebar .sidebar-keyword ul li a:hover {
  color:#2c2c2c;
  border-color: #fac800;
}
.theme-sidebar .sidebar-keyword {
  margin-bottom: 65px;
}
.theme-large-grid {
  width: 72.60%;
  padding-right: 99px;
}
.single-blog-page .blog-post-container .single-blog-post {
  margin-bottom: 70px;
}
.single-blog-page .blog-post-container .single-blog-post .img {
  background: #000;
  overflow: hidden;
  margin-bottom: 20px;
}
.single-blog-page .blog-post-container .single-blog-post .img img {
  -webkit-transition: all .5s ease-in-out;
     -moz-transition: all .5s ease-in-out;
      -ms-transition: all .5s ease-in-out;
       -o-transition: all .5s ease-in-out;
          transition: all .5s ease-in-out;
}
.single-blog-page .blog-post-container .single-blog-post:hover .img img {
  opacity: 0.4;
  -webkit-transform: scale3D(1.1,1.1,1);
     -moz-transform: scale3D(1.1,1.1,1);
      -ms-transform: scale3D(1.1,1.1,1);
       -o-transform: scale3D(1.1,1.1,1);
          transform: scale3D(1.1,1.1,1);
}
.single-blog-page .blog-post-container .single-blog-post .post-text ul li {
  display: inline-block;
  font-weight: 300;
  color:#b5b4b1;
  margin-top: 15px;
}
.single-blog-page .blog-post-container .single-blog-post .post-text ul li span {
  font-weight: 500;
}
.single-blog-page .blog-post-container .single-blog-post .post-text h4 a {
  font-weight: normal;
  font-size: 28px;
  color:#25292f;
  display: block;
  margin: 12px 0 26px 0;
}
.single-blog-page .blog-post-container .single-blog-post .post-text>a {
  width: 125px;
  line-height: 45px;
  text-align: center;
  font-size: 15px;
  text-transform: uppercase;
  color: #25292f;
  border: 1px solid #eaeaea;
  margin-top: 25px;
}
.single-blog-page .blog-post-container .single-blog-post .post-text>a:hover {
  color:#fff;
}
.single-blog-page .blog-post-container .more-page-button ul li {
  display: inline-block;
}
.single-blog-page .blog-post-container .more-page-button ul li a {
  line-height: 35px;
  background: #eaeaea;
  font-size: 17px;
  font-weight: 500;
  color:#282828;
  padding: 0 13px;
}
.single-blog-page .blog-post-container .more-page-button {
  margin: -10px 0 0 0;
}
.single-blog-page {
  margin-bottom: 165px;
}

/*======================== Blog Details Page =================*/
.blog-details-page {
  margin-bottom: 125px;
}
.blog-details-page .post-meta-content> img {
  margin-bottom: 20px;
}
.blog-details-page .post-meta-content> ul li {
  display: inline-block;
  font-weight: 300;
  color:#b5b4b1;
  margin-top: 15px;
}
.blog-details-page .post-meta-content> ul li span {
  font-weight: 500;
}
.blog-details-page .post-meta-content> h4 {
  font-weight: normal;
  font-size: 28px;
  color:#25292f;
  display: block;
  margin: 12px 0 26px 0;
}
.blog-details-page .post-meta-content .share-option {
  border-bottom: 1px solid #efefef;
  padding: 50px 0 12px 0;
  margin-bottom: 75px;
}
.blog-details-page .post-meta-content .share-option p {
  font-weight: 500;
  color:#7b7b7b;
}
.blog-details-page .post-meta-content .share-option ul li {
  display: inline-block;
  margin-left: 12px;
  font-weight: 500;
  color:#25292f;
  line-height: 30px;
}
.blog-details-page .post-meta-content .share-option ul li a {
  color:#696969;
  font-size: 16px;
}
.blog-details-page .post-meta-content h5 {
  font-weight: 500;
  font-size: 36px;
  margin-bottom: 33px;
}
.blog-details-page .post-meta-content .comment-box-wrapper {
  border:1px solid #efefef;
  padding: 25px 30px 20px 30px;
  margin-bottom: 65px;
}
.blog-details-page .post-meta-content .comment-box-wrapper .comment {
  padding-left: 22px;
  width: 86%;
  position: relative;
}
.blog-details-page .post-meta-content .comment-box-wrapper .comment button {
  width: 65px;
  line-height: 30px;
  color:#fff;
  font-weight: 700;
  font-size: 14px;
  text-transform: uppercase;
  background: #262626;
  position: absolute;
  top:0;
  right: 0;
}
.blog-details-page .post-meta-content .comment-box-wrapper .comment h6 {
  font-size: 18px;
  font-weight: 500;
  margin-bottom: 3px;
}
.blog-details-page .post-meta-content .comment-box-wrapper .comment span {
  font-size: 17px;
  font-weight: 300;
  color:#b6b6b6;
}
.blog-details-page .post-meta-content .comment-box-wrapper .comment p {
  margin-top: 13px;
  color:#8d8d8d;
}
.blog-details-page .post-meta-content .comment-box-wrapper .reply-comment {
  border-top:1px solid #efefef;
  padding-top: 25px;
  margin: 20px 0 0 103px;
}
.blog-details-page .post-meta-content .leave-reply form {
  background: #f7f7f7;
  border:1px solid #f2f2f2;
  padding: 35px 30px 35px 30px;
}
.blog-details-page .post-meta-content .leave-reply form .row {
  margin-left: -12px;
  margin-right: -12px;
}
.blog-details-page .post-meta-content .leave-reply form .row [class*="col-"] {
  padding-left: 12px;
  padding-right: 12px;
}
.blog-details-page .post-meta-content .leave-reply form input,
.blog-details-page .post-meta-content .leave-reply form textarea {
  width: 100%;
  background: #fff;
  border:1px solid transparent;
  padding: 0 15px;
  margin-bottom: 15px;
  font-size: 17px;
  font-weight: 300;
}
.blog-details-page .post-meta-content .leave-reply form input {
  height: 55px;
}
.blog-details-page .post-meta-content .leave-reply form textarea {
  max-width: 100%;
  min-height: 195px;
  padding: 20px 15px;
}
.blog-details-page .post-meta-content .leave-reply form button {
  width: 160px;
  line-height: 50px;
  color:#fff;
  font-weight: 500;
  font-size: 17px;
}
.blog-details-page .post-meta-content .leave-reply form input:focus,
.blog-details-page .post-meta-content .leave-reply form textarea:focus {
  border-color:#fac800;
}
/*===================== Shop Page ===============*/
.shop-item-wrapper .dropdown button {
  width: 200px;
  line-height: 40px;
  padding: 0 15px;
  border: 1px solid #efefef;
  font-size: 16px;
  font-weight: 300;
  background: #fff;
  text-align: left;
}
.shop-item-wrapper .dropdown button .fa {
  float:right;
  line-height: 40px;
  font-size: 18px;
}
.shop-item-wrapper .dropdown .dropdown-menu {
  width: 100%;
  border: 1px solid #efefef;
  border-top:none;
}
.shop-item-wrapper .dropdown .dropdown-menu li {
  line-height: 30px;
  padding: 0 15px;
  cursor: pointer;
}
.shop-item-wrapper .row {
  margin:40px -29px 0 -29px;
}
.shop-item-wrapper .single-item {
  padding-left: 29px;
  padding-right: 29px;
  width: 50%;
  margin-bottom: 55px;
}
.shop-item-wrapper .single-item>div {
  position: relative;
}
.shop-item-wrapper .single-item .img {
  background: #f7f7f7;
  padding: 20px 0;
  text-align: center;
}
.shop-item-wrapper .single-item .img img {
  width: 185px;
  height: 276px;
  -webkit-box-shadow: 0px 2px 3px -1px rgba(0,0,0,0.25);
  -moz-box-shadow: 0px 2px 3px -1px rgba(0,0,0,0.25);
  box-shadow: 0px 2px 3px -1px rgba(0,0,0,0.25);
}
.shop-item-wrapper .single-item>div>a.item-name {
  font-weight: normal;
  font-size: 24px;
  color:#25292f;
  display: block;
  margin: 24px 0 0 0;
}
.shop-item-wrapper .single-item>div>span {
  font-weight: 300;
  color:#bababa;
  display: block;
}
.shop-item-wrapper .single-item>div>span b {
  font-weight: 500;
  font-size: 30px;
  vertical-align: middle;
}
.shop-item-wrapper .single-item>div> ul li {
  display: inline-block;
  font-size: 15px;
}
.shop-item-wrapper .single-item>div> ul li:last-child {
  color:#dadada;
}
.shop-item-wrapper .single-item a.add-cart {
  width: 120px;
  line-height: 40px;
  text-align: center;
  border: 1px solid #efefef;
  font-size: 14px;
  font-weight: 300;
  color:#25292f;
  text-transform: uppercase;
  position: absolute;
  bottom: 0;
  right: 0;
}
.shop-item-wrapper .single-item a.add-cart:hover {
  color:#fff;
}
.shop-item-wrapper .more-page-button ul li {
  display: inline-block;
}
.shop-item-wrapper .more-page-button ul li a {
  line-height: 35px;
  background: #202020;
  font-size: 17px;
  font-weight: 500;
  color:#fff;
  padding: 0 13px;
}
.shop-page {
  margin-bottom: 125px;
}
/*====================== Shop Details ====================*/
.shop-details-page {
  margin-bottom: 136px;
}
.shop-details-wrapper .product-history .img {
  width: 46.65%;
  background: #f7f7f7;
  padding: 20px 0;
  text-align: center;
}
.shop-details-wrapper .product-history .img img {
  margin: 0 auto;
}
.shop-details-wrapper .product-history .product-info {
  width: 53.35%;
  padding-left: 32px;
}
.shop-details-wrapper .product-history .product-info h4 {
  font-size: 24px;
  font-weight: 500;
  margin: -3px 0 14px 0;
}
.shop-details-wrapper .product-history .product-info ul li {
  display: inline-block;
  font-size: 15px;
  color:#8d8d8d;
}
.shop-details-wrapper .product-history .product-info ul li:nth-child(5) .fa {
  color:#dadada;
}
.shop-details-wrapper .product-history .product-info ul li:last-child {
  font-size: 17px;
  font-weight: 300;
  vertical-align: middle;
  margin-left: 10px;
}
.shop-details-wrapper .product-history .product-info b {
  display: block;
  font-weight: 500;
  font-size: 36px;
  margin: 4px 0 10px 0;
}
.shop-details-wrapper .product-history .product-info p {
  margin-bottom: 26px;
}
.shop-details-wrapper .product-history .product-info button {
  display: inline-block;
  width: 136px;
  line-height: 45px;
  font-size: 14px;
  color:#fff;
  margin-left: 10px;
}
.shop-details-wrapper .product-history .product-info input[type="number"] {
  width: 46px;
  height: 46px;
  background: #fff;
  border: 2px solid #efefef;
  text-align: right;
  padding-right: 5px;
  vertical-align: middle;
}
.shop-details-wrapper .product-history .product-info>span {
  font-size: 17px;
  font-weight: 300;
  color:#59c23d;
  display: block;
  margin-top: 13px;
}
.shop-details-wrapper .product-tab {
  margin-top: 78px;
}
.shop-details-wrapper .product-tab .nav-tabs > li > a {
  line-height: 47px;
  font-size: 15px;
  font-weight: 700;
  color:#3f3e3e;
  border-radius: 0;
  padding: 0 31px;
  border:1px solid #efefef;
  border-bottom-color: #fff;
  margin: 0;
  background: #f4f4f4;
}
.shop-details-wrapper .product-tab .nav-tabs > li.active > a,
.shop-details-wrapper .product-tab .nav-tabs > li.active > a:hover, 
.shop-details-wrapper .product-tab .nav-tabs > li.active > a:focus {
  background: transparent;
}
.shop-details-wrapper .product-tab .nav-tabs {
  border-color:#efefef;
}
.shop-details-wrapper .product-tab .tab-content h5 {
  font-size: 24px;
  font-weight: normal;
  margin: 0 0 12px 0;
}
.shop-details-wrapper .product-tab .tab-content {
  padding-top: 28px;
}
.shop-details-wrapper .related-product h4 {
  font-weight: 500;
  font-size: 30px;
  margin: 55px 0 30px 0;
}
.shop-details-wrapper .related-product .item .img {
  background: #f7f7f7;
  padding: 15px 0;
  text-align: center;
}
.shop-details-wrapper .related-product .item .img img {
  margin: 0 auto;
}
.shop-details-wrapper .related-product .item a.item-name {
  font-weight: normal;
  font-size: 22px;
  color:#25292f;
  display: block;
  margin: 17px 0 0 0;
}
.shop-details-wrapper .related-product .item span {
  font-weight: 300;
  color:#bababa;
  display: block;
}
.shop-details-wrapper .related-product .item span b {
  font-weight: 500;
  font-size: 30px;
  vertical-align: middle;
}
.shop-details-wrapper .related-product .item ul {
  margin-top: 10px;
}
.shop-details-wrapper .related-product .item ul li {
  display: inline-block;
  font-size: 12px;
}
.shop-details-wrapper .related-product .item:last-child {
  color:#dadada;
}
.shop-details-wrapper .related-product .item a.add-cart {
  width: 120px;
  line-height: 40px;
  text-align: center;
  border: 1px solid #efefef;
  font-size: 14px;
  font-weight: 300;
  color:#25292f;
  text-transform: uppercase;
  margin-top: 12px;
}
.shop-details-wrapper .related-product .item a.add-cart:hover {
  color:#fff;
}
.shop-details-wrapper .related-product .item {
  margin-right: 15px;
  margin-left: 15px;
}
.shop-details-wrapper .related-product .owl-carousel .owl-controls {
  top:-60px;
}
.shop-details-wrapper .related-product .owl-theme .owl-nav [class*=owl-] {
  border:1px solid #efefef;
}
.shop-details-wrapper .related-product .owl-theme .owl-nav [class*=owl-]:hover {
  background: #262626;
  color:#fff;
  border-color:#262626;
}
/*================== Contact Us ================*/
#google-map-area {
  height: 450px;
  margin-bottom: 80px;
}
#contact-google-map {
  width: 100%;
  height: 100%;
}
.contactUs-address h4 {
  font-size: 36px;
  line-height: 45px;
  margin-bottom: 35px;
}
.contactUs-address {
  padding-left: 38px;
}
.contactUs-address>p {
  margin:-7px 0 30px 0;
}
.contactUs-address .single_address .icon .ficon:before {
  color:#e3e3e3;
  line-height: 60px;
  font-size: 37px;
}
.contactUs-address .single_address h6 {
  font-weight: 500;
  font-size: 18px;
  text-transform: uppercase;
  margin-bottom: 5px;
}
.contactUs-address .single_address span {
  font-weight: 300;
}
.contactUs-address .single_address {
  margin-bottom: 35px;
}
.contactUs-address .single_address .text {
  padding-left: 26px;
  margin-top: 10px;
}
.contact-us-page {
  margin-bottom: 145px;
}
/*(((((((((((((((((((((((  Contact form activation ))))))))))))))))))*/
.contact-us-form .alert_wrapper {
  display: none;
  position: fixed;
  width: 100%;
  height:100%;
  background: rgba(255,255,255,0.7);
  top: 0;
  left: 0;
  z-index: 9999999;
}
.contact-us-form #success,
.contact-us-form #error {
  position: relative;
  width:500px;
  height: 100px;
  top: 50%;
  margin-top: -50px;
  margin-left: -250px;
  left:50%;
  background: #fff;
  border:1px solid #ffb504;
  text-align: center;
}
.contact-us-form #success .wrapper,
.contact-us-form #error .wrapper {
  display: table;
  width:100%;
  height: 100%;
}
.contact-us-form #success .wrapper p,
.contact-us-form #error .wrapper p{
  display: table-cell;
  vertical-align: middle;
}
.contact-us-form #success {
  color: #ffb504;
}
.contact-us-form #error {
  color: red;
}
.contact-us-form #error button,
.contact-us-form #success button {
  color:#fff;
  width:40px;
  height:40px;
  line-height: 20px;
  background: #ffb504;
  border-radius: 50%;
  position: absolute;
  top: -20px;
  right: -20px;
  font-size: 25px;
}
.form-validation label.error {
  display: none !important;
}
.form-validation input.error,
.form-validation textarea.error {
  border:1px solid #f03838 !important;
}


/* ===== ABOUT: two images like old site ===== */
.about-company.about-us-page-fix .img-wrapper.two-up .single-img {
  width: 50%;
  padding: 0 5px;
  box-sizing: border-box;
  position: relative;
}
.about-company.about-us-page-fix .img-wrapper.two-up .single-img img {
  display: block;
  width: 100%;
  height: 420px;  /* same height as old site */
  height: 380px;
  object-fit: cover;
  margin: 0;
}

/* gold SVG positions */

.about-company .deco{ position:absolute; pointer-events:none; }
.about-company .deco-a{ top:-40px; left:-30px; z-index:2; }
.about-company .deco-b{ bottom:-40px; left:-30px; opacity:.21; }
.about-company .deco-c{ top:-80px; right:-20px; z-index:2; }

/* responsive fix */
@media (max-width: 991px) {
  .about-company.about-us-page-fix .img-wrapper.two-up .single-img { width: 100%; padding: 0 0 10px; }
  .about-company.about-us-page-fix .img-wrapper.two-up .single-img img { height: auto; }
  .about-company .deco { display: none; }
}


/* Force a clean 2-up row (no floats), equal height, aligned at the top */
.about-company.about-us-page-fix .img-wrapper.two-up{
  display:flex;
  align-items:flex-start;
  gap:10px;                 /* space between the photos */
}
.about-company.about-us-page-fix .img-wrapper.two-up .single-img{
  float:none;               /* cancel old floats */
  width:50%;
  box-sizing:border-box;
  position:relative;        /* for SVGs */
}
.about-company.about-us-page-fix .img-wrapper.two-up .single-img img{
  display:block;
  width:100%;
  height:420px;             /* same as old site; change to 380–400 if you want smaller */
  object-fit:cover;
  margin:0;
}
/* ===== Animated photo cards ===== */
.about-company.about-us-page-fix .img-wrapper.two-up {
  display: flex;
  gap: 12px;
  align-items: flex-start;
}

.about-company.about-us-page-fix .img-wrapper.two-up .single-img {
  position: relative;
  width: 50%;
  height: 420px;
  overflow: hidden;
  border: 3px solid #dbb351;   /* gold border */
  border-radius: 14px;         /* rounded corners */
  box-sizing: border-box;      /* stable layout */
  box-shadow: 0 10px 22px rgba(0,0,0,.08);
  isolation: isolate;
  transform: translateY(6px);
  animation: fadeUp .8s ease-out both;
}


.about-company.about-us-page-fix .img-wrapper.two-up .single-img img {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: translate(-50%, -50%) scale(1);
  transition: transform .6s ease, filter .6s ease, opacity .4s ease;
}


/* Subtle grain/lines overlay */
.about-company.about-us-page-fix .img-wrapper.two-up .single-img::before{
  content:"";
  position:absolute; inset:0;
  background:
    linear-gradient(135deg, rgba(219,179,81,.18) 0%, rgba(219,179,81,0) 40%),
    repeating-linear-gradient( 90deg, rgba(255,255,255,.08) 0 2px, rgba(255,255,255,0) 2px 4px);
  mix-blend-mode: soft-light;
  pointer-events:none;
  opacity:.6;
  transition: opacity .4s ease;
}

/* Gold shine sweep */
.about-company.about-us-page-fix .img-wrapper.two-up .single-img::after{
  content:"";
  position:absolute; top:0; left:-120%;
  width:60%; height:100%;
  background: linear-gradient(105deg, rgba(255,255,255,0) 10%, rgba(219,179,81,.35) 45%, rgba(255,255,255,0) 90%);
  transform: skewX(-12deg);
  filter: blur(1px);
  pointer-events:none;
  transition: left .9s ease;
}

/* Hover */
.about-company.about-us-page-fix .img-wrapper.two-up .single-img:hover img {
  transform: translate(-50%, -50%) scale(1.1);
  filter: saturate(1.06) contrast(1.03);
}

.about-company.about-us-page-fix .img-wrapper.two-up .single-img:hover::after{
  left: 120%;
}
.about-company.about-us-page-fix .img-wrapper.two-up .single-img:hover::before{
  opacity:.8;
}

/* Floating gold shapes */
.about-company .deco { animation: bob 6s ease-in-out infinite alternate; }
.about-company .deco-a { animation-delay: .2s; }
.about-company .deco-b { animation-delay: .5s; }
.about-company .deco-c { animation-delay: .1s; }

/* Keyframes */
@keyframes fadeUp{
  from{ opacity:0; transform: translateY(24px); }
  to{ opacity:1; transform: translateY(6px); }
}
@keyframes bob{
  from{ transform: translateY(0) }
  to{   transform: translateY(-8px) }
}

/* Responsive */
@media (max-width: 991px){
  .about-company.about-us-page-fix .img-wrapper.two-up{ display:block; }
  .about-company.about-us-page-fix .img-wrapper.two-up .single-img{ width:100%; margin-bottom:12px; transform:none; }
  .about-company.about-us-page-fix .img-wrapper.two-up .single-img img{ height:auto; }
  .about-company .deco{ display:none; }
}
/* Add border to About Us images */
.about-company.about-us-page-fix .img-wrapper.two-up .single-img{
  border: 3px solid #dbb351;   /* gold border */
  border-radius: 14px;         /* rounded corners */
  box-sizing: border-box;      /* keeps layout stable */
}




/* === Our Valued Companies Section === */


.client-companies {
  padding: 50px 0 60px 0;
  background: #fff;
}

.client-companies .theme-title-style {
  margin-bottom: 80px;  /* spacing below heading */
  display: inline-block;
  position: relative;
}

/* Company Cards */
.company-card {
  background: #fff;
  border: 1px solid #eee;
  border-radius: 8px;
  padding: 25px 20px;
  text-align: center;
  min-height: 280px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.company-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 6px 20px rgba(50, 126, 233, 0.08);
}
.company-card h3 {
  font-size: 18px;
  font-weight: 600;
  margin-bottom: 12px;
  color: #333;
}
.company-card p {
  font-size: 14px;
  color: #555;
  flex-grow: 1;
}
.company-btn {
  display: inline-block;
  margin-top: 15px;
  padding: 10px 25px;
  background: #fac800;
  color: #fff;
  font-size: 14px;
  border-radius: 25px;
  transition: background 0.3s ease;
}
.company-btn:hover {
  background: #d4a80c;
  text-decoration: none;
}

/* Hide arrows */
.client-companies .owl-nav {
  display: none !important;
}

/* === Companies Slider Dots === */
.companies-dots {
  width: 100%;
  text-align: center;
  margin-top: -66px;  /* space below cards */
  padding: 56px;
}

.companies-dots .owl-dot {
  display: inline-block;
}

.companies-dots .owl-dot span {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: #ddd;   /* inactive gray */
  margin: 0 6px;
  display: inline-block;
  transition: all 0.3s ease;
}

.companies-dots .owl-dot.active span {
  background: #fac800; /* active yellow */
}
/* Company card images */
.company-card .company-img {
  margin-bottom: 15px;
}

.company-card .company-img img {
  max-width: 210px;   /* small size */
  max-height: 210px;
  object-fit: contain;
  margin: 0 auto;
  display: block;
}



/*service side bar trading*/
/* Sidebar Services Box */
.sidebar-services-box {
  background: linear-gradient(135deg, #ffffff, #f9f9f9);
  border: 1px solid #e5e5e5;
  padding: 22px 20px;
  margin-bottom: 25px;
  border-radius: 12px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.05);
}

.sidebar-services-box h4 {
  font-size: 20px;
  margin-bottom: 18px;
  color: #d4af37; /* theme gold */
  font-weight: 700;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  border-bottom: 2px solid #d4af37;
  display: inline-block;
  padding-bottom: 5px;
}

/* Services List */
.services-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.services-list li {
  padding: 12px 14px;
  margin-bottom: 10px;
  border: 1px solid #eee;
  border-radius: 8px;
  background: #fff;
  font-size: 15px;
  font-weight: 500;
  color: #333;
  display: flex;
  align-items: center;
  gap: 10px;
  transition: all 0.3s ease;
  cursor: pointer;
  box-shadow: 0 2px 6px rgba(0,0,0,0.03);
}

/* Add modern bullet/icon */
.services-list li::before {
  content: "➤";
  color: #d4af37;
  font-size: 14px;
  transition: color 0.3s ease;
}

/* Remove last gap */
.services-list li:last-child {
  margin-bottom: 0;
}

/* Hover Effect */
.services-list li:hover {
  background: #d4af37;
  color: #fff;
  border-color: #d4af37;
  box-shadow: 0 4px 12px rgba(212,175,55,0.3);
  transform: scale(1.03);
}

.services-list li:hover::before {
  color: #fff;
}


/* Push the services box down */
.sidebar-services-box {
  margin-top: 53px;   /* moves the whole box lower */
}





/* Responsive fix for inner-banner heading */
.inner-banner .opacity h2 {
  font-size: 60px;
  font-weight: 900;
  color: #fff;
  text-transform: uppercase;
  word-wrap: break-word;   /* ensures long words break if needed */
  text-align: center;
}

/* Tablet screens */
@media (max-width: 991px) {
  .inner-banner .opacity h2 {
    font-size: 42px;
    line-height: 52px;
  }
}

/* Mobile screens */
@media (max-width: 600px) {
  .inner-banner .opacity h2 {
    font-size: 30px;
    line-height: 40px;
    padding: 0 10px; /* small side padding so it doesn't touch screen edges */
  }
}



/* ===== FINAL HERO REPLACEMENT (no blue wave, no square) ===== */

/* scope everything under #techno-hero to avoid conflicts */
#techno-hero {
  display: flex !important;
  gap: 56px !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  max-width: 1200px !important;
  margin: 48px auto !important;
  padding: 0 20px !important;
  box-sizing: border-box !important;
  font-family: inherit !important;
}

/* left column */
#techno-hero .hero-left-col {
  flex: 1 1 52% !important;
  min-width: 320px !important;
  position: relative !important;
}

/* main image frame */
#techno-hero .hero-image-frame {
  position: relative !important;
  width: 100% !important;
  min-height: 480px !important;
  border-radius: 12px !important;
  overflow: hidden !important;
  background-size: cover !important;
  background-position: center center !important;
  box-shadow: 0 22px 56px rgba(6,18,40,0.12) !important;
  border: 1px solid rgba(11,24,40,0.04) !important;
  z-index: 3 !important;
  transition: transform .45s ease !important;
}
#techno-hero .hero-image-frame:hover { transform: translateY(-6px) !important; }

/* remove any old square-ish overlays by forcing no extra pseudo elements
   (if your previous stylesheet added a ::before/::after for .decor-shape, this cancels them) */
#techno-hero .decor-shape,
#techno-hero .decor-shape * { display: none !important; visibility: hidden !important; }

/* border-decor corner SVG overlay */
#techno-hero .border-decor.corner {
  position: absolute !important;
  inset: 0 !important;
  z-index: 2 !important;
  pointer-events: none !important;
}
#techno-hero .border-decor.corner svg {
  width: 100% !important;
  height: 100% !important;
  display: block !important;
}

/* SVG accent stroke colors and very subtle animation */
#techno-hero .border-decor.corner .accent-top-left {
  stroke: rgba(201,147,47,0.55);
  stroke-width: 6;
  stroke-linecap: round;
  stroke-linejoin: round;
  fill: none;
  stroke-dasharray: 180;
  stroke-dashoffset: 180;
  animation: dashIn 2.2s ease forwards;
}
#techno-hero .border-decor.corner .accent-bottom-right {
  stroke: rgba(30,107,244,0.45);
  stroke-width: 6;
  stroke-linecap: round;
  stroke-linejoin: round;
  fill: none;
  stroke-dasharray: 180;
  stroke-dashoffset: 180;
  animation: dashIn 2.6s ease 0.15s forwards;
}

@keyframes dashIn {
  to { stroke-dashoffset: 0; }
}

/* inset-thumb cleaned (NO white border that caused that square) */
#techno-hero .inset-thumb {
  position: absolute !important;
  left: 20px !important;
  bottom: 20px !important;
  width: 160px !important;
  height: 96px !important;
  border-radius: 8px !important;
  overflow: hidden !important;
  background-size: cover !important;
  background-position: center !important;
  border: none !important; /* remove white border */
  box-shadow: 0 14px 36px rgba(6,18,40,0.12) !important;
  z-index: 5 !important;
}

/* centered logo card */
#techno-hero .logo-card {
  position: absolute !important;
  left: 50% !important;
  bottom: 28px !important;
  transform: translateX(-50%) !important;
  width: 48% !important;
  min-width: 220px !important;
  max-width: 380px !important;
  padding: 14px 18px !important;
  border-radius: 12px !important;
  background: linear-gradient(180deg,#fff,#fbfdff) !important;
  box-shadow: 0 16px 40px rgba(6,18,40,0.14) !important;
  z-index: 6 !important;
}
#techno-hero .logo-card img { max-width: 100% !important; height: auto !important; display: block !important; }

/* RIGHT: text column (keeps your original classes) */
#techno-hero .hero-right-col,
#techno-hero .column.column-1-2 {
  flex: 1 1 44% !important;
  min-width: 300px !important;
  padding-top: 6px !important;
}

/* eyebrow, title, paragraphs */
#techno-hero label.box-header {
  display:block !important;
  color: #c9932f !important;
  font-weight: 700 !important;
  letter-spacing: 0.06em !important;
  margin-bottom: 12px !important;
  font-size: 13px !important;
}
#techno-hero h2.box-header {
  font-size: 34px !important;
  line-height: 1.06 !important;
  margin: 0 0 16px 0 !important;
  font-weight: 800 !important;
  color: #0e1b2b !important;
}
#techno-hero h5 {
  font-size: 16px !important;
  line-height: 1.78 !important;
  color: #444 !important;
  margin: 0 !important;
  font-weight: 400 !important;
}

/* responsive */
@media (max-width:1100px) {
  #techno-hero { gap: 40px !important; margin: 36px auto !important; }
  #techno-hero .hero-image-frame { min-height: 420px !important; }
  #techno-hero h2.box-header { font-size: 30px !important; }
  #techno-hero .logo-card { width: 64% !important; }
}
@media (max-width:900px) {
  #techno-hero { flex-direction: column !important; gap: 28px !important; margin: 28px auto !important; }
  #techno-hero .hero-left-col, #techno-hero .hero-right-col, #techno-hero .column.column-1-2 { flex:1 1 100% !important; min-width:100% !important; }
  #techno-hero .logo-card { position: static !important; transform:none !important; margin: -48px auto 0 !important; width: 68% !important; }
  #techno-hero .inset-thumb { left: 14px !important; top: 18% !important; bottom: auto !important; }
}

/* safety */
#techno-hero * { box-sizing: border-box !important; }






/* ===== Techno serve Container ===== */
#techno-hero {
  display: flex;
  gap: 56px;
  align-items: flex-start;
  justify-content: space-between;
  max-width: 1200px;
  margin: 48px auto;
  padding: 0 20px;
}

/* Left column */
.hero-left-col {
  flex: 1 1 52%;
  min-width: 320px;
  position: relative;
}

/* Main image frame */
.hero-image-frame {
  position: relative;
  width: 100%;
  min-height: 480px;
  border-radius: 12px;
  overflow: hidden;
  background-size: cover;
  background-position: center;
  box-shadow: 0 22px 56px rgba(6,18,40,0.12);
  z-index: 1;
}

/* Inset thumbnail */
.inset-thumb {
  position: absolute;
  left: 20px;
  bottom: 20px;
  width: 160px;
  height: 96px;
  border-radius: 8px;
  overflow: hidden;
  background-size: cover;
  background-position: center;
  box-shadow: 0 14px 36px rgba(6,18,40,0.12);
  z-index: 2;
}

/* Logo card */
.logo-card {
  position: absolute;
  left: 50%;
  bottom: 28px;
  transform: translateX(-50%);
  width: 48%;
  min-width: 220px;
  max-width: 380px;
  padding: 14px 18px;
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 16px 40px rgba(6,18,40,0.14);
  z-index: 3;
  text-align: center;
}
.logo-card img { max-width: 100%; height: auto; }

/* ===== Orbiting Corner Lines ===== */
.corner-line {
  position: absolute;
  width: 60px;
  height: 4px;
  background: #c9932f; /* yellow */
  border-radius: 2px;
  opacity: 0;
  z-index: 0;
  animation: orbit 6s linear infinite;
}

/* Four lines positioned initially at corners */
.line1 { top: -20px; left: -20px; }
.line2 { top: -20px; right: -20px; animation-delay: 1.5s; }
.line3 { bottom: -20px; right: -20px; animation-delay: 3s; }
.line4 { bottom: -20px; left: -20px; animation-delay: 4.5s; }

/* Orbit animation: fade + circular movement */
@keyframes orbit {
  0%   { opacity: 0; transform: translate(0,0) rotate(0deg); }
  10%  { opacity: 1; }
  25%  { transform: translate(40px,0) rotate(90deg); opacity: 0.8; }
  50%  { transform: translate(40px,40px) rotate(180deg); opacity: 0.6; }
  75%  { transform: translate(0,40px) rotate(270deg); opacity: 0.4; }
  90%  { opacity: 0; }
  100% { transform: translate(0,0) rotate(360deg); opacity: 0; }
}

/* Right column */
.hero-right-col {
  flex: 1 1 44%;
  min-width: 300px;
  padding-top: 6px;
}
.hero-right-col label.box-header {
  display:block;
  color: #c9932f;
  font-weight: 700;
  letter-spacing: 0.06em;
  margin-bottom: 12px;
  font-size: 13px;
}
.hero-right-col h2.box-header {
  font-size: 34px;
  line-height: 1.06;
  margin: 0 0 16px 0;
  font-weight: 800;
  color: #0e1b2b;
}
.hero-right-col h5 {
  font-size: 15px;
  line-height: 1.78;
  color: #444;
  margin: 0;
  font-weight: 400;
}

/* Responsive */
@media (max-width: 900px) {
  #techno-hero { flex-direction: column; gap: 28px; margin: 28px auto; padding: 0 14px; }
  .hero-left-col, .hero-right-col { flex: 1 1 100%; min-width: 100%; }
  .logo-card { position: static; transform: none; margin: -48px auto 0; width: 68%; }
  .inset-thumb { left: 14px; top: 18%; bottom: auto; }
}

/* ===== Four Accent Lines (each moves on its axis + fades) ===== */
.hero-left-col {
  position: relative;
  overflow: visible;
}

/* Common look */
.hero-left-col::before,
.hero-left-col::after,
.hero-left-col span.side-top,
.hero-left-col span.side-bottom {
  content: "";
  position: absolute;
  background: #c9932f; /* gold */
  border-radius: 2px;
  opacity: 0;
  z-index: 0;
}

/* Top line */
.hero-left-col span.side-top {
  top: -25px;
  left: 20%;
  width: 80px;
  height: 4px;
  animation: lineHorizontal 4s ease-in-out infinite;
  animation-delay: 0s;
}

/* Bottom line */
.hero-left-col span.side-bottom {
  bottom: -25px;
  right: 20%;
  width: 80px;
  height: 4px;
  animation: lineHorizontal 4s ease-in-out infinite;
  animation-delay: 1s;
}

/* Left line */
.hero-left-col::before {
  left: -25px;
  top: 20%;
  width: 4px;
  height: 80px;
  animation: lineVertical 4s ease-in-out infinite;
  animation-delay: 2s;
}

/* Right line */
.hero-left-col::after {
  right: -25px;
  bottom: 20%;
  width: 4px;
  height: 80px;
  animation: lineVertical 4s ease-in-out infinite;
  animation-delay: 3s;
}

/* Animations */
@keyframes lineHorizontal {
  0%   { opacity: 0; transform: translateX(0); }
  20%  { opacity: 1; transform: translateX(10px); }
  50%  { opacity: 0.6; transform: translateX(0); }
  80%  { opacity: 0; transform: translateX(-10px); }
  100% { opacity: 0; transform: translateX(0); }
}

@keyframes lineVertical {
  0%   { opacity: 0; transform: translateY(0); }
  20%  { opacity: 1; transform: translateY(-10px); }
  50%  { opacity: 0.6; transform: translateY(0); }
  80%  { opacity: 0; transform: translateY(10px); }
  100% { opacity: 0; transform: translateY(0); }
}




/* ===== Techno serve Container end ===== */


/* ===== Services Provided section ===== */
#services-provided { 
  padding: 36px 0 56px;
  background: transparent; /* keep page bg; change if needed */
  color: #263238;
}

#services-provided .services-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
  box-sizing: border-box;
}

/* Title bar */
#services-provided .services-title h3 {
  margin: 0 0 18px 0;
  padding: 18px 22px;
  background: #d6b356; /* warm gold (lighter) */
  color: #fff;
  font-size: 18px;
  font-weight: 700;
  border-radius: 2px;
  display: inline-block;
  letter-spacing: 0.03em;
}

/* grid layout */
#services-provided .services-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px 48px;
  margin-top: 18px;
  align-items: start;
}

/* each column list */
#services-provided .services-col {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 14px;
}

/* list item style: alternating pale boxes (like screenshot) */
#services-provided .services-col li {
  position: relative;
  padding: 18px 18px;
  font-size: 16px;
  color: #2f3b3f;
  background: #f3f6f8; /* pale box */
  border-radius: 4px;
  min-height: 48px;
  display: flex;
  align-items: center;
}

/* small gold bullet on left */
#services-provided .services-col li::before {
  content: "";
  width: 8px;
  height: 8px;
  background: #c9932f;
  border-radius: 50%;
  margin-right: 12px;
  flex: 0 0 auto;
  box-shadow: 0 0 6px rgba(201,147,47,0.18);
}

/* larger gaps for visual parity with screenshot */
#services-provided .services-col:nth-child(1) li:nth-child(odd),
#services-provided .services-col:nth-child(2) li:nth-child(odd) {
  background: #eef2f5; /* slightly different zebra feel */
}

/* responsive: stack to one column on small screens */
@media (max-width: 900px) {
  #services-provided .services-grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }
  #services-provided .services-title h3 {
    display: block;
    width: 100%;
    border-radius: 4px;
  }
}

/* small utility if you want more spacing below */
#services-provided { margin-bottom: 32px; }




/* ===== SERVICES CARDS — Dark Theme ===== */
#services-cards {
  padding: 60px 0 100px;
  background: #282828; /* dark background */
  color: #eee;
  box-sizing: border-box;
}

#services-cards .services-cards-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
}

/* Section header */
#services-cards .services-cards-head h2.theme-title-style {
  position: relative;
  padding-left: 18px;
  line-height: 55px;
  font-size: 26px;
  font-weight: 800;
  text-transform: uppercase;
  margin: 0;
  color: #fff;
  z-index: 2;
}
#services-cards .services-cards-head h2.theme-title-style:before {
  content: '';
  width: 202px;
  height: 100%;
  border: 3px solid rgba(209,160,67,0.4); /* golden frame */
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
}
#services-cards .services-cards-head p {
  margin: 10px 0 28px 0;
  font-size: 18px;
  color: #aaa;
  font-weight: 500;
}

/* Grid layout */
#services-cards .cards-grid {
  display: flex;
  gap: 20px;
  align-items: flex-start;
  justify-content: space-between;
  flex-wrap: wrap;
  margin-top: 10px;
}

/* Columns */
#services-cards .card-col {
  flex: 1 1 23%;
  display: flex;
  flex-direction: column;
  gap: 14px;
  box-sizing: border-box;
  min-width: 220px;
}

/* Cards */
#services-cards .service-card {
  background: #1e1e1e;
  border: 2px solid #2a2a2a;
  border-radius: 10px;
  padding: 14px 16px;
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 15px;
  color: #ddd;
  line-height: 1.35;
  transition: transform .28s ease, box-shadow .28s ease, border-color .28s ease, background-color .28s ease;
  cursor: pointer;
  box-shadow: 0 6px 18px rgba(0,0,0,0.5);
}

/* Arrow */
#services-cards .service-card .ic {
  flex: 0 0 auto;
  font-size: 16px;
  color: #d1a043; /* gold */
  width: 22px;
  height: 22px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  font-weight: 700;
  margin-right: 6px;
  transition: transform .28s ease, color .28s ease;
}
#services-cards .service-card .ic::before {
  content: "➤";
  display: inline-block;
}

/* Card text */
#services-cards .service-card .card-body {
  flex: 1;
  color: #ddd;
  font-size: 15px;
  font-weight: 500;
}

/* Hover effects */
#services-cards .service-card:hover {
  background: #d1a043;   /* gold */
  color: #fff;
  border-color: #d1a043;
  transform: translateY(-6px);
  box-shadow: 0 22px 46px rgba(209,160,67,0.3);
}
#services-cards .service-card:hover .card-body { color: #fff; }
#services-cards .service-card:hover .ic { color: #fff; transform: translateX(6px); }

/* Links inside cards */
#services-cards .service-card a {
  color: inherit;
  text-decoration: underline;
}

/* Responsive */
@media (max-width: 980px) {
  #services-cards .card-col { flex: 1 1 48%; }
  #services-cards .services-cards-head h2.theme-title-style { font-size: 22px; line-height: 48px; }
}
@media (max-width: 560px) {
  #services-cards .card-col { flex: 1 1 100%; }
  #services-cards .service-card { padding: 12px; }
  #services-cards .services-cards-head h2.theme-title-style { font-size: 20px; line-height: 44px; }
}


/* ===== csw slider CSS ===== */
.csw-outer-band { display:flex; justify-content:center; padding:64px 0; background:#ffffff; }
.csw-band-inner { width:100%; max-width:760px; display:flex; flex-direction:column; align-items:center; gap:12px; position:relative; }

.csw-preview-area { width:100%; height:320px; display:flex; align-items:center; justify-content:center; position:relative; }
.csw-dark-card { width:100%; height:100%; background:#161616; border-radius:6px; display:flex; align-items:center; justify-content:center; position:relative; box-shadow:0 8px 24px rgba(0,0,0,0.3); overflow:hidden; }
.csw-cert-frame { background:#fff; padding:10px; border-radius:4px; box-shadow:0 8px 20px rgba(0,0,0,0.25); width:280px; max-width:calc(100% - 40px); }
.csw-cert-frame img { display:block; width:100%; height:auto; object-fit:contain; border-radius:3px; cursor:pointer; }

.csw-single-view { width:100%; height:100%; display:none; align-items:center; justify-content:center; position:relative; overflow:hidden; }
.csw-single-view img { max-width:calc(100% - 40px); max-height:280px; object-fit:contain; border-radius:4px; box-shadow:0 10px 28px rgba(0,0,0,0.45); cursor:pointer; background:#fff; padding:6px; }

.csw-nav-btn { position:absolute; top:50%; transform:translateY(-50%); width:40px; height:40px; border-radius:50%; background:rgba(255,255,255,0.15); display:grid; place-items:center; cursor:pointer; border:none; color:#080808; font-size:18px; z-index:50; box-shadow:0 4px 12px rgba(0,0,0,0.25); }
.csw-nav-left{ left:12px; } .csw-nav-right{ right:12px; }

.csw-inner-dots { position:absolute; bottom:12px; left:50%; transform:translateX(-50%); display:flex; gap:6px; z-index:60; }
.csw-inner-dots button { width:8px; height:8px; border-radius:50%; border:none; background:rgba(255,255,255,0.45); cursor:pointer; box-shadow:0 2px 6px rgba(0,0,0,0.25); }
.csw-inner-dots button.is-active { background:#fff; transform:scale(1.05); }

.csw-outer-dots { display:flex; gap:8px; justify-content:center; align-items:center; margin-top:8px; }
.csw-outer-dots button { width:10px; height:10px; border-radius:50%; border:none; background:rgba(0,0,0,0.3); opacity:0.6; cursor:pointer; box-shadow:0 2px 6px rgba(0,0,0,0.2); }
.csw-outer-dots button.is-active { background:#000; opacity:1; transform:scale(1.05); }

/* Edge (viewport) arrows */
.csw-edge-shift {
  position:fixed;
  top:50%;
  width:56px;
  height:56px;
  border-radius:50%;
  background:rgba(0,0,0,0.28);
  color:#fff;
  display:grid;
  place-items:center;
  z-index:2200;
  border:none;
  font-size:22px;
  box-shadow:0 6px 18px rgba(0,0,0,0.35);
  transform:translateY(-50%);
  opacity:0;
  pointer-events:none;
  transition:opacity .18s ease, transform .18s ease;
}
#cswEdgeLeft { left:12px; } #cswEdgeRight { right:12px; }

/* visible state (toggled by JS only when slider is visible in viewport & proximity/hover) */
body.csw-edge-visible #cswEdgeLeft,
body.csw-edge-visible #cswEdgeRight {
  opacity:1;
  pointer-events:auto;
  transform:translateY(-50%) translateX(0);
}

/* small screens: hide */
@media (max-width:720px) { .csw-edge-shift { display:none !important; } }

/* ===== Modal styles (zoom/pan area) ===== */
.csw-modal { position:fixed; inset:0; display:none; z-index:10000; font-family:inherit; }
.csw-modal.open { display:block; }

.csw-modal-backdrop { position:absolute; inset:0; background:rgba(0,0,0,0.75); backdrop-filter: blur(2px); }

.csw-modal-viewport {
  position:absolute; left:50%; top:50%; transform:translate(-50%,-50%);
  width: min(94vw, 1100px); height: min(92vh, 820px);
  display:flex; flex-direction:column; outline:none;
  z-index:10001;
}
.csw-modal-toolbar { display:flex; align-items:center; justify-content:space-between; padding:10px 12px; gap:8px; pointer-events:auto; }
.csw-modal-close { background:#fff; color:#111; border:none; padding:6px 10px; border-radius:8px; cursor:pointer; font-size:16px; box-shadow:0 6px 18px rgba(0,0,0,0.18); }
.csw-modal-controls { display:flex; align-items:center; gap:8px; }

.csw-modal-controls button { background: rgba(255,255,255,0.95); border:none; padding:6px 10px; border-radius:6px; cursor:pointer; font-size:16px; box-shadow:0 6px 18px rgba(0,0,0,0.12); color:#111; }
.csw-zoom-pct { font-size:13px; color:#fff; background:rgba(0,0,0,0.45); padding:6px 8px; border-radius:6px; margin-left:6px; }

.csw-modal-body { flex:1 1 auto; display:flex; align-items:center; justify-content:center; overflow:hidden; position:relative; border-radius:6px; background:#fff; margin:0 12px 12px 12px; }
.csw-modal-body img { user-select:none; -webkit-user-drag:none; max-width:none; max-height:none; will-change:transform; transform-origin:0 0; cursor:grab; display:block; }
.csw-modal-body img.dragging { cursor:grabbing; }

/* responsive */
@media (max-width:900px) { .csw-band-inner { max-width:92vw; } .csw-preview-area { height:280px; } }
@media (max-width:480px) { .csw-preview-area { height:240px; } .csw-cert-frame { width:200px; } .csw-modal-viewport { width:94vw; height:86vh; } }


/* Simple modal: medium size image and only close button visible */
#cswModal {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 1200;
  align-items: center;
  justify-content: center;
}
#cswModal.open { display: flex; }
#cswModalBackdrop {
  position: absolute; inset: 0; background: rgba(0,0,0,0.6);
}
#cswModalBody {
  position: relative;
  z-index: 2;
  max-width: 90%;
  max-height: 90%;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
}
#cswModalImg {
  pointer-events: auto;
  max-width: 70%;   /* medium width (change to 60%/80% as you prefer) */
  max-height: 70%;
  object-fit: contain;
  display: block;
  border-radius: 6px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.6);
}

/* Close button: visible, positioned top-right of modal body */
#cswModalClose {
  position: absolute;
  top: -12px;
  right: -12px;
  z-index: 3;
  pointer-events: auto;
  background: #fff;
  border-radius: 50%;
  border: none;
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 12px rgba(0,0,0,0.2);
  cursor: pointer;
}

/* Optional small style to hide any zoom controls if present */
.csw-zoom-controls { display: none !important; }










/* contact info technoserve */
.contact-timeline {
  padding: 70px 20px;
  background: #f6f6f6;
  text-align: center;
}

.timeline-title {
  font-size: 26px;
  font-weight: 700;
  margin-bottom: 50px;
  color: #222;
}

.timeline {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  gap: 40px;
  flex-wrap: wrap;
  position: relative;
}

/* Connector line (horizontal on desktop) */
.contact-dark {
  padding: 80px 20px;
  background: #282828; /* dark background */
  text-align: center;
}

.contact-title {
  font-size: 28px;
  font-weight: 700;
  margin-bottom: 50px;
  color: #fff;
  letter-spacing: 1px;
}

.contact-grid {
  display: flex;
  justify-content: center;
  gap: 40px;
  flex-wrap: wrap;
}

.contact-card {
  flex: 1 1 280px;
  max-width: 320px;
  padding: 30px 25px;
  border-radius: 12px;
  background: #1e1e1e;
  color: #ddd;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.6);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.contact-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 12px 26px rgba(0, 0, 0, 0.9);
}

.icon-wrap {
  width: 70px;
  height: 70px;
  border-radius: 50%;
  background: rgba(209, 160, 67, 0.1);
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 auto 18px;
  color: #d1a043; /* golden accent */
  transition: transform 0.3s ease, background 0.3s ease;
}

.contact-card:hover .icon-wrap {
  transform: scale(1.15);
  background: rgba(209, 160, 67, 0.2);
}

.contact-card h3 {
  font-size: 19px;
  margin-bottom: 10px;
  color: #fff;
}

.contact-card p {
  font-size: 15px;
  line-height: 1.7;
  color: #ccc;
}

.contact-card a {
  color: #d1a043;
  font-weight: 500;
  text-decoration: none;
}

.contact-card a:hover {
  text-decoration: underline;
}

/* my website link */

.hero-image-frame {
  position: relative; /* anchor for absolute button */
}
.external-link-small {
  position: absolute;
  left: 24px;
  bottom: -40px;
  z-index: 999;
  display: inline-block;
  padding: 12px 28px;
  border-radius: 64px;
  background: #1c1c1c;             /* dark inside */
  border: 2px solid #d1a043;       /* gold border */
  color: #fff;                     /* white text */
  font-weight: 600;
  text-decoration: none;
  transition: all 0.3s ease-in-out;
}

.external-link-small:hover {
  background: #d1a043;             /* gold */
  color: #fff;                     /* keep white text */
  border-color: #d1a043;           /* gold border */
  transform: translateY(-6px);     /* lift */
  box-shadow: 0 22px 46px rgba(209,160,67,0.3); /* gold shadow */
}









/* submenu i made */
/* -------------------------
   Products & Services menu
   (place after your existing nav CSS)
   ------------------------- */
/* ===============================
   PRODUCTS & SERVICES MENU
   =============================== */

/* base / desktop */
.ps-nav { position: relative; }
.ps-nav > .ps-link {
  display: block;
  padding: 10px 15px;
  font-size: 20px;
  color: #fff;
}

/* main dropdown */
.ps-dropdown {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  min-width: 220px;
  background: #fff;
  box-shadow: 0 8px 20px rgba(0,0,0,0.15);
  border-radius: 4px;
  z-index: 999;
}

/* show main dropdown on hover (desktop) */
.ps-nav:hover > .ps-dropdown,
.ps-nav:focus-within > .ps-dropdown {
  display: block;
}

/* dropdown item wrapper */
.ps-dropdown .ps-item { position: relative; }

/* first-level parent links */
.ps-dropdown .ps-item > .ps-parent {
  line-height: 40px;
  font-size: 16px;
  color: #76808a;
  padding: 0 20px;
  display: block;
  border-bottom: 1px solid #ededed;
  transition: all .3s ease-in-out;
}
.ps-dropdown .ps-item:last-child > .ps-parent { border-bottom: none; }
.ps-dropdown .ps-item > .ps-parent:hover { color: #fac800; }

/* submenus */
.ps-dropdown .ps-sub {
  display: none;
  position: absolute;
  top: 0;
  left: 100%;
  min-width: 220px;
  background: #fff;
  box-shadow: 0 8px 20px rgba(0,0,0,0.12);
  border-radius: 4px;
  z-index: 1000;
}
.ps-dropdown .ps-item:hover > .ps-sub { display: block; }

/* links inside submenus */
.ps-sub li a {
  line-height: 40px;
  font-size: 16px;
  color: #76808a;
  padding: 0 20px;
  display: block;
  border-bottom: 1px solid #ededed;
  transition: all .3s ease-in-out;
}
.ps-sub li:last-child a { border-bottom: none; }
.ps-sub li a:hover { color: #fac800; }

/* ===============================
   MOBILE & TABLET (≤991px)
   =============================== */
/* Modern Rounded Gradient Mobile Menu Redesign */
/* Compact Blue-Gold Mobile Menu Theme */
@media (max-width: 991px) {
  /* Navbar container */
  .navbar-collapse {
    background: linear-gradient(180deg, #1a3b8b 0%, #0f245d 100%);
    border-radius: 12px;
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.2);
    padding: 10px;
    width: 90%;
    margin: 0 auto;
    transition: all 0.3s ease-in-out;
  }

  /* Main nav links */
  .navbar-nav > li > a {
    color: #ffffff;
    font-size: 15px;
    padding: 10px 14px;
    border-radius: 6px;
    display: block;
    background: rgba(255, 255, 255, 0.05);
    transition: background 0.3s ease;
  }

  .navbar-nav > li > a:hover,
  .navbar-nav > li.current-page-item > a {
    background: rgba(255, 215, 0, 0.15);
    color: #fac800;
  }

  /* Dropdown containers */
  .ps-dropdown, .ps-sub {
    position: static !important;
    overflow: hidden;
    max-height: 0;
    opacity: 0;
    transform: translateY(-8px);
    background: #0e1c44;
    border-radius: 8px;
    border-left: 3px solid #fac800;
    transition: all 0.4s ease;
  }

  #navbar-collapse-1 li.menu-open > .ps-dropdown,
  #navbar-collapse-1 li.menu-open > .ps-sub {
    max-height: 400px;
    opacity: 1;
    transform: translateY(0);
  }

  /* Parent menu links */
  .ps-dropdown .ps-item > .ps-parent {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 10px 16px;
    font-size: 15px;
    color: #fac800;
    background: #183573;
    border-radius: 6px;
    margin: 4px 0;
    transition: all 0.3s ease;
  }

  .ps-dropdown .ps-item > .ps-parent:hover {
    background: #204494;
    color: #fff;
  }

  /* Caret icon */
  .ps-dropdown .ps-item > .ps-parent::after {
    content: "\25BC";
    font-size: 10px;
    color: #fac800;
    margin-left: 8px;
    transition: transform 0.3s ease;
  }

  .ps-item.menu-open > .ps-parent::after {
    transform: rotate(180deg);
  }

  /* Submenu links */
  .ps-sub li a {
    display: block;
    padding: 8px 22px;
    font-size: 14px;
    color: #f1f1f1;
    background: #10295d;
    border-left: 2px solid transparent;
    transition: all 0.3s ease;
  }

  .ps-sub li a:hover {
    background: #1c3a7d;
    border-left: 2px solid #fac800;
    color: #fff;
  }

  /* Submenu animation */
  .ps-item.menu-open > .ps-sub li {
    opacity: 0;
    transform: translateX(-10px);
    animation: fadeSlideIn 0.4s ease forwards;
  }

  .ps-item.menu-open > .ps-sub li:nth-child(1) { animation-delay: 0.05s; }
  .ps-item.menu-open > .ps-sub li:nth-child(2) { animation-delay: 0.1s; }
  .ps-item.menu-open > .ps-sub li:nth-child(3) { animation-delay: 0.15s; }
  .ps-item.menu-open > .ps-sub li:nth-child(4) { animation-delay: 0.2s; }

  @keyframes fadeSlideIn {
    0% { opacity: 0; transform: translateX(-8px); }
    100% { opacity: 1; transform: translateX(0); }
  }

  /* Active state */
  .ps-sub li.active a {
    background: #204494;
    color: #fac800;
    border-left: 2px solid #fac800;
  }

  /* Add a glow when open */
  #navbar-collapse-1 li.menu-open > .ps-parent {
    box-shadow: inset 0 0 10px rgba(250, 200, 0, 0.25);
  }
}





/* APECO */

/* ===== APECO: Precise alignment for left/right inside #services-cards ===== */
/* Scoped so it won't affect other pages */
#services-cards .apeco-two {
  display: grid;
  grid-template-columns: 34% 1fr;    /* left column width; change to 30%/36% if needed */
  gap: 28px;
  align-items: start;               /* keep both columns top-aligned */
  width: 100%;
  box-sizing: border-box;
  margin-top: 0;
}

/* Make sure apeco wrappers inherit same container padding/width */
#services-cards .apeco-two .apeco-left,
#services-cards .apeco-two .apeco-right {
  box-sizing: border-box;
  width: 100%;
}

/* LEFT: use exact .service-card visual styling so size/spacing matches */
#services-cards .apeco-left .service-card {
  background: #1e1e1e;               /* same as site cards */
  border: 2px solid #2a2a2a;         /* same border */
  border-radius: 10px;
  padding: 14px 16px;                /* exact same padding */
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 15px;
  color: #ddd;
  line-height: 1.35;
  box-shadow: 0 6px 18px rgba(0,0,0,0.5);
  transition: transform .28s ease, box-shadow .28s ease, border-color .28s ease, background-color .28s ease;
  width: 100%;
}

/* Ensure arrow and card-body are same sizes */
#services-cards .apeco-left .service-card .ic {
  width: 22px;
  height: 22px;
  font-size: 16px;
  margin-right: 6px;
  color: #d1a043;
}
#services-cards .apeco-left .service-card .card-body {
  flex: 1;
  font-size: 15px;
  font-weight: 500;
  color: #ddd;
}

/* Right side: keep existing cards-grid behavior but ensure vertical alignment */
#services-cards .apeco-right .cards-grid {
  display: flex;
  gap: 20px;
  align-items: flex-start; /* keep top aligned */
  flex-wrap: wrap;
}

/* Match your existing .card-col behavior for consistent widths */
#services-cards .apeco-right .card-col {
  flex: 1 1 23%;
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-width: 220px;
  box-sizing: border-box;
}

/* Subheadings (small framed title) — match theme */
#services-cards .apeco-subhead {
  position: relative;
  padding-left: 18px;
  line-height: 40px;
  font-size: 18px;
  font-weight: 800;
  text-transform: uppercase;
  color: #fff;
  margin: 0 0 12px 0;
  z-index: 2;
}
#services-cards .apeco-subhead:before {
  content: '';
  width: 160px;
  height: 100%;
  border: 3px solid rgba(209,160,67,0.35);
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
}

/* Hover behavior: keep same gold hover (uses your theme color) */
#services-cards .apeco-left .service-card:hover,
#services-cards .apeco-right .service-card:hover {
  background: #d1a043;
  color: #fff;
  border-color: #d1a043;
  transform: translateY(-6px);
  box-shadow: 0 22px 46px rgba(209,160,67,0.3);
}
#services-cards .apeco-left .service-card:hover .card-body,
#services-cards .apeco-right .service-card:hover .card-body { color: #fff; }
#services-cards .apeco-left .service-card:hover .ic,
#services-cards .apeco-right .service-card:hover .ic { color: #fff; transform: translateX(6px); }

/* Mobile adjustments: stack and make left cards smaller padding to match responsive rules */
@media (max-width: 980px) {
  #services-cards .apeco-two { grid-template-columns: 1fr; gap: 18px; }
  #services-cards .apeco-right .card-col { flex: 1 1 48%; }
}
@media (max-width: 560px) {
  #services-cards .apeco-right .card-col { flex: 1 1 100%; }
  #services-cards .apeco-left .service-card { padding: 12px; }
}



/* ---------- vp: vise president / layout ---------- */
.vp-hero-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 40px;
  flex-wrap: wrap;
  margin: 40px 0;
}

.vp-left-half, .vp-right-half {
  flex: 1;
  min-width: 320px;
}
.vp-right-half {
  flex: 1;
  min-width: 320px;
  margin-left: -85px; /* shift text block left */
}


.vp-img-wrapper {
  display: flex;
  justify-content: center;
}

/* ---------- Image card with static glow ---------- */
.vp-single-img {
  position: relative;
  overflow: hidden;
  border-radius: 10px;
  border: 3px solid #dbb351; /* gold border always visible */
  box-shadow: 0 0 25px rgba(219, 179, 81, 0.6); /* static glow */
  transition: transform 0.3s ease;
  display: inline-block;
}

.vp-single-img img {
  display: block;
  width: 394px;
  height: 448px;
  object-fit: cover;
  border-radius: 7px;
  position: relative;
  z-index: 1;
}

/* Decorative svgs */
.vp-single-img .vp-deco {
  position: absolute;
  pointer-events: none;
}
.vp-deco-a { top: -8px; left: -8px; z-index: 3; }
.vp-deco-b { bottom: -26px; left: -26px; z-index: 1; }

/* ---------- Flare effect ---------- */
.vp-single-img::after {
  content: "";
  position: absolute;
  top: 0;
  left: -80%;
  width: 50%;
  height: 120%;
  background: linear-gradient(
    110deg,
    rgba(255,255,255,0) 0%,
    rgba(255,255,220,0.65) 50%,
    rgba(255,255,255,0) 100%
  );
  transform: skewX(-18deg);
  z-index: 2;
  opacity: 0;
  pointer-events: none;
}

/* run flare only on hover */
.vp-single-img:hover {
  transform: translateY(-8px) scale(1.015);
}

.vp-single-img:hover::after {
  opacity: 1;
  animation: vp-flareSwipe 900ms ease forwards;
}

/* flare movement */
@keyframes vp-flareSwipe {
  0%   { left: -80%; opacity: 0; }
  20%  { opacity: 1; }
  100% { left: 140%; opacity: 0; }
}

/* ---------- Right text ---------- */
.vp-box-header {
  display: block;
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 1px;
  color: #c9932f;
  margin-bottom: 6px;
}
.vp-hero-right-col h2 {
  font-size: 26px;
  line-height: 1.2;
  color: #071727;
  margin: 0 0 8px 0;
}
.vp-hero-right-col h5 {
  font-weight: 400;
  font-size: 15px;
  line-height: 1.7;
  color: #4b5b63;
  margin-top: 18px;
}

/* ---------- Responsive ---------- */
@media (max-width: 900px) {
  .vp-right-half {
    margin-left: 0; /* reset on mobile */
  }
}

/* HERO ROW LAYOUT WITH CONSISTENT SPACING */
.vp-hero-row {
  display: flex;
  align-items: center;
  justify-content: center;   /* center the whole row */
  gap: 50px;                 /* spacing between left & right halves */
  padding: 60px 40px;        /* space around the section */
  flex-wrap: wrap;
  box-sizing: border-box;
}

/* halves */
.vp-left-half, .vp-right-half {
  flex: 1;
  min-width: 320px;
}

/* image wrapper spacing */
.vp-img-wrapper {
  display: flex;
  justify-content: center;
}

/* right side text block spacing */
.vp-hero-right-col {
  padding: 20px;          /* inner padding for breathing room */
  box-sizing: border-box;
}

.vp-hero-right-col label,
.vp-hero-right-col h2,
.vp-hero-right-col h5 {
  margin-bottom: 18px;    /* consistent space between elements */
}

.vp-hero-right-col h2 {
  margin-top: 10px;
  margin-bottom: 20px;
}

/* responsive spacing */
@media (max-width: 900px) {
  .vp-hero-row {
    flex-direction: column;
    text-align: center;
    gap: 30px;            /* smaller gap on mobile */
    padding: 30px 20px;
  }
  .vp-hero-right-col { padding: 10px; }
}




/* Youtube section */

.vp-youtube-section {
  background: #2f2f2f;
  padding: 60px 20px;
  text-align: center;
}

.vp-youtube-title {
  font-size: 22px;
  margin-bottom: 20px;
  font-weight: bold;
  color: #fff;
}

/* Thumbnail with border */
.vp-youtube-thumbnail {
  position: relative;
  display: inline-block;
  max-width: 650px; /* smaller width */
  width: 100%;
  cursor: pointer;
  border: 3px solid #dbb351; /* gold border */
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 0 20px rgba(219,179,81,0.5); /* soft gold glow */
}

.vp-youtube-thumbnail img {
  width: 100%;
  display: block;
}

/* Play button smaller */
.play-button {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 50px;  /* smaller */
  height: 50px;
  background: rgba(255,255,255,0.2);
  border: 2px solid #fff;  /* white border */
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
}

.play-button i {
  font-size: 20px;
  color: #fff;
}

.vp-youtube-thumbnail:hover .play-button {
  background: rgba(255,255,255,0.4);
  transform: translate(-50%, -50%) scale(1.1); /* little bounce on hover */
}
.vp-youtube-thumbnail {
  position: relative;
  display: inline-block;
  max-width: 650px; /* fixed width */
  width: 100%;
  height: 330px; /* fixed height to match iframe */
  cursor: pointer;
  border: 3px solid #997a2b; /* gold border */
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 0 20px rgba(219,179,81,0.5);
}

.vp-youtube-thumbnail img {
  width: 100%;
  height: 100%;
  object-fit: cover; /* crop nicely */
  display: block;
}





/* for saudi oil service */
/* Balanced Products & Services */
#services-cards .apeco-two {
  display: grid;
  grid-template-columns: 1fr 1fr;  /* equal width columns */
  gap: 40px;                       /* spacing between columns */
  align-items: stretch;            /* equal height for balance */
  width: 100%;
  box-sizing: border-box;
}

/* Headings */
#services-cards .apeco-subhead {
  margin-bottom: 10px;
  min-height: 40px;               /* keeps headings aligned */
  display: flex;
  align-items: center;
}

/* Paragraphs */
#services-cards .apeco-desc {
  font-size: 15px;
  color: #ccc;                    /* lighter gray */
  margin: 0 0 24px 0;
  line-height: 1.65;
  min-height: 44px;               /* keeps paragraphs aligned */
  max-width: 92%;
}
/* Extra spacing between points */
#services-cards .service-card {
  margin-bottom: 14px;   /* space under each point */
}

#services-cards .service-card:last-child {
  margin-bottom: 0;      /* remove space after the last one */
}


/*END*/

/* APECO service cards */

/* ===== APECO: Two-column master layout ===== */
#services-cards .apeco-two {
  display: grid;
  grid-template-columns: 1fr 1fr;  /* equal width */
  gap: 40px;                       /* space between columns */
  align-items: start;
  width: 100%;
  box-sizing: border-box;
}

/* ===== Headings (gold subhead style) ===== */
#services-cards .apeco-subhead {
  margin-bottom: 6px;
  min-height: 38px;    /* keeps headings aligned across both columns */
  display: flex;
  align-items: center;
}

/* ===== Small paragraph under headings ===== */
#services-cards .apeco-desc {
  font-size: 15px;
  color: #ccc;
  margin: 0 0 22px 0;  /* breathing room before first card */
  line-height: 1.65;
  min-height: 42px;    /* ensures both sides align at top */
  max-width: 92%;
}

/* ===== Cards spacing ===== */
#services-cards .service-card {
  margin-bottom: 14px;
}
#services-cards .service-card:last-child {
  margin-bottom: 0;
}

/* ===== Split LEFT & RIGHT into two columns each ===== */
#services-cards .apeco-left-grid,
#services-cards .apeco-right-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px 24px;  /* row-gap and column-gap */
}

/* Cards inside split grids */
#services-cards .apeco-left-grid .service-card,
#services-cards .apeco-right-grid .service-card {
  margin-bottom: 14px;
}
#services-cards .apeco-left-grid .service-card:last-child,
#services-cards .apeco-right-grid .service-card:last-child {
  margin-bottom: 0;
}

/* ===== Responsive adjustments ===== */
@media (max-width: 900px) {
  #services-cards .apeco-left-grid,
  #services-cards .apeco-right-grid {
    grid-template-columns: 1fr;  /* stack into single column */
  }
  #services-cards .apeco-two {
    grid-template-columns: 1fr;  /* stack left & right */
  }
}











/* ===== PRODUCTS Section (Final Fixed) ===== */
/* ===== PRODUCTS Section (Final Fixed) ===== */

#products-gallery.dark-bg {
  background: #282828;
  padding: 80px 0 60px;
  margin: 60px 0;
  width: 100%;
}

#products-gallery .services-cards-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
  margin-top: 30px;
}

/* Section Heading */
#products-gallery .products-head {
  text-align: left;
  margin-bottom: 42px;
  position: relative;
}
#products-gallery .products-head h2.theme-title-style {
  position: relative;
  padding-left: 18px;
  line-height: 55px;
  font-size: 26px;
  font-weight: 800;
  text-transform: uppercase;
  margin: 0 0 10px;
  color: #fff;
  z-index: 2;
}
#products-gallery .products-head h2.theme-title-style:before {
  content: '';
  width: 220px;
  height: 100%;
  border: 3px solid rgba(209,160,67,0.9);
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  box-shadow: 0 0 8px rgba(209,160,67,0.6);
}
#products-gallery .products-head p {
  font-size: 15px;
  color: #ccc;
  margin: 0;
  padding-left: 5px;
}

/* Outer Carousel */
.products-carousel {
  padding-bottom: 30px;
}
.products-carousel .splide__list {
  align-items: stretch;
}
.products-carousel .splide__slide {
  display: flex;
  justify-content: center;
  align-items: stretch;
}

/* Product Card */
.products-carousel .service-card {
  background: #1e1e1e;
  border: 2px solid #333;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 4px 14px rgba(0,0,0,0.35);
  transition: border-color .3s ease, box-shadow .3s ease;
  max-width: 350px;
  width: 100%;
  display: flex;
  flex-direction: column;
}

.products-carousel .service-card:hover {
  border-color: #d1a043;
  box-shadow: 0 4px 14px rgba(209,160,67,0.5);
}

.products-carousel .service-card:hover h3,
.products-carousel .service-card:hover .product-desc {
  color: #fff;
}

/* Inner Image Carousel */
.product-splide {
  border-bottom: 1px solid #333;
  position: relative !important;
  border-top-left-radius: 16px;
  border-top-right-radius: 16px;
  overflow: hidden !important;
}
.product-splide .splide__track {
  height: 180px;
  border-top-left-radius: 16px;
  border-top-right-radius: 16px;
  overflow: hidden;
}
.product-splide .splide__slide img {
  width: 100%;
  height: 200px;              /* adjust height if needed */
  object-fit: cover;          /* ✅ fills the entire frame */
  background: none;           /* ✅ removes white padding effect */
  border-radius: 0;           /* keeps corners clean */
  display: block;
  margin: 0 auto;
  transition: transform 0.4s ease, filter 0.3s ease;
}

.service-card:hover .splide__slide img {
  transform: scale(1.05);
  filter: brightness(1.1);
}

/* Arrows */
.product-splide .splide__arrows {
  display: flex !important;
  z-index: 10;
}
.product-splide .splide__arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(0,0,0,0.65);
  color: #fac800;
  border-radius: 50%;
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 6px rgba(0,0,0,0.4);
  transition: background 0.3s ease;
}
.product-splide .splide__arrow:hover {
  background: #fac800;
  color: #000;
}
.product-splide .splide__arrow--prev { left: 8px; }
.product-splide .splide__arrow--next { right: 8px; }

/* Card Body */
.products-carousel .card-body {
  padding: 18px;
  text-align: left;
  transition: opacity 0.4s ease, transform 0.4s ease;
}
.products-carousel .card-body h3 {
  font-size: 18px;
  font-weight: 600;
  color: #fac800;
  margin-bottom: 10px;
}
.products-carousel .card-body .product-desc {
  font-size: 14px;
  color: #aaa;
  margin-bottom: 15px;
  line-height: 1.6;
  min-height: 60px;
}

/* Quote Button */
.products-carousel .quote-btn {
  display: inline-block;
  padding: 8px 18px;
  background: #fac800;
  color: #000;
  border-radius: 24px;
  font-size: 14px;
  font-weight: 600;
  text-decoration: none;
  transition: all .3s ease;
}
.products-carousel .quote-btn:hover {
  background: #d1a043;
  transform: translateY(-2px) scale(1.05);
  box-shadow: 0 4px 12px rgba(209,160,67,0.4);
}

/* Pagination (inside product images, fixed position) */
.product-splide .splide__pagination {
  position: absolute !important;
  bottom: 10px !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  display: flex !important;
  justify-content: center !important;
  width: 100% !important;
  flex-wrap: nowrap !important;
  z-index: 10 !important;
}

.product-splide .splide__pagination__page {
  width: 10px !important;
  height: 10px !important;
  background: #666 !important;
  border-radius: 50% !important;
  margin: 0 4px !important;
  opacity: 0.8 !important;
  transition: all 0.3s ease !important;
}

.product-splide .splide__pagination__page.is-active {
  background: #fac800 !important;
  transform: scale(1.25) !important;
}

/* Responsive tweaks */
@media (max-width: 992px) {
  .product-splide .splide__track { height: 160px; }
  .product-splide .splide__slide img { height: 160px; }
}

@media (max-width: 600px) {
  .product-splide .splide__track { height: 220px; }
  .product-splide .splide__slide img { height: 220px; }
  .products-carousel .splide__slide { padding: 0 6px; }
  .product-splide .splide__pagination {
    bottom: 12px !important;
    gap: 10px !important;
  }
}




/* ===== END ===== */



/*end */


/* about us renew */


/* Leaders Section */
.leader-section {
  padding: 0px 10%;
  background: #fff;
}

/* Heading - match screenshot */
.leader-heading {
  font-size: 36px;          /* adjust to match picture */
  font-weight: 600;         /* semi-bold */
  text-align: left;         /* aligned to left */
  margin-bottom: 40px;      /* space between heading and content */
  color: #111;
  font-family: 'Helvetica Neue', Arial, sans-serif; /* clean font style */
  position: relative;
}

.leader-heading::after {
  content: "";
  display: block;
  width: 70px;              /* line width */
  height: 3px;
  background: #c7a84e;      /* golden underline */
  margin-top: 8px;
  border-radius: 2px;
}

/* Container */
.leader-container {
  display: flex;
  align-items: center;
  gap: 60px;
}

/* Left Side Image */
.leader-image img {
  width: 520px;
  height: auto;
  border-radius: 12px;
  box-shadow: 0 8px 25px rgba(0,0,0,0.08);
  transition: transform 0.4s ease, box-shadow 0.4s ease;
}

.leader-image img:hover {
  transform: scale(1.05) translateY(-8px);
  box-shadow: 0 12px 30px rgba(0,0,0,0.15);
}

/* Right Side Text */
.leader-text {
  max-width: 600px;
}

.leader-subtitle {
  font-size: 14px;
  /* text-transform: uppercase; */  /* ❌ remove this */
  color: #6c757d;
  letter-spacing: 1px;
  margin-bottom: 10px;
  font-family: 'Poppins', sans-serif;
}


.leader-name {
  font-size: 32px;
  font-weight: 750;
  margin-bottom: 8px;
  color: #111;
}

.leader-role {
  font-size: 16px;
  font-weight: 500;
  color: #c7a84e;
  margin-bottom: 20px;
}

.leader-desc {
  font-size: 16px;
  line-height: 1.7;
  color: #333;
}

.leader-heading {
  font-size: 36px;
  font-weight: 600;
  text-align: left;
  margin-bottom: 40px;
  color: #111;
  font-family: 'Poppins', sans-serif;  /* matches screenshot */
}


.leader-heading {
  font-size: 36px;                /* same size as screenshot */
  font-weight: 600;               /* semi-bold */
  text-align: left;               /* aligned left */
  margin-bottom: 40px;
  color: #111;
  font-family: 'Poppins', sans-serif; 
  text-transform: none;           /* ✅ no full capital */
  letter-spacing: 0.5px;          /* subtle spacing like screenshot */
}


.leader-section {
  padding: 0px 14%;
  background: #fff;
}

.leader-container {
  display: flex;
  align-items: center;
  gap: 60px;
  margin-bottom: 80px; /* spacing between leaders */
}

.leader-container.reverse {
  flex-direction: row-reverse;
}

.leader-image img {
  width: 520px;
  height: auto;
  border-radius: 12px;
  box-shadow: 0 8px 25px rgba(0,0,0,0.08);
}
/* Default layout: image left, text right */
.leader-container {
  display: flex;
  align-items: center;
  gap: 60px;
  margin-bottom: 80px; /* space between leaders */
}

/* Reverse layout: image right, text left */
.leader-container.reverse {
  flex-direction: row-reverse;
}
.leader-container {
  display: flex;
  justify-content: space-between; /* makes both sides stay apart */
  align-items: center;            /* vertical alignment */
  gap: 60px;
  margin-bottom: 80px;
}

.leader-container.reverse {
  flex-direction: row-reverse;    /* flips image to right */
}

.leader-text {
  flex: 1; /* ensures text takes available space */
}

.leader-image {
  flex-shrink: 0; /* prevents image from shrinking */
}

.leader-image img {
  width: 520px;  /* keep consistent */
  max-width: 100%; /* responsive */
  height: auto;
  border-radius: 12px;
  box-shadow: 0 8px 25px rgba(0,0,0,0.08);
}
/* --------- Responsive fixes (paste at end of file) ---------- */

/* medium: reduce image width + gap so layout fits narrower screens */
@media (max-width: 1200px) {
  .leader-section { padding: 40px 6%; }
  .leader-container { gap: 40px; margin-bottom: 60px; }
  .leader-image { flex: 0 0 440px; }
  .leader-image img { max-width: 440px; }
  .leader-name { font-size: 30px; }
  .leader-heading { font-size: 34px; }
}

/* tablet: smaller image, tighten typography */
@media (max-width: 992px) {
  .leader-section { padding: 36px 5%; }
  .leader-container { gap: 32px; }
  .leader-image { flex: 0 0 360px; }
  .leader-image img { max-width: 360px; border-radius: 10px; }
  .leader-text { max-width: 100%; }
  .leader-name { font-size: 28px; }
  .leader-heading { font-size: 30px; }
  .leader-desc { font-size: 15px; line-height: 1.65; }
}

/* mobile: stack vertically, image full-width on top, text below */
@media (max-width: 768px) {
  .leader-section { padding: 28px 5%; }
  .leader-container,
  .leader-container.reverse {
    flex-direction: column;   /* stack */
    align-items: flex-start;
  }

  /* image full width and first on stack */
  .leader-image {
    width: 100%;
    flex: 0 0 auto;
    order: 0;       /* image first */
    margin-bottom: 20px;
    display: block;
  }
  .leader-image img {
    width: 100%;
    max-width: 100%;
    height: auto;
    object-fit: cover;
    border-radius: 10px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.06);
  }

  /* text full width below */
  .leader-text {
    width: 100%;
    order: 1;
    padding-right: 0;
  }

  /* smaller typography for mobile readability */
  .leader-heading { font-size: 26px; text-align: center; margin-bottom: 28px; }
  .leader-subtitle { font-size: 12px; letter-spacing: 1px; }
  .leader-name { font-size: 22px; }
  .leader-role { font-size: 15px; margin-bottom: 12px; }
  .leader-desc { font-size: 15px; line-height: 1.6; }
}

/* very small phones */
@media (max-width: 420px) {
  .leader-section { padding-left: 18px; padding-right: 18px; }
  .leader-heading { font-size: 22px; }
  .leader-image { margin-bottom: 16px; }
  .leader-name { font-size: 20px; }
  .leader-desc { font-size: 14px; }
}

/* safety: ensure images never overflow globally */
.leader-image img { max-width: 100%; height: auto; display: block; }


@media (max-width: 768px) {
  .leader-heading {
    text-align: center;
  }
  .leader-heading::after {
    margin: 8px auto 0; /* centers underline */
  }
}
/* Pagination dots for main carousel */
.products-carousel .splide__pagination {
  display: flex;
  justify-content: center;
  margin-top: 40px;   /* was 25px → now dots are lower */
  gap: 10px;
  margin-bottom: -19px; /* adjust if needed */
}



/* GHI section */
/* Import Google Font */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');

/* ===== Mission & Vision Section (Grey-White + Typography) ===== */
#mission-vision {
  background: #f7f7f7;
  padding: 90px 20px;
  width: 100%;
  font-family: 'Inter', sans-serif; /* clean modern font */
  margin-top: 132px;
}

.mv-container {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
  gap: 50px;
  max-width: 1200px;
  margin: 0 auto;
}

.mv-card {
  background: #fff;
  padding: 50px 35px;
  border-radius: 14px;
  border: 1px solid #e6e6e6;
  box-shadow: 0 6px 20px rgba(0,0,0,0.07);
  transition: all 0.3s ease;
}

.mv-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 14px 30px rgba(0,0,0,0.12);
}

.mv-card h3 {
  font-size: 24px;
  font-weight: 700;
  margin-bottom: 18px;
  color: #222;
  text-transform: uppercase;
  letter-spacing: 1.2px;
  line-height: 1.3;
  position: relative;
}

.mv-card h3::after {
  content: "";
  display: block;
  width: 65px;
  height: 3px;
  background: #FFD500;
  margin-top: 12px;
  border-radius: 2px;
}

.mv-card p {
  font-size: 17px;
  font-weight: 400;
  line-height: 1.8;
  color: #444;
}

.mv-card a {
  color: #FFD500;
  font-weight: 500;
  text-decoration: none;
  transition: color 0.2s ease;
}

.mv-card a:hover {
  color: #e6c200;
  text-decoration: underline;
}


/*GHI section end*/
/* ===== Registration Section ===== */
#registration {
  padding: 40px 20px;
  background: #fff; /* change if needed */
}

#registration .registration-container {
  max-width: 900px;
  margin: 0 auto;
}

#registration h3 {
  font-size: 20px;
  font-weight: 600;
  margin-bottom: 20px;
  color: #222;
}

.registration-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.registration-list li {
  display: flex;
  align-items: center;
  margin-bottom: 15px;
  font-size: 16px;
  color: #333;
}

.registration-list .check-icon {
  color: #d4a437; /* gold check icon */
  font-size: 18px;
  margin-right: 10px;
}


/* ISS section */

/* ===== ISS Section (Dark Background + Cards) ===== */


/* ===== Balanced 2x2 services grid ===== */
.ghi-services-wrapper { padding: 40px 18px; background:#151515; }
.ghi-services-grid {
  max-width:1200px;
  margin:0 auto;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:28px;
  align-items:start;
  grid-auto-rows: minmax(220px, auto);
  box-sizing: border-box;
}

/* Each section (card container) */
.ghi-service-section {
  background: #222;
  border-radius: 12px;
  padding:18px;
  display:flex;
  flex-direction:column;
  box-shadow: 0 10px 28px rgba(0,0,0,0.45);
  border-left: 4px solid rgba(209,160,67,0.06);
}

/* header */
.ghi-svc-head { margin-bottom:12px; }
.ghi-svc-head h2 {
  font-size:18px;
  color:#fff;
  margin:0 0 6px 0;
  font-weight:700;
  text-transform:uppercase;
  position:relative;
  padding-left:14px;
}
.ghi-svc-head h2:before {
  content:'';
  position:absolute;
  left:0; top:0; bottom:0;
  width:6px;
  background: linear-gradient(180deg, rgba(209,160,67,1), rgba(209,160,67,0.6));
  border-radius:3px;
}
.ghi-svc-head p {
  margin:0;
  color:#bdbdbd;
  font-size:13px;
  font-weight:500;
}

/* cards-grid */
.ghi-cards-grid {
  flex:1;
  display:flex;
  flex-direction:column;
  gap:12px;
  justify-content: space-between;
}

/* two-column inner layout */
.ghi-cards-grid.two-col {
  flex-direction:row;
  gap:12px;
}
.ghi-cards-grid.two-col .col {
  flex:1;
  display:flex;
  flex-direction:column;
  gap:12px;
  justify-content: space-between;
}

/* individual small cards */
.ghi-svc-item {
  background:#1e1e1e;
  border-radius:8px;
  padding:10px 12px;
  color:#e6e6e6;
  font-size:13.5px;
  line-height:1.35;
  border:1px solid rgba(255,255,255,0.02);
  display:flex;
  align-items:center;
  gap:10px;
  transition: all .22s ease;
  box-shadow: 0 6px 14px rgba(0,0,0,0.45);
}
.ghi-svc-item:hover {
  transform: translateX(6px);
  background: #d1a043;
  color:#fff;
  border-color:#d1a043;
  box-shadow: 0 18px 36px rgba(209,160,67,0.2);
}

/* arrow icon */
.ghi-svc-item::before {
  content:'➤';
  color:#d1a043;
  font-weight:700;
  display:inline-block;
  width:18px;
  text-align:center;
  margin-right:6px;
}
.ghi-svc-item:hover::before { color:#fff; transform:translateX(4px); }

/* small per-section color tweak */
#ghi-services-cards-1 { border-left-color: rgba(209,160,67,0.05); }
#ghi-services-cards-2 { border-left-color: rgba(209,160,67,0.08); }
#ghi-services-cards-3 { border-left-color: rgba(209,160,67,0.06); }
#ghi-services-cards-4 { border-left-color: rgba(209,160,67,0.07); }

/* responsive */
@media (max-width:980px) {
  .ghi-services-grid { grid-template-columns: 1fr; }
  .ghi-cards-grid.two-col { flex-direction:column; }
}
@media (max-width:480px) {
  .ghi-svc-head h2 { font-size:16px; }
  .ghi-svc-item { font-size:13px; padding:9px 10px; }
  .ghi-services-grid { gap:16px; }
}


/* end */

/* SWT section */
/* ===== SWT Section (Dark Background + Cards) ===== */

/* ===== SWT Section (Dark Background + Cards) ===== */

.swt-services-wrapper { padding: 40px 18px; background:#151515; }
.swt-services-grid {
  max-width:1200px;
  margin:0 auto;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:28px;
  align-items:start;
  grid-auto-rows: minmax(220px, auto);
  box-sizing: border-box;
}

.swt-service-section {
  background: #222;
  border-radius: 12px;
  padding:18px;
  display:flex;
  flex-direction:column;
  box-shadow: 0 10px 28px rgba(0,0,0,0.45);
  border-left: 4px solid rgba(209,160,67,0.06);
}

.swt-svc-head { margin-bottom:12px; }
.swt-svc-head h2 {
  font-size:18px;
  color:#fff;
  margin:0 0 6px 0;
  font-weight:700;
  text-transform:uppercase;
  position:relative;
  padding-left:14px;
}
.swt-svc-head h2:before {
  content:'';
  position:absolute;
  left:0; top:0; bottom:0;
  width:6px;
  background: linear-gradient(180deg, rgba(209,160,67,1), rgba(209,160,67,0.6));
  border-radius:3px;
}
.swt-svc-head p {
  margin:0;
  color:#bdbdbd;
  font-size:13px;
  font-weight:500;
}

.swt-cards-grid {
  flex:1;
  display:flex;
  flex-direction:column;
  gap:12px;
  justify-content: space-between;
}

.swt-svc-item {
  background:#1e1e1e;
  border-radius:8px;
  padding:10px 12px;
  color:#e6e6e6;
  font-size:13.5px;
  line-height:1.35;
  border:1px solid rgba(255,255,255,0.02);
  display:flex;
  align-items:center;
  gap:10px;
  transition: all .22s ease;
  box-shadow: 0 6px 14px rgba(0,0,0,0.45);
}
.swt-svc-item:hover {
  transform: translateX(6px);
  background: #d1a043;
  color:#fff;
  border-color:#d1a043;
  box-shadow: 0 18px 36px rgba(209,160,67,0.2);
}

.swt-svc-item::before {
  content:'➤';
  color:#d1a043;
  font-weight:700;
  display:inline-block;
  width:18px;
  text-align:center;
  margin-right:6px;
}
.swt-svc-item:hover::before { color:#fff; transform:translateX(4px); }

#swt-services-cards-1 { border-left-color: rgba(209,160,67,0.05); }
#swt-services-cards-2 { border-left-color: rgba(209,160,67,0.08); }
#swt-services-cards-3 { border-left-color: rgba(209,160,67,0.06); }
#swt-services-cards-4 { border-left-color: rgba(209,160,67,0.07); }

@media (max-width:980px) {
  .swt-services-grid { grid-template-columns: 1fr; }
}
@media (max-width:480px) {
  .swt-svc-head h2 { font-size:16px; }
  .swt-svc-item { font-size:13px; padding:9px 10px; }
  .swt-services-grid { gap:16px; }
}
/* end */

/* al raya section */

/* ===== Amenities Grid Cards ===== */
.amenities-grid-wrapper {
  padding: 40px 18px;
  background: #151515;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.amenities-grid-head {
  text-align: center;
  margin-bottom: 28px;
}
.amenities-grid-head h2 {
  font-size: 20px;
  font-weight: 700;
  text-transform: uppercase;
  color: #fff;
  position: relative;
  display: inline-block;
  padding-left: 12px;
}
.amenities-grid-head h2::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 6px;
  background: linear-gradient(180deg, rgba(209,160,67,1), rgba(209,160,67,0.6));
  border-radius: 3px;
}
.amenities-grid-head p {
  color: #bdbdbd;
  font-size: 14px;
  margin: 6px 0 0;
}

.amenities-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 24px;
  width: 100%;
  max-width: 1100px;
}

.amenities-card {
  background: #222;
  border-left: 4px solid rgba(209,160,67,0.3);
  border-radius: 12px;
  padding: 20px;
  box-shadow: 0 10px 28px rgba(0,0,0,0.45);
  transition: all 0.3s ease;
}
.amenities-card:hover {
  transform: translateY(-6px);
  border-left-color: #d1a043;
  box-shadow: 0 18px 36px rgba(209,160,67,0.25);
}

.amenities-card h3 {
  color: #fff;
  font-size: 16px;
  margin-bottom: 12px;
  font-weight: 600;
  text-transform: uppercase;
}

.amenities-card ul {
  list-style: none;
  margin: 0 0 14px;
  padding: 0;
}
.amenities-card ul li {
  font-size: 13.5px;
  color: #e6e6e6;
  margin-bottom: 6px;
  position: relative;
  padding-left: 20px;
}
.amenities-card ul li::before {
  content: '➤';
  position: absolute;
  left: 0;
  color: #d1a043;
  font-weight: 700;
}

.amenities-meta {
  display: flex;
  justify-content: space-between;
  font-size: 13px;
  color: #bdbdbd;
  border-top: 1px solid rgba(255,255,255,0.08);
  padding-top: 10px;
}
.amenities-meta strong {
  color: #d1a043;
}







/* BITS section */

/* ===== Balanced 2x2 Products & Services Grid ===== */
.ps-services-wrapper { 
  padding: 40px 18px; 
  background:#151515; 
}
.ps-services-grid {
  max-width:1200px;
  margin:0 auto;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:28px;
  align-items:start;
  grid-auto-rows: minmax(220px, auto);
  box-sizing: border-box;
}

/* Each section (card container) */
.ps-service-section {
  background: #222;
  border-radius: 12px;
  padding:18px;
  display:flex;
  flex-direction:column;
  box-shadow: 0 10px 28px rgba(0,0,0,0.45);
  border-left: 4px solid rgba(209,160,67,0.06);
}

/* header */
.ps-svc-head { margin-bottom:12px; }
.ps-svc-head h2 {
  font-size:18px;
  color:#fff;
  margin:0 0 6px 0;
  font-weight:700;
  text-transform:uppercase;
  position:relative;
  padding-left:14px;
}
.ps-svc-head h2:before {
  content:'';
  position:absolute;
  left:0; top:0; bottom:0;
  width:6px;
  background: linear-gradient(180deg, rgba(209,160,67,1), rgba(209,160,67,0.6));
  border-radius:3px;
}
.ps-svc-head p {
  margin:0;
  color:#bdbdbd;
  font-size:13px;
  font-weight:500;
}

/* cards-grid */
.ps-cards-grid {
  flex:1;
  display:flex;
  flex-direction:column;
  gap:12px;
  justify-content: space-between;
}

/* two-column inner layout */
.ps-cards-grid.two-col {
  flex-direction:row;
  gap:12px;
}
.ps-cards-grid.two-col .col {
  flex:1;
  display:flex;
  flex-direction:column;
  gap:12px;
  justify-content: space-between;
}

/* individual small cards */
.ps-svc-item {
  background:#1e1e1e;
  border-radius:8px;
  padding:10px 12px;
  color:#e6e6e6;
  font-size:13.5px;
  line-height:1.35;
  border:1px solid rgba(255,255,255,0.02);
  display:flex;
  align-items:center;
  gap:10px;
  transition: all .22s ease;
  box-shadow: 0 6px 14px rgba(0,0,0,0.45);
}
.ps-svc-item:hover {
  transform: translateX(6px);
  background: #d1a043;
  color:#fff;
  border-color:#d1a043;
  box-shadow: 0 18px 36px rgba(209,160,67,0.2);
}

/* arrow icon */
.ps-svc-item::before {
  content:'➤';
  color:#d1a043;
  font-weight:700;
  display:inline-block;
  width:18px;
  text-align:center;
  margin-right:6px;
}
.ps-svc-item:hover::before { 
  color:#fff; 
  transform:translateX(4px); 
}

/* small per-section color tweak */
#ps-services-cards-1 { border-left-color: rgba(209,160,67,0.05); }
#ps-services-cards-2 { border-left-color: rgba(209,160,67,0.08); }
#ps-services-cards-3 { border-left-color: rgba(209,160,67,0.06); }
#ps-services-cards-4 { border-left-color: rgba(209,160,67,0.07); }

/* responsive */
@media (max-width:980px) {
  .ps-services-grid { grid-template-columns: 1fr; }
  .ps-cards-grid.two-col { flex-direction:column; }
}
@media (max-width:480px) {
  .ps-svc-head h2 { font-size:16px; }
  .ps-svc-item { font-size:13px; padding:9px 10px; }
  .ps-services-grid { gap:16px; }
}


/* end */

/* BITS section partners */
/* ===== Partners Carousel ===== */

/* Section Base */
.partners-hover {
  padding: 100px 20px;
  background: #fff;
  text-align: center;
  font-family: "Poppins", sans-serif;
}

.section-title {
  font-size: 3rem;   
  font-weight: 800;
  margin-bottom: 20px;
  color: #111;
  display: inline-block;     /* shrink to text size */
  position: relative;
  padding: 5px 15px;         /* space inside the border */
  line-height: 1.3;
  border: 3px solid rgba(250,200,0,0.3); /* Golden border */
}


.section-subtitle {
  font-size: 1.5rem;   
  color: #555;
  max-width: 900px;
  margin: 0 auto 70px;
  line-height: 1.8;
}

/* Grid */
.partners-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr); /* Always 2 cards side by side */
  gap: 30px;  /* Small gap */
  justify-content: center; /* Center alignment */
  align-items: stretch;
}

/* Partner Card */
.partner-card {
  position: relative;
  width: 100%;
  max-width: 380px;
  height: 460px;
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 6px 20px rgba(0,0,0,0.12);
  cursor: pointer;
  transition: transform 0.3s ease;
  background: #f9f9f9;
  margin: 0 auto; /* Keep centered */
}

.partner-card:hover {
  transform: translateY(-8px);
}

/* Front Face */
.card-front {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 100%;
  padding: 30px;
}

.partner-logo {
  width: 210px;   
  margin-bottom: 20px;
}

.card-front h3 {
  font-size: 2rem;   
  color: #111;
  font-weight: 700;
}

/* Overlay - Premium Dark Theme */
.card-overlay {
  position: absolute;
  inset: 0;
  background: rgba(30, 30, 30, 0.96); /* Deep charcoal */
  color: #fff;
  padding: 45px 30px;
  text-align: left;
  transform: translateY(100%);
  transition: transform 0.4s ease;
}

.partner-card:hover .card-overlay {
  transform: translateY(0);
}

.card-overlay p {
  font-size: 1.4rem;
  margin-bottom: 20px;
  line-height: 1.6;
  color: #fff;
}

.card-overlay ul {
  list-style: disc;
  margin-left: 20px;
  margin-bottom: 25px;
  font-size: 1.3rem;
  line-height: 1.6;
  color: #fff;
}

/* CTA Button */
.cta-link {
  font-size: 1.4rem;
  font-weight: 600;
  color: #1e1e1e;
  background: #f1c40f;  /* Golden yellow */
  padding: 10px 20px;
  border-radius: 6px;
  text-decoration: none;
  transition: background 0.3s ease, color 0.3s ease;
}

.cta-link:hover {
  background: #1e1e1e;  /* Dark on hover */
  color: #f1c40f;       /* Yellow text */
  border: 1px solid #f1c40f;
}

/* Responsive */
@media (max-width: 768px) {
  .section-title {
    font-size: 2.4rem;
  }
  .section-subtitle {
    font-size: 1.2rem;
  }
  .partners-grid {
    grid-template-columns: 1fr; /* Stack on mobile */
  }
  .partner-card {
    height: auto;
    min-height: 400px;
  }
  .card-overlay {
    position: relative;
    transform: none;
    background: #1e1e1e;
    padding: 35px 25px;
  }
  .partner-card:hover .card-overlay {
    transform: none;
  }
}
/* Grid */
.partners-grid {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  gap: 65px;          /* Space between cards */
  flex-wrap: wrap;
  margin: 0 auto;
  max-width: max-content; /* Container adapts to cards + gap */
}


/* Partner Card */
.partner-card {
  flex: 0 0 380px;                /* Fixed width */
  max-width: 380px;
  height: 369px;
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 6px 20px rgba(0,0,0,0.12);
  cursor: pointer;
  transition: transform 0.3s ease;
  background: #f9f9f9;
  margin: 0;
}

/* Overlay - make hover also work on tap/focus */
.partner-card:hover .card-overlay,
.partner-card:active .card-overlay,
.partner-card:focus-within .card-overlay {
  transform: translateY(0);
}
/* Enable tap-to-open on mobile */
@media (max-width: 768px) {
  .card-overlay {
    position: absolute;
    inset: 0;
    background: rgba(30, 30, 30, 0.96);
    transform: translateY(100%);  /* keep hidden initially */
    transition: transform 0.4s ease;
  }

  /* Show overlay on hover, active or focus */
  .partner-card:hover .card-overlay,
  .partner-card:active .card-overlay,
  .partner-card:focus-within .card-overlay {
    transform: translateY(0);
  }
}



/* target market section */
/* ===== Target Market Section ===== */



/* partners new logos */
.partners {
  text-align: left;
  padding: 60px 20px;
  background: #f7f7f7; /* light grey background */
}

.partners-heading {
  position: relative;
  display: inline-block;       /* shrink-wrap so outline sits nicely */
  padding-left: 24px;         /* room for the left box */
  padding-right: 10px;
  line-height: 55px;          /* keep your preferred height */
  font-size: 26px;
  font-weight: 800;
  font-family: 'Raleway', sans-serif;
  color: #111;
  margin-bottom: 40px;
  background: transparent !important; /* override any white bg */
  z-index: 2;                 /* stay above the :before box */
  margin-left: 188px;   /* align with grid */
  margin-bottom: 70px;
}

/* transparent yellow outline behind the text */
.partners-heading::before {
  content: "";
  box-sizing: border-box;     /* border counts in width/height */
  position: absolute;
  top: 0;
  left: 0;
  width: 202px;               /* change this if you want narrower/wider */
  height: 100%;
  border: 3px solid rgba(250,200,0,0.3);
  background: transparent !important; /* ensure no fill */
  z-index: 1;                 /* behind text, above section bg */
  pointer-events: none;
}


.partners-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr); /* 6 logos per row */
  gap: 11px; /* very little gap */
  justify-content: center;
  align-items: center;
  max-width: 912px;
  margin: 0 auto;
  margin-top: 62px;
}

.partners-grid img {
  max-height: 235px;   /* bigger logos */
  padding: 1px;       /* a bit more breathing room */
  background: rgba(255, 255, 255, 0.7);
  border-radius: 12px;
  backdrop-filter: blur(6px);
  filter: grayscale(100%);
  transition: all 0.3s ease;
}

.partners-grid img:hover {
  filter: grayscale(0%);
  background: rgba(255, 255, 255, 0.95);
  transform: scale(1.05);
  box-shadow: 0 6px 20px rgba(0,0,0,0.25);
}



.partners-more {
  text-align: center;
  margin-top: 35px;
}

.btn-outline {
  display: inline-block;
  padding: 16px 40px;  /* bigger size */
  font-size: 1.1rem;   /* slightly larger text */
  font-weight: 600;
  color: #e0a800;      /* lighter yellow */
  border: 2px solid #e0a800;
  border-radius: 6px;
  text-decoration: none;
  transition: all 0.3s ease;
}

.btn-outline:hover {
  background-color: #e0a800; /* light yellow fill */
  color: #fff;
}
.partners-heading {
  margin-left: 188px;
}

@media (max-width: 1024px) {
  .partners-heading {
    margin-left: 80px; /* smaller margin for tablets */
  }
}

@media (max-width: 768px) {
  .partners-heading {
    margin-left: 20px; /* nearly flush on mobile */
    font-size: 22px;   /* smaller text */
  }
}


/* same client for grey background */

/* clients new logos */
.clients {
  text-align: left;
  padding: 60px 20px;
  background: #f7f7f7; /* light grey background */
}

.clients-heading {
  position: relative;
  display: inline-block;
  padding-left: 24px;
  padding-right: 10px;
  line-height: 55px;
  font-size: 26px;
  font-weight: 800;
  font-family: 'Raleway', sans-serif;
  color: #111;
  margin-bottom: 70px;
  background: transparent !important;
  z-index: 2;
  margin-left: 144px; /* align with grid */
}

/* transparent yellow outline behind the text */
.clients-heading::before {
  content: "";
  box-sizing: border-box;
  position: absolute;
  top: 0;
  left: 0;
  width: 202px;
  height: 100%;
  border: 3px solid rgba(250,200,0,0.3);
  background: transparent !important;
  z-index: 1;
  pointer-events: none;
}

.clients-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr); /* 6 logos per row */
  gap: 11px;
  justify-content: center;
  align-items: center;
  max-width: 912px;
  margin: 0 auto;
 
}

.clients-grid img {
  max-height: 235px;
  padding: 1px;
  background: rgba(255, 255, 255, 0.7);
  border-radius: 12px;
  backdrop-filter: blur(6px);
  filter: grayscale(100%);
  transition: all 0.3s ease;
}

.clients-grid img:hover {
  filter: grayscale(0%);
  background: rgba(255, 255, 255, 0.95);
  transform: scale(1.05);
  box-shadow: 0 6px 20px rgba(0,0,0,0.25);
}

.clients-more {
  text-align: center;
  margin-top: 35px;
}

.btn-outline-clients {
  display: inline-block;
  padding: 16px 40px;
  font-size: 1.1rem;
  font-weight: 600;
  color: #e0a800;
  border: 2px solid #e0a800;
  border-radius: 6px;
  text-decoration: none;
  transition: all 0.3s ease;
}

.btn-outline-clients:hover {
  background-color: #e0a800;
  color: #fff;
}

/* responsive tweaks */
@media (max-width: 1024px) {
  .clients-heading {
    margin-left: 65px;
  }
}

@media (max-width: 768px) {
  .clients-heading {
    margin-left: 0;       /* remove big left margin */
    text-align: center;   /* keep centered on mobile */
    font-size: 22px;
  }

  .clients-grid {
    grid-template-columns: repeat(3, 1fr); /* 3 logos per row */
    gap: 8px;
  }
}



/* end */

/* main client section */

/* main client page logos */
.main-clients-section {
  text-align: left;
  padding: 0px 0px;
  background: #ffffff;
  margin-top: 50px;
  margin-bottom: 100px;
}

.main-clients-heading {
  position: relative;
  display: inline-block;
  padding-left: 24px;
  padding-right: 10px;
  line-height: 55px;
  font-size: 26px;
  font-weight: 800;
  font-family: 'Raleway', sans-serif;
  color: #111;
  margin-bottom: 70px;
  background: transparent !important;
  z-index: 2;
  margin-left: 188px;  /* desktop spacing */
}

.main-clients-heading::before {
  content: "";
  box-sizing: border-box;
  position: absolute;
  top: 0;
  left: 0;
  width: 202px;
  height: 100%;
  border: 3px solid rgba(250,200,0,0.3);
  background: transparent !important;
  z-index: 1;
  pointer-events: none;
}

.main-clients-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr); /* desktop default */
  gap: 12px; 
  justify-content: center;
  align-items: center;
  max-width: 1100px;
  margin: 0 auto;
  margin-top: 50px;
}

.main-clients-grid img {
  max-height: 160px;
  padding: 15px;
  background: #fff;
  border: 1px solid #ccc;
  border-radius: 8px;
  display: block;
  margin: auto;
  filter: none;
  transition: all 0.3s ease;
}

.main-clients-grid img:hover {
  background: #fff;
  border-color: #aaa;
  transform: scale(1.05);
  box-shadow: 0 6px 20px rgba(0,0,0,0.15);
}

/* ✅ Responsive tweaks */
@media (max-width: 1200px) {
  .main-clients-grid {
    grid-template-columns: repeat(4, 1fr);
    gap: 10px;
  }
  .main-clients-heading {
    margin-left: 80px;
  }
}

@media (max-width: 991px) {
  .main-clients-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
  }
  .main-clients-heading {
    margin-left: 40px;
    font-size: 24px;
  }
}

@media (max-width: 768px) {
  .main-clients-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
    max-width: 78%;  /* fit smaller screens */}
  .main-clients-grid img {
    max-height: 130px;
    padding: 8px;
  }
}

@media (max-width: 480px) {
  .main-clients-grid {
    grid-template-columns: repeat(3 1fr);
    gap: 6px;
    margin-top: -18px;  
  }
  .main-clients-grid img {
    max-height: 90px;
    padding: 6px;
  }
}

/* ===== BITS Partners Section (scoped) ===== */
.bits-partners {
  padding: 100px 20px;
  background: #fff;
  text-align: center;
  font-family: "Poppins", sans-serif;
}

.bits-section-title {
  font-size: 2.8rem;
  font-weight: 800;
  margin-bottom: 20px;
  color: #111;
  display: inline-block;
  padding: 5px 15px;
  border: 3px solid rgba(250,200,0,0.3);
}

.bits-section-subtitle {
  font-size: 1.4rem;
  color: #555;
  max-width: 900px;
  margin: 0 auto 60px;
  line-height: 1.8;
}

/* Grid */
.bits-partners-grid {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  gap: 65px;
  flex-wrap: wrap;
  margin: 0 auto;
  max-width: max-content;
}

/* Partner Card */
.bits-partner-card {
  flex: 0 0 380px;
  max-width: 380px;
  height: 380px;
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 6px 20px rgba(0,0,0,0.12);
  background: #f9f9f9;
  position: relative;
  transition: transform 0.3s ease;
  cursor: pointer;
}

.bits-partner-card:hover {
  transform: translateY(-8px);
}

.bits-card-front {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  height: 100%;
  padding: 30px;
}

.bits-partner-logo {
  width: 210px;
  margin-bottom: 20px;
}

.bits-card-front h3 {
  font-size: 1.4rem;
  color: #111;
  font-weight: 700;
}

/* Overlay */
.bits-card-overlay {
  position: absolute;
  inset: 0;
  background: rgba(30,30,30,0.96);
  color: #fff;
  padding: 40px 28px;
  text-align: left;
  transform: translateY(100%);
  transition: transform 0.4s ease;
}

/* Hover effect for desktop */
.bits-partner-card:hover .bits-card-overlay {
  transform: translateY(0);
}

/* Touch effect for mobile - same as hover */
.bits-partner-card.active .bits-card-overlay {
  transform: translateY(0);
}

.bits-card-overlay p {
  font-size: 1.3rem;
  margin-bottom: 20px;
  line-height: 1.6;
  color: #fff;
}

.bits-card-overlay ul {
  list-style: disc;
  margin: 0 0 25px 20px;
  padding: 0;
  font-size: 1.2rem;
  line-height: 1.6;
  color: #fff;
}

/* CTA Button */
.bits-cta-link {
  font-size: 1.3rem;
  font-weight: 600;
  color: #1e1e1e;
  background: #f1c40f;
  padding: 10px 20px;
  border-radius: 6px;
  text-decoration: none;
  display: inline-block;
  transition: all 0.3s ease;
}

.bits-cta-link:hover {
  background: #1e1e1e;
  color: #f1c40f;
  border: 1px solid #f1c40f;
}

/* Mobile adjustments - keep same size and effect */
@media (max-width: 768px) {
  .bits-partners {
    padding: 60px 20px;
  }
  
  .bits-section-title {
    font-size: 2.2rem;
  }
  
  .bits-section-subtitle {
    font-size: 1.2rem;
  }
  
  .bits-partners-grid {
    flex-direction: column;
    gap: 40px;
  }
  
  .bits-partner-card {
    width: 90%;
    max-width: 380px;
  }
  
  .bits-card-overlay {
    padding: 35px 25px;
  }
  
  .bits-card-overlay p {
    font-size: 1.2rem;
  }
  
  .bits-card-overlay ul {
    font-size: 1.1rem;
  }
}



/* end */

/* mobile nav bar */
/* =======================
   FINAL MOBILE NAVBAR FIX
   ======================= */
@media (max-width: 991px) {
  /* Hide the desktop version completely */
  .theme-menu-two { display: none !important; }

  .mobile-navbar {
    background: linear-gradient(180deg, #1e4fa0 0%, #0f285f 100%);
    border-radius: 12px;
    box-shadow: 0 8px 25px rgba(0,0,0,0.3);
    padding: 10px 14px;
    width: 90%;
    margin: 12px auto;
  }

  .mobile-nav-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }

  .quote-btn {
    background: #fac800;
    color: #111;
    padding: 8px 14px;
    border-radius: 8px;
    font-weight: 600;
    text-decoration: none;
  }

  /* Hamburger */
  .hamburger {
    background: transparent;
    border: none;
    cursor: pointer;
    width: 34px;
  }
  .hamburger span {
    display: block;
    height: 3px;
    background: #fff;
    margin: 6px 0;
    border-radius: 3px;
    transition: all 0.3s ease;
  }
  .hamburger.active span:nth-child(1) {
    transform: translateY(9px) rotate(45deg);
    background: #fac800;
  }
  .hamburger.active span:nth-child(2) { opacity: 0; }
  .hamburger.active span:nth-child(3) {
    transform: translateY(-9px) rotate(-45deg);
    background: #fac800;
  }

  /* Menu Container */
  .mobile-nav-links {
    display: none;
    background: #0f285f;
    margin-top: 10px;
    border-radius: 10px;
    box-shadow: 0 4px 20px rgba(0,0,0,0.2);
  }
  .mobile-nav-links.open {
    display: block;
    animation: fadeSlide 0.4s ease forwards;
  }

  .mobile-nav-links a,
  .mobile-nav-links button {
    display: block;
    color: #fff;
    font-size: 15px;
    padding: 10px 14px;
    text-decoration: none;
    border-bottom: 1px solid rgba(255,255,255,0.1);
    background: transparent;
    width: 100%;
    text-align: left;
    transition: all 0.3s ease;
  }

  .mobile-nav-links a:hover,
  .mobile-nav-links button:hover {
    background: rgba(250,200,0,0.15);
    color: #fac800;
  }

  /* Dropdown Menus */
  .dropdown-menu, .sub-menu {
    display: none;
    background: #183573;
  }
  .dropdown-menu.open, .sub-menu.open {
    display: block;
    animation: fadeSlide 0.4s ease forwards;
  }

  /* Sub dropdown header */
  .sub-dropdown button {
    background: #1b366f;
    border-left: 3px solid #fac800;
  }
  .sub-menu a {
    padding-left: 28px;
    font-size: 14px;
    color: #eaeaea;
  }

  @keyframes fadeSlide {
    from { opacity: 0; transform: translateY(-10px); }
    to { opacity: 1; transform: translateY(0); }
  }
}

/* Hide mobile navbar on desktop */
@media (min-width: 992px) {
  .mobile-navbar { display: none !important; }
}






/* end */


/* ====== SEARCH DROPDOWN ONLY ====== */
.search-results {
  position: absolute;
  top: 100%;
  left: 0;
  width: 100%;
  background: #fff;
  border: 1px solid #ddd;
  border-radius: 6px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
  padding: 6px 0;
  margin-top: 5px;
  display: none;
  z-index: 9999;
  opacity: 0;
  transform: translateY(-5px);
  transition: all 0.25s ease;
}

.search-results.show {
  opacity: 1;
  transform: translateY(0);
  display: block;
}

.search-results a.result-item {
  display: block;
  padding: 10px 16px;
  color: #76808a;
  text-decoration: none;
  font-size: 15px;
  border-bottom: 1px solid #f1f1f1;
  transition: background 0.2s, color 0.2s;
}

.search-results a.result-item:last-child {
  border-bottom: none;
}

.search-results a.result-item:hover {
  background: #fff8cc; /* light yellow background */
  color: #222; /* keep text readable */
}

.search-results .no-results {
  padding: 10px 16px;
  color: #777;
  font-style: italic;
}



/* end */


/* our client <p> */

.clients-description {
  text-align: center;
  max-width: 800px;
  margin: 10px auto 40px auto;
  font-size: 19px;
  line-height: 28px;
  color: #555; /* or adjust to your theme color */
  margin-top: -33px;
}

/* END */




/* ===== Force Company Info Background Stability ===== */
/* ===== Company Info Background - No Jump on Refresh ===== */
.company-info {
  background: url(../images/home/1.jpg) no-repeat center center !important;
  background-size: cover !important;
  background-attachment: fixed !important;
  margin: 110px 0 0 0;
}

.company-info .opacity {
  height: 100%;
  background: rgba(19,68,141,0.9);
  padding: 75px 0 75px 0;
}


/* END */