/* @font-face {
	font-family: Roboto-Regular;
	src: url(../fonts/Roboto-Regular.eot);
	src: url(../fonts/Roboto-Regular.eot?#iefix) format("embedded-opentype"), url(../fonts/Roboto-Regular.otf) format("opentype"), url(../fonts/Roboto-Regular.svg) format("svg"), url(../fonts/Roboto-Regular.ttf) format("truetype"), url(../fonts/Roboto-Regular.woff) format("woff"), url(../fonts/Roboto-Regular.woff2) format("woff2");
}
@font-face {
	font-family: Roboto-Medium;
	src: url(../fonts/Roboto-Medium.eot);
	src: url(../fonts/Roboto-Medium.eot?#iefix) format("embedded-opentype"), url(../fonts/Roboto-Medium.otf) format("opentype"), url(../fonts/Roboto-Medium.svg) format("svg"), url(../fonts/Roboto-Medium.ttf) format("truetype"), url(../fonts/Roboto-Medium.woff) format("woff"), url(../fonts/Roboto-Medium.woff2) format("woff2");
}
@font-face {
	font-family: Roboto-Bold;
	src: url(../fonts/Roboto-Bold.eot);
	src: url(../fonts/Roboto-Bold.eot?#iefix) format("embedded-opentype"), url(../fonts/Roboto-Bold.otf) format("opentype"), url(../fonts/Roboto-Bold.svg) format("svg"), url(../fonts/Roboto-Bold.ttf) format("truetype"), url(../fonts/Roboto-Bold.woff) format("woff"), url(../fonts/Roboto-Bold.woff2) format("woff2");
} */

.video-section {
    position: relative;
}

.video-desc {
    position: absolute;
    top: calc(50% - 250px);
    left: 100px;
    padding: 15px;
    background: rgba(0, 0, 0, 0.55);
    color: #fff;
    min-width: 500px; 
}

.video-desc h1  {
    font-family: 'Söhne Breit Buch' !important;
    font-weight: 800 !important;
    font-size: 32px;
    margin-bottom: 44px;
}

.video-desc h2 {
    font-family: 'Söhne Breit Buch' !important;
    font-weight: 400 !important;
    font-size: 24px;
    margin-bottom: 22px;
}

#topVideo {
	width: 100%;
	display: block;
}

.cta-btn {
    background: #ca0d0e;
    border: 2px solid #ca0d0e;
    color: #fff;
    cursor: pointer;
    display: inline-block;
    font-family: "Söhne Breit Buch" !important;
    font-weight: 600;
    padding: 14px 30px;
    font-size: 18px;
    box-sizing: border-box;
    vertical-align: middle;
    border-radius: 100px;
    line-height: 1;
    text-transform: uppercase;
    text-decoration: none;
}

body {
	color: black!important;
}
.bg-black{
	background-color: #272727;
	color: #fff;
}
.grey-bg{
	background-color: #d4d4d4;
}
.c-white {
	color: white;
}
.mg-0 {
	margin: 0!important;
}
.bold{
	font-family: Roboto-Bold, Helvetica Neue,sans-serif;
	font-weight: 700;
}
.med{
	font-family: Roboto-Medium, Helvetica Neue,sans-serif;
}
.reg{
	font-family: Roboto-Regular, Helvetica Neue,sans-serif;
}
.template-cont p{
	font-family: Roboto-Regular, Helvetica Neue,sans-serif;
	letter-spacing: 0.4px;
    max-width: 920px;
    margin: auto;
}
.template-cont img{
	max-width: 100%;
}
.temp-cont{
	max-width: 1400px;
	margin: 0 auto;
}
/*======= MODULE HERO ===== */
.hero-text-cont{
	margin: 0 auto;
	text-align: center;
}
.hero-imgs{
	text-align: center;
}
/*======= MODULE A ======*/
.module-a {
	padding: 0;
	position: relative;
}
.module-a .head {
    text-shadow: 2px 2px 3px grey;
}

.mod-a-img {
	width: 100%;
}
.a-img-cont {
	position: relative;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	grid-template-rows: auto auto;
}

.align-center {
	text-align: center;
}

.pd-x {
	padding: 120px 0;
}

.a-pic-wrapper {
	grid-column: 1 / span 3;
	grid-row: 1 / span 2;
}

.a-text {
	padding: 0 15px;
	grid-column: 1 / span 3;
	grid-row: 2;
	align-self: center;
	margin-bottom: 100px;
}
/*======= MODULE B ===== */
.module-b{
	text-align: center;
}
.b-wrapper {
	max-width: 1400px;
	display: flex;
	flex-direction: column;
}

.b-cont{
	margin: 0 10px;
	text-align: left;
}
.b-intro {
	font-size: 16px;
}
/*====== MODULE D ======*/
.module-d {
	/* background: #d4d4d4; */
	padding: 20px 15px;
}
.module-d-container {
	max-width: 1400px;
	margin: auto;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
}
.module-d .slider-img-wrapper {
	max-width: 600px;
}
.module-d .content-block.hidden {
	display: none;
}
.right-container {
	max-width: 520px;
	display: flex;
	flex-direction: column;
	justify-content: center;
}
.content-title {
	font-size: 32px;
	font-family: Roboto-Bold, Helvetica Neue,sans-serif;
}
.slider-btn-img {
	display: none;
}
.slider-btn {
	text-transform: uppercase;
}
/* ======= MODULE E ====== */
.e-cont{
	display: flex;
	justify-content: center;
}
/*======= MODULE F ======*/
.f-container {
	max-width: 1400px;
	margin: auto;
	display: grid;
	grid-template-columns: 1fr 1fr;
	grid-template-rows: auto auto;
}

.f-container.bg-black {
	background: #1E1E1E;
	line-height: 0;
}

.f-container.bg-black .f-text {
	color: white;
}

.f-text {
	grid-column: 1 / span 2;
	grid-row: 1;
	color: white;
	line-height: 30px;
	text-align: left !important;
}

.f-img-cont {
	grid-column: 1 / span 2;
	grid-row: 2;
}

/*======= MODULE H ======*/
.module-h {
    max-width: 1400px;
    margin: 80px auto;
}

.h-cont {
    display: flex;
    justify-content: space-between;
    margin: 80px 0;
}

.h-text {
    max-width: 680px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

/*======= MODULE I ======*/
.i-img-cont {
	width: 100%;
	position: relative;
}
.mod-i-img {
	width: 100%;
}
.i-text-cont {
	max-width: 1400px;
    padding: 20px 5%;
    margin: auto;
    text-align: left;
}
.i-head {
	margin-top: 0;
	margin-bottom: 20px;
}
.i-text {
	color: white;
	position: absolute;
	left: 0;
	right: 0;
	margin: 0 auto;
	padding: 20px;
	top: 49%;
	width: 100%;
	max-width: 350px;
	text-align: left;
}
/*====== MODULE J ======*/
.module-j {
	/* background: #d4d4d4; */
	padding: 0 20px;
}
.slider-img-wrapper {
	text-align: center;
	overflow: hidden;
	position: relative;
	margin: auto;
}
.slider-img-block {
	max-width: 1400px;
	margin: auto;
}
.slider-img-block.hidden {
	display: none;
}
.slider-img-title {
	margin-bottom: 30px;
	font-size: 32px;
	font-family: Roboto-Bold, Helvetica Neue,sans-serif;
    font-weight: 700;
}
.slider-btn-wrapper {
	margin: 40px auto 0 auto;
	display: flex;
	justify-content: space-between;
	max-width: 600px;
	/* padding: 0 15px; */
	font-size: 14px;
}
.slider-btn {
	width: 100px;
	padding-bottom: 20px;
	text-align: center;
	cursor: pointer;
	border-bottom: 5px solid #C1C1C1;
}
.slider-btn.active {
	border-bottom: 5px solid black;
}
.arrow-btn {
	border: solid lightgray;
	border-width: 0 3px 3px 0;
	display: inline-block;
	padding: 7px;
	cursor: pointer;
}
.slider-img-arrow-next {
	position: absolute;
	top: 50%;
	right: 6px;
	transform: rotate(-45deg);
}
.slider-img-arrow-prev {
	position: absolute;
	top: 50%;
	left: 6px;
	transform: rotate(135deg);
}

/*======== SERVICE ROW ========*/
.service-cont{
	border: 1px solid #979797;
	border-radius: 4px;
	background-color: #3C3C3C;	
	color: #FFF;
}
.service-row{
	background-color: #1D1D1F;
	display: flex;
	justify-content: center;
}
.serv-text{
	max-width: 300px;
	padding-left: 10px;
}
p.serv-head{
	font-size: 24px;
	letter-spacing: 0;
	line-height: 40px;	
}
p.serv-p{
	color: #AAAAAA;
	font-size: 14px;
	letter-spacing: 0;
	line-height: 20px;
}
a.service-link{
	color: #fff;
	text-decoration: none;
}
.serv-img{
	width: 48px;
	height: 48px;
}
a.service-link:visited{
	color: #fff;
}
.s-right:hover{
	cursor: pointer;
}
/*======  TABLE STYLES ===== */
.tec-specs{
	background-color: #1D1D1F;
	border-top: 1px solid #979797;
	color: #fff;
}
p.tec-cat{
    font-size: 24px;
    color: #fff;
	margin: 20px 35px;
}
.tec-table{
	margin: 0 auto;
	max-width: 1400px;
}
.table{
	display: table;
	width: 100%;
	margin-bottom: 50px;
}
.tableRow {
	display: table-row;
}
.tableCell{
	display: table-cell;
	padding: 7px 35px;
    width: 50%;
	font-size: 16px;
	letter-spacing: 0;
	line-height: 20px;
    word-break: break-word;
}
.tableBody {
	display: table-row-group;
}
.tableRow:nth-child(odd) {
	background-color: #3C3C3C;
}
.tec-headline.upper{
	font-size: 36px;
	color: #fff;
	margin-bottom: 20px;
}
p.tec-spec-head{
	text-align: center;
	font-size: 28px;
	letter-spacing: 0;
	line-height: 40px;
	margin-bottom: 40px;
}
@media (max-width: 767px){
	#topVideo {
        display: block;
        width: 100%;
    }

    .video-desc {
        min-width: auto;
    }

    .video-desc h1 {
        font-size: 20px;
        margin: 0;
    }

    .video-desc h2 {
        font-size: 16px;
    }

    .video-desc {
        position: absolute;
        color: white;
        width: 100%;
        top: 100px;
        left: 0;
        right: 0;
        bottom: 0;
        text-align: center;
    }
	.template-cont{
		font-size: 16px;
		line-height: 24px;
	}
	.head{
		font-size: 24px;
		letter-spacing: 0;
		line-height: 30px;
	}
	.hero-head{
		font-size: 32px;
		letter-spacing: -0.17px;
		line-height: 40px;
	}
	.hero-imgs{
		margin-bottom: 50px;
	}
	.hero-text-cont{
		padding: 20px 15px 30px;
	}
	.hero-imgs img{
		padding: 10px 15px;
	}
/*========= MODULE B ====== */
	.module-b{
		text-align: center;
	}
	.b-head{
		font-size: 20px;
		letter-spacing: 0.15px;
		line-height: 30px;
		margin-top: 0;
		margin-bottom: 10px;
		font-family: Roboto-Bold, Helvetica Neue,sans-serif;
	}
	.b-text{
		padding: 15px 0;
	}
	/*====== MODULE E ====== */
	.module-e{
		padding: 0;
	}
	.e-cont{
		padding: 20px 15px;
	}
	.e-top{
		flex-direction: column;
	}
	.e-btm {
		display: flex;
		flex-direction: column-reverse;
	}
	/*======== MODULE F ===== */
	.f-text{
		margin-bottom: 30px;
		padding: 0 15px;
	}
	/*========= MODULE G ======*/
	.g-text{
		padding: 20px 15px 10px;
	}
	.g-head{
		margin-top: 0;
		margin-bottom: 20px;
	}
	/*======== MODULE I ===== */
	.module-i{
		display: flex;
		flex-direction: column;
	}
	.i-text{
		margin-bottom: 30px;
	}
	/*======== SERVICE ROW ========*/
	.service-row{
		flex-direction: column;
		padding: 20px 15px;
	}
	.service-cont {
		padding: 30px 15px;
		margin: 20px 0;
		text-align: center;
	}
	.serv-img{
		margin-bottom: 15px;
	}
	/*======== TABLE STYLES ====== */	
	.tec-specs{
		padding: 60px 15px;
	}
}
@media (min-width: 768px){
	.hero-head {
		font-size: 60px;
		font-weight: 500;
		line-height: 80px;
	}
	.hero-text-cont{
		max-width: 1400px;
		padding: 40px 0;
	}
	.hero-img-cont{
		width: 49%;
		display: inline-block;
	}
	/*========= MODULE A ====== */
	.a-text {
		max-width: 280px;
		margin-bottom: 0;
		grid-column: 3;
		grid-row: 1 / span 2;
		align-self: center;
	}

	/*========= MODULE B ====== */
	.b-wrapper {
		display: flex;
		flex-direction: row;
		margin: auto;
		padding: 25px 5%;
	}

	.b-cont{
		display: inline-block;
		max-width: 440px;
		vertical-align: text-top;
	}
	.b-text{
		padding-top: 20px;
	}
	.b-intro {
		height: 30px;
	}
	/*========= MODULE D ====== */
	.module-d {
		padding: 120px 20px;
	}
	.content-title {
		font-size: 48px;
	}
	.right-container {
		max-width: 100%;
	}
	.module-d-container {
		flex-direction: column;
	}
	/*======= MODULE E ======== */
	.module-e{
		padding: 40px 0;
	}
	/*======== MODULE G ======= */
	.g-text{
		max-width: 1400px;
		margin: 0 auto;
		display: flex;
	}
	.g-left{
		max-width: 440px; 
		margin-right: 40px;
	}
	.g-head{
		margin: 0;
	}
	.g-right{
		max-width: 920px;
	}
	/*======== MODULE I ===== */
	.module-i{
		text-align: center;
		position: relative;
	}
	/*======== MODULE J ===== */
	.slider-img-title {
		font-size: 48px;	
	}
	.slider-btn {
		width: 160px;
	}
	/*======== SERVICE ROW ========*/
	.service-row{
		flex-direction: row;
	}
	.service-cont{
		width: 440px;
		padding: 40px 30px;
		margin: 20px;
	}
	.serv-img, .serv-text{
		display: inline-block;
		vertical-align: top;
	}
	/*======== TABLE STYLES ====== */	
	.tec-specs{
		padding: 40px;
	}
	.tec-left,.tec-right{
		width: 49%;
		display: inline-block;
		padding: 0 25px;
	    vertical-align: top;
	}
}
@media (min-width: 768px) and (max-width: 1024px) and (orientation: portrait){
	.module-f{
		display: flex;
		flex-direction: column-reverse;
		padding: 60px 15px;
	}
	.f-text{
		margin-bottom: 30px;
	}
	img.k-img{
		padding: 5px 0;
		max-width: 680px
	}
	.module-i{
		display: flex;
		flex-direction: column;
	}
	.i-text{
		margin-bottom: 30px;
		right: 20px;
    	left: auto;
    	transform: translateY(-50%);
		max-width: 280px;
	}
}

@media (min-width: 768px) and (max-width: 1024px){
	.template-cont{
		font-size: 16px;
		line-height: 24px;
	}
	.head{
		opacity: 0.87;
		font-size: 24px;
		letter-spacing: 0;
		line-height: 30px;
	}
	.hero-imgs{
		display: flex;
		flex-direction: row;
		justify-content: center;
	}
	.hero-head{
		font-size: 48px;
		line-height: 60px;
		margin-top: 0;
	}
	.hero-img-cont:first-child{
		margin-right: 20px;
	}
	.hero-imgs,.hero-text-cont{
		padding: 20px 35px;
	}
	.hero-imgs{
		margin-bottom: 60px;
	}
	/*======== MODULE B ====== */
	.b-cont{
		margin: 20px 10px;
		width: 33%;
	}
	.b-head{
		font-size: 20px;
		line-height: 30px;
		letter-spacing: 0.1px;
    	margin-bottom: 1vw;
    	margin-top: 1vw;
		font-family: Roboto-Bold, Helvetica Neue,sans-serif;
	}
	/*======== MODULE D =======*/
	.module-d-container {
		max-width: 800px;
	}
	.module-d .slider-img-wrapper {
		max-width: 800px;
	}
	.slider-btn-wrapper {
		max-width: 800px;
	}
	/*======== MODULE E =======*/
	.module-e{
		padding: 45px 15px
	}
	.e-cont{
		flex-direction: column;
		padding: 15px 0;
		margin: 0 auto;
		max-width: 800px;
	}
	.e-btm{
		display: flex;
		flex-direction: column-reverse;
	}
	/*======== MODULE F =======*/
	.module-f{
		padding: 60px 30px;
	}
	/*======== MODULE G ====== */
	.g-text{
		flex-direction: column;
		padding: 25px 5%;
	}
	.service-row{
		padding: 20px 15px;
	}
	.service-cont {
		text-align: center;
	}
	.serv-img{
		margin-bottom: 15px;
	}

	.module-g-apage .table-row.lh{
		line-height: 19px;
	}

	.module-g-apage .table-row .price-crossed {
		font-size: 11px !important;
	}
}
@media (min-width: 1025px){
	.template-cont{
		font-size: 18px;
		line-height: 30px;
	}
	.head{
		opacity: 0.87;
		font-size: 48px;
		letter-spacing: 0;
		line-height: 60px;
		font-weight: 700;
	}
	.hero-img-cont:first-child{
		margin-right: 20px;
	}
	.hero-imgs{
		margin-bottom: 120px;
	}
	/*========= MODULE A ====== */
	.a-pic-wrapper {
		grid-column: 1 / span 3;
		grid-row: 1;
	}
	.a-text {
		/* right: 15%;
    	position: absolute;
    	left: 47%;
    	top: 50%;
    	transform: translateX(-50%) translateX(500px) translateY(-50%); */
		grid-column: 3;
		grid-row: 1;
		align-self: center;
   	 	max-width: 380px;
    	text-align: left;
	}
	/*========= MODULE B ====== */
	.module-b{
		text-align: center;
		padding: 120px 0;
	}
	.b-wrapper {
		padding: 0;
	}
	.b-head{
		font-size: 34px;
		line-height: 40px;
		letter-spacing: 0.3px;
		margin-bottom: 20px;
	}
	/*======== MODULE D =======*/
	.module-d-container {
		flex-direction: row;
	}
	.right-container {
		max-width: 520px;
	}
	.module-d .slider-img-wrapper {
		max-width: 800px;
	}
	.slider-btn-img {
		display: inline-block;
	}
	/*======== MODULE E =======*/
	.e-cont{
		flex-direction: row;
		padding: 40px 0;
		max-width: 1400px;
		margin: 0 auto;
	}
	.e-text{
		padding-top: 90px;
		max-width: 550px; 
	}
	/* .e-top .e-img, .e-btm .e-text{
		margin-right: 40px;
	} */
	.e-top .e-text, .e-btm .e-img{
		margin-left: 40px;
	}
	/*======== MODULE F =======*/
	.module-f {
		margin: 60px 0 60px 0;
	}
	.f-text {
		grid-column: 2;
		grid-row: 1;
		max-width: 380px;
		align-self: center;
		justify-self: end;
		margin-right: 40px;
		text-align: center;
	}
	.f-img-cont {
		grid-column: 1 / span 2;
		grid-row: 1;
	}
	/*======== MODULE G ======= */
	.g-text{
		flex-direction: row;
		padding: 40px 0 80px;
	}
	/*======== MODULE I ======= */
	.i-text{
		right: 190px;
    	left: auto;
    	transform: translateY(-50%);
    	max-width: 400px;
	}
	.i-text-cont {
		padding: 40px 0 120px 0;
	}
	/* ========= SERVICE ROW ====== */
	.service-row{
		padding: 60px 0;
	}
	.service-cont:hover{
		background-color: #000;
	}
	.serv-img{
		padding-right: 10px;
	}
}
@media(min-width: 2881px){
	.hero-full-img, .mod-a-img,.mod-c-img,.mod-g-img{width: 100%;}
}


/* COMPARATION CHART */
* {
    box-sizing: border-box;
}

.hidden-mobile {
    z-index: 1 !important;
}

.module-g-apage {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    justify-items: center;
    max-width: 1400px;
    margin: 30px auto;
}

.module-g-apage .column {
    text-align: center;
    width: 100%;
    max-width: 240px;
    position: relative;
    z-index: 3;
}

.module-g-apage .feature-column .table-body {
    border: none;
}

.module-g-apage .main-column .table-body {
    background: #FF5D5D;
    color: white;
    border: none;
	font-family: Söhne Breit Kraftig;
}

.module-g-apage .main-column .table-row {
    border-bottom: 1px solid white;
}

.module-g-apage .feature-column .table-body {
    text-align: left;
	font-family: Söhne Breit Kraftig;
	font-size: 16px;
}

.module-g-apage .table-head {
    font-size: 24px;
    font-weight: 700;
    margin-bottom: 10px;
	font-family: Söhne Breit Halbfett;
    min-height: 48px;
}

.module-g-apage .table-body {
    border: 1px solid #d3d3d3;
    border-radius: 30px;
    padding: 15px 30px;
}

.module-g-apage .table-row {
    border-bottom: 1px solid #d3d3d3;
    padding: 5px 0;
    height: 51px;
    line-height: 40px;
	font-weight: 700;
}

.module-g-apage .table-row .small-text {
	font-size: 14px;
}

/* .module-g-apage .table-row.price {
    line-height: 1.2;
} */

.module-g-apage .table-row.price {
    font-size: 18px;
}

.module-g-apage .table-row .price-crossed {
	font-size: 14px;
	text-decoration: line-through;
}

.module-g-apage .table-row:last-child {
    border-bottom: none;
}

.module-g-apage .table-row img {
    width: 30px;
    vertical-align: middle;
}

.module-g-apage .slider-btn-wrapper {
    width: 100%;
    grid-column: 1 / span 3;
    grid-row: 2;
    margin-top: 50px;
    display: none;
}

.module-g-apage .slider-btn-wrapper .slider-btn {
    width: 25%;
    height: 5px;
    background: #c1c1c1;
	padding-bottom: 0 !important;
}

.module-g-apage .slider-btn.active {
    background: #000;
}

@media (max-width: 912px) {
    .module-g-apage .column {
        max-width: 142px;
    }

    .module-g-apage .table-head {
        font-size: 21px;
    }

    .module-g-apage .table-body {
        padding: 15px;
    }

    .module-g-apage .table-row img {
        width: 25px;
    }
}

@media (max-width: 480px) {
	.module-f {margin-bottom: 64px;}
	.module-f .f-container {
		background: white;
	}

	.module-f .f-container .f-text {
		color: black;
	}

	.h-text-wrapper {
		padding: 0 20px;
	}

	.module-g .g-head, 
	.module-e .e-head {margin-bottom: 20px;}

    .module-g-apage {
        grid-template-columns: repeat(3, 1fr);
		padding: 0 9px;
    }

	.carousel-module-g {
		max-width: 119px;
	}

	.slick-dots li button:before{
		opacity: .25 !important;
	}

	.slick-dots li.slick-active button:before {
		opacity: .75 !important;
	}

    .module-g-apage .column:nth-child(3),
    .module-g-apage .column:nth-child(4),
    .module-g-apage .column:nth-child(5) {
        grid-column: 3;
        grid-row: 1;
        background: white;
    }

    .module-g-apage .table-head {
        font-size: 18px;
    }

    .module-g-apage .table-body {
        border: none;
        padding: 0;
		font-size: 12px !important;
    }

    .module-g-apage .table-row {
        height: 40px;
        line-height: 30px;
    }

	.module-g-apage .table-row .small-text {
		font-size: 7px;
	}

    .module-g-apage .table-row img {
        width: 20px;
		display: inline-block;
    }

    .module-g-apage .slider-btn-wrapper {
        display: flex;
        justify-content: space-around;
    }

	.module-g-apage .table-row .price-crossed {
		font-size: 9px;
	}

	.module-j .slider-btn {
		font-size: 12px !important;
	}

	.module-j .slider-img-arrow-prev,
	.module-j .slider-img-arrow-next {
		top: 60%;
	}
}