@font-face {
	font-family: "KlavikaWebBasicRegular";
	src: url("../Fonts/Klavika/KlavikaWebBasicRegular.eot") format("eot"),
         url("../Fonts/Klavika/KlavikaWebBasicRegular.woff") format("woff");
}
@font-face {
    font-family: "KlavikaWebBasicLight";
    src: url("../Fonts/Klavika/KlavikaWebBasicLight.eot") format("eot"),
         url("../Fonts/Klavika/KlavikaWebBasicLight.woff") format("woff"),
         url("../Fonts/Klavika/KlavikaWebBasicLight.woff2") format("woff");
}
@font-face {
    font-family: "KlavikaWebBasicMedium";
    src: url("../Fonts/Klavika/KlavikaWebBasicMedium.eot") format("eot"),
         url("../Fonts/Klavika/KlavikaWebBasicMedium.woff") format("woff"),
         url("../Fonts/Klavika/KlavikaWebBasicMedium.woff2") format("woff");
}
@font-face {
    font-family: "KlavikaWebBasicLightItalic";
    src: url("../Fonts/Klavika/KlavikaWebBasicLightItalic.eot") format("eot"),
         url("../Fonts/Klavika/KlavikaWebBasicLightItalic.woff") format("woff"),
         url("../Fonts/Klavika/KlavikaWebBasicLightItalic.woff2") format("woff");
}
@font-face {
    font-family: "KlavikaWebBasicBoldItalic";
    src: url("../Fonts/Klavika/KlavikaWebBasicBoldItalic.eot") format("eot"),
         url("../Fonts/Klavika/KlavikaWebBasicBoldItalic.woff") format("woff"),
         url("../Fonts/Klavika/KlavikaWebBasicBoldItalic.woff2") format("woff");
}


html {
	scroll-behavior: smooth;
}

body {
	margin: 0;
    min-width: 320px;
}

#top.wrapper {
    max-width: 1920px;
    min-width: 320px;
    position: relative;
}

* {
	font-family: KlavikaWebBasicLight, Helvetica, Verdana, Arial;
	font-size: 16px;
}
/* Focus styles */
*:focus {
    box-shadow: 0 0 1.5px 2px #FF480C;
}
.accordion .btn-link:focus {
    box-shadow: 0px 3px 2px -1px #FF480C;
    z-index: 9;
    position: relative;
}
.orangeFarbverlauf *:focus {
    box-shadow: 0 0 1.5px 2px rgb(0, 67, 82);
}
.sitemap a,
.navbar__logo-container a,
.news-homepage-list-img-wrap a,
.news-list-more a,
.news-list-view a {
    display: inline-block;
}
.externalimagelinks__list-element a {
    display: block;
}
body h1, body h2, body h3, body h4, body h5, body h6,
body h1 *, body h2 *, body h3 *, body h4 *, body h5 *, body h6 * {
    font-weight: normal;
    color: rgb(0, 67, 82);
    font-size: inherit;
    font-family: KlavikaWebBasicLight, Helvetica, Arial;
    line-height: 1em;
    margin-bottom: 1rem;
}
body h1 {
	font-size: 3.5rem;
}
body h2 {
	font-size: 2.5rem;
}
body h3,
body h3 * {
	font-size: 1.4rem;
    font-family: KlavikaWebBasicMedium;
    line-height: 1.8rem;
}
body h4 {
	font-size: 1em;
}
body h5 {
	font-size: 0.83em;
}
body h6 {
	font-size: 0.67em;
}

/* Testserver-Title */
.testserver-title {
    position: fixed;
    height: 80px;
    width: 100%;
    background-color: red;
    z-index: 9999999999;

    display: flex;
    text-align: center;
    justify-content: center;
    align-items: center;
    color: yellow;
    font-size: 50px;
}

/* Status-Klassen */
.setFieldVisible {
    display: flex !important;
}
.setFieldHidden {
    display: none !important;
}

/* TYPO3 Header Content Element */
.frame header h1 {
    margin-bottom: 0;
    margin-top: 0.3em;
}

p,
p *,
li {
    font-family: Arial;
    letter-spacing: 0.025em;
    color: #333333;

    overflow-wrap: break-word;
    word-wrap: break-word;
    -webkit-hyphens: auto;
    -ms-hyphens: auto;
    -moz-hyphens: auto;
    hyphens: auto;
}

/* Aufzählungen */
ol {
    counter-reset: item;
}

ol > li {
    counter-increment: item;
}

ol ol > li {
    display: block;
}

ol ol > li:before {
    content: counters(item, ".") ". ";
    margin-left: -34px;
}


ol > li.no-list-style {
    counter-increment: item-1 !important;
}
ol ol > li.no-list-style:before {
    content: "";
}
li.no-list-style {
    list-style-type: none !important;
}


ul {
    list-style-type: square;
}


/* Leichte Sprache */
.leichtesprache {
    line-height: 2.2em !important;
}
.leichtesprache .ce-border img, .leichtesprache .ce-border iframe {
    border: 1px solid rgb(2, 104, 126);
}

/* BITE Bewerbermanager-Tool */
.frame .bite-container .bite-title * {
    font-family: Arial;
}
.frame .bite-no-results,
.frame .bite-no-results *,
.bite-no-results,
.bite-no-results * {
    font-family: Arial;
    font-size: 18px;
    color: rgb(0, 67, 82);
}


/*********/
/* Icons */
/*********/

/* Phone Icon */
.phone::before {
    font-family: FontAwesome;
    content: "\f095";
    padding-right: 11px;
    text-decoration: none;
    display:inline-block;
}
.phone:hover::before,
.mail:hover::before,
.fax:hover::before {
    text-decoration: none ;
}

    /* Mail Icon */
.mail::before {
    font-family: FontAwesome;
    content: "\f0e0";
    padding-right: 8px;
    font-size: 15px;
    display:inline-block;
}

/* Fax Icon */
.fax::before {
    font-family: FontAwesome;
    content: "\f1ac";
    padding-right: 8px;
    font-size: 15px;
    display:inline-block;
}

/*****************/
/* TABLES IN RTE */
/*****************/
.table-responsive table {
    width: 100%;
    min-width: 600px;
    border-collapse: collapse;
}
.table-responsive table,
.table-responsive td,
.table-responsive th {
    border: 1px solid #004352;
}
.table-responsive td,
.table-responsive th {
    padding: 15px;
    min-width: 150px;
}

.table-responsive th {
    background: #004352;
}
.table-responsive th * {
    color: #fff;
}
.table-responsive tbody tr:nth-child(odd) {
    background-color: #fff;
}
.bright-text .table-responsive tbody tr:nth-child(odd) * {
    background-color: #fff;
    color: #000 !important;
}



/**
Responsive images
 */
img {
    max-width: 100%;
    height: auto;
}

img.block {
	display:block;
}

div, img {
	margin:0;
	padding:0;
	border:0;
}

main a,
main a:hover {
    text-decoration: none !important;
    color: rgb(2, 104, 126) !important;
    font-weight: bold;
}
main a:hover {
    text-decoration: underline !important;
}

p a {
    overflow-wrap: break-word;
    word-wrap: break-word;
    -webkit-hyphens: auto;
    -ms-hyphens: auto;
    -moz-hyphens: auto;
    hyphens: auto;
}

/* Die Schriftfarbe von Telefonnummern wird beim IPad blau angezeigt, hiermit wird es zurückgesetzt */
a[x-apple-data-detectors] {
    color: inherit !important;
    text-decoration: none !important;
    font-size: inherit !important;
    font-family: inherit !important;
    font-weight: inherit !important;
    line-height: inherit !important;
}

.wrapper {
	padding: 2vw 2vw 0;
}

#einspaltig {
    overflow: hidden;
}
.wrapper > main {
	min-height: 15vw;
    background: rgb(230,246,252); /*Old browsers */
    background: -moz-linear-gradient(-45deg, rgb(230,246,252) 0%, rgb(195,215,223) 100%);  /*FF3.6-15 */
    background: -webkit-linear-gradient(-45deg, rgb(230,246,252) 0%,rgb(195,215,223) 100%);  /*Chrome10-25,Safari5.1-6 */
    background: linear-gradient(135deg, rgb(230,246,252) 0%,rgb(195,215,223) 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#e6f6fc', endColorstr='#c3d7df',GradientType=1 ); /* IE6-9 fallback on horizontal gradient */
}


/*.homepage-headline .headline-background {
    background: url(/fileadmin/images/title.png) no-repeat center;
    background-size: contain;
    width: 650px;
    height: 250px;
    text-align: center;
}*/
.homepage-headline .headline-background {
    background: url(/fileadmin/images/title.png) no-repeat center;
    background-size: contain;
    /* width: 60vw; */
    /* height: 20vw; */
    text-align: center;
    margin-left: -10vw;
    /* min-width: 600px; */
    /* min-height: 300px; */
    padding: 6vw 10vw 8vw;
}

.homepage-headline .headline {
    /* max-width: 26rem; */
    /* min-width: 26rem; */
    /* display: inline-block; */
    padding-left: 4rem;
    font-family: KlavikaWebBasicLightItalic;
    white-space: nowrap;
    margin-bottom: 0;
    position: relative;
    top: -3vw;
    color: #fff;
    text-shadow: 0 -1px 1px #666666, 0 1px 1px #FFFFFF;
    /* display: block; */
    font-size: 3.5vw;
}
/*.homepage-headline .headline span {
    font-family: KlavikaWebBasicBoldItalic;
    font-size: 5.5rem;
    display: block;

    position: absolute;
    top: 50px;
    left: 10px;
}*/
.homepage-headline .headline span {
    font-family: KlavikaWebBasicBoldItalic;
    font-size: 5vw;
    /* display: block; */
    position: absolute;
    top: 3vw;
    left: 4vw;
}

.teaser-home .description-box {
    margin-top: -5.5vw;
}


/*********************************/
/* Studium und Ausbildung - Bild */
/*********************************/
.setShadow .image {
    /*box-shadow: 0 1px 3px 1px rgba(157,150,147,.7);*/
    margin: 5px;
    border-radius: 1%;
}
.setShadow .image *{
    border-radius: 1%;
}
.setShadow .row > div:nth-child(2) {
    width: auto;
    position: relative;
    display: inline-block;
    margin: 0;
    overflow: visible;
}
.setShadow .row > div:nth-child(2) img {
    height: 100%;
    width: auto;
    position: absolute;
    object-fit: cover;
    right: 0;
    top: 0;
    margin-right: 15px;
    box-shadow: 0 1px 3px 1px rgba(157,150,147,.7);
}



/*
Headerbild
 */
.frame-type-image:first-of-type {
    min-height: 170px;
}

/* Padding entfernen
.removePadding {
	padding: 0 !important;
}
.removeTopPadding .row {
	padding-top: 0 !important;
}
*/


/* Abstand */
.center__middle.content-container > * > * {
	margin: 0 15%;
	padding: 25px 0;
}
#doublePadding,
.doublePadding {
	padding: 50px 0 !important;
}
.removePadding {
    padding: 0 !important;
}
.removePaddingTop {
    padding-top: 0 !important;
}
.removePaddingBottom {
    padding-bottom: 0 !important;
}
.doublePaddingBottom {
    padding-bottom: 50px !important;
}

/* Abstände rückgängig machen (für z. B. linkes Bild auf der Startseite) */
.ce-above .ce-gallery {
	margin-bottom: 0;
}

/* Teaser (Startseite) */
.center__middle.content-container .teaser-home-spacing {
	padding-top: 160px;
}
.teaser-home .ce-center .ce-outer,
.teaser-home .ce-center .ce-inner {
	float: none;
	right: 0;
}



/*************/
/* Lade-Icon */
/*************/
html, body {
    /* For the loading indicator to be vertically centered ensure */
    /* the html and body elements take up the full viewport */
    min-height: 100%;
}
html.loading {
    background: #fff url('/fileadmin/images/Icons/loading.gif') no-repeat 50% 50%;
}
video {
    background: transparent url('/fileadmin/images/Icons/loading.gif') no-repeat 50% 50%;
}
/*
body {
    -webkit-transition: opacity 1s ease-in;
     transition: opacity 1s ease-in;
}
*/
html.loading body {
    /* Make the contents of the body opaque during loading */
    /* NICHT "display:none" verwenden, weil sonst z. B. die Accordion-Buttons nicht richtig geladen werden */
    opacity: 0;
}
html.loading body .wrapper {
	display: none;
}


/*****************/
/* FARBVERLAEUFE */
/*****************/
.tuerkiesFarbverlauf {
	background-color: rgb(213,229,235);
	background: url(/fileadmin/images/bg_leistungsspektrum.png) no-repeat, -moz-linear-gradient(126deg, rgb(213,229,235) 0%, rgb(169,195,206) 100%) !important;
	background: url(/fileadmin/images/bg_leistungsspektrum.png) no-repeat, -webkit-linear-gradient(126deg, rgb(213,229,235) 0%,rgb(169,195,206) 100%) !important;
	background: url(/fileadmin/images/bg_leistungsspektrum.png) no-repeat, linear-gradient(126deg, rgb(213,229,235) 0%,rgb(169,195,206) 100%) !important;
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#d5e5eb', endColorstr='#a9c3ce',GradientType=1 );
}

.orangeFarbverlauf {
	background-color: rgb(236,99,134);
	background: url(/fileadmin/images/startseite_ausschreibungen.png) no-repeat, -moz-linear-gradient(top, rgb(236,99,134) 0%, rgb(255,72,12) 75%) !important;
	background: url(/fileadmin/images/startseite_ausschreibungen.png) no-repeat, -webkit-linear-gradient(top, rgb(236,99,134) 0%,rgb(255,72,12) 75%) !important;
	background: url(/fileadmin/images/startseite_ausschreibungen.png) no-repeat, linear-gradient(to bottom, rgb(236,99,134) 0%,rgb(255,72,12) 75%) !important;
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ec6386', endColorstr='#ff480c',GradientType=0 );
}

/**********/
/* BUTTON */
/**********/
.bitbw-btn {
	position: relative;
	text-decoration: none;
	background-color: rgba(0, 0, 0, 0.2);
	padding: 10px 20px;
	border-radius: 3px;
	color: #FF480C !important;
	display: inline-block;
    font-weight: normal;
    border: 2px solid #eeeeee;
    transition: 0.3s;
}
.bitbw-btn:hover {
    transition: 0.3s;
    color: #004352 !important;
    text-decoration: none !important;
    font-weight: normal;
    background-color: #ffffff;
}
.bright-text .bitbw-btn {
    color: #FF480C !important;
}
.bright-text .bitbw-btn:hover {
    color: #000000 !important;
}
.bitbw-btn::after {
	content: "\f0da";
	font-family: fontawesome;
	margin-left: 5px;
	position: relative;
	bottom: -1px !important;
}

.bitbw-btn.ghostBtn {
	transition: 0.3s;
	color: #004352 !important;
	background: transparent;
	border: 2px solid #004352;
    text-shadow: none;
}

.bitbw-btn.ghostBtn:hover {
	transition: 0.3s;
	color: white !important;
	background-color: #004352;
	border: 2px solid #004352;
}
.bitbw-btn.ghostBtn::after {
	bottom: 10px;
}
.bright-text .bitbw-btn.ghostBtn {
    color: white !important;
    background: transparent;
    border: 2px solid white;
}

.bright-text .bitbw-btn.ghostBtn:hover {
    color: #004352 !important;
    background-color: white;
    border: 2px solid #eeeeee;
}

/**********************/
/* LINK-BUTTON (Maske)*/
/**********************/
.linkbtn-container {
	background: rgba(255, 255, 255, 0.4);
	padding: 30px;
	padding-left: 0 !important;
	padding-right: 0 !important;
	display: flex;
}
.linkbtn {
	z-index: 99;
}
.linkbtn-margin {
	display: flex;
	flex: 0 1 auto;
    align-items: flex-start;
	flex-direction: row;
	margin: 0 15%;
	width: 100%;
	padding: 0 !important;
	position: relative;
}
.linkbtn-container.setRightPosition .linkbtn-margin {
	flex-direction: row-reverse;
}
.linkbtn-description {
	padding: 0 !important;
	margin: 0;
	align-self: center;
}

.center__middle.content-container .linkbtn-link {
	-moz-box-shadow: inset 0px 1px 0px 0px #03707c;
    -webkit-box-shadow: inset 0px 1px 0px 0px #03707c;
    box-shadow: inset 0px 1px 0px 0px #03707c;
    background: -webkit-gradient(linear, left top, left bottom, color-stop(0.05, #005c6e), color-stop(1, #004352));
    background: -moz-linear-gradient(top, #005c6e 5%, #004352 100%);
    background: -webkit-linear-gradient(top, #005c6e 5%, #004352 100%);
    background: -o-linear-gradient(top, #005c6e 5%, #004352 100%);
    background: -ms-linear-gradient(top, #005c6e 5%, #004352 100%);
    background: linear-gradient(to bottom, #005c6e 5%, #004352 100%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#005c6e', endColorstr='#004352',GradientType=0);
    background-color: #005c6e;
    -moz-border-radius: 3px;
    -webkit-border-radius: 3px;
    border-radius: 3px;
    border: 1px solid #024147;
    display: inline-block;
    cursor: pointer;
    color: #fff !important;
    padding: 6px 25px 6px 35px;
    text-decoration: none;
    text-shadow: 0px 1px 0px #002e33;
	margin: 0 15px; /* grid-Abstand */
    font-weight: normal;
}
.center__middle.content-container .linkbtn-link:hover {
    background: -webkit-gradient(linear, left top, left bottom, color-stop(0.05, #004352), color-stop(1, #005c6e));
    background: -moz-linear-gradient(top, #004352 5%, #005c6e 100%);
    background: -webkit-linear-gradient(top, #004352 5%, #005c6e 100%);
    background: -o-linear-gradient(top, #004352 5%, #005c6e 100%);
    background: -ms-linear-gradient(top, #004352 5%, #005c6e 100%);
    background: linear-gradient(to bottom, #004352 5%, #005c6e 100%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#004352', endColorstr='#005c6e',GradientType=0);
    background-color: #004352;
    border-color: #024147;
	cursor: pointer;
    text-decoration: none !important;
    font-weight: normal;
}


/* Button linksbündig (Pfeil zeigt nach links) */
.linkbtn-container .linkbtn a {
	background: rgb(0, 92, 103);
	color: white;
	text-decoration: none;
	border: 1px solid rgb(6, 69, 74);
	border-radius: 3px;
	display: inline-block;
	position: relative;
}

.linkbtn-container .linkbtn a::before {
	font-family: fontawesome;
    content: "\f0d9";
    margin-right: 6px;
    color: white;
    font-size: 16px;
    position: absolute;
    left: 22px;
	top: 6px;
}
/* Button rechtsbündig (Pfeil zeigt nach rechts) */
.center__middle.content-container .linkbtn-container.setRightPosition .linkbtn-link{
	padding: 6px 35px 6px 25px;
}
.linkbtn-container.setRightPosition a::before {
	all: unset;
	content: "";
}
.linkbtn-container.setRightPosition a::after {
	content: "\f0da";
	font-family: fontawesome;
    margin-left: 6px;
    color: white;
    font-size: 16px;
    position: absolute;
    right: 22px;
	bottom: 5px;
}


.linkbtn-container a#loadMore {
	padding-right: 40px;
}
.linkbtn-container a#loadMore::before {
	content:"";
}
.linkbtn-container a#loadMore::after {
	font-family: fontawesome;
	content: "\f0d7";
	color: white;
	font-size: 14px;
	margin-top: 2px;
	margin-left: 6px;
	position: absolute;
}
.linkbtn-container.setHidden {
	display: none;
}





/*-------------------------------------------------------*\
  # HEADER
\*-------------------------------------------------------*/

header.header {
	position: absolute;
	z-index: 999;
	padding: 4rem 0 0;
	width: calc(100% - 4vw);
    max-width: 100%;
}

/* Logo mit Navigation */
.navbar {
	display: flex;
	position: relative;
}

.navbar__logo-container {
	position: absolute;
    top: -12px;
}

/*------------------------------*\
  # NAVIGATION & LANGUAGE MENU
\*------------------------------*/

/* Navigation mit Suche und Sprachauswahl */
.navbar__main-nav {
	height: 51px;
	min-width: 1160px;

	clear: both;

	/*flex: 1;*/
	height: 20%;
	position: relative;

	margin-top: 14px;
	margin-left: 2.6vw;

	margin: 0 15% !important;
	padding: 0 15px;
	display: flex;
	flex: 1 !important;
}
.navbar__main-nav .main-menu {
	/* flex: 1 auto; */
	padding-right: 22px;
}

.navbar__main-nav .languageBox {
	/*flex: 0 1 auto;*/
    position: absolute;
	top: 0;
    right: 0;
	display: inline-block;
	height: 60px;
    visibility: hidden;
}

.navbar__main-nav-border {
	border-top: 1px solid white;
	border-bottom: 1px solid white;
	border-right: 1px solid white;
	padding-left: 0 !important;
	padding-right: 0 !important;
	margin-left: 6%;

	clear: both;

	/*flex: 1;*/
	height: 52px;
	position: relative;

	display: flex;
	flex: 1 !important;
}

.navbar__main-nav-backgroundBorder {
	/*position: relative;*/

	display: flex;
	flex: 1 !important;

	/*border: 25px solid rgba(0,0,0, 0.6);
	border-left: 13px solid transparent;
	border-right: 0 solid transparent;*/
    /*background-color: rgba(0,0,0, 0.6);*/
    border: none;
    background: url(/typo3conf/ext/sitepackage/Resources/Public/Icons/arrow_bg.svg) no-repeat left center;
    background-size: cover;
}

.navbar__main-nav-backgroundBorder > * {
	/*margin-top: -25px !important;
	margin-left: -11px !important;
	height: 52px;*/
}
.navbar__main-nav-backgroundBorder .languageBox {
	/*margin-right: -25px;*/

}

/* Hauptmenü PFEILE */
.navbar__main-nav > ul > .submenu-item::before {

	/*
	content: "";
	position: absolute;
	transform: skew(25deg, 0deg);
	width: 99%;
	height: 47%;
	background: rgba(254,139,179,0.5);
	border-left: 2px solid red;
	border-right: 2px solid red;
	border-top: 2px solid red;
	*/

	/*
	content: "";
	display: block;
	border-top: 1px solid white;
	border-right: 1px solid white;
	transform: rotate(45deg);
	width: 35px;
	height: 35px;
	background-color: transparent;
	position: absolute;
	top: 6.5px;
	left: -18px;
	*/
}
/*
.navbar__main-nav > ul > .submenu-item::after {
	content: "";
	display: block;
	border-top: 1px solid white;
	border-right: 1px solid white;
	transform: rotate(45deg);
	width: 35px;
	height: 35px;
	background-color: transparent;
	position: absolute;
	top: 6.5px;
	right: -18px;
}*/

.navbar__main-nav > ul > .submenu-item::after {

	/*
	content: "";
	position: absolute;
	transform: skew(-25deg, 0deg);
	width: 99%;
	height: 47%;
	background: rgba(254,139,179,0.5);
	border-left: 2px solid red;
	border-right: 2px solid red;
	border-bottom: 2px solid red;
	bottom: 0;
	left: 0;
	*/

	/*
	content: "";
	display: block;
	border-right: 34px solid transparent;
	transform: rotate(135deg);
	width: 0;
	height: 0;
	background-color: transparent;
	position: absolute;
	top: 7.5px;
	right: -17px;
	border-top: 34px solid rgba(0,0,0,0.5);
	*/
}
.navbar__main-nav > ul > .submenu-item:hover::after {
	/*
	border-top: none;
	border-right: 35.5px solid white;
	width: 0;
	height: 0;
	right: -17px;
	border-bottom: 35.5px solid transparent;
	*/
}
.navbar__main-nav ul.main-menu > li {
    height: 50px;
    padding: 0;
    display: table;
    margin-left: -19px;
}
.navbar__main-nav ul.main-menu > li:first-child {
    margin-left: 2px;
}
.navbar__main-nav ul.main-menu > li a {
    vertical-align: middle;
    height: 100%;
}
.navbar__main-nav ul.main-menu > li:hover > a,
.navbar__main-nav ul.main-menu > li.active > a,
.navbar__main-nav ul.main-menu > li:hover > button.arrowToggle,
.navbar__main-nav ul.main-menu > li.active > button.arrowToggle {
    background-color: rgba(90, 133, 142, 0.5);
}
.navbar__main-nav ul.main-menu > li::before {
    width: 17px;
    content: " ";
    display: table-cell;
    background: transparent;
    height: 100%;
}
.navbar__main-nav ul.main-menu > li:hover::before,
.navbar__main-nav ul.main-menu > li.active::before {
    background: url(/typo3conf/ext/sitepackage/Resources/Public/Icons/arrow_active_end.svg) no-repeat left center;
    background-size: contain;
    border-top: 1px solid rgba(90, 133, 142, 0.5);
    border-bottom: 1px solid rgba(90, 133, 142, 0.5);
}
.navbar__main-nav ul.main-menu > li::after {
    width: 17px;
    content: "";
    display: table-cell;
    background: transparent;
    height: 100%;
}
.navbar__main-nav ul.main-menu > li:hover::after,
.navbar__main-nav ul.main-menu > li.active::after {
    background: url(/typo3conf/ext/sitepackage/Resources/Public/Icons/arrow_active_start.svg) no-repeat left -2px center;
    background-size: contain;
}
/* Pfeil-Form */
.navbar__main-nav .svg {
	position: absolute;
	left: 0;
	top: 0;
	height: 50px;
	width: 300px;
}
.navbar__main-nav .languageBox .svg {
	width: 101%;
}
.navbar__main-nav ul.main-menu > li:hover polygon,
.navbar__main-nav ul.main-menu > li.active polygon,
.languageBox:hover polygon {
	fill: rgba(90, 133, 142, 0.5); /* türkis */
}

/* Fuer Hamburger-Button */
input#dropMenu {
	display:none;
}
#hamburger {
    display: none;
}
button.arrowToggle {
    display: block;
    height: 100%;
    width: 19px;
    position: relative;
    color: white;
    background-color: transparent;
    border: none;
    font-weight: bold;
    z-index: 10;
}
button.arrowToggle::before {
    content: "\f107";
    font-family: "FontAwesome";
    margin-left: -6px;
}
/* Haupt-Menü */
.main-menu,
.languageBox .dropdown-toggle {
	margin: 0;
	padding-left: 0;
	display: flex;
}


/* DropDown-Menü - 2. + 3. Ebene */
.main-submenu,
.main-submenu-child,
.languageBox ul {
	visibility: hidden;
	opacity: 0;
	position: absolute;
	transition: all 0.5s ease;
	min-width: 100%;
	padding-left: 0;
	background-color: white;
	box-shadow: 0 1px 5px 1px rgba(0,0,0,.7);
	margin: 0;
    top: 51px;
    /* margin-top: -5px; */
}


ul li.open > ul,
ul li:hover > ul,
ul li ul:hover,
.languageBox .language-btn-group:hover ul,
.languageBox .dropdown-toggle ~ ul:hover,
.languageBox ul.show {
	visibility: visible;
	opacity: 1;
	display: block;
}

/* DropDown-Menü - 2. Ebene */
.main-submenu {
	left: 0;
}


/* DropDown-Menü - 3. Ebene */
.main-submenu-child {
	left: 100%;
	top: 0;
}



/* Menüpunkte - Alle Ebenen */
.main-menu li,
.languageBox li {
	list-style-type: none;
	display: block;
	transition-duration: 0.5s;
}
/* untere Ebenen */
.main-menu li li:hover,
.languageBox ul li:hover,
.main-menu li li.active {
	background-color: #336975;
}


/* Menüpunkte - 1. Ebene */
.main-menu > li {
	/* display: inline-block; */
	position: relative;
	#width: 8.5em;
    background: url(/typo3conf/ext/sitepackage/Resources/Public/Icons/arrow.svg) no-repeat right center;
    background-size: contain;
}
.main-menu > li:hover,
.languageBox .language-btn-group:hover {
	cursor: pointer;
}

/* Menüpunkte - 2. + 3. Ebene */
.main-submenu li,
.languageBox li {
	clear: both;
	text-align: left;
	left: 0;
	background-color: white;
}



/* Menüpunkte Links - Alle Ebenen */
.main-menu a,
.main-menu a span,
.languageBox a span,
.languageBox ul a {
	text-decoration: none !important;
	white-space: nowrap;
	font-weight: bold;
	font-size: 16px;
	/*height: 100%;*/
	display: flex;
	align-items: center;
}
.main-menu > li a {
    padding: 0 14px;
    display: table-cell;
}
.main-menu > li.submenu-item a {
    padding: 0 3px 0 14px;
    display: table-cell;
}
.main-menu > li.submenu-item li a,
.main-menu > li li a ,
.languageBox ul a {
	padding: 14px;
    display: block;
}


/* Menüpunkte Links - 1. Ebenen */
.main-menu > li > a  {
	color: white;
	position: relative;
	z-index: 9999;
	/*width: 100%;*/
	/* height: 50px; */
}
.main-menu > li > a > span {
	/*padding-left: 22px;
	justify-content: center;*/
}
.languageBox .dropdown-toggle > span {
	padding-left: 36px;
}



/* Menüpunkte Links - 2. + 3. Ebenen */
.main-submenu a span,
.languageBox ul a {
	color: #004352;
}
.main-submenu > li:hover > a > span,
.main-submenu li li:hover > a > span,
.languageBox ul li:hover a,
.main-submenu > li.active > a > span,
.main-submenu li li.active > a > span {
	color: white;
}


/* 3. Ebene ausblenden */
.nav .main-submenu .main-submenu-child {
    display: none;
}
.nav .main-submenu .submenu-item {

}


/* Arrow Icon */
/* 1. Ebene */
.main-menu > li.submenu-item > a span::after,
.languageBox .dropdown-toggle span::after {
	/*content: "\f107";
	font-family: "FontAwesome";
	padding-left: 10px;*/
}

.main-menu > li:hover > a.dropdown-toggle span::after,
.languageBox > .btn-group:hover > .dropdown-toggle span::after {
	content: "\f106";
	transition-duration: 0.5s;
}

/* 2. Ebene */
/*.main-menu li li a.dropdown-toggle span::after {
	content: "\f054";
	font-family: "FontAwesome";
	font-weight: normal;
	font-size: 12px;
	padding-left: 10px;
}
.main-menu li li:hover a.dropdown-toggle span::after {
	content: "\f053";
}*/

/* DropDown-Checkbox für Responsive Webdesign - ausblenden */
input[id^="drop"] {
	display: none;
}
/* Navigation Barrierefreiheit - Gebärdensprache Leichte Sprache */
#bf-nav {
    position: absolute;
    top: 0;
    right: 15%;
    padding-right: 15px;
}
#bf-nav::after {
    content: "";
    width: 99%;
    display: block;
    position: absolute;
    top: 0;
    z-index: 11;
    left: -12px;
    -webkit-box-shadow: inset -3px 7px 9px -10px rgba(0,0,0,0.75);
    box-shadow: inset -3px 7px 9px -10px rgba(0,0,0,0.75);
    height: 8px;
}
#bf-nav ul {
    list-style: none;
    padding: 0;
    margin: -1px 0 0 0;
    position: relative;
}
#bf-nav ul li {
    display: inline-block;
    background-size: 1.2em !important;
    background-color: #FFFFFF;
    position: relative;
    padding: 2px 10px 2px;
    margin-right: 12px;
    z-index: 3;
}
#bf-nav ul li:nth-child(1) {
    z-index: 10;
}
#bf-nav ul li:nth-child(2) {
    z-index: 9;
}
#bf-nav ul li:nth-child(3) {
    z-index: 8;
}
#bf-nav ul li:nth-child(4) {
    z-index: 7;
}
#bf-nav ul li:nth-child(5) {
    z-index: 6;
}
#bf-nav ul li:before,
#bf-nav ul li:after {
    display: block;
    content: " ";
    position: absolute;
    top: 0px;
    height: 100%;
    width: 14px;
    background-color: #FFF;
    z-index: 2;
}
#bf-nav ul li:before {
    right: -9px;
    transform: skew(-10deg, 0deg);
    box-shadow: rgba(0,0,0,.1) 3px 2px 5px, inset rgba(255,255,255,.09) -1px 0;
    border-radius: 0px 0px 8px 0px;
}
#bf-nav ul li:after {
    left: -9px;
    transform: skew(10deg, 0deg);
    box-shadow: rgba(0,0,0,.1) -3px 2px 5px, inset rgba(255,255,255,.09) 1px 0;
    border-radius: 0px 0px 0px 8px;
}
#bf-nav a {
    color: #555555;
    padding: 3px 0 3px 1.6em;
    font-weight: bold;
}
#bf-nav ul li.dgs-lnk a {
    background: #FFFFFF url(/typo3conf/ext/sitepackage/Resources/Public/Icons/ico_dgs.svg) no-repeat left center;
}
#bf-nav ul li.ls-lnk a {
    background: #FFFFFF url(/typo3conf/ext/sitepackage/Resources/Public/Icons/ico_leichte_sprache.svg) no-repeat left center;
}

/*--------------------------------------*\
  # CONTAINER : SEARCH & LANGUAGE MENU
\*--------------------------------------*/
.sideMenuElements {
	position: absolute;
	right: 0;
	top: 0;
}


/*-----------*\
  # SEARCH
\*-----------*/

.navbar__main-nav .searchBox {
    position: absolute;
    top: 0;
    right: 0; /*128px;*/
    display: inline-block;
    height: 52px;
}

.search-field-container {
	display: flex;
	align-items: center;
	display: flex;
	/*border: 24.5px solid rgba(0,0,0,0.5);*/
	height: 52px;
	border-left: 20px solid transparent;
	padding-right: 20px;
}
.search-field-container > div:first-child {
	display: none;
}

.searchBox .searchBox-btn {
	background: none;
	border: none;
}
.searchBox .searchBox-btn:hover {
    cursor: pointer;
}
.searchBox .searchBox-btn:focus {
    border: none;
}
nav .searchBox .searchBox-btn {
	background: url("/fileadmin/images/Icons/magnifying-glass.svg") no-repeat;
	background-size: contain;
	width: 23px;
	height: 23px;
    margin-top: 4px;
}
.searchBox .searchBox-btn {
	background: url("/fileadmin/images/Icons/ico_suche/ico_suche.svg") no-repeat;
	width: 22px;
	height: 22px;
}

.searchBox .btn:hover {
	cursor: pointer;
}

/* Menu-Container des Suche */
.searchBox .search-input-group {
	min-width: 140px;
	text-align: right;
	position: relative;
}
nav .searchBox .search-input-group .search-input-group-btn {
	filter: invert(100%);
}
nav .searchBox .search-input-group .searchBox-btn {
	filter: brightness(0);
    font-size: 22px;
    vertical-align: middle;
}
.searchBox .search-field {
    position: absolute;
    right: 0;
    transition: all 0.5s ease-in-out;
    background-color: rgba(0,0,0,0.0); /* Niemals "transparent" setzen, weil IE-10 setzt sonst das input-Feld als unsichtbar und wäre somit nicht selektierbar */
    border: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.5) !important;
    box-sizing: border-box;
    color: rgba(255, 255, 255, 0.75);
    cursor: pointer;
    font-size: 1em;
    font-weight: 300;
    opacity: 0;
    padding-right: 1.75rem;
    z-index: 3;
    width: 30px;
}
/* Such-Eingabefeld */
.searchBox .search-field:focus {
	cursor: text;
	opacity: 1;
	outline: none;
	width: 75%; /* Breite des Such-Eingabefelds */
	z-index: 1;
	margin-right: 35px;
	padding-right: 5px;
    box-shadow: 0 0 1.5px 2px #FFFFFF;
}
.searchBox .btn-submit {
    transition: all 0.2s ease-in-out;
    background-color: transparent;
    border: none;
    float: right;
    position: relative;
    width: 21px;
    height: 30px;
    z-index: 2;
    color: white;
    top: -0.4em;
    background-repeat: no-repeat;
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 21 23'%3E%3Cstyle%3E .fill{fill:%23fff;} %3C/style%3E%3Cpath class='fill' d='M5.06,4.29a6.71,6.71,0,0,0-.81,9.39,6.57,6.57,0,0,0,9.31.82,6.71,6.71,0,0,0,.81-9.39,6.57,6.57,0,0,0-9.31-.82Zm11.38-.93a9.49,9.49,0,0,1,.42,11.52l3.6,4.33a2.33,2.33,0,0,1-.28,3.25A2.29,2.29,0,0,1,17,22.18l-3.59-4.32a9.46,9.46,0,0,1-4,.93,9.29,9.29,0,0,1-7.14-3.36A9.46,9.46,0,0,1,3.32,2.2,9.25,9.25,0,0,1,16.44,3.36Z'/%3E%3C/svg%3E");
}



/*--------------------*\
  # SEARCH FIELD/BOX
\*--------------------*/

/* Suchergebnisse-Box - 12er-Columns Padding links und rechts setzen */
.tx-indexedsearch-searchbox {
	padding-left: 15px;
	padding-right: 15px;
}

/* Bilder/Icons sollen nicht zu gross dargestellt werden */
.tx-indexedsearch-icon img {
	width: auto;
}


/*----------------*\
  # SEARCH RESULTS
\*----------------*/

/* "Search for '...' ausblenden " */
.frame {
	visibility: collapse;
}
.frame * {
	visibility: visible;
}

/* Suchfeld */
.tx-indexedsearch-searchbox {
	padding: 0 !important;
}
.tx-indexedsearch-searchbox legend {
	display: none;
}
.tx-indexedsearch-searchbox fieldset {
	border: 1px solid rgb(168, 195, 206);
	padding: 0;
	display: flex;
	position: relative;
}
.tx-indexedsearch-form {
	background: wheat;
	display: flex;
	flex: 1;
	overflow: hidden;
}
.tx-indexedsearch-search-submit {
	flex: 0 1 auto;
}
/* Suchfeld */
.tx-indexedsearch-searchbox-sword {
	border: none;
	padding-left: 30px;
	padding-right: 10px;
	width: 100%;
	flex: 1;
}

/* Ausblenden: "Was" (Begriff) gesucht wurde (in der Suchleiste) und Anzahl an Suchergebnissen*/
.tx-indexedsearch-browsebox,
.tx-indexedsearch-info-sword {
	display: none !important;
}
.tx-indexedsearch-res {
	background-color: white;
	padding: 2% !important;
	margin: 6vh 15% !important;
	border-radius: 5px;
	box-shadow: 0 1px 5px 1px rgba(157,150,147,.7);
}
.tx-indexedsearch-res > h3 {
	display: inline-flex;
}

.tx-indexedsearch-form .svg {
	position: absolute;
}
.tx-indexedsearch-form label {
	border-top: 10px solid #1A7A8D;
	/* border-right: 5px solid rgb(133, 177, 190); */
	border-bottom: 10px solid #1A7A8D;
	border-left: 10px solid #1A7A8D;
	border-right: 10px solid #1A7A8D;
	color: white;
	background: #1A7A8D;
	position: relative;
	padding: 0 5px;
	font-size: 16px;
	text-transform: uppercase;
    margin-bottom: 0;
}
.tx-indexedsearch-form label::after {
	content: "";
	border-top: 22.5px solid transparent;
	border-right: 8px solid transparent;
	border-bottom: 22.5px solid transparent;
	border-left: 17px solid #1A7A8D;
	color: white;
	position: absolute;
    top: 50%;
    transform: translateY(-50%);
	right: -33px;
}

/* Suchergebnis-Button */
.searchBox.tx-indexedsearch-search-submit {
    position: absolute;
    right: 8px;
    top: 50%;
    line-height: 0;
    background-color: rgba(0, 0, 0, 0);
    width: 22px;
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
}

/* Suchergebnis-Icon ausblenden */
.tx-indexedsearch-icon {
	display: none;
}

/* Suchergebnis-Titel */
.tx-indexedsearch-title a,
.tx-indexedsearch-title a:hover {
	color: rgb(32, 90, 104);
	text-decoration: none;
    font-weight: normal;
}
.tx-indexedsearch-res h2 {
    margin-top: 0;
    margin-bottom: 1rem;
}
.tx-indexedsearch-res h2,
.tx-indexedsearch-res h2 * {
    font-family: KlavikaWebBasicMedium;
    font-size: 1.4rem;
    line-height: 1.8rem;
}

.tx-indexedsearch-info {
	margin-bottom: 0;
}

.tx-indexedsearch-text-item-path {
	margin-left: 0;
}
.tx-indexedsearch-text-item-path a {
	text-decoration: none;
	color: rgb(71, 138, 155);
    word-break: break-all;
}
.modified-date {
	display: inline-flex;
}
.modified-date dd.tx-indexedsearch-text-item-mtime {
	margin-left: 3px;
}

/*----------------*\
  # LANGUAGE MENU
\*----------------*/
.languageBox a.dropdown-toggle {
	color: white;
	text-decoration: none;
	position: relative;
	z-index: 9;
}
.languageBox a.dropdown-toggle span {
	z-index: 999;
	width: 100%;
}
.languageBox .btn-group,
.languageBox a.dropdown-toggle,
.languageBox a.dropdown-toggle span {
	height: 100%;
}
.languageBox {
	position: relative;
	width: 140px;
}
/*
.languageBox ul {
	min-width: auto;
}
*/
.languageBox ul {
	margin-top: 0;
}


/*-------*\
  # LOGO
\*-------*/
.navbar__logo {
	width: 248px;
	padding-left: 11px;
	margin-left: 49px;
}


/*---------------*\
  # BREADCRUMBS
\*---------------*/

.breadcrumbs-container {
	padding: 10px 20px;
	display: none;
}
.breadcrumbs-container * {
	color: white;
}

.breadcrumb,
.breadcrumb li {
	display: inline-block;
}
.breadcrumb {
	padding-left: 0;
	margin: 5px 0;
}
.breadcrumb li {
	list-style: none;
}
.breadcrumb li a {
	text-decoration: none;
}
.breadcrumb li * {
	padding: 0 10px;
	font-style: italic;
}


/*-------------------------------------------------------*\
  # WRAPPER CONTENT
\*-------------------------------------------------------*/

.wrapper {
	margin:0px auto;
}

.body {
	/* padding-bottom: 10px; */
	margin: 0;
}

/*
.content-container > * {
	border: 1px solid #ccc;
	box-shadow: 0 1px 5px 1px rgba(157,150,147,.7);
}
 */

@media (min-width: 800px) {

  .body {
    display: flex;
    flex-direction: row;
    /*padding-bottom: 10px;*/
  }

  .content-container {
    flex: 1;
    vertical-align: top;
  }

  .body > .center {
    flex-direction: column;
    flex: 1;
  }

}

/*--------------------*\
  # CONTENT-CONTAINER
\*--------------------*/

/* Content-container Überschrift ausblenden */
/*.content-container > div > h2 {
	display: none;
}*/

/* Unterseiten Teaser-Bilder */
.center > .center__middle.content-container > .frame > .ce-image {
	padding: 0;
	margin: 0;
}
.center > .center__middle.content-container > .frame-type-image {
	border-bottom: 1px solid rgb(168, 195, 204);
}
/* Bild soll so gross/breit sein wie dessen Container */
.center > .center__middle.content-container > .frame > .ce-image * {
	width: 100%;
	height: 100%;
}

/*--------------------------*\
  # News (Startseite)
\*--------------------------*/
.news-contain.grid-container .row {
	padding-top: 4%;
	padding-bottom: 3%;
}

/*--------------------------*\
  # SCROLL DOWN (Startseite)
\*--------------------------*/
.scrolldown-container {
	text-align: center;
	margin-top: 10%;
	position: relative;
}
a.scrolldown-link {
	/*
	position: absolute;
	bottom: 20px;
	left: 50%;
	*/
	z-index: 2;
	display: inline-block;
	-webkit-transform: translate(0, -50%);
	transform: translate(0, -50%);
	/* font: normal 400 20px/1 'Josefin Sans', sans-serif; */
	letter-spacing: .1em;
	text-decoration: none;
	transition: opacity .3s;

	padding-top: 60px;
}

a.scrolldown-link,
.teaser-home-spacing a.scrolldown-link:hover {
	color: rgb(255, 72, 12) !important;
    text-decoration: none !important;
    font-weight: normal;
}

a.scrolldown-link span {
	position: absolute;
	top: 0;
	left: 50%;
	width: 30px;
	height: 50px;
	margin-left: -15px;
	border: 2px solid rgb(255, 72, 12);
	border-radius: 50px;
	box-sizing: border-box;
}
a.scrolldown-link span::before {
	position: absolute;
	top: 10px;
	left: 50%;
	content: '';
	width: 6px;
	height: 6px;
	margin-left: -3px;
	background-color: rgb(255, 72, 12);
	border-radius: 100%;
	-webkit-animation: sdb10 2s infinite;
	animation: sdb10 2s infinite;
	box-sizing: border-box;
}
a.scrolldown-link p {
    background-color: rgba(0, 0, 0, 0.5);
    padding: 2px 4px;
    border: 1px solid transparent;
    border-radius: 3px;
    color: rgb(255, 72, 12) !important;
}
@-webkit-keyframes sdb10 {
	0% {
		-webkit-transform: translate(0, 0);
		opacity: 0;
	}
	40% {
		opacity: 1;
	}
	80% {
		-webkit-transform: translate(0, 20px);
		opacity: 0;
	}
	100% {
		opacity: 0;
	}
}
@keyframes sdb10 {
	0% {
		transform: translate(0, 0);
		opacity: 0;
	}
	40% {
		opacity: 1;
	}
	80% {
		transform: translate(0, 20px);
		opacity: 0;
	}
	100% {
		opacity: 0;
	}
}

/*--------------*\
  # SCROLL UP
\*--------------*/
#return-to-top {
    position: fixed;
    bottom: 2vw;
    right: 3vw;
    background: rgb(255, 255, 255);
    background: rgba(255, 255, 255, 0.7);
    width: 3.2em;
    height: 2.7em;
    display: block;
    text-decoration: none;
    -webkit-border-radius: 35px;
    -moz-border-radius: 35px;
    border-radius: 4px;
    display: none;
    -webkit-transition: all 0.3s linear;
    -moz-transition: all 0.3s ease;
    -ms-transition: all 0.3s ease;
    -o-transition: all 0.3s ease;
    transition: all 0.3s ease;
    z-index: 999;
}
#return-to-top span:not(.sr-only) {
	font-family: fontawesome;
	color: #3F7380;
	margin: 0;
	position: relative;
	left: 0.34em;
	top: 0;
	font-size: 38px;
    line-height: 1.2;
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	-ms-transition: all 0.3s ease;
	-o-transition: all 0.3s ease;
	transition: all 0.3s ease;
}
#return-to-top:hover {
    background: rgba(0, 67, 83, 0.7);
}
#return-to-top:hover span {
    color: #fff;
    top: -2px;
}


/*-------------------------------------------------------*\
  # Video Element
\*-------------------------------------------------------*/
.video-iframe * {
	width: 100%;
	height: 100%;
}
.frame-type-textmedia .video-embed {
	position: relative;
	padding-bottom: 56.25%;
	padding-top: 30px;
	height: 0;
	overflow: hidden;
}
.frame-type-textmedia iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}


/*-------------------------------------------------------*\
  # FOOTER
\*-------------------------------------------------------*/

footer {
	clear: both;
	color: white;
	background-color: white;
	display: flex !important;
	margin: 3% 15%;
	padding: 0 15px;
}

footer span {
	font-style: italic;
	display: block;
	text-align: right;
}

/* --- Footernavigation & Externe Links --- */
footer ul {
	list-style: none;
	padding-left: 10px;
	border-left: 2px solid rgba(32, 90, 104, 1.0);
	padding-bottom: 30px;
	margin: 0;
}
.footer .menu-item {
	margin: 8px 0;
}
footer * {
	color: black !important;
    font-weight: normal;
}
footer a:hover {
    font-weight: normal;
}

/* --- Footernavigation --- */
.footer-links {
	display: flex;
	flex-direction: row;
}
.footer-links a {
    color: #333333;
}
.footer-links a:hover,
.footer-links a:active {
    color: rgb(69, 140, 160);
}

/* --- Externe Links --- */
.external-links {
	margin-left: 70px;
}


/* Löwen Icons */
.external-links a:before {
	content: "";
	display: inline-block;
	background: url("/fileadmin/images/Icons/icon_external-link.svg") no-repeat;
	width: 25px;
	height: 15px;
	margin: 4px 6px 0 0;
	vertical-align: middle;
}
/* Serviceportal Löwe (Seiten-id = 58) */
.external-links li#site-58 a:before {
	background: url("/fileadmin/images/Icons/icon_serviceportal-bw.png") no-repeat;
	background-size: 25px auto;
	margin-top: -1px;
}
/* Xing (Seiten-id = 56) */
.external-links li#site-56 a::before {
	background: url("/fileadmin/images/Icons/icon_xing.svg") no-repeat;
	margin-top: -2px;
	margin-left: 8px;
	margin-right: 0;
}

/* --- Baden-Wuerttemberg Logo --- */
.footer .imgContainer {
	flex: 1 1 auto;
}
.footer .imgContainer img {
	float: right;
	max-height: 140px;
	max-width: none;
	width: auto;
}


/***********************************/
/* Seitenübersicht-Seite - Sitemap */
/***********************************/
.sitemap ul {
    list-style: none;
    padding-left: 0;
    max-width: 840px;
}
.sitemap .frame {
    display: inline-block;
    vertical-align: top;
}
/* 1. Ebene */
.sitemap .frame > ul > li {
    float: left;
    vertical-align: top;
    margin-right: 50px;
    width: 230px;
}
.sitemap .frame > ul > li:last-child {
    float: auto;
    vertical-align: top;
}
/* Footer-Seiten */
.sitemap .frame:last-child {
    margin-top: 15px;
}
.sitemap .frame:last-child > ul > li {
    float: none;
    width: auto;
}
.sitemap .frame:last-child > ul > li {
    margin-right: 0;
}

/* 2. Ebene */
.sitemap .frame > ul > li > ul {
    padding-left: 0;
}

/* 3. Ebene */
.sitemap .frame > ul > li > ul > li > ul {
    padding-left: 25px;
}

/* Schrift */
.sitemap a span,
.sitemap .frame:last-child > ul > li > a > span {
    font-weight: normal;
    font-size: 16px;
    color: #333333;

    display: block;
    margin-bottom: 7px;
}
.sitemap .frame:last-child > ul > li > a > span {
    margin-top: 0;
}
.sitemap .frame > ul > li > a span{
    font-weight: bold;
    font-size: 20px;
    color: rgb(0, 67, 83);

    display: block;
    margin: 15px 0;
}






/*************************************/
/* BITE - Bewerbermanagement - Liste */
/*************************************/
.frame .bite-container {
    list-style: none;
    padding-left: 0;
}
.frame .bite-container .bite-title {
    padding: 15px;
    margin-bottom: 0;
    border-top: 1px solid rgb(168, 195, 204);
}
.frame .bite-container .bite-title:first-child {
    border-top: 0;
}

.frame .bite-container .bite-title a:link,
.frame .bite-container .bite-title a:visited {
    color: #333 !important;
    font-weight: normal;
}

.frame .bite-container .bite-title a::before,
.frame .bite-container .bite-title a {
    margin-left: 0;
    content: "";
}

.frame .bite-container .bite-title a::after {
    font-family: fontawesome;
    content: "\f0da";
    margin-left: 6px;
    color: rgb(255, 72, 12);
    margin-top: -3px;
    vertical-align: middle;
    display: inline-block; /* somit wird hover-underline entfernt */
}
.frame .bite-container .bite-title a:hover::after {
    text-decoration: none;
}
/*************************/
/* Video Container Vimeo */
/*************************/
.center__middle.content-container div.video-wrapper {
    padding: 56.25% 0 0 0;
    position: relative;
}
.center__middle.content-container hr.video-separator {
    height: 1px;
    border: none;
    margin: 2em 0;
}

/************************/
/* Responsive Webdesign */
/************************/

@media (max-width: 1550px) {

	/**************/
	/* Navigation */
	/**************/

	.navbar__main-nav {
		min-width: auto;
		margin: 0 15% 0 0 !important; /* Abstand ändern */
	}

	.navbar__main-nav-border {
		border: 1px solid white;
	}

	.navbar__logo-container {
		position: relative;
	}
    .navbar__main-nav ul.main-menu > li:hover > a,
    .navbar__main-nav ul.main-menu > li.active > a,
    .navbar__main-nav ul.main-menu > li:hover > button.arrowToggle,
    .navbar__main-nav ul.main-menu > li.active > button.arrowToggle {
        background-color: transparent;
    }
    .navbar__main-nav ul.main-menu > li::before {
        display: none;
    }
    .navbar__main-nav ul.main-menu > li:hover::before,
    .navbar__main-nav ul.main-menu > li.active::before {
        background-image: none;
    }
    .navbar__main-nav ul.main-menu > li::after {
        display: none;
    }
    .navbar__main-nav ul.main-menu > li:hover::after,
    .navbar__main-nav ul.main-menu > li.active::after {
        background-image: none;
    }
    .navbar__main-nav ul.main-menu > li a {
        display: block;
        padding: 14px;
        vertical-align: auto;
        height: auto;
        z-index: 10;
    }
    .navbar__main-nav ul.main-menu > li,
    .navbar__main-nav ul.main-menu > li:first-child {
        margin: 0;
    }
    .navbar__main-nav ul.main-menu > li > button.arrowToggle {
        position: absolute;
        height: auto;
        top: 0;
        right: 0;
        z-index: 11;
    }
	/* Hamburger-Button */
    #hamburger,
    label.menuToggle {
		color: #fff;
		border: none;
		width: 50px;
        height: 51px;
        line-height: 50px;
		padding: 25px 0;
		margin-bottom: 1px;
		display: flex;
		justify-content: center;
		align-items: center;
        cursor: pointer;
	}
    #hamburger {
        padding: 0;
        background-color: transparent;
        line-height: unset;
    }
    #hamburger.is-active {
        background-color: #fff;
    }
    #hamburger:hover,
	label.menuToggle:hover {
		cursor: pointer;
	}
    #hamburger::before,
	#hamburgerBtn::before {
		font-family: FontAwesome;
		content: "\f0c9";
		font-size: 27px;
		line-height: 2em;
	}
    #hamburger::before {
        line-height: unset;
    }
    #hamburger.is-active::before,
	.navbar__main-nav-backgroundBorder [id^="drop"]:checked ~ .menuToggle,
	.navbar__main-nav-backgroundBorder [id^="drop"]:checked ~ .menuToggle #hamburgerBtn::before {
		content: "\f00d" !important;
		color: #004352 !important;
	}




	/* Hauptnavigation - ab 1. Ebene */
	.nav.navbar-nav.navbar-right.main-menu {
		display: none;
        position: absolute;
		top: 51px;
        left: -1px;
        right: -1px;
		padding: 0;
		hyphens: auto;
	}
    nav .nav.navbar-nav.navbar-right.main-menu.is-active {
        display: block;
        border-top: 1px solid #fff;
    }
	.main-menu > li {
		width: 100%;
		display: flex;
		flex-wrap: wrap;
		border-bottom: 1px solid #fff;
		border-left: 1px solid #fff;
		border-right: 1px solid #fff;
	}
	.main-menu > li > a {
		flex: 1;
	}

	.main-menu > li > a > span,
	.languageBox .dropdown-toggle > span {
		justify-content: flex-start;
	}

	.main-menu > li > a > span {
		padding-left: 0;
	}
	/*.languageBox .dropdown-toggle > span {
		padding-left: 36px;
	}*/

	/* Hintergrundfarbe (türkis) der 1. Menue-Ebene Buttons */
	.nav.navbar-nav.navbar-right.main-menu > * {
		background: #004352;
	}

	/* Ausblenden der Pfeilformen der Menue-Buttons, aus der Desktop-Ansicht */
	.nav.navbar-nav.navbar-right.main-menu svg {
		display: none;
	}


	.main-menu > li.submenu-item > a span::after {
		content: none;
		padding-left: 0;
	}
	.main-menu > li:hover > a.dropdown-toggle span::after,
	.languageBox > .btn-group:hover > .dropdown-toggle span::after {
		content: none;
		transition-duration: 0.5s;
	}
    .main-submenu,
    .main-submenu-child,
    .languageBox ul {
        box-shadow: none;
    }
	/* Submenü bzw. 2. Menue-Ebene Buttons */
	.nav.navbar-nav.navbar-right.main-menu .main-submenu {
		display: none;
		position: relative;
		top: 0;
		visibility: visible;
		opacity: 1.0;
		border: 1px solid #fff;
	}
	.navbar__main-nav-backgroundBorder {
		flex-direction: column;
		border: none;
		background: rgba(0,0,0, 0.5);
	}
	.navbar__main-nav-backgroundBorder > * {
		margin-left: 0 !important;
		margin-top: 0 !important;
	}

	/* Bedeutung von "~": Element "ul.root", wenn davor Element "#headerNav [id^=drop]:checked" vorkommt (im gleichen Elternelement) */
	/* Die Hauptmenuepunkte in einem Dropdown anzeigen */
	.navbar__main-nav-backgroundBorder  [id^=drop]:checked ~ ul,
    .navbar__main-nav-backgroundBorder  .submenu-item.open ul {
		display: block !important;
	}

	/* Suchfeld - Abstand links verkleinern */
	.search-field-container {
		padding-left: 30px;
	}


	/* Submenue - 2. Menue-Ebene - DropDown Button */
	label.arrowToggle,
    button.arrowToggle {
		display: flex;
		align-items: center;
		cursor: pointer;
	}
    button.arrowToggle {
        width: auto;
    }
	label.arrowToggle::before,
    button.arrowToggle::before {
		content: "";
		height: 16px;
		padding: 5px 0;
		border-right: 1px solid #fff;
	}
	label.arrowToggle::after,
    button.arrowToggle::after {
		font-family: FontAwesome;
		font-size: 18px;
		line-height: 0;
		color: #fff;
		content: "\f107";
		float: right;
		padding: 26px 52px 26px;
		margin-top: 0;
		box-sizing: border-box;
		font-weight: bold;
	}
	input[id^=drop]:checked ~ label.arrowToggle::after,
    button.arrowToggle.is-active::after  {
		content: "\f106";
		transition-duration: 0.5s;
	}


}

@media (max-width: 992px) {

    /* Studium und Ausbildung - Bild-Container */
    .setShadow .row > div:nth-child(2) {
        margin-bottom: 15px;
    }
    /* Studium und Ausbildung - Bild */
    .setShadow .row > div:nth-child(2) img {
        position: relative;
        object-fit: unset;
        height: auto;
    }

	/* Teaser (Startseite) */
	.center__middle.content-container .teaser-home-spacing {
		padding-top: 220px;
	}


    /* Teaser Überschrift "Erleben Sie IT in BWgung!" anpassen */
    .homepage-headline .headline-background {
        margin: 0 -20vw;
        padding: 15vw 22vw 15vw;
    }
    .homepage-headline .headline {
        padding-left: 1rem;
        top: -8vw;
        font-size: 7.5vw;
    }
    .homepage-headline .headline span {
        font-size: 10vw;
        top: 6vw;
        left: 1vw;
    }

    .teaser-home .description-box {
        margin-top: -12.5vw;
    }



	/********/
	/* Logo */
	/********/
	.navbar__logo {
		width: 200px;
		padding: 15px;
	}



	/**************/
	/* Navigation */
	/**************/

	.navbar {
		flex-direction: column;
	}

	.navbar__main-nav {
		margin: 0 15% !important; /* Abstand ändern */
	}
	.navbar__main-nav-border {
		margin-left: 0;
	}

	.navbar__logo-container {
        top: 0;
		margin: 0 15%;
	}
	.navbar__logo {
		margin-left: 0;
		padding-left: 15px;
	}



	/**********************/
	/* Scroll-Down Button */
	/**********************/
	.scrolldown-container {
		margin-top: 10vw;
	}




    /**********/
    /* Footer */
    /**********/
	.footer {
		flex-wrap: wrap;
	}
	.footer > * {
		flex: 1 1 auto;
		justify-content: center;
	}
	.footer .imgContainer {
		justify-content: center;
		display: flex;
		margin: 50px 0 35px;
	}


    /************************************************************/
    /* Reihenfolge vertikal setzen (Kontaktpersonen nach unten) */
    /************************************************************/
    .row.jobdetail__content {
        flex-wrap: wrap-reverse;
    }

    header.header {
        padding: 3vw 0 0;
    }
    #bf-nav {
        line-height: 1.2em;
    }

}

@media (max-width: 767px) {
    body h1 {
        font-weight: normal;
        font-size: 2.5em;
    }
    /*.navbar__logo-container {
        top: 0px;
        margin-bottom: 0;
    }*/
}

@media (max-width: 576px) {
    body h1 {
        font-size: 2rem;
    }
	.center__middle.content-container > * > * {
		margin: 0;
	}

    .linkbtn {
        margin: 0 2%;
    }


	/**************/
	/* Navigation */
	/**************/
	.navbar__logo-container {
		margin: 2%;
	}
	.navbar__main-nav {
		margin: 0 2% !important;
	}


	/* Teaser (Startseite) */
	.center__middle.content-container .teaser-home-spacing {
		padding-top: 135px;
		/*padding-bottom: 10%;*/
	}
	.center__middle.content-container .teaser-home-spacing .img-container .row > * {
		padding: 0;
	}
	.center__middle.content-container .teaser-home .img-container img {
		width: 140%;
		margin-bottom: 11%;
	}



	/********/
	/* Logo */
	/********/
	.navbar__logo {
		width: 200px;
	}



	/**********************/
	/* Scroll-Down Button */
	/**********************/
	.scrolldown-container {
		margin-top: 20vw;
	}




	.footer {
		margin: 15px 0 0;
	}
	.footer * {
		overflow-wrap: break-word;
		word-wrap: break-word;
		-webkit-hyphens: auto;
		-ms-hyphens: auto;
		-moz-hyphens: auto;
		hyphens: auto;
	}

	.footer .imgContainer {
		margin-bottom: 50px;
	}

    .external-links {
        margin-left: 10vw;
    }


    /* Teaser Überschrift "Erleben Sie IT in BWgung!" anpassen */
    .homepage-headline .headline-background {
        margin: 0 -40vw;
        padding: 36vw 42vw 50vw;
    }
    .homepage-headline .headline {
        padding-left: 1rem;
        top: -8vw;
        font-size: 11.5vw;
    }
    .homepage-headline .headline span {
        font-size: 16vw;
        top: 10vw;
        left: 1vw;
    }

    .teaser-home .description-box {
        margin-top: -36vw;
    }
    /* SEARCH RESULTS */
    .tx-indexedsearch-res {
        padding: 2% !important;
        margin: 2vh 5% !important;
        overflow-wrap: break-word;
    }
    #bf-nav {
        right: unset;
        left: 20px;
    }
    .grid-container .frame .ce-right .ce-gallery {
        float: none;
    }
}
@media (max-width: 480px) {
    #bf-nav {
        left: 0;
    }
    #bf-nav ul {
        margin-left: 3px;
    }
    #bf-nav ul li {
        padding: 5px;
        font-size: 90%;
        margin-right: 0;
        border-bottom-left-radius: 5px;
        border-bottom-right-radius: 5px;
    }
    #bf-nav ul li a {
        font-size: 90%;
        padding: 5px 5px 5px 2em;
    }
    #bf-nav ul li:before,
    #bf-nav ul li:after {
        display: none;
    }
}


@media (max-width: 380px) {

    .footer-links {
        display: flex;
        flex-direction: column;
    }

    .external-links {
        margin-left: 0;
    }
}
