html, body { width: 100%; height: 100%; position: relative; -webkit-overflow-scrolling: touch; -ms-text-size-adjust: 100%; -webkit-text-size-adjust: 100%; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
body { background: #2b5da8; font-family: 'Source Sans Pro', sans-serif; color: #333; font-size: 100.01%; font-weight: 400; line-height: 1.3; }
html.open, .open body { overflow-x: hidden; }

*, *::before, *::after { -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; padding: 0; margin: 0; }
a { color: #2b5da8; text-decoration: underline; font-weight: 700; }
a:hover { color: #2daae1; text-decoration: none; }

img, iframe { border: none; }
a:focus, button:focus { outline: none; }
a[href^=tel] { color: inherit; text-decoration: none; }

.clear { clear: both; height: 0; }
.clearfix::after, .widthFix::after { display: block; content: ""; height: 0; clear: both; visibility: hidden; }

h1, h2, h3, h4, p, table { margin: 0 0 10px 0; }
h1 { font-size: 28px; font-weight: 400; color: #2b5da8; line-height: 120%; }
h2 { font-size: 21px; font-weight: 400; color: #2b5da8; padding-top: 20px; }
h3 { font-size: 16px; font-weight: 700; color: #2b5da8; border-bottom: 1px dotted #333; padding-top: 15px; margin: 0 0 5px 0; clear: both; }
h1 + h2 { padding: 0; }


#container, #header, #columnRight, #content, #content .inner, #sidebar, #footer { width: 100%; position: relative; z-index: 1; overflow: hidden; }
.widthFix { max-width: 1360px; margin: 0 auto; }
#logo img, #emotion img, #blog img { display: block; width: 100%; height: auto; }
#mainNav ul, #footerNav ul { list-style-type: none; margin: 0; padding: 0; }
#mainNav a, #footerNav a { font-weight: 400; text-decoration: none; }
#logoDesktop, .visible-desktop, .hidden { display: none; }
.visible-mobile { display: block; }

#container { min-height: 100%; }

#header { background: #fff; box-shadow: 0 0 3px 1px rgba(0,0,0,.1); z-index: 100; }
	#header .widthFix { position: relative; }
		#logo { width: 220px; padding: 10px 15px; }

#main { background: #e9e9e9; width: 100%; }
#columnleft { background: #2b5da8; position: absolute; left: -80%; width: 80%; top: 0; height: 100%; overflow-x: hidden; overflow-y: auto; z-index: 100; }
.container.active #columnleft { left: 0; }

/* Navigation */
#mainNav { padding: 64px 0 60px 0; }
#mainNav ul { border-bottom: 1px solid #1e4175; box-shadow: inset 0 -1px 0 0 #4f82cf; padding-bottom: 1px; }
	#mainNav ul li { display: block; position: relative; }
		#mainNav ul li a { display: block; font-size: 17px; line-height: 48px; color: #fff; padding: 0 50px 0 15px; border-top: 1px solid #4f82cf; box-shadow: inset 0 1px 0 0 #094e24; }
			#mainNav ul li a:hover, #mainNav ul li.active > a, #mainNav ul li.current > a { background: rgba(0,0,0,.3); }
			#mainNav ul li.current + li a { box-shadow: none; }
/* Menü-Icons 
#mainNav ul li.parent span.menu-icon { display: block; background: transparent; width: 47px; height: 47px; font-size: 28px; line-height: 47px; color: #fff; position: absolute; top: 2px; right: 0; cursor: pointer; text-align: center; }
	#mainNav ul li.parent span.menu-icon::before { content: '\f107'; }
	#mainNav ul li.parent.open > span.menu-icon::before, #mainNav ul li.parent.active > span.menu-icon::before { content: '\f106'; } */
/* Zweite Ebene */
#mainNav ul.nav-child:last-child { border: none; box-shadow: none; }
/*  #mainNav ul.nav-child { display: block; width: 100%; max-height: 0; margin: 0; padding: 0; position: relative; border: none; box-shadow: none; overflow: hidden; }
	  #mainNav ul li.open > ul.nav-child, #mainNav ul li.active > ul.nav-child { max-height: 500px; padding: 0 0 7px 0; }
		#mainNav ul.nav-child li a { color: #fff; font-size: 16px; line-height: 130%; padding: 8px 15px 8px 25px; margin-top: 1px; border: none; box-shadow: none; }
		#mainNav ul.nav-child li.parent a { padding-right: 50px; } */

#content { padding: 20px 15px; }
#blog, #sidebar { padding: 0 15px 20px 15px; }

#footer { background: #2b5da8; color: #fff; padding: 25px 0; }
	#footerNav { width: auto; display: table; margin: 0 auto; }
		#footerNav ul li a { display: block; width: 150px; background: rgba(0,0,0,.25); font-size: 16px; line-height: 40px; text-align: center; color: #fff; margin: 0 0 10px 0; }
			#footerNav a:hover, #footerNav li.current a { background: rgba(0,0,0,.6); color: #fff; }
	#footer .copyright { width: 100%; color: #fff; font-size: 14px; font-weight: 700; text-align: center; padding-top: 20px; }
		#footer .copyright a { display: block; font-size: 12px; color: rgba(255,255,255,.6); text-decoration: none; }
			#footer .copyright a:hover { color: #fff; }

/* BOX + BLOG + CATALOGER ÜBERSICHT */
#blog .box { display: block; float: left; background: #fff; width: 100%; margin-bottom: 20px; text-decoration: none; border: 1px solid #ddd; position: relative; overflow: hidden; }
	#blog .box img { -moz-transform: scale(1.1); -webkit-transform: scale(1.1); -o-transform: scale(1.1); -ms-transform: scale(1.1); transform: scale(1.1); position: relative; z-index: 1; }
		#blog .box:hover img { -moz-transform: scale(1); -webkit-transform: scale(1); -o-transform: scale(1); -ms-transform: scale(1); transform: scale(1); }
	#blog .box .text { background: rgba(255,255,255,.8); width: 100%; padding: 10px 15px; position: absolute; left: 0; bottom: 0; z-index: 10; }
		#blog .box:hover .text { background: rgba(255,255,255,1); }
	#blog .box h2 { font-size: 20px; padding: 0; margin: 0; }

#sidebar .box { display: block; background: #fff; width: 100%; font-weight: 400; color: #333; text-decoration: none; padding: 15px 90px 15px 15px; margin-bottom: 30px; border: 1px solid #d7d7d7; position: relative; }
	#sidebar .box::before { content: '\f1c1'; display: block; width: 60px; height: 60px; line-height: 60px; font-size: 60px; color: #c00; position: absolute; top: 50%; right: 15px; margin-top: -30px; }
	#sidebar .box:hover { color: #2b5da8; }
	#sidebar .box h2 { font-size: 22px; padding: 0; margin: 0 0 5px 0; }	

/* LISTEN */
#content ul, #content ol { line-height: 130%; padding-left: 35px; margin: 0 0 25px 0; }
#content ul.noDot { list-style-type: none; padding: 0; margin: 0 0 25px 0; }
	#content li { padding: 3px 0; }
	#content .noDot li { padding: 0; }

/* Bilder */
#content .bildvoll { display: block; width: 100%; height: auto; margin: 0 0 20px 0; }
#content .bild3links { display: block; float: left; width: 33%; height: auto; margin: 0 20px 15px 0; }
#content .bild3rechts { display: block; float: right; width: 33%; height: auto; margin: 0 0 15px 20px; }

/* EFFEKTE */
#header, #logo, #columnleft, #footer, #footerNav a, .button, #blog .box *, #sidebar .box, #sidebar .box::before { -webkit-transition: all .4s ease-out; -moz-transition: all .4s ease-out; transition: all .4s ease-out; }
#mainNav ul li > a, #mainNav ul.nav-child { -webkit-transition: all .25s ease-out; -moz-transition: all .25s ease-out; transition: all .25s ease-out; }
#container::before { -webkit-transition: opacity .4s ease-out; -moz-transition: opacity .4s ease-out; transition: opacity .4s ease-out; }

/* Responsive Menu */
#toggleNavbar { display: block; width: 64px; height: 25px; padding: 0 15px; position: absolute; bottom: 50%; right: 0; z-index: 100; margin-bottom: -13px; }
#toggleNavbar .icon, #toggleNavbar .icon::before, #toggleNavbar .icon::after { background: #333; width: 24px; height: 3px; position: absolute; transition: 0.6s ease; transition-timing-function: cubic-bezier(.75, 0, .29, 1.01); }
#toggleNavbar .icon { top: 12px; left: 20px; }
#toggleNavbar .icon::before { content: ""; top: -7px; }
#toggleNavbar .icon::after { content: ""; top: 7px; }

/* on activation */
.active #toggleNavbar .icon { background: transparent; }
.active #toggleNavbar .icon::before { top: 0 !important; -moz-transform: rotate(45deg); -webkit-transform: rotate(45deg); -o-transform: rotate(45deg); -ms-transform: rotate(45deg); transform: rotate(45deg); }
.active #toggleNavbar .icon::after { top: 0 !important; -moz-transform: rotate(-225deg); -webkit-transform: rotate(-225deg); -o-transform: rotate(-225deg); -ms-transform: rotate(-225deg); transform: rotate(-225deg); }

/* BUTTONS */
.buttonCol { width: 100%; margin-top: 30px; }
	.buttonCol .button::before { content: '\f104'; padding-right: 10px; margin-left: -5px; }
.button { display: inline-block; background: #2b5da8; font-size: 18px; font-weight: 700; line-height: 38px; color: #fff; border: none; border-radius: 3px; margin: 0; padding: 0 30px; text-decoration: none; cursor: pointer; position: relative; overflow: hidden; }
	.button:hover { background: #2daae1; color: #fff; }

/* SITEMAP */
#content ul.sitemap { padding: 10px 0 0 0; list-style-type: none; }
	#content ul.sitemap ul { list-style-type: none; }
		#content ul.sitemap li { padding: 8px 0; }
			#content ul.sitemap li a { font-size: 20px; text-decoration: none; padding-left: 15px; position: relative; display: inline-block; }
			#content ul.sitemap li a:hover { text-decoration: underline; }
			#content ul.sitemap a::before { content: '\f105'; font-size: inherit; position: absolute; top: 0; left: 2px; }
			#content ul.sitemap a:hover::before { text-decoration: none; }
			#content ul.sitemap li p { font-size: 15px; margin: 0; padding: 2px 0 0 16px; }
				#content ul.sitemap ul { padding: 8px 0 8px 35px; margin: 0; border: none; }
					#content ul.sitemap ul li a { font-size: 17px; }

/* TABELLEN + LISTEN */
table { width: 100%; margin: 0 0 15px 0; font-size: 0.929em; }
table td, table th { background: #fff; padding: 6px 8px; text-align: left; vertical-align: top; }
table th { font-weight: 700; background: #2b5da8; color: #fff; }
	table th:nth-child(n+2), table td:nth-child(n+2) { text-align: right; }

#content ul, #content ol { line-height: 130%; padding-left: 35px; margin: 0 0 25px 0; }
	#content ul li { padding: 3px 0; }

/* MENÜ FADE OUT */
.open #header { background: #bbb; }
.open #logo { opacity: .4; }
#container::before { content:''; width: 0; height: 0; position: absolute; top: 0; left: 0; background: #000; z-index: 100; opacity: 0; }
	.open #container::before { width: 100%; height: 100%; opacity: .5; }

/* KONTAKTFORMULAR */
.contactform > div { margin-bottom: 15px; }
.contactform div.devider, .contactform div.advice { clear: both; padding-top: 10px; }
	label, input, select { display: inline-block; font-size: 1em; font-weight: 400; border: none; border-radius: 0; -webkit-appearance: none; -moz-appearance: none; appearance: none; }
	.contactform label, .contactform input { width: 80px; font-size: 17px; height: 32px; line-height: 32px; }
	.contactform input { width: 100%; font-size: 16px; padding-left: 10px; border: 1px solid #ddd; border-radius: 4px; }

	.contactform select { width: auto; height: 35px; font-size: 15px; padding: 6px 34px 7px 10px; margin-right: 1px; border: 1px solid #ddd; background-color: #fff; background-image: url(/gfx/arrow.png); background-position: right top; background-repeat: no-repeat; background-size: 33px auto; }
	.contactform select option { background: #fff; border: none; padding: 10px; }
	.contactform select option:hover, .contactform select option:checked { box-shadow: 0 0 10px 100px #2b5da8 inset; }
	.contactform select::-ms-expand { display: none; }

	.contactform textarea { width: 100%; height: 150px; font-family: 'Source Sans Pro', sans-serif; font-size: 16px; font-weight: 400; padding: 10px; border: 1px solid #ddd; }
	.contactform .submit { padding-top: 15px; }
	.contactform .submit .button { margin: 0 auto; }
	#content .error_message ul { background: #fff; list-style-type: none; color: #c00; padding: 10px 15px; margin: 0 0 20px 0; border: 3px solid #bb0000; }
	.contactform .small { display: block; color: #c00; font-size: 15px; line-height: 2; }

/* COOKIEBAR */
#cookie-bar { background: rgba(0,0,0,.8); font-size: 16px; line-height: 1.4; color: #fff; }
	#cookie-bar.fixed { width: 100%; position: fixed; top: 0; left: 0; }
		#cookie-bar.fixed.bottom { bottom: 0; top: auto; }
	#cookie-bar .widthFix { padding: 20px; }
		#cookie-bar .message span { margin-right: 15px; }
			#cookie-bar a { text-decoration: none; }
		#cookie-bar .button { display: block; float: right; font-size: 18px; margin-top: 15px; }


/* Landscape phone to portrait tablet 
---------------------------- */

@media screen and (min-width: 480px) {

#logo { width: 240px; padding: 15px 20px; }
#toggleNavbar { right: 5px; }

/* MENÜ */
#columnleft { left: -60%; width: 60%; }

#mainNav { padding-top: 76px; }
	#mainNav ul li a { padding-left: 20px; }
/* #mainNav ul.nav-child li a { padding-left: 30px; } */

#content { padding: 25px 20px; }
#blog, #sidebar { padding: 0 20px 25px 20px; }

/* COOKIEBAR */
#cookie-bar .widthFix { padding: 20px 175px 20px 20px; }
	#cookie-bar .button { position: absolute; top: 50%; right: 20px; margin-top: -18px; }

}


/* Blog Fix 
---------------------------- */

@media screen and (min-width: 540px) {

#blog .box { width: 48.5%; margin: 0 3% 3% 0; }
	#blog .box:nth-child(2n) { margin: 0 0 3% 0; }

}


/* Portrait tablet to landscape and desktop
------------------------------------- */

@media screen and (min-width: 768px) {

h1 { font-size: 34px; margin: 0 0 15px 0; }
h2 { font-size: 24px; }
h3 { font-size: 18px; }

.visible-mobile { display: none; }
.visible-desktop { display: block; }

/* MENÜ */
#columnleft { left: -40%; width: 40%; }

#logo { width: 260px; padding: 15px 25px; }
#toggleNavbar { right: 10px; }

#mainNav { padding-top: 78px; }

#content { padding: 30px 25px; }
#blog, #sidebar { padding: 0 25px 30px 25px; }
#sidebar .box h2 { font-size: 26px; }	

#footerNav ul li { float: left; }
#footerNav ul li a { width: auto; padding: 0 20px; margin: 0 5px 10px 5px; }

/* KONTAKTFORMULAR */
.contactform > div { margin-bottom: 25px; }
.contactform div.devider { padding-top: 0; margin-bottom: 15px; }
.contactform label, .contactform input { width: 100px; }
.contactform input { width: 400px; }
.contactform textarea { width: 720px; height: 320px; padding: 15px; }
.contactform .submit .button { margin: 0; }

}


/* desktop small
------------------------------------------- */

@media screen and (min-width: 992px) {

#logo { width: 280px; padding: 15px 35px; }
#toggleNavbar { right: 20px; }
#stickyFix { display: block; width: 1px; height: 1px; position: absolute; top: 0; left: 0; }

.fixed #header { position: fixed; top: 0; }
.fixed #logo { width: 220px; padding: 10px 35px; }
.fixed #main { padding-top: 55px; }

#columnleft { left: -400px; width: 400px; }

/* Navigation */
#mainNav ul li a { font-size: 18px; }
/* #mainNav ul.nav-child li a { font-size: 17px; } */

#content { padding: 30px 35px; }
#blog { padding: 0 30px 35px 30px; }

#content { width: 100%; float: left; margin: 0 -335px 0 0; }
	#content .inner { width: auto; margin-right: 350px; }
#sidebar { width: 335px; float: left; padding: 30px 35px 30px 0; }

/* BOX + BLOG + CATALOGER ÜBERSICHT */
#blog .box { width: 31.5%; margin: 0 2.75% 2.75% 0; }
	#blog .box:nth-child(2n) { margin: 0 2.75% 2.75% 0; }
	#blog .box:nth-child(3n) { margin: 0 0 2.75% 0; }

/* TABELLEN + LISTEN */
#content table { font-size: 1em; }
#content td, #content th { padding: 8px 12px; }

/* COOKIEBAR */
#cookie-bar { font-size: 18px; }
	#cookie-bar .widthFix { padding: 20px 185px 20px 30px; }
		#cookie-bar .button { right: 30px; }

}

	
/* desktop 
------------------------------------------- */

@media screen and (min-width: 1200px) {

body{ font-size: 18px; }
#logo { width: 290px; padding: 20px 40px; }
#toggleNavbar { right: 25px; }

#mainNav { padding-top: 88px; }
/* Navigation */
#mainNav ul li a { font-size: 20px; padding-left: 30px; }

/* Zweite Ebene */
/* #mainNav ul.nav-child li a { font-size: 18px; padding-left: 50px; } */
/* Menü-Icons Zweite Ebene */
/* #mainNav ul.level-1 li.parent span.menu-icon { height: 39px; line-height: 39px; } */

#content { padding: 40px; }
#emotion { padding: 40px 40px 0 40px; }
#blog { padding: 0 40px 40px 40px; }

#content { margin: 0 -380px 0 0;  }
	#content .inner { margin-right: 390px; }
#sidebar { width: 380px; padding: 40px 40px 40px 0; }

/* BOX + BLOG + CATALOGER ÜBERSICHT */
#blog .box .text { padding: 12px 15px; }
	#blog .box h2 { font-size: 21px; }

#footerNav ul li a { font-size: 18px; }
#footer .copyright { font-size: 16px; }
#footer .copyright a { font-size: 14px; }

/* COOKIEBAR */
#cookie-bar .widthFix { padding: 20px 195px 20px 40px; }
	#cookie-bar .button { right: 40px; }

}

/* source-sans-pro-regular - latin */
@font-face {
  font-family: 'Source Sans Pro';
  font-style: normal;
  font-weight: 400;
  src: local(''),
       url('../font/source-sans-pro-v21-latin-regular.woff2') format('woff2'), /* Chrome 26+, Opera 23+, Firefox 39+ */
       url('../font/source-sans-pro-v21-latin-regular.woff') format('woff'); /* Chrome 6+, Firefox 3.6+, IE 9+, Safari 5.1+ */
}

/* source-sans-pro-700 - latin */
@font-face {
  font-family: 'Source Sans Pro';
  font-style: normal;
  font-weight: 700;
  src: local(''),
       url('../font/source-sans-pro-v21-latin-700.woff2') format('woff2'), /* Chrome 26+, Opera 23+, Firefox 39+ */
       url('../font/source-sans-pro-v21-latin-700.woff') format('woff'); /* Chrome 6+, Firefox 3.6+, IE 9+, Safari 5.1+ */
}


@font-face {
  font-family: 'fontello';
  src: url('../font/fontello.eot?77576791');
  src: url('../font/fontello.eot?77576791#iefix') format('embedded-opentype'),
       url('../font/fontello.woff2?77576791') format('woff2'),
       url('../font/fontello.woff?77576791') format('woff'),
       url('../font/fontello.ttf?77576791') format('truetype'),
       url('../font/fontello.svg?77576791#fontello') format('svg');
  font-weight: normal;
  font-style: normal;
}
 
[class^="icon-"]:before, [class*=" icon-"]:before, #columnleft span.menu-icon::before, #sidebar .box::before, #content ul.sitemap a:before, .contactform select::after, .buttonCol .button::before { font-family: "fontello"; font-style: normal; font-weight: normal; font-variant: normal; text-transform: none; speak: none; display: inline-block; text-decoration: inherit; text-align: center; }

.icon-gplus-squared:before { content: '\f0d4'; } /* '' */
.icon-angle-left:before { content: '\f104'; } /* '' */
.icon-angle-right:before { content: '\f105'; } /* '' */
.icon-angle-up:before { content: '\f106'; } /* '' */
.icon-angle-down:before { content: '\f107'; } /* '' */
.icon-file-pdf:before { content: '\f1c1'; } /* '' */
.icon-facebook-squared:before { content: '\f308'; } /* '' */
