/* HINWEIS GOOGLE FONT

Ersetzen Sie den Google Fonts Code in der fe_page.html5 durch:

<link href="http://fonts.googleapis.com/css?family=Lato" rel="stylesheet" type="text/css"/>
<link href='http://fonts.googleapis.com/css?family=Lato&subset=latin,latin-ext' rel='stylesheet' type='text/css'>
Weitere Informationen zu Google Fonts finden Sie hier: https://developers.google.com/fonts/faq
*/

nav.mainmenu ul ul li a {
  text-transform: none;
  font-size: 12px;
  font-family: Lato;
}
body {
  font-size: 14px;
  font-family: Lato;
  font-weight: 300;
}
.logo {
  background-position: center center;
}

h1,h2,h3,h4,h5,h6 {
  font-family: Lato;
  font-weight: 300;
  color: #949494;
}
h1 {
  font-size: 40px;
}
h2 {
  font-size: 30px;
}
h3 {
  font-size: 24px;
}
h4 {
  font-size: 18px;
}
h5 {
  font-size: 14px;
}
h6 {
  font-size: 14px;
}
/* Ausnahme Home Boxen */
.home .imagebox_content {
	top: 0;
}
.home .imagebox_content h3 {
	color: #fff;
	font-size: 40px;
	line-height: 1.2em;
}
.home .imagebox_content p {
	color: #fff;
	font-size: 14px;
	line-height: 1.2em;
}
@media only screen and (max-width: 1460px) {
	.home .imagebox_content h3 {
		font-size: 28px;
	}
}
@media only screen and (max-width: 1024px) {
	.home .imagebox_content h3 {
		font-size: 14px;
	}
}
@media only screen and (max-width: 767px) {
	.home .imagebox_content h3 {
		font-size: 28px;
	}
}
@media only screen and (max-width: 400px) {
	.home .imagebox_content h3 {
		font-size: 22px;
	}
}
/* Ausnahme Home Boxen */

nav.mainmenu ul li a {
  font-family: Lato;
  font-size: 13px;
}


#header .mod_sprachwechsler {
	padding-right: 0;
	padding-left: 0;
	text-align: center;
}
.sprachwechsler span, .sprachwechsler a {color: rgba(255,255,255,0.9);}
.sprachwechsler .active {color: #e42322!important;}

#header .mod_sprachwechsler li:first-child {
	padding-left: 11px;
}
nav.mainmenu a,
#header .mod_sprachwechsler li a,
.socials a:before,
#header .contentbox, 
#header .contentbox a {
	color: rgba(255,255,255,0.9);
}
#header .mod_sprachwechsler li {
	border-color: rgba(255,255,255,0.3);
}
nav.mainmenu .level_2 a:hover, nav.mainmenu .level_2 a.active, nav.mainmenu .level_2 a.trail {
	color: rgba(255,255,255,0.6);
}
.menu-btn-inside .line, .menu-btn-inside .line:before, .menu-btn-inside .line:after {
	background: rgba(255,255,255,0.9);
}
#header .contentbox {
	text-align: center;
	padding: 0;
}
#header .socials {
	padding-left: 0;
	padding-right: 0;
	text-align: center;
}


/* Eigene Styles */


.portfolioliste .frontside .image_container img {
	width: 100%;
	height: auto;
}

#portfolio_306, #portfolio_307, #portfolio_353, #portfolio_355 {
	width:calc(100% - 10px);
	left: 5px;
	border: 1px solid #595959;
}

.filterholder {
	height: 5px;	
}

#portfolio_95 .pagination {
	position: absolute;
	bottom: -20px;
	z-index: 10;
}
/* */
.filterholder .block{
	overflow: visible;
}

.filterholder {
	height: 4px;
}

#blogfilter .filterholder {
	height: 0px;
}

.portfolio_wrapper {
	padding: 5px 5px 5px 6px;
}

/*
#und-fuer-wen div {
	top: 0px!important;
}

#und-fuer-wen div:nth-child(n+4) {
	top: -10px!important;
	border: 1px solid red;
}
*/

#infscr-loading {
    z-index: 100;
    position: absolute;
    bottom: 40px;
    left: 250px
}

#piwikframe {
		height: 215px;
	}
@media only screen and (max-width: 1100px) {
	#piwikframe {
		height: 120px;
	}
}
@media only screen and (max-width: 767px) {
	#piwikframe {
		height: 240px;
	}
}



.filter span  {
	background: #e42322;
	color: #fff;
}
.filter ul  {
	background: #eee;
	min-width: 165px;
}


.ce_text .filter li a {
	color: #949494!important;
	font-weight: 300!important;
}
.ce_text .filter li a:hover {
	text-decoration: none!important;
	color: #fff!important;
	font-weight: 300!important;	
}
.nachrichtenliste a {
	color: #e42322!important;
	font-weight: 300;
}
.nachrichtenliste .title a {
	color: #949494!important;
	font-weight: 300;
}

#reset {
	padding:10px 0px 10px 18px !important;
}

.filter .mod_newscategories li:first-child{margin-left: -20px!important; font-weight: 700!important;}

.weiterlesen {margin-top: 15px;}
.weiterlesen a, .teaser a {font-weight: 700;}
.weiterlesen a:hover, .teaser a:hover {text-decoration: underline;}

.mod_newsreader .back {
	display: block;
  position: relative;
	left: 10px;
	bottom: 42px;
}

.mod_newsreader .back a {
	color: #fff;
}

strong {font-weight: 700;}


.portfolioliste {
	border: 5px solid #595959;
}

#rechtsgebiete .portfolioliste, #rechtsgebiete-en .portfolioliste {
	border: 5px solid #f2f2f2;
}

.darksite:not(li):not(.sibling) {background-color: #595959;}
.mod_navigation .darksite {background-color: #303030!important;}

.teambox_content .beschreibung ul li {
	margin-left: 15px;
	list-style: disc;
}
.teambox .teambox_sublinks {
	margin-top: 10px;
}

.teambox .teambox_sublinks a, .servicebox .iconbox_content a {
	color: #e42322!important;
	-webkit-transition: All 0.3s ease;
	-moz-transition: All 0.3s ease;
	-o-transition: All 0.3s ease;
	-ms-transition: All 0.3s ease;
	transition: All 0.3s ease;
	font-weight: 700;	
}


.teambox .teambox_sublinks a:hover, .servicebox .iconbox_content a:hover {
	text-decoration: underline;
}

.servicebox {
	font-size: 14px;
	font-family: Lato;
	font-weight: 300;
}
.servicebox a {
	margin-top: 0px;
}

.servicebox .iconbox_content p {
	margin-bottom: 0px;
}


.nachrichtenliste .right_content {
    table-layout: fixed;
    width: 100%;
    max-width: 895px;
}

/*.pagination li, .pagination p {display: none;}*/

#header .mod_sprachwechsler {
	bottom: 250px;
}

#header .socials {
	bottom: 140px;
}

#header .contentbox {
	bottom: 55px;
}

.ce_text li, .ce_list li, .ce_textarea li, .ce_text ol, .ce_list ol, .ce_textarea ol {
	line-height: 22px;
}

.autogrid_wrapper .ce_text {
	margin-bottom: 0px!important;	
}


.newsletter {max-width: 650px;}




#main .ce_text a, .portfolioliste a {
	color: #e42322;
	font-weight: 700;
}
#main .ce_text a:hover, .portfolioliste a:hover {
	text-decoration: underline;	
}


.back_subline, .back_subline p {
	font-size: 14px;
	line-height: 16px;	
}
.portfolioliste .backside .back_title {
	font-size: 14px;
	line-height: 16px;
}

@media only screen and (max-width: 1220px) {
	.back_subline, .back_subline p {
		font-size: 13px;
		line-height: 15px;	
	}
	.back_subline a {
		font-size: 13px;
		line-height: 15px;	
	}
	#main .ce_text a, .portfolioliste a {
		font-size: 13px;
		line-height: 15px;
	}
}

@media only screen and (max-width: 1024px) {
	
	.portfolioliste.port_overlay .backside .content::after {display: none; height: 0px;}
	.back_subline {margin-top: 0px!important;}	
	.back_subline, .back_subline p {
		font-size: 13px;
		line-height: 15px;	
	}
	.back_subline a {
		font-size: 13px;
		line-height: 15px;	
	}
	#main .ce_text a, .portfolioliste a {
		font-size: 13px;
		line-height: 15px;
	}
}

@media only screen and (max-width: 890px) {
	
	.portfolioliste.port_overlay .backside .content::after {display: block; height: 1px; margin-bottom: 6px; margin-top: 6px;}
	.back_subline {margin-top: -4px!important;}	
	.back_subline, .back_subline p {
		font-size: 14px;
		line-height: 16px;	
	}
	.back_subline a {
		font-size: 14px;
		line-height: 16px;	
	}
	#main .ce_text a, .portfolioliste a {
		font-size: 14px;
		line-height: 16px;
	}
}

#rechtsgebiete .back_subline p, #portfolio_306 .back_subline p {margin-bottom: 0px;}

.portfolioliste .backside .back_title {
	margin-top: -2px;
}
.portfolioliste .backside {padding: 3px 10px 3px 10px;}

.portfolioliste.port_overlay .backside .content::after {
	margin-bottom: 6px;
}
.back_subline {margin-top: -4px;}



#bottom-copyright {
	line-height: 16px;	
}
@media only screen and (max-width: 767px), screen and (min-device-width : 768px) and (max-device-width : 1024px) and (orientation : portrait) {
	#header .contentbox {
		bottom: 55px;
		padding-bottom: 15px;
	}
}

.caroufredsel_gallery .image_container {margin-right: 10%;}

.caroufredsel_navi {
	font-size: 40px;
	font-weight: bold;
	color: #e42322;
}
.caroufredsel_prev {
	color: #e42322;
	position: absolute;
	left: 20px;
	margin-top: 12.5%;
}
.caroufredsel_next {
	color: #e42322;
	position: absolute;
	right: 5%;
	margin-top: 12.5%;
	z-index: 10000;
}

hr {
	background-color: #969696;
	height: 1px;
	width: 100%;
	border: medium none;
	margin-top: 20px;
	margin-bottom: 20px;
}

.beschreibung p {margin-bottom: 0px;}


@media only screen and (max-width: 1284px){
	.teambox h3 {
		font-size: 16px;
		letter-spacing: 1px;
	}
}
@media only screen and (max-width: 1230px){
	.teambox h3 {
		font-size: 15px;
		letter-spacing: 1px;
	}
}
@media only screen and (max-width: 768px){
	.teambox h3 {
		font-size: 16px;
		letter-spacing: 2px;
	}
}
@media only screen and (max-width: 1200px){
	#team .one_third, #team-en .one_third {width: 50%;}
}

@media only screen and (max-width: 980px){
	#team .one_third, #team-en .one_third {width: 100%;}
}

.nachrichtenliste .teaser p {margin-bottom: 0px;}

.beschreibung {font-size: 13px!important;}

/*.mod_navigation .vlist {margin-top: -20px;}*/
.logo{height: 190px;}

.ce_text .filter li a {
	color: #949494 !important;
	font-weight: 300 !important;
	display: inline-block;
	min-height: 32px;
	white-space: nowrap;
	width: 100%;
}
.filter li a {
	line-height: 1em;
	padding: 10px 6px 10px 6px;
}

#und-fuer-wen, #wir-koennen-nicht-alles, #we-cannot-do-everything, #and-for-whom {background-color: #595959;}

.filtersite-headline {
	margin: 10px 0 0 10px;
	color: #fff;
	position: relative;
	z-index: 1000;	
}

.back_subline p {margin-bottom: 0px;}



/* Kontakt Bild Statt Maps */
#kontakt-bild  .load-item {
	display: none !important;
}

#kontakt-bild {
	background-image: url('/files/images/kontakt_anstatt-map_1600x1324.jpg'); 
	margin: auto;
	background-repeat: no-repeat;
	background-size: cover;
	background-position: calc(50% + 50px) center;
	background-color: #fff;
}

@media only screen and (min-width: 769px){
	#kontakt-bild {
		left: 540px;
		right: 0;
		top: 0;
		bottom: 0;
		z-index: -1;
		position: fixed;
	}
}
@media only screen and (max-width: 768px){
	#kontakt-bild {
		height: 440px;
		background-position: 50% center;
	}
}

/* Cookiebar */
#cookiebar {
	text-align: left!important;
	z-index: 10001!important;
	font-size: 14px!important;
	line-height: 18px!important;
	background-color: #dedede!important;
}
#cookiebar-desc {
	padding: 15px 110px 15px 15px!important;
}
#cookiebar-desc, #cookiebar-desc a {
	color: #000!important;
}
#cookiebar button {
	height: 34px!important;
	padding: 2px 14px!important;
	margin: 0!important;
	border: none!important;
	background-color: #e42322!important;
	color: #fff;
	cursor: pointer!important;
	font-weight: 700!important;
	line-height: 18px!important;   
	position: absolute!important;
	right: 15px!important;
	top: calc(50% - 18px)!important;
}