@charset "utf-8";
/* CSS Document */
*{
	margin: 0px;
	padding: 0px;
	 -webkit-font-smoothing: antialiased;
	box-sizing: border-box;
}
html {
	scroll-behavior: smooth;
}
body{
	font-family: 'Open Sans', sans-serif;
	min-width: 356px;

}
h1, h2, h3, h4, h5, h6, .head1, .head2, .head3, .head4, .head5, .head6{
	font-weight: 700;
	color: #707070;
    word-break: keep-all;
	hyphens: none;
}
h1, h2, h3, h4, .head1, .head2, .head3, .head4{
    line-height: 130%;
}
h1, .head1{
	font-size: 40px;
	margin-bottom: 25px;
	text-transform: uppercase;
}
h2, .head2{
	font-size: 37px;
	margin-bottom: 10px;
	text-transform: uppercase;
}
h3, .head3{
	font-size: 28px;
	margin-bottom: 10px;
	text-transform: uppercase;
}
h4, .head4{
	font-size: 25px;
	margin-bottom: 10px;
}
h5, .head5{
	font-size: 20px;
}
h6, .head6{
	font-size: 18px;
}
p, table, tr, td, div, ul, li, ol, input, textarea, div, select, option, span{
	font-size: 16px;
	line-height: 180%;
	font-weight: 400;
	color: #707070;	
}
p {
    word-break: break-word;
    hyphens: auto;
}
a:link, a:visited{
	color: #00296b;
	text-decoration: none;
}
a:active, a:hover{
	color: #666;
}
strong, b{
	font-weight: 700;
}
em, i{
	font-style: italic;
}
.content ul, .content ol{
	margin-left: 0px;
}
.content ul li, .content ol li{
	margin-bottom: 10px;
}

/*Allgemein*/
#header_wrap .wrapper, footer .wrapper, #footer_social .wrapper{
	width: 96%;
	margin-left: 2%;
	margin-right: 2%;
	position: relative;
}
.wrapper{
	width: 80%;
	margin-left: 10%;
	margin-right: 10%;
	position: relative;
}
.wrapper_small{
	width: 100%;
	margin-left: auto;
	margin-right: auto;
	max-width: 1200px;
}
#header_wrap{
	position: fixed;
	width: 100%;
	background: #00296b;
	z-index: 999;
}
#header{
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.lang_icon {
    border-radius: 100%;
    border: none;
    vertical-align: top;
    max-width: 30px;
}
#logo_wrap{
	max-width: 120px;
	margin: 5px;
	transition: 0.3s;
}
.logo{
	width: 100%;
	border: none;
}
.logo_mobil{
	max-width: 140px;
	margin-bottom: 15px;
	border: none;
}
#banner{
	position: relative;
	z-index: 0;
	top: 0;
}
.flex_wrap.no_wrap{
    flex-wrap: nowrap;
}
.header_banner_pic{
	width: 100%;
}
#breadcrumb{
	background:#e8e8e8;
	padding-bottom: 10px;
	padding-top: 10px;
}
ul#bc_navigation{
	list-style: none;
}
ul#bc_navigation li{
	display: inline-block;
}
ul#bc_navigation li:not(:first-child):before{
  	content: "\f101";
   font-family: "Font Awesome 5 Brands", "Font Awesome 5 Free";
    display: inline-block;
    width:25px;
    text-align: center;
    color: #999;
	font-weight: 900;
}
ul#bc_navigation li a, ul#bc_navigation li{
	color: #666;
	text-transform: uppercase;
	font-size: 14px;
}
.content{
	padding-bottom: 30px;
	padding-top: 15px;
}
.content_big{
    padding-bottom: 30px;
    padding-top: 60px;
}
.logo_footer{
	max-width: 120px;
	filter: grayscale(100%);
	border: none;
	opacity: 0.8;
}
.social_icon {
    font-size: 30px;
}
#hi div.history-line{
    display: flex;
    padding-top: 80px;
    padding-bottom: 60px;
    text-align: center;
}
#hi div.history-line-mob{
    display: none;
}
#hi div.history-line div.history_col p.head4{
    margin-bottom: 15px;
}
#hi div.history-line div.history_col{
    padding: 0px 20px;
    width: 16.66%;
}
#hi div.history-line div.history_col div.circle-round{
    height: 50px;
    width: 50px;
    background-color: #00296b;
    margin: 0px auto 20px;
    border-radius: 50%;
    position: relative;
}
#hi div.history-line div.history_col div.circle{
    position: relative;
}
#hi div.history-line div.history_col div.circle:after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 62%;
    top: 50%;
    border-top: 3px dashed #00296b;
    width: 100%;
}
#hi div.history-line div.history_col:last-child div.circle:after {
    display: none;
}
.history-timeline{
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-evenly;
    max-width: 1600px;
    width: 94%;
    margin: 0 auto;
    padding: 0px 3%;
    flex-direction: row-reverse;
}
.history-timeline:nth-child(even){
    flex-direction: row;
}
.history-timeline .box-txt{
    width: 46.75%;
    /*background-color: antiquewhite;*/
    padding: 8px 0px 55px;
}
.history-timeline:nth-child(odd) .box-txt .headline{
    padding-left: 50px;
    text-align: left;
}
.history-timeline:nth-child(even) .box-txt .headline{
    padding-right: 50px;
    text-align: right;
}
.history-timeline:nth-child(odd) .box-txt .text_history{
    padding-left: 50px;
    text-align: left;
}
.history-timeline:nth-child(even) .box-txt .text_history{
    padding-right: 50px;
    text-align: right;
}
.history-timeline .box-txt .head3.sub{
    margin-bottom: 5px;
    font-size: 30px;
}
.history-timeline .box-txt .year{
    margin-bottom: 0px;
}
.history-timeline .box-txt .trenner_small{
    margin: 20px 0px;
    float: left;
}
.history-timeline:nth-child(2n) .box-txt .trenner_small{
    margin: 20px 0px;
    float: right;
}
.history-timeline .timeline{
   /* width: 0.5%;
    background-color: #f3f3f3;*/
    margin: 0% 3%;
    border-right: 4px dashed #00296b;
}
.history-timeline .box-img{
    width: 46.75%;
    /*background-color: aliceblue;*/
}
.history-timeline .box-img img{
    display: block;
    width: 100%;
    padding: 30px 0px;
}
.clear{
    clear: both;
}
.history-timeline .timeline .point{
    background-color: #00296b;
    height: 50px;
    width: 50px;
    margin-left: -22.5px;
    position: absolute;
    border-radius: 50%;
}  
.history-timeline:last-child .timeline{
    border-right: 0px;
}

.history-timeline p.bildunterschrift{
    font-size: 15px;
    color: #868686;
}
footer{
	padding-bottom: 10px;
	padding-top: 10px;
	background: url(../img/logo-sigl-bg.png) left bottom no-repeat #00296b;
}
footer p{
	font-size: 16px;
	line-height: 160%;
	margin-bottom: 10px;
}
footer p, footer a, footer p a{
	color: #FFF !important;
}
.footer_head{
	color: #FFF;
	font-size: 24px;
	text-transform: uppercase;
	font-weight: 700;
}
.trenner_footer{
	background: #FFF;
	height: 1px;
	width: 80px;
	margin: 20px 0px;
	opacity: 0.4;
}
.adresse_mobil{
	display: none;
}
#bottom{
	padding: 10px 0px;
	background: #111;
}
.copy{
	color: #CCC;
	font-size: 14px;
	text-align: center;
}

.flex_wrap{
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.flex_wrap_center{
	display: flex;
	flex-wrap: wrap;
	align-content: center;
	justify-content: center;
}
.col1{
	width: 100%;
}
.col2{
	width: 49%;
    position: relative;
}
.col2_sm{
	width: 47%;
    position: relative;
}
.col3{
	width: 31%;
    position: relative;
}
.col4{
	width: 24%;
    position: relative;
}
.col5{
	width: 20%;
}
.col6{
	width: 16.66666%;
}
.col7{
	width: 80%;
}
.col8{
	width: 74%;
}
.col_big{
	width: 68%;
}
.col_small{
	width: 30%;
}
.col_margin{
	margin-bottom: 25px;
}
div.table div.table-col{
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
}
.overlay_pic{
	position: relative;
	background: url("../img/overlay_firma.jpg") center no-repeat;
	background-size: cover;
	min-height: 550px;
}
.overlay_box{
	background: rgba(0,41,107,0.7);
	position: absolute;
	bottom: 0;
	width: 96%;
	margin-left: 2%;
	margin-right: 2%;
	margin-bottom: 5%;
}
ul.check_list, ul.icon_list{
  	list-style: none;
  	padding: 0;
	margin-top: 10px;
}	
ul.check_list li {
  	padding-left: 20px;
	margin-bottom: 15px;
}
ul.check_list li:before {
  	content: "\f00c";
    font-family: "Font Awesome 5 Brands", "Font Awesome 5 Free";
    background: #00296b;
    color: #FFF;
    display: inline-block;
    margin-left: -1.2em;
    width: 30px;
    height: 30px;
    border-radius: 100%;
    text-align: center;
    margin-right: 5px;
	font-weight: 900;
}
ul.icon_list{
	margin-left: 0px;
}
ul.icon_list li{
	display: inline-block;
	margin: 10px;
}
ul.icon_list li:first-child{
	margin-left: 0px;
}
ul.icon_list li img{
	width: 100%;
	max-width: 60px;
}
ul.sub_nav_box {
    background: #00296b;
    list-style: none;
    margin-left: 0;
	margin-top: 10px;
}
ul.sub_nav_box li {
    padding: 6px 20px;
    border-bottom: 1px solid rgba(256,256,256,0.5);
    margin-bottom: 0px;
}
ul.sub_nav_box li a, ul.sub_nav_box li a span{
	color: #FFF;
	text-transform: uppercase;
	font-weight: 700;
	font-size: 18px;
}
ul.sub_nav_box li span{
	color: #FFF;
	text-transform: uppercase;
	font-weight: 700;
	font-size: 18px;
}
ul.sub_nav_box li:hover a, ul.sub_nav_box li:hover a span{
	color: #fdc500;
}
ul.sub_nav_box li a {
    display: flex;
    justify-content: space-between;
    align-items: center;
}
ul.sub_nav_box li span {
    display: flex;
    justify-content: space-between;
    align-items: center;
}
ul.none{
	/*list-style: none;
	margin-bottom: 10px;
	margin-top: 10px;*/
    margin-left: 15px;
}
ul.none li{
	margin-bottom: 10px;
}
ul.regular{
	margin-bottom: 10px;
	margin-left: 15px;
	margin-top: 10px;
}
ul.regular li{
	margin-bottom: 5px;
}
.list_icon{
	max-width: 40px;
	margin-right: 5px;
	vertical-align: middle;
}
.align_center{
	align-items: center;
}
.inner_wrap_main{
	padding: 40px;
}
.inner_wrap{
	padding: 20px;
}
.inner_wrap_main_box{
    padding: 0px 40px;
}
.out_wrap{
	margin: 20px;
	position: relative;
}
.inner_wrap_big{
	padding: 35px;
}
.border_radius{
	border-radius: 0px;
}
.bottom_space{
    margin: 25px 0;
}
.button_small{
	max-width: 350px;
}
.button_large{
	max-width: 550px;
}
.button, .button_yel, .button_yel_big{
	transition: 0.5s;
	margin: 25px 0px;
}
.button:hover, .button_yel:hover, .button_yel_big:hover{
	transform: scale(1.05);
	background: #333;
    color: #fdc500;
}
.button a, .button_yel a, .button_yel_big a{
	padding: 15px 25px;
	text-transform: uppercase;
	display: block;
	font-weight: 700;
	font-size: 18px;
}
.button{
	background: #00296b;
}
.button_yel{
	font-weight: 800;
    background: #fdc500;
    float: right;
    font-family: 'Open Sans', sans-serif;
    text-transform: uppercase;
    padding: 5px 80px;
    cursor: pointer;
    border: none;
    color: #00296b;
}
.button_yel_big{
    font-weight: 800;
    background: #fdc500;
    font-family: 'Open Sans', sans-serif;
    text-transform: uppercase;
    padding: 8px 100px;
    cursor: pointer;
    border: none;
    color: #00296b;
}
.button a{
	color: #FFF;
}
.button_yel a{
	color: #00296b;
}
.button_yel:hover a{
	color: #FFF;
}
input[type='checkbox'],
input[type='radio']{
    margin-right: 5px;
    height: 17px;
    width: 17px;
    vertical-align: middle;    
}
.blue_box{
	background: #00296b;
	padding: 15px;
}
.gr_bg{
	background: #e8e8e8;
}
.wh_bg{
	background: #FFF;
}
.bl_bg{
	background: #00296b;
}
.subline{
	color: #00296b;
	text-transform: none;
	margin-bottom: 15px;
}
.big_link{
	text-transform: uppercase;
	font-weight: 700;
	color: #00296b;
	font-size: 20px;
}
.teaser_col{
	background: #fff;
	overflow: hidden;
	margin: 20px 0px;
}
.teaser_pic{
	width: 100%;
}
.teaser_round_pic{
	border-radius: 100%;
	width: 90%;
}
.full_pic, .icon{
	width: 100%;
	vertical-align: top;
}
.full_pic.check_icon{
	max-width: 120px;
	margin-bottom: 15px;
}
.icon{
	max-width: 120px;
	margin-bottom:5px;
}
.center{
	text-align: center;
}
.justify{
	text-align: justify;
}
.justify-center{
    text-align-last: center;
}
.white_text{
	color: #FFF;
}
.yellow_link, .yellow_link a{
	color: #fdc500;
	text-transform: uppercase;
	font-size: 18px;
	font-weight: 700;
}
.margin_bottom{
	margin-bottom: 50px;
}
.uppercase{
	text-transform: uppercase;
}
.blue_head{
	color: #00296b;
}
.left{
	float:left;
	width: 48%;
}
.right{
	float: right;
	width: 48%;
}
.clear{
	clear: both;
}
.space{
    margin-bottom: 40px;
}
.head-table{
    margin-right: 10px;
}
.button_box{
	position: absolute;
	width: 80%;
	bottom: 0px;
}
.button_space{
	padding-bottom: 80px;
}
.button_space_small{
    padding-bottom: 10px;
}
.button_space_md{
    padding-bottom: 40px;
}

/*Kontaktformular*/
.form-group {
    display: flex;
    justify-content: space-between;
    margin-bottom: 15px;
	align-items: center;
}
.form-check-group{
	display: flex;
	margin-bottom: 15px;
}
.form-check-group .radio{
	margin-right: 15px;
}
.form-check-group .radio input{
	margin-right: 5px;
}
.control-label {
    width: 20%;
    min-width: 160px;
}
.col2.no-label label {
    display: none;
}
.form-group input, textarea.form-control{
	width: 100%;
	border-radius: 10px;
	padding: 5px;
	background: #efefef;
	border: none;
	max-height: 300px;
}
.form-group input:focus-visible,  textarea.form-control:focus-visible{
	outline: none;
	border: 1px solid #DDD;
}
.ds_wrap {
    font-size: 14px;
    line-height: 16px;
    background: #efefef;
    padding: 15px;
    border-radius: 10px;
    width: 100%;
    margin: 20px 0px;
}
.btn.btn-primary{
	border-radius: 10px;
	width: 100%;
	max-width: 350px;
	color: #FFF;
	background: #00296b;
	padding: 10px 15px;
	margin: 10px 0px;
	border: none;
	font-size:20px;
	transition: 0.3s;
}
.btn.btn-primary:hover{
	transform: scale(1.1);
	background: #222;
	cursor: pointer;
}
.green_box {
    background: #00296b;
    border-radius: 10px;
    padding: 20px;
}
.green_box p{
    color: #FFF;
}
div.y-video{
	text-align: center;
}
div.y-video>iframe{
	border-radius: 10px;
	overflow: hidden;
}
.kontakt_wrap i{
	min-width: 35px;
	text-align: center;
}
.frage_kontakt{
	margin-bottom: 15px;
}
.vorteile{
    margin-top: -31px;
}

@media(min-width:1920px){
	.wrapper{
		max-width: 1700px;
	}
}
@media(max-width:1450px){
	.wrapper_small{
		width: 96%;
		margin-left: 2%;
		margin-right: 2%;
	}
	.inner_wrap_main{
		padding: 35px;
	}
	.inner_wrap{
		padding: 15px;
	}
	.inner_wrap_big{
		padding: 35px;
	}
	.button_banner a {
		font-size: 22px;
	}
	.adresse_mobil{
		display: block;
	}
	.adresse_dt{
		display: none;
	}
}

@media(max-width:1300px){
}

@media(max-width:1200px){
	.wrapper{
		width: 90%;
		margin-left: 5%;
		margin-right: 5%;
	}
	.wrapper_small{
		width: 96%;
		margin-left: 2%;
		margin-right: 2%;
	}
	.col3{
		width: 46%;
	}
	.col5, .col6{
		width: 32%;
	}
	.banner-text-box{
		margin-top: 150px;
		margin-left: 20px;
	}
    .placeholder{
        display: none;
    }
}

@media(max-width:1100px){
    #hi div.history-line{
        display: none;
    }
    #hi div.history-line-mob{
        display: block;
    }
	h1, .head1{
		font-size: 45px;
		margin-bottom: 20px;
	}
	h2, .head2{
		font-size: 35px;
		margin-bottom: 20px;
	}
	h3, .head3{
		font-size: 30px;
		margin-bottom: 10px;
	}
	h4, .head4{
		font-size: 25px;
		margin-bottom: 5px;
	}
	.col2, .col2_sm{
		width: 100%;
		margin-bottom: 15px !important;
	}
    .flex_wrap.no_wrap{
        flex-wrap: wrap;
    }
	.col4, .col5, .col6{
		width: 48%;
		margin-bottom: 15px;
	}
	.inner_wrap_main{
		padding: 20px;
	}
	.inner_wrap{
		padding: 10px;
	}
	.inner_wrap_big{
		padding: 20px;
	}
	.banner-text-box{
		display: none;
	}
}

@media(max-width:756px){
	.wrapper{
		width: 96%;
		margin-left: 2%;
		margin-right: 2%;
	}
	h1, .head1{
		font-size: 35px;
		margin-bottom: 15px;
	}
	h2, .head2{
		font-size: 30px;
		margin-bottom: 10px;
	}
	h3, .head3{
		font-size: 23px;
		margin-bottom: 5px;
	}
	h4, .head4{
		font-size: 22px;
		margin-bottom: 10px;
	}
	h5, .head5{
		font-size: 19px;
	}
	h6, .head6{
		font-size: 17px;
	}
	p, table, tr, td, div, ul, li, ol, input, textarea, div, select, option, span{
		font-size: 16px;
	}
	.content{
		padding-bottom: 20px;
		padding-top: 20px;
	}
    .content_big{
		padding-bottom: 20px;
		padding-top: 40px;
	}
	.inner_wrap_main{
		padding: 10px;
	}
	.left, .right{
		width: 100%;
		float: none;
	}
	.left{
		margin-bottom: 15px;
	}
	.navi_dt{
		display: none;
	}
	.flex_wrap{
		justify-content: center;
	}
	.col_small, .col_big{
		width: 100%;
		margin-bottom: 10px !important;
	}
	.col3{
		width: 100%;
	}
	.col_eigenschaften_big, .col_eigenschaften_small{
		width: 100%;
	}
	.col_eigenschaften_big{
		margin-bottom: 15px;
	}
	#map_wrap{
		height: 350px;
	}
	.out_wrap{
		margin: 0px;
	}
}

@media(max-width:556px){
	p, table, tr, td, div, ul, li, ol, input, textarea, div, select, option, span{
		line-height: 170%;
	}
	h1, h2, h3, h4, .head1, .head2, .head3, .head4{
		line-height: 110%;
		word-break: keep-all;
		hyphens: none;
	}
	p.subline{
		line-height: 140%;
	}
	h1, .head1{
		font-size: 24px;
		margin-bottom: 15px;
	}
	h2, .head2{
		font-size: 22px;
		margin-bottom: 10px;
	}
	h3, .head3{
		font-size: 20px;
		margin-bottom: 5px;
	}
	h4, .head4{
		font-size: 18px;
		margin-bottom: 5px;
	}
	h5, .head5{
		font-size: 16px;
	}
	h6, .head6{
		font-size: 15px;
	}
	p, table, tr, td, div, ul, li, ol, input, textarea, div, select, option, span{
		font-size: 15px;
	}
	.subline{
		margin-bottom: 5px;
	}
	.flex_wrap{
		display: block;
	}
	.col3, .col4, .col5, .col6, .col_big{
		width: 100%;
		margin-bottom: 10px !important;
	}
	.inner_wrap_main{
		padding: 5px;
	}
	#map_wrap{
		height: 250px;
	}
	#logo_wrap{
		max-width: 60px;
	}
	.form-group {
    	display: block;
	}
	.form-check-group{
		display: block;
	}
	.control-label{
		width: 100%;
	}
	.col2_sm .button_box, .col3 .button_box, .col2 .button_box{
		position: relative;
		width: 100%;
	}
	.bottom_space, .button_space, .button, .button_yel, .button_yel_big, .button_space_md{
		margin: 5px 0px;
		padding-bottom: 0px;
	}
	
}
@media(max-width:456px){
	.wrapper{
		width: 98%;
		margin-left: 1%;
		margin-right: 1%;
	}
	.inner_wrap_main {
		padding: 5px 0px;
	}
	.inner_wrap {
		padding: 10px 5px;
	}
	h1, .head1{
		font-size: 20px;
		margin-bottom: 10px;
	}
	h2, .head2{
		font-size: 20px;
		margin-bottom: 5px;
	}
	h3, .head3{
		font-size: 18px;
		margin-bottom: 5px;
	}
	h4, .head4{
		font-size: 17px;
		margin-bottom: 0px;
	}
	h5, .head5{
		font-size: 16px;
	}
	h6, .head6{
		font-size: 15px;
	}
	p, table, tr, td, div, ul, li, ol, input, textarea, div, select, option, span{
		font-size: 15px;
	}
}

