body{
    font-family: "Roboto", sans-serif;
}

.container{
    max-width: 1190px;
    margin: auto;
}

h1,h2,h3,h4,h5,p,a{
    letter-spacing: 0;
}

:hover{
    transition: all 800ms;
}

h1{
    font-weight: bold;
}

h1,h2,h3,h4{
    font-family: "Oswald", sans-serif;
}

a.btn{
    background: rgba(95, 187, 70, 1);
    color: #FFF;
    text-decoration: none;
    padding: .5em 1.5em;
    border: 1px solid #FFF;
    border-radius: 5px;
}

a.btn:hover, #request-inspection .wpcf7 input[type="submit"]:hover{
    color: #FFF;
    background: #0e4404;
}

.page h2{
    font-size: 28px;
    font-weight: normal;
    color: #407f2e;
    margin-bottom: .75em;
}

.page .title{
    background: #2c2d2d;
}

.page .title h1{
    color: #FFF;
    font-size: 34px;
}

.home h2{
    font-size: 30px;
    font-weight: bold;
    color: #171717;
}

a, a:hover, a:focus{
    color: #5fbb46;
    cursor: pointer !important;
}

:focus{
    outline: none !important;
}

p{
    font-size: 16px;
    line-height: 24px;
    color: #171717;
}

#top-header{
    background: #317c1d;
}

header{
    background: #5fbb46;
}

h2.phone{
    font-size: 28px;
    font-weight: bold;
    float:right;
}

h2.phone a{
    text-decoration: none;
    color: #FFF;
}

h2.phone i{
    color: #0e4404;
}

input:focus{
    border-color:#407f2e !important;
}

.main-menu{
    background: #FFF;
    box-shadow: rgba(0, 0, 0, .25) 0 3px 11px 0;
}

#social-header {
    float: left;
}

#social-header li{
    list-style:none;
    float:left;
}

#social-header li a{
    font-size: 24px;
    color: #FFF;
    margin-right: .5em;
    line-height: normal;
}

#social-header.social-header-mobile li a{
    margin-right: .5em;
    margin-left: .5em;
}

#review-top{
    font-family: "Roboto", sans-serif;
}

#review-top a{
    font-size: 26px; 
    color: #ffc834;
    font-weight: bold;
    text-decoration:none;
}
#review-top a i{
    font-size: 20px;
}

#review-top a span{
    font-size: 14px;
    color: #FFF;
    text-decoration: underline;
    font-weight: normal;
}

#logos-header{
    display: flex;
    align-items: center;
}

#logos-header li{
    list-style: none;
    float: left;
}

#logos-header img{
	max-height: 60px;
}

.free-consultation{
    float: right;
    background: #0e4404;
    color: #FFF;
    text-decoration: none;
    font-size: 16px;
    padding: .5em .8em;
    border-radius: 5px;
}

.logo img{
	max-width: 156px;
}

.serving{
    font-size: 15px;
    font-weight: 400;
    color: #FFF;
    clear: both;
    float: right;
    font-family: "Roboto", sans-serif;
}

#menu-main-menu{
    float: left;
    padding: 0;
    margin: 0;
}

#menu-main-menu .sub-menu{
    z-index: 999;
    position: absolute;
    width: auto;
    max-width: none;
    padding: 0px 0px 0px 0px;
    border: 0;
    background: #f1f1f1;
    border-radius: 0;
    list-style: none;
    display: none;
    top: 2.5em;
}


#menu-main-menu .sub-menu li a{
    border-right: none;
    padding: 16px 14px;
    float: left;
    border-bottom: 1px solid #EEE;
    width: 100%;
    background: #FFF;
}

#menu-main-menu .sub-menu li a i{
    display: none;
}

#menu-main-menu .sub-menu li{
    clear: both;
    width: 328px;
}

#menu-main-menu .menu-item-has-children:hover .sub-menu{
    display: block;
}


#menu-main-menu li{
    float: left;
    list-style: none;
    margin-right: .5em;
    margin-left: .5em;
}

#menu-main-menu li a{
    font-weight: normal;
    text-decoration: none;
    font-size: 16px;
    padding: .25em;
    color: #000;
    float: left;
    cursor: pointer;
}

#menu-main-menu li.current-menu-item a{
    color: #407f2e;
    border-bottom: 2px solid #407f2e;
	    padding-bottom: 2px;
}

#menu-main-menu li a:hover{
 color: #407f2e;
}

.menu-main-menu-container{
    display: flex;
    justify-content: center !important;
    margin-top: .5em;
    margin-bottom: .5em;
}

.banner{
    background-image: url(../assets/images/banner-bg.jpg);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center center;
    background-color: #777;
    background-blend-mode: multiply;
}

.home .banner{
    position: relative;
    overflow: hidden;
    border: none;
}
.past-work h1{
    background: none !important;
    padding: 1em !important;
}

.past-work{
    background-image: url(../assets/images/interactive.jpg);
}

.seniors{
	  background-image: url(../assets/images/Roof-Replacement-Banner.jpg);
	 background-color: #555;
}

.residential-roofing{
	 background-color: #555;
}

.residential-roofing img, .lp2 img, .lp-img2p img{
	    border-radius: var(--bs-border-radius) !important;
}

.page-id-380 .banner{
    background-image: url(../assets/images/Commercial-Banner.jpg);
}

.certain-teed{
	background-image: url(https://www.dhroof.com/wp-content/uploads/2025/05/certain-teed.jpg);
}
.roof-replacement-page{
    background-image: url(../assets/images/Roof-Replacement-Banner.jpg);
}

.roof-repair-page{
    background-image: url(../assets/images/Roof-Repairs-Banner.jpg);
}

.roof-installation-page{
    background-image: url(../assets/images/Roof-Installation-Banner.jpg);
    background-position: bottom;
}

.roof-inspection-page{
    background-image: url(../assets/images/Roof-Inspection-Banner.jpg);
    background-position: top;
}

.asphalt-shingle-page{
    background-image: url(../assets/images/Asphalt-Shingle-Banner.jpg);
    background-position: top;
}

.siding-page{
    background-image: url(../assets/images/Siding-Banner.jpg);
}

.gutter-page{
    background-image: url(../assets/images/Gutter-Banner.jpg);
}

.storm-page{
    background-image: url(../assets/images/Storm-Banner.jpg);
}


.banner .row{
    display: flex;
    align-items: center;
}

.page-id-2984 .banner, .page-id-3082 .banner, .page-id-3131 .banner, .page-id-3148 .banner, .page-id-3153 .banner, .page-id-3193 .banner{
	background-image: url(https://www.dhroof.com/wp-content/uploads/photo-gallery/dream-home-roofing-gallery-05-19.jpg);
}

.page-id-3006 .banner, .page-id-3091 .banner, .page-id-3133 .banner, .page-id-3149 .banner, .page-id-3188 .banner, .page-id-3194 .banner{
	background-image: url(https://www.dhroof.com/wp-content/uploads/photo-gallery/dream-home-roofing-gallery-19-19.jpg);
}

.page-id-3025 .banner, .page-id-3098 .banner, .page-id-3138 .banner, .page-id-3150 .banner, .page-id-3189 .banner, .page-id-3195 .banner{
	background-image: url(https://www.dhroof.com/wp-content/uploads/photo-gallery/dream-home-roofing-gallery-10-19.jpg);
}

.page-id-3063 .banner, .page-id-3116 .banner, .page-id-3145 .banner, .page-id-3154 .banner, .page-id-3190 .banner{
	background-image: url(https://www.dhroof.com/wp-content/uploads/photo-gallery/dream-home-roofing-gallery-06-19.jpg);
}

.page-id-3232 .banner{
	background-image: url(https://www.dhroof.com/wp-content/uploads/photo-gallery/dream-home-roofing-gallery-12-19.jpg);
}

.page-id-3069 .banner, .page-id-3122 .banner, .page-id-3146 .banner, .page-id-3151 .banner, .page-id-3191 .banner{
	background-image: url(https://www.dhroof.com/wp-content/uploads/photo-gallery/dream-home-roofing-gallery-100-1.jpg);
}

#request-inspection {
    background: rgba(0, 0, 0, .7);
    border: 1px solid #FFF;
    border-radius: 10px;
    padding: 2em;
}

.see-work h2, .learn-more-home h2{
    color: #407f2e;
    font-weight: normal;
    font-size: 26px;
}

.learn-more-home .modal-content{
    background: #000;
}

.learn-more-home .btn-close{
    border-color: #EEE;
    background-color: #EEE !important;
    opacity: 1 !important;
}

.learn-more-home .modal-dialog{
    max-width: 600px;
}

.learn-more-home .modal-header, .learn-more-home .modal-footer{
    border-color: #333;
}

.review-home{
    background-image: url(../assets/images/review-bg.jpg);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
}

.review-home .stars i{
    color: #ffc834;
    font-weight: bold;
    font-size: 18px;
}

.review-home .review-container{
    background: rgba(0, 0, 0, .78);
    max-width: 1600px;
    margin: 0 auto;
}

.review-home h3{
    font-size: 28px;
}

.review-logo{
    width: 8%;
    float: left;
}

.review-content h3{
    font-family: "Roboto", sans-serif;
    font-size: 20px;
    font-weight: bold;
}

.review-content i{
    color: #ffc834;
    font-size: 22px;
}

.review-content{
    float: right;
    width: 92%;
    padding-bottom: 2em;
    border-bottom: 1px solid #EEE;
    margin-bottom: 1.5em;
}

.review-content .review-date{
    font-size: 14px;
}

.single-review{
    clear: both;
}

.review-content .review-reply{
    background: rgb(236, 236, 236);
    border-top-left-radius: 0 !important;
}

.review-content .review-reply h4{
    font-family: "Roboto", sans-serif;
    font-size: 13px;
    text-transform: uppercase;
    font-weight: normal;
    color: #555;
}

.review-home i{
    color: #FFF;
    font-size: 50px;
    font-weight: normal;
    margin-bottom: 10px;
}

.review-content p span{
    clear: both;
    float: left;
    display: block;
    width: 100%;
    margin-bottom: 5px;
    color: #235c9e;
    font-weight: bold;
}

.review-load-more{
    float: left;
    max-width: 200px;
    clear: both;
    margin-bottom: 2em;
    background: rgba(95, 187, 70, 1);
    border: none !important;
    /* outline: none; */
    box-shadow: none !important;
    color: #FFF;
}

.review-content p span i{
    color: #235c9e;
}

.review-choices{
    display: none;
}

#all-reviews{
    display: block;
}

.review-home .border-white{
    border-top: 1px solid;
}

.view-work{
    background: rgba(95, 187, 70, 1);
}

.view-work img{
    max-width: 228px;
}

.view-work h2{
    font-weight: normal;
    font-size: 28px;
}

.view-work .img-vwork{
    background-image: url(../assets/images/home-map2.jpg);
    background-repeat: no-repeat;
    background-size: cover;
}

.view-work a.btn{
    margin: 0 auto;
    display: block;
    max-width: 318px;
    background: #0e4404 !important;
    font-weight: bold;
    font-size: 20px;
    border-width: 2px;
}

.insurance-process{
    color: rgba(95, 187, 70, 1);
    font-weight: bold;

}

.textstart{
    background: #407f2e;
}

.textstart p{
    font-size: 14px;
}

.textstart h5 span{
    color: #74ec4e!important;
}

#request-inspection input, #request-inspection select, #request-inspection textarea{
    width: 100%;
    background: #FFF;
    border: none;
    padding: .75em;
    border-radius: 5px;
    margin-bottom: 1em;
    color: #000;
    font-weight: bold;
}


#request-inspection ::placeholder{
    color: #171717;
}

#request-inspection textarea{
    height: 80px;
    resize: none;
}

#request-inspection h3{
    color: #FFF;
    font-weight: 400;
    font-size: 24px;
    font-family: "Oswald", sans-serif;
}

#request-inspection .wpcf7 input[type="submit"]{
    color: #FFF;
    padding: 1em;
    margin-bottom: 0;
    background: rgba(95, 187, 70, 1);
    font-weight: normal;
    font-size: 14px;
    border: 1px solid #FFF;
}

#request-inspection p{
    margin-bottom: 0;
}

#request-inspection .wpcf7-response-output{
    margin: 0;
    padding: 0;
    color: RED;
    text-align: center;
    font-size: 14px;
}

.banner #request-inspection .wpcf7-response-output{
	color: #FFF;
}


.home h1, .inner-page h1, .page-id-380 h1 {
    color: #FFF;
    font-weight: normal;
    font-size: 38px;
    background: rgb(23, 23, 23);
    background: linear-gradient(90deg, rgba(23, 23, 23, 1) 0%, rgba(23, 23, 23, 0) 100%);
    padding: .5em .5em;
    font-family: "Oswald", sans-serif;
    font-weight: bold;
    font-size: 40px;
    border-radius: 6px;
}

.residential-roofing h1{
	    background: rgb(95, 187, 70);
    background: linear-gradient(90deg, rgba(95, 187, 77, 1) 0%, rgba(95, 187, 70, .5) 100%);
	font-size: 38px;
}

.page-id-3192 .residential-roofing h1{
	font-size: 37px;
}

.residential-roofing a.btn{
	color: #FFF !important;
	font-size: 20px;
	font-weight: bold;
}

.home h1 span{
    font-size: 32px;
}

.home-content p{
    color: #171717;
    text-align: justify;
}

.home-content img{
    border: 4px solid #FFF;
    box-shadow: #888 0px 0px 3px;
}

#hour-banner{
    font-size:18px;
    font-family: "Roboto", sans-serif;
}

#hour-banner span.closed{
    color:red;
}

#hour-banner span.open{
    color: #5fbb46;
}

#banner-list li{
    list-style: none;
    color: #FFF;
    font-size: 22px;
    padding-left: 1em;
    line-height: 40px;
}

#banner-list li i{
    color: #5fbb46;
}

.phone-banner{
    text-decoration: none;
    font-size: 24px;
}

.phone-banner a{
    text-decoration: none;
}

.serving-residential{
    background:#407f2e;
}

.serving-residential h2{
    font-size: 26px;
    font-weight: normal;
    font-family: "Oswald", sans-serif;
}

.serving-residential ul{
    columns: 3;
    list-style: none;
}

.serving-residential ul li a{
    text-decoration: none;
}


.serving-residential ul li a:hover img{
    transform: scale(1.1);
}

.serving-residential ul li{
    margin-bottom: .5em;
    overflow: hidden;
}

.serving-residential p{
    font-size: 16px;
    line-height: 24px;
}

.serving-residential img{
    height: 200px;
    object-fit: cover;
    width: 100%;
}

.serving-residential ul li h3{
    background: #5fbb46;
    width: 100%;
    font-size: 21px;
    font-weight: normal;
    font-family: "Oswald", sans-serif;
    overflow: hidden;
}

.why-choose{
    background-color: #4c9737;
}

.why-choose ul{
    list-style: none;
    columns: 3;
}

.why-choose ul li{
    margin-bottom: 2em;
}

.why-choose ul li img{
    margin-bottom: 1em;
}

.why-choose h2{
    font-weight: normal;
    font-size: 36px;
}


.why-choose a{
    float: right;
}

.single-post h1{
    color: #FFF;
    font-weight: normal;
    font-size: 38px;
    padding: .75em 0 .25em !important;
    margin-bottom: 0;
	line-height: normal;
}

.single-post .entry-meta{
	    padding-bottom: 2em;
}

.postid-393 header.entry-header, .postid-396 header.entry-header, .postid-400 header.entry-header, .postid-398 header.entry-header, .postid-402 header.entry-header, .postid-404 header.entry-header, .postid-406 header.entry-header, .postid-412 header.entry-header{
    background-position: center;
    background-size: cover;
    padding: 10em;
    background-repeat: no-repeat;
    background-color: #CCC;
    background-blend-mode: multiply;
    margin-bottom: 3em;
    background-attachment: fixed;
}

.postid-393 .entry-header{
    background-image: url(../assets/images/Understanding-the-Value-Roofers-Bring-to-Your-Home.jpg) !important;
}

.postid-396 .entry-header{
    background-image: url(../assets/images/4-Tips-for-Choosing-the-Right-Local-Roofer-for-Your-Needs.jpg) !important;
}

.postid-400 .entry-header{
    background-image: url(../assets/images/Your-Guide-to-Hiring-a-Local-Roofer.jpg) !important;
}

.postid-398 .entry-header{
    background-image: url(../assets/images/Your-Guide-to-Roof-Repair-Services.jpg) !important;
}

.postid-402 .entry-header{
    background-image: url(../assets/images/6-Benefits-of-Hiring-Local-Roofers-to-Replace-Your-Roof.jpg) !important;
    background-position: bottom !important;
}

.postid-404 .entry-header{
    background-image: url(../assets/images/How-to-Find-Quality-Roofers.jpg) !important;
}

.postid-406 .entry-header{
    background-image: url(../assets/images/6-Benefits-of-Using-Roof-Repair-Services.jpg) !important;
}

.postid-412 .entry-header{
    background-image: url(../assets/images/4-Questions-to-Ask-Your-Local-Roof-Services.jpg) !important;
}



.single-post .byline, .single-post .edit-link, .single-post h1:before, .single-post .entry-footer, .single-post .author-info, .single-post #comments, .single-post .post-thumbnail{
    display: none;
}

.single-post .nav-links a{
    text-decoration: none;
    text-transform: none;
}

.single-post .nav-links a:hover, .single-post .nav-links a:focus{
    color: #407f2e;
}

.single-post .entry-content h3{
    font-size: 26px;
    color: #407f2e;
    font-weight: normal;
}

.single-post .posted-on a{
    color: #FFF;
    text-align: center;
    text-decoration: none;
    font-size: 17px;
}

.bloglist li{
    box-shadow: rgba(0, 0, 0, .25) 0 3px 11px 0 !important;
    position: relative;
}

.bloglist .wp-block-latest-posts__post-title{
    padding: 0 1em;
    width: 100%;
    display: block;
    float: left;
    font-family: "Oswald", sans-serif;
    text-decoration: none;
    color: #407f2e;
    font-size: 18px;
    font-weight: bold;
    margin-bottom: .5em;
}

.bloglist .wp-block-latest-posts__post-excerpt{
    padding: 0 1em 2.5em;
    font-size: 15px;
    color: #555;
    float: left;
}

.bloglist .wp-block-latest-posts__read-more{
    position: absolute;
    font-weight: bold;
    margin-top: 12px;
    right: 1em;
    bottom: 1em;
    color: #FFF;
    background: #5fbb46;
    padding: 3px 10px;
    text-decoration: none;
    border-radius: 3px;
}

.bloglist .wp-block-latest-posts__read-more:hover, .bloglist .wp-block-latest-posts__read-more:focus{
    background: #407f2e;
    color: #FFF;
}

#wp-block-search__input-1{
    border-color: #DDD;
    background: #FFF;
}

.search-blog .wp-block-search__inside-wrapper {
    background: #EFEFEF;
    border: 1px solid #CCC;
}

h3{
    font-size: 18px;
}

.contact-us h3{
    line-height: normal;
}

.search-results .type-page, .search-results span.edit-link, .search-results article .entry-footer, .search-results span.byline{
    display: none;
}

.search-results article header{
    background: none;
}

.search-results article{
    border-bottom: 1px solid #BBB;
    padding-bottom: 1em;
    margin-bottom: 2em;
}

.search-results article h2 a{
    line-height: normal;
}


.search-results article h2 a:hover{
    color: #5fbb46;
}

.search-results article a.more-link{
    float: right;
    background: #5fbb46;
    color: #FFF;
    text-decoration: none;
    padding: .5em 1.25em;
    border-radius: 5px;
}

.contact-left ::placeholder{
    color: #333;
}

.contact-left input, .contact-left select, .contact-left textarea{
    width: 100%;
    padding: 1em;
    margin-bottom: 1em;
    border-color: #CCC;
    font-size: 15px;
    background: #fbfbfb;
}

.inspection-page input, .inspection-page  select, .inspection-page  textarea{
    width: 100%;
    padding: .75em;
    margin-bottom: .5em;
    border-color: #CCC;
    font-size: 15px;
    background: #f4f4f4;
}

.inspection-page label{
    margin-bottom: 6px;
}

.inspection-page textarea{
    height: 100px;
    resize: none;
}

.contact-left input[type="submit"], .inspection-page input[type="submit"]{
    width: auto;
    background: rgba(95, 187, 70, 1);
    padding: .75em 4em;
    border: none;
    border-radius: 5px;
}

.contact-left input:focus, .contact-left textarea:focus{
    border-color: rgba(95, 187, 70, 1);
}

.wpcf7-response-output{
    color: #407f2e;
}

.ask-about{
    background: rgba(64, 127, 46, 1);
    border-bottom-left-radius: 15px;
    border-top-right-radius: 15px;
}

.second-generation{
    background: rgba(76, 151, 55, 1) !important;
    border-top: 5px solid rgba(95, 187, 70, 1);
    border-bottom: 5px solid rgba(95, 187, 70, 1);
    border-radius: 5px;
}

.second-generation i{
    text-align: center;
    display: block;
    color: #FFF;
    font-size: 45px;
    font-weight: 600;
    margin-bottom: .25em;
}

.inner-page .learn-more-home{
    background: rgba(238, 238, 238, 1) !important;
}

.blog-page h1, .review-page h1, .fullwidth-page h1, .contact-page h1, .inspection-page h1{
    padding: 0 !important;
}

.blog-page .banner, .review-page .banner, .fullwidth-page .banner, .contact-page .banner, .inspection-page .banner{
    background: rgba(64, 127, 46, 1) !important;
}

.contact-left i{
    font-size: 22px;
    color: #5fbb46;
}

.contact-left h3{
    color: rgba(64, 127, 46, 1);
    font-size: 26px;
    font-weight: normal;
}

.contact-divider{
    border-top: 4px solid rgba(34, 34, 34, 0.3) !important;
    width: 32px;
}

#social-contact{
    list-style: none;
}

#social-contact li a{
    float: left;
    font-size: 32px;
    margin-right: 14px;
    color: rgba(64, 127, 46, 1) !important;
}

#social-contact li a i{
    font-size: 32px;
}

.review-page .overall-rating{
    font-size: 24px !important;
    font-family: "Roboto", sans-serif;
}

.page-id-699 details summary{
    color: #407f2e;
    font-size: 18px;
    font-family: "Oswald", sans-serif;
    padding: 1em;
    border: 1px solid #CCC;
}

.page-id-699 details p{
    padding: 1em;
    margin: 0;
    border: 2px solid #407f2e;
}
.page-id-699 details[open] summary{
    background: #407f2e;
    color: #FFF;
}

.page-id-73 .inner-page h3{
    color: #407f2e;
    font-size: 26px;
    font-weight: 400;
    margin-bottom: 1em;
}

.page-id-73 .content-inner{
    padding-bottom: 0 !important;
}

.about-home-roofing{
    border-bottom: 1px dotted #AAA;
    padding-bottom: 1.5em;
    margin-bottom: 3em;
}

.page-id-73 .inner-page p{
    text-align: left;
}

#review-choices{
    border-top: 1px solid #eaeaea;
    padding-top: 1em;
    border-bottom: 1px solid #eaeaea;
    float: left;
    width: 100%;
    padding-bottom: 1em;
    margin-bottom: 2em;
}

#review-choices i{
    color: #ffc834;
}

#review-choices a{
    background: #f5f5f5;
    border: 1px solid #a5a5a5;
    text-decoration: none;
    color: #666;
    padding: 5px 16px;
    border-radius: 20px;
    float: left;
    margin-right:.5em;
}

.review-page .overall-rating i{
    color: #ffc834;
    font-size: 38px !important;
}

#review-choices img{
    height: 23px;
    vertical-align: top;
}

.second-generation h3{
    font-size: 26px !important;
    font-weight: normal;
}

.second-generation p{
    font-size: 18px;
    margin-top: 1em;
}

#block-3{
    background: rgba(64, 127, 46, 1);
    padding: 1em;
    border-radius: 5px;
}

#block-3 p{
    margin: 0;
    text-align: left;   
}

#block-3 h3{
    font-size: 26px;
    color: #FFF;
}

#block-3 h4{
    font-family: "Roboto", sans-serif;
    clear: both;
    font-size: 20px;
}

.review-widget-divider{
    float: left;
    border-top: 4px solid #FFF;
    width: 30px;
    clear: both;
    margin-bottom: 1em;
}

.contact-bottom ul{
    list-style: none;
}

.contact-bottom li{
    float: left;
    margin: 0 2.5em;
}

.contact-bottom{
    border-top: 1px solid #DDD;
}

#review-success{
    display: none;
    border: rgba(64, 127, 46, 1) 2px solid;
    padding: 1em;
    margin-bottom: 1em;
}

#review-success h3{
    color: rgba(64, 127, 46, 1);
    text-align: center;
    font-weight: normal;
    font-size: 28px;
    margin-bottom: 0;
}

#write-review{
    max-width: 600px;
    margin: 0 auto;
    background: #f8f8f8;
    padding: 2em;
}

#write-review input, #write-review textarea, #write-review select{
    width: 100%;
    resize: none;
    border: 1px solid #CCC;
    background: #FFF;
    margin-bottom: .5em;
    padding: .75em;
}

#write-review input[type="submit"]{
    background: rgba(64, 127, 46, 1) !important;
    color: #FFF ! Important;
    border: none;
    padding: 1em;
}

#write-review .rate-us{
    margin-top: .5em;
    margin-bottom: .5em;
}

#write-review textarea{
    height:200px;
}

#write-review label{
    font-size: 16px;
    margin-bottom: 4px;
}

.pending-review .border-black{
    border-bottom: 1px solid #AAA;
    margin-bottom: 2em;
}

.pending-review h5.stars{
    color:#ffc834;
}

.cb-container{
    display: flex;
    justify-content: center !important;
    margin-top: .5em;
    margin-bottom: .5em;
}

.contact-bottom li img{
    height: 90px;
}

#block-3 h5.stars{
    color: #ffc834;
    font-weight: normal;
    font-size: 18px;
}

#block-3 .border-white{
    border-top: 1px solid #FFF;
}

#block-3 a{
    color: #FFF !important;
}

.ask-about p{
    margin: 0;
    font-size: 18px;
    font-weight: bold;
}

.ask-about i{
    color: #FFF;
    font-size: 48px;
    text-align: center;
    display: block;
}

.ask-about a{
    color: #fff;
}

#nav_menu-3{
    padding: 1.5em;
    border: 1px solid #CCC;
    background: rgba(240, 240, 240, 0.3) !important;
    border-radius: 5px;
}

#nav_menu-3 h2{
    text-transform: none;
    font-size: 26px;
    border-bottom: 4px solid rgba(198, 197, 197, 0.4);
    padding-bottom: .25em;
    margin-bottom: .5em;
}

#nav_menu-3 ul li a{
    text-decoration: none;
    color: #000;
    font-size: 16px;
    line-height: 32px;
}

#nav_menu-3 ul li a:hover, #nav_menu-3 li.current-menu-item a{
    color: rgba(64, 127, 46, 1);
    border-bottom: 2px solid rgba(64, 127, 46, 1);
    padding-bottom: 3px;
}

.col-three{
    -webkit-column-count: 3;
    -moz-column-count: 3;
    column-count: 3;
    column-gap: 100px;
}

.contact-left textarea{
    resize: none;
    height:150px;
}

.contact-right ul{
    list-style: none;
    padding:0;
}

.contact-right ul li{
    font-size: 22px;
}

.contact-right ul li.serving{
    font-size: 18px;
    font-weight: bold;
}

.contact-right .menu{
    border-top: 1px solid #EEE;
    padding-top: 1.4em;
}

.footer{
    background: rgba(95, 187, 70, 1);
}

.footer h3{
    text-transform: uppercase;
    font-size: 22px;
    color: #FFF;
    font-weight: normal;
}

.footer .col-lg-4{
    border-right: 1px solid rgba(255, 255, 255, .3);
}

.footer-divider{
    border-color: rgba(255, 255, 255, .3) !important;
    border: 2px solid;
    width: 40px;
    margin-bottom: 1em;
}

.footer h4{
    font-size: 16px;
    font-weight: bold;
}

.footer ul li{
    list-style:none;
    font-size: 16px;
    color: #FFF;
}

.footer ul li i{
    color: #33607e;
}

.footer ul li a{
    text-decoration: none;
    color: #FFF;
}

#services-footer{
    columns: 2;
    border-top: 3px solid #33607e;
}

#services-footer li a{
    color: #FFF;
    text-decoration: none;
}

#social-footer li{
    float: left;
}

#social-footer li a i{
    color: #FFF;
    font-size: 28px;
    margin-right: .5em;
}

#floating-side{
    position: fixed;
    right: 0;
    top: 30%;
    z-index: 9999;
    list-style: none;
}

#floating-side li{
    float: right;
    clear: both;
}

#floating-side i{
    background: rgba(14, 68, 4, 1);
    color: #FFF;
    font-size: 20px;
    padding: 10px;
    margin-right: 7px;
    float: left;
}

#floating-side a{
    text-decoration: none;
    color: #444;
    font-size: 14px;
    background: #FFF;
    padding: 0px;
    float: left;
    padding-right: 20px;
    line-height: 40px;
    border-bottom: 1px solid #407f2e;
}

#shareus ul{
    list-style: none;
    padding: 0;
    margin: 0;
}

#shareus ul li{
    float: left;
    width: 25%;
}

#shareus ul li a{
    text-align: center;
    float: left;
    width: 96%;
    border: 1px solid rgb(255, 255, 255, .5);
    text-decoration: none;
    padding: 5px;
    margin: 2%;
    border-radius: 5px;
    color: #FFF;
}

#shareus .modal-content{
    background: rgba(14, 68, 4, 1);
}

#shareus .modal-header{
    background: #175f09;
    border-color: #2e891d;
}

#shareus h3{
    margin: 0;
    text-align: center;
    width: 100%;
    font-size: 22px;
    font-weight: normal;
}

#shareus .btn-close{
    opacity: 1;
}

#shareus .btn-close:hover, #shareus .btn-close:focus{
    background-color: #FFF;
}

#floating-side a:hover{
    margin-right: 0px !important;
}

.copyright p, .copyright a{
    color: #666 !important;
    font-size: 12px;
}

.copyright li a{
    float: left;
}

.menu-footer-menu-container{
    display: flex;
    justify-content: center !important;
}

#menu-footer-menu, #menu-footer-menu li, #menu-footer-menu li a{
    float: left;
}

#menu-footer-menu li a{
    text-decoration: none;
    border-right: 1px solid #666;
    padding: 0px 8px;
}

#menu-footer-menu{
    list-style: none;
    margin-bottom: .5em;
}

.inner-page .widget-area .widget{
    max-width: none;
    clear: both;
    display: block;
    float: left;
    position: inherit !important;
    left: auto !important;
    top: auto !important;
	    padding-right: calc(var(--bs-gutter-x)* .5);
    padding-left: calc(var(--bs-gutter-x)* .5);
}

.inner-page p{
    text-align: justify;
}

.services-sidebar{
    padding: 0;
}

.services-sidebar li{
    list-style:none;
}

.inner-page .widget-area .container{
    padding-top: 1em;
    padding-right: 0;
    padding-bottom: 0;
}

.inner-page .widget-area > .container:before{
    display: none;
}

.inner-page .widget-area .inquire-sidebar .wp-block-button, .inner-page .widget-area .inquire-sidebar .wp-block-button a{
    width: 100%;
}


.inner-page .widget-area #block-4{
    margin-bottom: 0;
}

.picture-page {
    height: 40vh;
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
}

.our-services-home.services-sidebar li a{
    width:33.3333333%;
    border-radius: 0;
    margin-bottom:0;
    background-color: #1e94cc;
    border-color: #2ab1f1 !important;
}

.our-services-home-2.services-sidebar li a{
    width:50%;
    border-radius: 0;
    margin-bottom:0;
    background-color: #1e94cc;
    border-color: #2ab1f1;
}


.inquire-sidebar a:hover{
    background: #171717 !important;
    color: #FFF !important;
 
}

#block-5{
    margin-bottom: .2em;
}

.logged-in #my-menu{
    margin-top: 46px;
}

#mmenu{
    position: absolute;
    top: -5px;
    right: calc(var(--bs-gutter-x)* .5);
}

#mobile-header{
    background: #5fbb46;
	padding-top: 1em;
}

#mobile-header .logo img{
    max-width: 300px;
    margin-bottom: .5em !important;
}

#mobile-header h2.phone {
    padding: 6px;
    width: 100%;
    background: #0e4404;
    font-weight: normal;
    border-radius: 5px;
}

#mobile-header h2.phone i{
    color: #FFF;
}

#social-header-container{
    display: flex;
    justify-content: center !important;
    margin-top: .5em;
    clear:both;
}

#mobile-header h3 a{
    font-size: 20px;
}

#mobile-header h3 a i {
    font-size: 18px;
}

#mobile-header h3 a span{
    font-size: 13px;
    color: #333;
}

#mobile-header h2.phone a{
    font-size: 22px;
    line-height: normal;
}

.sc-mobile{
    width: 100%;
    text-align: center;
    margin-top: 8px;
}

#menu-main-menu-1 li a i{
	display: none;
}

.contact-us h2{
    color: #171717;
}


@media only screen and (max-width: 1260px) {
    .services-list p{
        height: auto;
    }
}

@media only screen and (max-width: 1160px) {
    .areas-serve ul{
        columns: 3;
    }
}

.contact-bottom ul{
    padding: 0;
}

@media only screen and (max-width: 980px) {
    .contact-bottom li{
        margin: 0 .5em;
    }

    .banner h1 br{
      display: none;
    }

    .menu-main-menu-container{
        margin-top: 0 !important;
    }
    #floating-side{
        top: auto;
        bottom: 0;
        margin-bottom: 0;
    }

    #banner-list li{
        font-size: 18px;
        padding-left: 1em;
        line-height: 30px;
        text-align: center;
    }
    
    .phone-banner{
        display: none;
    }

    .bbb{
        margin: 0 auto !important;
        float: none !important;
        display: block;
    }

    .bbb img{
            margin: 0 auto;
    display: block;
    margin-bottom: 1em;
    max-width: 250px;
    }

    #hour-banner {
        font-size: 16px;
        font-family: "Roboto", sans-serif;
        text-align: center;
        margin-top: 16px !important;
        margin-bottom: 10px !important;
    }

    h1{
        font-size: 28px !important;
    }
    h2{
        font-size: 26px !important;
    }
    h3{
        font-size: 18px !important;
    }
    #social-header{
        clear:both;
    }

    #get-estimate-home h3{
        font-size: 20px;
    }

    .footer-top .footer-div{
        margin-bottom: 1.5em;
    }
    .contact-us h3{
        font-size: 18px !important;
    }
	.inner-page .widget-area .container{
		padding-left: 0;
	}
	.contact-right ul li.serving{
		float: left;
	}
    #mobile-header h2.phone a{
        font-size:19px;
    }

    #review-choices a{
        clear: both;
        margin: 0 auto;
        float: none;
        display: block;
        margin-bottom: 5px;
        text-align: center;
        max-width: 293px;
        border-radius: 0px;
    }
    #review-choices img{
        width: auto !important;
    }
    .review-logo{
        padding-right: 10px;
        width:12%;
    }
    .review-content{
        width:88%;
    }

}

@media only screen and (max-width: 870px) {
    .areas-serve ul{
        columns: 2;
    }
    .areas-serve ul li{
        font-size: 14px;
        margin-left: 1.75em;
        text-indent: -.6em;
        line-height: normal;
        border-bottom: 1px solid #DDD;
        padding-bottom: 5px;
        margin-bottom: 5px;
    }
}

.search-results article{
    padding-bottom: 2em;
}
.search-results article a.more-link{
    margin-top: .5em;
}



.whychooseroof ul{
	list-style:none;
}

.whychooseroof ul li{
	    max-width: 75px;
    margin-right: 1em;
}

.whychooseroof h3{
	border-bottom: 1px solid #407f2e;
  padding-bottom: .25em;
  font-size: 20px !important;
}


.whychooseroof h3 i{
	color: #407f2e;
}

.schedule-free{
	background-color: #4c9737;
}

.schedule-free h2, .schedule-free p{
	color: #FFF;
}

	.lp2p .wp-block-columns{
		margin-bottom: 0;
	}
@media only screen and (max-width: 767px) {
	
	.residential-roofing h2{
		text-align: center;
	}
	.whychooseroof h3{
		font-size: 16px !important;
	}
	
	.page-template-residential-roofing h3, .page-template-residential-roofing p, .page-template-residential-roofing h2{
		text-align: center;
	}
	.page-template-residential-roofing a.btn{
	margin: 0 auto;
  display: block;
	}
	
	.page-template-residential-roofing #banner-list li{
		font-size: 16px;
	}
	
	.whychooseroof ul{
		margin: 0 auto !important;
  display: block;
  max-width: 260px;
	}
	
	.page-template-residential-roofing .banner h2{
		font-size: 20px !important;
  font-weight: 200 !important;
	}
	

	
	.residential-roofing #request-inspection{
		padding: 1.25em;
	}
	.residential-roofing a.btn{
		    font-size: 14px;
    font-weight: normal;
	}
	
	.page-template-residential-roofing #banner-list li{
		padding-left: 0;
	}
	.container-iframe{
		padding-top: 0 !important;
		position: relative !important;
	}
	
	.container-iframe iframe{
		    height: 500px !important;
    position: inherit !important;
	}
	
	.wpsr-business-info .wpsr-business-info-left .wpsr-business-info-logo img{
		height: 40px;
	}
	
	.wpsr-review-template .wpsr-reviewer-image img{
		width: auto !important;
	}
	.single-post header.entry-header{
		padding: 1em;
		        border-top: 2px solid #FFF;
	}
	
	.single-post .entry-meta{
		padding-bottom: .75em;
	}
	
	.single-post .entry-content p{
		line-height: normal;
	}

    .wp-block-latest-posts.is-grid li{
        margin-right: 0;
    }

  .widget-area{
      padding: .75em;
  }
 
    .blog-page h1, .review-page h1, .fullwidth-page h1, .contact-page h1, .inspection-page h1{
        margin-bottom:0;
    }
    .blog-page h2, .review-page h2, .fullwidth-page h2, .contact-page h2, .inspection-page h2{
        text-align: center;
    }

    .ask-about br{
        display: none;
    }
    .ask-about p{
        margin-top: .5em !important;
        text-align: center;
        font-size: 16px;
    }
    .ask-about{
        margin: 1em 0 !important;
    }

    .inner-page h2{
        margin-top: 0 !important;
    }
    h1{
        font-size: 24px !important;
        text-align: center !important;
    }
    .home h1 span, .home h1{
        font-size: 24px !important;
        float: left;
        clear: both;
        width: 100%;
    }
    h2{
        font-size: 22px !important;
    }
    h3{
        font-size: 20px !important;
    }

    .footer h3, .footer h4{
        text-align: center;
    }

    .serving-residential ul{
        columns: 1;
        width: 100%;
    }

    .why-choose h2, .why-choose p, .serving-residential p, .see-work h2, .learn-more-home h2, .learn-more-home p{
        text-align: center !important;
    }


    .why-choose a, .learn-more-home a.btn, .review-container a.btn, #block-3 a.btn, .write-a-review, .contact-left input[type="submit"], .inspection-page input[type="submit"]{
        float: none;
        margin: 0 auto;
        display: block;
        max-width: 300px;
        margin-bottom: 2em;
    }

    .write-a-review{
        float:none !important;
        clear: both;
    }
    .learn-more-home a.btn, .write-a-review{
        margin-bottom: 1em;
    }

    .review-page .overall-rating{
        text-align: center;
        width: 100%;
        font-size: 16px !important;
        margin-bottom: 1em !important;
    }

    .review-page .overall-rating i{
        font-size: 22px !important;
    }

    .review-container a.btn, #block-3 a.btn{
        margin-bottom: 0;
    }

    .review-widget-divider{
        margin: 0 auto;
        display: block;
        float: none;
        margin-bottom: .5em;
    }
    #block-3 h3{
        text-align: center;
    }

    #block-3 h4{
        font-size: 16px;
    }

    .why-choose ul{
        padding: 0;
    columns: 1;
    margin: 0;
    }

    .why-choose ul li{
        margin-bottom: .5em;
    width: 100%;
    float: left;
    }

    .why-choose ul li br{
        display: none;
    }

    .learn-more-home img{
        margin: 0 auto;
        float: none;
        display: block;
    }

    .view-work .img-vwork{
        height:180px;
    }

    .footer-divider{
        margin: 0 auto;
    }
    .footer p, .footer li{
        text-align: center;
    }
    .copyright p, .copyright a{
        text-align: center;
    }

    #social-footer{
        margin: 0 auto;
        display: block;
        max-width: 126px;
        margin-bottom: 4em;
    }
    #social-footer li a i{
        margin-left: .25em;
        margin-right: .25em;
    }

    .home h1, .inner-page h1, .page-id-380 h1{
        background: rgb(0, 0, 0, .6);
    }
	.residential-roofing h1 {
  background: rgb(95,187,70);
  background: linear-gradient(90deg,rgba(95,187,77,1) 0%,rgba(95,187,70,.5) 100%);
		    margin-bottom: .75em !important;
	}
	
	.residential-roofing h2{
		font-weight: normal;
	}
	
	.page-template-residential-roofing img{
		margin-bottom: 1em;
	}
    p, .wp-block-list li, .serving-residential p{
        font-size: 14px;
    line-height: 22px;
    }
    #nav_menu-3 h2{
        text-align: center;
    }
    #nav_menu-3 ul li{
        text-align: center;
    }
    .second-generation{
        margin-top: 1.5em !important;
    }
	
	.page-id-2898 .learn-more-home #banner-list{
		margin-bottom: 1em !important;
	}
	.page-id-2898 .learn-more-home #banner-list li{
		    padding-left: 0;
    text-align: left;
		font-size: 13px;
		
	}
}

@media screen and (max-width: 620px) {
    #wpadminbar {
        position: fixed;
    }
    .inner-page img{
        width: 100% !important;
    }
	.page-id-1498 .inner-page img{
		width: auto !important;
	}
    .home-content figure, .home-content figure img{
        width: 100% !important;
    }
    .contact-bottom li img{
        height: 62px;
    }
    .contact-bottom{
        padding-top: 1.5em !important;
    }

}

@media only screen and (max-width: 500px) {
    #shareus ul li{
        width: 50%;
    }
	.cb-container{
		display: block;
	}
	.contact-bottom ul{

	}
    .contact-bottom li{
        margin: 1em 0;
		width: 33%;
		float:left;
		padding: .5em;
    }
    .contact-bottom li img {
       height: 80px;
    width: auto !important;
    margin: 0 auto;
    display: block;
    }
	
}

@media screen and (max-width: 462px) {
    #services-footer{
        columns: 1;
        margin: 0 auto;
        float: none;
        width: 198px;
        margin-bottom: 1em;
    }
    #services-footer li a{
        border-bottom: 1px solid #333;
        width: 100%;
        float: left;
        margin-bottom: 4px;
        padding-bottom: 4px;
    }
}

@media screen and (max-width: 458px) {
    #mobile-header .logo img{
        max-width: 220px;
    }
}



@media screen and (max-width: 400px) {
    #mobile-header .logo img {
        max-width: 192px;
    }
}

.mm-panels>.mm-panel{
    background: #FFF;
}

.mburger{
    border: none;
    color: #0e4404 !important;
}

.mm-menu{
    display: block;
}

.mm-navbar{
    background: #0e4404 !important;
}

.mm-navbar__title{
    color: #FFF !important;
}

.mm-btn_prev:before{
	border-color: #FFF;
}

header{
	z-index: 999 !important;
}

body{
	overflow-y: auto !important;
}

.home .banner video {
  position: absolute;
  top: 50%;
  left: 50%;
  min-width: 100%;
  min-height: 100%;
  width: auto;
  height: auto;
  z-index: 0;
  -ms-transform: translateX(-50%) translateY(-50%);
  -moz-transform: translateX(-50%) translateY(-50%);
  -webkit-transform: translateX(-50%) translateY(-50%);
  transform: translateX(-50%) translateY(-50%);
}

home.overlay {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  background-color: black;
  opacity: 0.5;
  z-index: 1;
}

.certainteed-div{
	    border-bottom: 5px solid #317c1d;
    padding-bottom: 1.5em;
    margin-bottom: 2.5em;
	align-items: center !important;
}

.certainteed-div li{
	    color: #0e4404;
    line-height: 32px;
    font-size: 17px;
}

.certainteed-div ul{
	border-top: 1px solid #CCC;
    padding-top: 1em;
    border-bottom: 1px solid #CCC;
    padding-bottom: 1em;
}

.page-id-2201 .past-work{
	display:none;
}

form.submitting .wpcf7-spinner 
{
    visibility: visible;
}
.wpcf7-spinner {
    visibility: hidden;
    display: inline-block;
    background: url(https://www.dhroof.com/wp-content/uploads/2025/05/loader.gif) no-repeat;
    width: 30px;
    height: 30px;
    background-size: 100%;
    padding: 0;
    display: block;
    margin-top: -37px;
    z-index: 999999;
    float: right;
    position: relative;
    margin-right: 14px;
}

.senior-badgelist li img{
	    max-width: 104px;
}
.senior-badgelist li{
	
}

.senior-badgelist{
    margin: auto;
    max-width: 266px;
    padding: 0;
}

.whos-eligible h3{
	    border-bottom: 2px solid #407f2e;
    padding-bottom: .5em;
    margin-bottom: .75em;
}

.why-choose-senior ul{
	
}

.why-choose-senior ul li{
	margin-bottom: 0;
}


.why-choose-senior ul li img{
	padding: .5em;
}

.page-id-2898 .inputfield{
	    width: 100%;
    margin-bottom: .75em;
    border: 1px solid #BBB;
    padding: .75em;
}

.page-id-2898 label{
	font-size: 14px;
}

.page-id-2898 input[type="submit"]
{
	    background: rgba(95, 187, 70, 1) !important;
    color: #FFF;
    text-decoration: none;
    padding: 1em 1.5em;
    border: 1px solid #FFF;
    border-radius: 5px;
    line-height: normal;
    margin: 0 auto;
    float: none;
    display: block;
    font-weight: normal;
}

.claim-discount .wpcf7-response-output{
	margin: 0;
	    text-align: center;
}

.page-id-2898 .seniors .btn-close{
    border-color: #407f2e !important;
    background-color: #407f2e !important;
	box-shadow: none !important;
}

#wpcf7-f2919-o2 p{
	margin-bottom: 0;
}