body{font-family: "Public Sans", serif; font-weight:400; font-size:16px; line-height:1.6; color:#0b0b0b; overflow-x: hidden;}
.left{float:left;} .right{float:right;} .clear{clear:both;}

[class*='col-'].left{margin: 0 40px 20px 0;}
[class*='col-'].right{margin: 0 0 20px 40px;}

html{scroll-padding-top:120px;}
a{ color:#15294c; text-decoration:underline;}
a:hover{ color:#000; 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: "Public Sans", serif; font-size:30px; line-height:1.5; color:#1e345b; margin:0 0 20px; font-weight:800;}
.sub-heading, .sub-heading2{font-size:24px;}
.sub-heading2{font-size:20px;}

.heading .heading, .heading .sub-heading, .heading .sub-heading2{ margin-bottom:0;}

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

b, strong{font-weight: 600;}

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

.img-wrapper{ margin-bottom:10px;}

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

.style{margin:0 0 20px 0; padding-left: 10px;}
.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, object, embed, video{max-width: 100%; height: auto;}

.map{max-width: 100%; min-height: 340px;}

.main-image{max-width: 45%;}

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

.blue-bg{background: #efefef; position: relative; color: #fff;}
.blue-bg::before{position:absolute; content:""; background:rgba(30,52,91,.88); left:0; top:0; width:100%; height:100%;}
.blue-bg .container, .blue-bg [class*='container-']{position: relative;}
.blue-bg .heading, .blue-bg .sub-heading, .blue-bg .sub-heading2, .blue-bg a{color: #fff;}

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

.zipcodes{ font-size:13px; text-align:center; margin-bottom:15px;}

.button{background: #b70404; 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: #393939!important; color: #fff!important;}


.accordion-item:not(:first-of-type){border: solid 1px#ccc!important;}
.accordion-item{margin-bottom: 25px; border: solid 1px#ccc!important;}
.accordion-button{cursor: pointer; font-size: 18px; font-weight: bold;}
.accordion-button:not(.collapsed){color: #fff; background: #b70404;}
.accordion-collapse{padding: 15px 20px 1px;}


header{background:#fff; position: fixed; top: 0; transition: all 0.3s ease-in-out; width: 100%; z-index: 9999;}
.top-row{ background:#1e345b; color:#fff; padding: 8px 0 10px; font-size: 17px; line-height: 1.2; font-weight: 500; transition:all .3s ease-in-out}
.top-row .text-right a{font-size: 20px; font-weight: bold; color: #fff; text-decoration: none;}

.logo-area{padding: 15px 0; -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);}
.logo-area .logo img{max-height: 100px; transition:all .3s ease-in-out}

/* Start Menu css */
.header-menu{transition:all .3s ease-in-out}
.navbar-brand{ font-size:14px; display:none}
.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-nav{margin: 0 0 0 auto;}
.navbar .navbar-nav .nav-item .nav-link{font-family: "Public Sans", serif; text-align:center; color:#15294c; font-size:15px; line-height:1.3; font-weight:600; text-transform:uppercase; padding:12px 14px; 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:#b70404;}

/*.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:#051ca2!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 .top-row{ margin-top:-42px}

.header-up .header-menu{margin-top: 0;}
.header-up .logo-area{padding: 8px 0;}
.header-up .logo-area .logo img{ max-height:70px}
.header-up .button{padding: 12px 15px;}
.headerclear{ margin-top:170px}
/* End Sticky Header */

.banner{position: relative; padding: 180px 20px 160px; min-height: 480px;}
.banner::before{position:absolute; content:""; background:rgba(30,52,91,.5); left:0; top:0; width:100%; height:100%;}
.banner .banner-text{text-align: center; position: relative; color: #fff; max-width: 80%; margin: 0 auto;}
.banner .banner-text .heading, .banner .banner-text .sub-heading, .banner .banner-text .sub-heading2{color: #fff; text-transform: uppercase;}
.banner .banner-text .heading{font-size: 60px; line-height: 1.1; font-weight: 900; margin-bottom: 20px;}

.banner .banner-text .heading  .line-through span{display: flex; align-items: center; font-size: 30px;}
.banner .banner-text .heading  .line-through span::before, .banner .banner-text .heading  .line-through span::after{border: solid 1px #fff; content: ""; display: block; flex-grow: 1;}


.banner-inner{padding: 120px 20px 100px; min-height: 360px;}
.banner-inner .banner-text .heading{font-size: 70px;}

.home-why-us{background: url("../img/polyurethane-foam-roofing.webp") right center no-repeat; background-size: 60%; position: relative;}
.home-why-us::before{position:absolute; content:""; background:#b70404; left:0; top:0; width:40%; height:100%;}
.home-why-us .container-xl{position: relative;}
.home-why-us .container-xl .wrapper{background: #b70404; position: relative; padding: 20px 20px 40px; margin-bottom: 20px;}
.home-why-us .container-xl .wrapper::before{position:absolute; content:""; background:#1e345b; right:15px; top: -15px; width:100%; height:100%;}
.home-why-us .container-xl .wrapper::after{position:absolute; content:""; background:#1e345b; left:-80%; top: -15px; width:100%; height:100%;}
.home-why-us .container-xl .wrapper div{position: relative; z-index: 1;}
.home-why-us .heading{font-size: 40px; color: #fff;}
.home-why-us .style{padding: 0;}
.home-why-us .style li{list-style: none; background: url("../img/arrow-bullet.png") left center no-repeat; margin: 0 0 18px; font-size: 19px; color: #fff; padding: 0 0 4px 32px;}

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


.counters{text-align: center; margin-bottom: 40px;}
.counters strong, .counters span{font-size: 60px; line-height: 1; color: #606060; font-weight: 800;}
.counters p{font-size: 20px; line-height: 1.2; color: #1e345b; font-weight: 800; margin-top: 5px;}

.inner-review-counter{padding: 40px 0 10px; background: url("../img/polyurethane-spray-foam.webp") center no-repeat fixed; background-size: cover;}
.inner-review-counter .counters{margin-bottom: 0;}
.inner-review-counter .counters strong, .counters span, .inner-review-counter .counters p{color: #fff;}

.home-review .heading{color: #000; font-weight: 700;}
.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;}

.spray-foam-roofing-bg{background: url("../img/polyurethane-spray-foam.webp") center no-repeat fixed; background-size: cover;}
.req-appointment-bg{background: url("../img/commercial-foam-roofing.webp") center no-repeat fixed; background-size: cover;}
.req-appointment-bg .heading{font-size: 40px; margin-bottom: 50px;}
.req-appointment-bg .sub-heading{text-transform: uppercase; font-weight: 700; margin-bottom: 0;}

.recent-projects{background: #ececec;}
.grid-image-item{margin-bottom: 25px;}
.feed-wrapper{border: solid 1px #a3a3a3;}
.feed-wrapper span{display: block; padding: 10px; font-size: 15px; line-height: 1.4;}

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

.contact-page p{font-size: 20px;}
.contact-page a{text-decoration: none;}

.service-area-section .google-map{margin-bottom: 0; min-height: 410px;}

.service-area{position: relative; background: url("../img/spf-roofing-service-areas.webp") center no-repeat; padding: 30px;}
.service-area::before{position:absolute; content:""; background:rgba(183, 4, 4, .88); left:0; top:0; width:100%; height:100%;}
.service-area .row{position: relative;}
.service-area .sub-heading{color: #fff; margin-bottom: 10px;}
.service-area .city{padding: 0; margin: 0;}
.service-area .city li{list-style: none; background: url("../img/service-area-icon.png") left center no-repeat; padding-left: 15px;margin-bottom: 5px;}
.service-area .city li a{color: #fff; text-decoration: none;}
.service-area .city li a:hover{text-decoration: underline;}

.footer{background:#ececec url("../img/spf-roof-system-expert.webp") bottom left no-repeat; padding-bottom: 0; position: relative;}
.footer:before{position:absolute; content:""; background:rgba(236,236,236,.8); left:0; top:0; width:100%; height:100%;}
.footer .container-xl{position: relative; z-index: 1;}
.footer .sub-heading{font-size: 20px; font-weight: 500; color: #000;}
.footer p{line-height: 1.2; font-size: 17px; margin-bottom: 20px;}
.footer a{color: #0b0b0b; text-decoration: none!important;}
.footer .phone{font-size: 20px; font-weight: 600;}
.footer .style{padding: 0;}
.footer .style li{list-style: none; margin: 0 0 15px;}

footer{background: #b70404; text-align: center; color: #fff;padding: 15px 10px;}

.contact-form{padding: 10px; margin-bottom: 30px; background: #1e345b; text-align: center;}
.contact-form .sub-heading{color: #fff; margin-bottom: 0;}

.copyright a{color: #fff; text-decoration: none;}


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

@media (max-width: 1199.98px) {
.heading, .sub-heading, .sub-heading2{font-size:28px; line-height: 1.3;}
.sub-heading, .sub-heading2{font-size:22px;}

.banner .banner-text .heading, .home-why-us .heading, .req-appointment-bg .heading{font-size: 58px;}

.spray-foam-roofing-bg{background: url("../img/spf-roofing-experts.webp") center no-repeat fixed; background-size: cover;}
.req-appointment-bg{background: url("../img/residential-foam-roofing.webp") center no-repeat fixed; background-size: cover;}


.navbar .navbar-nav .nav-item .nav-link{padding:12px 10px;}
.header-menu .button{padding: 15px 10px; font-size: 16px;}

.home-why-us{background-size: cover; background-position: left;}

.counters strong, .counters span{font-size: 50px;}
.counters p{font-size: 18px;}

.service-area .city li{font-size: 15px;}
}

@media (max-width: 991.98px) {
.heading br, .sub-heading br, .sub-heading2 br{ display:none}

.banner .banner-text{max-width: 90%;}
.banner .banner-text .heading, .home-why-us .heading, .req-appointment-bg .heading{font-size: 52px;}
.banner .banner-text .heading  .line-through span{font-size: 26px;}

hr.bdr{ margin:30px auto 40px}

.button{padding:12px 20px;}

section{ padding:50px 0px 30px;}

.logo-area{padding: 10px 0 0;}
.logo-area .logo img{max-height: 80px;}

.navbar{padding: 0;}
.navbar-nav{margin: 0 auto;}

.counters strong, .counters span{font-size: 40px;}
.counters p{font-size: 17px;}

.footer .bullet-group li{display: inline;}
.footer .bullet-group li::before{content: "|"; margin: 0 7px 0 4px;}
.footer .bullet-group li:first-child::before{content: "";}
.quick-links{text-align: center;}
}

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

.main-content [class*='col-'].left, .main-content [class*='col-'].right{float: none;}

.img-wrapper{text-align: center;}
.main-image{max-width: 90%;}

.header-up .logo-area{padding-bottom: 0;}

.headerclear{ margin-top:185px}

.banner .banner-text .heading, .home-why-us .heading, .req-appointment-bg .heading{font-size: 40px;}
.banner .banner-text .heading  .line-through span{font-size: 24px;}

.home-why-us{background: url("../img/elastomeric-acrylic-roof-coating.webp") right center no-repeat; background-size: cover;}
.spray-foam-roofing-bg{background: url("../img/home-spray-foam-insulation.webp") center no-repeat; background-size: cover;}
.req-appointment-bg{background: url("../img/spray-foam-roofing.webp") center no-repeat; background-size: cover;}

/* Start Menu css */
.header-menu{padding:0; background: #fff; border-top: solid 1px #ccc; margin-top: 7px;}
.navbar-toggler{ padding:.50rem .75rem}
.navbar{ padding:0!important;}
.navbar .navbar-brand{ display:block}
.navbar .navbar-nav{ margin-bottom:0!important}
.navbar .navbar-nav .nav-item .nav-link{ color:#fff; font-size:18px; line-height:22px; padding:10px 15px; border-bottom:1px solid #c22206; 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, .navbar .navbar-nav .nav-item.current-parent .nav-link, .navbar .navbar-nav .nav-item.current-parent .nav-link.current{ background: #ad1421; color: #fff;}

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

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

.banner{padding: 120px 20px 100px; min-height: inherit;}
.home-why-us .style li{background-size: 17px; margin: 0 0 10px; color: #fff; padding: 0 0 0 22px;}

.counters strong, .counters span{font-size: 30px;}
.counters p{font-size: 15px;}


}

@media (max-width: 575.98px) {
.heading, .sub-heading, .sub-heading2{font-size:22px;}
.sub-heading{font-size:19px;}

.header-up .top-row{ margin-top:-62px}
.headerclear{ margin-top:185px}

.top-row, .top-row .text-right{text-align: center;}

.logo-area .button{padding: 10px 7px; font-size: 15px;}

.banner .banner-text .heading, .home-why-us .heading, .req-appointment-bg .heading{font-size: 34px;}
.banner .banner-text .heading  .line-through span{font-size: 22px;}

.home-why-us{background: #efefef;}
}