
/* -------------------------------------------------------
color 1: #3faf67; //grün
color 2: #2f6bb6; // blau

8px = 0.5rem
9px = 0.5625rem
10px = 0.625rem
11px = 0.6875rem
12px = 0.75rem
13px = 0.8125rem
14px = 0.875rem
15px = 0.9375rem
16px = 1rem (base)
18px = 1.125rem
20px = 1.25rem
22px = 1.375rem
24px = 1.5rem
26px = 1.625rem
28px = 1.75rem
30px = 1.875rem
32px = 2rem
34px = 2.125rem
36px = 2.25rem
38px = 2.375rem
40px = 2.5rem
 ------------------------------------------------------- */


*, *:after, *::before{
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

body{
	border: none;
  color: var(--colorblack);
  font-family: 'Open Sans';
  font-size: 16px;
  font-weight: 300;
  line-height: 1.5;
  margin: 0;
  padding: 0;
  letter-spacing:1px;
/*  overflow-x: hidden;*/
hyphens: auto;
-webkit-hyphens: auto;
    -moz-hyphens: auto;
    -ms-hyphens: auto;
    -o-hyphens: auto;
	hyphenate-limit-chars: auto 5;
   hyphenate-limit-lines: 2;
}

/*Farben bei markiertem Text*/
::-moz-selection { background: var(--gold); color: var(--petrol); }
::selection { background: var(--gold); color: var(--petrol); }
/*Farben bei markiertem Text*/

i {font-style: italic;}

a {outline: none; text-decoration: none; color: var(--gold, #000);}

a:hover {text-decoration: underline;}

h1, h2, h3{
  font-family: 'Open Sans';
  padding: 0;
  hyphens: manual;
}

h1{
  
  font-size: 1.9rem;
  font-weight: 300;
  letter-spacing: 0.2em;
  margin: 2rem 0 3rem;
  text-transform: uppercase;
    position: relative;
  display: inline-block; /* oder block, je nach Layout */
  padding-bottom: 0.5em; /* Abstand zur Linie */
    
}

h1::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  height: 6px; /* Dicke der Linie */
  width: 200px; /* feste Breite der Linie */
  background-color: var(--gold); 
}

@media screen and (max-width: 690px), (max-device-width: 690px) {
	h1 {
		letter-spacing: 0;
	}
}

h1:first-child{margin-top: 0;}

h2{
  
  font-size: 1.4rem;
  font-weight: 400;
  margin: 1.5rem 0 2.5rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

h3{
  
  font-size: 1.2rem;
  font-weight: 400;
  margin: 1.5rem 0 1.5rem;
}

h1 + h2 {margin-top: 0;}

p {margin: 0 0 3rem; padding: 0;}

em {font-style: italic;}

strong, .strong {font-weight: 400;}

small{font-size: 0.8em;}

img{border: 0;}

hr {
border: 0;
width: 95%;
height: 1px;
margin: 1.5rem auto 1.5rem;
}

ol, ul{
  font-weight: normal;
  list-style-position: outside;
  margin: 50px 0 25px 30px;
  padding: 0;
  text-align: left;
}

ol{list-style-type: decimal-leading-zero;}

ul{list-style-type: square;}

li{padding: 0 0 1.5rem 0;}

ul li::marker {color: #000;}

div.clear{clear: both; float: none;}

.mb-1{margin-bottom: 1rem;}
.mb-2{margin-bottom: 2rem;}

.bg-white {
	background: #fff;
	background-image: url('../images/footer-logo.png');
	background-position: center bottom;
	background-repeat:no-repeat;
	/*padding-bottom: 5rem;*/
}
.bg-white h1 {color: var(--petrol)!important; }
.bg-white li::marker {color: var(--petrol)!important; }
.bg-white h2 {color: var(--petrol)!important; }
.bg-white h3 {color: var(--petrol)!important; }
.bg-white a {color: var(--petrol); }
.bg-white hr {background-color: var(--petrol); }
.bg-petrol {background: var(--petrol);}
.bg-petrol hr {background-color: var(--gelb);}
.bg-petrol > * {color: #fff!important;}
.bg-petrol a, h1, h2, h3, li::marker {color: #fff!important; }
.bg-pink {background: var(--pink);}
.bg-pink > * {color: #fff!important;}
.bg-pink h1, li::marker {color: #fff!important; }
.bg-pink h2 {color: #fff!important; }
.bg-pink h3 {color: #fff!important; }
.bg-pink a {color: #fff!important; }
.bg-gelb h1 {color: var(--petrol)!important; }
.bg-gelb li::marker {color: var(--petrol)!important; }
.bg-gelb h2 {color: var(--petrol)!important; }
.bg-gelb h3 {color: var(--petrol)!important; }
.bg-gelb a {color: var(--petrol); }
.bg-gelb hr {background-color: var(--petrol); }
.bg-gelb {background: var(--gelb); }

.bg {
	background-position: center center;
	background-attachment: static;
	background-repeat: no-repeat;
	background-size: cover;
	padding: 0!important;
}

.black-layer{
	background: rgba(0,0,0,0.7);
	padding: 1.75em;
	}

.white-layer{
	background: rgba(255,255,255,0.5);
	padding: 1.75em;
	}

.black-color {
	color: #000;
}

.white-color {
	color: #fff;
}

.noborder {border: none!important;}

.border-t-dark { border-top: 1px solid #000; }
.border-b-dark { border-bottom: 1px solid #000; }
.border-t-light { border-top: 1px solid #fff; }
.border-b-light { border-bottom: 1px solid #fff; }


/*-------------------------------------------------------------------
-------------------------------------------------------------------*/




#head {
    background-position: center center;
    background-attachment: fixed;
    background-repeat: no-repeat;
    background-size: cover;
    height: 100vh;
    width: 100vw;
    max-width: 100%;
		overflow-x: hidden;
}


@media screen and (max-width: 650px), (max-device-width: 650px) {
	#head {
    background-attachment: scroll;
}
}

#head-overlay  {
    background: rgba(0,0,0,1);
    height: 100vh;
    width: 100vw;
	
}

#head-in > div#navigation {
  align-items: flex-end;
  display: flex;
}
#head-in > div#navigation {
	justify-content: center;
	background: var(--petrol);
	box-shadow: 0 0 10px rgba(0, 0, 0, 0.8);
	width: 100%;
	position: fixed;
	z-index:9999999!important;
	}

#head-in > div#logo-content {
	display: flex;
	flex-wrap: wrap;
	flex-direction: column;
	justify-content: center;
	padding-top:21vh;
	}

#head-in > div#logo-content > div {
	font-size: 1.2rem;
	color: #fff;
	text-align: center;
	}


#head-in > div#logo-content > #logo > img {
	display: block;
	margin: 0 auto;
	padding: 2rem;
	width: 100%;
	max-width: 400px;
	}


#head-in > div#logo-content > #slogan {
	text-shadow: 0 0 5px rgba(0,0,0,0.5);
	font-weight: 600;
	}

#head-in > div#logo-content > #btn {
	display:flex;
	align-items:center;
	justify-content: center;
	}

#head-in > div#logo-content > #btn > a{
	text-decoration: none; 
	background: var(--petrol);
	border: 1px solid var(--gold);
	box-shadow: 0 0 5px rgba(0,0,0,0.5);
	padding: 0.33rem;
	color: var(--gold);
	border-radius: 5px;
	margin: 1rem 0;
	}

#head-in > div#logo-content > #btn > a:hover{
	background: var(--gold);
    border: 1px solid var(--petrol);
    color: var(--petrol);
}

/* -------------------------- */

#wrap {
	font-size: 1.125rem;
}

.content {
    padding: 1.75rem;
	padding-bottom: 9rem;
}

.bg-white {
	padding-bottom: 15rem;
}

.content-in {
    margin: 50px auto;
    max-width: 1200px;
    width: 100%;
}

.box-group {
	display: flex;
	flex-wrap: wrap;
	gap: 5rem;
}

.box-group5050 > div {
	flex: 1 0 calc(50% - 5rem);
}



.box-group6040 > div {
	padding-bottom: 1rem;
}

.box-group6040 > div:nth-of-type(odd) {
		width: calc(60% - 2.5rem);
}

.box-group6040 > div:nth-of-type(even) {
	width: calc(40% - 2.5rem);
}

.box-group3366 > div:nth-of-type(odd) {
		width: calc(33.3% - 2.5rem);
}

.box-group3366 > div:nth-of-type(even) {
	width: calc(66.6% - 2.5rem);
}

.box-group6633 > div:nth-of-type(odd) {
		width: calc(66.6% - 2.5rem);
}

.box-group6633 > div:nth-of-type(even) {
	width: calc(33.3% - 2.5rem);
}
}

@media screen and (max-width: 850px), (max-device-width: 850px) {
	.box-group5050 > div {
	flex: 0 0 100%;
	
}
.box-group5050 > div > a > img{
	width: 10%;
}
}

@media screen and (max-width:750px), (max-device-width: 750px) {
  .box-group6040 > div {	width: 100%!important;	}
	.box-group6040 > div:nth-of-type(odd) {	padding-right: 0; order:2;}
	.box-group6040 > div:nth-of-type(even) {	padding-left: 0; order: 1;	}
	.box-group3366 > div {	width: 100%!important;	}
	.box-group3366 > div:nth-of-type(odd) {	order:2;}
	.box-group3366 > div:nth-of-type(even) {order: 1;	}
  .box-group6633 > div {	width: 100%!important;	}
  .box-group33 > div {	flex: 1 0 100%; margin-bottom: 1rem; 	}
}

.box-group33 > div {
	flex: 1 0 calc(33.33% - 10rem);
	}




@media screen and (max-width: 1050px), (max-device-width: 1050px) {
.box-group33 > div {
	
}

.box-group33 > div:nth-of-type(1) {
	flex: 1 0 100%; margin-bottom: 1rem;
}
.box-group33 > div:nth-of-type(2){
	flex: 1 0 calc(50% - 2.5rem); 
}
.box-group33 > div:nth-of-type(3) {
	flex: 1 0 calc(50% - 2.5rem); 
}


}

@media screen and (max-width: 650px), (max-device-width: 650px) {
.box-group33 > div:nth-of-type(1) {
	flex: 1 0 100%; margin-bottom: 1rem;
}
.box-group33 > div:nth-of-type(2) {
	flex: 1 0 100%; margin-bottom: 1rem;
}
.box-group33 > div:nth-of-type(3) {
	flex: 1 0 100%;
}	
}

#footer * {color: #fff;}

#footer  {
    padding: 1.75rem;
}


#footer-in {
    margin: 0 auto;
    max-width: 1200px;
    width: 100%;
}

#imprint {display: flex; flex-wrap: wrap; padding: 2rem 0;}

#imprint div {flex-grow: 1;}

@media screen and (max-width: 900px), (max-device-width: 900px) {
  #imprint div {width: 50%;}
  #imprint div:nth-last-of-type(-n +2) {padding-top: 2rem;}
}

@media screen and (max-width: 600px), (max-device-width: 600px) {
  #imprint div {width: 100%; text-align:center;}
  #imprint div:nth-last-of-type(-n +2) {padding-top: 0rem;}
  #imprint div:nth-of-type(n +2) {padding-top: 2rem;}
}

#imprint div h3 {
  
  margin: 0 0 0.5rem 0;
  text-transform: uppercase;
}

#imprint * {
  line-height: 1.9;
}

a.contentpic {
  line-height: 0!important;
  display: block;
  margin-bottom: 1rem;
  
}

a.contentpic img {
	border: 6px solid var(--gold);
	width: 100%;
  line-height: 0!important;
  box-shadow: 0 0 5px rgba(0,0,0,0.5);
}




div.box-group6633 > div > a.contentpic > img {
	border-radius: 0 0 0 0;
	height: 230px;
	object-fit: cover;
	width: 100% !important;
}


div.box-group6633 > div > a.contentpic-v > img {
	height: auto;
}





div.box-group6633:first-of-type > div > a.contentpic > img {
	border-radius: 0 15px 0 15px;
}

div.box-group6633:last-of-type > div > a.contentpic > img {
	border-radius: 0 15px 0 15px;
}

div.box-group6633:only-of-type > div > a.contentpic > img {
	border-radius: 0 15px 0 15px;
}



@media screen and (max-width: 750px), (max-device-width: 750px) {
div.box-group6633:first-of-type > div > a.contentpic > img {
	border-radius: 0 0 0 0;
}
div.box-group6633:last-of-type > div > a.contentpic > img {
	border-radius: 0 0 0 0;
}
div.box-group6633:only-of-type > div > a.contentpic > img {
	border-radius: 0 0 0 0;
}
}


div.box-group33 div > a.contentpic > img {
	border-radius: 0 0 0 0;
}




a.contentpic:hover img {
  box-shadow: 0 0 6px rgba(0,0,0,0.8);
}

.responsive-video iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.responsive-video {
	position: relative;
	padding-bottom: 56.25%; /* Default for 1600x900 videos 16:9 ratio*/
	padding-top: 0px;
	height: 0;
	overflow: hidden;
}


@media (max-width: 750px) {
  .qr-code {
    display: none;
  }
}