@font-face {
  font-family: 'Hind';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("../fonts/Hind-Light.woff2") format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Hind';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/Hind-Regular.woff2") format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Hind';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/Hind-Medium.woff2") format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Hind';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../fonts/Hind-SemiBold.woff2") format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Hind';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../fonts/Hind-Bold.woff2") format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Encode Sans';
  font-style: normal;
  font-weight: 100;
  font-stretch: normal;
  font-display: swap;
  src: url("../fonts/Encode-Sans-Thin.woff2") format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Encode Sans';
  font-style: normal;
  font-weight: 300;
  font-stretch: normal;
  font-display: swap;
  src: url("../fonts/Encode-Sans-Light.woff2") format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Encode Sans';
  font-style: normal;
  font-weight: 400;
  font-stretch: normal;
  font-display: swap;
  src: url("../fonts/Encode-Sans-Regular.woff2") format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Encode Sans';
  font-style: normal;
  font-weight: 500;
  font-stretch: normal;
  font-display: swap;
  src: url("../fonts/Encode-Sans-Medium.woff2") format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Encode Sans';
  font-style: normal;
  font-weight: 600;
  font-stretch: normal;
  font-display: swap;
  src: url("../fonts/Encode-Sans-SemiBold.woff2") format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Encode Sans';
  font-style: normal;
  font-weight: 700;
  font-stretch: normal;
  font-display: swap;
  src: url("../fonts/Encode-Sans-Bold.woff2") format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Encode Sans';
  font-style: normal;
  font-weight: 800;
  font-stretch: normal;
  font-display: swap;
  src: url("../fonts/Encode-Sans-ExtraBold.woff2") format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
html {
    margin: 0;
    padding: 0;
    max-width: 100%;
    scrollbar-width: thin;
    overflow-x: hidden;
    max-width: 100vw;
}

@media(max-width:1350px){
html {
    font-size: 14px;
}  
html[data-fontsize="larger"] {
    font-size: 16px;
}  
html[data-fontsize="largest"] {
    font-size: 18px;
}   
}
@media(max-width:1799px) and (min-width:1351px){
html {
    font-size: 16px;
}   
html[data-fontsize="larger"] {
    font-size: 18px;
}  
html[data-fontsize="largest"] {
    font-size: 20px;
}
nav ul li > a, nav ul li > span {
    transition: height 0.5s ease-in;
    display: block;
    margin: 26px 15px;
    color: #fff;
}  
}
@media(min-width:1800px){
html {
    font-size: 18px;
}   
html[data-fontsize="larger"] {
    font-size: 20px;
}  
html[data-fontsize="largest"] {
    font-size: 22px;
}  
}


body{
	margin: 0;
	padding: 0;
    min-height: 100%;
    min-width: 300px;
    max-width: 100vw;
    height: auto;
    position: relative;
    overflow: hidden;
	font-family: 'Hind', Sans-Serif;
	font-weight: 400;
	line-height: 1.5em;
	color: #5d5d5d;
	background: #fff;
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
    -webkit-appearance: none;
}
h1, .h1, h2, .h2, h3, .h3, h4, .h4, h5, .h5 {
    font-weight: 700;
    page-break-inside: avoid;
	font-family: 'Encode Sans', Serif;
}

h1, h2 {
	line-height: 1.2em;
	font-size: 1.8em;
}

h3{
  line-height: 1.5em;
  font-size: 1.3em;
}

h4{
  font-size: 1em;
}
p {
    line-height: 1.6em;
}
a {
    text-decoration: none;
    transition: color 0.5s ease-in;
    color: #af0c26;
}

hr {
	height: 2px;
	width: 100%;
	background-color: #af0c26;
	color: #af0c26;
}
.showmoretext {
    cursor: pointer;
}
.showmoretext span:first-of-type, .showmoretext.smtopen span:last-of-type {
    display: block;
}
.showmoretext.smtopen span:first-of-type, .showmoretext span:last-of-type {
    display: none;
}
.moretext {
    overflow: hidden;
    height: auto;
    max-height: 0;
    transition: max-height 0.5s linear;
}
.moretext.smt {
    max-height: 5000px;
}

ul {
	padding: 0px;
}

li {
	list-style: none;
}

#main ul {
	padding-left: 25px;
}

#main ul li {
	position: relative;
}

#main ul li p {
	margin: 0px;
} 

#main ul li:before {
	position: absolute;
	content: "";
	border-radius: 100%;
	width: 5px;
	height: 5px;
	background-color: #004588;
	display: block;
	margin-left: -25px;
	margin-top: 7px;
}

#main ul li ul li:before {
	position: absolute;
	content: "";
	width: 10px;
	height: 2px;
	margin-top:9px;
	background-color: #004588;
	display: block;
}

#main .teamtxt ul {
	padding:0px;
}

#main .teamtxt li:before {
	height: 0px;
	width: 0px;
	opacity: 0;
}

.heading h3 {
	color: #af0c26;
}

.wrapper {
    padding: 0px;
	max-width: 1920px;
	margin: 0 auto;
	position: relative
}
.slogan {
	top: 55%;
}
.flex {
    display: flex;
    flex-flow: row wrap;
    width: 100%;
}
.box1 {flex: 1 1 150px;}
.box2 {flex: 2 1 300px;}
.box3 {flex: 3 1 450px;}
.box4 {flex: 4 1 600px;}
.box5 {flex: 5 1 750px;}
.box5 {flex: 6 1 900px;;}
.boxfull {flex: 1 1 100%;}
.box1, .box2,.box3,.box4,.box5, .boxfull {padding: 30px;max-width: 100%;}
.flex.box1, .flex.box2,.flex.box3,.flex.box4,.flex.box5 {
    margin: -30px;
}

.teaser {
	position: relative;
	width: calc(100% - 150px);
	margin: -100px auto 0px;
	background-color: #fff;
	box-shadow: 0 0 10px rgba(0,0,0,0.5);
	border-radius: 25px;
	min-height: 200px;
	
}

.menu {
    transition: background 0.5s ease-in,max-width 0.2s ease-in;
    position: absolute;
    z-index: 1000;
    width: auto;
    max-width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-flow: row wrap;
    right: 0px;
    top: 35px;
}

.menu.open {
	background-color: #f4f4f4 !important;
}

.menu .navbutton span {
	color: #fff;
	transition: color 0.5s ease-in;
}

.open .navbutton span {
	color: #af0c26;
}

.menu .navbutton i {
    position: absolute;
    right: -10px;
    top: 0px;
    bottom: auto;
    margin: auto;
    display: inline-flex;
    height: 1em;
}

.menu .navbutton i:before {
    display: block;
    transition: transform 0.5s ease-in-out;
}
.menu .navbutton i.fa-times:before, .menu.open .navbutton .fa-bars:before {
    transform: scale(0);
}
.menu.open .navbutton i.fa-times:before, .menu .navbutton .fa-bars:before {
    transform: scale(1);
}
nav, .iconnav, .footernav {
    padding-top: 0px;
    padding-bottom: 0px;
    text-transform: uppercase;
    font-size: 1.2rem;
    position: relative;
    white-space: nowrap;
}
nav.mainnav {
    padding: 10px 48px;
    justify-content: center;
	align-items: center;
	margin: 0px;
}
nav ul {
    list-style: none;
    padding: 0;
}
@media(min-width:1800px){
nav ul li > a, nav ul li > span{
	transition: height 0.5s ease-in;
    display: block;
    margin: 24px 15px;
    color: #fff;
}
}
@media(max-width:1799px) and (min-width:1351px){
nav ul li > a, nav ul li > span {
    transition: height 0.5s ease-in;
    display: block;
    margin: 26px 15px;
    color: #fff;
}  
}
nav ul li.active > a, nav ul li.active > span {
    font-weight: 600;
}
nav > ul li {
    cursor: pointer;
	position: relative;
}

@keyframes dd {
    0%{top:-60px}
    100%{top: 0}
}
@keyframes dd2 {
    0%{top:-60px}
    100%{top: 0}
}
/* Normales Menü */
@media (min-width:1501px) {
nav .navbutton {
    display: none;
}   
nav .navi {
    display: flex;
    flex-flow: row;
    align-items: left;
    justify-content: flex-end;
    margin: 0 auto;
    width: 100%;
} 
nav > ul li .sub {
    position: absolute;
    height: auto;
    z-index: 2;
    transition: all 0.5s ease-in;
    padding: 0 18px;
    background-color: #fff;
    width: auto;
    top: 100%;
    margin-left: -20px;
} 
.sticked nav > ul li .sub {
    top: calc(100% + 10px);
    width: calc(100% + 150px);
} 
nav > ul li .sub li {
    height: auto;
    max-height: 0px;
    opacity: 0;
    transition: max-height 0.5s ease-in, opacity 0.5s ease-in;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    line-height: 30px;
}
nav > ul li.showsub .sub, nav > ul li:hover .sub {
    padding: 10px 18px;
    z-index: 3;
}
.sticked nav > ul li.showsub .sub, .sticked nav > ul li:hover .sub {
    box-shadow: 0 0 10px rgba(0,0,0,0.5);
} 
nav > ul li.showsub .sub li, nav > ul li:hover .sub li {
    max-height: 30px;
    opacity: 1;
}
nav > ul li .sub li a {
	color: #af0c26;
	transition: color 0.5s ease-in;
}
nav > ul li .sub li a:hover {
	color: #004588;
}
nav:not(.footernav, .iconnav) ul li:after {
	position: absolute;
	content: '';
	opacity: 0;
	background-color: #fff;
	height: 5px;
	display: block;
	transition: opacity 0.5s ease-in;
	bottom: 0px;
	width: 100%;
}
.sticked nav:not(.footernav, .iconnav) ul li:after {
	bottom: -10px;
}

nav:not(.footernav, .iconnav) ul li:hover::after {
	opacity: 1;
}
}
@media (min-width:1320px) {
/* Sticked */
.sticked #logo {
    left: 0;
    padding: 10px 30px;
    text-align: left;
}
.sticked #logo img {
	width: auto;
	min-width: 70px;
	object-fit: contain;
	min-height: 0px;
	left: 30px;
	right: auto;
}
.sticked section .menu {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 100;
    animation-fill-mode: forwards;
    animation-delay: 0.5s;
    width: 100%;
    box-shadow: 0 0 10px rgba(0,0,0,0.5);
	background-color: #af0c26;
} 
.sticked section .menu nav{
    padding-top: 10px;
    padding-bottom: 10px;
}    

.sticked nav > ul > li > a, .sticked nav > ul > li > span, .sticked .sharebox{
    margin: 5px 15px;
}    
}
@media (max-width:1319px) {
/* Sticked */
.sticked #logo {
    left: 0;
    padding: 10px;
}
.sticked #logo img {
	width: auto;
	min-width: 20px;
	height: 35px;
	object-fit: contain;
	min-height: 0px;
}
nav.mainnav {
	padding: 10px;
}
.sticked section .menu nav {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 100;
    animation-fill-mode: forwards;
    animation-delay: 0.5s;
    width: 100%;
    box-shadow: 0 0 10px rgba(0,0,0,0.5);
    padding-top: 14px;
    padding-bottom: 14px;
    background-color: #f4f4f4;
} 
.sticked section .menu nav ul {
    justify-content: center;
}
.sticked section .menu nav .navbutton {
	margin-right: 55px;
}
.sticked section .menu nav .navbutton span {
	color: #af0c26;
	transition: color 0.5s ease-in;
}
header .tools {
	margin: 18px 0px !important;
	padding: 0px !important;
}
}
/* Dropdown Menü */
@media (max-width:1500px) {  
.menu {
    background-color: transparent;
}  
body header {
    height: 65vh;
}
nav.wrapper.mainnav {
	display: flex;
    padding: 10px 18px;
    justify-content: center;
	align-items: flex-start;
	margin: 0px;
}
.menu nav ul li > a, .menu nav ul li > span {
    color: #af0c26;
    transition: color 0.5s ease-in;
}

.menu nav ul li > a:hover, .menu nav ul li > span:hover {
    color: #004588;
}

nav > ul li.showsub .sub li, nav > ul li:hover .sub li {
    max-height: 45px;
    opacity: 1;
}

nav, .iconnav, .footernav {
	white-space: normal;
	font-size: 20px;
}
section.menu {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 100;
    display: block;
}
.sticked section.menu nav {
    position: fixed
    top: -100%;
    animation-fill-mode: forwards;
    animation-delay: 0.5s;
}
.sticked section.menu {
    position: fixed;
    top: 83px;
}    
nav .navbutton {
    display: block;
	text-align: right;
	margin-right: 25px;
} 
.sticked nav .navbutton span {
    margin-top: 0;
    margin-bottom: 0;
    transition: margin-bottom 0.5s ease-in;
}

.sticked .open nav .navbutton span {
    margin-bottom: 15px;
} 
nav .navi {
    display: block;
    width: 100%;
    margin: 0 auto;
    position: relative;
} 
nav ul li > a, nav ul li > span{
    transition: color 0.5s ease-in;
    display: block;
    margin: 15px 15px 15px 52px;
}  

nav ul li > a:hover, nav ul li > span:hover {
	color: #af0c26;
}  
nav.mainnav > ul > li:not(.navbutton) {
    display: block;
    height: auto;
    padding: 0;
    overflow: hidden;
    max-height: 0px;
    opacity: 0;
    pointer-events: none;
    transition: max-height 0.5s ease-in, opacity 0.5s ease-in;
} 
nav > ul > li.sbx{
    position: absolute;
    top: 0;
    right: 0;
    margin: -15px 0;
} 
.open nav > ul > li:not(.navbutton) {
    opacity: 1;
    pointer-events: all;
    max-height: 600px;
}
nav > ul li .sub{
    height: auto;
    padding: 0;
    transition: all 0.5s ease-in;
} 
nav > ul li .sub li{
    height: auto;
    max-height: 0px;
    opacity: 0;
    padding: 0 10px;
    transition: max-height 0.5s ease-in, opacity 0.5s ease-in;
    overflow: hidden;
}
nav > ul li.showsub .sub{
    padding: 0;
} 
nav > ul li.showsub .sub li{
    max-height: 60px;
    opacity: 1;
    padding: 4px 10px;
}
}

/* Shariff */
.sharebox {
    width: auto;
    display: block;
    padding: 0;
    box-sizing: border-box;
}
.showshare {
    cursor: pointer;
    transition: color 0.5s ease-in;
	font-size: 1.3rem;
}
.showshare:hover, .share > p i:hover {
    color: #004588;
}

.share {
    display: block;
    flex-flow: row;
    align-items: center;
}
.share > p  {
    display: inline-flex;
    cursor: pointer;
    margin: 0px 10px;
    height: 21px;
    align-items: center;
}
.share > p i {
    line-height: 1em;
    font-size: 19px;
    display: block;
    color: #fff;
    transition: color 0.5s ease-in;
}
.sharebuttons {
    height: auto;
    transition: all 0.5s ease-in;
    display: flex;
    flex-flow: row wrap;
    max-height: 0px;
    padding: 0px 30px;
    pointer-events: none;
    background-color: #004588;
    color: #fff;
    z-index: 1000000;
	position: relative;
	opacity: 0;
}
.sharebuttons .tosoc a {
    color: #fff;
    font-weight: 600;
}
.sharebuttons.visible {
    overflow: hidden;
    max-height: 200px;
    padding: 30px 30px;
    pointer-events: all;
    opacity: 1;
}
.sharebuttons > i {
    flex: 0 0 30px;
    display: flex;
    align-items: center;
    cursor: pointer;
}
.sharebuttons > div:not(.tosoc) {
    display: inline-flex;
    align-items: center;
    justify-content: flex-start;
    width: 100% !important;
    text-align: left;
    height: auto;
    margin: 10px 0;
    flex: 1 1 400px;
}
.sharebuttons > div.tosoc {
    padding: 0px !important;
    display: block;
    width: 100% !important;
    text-align: right;
    height: auto;
}
.sharebuttons .shariff .orientation-horizontal {
    justify-content: flex-end;
    width: 100%;
}
.sharebuttons .shariff .orientation-horizontal li {
    margin-bottom: 5px;
    margin-right: 5px;
}
.sharebuttons .shariff li,.sharebuttons .shariff li a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 35px;
    height: 35px;
    border-radius: 100%;
}
.sharebuttons > .tosoc p {
    margin: 0;
    -webkit-hyphens: auto;
    hyphens: auto;
    font-size: 0.8rem;
    line-height: 1.3em;
    white-space: normal;
    text-transform: none;
}
.sharebuttons > div:last-child {
    padding-bottom: 10px!important;
}
.sharebuttons > div:only-child {
    padding-bottom: 10px!important;
}

header {
    position: relative;
    color: #fff;
    height: 70vh;
    min-height: 600px;
    display: flex;
    flex-flow: column;
}

.preheader {
	width: 100%;
	min-height: 120px;
    background-color: rgb(175,12,38);
	box-shadow: 0 0 10px rgba(0,0,0,0.5);
	position: relative;
}

header.large {
    height: 90vh;
    min-height: 850px;
    max-height: 1200px;
}
header  > * {
    width: 100%;
}
header > .menu {
    flex: 0 0 75px;
}

header > .headerimg {
    flex: 1 1 calc(70% - 75px);
	position: relative;
    z-index: 0;
    background-image: linear-gradient(to bottom, rgba(0, 69, 136,0.2) 0%, transparent 100%);
}
header > .headerimg h1 {
	position: absolute;
    z-index: 1;
	left: 30px;
    text-align: left;
	text-shadow: 0 0 10px rgba(0,0,0,0.5);
    font-weight: 500;
    font-family: 'Encode Sans', Serif;    
}
header > .headerimg img {
    position: absolute;
    object-fit: cover;
    top: 0;
    left: 0;
    right: 0;
    margin: auto;
    width: 100%;
    height: 100%;
    max-width: 1920px;
}
header > .headerimg:before {
	content: '';
	position: absolute;
	width: 100%;
    height: 100%;
    left: 0;
    right: 0;
    top: 0;
    margin: auto;
    max-width: 1920px;
    background-image: linear-gradient(to top right, rgba(0,0,0,0.2) 42%, transparent 60%);
	z-index: 1;
}
header > .headerimg h1 span {
    display: block;
    padding: 5px 30px;
	margin-bottom: 5px;
	margin-left: 25px;
}
header > .headerimg h1 span:first-child {
    font-size: 4rem;
	line-height: 6rem;
}
header > .headerimg h1 span:last-child {
    font-size: 2rem;
    text-transform: uppercase;
	font-weight: 300;
}

header.large > .headerimg .jobteaserbutton {
	background-color: rgba(0, 69, 136, 0.7);
	border-radius: 25px 0px 0px 25px;
	position: absolute;
    font-weight: 500;
    font-family: 'Encode Sans', Serif;
    font-size: 1.5rem;
    right: 0px;
	top: 50px;
    padding: 10px 90px 30px 30px;
	box-shadow: 0 0 10px rgba(0,0,0,0.5);
    z-index: 1;
}

header > .headerimg .jobteaserbutton {
	background-color: rgba(0, 69, 136, 0.7);
	border-radius: 25px 0px 0px 25px;
	position: absolute;
    font-weight: 500;
    font-family: 'Encode Sans', Serif;
    font-size: 1.5rem;
    right: 0px;
    padding: 10px 90px 30px 30px;
	top: 60px;
    z-index: 1
}

header > .headerimg .jobteaserbutton p {
	margin: 0px 0px 10px 0px;
	padding: 0px;
}

header > .headerimg .jobteaserbutton a {
	background-color: #fff;
	color: #af0c26;
	text-align: center;
	padding: 10px;
	text-transform: uppercase;
	font-size: 0.8rem;
	width: 100%;
	display: block;
	border-radius: 10px;
}
header > .headerimg .jobteaserbutton a:hover {
	background-color: #af0c26;
	color: #fff;
	transition: all 0.5s ease-in;
}

@media (min-width:1920px){
header.large > .headerimg .jobteaserbutton {
	border-radius: 25px;
}
header > .headerimg .jobteaserbutton {
	border-radius: 25px;
    right: 30px;
	padding: 30px !important;
}

header > .headerimg .jobteaserbutton a {
	width: calc(100% - 20px);
}
.jobteaserbutton > p {
	text-align: center;
}
}

header .tools {
    position: absolute;
    top: 5px;
    right: 5px;
    width: auto;
    z-index: 100000;
    display: flex;
    margin: 18px;
	padding: 0px 30px;
}
header .tools > * {
    padding: 0px 10px;
    margin: 0px 10px;
    display: flex;
    align-items: baseline;
}
header .tools .cfs {
    font-size: 1.3rem;
    font-weight: 400;
}
header .tools .cfs span {
    cursor: pointer;
    transition: color 0.5s ease-in;
}
header .tools a:hover, header .tools span:hover {
    color: rgba(255,255,255,0.7);
}
header .tools .cfs span:nth-child(2) {
    font-size: 1.2em;
}
header .tools .cfs span:nth-child(3) {
    font-size: 1.3em;
}
header .tools .sbx, header .tools .userlog {
    display: flex;
    align-items: baseline;
}
header .tools a {
	color: #fff;
	font-size: 1rem;
}

header .logo {
	position: absolute;
	z-index: 2;
	width: 400px;
	height: 400px;
	background-color: #fff;
	border-radius: 100%;
	-moz-border-radius: 100%;
	-webkit-border-radius: 100%;
	transform: translateY(-50%);
	margin: 0px 30px;
	padding: 20px;
	box-sizing: border-box;
	display: flex;
	align-items: center;
	justify-content: center;	
	transition: all 0.5s ease-in;
	box-shadow: 0 0 10px rgba(0,0,0,0.5);
}
@media (max-width:1560px) {
.teaser {
    position: relative;
    width: calc(100% - 20px);
    margin: -100px auto 0px;
    background-color: #fff;
    box-shadow: 0 0 10px rgba(0,0,0,0.5);
    border-radius: 25px;
    min-height: 200px;
}
header > .headerimg h1 span {
	margin-left: 0px;
	padding: 0px;
}
}

@media (max-width:880px) {
header .logo {
    width: 400px;
    height: 400px;
    margin: 0px;
}

header > .headerimg h1 {
	top: 25px;
}

header > .headerimg h1 span {
	padding: 0px;
}

.fullinfoteaser h2 span:first-child {
	font-size: 3rem !important;
}
.teaserwrapper {
    display: block !important;
}
.smallteasers {
	display: flex;
	align-items: flex-end !important;
	justify-content: flex-end !important;
}
.smallteasers:after {
	content: "";
	position: absolute;
	background-color: #fff;
	height: 2px !important;
	width: 100% !important;
	opacity: 1;
}	
.teasericon {
	bottom: 65px;
}
}

@media (min-width:781px) {
#logo img {
    width: 100%;
	min-width: 150px;
	margin-top: 50%;
	max-width: 230px;
}
}
@media (max-width:780px) {
nav.mainnav {
	padding: 10px;
}
header .logo {
	transform: translateY(-32%);
	margin-left: -35px;
}
header .logo {
	width: 300px;
	height: 300px;
}
#logo img {
	max-width: 200px;
	margin-top: 20%;
}
header .tools > * {
    padding: 0px 10px;
    margin: 0px 10px;
    display: flex;
    align-items: baseline;
}
header .tools > * {
    padding: 0px;
    margin: 0px 10px;
    display: flex;
    align-items: baseline;
}
.slogan {
	top: 70%;
}

header > .headerimg h1 {
    top: -80px;
	left: 15px;
}
header > .headerimg h1 span:first-child {
    font-size: 2rem;
	line-height: 4rem;
}
header > .headerimg h1 span:last-child {
    font-size: 1.5rem;
    text-transform: uppercase;
	font-weight: 300;
}
header.large > .headerimg .jobteaserbutton {
    top: -330px;
    background-color: rgba(0, 69, 136, 0.7);
    border-radius: 25px 0px 0px 25px;
    position: absolute;
    font-weight: 500;
    font-family: 'Encode Sans', Serif;
    font-size: 1.2rem;
    right: 0px;
    padding: 10px 40px 30px 30px;
    box-shadow: 0 0 10px rgba(0,0,0,0.5);
}
}

@media (max-width:500px) {
header .logo {
	width: 200px;
	height: 200px;
}
#logo img {
    max-width: 140px !important;
	min-width: 140px !important;
}
.preheader {
	min-height: 100px;
	transition: all 0.5s ease-in;
}

header > .headerimg h1 span:first-child {
    font-size: 2rem;
	line-height: 2rem;
}
.menu {
	top: 40px;
	transition: all 0.5s ease-in;
}
nav .navbutton {
margin-right: 16px;
}
.home .content > #main, .home .content > #member {
     margin-top: 35px !important;
}
.contentimg {
	width: 100%;
}
.pagetitle h2 span:first-child, .pagetitle h1 span:first-child {
    font-size: 2rem !important;
    line-height: 2rem !important;
}
.pagetitle h2 span:last-child, .pagetitle h1 span:last-child {
    font-size: 1.1rem !important;
}
}

@media (max-width:600px) {
.footernav {
	display: block !important;
	height: auto !important;
	margin-bottom: 150px !important;
}
}
@media (max-width:450px) {
.footernav {
    margin-bottom: 165px !important;
}
}

@media (max-width:450px) {
header .tools p {
	display: none !important;
}
header > .headerimg h1 {
    top: -80px !important;
}

.infojobbox a {
	font-size: 1rem !important;
}
nav, .iconnav, .footernav {
    white-space: normal;
    font-size: 14px;
}
}

#logo {
	width: 100%;
	text-align: center;
	display: block;
	position: relative;
}
/* BREADCRUMBS */
.breadwrapper > .wrapper {
    background-color: #004588;
}

nav#breadcrumbs {
    color: #fff;
    position: relative;
    padding: 5px 30px;
    display: flex;
    flex-flow: row wrap;
    align-items: center;
    align-content: center;
    justify-content: space-between;
    font-size: 1rem;
    width: 100%;
    margin: 0;
}
nav#breadcrumbs a {
    color: #fff;
    font-weight: 400;
}
nav#breadcrumbs .ssm {
    font-size: 1.4em;
    cursor: pointer;
}
/* Content */

.content > * {
    position: relative;
}
.content > #main {
    margin-top: 45px;
}
.home .content > #main, .home .content > #member {
    margin-top: 95px;
	margin-bottom: 60px;
    display: flex;
    align-items: flex-start;
    justify-content: space-evenly;
}
@media (min-width: 1200px){
.iconnavi li.empty{
	display: none;
}
}

.empty {
	min-height: 0 !important;
	padding-top: 0 !important;
	padding-bottom: 0 !important;
	margin-top: 0 !important;
	opacity: 0 !important;
	margin-bottom: 0 !important;
}
@media (min-width:1501px){
.contentimg {
    width: 100%;
    height: auto;
	display:flex;
	align-items: stretch;
}
}

@media (max-width:1500px){
.contentimg {
    width: 100%;
    height: auto;
    margin: 0px;
    display: flex;
    align-items: stretch;
}
}

.img {
	object-fit: cover;
}

.contentimg img {
    width: 100%;
 	min-width: 250px;
	min-height: 250px;
    box-sizing: border-box;
	object-fit: cover;
	object-position: center;
}

#top, #bottom {
	width: 100%;
    margin: 0px 60px 0px 0px;
	max-width: 1000px;
	margin-bottom: 40px;
}
.stellenwrapper, .newsteaser {
	margin-left: -30px;
}

.stelle {
	margin-bottom: 50px;
	display: flex;
    align-items: flex-start;
    flex-flow: column;
    justify-content: space-between;
}

.stelle h3 {
	color: #af0c26;
}

table {
	width: 100%;
}

tr {
	vertical-align: top;
}

td {
	min-width: 100px;
}

iframe {
    width: 100%;
}
span.table {
    display: block;
    max-width: 430px;
	margin-bottom: 15px;
}
span.table.cont {
    max-width: 100%;
}
span.table > span{
    display: flex;
    flex-flow: row wrap;
}
span.table > span > * {
    flex: 1 1 90px;
}

span.table > span > *:first-child {
    flex: 1 1 95px;
}
span.table > span > *:last-child {
    flex: 3 1 100px;
}
span.table.cont > span > *:first-child {
    flex: 0 1 100px;
}
span.table.cont > span > *:last-child {
    flex: 4 1 240px;
}

@media (max-width:600px) {
#top, #bottom {
    margin: 0px;
}
.contentimg {
	padding: 30px 0px;
}
.kuratorium .teamsubbox > div img {
	width: 140px;
	transition: all 0.5s ease-in;
}
.kuratorium .teamsubbox .teamitem .teamtxt {
	min-width: 100px;
}
.teamsubbox > div img {
    width: 140px;
	transition: all 0.5s ease-in;
}
.teamtxt h5 {
	color: #af0c26;
    font-size: 1.2rem;
	transition: all 0.5s ease-in;
}

footer {
    margin: 30px;
    text-align: center;
}
}

.pagetitle h2, .pagetitle h1, .fullinfoteaser h2, .infotxtbox h2, .fullmemberteaser h2 {
    font-weight: 500;
    font-family: 'Encode Sans', Serif;
    padding: 0px;
    margin: 0px;    
}

.pagetitle h2 span, .pagetitle h1 span {
    display: block;
	margin-bottom: 5px;
}
.pagetitle h2 span:first-child, .pagetitle h1 span:first-child {
    font-size: 4rem;
	line-height: 3rem;
	color: #af0c26;
	margin-bottom: 15px;
}
.pagetitle h2 span:last-child, .pagetitle h1 span:last-child {
    font-size: 1.6rem;
    text-transform: uppercase;
    color: #5d5d5d;
	font-weight: 300;
}

.stelle .pagetitle h2 span:first-child, .pagetitle h1 span:first-child {
    font-size: 2rem;
    line-height: 3rem;
    color: #af0c26;
}

strong {
	color: #004588;
}

.bannerteaser {
	display: flex;
	box-sizing: border-box;
    flex-flow: row wrap;
	width: 100%;
	min-height: 200px;
	padding: 20px 75px;
	background-color: #af0c26;
	position: relative;
}

@media (max-width: 600px) {

header.large {
    height: 60vh;
    min-height: 600px;
}
	
.iconnavi .box1 {
	padding: 10px;
	flex: 1 1 100%;
}
nav.iconnav > ul li .sub {
    position: absolute;
    height: auto;
    z-index: 2;
    transition: all 0.5s ease-in;
    padding: 10px;
    background-color: #f4f4f4;
    width: calc(100% - 60px);
    top: 20px;
    left: 20px;
	opacity: 0;
}
nav.iconnav ul li > a, nav.iconnav ul li > span {
    transition: height 0.5s ease-in;
    display: block;
    margin: 0;
    color: #af0c26;
    font-size: 1.0rem;
}
.home .content > #main, .home .content > #member {
	margin-bottom: 0px;
}

.bannerteaser {
    margin-bottom: 0px;
    padding: 0px 15px;
}
.iconnavi li:after {
	width: calc(100% - 40px)!important;
    height: 2px !important;
    margin-top: -35px;
    left: 20px !important;
}
}

@media (max-width: 650px) {
.fullfooternav {
    padding: 0px !important;
}
}

.iconnav {
	white-space: normal;
	text-transform: none;	
	padding: 0px !important;
}

.iconnavi {
    margin: 0 auto;
    width: 100%;	
}
.iconnavi li:after {
	content: "";
	position: absolute;
	left: 0px;
	background-color: #b9b9b9;
	height: calc(100% - 60px);
	width: 2px;
	top: 35px;
	opacity: 1
}
.iconnavi li:first-of-type:after/*, .iconnavi li.hw:nth-of-type(odd):after*/{
	opacity: 0;
}
.iconnav li ul li:after {
	opacity: 0;
}

.iconnavwrapper {
	display: flex;
	align-items: baseline;
	padding: 30px 10px;
}

.iconnavwrapper span:first-child {
	color: #af0c26;
}
.iconnavwrapper span:last-child {
	color: #5d5d5d;
	font-size: 1rem;
}
@media (min-width:601px){
.iconnavwrapper {
	display: flex;
	align-items: baseline;
	padding: 30px 10px;
}
}
@media (max-width:600px) {
.iconnavwrapper {
	min-width: 250px;
	width: 100%;
}
}


@media (min-width:1501px) {
nav.iconnav > ul li .sub {
	position: absolute;
	height: auto;
	z-index: 2;
	transition: all 0.5s ease-in;
	padding: 20px;
	background-color: #f4f4f4;
	width: calc(100% - 60px);
	top: calc(50% - 80px);
	left: 20px;
	opacity: 0;
}
.iconnavwrapper .icon {
	color: #af0c26;
	font-size: 2rem;
	padding: 20px;
	position: absolute;
	top: 20px;
	right: 0px;
}
}
@media (min-width:601px) and (max-width:1500px) {
nav.iconnav > ul li .sub {
    position: absolute;
    height: auto;
    z-index: 2;
    transition: all 0.5s ease-in;
    padding: 20px;
    background-color: #f4f4f4;
    width: calc(100% - 60px);
    top: calc(50% - 68px);
    left: 0px;
    opacity: 0;
}
.iconnavwrapper .icon {
	color: #af0c26;
	font-size: 2rem;
	padding: 20px;
	position: absolute;
	top: 20px;
	right: 0px;
}
}

@media (max-width:600px) {
.iconnavwrapper .icon {
	color: #af0c26;
	font-size: 2rem;
	padding: 20px;
	position: absolute;
	top: 0px;
	right: 0px;
}
}

nav.iconnav > ul li .sub:hover {
	opacity: 1;
}

nav.iconnav ul li > a, nav.iconnav ul li > span {
    transition: height 0.5s ease-in;
    display: block;
    margin: 0 15px;
    color: #af0c26;
	font-size: 1.0rem;
}

.infowrapper {
	flex: 3 1 300px;
}

.teaserwrapper {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	Text-align: left;	
	margin: 60px 0px;
}

.smallteasers {
	display: flex;
	align-items: flex-start;
	justify-content: end;
	position: relative;
	max-height: 180px;
}

.smallteasers a {
	color: #fff;
	font-weight: 500;
	font-size: 1.5rem;
}
.smallteasers a:after {
	position: relative;
	margin-top: 10px;
	display: block;
	content: "";
	height: 2px;
	opacity: 0;
	background-color: #fff;
	width: 100%;
	transition: all 0.5s ease-in;
}

.smallteasers a:hover::after {
	opacity: 1;
}

.smallteasers i {
	color: #fff;
	font-size: 2rem;
}
.smallteasers p {
	color: #fff;
}

.smallteasers:after {
	content: "";
	position: absolute;
	background-color:#b9b9b9;
	height: 100%;
	width: 2px;
	opacity: 1;
	right: 0px;
}
.smallteasers:last-child:after {
	opacity: 0;
}

.teasericon {
	position: relative;
	left: -40px;
	padding: 20px;
}

.fullinfoteaser h2 span {
    display: block;
	margin-bottom: 5px;	
}

.fullinfoteaser h2 span:first-child {
    font-size: 4rem;
	line-height: 6rem;
	color: #fff;
	text-align: center;
}
.fullinfoteaser h2 span:last-child {
    font-size: 1.6rem;
    text-transform: uppercase;
    color: #fff;
	text-align: center;
	font-weight: 300;

}

.infocontbox {
	display: flex;
	flex: 1 1 350px;
	border-radius: 25px;
	box-shadow: 0 0 10px rgba(0,0,0,0.5);
	margin-top: -45px;
	margin-bottom: -45px;
	overflow: hidden;
	max-height: 600px;
}

.infocontwrapper {
	width: 100%;
	display: flex;
	flex-flow: row wrap;
	align-items: stretch;
	align-content: stretch;
}
.infotxtbox {
	display: flex;
	align-items: center;
	justify-content: center;
	background-color: #fff;
	padding: 20px;
	width: calc(100% - 40px);
	margin: 0 auto;
	text-align: center;
	min-height: 200px;
	flex: 1 1 100%;
	
}
.infotxtbox h2 span {
    display: block;
	margin-bottom: 5px;
}

.infotxtbox h2 span:first-child {
    font-size: 4rem;
	line-height: 6rem;
	color: #af0c26;
}
.infotxtbox h2 span:last-child {
    font-size: 1.6rem;
    text-transform: uppercase;
    color: #004588;
	font-weight: 300;

}

.columnwrapper {
	flex: 1 1 100%;
}

.infojobbox {
	background-color: #004588;
	padding: 20px;
	width: calc(50% - 40px);
	display: flex;
	align-items: flex-start;
	justify-content: center;
	flex-flow: column;
}

.infoimgbox {
	display: flex;
	align-items: stretch;
	width: 50%;
}

.infoimgbox img {
	width: 100%;
	height: 100%;
	object-fit: cover;	
}

.infojobbox a {
	text-transform: uppercase;
	font-size: 1.3rem;
	color: #fff;
	padding: 10px 0px;
	text-align: left;
}

.infojobbox a:after {
	position: relative;
	margin-top: 10px;
	display: block;
	content: "";
	height: 2px;
	opacity: 0;
	background-color: #fff;
	width: 100%;
	transition: all 0.5s ease-in;
}
.infojobbox a:hover:after {
	opacity: 1;
}

.memberteaser {
	display: flex;
	align-items: flex-start;
}

.fullmemberteaser {
	box-sizing: border-box;
	width: 100%;
	min-height: 200px;
	margin: 100px auto;
	padding: 0px 60px;
}
.fullmemberteaser h2 span {
    display: block;
	margin-bottom: 5px;
}
.fullmemberteaser h2 span:first-child {
    font-size: 4rem;
	line-height: 6rem;
	color: #af0c26;
}
.fullmemberteaser h2 span:last-child {
    font-size: 1.6rem;
    text-transform: uppercase;
    color: #5d5d5d;
	font-weight: 300;
}

.memberbuttonwrapper {
	margin: 50px -15px;
}

.memberbutton {
	background-color: #004588;
	color: #fff;
	border-radius: 10px;
	text-transform: uppercase;
	transition: all 0.5s ease-in;
	text-align: center;
	margin: 15px;
}

.memberbutton:hover {
	background-color: #af0c26;
	color: #fff !important;
}

.memberbutton a {
	color: #fff;
}
.team {
	margin: 0px;
}

.teamtxt ul {
	margin: 0px;
	list-style: none;
}

.teamwrapper {
	width: 100%;
}
.teamwrapper ul li {
	background: none;
}

.teamwrapper h4 {
	color: #af0c26;
    font-weight: 500;
    font-family: 'Encode Sans', Serif;	
}
.teamsubbox {
	display: flex;
	margin: 10px 0;
	box-sizing: border-box;
	flex-flow: row wrap;
}
.teamsubbox > div {
	display: flex;
	flex: 3 1 300px;
	align-items: center;
	margin: 10px auto;
}

@media (min-width:601px){
.teamsubbox > div img {
	display: block;
	width: 200px;
	transition: all 0.5s ease-in;
}
.teamsubbox .teamitem .teamtxt {
	min-width: 150px;
}
.teamtxt h5 {
	color: #af0c26;
	font-size: 1.7rem;
	transition: all 0.5s ease-in;
}
}
.teamsubbox  h5 {
	font-size: 1.3rem;
}
.swrapper .teamsubbox > div img {
	display: block;
	width: 150px;
}
.swrapper .teamsubbox h5 {
	font-size: 1.2rem;
}

.teamtxt {
	padding: 0px 20px;
}


.teamsubbox > div .teamitem {
	padding: 10px 0 10px;
}
.teamsubbox > div.empty {
    margin-bottom: 0;
    margin-top: 0;
}

/* Sidebar */

.right {
	background-color: #f4f4f4;
}

.subnav .heading h2, .subnav .heading a {
	color: #af0c26;
	transition: color 0.5s ease-in;
	font-weight: 400;
}
.subnav .heading a:hover {
	color: #004588;
}
.swrapper .subnav li:not(:first-child) {
	padding-left: 15px;
}

.swrapper .subnav li:not(:first-child):before {
	position: relative;
	content: "";
	border-radius: 100%;
	width: 5px;
	height: 5px;
	background-color: #5d5d5d;
	display: block;
	top: 12px;
	left: -15px;
}

.subnav li a {
	color: #004588;
	transition: color 0.5s ease-in;
}

.subnav li a:hover {
	color: #af0c26;
	font-weight: 400;
}

.subnav a.active, .subnav a.active:hover {
    font-weight: 600;
}

.newsitem h2, .newsitem h2 a {
	color: #af0c26;
	font-weight: 400;
	transition: color 0.5s ease-in;
}

.newsitem h3 {
	font-size: 1rem;
}


/* Formular */
form {
    text-align: left;
    display: flex;
    flex-flow: row wrap;
    width: auto;
    padding: 0px;
}
.formbox {
    margin: 0px;
    position: relative;
}
form .form-field, form .form-spacer, .form-actions.secondary-accent, form > label {
    display: block;
    width: 100%;
    margin: 0px 0px 20px;
    padding: 0px 20px;
}
form .form-field.empty {
    margin-bottom: 0;
    margin-top: 0;
    padding-bottom: 0;
    padding-top: 0;
}
form .form-spacer {
    margin-top: 10px;
}
form .form-field {
    box-sizing: border-box;
}
form .form-field.half {
    flex: 1 1 350px;
}
form .form-field.full {
    flex: 1 1 100%;
}
form .form-field .form-label {
    margin-bottom: 5px;
}
form .form-field.default .form-data {
    display: none;
}
.form-input-wrapper, .form-input-wrapper input, form-select-wrapper, select  {
    width: 100%;
    max-width: none;
}
form .checkboxes {
    display: block;
}
form .checkboxes > label {
    padding: 0;
    margin: 0;
}
.button, .dz-button {
	background-color: #004588;
	color: #fff;
	border-radius: 15px;
    font-weight: 500;
    font-family: 'Hind', Serif;
    font-size: 1rem;
    padding: 10px 30px;
	cursor: pointer;
    transition: background-color 0.5s ease-in;
	border: none;
}

.button:hover, .dz-button:hover {
	background-color: #af0c26;
}

.dz-button strong {
	color: #fff;
}

.buttons {
    flex: 1 1 100%;
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    box-sizing: border-box;
    align-self: flex-end;
    margin: 40px 0;
}
.buttons button, .buttons .button {
    flex: 1 1 150px;
    margin: 10px;
	border: none;
}
a.buttonbox, p.buttonbox, span.buttonbox {
    text-transform: uppercase;
    display: flex;
    margin: 20px 0;
    justify-content: flex-start;
    align-items: center;
}
a.buttonbox > span:not(.button), p.buttonbox > span:not(.button), span.buttonbox > span:not(.button) {
    background-color: #004588;
    color: #fff;
    padding: 0.7em 1em;
    margin-left: -0.5em;
    margin-right: -30px;
    z-index: 0;
    position: relative;
    flex: 1 1;
}
a.buttonbox > .button, p.buttonbox > .button, span.buttonbox > .button {
    z-index: 1;
    margin-left: -0.4em;
}
.form-textarea-wrapper, .form-textarea-wrapper textarea {
    width: 100%;
}
.form-textarea-wrapper textarea {
    min-width: 100%;
    max-width: 100%;
    min-height: 200px;
    resize: none;
}
input, textarea, button {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    font-family: 'Hind', sans-serif;
	cursor: pointer;
} 
input, textarea, .trysubmit .touched:required:valid, select {
    border: none;
    padding: 10px;
    font-size: 1rem;
    box-sizing: border-box;
    font-weight: 300;
    background-color: #ddd;
    border-radius: 0px;
    color: inherit;
    transition: background-color 0.5s ease-in, color 0.5s ease-in;
    box-shadow: none;
	border: 1px solid #ddd;
}
.trysubmit :required:invalid {
    background-color: #b83838;
}
form.trysubmit input[type='checkbox']:required:invalid + label,
form.trysubmit input[type='radio']:required:invalid +label {
    color: #f83838;
}
input:focus, textarea:focus {
    background-color: #fff;
	border: 1px solid #5d5d5d;
}
input[readonly="readonly"] {
    cursor: not-allowed;
    background-color: rgba(255,255,255,0.1);
    color: #af0c26;
}
.radio {
	display: block;
}
form input[type='checkbox'],
form input[type='radio'] {
  width:auto;
  float:left;
  margin-right: .75em;
  background:transparent;
  border:none;
}

form input[type='checkbox']:checked,
form input[type='checkbox']:not(:checked),
form input[type='radio']:checked,
form input[type='radio']:not(:checked) {
  background: transparent;
  position: absolute;
  visibility: hidden;
  margin:0;
  padding:0;
}

form input[type='checkbox'] + label,
form input[type='radio'] + label {
    cursor: pointer;
    display: block;
}

form input[type='checkbox']:checked + label::before,
form input[type='checkbox']:not(:checked) + label::before,
form input[type='radio']:checked + label::before,
form input[type='radio']:not(:checked) + label::before {
    content: '' !important;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    width: 17px;
    height:17px;
    border-radius: 50%;
    position: relative;
    top:-5px;
    background-color: #a6a5a5;
    background-image: url(../img/check.png);
    margin-right: 0.3rem;
    background-size: 0%;
    background-repeat: no-repeat;
    background-position: center;
    transition: all .2s ease-in;
    text-align: center;
    font-size: 2rem;
    line-height: 0.5em;
    text-indent: 0px;
    border: none;
}

form input[type=radio]:checked + label::before,
form input[type=radio]:not(:checked) + label::before {
  border-radius: 50%;
}

form input[type='checkbox']:hover  + label::before,
form input[type='radio']:hover  + label::before {
    background-color: #004588;
    background-size: 65%;
    background-repeat: no-repeat;
    background-position: center;
    transition: all .2s ease-in;
}

form input[type='checkbox']:checked  + label::before,
form input[type='radio']:checked  + label::before {
    background-color: #004588;
    background-size: 70%;
    background-repeat: no-repeat;
    background-position: center;
    transition: all .2s ease-in;
}
form .stsel > .form-data {
    -webkit-columns: 130px;
    -moz-columns: 130px;
    columns: 130px;
    column-count: auto;
    -webkit-column-gap: 40px;
    -moz-column-gap: 40px;
    column-gap: 40px;
    -webkit-column-count: 2;
    -moz-column-count: 2;
    column-count: 2;
    column-fill: balance;
}
form .stsel > .form-data label {
    -webkit-column-break-inside: avoid;
    page-break-inside: avoid;
    break-inside: avoid;
    display: inline-block !important;
    padding-left: 21px;
}
#form-result {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
    width: 100%;
    height: 100%;
    opacity: 0;
    pointer-events: none;
    transition: all 0.5s ease-in;
    z-index: 2;
    backdrop-filter: blur(5px);
}
#form-result.shownotice {
    opacity: 1;
    pointer-events: all;
}
div.notices {
    position: relative;
    height: 100px;
    padding: 0;
    margin: 0;
    z-index: 2000;
    width: calc(100% - 20px);
    background-color: transparent;
    box-sizing: border-box;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
    top: 0;
    left: 0;
}
div.notices p > i {
    display: block;
    font-size: 4em;
    margin: -0.3em 0 0.3em;
}
#form-result.shownotice div.notices p > i.fa-check-circle {
    animation: bubb 5s linear;
}

#form-result.shownotice div.notices p > i.fa-circle-notch {
    animation: turn 1s linear infinite;
}
#form-result.shownotice div.notices p > i.fa-times-circle {
    animation: bubb2 3s linear infinite;
}
@keyframes bubb {
    0% {transform: scale(1);}
    7% {transform: scale(1);}
    10% {transform: scale(1.1);}
    13% {transform: scale(1);}
    16% {transform: scale(1.1);}
    19% {transform: scale(1);}
    100% {transform: scale(1);}
}
@keyframes bubb2 {
    0% {transform: translate(0);}
    7% {transform: translate(0);}
    10% {transform: translate(1rem,0rem);}
    12% {transform: translate(-1rem,0rem);}
    13% {transform: translate(0);}
    16% {transform: translate(2rem, 0);}
    18% {transform: translate(-2rem, 0);}
    19% {transform: translate(0);}
    20% {transform: scale(1);}
    35% {transform: scale(1.2);}
    40% {transform: scale(1);}
    100% {transform: translate(0);}
}
@keyframes turn {
    0% {transform: rotate(0deg);}
    100% {transform: rotate(360deg);}
}
body #form-result {
    background: rgba(255, 255, 255, 0.9);
}
body #form-result div.notices {
    background: transparent;
}
#closeform {
    position: absolute;
    bottom: 50px;
    right: 50px;
    z-index: 10000;
    cursor: pointer;
    font-size: 3rem;
}
div.notices.yellow {
    border-left: 0px solid #ba9800 !important;
    color: #d89b26 !important;
}
div.notices.red {
    border-left: 0px solid #f14101 !important;
    color: #a72525 !important;
}
div.notices.blue {
    border-left: 0px solid #005498 !important;
    color: #2572a7 !important;
}
div.notices.green {
    border-left: 0px solid #1d4774 !important;
    color: #a9ca32 !important;
}
div.notices p {
    margin: 0 !important;
}

/* Lightbox */
img.pu {
    cursor: zoom-in;
	border: 2px solid #fff;
	transition: all 0.5s ease-in;
	min-width: 250px;
	width: 48%;
}

img.pu.large {
    cursor: zoom-in;
	border: 2px solid #fff;
	transition: all 0.5s ease-in;
	min-width: 250px;
	width: 100%;
}

img.pu:hover {
	border: 2px solid #af0c26;

}

.pu-imagebox {
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    margin: auto;
    max-width: 100vw;
    max-height: 100vh;
    background-color: rgba(0,0,0,0.7);
    z-index: 2000;
    width: auto;
    height: auto;
    padding: 40px;
    display: flex;
    flex-flow: column;
    align-items: center;
    justify-content: space-between;
    box-sizing: border-box;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.5s ease-in;
}
.pu-imagebox.pu-show {
    pointer-events: all;
    opacity: 1;
    transition: opacity 0.5s ease-in;
}
.pu-sign {
    color: #fff;
    cursor: pointer;
    font-size: 3rem;
    position: absolute;
    -ms-user-select: none;
    -moz-user-select: none;
    -webkit-user-select: none; 
    opacity: 0.7;
    transition: opacity 0.5s ease-in;
}
.pu-sign:hover {
    opacity: 1;
}
.pu-arr {
    top: 0;
    bottom: 0;
    margin: auto;
    height: 1em;
}
.pu-arr#pu-left {
    left: 20px;
}
.pu-arr#pu-right {
    right: 20px;
}
.pu-close {
    top: 15px;
    right: 20px;
}
.pu-imagewrapper {
    position: relative;
    height: calc(100% - 80px);
    width: calc(100% - 80px);
    margin: 0 auto;
}
.pu-imagewrapper img {
    max-width: 100%;
    max-height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto;
    animation: pu-fadein 0.5s ease-in;
}
@keyframes pu-fadein {
    0% {opacity: 0;}
    100% {opacity: 1;}
}
.pu-text {
    color: #fff;
    font-size: 1.5rem;
    text-align: center;
}

/* FOOTER */
.prefooter {
	position: relative;
	display: flex;
	box-sizing: border-box;
    flex-flow: row wrap;
	width: 100%;
	min-height: 200px;
	margin-bottom: 100px;
	padding: 0px 60px;
	background-color: #e5e5e5;
}
.fullfooternav {
	display: flex;
	width: 100%;
	padding: 30px;
	justify-content: center;
	align-items: stretch;
}

.footerwrapper {
	flex: 3 1 350px;
	display: block;
}

.footernav {
	display: block;
	font-size: 0.8rem;
	padding: 0px;
}

@media (max-width: 1100px) {
.footercontbox {
    padding: 40px 0px;
}
.footernav {
	display: flex;
	font-size: 0.8rem;
	padding: 0px;
}
}

@media (max-width:1250px)  {
.footernav {
	height: 440px;
}
}

@media (max-width: 1100px) {
.fullfooternav {
    display: block;
}
}

@media (max-width: 800px) {
header {
    position: relative;
    color: #fff;
    height: 70vh;
    min-height: 450px;
    display: flex;
    flex-flow: column;
}
.prefooter {
    padding: 15px;
}
header > .headerimg .jobteaserbutton {
    top: -15px;
}
.footerwrapper {
    margin-bottom: 25px;
}
}

nav.footernav ul li > a, nav.footernav ul li > span {
    transition: color 0.5s ease-in;
    display: block;
    margin: 0 15px;
    color: #000;
}
nav.footernav ul li > a:hover {
    transition: color 0.5s ease-in;
    display: block;
    margin: 0 15px;
    color: #af0c26;
    font-weight: 400;
}

nav.footernav .footernavi {
    text-align: left;
    -webkit-columns: 250px;
    -moz-columns: 250px;
    columns: 250px;
 	width: 100%;
    -webkit-column-gap: 10px;
    -moz-column-gap: 10px;
    column-gap: 10px;
    -webkit-column-count: auto;
    -moz-column-count: auto;
    column-count: auto;
    column-fill: balance;
} 
nav.footernav .footernavi > li {
	break-inside: avoid;
}


nav.footernav > ul li .subnav {
    display: block;
    position: relative;
    padding: 0 18px;
} 

nav.footernav > ul li .subnav li {
    height: auto;
    display: flex;
    align-items: center;
    justify-content: flex-start;
	text-transform: none;
	font-weight: 300;
}

.footernav .subnav li:before {
	position: relative;
	content: "";
	border-radius: 100%;
	width: 5px;
	height: 5px;
	background-color: #5d5d5d;
	display: block;
}

.footercontbox {
	display: flex;
	flex: 1 1 350px;
	justify-content: flex-start;
	align-items: center;
    background-image: url('../img/kontakt.jpg');
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center center;
	border-radius: 25px;
	box-shadow: 0 0 10px rgba(0,0,0,0.5);
	margin-top: -65px;
	margin-bottom: -65px;
	width: 100%;
}

.footercontwrapper {
	border-radius: 0px 25px 25px 0px;
	width: 50%;
	min-width: 300px;
}

.footertxtbox {
	background-color: #004588;
	color: #fff;
	padding: 20px;
	border-radius: 0px 25px 0px 0px;
}
.footertxtbox a {
	color: #fff;
	transition: all 0.5s ease-in;
}
.footertxtbox a:hover {
	color: rgba(255,255,255,0.8);
	transition: all 0.5s ease-in;
}
.footercontbutton {
	background-color: #af0c26;
	padding: 20px;
	border-radius: 0px 0px 25px 0px;
	text-align: center;
	transition: all 0.5s ease-in;
}

.footercontbutton a {
	color: #fff;
	text-transform: uppercase;
	text-align: center;
	transition: all 0.5s ease-in;
}
.footercontbutton a:hover  {
	color: rgba(255,255,255,0.7);
}


footer {
    display: flex;
    align-content: center;
    justify-content: center;
    margin: 30px auto;
}

@media (max-width: 500px){
.box1, .box2, .box3, .box4, .box5, .boxfull {
    padding: 25px;
} 
}
.jspu {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    max-height: 100vh;
    background-color: rgba(255,255,255,0.5);
    z-index: 100000;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.5s ease-in-out;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 20px;
    box-sizing: border-box;
}
@media (max-height: 1000px) and (orientation: landscape){
.jspu {
    overflow-y: scroll;
    scrollbar-width: thin;
}
}
.jspuopen .jspu {
    opacity: 1;
    pointer-events: all;
}
.jspu .jspu-box {
    width: 70%;
    height: auto;
    max-width: 900px;
    position: relative;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto;
    padding: 20px;
    background-color: rgb(175,12,38);
    border-radius: 10px;
    z-index: 1000;
}
.jspu .jspu-box .jspu-content {
    position: absolute;
    bottom: 0;
    left: 0;
    padding: 30px;
    padding-bottom: calc(3rem + 20px);
    background-color: rgba(130, 187, 37,0.6);
    width: 100%;
}
.jspu .jspu-box .jspu-content > * {
    margin-top: 0;
    color: rgb(175,12,38);
}
.jspu .jspu-box img {
    display: block;
    width: 100%;
    height: auto;
}
.jspu .jspu-button {
    display: block;
    position: absolute;
    color: #fff;
    text-transform: uppercase;
    padding: 10px;
    background-color: #004588;
    border: 5px solid rgb(175,12,38);
    border-radius: 3px;
    font-size: 1.4rem;
    bottom: 30px;
    left: 30px;
    box-shadow: 0 0 15px rgba(0, 0, 0, 0.5)
}
.jspu .jspuclose {
    position: absolute;
    right: 0px;
    top: 0px;
    font-size: 2rem;
    line-height: 1;
    cursor: pointer;
    color: #fff;
    background-color: #af0b27;
    padding: 10px;
    width: calc(1em + 10px);
    height: calc(1em + 10px);
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 100%;
}

.contact-block {

}

.contact-block__content {
  max-width: 800px;
  margin: 0 auto;
  border-radius: 30px;
  padding: 50px 60px;
  width: 100%;
  background: #af0c26;
  color: #fff;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.5);
  margin-bottom: 100px;
}

.contact-block__content button,
.v-btn {
    background-color: #fff;
    color: #af0c26;
    text-align: center;
    padding: 10px;
    text-transform: uppercase;
    font-size: 0.8rem;
    width: 100%;
    display: block;
    border-radius: 10px;
    transition: all 0.3s ease;
    margin-top: 20px;
}

.contact-block__content button:hover,
.v-btn:hover {
  box-shadow: 0px 5px 10px 0px rgba(0, 0, 0, 0.4);
}

.v-btn {
  background: #af0c26;
  color: #fff;
}

.input-sec {
  font-size: 18px;
  margin-bottom: 15px;
  width: 100%;
}

.input-sec label {
  margin-bottom: 10px;
  color: #fff;
  font-size: 18px;
  font-family: 'Source Sans 3';
  margin-bottom: 10px;
}

.input-sec input[type="text"], .input-sec input[type="email"], .input-sec select {
  background: #ffffff;
  color: #000;
  font-size: 18px;
  border-radius: 10px;
  padding: 12px 20px;
  margin: 8px 0px;
  width: 100%;
  position: relative;
  box-sizing: border-box;
}

body {
  scroll-behavior: smooth;
}

.contact-block__content h2 {
  margin-top: 0;
        font-size: 4rem;
        line-height: 1.2;
        color: #fff;
        text-align: center;
        margin-bottom: 20px;
}

@media (max-width:768px){
  .contact-block__content {
    max-width: 80vw;
    padding: 40px 20px;
  }
  .contact-block__content h2 { 
    font-size: 32px;
  }
}

