
.layout--generic-block {
	background-color: rgba(33, 39, 53, 1);
}

/*================ Video Background ================*/

.layout--generic-block .grad {
	position: fixed;
	background: rgb(0,0,0);
	background: linear-gradient(90deg, rgba(0,0,0,0) -20%, rgba(0,0,0,0) 100%);
	min-width: 100%; 
	min-height: 100%;
	z-index: -1;
}

/*===================================================================================*/

.layout--generic-block .steps-content {
	background-color: rgba(33, 39, 53, .8);
}

.steps-wrapper ul {
	display: flex;
	justify-content: space-between;
	align-items: stretch;
	flex-flow: column;
	list-style: none;
	padding: 0;
	margin: 0 auto;
	width: 100%;
	overflow: hidden;
	border-collapse: collapse;
}

.step {
	list-style-type: none;
	text-align: left;
	position: relative;
	float: left;
	width: 100%;
	height: 100%;
	padding-bottom: 2px;
}

.stepicon {
	position: absolute;
	margin: auto 10px;
	width: 30px;
    top: 0;
    bottom: 0;
	float: left;
	border-radius: 50%;
	-webkit-transition: -webkit-transform .4s ease-in-out;
	transition: transform .8s ease-in-out;
}

.steptext {
	margin-left: 50px;
	display: table;
	height: 40px;
}

.steplink {
	text-decoration: none;
}

.steplink:hover .stepicon {
	-webkit-transform: rotate(360deg) scale(1.1);
	transform: rotate(360deg) scale(1.1);
}

.steplink:hover .steps-content {
	background-color: rgba(13, 19, 33, .8);
}

.layout--generic-block .steps-wrapper {
	margin: 0px;
}

.layout--generic-block .content-wrap {
	padding-top: 85px;
	background: linear-gradient(0deg, rgba(0,0,0,0) 10%, rgba(0,0,0,0) 60%), url(../assets/bg_m.jpg) no-repeat;
	background-size: 150%;
	background-position: top;
	background-position-y: 0;
}
.content {
	max-width: 1170px;
	margin: 0 auto;
	padding: 0
}

.layout--generic-block .headline {
	width: 100%;
	text-align:left;
	padding: 15px 30px 15px 15px;
	margin-top:300px;
	background-color: rgba(33, 39, 53, .8);
	margin-bottom:2px;
	
}

.layout--generic-block .cta-wrapper {
	padding-left: 30px;
	text-align:left;
}

.layout--generic-block .kv-mask {
	height: 0px
}

/*================================*/

@media only screen and (min-width:768px) {
	.layout--generic-block .content-wrap {
		background: linear-gradient(90deg, rgba(0,0,0,0) -20%, rgba(0,0,0,0) 100%), url(../assets/bg_t.jpg) no-repeat;
		background-size: cover;
		background-position: top;
		background-position-y: 0;
	}
	.layout--generic-block .banner {
		width: 70%;
		float: left;
		margin-top: 40px;
	}
	.layout--generic-block .headline {
		margin-top: 0px;
		text-align:left;
		background-color: rgba(33, 39, 53, 0);
		padding: 30px;
	}
	.layout--generic-block .kv-mask {
		height: 64vh;
	}
	.steps-wrapper ul {
		display: flex;	
		flex-flow: row wrap;
	}
	.step {
		padding-bottom: 10px;
		margin-right: 2.5px;
		width: 49.5%;
	}
	.step:last-child, .step:nth-child(2) {
		margin-left: 2.5px
	}
	.step:last-child, .step:nth-child(2){
		margin-right: 0
	}
	.step:last-child .steps-content {
		background-image: none;
		padding-right: 0
	}
	
	.layout--generic-block .steps-content {
		background-color: rgba(33, 39, 53, .8);
	}

	.stepicon {
		width: 50px;
		height: 50px;
		bottom: 10px;
	}

	.steptext {
		height: 70px;
		margin-left: 65px;
	}
}

@media only screen and (min-width:991px) {
	.layout--generic-block .content-wrap {
		background: linear-gradient(90deg, rgba(0,0,0,0) -20%, rgba(0,0,0,0) 100%), url(../assets/bg.jpg) no-repeat;
		background-position: right top;
		background-size: cover;
		background-position-y: 0;
		height:100%;
	}
	.layout--generic-block .banner {
		width: 70%;
		float: left;
		margin-top: 40px;
	}
	.layout--generic-block .headline {
		text-align:left;
		margin-top:0px;
		background-color: rgba(33, 39, 53, 0);
		padding: 30px;
	}
	.layout--generic-block .kv-mask {
		height: 68vh;
	}
	.steps-wrapper ul {
		flex-flow: row
	}
	.step {
		padding-bottom: 10px;
	}
	.step:last-child, .step:nth-child(2), .step:nth-child(3) {
		margin-left: 2.5px
	}
	.step:last-child {
		margin-right: 0
	}
	.step:nth-child(2) {
		margin-right: 2.5px;
	}
	
	.layout--generic-block .steps-content {
		background-color: rgba(33, 39, 53, .8);
	}
	
	.stepicon {
		width: 50px;
		height: 50px;
		bottom: 10px;
	}
	.steptext {
		height: 70px;
		margin-left: 65px;
	}
}


/*================/

Main Title > H1
SUB Title > H2
STEPS Title > H3
STEPS Text > P

/================*/

h1, h2, h3 {
	line-height: 1em;
	font-family: Open Sans, sans-serif;
	color: #fff;
	text-transform: uppercase;
	margin: 0px;
}

h1 a, h2 a, h3 a {
	color: inherit;
	text-decoration: none
}

/*=Mobile=*/
.layout--generic-block h1 {
	font-size: 23px;
	line-height: 1em;
	font-weight: 800;
	margin-bottom: 10px;
}
	
.layout--generic-block h1 br{
	display: none;
} 

.layout--generic-block h3 br{
	display: none;
}
	
.layout--generic-block h2 {
	margin: 0px;
	color: hsla(0, 0%, 100%, .8);
	font-size: 12px;
	line-height: 1em;
	font-weight: 400;
}  

.layout--generic-block h3 {
	font-size: 14px;
	padding: 10px 20px 10px 5px;
	display: table-cell;
	vertical-align: middle;
	font-weight: 700;
}

/*=Tablet=*/
@media only screen and (min-width: 768px) {
	.layout--generic-block h1 {
		font-size: 50px;
		line-height: 1em;
		margin-bottom: 10px;
	}
	
	.layout--generic-block h1 br{
		display: block;
	} 
	
	.layout--generic-block h3 br{
		display: block;
	}
	
	.layout--generic-block h2 {
		font-size: 18px;
		line-height: 1;
	}   

	.layout--generic-block h3 {
		padding: 15px 20px 15px 5px;
		font-size: 18px;
	}
}

/*=Desktop=*/
@media only screen and (min-width: 991px) {
	.layout--generic-block h1 {
		font-size: 60px;
		line-height: 1em;
		margin-bottom: 10px;
	} 
	
	.layout--generic-block h1 br{
		display: block;
	}  
	
	.layout--generic-block h3 br{
		display: block;
	}
	
	.layout--generic-block h2 {
		font-size: 20px;
		line-height: 1;
	}   

	.layout--generic-block h3 {
		padding: 15px 20px 15px 5px;
		font-size: 19px;
	}

}
