/* ------ GENERAL ------ */

* {
  box-sizing: border-box;
}

header, main, footer, article, nav, section, aside {
  display: block;
}
body {
  background: #fff;
  margin: 0px;
  font-family:  'Montserrat', 'Open Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, 'Noto Sans', sans-serif;
  color: #323232;
  font-size: 17px;
  font-weight: 400;
  line-height: 1.5em;
  background: #f2f2f2;
}
@media only screen and (max-width: 1025px) {
  body {
    color: #000000;
	font-size: 15px;
  }
}
h1, h2, h3 {
  font-family: 'Montserrat', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif;
  color: inherit;
  font-weight: 500;
  overflow-wrap: break-word;
  margin-bottom: 1rem;
  margin-top: 0;
  line-height: 1.3em;
  hyphens: auto;
}
h4, h5, h6 {
	font-family: 'Montserrat', 'Open Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, 'Noto Sans', sans-serif;
	font-weight: 400;
	line-height: 1.3em; 
	margin-bottom: 1rem;
  	margin-top: 0;
}
h1 {
  font-size: clamp(38px, 4vw, 55px);
  line-height: 1.3em;
	 color: #2c446c;
}
h1.logo-title {
  font-size: clamp(38px, 4vw, 78px);
}
h2 {
  font-size: clamp(24px, 3vw, 30px);
}
h3 {
  font-size: 20px;
  margin-bottom: 0.5rem;
}
h4 {
  font-size: 16px;
  letter-spacing: 0.1px;
  font-weight: 500;
}

@media only screen and (min-width: 768px) {
	h1, h2, h3, h4, h5, h6 {
		hyphens: manual;	
	}
	h4 {
		font-size: 19px;
	}
}

@media only screen and (min-width: 1025px) {
  h3 {
    font-size: 22px;
  }
}
a {
  transition: all 0.8s ease 0s;
  text-decoration: none;
}
a:hover {
  text-decoration: none !important;
	transition: all 0.8s ease 0s;
}
a[rel="noreferrer noopener"]:after, a[target="_blank"]:after {
  content: "\f139";
  transform: rotate(45deg);
  font-size: 0.7em;
  vertical-align: super;
  line-height: 1em;
  margin-left: 0.2em;
  margin-right: 0.2em;
  font-family: 'Font Awesome 6 Free';
  font-weight: 900;
  color: #dc911e;
  display: inline-block !important;
}
a.wp-block-button__link[rel="noreferrer noopener"]:after {
  color: #fff !important;
}
figure a[rel="noreferrer noopener"]:after, figure a[target="_blank"]:after, #powered a:after, .no-after:after {
	content: none !important;
}

p {
  margin-top: 0;
  margin-bottom: 1em;
  hyphens: manual;
}
p:last-child {
  margin-bottom: 0 !important;
}
p.small, li.small, ul.small {
	font-size: 15px;
	line-height: 1.4;
	margin-bottom :0.6em;
}

@supports (hyphens: auto) or (-webkit-hyphens: auto) or (-ms-hyphens: auto) {
    p {
      hyphens: manual;
      -webkit-hyphens: manual;
      -ms-hyphens: manual;
    }
    .hyphens {
      hyphens: auto;
      -webkit-hyphens: auto;
      -ms-hyphens: auto;
    }
}
.hide {
	display: none !important;
}
.no-margin {
	margin: 0 !important;
}
.no-margin-top {
	margin-top: 0 !important;
}
.no-padding {
	padding: 0 !important;
}
.sprungmarke-pos {
  visibility: hidden;
  position: relative;
}
 .sprungmarke-ext {
  visibility: hidden;
  height: 0px !important;
  position: absolute;
  margin-top: -100px;
}
/* ---------- Container -------------*/
.container-100 {
  width: 100%;
  box-sizing: border-box;
  padding: 2rem 0;
}

.container-100.title {
	padding-bottom: 2rem;
}
.container-100.less-padding {
	padding: 1.5rem 0;
}

.container-100.intro {
box-shadow: inset 0px -7px 7px -4px rgba(0,0,0,0.05);
}

@media only screen and (min-width: 768px) {
  .container-100 {
    padding:  4rem 0;
  }
	
}
@media only screen and (min-width: 1024px) {
  .container-100 {
    padding:  5rem 0;
  }
	.container-100.title {
		padding-bottom: 3rem;
	}
	.container-100.less-padding {
		padding: 3rem 0;
	}
}
.container, .navigation.pagination {
  width: 100%;
  padding-right: 15px;
  padding-left: 15px;
  margin-right: auto;
  margin-left: auto;
}
@media (min-width: 600px) {
  .container, .navigation.pagination {
    max-width: 560px;
  }
}
@media (min-width: 767px) {
  .container, .navigation.pagination {
    max-width: 90vw;
  }
}
@media (min-width: 1025px) {
  .container, .navigation.pagination {
    max-width: 960px;
  }
}
@media (min-width: 1201px) {
  .container, .navigation.pagination {
    max-width: 1140px;
  }
}

.wp-block-button__link {
  background-color: #dc911e !important;
  color: #fff !important;
  font-size: 16px;
  border-radius: 3px;
  padding: 12px 20px;
  -webkit-transition-duration: 0.5s !important;
  transition-duration: 0.5s !important;
  text-decoration: none !important;
  border: none;
	cursor: pointer;
}
.button_small .wp-block-button__link{
	padding: 2px 5px !important;
	font-size: 0.8rem !important;
}
.wp-block-button__link:hover {
  color: #fff;
  background-color: #323232 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
	text-decoration: none !important;
}
.wp-block-button__link:hover:before {
  content: none;
}
.wp-block-buttons .wp-block-button a.wp-block-button__link:before, .wp-block-buttons .wp-block-button a.wp-block-button__link:hover:before {
  font-family: 'Font Awesome 6 Free';
  font-weight: 900;
  padding-right: 0.4em;
  vertical-align: 1px;
}
.wp-block-buttons .wp-block-button.downloadbutton a.wp-block-button__link:before, .wp-block-buttons .wp-block-button.downloadbutton a.wp-block-button__link[rel="noreferrer noopener"]:before {
  content: "\f019";
  font-size: 0.8em;
}
.wp-block-buttons.alignright {
  text-align: right;
}
.wp-block-buttons.is-content-justification-center {
  text-align: center;
}

p + .wp-block-buttons {
	margin-top: 30px;
}


/* ------ MAIN ------ */

main {
  min-height: calc(100vh - 60px);
  padding-top: 50px;
	padding-left: 0 !important;
	padding-right: 0 !important;
  background-size: auto;
  background-position: 0% 100%;
  background-attachment: scroll;
  background-repeat: no-repeat;
}

main article {
  padding: 0;
}
main .sprungmarke {
  height: 50px;
  margin-top: -50px;
}
@media only screen and (min-width: 1201px) {
	main {
		padding-top: 0;
	}
	main .sprungmarke {
		height: 150px;
		margin-top: -150px;
	}
}
main .list {
  line-height: 1.8;
  margin-left: 4.5em !important;
}
main .list li {
  line-height: 2.1;
}
main .list li span {
  left: -2.5em;
}
main .list li i {
  color: #45526d;
}
main a {
  color: #dc911e;
	font-weight: 600;
  transition: all 0.5s ease 0s;
  text-decoration: none !important;
}
main a:hover {
  text-decoration: underline !important;
}
main a:hover.dark {
  background: #dc911e;
}
main ul, main ol {
  margin-top: 0;
  margin-bottom: 1rem;
  padding-left: 19px;
}

main .no-margin li:not(:last-child) {
	margin: 0;
}
main .no-margin li:last-child {
	margin: 0 0 1rem 0;
}

/* ------ HEADER ------ */

header {
  display: flex;
  position: fixed;
  width: 100%;
  height: 50px;
  box-sizing: border-box;
  z-index: 20;
  transition: 0.8s linear 0s;
  justify-content: space-between;
  flex-direction: row;
  background: rgba(255,255,255,0.9);
}

header #logo {
	display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  margin-left: 10px;
  margin-right: 10px;
  opacity: 1;
  transition: 0.3s ease 0s;
	z-index: 9999;
}
header #logo a {
	display: flex;
}
header #logo img {
  transition: 0.8s ease 0s;
  width: auto;
	max-height: 30px;
}

@media only screen and (min-width: 1201px) {
  header {
    height: 120px;
	  flex-direction: row;
	  border-bottom: none;
	  background: linear-gradient(to bottom, rgba(0,0,0,0.2) 0%,rgba(0,0,0,0) 100%);	
  }
	header #logo {
		margin-left: 2%;
    	padding: 3vw 1vw;
    	background: #ffffff;
    	border-radius: 0 0 10px 10px;
		max-height: 100px;
	}
	header #logo img {
		height: auto;
    	max-width: 20vw;
		max-height: 100px;
    	padding: 8px 15px;
  	}
}
@media only screen and (min-width: 1400px) {
	header #logo {
		margin-left: 5%;
	}
}


footer {
  height: auto;
  background: #000;
  color: #fff;
  font-size: 15px;
  line-height: 22px;
}
footer a {
  color: #fff !important;
}
footer a:hover {
  color: #dc911e !important;
}
footer .container {
  width: 100%;
  padding-right: 15px;
  padding-left: 15px;
  margin-right: auto;
  margin-left: auto;
}
footer #topFooter .fas {
  padding-right: 8px;
}
footer #bottomFooter {
  min-height: 35px;
  line-height: 33px;
  border-top: 1px solid #323232;
}
footer p, footer a {
  font-size: 13px;
  color: #fff;
  text-align: center;
  margin-top: 0;
}

footer .wp-block-image a:hover img {
	transform:none;
}
#side-buttons {
  position: fixed;
  right: 15px;
  bottom: 20px;
  z-index: 95;
  overflow: visible;
}
@media (max-width: 1024px) {
  footer .social i.fa-youtube-square {
    padding-right: 0px;
  }
	#side-buttons {
		bottom: 10px;
	}
}
@media (min-width: 600px) {
  footer .container {
    max-width: 560px !important;
  }
}
@media (min-width: 768px) {
  footer .container {
    max-width: 90vw !important;
  }
footer p {
    margin-bottom: 0.5rem;
    font-size: 13px;
    text-align: left;
  }
}
@media (min-width: 1024px) {
  footer .container {
    max-width: 850px !important;
  }
}
@media (min-width: 1200px) {
  footer .container {
    max-width: 1140px !important;
  }
}


/* ------ PLUGINS ------ */

/* --- smart-slider --- */

/* --- Complianz CookieBanner --- */

#cmplz-cookiebanner-container .cmplz-cookiebanner{
	padding: 25px 20px 20px 20px;
}

.privacy-policy #cmplz-cookiebanner-container {
	background-color: transparent;
}

.privacy-policy #cmplz-cookiebanner-container .cmplz-cookiebanner {
	top: initial;
    left: initial;
    right: 10px;
    bottom: 10px;
    transform: initial;
}

.cmplz-cookiebanner .cmplz-close svg {
    color: #dc911e;
}

.cmplz-cookiebanner .cmplz-title {
    font-size: 20px !important;
    font-family: "Exo_2", -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, 'Noto Sans', sans-serif;
  font-weight: 600;
	 color: #dc911e;
}

#cmplz-cookiebanner-container .cmplz-description {
	line-height: 1.4em;
}

#cmplz-cookiebanner-container .cmplz-cookiebanner .cmplz-message {
	margin-bottom: 10px;
}

.cmplz-cookiebanner .cmplz-categories .cmplz-category {
    background-color: #f2f2f2 !important;
}

.cmplz-cookiebanner .cmplz-categories .cmplz-description {
	border-top: 1px solid #c8c8c8;
	background: #fff;
}

.cmplz-cookiebanner .cmplz-categories span {
	color: #323232 !important;
}

#cmplz-cookiebanner-container .cmplz-buttons button, #cmplz-manage-consent button.cmplz-manage-consent {
	border: none;
	height: auto;
}

#cmplz-cookiebanner-container .cmplz-buttons .cmplz-btn:hover {
  color: #fff;
  transition: 0.3s;
  background: #dc911e;
}

#cmplz-manage-consent button.cmplz-btn.cmplz-manage-consent, #Datenschutz button.cmplz-btn.cmplz-manage-consent {
	font-family: 'Font Awesome 6 Free' !important;
	font-weight: 900;
	background-color: #dc911e;
	box-shadow: none;
	font-size: 0.9rem;
	line-height: 1em;
	color: #fff;
	height: 25px;
	min-width: 25px;
	max-width: 25px;
	padding: 4px;
	transition: 0.5s;
	border: none;
	border-radius: 500px;
}

#cmplz-manage-consent button.cmplz-btn.cmplz-manage-consent {
	right: inherit;
    top: inherit;
    left: 15px;
    bottom: 15px !important;
	 z-index: 999999999999;
  filter: drop-shadow(1px 1px 0px rgba(0, 0, 0, 0.5));
}

#cmplz-manage-consent button.cmplz-btn.cmplz-manage-consent:hover, #Datenschutz button.cmplz-btn.cmplz-manage-consent:hover {
	background: #323232 !important;
}


#cmplz-manage-consent button.cmplz-btn:hover:before {
	content: "Cookie-Einstellungen";
  	color: #323232;
	z-index: 9999;
	position: absolute;
    left: 17px;
    top: -30px;
    width: max-content;
    font-size: 12px;
    font-family: sans-serif;
    background: #fff;
    border: 1px solid #000;
    padding: 5px;
	font-weight: 400;
}

.cmplz-blocked-content-container {
	height: auto !important;
}

.cmplz-blocked-content-container.recaptcha-div {
	min-height: 120px;
	margin-top: 10px;
}

.cmplz-placeholder-element {
	border-radius: 5px;
}

.cmplz-blocked-content-container .cmplz-blocked-content-notice, .cmplz-wp-video .cmplz-blocked-content-notice {
	 font-size: 12px !important; 
	 line-height: 1.4em;
	background-color: rgba(0,60,90,0.6) !important;
	border: none;
	border-radius: 5px;
	width: 100% !important;
	height: 100% !important;
	z-index: 97;
	cursor: pointer;
}

.cmplz-blocked-content-container.recaptcha-div .cmplz-blocked-content-notice {
	max-width: 100%;
	height: 100%;
	border-radius: 0px;
}

.cmplz-blocked-content-container:hover .cmplz-blocked-content-notice, .cmplz-wp-video:hover .cmplz-blocked-content-notice {
	background-color: rgba(186,122,26,0.8) !important;
}

@media (max-width: 1450px) {
	#cmplz-manage-consent button.cmplz-btn.cmplz-manage-consent {
		font-size: 0.9rem;
		right: 10px;
	}
}

@media (max-width: 1050px) {
	#cmplz-manage-consent button.cmplz-btn.cmplz-manage-consent {
	
		display:none;
	}
	
	#cmplz-manage-consent button.cmplz-btn.cmplz-manage-consent:hover {
		background-color: #dc911e !important;
		color: #ffffff !important;
	}
}


/* --- WPForms Kontaktformular --- */

div.wpforms-container-full.ek-contact-form .wpforms-form input, div.wpforms-container-full.ek-contact-form .wpforms-form textarea {
	border: none;
}
div.wpforms-container-full.ek-contact-form .wpforms-form input:focus-visible, div.wpforms-container-full.ek-contact-form .wpforms-form textarea:focus-visible {
	outline: 2px solid #dc911e;
	border-radius: 1px;
}
.ek-contact-form .cmplz-blocked-content-container {
	position: relative !important;
}

.ek-contact-form .cmplz-blocked-content-container button {
	border-radius: 5px !important;
}
.wpforms-form input, .wpforms-form textarea {
	background-color: #fff !important;
}

.wpforms-form input[type=submit], 
.wpforms-form button[type=submit] {
    background-color: #dc911e !important;
	border: none !important;
	border-radius: 3px !important;
	padding: 8px 15px !important;
	font-size: 16px !important;
	margin-top: 25px !important;
	transition: 0.5s;
}
.wpforms-form input[type=submit]:hover, 
.wpforms-form input[type=submit]:active, 
.wpforms-form button[type=submit]:hover, 
.wpforms-form button[type=submit]:active {
	 background-color: #323232 !important;
	border-radius: 3px !important;
}

.wpforms-form .wpforms-recaptcha-container {
    padding: 0 !important;
	margin-top: 20px !important;
}
div.wpforms-container-full.ek-contact-form .wpforms-form .wpforms-field {
	padding: 15px 0;
}
.wpforms-form .wpforms-field-label {
	font-weight: 400 !important;
}
div.wpforms-container-full.ek-contact-form  .wpforms-form label.wpforms-error {
	font-family: "Exo_2", -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, 'Noto Sans', sans-serif;
  	font-weight: 600;
	margin-top: 0px;
}

.ek-contact-form .wpforms-confirmation-container-full {
	background: #3c5000 !important;
    border: none !important;
    box-sizing: border-box !important;
	color: #fff;
	margin-top: 55px !important;
}
.ek-contact-form .wpforms-confirmation-container-full p {
	color: #fff !important;
}



/* --- Kadence-blocks --- */
figure.wp-block-image.aligncenter {
  margin-left: auto;
  margin-right: auto;
}

/* gallery */
.l-height-plus p, p.l-height-plus {
	line-height: 2em;
}
.kb-gallery-ul li:last-child {
  margin: 0 auto;
}
.kadence-blocks-gallery-item figure {
  border: 2px solid transparent;
  transition: 0.8s;
}
.kadence-blocks-gallery-item figure:hover {
  border: 2px solid #fff;
  transition: 0.8s;
}
.bordercolor .kadence-blocks-gallery-item figure:hover {
  border: 2px solid #00b0df;
  transition: 0.8s;
}
.kd-gallery-item-vert-center .kadence-blocks-gallery-item {
  align-self: center;
}
.kadence-blocks-gallery-item__caption {
  line-height: 1rem;
}
.caption-cpr .kadence-blocks-gallery-item__caption {
  padding-bottom: 2px !important;
}
.caption-cpr .kadence-blocks-gallery-item__caption p {
  margin: 0;
  line-height: 1.3em;
}
.caption-cpr .kadence-blocks-gallery-item__caption .no-cpr {
  padding-bottom: 8px;
}
.caption-cpr .kadence-blocks-gallery-item__caption .cpr {
  font-size: 0.8em;
  letter-spacing: 0.5px;
  margin: 2px 0;
}
.glightbox-kadence-dark{
	--glightbox-main-overlay: rgba(0, 0, 0, 0.85);
	--glightbox-nav-bg-color: transparent;
    --glightbox-nav-bg-hover-color: rgba(0, 176, 223, 0.85);
}
.glightbox-container .gdesc-inner {
    padding: 15px 20px 20px 20px;
    text-align: center;
}

.kt-blocks-accordion-header:hover {
  cursor: pointer;
}

.wp-block-kadence-infobox a, .wp-block-kadence-infobox a:hover{
	color: #383838;
	text-decoration: none;
}

@media (min-width: 992px) {
	.glightbox-container .gclose {
		opacity: 1; 
	}
}
@media (min-width: 769px) {
	.glightbox-container .gclose, .glightbox-container .gnext, .glightbox-container .gprev {
		transition: 0.5s;
	}
}
@media only screen and (min-width: 1025px) {
  .width66perc {
    width: 66%;
    margin: 0 auto;
  }
}
@media only screen and (max-width: 1025px) {
  button.slbArrow:focus {
    outline: none;
  }
}


/* ------------*/