/* CSS Reset by Eric Meyer   
   http://meyerweb.com/eric/tools/css/reset/ 
   v2.0 | 20110126
   License: none (public domain)
*/

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed, 
figure, figcaption, footer, header, hgroup, 
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;
}

  


/* Tell the browser to render HTML 5 elements as block */  

header, footer, aside, nav, section, article 
{  
    display: block;  
}




/* Font Includes */

@font-face {
	font-family: WebCenturySchoolbook;
	src: local("CenturySchoolbook"), url(/css/fonts/schlbk.ttf);
}




/* BODY definitions */  

body 
{
    margin: auto;  
    font: 14px/22px WebCenturySchoolbook, Times New Roman, Times, Serif; 
    color: #444444; 
    _background: #e6e6e6;
	background: url(/img/general/bg_body.jpg) #e6e6e6 center top repeat-x; 
	background-attachment: fixed;
}




/* Font and Pics definitions */

h1.companyname { display: inline; }
h2.title1 { font-size: 30px; color: #444444; margin-bottom: 11px; }
h2.title2 { font-size: 30px; color: #7c7c7c; font-style: italic; margin-bottom: 30px; margin-left: 60px; }
h2.subtitle { font-size: 17px; color: #194aaf; margin-bottom: 20px; }

.bold { font-weight: bold; }
.italic { font-style: italic; }
.small { font-size: 11px; }
.blue { color: #194aaf; }
.red   { color: #BB0000; }

.para { padding-bottom: 12px; }
.intertitle { font-size: 17px; color: #194aaf; padding-bottom: 12px; }

.blind { display: none; visibility: hidden; }

.pic_normal { border: 1px solid #444444; }
.pic_right { float: right; margin-left: 12px; border: 1px solid #444444; }
.pic_left   { float: left; margin-right: 12px; border: 1px solid #444444; }
.pic_paraicon { float: left; margin-right: 12px; margin-top: 6px; }

.feldstyle { border: 1px solid #bbbbbb; }
.butstyle { color: #272727; }

.marg_b_12	{ margin-bottom: 12px; }
.marg_b_30	{ margin-bottom: 30px; }

.material-icons 			{ text-rendering: optimizeLegibility; }
.material-icons.md-28 	{ font-size: 28px; }
.material-icons.md-blue 	{ color: rgb(25, 74, 175); }
.material-icons.md-big-link 	{ position: relative; top: 6px; }

a.cc-link, a.cc-link:link, a.cc-link:visited { color: #31a8f0 !important; }




/* Hyperlink Settings for NORMAL links in texts */

a:link,
a:visited,
a:active
{
	color: #153c8e;
	text-decoration: none;
}

a:hover
{
	color: #198ce5;
	text-decoration: underline;
}



/* Hyperlink Settings for SPECIAL links in texts */

a.verweis:link,
a.verweis:visited,
a.verweis:active
{
	color: #153c8e;
	text-decoration: none;
}

a.verweis:hover
{
	color: #198ce5;
	text-decoration: underline;
}

a.verweis:before { content:"\203A \0020"; }





/* ---- Wrapper and Page Container Definitions ---- */

div#wrapper
{
	margin: auto;  
	width: 100%;
	_background: url(/img/general/bg_body.jpg) top repeat-x; 
}

div#main
{
	margin: auto;  
	width: 900px;
	background: #ffffff;  
	-webkit-box-shadow:	1px 0px 10px 0px #ccc, -1px 0px 10px 0px #ccc;
	-moz-box-shadow: 	1px 0px 10px 0px #ccc, -1px 0px 10px 0px #ccc;
	box-shadow:		1px 0px 10px 0px #999, -1px 0px 10px 0px #999;
}




/* HEADER definitions */

header
{
	margin: auto; 
	width: 790px;
}

header .left
{
	margin-top: 44px;
	text-align: left;
}

header .right
{
	float: right;
	text-align: right;
	margin-top: 16px;
	padding-top: 53px;
	font-family: WebCenturySchoolbook, Times New Roman, Times, Serif;
	font-size: 18px;
	color: #444444;
}




/* NAV definitions */

nav
{
	margin: auto;  
	margin-top: 25px;
	width: 810px;
	text-align: center;
}

nav .shadow
{
	background: url(/img/general/splash_shadow.png) top center no-repeat;
}

nav .splash
{
	margin: auto;  
	width: 790px;
}

nav .buttons 
{
	margin: auto;
	margin-top: -7px;
	width: 790px;
	height: 43px; 
	background: url(/img/general/bg_mainmenu.png) top center no-repeat;
}

nav .buttons .sentence
{
	font-size: 18px; 
	font-style: italic; 
	color: #f0f0f0; 
	padding-top: 11px;
}

nav .menu_pipe
{
	float: left;
	width: 2px;
	height: 43px;
	background: url(/img/general/menu_pipe.png) no-repeat;
}

nav a.unternehmen:link,
nav a.unternehmen:visited,
nav a.unternehmen:active
{
	float: left;
	text-indent:-3000px;
	width: 148px;
	height: 43px;
	background: url(/img/general/menu_sprite_normal.png) no-repeat 0 0;
}

nav a.unternehmen:hover
{
	float: left;
	text-indent:-3000px;
	width: 148px;
	height: 43px;
	background: url(/img/general/menu_sprite_hover.png) no-repeat 0 0;
}

nav a.unternehmen_aktiv
{
	float: left;
	text-indent:-3000px;
	width: 148px;
	height: 43px;
	background: url(/img/general/menu_sprite_hover.png) no-repeat 0 0;
}

nav a.leistungen:link,
nav a.leistungen:visited,
nav a.leistungen:active
{
	float: left;
	text-indent:-3000px;
	width: 125px;
	height: 43px;
	background: url(/img/general/menu_sprite_normal.png) no-repeat -150px 0;
}

nav a.leistungen:hover
{
	float: left;
	text-indent:-3000px;
	width: 125px;
	height: 43px;
	background: url(/img/general/menu_sprite_hover.png) no-repeat -150px 0;
}

nav a.leistungen_aktiv
{
	float: left;
	text-indent:-3000px;
	width: 125px;
	height: 43px;
	background: url(/img/general/menu_sprite_hover.png) no-repeat -150px 0;
}

nav a.service:link,
nav a.service:visited,
nav a.service:active
{
	float: left;
	text-indent:-3000px;
	width: 104px;
	height: 43px;
	background: url(/img/general/menu_sprite_normal.png) no-repeat -277px 0;
}

nav a.service:hover
{
	float: left;
	text-indent:-3000px;
	width: 104px;
	height: 43px;
	background: url(/img/general/menu_sprite_hover.png) no-repeat -277px 0;
}

nav a.service_aktiv
{
	float: left;
	text-indent:-3000px;
	width: 104px;
	height: 43px;
	background: url(/img/general/menu_sprite_hover.png) no-repeat -277px 0;
}

nav a.referenzen:link,
nav a.referenzen:visited,
nav a.referenzen:active
{
	float: left;
	text-indent:-3000px;
	width: 130px;
	height: 43px;
	background: url(/img/general/menu_sprite_normal.png) no-repeat -383px 0;
}

nav a.referenzen:hover
{
	float: left;
	text-indent:-3000px;
	width: 130px;
	height: 43px;
	background: url(/img/general/menu_sprite_hover.png) no-repeat -383px 0;
}

nav a.referenzen_aktiv
{
	float: left;
	text-indent:-3000px;
	width: 130px;
	height: 43px;
	background: url(/img/general/menu_sprite_hover.png) no-repeat -383px 0;
}

nav a.check:link,
nav a.check:visited,
nav a.check:active
{
	float: left;
	text-indent:-3000px;
	width: 149px;
	height: 43px;
	background: url(/img/general/menu_sprite_normal.png) no-repeat -515px 0;
}

nav a.check:hover
{
	float: left;
	text-indent:-3000px;
	width: 149px;
	height: 43px;
	background: url(/img/general/menu_sprite_hover.png) no-repeat -515px 0;
}

nav a.check_aktiv
{
	float: left;
	text-indent:-3000px;
	width: 149px;
	height: 43px;
	background: url(/img/general/menu_sprite_hover.png) no-repeat -515px 0;
}

nav a.kontakt:link,
nav a.kontakt:visited,
nav a.kontakt:active
{
	float: left;
	text-indent:-3000px;
	width: 124px;
	height: 43px;
	background: url(/img/general/menu_sprite_normal.png) no-repeat -666px 0;
}

nav a.kontakt:hover
{
	float: left;
	text-indent:-3000px;
	width: 124px;
	height: 43px;
	background: url(/img/general/menu_sprite_hover.png) no-repeat -666px 0;
}

nav a.kontakt_aktiv
{
	float: left;
	text-indent:-3000px;
	width: 124px;
	height: 43px;
	background: url(/img/general/menu_sprite_hover.png) no-repeat -666px 0;
}




/* --- submenus --- */

nav .submenu1
{
	position: absolute;
	z-index: 100;
	margin: auto;
	margin-left: 27px;
	top: 334px;
	width: 119px;
	background: #afc8f0;
	-moz-border-radius: 0px 0px 5px 5px;
	-webkit-border-radius: 0px 0px 5px 5px;
	border-radius: 0px 0px 5px 5px;
	text-align: left;
	padding-left: 5px; 
	padding-top: 3px;
	padding-bottom: 5px;
	behavior: url(/css/PIE.htc);
}

nav .submenu2
{
	position: absolute;
	z-index: 100;
	margin: auto;
	margin-left: 166px;
	top: 334px;
	width: 111px;
	background: #afc8f0;
	-moz-border-radius: 0px 0px 5px 5px;
	-webkit-border-radius: 0px 0px 5px 5px;
	border-radius: 0px 0px 5px 5px;
	text-align: left;
	padding-left: 5px; 
	padding-top: 3px;
	padding-bottom: 5px;
	behavior: url(/css/PIE.htc);
}

nav .submenu3
{
	position: absolute;
	z-index: 100;
	margin: auto;
	margin-left: 299px;
	top: 334px;
	width: 80px;
	background: #afc8f0;
	-moz-border-radius: 0px 0px 5px 5px;
	-webkit-border-radius: 0px 0px 5px 5px;
	border-radius: 0px 0px 5px 5px;
	text-align: left;
	padding-left: 5px; 
	padding-top: 3px;
	padding-bottom: 5px;
	behavior: url(/css/PIE.htc);
}



/* --- submenu items --- */

nav a.submenu:link,
nav a.submenu:visited,
nav a.submenu:active
{
	font-family: WebCenturySchoolbook, Times New Roman, Times, Serif;
	font-size: 13px;
	text-decoration: none;
	color: #153c8e;
	min-width: 110px;
}

nav a.submenu:hover
{
	color: #198ce5;
}




/* SECTION definitions (content area) */

section
{
	margin: auto;  
	margin-top: 70px;
	margin-bottom: 70px;
	width: 790px;
}

section .leftrow
{
	float: left;
	margin: auto;  
	width: 200px;
}

section .rightrow
{
	float: right;
	margin: auto;  
	width: 550px;
}



/* ASIDE definitions (boxes on left wing) */

aside
{
	width: 200px;
	margin-bottom: 30px;
	behavior: url(/css/PIE.htc);
}

aside .icon
{
	float: left;
	vertical-align: text-top;
	margin-right: 8px;
}

aside .header
{
	position: relative;
	width: 170px;
	height: 24px;
	padding: 5px 15px;
	-moz-border-radius: 5px 5px 0px 0px;
	-webkit-border-radius: 5px 5px 0px 0px;
	border-radius: 5px 5px 0px 0px;
	background: #4476da;
	background: -webkit-gradient(linear, 0 0, 0 bottom, from(#5182e5), to(#285bc1));
	background: -webkit-linear-gradient(#5182e5, #285bc1);
	background: -moz-linear-gradient(#5182e5, #285bc1);
	background: -ms-linear-gradient(#5182e5, #285bc1);
	background: -o-linear-gradient(#5182e5, #285bc1);
	background: linear-gradient(#5182e5, #285bc1);
	-pie-background: linear-gradient(#5182e5, #285bc1);
	behavior: url(/css/PIE.htc);

	font-family: WebCenturySchoolbook, Times New Roman, Times, Serif;
	font-size: 14px;
	color: #F0F0F0;
	
	z-index: 50;
}

aside .content
{
	position: relative;
	width: 170px;
	padding: 5px 15px;
	-moz-border-radius: 0px 0px 5px 5px;
	-webkit-border-radius: 0px 0px 5px 5px;
	border-radius: 0px 0px 5px 5px;
	background: #e5e5e5;
	behavior: url(/css/PIE.htc);

	z-index: 50;
}

aside .icon_email
{
	margin-right: 4px;
}

aside a.boxnavi:link,
aside a.boxnavi:visited,
aside a.boxnavi:active
{
	text-decoration: none;
	color: #153c8e;
}

aside a.boxnavi:hover
{
	color: #198ce5;
}

aside a.boxnavi:before { content:"\203A \0020"; }






/* ARTICLE definitions (contents on right wing) */

article
{
}

	article ul 
	{
		list-style: disc outside;
		padding-left: 15px;
	}
	
	article a:link,
	article a:visited,
	article a:active
	{
		color: #006600;
		text-decoration: none;
	}

	article a:hover
	{
		color: #00aa00;
		text-decoration: underline;
	}
	
	
	article a.gross_blau:link,
	article a.gross_blau:visited,
	article a.gross_blau:active
	{
		font-size: 17px; 
		color: #194aaf;
		text-decoration: none;
	}

	article a.gross_blau:hover
	{
		font-size: 17px; 
		color: #194aaf;
		text-decoration: underline;
	}






/* FOOTER definitions */

footer
{
	clear: both;
	margin: auto;  
	_margin-top: 90px;
	width: 790px;
}

footer .top_left
{
	float: left;
	text-align: left;
	width: 270px;
}

	footer a.top:link,
	footer a.top:visited,
	footer a.top:active
	{
		float: left;
		text-indent:-3000px;
		width: 20px;
		height: 20px;
		background: url(/img/general/footer_top_normal.png) no-repeat 0 0;
		margin-top: 61px;
	}

	footer a.top:hover
	{
		float: left;
		text-indent:-3000px;
		width: 20px;
		height: 20px;
		background: url(/img/general/footer_top_hover.png) no-repeat 0 0;
		margin-top: 61px;
	}
	
	footer a.bookmark:link,
	footer a.bookmark:visited,
	footer a.bookmark:active
	{
		float: left;
		text-indent:-3000px;
		width: 20px;
		height: 20px;
		background: url(/img/general/footer_bookmark_normal.png) no-repeat 0 0;
		margin-top: 61px;
		margin-left: 8px;
	}

	footer a.bookmark:hover
	{
		float: left;
		text-indent:-3000px;
		width: 20px;
		height: 20px;
		background: url(/img/general/footer_bookmark_hover.png) no-repeat 0 0;
		margin-top: 61px;
		margin-left: 8px;
	}
	
	footer a.print:link,
	footer a.print:visited,
	footer a.print:active
	{
		float: left;
		text-indent:-3000px;
		width: 20px;
		height: 20px;
		background: url(/img/general/footer_print_normal.png) no-repeat 0 0;
		margin-top: 61px;
		margin-left: 8px;
	}

	footer a.print:hover
	{
		float: left;
		text-indent:-3000px;
		width: 20px;
		height: 20px;
		background: url(/img/general/footer_print_hover.png) no-repeat 0 0;
		margin-top: 61px;
		margin-left: 8px;
	}
	
	footer .bookmarks
	{	
		float: left;
		width: 150px;
		height: 20px;
		margin-top: 61px;
		margin-left: 8px;
	}
	


footer .top_right
{
	float: right;
	text-align: right;
	width: 520px;
}

	footer .logo_bvsi
	{
		float: right;
		text-align: right;
		width: 80px;
		height: 80px;
		margin-bottom: 5px;
	}

	footer .logo_we
	{
		float: right;
		text-align: right;
		width: 80px;
		height: 80px;
		margin-left: 45px;
		margin-bottom: 5px;
	}

	footer .logo_gi
	{
		float: right;
		text-align: right;
		width: 122px;
		height: 80px;
		margin-left: 33px;
		margin-bottom: 5px;
	}

	footer .logo_green
	{
		float: right;
		text-align: right;
		width: 54px;
		height: 80px;
		margin-left: 33px;
		margin-bottom: 5px;
		margin-right: 5px;
	}


footer .line
{
	float: left; 
	width: 790px;
}

footer .bottom_left
{
	float: left;
	text-align: left;
	width: 395px;
	padding-top: 0px;
}

	footer .tw
	{
		float: left;
		text-align: left;
		width: 110px;
		margin-top: 4px;
	}

	footer .gp
	{
		float: left;
		text-align: left;
		width: 80px;
		margin-top: 4px;
	}
	
	footer .fb
	{
		float: left;
		text-align: left;
		width: 100px;
		margin-top: 4px;
	}


footer .bottom_right
{
	float: right;
	text-align: right;
	width: 395px;
	padding-top: 0px;
	font-size: 14px;
}

	footer a.textlink:link,
	footer a.textlink:visited,
	footer a.textlink:active
	{
		color: #444444;
		text-decoration: none;
		margin-left: 0px;
	}

	footer a.textlink:hover
	{
		color: #444444;
		text-decoration: underline;
		margin-left: 0px;
	}


footer .copyright
{
	float: left; 
	text-align: center;
	width: 790px;
	margin-top: 40px;
	margin-bottom: 30px;

	font-family: WebCenturySchoolbook, Times New Roman, Times, Serif;
	font-size: 11px;
	color: #AAAAAA;
}



/* --- clearfix --- */

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


  



/* ---- Be nasty to Safari (special css definitions) ---- */

@media all 
{
	@import url(/css/style_sf.css);
}



/* ---- SUCKERFISH ----- */

ul { /* all lists */
	padding: 0;
	margin: 0;
	list-style: none;
}

li { /* all list items */
	float: left;
	position: relative;
	_width: 10em;
}

li ul { /* second-level lists */
	display: none;
	position: absolute;
	top: 0;
	left: 0;
	margin-top: 43px;
	/* my own settings */
	z-index: 100;
	width: 124px;
	margin-left: 17px;
	background: #afc8f0;
	-moz-border-radius: 0px 0px 5px 5px;
	-webkit-border-radius: 0px 0px 5px 5px;
	border-radius: 0px 0px 5px 5px;
	text-align: left;
	padding-left: 5px; 
	padding-top: 3px;
	padding-bottom: 5px;
	_behavior: url(/css/PIE.htc);
}

li ul.leistungen {
	margin-left: 6px;
	width: 230px;
}

li ul.services {
	margin-left: 11px;
	width: 185px;
}

li>ul { /* to override top and left in browsers other than IE, which will position to the top right of the containing li, rather than bottom left */
	top: auto;
	left: auto;
}

li:hover ul, li.over ul { /* lists nested under hovered list items */
	display: block;
}

