@charset "utf-8";
/* CSS Document */

:root {
  --grey: rgb(80,83,80);
  --black: rgb(29,29,27);
  --blue: rgb(0,113,206);
  --white: rgb(255,255,255);
  --grey2: rgb(238,238,238);
  --grey3: rgb(200,200,200);
}

body {margin: 0; padding: 0; font-family: "Roboto Condensed", sans-serif; font-size: 20px; color: var(--grey); background-color: var(--white);}

img {width: 100%; height: auto; border: 0; display: block;}
.clearer::after {content: ""; display: table; clear: both;}
.btn {padding: 10px 18px; color: var(--white)!important; background-color: var(--blue); text-decoration: none; transition: all .5s ease;}
.btn:hover {background-color: var(--black); transition: all .5s ease; font-weight: 700;}


.header {width: calc(100% - 50px); background-color: var(--white); position: fixed; top: 0; left: 0; z-index: 1000;}
.header-top {width: 100%; height: 20px; background-color: var(--grey2); transition: all .5s ease;}
.header-inner {width: 90%; max-width: 1728px; float: right; position: relative; padding: 30px 0 20px 0; transition: padding .5s ease;}
.brand {width: 40%; max-width: 280px; transition: all .5s ease;}
.header::after {content: ""; position: absolute; top: 0; right: -50px; background-color: var(--grey2); height: 100%; width: 50px;}

.phonemail {position: absolute; right: 38px; bottom: 20px; transition: all .5s ease;}
.h-phone, .h-mail {width: 41px; height: 41px; background-color: var(--black); color: var(--white); text-align: center; font-size: 16px; box-sizing: border-box; vertical-align: middle; display: table-cell;}
.h-phone {position: relative; right: 5px;}
.h-phone:hover, .h-mail:hover {background-color: var(--blue);}


.slider-main {width: 100%; background-color: var(--grey2);}
.slider {width: calc(100% - 50px);}
.slider .ls-wp-container {max-height: 800px!important; overflow: hidden;}
.slider-text {position: absolute; left: 0; bottom: 0;}
.slider-text h2, .slider-text h3 {display: table; box-sizing: border-box;}
.slider-text h2 {font-size: 54px; color: var(--white); text-transform: uppercase; background-color: var(--blue); margin: 0; margin: 7px 0 0 0; padding: 10px 14px; font-weight: 900;}
.slider-text h3 {font-size: 26px; color: var(--white); text-transform: uppercase; background-color: var(--black); margin: 7px 0 0 0; padding: 8px 12px;}
@media screen and (max-width: 1715px){
.slider-text h2 {font-size: 48px;}
.slider-text h3 {font-size: 22px;}
}
@media screen and (max-width: 1420px){
.slider-text h2 {font-size: 42px;}
.slider-text h3 {font-size: 20px;}
}
@media screen and (max-width: 1280px){
.slider-text {left: -150px;}
}
@media screen and (max-width: 940px){
.slider-text h2 {font-size: 32px;}
.slider-text h3 {font-size: 16px;}
}
@media screen and (max-width: 710px){
.slider-text {left: -300px; top: -110px;}
}
@media screen and (max-width: 580px){
.slider-text {left: -250px; top: -110px;}
}
@media screen and (max-width: 540px){
.h-phone, .h-mail {width: 34px; height: 34px;}
.phonemail {right: 20px;}
}
@media screen and (max-width: 480px){
.slider-text h2 {font-size: 28px;}
.slider-text h3 {font-size: 15px;}
.slider-text {left: -230px; top: -100px;}
.brand {width: 50%;}
}
@media screen and (max-width: 440px){
.slider-text h2 {font-size: 22px; margin: 4px 0 0 0; padding: 8px 10px;}
.slider-text h3 {font-size: 13px; margin: 4px 0 0 0; padding: 6px 8px;}
.slider-text {left: -200px; top: -90px;}
}
@media screen and (max-width: 390px){
.slider-text h2 {font-size: 20px; margin: 4px 0 0 0; padding: 8px 8px;}
.slider-text h3 {font-size: 11px; margin: 4px 0 0 0; padding: 6px 6px;}
.slider-text {left: -170px; top: -60px;}
}
@media screen and (max-width: 960px){
.header-inner {width: 98%;}
}
@media screen and (max-width: 680px){
.header, .slider {width: calc(100% - 20px);}
.heder::after {right: -20px; width: 20px;}
}

.row-fluid {position: absolute; top: 119px; left: 0; width: 100%;}


.content {width: 92%; max-width: 1200px; position: relative; padding: 200px 0; margin: 0 auto;}

.textbild {width: 100%; max-width: 1060px; margin: 0 auto;}
.c-textbild, .c-bildtext {width: 53.77358454%; max-width: 570px; float: left; position: relative;}
.c-textbild {box-sizing: border-box; padding: 85px 70px; background-color: var(--grey2); z-index: 10; top: 110px;}
.c-bildtext {z-index: 1; margin-left: -80px;}
.c-textbild h5, .content h5 {font-size: 16px; color: var(--blue); text-transform: uppercase; margin: 0 0 30px 0;}
.c-textbild h2, .content h2, .content h1 {font-size: 30px; color: var(--black); margin: 0 0 40px 0; font-weight: 900;}
.c-textbild p, .content p {font-size: 20px; line-height: 32px; color: var(--grey); margin: 0 0 40px 0;}
.c-textbild::after, .c-textbild::before {content: ""; width: 70px; height: 10px; position: absolute; background-color: var(--blue); left: 0px;}
.c-textbild::after {bottom: -20px;}
.c-textbild::before {top: -20px;}
.c-bildtext::after {content: ""; width: 70px; height: 10px; position: absolute; background-color: var(--blue); right: 0px; bottom: -20px; display: none;}

.content h3 {font-size: 24px; font-weight: 900; color: var(--blue); margin: 0 0 20px 0;}
.content hr {border: 0; height: 2px; color: var(--blue); background-color: var(--blue); margin: 40px 0;}
.content a {color: var(--blue); text-decoration: none;}
.content a:hover {color: var(--black); font-weight: 700;}


.content-einleitung {width: 100%; background-color: var(--grey2); position: relative;}
.content-einleitung .custom::after {content: ""; display: table; clear: both;}
.ce-bild {float: right; width: 65%; max-width: 1260px; position: relative; z-index: 1;}
.ce-inner {position: absolute; bottom: 0; left: 50%; transform: translateX(-50%); z-index: 10; width: 92%; max-width: 1200px; height: 1px;}
.ce-content {width: 90%; max-width: 540px; box-sizing: border-box; padding: 60px 40px; background-color: var(--blue); margin: -30% 0 0 0;}
.ce-content h2 {font-size: 50px; font-weight: 700; color: var(--white); text-transform: uppercase; margin: 0; line-height: 54px;}
.ce-content h3 {font-size: 22px; font-weight: 700; color: var(--white); margin: 0; line-height: 26px;}
.ce-content hr {height: 6px; border: 0; background-color: var(--black); color: var(--black); width: 50%; margin: 60px auto;}

.teiler50 {width: 50%; max-width: 600px; float: left;}
.teiler50 i {width: 20px; margin-right: 15px;}
.teiler50 a {color: var(--blue); text-decoration: none; transition: all .5s ease;}
.teiler50 a:hover {color: var(--black); transition: all .5s ease;}

.kontakt-fm {width: 100%; background: linear-gradient(90deg, var(--white) 50%, var(--grey2) 50%);}
.kontakt-fm-inner {width: 92%; max-width: 1200px; margin: 0 auto; box-sizing: border-box; padding: 70px 0 70px 70px; background-color: var(--grey2);}

.google-maps {width: calc(100% - 50px); padding: 200px 0 0 0;}
.google-maps iframe {height: 650px;}


.slogan {width: calc(100% - 50px); position: relative; padding: 0 0 100px 0;}
.slogan-inner {width: 90%; max-width: 1728px; float: right; position: relative;}
.slogan-bild {width: 50%; max-width: 960px; position: relative; z-index: 10; float: left;}
.slogan-textbox {width: 60%; max-width: 1152px; background-color: var(--grey2); position: relative; z-index: 1; float: left; margin: 25% 0 0 -10%; box-sizing: border-box; padding: 50px 50px 50px calc(10% + 50px);}
.slogan-textbox h2 {font-size: 64px; line-height: 68px; color: var(--blue); margin: 0; text-transform: uppercase; font-weight: 900; display: table-caption; inline-size: 90%;}

@media screen and (max-width: 1000px){
.slogan {width: 100%;}
.slogan-inner {width: 100%; float: none;}
.slogan-bild {width: 90%; float: none;}
.slogan-textbox {width: 90%; float: right; margin: -50px 0 0 0; padding: 70px 30px 30px 30px;}
.content-einleitung {background-color: transparent;}
.ce-bild {width: 100%; float: none;}
.ce-inner {position: relative; height: auto; bottom: auto; left: auto; transform: translateX(0); margin: -200px auto 0 auto;}
}
@media screen and (max-width: 800px){
.c-textbild, .c-bildtext {width: 96%; max-width: none; float: none;}
.c-textbild {top: 0;}
.c-bildtext {float: right; margin: -130px -4% 0 0;}
.c-bildtext::after {display: block;}
.c-textbild::after {display: none;}
}
@media screen and (max-width: 670px){
.content {padding: 100px 0;}
.ce-inner {margin: -100px auto 0 auto;}
.ce-content {max-width: 340px; padding: 40px 20px; margin: 0;}
.ce-content h2 {font-size: 40px; line-height: 44px;}
.ce-content h3 {font-size: 18px; line-height: 22px;}
.slogan-textbox h2 {font-size: 52px; line-height: 56px;}
}
@media screen and (max-width: 570px){
.teiler50 {width: 100%; float: none;}
}
@media screen and (max-width: 480px){
.c-textbild {padding: 76px 30px;}
.kontakt-fm-inner {padding: 50px 0 50px 20px;}
}
@media screen and (max-width: 420px){
.ce-inner {margin: -40px auto 0 auto;}
.kontakt-fm-inner {padding: 50px 0;}
}
 

/* Service Startseite */
.service-master {width: 100%; background-image: url("../../../images/backgrounds/hg_leistungen.webp"); background-position: center center; background-size: cover; padding: 200px 0; position: relative;}
.service-inner {width: 92%; max-width: 1360px; margin: 0 auto; display: flex; flex-wrap: wrap; justify-content: center; position: relative; z-index: 10;}
.service-header {width: 92%; max-width: 700px; margin: 0 auto 120px auto; text-align: center;}
.service-header h3 {font-size: 18px; color: var(--blue); text-transform: uppercase; margin: 0 0 15px 0; font-weight: 900;}
.service-header h2 {font-size: 30px; color: var(--black); margin: 0; font-weight: 900; line-height: 44px;}
.service-box {width: 300px; margin: 0 20px; box-sizing: border-box; padding: 84px 20px 30px 20px; text-align: center; position: relative; box-shadow: 0px 5px 25px 5px rgba(0,0,0,0.25); background-color: var(--white);}
.service-box h4 {font-size: 26px; color: var(--black); height: 64px; margin: 0 0 30px 0;}
.service-box p {font-size: 20px; line-height: 32px; color: var(--grey); margin: 0 0 40px 0;}
.sb-icon {width: 100px; height: 100px; background-color: var(--blue); position: absolute; left: 50%; margin-left: -50px; top: -50px; box-sizing: border-box; padding: 25px 20px 20px 20px; transition: all .5s ease;}
.sbb:hover .sb-icon {background-color: var(--black); transition: all .5s ease;}
.service-border {width: calc(92% + 80px); max-width: 1400px; height: 80px; position: absolute; bottom: 160px; left: 50%; transform: translateX(-50%); border-bottom: 3px var(--white) dotted; border-left: 3px var(--white) dotted; border-right: 3px var(--white) dotted; z-index: 1;}
.service-border::after {content: ""; height: 160px; position: absolute; bottom: -164px; left: 50%; transform: translateX(-50%); border-left: 3px var(--white) dotted;}

.service-master2 {width: 100%; padding: 220px 0 0 0; position: relative; background-image: linear-gradient(var(--grey3), var(--white));}
.service-inner2 {width: 92%; max-width: 800px; margin: 0 auto; position: relative; z-index: 10;}
.service-box2 {width: 100%; box-sizing: border-box; padding: 20px; background-color: var(--blue); margin: 0 0 50px 0; box-shadow: 0px 5px 25px 5px rgba(0,0,0,0.15); position: relative;}
.service-box2 h2 {color: var(--white); background-color: var(--black); margin: 0; font-size: 30px; line-height: 30px; padding: 6px 12px; position: absolute; left: 20px; top: -20px;}
.service-box2 p {font-size: 20px; line-height: 32px; color: var(--white); margin: 30px 0;}
.service-border2 {width: calc(92% + 80px); max-width: 880px; height: 80px; position: absolute; top: 160px; left: 50%; transform: translateX(-50%); border-top: 3px var(--white) dotted; border-left: 3px var(--white) dotted; border-right: 3px var(--white) dotted; z-index: 1;}
.service-border2::after {content: ""; height: 160px; position: absolute; top: -164px; left: 50%; transform: translateX(-50%); border-left: 3px var(--white) dotted;}
@media screen and (max-width: 1475px){
.service-inner {max-width: 800px;}
.service-box:nth-child(1), .service-box:nth-child(2) {margin: 0 20px 100px 20px;}
.service-box:nth-child(3), .service-box:nth-child(4) {margin: 0 20px;}
.service-border {width: calc(680px + 40px);}
}
@media screen and (max-width: 920px){
.service-inner2 {width: 80%;}
.service-border2 {width: calc(80% + 80px);}
}
@media screen and (max-width: 739px){
.service-box:nth-child(3) {margin: 0 20px 100px 20px;}
.service-border {width: calc(300px + 80px);}
}
@media screen and (max-width: 435px){
.service-box2 h2 {font-size: 24px; line-height: 24px; left: 10px;}
.service-border2 {width: calc(80% + 40px);}
.service-border {width: calc(100% - 40px);}
}


/* Kontaktaufnahme Startseite */
.start-contact {width: 100%; padding: 160px 0 0 0; position: relative;}
.start-contact-inner {width: 92%; max-width: 1280px; margin: 0 auto; overflow: auto; padding: 40px 0 0 0;}
.start-contact-form, .start-contact-info {width: 50%; max-width: 640px; float: right;}
.start-contact-form {position: relative; z-index: 200;}
.start-contact-info {box-sizing: border-box; padding: 50px;}
.start-contact-info h3 {font-size: 18px; color: var(--blue); text-transform: uppercase; margin: 0 0 15px 0; font-weight: 900;}
.start-contact-info h2 {font-size: 30px; color: var(--black); margin: 0 0 40px 0; font-weight: 900; line-height: 44px;}
.start-contact-info p {font-size: 20px; line-height: 32px; color: var(--grey); margin: 0 0 40px 0;}
@media screen and (max-width: 1320px){
.start-contact-form, .start-contact-info {float: none; width: 100%;}
.start-contact-info {max-width: none;}
.start-contact-form {margin: 0 auto;}
}


/* Video Sequenz */
.video-hg-master {width: calc(100% - 88px); height: 800px; position: relative; overflow: hidden; margin: -200px 0 0 0; z-index: 100;}
.video-hg-master .m-video {position: absolute; left: -100px; top: -10%; min-width: 100%; min-height: 100%; width: auto; height: auto; object-fit: cover;}
.video-inner-master {width: 92%; max-width: 1560px; position: relative; z-index: 110; margin: 0 auto; padding: 165px 0;}
.video-inner-master h2 {display: table; float: right; color: var(--white); font-size: 50px; font-weight: 900; text-transform: uppercase;}
@media screen and (max-width: 650px){
.video-hg-master .m-video {left: -300px; top: 10%;}
.start-contact-info {padding: 50px 20px;}
}


/* Footer */
.footer {width: 100%; padding: 160px 0 0 0; position: relative;}
.footer-inner {width: 92%; max-width: 1280px; margin: 0 auto;}
.footer-contact, .footer-logo {width: 50%; max-width: 640px; float: left;}
.footer-contact-inner {width: 100%; max-width: 560px; margin: 0 auto 60px auto; box-shadow: 0px 5px 5px 5px rgba(0,0,0,0.115); box-sizing: border-box; padding: 50px; background-color: var(--white); position: relative; z-index: 100;}
.footer-contact-inner h2 {font-size: 32px; line-height: 34px; margin: 0 0 40px 0; color: var(--blue);}
.footer-contact-inner .btn {margin: 40px 0 0 0; display: table;}
.footer-icon-contact {padding: 30px 0; border-bottom: 1px var(--grey2) solid;}
.footer-icon, .footer-contact-info {float: left;}
.footer-icon {width: 20%; box-sizing: border-box; padding-right: 40px; color: var(--black);}
.footer-icon i {font-size: 46px; margin: 0 auto; display: table;}
.footer-contact-info {width: 80%;}
.footer-contact-info h3 {font-size: 24px; color: var(--black); margin: 0 0 5px 0;}
.footer-contact-info p, .footer-contact-info a {font-size: 20px; color: var(--grey); margin: 0; text-decoration: none;}
.footer-logo .mtecon-brand {width: 60%; max-width: 320px; margin: 150px 0 0 40px;}
.footer-hg {width: 100%; height: 50%; position: absolute; left: 0; bottom: 0; background-color: var(--black); z-index: 1;}
.footer-hg-inner {width: 92%; max-width: 1200px; position: absolute; left: 50%; transform: translateX(-50%); bottom: 60px; color: var(--grey2);}
.footer-hg-inner p {margin: 0; font-size: 16px;}
.footer-hg-inner a {color: var(--grey2); text-decoration: none; transition: all .5s ease;}
.footer-hg-inner a:hover {color: var(--blue); transition: all .5s ease;}
@media screen and (max-width: 995px){
.footer-icon, .footer-contact-info {float: none; width: 100%}
.footer-icon {padding-right: 0; margin-bottom: 20px;}
.footer-icon i {margin: 0;}
}
@media screen and (max-width: 840px){
.footer-contact, .footer-logo {width: 100%; max-width: none; float: none;}
.footer-logo {margin-bottom: 70px;}
.footer-contact-inner {margin: 0 auto 100px auto;}
}
@media screen and (max-width: 694px){
.footer-logo .mtecon-brand {margin: 0;}
}
@media screen and (max-width: 440px){
.footer-contact-inner {padding: 50px 20px;}
}







