/* Reset CSS */
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, font, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
dl, dt, dd, ol, 
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td {
	margin: 0;
	padding: 0;
	border: 0;
	outline: 0;
	font-weight: inherit;
	font-style: inherit;
	font-size: 100%;
	font-family: inherit;
	vertical-align: baseline;
}
/* remember to define focus styles! */
:focus {
	outline: 0;
}
body {
	line-height:1;
	color: black;
	background: white;
}
ol, ul {
	/*list-style: none;*/
}
/* tables still need 'cellspacing="0"' in the markup */
table {
	border-collapse: separate;
	border-spacing: 0;
}
caption, th, td {
	text-align: left;
	font-weight: normal;
}
blockquote:before, blockquote:after,
q:before, q:after {
	content: "";
}
blockquote, q {
	quotes: "" "";
}


/* Custom Fonts */
@font-face {
  font-family: 'Inter';
  src: url('./fonts/Inter-Regular.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Inter';
  src: url('./fonts/Inter-SemiBold.woff2') format('woff2');
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Inter';
  src: url('./fonts/Inter-Bold.woff2') format('woff2');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}


/* CSS Document */
a { outline:none;  }
a img { border:0; outline:0; }
.clearboth { width:100%; clear:both; height:0; overflow:hidden; }
img { max-width: 100%; }

ul,ol { list-style-position:inside; padding-left:0; margin-bottom:20px; }
ul li,
ol li { font-size:18px; line-height:20px; color:#6C7084;  font-family:'Inter', Arial, Helvetica, sans-serif; }

p { font-size:18px; line-height:28px; color:#6C7084;  font-family:'', Arial, Helvetica, sans-serif; }


.loader {
  border: 4px solid #f3f3f3; /* Light grey */
  border-top: 4px solid #f47423; /* Blue */
  border-radius: 50%;
  width: 30px;
  height: 30px;
  margin:0 auto;
  animation: spin 2s linear infinite;
}

@keyframes spin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}


body { background-color: #ffffff; font-size:18px; line-height:20px; color:#6C7084;  font-family:'Inter','Segoe UI', Arial, Helvetica, sans-serif; }

.btn-primary { display: inline-block; margin-top:20px; height: 44px; line-height: 40px; font-size: 18px; text-decoration: none; border:2px solid #434345; color:#434345; background: none; padding:0 28px; font-family: 'Segoe UI Semibold'; -webkit-border-radius: 120px; -moz-border-radius: 120px; border-radius: 120px; transition: all 0.1s linear; }
.btn-primary:hover { border-color: #ff6300; background-color: #ff6300; color:#ffffff; }

.mobile-menu { display: none; width: 48px; height: 40px; padding: 11px; position: absolute; left:12px; top:20px; }
.mobile-menu:before,
.mobile-menu:after { content: ''; display: block; background: #034170; height: 2px; }
.mobile-menu span { background: #034170; display: block; height: 2px; margin: 6px 0; }

nav#menu ul li { color:#034170; font-size:14px; line-height: 20px; }
nav#menu ul li.social-icon { }
nav#menu ul li.social-icon a { display: inline-block; flex:none; padding: 20px; opacity: 0.4; vertical-align: bottom; }
nav#menu ul li.social-icon img {  height: 20px; } 


.header-wrap { background-color:#ffffff; }
.header-top-inner { width: 1170px; height: 118px; border-bottom:1px solid #EFEFEF; margin:0 auto; position: relative; }
.header-top-inner .head-logo { float:left; margin: 14px 0 0 0; }
.header-top-inner .head-logo img { height: 90px; }
.header-top-inner .head-contact-details { float:right; margin-top:35px; }
.header-top-inner .head-contact-details .each-info { float:left; padding:0 0 0 68px; position: relative; margin-left: 50px; min-height: 49px; position: relative; }
.header-top-inner .head-contact-details .each-info .circle { position: absolute; left:0; top:0; width: 48px; height: 48px; text-align: center; background-color:#f47423; -webkit-border-radius: 120px; -moz-border-radius: 120px; border-radius: 120px; }
.header-top-inner .head-contact-details .each-info .circle img { height: 24px; margin-top:12px; }
.header-top-inner .head-contact-details .each-info .text { font-size: 16px; line-height: 24px; color:#434345;  }
.header-top-inner .head-contact-details .each-info .text span { display:block; color:#999999; }
.header-top-inner .head-contact-details .each-info .text a { color:#434345; text-decoration: none; }
.header-top-inner .head-contact-details .each-info .text a:hover { color:#f47423; }


.header-bottom-inner { width: 1170px; margin:0 auto; height: 70px; }
.header-bottom-inner ul.main-menu { float:left; padding:0; margin:0; list-style: none; }
.header-bottom-inner ul.main-menu li { float:left; margin:23px 75px 0 0; }
.header-bottom-inner ul.main-menu li a { display:block; color:#434345; font-size:14px; line-height: 20px; font-weight: bold; text-transform: uppercase; letter-spacing: 1px; text-decoration: none; }
.header-bottom-inner ul.main-menu li.active a { color:#ff6300; }
.header-bottom-inner ul.main-menu li a:hover { color:#ff6300;}


.header-bottom-inner ul.social-icons { float:right; padding:0; margin:0; list-style: none; }
.header-bottom-inner ul.social-icons li { float:left; margin:25px 0 0 30px; }
.header-bottom-inner ul.social-icons li a { display:block; opacity: 0.4; }
.header-bottom-inner ul.social-icons li a:hover { opacity: 1; }
.header-bottom-inner ul.social-icons li img { height: 20px; vertical-align: bottom; }

.homepage-banner { background-color:#034170; background-repeat: no-repeat; background-size: cover; background-position: center top; position: relative; }
.homepage-banner:after { content:" "; position: absolute; left:0; top:0; width:100%; height:100%; background-color: #000; opacity: 0.50; }
.homepage-banner-inner { width:1170px; height: 600px; display: flex; flex-direction:row; flex-wrap:nowrap; justify-content:flex-start;  margin:0 auto; position: relative; z-index: 10; }
.homepage-banner-inner .banner-caption { align-self:center; max-width: 800px;  }
.homepage-banner-inner .banner-caption h1.title { font-size:42px; line-height: 52px; font-weight: normal; color:#ffffff; letter-spacing: -1px; font-family: 'Segoe UI Semibold'; }
.homepage-banner-inner .banner-caption .sub-text { font-size:20px; color:#ffffff; line-height: 26px; padding:14px 0 30px 0; padding-right: 100px; }


h1.section-title { font-size: 40px; line-height: 44px; letter-spacing: -1px; color:#434345; margin-bottom: 25px;  font-family: 'Segoe UI Semibold'; }
h1.section-title .sub-title { display:block; color:#f47423; font-size: 20px; letter-spacing: normal; line-height: 28px; padding-bottom: 15px; }

p { margin-bottom: 40px; }

ul.check-list { padding:0; margin:0; list-style: none; }
ul.check-list li { font-size: 18px; line-height: 26px; padding:0 0 0 38px; margin-bottom: 14px; color:#202020; background-image: url('../images/Check_circle.svg'); background-size: 23px 23px;  background-repeat: no-repeat; background-position: 1px 2px; }
ul.check-list li b { font-weight: 400; font-family: 'Segoe UI Semibold'; }

ul.check-list.two-col li { display: inline-block; width: 48%; }


.about-section-wrap { padding:140px 0; overflow:hidden; }
.about-section-wrap-inner { width:1170px; margin:0 auto; }
.about-section-wrap-inner .image-left { width: 672px; float:left; position: relative; z-index: 1; }
.about-section-wrap-inner .image-left img { max-width: 100%; position: relative; z-index: 10; border-radius: 6px; }
.about-section-wrap-inner .bg-design-1 { width: 125px; height: 125px; position: absolute; left:-62px; top:-62px; z-index: 1; background-image: url('../images/bg_marker02.png'); background-repeat: no-repeat; background-size: 125px 125px; opacity: 0.15; }
.about-section-wrap-inner .bg-design-2 { width: 125px; height: 125px; position: absolute; right:72px; bottom:-96px; z-index: 1; background-image: url('../images/bg_marker02.png'); background-repeat: no-repeat; background-size: 125px 125px; opacity: 0.15; }
.about-section-wrap-inner .about-text-col { width: 650px; padding:40px; margin:90px 0 0 -155px; position: relative; z-index: 5; float:left; background-color: #ffffff; border-radius: 6px; box-sizing:border-box; box-shadow: 0px 3px 6px rgba(0,0,0,0.08); }
.about-section-wrap-inner .about-text-col p { margin-bottom: 20px; }
.about-section-wrap-inner .about-text-col ul.check-list { padding-top:20px; }

.services-section-wrap { padding:140px 0 0; overflow:hidden; background-color:#EFF2F7; background-image:url(../images/services-bg-image-1.png); background-repeat: no-repeat; background-position: top center;  }
.services-section-wrap-inner { width:1170px; margin:0 auto; }
.services-section-wrap-inner h1.section-title { text-align: center; }
.services-section-wrap-inner .intro-text { text-align: center; max-width: 600px; margin:0 auto; padding-bottom: 80px; }

.services-list { display: flex; flex-wrap: wrap;  clear:both; margin:0 -15px; }
.services-list .each-service-col { display:flex; flex-wrap:wrap; flex: 0 0 50%; max-width: 50%; padding-bottom: 30px; padding-left: 15px; padding-right: 15px; box-sizing:border-box; -moz-box-sizing:border-box;  }
.services-list .each-service { border-top:5px solid rgba(0,0,0,0.15); padding:50px 30px 30px; background-color: #ffffff; border-radius: 6px; box-sizing:border-box; box-shadow: 0px 3px 6px rgba(0,0,0,0.08); }
.services-list .each-service .icon-wrap { padding-bottom: 20px; }
.services-list .each-service .icon-wrap img { height: 69px; }
.services-list .each-service h3.service-name { font-size: 22px; line-height: 30px; margin-bottom: 20px; color:#434345; font-family: 'Segoe UI Semibold'; }
.services-list .each-service p { margin-bottom: 20px; }

.services-list-wrap2 { background-color: #fafafa; padding-bottom: 110px; }
.services-list-inner2 { width:1170px; margin:-26px auto 0 auto; }

.services-tabs { position: relative; top:-45px; margin-left: -1%; margin-right:-1%; display: flex; flex-direction: row; flex-wrap: wrap; justify-content: center; align-content: flex-start; align-items: flex-start; }
.services-tabs .tab-nav-item { width:18%; margin-left: 1%; margin-right: 1%; text-decoration: none; transition: all 0.1s linear; border:1px solid #ffffff; vertical-align: top; position: relative; min-width: 175px; min-height: 90px; font-size: 18px; line-height: 24px; padding: 10px 36px 10px; box-shadow: 0px 3px 6px rgba(0,0,0,0.08); color:#434345; background-color: #ffffff; border-radius: 6px; display: inline-flex; font-family: 'Inter'; display: inline-flex; flex-direction: column; flex-wrap: wrap;justify-content: center; align-content: flex-start;align-items: flex-start; cursor: pointer; }
.services-tabs .tab-nav-item .ttext { display: inline-block; position: relative; }
.services-tabs .tab-nav-item:after { content: "+";  font-family:'Inter', Arial, Helvetica, sans-serif;  position: absolute; top: 1px;left: 5px;font-size: 20px; line-height: 20px; }
.services-tabs .tab-nav-item.tab-active { color:#ffffff; background-color:#434345; border-color:#434345; }
.services-tabs .tab-nav-item:hover { border-color:#434345; }


.services-tab-content { min-height: 200px; overflow: hidden; }
.services-tab-content .text-column { width: 65%; float:left; }
.services-tab-content h2.service-name { font-size: 40px; line-height: 44px;letter-spacing: -1px; color: #434345; margin-bottom: 35px;  font-family: 'Segoe UI Semibold'; }
.services-tab-content p { margin-bottom: 25px; }
.services-tab-content .image-column { width: 32%; float: right; padding-top:85px;  }
.services-tab-content .image-column img { max-width: 100%; display: block; border-radius: 6px; }


.services-tab-content h3 { font-size: 24px; letter-spacing: -1px; color: #434345; margin:30px 0 15px;  font-family: 'Segoe UI Semibold'; } 
.services-tab-content .h4 { display: block; padding:4px 0 4px; color:#434345; font-size: 19px; font-family: 'Segoe UI Semibold';  }

.services-tab-content .sub-tabs { padding:0; margin:0 0 30px; list-style: none; border-bottom: 1px solid #EFEFEF; }
.services-tab-content .sub-tabs a { display: inline-block; margin-right: 15px; text-decoration: none; padding:12px 20px;  font-size: 20px; font-family: 'Segoe UI Semibold'; color:#434345; -webkit-border-top-left-radius: 6px; -webkit-border-top-right-radius: 6px; -moz-border-radius-topleft: 6px; -moz-border-radius-topright: 6px; border-top-left-radius: 6px; border-top-right-radius: 6px; }
.services-tab-content .sub-tabs a.subtab-active { border-bottom:2px solid #f47423; color:#f47423; }

.services-tab-content .list-of-services { width: 50%; float:left; overflow:hidden; padding-top:10px; }
.services-tab-content .list-of-services li { padding-right: 10px; } 




.know-more-section-wrap { padding:140px 0; overflow:hidden; background-color: #ffffff; }
.know-more-section-wrap-inner { width:1170px; margin:0 auto; }

.know-more-tabs { margin-left: -7px; margin-right: -7px; ; display: flex; flex-direction: row; flex-wrap: wrap; justify-content: center; align-content: flex-start; align-items: flex-start; }
.know-more-tabs .tab-nav-item { flex-grow:1; text-decoration: none; transition: all 0.1s linear; border:1px solid #ffffff; vertical-align: top; position: relative; margin-left: 7px; margin-right: 7px; min-width: 175px; min-height: 90px; font-size: 20px; letter-spacing: -0.5px; line-height: 24px; padding: 10px 36px 10px; box-shadow: 0px 3px 6px rgba(0,0,0,0.08); color:#434345; background-color: #ffffff; border-radius: 6px; display: inline-flex; font-family: 'Inter'; display: inline-flex; flex-direction: column; flex-wrap: wrap;justify-content: center; align-content: flex-start;align-items: flex-start; cursor: pointer; }
.know-more-tabs .tab-nav-item .ttext { display: inline-block; position: relative; }
.know-more-tabs .tab-nav-item:after { content: "+";  font-family:'Inter', Arial, Helvetica, sans-serif;  position: absolute; top: 1px;left: 5px;font-size: 20px; line-height: 20px; }
.know-more-tabs .tab-nav-item.km-tab-active { color:#ffffff; background-color:#434345; border-color:#434345; }
.know-more-tabs .tab-nav-item:hover { border-color:#434345; }

.know-more-tabs-stage { padding: 60px 0 0 0; }
.know-more-tab-content { overflow: hidden; }
.know-more-tab-content .left-column { width:52%; float:left; padding-top:30px; }
.know-more-tab-content .right-column { width:42%; float:right; }
.know-more-tab-content .right-column img { border-radius: 4px; }
.know-more-tab-content .right-column .column-1 { width:50%; float:left; }
.know-more-tab-content .right-column .column-2 { width:50%; float:right; padding-top:30px; }
.know-more-tab-content .small-box { text-align: center; border-bottom:1px solid #f47423; display:block; width: auto; min-height: 240px; padding:50px 30px 30px; margin:30px 15px 0; box-sizing:border-box; background-color: #F1F4F7; border-radius: 6px; }
.know-more-tab-content .small-box p { margin-bottom: 20px; }
.know-more-tab-content .small-box .icon-img { height: 88px; }
.know-more-tab-content .small-box .b-title { padding:20px 0 8px; font-size:20px; line-height: 28px; color:#434345; font-family: 'Inter'; } 


/* Contact Section */
.contact-section-wrap { padding:140px 0; overflow:hidden; background-color: #F4F4F4; background-image:url(../images/circuit-bg.png); background-repeat: no-repeat; background-position: top right; }
.contact-section-wrap-inner { width:1170px; margin:0 auto; display: flex; }
.contact-section-wrap-inner h1.section-title { text-align: left; }

.contact-section-wrap .contact-left-column { width: 60%; display: block; margin:0 auto; padding:32px; background-color: #ffffff; border-radius: 6px; -webkit-box-sizing: border-box; box-sizing:border-box; box-shadow: 0px 3px 6px rgba(0,0,0,0.08); }
.contact-section-wrap .contact-left-column .text1 { color:#434345;  font-family: 'Segoe UI Semibold';  }
.contact-section-wrap .contact-left-column .each-contact-info { padding: 0 0 0 46px; margin-bottom: 20px; font-size: 18px; line-height: 24px; color:#6C7084; position: relative; min-height: 49px; }
.contact-section-wrap .contact-left-column .each-contact-info span { display: block; color:#f47423; font-family: 'Segoe UI Semibold'; }
.contact-section-wrap .contact-left-column .each-contact-info a { color:#6C7084; text-decoration: none; }
.contact-section-wrap .contact-left-column .each-contact-info a:hover { text-decoration: underline; }
.contact-section-wrap .contact-left-column .each-contact-info .icon { width: 24px; position: absolute; left:0; top:1px; }

.contact-social-media { overflow: hidden; padding-top: 30px; }
.contact-social-media .each-box { float:left; text-align: center; width: 50px; height: 50px; margin-right: 10px; border-radius: 6px; background-color:rgba(244,116,35,0.05); }
.contact-social-media .each-box:hover { background-color:rgba(244,116,35,0.15); }

.contact-social-media .each-box img { height: 18px; position: relative; top:16px; }

.contact-section-wrap .contact-right-column { width: 57%; margin-left: 3%; float: right; padding:32px; background-color: #ffffff; border-radius: 6px; -webkit-box-sizing: border-box; box-sizing:border-box; box-shadow: 0px 3px 6px rgba(0,0,0,0.08); }
.contact-section-wrap .contact-right-column h3 { letter-spacing: -1px; color: #434345; font-size: 25px; line-height: 35px; margin-bottom: 25px; font-family: 'Segoe UI Semibold'; }

.contact-form { margin:0 auto; padding:0; }
.contact-form input.textbox {  width: 100%; height: 46px; font-size: 15px; color:#000; line-height: normal; padding:0 20px; box-sizing:border-box; border-radius: 6px; background-color:#fafafa; border:1px solid #EBEBEB; box-shadow: 0px 2px 4px rgba(0,0,0,0.06);  font-family:'Inter', Arial, Helvetica, sans-serif; }
.contact-form input.textbox:focus,
.contact-form input.textbox:active,
.contact-form textarea:focus,
.contact-form textarea:active { border-color:#f47423; }
.contact-form label.text { display: inline-block; font-size:15px; color:#6C7084; padding-bottom: 10px; }
.contact-form .each-row { padding-bottom: 30px; margin:0 -15px; overflow:hidden; }
.contact-form .col-12 { width: 100%; padding:0 15px; box-sizing:border-box; }
.contact-form .col-6 { float:left; width: 50%; padding:0 15px; box-sizing:border-box; }
.contact-form textarea { width: 100%; height: 150px; font-size: 15px; color:#000; line-height: normal; padding:15px 20px; box-sizing:border-box; border-radius: 6px; background-color:#fafafa; border:1px solid #EBEBEB; box-shadow: 0px 2px 4px rgba(0,0,0,0.06);  font-family:'Inter', Arial, Helvetica, sans-serif; }
.contact-form input.textbox.error,
 .contact-form textarea.error { border-color:#ff2828; }

.checkboxgroup { padding-bottom: 10px; }
.checkboxgroup p { font-size: 15px; color:#6C7084; margin-bottom:0; }
.checkboxgroup label { display:inline-block; font-size: 15px; margin-right: 15px; margin-top: 12px!important; color:#434345; }

.contact-form .submit-btn { width: 180px; height: 55px; line-height: normal; font-size: 18px; color: #ffffff; background: #f47423; text-align: center; border-radius: 36px; border:0; font-family:'Segoe UI Semibold', Arial, Helvetica, sans-serif; cursor: pointer; transition: all 0.1s linear; }
.contact-form .submit-btn:hover { background-color: #ff6300; }
.contact-form .submit-btn.hide-text .btn-txt { display:none; }
.contact-form .submit-btn .loader { display: none; }
.contact-form .submit-btn:disabled { background: #dddddd; cursor: not-allowed; }

.name-error, .email-error, .message-error, .error { display: block; font-size: 14px; padding:2px 0; color: #ff2828;}
.success { display:none; background: #e0ffc7; padding:10px 14px; margin:0 0 15px; border-radius: 6px; font-size:15px; color: #507e05; }

.footer-wrap { background-color: #434345; padding:40px 0; }
.footer-wrap-inner { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; width:1170px; margin:0 auto; overflow: hidden; }
.footer-wrap-inner ul.foot-links { float:left; padding:0; margin:0; list-style: none; }
.footer-wrap-inner ul.foot-links li { float:left; font-size: 14px; color:#ffffff; }
.footer-wrap-inner ul.foot-links li.separator { padding:0 15px; }
.footer-wrap-inner ul.foot-links li a { color:#ffffff; font-size: 14px; text-decoration: none; }
.footer-wrap-inner ul.foot-links li a:hover { text-decoration: underline; }
.footer-wrap-inner .foot-copyright{ color:#ffffff; font-size: 14px;  }






/**********************************************/
/*** Responsive Layout ***/
/**********************************************/


@media only screen and (max-width:1170px) { 


    .header-top-inner { width: auto; padding:0 20px; }
    .header-bottom-inner { width: auto; padding:0 20px; }

    .homepage-banner-inner { width: auto; padding:0 20px; }
    .about-section-wrap-inner { width: auto; padding:0 20px; }
    .services-section-wrap-inner { width: auto; padding:0 20px; }
    .services-section-wrap-inner { width: auto; padding:0 20px; }
    .footer-wrap-inner { width: auto; padding:0 20px; }


    .about-section-wrap-inner .image-left { width: 60%; }
    .about-section-wrap-inner .about-text-col { width: 50%; margin-left: -10%; }


    .services-list { /* grid-template-columns: 33% 33% 33%; grid-template-rows: 400px 400px; grid-row-gap: 30px; grid-column-gap: 2%; */ }
    .services-section-wrap-inner h1.section-title { padding-left: 30px; padding-right: 30px; }
    .services-list-inner2 { width: auto; padding-left: 20px; padding-right: 20px; }

    .know-more-section-wrap-inner { width: auto; padding-left: 20px; padding-right: 20px; }
    .know-more-tab-content .small-box { margin:20px 10px 0; }

    .contact-section-wrap-inner { width: auto; padding-left: 20px; padding-right: 20px; }


    .footer-wrap-inner .each-col { padding:0 7px; }
  

}



@media only screen and (max-width:991px) { 

    h1.section-title { font-size: 42px; line-height: 50px; }
    h1.section-title br { display: none; }

    .header-top-inner { text-align: center; }
    .header-top-inner .head-logo { float:none; display: inline-block; }
    .header-top-inner .head-contact-details { display: none; }

    .header-bottom-inner ul.main-menu li { margin-right: 40px; }

    .about-section-wrap { padding:80px 0; }
    .about-section-wrap-inner .image-left { width: 40%; }
    .about-section-wrap-inner .about-text-col { width: 70%; padding:40px 20px; }

    .services-section-wrap { padding:80px 0; }
    .services-list {  /* grid-template-columns: 48% 48%; grid-template-rows: 380px 380px 380px; grid-row-gap: 30px; grid-column-gap: 4%;*/ }

    .services-tabs .tab-nav-item { min-width: 75px; font-size: 16px; line-height: 22px; padding-left: 26px; }


    .contact-section-wrap { padding:80px 0; }
    .contact-section-wrap-inner { display: block; }
    .contact-section-wrap .contact-left-column { width: 100%; margin-bottom: 20px; }
    .contact-section-wrap .contact-right-column { width: 100%; margin-left: 0; }

    .footer-wrap { padding:0; }
    .footer-wrap-inner .each-col { width: 50%; }
    .footer-wrap-inner .footer-bottom-links { padding:20px 10px; border-left:0; display: block; width: 100%; text-align: center; }



}


@media only screen and (max-width:767px) { 

    .mobile-menu  { display: block; }
    .header-bottom-inner { display: none; }

    .header-top-inner { height: 80px; }


    .header-top-inner .head-logo img { height: 52px; }

    .about-section-wrap { padding:40px 0; }
    .about-section-wrap-inner { padding: 0 15px; }
    .about-section-wrap-inner .image-left { width: 100%; }
    .about-section-wrap-inner .about-text-col { width: 100%; margin:-20px 0 0 0; padding:25px 15px; }


    .services-section-wrap { padding:40px 0; }
    .services-section-wrap-inner { padding-left: 15px; padding-right: 15px; }
    .services-list-wrap2 { padding-bottom: 40px; }
    .services-list-inner2 { padding-left: 15px; padding-right: 15px; }
    .services-list .each-service-col { flex: 0 0 100%; max-width: 100%; }
    .services-section-wrap-inner h1.section-title { padding-left:0; padding-right:0; }

    .services-tabs .tab-nav-item { width: 48%; margin-bottom: 10px; }
    .services-tab-content .list-of-services { width: 100%; }
    .services-tab-content .text-column { width: 100%; }
    .services-tab-content .image-column { width: 100%; }


    .know-more-section-wrap { padding:40px 0; }
    .know-more-section-wrap-inner { padding-left: 15px; padding-right: 15px; }
    .know-more-tabs .tab-nav-item { margin-bottom: 10px; }
    .know-more-tab-content .left-column { width: 100%; }
    .know-more-tab-content .right-column { width: 100%; margin-right: 0; padding-top: 20px; }
    .know-more-tabs-stage { padding-top: 30px; }
    .know-more-tab-content .small-box { padding:25px 15px 15px; min-height: unset; }
    .know-more-tab-content .small-box { margin-left:0; margin-right:0; }
    .know-more-tab-content .right-column .column-1 { width: 100%; }
    .know-more-tab-content .right-column .column-2 { width: 100%; padding-top: 0; }


    .contact-section-wrap { padding: 40px 0; }
    .contact-section-wrap-inner { padding-left: 15px; padding-right: 15px }
    .contact-section-wrap .contact-left-column { padding:20px 15px; }
    .contact-section-wrap .contact-right-column { padding:20px 15px; }

    .footer-wrap-inner { padding:0 15px; }
    .footer-wrap-inner .each-col { width: 100%; }
    .footer-wrap-inner .footer-contact-info-row { padding-bottom: 10px; }

}



@media only screen and (max-width:640px) { 

    .contact-form .col-6 { width: 100%; padding-bottom: 30px; }
    .contact-form .c-two-cols { padding-bottom: 0; }

    .footer-wrap-inner .footer-bottom-links { overflow:hidden; }
    .footer-wrap-inner ul.foot-links { float:none; width:100%; text-align: center; padding-bottom: 30px; }
    .footer-wrap-inner ul.foot-links li { float:none; display: inline-block; }
    .footer-wrap-inner .foot-copyright { float:none; display: block; text-align: center; }


}

#cbus-adelaide .about-section-wrap-inner {
  display: flex;
  align-items: center;
  padding-top: 40px;
  padding-bottom: 40px;
}

#cbus-adelaide h2.service-name {
  color: #000;
  font-weight: 600;
  margin-top: 28px;
  padding-bottom: 6px;
  border-bottom: 1px solid #ddd;
}
#cbus-adelaide .check-list li {
  font-size: inherit;
  font-weight: normal;
  color: inherit;
}

/* ============================
   C-Bus Adelaide: Mobile layout
   Hide image, single-column text
   ============================ */

@media (max-width: 768px) {

  /* Hide the left image entirely */
  #cbus-adelaide .image-left {
    display: none !important;
  }

  /* Make the wrapper normal block flow */
  #cbus-adelaide .about-section-wrap-inner {
    display: block !important;
  }

  /* Make the text column full width */
  #cbus-adelaide .about-text-col {
    width: 100% !important;
    float: none !important;
    margin: 0 !important;
    padding: 0 20px !important;   /* adjust for your site spacing */
    box-sizing: border-box;
  }

  /* Optional: tighten heading spacing for phones */
  #cbus-adelaide .section-title {
    margin-bottom: 12px;
  }

  #cbus-adelaide h2.service-name {
    margin-top: 18px;
  }
}

@media (max-width: 768px) {

  /* Add space above the CTA button on mobile */
  #cbus-adelaide .btn-primary {
    margin-bottom: 20px;
  }

}

/* ============================
   C-Bus Adelaide CTA button
   Match hero "Contact Us Today"
   ============================ */

#cbus-adelaide .btn-primary {
  background-color: #f37021;
  border-color: #f37021;
  color: #fff;
}

/* Hover / active states */
#cbus-adelaide .btn-primary:hover,
#cbus-adelaide .btn-primary:focus {
  background-color: #d95f1b; /* slightly darker orange */
  border-color: #d95f1b;
  color: #fff;
}

/* ============================
   C-Bus FAQ section (mirrored)
   Card overlaps image on RIGHT
   ============================ */

#cbus-faq .about-section-wrap-inner {
  position: relative;
}

/* Right-side image block (mirrors .image-left) */
#cbus-faq .image-right {
  width: 672px;
  float: right;
  position: relative;
  z-index: 1;
}

#cbus-faq .image-right img {
  max-width: 100%;
  position: relative;
  z-index: 10;
  border-radius: 6px;
}

/* Re-use the same background markers */
#cbus-faq .image-right .bg-design-1 {
  left: auto;
  right: -62px;
  top: -62px;
}

#cbus-faq .image-right .bg-design-2 {
  right: auto;
  left: 72px;
  bottom: -96px;
}

/* The text "card" overlaps into the image area (mirror of margin-left:-155px) */
#cbus-faq .about-text-col {
  margin: 90px -155px 0 0; /* <-- this creates the overlap on the RIGHT */
}

/* FAQ heading should be orange (match your accent colour) */
#cbus-faq h2.service-name {
  color: #f47423;
  font-weight: 600;
  margin-top: 28px;
  padding-bottom: 6px;
  border-bottom: 1px solid #ddd;
}

/* Questions in black (answers keep default paragraph styling) */
#cbus-faq .cbus-faq-q {
  color: #000;
  font-weight: 600;
  margin: 18px 0 6px;
}

/* ============================
   C-Bus FAQ: Mobile layout
   Hide image, full-width text
   ============================ */
@media (max-width: 768px) {

  #cbus-faq .image-right {
    display: none !important;
  }

  #cbus-faq .about-section-wrap-inner {
    display: block !important;
  }

  #cbus-faq .about-text-col {
    width: 100% !important;
    float: none !important;
    margin: 0 !important;
    padding: 0 20px !important;
    box-sizing: border-box;
  }
}

/* ============================
   Reduce vertical spacing between sections
   ============================ */

/* Main content sections */
.about-section-wrap,
.contact-section-wrap {
  padding-top: 70px;
  padding-bottom: 70px;
}

/* Slightly tighter on desktop only */
@media (min-width: 1024px) {
  .about-section-wrap,
  .contact-section-wrap {
    padding-top: 60px;
    padding-bottom: 60px;
  }
}

/* Reduce gap specifically between C-Bus section and FAQ */
#cbus-adelaide {
  padding-bottom: 40px;
}

#cbus-faq {
  padding-top: 40px;
}

/* Make the FAQ hero act as the positioning container */
#cbus-faq .cbus-faq-hero{
  position: relative;
}

/* Clear floats so the section height is correct */
#cbus-faq .cbus-faq-hero::after{
  content: "";
  display: table;
  clear: both;
}

/* Pin the image panel to the right AND centre it vertically */
#cbus-faq .image-right{
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
  width: 672px;      /* same as your other image block */
  z-index: 1;
  float: none;       /* override float-right behaviour */
  display: flex;
  padding-top: 150px; /* adjust this */ /* <-- vertical centring happens here */
}

/* Make the image fill the panel cleanly */
#cbus-faq .image-right img{
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Ensure the text card stays above the image */
#cbus-faq .about-text-col{
  position: relative;
  z-index: 2;
  margin: 90px -155px 0 0; /* keep your overlap */
}

/* ============================
   FAQ CTA (bottom of FAQ card)
   ============================ */

#cbus-faq .cbus-faq-cta{
  margin-top: 22px;   /* space from last FAQ item */
}

/* CTA question text (black, like FAQ questions) */
#cbus-faq .cbus-faq-cta-text{
  color: #000;
  font-weight: 600;
  margin-bottom: 8px;
}

/* CTA button — force primary orange and lift slightly */
#cbus-faq .cbus-faq-cta .btn-primary{
  margin-top: 20;              /* lift button closer */
  background-color: #f47423;
  border-color: #f47423;
  color: #fff;
}

/* Hover state to match site behaviour */
#cbus-faq .cbus-faq-cta .btn-primary:hover{
  background-color: #d9621e;
  border-color: #d9621e;
}