/************
    BASICS
*************/
html
{
    font-size:16px;
}
* {
    box-sizing: border-box;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    -ms-box-sizing: border-box;
}

body {
    font-family: Calibri, Candara, Segoe, "Segoe UI", Optima, Arial, sans-serif;
    font-size: 1em;
    font-weight: normal;
}

body:before {
  content: "";
  display: block;
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: -10;
  background: url(../images/bg-body.jpg) no-repeat center center;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -o-background-size: cover;
  background-size: cover;
}

a:focus {
    outline-style: none;

}

h1 {
    font-size: 3em;
    margin:0 0 15px 0;
    color:#443939;
    font-weight:normal;
}

h2 {
    font-weight: bold!important;
    font-size: 1.2em;
    margin-bottom:5px;
}

a {
    color: darkorange;
    text-decoration: none;
}

a:hover {
    text-decoration: none;
}

.print {
    display: none;
}

.shadow {
    width: 980px;
    margin: 0 auto;
    box-shadow:0 2px 10px #333333;
}

header, .content-body, footer, nav.topmenu {
    min-width: 980px;
}

/************
   HEADER
*************/

header {
    background: white;
    width: 60%;
    max-height: 12%;
    margin: 5% auto 0 auto;
}

header img {
    text-align: center;
    margin: auto 0;
    max-width: 100%;
}

/************
   TOPMENU
*************/

.topmenu {
    width: 60%;
    height: 50px;
    background-color: #372F2F;
    margin: 0 auto;
    border-bottom: 5px solid #FFA64D;
}

.topmenu ul{
    float: left;
    margin: 0;
    height: 50px;
    width: auto;
    padding-left:5px;
}

.topmenu li {
    float: left;
    list-style: none;
    margin: 0 15px 0 0;
}


.topmenu li a {
    color: white;
    line-height: 45px;
    font-size:19px;
    padding-left: 28px;
}

.topmenu li a:hover,
.topmenu li a.active {
    background: url(../images/hover-topmenu.png) no-repeat left center;

}



/************
   CONTENT
*************/

.bg-basic {
    min-width: 980px;
    background: white;
}

.content-body {
    background: url(../images/bg-content.jpg) no-repeat top left;
    background-size: cover;
    width: 60%;
    margin: 0 auto;
    overflow: hidden;
    position:relative;
    /*border: 1px solid white;*/
}

.leftmenu {
    width:24%;
    background: transparent;
    float: left;
    margin:6% 0 6% 0.5%;
    overflow: hidden;
}

.leftmenu ul {
    padding: 0;
    margin: 0;
}

.leftmenu li {

    list-style: none;
}

.leftmenu li a {
    color: #372F2F;
    padding-left: 11%;
    display: block;
}

.leftmenu li.level1 {
    font-size: 1.2em;
    font-weight: bold;
    margin-top: 15px;
    line-height: 1.2em;
}
.leftmenu li.level1:first-child
{
    margin-top:0;
}
.leftmenu li.level1 a:hover,
.leftmenu li.level1 a.active {
    color: black;
    background: url(../images/hover-topmenu.png) no-repeat left center;

}

.leftmenu li.level2 a:hover,
.leftmenu li.level2 a.active {
    color: #d47702;
    background: none;

}

.content {
    width:73%;
    min-height: 120%;
    background-color: transparent;
    float: right;
    margin: 6% 1% 6% 1%;
}

.content.home {
    width: 96%;
}

.box{
    width: 31.2%;
    height: 12.3em;
    background: grey;
    float: left;
    margin: 0 18px 10px 0;
    position: relative;
}

.box p {
    color: black;
    font-size: 130%;
    text-align: center;

}

.box .cattext{
    width: 100%;
    position: absolute;
    bottom: 0;
    height: 2.3em;
    background:white;
    opacity: 0.7;
    display: block;
    line-height: 2.3em;
    color: black;

    -moz-box-shadow:0px 0px 2px rgba(0,0,0,0.65);
    -webkit-box-shadow:0px 0px 2px rgba(0,0,0,0.65);
    box-shadow:0px 0px 2px rgba(0,0,0,0.65);
    -ms-filter:"progid:DXImageTransform.Microsoft.dropshadow(OffX=0,OffY=0,Color=#a6000000,Positive=true)";
    filter:progid:DXImageTransform.Microsoft.dropshadow(OffX=0,OffY=0,Color=#a6000000,Positive=true);
}

.box:hover .cattext{
    -moz-box-shadow:0px 0px 4px rgba(0,0,0,0.85);
    -webkit-box-shadow:0px 0px 4px rgba(0,0,0,0.85);
    box-shadow:0px 0px 4px rgba(0,0,0,0.85);
    -ms-filter:"progid:DXImageTransform.Microsoft.dropshadow(OffX=0,OffY=0,Color=#d9000000,Positive=true)";
    filter:progid:DXImageTransform.Microsoft.dropshadow(OffX=0,OffY=0,Color=#d9000000,Positive=true);

}

.box[title="last"] {
    margin-right: 0;
}

.cattext h1
{
    font-size:22px;
    text-align:center;
    color:black;
}
/* News */



.news {
    border-top: 1px solid #372f2f;
}

.news .readmore.collapsed .text {
    display: none;
}
.news .readmore .readmorelink {
    color: white;
    display: block;
    padding: 0 10px;
    text-decoration: none;
    margin-bottom: 20px;
    background: #372f2f;
    height: 30px;
    line-height: 30px;
}

.news .readmore.collapsed .readmorelink {
    background: #ffa64d url(../images/news-expander.png) no-repeat right+10px center;
}

.news .readmore.expanded .readmorelink {
    background: #ffa64d url(../images/news-collapser.png) no-repeat right+10px center;
}
.homenews ul.menu
{
    padding-left:0;
    list-style: none;
}
.homenews ul.menu li.title
{
    font-size:22px;
    color:black;
    font-weight:bold;
}
.homenews ul.menu li
{
    margin-bottom:10px;
}
.homenews ul.menu li p
{
    margin:0;
    color:black;
}
.homenews ul.menu li a:hover,
.homenews ul.menu li a:hover p
{
    text-decoration:underline;
}
/************
   FOOTER
*************/

footer {
    width: 980px;
    margin: 0 auto 7% auto;
}


.footermenu {
    width: 40%;
    float: right;
    background: transparent;
}

.footermenu ul {
    display: inline;
}

.footermenu li {
    float: right;
    list-style: none;
    line-height:14px;
}

.footermenu li a {
    color: white;
    font-size: 14px;
}

.copyright {
    color: #333333;
    font-size: 12px;
    max-width: 30%;
    margin-top: 1%;
}

.copyright a {
    color: #333333;
}

.copyright a:hover {
    text-decoration: underline;
}

/****************
* Fotogallerie
****************/
.fotogallery {
    position: relative;
    height: 120px;
    overflow: hidden;
    margin-top: 40px;
}

.fotogallery .images {
    position: absolute;
    top: 0;
    left: 57px;
    height: 120px;
    width: 600px;
    overflow: hidden;
}

.fotogallery .images .inner {
    position: absolute;
    overflow: hidden;
    left: 0;
    right: 0;
    width: 5000px;
}

.fotogallery .images a {
    display: block;
    width: 120px;
    height: 120px;
    float: left;
    margin: 0 15px;

    overflow: hidden;
    -moz-border-radius:6px;
    -webkit-border-radius:6px;
    border-radius:6px;
    -moz-box-shadow:0px 0px 3px rgba(0,0,0,0.35);
    -webkit-box-shadow:0px 0px 3px rgba(0,0,0,0.35);
    box-shadow:0px 0px 3px rgba(0,0,0,0.35);
    -ms-filter:"progid:DXImageTransform.Microsoft.Glow(Color=#ff000000,Strength=3)";
    filter:progid:DXImageTransform.Microsoft.Glow(Color=#ff000000,Strength=3);
}

.fotogallery a.forwards {
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    width: 40px;
    height: 120px;
    background: url(../fotogallery/images/photogallery-arrows.png) no-repeat right -130px;
}

.fotogallery a.backwards {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 40px;
    height: 120px;
    background: url(../fotogallery/images/photogallery-arrows.png) no-repeat left -130px;
}

.fotogallery a.forwards:hover {
    background-position: right top;
}

.fotogallery a.backwards:hover {
    background-position: left top;
}

.fotogallery a.forwards.disabled {
    background-position: right bottom;
}

.fotogallery a.backwards.disabled {
    background-position: left bottom;
}

.fotogallery .images a img {
    display: block;
}

/****************
* Kontaktformular
****************/

.html, button, input, select, textarea {
    font-family: "calibri";
}

form.kontakt{/* Formular */
	font-size: 12px;
	margin-top: 0px;
	margin-bottom:35px;
}

form.kontakt legend{
	font-size:14px; 
	font-weight:normal;
	color:#000000;
	font-style: italic;
	margin: 0px 10px;
}
form.kontakt fieldset{
	border:2px solid #cccccc;
	margin-bottom: 25px;
	padding-top: 0px;
}
form.kontakt label,
form.kontakt.kontaktformular label{
	padding: 4px 15px 4px 0px;
	text-align:left;
	font-size:14px;

}
form.kontakt table.formulartabelle label{
	padding: 4px 15px 4px 0px;
	text-align:left
}

table.formulartabelle{
margin: 0px 0px;
}
table.formulartabelle th,
table.formulartabelle td{
	text-align: left;
	padding-bottom:3px;
}
table.formulartabelle th{
	width: 250px;
	text-align: left;
    

}
table.formulartabelle td{
	vertical-align:middle;
	font-size:14px;
	height:20px;
	
}
label.beforeSelect{
	margin-right: 2px;
}
input.textfeld{
	width:250px;
	border: 1px solid #cccccc;
}
input.w50{
width: 50px;
}
textarea{
	width: 250px;
	height: 100px;
	border: 1px solid #cccccc;
}
input.textfeld:hover,
textarea:hover,
input.textfeld:focus,
textarea:focus
td.error input,
td.error textarea{
	background-color: #d8dee7;
	border-color: #cccccc;
}
input.checkbox{
	line-height:120%;
}
.checkbox{
	vertical-align: bottom;
	margin: 2px;
	height: 22px;
}
select.seletfeld{
	padding:1px;
	margin:2px 2px 2px 0px;
	border:1px solid #CCCCCC;
	height: 17px;
	float:left;
}

caption{
	text-align: left;
	font-weight: bold;
	margin-bottom:5px;
	padding: 0px 5px;
}
input.senden, input.zurueck{
	width:100px;
	text-align:center;
	cursor:pointer;
	border-width: 1px;
	border-style: solid;
	border-color: #003300;
	padding: 0px;
	margin: 0px;
}

#errMsg {
	color: #cc0000;
	margin: 3px;
	padding: 0;
}
.error { color: #cc0000 }

.klein
{
    font-size:11px!important;
    color:#666666;
    text-align:left;
}

/***************
   REFERENZEN
****************/

.reference{
    width: 300px;
    float: left;
    margin: 0 80px 20px 0;
}

.reference .text {
    text-align: center;
}

.reference .text h1 {

}

.reference .text h2 {
    margin-top: 5px;
    margin-bottom:5px;
}

.reference.last {
    margin-right: 0;
}
.reference img
{
    -moz-box-shadow:0px 0px 3px rgba(0,0,0,0.35);
    -webkit-box-shadow:0px 0px 3px rgba(0,0,0,0.35);
    box-shadow:0px 0px 3px rgba(0,0,0,0.35);
    -ms-filter:"progid:DXImageTransform.Microsoft.Glow(Color=#ff000000,Strength=3)";
    filter:progid:DXImageTransform.Microsoft.Glow(Color=#ff000000,Strength=3);
}

/* Team */

table.team td
{
    padding-bottom:5px;
    vertical-align:top;
    text-align:center;
    width:33.3333%
}
table.team.lehrlinge td
{
    padding-bottom:5px;
    vertical-align:top;
    text-align:center;
    width:50%
}
table.team td img
{
    -moz-box-shadow:0px 0px 3px rgba(0,0,0,0.35);
    -webkit-box-shadow:0px 0px 3px rgba(0,0,0,0.35);
    box-shadow:0px 0px 3px rgba(0,0,0,0.35);
    -ms-filter:"progid:DXImageTransform.Microsoft.Glow(Color=#ff000000,Strength=3)";
    filter:progid:DXImageTransform.Microsoft.Glow(Color=#ff000000,Strength=3);
}
table.team td p
{
    margin:0;
}
table.team td p+p
{
    margin-bottom:15px;
}

.linkbox
{
    width:33.3333%;
    float:left;
}







