/*
Theme Name: Erickson and Sons
Theme URI: http://demo.qodeinteractive.com/bridge/
Description: A child theme of Bridge Theme
Author: Norse Sound Creative
Author URI: https://norsesoundcreative.com/
Version: 1.0.0
Template: bridge
*/
@import url("../bridge/style.css");

html{scroll-behavior:smooth}

header { position: fixed !important; }
.header_top { background-color: transparent !important; }
.header_bottom { background-color: transparent !important; }
.header_top .container_inner,
.header_bottom .container_inner { max-width: 1780px; margin: auto; width: 100%; }

header.scrolled .header_inner .header_top,
header.scrolled .header_inner .header_bottom  { background-color: black !important; }

a:hover,
a:hover span { color: #15b900 !important; }

.header_top .review-link { font-family: "Russo One", Sans-serif;  font-style: italic; }
.header_top .review-link a { color: white; font-family: "Russo One", Sans-serif; font-weight: 500; font-style: italic; font-size: 10px; }
.header_top .review-link a:hover { color: #15b900; }

.header_bottom  nav.main_menu>ul>li>a { font-family: "Russo One", Sans-serif; font-style: italic; color: white; font-weight: normal; padding: 0 20px; }
.header_bottom nav.main_menu>ul li.current-menu-item a { color:#15b900; } 
.header_bottom nav.main_menu ul li.menu-item-has-children:after { content: "\f107"; font-family: "Fontawesome"; font-size: 16px; position: absolute; top: 50%; transform: skewX(-12deg)translateY(-50%); right: 5px; font-weight: bold; color: var(--secondary); }
.header_bottom nav.main_menu ul li .drop_down_start { top: 80%; }
.header_bottom nav.main_menu ul li .drop_down_start li a { color: white; font-family: "Russo One", Sans-serif; font-weight: normal; font-style: italic; }


.content .container, 
.content .container .container_inner { max-width: 100%; width: auto !important; background-color: transparent !important; display: block !important; padding: 0px !important; }

#slider_title .elementor-widget-heading:before { content: ""; position: absolute; height: 260px; width: 260px; background-color: transparent; border: 30px solid #15b900; left: 0px; top: 50%; transform: skewX(-12deg)translateY(-50%); transform-origin: left; z-index: -1; }
#slider_title #bulldozer { position: unset; }
#slider_title #bulldozer img { width: 750px; position: absolute; top: -25%; right: 0px; }
#slider_title #bulldozer .elementor-widget-container { position: unset; }
#slider_title #slider_text p { width: 50%; }


@media (max-width: 1400px) { 
   #slider_title:before { top: -70px; } 
   #slider_title #bulldozer img { width: 700px; top: 50%; transform: translateY(-50%); }
   #slider_title .elementor-widget-wrap > div.elementor-element:first-child { width: 100% !important; max-width: 100%; }
   /* #slider_title .elementor-widget-wrap > div.elementor-element:nth-child(2) {  margin-top: 40px;} */
}

@media (max-width: 1000px) { 
   .header_top {  position: absolute; right: 70px; top: 43px; transform: translateY(-50%); display: flex !important; }
   .header_top .left { display: none; }
   .header_top .right { display: flex; }
   .header_inner_right { display: none; }
   .header_bottom { background-color: black !important; padding: 10px 20px !important; }
   #slider_title:before { height: 180px; width: 180px; }
   #slider_title #bulldozer img { width: 500px; top: 50%; opacity: 0.7; }
   header .container_inner .header_inner_left { display: flex; align-items: center; flex-direction: row-reverse; }
   #slider_title .elementor-widget-heading:before { height: 200px; width: 200px; }
   header .container_inner .header_inner_left .mobile_menu_button { height: 70px; margin-right: 0px; } 
   header .container_inner .header_inner_left .logo_wrapper { height: 70px!important; left: 0px; }
   header .container_inner .header_inner_left .logo_wrapper a { height: 50px !important; left: 20px; }
   header .container_inner .header_inner_left .mobile_menu_button span { font-size: 18px; color: #15b900; }
   .header_bottom .container_inner .mobile_menu { background-color: black; }
   .header_bottom .container_inner .mobile_menu ul#menu-main-menu-1 { background-color: black; }
   .header_bottom .container_inner .mobile_menu ul#menu-main-menu-1 li a { font-family: "Russo One", Sans-serif; font-style: italic; text-transform: uppercase; color: white; }
   .header_bottom .container_inner .mobile_menu ul#menu-main-menu-1 li.current-menu-item a { color: #15b900; } 
}

@media (max-width: 991px) { 
   #slider_title #slider_text p { width: 100%; }
}


@media (max-width: 599px) { 
   header .container_inner .header_inner_left .logo_wrapper a { left: 0px; }
}

@media (max-width: 567px) { 
   h1, h2, h3, h4, h5, h6 { text-transform: none !important; }
   #slider_title:before { top: -40px; }
   #slider_title #bulldozer img { opacity: 0.6; top: 50%; width: 320px; }
   #slider_title .elementor-widget-wrap > div.elementor-element:first-child h2 br { display: none; }
}

@media (max-width: 400px) { 
   .header_top  { display: none !important; }
}

#services_section .services:before { content: ""; position: absolute; height: 70px; width: 70px; background-color: transparent; border: 10px solid #15b900; left: 0px; top: 0px; transform: skewX(-12deg);  transform-origin: bottom; }

@media (max-width: 1290px) { 
   #services_section .elementor-container .elementor-widget-container h3 { font-size: 24px; }
}


#about_section:before { content: ""; width: 50%; background-color: white; height: 100%; position: absolute; left: 0px; top: 0px; transform: skewX(-12deg); transform-origin: bottom; }
#about_section .about-title .elementor-widget-container:before { content: ""; position: absolute; height: 150px; width: 150px; background-color: transparent; border: 25px solid black; left: 0px; top: 50%; transform: skewX(-12deg)translateY(-50%);  transform-origin: bottom; }
#about_section .about-video .elementor-widget-container { overflow: inherit; }
#about_section .about-title .elementor-widget-container h2 { position: relative; z-index: 9; } 
#about_section .about-video .elementor-widget-container::before { content: ""; width: 100%; height: 100%; position: absolute; background-color: #15b900; right: -20px; bottom: -20px;}
#about_section .about-video .elementor-widget-container img { z-index: 999; position: relative; }

@media (max-width: 1740px) {  
   #about_section { padding-left: 140px; }
}

@media (max-width: 1136px) {  
   #about_section { padding-left: 20px; }
   #about_section:before { transform-origin: top; }
}

@media (max-width: 1024px) {
   #about_section:before { display: none; } 
   #about_section .about-title h2 { color: white; }
   #about_section .about-title .elementor-widget-container:before { border-color: #15b900; }
   #about_section .elementor-widget-text-editor .elementor-widget-container p { color: white; }
}  


#who_are_we .title .elementor-widget-container h2 { position: relative; display: inline-block; }
#who_are_we .title .elementor-widget-container h2:before { content: ""; position: absolute; height: 150px; width: 150px; background-color: transparent; border: 25px solid black; left: -70px; top: 50%; transform: skewX(-12deg)translateY(-50%);  transform-origin: bottom; z-index: -1; }

@media (max-width: 567px) {  
   #who_are_we .title .elementor-widget-container h2:before { left: -60px; height: 130px; width: 130px; }
}


#services .services .services-wrapper { display: flex; justify-content: flex-start; flex-wrap: wrap; }
#services .services .services-wrapper .service { width: 33.33%; height: 280px; }
#services .services .services-wrapper .service .wrapper { display: flex; flex-direction: column; justify-content: center; align-items: center; height: 100%; background-color: #15b900; transition: background-color 0.5s ease; }
#services .services .services-wrapper .service .wrapper .image { position: absolute; z-index: -1; height: 100%; width: 100%; left: 0px; right: 0; top: 0; bottom: 0; mix-blend-mode: multiply; }
#services .services .services-wrapper .service .wrapper .image img { width: 100%; height: 100%; object-fit: cover; }
#services .services .services-wrapper .service .wrapper .service-title h3 { color: white; display: table-caption; text-align: center; line-height: 28px } 
#services .services .services-wrapper .service .wrapper .service-title h3 a { color: inherit; font-family: inherit; font-style: inherit; font-size: 24px; }
#services .services .services-wrapper .service .wrapper .category p { color: white;  margin-top: 20px; display: none; }
#services .services .services-wrapper .service:hover .wrapper { background-color: transparent; }
#services .services .services-wrapper .service:hover .service-title h3 { color: #15b900; }
#services .services .services-filter { display: none; }
#services .services .services-filter .filter-wrapper { display: flex; justify-content: center; flex-wrap: wrap;  background-color: black; }
#services .services .services-filter .filter-wrapper button { background-color: transparent; color: white; border: 0px; text-transform: uppercase; font-family: "Russo One", Sans-serif; font-size: 18px; font-style: italic; padding: 40px 35px;} 
#services .services .services-filter .filter-wrapper button:hover { cursor: pointer; color: #16BA00; }
#services .services .services-filter .filter-wrapper button.active {  color: #16BA00; }

@media (max-width: 1024px) { 
   #services .services .services-filter .filter-wrapper { background-color: white; }
   #services .services .services-filter .filter-wrapper button { color: #15b900; }
}

@media (max-width: 991px) { 
   #services .services .services-wrapper .service { width: 50%; }
}

@media (max-width: 767px) { 
   #services .services .services-filter .filter-wrapper button { padding: 30px 20px; }
}

@media (max-width: 618px) { 
   #services .services .services-wrapper .service { width: 100%; }
}

@media (max-width: 418px) { 
   #services .services .services-wrapper .service { height: 330px; }
   #services .services .services-wrapper .service .wrapper .service-title h3 a { line-height: 1.3em; text-transform: capitalize !important; font-size: 32px; }
}


#testimonials > .elementor-container::before { content: ""; width: 41%; background-color: black; height: 100%; position: absolute; left: 0px; top: 0px; transform: skewX(-12deg); transform-origin: bottom; }
#testimonials > .elementor-container .title h2 { font-size: 55px; line-height: 1.2em; }
#testimonials > .elementor-container .title:before { content: ""; position: absolute; height: 225px; width: 225px; background-color: transparent; border: 30px solid #16ba00; left: 0px; top: 50%; transform: skewX(-12deg)translateY(-50%);  transform-origin: bottom; z-index: -1; }
#testimonials > .elementor-container .testimonial_content_inner { background-color: transparent !important; display: flex; flex-direction: column-reverse; padding: 0px; }
#testimonials > .elementor-container .testimonial_text_inner p { color: black; }
#testimonials > .elementor-container .testimonial_content_inner .testimonial_title_holder { margin-top: 20px; }
#testimonials > .elementor-container .testimonial_text_inner p.testimonial_author { font-family: "Russo One", Sans-serif; font-size: 18px; color: #15ba00; font-style: italic; }
#testimonials > .elementor-container .testimonial_text_inner p.testimonial_author:before { content: "- "; }
#testimonials > .elementor-container ol li { margin: 0 7px; }
#testimonials > .elementor-container ol li a { width: 15px; height: 15px; border-radius: 0px; border: 3px solid #16ba00; background-color: #16ba00; }
#testimonials > .elementor-container ol li a.flex-active { background-color: black; }

@media (max-width: 1420px) { 
   #testimonials > .elementor-container::before { left: -20px; }
}

@media (max-width: 991px) { 
   #testimonials > .elementor-container .title h2 { font-size: 40px; }
   #testimonials > .elementor-container .title:before { left: -40px; }
}

@media (max-width: 890px) { 
   #testimonials > .elementor-container .elementor-element-populated { padding: 0px 75px 0px 75px; }
}

@media (max-width: 767px) {
   #testimonials > .elementor-container::before  { display: none; }
   #testimonials > .elementor-container .title h2 { color: black; }
   #testimonials > .elementor-container .title:before { height: 160px; width: 160px; left: 0px; }
   #testimonials > .elementor-container .elementor-element-populated { padding: 0px; }
} 


.content .content_inner .title_outer .title { position: relative; background-repeat: no-repeat; height: 400px !important; background-size: cover !important; background-position-y: center; }
.content .content_inner .title_outer .title:before{ content: ""; position: absolute; width: 100%; height: 100%; background-color: black; opacity: 0.7; }
.content .content_inner .title_outer .title .title_holder { position: absolute; top: 55%; left: 50%; transform: translateX(-50%); padding-top: 0px !important; z-index: 9;}
.content .content_inner .title_outer .title .title_subtitle_holder { display: block !important; max-width: 1440px; margin: auto; padding: 0px !important; }
.content .content_inner .title_outer .title .title_subtitle_holder .title_subtitle_holder_inner { display: flex; flex-direction: column; justify-content: center; text-align: center; }
.content .content_inner .title_outer .title .title_subtitle_holder .title_subtitle_holder_inner h1 { font-size: 44px; color: white; font-weight: 500; }
.content .content_inner .title_outer .title .title_subtitle_holder .title_subtitle_holder_inner .separator { display: none; }
.content .content_inner .title_outer .title .title_subtitle_holder .title_subtitle_holder_inner .breadcrumb { position: relative; }
.content .content_inner .title_outer .title .title_subtitle_holder .title_subtitle_holder_inner .breadcrumb a,
.content .content_inner .title_outer .title .title_subtitle_holder .title_subtitle_holder_inner .breadcrumb span { color: white; font-size: 16px; font-family: 'Russo One', sans-serif; text-transform: uppercase; font-weight: 500; }
.content .content_inner .title_outer .title .title_subtitle_holder .title_subtitle_holder_inner .breadcrumb span { color: #15b900; }
.content .content_inner .title_outer .title .title_subtitle_holder .title_subtitle_holder_inner .breadcrumb .delimiter { font-size: 0px; }
.content .content_inner .title_outer .title .title_subtitle_holder .title_subtitle_holder_inner .breadcrumb .delimiter::before { content: "\f105"; font-family: Fontawesome; font-size: 18px; padding: 0px 12px; font-weight: 700; color: white; }
.content .elementor-container .inner-page-title:before { content: ""; position: absolute; height: 225px; width: 225px; background-color: transparent; border: 30px solid #16ba00; left: 0px; top: 50%; transform: skewX(-12deg)translateY(-50%); transform-origin: left; z-index: -1; }
.content .elementor-container .inner-page-title { padding-left: 75px; line-height: 1.3em; margin-bottom: 110px !important; }
.content .elementor-container .inner-page-title h2 { line-height: 1.3em; margin-top: 10px; }


@media (max-width: 1024px) { 
   .content .elementor-container .inner-page-title h2 { font-size: 40px; }
}

@media (max-width: 1000px) { 
   /* .content .content_inner .title_outer .title { background: inherit; } */
   .content .elementor-container .inner-page-title { margin-bottom: 80px !important; }
   .content .elementor-container .inner-page-title:before { height: 180px; width: 180px; }
   .content .content_inner .title_outer .title .title_holder { top: 0px; }
   .content .content_inner .title_outer .title .not_responsive img { height: 400px; object-fit: cover; }
   .content .content_inner .title_outer .title .not_responsive:before {  content: ""; position: absolute; width: 100%; height: 100%; background-color: black; opacity: 0.7; z-index: 1; }
   .content .content_inner .title_outer .title .title_subtitle_holder { position: absolute; top: 50%; }
}

@media (max-width: 400px) { 
   .content .elementor-container .inner-page-title { padding-left: 40px; }
}


section#about_team:before { content: ""; position: absolute; background-color: black; height: 100%; width: 50%; top: 0px; right: 0px; z-index: -1;}

@media (max-width: 1024px) {
   section#about_team:before { display: none; }
}


/* section#mission_vision { background-size: 50% 100%; } */
section#mission_vision:before { content: ""; position: absolute; width: 100%; height: 100%; top: 0; left: 0; background: rgba(23,198,47); background: linear-gradient(270deg, rgba(23,198,47,0) 0%, rgba(23,198,47,1) 42%); }

@media (max-width: 1560px) {
   section#mission_vision { background-size: contain; }
}

@media (max-width: 900px) {
   section#mission_vision { background-size: cover; }
}

section#services_intro .elementor-container .inner-page-title { margin: auto; }


#contact-section .gform_wrapper form .ginput_container input,
#contact-section .gform_wrapper form .ginput_container textarea { background-color: #dcf5d9;  font-family: "Russo One", Sans-serif; font-size: 18px; font-style: italic; height: auto; padding: 25px; font-weight: normal; }
#contact-section .gform_wrapper form .gform_footer input[type=submit] { color: #FFFFFF; background-color: var( --e-global-color-primary ); border-style: solid; border-width: 2px 2px 2px 2px; border-color: var( --e-global-color-secondary ); border-radius: 0px 0px 0px 0px; padding: 8px 25px; height: auto; font-family: "Russo One", Sans-serif; font-weight: normal; font-style: italic; font-size: 15px; }
#contact-section .gform_wrapper form .gform_footer input[type=submit]:hover { color: #15b900; background-color: white; }
#contact-section .gform_wrapper form .gform_footer .gform_ajax_spinner { margin-left: 20px; }


.staff .q_team .q_team_image img { height: 440px; object-fit: cover; }
.staff .q_team .q_team_title_holder span{ color: #15b900 !important; font-weight: 300; letter-spacing: -1px; }


.sitemap-col { justify-content: center; padding: 80px 20px; }
.sitemap-col ul { list-style: none; gap:10px !important; }
.sitemap-col ul li { position: relative; padding-left: 20px; }
.sitemap-col ul li:before {  content: ""; position: absolute; height: 5px; width: 5px; background-color: transparent; border: 3px solid #16ba01; left: 0px; top: 50%; transform: translateY(-50%);  transform-origin: bottom; z-index: -1;  }
.sitemap-col ul li a { font-family: "Russo One", Sans-serif; font-style: italic; color: black !important; }

@media (max-width: 600px) {
   .sitemap-col button.wp-block-navigation__responsive-container-open  { display: none; } 
   .sitemap-col button.wp-block-navigation__responsive-container-close  { display: none; } 
   .sitemap-col .wp-block-navigation__responsive-container { display: block; position: unset; }
}

@media (max-width: 567px) {
   #contact-section .gform_wrapper  form .ginput_container input,
   #contact-section .gform_wrapper  form .ginput_container textarea { padding: 15px 25px; }
}


.page_not_found a.qbutton { font-family: "Russo One"; font-style: italic; color: white; background-color: #16BA00; font-weight: normal; padding: 10px 30px; font-size: 15px; border-radius: 0px; }
.page_not_found a.qbutton:hover { border-color: #000; color: white; background-color: white;}


footer .footer_inner .footer_top_holder { background-color: black; }
footer .footer_inner .footer_top_holder .container_inner { max-width: 1470px; width: 100%; }
footer .footer_inner .footer_top_holder .container_inner .widget h5 { font-size: 18px; color: white; margin-bottom: 50px; }
footer .footer_inner .footer_top_holder .container_inner .widget li a { font-size: 16px; color: white; }
footer .footer_inner .footer_top_holder .container_inner .widget li a:hover { color: #16ba00 !important; }
footer .footer_inner .footer_top_holder .container_inner .widget li:last-child a { white-space: nowrap; }
footer .footer_inner .footer_top_holder .container_inner .column2 .widget  { padding-left: 55px; }
footer .footer_inner .footer_top_holder .container_inner .widget .footer-address { margin-top: 50px; }
footer .footer_inner .footer_top_holder .container_inner .widget .footer-address li { display: flex; padding: 3px 0px; align-items: flex-end; }
footer .footer_inner .footer_top_holder .container_inner .widget .footer-address li span { width: 60%; color: white;  }
footer .footer_inner .footer_top_holder .container_inner .widget .footer-address li span:first-child { width: 40%; color: #15b900; }

@media (max-width: 1470px) {
   footer .footer_inner .footer_top_holder .container_inner { padding: 0px 20px; max-width: 100%; }
}

@media (max-width: 1300px) {
   footer .footer_inner .footer_top_holder .container_inner .widget .footer-address li span:first-child { width: 25%; }
}

@media (max-width: 1100px) {
   footer .footer_inner .footer_top_holder .container_inner .three_columns > div { width: 50%; }
   footer .footer_inner .footer_top_holder .container_inner .three_columns > div:last-child { margin-top: 30px; width: 100%; }
   footer .footer_inner .footer_top_holder .container_inner .three_columns > div figure img { width: 320px;  }
}

@media (max-width: 567px) {
   footer .footer_inner .footer_top_holder .container_inner .column2 .widget { padding-left: 0px; margin-top: 20px; }
   footer .footer_inner .footer_top_holder .container_inner .three_columns > div { width: 100%; }
}

@media (max-width: 400px) {
   footer .footer_inner .footer_top_holder .container_inner .widget .footer-address li span:first-child { width: 25%;}
   footer .footer_inner .footer_top_holder .container_inner .widget .footer-address li span { width: 75%; }
}

footer .footer_inner .footer_bottom_holder { background-color: #15b900; }
footer .footer_inner .footer_bottom_holder .container_inner { max-width: 1470px; width: 100%; }
footer .footer_inner .footer_bottom_holder .container_inner .footer_bottom { height: auto; padding: 8px 0px; }
footer .footer_inner .footer_bottom_holder .container_inner .footer_bottom p { text-align: left; font-size: 14px; color: white; }
footer .footer_inner .footer_bottom_holder .container_inner .column2  .footer_bottom p { text-align: right; color: white; }
footer .footer_inner .footer_bottom_holder .container_inner .column2  .footer_bottom p a { color: white; }
footer .footer_inner .footer_bottom_holder .container_inner .column2  .footer_bottom p a:hover { color: black !important; }

@media (max-width: 1470px) {
   footer .footer_inner .footer_bottom_holder .container_inner { padding: 0px 20px; max-width: fit-content; }
}

@media (max-width: 768px) {
   footer .footer_inner .footer_bottom_holder .container_inner { padding: 0px; }
   footer .footer_inner .footer_bottom_holder .container_inner .footer_bottom p { text-align: center; }
   footer .footer_inner .footer_bottom_holder .container_inner .footer_bottom_columns  { display: flex; flex-direction: column; }
   footer .footer_inner .footer_bottom_holder .container_inner .footer_bottom_column { width: 100%; }
   footer .footer_inner .footer_bottom_holder .container_inner .column2 .footer_bottom p { text-align: center; }
}