body{font-family: "Open Sans", sans-serif; font-weight:500; font-size:16px; line-height:1.6; color:#282828; overflow-x: hidden;}

html{scroll-padding-top:220px;}
a{ color:#415064; text-decoration:underline;}
a:hover{ color:#282828; text-decoration: none;}
a:focus{ outline:none;}

.bullet-group{ margin-bottom:30px;}
.bullet-group .style{ margin:0 !important;}

.heading, .sub-heading, .sub-heading2{font-family: "Open Sans", sans-serif; font-size:32px; line-height:1.5; color:#415064; margin:0 0 20px; font-weight:800;}
.sub-heading, .sub-heading2{font-size:22px; font-weight: 600;}
.sub-heading2{font-size:19px;}

.heading .heading, .heading .sub-heading{margin-bottom:0;}
.heading .sub-heading{font-family: "Domine", serif;}

.heading.bdr-btm, .sub-heading.bdr-btm, .sub-heading2.bdr-btm{ border-bottom: solid 5px #28acd7; line-height: 1.2; display: inline-block; padding-bottom: 5px;}

hr.bdr{ border:none; height:3px; background:#ddd; opacity:1; width:60%; margin:50px auto}

b, strong{font-weight: 700;}

p{ font-size:16px; line-height:1.6}
p, .mb, .img-wrapper{ margin-bottom:30px;}

.modal{z-index: 9999; background: #00000099;}
.modal-content{padding: 20px;}
.modal .btn-close{position: absolute; top:10px; right: 10px; width: .3em; height: .3em;}

.grid-image-item{margin-bottom: 25px;}

.style{margin:0 0 20px 0; padding-left: 10px; text-align: left;}
.style li{list-style:disc; margin:0 0 10px 20px; line-height:26px}
.style ul{ margin-top:10px}
.style li a{ text-decoration:underline;}
.style li a:hover{ text-decoration:none}
.style .style li{list-style:circle;}
ol.style li{list-style:decimal;}
ol.style li ul li{list-style:disc;}

.text-left{text-align: left;} .text-right{text-align: right;} .text-center{text-align: center;}

img.right {float: right; margin: 5px 0 20px 15px;}
img.left {float: left; margin: 5px 20px 5px 0;}
img, video, iframe{ max-width:100%}
img.curve{border-top-left-radius: 80px; border-bottom-right-radius: 80px;}

.map{background: #ddd; border: solid 1px #b4b4b4; padding: 10px;}

.container-xl{ max-width:1240px;}
section{ padding:80px 0px 50px;}
.padding{padding:60px 40px;}

.button{background: #212d40; background: linear-gradient(33deg, rgba(33, 45, 64, 1) 0%, rgba(35, 48, 66, 1) 50%, rgba(77, 93, 117, 1) 100%); color: #fff; display:inline-block; text-decoration: none; font-size: 18px; line-height: 1.2; padding:15px 25px; text-align:center; transition:all .3s ease-in-out; font-weight:600; margin: 5px;}
.button:hover{ background: #2e2e2e; background: linear-gradient(33deg, rgba(46, 46, 46, 1) 0%, rgba(48, 48, 48, 1) 50%, rgba(26, 23, 23, 1) 100%); color: #fff!important;}

.blue-bg{background: #2e2e2e; background: linear-gradient(33deg, rgba(46, 46, 46, 1) 0%, rgba(48, 48, 48, 1) 50%, rgba(26, 23, 23, 1) 100%); position: relative; color: #fff;}
.blue-bg .heading, .blue-bg .sub-heading, .blue-bg .sub-heading2, .blue-bg a{color: #fff;}
.blue-bg .button{background: #fff; color: #28acd7;}

.logo-img{position: relative; margin-bottom: 30px;}
.logo-img::before{position:absolute; content:""; background:url("../img/logo.webp") center no-repeat; background-size: 218px; left:-74px; bottom:-95px; width:218px; height: 160px;}

.social{margin-bottom: 30px;}
.social a{margin:0 2px;}
.social img{ max-height:34px; transition:all .3s ease-in-out;}

header{background: #2C2C2C; background: linear-gradient(33deg, rgba(44, 44, 44, 1) 0%, rgba(31, 28, 28, 1) 50%, rgba(44, 44, 44, 1) 100%); color: #dfdfdf; font-size: 18px; position: fixed; top: 0; transition: all 0.3s ease-in-out; width: 100%; z-index: 9999;}
header .logo-area{padding: 15px 0; transition:all .3s ease-in-out;}
header .logo img{height: 100px; transition:all .3s ease-in-out;}
header .license{text-align: right; font-size: 14px; font-weight: 400; color: #b4b4b4; border-bottom: solid 1px #454545; padding-bottom: 8px; margin-bottom: 6px; transition:all .3s ease-in-out;}
header .head-contact{text-align: right;}
header .head-contact .phone{font-size: 32px; line-height: 1.2; font-weight: 800; margin-left: 10px; display: inline-block; color: #dfdfdf; text-decoration: none; transition:all .3s ease-in-out;}
header .head-contact .sub-heading{font-size: 20px; color: #cfcfcf; font-weight: bold; margin-bottom: 0; transition:all .3s ease-in-out;}


/* Start Menu css */
.header-menu{background: #fff; color: #333333; -webkit-box-shadow: 0 1px 5px rgba(0,0,0,0.4); -moz-box-shadow: 0 1px 5px rgba(0,0,0,0.4); -o-box-shadow: 0 1px 5px rgba(0,0,0,0.4); box-shadow: 0 1px 5px rgba(0,0,0,0.4); transition:all .3s ease-in-out;}
.navbar-brand{ font-size:14px; display:none}
.navbar{padding-top: 0; padding-bottom: 0;}
.navbar .navbar-toggler-icon{background-image: url("data:image/svg+xml,%3csvg viewBox='0 0 30 30' xmlns='http://www.w3.org/2000/svg'%3e%3cpath stroke='rgba(72, 72, 72, 1)' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");}
.navbar .navbar-toggler{ border:none; color:#000; }
.navbar .navbar-toggler:focus{box-shadow: none}
.navbar .navbar-toggler .open-menu{ font-size:20px;}
.navbar .navbar-brand{ display:none}
.navbar .navbar-nav .nav-item:last-child{background: #303f52;}
.navbar .navbar-nav .nav-item:last-child .nav-link{color: #fff;}
.navbar .navbar-nav .nav-item:last-child:hover{background: #28acd7;}
.navbar .navbar-nav .nav-item:last-child:hover .nav-link{color: #fff;}
.navbar .navbar-nav .nav-item .nav-link{font-family: "Open Sans", sans-serif; text-align:center; color:#333333; font-size:16px; line-height:1.3; font-weight:600; padding:30px 12px; transition:all .3s ease-in-out;}
.navbar .navbar-nav .nav-item .nav-link:hover, .navbar .navbar-nav .nav-item.current-parent .nav-link, .navbar .navbar-nav .nav-item.current-parent .nav-link.current{ color:#28acd7;}

.navbar .navbar-nav .nav-item:last-child .nav-link:hover, .navbar .navbar-nav .nav-item:last-child.current-parent .nav-link, .navbar .navbar-nav .nav-item:last-child.current-parent .nav-link.current{background: #28acd7; color: #fff;}

/*.dropdown-toggle::after { display: none}*/
.dropdown-menu{ min-width:12rem}
.dropdown-menu .nav-item.dropdown .nav-link{text-transform:none; font-size:14px; text-align:left; padding:5px 1rem; color:#212529}
.dropdown-item, .nav-item .dropdown .dropdown-toggle{ line-height:1.3; padding:5px 1rem!important; font-size:18px!important; font-weight: 400!important; border-bottom: solid 1px #ccc;}
.dropdown-item:hover, .dropdown-item:focus, .dropdown-menu .nav-item.dropdown .nav-link:hover{ background:#242425!important; color:#fff;}
.dropdown-item.current{ background:#222020!important; color:#fff!important;}
.dropdown .submenu{left: 90%; top: -2px;}
/* End Menu css */

/* Start Sticky Header */
.header-up{ transition:all .3s ease-in-out;}
.header-up .logo-area{padding: 10px 0;}
.header-up .logo img{height: 90px;}
.header-up .license{padding-bottom: 5px; margin-bottom: 2px;}
.header-up .head-contact .phone{font-size: 26px;}
.header-up .head-contact .sub-heading{font-size: 17px;}
.header-up .navbar .navbar-nav .nav-item .nav-link{padding:18px 12px;}

.headerclear{ margin-top:210px}
/* End Sticky Header */

.banner{background-size: cover!important; position: relative; padding: 140px 20px 380px; min-height: 480px; text-align: center; margin-bottom: -80px;}
.banner::before{position:absolute; content:""; background:rgba(41,54,71,.5); left:0; top:0; width:100%; height:100%;}
.banner svg{position: absolute; left: 0; bottom: -2px;}
.banner .banner-text{text-align: center; position: relative; color: #fff;}
.banner .banner-text .heading, .banner .banner-text .sub-heading{color: #fff;}
.banner .banner-text .heading{font-size: 42px; line-height: 1.2; font-weight: 800; margin-bottom: 0; text-shadow: 1px 1px 2px #000;}
.banner .banner-text .sub-heading{font-family: "Domine", serif; font-size: 28px; font-weight: 700;}
.banner .blue-bg{max-width: 640px; margin: 0 auto; font-size: 18px; padding: 10px;}
.banner .blue-bg span{display: inline-block;}
.banner .blue-bg span::after{content: " -";}
.banner .blue-bg span:last-child::after{content: "";}

.banner-inner{padding: 100px 20px 300px; min-height: 340px;}

.industries-we-serve{position: relative; margin: 50px 0; background: #212d40; background: linear-gradient(33deg, rgba(33, 45, 64, 1) 0%, rgba(35, 48, 66, 1) 50%, rgba(77, 93, 117, 1) 100%); font-size: 20px; color: #fff;}
.industries-we-serve::before{position:absolute; content:""; background:url("../img/logo-arrow-top.webp") top center no-repeat; left:0; right: 0; top:-80px; width:100%; height:235px;}
.industries-we-serve::after{position:absolute; content:""; background:url("../img/logo-arrow-bottom.webp") top center no-repeat; left:0; right: 0; bottom:-80px; width:100%; height:307px;}

.industries-we-serve .container-xl{position: relative; z-index: 1;}
.industries-we-serve .heading{color: #fff;}
.industries-we-serve p{font-size: 20px; margin-bottom: 60px;}
.indaustries-serve a{position: relative; cursor: pointer!important; background: #000;}
.indaustries-serve a span, .indaustries-serve a .sub-heading{position: absolute; left: 0; bottom: 25px; padding: 10px 25px 10px 15px; background: #fff; border-top-right-radius:50px; border-bottom-right-radius:50px; display: inline-block; width: auto; max-width: 90%; font-size: 20px; font-weight: 600; line-height: 1.2; color: #282828; text-decoration: none; z-index: 1; transition:all .3s ease-in-out;}
.indaustries-serve a:hover span{background: #2e2e2e; background: linear-gradient(33deg, rgba(46, 46, 46, 1) 0%, rgba(48, 48, 48, 1) 50%, rgba(26, 23, 23, 1) 100%); color: #fff;}
.industries-we-serve .lSSlideOuter .lSPager.lSpg > li a{background-color:#b1b1b1;}
.indaustries-serve a img{opacity: .6; transition:all .3s ease-in-out;}
.indaustries-serve a:hover img{opacity: 1;}

.industries-page section p{font-size: 19px; line-height: 1.8;}

.what-we-serve{margin-top: 50px;}
.what-we-serve .col div{position: relative; background: #fff; border: solid 3px #232323; border-radius: 20px; margin:0 8% 50px; padding: 8px 20px 8px 60px;}
.what-we-serve .col div span{display: flex; height: 75px; width: 75px; background: #212d40; background: linear-gradient(33deg, rgba(33, 45, 64, 1) 0%, rgba(35, 48, 66, 1) 50%, rgba(77, 93, 117, 1) 100%); border: solid 3px #182231; border-radius: 50%;  padding: 10px; align-items: center; justify-content: center; position: absolute; inset:0; margin: auto auto auto -30px;}
.what-we-serve .col div span img{height: 45px;}
.what-we-serve .col div .sub-heading{font-weight: 700; margin-bottom: 5px;}
.what-we-serve .col div p{margin-bottom: 5px; font-weight: 600; line-height: 1.4;}


.why-choose{position: relative; background: url("../img/new-construction-plumbing.webp") center no-repeat;}
.why-choose::before{position:absolute; content:""; background:rgba(32, 32, 32, .9); top: 0; left: 0; width:100%; height:100%;}
.why-choose .container-xl{position: relative; color: #fff;}
.why-choose .heading, .why-choose .sub-heading{color: #fff; transition:all .3s ease-in-out;}
.why-choose p{font-size: 20px; margin-bottom: 60px;}
.why-choose .box{display: flex; align-items: center; background: #202020; background: linear-gradient(33deg, rgba(32, 32, 32, 1) 0%, rgba(26, 23, 23, 1) 50%, rgba(26, 23, 23, 1) 100%); border: solid 1px #3a3a3a; padding: 15px 20px; margin:0 10px 40px; transition:all .3s ease-in-out;}
.why-choose .box .sub-heading{margin-bottom: 10px;}
.why-choose .box p{font-size: 16px; font-weight: 400; margin-bottom: 5px;}
.why-choose .box img{max-height: 50px; max-width: 60px; margin-right: 20px; transition:all .3s ease-in-out;}

.why-choose .box:hover{border: solid 1px #28acd7;}
.why-choose .box:hover img{margin-bottom: 70px;}
.why-choose .box:hover .sub-heading{color: #28acd7;}

.why-choose .style{margin-bottom: 30px;}
.why-choose .style li{font-size: 20px; margin-bottom: 15px;}

/*.google-map{background: url(../img/google-map.webp) center no-repeat; position: relative; min-height: 320px; margin-bottom: 30px;}
.google-map a{display: block; position: absolute; content: ""; width: 100%; top: 0; bottom: 0;}*/

svg.service-area-svg{margin: -170px 0 -10px; position: relative; z-index: -1;}
.service-area{background: #303f52 url("../img/service-areas.webp") bottom center no-repeat; position: relative; color: #fff; padding-top: 30px;}
.service-area::before{position:absolute; content:""; background:rgba(48,63,82,.9); left:0; top:0; width:100%; height:100%;}
.service-area .container-xl{position: relative; z-index: 1;}
.service-area .heading, .service-area .sub-heading, .service-area a{color: #fff;} 
.service-area .sub-heading{font-size: 18px; line-height: 1.4; font-weight: 700;}
.service-area .style{padding: 0;}
.service-area .style li{list-style: none; margin: 0 0 7px 10px; background: url("../img/service-area-bullet.webp") left center no-repeat; padding-left: 25px;}

.contact-form{background: #222020; padding: 20px; margin-bottom: 30px;}
.contact-form .heading, .contact-form .sub-heading{color: #fff;}
.modal-content .contact-form{margin-bottom: 0;}

.review-icons{text-align: center;}
.review-icons .heading, .review-icons .heading .heading, .review-icons .sub-heading{font-size:22px; margin-bottom:10px;}
.review-icons .sub-heading{ font-size:18px;}
.review-icons .mb a{margin: 10px 20px; display: inline-block;}
.review-icons a{ margin:0;}

.review-social{background: url("../img/5star.png") top center no-repeat; padding-top: 22px; text-align: center;}
.review-social strong{display: block;}
.review-social.nostar{background:none!important; padding: 0!important;}
.review-social span{display:block; font-weight: bold; font-size: 16px; line-height: 20px; margin-bottom: 5px;}
.review-social p{font-size: 14px!important; margin-bottom: 0;}
.review-social img{display: inline!important;}

.reviews{padding: 15px 20px 5px; margin: 0 0 30px; text-align: center; -webkit-box-shadow: 0 1px 5px rgba(0,0,0,0.4); -moz-box-shadow: 0 1px 5px rgba(0,0,0,0.4); -o-box-shadow: 0 1px 5px rgba(0,0,0,0.4); box-shadow: 0 1px 5px rgba(0,0,0,0.4); -webkit-border-radius: 18px; -khtml-border-radius: 18px; -moz-border-radius: 18px; -o-border-radius: 18px; border-radius: 18px;}
.reviews:before, .reviews:after {content: " "; display: table;} .reviews:after {clear: both; }
.reviews p{font-size: 20px; line-height: 1.6; margin-bottom: 15px; color: #323232;}

.review-heading{font-size: 24px; line-height: 1.2; font-weight: 500; color: #323232; margin: 0 0 20px; text-transform: uppercase;}

.review-page .reviews{text-align: left;}
.review-page .review-social{background: url("../img/5star.png") top right no-repeat; text-align: right;}
.review-page .reviews p{font-size: 16px;}

.review-slider .reviews{padding: 0 1.5%; -webkit-box-shadow: none; -moz-box-shadow: none; -o-box-shadow: none; box-shadow: none; -webkit-border-radius: 0; -khtml-border-radius: 0; -moz-border-radius: 0; -o-border-radius: 0; border-radius: 0;}
.review-slider .review-heading{background: url("../img/5star-l.png") top center no-repeat; padding-top: 60px; margin-bottom: 5px;}
.review-slider .review-social{background: none; padding-top: 0; font-size: 15px; font-weight: 700;}
.review-slider .review-social span{font-size: 18px;}

.footer{background: #2c2c2c; color: #d7d7d7;}
.footer .logo img{height: 100px;}
.footer .sub-heading{font-weight: 700; color: #fff;}
.footer p{margin-bottom: 20px; line-height: 1.4;}
.footer a{text-decoration: none; color: #d7d7d7;}
.footer a:hover{color: #fff;}
.footer .phone{font-size: 22px; font-weight: 700; line-height: 1;}
.footer .style{margin: 0; padding: 0;}
.footer .style li{list-style: none; margin-left: 0;}
.footer .style li a{text-decoration: none;}
.footer .contact-form{background: none; padding: 0;}

.copyright{background: #2c2c2c; color: #d7d7d7; border-top: solid 1px#484848; text-align: center; padding: 30px 10px;}
.copyright a{color: #d7d7d7;}
.copyright a:hover{color: #fff;}

#back-to-top{position:fixed; bottom:10%; right:2%; background:#28acd7; padding:5px; transition:.5s; display:none; z-index:1000}
#back-to-top:hover{background:#303f52;}



@media (max-width: 1199.98px) {
.heading, .sub-heading, .sub-heading2{font-size:30px;}
.sub-heading, .sub-heading2{font-size:20px;}
.sub-heading2{font-size:18px;}

.padding{padding:30px 20px;}

.navbar .navbar-nav .nav-item .nav-link{font-size:14px; padding:30px 7px;}
.header-up .navbar .navbar-nav .nav-item .nav-link{padding:18px 7px;}

.banner{padding: 100px 20px 300px;}
.banner .banner-text .heading{font-size: 38px;}
.banner .banner-text .sub-heading{font-size: 26px;}

.banner-inner{padding: 100px 20px 240px; min-height: 300px;}

.indaustries-serve a span, .indaustries-serve a .sub-heading{padding: 10px 20px 10px 10px; font-size: 17px;}

.why-choose .box{padding: 12px 15px; margin:0 0 30px;}
}

@media (max-width: 991.98px) {
.heading, .sub-heading, .sub-heading2{font-size:26px; line-height: 1.4;}
.sub-heading, .sub-heading2{font-size:19px;}
.sub-heading2{font-size:17px;}

.heading br, .sub-heading br, .sub-heading2 br{ display:none}

hr.bdr{ margin:30px auto 40px}
.button{padding:12px 20px;}
section{ padding:50px 0px 30px;}

.logo-img::before{background:url("../img/logo.webp") center no-repeat; background-size: 180px; left:-65px; bottom:-80px; width:180px; height: 132px;}

header .head-contact .phone{font-size: 28px; margin-left: 5px;}
header .head-contact .sub-heading{font-size: 19px;}
.headerclear{ margin-top:190px}

.banner{margin-bottom: -50px; padding: 80px 20px 240px;}
.banner .banner-text .heading{font-size: 34px;}
.banner .banner-text .sub-heading{font-size: 24px;}
.banner .blue-bg{max-width: 560px; font-size: 16px;}

.banner-inner{padding: 80px 20px 240px; min-height: 240px;}

.industries-we-serve::before{background-size: 549px; top:-50px; height:150px;}
.industries-we-serve::after{background-size: 560px; bottom:-50px; height:200px;}
.industries-we-serve p, .why-choose p{font-size: 17px; margin-bottom: 40px;}
.indaustries-serve a span, .indaustries-serve a .sub-heading{font-size: 16px; bottom: 15px; padding: 8px 20px 8px 10px;}

.we-serve{background-size: 300px;}
.we-serve::after{background-size: 166px; width:166px; height:54px; bottom: -37px;}

svg.service-area-svg{margin: -140px 0 -10px;}
.service-area .sub-heading{font-size: 17px;}
}

@media (max-width: 767.98px) {
.heading, .sub-heading, .sub-heading2{font-size:24px;}
.sub-heading, .sub-heading2{font-size:18px;}

.padding{padding:20px 15px;}

img.curve{border-top-left-radius: 50px; border-bottom-right-radius: 50px;}

.logo-img{margin: 0 50px 30px;}
.logo-img::before{background:url("../img/logo.webp") center no-repeat; background-size: 120px; left:-40px; bottom:-55px; width:120px; height: 88px;}

header .license{text-align: center; padding:6px 10px; margin: 0;}
header .logo-area{padding: 10px 0;}
header .logo img{height: 80px;}
header .head-contact{margin-bottom: 10px;}
header .head-contact .phone{font-size: 26px;}
header .head-contact .sub-heading{font-size: 18px;}

.header-up .logo img{height: 70px;}
.header-up .head-contact .phone{font-size: 24px;}
.header-up .head-contact .sub-heading{font-size: 17px;}

.headerclear{ margin-top:180px}

/* Start Menu css */
.navbar-toggler{ padding:.50rem .75rem}
.navbar .navbar-brand{ display:block}
.navbar .navbar-nav .nav-item .nav-link{background: #415064; color:#fff; font-size:18px; line-height:22px; padding:10px 15px!important; border-bottom:1px solid #304157; text-align:left;}
.navbar .navbar-nav .nav-item .nav-link br{display: none;}
.navbar .navbar-nav .nav-item:hover, .navbar .navbar-nav .nav-item:hover .nav-link{ background: #28acd7; color: #fff;}
.navbar .navbar-nav .nav-item .nav-link:hover, .navbar .navbar-nav .nav-item.current-parent .nav-link, .navbar .navbar-nav .nav-item.current-parent .nav-link.current{ background: #1b2b41!important; color:#fff!important;}

.dropdown-toggle::after { display: inline-block}
.dropdown-item{ font-size:15px;}
.dropdown-item br{ display:none}

.navbar .navbar-nav{ background:#28acd7;}
.navbar .navbar-nav .nav-item:last-child .nav-link{ border-bottom:none;}
/* End Menu css */

.banner .banner-text .heading{font-size: 30px;}
.banner .banner-text .sub-heading{font-size: 20px;}
.banner .blue-bg{max-width: 540px; font-size: 15px; font-weight: 700;}

.we-serve{padding-bottom: 100px;}
.what-we-serve .col div{border-radius: 15px; margin:0 5% 30px;}

.why-choose{background-size: cover;}
.why-choose .box{margin: 0 5% 30px;}

svg.service-area-svg{margin: -100px 0 -10px;}
}

@media (max-width: 575.98px) {
html{scroll-padding-top:250px;}
header .head-contact .phone{font-size: 22px;}
header .head-contact .sub-heading{font-size: 17px;}

header .logo img{height: auto;}

.header-up .head-contact .phone{font-size: 19px;}
.header-up .head-contact .sub-heading{font-size: 15px;}

.banner{padding: 120px 20px 240px;}
.banner-inner{padding: 120px 20px 200px; min-height: 240px;}

svg.service-area-svg{margin: -50px 0 -10px;}
}