@font-face {
	font-family: 'abelregular';
	src: url('../fonts/abel-regular-webfont.eot');
	src: url('../fonts/abel-regular-webfont.eot?#iefix') format('embedded-opentype'),
	url('../fonts/abel-regular-webfont.woff2') format('woff2'),
	url('../fonts/abel-regular-webfont.woff') format('woff'),
	url('../fonts/abel-regular-webfont.ttf') format('truetype'),
	url('../fonts/abel-regular-webfont.svg#abelregular') format('svg');
	font-weight: normal;
	font-style: normal;

}
h1 {
	font-size: 1.6em;
	font-family: "abelregular";
	font-weight: bold;
	letter-spacing: 0.01em;
	padding: 0px;
	margin: 0px;
}


h2 {
	font-size: 1.3em;
	
	font-family: "abelregular";
	color: #414141;
	text-align: left;
	letter-spacing: 0.01em;
	padding: 0px;
	margin-top: 0px;
}

h3 {
	font-size: 1em;
	font-family: "abelregular";
	font-weight: 400;
	text-align: left;
	letter-spacing: 0.08em;
	padding: 20px 0px 4px 0px;
	margin: 0px;
	font-weight: 600;
}
.ds h3{
	font-size: 1em;
	padding: 10px 0px;
	color: #F7A611;
}
h4 {
	font-size: 0.9em;
	font-weight: 300;
	font-family: "abelregular";
	letter-spacing: 0.08em;
}

h5 {
	font-size: 0.9em;
	font-weight: 300;
	font-family: "abelregular";
	color: #414141;
	padding: 0;
	margin: 0;
}
hr {
	height: 1px;
	background-color: rgb(255, 255, 255);
	width: 100%;
	border: none;
	margin-bottom: 20px;
}
p {
	letter-spacing: 0.04em;
	line-height: 1.4em;
	margin: 10px 0px 10px 0px;
	font-weight: 500;
	font-size: 1.05em;
	color: #414141;
}

p a {
	font-size: 0.92em;
}
strong{
	font-size: 1em;
	padding: 10px 0px;
	color: #F7A611;
}

ul li {
	list-style: none;
}

li {
	font-size: 1.1em;
	letter-spacing: 0.1em;
	line-height: 1.4em;
	margin: 1px 0px 1px 0px;
	font-weight: 500;
	font-size: 1.1em;
}
.list li:before{
	content: "- ";
	color: #F7A611;
}

/*-------------------------------------------base*/

body {
	box-sizing: border-box;
	font-family: "abelregular";
	font-weight: 100;
	margin: 0px;
	background-color: whitesmoke;
	display: block;
	height: 100%;
}
header {
	display:grid;
	grid-template-areas:  "branding nav";
	grid-template-columns: 1fr 2fr;
	position: fixed;
	top: 0px;
	height: 50px;
	font-size: 0.9em;
	background-color: #2b2b2b;
	width: 100%;
	z-index: 900;
	box-shadow: 0px 1px 1px rgba(68, 68, 68, 0.466);
}
#branding{
	background-image: url(../img/css/voltaikwerk.png);
	background-repeat: no-repeat;
	background-size: contain;
	background-position:top;
	-webkit-background-size: contain;
	-webkit-background-position: right top;
	height: 33px;
	z-index: 999;
	margin: 8px 10px 0px 10px;
	position: relative;
	left: 10px;
	width: 200px;
}

.headbanner
{
	position:fixed;
	height: 30%;
	width: 100%;
	z-index: -1;
	
}
.headbanner p{
	position: relative;
	top: 45%;
	color: white;
	font-size: 2em;
	font-weight: 700;
	display: block;
	text-align: center;
	text-shadow: 0.1em 0.1em 0.2em black;
}
.homeimg
{
	background-image: url(../img/head/home.jpg);
	background-repeat: no-repeat;
	background-size: cover;
	background-position:center center;
}
.solarmoduleimg
{
	background-image: url(../img/head/solarmodule.jpg);
	background-repeat: no-repeat;
	background-size: cover;
	background-position:center center;
}


.montagesystemeimg
{
	background-image: url(../img/head/montagesysteme.jpg);
	background-repeat: no-repeat;
	background-size: cover;
	background-position:center center;
}
.wechselrichterimg
{
	background-image: url(../img/head/wechselrichter.jpg);
	background-repeat: no-repeat;
	background-size: cover;
	background-position:center center;
}
.speichersystemeimg
{
	background-image: url(../img/head/speichermodule.jpg);
	background-repeat: no-repeat;
	background-size: cover;
	background-position:center center;
}
.referenzenimg
{
	background-image: url(../img/head/referenzen.jpg);
	background-repeat: no-repeat;
	background-size: cover;
	background-position:center center;
}

.downloadsimg
{
	background-image: url(../img/head/downloads.jpg);
	background-repeat: no-repeat;
	background-size: cover;
	background-position:center center;
}
.kontaktimg
{
	background-image: url(../img/head/kontakt.jpg);
	background-repeat: no-repeat;
	background-size: cover;
	background-position:center center;
}
.dsgvoimg
{
	background-image: url(../img/head/dsgvo.jpg);
	background-repeat: no-repeat;
	background-size: cover;
	background-position:center center;
}
.impressumimg
{
	background-image: url(../img/head/impressum.jpg);
	background-repeat: no-repeat;
	background-size: cover;
	background-position:center center;
}
.nocookies{
font-size: small;
position: absolute;
top: 0px;	
right: 0px;
background-color: #c9c9c9;
padding: 0px 4px ;
z-index: 5;
}

.urheber{
	position: absolute;
	text-decoration: none;
	display: flex;
	gap: 10px;
	top: atuo;
	bottom: 0px;
	width: auto;
	background-color: #ffffff82;
	padding: 0px 15px;
	line-height: 0.8em;

}


.urheber cite, .urheber cite p{
	padding: 0px;
	margin: 2px 0px;
	font-size: small;
	text-shadow: none;
	text-decoration: none;
	font-weight: 100;
	top: 0px;
	display: flex;
	position: relative;
	color:#000000;
}
.urheber:hover > a.tooltip {
	display: flex;
}
a.tooltip:hover{
	color: #8e3817;
	font-style: italic;
}

a.tooltip {
	text-decoration: none;
	color: #000000;
	margin-top: 7px;
	display: none;
	font-size: small;
	position: relative;

  }

  a.tooltip::before {
	content: "";
	-webkit-transition: all 0.4s ease;
	-moz-transition : all 0.4s ease;
	transition : all 0.4s ease;
	opacity: 0;
  }

  a.tooltip::after {
	content: attr(data-tooltip);
	/*HGFarbe eingebl. Name*/
	-webkit-border-radius: 10px;
	-moz-border-radius : 10px;
	border-radius : 2px;
	opacity: 0;
	z-index: 4;
	-webkit-transition: all 0.4s ease;
	-moz-transition : all 0.4s ease;
	transition : all 0.4s ease;
	font-size: smaller;
	position: relative;
	left: 6px;
	padding-right: 6px;
  }
 
  a.tooltip:hover::after, a:hover:before {
	display: inline;
	opacity: 1;
	position: relative;
	left:10px;
	font-size: small;

  }

main 
{
	top: 30%;
	margin:0 auto;
	font-family: "abelregular";
	color: #414141;
	width: 100%;
	background-color: whitesmoke;
	position: absolute;
	z-index: 1;
}


main a {
	color: #917644;
	text-decoration: none;
}
main a:hover {
	color: #F7A611;
}



main section {
	width: auto;
	padding-top: 0px;

	text-align: justify;
	-moz-hyphens: auto;
	-o-hyphens: auto;
	-webkit-hyphens: auto;
	-ms-hyphens: auto;
	hyphens: auto;
}
#grid
{
	display: grid;
 	grid-template-columns: 6fr 3fr;
 	grid-column-gap: 80px;
	width: 75%;	
	max-width: 1300px;
	min-height: 53vh;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 20px;
	padding-top: 40px;
}
#left {
	display: block;
	width: 100%;
	margin-left: auto;
	margin-right: auto;
	z-index: 5;
	/*box-shadow: 2px 2px 6px 2px rgba(0, 0, 0, 0.3);*/

}


aside{
	min-width: 260px;
	text-align: center;
	font-size: 1em;
	color: #414141;
	padding-top: 10px;
}




.boxhead
{
	background-color: #2b2b2b;
	border-radius: 6px 6px 0px 0px;
	padding: 10px;
	border-bottom: 1px solid rgb(255, 255, 255);
}
.logo
{
	background-image: url(../img/css/voltaikwerk.png);
	background-size: contain;
	background-repeat: no-repeat;
	background-position: left;
	height: 40px;
	
}

#box1{
	border-radius: 6px;
	background-color: rgb(238, 238, 238);
	padding-bottom: 10px;
	box-shadow: 0px 0px 1px 1px rgba(0, 0, 0, 0.116);
	
}
#box1 p
{
	letter-spacing: 1px;
	font-size: 0.8em;
	font-weight: 100;
	padding: 0px 5px 10px 5px;

}
#box1 i
{
	display: block;
	letter-spacing: 1px;
	font-size: 0.9em;
	
}
.roundimg {
	position: relative;
	border-radius: 100px;
	width: 150px;
	display: table;
	margin: 20px auto 20px auto;
	border: 2px solid #F7A611;
}
.box {
	border-radius: 6px;
	background-color: rgb(238, 238, 238);
	padding-bottom: 10px;
	margin-top: 30px;
	font-size: 0.9em;
	
}
.mapaside {
 width: 85%;
 box-shadow: 0px 0px 1px 1px rgba(0, 0, 0, 0.116);
 border-radius: 4px;
 height: 220px;
}

aside h1 {
	font-size: 1.2em;
	font-weight: 1000;
	text-align: center;
}
aside h2 {
	font-size: 1em;
	font-weight: 500;
	text-align: center;
}
/*---------------- Nav small devices */

#nav-smd {
	display: none;
	background: transparent;
	height: 50px;
}
#nav-smd ul{
	padding: 0px;
	margin:0px;
}
#nav-smd a img{
	width: 50px;
	height: 40px;
	padding-top: 4px;
}

/*----------------------------------------------Navigation*/

nav {
	width: 100%;
	height: 100%;
	text-align: center;
	font-size: 0.9em;
	font-family: "abelregular";
	letter-spacing: 0.1em;
	position: relative;
}

nav ul{
	display: grid;
	grid-template-areas: "a b c";
	column-gap: 15px;
	width: min-content;
}
nav li{
	line-height: normal;
	position: relative;
	display: inline;
	padding:0px 4px 0px 4px;
}

nav ul li {
	display: inline;
	line-height: normal;

}

nav ul li a {
	color: rgb(255, 255, 255);
	font-size: 1.125em;
	text-decoration: none;
	padding-right: 10px;
}

nav ul li a:hover {
	color: #F7A611;

}
.active {
	color: #F7A611;

}
nav ul ul {
	display: none;
	position: absolute;
	background-color: #2b2b2b;
	padding-left: 0px;
	padding-top: 10px;
	text-align: left;
	font-size: 0.9em;
}

nav ul li:hover > ul {
	display: block;
	text-align: left;
	top: -3px;
	left: -4px;
	z-index: 1;
	position: absolute;
	top: 20px;
	box-shadow: 0px 1px 1px rgba(68, 68, 68, 0.466);
}
nav ul ul li{
	text-align: left;
	padding: 3px 4px 3px 8px;
	display: block;
}

nav ul ul li:hover{

	display: block;
}
nav ul .aufbau{
	display: none;
}

/*-----------------------------------------------maincontent left*/


main section ul {
	margin: 0px;
	padding: 10px 0px 10px 5px;
	line-height: 2em;
	letter-spacing: 0.1em;
}


form div {
	margin-top: 8px;
}

#kontaktform {
	margin-left: 20px;
	margin-right: 20px;
	font-family: "abelregular";
	font-size: 1em;
}

input {
	border-radius: 4px;
	opacity: 0.7;
	height: 20px;
}

textarea {
	width: 90%;
	height: 300px;
	font-size: 0.9em;
	border-radius: 4px;
	padding: 0.8em;
	font-weight: 600;
	border: 1px solid #b9b9b9;
	opacity: 0.7;
}

/*Referenzen----------------------------------------------*/
@keyframes refboxshow {
	from {
		opacity: 0;
		transition-duration: 1s;
		transform: translate(0, 0%);

	}
	to {
		opacity: 1;
	
		transform: none;
	}
}

@keyframes refboxhide {
	from {
		opacity: 1;

		transform: translate(0, 1%);
	}
	to {
		opacity: 0;

		transform: none;
	}
}
	

.refbox{
	width: 100%;
	padding-bottom: 30px;
}
.refbox h2, .refbox h3{
	color:#F7A611;
	margin: 0px;
	padding: 0px;	
}
.refbox .logo{
	background-size: 50px;
}
.refboxhead{
	display: flex;
	background-color: rgb(185, 177, 161);
	border-radius: 6px 6px 0px 0px;
	padding: 10px;
	color: white;
	flex-direction: row;
	
}
.refboxhead img{
	width: 200px;
	height: auto;
	border-radius: 5px;
}
.refboxhead p{
	margin: auto ;
	color: whitesmoke;
	font-size: 1.3em;
	max-width: 80%;
	display: block;

}
.refboxbody{
	position: relative;
	background-color: #d4d4d4;
	display: none;
}

 
.refshow{
	display: block;
	animation: refboxshow 1s;
}

.refhide{
	animation: refboxhide 1s;
	display: none;
}
.refboxcontent{
	display: flex;
	flex-direction: column;

}
.refboxcontent img{
	border-radius: 6px;
	width: 90%;
	height: auto;
	text-align: center;
	margin: 3%;
}
.refboxfoot{
	border-radius: 0px 0px 6px 6px;
	background-color:rgb(185, 177, 161);
	height: 6px;
}

/*-------------------------------------------------footer*/
footer {
	display: block;
	position:relative;
	bottom: 0px;
	width: 100%;
	height: auto;
	border-top: 1px solid #F7A611;
	padding-bottom: 10px;
	background-color: whitesmoke;
	font-size: 1em;
	z-index: 8;
}

footer ul{
	display: flex;
}

footer li {
	font-size: 1em;
}
footer a{
	text-decoration: none;
	color: black;
	margin-left: 20px;
	letter-spacing: 0.01em;
}
footer a:hover{
	color: #F7A611;
}

