@charset "utf-8";

@font-face {
  font-family: 'Euclid';
  font-weight: normal;
  font-style: normal;
  src: local(''),
       url('../webfonts/EuclidCircularA-Regular-WebXL.woff2') format('woff2'), 
       url('../webfonts/EuclidCircularA-Regular-WebXL.woff') format('woff'); 
}

@font-face {
  font-family: 'Euclid';
  font-weight: bold;
  font-style: normal;
  src: local(''),
       url('../webfonts/EuclidCircularA-Medium-WebXL.woff2') format('woff2'), 
       url('../webfonts/EuclidCircularA-Medium-WebXL.woff') format('woff'); 
}

@font-face {
  font-family: 'Euclid';
  font-weight: 900;
  font-style: normal;
  src: local(''),
       url('../webfonts/EuclidCircularA-Bold-WebXL.woff2') format('woff2'), 
       url('../webfonts/EuclidCircularA-Bold-WebXL.woff') format('woff'); 
}

@font-face {
  font-family: 'SangBleu';
  font-weight: normal;
  font-style: normal;
  src: local(''),
       url('../webfonts/SangBleuKingdom-Regular-WebXL.woff2') format('woff2'), 
       url('../webfonts/SangBleuKingdom-Regular-WebXL.woff') format('woff'); 
}

@font-face {
  font-family: 'SangBleu';
  font-weight: normal;
  font-style: italic;
  src: local(''),
       url('../webfonts/SangBleuKingdom-RegularItalic-WebXL.woff2') format('woff2'), 
       url('../webfonts/SangBleuKingdom-RegularItalic-WebXL.woff') format('woff'); 
}

@font-face {
  font-family: 'SangBleu';
  font-weight: bold;
  font-style: normal;
  src: local(''),
       url('../webfonts/SangBleuKingdom-Medium-WebXL.woff2') format('woff2'), 
       url('../webfonts/SangBleuKingdom-Medium-WebXL.woff') format('woff'); 
}

@font-face {
  font-family: 'SangBleu';
  font-weight: bold;
  font-style: italic;
  src: local(''),
       url('../webfonts/SangBleuKingdom-MediumItalic-WebXL.woff2') format('woff2'), 
       url('../webfonts/SangBleuKingdom-MediumItalic-WebXL.woff') format('woff'); 
}

@font-face {
  font-family: 'Wagon';
  font-weight: normal;
  font-style: normal;
  src: local(''),
       url('../webfonts/Wagon-ExtraLight.woff2') format('woff2'), 
       url('../webfonts/Wagon-ExtraLight.woff') format('woff'); 
}

@font-face {
  font-family: 'Wagon';
  font-weight: normal;
  font-style: italic;
  src: local(''),
       url('../webfonts/Wagon-ExtraLightItalic.woff2') format('woff2'), 
       url('../webfonts/Wagon-ExtraLightItalic.woff') format('woff'); 
}

html { 
	margin: 0px;
	min-height: 100%;
}
 
:focus {
	 outline:0; 
	 -moz-outline:0; 
} 

img {
	vertical-align: baseline;
}

span,div {
	zoom: 1;
}			   

input::-webkit-outer-spin-button, 
input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

input[type=number] {
  -moz-appearance: textfield;
}

a {
	zoom: 1;
	color: inherit;
}
	
a img {
	border-width: 0px;
}	   

a:hover  {
	color: inherit;
}

form {
	margin: 0px;
	padding: 0px;
}
	
sup { 
	vertical-align: baseline;
	position: relative;
	top: -0.5em;
	font-size: 70%;
	line-height: 70%;
}

body {	 
	position: relative;
	margin: 0;
	padding: 0px;
	-webkit-text-size-adjust: none;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	font-family: "Euclid",sans-serif;
	font-size: 20px; 
	line-height: 30px;	
	background-color: white;
	color: black;
	height: 100%;
	overflow-x: hidden;
}	 

.smalltext { font-size: 80%; }

/**** HEADER ****/

.header {
	box-sizing: border-box;
	position: relative;
	z-index: 99;
	left: 0px;
	top: 0px;
	width: 100%;
}

.header .logo {
	position: absolute;
	left: 40px;
	top: 30px;
	font-weight: bold;
	font-size: 24px;
	line-height: 28px;
	letter-spacing: 1px;
	text-decoration: none;
}

.header .logo sup {	
	line-height: 12px;
	position: relative; top: -7px;
}

.header .menuicons {
	position: absolute;
	right:40px;
	top: 31px;
}

#menu-hide { display: none; }

.header .sprachauswahl {
	position: absolute;
	right: 90px;
	top: 30px;
	font-size: 17px;
	line-height: 24px;
	letter-spacing: 0.5px;
}

.header .sprachauswahl a { text-decoration: none; }
.header .sprachauswahl a:hover { text-decoration: underline; }
.header .sprachauswahl a.sel { font-weight: 900; }

.menu {
	display: none;
	position: absolute;
	z-index: 99;
	right:40px;
	top: 70px;
}

.menu ul {
	font-size: 17px;
	line-height: 24px;
	text-align: right;
	margin: 0px;
	padding: 0px;
	list-style-type: none;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	font-weight: bold;
}

.menu a { text-decoration: none; }
.menu a:hover { text-decoration: underline; }

/**** MAIN ****/

.content {
	max-width: 1000px;
	padding: 75px 30px 75px 30px;
	margin: auto;
}

.content p {
	margin-left: auto;
	margin-right: auto;
	max-width: 750px;
}

.startseite {
	box-sizing: border-box;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	width: 100%;
	padding: 140px 30px 150px 30px;
}

.startseite h1 {
	font-family: "Wagon";
	font-size: 70px;
	line-height: 76px;
	font-weight: normal;
	margin-top: 25px;
	margin-bottom: 0px;
}

.startseite h1 p {
	margin: 0px;
}

.pfeil {
	position: absolute;
	left: 50%;
	bottom: 25px;
	margin-left: -35px;
}

.block {
	position: relative;
	width: 100%;
	margin: 0px;
}

.block ul {
	list-style-type: "- ";
	padding-left: 10px;
	margin-top: -15px;
}

.block h2 {
	font-size: 22px;
	line-height: 26px;
	margin-top: 0px;
	margin-bottom: 30px;
	text-align: center;
	text-transform: uppercase;
	letter-spacing: 1px;
}

.block h2.left { 
	text-align: left; 
	margin-left: auto;
	margin-right: auto;
	max-width: 750px;
}

.block h2.big {
	font-family: "Wagon";
	font-size: 44px;
	line-height: 46px;
	font-weight: normal;
	margin-top: 0px;
	margin-bottom: 60px;
	text-align: center;
	text-transform: none;
}

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

.block video {
	max-width: 100%;
}

.block-image { max-width: 420px; }

.aktuell-link {
	position: absolute;
	top: 0px;
	right: 190px;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 170px;
	height: 170px;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	font-weight: bold;
	text-decoration: none;
	text-align: center;
}

.accordion-head {
	font-style: italic;
	text-decoration: underline;
	cursor: pointer;
	margin-top: 20px;
}

.accordion-body {
	padding: 0px 15px 1px 15px;
}

.imageblock {
	font-size: 0;
	line-height: 0;
}

.imageblock .image-big {
	display: inline-block;
	width: 66.66666%;
}

.imageblock .image-small {
	display: inline-block;
	width: 33.33333%;
}

.float-left {
	float: left;
	margin-right: 15px;
	margin-top: 6px;
	margin-left: -30px;
}

.anfahrtsplan {
	margin-top: 30px;
	margin-bottom: 0px;
	margin-left: auto;
	margin-right: auto;
	max-width: 750px;
}

.anfahrtsplan img {
	max-width: 400px;
}

.zitat {
	font-family: "Wagon";
	font-size: 60px;
	line-height: 68px;
	font-style: italic;
	text-align: center;
	letter-spacing: 1px;
}

.quelle {
	margin-top: -48px;
	margin-bottom: 50px;
	font-size: 16px;
	line-height: 20px;
	text-align: center;
	color: black;
}

.zitat p {
	max-width: none !important;
}

h1.big  {
	font-family: "Wagon";
	font-size: 68px;
	line-height: 70px;
	font-weight: normal;
	margin-top: 65px;
	margin-bottom: 70px;
	text-align: center;
	max-width: 70%;
	margin-left: auto;
	margin-right: auto;
}

.bildunterschrift {
	font-size: 16px;
	line-height: 20px;
	text-align: center;
	color: black;
	padding-top: 10px;
	padding-bottom: 10px;
}

.portrait {
	width: 120px;
	margin: 20px auto 30px auto;
}

.stoerer {
	box-sizing: border-box;
	position: absolute;
	display: flex;
	align-items: center;
	justify-content: center;
	left: 50px; 
	top: 0px;
	width: 120px;
	height: 120px;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	font-weight: bold;
	text-decoration: none;
	text-align: center;
	font-size: 16px;
	line-height: 20px;
	padding: 15px;
}

/**** RASTER ****/

.raster {
	font-size: 0;
	line-height: 0;
	max-width: 800px;
	margin: auto;
}

.raster .element {
	display: inline-block;
	position: relative;
	width: 33.333%;
	padding-top: 33.333%;
}

.raster .element h3 {
	position: absolute;
	top: 40px;
	left: 15px;
	width: calc(100% - 30px);
	font-family: "Wagon";
	font-size: 30px;
	line-height: 32px;
	font-weight: normal;
	margin: 0px;
}	

.raster .element .overlay {
	display: none;
	box-sizing: border-box;
	position: absolute;
	left: 0px;
	top: 0px;
	width: 100%;
	height: 100%;
	padding: 15px;
	background-color: rgba(255,255,255,0.8);
	color: black;
	font-size: 16px;
	line-height: 20px;
}

/* .raster .element:hover .overlay {
	display: block;
} */

/**** FORMULAR ****/

.content form {
	margin-left: auto;
	margin-right: auto;
	max-width: 750px;
	margin-bottom: 40px;
}

.content form .auswahl {
	margin-bottom: 25px;
}

.content form .checkbox-label {
	display: block;
	font-weight: bold;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	font-size: 18px;
	line-height: 24px;
	margin-top: 8px;
	margin-bottom: 8px;
}

.content form .feld {
	display: inline-block;
	vertical-align: top;
	margin-top: 8px;
}

.content form .textfield {
	box-sizing: border-box;
	width: calc(100% - 12px);
	border: none;
	font-size: 18px;
	padding: 10px 5px;
}

.content form .feld label {
	font-size: 12px;
	letter-spacing: 1px;
	text-transform: uppercase;
	padding: 5px 15px 0px 8px;
}

#feld-vorname { width: 280px; }
#feld-nachname { width: 460px; }
#feld-email { width: 370px; }
#feld-telefon { width: 370px; }
#feld-plz { width: 200px; }
#feld-strasse { width: 370px; }
#feld-hausnummer { width: 165px; }



.content form .button {
	margin-top: 30px;
	text-align: center;
	position: relative;
}

.content form  .button .pflichtfelder-info {
	position: absolute;
	left: 0px;
	top: 0px;
	font-size: 12px;
	letter-spacing: 1px;
	text-transform: uppercase;
}

.content form .button input, .button a {
	display: inline-block;
	background-color: black;
	color: white;
	font-size: 12px;
	letter-spacing: 1px;
	text-transform: uppercase;
	padding: 5px 35px;
	border: none;
	-webkit-appearance: none;
	text-decoration: none;
	margin-top: 10px;
	margin-bottom: 20px;
}



/**** FOOTER ****/

.footer {
	box-sizing: border-box;
	padding-left: 30px;
	padding-right: 30px;
}

.footer p {
	margin: 0px auto 0px auto;
	max-width: 750px;
	font-size: 14px;
	line-height: 18px;
	text-transform: uppercase;
	font-weight: bold;
	letter-spacing: 0.5px;
}	

.footer p a { text-decoration: none; }
.footer p a:hover { text-decoration: underline; }

.footer .smalltext {
	padding-top: 20px;
	padding-bottom: 60px;
}

.footer .smalltext p {
	text-transform: none;
	letter-spacing: 0px;
	font-weight: normal;
	font-size: 12px;
	line-height: 16px;
}

/**** SMALL SCREENS ****/

@media only screen and (max-width: 1500px) {	
	body {	font-size: 18px; line-height: 27px; }
	.content { padding: 60px 30px 60px 30px; }
	.content p, .content h2.left, .anfahrtsplan, .footer p, .content form { max-width: 670px; }
	.block h2.big { margin-bottom: 50px; }
	#feld-vorname { width: 240px; }
	#feld-nachname { width: 420px; }
	#feld-email { width: 330px; }
	#feld-telefon { width: 330px; }
	#feld-plz { width: 180px; }
	#feld-strasse { width: 330px; }
	#feld-hausnummer { width: 145px; }
}

@media only screen and (max-width: 1040px) {	
	.header .logo { left: 25px; top: 20px; font-size: 20px; line-height: 24px; }
	.header .menuicons { right: 25px; top: 21px; }
	.header .menuicons img { width: 25px; }
	.header .sprachauswahl { right: 66px; top: 20px; font-size: 15px; line-height: 20px; }
	.menu { right: 25px; top: 60px; }
	.menu ul { font-size: 15px; line-height: 22px; }
	.aktuell-link { right: 160px; width: 140px; height: 140px; }
	.startseite h1, h1.big { font-size: 60px; line-height: 65px; }
	.zitat { font-size: 54px; line-height: 60px; }
	.quelle { margin-top: -40px; }
	.stoerer { font-size: 14px; line-height: 18px; width: 100px; height: 100px; left: 25px; }
	.block.mit-stoerer { padding-top: 80px; }
}

@media only screen and (max-width: 850px) {	
	.startseite { padding: 110px 30px 120px 30px; }
	.aktuell-link {right: 0px; top: 70px; width: 120px; height: 120px; font-size: 16px; line-height: 22px; }
	.menu { position: relative; right: 0px; top: 0px; background-color: #e9e6db; }
	.menu ul { text-align: center; font-size: 17px; line-height: 24px; }
	.menu ul li { border-bottom: 1px solid #d3cdb7; }
	.menu ul li a { display: block; padding-top: 5px; padding-bottom: 4px; }
	.menu ul li a:hover { text-decoration: none; background-color: rgba(255,255,255,0.2); }
	.content { padding: 40px 30px 40px 30px; }
	.block h2.big { font-size: 38px; line-height: 40px; margin-top: 10px; margin-bottom: 40px; }
	.raster .element h3 { font-size: 24px; line-height: 26px; top: 30px; left: 12px; width: calc(100% - 24px); }
	.raster .element .overlay { font-size: 14px; line-height: 17px; padding: 12px; }
	.zitat { font-size: 42px; line-height: 48px; }
	.quelle { margin-top: -30px; margin-bottom: 40px; }
	.bildunterschrift { font-size: 14px; }
	.content form { max-width: 400px; }
	.content form .feld { width: 100% !important; display: block; max-width: 400px; }
	.content form .textfield { width: 100%; }
	.content form .checkbox-label { font-size: 16px; line-height: 18px; }
	.content form .button { text-align: right; }
}

@media only screen and (max-width: 700px) {		
	.raster .element h3 { font-size: 21px; line-height: 24px; top: 25px; left: 10px; width: calc(100% - 20px); }
	.raster .element .overlay { font-size: 12px; line-height: 14px; padding: 10px; }
}

@media only screen and (max-width: 620px) {
	.logo { width: 180px; height: 180px; }
	.startseite h1, h1.big { font-size: 50px; line-height: 53px; }
	.raster .element { width: 100%; font-size: 24px; line-height: 26px; padding-top: 100px; }
	.zitat { font-size: 36px; line-height: 40px; }
	.quelle { margin-top: -20px; margin-bottom: 40px; font-size: 14px; }
}	

@media only screen and (max-width: 460px) {
	.logo { width: 130px; height: 130px; }
	.aktuell-link {right: 0px; top: 70px; width: 90px; height: 90px; font-size: 14px; line-height: 20px; }
	.startseite h1, h1.big { font-size: 44px; line-height: 46px; }
	.main h1 { max-width: none; }
	.raster .element { padding-top: 130px; }
	.zitat { font-size: 32px; line-height: 37px; }
	.imageblock .image-big, .imageblock .image-small { width: 100%; }
}