/* pt-sans-regular - latin */
@font-face {
  font-family: 'PT Sans';
  font-style: normal;
  font-weight: 400;
  src: url('/fonts/pt-sans-v12-latin-regular.eot'); /* IE9 Compat Modes */
  src: local(''),
       url('/fonts/pt-sans-v12-latin-regular.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
       url('/fonts/pt-sans-v12-latin-regular.woff2') format('woff2'), /* Super Modern Browsers */
       url('/fonts/pt-sans-v12-latin-regular.woff') format('woff'), /* Modern Browsers */
       url('/fonts/pt-sans-v12-latin-regular.ttf') format('truetype'), /* Safari, Android, iOS */
       url('/fonts/pt-sans-v12-latin-regular.svg#PTSans') format('svg'); /* Legacy iOS */
}

/* pt-sans-italic - latin */
@font-face {
  font-family: 'PT Sans';
  font-style: italic;
  font-weight: 400;
  src: url('/fonts/pt-sans-v12-latin-italic.eot'); /* IE9 Compat Modes */
  src: local(''),
       url('/fonts/pt-sans-v12-latin-italic.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
       url('/fonts/pt-sans-v12-latin-italic.woff2') format('woff2'), /* Super Modern Browsers */
       url('/fonts/pt-sans-v12-latin-italic.woff') format('woff'), /* Modern Browsers */
       url('/fonts/pt-sans-v12-latin-italic.ttf') format('truetype'), /* Safari, Android, iOS */
       url('/fonts/pt-sans-v12-latin-italic.svg#PTSans') format('svg'); /* Legacy iOS */
}

/* pt-sans-700 - latin */
@font-face {
  font-family: 'PT Sans';
  font-style: normal;
  font-weight: 700;
  src: url('/fonts/pt-sans-v12-latin-700.eot'); /* IE9 Compat Modes */
  src: local(''),
       url('/fonts/pt-sans-v12-latin-700.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
       url('/fonts/pt-sans-v12-latin-700.woff2') format('woff2'), /* Super Modern Browsers */
       url('/fonts/pt-sans-v12-latin-700.woff') format('woff'), /* Modern Browsers */
       url('/fonts/pt-sans-v12-latin-700.ttf') format('truetype'), /* Safari, Android, iOS */
       url('/fonts/pt-sans-v12-latin-700.svg#PTSans') format('svg'); /* Legacy iOS */
}

/* pt-sans-700italic - latin */
@font-face {
  font-family: 'PT Sans';
  font-style: italic;
  font-weight: 700;
  src: url('/fonts/pt-sans-v12-latin-700italic.eot'); /* IE9 Compat Modes */
  src: local(''),
       url('/fonts/pt-sans-v12-latin-700italic.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
       url('/fonts/pt-sans-v12-latin-700italic.woff2') format('woff2'), /* Super Modern Browsers */
       url('/fonts/pt-sans-v12-latin-700italic.woff') format('woff'), /* Modern Browsers */
       url('/fonts/pt-sans-v12-latin-700italic.ttf') format('truetype'), /* Safari, Android, iOS */
       url('/fonts/pt-sans-v12-latin-700italic.svg#PTSans') format('svg'); /* Legacy iOS */
}




*  {
	margin:0;
	padding:0;
	}

body   {  
	margin:0 auto;
   padding:0;
   font-family:'PT Sans','Bitstream vera sans','dejavu sans',sans-serif;
   font-size:100.01%; 
   background-color:#fff;
   color:#000;
	margin:0 2% 0 1%;
   width: 97%;
   
	}

header  {  
   background-color:transparent;
   margin:8px 0 0 0;
   height:60px;
   width:100%;
	}

header img   {  
	position:absolute;
	top: 10px;
   left:10px;
   width:250px;
	}
	

header h1   {  
	position:absolute;
   left:-3000px;
   color:#fff;
   font-weight:normal;
   width: 98%;
   margin: 0 0 10px 0;
   padding:15px 0 0 0;
	}
	
/* Mobile-Hamburger */	
	
nav section.menu {
	}

nav section.menu li a {
	}

.navi   {
	height:18px;
	}	
	
.navi .menu {
   right: 0;
   -webkit-box-shadow: 0px 3px 5px 0px rgba(50, 50, 50, 0.75);
   -moz-box-shadow:    0px 3px 5px 0px rgba(50, 50, 50, 0.75);
   box-shadow:         0px 3px 5px 0px rgba(50, 50, 50, 0.75);
   background: #eee;
   height: auto;  
   position: relative;  
   transition: top 0.5s ease-in-out; 
   margin-left: 20px;
   }

.navi input#toggle {
	display: none;
   }

.navi input#toggle + label {
	}

nav ul  {  
	padding: 0.2em 0.5em 1em 1em;
	list-style: none;
	}
	
nav ul li
   {  margin: 1em 0 0 0;
      font-size: 1em;
      width:14em;
}

nav li ul   {
	padding:0;
	margin-left: 24px;	
	}

nav ul li ul li
   {  
}
	
nav li ul li ul  {
	}	

nav ul li.active  {
}
	
nav li li.active   {
	margin-top: 1em;	
	}	

/*

nav li li
   {  margin: 0;
      width:14em;
}

nav li li li
   {  margin: 0;
      width:14em;
}

*/

nav li a
   {  font-size:1.0em;
   	font-weight: bold;
      line-height: 1.3;
      text-decoration: none;
      color: #fff;
      display: block;
      padding: 1px 6px 1px 6px;
      background:#000;
      border-left: 6px solid #dc141c;
}

nav li a:hover,
nav li a.current
   {  color: #fff;
      background:#dc141c;
      border-left: 6px solid #000;
}

label.button { 
   display: block;
   background: #555; width: 55px; height: 42px; 
   position: absolute;
   top: 15px;
   right:15px; 
   margin-left: auto; margin-right: auto;
   border-radius: 4px; 
}

.line { 
   position: absolute; 
   left:10px;
   height: 4px; width: 35px; 
   background: #fff; border-radius: 2px;
   display: block; 
   transition: 0.5s; 
   transform-origin: center; 
}

#toggle:not(:checked) + .button .line:nth-child(1){
   transform: translateY(10px) rotate(-45deg);
}

#toggle:not(:checked) + .button .line:nth-child(2){
   opacity:0;
}

#toggle:not(:checked) + .button .line:nth-child(3){
   transform: translateY(-10px) rotate(45deg);
}

.button .line:nth-child(1) { top: 10px; }
.button .line:nth-child(2) { top: 20px; }
.button .line:nth-child(3) { top: 30px; }

input#toggle:checked ~ .menu {
   top: -800px;
   }	
   
/* Ende Hamburger */	
	

#container  {
	display: flex;
	flex-direction: column;	
	}

.spalte   {
	display: none;
	}

main  {
	display: flex;
	flex-direction: column;	
	}

article   {
	padding: 0 2% 40px 4%;
	width:94%;	
}	
	
article h1 {
font-size: 1.6em;
font-weight:700;
margin: 0 0 0.5em 0;
line-height: 1.1;
width:100%;
}

article h2 {
font-size: 1.4em;
font-weight:700;
margin:0;
padding: 0 0 0.3em 0;
line-height: 1.1;
width:100%;
}

article h3 {
font-size: 1.4em;
font-weight:700;
margin:0;
padding: 0.9em 0 0.6em 0;
line-height: 1.1;
width:100%;
}

article h4 {
font-size: 1.1em;
font-weight:700;
margin:0;
padding: 0.7em 0 0.4em 0;
line-height: 1.1;
width:100%;
}

article h6   /* wird als Spitzmarke verwendet */  {
	font-size: 1.2em;
	font-weight:400;
	margin:0;
   padding: 0 0 0.5em 0;
	text-decoration:underline;
	line-height: 1.1;
	width:100%;
	}

article img {
padding: 1px;
display: inline;
width:100%;
}

article a:link,
aside a:link,
#extras a:link{
color:#f00;
}

article a:visited,
aside a:visited,
#extras a:visited {
color:#b22222;
}

article a:hover,
article a:active,
aside a:active,
aside a:hover {
color:#f00;
}

main p, main li {
margin:0;
font-size: 1em;
font-weight:400;
line-height:1.4;
padding:0 0 0.5em 0;
}

main ul, main ol {
margin:0 0 0 18px;
}

article p.footnote   {
	padding-bottom:0.1em;	
	}

article p.iview   {
	text-indent:-1.5em;	
	margin-left:1.5em;
	font-style:italic;
	}
	
article .kasten   {
	float:right;
	margin:5px 0 2px 6px;	
	padding:15px 2px 12px 20px; 
	background-color:#f00;
	color:#fff;
	font-size:1.3em;
	font-style:italic;
	width:45%;
}	

article a, aside a {
text-decoration: none;
}

article a:hover, aside a:hover {
text-decoration: underline;
}

article a img, aside a img {
border: 0;
}

.hyphens {
   -moz-hyphens: auto;
   -o-hyphens: auto;
   -webkit-hyphens: auto;
   -ms-hyphens: auto;
   hyphens: auto; 
   }

aside  {
	padding: 20px 2% 40px 4%;
	width:94%;
	background-color: #fff0da;
	border-top: 4px solid #f00; 
	border-bottom: 4px solid #f00; 
	z-index:2;
}	

aside h2 {
font-size: 1.3em;
font-weight:700;
margin:0;
padding: 0 0 0.6em 0;
line-height: 1.1;
width:100%;
}

aside h3 {
font-size: 1.3em;
font-weight:700;
margin:0;
padding: 1em 0 0.4em 0;
line-height: 1.1;
width:100%;
}

aside p {
margin:0;
padding:0 0 0.5em 0;
font-size: 1em;
font-weight:400;
line-height:1.3;
}

article p,
aside p    {
   -moz-hyphens: auto;
   -o-hyphens: auto;
   -webkit-hyphens: auto;
   -ms-hyphens: auto;
   hyphens: auto; 
	}

footer {
	position:fixed;
	left:0;
	bottom:0;
	background-color:#dc141c;
	width:100%;
	z-index:9;
	}


footer p {
	color: #fff;
	padding:10px 0.5% 8px 0;
	width:99.5%;
	font-size: 0.7em;
	text-align:right;
	}

footer p a,
footer p a:link,
footer p a:visited  {
	color: #fff;
	text-decoration: none;
	}

footer p a:hover {
	text-decoration: underline;
	}

.article-list   {
	margin: 1em 0 40px 30px;
	}

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

#navi2  {
	padding-bottom:3.5em;
	}
	
#navi2 ul{
   font-size:1em;
   font-weight:normal;
   line-height:2.2;
   padding-left:1em;
   }

#navi2 li{
   display:inline;
   list-style-image:none;
   padding-right: 2em;
   }

#navi2 li a{
   text-decoration:none;
   }

#navi2 li a:link,
#navi2 li a:visited{
   text-decoration:none;
   color:#000;
   font-weight:normal;
   }

#navi2 li a:active,
#navi2 li a:hover,
#navi2 li a:focus{
   color:#f00;
   text-decoration:underline;
   font-weight:normal;
   }

#navi2 li a.aktiv{
   background-color:#ff9933;
   font-weight:normal;
   }

.team  {
	margin-bottom:5px;
	}
	
#demo p   {
	font-size:1.5em;
	}	
	
.nachoben   {
	position:fixed;
	right:0.5em;
	bottom:0;
	width: 200px;
	text-align:right;
	z-index:9;
	padding-bottom: 38px;
	}	
	
.nachoben a  {
	background-color:#fff;
	}	


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

body   {  
   background-color:#f5f5f5;
   background-image:url(images/gitter-rot.gif);
   background-size:42px 120px;
   background-repeat:repeat-x;
   margin:0 1% 0 2%;
   width:97%;
   
	}

header  {  
   height:120px;
	}

header img   {  
	top: 34px;
   left:12%;
   width:350px;
	}

article   {
	padding: 0 0 40px 0;
	width:100%;
	max-width:700px;	
	}	


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

#navi2{
   position:absolute;
   top:109px;
   right:0.5%;
   width:99.5%;
   max-width:1440px;
   padding:0;
   text-align:right;
   z-index:5;
   }

#navi2 ul{
   font-size:0.8em;
   font-weight:normal;
   line-height:1.2;
   margin:0;
   padding:0;
   }

#navi2 li{
   display:inline;
   list-style-image:none;
   padding:2px 3px 0 6px;
   margin:0;
   border-left:3px #f00 solid;
   }

#navi2 li a{
   text-decoration:none;
   }

#navi2 li a:link,
#navi2 li a:visited{
   text-decoration:none;
   color:#000;
   font-weight:normal;
   }

#navi2 li a:active,
#navi2 li a:hover,
#navi2 li a:focus{
   color:#f00;
   text-decoration:underline;
   font-weight:normal;
   }

#navi2 li a.aktiv{
   background-color:#ff9933;
   font-weight:normal;
   }



}



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


body   {
	margin:0 1% 0 1%;
	width:98%;
	}

header img   {  
	top: 32px;
   left:15%;
   width:400px;
	}

article   {
	padding: 0 1em 40px 1em;
	width:98%;
	}	
	
aside  {
	padding: 18px 1em 40px 1em;
	z-index: 0;
	}
	
	
.left {
margin: 10px 10px 5px 0;
float: left;
}

.flLeft img {
margin: 5px 16px 0 0;
float: left;
}

.floatLeft, 
dl.image 
{
	float:left;
	margin: 4px 12px 6px 0;
	}

.image dd  {
	margin-left:0;
	font-style:italic;
	width:250px;
	line-height:110%;
	}

.right {
margin: 10px 0 5px 10px;
float: right;
}

.textright {
text-align: right;
}

.center {
text-align: center;
}

.small {
font-size: 0.8em;
}

.bold {
font-weight: bold;
}

.hide {
display: none;
}



.sf-menu, .sf-menu * {
	margin: 0;
	padding: 0;
	list-style: none;
}
.sf-menu li {
	position: relative;
}
.sf-menu ul {
	position: absolute;
	display: none;
	top: 100%;
	left: 0;
	z-index: 99;
}
.sf-menu > li {
	float: left;
}
.sf-menu li:hover > ul,
.sf-menu li.sfHover > ul {
	display: block;
}

.sf-menu a {
	display: block;
	position: relative;
}
.sf-menu ul ul {
	top: 0;
	left: 100%;
}


}

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

body   {
	margin:0;
	width:100%;
	}

header  {  
   height:130px;
	}


section  {
	display: flex;
	flex-direction: column;	
	}

main  {
	display: flex;
	flex-direction: row;	
	align-items: stretch;
	justify-content:space-between;
	}
	
article   {
	padding: 0 20px 40px 1em;
	min-width:450px;
	}	
	
aside  {
	flex-shrink:0;	
	margin-top:7px;	
	padding: 12px 3px 40px 15px;
	width:190px;
	background-color: #fff;
	border-top: 2px solid #f00; 
	border-left: 2px solid #f00;  	
	}	

	
aside p, aside li {
	font-size: 0.9em;
	font-weight:400;
	line-height: 1.3;
	}

}


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

label.button  
	{	display: none;
		}		
		
input#toggle:checked ~ .menu
	{	top: 0;
		}		
		
.navi .menu {
   right: 0;
   -webkit-box-shadow: none;
   -moz-box-shadow:    none;
   box-shadow:         none;
   background: transparent;
   height: auto;  
   position: static;  
   transition: none; 
   margin-left:0;
   }

nav    {
	margin: 0 10px 50px 1em;
	width: auto;
	}
	
nav ul   {
	display:flex;
	flex-direction: row;
	justify-content: flex-start;
	padding: 1em 0 1.3em 0;
	list-style: none;
	z-index:5;
	}	

nav ul li
	{  margin: 0 1em 0 0;
      font-size: 0.9em;
      margin: 0 10px 0 0;
      width:auto;
}

nav li.active, nav li li.active  {
	}

nav li li   {
	font-size: inherit;
	}

nav li a
   {  font-weight: bold;
      line-height: 1.3;
      text-decoration: none;
      color: #fff;
      display: block;
      padding: 1px 6px 1px 6px;
      background:#000;
      border-left: 6px solid #dc141c;
}

nav li a:hover,
nav li a.current
   {  color: #fff;
      background:#dc141c;
      border-left: 6px solid #000;
}

nav ul.nav2nd, nav ul.nav3rd   {
	display:flex;
	flex-direction: column;
	justify-content: flex-start;
	background-color:#fff;
	padding: 0 4px 4px 4px; 
	}

nav ul.nav2nd li, nav ul.nav3rd li  {
	margin-top:1em;
	width:auto;
}

nav ul.nav3rd   {
	margin-left: 16px;	
	}

/*
nav ul li ul  {
	visibility: hidden;
	}
*/	
nav ul li ul li  {
	}	

nav ul li ul li ul  {
	}

article   {
	padding: 0 20px 40px 1em;
	min-width:410px;
	}	
	
aside  {
	flex-shrink:0;	
	margin-top:7px;	
	padding: 12px 3px 40px 15px;
	width:230px;
	background-color: #fff;
	border-top: 2px solid #f00; 
	border-left: 2px solid #f00;  	
	}	

	


}



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

header img   {  
	top: 18px;
   left:230px;
   width:500px;
	}


article   {
	padding: 0 60px 40px 60px;
	width:auto;
	max-width:700px;	
	}	
	
aside    {
	width:250px;	
	} 	
	
nav    {
	margin: 0 10px 60px 60px;
	}

nav ul li  {  
	font-size:1em;
   }


}

/*

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

aside    {
	width:270px;	
	} 	

}

*/

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

header img   {  
   left:220px;
	}

nav    {
	margin: 0 10px 60px 40px;
	}

nav ul.nav2nd, nav ul.nav3rd   {
	background-color:transparent;
	padding: 0; 
	}

nav ul.nav2nd li, nav ul.nav3rd li  {
	margin-top: 10px;
	width:12em;
}

nav ul.nav3rd   {
	margin-left: 0;	
	}

header  {  
   height:155px;
	}

#container  {
	display: flex;
	flex-direction: row;	
	}

article   {
	padding: 0 40px 40px 0;
	width:100%;
	max-width:700px;	
	}	

aside  {
	width:230px;
	}	

nav ul  {  
	margin:0 40px 0 40px;
	padding: 0;
	width:220px;
	list-style: none;
	}
	
nav ul li
   {  margin: 1em 0 0 0;
      font-size: 1em;
      width:14em;
}

nav li ul   {
	padding:0;
	margin-left: 12px;	
	}

nav ul li ul li
   {  
}
	
nav li ul li ul  {
	}	

nav ul li.active  {
}
	
nav li li.active   {
	margin-top: 1em;	
	}	

nav    {
	margin: -6px 0 0 0;
	padding: 0 40px 0 30px;
	width:230px;	
	}
	
nav ul  {  
	padding: 0 0.5em 1em 1em;
	list-style: none;
	}
	
/*

nav ul li
   {  margin: 1em 0 0 0;
      font-size: 1em;
      width:14em;
}

nav li ul   {
	padding:0;
	margin-left: 24px;	
	}

*/	
	
nav ul   {
	display:flex;
	flex-direction: column;	
	padding:0;
	}	

nav li li, nav li li li
   {  margin: 0;
}

nav ul  {  
	margin:0;	
	padding: 0;
	list-style: none;
	}
	
nav ul li
   {  margin: 10px 0 0 0;
      font-size: 1em;
      width:12em;
}

nav li.active  {
	margin: 10px 0 0 0;
	width:12em;
	}

nav li li.active  {
	margin: 10px -16px 0 16px;
	width:12em;
	}

nav ul li ul  {
	visibility:visible;
	padding:0;
	background-color: transparent;
	}
	
nav ul li ul li ul  {
	}

nav li li
   {  margin: 10px -16px 0 16px;
      font-size: 1em;
      width:12em;
}

nav li li li
   {  margin: 10px -16px 0 16px;
      width:12em;
}

nav li a
   {  font-size:1.0em;
   	font-weight: bold;
      line-height: 1.3;
      text-decoration: none;
      color: #fff;
      display: block;
      padding: 1px 6px 1px 6px;
      background:#000;
      border-left: 6px solid #dc141c;
}

nav li a:hover,
nav li a.current
   {  color: #fff;
      background:#dc141c;
      border-left: 6px solid #000;
}



}



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

header img   {  
	top: 15px;
   left:250px;
	}

#container  {
	justify-content: flex-end;	
	}

article   {
	padding: 0 60px 40px 0;
	width: 100%;
	max-width:700px;	
	}	
	
aside  {
	padding: 12px 10px 40px 18px;
	width:auto;
	max-width:290px;
	}	
	
nav    {
	margin-right:10px; 	
	padding: 0 50px 40px 40px;
	}
	


}

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

#container  {
	max-width:1440px;	
	}

#navi2{
   left: 0;
   }

article   {
	padding: 0 60px 40px 0;
	width:700px;	
	}	
	

}

