/* Version: 11.04.2018 */
/* --- Normal --- */
@font-face { 
	font-family: "Source Sans 3"; 
	src: url('https://fonts.pwrk.dev/ofl/sourcesans3/SourceSans3[wght].woff2') format('woff2') ;
	font-weight: 200, 300, 400, 500, 600, 700, 800, 900;
	font-style: normal;
}

/* --- Italic --- */
@font-face { 
	font-family: "Source Sans 3"; 
	src: url('https://fonts.pwrk.dev/ofl/sourcesans3/SourceSans3-Italic[wght].woff2') format('woff2') ; 
	font-weight: 200, 300, 400, 500, 600, 700, 800, 900;
  	font-style: italic;
}

 /* ------------------- Allgemein/General ------------------------- */

* {
	box-sizing: border-box;
  	margin: 0;
  	padding: 0;
}

 html {
	line-height: 1.15;
	-webkit-text-size-adjust: 100%;
}

body {
	font-family: "Source Sans 3", Arial, Helvetica, sans-serif;
	font-size: 100%;
	color: #777777;
	text-decoration: none;
	font-weight: 300;
	word-spacing: normal;
	line-height: 1.5;
	background-color: #f1f1f1;
	-webkit-print-color-adjust:exact;
}

p {
  	margin: 0 0 1rem 0;
}

p.empty {
  	margin: 0;
}

p strong {
	font-weight: 400;
}

h1 {
  	line-height: 1.5;
	font-size: 2rem;
	font-weight: 600;
	padding: 0;
	margin: 0;
}

h2 {
  	margin: 0;
  	line-height: 1.3;
  	font-size: 1.5rem;
  	font-weight: 600;
}

h3 {
	margin: 0;
	line-height: 1.1;
	font-size: 1.2rem;
	font-weight: 600;
}

.box-relative{
position: relative;
}

img {
  	max-width: 100%;
  	height: auto;
  	width: auto9;
  	border: 0;
  	vertical-align: middle;
}

a {
	text-decoration: underline;
  	color: #000;
}

a:hover {
	text-decoration: none;
  	color: #000;
}

hr {
	color: #000;
	border-color: #000;
	background-color: #000;
	margin: 1rem 0;
	height: 1px;
}

/* ------------------- Struktur/Structure ------------------------- */

.frame-outer {
	position: relative;
	padding: 0;
	width: 720px;
	margin: 1.3rem auto;
	background-color: #FFF;
	border: 0.02rem solid #A7A9A4;
	box-shadow: -0.1rem 0.1rem 1rem #999;
	font-size: 1rem;
}

.frame-outer::after {
  	content: "";
  	display: block;
  	clear: both;
}

.header {
  	position: relative;
	padding: 1.1rem 3%;
}

.content {
	position: relative;
}

.content::after {
  	content: "";
  	display: block;
  	clear: both;
}

.box-left {
  	width: 48%;
background-color: #FFF;
	padding: 1rem 20px;
	border-radius: 5px;
	-webkit-transition: .4s ease-out all;
	transition: .4s ease-out all;
}

.box-right {
	position: relative;
width: 48%;
background-color: #FFF;
	padding: 1rem 20px;
	border-radius: 5px;
	-webkit-transition: .4s ease-out all;
	transition: .4s ease-out all;
}

.box {
	position: relative;
width: 100%;
background-color: #FFF;
	padding: 1rem 20px;
	border-radius: 5px;
	-webkit-transition: .4s ease-out all;
	transition: .4s ease-out all;
}
.auszeichnungen{
position: absolute;
bottom: 2rem;
	text-align: center;
}

.clear {
  	clear: both;
  	font-size: 0;
  	line-height: 0;
}

.footer {
	position: relative;
	padding: 1.1rem 3%;
	border-top: 5px solid #414f58;
	color: #BBB;
	background-color: #333333;
}

.footer .box-right{
background-color: inherit;
	padding: 0;
	border-radius: 0;
	-webkit-transition: inherit;
	transition: inherit;
}


.footer .box-left{
background-color: inherit;
	padding: 0;
	border-radius:0;
	-webkit-transition: inherit;
	transition: inherit;
}


.footer a {
	color: #BBB;
}

.footer::after {
  	content: "";
  	display: block;
  	clear: both;
}

/* ------------------- Abstände/Distances ------------------------- */

.nomag { margin-bottom: 0; }

.mag05 { margin-bottom: 0.5rem; }

.mag075 { margin-bottom: 0.75rem; }

.mag1 { margin-bottom: 1rem; }

.mag15 { margin-bottom: 1.5rem; }

.mag2 { margin-bottom: 2rem; }

/* ------------------- Formatierung/Formating ------------------------- */

.logo {
  	width: 10rem;
  	float: left;
}

.refnr {
	
}

.justifier {
  	text-align: justify;
  	text-align-last: justify;
}

.justifier:after {
  	content: "";
  	display: inline-block;
  	width: 100%;
}

.justify {
	text-align: justify;
}

.button a {
  	position: relative;
    display: inline-block;
    margin-top: 4.5em;
    padding: 1em 3em;
    border-bottom: 4px solid transparent;
    border-bottom-color: transparent;
    font-weight: bold;
    text-transform: uppercase;
	text-decoration: none;
    letter-spacing: 1px;
    opacity: 1;
    -webkit-transition: .2s ease-out all;
    transition: .2s ease-out all;
    -webkit-animation: .75s 1.25s animation-fadeIn ease-out forwards;
    animation: .75s 1.25s animation-fadeIn ease-out forwards;
	background-color: #005089;
	color: #FFFFFF;
	border-color: #003770;
	border-radius: 5px;
}

.button a:hover {
	color: #777;
	background-color: #FFF;
	border-color: #e6e6e6;
}

/* ------------------ Listen & Tabellen/Lists & Tables ------------------------ */

ul {
	/* position: relative; */
  	margin: 0 auto 1rem 0.5rem;
  	padding-left: 0.5rem;
  	list-style-type: disc;
}

li {
  	margin: auto;
  	padding: 0;
}

/* 
li::before {
  	position: absolute;
  	left: -0.8rem;
  	content: "■";
  	font-size: 0.8rem;
  	color: red;
} */

/* ------------------ Slider - Right to Left ------------------------ */
/*
.slider-wrap {
	max-width:720px;
  	width: auto;
  	height: auto;
	position:relative;
	overflow: hidden;
}

.slideshow {
	position: absolute;
  	width: 100%;
  	top: 0px;
  	left: 0px;
  	z-index: 0;
}

.slideshow li span {
	width: 100%;
	height:100%;
	position: absolute;
	top: 0px;
	left: 0px;
	color: transparent;
	background-size: cover;
	background-position: 50% 50%;
	background-repeat: none;
	opacity: 0;
	z-index: 0;
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	-webkit-animation: image 24s linear infinite;
	animation: image 24s linear infinite;
}

@keyframes image {
  0% {
    opacity: 1;
    transform: translateX(100%);
  }
  
  1% {
    transform: translateX(0);
  }
  
  25% {
    transform: translateX(0);
  }
  
  26% {
    opacity: 1;
    transform: translateX(-100%);
  }
  27% {
    opacity: 0;
    transform: translateX(-100%);
  }
}

@-webkit-keyframes image {
  0% {
    opacity: 1;
    transform: translateX(100%);
  }
  
  1% {
    transform: translateX(0);
  }
  
  25% {
    transform: translateX(0);
  }
  
  26% {
    opacity: 1;
    transform: translateX(-100%);
  }
  27% {
    opacity: 0;
    transform: translateX(-100%);
  }
}

.slideshow li {
    margin:0;
    padding:0;
  	list-style: none;
}
.slideshow li:nth-child(1) span {
}
.slideshow li:nth-child(2) span {
  	-webkit-animation-delay: 6s;
  	animation-delay: 6s;
}
.slideshow li:nth-child(3) span {
  	-webkit-animation-delay: 12s;
  	animation-delay: 12s;
}

.slideshow li:nth-child(4) span {
  	-webkit-animation-delay: 18s;
  	animation-delay: 18s;
}
ul.slideshow {
    margin: 0;
}

.slider-wrap li::before{
	display: none;
}

.slider-wrap ul {
    margin:0;
    padding-left:0px;
    list-style-type: none;
    list-style:none;
	border-bottom:none;
	border-color: #fff;
    border-width: 0px;
	padding-bottom:5px;
}
*/
/* ------------------ Tooltip ------------------------ */

[data-tooltip] {
  	position: relative;
  	z-index: 2;
  	cursor: pointer;
}

[data-tooltip]:before,
[data-tooltip]:after {
	visibility: hidden;
	-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
	filter: progid: DXImageTransform.Microsoft.Alpha(Opacity=0);
	opacity: 0;
	pointer-events: none;
}

[data-tooltip]:before {
  	position: absolute;
  	bottom: 150%;
  	left: 50%;
  	margin-bottom: 5px;
  	margin-left: -80px;
  	padding: 7px;
  	width: 160px;
  	-webkit-border-radius: 3px;
  	-moz-border-radius: 3px;
  	border-radius: 3px;
  	background-color: #000;
  	background-color: hsla(0, 0%, 20%, 0.9);
  	color: #fff;
  	content: attr(data-tooltip);
  	text-align: center;
  	font-size: 14px;
  	line-height: 1.2;
}

[data-tooltip]:after {
  	position: absolute;
  	bottom: 150%;
  	left: 50%;
  	margin-left: -5px;
  	width: 0;
  	border-top: 5px solid #000;
  	border-top: 5px solid hsla(0, 0%, 20%, 0.9);
  	border-right: 5px solid transparent;
  	border-left: 5px solid transparent;
  	content: " ";
  	font-size: 0;
  	line-height: 0;
}

[data-tooltip]:hover:before,
[data-tooltip]:hover:after {
  	visibility: visible;
  	-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
  	filter: progid: DXImageTransform.Microsoft.Alpha(Opacity=100);
  	opacity: 1;
}

/* ------------------ Custom Code ------------------------ */

.title-block {
	position: absolute;
	bottom: 1rem;
	left: 0; 
  	right: 0; 
  	margin: 0 auto;
	padding: 0.2em 20px;
	width: 94%;
	border-radius: 5px;
	color: #FFF;
	background-color: rgba(100,100,100, 0.7);
}
.title-block_double {
	position: absolute;
	top: 22rem;
	left: 0; 
  	right: 0; 
  	margin: 0 auto;
	padding: 0.2em 20px;
	width: 94%;
	border-radius: 5px;
	color: #FFF;
	background-color: rgba(100,100,100, 0.7);
}
.title-block2 {
	position: absolute;
	top: 20rem;
	left: 0; 
  	right: 0; 
  	margin: 0 auto;
	padding: 0.2em 20px;
	width: 94%;
	border-radius: 5px;
	color: #FFF;
	background-color: rgba(100,100,100, 0.7);
}

.desc-wrapper {
	padding: 1.1rem 3%;
	background-color: #eeeff0;
}

.content-wrapper {
	padding: 1.1rem 3%;
	background-color: #f7f8f9;
}

.content-block {
	padding: 1rem 20px;
	border-radius: 5px;
	-webkit-transition: .4s ease-out all;
	transition: .4s ease-out all;
  background-color: #FFF;
}

.hover:hover {
	box-shadow: 0 0 20px rgba(0, 0, 0, 0.15);
}

.flex {
  display: flex;
  display: -ms-flexbox;
  display: -webkit-flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  margin: 1rem 0;
}

.left,
.right {
  width: 48%;
  padding: 1rem 1.2rem;
  border-radius: 0.5rem;
  background-color: #FFF;
  -webkit-transition: .4s ease-out all;
  transition: .4s ease-out all;
}

.left:hover,
.right:hover {
	box-shadow: 0 0 20px rgba(0, 0, 0, 0.15);
}


.hbox{
    padding: 1.1rem 3%;
    background-color: #f7f8f9;
}
.hbox h2{
    font-size: 1.3rem;
}
.hbox p{
    margin-bottom: 0.5rem;
}


.apply {}
