@font-face {
	font-family: "Saira";
	src: url("../fonts/Saira-Regular.ttf") format("truetype");
	font-weight: 400;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: "Saira";
	src: url("../fonts/Saira-Bold.ttf") format("truetype");
	font-weight: 700;
	font-style: normal;
	font-display: swap;
}

html {
	scroll-behavior: smooth;
}

body {
	color: #222;
	margin: 0px;
	padding: 0px;
	font-family: 'Saira', sans-serif;
}

a {
	color: inherit;
	text-decoration: none;
}

ul {
	list-style-type: none;
	margin: 0px;
	padding: 0px;
}

button, input, select, textarea {
	font-family: 'Saira', sans-serif;
}

.kurse-seite {
	margin-top: 100px;
}

.kurse h1 {
	font-size: 36px;
	line-height: 42px;
}

.kurse ul {
	list-style-type: none;
	margin: 0 0 30px 0;
	padding: 0px;
}

.kurse li {
	line-height: 16px;
	margin-bottom: 0px;
	margin-left: 5px;
	padding: 10px 5px;
}

.kurse li:nth-child(odd) {
	background-color: #ededed;
}


.kurse li.head {
	font-size: 22px;
	line-height: 26px;
	font-weight: 600;
	margin: 30px 0 20px 0;
	color: black;
	background-color: white !important;
}

#filter {
	display: none;
}

#close-kursnav {
	display: none;
}

.kursdetail h1 {
	font-size: 40px;
	margin-bottom: 40px;
}

.kursdetail .infos {
	margin-top: 40px;
}

.kursdetail .text-box {
	line-height: 22px;
}

.kursdetail .text-box span {
	font-size: 24px;
	line-height: 30px;
	margin: 12px 0px 3px 0px;
	display: block;
}

.kursdetail .text-box a {
	color: white;
}

.kursdetail .kursblock {
	display: none;
}

.kursdetail .details .text-box {
	padding: 20px;
	margin-bottom: 20px;
}

.kursdetail .details .text-box span {
	font-size: 16px;
	line-height: 20px;
	font-weight: 700;
	margin-top: 0px;
}

.kursdetail .text-box.black {
	background-color: rgba(230, 152, 54, 1);
}

.kursdetail .text-box.black {
	padding: 10px 20px 20px 20px;
	min-height: 40px;
	color: white;
}

.kursdetail .text-box {
	margin-bottom: 50px;
}

.kursdetail .anmeldenNew {
	background-color: #e3e3e3;
	margin-bottom: 30px;
	padding-top: 30px;
	border-radius: 4px;
}

.kursdetail .anmeldenNew h4 {
	font-size: 26px;
}

#kurstermine .widget-tags a {
	background-color: #2aa861;
}

#kurstermine .widget-tags a.active {
	background-color: #36394a;
}

.widget-tags a {
	display: inline-block;
	padding: 5px 15px;
	margin: 2px 0;
	background-color: rgba(230, 152, 54, 1);
	color: #fff;
	text-decoration: none;
	border: none;
	box-shadow: none;
}

.widget-tags a:hover {
	border: none;
	box-shadow: none;
	color: white;
}

.plaetze i {
	font-size: 26px;
}

.plaetze i.gruen {
	color: #00be37;
}

.plaetze i.gelb {
	color: #e9db10;
}

.plaetze i.orange {
	color: #f58c0d;
}

.plaetze i.rot {
	color: #df0000;
}

.kursdetail .video img {
	max-width: 100%;
	margin-bottom: 30px;
}

.kursdetail button, #linkKurstermine {
	padding: 10px 30px;
    border: none;
    background-color: black;
    color: #fff;
    font-size: 16px;
    transition: all 0.3s;
}

.kursdetail button:hover, #linkKurstermine:hover {
	background-color: #424242;
}

a.mehr {
	text-decoration: underline;
}

.details-button {
	background-color: #a82a74;
	height: 65px;
}

#details, .kurs-anmelden {
	display: inline-block;
    padding: 10px 30px;
    margin: 2px 0;
    background-color: rgba(230, 152, 54, 1);
    color: #fff;
    text-decoration: none;
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
    font-size: 22px;
    font-weight: 700;
    margin-bottom: 15px;
}

#details:hover, .kurs-anmelden:hover {
	text-decoration: none;
	color: white;
	background-color: #36394a;
}

.kurs-anmelden {
	font-size: 16px;
	font-weight: 400;
	margin-top: 15px;
	margin-bottom: 0px;
}

#kursinfo h1 {
	font-size: 26px;
	line-height: 30px;
}

table.kursinfo td {
	padding: 7px 12px;
	line-height: 20px;
	vertical-align: top;
}

table.kursinfo tr:nth-child(even) {
	border-top: 1px solid #ededed;
	border-bottom: 1px solid #ededed;
	background-color: #f8f8f8;
}

table.kursinfo tr td:first-child {
	font-weight: 700;
}

title.featherlight-inner {
	display: none !important;
}

#linkKurstermine {
	cursor: pointer;
	
}

.featherlight .featherlight-close-icon {
	font-size: 30px;
}

#section-kursprogramm {
	margin-bottom: 0px;
	padding-bottom: 0px;
}

.kurse-seite .widget ul li {
	border: none;
}

.neu {
	color: rgba(230, 152, 54, 1);
	display: inline-block;
	margin-left: 10px;
	text-transform: uppercase;
	font-weight: 700;
	border: 1px solid rgba(230, 152, 54, 1);
	padding: 3px;
	border-radius: 3px;
}

.bvmbz {
	color: #2aa861;
	display: inline-block;
	margin-left: 10px;
	text-transform: uppercase;
	font-weight: 700;
	border: 1px solid #2aa861;
	padding: 3px;
	border-radius: 3px;
}

.kddr {
	color: #2aa861;
	display: inline-block;
	margin-left: 10px;
	text-transform: uppercase;
	font-weight: 700;
	border: 1px solid #2aa861;
	padding: 3px;
	border-radius: 3px;
}

.neu-badge {
	margin-bottom: 20px;
}

#errors, #agbText, #widerrufText {
	color: red;
	display: none;
}

.error {
	border-color: red;
}

.highlight {
	font-weight: 700;
}

#page-header.full {
	background-size: cover;
}

.btn.bg {
	color: white;
	font-size: 26px;
}

#agbcontainer.error, #widerrufsfristcontainer.error, #foerderungcontainer.error {
	background-color: rgba(255, 0, 0, 0.4);
}

#captchaText.error {
	color: red;
}

.kursbild {
	margin-bottom: 20px;
}

.kursbild img {
	width: 150px;
}

@media (max-width: 991px) {
	#kursnav {
		position: fixed;
		top: 0px;
		bottom: 0px;
		overflow-y: auto;
		left: -300px;
		height: 100%;
		background-color: rgba(255, 255, 255, 0.98);
		width: 280px;
		z-index: 999999;
		padding-top: 40px;
		-webkit-box-shadow: 9px 0px 15px 0px rgba(0,0,0,0.33);
		-moz-box-shadow: 9px 0px 15px 0px rgba(0,0,0,0.33);
		box-shadow: 9px 0px 15px 0px rgba(0,0,0,0.33);
		-webkit-transition: all 0.3s;
				transition: all 0.3s;
	}
	
	#close-kursnav {
		display: block;
		font-size: 20px;
		margin-bottom: 20px;
		font-weight: 700;
		cursor: pointer;
	}
	
	#kursnav.active {
		left: 0px;
	}
	
	#filter {
		width: 100%;
		height: 33px;
		position: fixed;
		left: 0px;
		top: 0px;
		display: block;
		z-index: 9999;
		background-color: rgba(230, 152, 54, 1);
		color: white;
		font-size: 20px;
		font-weight: 700;
		padding-top: 2px;
		text-align: center;
		cursor: pointer;
	}
	
	.kurse li {
		margin-left: 0px;
		padding: 10px;
		margin-bottom: 0px;
	}
	
	.kurse li:nth-child(odd) {
		background-color: #ededed;
	}
	
	.kurse li a:before {
		display: none;	
	}
	
	.kursdetail .anmeldenNew {
		padding-bottom: 30px;
	}
	
	.kursdetail h1 {
		font-size: 20px;
		line-height: 24px;
	}
	
	.kursdetail .details h4 {
		font-size: 22px;
		line-height: 26px;
	}
	
	.kursdetail .text-box {
		margin-bottom: 3px;
		padding: 20px 20px;
	}
	
	.kursdetail .details .text-box {
		margin-bottom: 3px;
	}
	
	.kursdetail #page-header {
		display: none;
	}
	
	.kursdetail #page-content {
		margin-top: 100px;
	}
}

#kursinfo .noprint {
	display: inline-block;
	margin-right: 10px;
}

#kursbeschreibung {
	margin-top: 30px;
}

.kurse-seite input[type=text], .kurse-seite select, .kurse-seite textarea {
    padding: 10px 20px;
    margin-bottom: 20px;
}

.kurse-seite select {
	width: 100%;
}