body {
	float: left;
	width: 100%;
	font-family:  CenturyGothicStd, Century Gothic, 'Century Gothic', CenturyGothic, AppleGothic, 'Muli', sans-serif, Arial, Helvetica;
	color:#323232;
	font-size:11px;
	box-sizing: border-box;
}

* {
	letter-spacing: 1px;
}

a {
	color: #323232;
	}
	a:hover{
		color: #454545;
		}



.linkwhite{
	color: #FFF;
	text-decoration: none;
}
	.linkwhite:hover{
		color: #ccc;
	}

h1 {
	font-size: 24px;
	font-weight: bold;
	line-height: 1.4;
	}

h2 {
	font-size: 95%;
	font-weight: bold;
	line-height:130%;
	color:#333;
	}

h3 {
	font-size: 150%;
	font-weight: bold;
	line-height:100%;
	color:#333;
	}

.floatleft {
	float: left;
}

.floatright {
	float: right;
}



/* main containers */


#maincontent {
	float: left;
	width: 100%;
	padding: 0 0px 0px 0px;
	position: relative;
	box-sizing: border-box;
	background-color:#FFF;
}
#content {
	margin: 0 auto;
	width: 100%;
	max-width: 978px;
}

#middlecolumn {
	float: left;
	width: 53%;
	padding-left: 15px;
	padding-right: 15px;
	color: #333;
	box-sizing: border-box;
	margin-bottom: 30px;
}


/* header */

#header {
	float: left;
	width:100%;
	height: 234px;
	margin: 0 auto;
	position: relative;
	overflow: hidden;
	background: url(/public/images/header-bg-startpage.jpg) no-repeat left;
}

#headermobile {
	display: none;
}

	#header.startpage {
		background: url(/public/images/header-bg-startpage.jpg) no-repeat left;
	}

	#header.shops {
		background: url(/public/images/header-bg-shops.jpg) no-repeat left;
	}

	#header.shop {
		background: url(/public/images/header-bg-shop.jpg) no-repeat left;
	}

	#header.oeffnungszeiten {
		background: url(/public/images/header-bg-oeffnungszeiten.jpg) no-repeat left;
	}

	#header.office {
		background: url(/public/images/header-bg-office.jpg) no-repeat left;
	}
	#header.kontakt {
		background: url(/public/images/header-bg-kontakt.jpg) no-repeat left;
	}
	#header.impressum {
		background: url(/public/images/header-bg-impressum.jpg) no-repeat left;
	}
	#menuimage {
		float: left;
		width: 40px;
		position: absolute;
		top: 5px;
		right: 20px;
	}

	#topmobilenavi {
		float: left;
		width: 100%;
		padding: 10px 20px 5px 20px;
		margin: 0;
		background-color: rgba(0,0,0,0.1);
		box-sizing: border-box;
		position: relative;
		margin-top: -53px;
		-webkit-transition: 0.3s;
		-moz-transition: 0.3s;
		-o-transition: 0.3s;
		transition: 0.3s;
		}

		#topmobilenavi li {
			float: left;
			list-style: none;
		}

		#topmobilenavi .menuitem{
			float: left;
			text-decoration: none;
			text-align: center;
			padding: 0px 9px 0px 9px;
			cursor: pointer;
			line-height: 37px;
			height: 38px;
			overflow: hidden;
			font-size: 16px;
			box-sizing: border-box;
			position: relative;
			text-transform: uppercase;
			}

	#navigation {
		float: right;
		position: absolute;
		right: 0;
		bottom: -11px;
		height: 35px;
		padding: 2px 20px;
		background-color: rgba(255,255,255,0.8);
		-webkit-transition: 0.3s;
		-moz-transition: 0.3s;
		-o-transition: 0.3s;
		transition: 0.3s;
	}

		#navigation li {
			float: left;
			list-style: none;
			position: relative;
		}

		#navigation .menuitem{
			float: left;
			text-decoration: none;
			text-align: center;
			padding: 0px 9px 0px 9px;
			cursor: pointer;
			line-height: 37px;
			height: 38px;
			overflow: hidden;
			font-size: 16px;
			box-sizing: border-box;
			position: relative;
			text-transform: uppercase;
			letter-spacing: 1.5px;
			}
			#navigation .menuitem:hover {

				}
		#navigation .menuitem.current {
			font-family:  CenturyGothicStd-Bold, CenturyGothicStd, Century Gothic, 'Century Gothic', CenturyGothic, AppleGothic, 'Muli', sans-serif, Arial, Helvetica;
			font-weight: 400;
			}
		#navigation .submenucontent{
			float: left;
			display: none;
			box-sizing: border-box;
			background-color: #141414;
			position: absolute;
			width: 100%;
			padding:10px 0px 10px 0px;
			top: 38px;
			left: 0px;
			box-shadow: 0px 3px 5px rgba(0,0,0,0.4);
			z-index: 2;
		}
		#navigation .submenuitem{
			float: left;
			width:100%;
			text-decoration: none;
			padding: 5px 15px 5px 15px;
			cursor: pointer;
			color: #FFF;
			font-size:12px;
			box-sizing: border-box;
			}
			#navigation .submenuitem:hover {
				background-color: #333;
				}

/* footer */

#footer {
	float: left;
	text-align: center;
	width: 100%;
	background-color: #ededed;
	font-size: 16px;
	font-family:  CenturyGothicStd-Bold, CenturyGothicStd, Century Gothic, 'Century Gothic', CenturyGothic, AppleGothic, 'Muli', sans-serif, Arial, Helvetica;
	font-weight: 400;
	padding: 30px 50px;
	color: #0d0d0d;
	box-sizing: border-box;
}

	.footerpart {
		display: inline-block;
		padding: 10px 10px;
		line-height: 1.6;
	}

	.footerpart a {
		color: #0d0d0d;
		text-decoration: none;
	}



/* all pages */
.greybg {
	background-color: #f4f4f4;
}


/* start page */

#startpage {
	float: left;
	width: 100%;
}


	#startpage h1 {
		text-align: center;
		margin: 40px 20px 30px 20px;
		line-height: 1.4;
		font-family:  CenturyGothicStd-Bold, CenturyGothicStd, Century Gothic, 'Century Gothic', CenturyGothic, AppleGothic, 'Muli', sans-serif, Arial, Helvetica;
		font-weight: 400;
	}

	#startpage .newscontainer {
		float: left;
		padding: 23px;
		box-sizing: border-box;
		width: 254px;
		margin-right: 36px;
		margin-bottom: 36px;
		-webkit-transition: 0.3s;
		-moz-transition: 0.3s;
		-o-transition: 0.3s;
		transition: 0.3s;
	}

		#startpage .newscontainer .block {
			margin-top: 40px;
			position: relative;
		}

		#startpage .newscontainer .block.first {
			margin-top: 0px;
		}

			#startpage .newscontainer h3.title {
				margin-top: 15px;
				margin-bottom: 0px;
				font-size: 15px;
				font-weight: bold;
				letter-spacing: 1.5px;
				font-family:  CenturyGothicStd-Bold, CenturyGothicStd, Century Gothic, 'Century Gothic', CenturyGothic, AppleGothic, 'Muli', sans-serif, Arial, Helvetica;
			}

			#startpage .newscontainer .pretext {
				margin-top: 10px;
				margin-right: 35px;
				font-size: 14px;
			}

			#startpage .newscontainer a {
				text-decoration: none;
			}

			#startpage .newscontainer img.more {
				position: absolute;
				bottom: -3px;
				right: -3px;
				width: 32px;
			}

	#startpage .maincontainer {
		margin-left: 290px;
		margin-bottom: 36px;
		-webkit-transition: 0.3s;
		-moz-transition: 0.3s;
		-o-transition: 0.3s;
		transition: 0.3s;
	}

		#startpage .maincontainer .bigimage {
			display: block;
			width: 100%;
			box-sizing: border-box;
			border: 1px solid #f7f7f7;
			margin-bottom: 36px;
		}

		#startpage .maincontainer .block {
			padding: 30px;
			-webkit-transition: 0.3s;
			-moz-transition: 0.3s;
			-o-transition: 0.3s;
			transition: 0.3s;
		}

		#startpage .maincontainer .block .title {
			font-size: 22px;
			margin-bottom: 20px;
			font-weight: bold;
			letter-spacing: 1px;
			font-family:  CenturyGothicStd-Bold, CenturyGothicStd, Century Gothic, 'Century Gothic', CenturyGothic, AppleGothic, 'Muli', sans-serif, Arial, Helvetica;
			font-weight: 400;
		}

		#startpage .maincontainer .block .text {
			font-size: 16px;
			line-height: 1.4;
			letter-spacing: 1px;
		}

		#startpage .maincontainer .block img {
			height: auto !important;
			-webkit-transition: 0.3s;
			-moz-transition: 0.3s;
			-o-transition: 0.3s;
			transition: 0.3s;
		}


/* article */

#article {
	float: left;
	width: 100%;
	margin-bottom: 50px;
	-webkit-transition: 0.3s;
	-moz-transition: 0.3s;
	-o-transition: 0.3s;
	transition: 0.3s;
}

	#article h1 {
		margin-top: 50px;
		margin-bottom: 30px;
		font-family:  CenturyGothicStd-Bold, CenturyGothicStd, Century Gothic, 'Century Gothic', CenturyGothic, AppleGothic, 'Muli', sans-serif, Arial, Helvetica;
		font-weight: 400;
	}

	#article .textcontainer {
		font-size: 16px;
		line-height: 1.7;
	}

	#article .textcontainer img {
		-webkit-transition: 0.3s;
		-moz-transition: 0.3s;
		-o-transition: 0.3s;
		transition: 0.3s;
	}

/* shops */

#shops {
	float: left;
	width: 100%;
}

	#shops .topline {
		float: left;
		width: 100%;
		margin-top: 30px;
		margin-bottom: 10px;
	}

	#shops.shop .topline {
		font-size: 18px;
		font-weight: bold;
		text-transform: uppercase;
		margin-top: 53px;
		margin-bottom: 26px;
		font-family:  CenturyGothicStd-Bold, CenturyGothicStd, Century Gothic, 'Century Gothic', CenturyGothic, AppleGothic, 'Muli', sans-serif, Arial, Helvetica;
		font-weight: 400;
	}

	#shops.shop .topline a {
		text-decoration: none;
	}

	#shops.shop .topline a:hover {
		text-decoration: underline;
	}

	#shops .topline .breadcrumb {
		float: left;
		font-size: 22px;
	}

	#shops .topline .maptitle {
		float: right;
		margin-top: 5px;
	}

	#shops .topline h1 {
		font-family:  CenturyGothicStd-Bold, CenturyGothicStd, Century Gothic, 'Century Gothic', CenturyGothic, AppleGothic, 'Muli', sans-serif, Arial, Helvetica;
		font-weight: 400;
		text-transform: uppercase;
		-webkit-transition: 0.3s;
		-moz-transition: 0.3s;
		-o-transition: 0.3s;
		transition: 0.3s;
	}

		#shops .levels {
			float: right;
			margin-top: 20px;
			font-size: 16px;
			text-transform: uppercase;
			-webkit-transition: 0.3s;
			-moz-transition: 0.3s;
			-o-transition: 0.3s;
			transition: 0.3s;
		}

		#shops .levels a {
			text-decoration: none;
			margin-left: 10px;
		}

		#shops .levels a.active {
			font-family:  CenturyGothicStd-Bold, CenturyGothicStd, Century Gothic, 'Century Gothic', CenturyGothic, AppleGothic, 'Muli', sans-serif, Arial, Helvetica;
			font-weight: 400;
		}

	#shops .middlecontainer {
		float: left;
		position: relative;
		width: 100%;
		margin-bottom: 40px;
	}

		#shops .blockleft {
			float: left;
			width: 48.5%;
			min-height: 387px;
			padding: 30px;
			box-sizing: border-box;
			-webkit-transition: 0.3s;
			-moz-transition: 0.3s;
			-o-transition: 0.3s;
			transition: 0.3s;
			overflow: hidden;
		}

			#shops .blockleft .line {
				display: block;
				float: left;
				width: 100%;
				margin-bottom: 7px;
				font-size: 14px;
			}

			#shops .blockleft .title {
				float: left;
				width: 50%;
				text-decoration: none;
				font-family:  CenturyGothicStd-Bold, CenturyGothicStd, Century Gothic, 'Century Gothic', CenturyGothic, AppleGothic, 'Muli', sans-serif, Arial, Helvetica;
				font-weight: 400;
				text-transform: uppercase;
			}

			#shops .blockleft .title a,
			#shops .blockleft .line a {
				text-decoration: none;
			}

			#shops .blockleft .title a:hover,
			#shops .blockleft .line a:hover {
				text-decoration: underline;
			}

			#shops .blockleft .category {
				float: left;
				width: 50%;
				padding-left: 15px;
				box-sizing: border-box;
			}

		#shops .blockright {
			float: right;
			width: 48.5%;
			border: 2px solid #f1f1f1;
			box-sizing: border-box;
			-webkit-transition: 0.3s;
			-moz-transition: 0.3s;
			-o-transition: 0.3s;
			transition: 0.3s;
		}

			#shops .blockright img {
				float: left;
				width: 100%;
			}

		#shops .blockbottom {
			float: left;
			width: 100%;
			padding: 30px;
			box-sizing: border-box;
			margin-top: 30px;
		}

			#shops .blockbottom .main,
			#shops .blockbottom .title,
			#shops .blockbottom .text {
				width: 48.4%;
			}

			#shops .blockbottom .text {
				letter-spacing: 2px;
			}

			#shops .blockbottom .main {
				float: right;
			}

			#shops .blockbottom .title {
				float: left;
				font-size: 17px;
				line-height: 1.6;
				font-weight: bold;
				font-family:  CenturyGothicStd-Bold, CenturyGothicStd, Century Gothic, 'Century Gothic', CenturyGothic, AppleGothic, 'Muli', sans-serif, Arial, Helvetica;
				font-weight: 400;
				margin-bottom: 20px;
				-webkit-transition: 0.3s;
				-moz-transition: 0.3s;
				-o-transition: 0.3s;
				transition: 0.3s;
			}

			#shops .blockbottom .text {
				float: left;
				font-size: 15px;
				line-height: 1.4;
				-webkit-transition: 0.3s;
				-moz-transition: 0.3s;
				-o-transition: 0.3s;
				transition: 0.3s;
			}

/* blocks */

#blocks {
	float: left;
	width: 100%;
	font-size: 16px;
	margin-top: 30px;
}

	#blocks .leftcontainer {
		float: left;
		width: 57%;
		margin-right: 3%;
		margin-bottom: 30px;
		padding: 30px;
		box-sizing: border-box;
		-webkit-transition: 0.3s;
		-moz-transition: 0.3s;
		-o-transition: 0.3s;
		transition: 0.3s;
	}


	#blocks .rightcontainer {
		float: right;
		width: 40%;
		margin-bottom: 30px;
		padding: 30px;
		box-sizing: border-box;
		-webkit-transition: 0.3s;
		-moz-transition: 0.3s;
		-o-transition: 0.3s;
		transition: 0.3s;
	}

	#blocks .leftcontainer strong,
	#blocks .rightcontainer strong {
		font-family:  CenturyGothicStd-Bold, CenturyGothicStd, Century Gothic, 'Century Gothic', CenturyGothic, AppleGothic, 'Muli', sans-serif, Arial, Helvetica;
		font-weight: 400;
	}



	#blocks .bottomcontainer {
		float: left;
		width: 100%;
		margin-bottom: 40px;
	}

		#blocks .bottomcontainer img {
			width: 100%;
			float: left;
		}


/*  */

.menuline {
	width: 100%;
	height: 7px;
	background-color: #4C4C4C;
	border-bottom: 1px solid #2b2b2b;
	border-top: 1px solid #2b2b2b;
	margin-top: -1px;
	}






.contactform{
	float: left;
	width: 85%;
	box-sizing: border-box;
	margin-top: 20px;
	margin-bottom: 50px;
}
	.contactform .successblock{
		float: left;
		width: 100%;
		box-sizing: border-box;
		padding: 8px 16px;
		font-size: 13px;
		color: #668822;
		margin-top: 20px;
		margin-bottom: 20px;
		line-height: 1.8;
		font-weight: bold;
		background-color: #EFFBD7;
	}
	.contactform .errorblock{
		float: left;
		width: 100%;
		box-sizing: border-box;
		padding: 8px 16px;
		font-size: 13px;
		color: #A54B4B;
		margin-top: 20px;
		margin-bottom: 20px;
		line-height: 1.8;
		font-weight: bold;
		background-color: #F9E5E5;
	}
	.contactform .errorstar{
		float: left;
		font-size: 20px;
		color: #A54B4B;
		padding-left: 7px;
		margin-top: 6px;
		margin-bottom: -5px;
		font-weight: bold;
		margin-right: -20px;
	}
	.contactform .star{
		display: inline-block;
		font-size: 16px;
		color: #A54B4B;
		font-weight: bold;
	}
	.contactform .inputblock{
		float: left;
		width: 100%;
		box-sizing: border-box;
		margin-bottom: 15px;
	}
	.contactform .title{
		float: left;
		width: 100%;
		box-sizing: border-box;
		margin-bottom: 3px;
		font-size: 13px;
		color: #333;
	}
	.contactform input, .contactform textarea{
		float: left;
		width: 100%;
		box-sizing: border-box;
		border-radius: 3px;
		-moz-border-radius: 3px;
		-webkit-border-radius: 3px;
		box-shadow: inset 0px 1px 7px rgba(0, 0, 0, 0.26);
		-moz-box-shadow: inset 0px 1px 7px rgba(0, 0, 0, 0.26);
		-webkit-box-shadow: inset 0px 1px 7px rgba(0, 0, 0, 0.26);
		border: 1px solid #c0c0c0;
		padding: 6px 10px;
		font-size: 13px;
		background-color: #f5f5f5;
		color: #333;
	}
	.contactform button{
		float: left;
		box-sizing: border-box;
		padding: 4px 8px;
		font-size: 13px;
		color: #666;
		margin-top: 10px;
	}








@media only screen and (max-width : 1016px) {

	.footerpart.middle {
		width: 100%;
	}

	#article {
		box-sizing: border-box;
		padding: 0 20px;
		-webkit-transition: 0.3s;
		-moz-transition: 0.3s;
		-o-transition: 0.3s;
		transition: 0.3s;
	}

	#shops .topline h1,
	#shops .topline .breadcrumb {
		margin-left: 20px;
		-webkit-transition: 0.3s;
		-moz-transition: 0.3s;
		-o-transition: 0.3s;
		transition: 0.3s;
	}

	#shops .topline .levels,
	#shops .topline .maptitle {
		margin-right: 20px;
		-webkit-transition: 0.3s;
		-moz-transition: 0.3s;
		-o-transition: 0.3s;
		transition: 0.3s;
	}

	#header {
		background-size: 100% 100% !important;
	}

}


@media only screen and (max-width : 978px) {


	#shops .blockleft {
		min-height: 0px;
		padding: 20px;
		-webkit-transition: 0.3s;
		-moz-transition: 0.3s;
		-o-transition: 0.3s;
		transition: 0.3s;
	}

}

@media only screen and (max-width : 900px) {

	#startpage .maincontainer .block img {
		width: 100% !important;
		height: auto !important;
		-webkit-transition: 0.3s;
		-moz-transition: 0.3s;
		-o-transition: 0.3s;
		transition: 0.3s;
	}

}


/* Tablet */
@media only screen and (max-width : 650px) {

	#footer {
		padding-left: 20px;
		padding-right: 20px;
		-webkit-transition: 0.3s;
		-moz-transition: 0.3s;
		-o-transition: 0.3s;
		transition: 0.3s;
	}

	#navigation {
		bottom: -50px;
		-webkit-transition: 0.3s;
		-moz-transition: 0.3s;
		-o-transition: 0.3s;
		transition: 0.3s;
	}

	#topmobilenavi {
		margin-top: 0;
		-webkit-transition: 0.3s;
		-moz-transition: 0.3s;
		-o-transition: 0.3s;
		transition: 0.3s;
	}

	#startpage .newscontainer {
		width: 100%;
		-webkit-transition: 0.3s;
		-moz-transition: 0.3s;
		-o-transition: 0.3s;
		transition: 0.3s;
	}

	#startpage .maincontainer {
		float: left;
		width: 100%;
		margin-left: 0px;
		-webkit-transition: 0.3s;
		-moz-transition: 0.3s;
		-o-transition: 0.3s;
		transition: 0.3s;
	}

	#startpage .maincontainer .block {
		padding: 15px;
		-webkit-transition: 0.3s;
		-moz-transition: 0.3s;
		-o-transition: 0.3s;
		transition: 0.3s;
	}

	#article .textcontainer img {
		width: 100% !important;
		-webkit-transition: 0.3s;
		-moz-transition: 0.3s;
		-o-transition: 0.3s;
		transition: 0.3s;
	}

	#shops .blockleft {
		width: 100%;
		margin-bottom: 30px;
		position: relative;
		-webkit-transition: 0.3s;
		-moz-transition: 0.3s;
		-o-transition: 0.3s;
		transition: 0.3s;
	}

	#shops .blockright {
		width: 100%;
		-webkit-transition: 0.3s;
		-moz-transition: 0.3s;
		-o-transition: 0.3s;
		transition: 0.3s;
	}

	#shops .blockbottom .main {
		width: 100%;
		margin-bottom: 20px;
		-webkit-transition: 0.3s;
		-moz-transition: 0.3s;
		-o-transition: 0.3s;
		transition: 0.3s;
	}

	#shops .blockbottom .title {
		width: 100%;
		-webkit-transition: 0.3s;
		-moz-transition: 0.3s;
		-o-transition: 0.3s;
		transition: 0.3s;
	}

	#shops .blockbottom .text {
		width: 100%;
		-webkit-transition: 0.3s;
		-moz-transition: 0.3s;
		-o-transition: 0.3s;
		transition: 0.3s;
	}

	#blocks .leftcontainer {
		width: 100%;
		-webkit-transition: 0.3s;
		-moz-transition: 0.3s;
		-o-transition: 0.3s;
		transition: 0.3s;
	}

	#blocks .rightcontainer {
		width: 100%;
		-webkit-transition: 0.3s;
		-moz-transition: 0.3s;
		-o-transition: 0.3s;
		transition: 0.3s;
	}

}

@media only screen and (max-width : 470px) {

	#shops .topline .levels {
		margin-right: 0;
		width: 100%;
	}

		#shops .topline .levels a {
			display: block;
			float: left;
			width: 100%;
			box-sizing: border-box;
			text-align: left;
			padding-left: 20px;
			margin-left: 0;
			margin-bottom: 7px;
		}

	#shops .topline .maptitle {
		margin-right: 0;
		width: 100%;
		padding: 0 20px;
		box-sizing: border-box;
		margin-top: 20px;
		font-size: 15px;
		line-height: 1.4;
	}

	#header {
		display: none;
	}

	#headermobile {
		display: block;
	}

		#headermobile img {
			width: 100%;
		}

	#startpage h1,
	#shops .topline,
	#article h1 {
		margin-top: 10px;
	}

}

/* Mobile M */
@media only screen and (max-width : 375px) {

	.footerpart {
		width: 100%!important;
		padding: 10px 0px;
		-webkit-transition: 0.3s;
		-moz-transition: 0.3s;
		-o-transition: 0.3s;
		transition: 0.3s;
	}
}

/* Mobile S */
@media only screen and (max-width : 320px) {

}



@media only screen and (min-width : 800px) {
	#menu {
			display: none;
				}
				}









