
/*=============================================
=              CSS                 =
=============================================*/


/* satisfy-regular - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Satisfy';
  font-style: normal;
  font-weight: 400;
  src: url('../fonts/satisfy-v21-latin-regular.eot'); /* IE9 Compat Modes */
  src: url('../fonts/satisfy-v21-latin-regular.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
       url('../fonts/satisfy-v21-latin-regular.woff2') format('woff2'), /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
       url('../fonts/satisfy-v21-latin-regular.woff') format('woff'), /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+, iOS 5+ */
       url('../fonts/satisfy-v21-latin-regular.ttf') format('truetype'), /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
       url('../fonts/satisfy-v21-latin-regular.svg#Satisfy') format('svg'); /* Legacy iOS */
}



/* encode-sans-100 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Encode Sans';
  font-style: normal;
  font-weight: 100;
  src: url('../fonts/encode-sans-v19-latin-100.eot'); /* IE9 Compat Modes */
  src: url('../fonts/encode-sans-v19-latin-100.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
       url('../fonts/encode-sans-v19-latin-100.woff2') format('woff2'), /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
       url('../fonts/encode-sans-v19-latin-100.woff') format('woff'), /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+, iOS 5+ */
       url('../fonts/encode-sans-v19-latin-100.ttf') format('truetype'), /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
       url('../fonts/encode-sans-v19-latin-100.svg#EncodeSans') format('svg'); /* Legacy iOS */
}
/* encode-sans-200 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Encode Sans';
  font-style: normal;
  font-weight: 200;
  src: url('../fonts/encode-sans-v19-latin-200.eot'); /* IE9 Compat Modes */
  src: url('../fonts/encode-sans-v19-latin-200.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
       url('../fonts/encode-sans-v19-latin-200.woff2') format('woff2'), /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
       url('../fonts/encode-sans-v19-latin-200.woff') format('woff'), /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+, iOS 5+ */
       url('../fonts/encode-sans-v19-latin-200.ttf') format('truetype'), /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
       url('../fonts/encode-sans-v19-latin-200.svg#EncodeSans') format('svg'); /* Legacy iOS */
}
/* encode-sans-300 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Encode Sans';
  font-style: normal;
  font-weight: 300;
  src: url('../fonts/encode-sans-v19-latin-300.eot'); /* IE9 Compat Modes */
  src: url('../fonts/encode-sans-v19-latin-300.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
       url('../fonts/encode-sans-v19-latin-300.woff2') format('woff2'), /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
       url('../fonts/encode-sans-v19-latin-300.woff') format('woff'), /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+, iOS 5+ */
       url('../fonts/encode-sans-v19-latin-300.ttf') format('truetype'), /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
       url('../fonts/encode-sans-v19-latin-300.svg#EncodeSans') format('svg'); /* Legacy iOS */
}
/* encode-sans-regular - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Encode Sans';
  font-style: normal;
  font-weight: 400;
  src: url('../fonts/encode-sans-v19-latin-regular.eot'); /* IE9 Compat Modes */
  src: url('../fonts/encode-sans-v19-latin-regular.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
       url('../fonts/encode-sans-v19-latin-regular.woff2') format('woff2'), /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
       url('../fonts/encode-sans-v19-latin-regular.woff') format('woff'), /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+, iOS 5+ */
       url('../fonts/encode-sans-v19-latin-regular.ttf') format('truetype'), /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
       url('../fonts/encode-sans-v19-latin-regular.svg#EncodeSans') format('svg'); /* Legacy iOS */
}
/* encode-sans-500 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Encode Sans';
  font-style: normal;
  font-weight: 500;
  src: url('../fonts/encode-sans-v19-latin-500.eot'); /* IE9 Compat Modes */
  src: url('../fonts/encode-sans-v19-latin-500.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
       url('../fonts/encode-sans-v19-latin-500.woff2') format('woff2'), /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
       url('../fonts/encode-sans-v19-latin-500.woff') format('woff'), /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+, iOS 5+ */
       url('../fonts/encode-sans-v19-latin-500.ttf') format('truetype'), /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
       url('../fonts/encode-sans-v19-latin-500.svg#EncodeSans') format('svg'); /* Legacy iOS */
}
/* encode-sans-600 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Encode Sans';
  font-style: normal;
  font-weight: 600;
  src: url('../fonts/encode-sans-v19-latin-600.eot'); /* IE9 Compat Modes */
  src: url('../fonts/encode-sans-v19-latin-600.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
       url('../fonts/encode-sans-v19-latin-600.woff2') format('woff2'), /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
       url('../fonts/encode-sans-v19-latin-600.woff') format('woff'), /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+, iOS 5+ */
       url('../fonts/encode-sans-v19-latin-600.ttf') format('truetype'), /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
       url('../fonts/encode-sans-v19-latin-600.svg#EncodeSans') format('svg'); /* Legacy iOS */
}
/* encode-sans-700 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Encode Sans';
  font-style: normal;
  font-weight: 700;
  src: url('../fonts/encode-sans-v19-latin-700.eot'); /* IE9 Compat Modes */
  src: url('../fonts/encode-sans-v19-latin-700.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
       url('../fonts/encode-sans-v19-latin-700.woff2') format('woff2'), /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
       url('../fonts/encode-sans-v19-latin-700.woff') format('woff'), /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+, iOS 5+ */
       url('../fonts/encode-sans-v19-latin-700.ttf') format('truetype'), /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
       url('../fonts/encode-sans-v19-latin-700.svg#EncodeSans') format('svg'); /* Legacy iOS */
}
/* encode-sans-800 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Encode Sans';
  font-style: normal;
  font-weight: 800;
  src: url('../fonts/encode-sans-v19-latin-800.eot'); /* IE9 Compat Modes */
  src: url('../fonts/encode-sans-v19-latin-800.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
       url('../fonts/encode-sans-v19-latin-800.woff2') format('woff2'), /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
       url('../fonts/encode-sans-v19-latin-800.woff') format('woff'), /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+, iOS 5+ */
       url('../fonts/encode-sans-v19-latin-800.ttf') format('truetype'), /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
       url('../fonts/encode-sans-v19-latin-800.svg#EncodeSans') format('svg'); /* Legacy iOS */
}
/* encode-sans-900 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Encode Sans';
  font-style: normal;
  font-weight: 900;
  src: url('../fonts/encode-sans-v19-latin-900.eot'); /* IE9 Compat Modes */
  src: url('../fonts/encode-sans-v19-latin-900.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
       url('../fonts/encode-sans-v19-latin-900.woff2') format('woff2'), /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
       url('../fonts/encode-sans-v19-latin-900.woff') format('woff'), /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+, iOS 5+ */
       url('../fonts/encode-sans-v19-latin-900.ttf') format('truetype'), /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
       url('../fonts/encode-sans-v19-latin-900.svg#EncodeSans') format('svg'); /* Legacy iOS */
}

*, *::after, *::before {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

html, body {
  height: 100%;
}

body {
  line-height: 36px;
  font-size: 22px;
  font-style: normal;
  font-weight: normal;
  visibility: visible;
  font-family: 'Encode Sans', sans-serif;
  color: #4A4A4A;
  position: relative;
  background-color: #ffffff;
}

h1, h2, h3, h4, h5, h6 {
  font-weight: normal;
  margin-top: 0;
  margin-bottom: 0;
  color: #FB9A00;
  font-family: 'Satisfy', serif;
}

h1 {
  font-size: 52px;
  line-height: 75px;
  font-weight: normal;
  margin-bottom: 45px;
}

h2 {
  font-size: 52px;
  line-height: 75px;
  font-weight: normal;
  margin-bottom: 45px;
}

h3 {
  font-size: 37px;
  line-height: 54px;
  font-weight: 300;
  color: #4A4A4A;
  margin-bottom: 20px;
}


img {
  max-width: 100%;
  height: auto;
}

p {
  line-height: 36px;
  font-size: 22px;
  margin-bottom: 20px;
  color: #4A4A4A;
  font-weight: normal;
}
ul {
  margin-bottom: 30px;
  padding-left: 20px;
}
li {
  line-height: 24px;
  font-size: 18px;
}

strong, p strong {
  font-weight: 600;
}
a, button {
  color: #4A4A4A;
  display: inline-block;
  line-height: inherit;
  text-decoration: none;
  cursor: pointer;
}

a, button, img, input {
  -webkit-transition: all 0.7s cubic-bezier(0.645, 0.045, 0.355, 1);
  -o-transition: all 0.7s cubic-bezier(0.645, 0.045, 0.355, 1);
  transition: all 0.7s cubic-bezier(0.645, 0.045, 0.355, 1);
}

*:focus {
  outline: none !important;
}

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

.btn.focus, .btn:focus {
  outline: none;
  -webkit-box-shadow: none;
          box-shadow: none;
}

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


/*===========================================
=        Custom Animation Css
===========================================*/
@keyframes zoombkg {
  0% {
    background-size: 110% auto;
  }
  100% {
    background-size: 100% auto;
  }
}
/*===========================================
=        Zoom IMG
===========================================*/
.zoomimage img {
  -webkit-transition: all 6000ms linear;
  -moz-transition: all 6000ms linear;
  -ms-transition: all 6000ms linear;
  -o-transition: all 6000ms linear;
  transition: all 6000ms linear;
}
.zoomimage:hover img {
  webkit-transform: scale(1.08);
  -ms-transform: scale(1.08);
  transform: scale(1.08);
}


/*=============================================
=              Header Css            =
=============================================*/
.header-area {
  position: absolute;
  z-index: 11;
  width: 100%;
}
.header-area .header-sticky>.container-fluid {
  padding-right: 50px;
  padding-left: 50px;
}
.header-area .is-sticky {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  -webkit-animation: .95s ease-in-out 0s normal none 1 running fadeInDown;
  animation: .95s ease-in-out 0s normal none 1 running fadeInDown;
  z-index: 999;
  -webkit-transition: all 0.7s cubic-bezier(0.645, 0.045, 0.355, 1);
  -o-transition: all 0.7s cubic-bezier(0.645, 0.045, 0.355, 1);
  transition: all 0.7s cubic-bezier(0.645, 0.045, 0.355, 1);
  -webkit-box-shadow: 0 8px 20px 0 rgba(0, 0, 0, 0.1);
  box-shadow: 0 8px 20px 0 rgba(0, 0, 0, 0.1);
  background-color: #4A4A4A;
  padding:10px 0;
}

.header-area .is-sticky .header-right {
  padding-top: 0;
}

.header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: relative;
}

.header-center {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    justify-content: center;
    align-items: center;
}

@keyframes fadeInLogo {
  0% {
    opacity: 0;
    transform: scale(0.8);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}

.header__logo {
  position: relative;
  margin-top: 20px;
	z-index: 9;
  opacity: 0;
  animation: fadeInLogo 3s forwards cubic-bezier(0.68, -0.55, 0.27, 1.55);
}
.header__logo img {
  width: 500px;
}
.sticky__logo {
  display: none;
}
.header-area .is-sticky .header__logo {
  display: none;
}
.header-area .is-sticky .sticky__logo {
  display: block;
  width: 260px;
}
.header-right {
  padding-top: 40px;
  display: flex;
  align-items: center;
}
.header-right-display.menu-active {
  display: none;
}

.header-left {
  padding-top: 40px;
}

.header-area .is-sticky .header-left {
  padding-top: 0
}

/* Mobile Mavigation icon */
.mobile-navigation-icon {
  position: relative;
  cursor: pointer;
  display: inline-block;
  margin-left: 20px;
}
.mobile-navigation-icon:before {
  font-family: 'Font Awesome 5 Free';
  font-weight: 900;
  content: "\f0c9";
  color: #ffffff;
  font-size: 40px;
}
.mobile-navigation-icon:hover:before {
  color: #FB9A00;
}



/*================================
    - Mobile Menu Css
==================================*/

.mobile-menu-overlay {
  position: fixed;
  right: 0;
  top: 0;
  width: 800px;
  height: 100vh;
  overflow: auto;
  -webkit-transition: all 1s cubic-bezier(0.645, 0.045, 0.355, 1);
  -o-transition: all 1s cubic-bezier(0.645, 0.045, 0.355, 1);
  transition: all 1s cubic-bezier(0.645, 0.045, 0.355, 1);
  z-index: 9999;
  visibility: hidden;
  opacity: 0;
  background: rgba(0,0,0,0.8);
}

.mobile-menu-overlay__inner {
  -webkit-transform: translateX(120%);
  -ms-transform: translateX(120%);
  transform: translateX(120%);
  width: 100%;
  height: 100%;
  cursor: default;
  -webkit-transition: all 1s cubic-bezier(0.645, 0.045, 0.355, 1);
  -o-transition: all 1s cubic-bezier(0.645, 0.045, 0.355, 1);
  transition: all 1s cubic-bezier(0.645, 0.045, 0.355, 1);
  overflow-y: auto;
  padding: 0 50px;
  z-index: 4;
  position: relative;
}

.mobile-menu-overlay.active {
  visibility: visible;
  opacity: 1;
}

.mobile-menu-overlay.active .mobile-menu-overlay__inner {
  -webkit-transform: translateX(0%);
  -ms-transform: translateX(0%);
  transform: translateX(0%);
}
.mobile-menu-overlay .header {
  justify-content: flex-end;
}
.mobile-menu-overlay .header-right {
  padding-top: 56px;
}
.mobile-menu-overlay__header .row {
  justify-content: center;
}
.mobile-menu-overlay__header .col-12 {
  -webkit-box-flex: 1;
  -webkit-flex-grow: 1;
  -ms-flex-positive: 1;
  flex-grow: 1;
  -webkit-align-self: stretch;
  -ms-flex-item-align: stretch;
  align-self: stretch;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
  -webkit-justify-content: flex-end;
  -ms-flex-pack: end;
  justify-content: flex-end;
  padding-top: 93px;
  max-width: 87%;
}

/* Mobile Mavigation close icon */
.mobile-menu-overlay__header .mobile-navigation-close-icon {
  position: relative;
  cursor: pointer;
  display: inline-block;
  margin-left: 20px;
}
.mobile-menu-overlay__header .mobile-navigation-close-icon:before {
  font-family: 'Font Awesome 5 Free';
  font-weight: 900;
  content: "\f00d";
  color: #ffffff;
  font-size: 40px;
}
.mobile-menu-overlay__header .mobile-navigation-close-icon:hover:before {
  color: #FB9A00;
}

.mobile-menu-overlay__body {
  padding: 100px 0 30px 0;
  text-align: center;
}

.mobile-menu-overlay__body .offcanvas-navigation ul {
  padding-left: 0;
}

.mobile-menu-overlay__body .offcanvas-navigation > ul > li {
  list-style: none;
  display: block;
  cursor: pointer;
}
.mobile-menu-overlay__body .offcanvas-navigation > ul > li a.active {
  color: #FB9A00;
}
.mobile-menu-overlay__body .offcanvas-navigation > ul > li > a, .mobile-menu-overlay__body .offcanvas-navigation > ul > li.has-children span {
  display: block;
  color: #ffffff;
  font-weight: normal;
  font-size: 24px;
  line-height: 24px;
  margin-bottom: 30px;
  text-transform: uppercase;
  -webkit-transition: all 0.7s cubic-bezier(0.645, 0.045, 0.355, 1);
  -o-transition: all 0.7s cubic-bezier(0.645, 0.045, 0.355, 1);
  transition: all 0.7s cubic-bezier(0.645, 0.045, 0.355, 1);
}

.mobile-menu-overlay__body .offcanvas-navigation > ul > li > a:hover, .mobile-menu-overlay__body .offcanvas-navigation > ul > li.has-children:hover span {
  color: #FB9A00;
}

.mobile-menu-overlay__body .offcanvas-navigation > ul > li.has-children .submenu {
  padding: 0 0 20px 0;
  display: none;
  -webkit-transition: all 1s cubic-bezier(0.645, 0.045, 0.355, 1);
  -o-transition: all 1s cubic-bezier(0.645, 0.045, 0.355, 1);
  transition: all 1s cubic-bezier(0.645, 0.045, 0.355, 1);
}
.has-children > span::after {
  content: '▼';
  font-size: 16px;
  margin-left: 10px;
  display: inline-block;
  vertical-align: middle;
}
.has-children.open > span::after {
  content: '▲';
}

.mobile-menu-overlay__body .offcanvas-navigation > ul > li.has-children .submenu > li {
  list-style: none;
  display: block;
  margin-bottom: 20px;
}

.mobile-menu-overlay__body .offcanvas-navigation > ul > li.has-children .submenu > li > a {
  display: block;
  color: #ffffff;
  font-size: 20px;
  letter-spacing: 1px;
  line-height: 20px;
  font-weight: 300;
  -webkit-transition: all 0.7s cubic-bezier(0.645, 0.045, 0.355, 1);
  -o-transition: all 0.7s cubic-bezier(0.645, 0.045, 0.355, 1);
  transition: all 0.7s cubic-bezier(0.645, 0.045, 0.355, 1);
}

.mobile-menu-overlay__body .offcanvas-navigation > ul > li.has-children .submenu > li > a:hover {
  color: #FB9A00;
}



/*======================
    - Socials im Menü
=======================*/
.menu-social i {
  color: #ffffff;
  font-size: 29px;
}
.menu-social i:hover {
  color: #FB9A00;
}


/*======================
    - language - Sprachen
=======================*/
.language-menu {
  padding: 0 10px;
  color: #ffffff;
  font-size: 35px;
  line-height: 35px;
}
.language-menu a {
  padding: 0 5px;
  color: #ffffff;
  font-size: 28px;
  line-height: 28px;
}
.language-menu a:hover {
  color: #FB9A00;
}
/*=====  End of Language  ======*/



/*======================
    - Header Icons
=======================*/
.header-icons {
  margin-right: 20px;
}
.header-icons a {
  font-size: 23px;
  color: #ffffff;
  padding-right: 10px;
}
.header-icons a:last-child {
  padding-right: 0;
}
.header-icons i {
  font-size: 23px;
  padding: 20px 5px;
    color: #ffffff;
}
.header-icons a:hover i, .header-icons a:hover {
  color: #FB9A00;
}
.header-area .is-sticky .header-icons i {
  padding: 17px 5px;
}




/*===========================================
=        Slider
===========================================*/
.flexible-image-slider-wrap {
  position: relative;
}
.swiper-container {
    width: 100%;
    height: 100%;
    overflow: hidden;
}

#home .service-hero-space {
  height: 100vh;
}
.service-hero-space {
  height: 500px;
  display: block;
  -webkit-box-align: end;
  -webkit-align-items: end;
      -ms-flex-align: end;
          align-items: end;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
}

.service-hero-space:before {
  content: '';
  background: linear-gradient(0deg, rgba(0,0,0,0) 0%, rgba(0,0,0,0.7) 100%);
  width: 100%;
  height: 300px;
  position: absolute;
  top: -1px;
  z-index: 3;
}
.service-hero-bg {
	background-size: cover;
  background-position: center center;
}



/*===========================================
=        Swiper Slider Navigation
===========================================*/

.swiper-button-prev, .swiper-button-next {
    opacity: 0;
    transition: opacity 0.5s ease;
    width: 134px;
    z-index: 1;
    position: absolute;
    top: 0;
    height: 100%;
    margin-top: 0;
}
.swiper-button-prev:hover,
.swiper-button-next:hover {
    opacity: 1;
}
.swiper-button-prev::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(to right, rgba(0, 0, 0, 0.7), transparent);
    z-index: -1;
    pointer-events: none;
}
.swiper-button-next::before {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(to left, rgba(0, 0, 0, 0.7), transparent);
    z-index: -1;
    pointer-events: none;
}
.swiper-button-prev {
    left: 0;
}
.swiper-button-prev:after {
    content: '';
    background-image: url('../assets/arrow-left.png');
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    width: 134px;
    height: 100%;
    position: relative;
    left: 20px;
}
.swiper-button-next {
    right: 0;
}
.swiper-button-next:after {
    content: '';
    background-image: url('../assets/arrow-right.png');
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    width: 134px;
    height: 100%;
    position: relative;
    right: 20px;
}

.roomslider .swiper-button-prev, .roomslider .swiper-button-next {
  width: 80px;
}
.roomslider .swiper-button-prev:after, .roomslider .swiper-button-next:after {
    background-size: 80px auto;
    width: 80px;
}


/*===========================================
=        Swiper Pagination
===========================================*/

.swiper-pagination .swiper-pagination-bullet-active, .swiper-pagination .swiper-pagination-bullet {
  background-color: #ffffff;
  opacity: 0.8;
  margin: 0 10px;
}
.swiper-pagination .swiper-pagination-bullet-active {
  transform: scale(1.5);
  opacity: 1;
}

/*===========================================
=        Error Page
===========================================*/
.error-section {
  padding-top: 300px;
  padding-bottom: 300px;
}
.error-section .error-title {
  font-size: 90px;
  line-height: 90px;
}
.error-section .error-button {
    font-weight: 500;
    text-transform: lowercase;
    font-size: 18px;
    display: inline-block;
    border: none;
    color: #ffffff;
    background: #FB9A00;
    padding: 7px 30px;
    border-radius: 30px;
    margin-top: 50px;
}
.error-section .error-button:hover {
    color: #4A4A4A;
}


/* Impressum Page */
.impressum {
  padding-top: 115px;
  padding-bottom: 115px;
}
.impressum .impressum_box {
  margin-bottom: 30px;
}
.impressum a {
  color: #4A4A4A;
}
.impressum .privacy {
  margin-top: 50px;
}




/*=============================================
=           Buttons         =
=============================================*/
.mehr-button {
  font-weight: normal;
  font-size: 20px;
  display: inline-block;
  border: none;
  color: #4A4A4A;
  padding: 0;
  position: relative;
  transition: color 1s ease;
  margin: 10px 22px;
}
.mehr-button::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: 0;
  width: 27px;
  height: 1px;
  background-color: #4A4A4A;
  transition: all 1s ease;
}
.mehr-button:hover {
  color: #FB9A00;
}
.mehr-button:hover::after {
  width: 100%;
  background-color: #FB9A00;
}
.mehr-button:focus {
  border: none;
  outline: none;
}



/*=============================================
=           Lupe bei Lightbox         =
=============================================*/
.swiperlightbox1 a:hover::after, .swiperlightbox2 a:hover::after, .swiperlightboxtab1 a:hover::after, .swiperlightboxtab2 a:hover::after, .swiperlightboxtab3 a:hover::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  height: 100%;
  background-image: url(../assets/lupe.png);
  background-color: rgba(74,74,74,0.5);
  background-size: 100px auto;
  background-repeat: no-repeat;
  background-position: center;
  pointer-events: none;
}



/*=============================================
=            Über uns About Content          =
=============================================*/

.about {
  padding-top: 100px;
  padding-bottom: 100px;
}
.about .socialwall {
  margin-top: 100px;
}
.about .bildergalerie {
  display: inline-block;
}


/*=============================================
=            Zimmer          =
=============================================*/

.zimmer {
  background: #f7f7f7;
  padding-top: 100px;
  padding-bottom: 100px;
}

.zimmer .allgemeineinfos {
  padding-top: 50px;
  padding-left: 100px;
}
.zimmer .personen:before {
  content: "\f0c0";
  font-family: "Font Awesome 5 Free";
  font-size: 30px;
  color: #FFC05D;
  font-weight: 900;
  padding-right: 25px;
}
.zimmer .qm:before {
  content: "\f523";
  font-family: "Font Awesome 5 Free";
  font-size: 30px;
  color: #FFC05D;
  font-weight: 900;
  padding-right: 28px;
  padding-left: 5px;
}


.accordion {
  margin-top: 20px;
}
.accordion .collapsing {
  transition: height 1s ease;
}
.accordion-item {
  background-color: transparent;
  border: none;
  border-bottom: 1px solid #4A4A4A;
  margin-bottom: 10px;
}
.accordion-item:first-of-type .accordion-button, .accordion-item.accordion-button {
  border: none;
}
.accordion-item:last-of-type {
  border-radius: 0;
}
.accordion-button {
  background: transparent;
  border: 0;
  padding: 5px 0;
  text-transform: none;
  font-size: 22px;
  font-weight: normal;
  line-height: 36px;
  color: #4A4A4A;
  display: flex;
  justify-content: space-between;
  width: 100%;
}
.accordion-button:not(.collapsed) {
  color: #4A4A4A;
  font-weight: 500;
  background-color: transparent;
}
.accordion-button:focus {
  box-shadow: none;
}
.accordion-button:not(.collapsed)::after, .accordion-button::after {
  display: none;
}
.accordion-button .button-label {
  text-align: left;
}
.accordion-button i {
  margin-left: auto;
  font-size: 24px;
  -webkit-text-stroke: 2px #f7f7f7;
}
.accordion-body {
  padding: 20px 0 10px 0;
}
.accordion-body p, .accordion-body li {
  font-size: 18px;
  line-height: 28px;
}

.zimmer .allgemeineinfos .mehr-button {
  margin: 10px 44px 10px 0;
}

.zimmerslider {
  padding-top: 50px;
  padding-left: 80px;
}
.mobile-buttons {
  display: none;
}




/*=============================================
=           Restaurant      =
=============================================*/

.restaurant {
  padding-top: 100px;
  padding-bottom: 100px;
}
.restaurant-text {
  padding-left: 50px;
}

/*=============================================
=            Umgebung      =
=============================================*/

.umgebung {
  padding-top: 100px;
  padding-bottom: 100px;
  background: #f7f7f7;
}
.umgebung-text {
  padding-left: 50px;
}
.nav-tabs {
  margin-top: 50px;
  margin-bottom: 50px;
  border: none;
}
.nav-tabs .nav-item {
  margin-right: 100px
}
.nav-tabs .nav-item:last-child {
  margin-right: 0;
}
.nav-tabs .nav-link {
  color: #B4B4B4;
  background-color: transparent;
  border: none;
  position: relative;
  padding: 2px 0;
  font-weight: 600;
}
.nav-tabs .nav-link::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: 0;
  width: 27px;
  height: 1px;
  background-color: #B4B4B4;
  transition: all 1s ease;
}

.nav-tabs .nav-link.active {
  color: #4A4A4A;
  background-color: transparent;
  font-weight: 500;
}
.nav-tabs .nav-link:hover {
  color: #7E7E7E;
}
.nav-tabs .nav-link:hover::after, .nav-tabs .nav-link.active::after {
  width: 100%;
  background-color: #7E7E7E;
}




/*=============================================
=           Home Anfrage          =
=============================================*/

.anfrage {
  padding-top: 100px;
  padding-bottom: 100px;
  text-align: center;
}
.anfrage form {
  margin-top: 50px;
}
.anfrage form label {
  color: #FB9A00;
  text-align: left;
  margin-top: 19px;
}

.anfrage form input[type="text"], .anfrage form input[type="date"], .anfrage form input[type="number"], .anfrage form input[type="tel"], .anfrage form input[type="email"], .anfrage form textarea, .anfrage form select {
  width: 100%;
  padding: 5px 10px;
  border: 1px solid #4A4A4A;;
  background: transparent;
  color: #4A4A4A;
  appearance: none; /* Entfernt das Standard-Styling */
  -webkit-appearance: none; /* Entfernt das Standard-Styling in WebKit-Browsern */
  -moz-appearance: none; /* Entfernt das Standard-Styling in Firefox */
  border-radius: 4px;
  height: 42px;
  font-size: 15px;
}
.anfrage form input[type="date"] {
    padding: 5px 10px;
    height: 42px;
}
.anfrage form select option {
  color: #4A4A4A;
}
.anfrage form textarea {
  height: 100px;
}

.anfrage .form-column {
  display: flex;
  flex-wrap: wrap;
  padding: 0px 15px;
}

.anfrage .form-data {
  padding: 0px 10px;
}

.anfrage .form-label {
  text-align: left;
  padding: 0px 10px;
}

.sendbtn {
  font-weight: normal;
  font-size: 20px;
  display: inline-block;
  border: none;
  color: #4A4A4A;
  padding: 0;
  position: relative;
  transition: color 1s ease;
  margin: 10px 22px;
}
.sendbtn::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: 0;
  width: 27px;
  height: 1px;
  background-color: #4A4A4A;
  transition: all 1s ease;
}
.sendbtn:hover {
  color: #FB9A00;
}
.sendbtn:hover::after {
  width: 100%;
  background-color: #FB9A00;
}

.anfrage .form-check .form-input-wrapper input {
  width: 20px;
  margin-right: 10px;
  height: 20px;
}
.anfrage .form-check {
  font-size: 17px;
  margin-top: 30px;
}
.anfrage .form-check .form-label {
  display: none;
}
.anfrage .form-captcha .form-label {
  display: none;
}

::-webkit-input-placeholder {
    /* WebKit browsers */
     color: transparent;
}
 :-moz-placeholder {
    /* Mozilla Firefox 4 to 18 */
     color: transparent;
}
 ::-moz-placeholder {
    /* Mozilla Firefox 19+ */
     color: transparent;
}
 :-ms-input-placeholder {
    /* Internet Explorer 10+ */
     color: transparent;
}
 input::placeholder {
     color: transparent;
}
 textarea::-webkit-input-placeholder {
    /* WebKit browsers */
     color: transparent;
}
 textarea:-moz-placeholder {
    /* Mozilla Firefox 4 to 18 */
     color: transparent;
}
 textarea::-moz-placeholder {
    /* Mozilla Firefox 19+ */
     color: transparent;
}
 textarea:-ms-input-placeholder {
    /* Internet Explorer 10+ */
     color: transparent;
}
 textarea::placeholder {
     color: transparent;
}



/*=============================================
=           Booking          =
=============================================*/

.booking {
  padding-top: 100px;
  padding-bottom: 100px;
  background-color: #f7f7f7;
  text-align: center;
}

.booking .Bs-Progress .Bs-ProgressBar,
.booking .fgz8rjd,
.booking .f1uyxqqn, .booking .f1uyxqqn:hover,
.booking .f1uyxqqn, .booking .f1uyxqqn:hover,
.booking .f1uyxqqn, .booking .f1uyxqqn:hover {
  background: #FB9A00;
}
.booking .f1hd1h5v b,
.booking .fwxscmf {
  color: #FB9A00;
}
.booking .fdx92gl {
  fill: #FB9A00;
}



/*=============================================
=           Anreise          =
=============================================*/

.anreise {
  padding-top: 100px;
  padding-bottom: 60px;
  text-align: center;
}


/*=============================================
=            Footer         =
=============================================*/

footer .footer {
  background-position: top center;
  background-repeat: no-repeat;
  background-size: cover;
  position: relative;
  z-index: 1;
}
footer .footer:before {
  content: '';
  height: 100%;
  width: 100%;
  background: linear-gradient(0deg, rgba(255,255,255,0.5) 0%, rgba(255,255,255,1) 100%);
  position: absolute;
  z-index: -1;
}
footer .footer-right {
  padding: 50px;
  text-align: center;
  justify-content: center;
  align-items: center;
  display: flex;
  flex-flow: column;
}
footer .footer-right .footer-logo {
  width: 500px;
}
footer .footer-social {
  margin-top: 10px;
}
footer .footer-social i {
  font-size: 28px;
  color: #4A4A4A;
  line-height: 48px;
  margin-left: 5px;
}
footer .footer-social i:hover {
  color: #FB9A00;
}
footer .footer-left {
  padding: 100px 50px 50px 50px;
}
footer .footer-left-inner {
  text-align: center;
}
footer .footer-left h4 {
  color: #FB9A00;
  font-size: 52px;
  line-height: 62px;
  margin-bottom: 40px;
}
footer .footer-left p {
  font-size: 23px;
  line-height: 38px;
}
footer .footer-left a {
  color: #4A4A4A;
}
footer .footer-left a:hover {
  color: #FB9A00;
}
footer .footer-left i {
  font-size: 35px;
}

footer .footer-logos {
  padding-top: 15px;
  padding-bottom: 15px;
  display: flex;
  align-items: center;
  flex-wrap: nowrap;
  place-content: space-evenly;
}



footer .copyright {
  background: #FB9A00;
}
footer .copyright .row {
  padding-top: 15px;
  padding-bottom: 15px;

}
footer .copyright p {
  color: #FFFFFF;
  margin-bottom: 0;
  font-size: 18px;
  line-height: 28px;
}
footer .copyright a {
    color: #FFFFFF;
}
footer .copyright a:hover {
  color: #4A4A4A;
}


/*=============================================
=            Infotext im Menü        =
=============================================*/
.menu-infotext {
  margin-top: 70px;
}
.menu-infotext, .menu-infotext p {
  color: #ffffff;
  margin-bottom: 0;
  font-size: 20px;
  line-height: 33px;
}



/*=============================================
=            Mobile Sidebar         =
=============================================*/


.mobile-sidebar {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  margin: 0;
  padding: 0;
  z-index: 999;
  background: #FB9A00;
}
.mobile-sidebar ul {
  display: flex;
  justify-content: center;
  margin: 0;
  padding: 0;
}
.mobile-sidebar li {
  list-style: none;
  display: inline-block;
  text-align: center;
  margin: 0;
  width: -webkit-fill-available;
  width: fill-available;
  width: 100%;
}

.mobile-sidebar a {
  color: #ffffff;
  text-decoration: none;
  display: block;
  height: 50px;
  font-size: 24px;
  line-height: 50px;
  position: relative;
  text-align: center;
  cursor: pointer;
  padding: 0;
  margin: 0;
}
.mobile-sidebar li:nth-child(1) {
  background: #fdab2a;
}
.mobile-sidebar li:nth-child(2) {
  background: #ffb137;
}
.mobile-sidebar li:nth-child(3) {
  background: #fdb84d;
}
.mobile-sidebar li:nth-child(4) {
  background: #FFC05D;
}

/* -------------------------------------------------------
--------------------   RESPONSIVE ------------------------
---------------------------------------------------------- */
@media (max-width: 1400px) {
  .header__logo img {
    width: 400px;
  }
  .mobile-menu-overlay {
    width: 500px;
  }
  .mobile-menu-overlay__body {
    padding-top: 40px;
  }
  .zimmer .allgemeineinfos, .zimmerslider {
    padding-left: 30px;
  }
}



@media (max-width: 1200px) {
  #home .homeslider .service-hero-space {
    height: 600px;
  }
  .homeslider .service-hero-space {
    height: 380px;
  }
  .swiper-button-prev, .swiper-button-next {
    width: 80px;
  }
  .swiper-button-prev::after, .swiper-button-next::after {
    background-size: 80px auto;
    width: 80px;
  }
  .roomslider .swiper-button-prev, .roomslider .swiper-button-next {
    width: 45px;
  }
  .roomslider .swiper-button-prev::after, .roomslider .swiper-button-next::after {
    background-size: 45px auto;
    width: 45px;
  }
  h1, h2 {
    font-size: 40px;
    line-height: 55px;
    margin-bottom: 25px;
  }
  h3  {
    font-size: 30px;
    line-height: 40px;
  }
  body, p, .accordion-button, .mehr-button, footer .footer-left p {
    font-size: 20px;
    line-height: 30px;
  }
  p, footer .footer-left p {
    margin-bottom: 15px;
  }
  footer .footer-left h4 {
    font-size: 40px;
    line-height: 60px;
    margin-bottom: 25px;
  }
  footer .footer-left {
    padding: 0 15px 50px 15px;
  }
  footer .copyright p {
    font-size: 16px;
  }
}

@media (max-width: 992px) {
  .header-area .header-sticky > .container-fluid {
    padding-left: 15px;
    padding-right: 15px;
  }
  .header__logo {
    margin-top: 38px;
  }
  .header__logo img {
    width: 270px;
  }
  .header-icons a {
    padding-right: 0;
  }
  .header-icons i {
    font-size: 21px;
  }
  .language-menu {
    font-size: 26px;
    line-height: 26px;
  }
  .language-menu a {
    font-size: 22px;
    line-height: 22px;
  }
  .mobile-menu-overlay {
    width: 400px;
  }
  .mobile-navigation-icon::before {
    font-size: 36px;
    line-height: 36px;
  }
  .mobile-menu-overlay__header .mobile-navigation-close-icon::before {
    font-size: 36px;
  }
  .mobile-menu-overlay__body .offcanvas-navigation > ul > li > a, .mobile-menu-overlay__body .offcanvas-navigation > ul > li.has-children span {
    font-size: 21px;
    line-height: 21px;
    margin-bottom: 17px;
  }
  .menu-infotext {
    margin-top: 40px;
  }
  .menu-infotext, .menu-infotext p {
    font-size: 19px;
    line-height: 29px;
  }
  #home .homeslider .service-hero-space {
    height: 500px;
  }
  .homeslider .service-hero-space {
    height: 350px;
  }
  .about, .zimmer, .restaurant, .umgebung, .anfrage, .booking {
    padding-top: 50px;
    padding-bottom: 50px;
  }
  .zimmer .allgemeineinfos {
    padding-left: 30px;
    padding-right: 30px;
    text-align: center;
  }
  .accordion-body {
    text-align: left;
  }
  .zimmerslider {
    padding-left: 10px;
    padding-right: 10px;
  }
  .restaurant .restaurant-row {
    flex-direction: column-reverse;
    text-align: center;
  }
  .restaurant-text {
    padding-left: 0;
    margin-bottom: 50px;
  }
  .umgebung .umgebung-row {
    flex-direction: column-reverse;
    text-align: center;
  }
  .umgebung-text {
    padding-left: 0;
    margin-bottom: 50px;
  }
}

@media (max-width: 768px) {
  .header-left {
    display: none;
  }
  .header-center {
    position: relative;
    left: 0;
    transform: translateX(0)
  }
  .header-right {
    padding-top: 31px;
  }
  .mobile-menu-overlay {
    width: 100%;
  }
  .mobile-menu-overlay__inner {
    padding: 0 15px;
  }
  .mobile-menu-overlay__body {
    padding-top: 20px;
  }
  #home .homeslider .service-hero-space {
    height: 390px;
  }
  .homeslider .service-hero-space {
    height: 300px;
  }
  .swiper-button-prev, .swiper-button-next {
    width: 50px;
  }
  .swiper-button-prev::after, .swiper-button-next::after {
    background-size: 50px auto;
    width: 50px;
  }
  .roomslider .swiper-button-prev, .roomslider .swiper-button-next {
    width: 40px;
  }
  .roomslider .swiper-button-prev::after, .roomslider .swiper-button-next::after {
    background-size: 40px auto;
    width: 40px;
  }
  h1, h2 {
    font-size: 36px;
    line-height: 49px;
  }
  h3  {
    font-size: 28px;
    line-height: 36px;
  }
  body, p, .accordion-button, .mehr-button, footer .footer-left p {
    font-size: 19px;
    line-height: 29px;
  }
  p, footer .footer-left p {
    margin-bottom: 10px;
  }
  .desktop-buttons {
    display: none;
  }
  .mobile-buttons {
    display: block;
    text-align: center;
    margin-top: 10px;
  }
  .anfrage .form-check {
    font-size: 16px;
    margin-top: 15px;
  }
  .nav-tabs {
    display: block;
  }
  .nav-tabs .nav-item {
    display: block;
    width: fit-content;
    margin: 5px auto;
    text-align: center;
  }
  .nav-tabs .nav-item:last-child {
    margin-right: auto;
  }
  .zimmer .personen:before {
    padding-right: 18px;
  }
  .zimmer .qm:before {
    padding-right: 18px;
    padding-left: 0;
  }
  footer .footer-left h4 {
    font-size: 40px;
    line-height: 60px;
    margin-bottom: 25px;
  }
  footer .footer-logos {
    display: block;
    text-align: center;
  }
  footer .footer-logos div {
    margin-bottom: 8px;
  }
  footer {
    padding-bottom: 50px;
  }
  .mobile-sidebar {
    display: block;
  }
}
@media (max-width: 660px) {
  #home .homeslider .service-hero-space {
    height: 350px;
  }
  .homeslider .service-hero-space {
    height: 300px;
  }
  .zimmer .allgemeineinfos, .zimmerslider {
    padding-left: 0;
    padding-right: 0;
  }
}


@media (max-width: 550px) {
  .mobile-navigation-icon {
    margin-left: 5px;
  }
  .language-menu {
    font-size: 15px;
    line-height: 15px;
  }
  .language-menu a {
    font-size: 15px;
    line-height: 15px;
    padding: 0 1px;
  }
  #home .homeslider .service-hero-space {
    height: 320px;
  }
  .homeslider .service-hero-space {
    height: 290px;
  }
}

@media (max-width: 512px) {
  .header__logo img {
    width: 235px;
  }
  .header-area .is-sticky .sticky__logo {
    width: 200px;
  }
  #home .homeslider .service-hero-space {
    height: 290px;
  }
  .homeslider .service-hero-space {
    height: 260px;
  }
}

@media (max-width: 400px) {
  .header__logo img {
    width: 200px;
  }
  .mehr-button {
    display: block;
    width: fit-content;
    margin: 5px auto;
    text-align: center;
  }
  .mehr-button:first-of-type {
    margin-top: 20px;
  }
  .bildergalerie .mehr-button:first-of-type {
    margin-top: 5px;
  }

  .language-menu {
    font-size: 14px;
    line-height: 14px;
  }
  .language-menu a {
    font-size: 14px;
    line-height: 14px;
    padding: 0;
  }
}
