/*
Theme Name: ABC Paving Theme
Author: Leadburst Marketing, Ltd.
Author URI: http://leadburst.com
Template: Total
Version: 1.1
*/
/* General Header CSS Styles */
/* Top Bar */
#top-bar-wrap { border-bottom-width: 8px; }

.top_phonenum { white-space: nowrap; text-decoration: none; }

.top_social { padding-top: 7px; }
.top_social--label { margin-right: 10px; font-size: 14px; font-weight: 500; }
.top_social--icon { display: inline-block; overflow: hidden; width: 19px; height: 17px; margin-right: 5px; text-indent: -9999px; background-image: url("img/socail-media-icons.png"); }
.top_social--icon:last-child { margin-right: 0; }
.top_social--icon.blog { background-position: 0 0; }
.top_social--icon.pinterest { background-position: 0 -17px; }
.top_social--icon.storeboard { background-position: 0 -34px; }
.top_social--icon.linkedin { background-position: 0 -51px; }
.top_social--icon.twitter { background-position: 0 -68px; }
.top_social--icon.facebook { background-position: 0 -85px; }
.top_social--icon.youtube { background-position: 0 -102px; }
.top_social--icon.googleplus { background-position: 0 -119px; }
.top_social--icon.instagram { background-position: 0 -136px; }

.navbar-style-one { height: 92px; margin-top: -46px; }
.navbar-style-one .dropdown-menu > li > a { height: 92px; line-height: 92px; }
.navbar-style-one .dropdown-menu > li > a > span.link-inner { padding: 0.8em; border-radius: 0; }

#site-navigation .dropdown-menu ul a { padding: 12px 20px; }

.page-header-table-cell { padding: 0; text-align: left; }

.page-header-content-wrapper { position: relative; display: inline-block; padding: 40px 40px; background: -webkit-linear-gradient(left, rgba(26, 24, 24, 0.87) 0%, rgba(26, 24, 24, 0.87) 1%, rgba(26, 24, 24, 0.87) 66%, rgba(26, 24, 24, 0.6) 83%, rgba(26, 24, 24, 0) 100%); background: -o-linear-gradient(left, rgba(26, 24, 24, 0.87) 0%, rgba(26, 24, 24, 0.87) 1%, rgba(26, 24, 24, 0.87) 66%, rgba(26, 24, 24, 0.6) 83%, rgba(26, 24, 24, 0) 100%); background: linear-gradient(to right, rgba(26, 24, 24, 0.87) 0%, rgba(26, 24, 24, 0.87) 1%, rgba(26, 24, 24, 0.87) 66%, rgba(26, 24, 24, 0.6) 83%, rgba(26, 24, 24, 0) 100%); filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#de1a1818', endColorstr='#001a1818',GradientType=1 ); }
.page-header-content-wrapper h1 { float: left; line-height: 1.2em; }

.page-header.background-image-page-header .page-subheading { position: relative; top: 8px; float: left; margin-left: 40px; }
.page-header.background-image-page-header .page-subheading img:hover { opacity: 0.8; }

@media (max-width: 767px) { #top-bar-content { font-size: 17px !important; }
  .top-bar-right { padding-top: 0 !important; }
  .top_social--label { display: none; }
  .page-header-content-wrapper { padding: 30px; }
  .page-header-content-wrapper h1 { font-size: 40px !important; }
  .page-header.background-image-page-header .page-subheading { top: 15px; margin-left: 0; }
  .page-header.background-image-page-header .page-subheading img { max-width: 140px; } }
@media (min-width: 768px) and (max-width: 1199px) { #site-logo img { max-width: 300px !important; }
  .navbar-style-one .dropdown-menu > li > a { padding: 0; } }
@media (max-width: 899px) { #top-bar-content, #top-bar-social-alt { float: none; display: block; text-align: center; } }
@media (max-width: 399px) { #top-bar-content, #top-bar-social-alt { float: none; display: block; text-align: center; } }
/* General Main CSS Styles */
.uppercase { text-transform: uppercase; }

.underline { position: relative; padding-bottom: 10px; }
.underline::before { position: absolute; bottom: 0; display: block; width: 85px; height: 0; content: ' '; border-bottom: 4px solid #f9eb04; }
.underline::after { position: absolute; bottom: 0; display: block; width: 85px; height: 0; content: ' '; border-bottom: 4px solid #7a7474; }
.underline.center::before { left: 50%; margin-left: -85px; }
.underline.center::after { right: 50%; margin-right: -85px; }
.underline.left::before { left: 0; }
.underline.left::after { left: 85px; }

#wpcf7-f648-o1 .fields-row.half { float: left; }
#wpcf7-f648-o1 .fields-row.half:nth-child(odd) { width: 57%; padding-right: 40px; }
#wpcf7-f648-o1 .fields-row.half:nth-child(even) { width: 43%; }
#wpcf7-f648-o1 .fields-row .field-item { position: relative; padding-bottom: 13px; }
#wpcf7-f648-o1 .fields-row .field-item .fa { font-size: 24px; position: absolute; z-index: 1; top: 13px; left: 15px; width: 28px; text-align: center; color: #888; }
#wpcf7-f648-o1 .fields-row .field-item input { font-size: 18px; width: 100%; margin: 0; padding: .5em .5em .5em 55px; color: #1e1e1e; border-width: 4px !important; }
#wpcf7-f648-o1 .fields-row .field-item input:focus { border-color: #f9eb04; box-shadow: inset 0 0 2px rgba(0, 0, 0, 0.5); }
#wpcf7-f648-o1 .fields-row p { font-size: 20px; font-weight: 700; color: white; }
#wpcf7-f648-o1 .fields-row small { font-size: 70%; font-weight: 400; color: white; }
#wpcf7-f648-o1 .wpcf7-list-item { display: block; margin-bottom: 5px; }
#wpcf7-f648-o1 .wpcf7-list-item label { font-size: 16px; }
#wpcf7-f648-o1 .wpcf7-list-item input { width: 18px; height: 18px; margin-top: 4px; margin-right: 5px; vertical-align: top; }
#wpcf7-f648-o1 .form-submit { text-align: center; padding-top: 15px; }
#wpcf7-f648-o1 .form-submit input { font-size: 24px; font-weight: 700; text-transform: uppercase; color: black; border-radius: 0; }
#wpcf7-f648-o1 .form-submit input:hover { color: white; background: #e13c0a; }
#wpcf7-f648-o1 div.wpcf7-validation-errors { font-size: 18px; font-weight: 700; padding: 15px; text-align: center; color: white; border: 4px solid white; background: #f03200; }
#wpcf7-f648-o1.wpcf7 .wpcf7-mail-sent-ok { font-size: 30px; font-weight: 700; padding: 15px; text-align: center; color: white; border: 4px solid white; background: #0fa028; }

/* General Footer CSS Styles */
.footer-callout-content { text-align: center; line-height: 1.2em; }
.footer-callout-content a { white-space: nowrap; font-weight: 700; }

#footer-menu { width: 100%; margin: 0 auto; text-align: center; }
#footer-menu li { margin: 0; padding: 0; }
#footer-menu li:after { padding: 0 15px; content: '|'; }
#footer-menu li:last-child:after { content: ''; }
#footer-menu a { color: #1e1e1e; font-weight: 600; }
.footer-credits{text-align:center;}
.footer-credits a:hover{opacity:.8;}
@media (max-width: 767px) { .footer-callout-content { font-size: 26px; } }
/* Homepage CSS Styles */
.quick_box { text-align: center; }
.quick_box--media { display: block; transition: all 0.3s; color: #424146; background-color: #fee900; background-repeat: no-repeat; background-position: center; }
.quick_box--media .inner { position: relative; min-height: 226px; padding-bottom: 30px; transition: all 0.2s; background: transparent url("img/quick-box-arrow.png") bottom center no-repeat; background-size: contain; }
.quick_box--media .icon { padding-top: 44px; transition: all 0.2s; }
.quick_box--media .title { position: absolute; right: 0; bottom: 30px; left: 0; width: 100%; transition: all 0.2s; text-transform: uppercase; font-size: 22px; font-weight: 400; line-height: 1.1em; }
.quick_box--media:hover { cursor: pointer; text-decoration: none; background-color: #323237; }
.quick_box--media:hover .icon img { -webkit-filter: invert(100%); -moz-filter: invert(100%); filter: invert(100%); }
.quick_box--media:hover .title { color: #fee900; }
.quick_box--content { min-height: 115px; padding: 15px 15px 20px; background-color: #424147; }
.quick_box--content p { margin: 0; color: white; font-size: 14px; line-height: 1.45em; }
.quick_box--content p a { color: #fee80a; }

.service_quick_boxes a:hover { text-decoration: none; }

.service_quick_box { position: relative; overflow: hidden; min-height: 280px; padding-top: 63px; transition: all .1s; text-align: center; background-color: rgba(0, 0, 0, 0.1); }
.service_quick_box.box-1 { background-color: rgb(66,65,71); }
.service_quick_box.box-2 { background-color: rgb(137,137,139); }
.service_quick_box.box-3 { background-color: rgb(190,191,191); }
.service_quick_box.box-4 { background-color: rgb(222,223,221); }
.service_quick_box.box-5 { background-color: rgb(231,231,231); }
.service_quick_box.box-6 { background-color: rgb(190,191,191); }
.service_quick_box.box-7 { background-color: rgb(137,137,139); }
.service_quick_box.box-8 { background-color: rgb(66,65,71); }
.service_quick_box .icon { display: block; width: 185px; height: 95px; margin: 0 auto; background-image: url("img/quickboxes-spritesheet.png"); background-repeat: no-repeat; }
.service_quick_box .icon-1 { background-position: 0 0; }
.service_quick_box .icon-2 { background-position: 0 -95px; }
.service_quick_box .icon-3 { background-position: 0 -190px; }
.service_quick_box .icon-4 { background-position: 0 -285px; }
.service_quick_box .icon-5 { background-position: 0 -380px; }
.service_quick_box .icon-6 { background-position: -370px 0; }
.service_quick_box .icon-7 { background-position: -370px -190px; }
.service_quick_box .title { padding: 30px 15px 15px; text-transform: uppercase; font-size: 22px; line-height: 1.2em; }
.service_quick_box.box-1 .title { color: rgb(255,255,255); }
.service_quick_box.box-2 .title { color: rgb(214,216,213); }
.service_quick_box.box-3 .title { color: rgb(51,50,55); }
.service_quick_box.box-4 .title { color: rgb(118,118,120); }
.service_quick_box.box-5 .title { color: rgb(110,110,110); }
.service_quick_box.box-6 .title { color: rgb(51,50,55); }
.service_quick_box.box-7 .title { color: rgb(214,216,213); }
.service_quick_box.box-8 { padding-top: 0; }
.service_quick_box.box-8 .title { position: absolute; top: 50%; right: 0; left: 0; display: block; width: 140px; height: 140px; margin: -70px auto 0; padding: 47px 10px; transition: all 0.3s; color: #333237; border-radius: 50%; background-color: #fee80a; font-weight: 700; line-height: 1.1em; }
.service_quick_box:hover { background-color: #fee809; }
.service_quick_box:hover .icon-1 { background-position: -185px 0; }
.service_quick_box:hover .icon-2 { background-position: -185px -95px; }
.service_quick_box:hover .icon-3 { background-position: -185px -190px; }
.service_quick_box:hover .icon-4 { background-position: -185px -285px; }
.service_quick_box:hover .icon-5 { background-position: -185px -380px; }
.service_quick_box:hover .icon-6 { background-position: -370px -95px; }
.service_quick_box:hover .icon-7 { background-position: -370px -285px; }
.service_quick_box:hover .title { color: #333436; }
.service_quick_box:hover.box-8 .title { transform: scale(1.2); color: #fee80a; background-color: #333237; }

.free-paving-estates-content { max-width: 1180px; margin: 0 auto; }
.free-paving-estates-content a { color: #fee80a; }

@media (min-width: 768px) and (max-width: 1024px) { .wpex-vc-column-spacing-40 .quick-boxes-top .vc_column-inner { padding: 0 5px; }
  .quick_box--media .icon img { width: 80%; max-width: 100%; }
  .quick_box--media .title { font-size: 18px; }
  .quick_box.box-1 .quick_box--media .title { font-size: 18px; }
  .quick_box--content p { font-size: 13px; }
  .service_quick_box { padding-top: 50px; }
  .service_quick_box .title { font-size: 18px; } }
/* Subpage Styles */
.years_experience { box-shadow: 0 3px 7px rgba(0, 0, 0, 0.2); }
.years_experience--content p { padding-top: 20px; font-size: 30px; font-weight: 300; font-style: italic; line-height: 40px; }
.years_experience--content strong { font-weight: 700; }

.for-what-section { background-image: url("img/what-wedo-bg.jpg"); background-repeat: no-repeat; background-position: 50%; background-size: cover; }

ul.list-style-1 { margin: 0; padding: 0; list-style: none; }
ul.list-style-1 li { margin: 0; padding: 0 0 0 34px; list-style: none; background: url("img/check-icon-3.png") no-repeat 0 2px; }

html .serve-map { background-position: top left !important; }

.locations-we-serve { padding: 350px 0 0 200px; }
.locations-we-serve ul.locations-list { float: left; margin: 0 80px 0 0; padding: 0; list-style: none; }
.locations-we-serve ul.locations-list:last-child { margin-right: 0; }
.locations-we-serve ul.locations-list li { margin: 0; padding: 1px 0 20px 40px; list-style: none; text-transform: uppercase; color: #444444; background: url("img/loc-bullet.png") no-repeat 0 0; font-size: 16px; font-weight: 300; line-height: 1.3em; }
.locations-we-serve ul.locations-list li strong { color: black; font-size: 20px; font-weight: 400; }

@media (max-width: 768px) { .years_experience--sign { display: none; }
  .years_experience--content { text-align: center; }
  .years_experience--content p { padding-top: 0; font-size: 20px; line-height: 25px; }
  .for-what-section { background-image: url("img/for-what-bg-mobile.jpg"); } }
@media (max-width: 1023px) { .locations-we-serve { padding: 150px 30px 0; } }
@media (max-width: 767px) { .locations-we-serve ul.locations-list { margin: 0 40px 0 0; }
  .locations-we-serve ul.locations-list:last-child { margin-right: 0; }
  .locations-we-serve ul.locations-list li { padding: 1px 0 20px 40px; font-size: 14px; }
  .locations-we-serve ul.locations-list li strong { font-size: 18px; } }
@media (max-width: 587px) { html .vc_custom_1467036167496 { margin-bottom: 20px !important; padding: 20px; background: rgba(255, 255, 255, 0.7); } }
html .faq-box .vc_toggle_title { padding-left: 40px !important; }
html .faq-box.vc_toggle_active .vc_toggle_title { border-color: rgba(0, 0, 0, 0.5); }
html .faq-box.vc_toggle_active .vc_toggle_title:hover { border-color: rgba(0, 0, 0, 0.5); }
html .faq-box .vc_toggle_content { padding: 25px !important; border-right: 1px solid #e4e4e4; border-left: 1px solid #e4e4e4; background-color: #fcfcfc; }
html .faq-box:last-child .vc_toggle_content { border-bottom: 1px solid #e4e4e4; }

.affiliations-box { min-height: 263px; }

#wpcf7-f4-p22-o2 .fields-row { margin-bottom: 20px; }
#wpcf7-f4-p22-o2 .fields-row .field-item.half { float: left; width: 50%; padding-right: 20px; }
#wpcf7-f4-p22-o2 .fields-row .field-item.half:last-child { padding-right: 0; }
#wpcf7-f4-p22-o2 .fields-row .field-item input, #wpcf7-f4-p22-o2 .fields-row .field-item textarea { border-color: #eaeaea; border-bottom-width: 4px; background: white; }
#wpcf7-f4-p22-o2 .fields-row .field-item input:focus, #wpcf7-f4-p22-o2 .fields-row .field-item textarea:focus { border-color: #3d3d3d; background: rgba(248, 234, 12, 0.1); }
#wpcf7-f4-p22-o2 .fields-row .field-item textarea { height: 350px; }
#wpcf7-f4-p22-o2 .fields-row .form-submit input { font-size: 20px; font-weight: 600; text-transform: uppercase; border-bottom: 5px solid #3d3d3d; border-radius: 0; }
#wpcf7-f4-p22-o2 .fields-row .form-submit input:hover { border-bottom-color: #faeb04; }

.contact-info-cta-box h3 { font-size: 22px; font-weight: 400; text-transform: uppercase; color: #000; }
.contact-info-cta-box .cta-info { margin-bottom: 25px; padding: 25px 20px; text-align: center; }
.contact-info-cta-box .cta-info p { font-size: 15px; font-weight: 600; line-height: 1.2em; margin: 0 0 10px; text-transform: uppercase; }
.contact-info-cta-box .cta-info h5 { font-size: 32px; line-height: 1em; margin: 0; white-space: nowrap; color: black; }
.contact-info-cta-box .cta-info h5 .fa { font-size: 26px; line-height: 34px; width: 34px; height: 34px; color: rgba(0, 0, 0, 0.3); border: 2px solid rgba(0, 0, 0, 0.3); border-radius: 50%; }
.contact-info-cta-box .cta-info h5 a { color: #0c9b6d; }
.contact-info-cta-box .cta-info.first { background: #f8ea0c; }
.contact-info-cta-box .cta-info.second { margin-bottom: 40px; color: white; background: #333333; }
.contact-info-cta-box .cta-info.second h5 { color: white; }
.contact-info-cta-box .cta-info.second h5 .fa { color: rgba(255, 255, 255, 0.5); border-color: rgba(255, 255, 255, 0.5); }
.contact-info-cta-box .cta-info.second h5 a { color: #f8ea0c; }

@media (max-width: 1150px) { .contact-info-cta-box .cta-info h5 { font-size: 26px; } }
@media (max-width: 991px) { .contact-section .vc_col-sm-8, .contact-section .vc_col-sm-4 { float: none; width: 100%; } }
@media (max-width: 599px) { #wpcf7-f4-p22-o2 .fields-row .field-item.half { float: none; width: 100%; padding-right: 0; } }
.blog-entry { padding: 35px 35px 10px; transition: all .2s; border-bottom: 5px solid #f8ea0c !important; background: rgba(0, 0, 0, 0.04); }
.blog-entry:hover { transform: scale(1.02); box-shadow: 0 5px 10px rgba(0, 0, 0, 0.2); }

.entries.left-thumbs .entry .entry-media { width: 40%; }

.entries.left-thumbs .entry .entry-details { width: 56%; }

.blog-entry-title { line-height: .7em; margin-bottom: 10px !important; }

.meta, .entry .meta { font-size: .8em; }

.blog-entry-excerpt p { font-size: .9em; line-height: 1.4em; }

.blog-entry-readmore { text-transform: uppercase; }
.blog-entry-readmore a { border-radius: 0; }

.sidebar-box { font-size: 16px; margin-bottom: 30px; padding: 25px; background: rgba(0, 0, 0, 0.02); }
.sidebar-box .widget-title { margin: -25px -25px 15px; padding: 15px 25px; border-bottom: 4px solid #7a7474; background: #f8ea0c; }

.wpex-widget-recent-posts { line-height: 18px; }
.wpex-widget-recent-posts-title { font-size: 14px; }
.wpex-widget-recent-posts-date { font-size: 12px !important; }

.single-post .page-header-content-wrapper, .archive .page-header-content-wrapper, .category .page-header-content-wrapper, .search .page-header-content-wrapper { display: block; padding: 0; background: none; filter: none; }
.single-post .page-header-content-wrapper h1, .archive .page-header-content-wrapper h1, .category .page-header-content-wrapper h1, .search .page-header-content-wrapper h1 { float: none; line-height: 1.3em; }
.single-post .page-header .page-header-title, .archive .page-header .page-header-title, .category .page-header .page-header-title, .search .page-header .page-header-title { font-size: 36px; }

input.wpcf7-form-control.wpcf7-submit{border-radius: 0px; width: 100%;}

.page-id-915 .page-header , .page-id-1012 .page-header , .page-id-1014 .page-header{display: none !Important; }

.page-id-915 #footer-callout-wrap , .page-id-1012 #footer-callout-wrap , .page-id-1014 #footer-callout-wrap {display: none !Important; }

.contactPageHeader{width: 90% !important; margin: 0px auto !important; max-width: 1210px !important;}


@media (max-width: 975px){
.contactPageHeader .wpb_column{width: 100% !important; }
.ctaButton{ float: none !important; width: 200px; margin: 0px auto; display: block;}
.contactPageHeader h1 , .contactPageHeader h2{text-align: center !important;}
}

#contactLinks .vcex-icon-box{
margin-bottom: 20px !important;
border-bottom-width: 1px !important;
padding-bottom: 20px !important;
border-bottom-color: #e5e5e5 !important;
border-bottom-style: dotted !important;
}