/*
  [CSS Index]
*/


/*
  1. TEMPLATE BACKGROUNDS
    1.1. hero slider IMG BACKGROUND
    1.2. parallax IMG BACKGROUND
    1.3. about IMG BACKGROUND
      1.3.1. about services IMG BACKGROUND
    1.4. rooms IMG BACKGROUND
    1.5. facilities IMG BACKGROUND
    1.6. gallery IMG BACKGROUND
    1.7. blog IMG BACKGROUND
    1.8. contact IMG BACKGROUND
  2. reset
  3. layout
  4. upper page  
  5. center container 
  6. main navigation
  7. overlay
  8. hero
  9. to top arrow
  10. scroll indicator
  11. parallax
  12. fullwidth IMG
  13. preloader
  14. hover effect
  15. google maps
  16. headings
  17. blockquote
  18. panel group
  19. footer
  21. link effect
  22. home quotes
  23. extras
  24. menu selector
  25. carousel ALL
  27. hover effect
  28. BG color
  29. hero bg
  30. PhotoSwipe CUSTOM
  31. Owl Carousel CUSTOM
  32. Swiper CUSTOM
  33. Magnific Popup CUSTOM
  34. Lity CUSTOM
  35. contact
  36. blog news
  37. extras
  38. fullwidth box IMG
  39. additionals
  40. finals
  41. blog
  42. section txt
  43. button home
  44. stars
  45. section heading
  46. parallax title content
  47. image caption
  48. post list
  49. inner spacer
  50. divider
*/


/* 1. TEMPLATE BACKGROUNDS */
/* 1.1. hero slider IMG BACKGROUND */
.bg-img-1 {
  background-image: url(../img/background/hero-bg-1.webp);
}

.bg-img-2 {
  background-image: url(../img/background/hero-bg-2.webp);
}

.bg-img-3 {
  background-image: url(../img/background/hero-bg-3.webp);
}

.bg-img-4 {
  background-image: url(../img/background/hero-bg-4.webp);
}


/* 1.2. parallax IMG BACKGROUND */
.parallax-image-bg-1 {
  background-image: url(../img/background/parallax-image-bg-1.webp);
}

.parallax-image-bg-2 {
  background-image: url(../img/background/parallax-image-bg-2.webp);
}

.parallax-image-bg-3 {
  background-image: url(../img/background/parallax-image-bg-3.webp);
}

.parallax-image-bg-4 {
  background-image: url(../img/background/parallax-image-bg-4.webp);
}


/* 1.3. about IMG BACKGROUND */
.about-bg-1 {
  background-image: url(../img/about/1.webp);
}

.about-bg-2 {
  background-image: url(../img/about/2.webp);
}


/* 1.3.1. about services IMG BACKGROUND */
.services-bg-1 {
  background-image: url(../img/about/services/1.webp);
}

.services-bg-2 {
  background-image: url(../img/about/services/2.webp);
}

.services-bg-3 {
  background-image: url(../img/about/services/3.webp);
}

.services-bg-4 {
  background-image: url(../img/about/services/4.webp);
}


/* 1.4. rooms IMG BACKGROUND */
.rooms-bg {
  background-image: url(../img/rooms/rooms-intro/1.webp);
}

.rooms-bg-1 {
  background-image: url(../img/rooms/1.webp);
}

.rooms-bg-2 {
  background-image: url(../img/rooms/2.webp);
}

.rooms-bg-3 {
  background-image: url(../img/rooms/3.webp);
}

.rooms-bg-4 {
  background-image: url(../img/rooms/4.webp);
}

.rooms-bg-5 {
  background-image: url(../img/rooms/5.webp);
}


/* 1.5. facilities IMG BACKGROUND */
.restaurant-bg {
  background-image: url(../img/facilities/restaurant/1.webp);
}

.spa-bg {
  background-image: url(../img/facilities/spa/1.webp);
}

.fitness-bg {
  background-image: url(../img/facilities/fitness/1.webp);
}

.pool-bg {
  background-image: url(../img/facilities/pool/1.webp);
}

.facilities-bg-1 {
  background-image: url(../img/facilities/1.webp);
}

.facilities-bg-2 {
  background-image: url(../img/facilities/2.webp);
}

.facilities-bg-3 {
  background-image: url(../img/facilities/3.webp);
}

.facilities-bg-4 {
  background-image: url(../img/facilities/4.webp);
}

.facilities-bg-5 {
  background-image: url(../img/facilities/5.webp);
}

.facilities-bg-6 {
  background-image: url(../img/facilities/6.webp);
}

.facilities-bg-7 {
  background-image: url(../img/facilities/7.webp);
}

.facilities-bg-8 {
  background-image: url(../img/facilities/8.webp);
}

.facilities-bg-9 {
  background-image: url(../img/facilities/9.webp);
}

.facilities-bg-10 {
  background-image: url(../img/facilities/10.webp);
}

.facilities-bg-11 {
  background-image: url(../img/facilities/11.webp);
}

.facilities-bg-12 {
  background-image: url(../img/facilities/12.webp);
}

.facilities-bg-13 {
  background-image: url(../img/facilities/13.webp);
}

.facilities-bg-14 {
  background-image: url(../img/facilities/14.webp);
}

.facilities-bg-15 {
  background-image: url(../img/facilities/15.webp);
}

.facilities-bg-16 {
  background-image: url(../img/facilities/16.webp);
}

.facilities-bg-17 {
  background-image: url(../img/facilities/17.webp);
}

.facilities-bg-18 {
  background-image: url(../img/facilities/18.webp);
}

.facilities-bg-19 {
  background-image: url(../img/facilities/19.webp);
}

.facilities-bg-20 {
  background-image: url(../img/facilities/20.webp);
}

.facilities-bg-21 {
  background-image: url(../img/facilities/21.webp);
}

.facilities-bg-22 {
  background-image: url(../img/facilities/22.webp);
}

.facilities-bg-23 {
  background-image: url(../img/facilities/23.webp);
}

.facilities-bg-24 {
  background-image: url(../img/facilities/24.webp);
}

.facilities-bg-25 {
  background-image: url(../img/facilities/25.webp);
}

.facilities-bg-26 {
  background-image: url(../img/facilities/26.webp);
}

.facilities-bg-27 {
  background-image: url(../img/facilities/27.webp);
}

.facilities-bg-28 {
  background-image: url(../img/facilities/28.webp);
}

.facilities-bg-29 {
  background-image: url(../img/facilities/29.webp);
}

.facilities-bg-30 {
  background-image: url(../img/facilities/30.webp);
}

.facilities-bg-31 {
  background-image: url(../img/facilities/31.webp);
}

.facilities-bg-32 {
  background-image: url(../img/facilities/32.webp);
}

.facilities-bg-33 {
  background-image: url(../img/facilities/33.webp);
}

.facilities-bg-34 {
  background-image: url(../img/facilities/34.webp);
}

/* 1.6. gallery IMG BACKGROUND */
.gallery-bg {
  background-image: url(../img/gallery/1.webp);
}


/* 1.7. blog IMG BACKGROUND */
.blog-bg {
  background-image: url(../img/blog/blog-intro/1.webp);
}

.blog-single-bg {
  background-image: url(../img/blog/blog-single-intro/1.webp);
}


/* 1.8. contact IMG BACKGROUND */
.contact-bg {
  background-image: url(../img/contact/1.webp);
}


/* 1.9. booking IMG BACKGROUND */
.booking-bg-1 {
  background-image: url(../img/booking/1.webp);
}

.booking-bg-2 {
  background-image: url(../img/booking/2.webp);
}

.booking-bg-3 {
  background-image: url(../img/booking/3.webp);
}

@font-face {
  font-family: 'bellamy_signature';
  src: url('../fonts/bellamy_signature-webfont.woff2') format('woff2'),
    url('../fonts/bellamy_signature-webfont.woff') format('woff'),
    url('../fonts/bellamy_signature-webfont.ttf') format('truetype'),
    url('../fonts/bellamy_signature-webfont.svg') format('svg');
  font-weight: normal;
  font-style: normal;
  font-display: fallback;
}

@font-face {
  font-family: 'Ionicons';
  src: url('../fonts/ionicons.ttf?v=2.0.0') format('truetype');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Satoshi-Regular';
  src: url('../fonts/Satoshi-Regular.woff2') format('woff2'),
    url('../fonts/Satoshi-Regular.woff') format('woff'),
    url('../fonts/Satoshi-Regular.ttf') format('truetype');
  font-weight: 300;
  font-style: normal;
  font-display: fallback;
}

@font-face {
  font-family: 'Satoshi-Bold';
  src: url('../fonts/Satoshi-Bold.woff2') format('woff2'),
    url('../fonts/Satoshi-Bold.woff') format('woff'),
    url('../fonts/Satoshi-Bold.ttf') format('truetype');
  font-weight: 700;
  font-style: normal;
  font-display: fallback;
}


/* 2. reset */
html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
}

html,
body {
  height: 100%;
  line-height: 170%;
}

body {}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block;
}

ol,
ul {
  list-style: none;
}

blockquote,
q {
  quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
  content: "";
  content: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

*:focus {
  outline: none;
}

/* remove dotted outline from links,
button and input element */
a:focus,
a:active,
button::-moz-focus-inner,
input[type="reset"]::-moz-focus-inner,
input[type="button"]::-moz-focus-inner,
input[type="submit"]::-moz-focus-inner {
  border: 0;
  outline: 0;
}

/* 3. layout */
body {
  font-family: 'Satoshi-Regular', sans-serif;
  font-size: 15px;
  font-style: normal;
  text-align: left;
  color: #5f5f5f;
  background: #fff;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  width: 100%;
  height: 100%;
  overflow-x: hidden;
  overflow-y: auto;
  margin: 0;
  padding: 0;
}

a,
a:hover,
a:active,
a:focus {
  color: #5f5f5f;
  text-decoration: none;
  outline: none;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -webkit-transition: all 0.5s linear;
  -moz-transition: all 0.5s linear;
  -ms-transition: all 0.5s linear;
  -o-transition: all 0.5s linear;
  transition: all 0.5s linear;
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}

p {
  text-align: left;
  font-size: 15px;
  letter-spacing: 0.05em;
  color: #5f5f5f;
  line-height: 1.8;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

p a,
p a:hover {
  color: #5f5f5f;
  text-decoration: none;
  outline: none;
  -webkit-transition: all 0.5s linear;
  -moz-transition: all 0.5s linear;
  -ms-transition: all 0.5s linear;
  -o-transition: all 0.5s linear;
  transition: all 0.5s linear;
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}

strong {
  font-weight: bold;
}

::-moz-selection {
  background: #5f5f5f;
  color: #fff;
}

::selection {
  background: #5f5f5f;
  color: #fff;
}

.nopadding {
  padding: 0 !important;
  margin: 0 !important;
}


/* 4. upper page */
.upper-page {
  position: relative;
  display: table;
  width: 100%;
  height: 100%;
  min-height: 586px;
}

@media only screen and (max-width: 768px) {
  .upper-page {
    /* min-height: 786px; */
  }
}


/* 5. center container */
.center-container {
  position: absolute;
  display: table;
  table-layout: fixed;
  width: 100%;
  height: 100%;
  background: none;
}

.center-block {
  display: table-cell;
  vertical-align: middle;
}


/* 6. main navigation */
/* navigation */
.logo .logo-light {
  opacity: 1;
  -moz-opacity: 1;
  -webkit-opacity: 1;
  filter: alpha(opacity=100);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
  height: auto;
}

.logo .logo-dark {
  opacity: 0;
  -moz-opacity: 0;
  -webkit-opacity: 0;
  filter: alpha(opacity=0);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  height: 0;
}

.main-navigation-bg .logo .logo-light {
  opacity: 0;
  -moz-opacity: 0;
  -webkit-opacity: 0;
  filter: alpha(opacity=0);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  height: 0;
}

.main-navigation-bg .logo .logo-dark {
  opacity: 1;
  -moz-opacity: 1;
  -webkit-opacity: 1;
  filter: alpha(opacity=100);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
  height: auto;
}

.navbar-bg-switch {
  position: fixed;
  width: 100%;
  top: 0;
  left: 0;
  -webkit-transition: all .4s ease-out;
  -moz-transition: all .4s ease-out;
  -ms-transition: all .4s ease-out;
  -o-transition: all .4s ease-out;
  transition: all .4s ease-out;
  z-index: 999;
}

.logo {
  height: 80px;
  display: flex;
  align-items: center;
  padding-top: 0 !important;
  margin: 0 0 0 50px;
  -webkit-transition: all .4s ease-out;
  -moz-transition: all .4s ease-out;
  -ms-transition: all .4s ease-out;
  -o-transition: all .4s ease-out;
  transition: all .4s ease-out;
}

/* Logo Bild */
.logo img {
  max-height: 42px;
  width: auto;
  display: block;
}

/* Tablet */
@media only screen and (max-width: 880px) {

  .logo {
    height: 70px;
    margin: 0 0 0 25px;
  }

  .logo img {
    max-height: 36px;
  }

}

/* Mobile */
@media only screen and (max-width: 768px) {

  .logo {
    height: 70px;
    margin: 0 0 0 10px;
  }

  .logo img {
    max-height: 34px;
  }

}

.main-navigation .navbar-nav li a {
  font-family: 'Satoshi-Regular', sans-serif;
  font-size: 14px;
  font-weight: 5;
  text-transform: uppercase;
  text-align: center;
  letter-spacing: 0.05em;
  text-decoration: none;
  margin: 0 auto;
  padding: 30px 15px 0 15px;
  -webkit-transition: all .4s ease-out;
  -moz-transition: all .4s ease-out;
  -ms-transition: all .4s ease-out;
  -o-transition: all .4s ease-out;
  transition: all .4s ease-out;
  color: #fff;
}

@media only screen and (max-width: 880px) {
  .main-navigation .navbar-nav li a {
    padding: 33px 15px 0 15px;
    right: 25px;
  }
}

@media only screen and (max-width: 768px) {
  .main-navigation .navbar-nav li a {
    color: #fff;
    padding: 10px 15px;
    right: auto;
  }
}

.main-navigation .navbar-nav li a:hover {
  color: #fff;
  -webkit-transition: all .4s ease-out;
  -moz-transition: all .4s ease-out;
  -ms-transition: all .4s ease-out;
  -o-transition: all .4s ease-out;
  transition: all .4s ease-out;
}

@media only screen and (max-width: 768px) {
  .main-navigation .navbar-nav li a:hover {
    color: #ffffff;
  }
}

.nav li a:focus,
.nav li a:hover {
  color: #fff;
  background: none;
  -webkit-transition: all .4s ease-out;
  -moz-transition: all .4s ease-out;
  -ms-transition: all .4s ease-out;
  -o-transition: all .4s ease-out;
  transition: all .4s ease-out;
}

.main-navigation-bg {
  height: 81px;
  -webkit-box-shadow: 0 0 15px rgba(196, 196, 196, .35);
  -moz-box-shadow: 0 0 15px rgba(196, 196, 196, .35);
  box-shadow: 0 0 15px rgba(196, 196, 196, .35);
  background: rgba(255, 255, 255, 1);
  -webkit-transition: all .4s ease-out;
  -moz-transition: all .4s ease-out;
  -ms-transition: all .4s ease-out;
  -o-transition: all .4s ease-out;
  transition: all .4s ease-out;
}

.main-navigation.fadeIn-element {
  opacity: 1 !important;
  transform: none !important;
  animation: none !important;
}

@media only screen and (max-width: 768px) {
  .main-navigation-bg {
    height: auto;
    min-height: 81px;
  }
}

.main-navigation-bg .main-navigation .navbar-nav li a {
  color: #9c9c9c;
  padding: 31px 15px 0 15px;
  -webkit-transition: all .4s ease-out;
  -moz-transition: all .4s ease-out;
  -ms-transition: all .4s ease-out;
  -o-transition: all .4s ease-out;
  transition: all .4s ease-out;
}

@media only screen and (max-width: 880px) {
  .main-navigation-bg .main-navigation .navbar-nav li a {
    padding: 32px 15px 0 15px;
  }
}

@media only screen and (max-width: 768px) {
  .main-navigation-bg .main-navigation .navbar-nav li a {
    padding: 10px 15px;
  }

  .main-navigation .navbar-nav li:first-child {
    padding-top: 7px;
  }

  .main-navigation .navbar-nav li:last-child {
    padding-bottom: 8px;
  }
}

.main-navigation-bg .main-navigation .navbar-nav li a:hover {
  color: #9c9c9c;
}

@media only screen and (max-width: 768px) {
  .navbar-toggle .icon-bar {
    background: #fff;
  }

  .main-navigation-bg .navbar-toggle .icon-bar {
    background: #111;
  }

  .navbar-toggle {
    margin-top: -42px;
    margin-right: 10px;
    -webkit-transition: all .4s ease-out;
    -moz-transition: all .4s ease-out;
    -ms-transition: all .4s ease-out;
    -o-transition: all .4s ease-out;
    transition: all .4s ease-out;
  }

  .main-navigation-bg .navbar-toggle {
    margin-top: -38px;
    margin-right: 10px;
    -webkit-transition: all .4s ease-out;
    -moz-transition: all .4s ease-out;
    -ms-transition: all .4s ease-out;
    -o-transition: all .4s ease-out;
    transition: all .4s ease-out;
  }

  .navbar-collapse {
    background: rgba(158, 24, 18, 1);
    margin-top: 19px;
  }
}

.navbar-nav .active a {
  color: #ccc !important;
  background: none;
  text-decoration: none;
}


/* dropdown */
.navbar .navbar-nav>li {
  height: 80px;
  -webkit-transition: all .4s ease-out;
  -moz-transition: all .4s ease-out;
  -ms-transition: all .4s ease-out;
  -o-transition: all .4s ease-out;
  transition: all .4s ease-out;
}

@media only screen and (max-width: 768px) {
  .navbar .navbar-nav>li {
    height: auto;
  }
}

.navbar .navbar-nav>li.open>a:hover,
.navbar .navbar-nav>li.open>a:focus {
  background-color: #9e1812;
}

.main-navigation-bg.navbar .navbar-nav>li {
  height: 80px;
  -webkit-transition: all .4s ease-out;
  -moz-transition: all .4s ease-out;
  -ms-transition: all .4s ease-out;
  -o-transition: all .4s ease-out;
  transition: all .4s ease-out;
}

@media only screen and (max-width: 768px) {
  .main-navigation-bg.navbar .navbar-nav>li {
    height: auto;
  }
}

.main-navigation .navbar-nav li .dropdown-menu a {
  font-size: 11px;
  color: #9c9c9c;
  padding: 25px 15px 0 15px;
}

@media only screen and (max-width: 768px) {
  .main-navigation .navbar-nav li .dropdown-menu a {
    font-size: 10px;
    padding: 5px 15px 5px 15px;
  }
}

/* Navigation vertikal mittig */
.navbar .navbar-nav>li>a:not(.nav-booking-btn) {
  height: 80px;
  line-height: 80px;
  padding-top: 0 !important;
  padding-bottom: 0 !important;

  display: flex;
  align-items: center;
}

.main-navigation-bg.navbar .navbar-nav>li>a:not(.nav-booking-btn) {
  height: 80px;
  line-height: 80px;
}

.main-navigation .navbar-nav li .dropdown-menu a:hover {
  color: #9c9c9c;
}

.main-navigation .navbar-nav li .dropdown-menu:last-child a {
  margin: 0;
}

.dropdown:hover .dropdown-menu {
  right: auto;
  left: 50%;
  -webkit-transform: translate(-50%, 0);
  -o-transform: translate(-50%, 0);
  transform: translate(-50%, 0);
}

@media only screen and (max-width: 768px) {
  .dropdown:hover .dropdown-menu {
    left: auto;
    -webkit-transform: translate(0, 0);
    -o-transform: translate(0, 0);
    transform: translate(0, 0);
  }
}

@media only screen and (min-width: 768px) {
  .dropdown:hover .dropdown-menu {
    display: block;
  }
}

.dropdown-menu>li:first-child {}

@media only screen and (max-width: 768px) {
  .dropdown-menu>li:first-child {
    margin-top: -7px;
  }
}

.dropdown-menu>li:last-child {
  padding-bottom: 25px !important;
}

@media only screen and (max-width: 768px) {
  .dropdown-menu>li:last-child {
    padding-bottom: 0 !important;
  }
}

.dropdown-menu {
  border: none;
  background: #9e1812;
  -webkit-border-radius: 10px;
  -moz-border-radius: 10px;
  -ms-border-radius: 10px;
  -o-border-radius: 10px;
  border-radius: 10px;
  -webkit-box-shadow: 0 10px 10px rgba(158, 24, 18, .35);
  -moz-box-shadow: 0 10px 10px rgba(158, 24, 18, .35);
  box-shadow: 0 10px 10px rgba(158, 24, 18, .35);
}


/* navbar dropdown BG color */
.navbar .navbar-nav>.open>a,
.navbar .navbar-nav>.open>a:focus,
.navbar .navbar-nav>.open>a:hover {
  background: rgba(158, 24, 18, 1);
}


/* dropdown disabled */
.dropdown a.disabled-custom {
  -webkit-pointer-events: none;
  -moz-pointer-events: none;
  pointer-events: none;
}

@media only screen and (max-width: 880px) {
  .dropdown a.disabled-custom {
    -webkit-pointer-events: auto;
    -moz-pointer-events: auto;
    pointer-events: auto;
  }
}


/* borders */
.extra-margin-border {
  position: relative;
  height: auto;
  min-height: inherit;
  margin-left: 50px;
  margin-right: 50px;
  background: none;
}

@media only screen and (max-width: 768px) {
  .extra-margin-border {
    margin-left: 25px;
    margin-right: 25px;
  }
}

.border-top,
.border-top.top-position-primary {
  position: absolute;
  background: rgba(255, 255, 255, .2);
  -webkit-transition: all .6s ease;
  -moz-transition: all .6s ease;
  -ms-transition: all .6s ease;
  -o-transition: all .6s ease;
  transition: all .6s ease;
  z-index: 105;
}

.border-top.top-position-primary {
  background: none;
}

.border-top {
  width: 100%;
  height: 1px;
  top: 110px;
}

@media only screen and (max-width: 768px) {
  .border-top {
    top: 110px;
  }
}

/* KEIN transform mehr */
.border-top.top-position-primary {
  -webkit-transform: none;
  -moz-transform: none;
  -ms-transform: none;
  -o-transform: none;
  transform: none;
}

/* 7. overlay */
.overlay:before {
  content: "";
  position: absolute;
  display: block;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  z-index: 1;
}


/* 8. hero */
.hero-fullscreen {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  overflow: hidden;
  z-index: 0;
}

.hero-bg {
  position: relative;
  width: 100%;
  height: 100%;
  background-position: center center;
  background-repeat: no-repeat;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -ms-background-size: cover;
  -o-background-size: cover;
  background-size: cover;
}

.hero-fullscreen-FIX {
  width: 100%;
  height: 100%;
}

/* 9. FAQ */
.sk-faq {
  background: #f7f3f2;
  padding: 110px 20px 120px;
}

.sk-faq-inner {
  max-width: 860px;
  margin: 0 auto;
  text-align: center;
}

.sk-section-label {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 18px;
  margin-bottom: 28px;
  font-size: 11px;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: #9c9c9c;
}

.sk-section-label span {
  width: 42px;
  height: 1px;
  background: #d8d1cf;
}

.sk-faq-title {
  position: relative;
  margin: 18px 0 44px; 
  font-family: 'Satoshi-Bold', sans-serif;
  font-size: 52px;
  line-height: 1.5;
  font-weight: 800;
  text-transform: uppercase;
  color: #111;
  z-index: 2; 
}

.sk-faq-title span {
  position: absolute;
  left: 50%;
  top: 52%;
  transform: translate(-50%, -50%);
  width: 100%;
  font-family: 'bellamy_signature', cursive;
  font-size: 110px; 
  line-height: 1;
  font-weight: 400;
  text-transform: none;
  text-align: center;
  white-space: nowrap;
  color: #9e1812; 
  pointer-events: none;
  z-index: 1; 
  user-select: none;
}

.sk-faq-list {
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.sk-faq-item {
  background: #fff;
  border-radius: 22px;
  overflow: hidden;
  box-shadow: 0 18px 45px rgba(0, 0, 0, .04);
}

.sk-faq-question {
  width: 100%;
  min-height: 74px;
  padding: 0 64px 0 34px;
  border: none;
  background: transparent;
  cursor: pointer;
  position: relative;
  text-align: left;
  font-family: 'Satoshi-Bold', sans-serif;
  font-size: 16px;
  line-height: 1.8;
  color: #222;
}

.sk-faq-question span {
  position: absolute;
  right: 30px;
  top: 50%;
  width: 24px;
  height: 24px;
  transform: translateY(-50%);
  border-radius: 50%;
  background: #f7f3f2;
}

.sk-faq-question span::before,
.sk-faq-question span::after {
  content: "";
  position: absolute;
  background: #9e1812;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}

.sk-faq-question span::before {
  width: 11px;
  height: 2px;
}

.sk-faq-question span::after {
  width: 2px;
  height: 11px;
  transition: opacity .25s ease;
}

.sk-faq-item.active .sk-faq-question span::after {
  opacity: 0;
}

.sk-faq-answer {
  max-height: 0;
  overflow: hidden;
  padding: 0 34px;
  text-align: left;
  font-size: 14px;
  line-height: 1.8;
  color: #8a8a8a;
  transition: max-height .55s ease, padding .55s ease;
}

.sk-faq-item.active .sk-faq-answer {
  max-height: 2000px !important;  
  padding: 0 34px 34px !important; 
}

@media only screen and (max-width: 768px) {
  .sk-faq {
    padding: 80px 15px 95px;
  }

  .sk-faq-title {
    font-size: 38px;
    margin-bottom: 48px;
  }

  .sk-faq-title span {
    font-size: 80px;
  }

  .sk-faq-question {
    min-height: 68px;
    padding: 0 54px 0 22px;
    font-size: 14px;
  }

  .sk-faq-answer {
    padding: 0 22px;
    font-size: 13px;
  }

  .sk-faq-item.active .sk-faq-answer {
    padding: 0 22px 34px;
  }
}

/* WELLNESS OFFERS */

.sk-wellness-category {
  margin: 45px 0 22px;
  font-family: 'Satoshi-Bold', sans-serif;
  font-size: 18px;
  text-transform: uppercase;
  letter-spacing: .16em;
  color: #9e1812;
}

.sk-faq-answer .offer-desc {
  margin: 0 0 18px 0;
  font-size: 15px;
  line-height: 1.8;
  font-weight: 400;
  color: #666;
  max-width: 760px;
}

.offer-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.offer-meta span {
  display: inline-flex;
  align-items: center;
  padding: 8px 14px;
  border-radius: 999px;
  background: #f7f3f2;
  color: #9e1812;
  font-family: 'Satoshi-Bold', sans-serif;
  font-size: 12px;
  letter-spacing: .04em;
  text-transform: uppercase;
}

/* 10. to top arrow */
.to-top-arrow {
  position: fixed;
  right: 80px;
  bottom: -10px;
  width: 50px;
  height: 50px;
  line-height: 47px;
  cursor: pointer;
  font-size: 16px;
  text-align: center;
  color: #fff;
  background: #9e1810;
  opacity: 0;
  -moz-opacity: 0;
  -webkit-opacity: 0;
  filter: alpha(opacity=0);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  -webkit-border-radius: 50%;
  -moz-border-radius: 50%;
  -ms-border-radius: 50%;
  -o-border-radius: 50%;
  border-radius: 50%;
  -webkit-transform: translateY(40px);
  -moz-transform: translateY(40px);
  -ms-transform: translateY(40px);
  -o-transform: translateY(40px);
  transform: translateY(40px);
  -webkit-transition: all .4s ease-out;
  -moz-transition: all .4s ease-out;
  -ms-transition: all .4s ease-out;
  -o-transition: all .4s ease-out;
  transition: all .4s ease-out;
  z-index: 105;
}

@media only screen and (max-width: 995px) {
  .to-top-arrow {
    right: 80px;
  }
}

@media only screen and (max-width: 880px) {
  .to-top-arrow {
    right: 30px;
  }
}

@media only screen and (max-width: 768px) {
  .to-top-arrow {
    right: 15px;
  }
}

.to-top-arrow.show {
  bottom: 60px;
  -webkit-transform: translateY(-20px);
  -moz-transform: translateY(-20px);
  -ms-transform: translateY(-20px);
  -o-transform: translateY(-20px);
  transform: translateY(-20px);
  opacity: 1;
  -moz-opacity: 1;
  -webkit-opacity: 1;
  filter: alpha(opacity=100);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
}

@media only screen and (max-width: 995px) {
  .to-top-arrow.show {
    bottom: 60px;
  }
}

@media only screen and (max-width: 880px) {
  .to-top-arrow.show {
    bottom: -5px;
  }
}

.to-top-arrow:hover {
  opacity: 1;
  -moz-opacity: 1;
  -webkit-opacity: 1;
  filter: alpha(opacity=50);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
}


/* 10. scroll indicator */
.scroll-indicator-wrapper {
  position: absolute;
  width: 1px !important;
  height: 100%;
  left: -1px;
  right: 0;
  margin-left: auto;
  margin-right: auto;
  opacity: 1;
  -moz-opacity: 1;
  -webkit-opacity: 1;
  filter: alpha(opacity=100);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
  visibility: visible;
  -webkit-transition: all .7s;
  -moz-transition: all .7s;
  -ms-transition: all .7s;
  -o-transition: all .7s;
  transition: all .7s;
}

.scroll-indicator {
  position: absolute;
  bottom: 100px;
  left: 50%;
  -webkit-transform: translate(-50%, 50%);
  -moz-transform: translate(-50%, 50%);
  -ms-transform: translate(-50%, 50%);
  transform: translate(-50%, 50%);
  z-index: 1005;
}

@media only screen and (max-width: 768px) {
  .scroll-indicator {
    bottom: 50px;
  }
}

.scroll-line {
  display: block;
  width: 1px;
  height: 50px;
  background: none;
}

@media only screen and (max-width: 768px) {
  .scroll-line {
    height: 25px;
  }
}

.scroll-line::before {
  content: "";
  display: block;
  width: 1px;
  height: 50%;
  top: 0;
  background-color: #9e1810;
  -webkit-animation: scroll-down 2s ease-in-out infinite;
  -ms-animation: scroll-down 2s ease-in-out infinite;
  animation: scroll-down 2s ease-in-out infinite;
}

@-webkit-keyframes scroll-down {
  0% {
    height: 0;
  }

  50% {
    height: 100%;
  }

  70% {
    height: 100%;
    transform: scaleY(0.5);
    transform-origin: bottom;
  }

  100% {
    height: 100%;
    transform: scaleY(0);
    transform-origin: bottom;
  }
}

@-ms-keyframes scroll-down {
  0% {
    height: 0;
  }

  50% {
    height: 100%;
  }

  70% {
    height: 100%;
    transform: scaleY(0.5);
    transform-origin: bottom;
  }

  100% {
    height: 100%;
    transform: scaleY(0);
    transform-origin: bottom;
  }
}

@keyframes scroll-down {
  0% {
    height: 0;
  }

  50% {
    height: 100%;
  }

  70% {
    height: 100%;
    transform: scaleY(0.5);
    transform-origin: bottom;
  }

  100% {
    height: 100%;
    transform: scaleY(0);
    transform-origin: bottom;
  }
}


/* 11. parallax */
.parallax-overlay,
.parallax-overlay-video-testimonials {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  z-index: 0;
}

.parallax-overlay {
  background: rgba(0, 0, 0, .3);
}

.parallax-overlay-video-testimonials {
  background: rgba(0, 0, 0, .1);
}

.parallax {
  display: block;
  width: 100%;
  height: 100%;
  overflow: hidden;
  padding: 200px 0;
}

@media only screen and (max-width: 880px) {
  .parallax {
    padding: 100px 0;
  }
}

.parallax-all {
  position: relative;
  background-repeat: no-repeat;
  background-position: center center;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -ms-background-size: cover;
  -o-background-size: cover;
  background-size: cover;
  border: none;
  z-index: 1;
}


/* parallax button more */
.more-wraper-center {
  position: relative;
  width: 120px !important;
  max-width: 120px;
  height: 120px;
  left: 0;
  right: 0;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
  z-index: 1;
}

.more-wraper-center.more-wraper-center-form {
  /* margin: 5px auto 0 auto; */
  margin: -5px auto 0 auto;
  bottom: -20px;
}

.more-button-bg-center {
  background: #fff;
  border: 2px dashed #fff;
}

.more-button-bg-center.more-button-bg-center-dark {
  background: #fff;
  border: 2px dashed #fff;
}

.more-button-circle {
  display: block;
  width: 100%;
  height: 100%;
  -webkit-border-radius: 50%;
  -moz-border-radius: 50%;
  -ms-border-radius: 50%;
  -o-border-radius: 50%;
  border-radius: 50%;
  background-clip: content-box;
  padding: 2.5px;
  cursor: pointer;
}

.more-wraper-center:hover .more-button-circle {
  -webkit-animation: spin 5s linear infinite;
  -moz-animation: spin 5s linear infinite;
  -ms-animation: spin 5s linear infinite;
  -o-animation: spin 5s linear infinite;
  animation: spin 5s linear infinite;
}

.more-button-txt-center {
  position: absolute;
  top: 60px;
  left: 60px;
  width: 120px !important;
  -webkit-transform: translate(-50%, -50%);
  -moz-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  font-family: 'Satoshi-Regular', sans-serif;
  font-size: 10px;
  font-style: normal;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: normal;
  line-height: 1.8;
  color: #fff;
  margin: 0 auto;
  cursor: pointer;
}

.more-button-txt-center span {
  color: #fff;
}

@-webkit-keyframes spin {
  to {
    -webkit-transform: rotate(360deg);
  }
}

@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}


/* 12. fullwidth IMG */
.img-fullwidth-wrapper {
  position: relative;
}

.img-fullwidth {
  min-height: 600px;
}

@media (min-width: 992px) {
  .img-fullwidth {
    position: absolute;
    width: 50vw;
    height: auto;
    top: 0;
    bottom: 0;
  }
}

@media only screen and (max-width: 640px) {
  .img-fullwidth {
    min-height: 350px;
  }
}

.img-fullwidth-all {
  background-repeat: no-repeat;
  background-position: center center;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -ms-background-size: cover;
  -o-background-size: cover;
  background-size: cover;
}


/* 13. preloader */
.preloader-bg {
  position: fixed;
  width: 100%;
  height: 100%;
  overflow: hidden;
  background: #fff;
  z-index: 999999;
}

#preloader {
  position: fixed;
  display: table;
  table-layout: fixed;
  width: 100%;
  height: 100%;
  overflow: hidden;
  background: #9e1812;
  z-index: 999999;
}

#preloader-status {
  display: table-cell;
  vertical-align: middle;
}

.preloader-position {
  position: relative;
  margin: 0 auto;
  text-align: center;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}

.loader {
  position: relative;
  width: 45px;
  height: 45px;
  left: 50%;
  top: auto;
  margin-left: -22px;
  margin-top: 2px;
  -webkit-animation: rotate 1s infinite linear;
  -moz-animation: rotate 1s infinite linear;
  -ms-animation: rotate 1s infinite linear;
  -o-animation: rotate 1s infinite linear;
  animation: rotate 1s infinite linear;
  border: 3px solid rgba(225, 225, 225, .15);
  -webkit-border-radius: 50%;
  -moz-border-radius: 50%;
  -ms-border-radius: 50%;
  -o-border-radius: 50%;
  border-radius: 50%;
}

.loader span {
  position: absolute;
  width: 45px;
  height: 45px;
  top: -3px;
  left: -3px;
  border: 3px solid transparent;
  border-top: 3px solid rgba(225, 225, 225, .75);
  -webkit-border-radius: 50%;
  -moz-border-radius: 50%;
  -ms-border-radius: 50%;
  -o-border-radius: 50%;
  border-radius: 50%;
}

@-webkit-keyframes rotate {
  0% {
    -webkit-transform: rotate(0deg);
  }

  100% {
    -webkit-transform: rotate(360deg);
  }
}

@keyframes rotate {
  0% {
    transform: rotate(0deg);
  }

  100% {
    transform: rotate(360deg);
  }
}


/* 14. hover effect */
.hover-icons {
  position: absolute;
  width: 100%;
  top: 50%;
  left: 15px;
  text-align: center;
  opacity: 0;
  -moz-opacity: 0;
  -webkit-opacity: 0;
  filter: alpha(opacity=0);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  -webkit-transition: all 0.35s ease-out;
  -moz-transition: all 0.35s ease-out;
  -ms-transition: all 0.35s ease-out;
  -o-transition: all 0.35s ease-out;
  transition: all 0.35s ease-out;
  -webkit-transform: translateY(-50%);
  -moz-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -o-transform: translateY(-50%);
  transform: translateY(-50%);
  -webkit-animation-fill-mode: forwards;
  animation-fill-mode: forwards;
  z-index: 1;
}

@media only screen and (min-width: 1024px) {
  .hover-icons {
    left: 10px;
  }
}

@media only screen and (max-width: 880px) {
  .hover-icons {
    left: 5px;
  }
}

@media only screen and (max-width: 640px) {
  .hover-icons {
    left: 0;
  }
}

.hover-icons a {
  position: relative;
  display: inline-block;
  vertical-align: middle;
  text-decoration: none;
  width: 50px;
  height: 50px;
  line-height: 50px;
  margin: 0 4px;
  font-size: 20px;
  background: #9e1812;
  border: 1px solid #9e1812;
  color: #fff;
  -webkit-transition: all 0.35s ease-out;
  -moz-transition: all 0.35s ease-out;
  -ms-transition: all 0.35s ease-out;
  -o-transition: all 0.35s ease-out;
  transition: all 0.35s ease-out;
  -webkit-border-radius: 50%;
  -moz-border-radius: 50%;
  -ms-border-radius: 50%;
  -o-border-radius: 50%;
  border-radius: 50%;
}

.hover-icons a.iw-slide-left {
  -webkit-transform: translate3d(-60px, 0, 0);
  -moz-transform: translate3d(-60px, 0, 0);
  -ms-transform: translate3d(-60px, 0, 0);
  -o-transform: translate3d(-60px, 0, 0);
  transform: translate3d(-60px, 0, 0);
}

.hover-icons a.iw-slide-right {
  -webkit-transform: translate3d(60px, 0, 0);
  -moz-transform: translate3d(60px, 0, 0);
  -ms-transform: translate3d(60px, 0, 0);
  -o-transform: translate3d(60px, 0, 0);
  transform: translate3d(60px, 0, 0);
}

.hover-effect-img:hover .hover-icons a {
  padding: 0;
  -webkit-transform: translate3d(0, 0, 0) !important;
  -moz-transform: translate3d(0, 0, 0) !important;
  -ms-transform: translate3d(0, 0, 0) !important;
  -o-transform: translate3d(0, 0, 0) !important;
  transform: translate3d(0, 0, 0) !important;
}

.hover-icons a:hover {
  background: #9e1812;
  border: 1px solid #9e1812;
  color: #fff;
}

.hover-icons a:hover:after {
  background: #9e1812;
}

.hover-effect-img:hover .hover-icons {
  opacity: 1;
  -moz-opacity: 1;
  -webkit-opacity: 1;
  filter: alpha(opacity=100);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
}

.hover-icons a:before {
  position: relative;
  z-index: 1;
}

.hover-icons a i {
  position: relative;
  z-index: 1;
}

.hover-effect-img {
  position: relative;
  z-index: 5 !important;
}

.hover-effect {
  position: absolute;
  background: #fff;
  opacity: 0;
  -moz-opacity: 0;
  -webkit-opacity: 0;
  filter: alpha(opacity=0);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  -webkit-transition: all 1s ease;
  -moz-transition: all 1s ease;
  -ms-transition: all 1s ease;
  -o-transition: all 1s ease;
  transition: all 1s ease;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  cursor: pointer;
}

.hover-effect {
  width: -webkit-calc(100% - 80px);
  width: -moz-calc(100% - 80px);
  width: calc(100% - 80px);
  height: -webkit-calc(100% - 80px);
  height: -moz-calc(100% - 80px);
  height: calc(100% - 80px);
  top: 40px;
  left: 40px;
  bottom: 40px;
  right: 40px;
}

@media only screen and (max-width: 880px) {
  .hover-effect {
    width: -webkit-calc(100% - 30px);
    width: -moz-calc(100% - 30px);
    width: calc(100% - 30px);
    height: -webkit-calc(100% - 30px);
    height: -moz-calc(100% - 30px);
    height: calc(100% - 30px);
    top: 15px;
    left: 15px;
    bottom: 15px;
    right: 15px;
  }
}

.hover-effect-img:hover .hover-effect {
  opacity: 0.85;
  -moz-opacity: 0.85;
  -webkit-opacity: 0.85;
  filter: alpha(opacity=85);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=85)";
  -webkit-transition: all 1s ease;
  -moz-transition: all 1s ease;
  -ms-transition: all 1s ease;
  -o-transition: all 1s ease;
  transition: all 1s ease;
}

.legendary-gallery {
  position: relative;
  margin: 0 auto; 
  max-width: 100%;
  padding: 0 15px; 
  z-index: 0;
}

@media only screen and (max-width: 880px) {
  .legendary-gallery {
    padding: 0 10px;
  }
}

.legendary-gallery figure {
  padding: 20px;
}

@media only screen and (max-width: 880px) {
  .legendary-gallery figure {
    padding: 0;
  }
}

.legendary-gallery figure:last-child {
  margin-bottom: 20px;
}

@media only screen and (max-width: 880px) {
  .legendary-gallery figure:last-child {
    margin-bottom: 15px;
  }
}

.legendary-gallery .img-caption {
  display: none;
}

.move-down {
  margin-bottom: 0;
}

@media only screen and (max-width: 880px) {
  .move-down {
    margin-bottom: 15px;
  }
}


/* 15. google maps */
#google-maps-wrapper {
  position: relative;
  width: 100%;
  height: 600px;
  overflow: hidden;
  -webkit-filter: grayscale(100%);
  filter: gray;
  filter: url("data:image/svg+xml;utf8,<svg xmlns=\'http://www.w3.org/2000/svg\'><filter id=\'grayscale\'><feColorMatrix type=\'matrix\' values=\'0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0 0 0 1 0\'/></filter></svg>#grayscale");
  bottom: -59px;
  margin: -59px auto 0 auto;
}

.google-maps {
  width: 100%;
  height: 600px;
}

.google-maps iframe {
  position: relative;
  top: -59px;
  width: 100%;
  height: 600px;
  -webkit-pointer-events: none;
  -moz-pointer-events: none;
  pointer-events: none;
}


/* 16. headings */
.hero-heading {
  position: relative;
  font-family: 'bellamy_signature', sans-serif;
  font-style: normal;
  font-weight: 20;
  font-size: 130px;
  text-align: center;
  text-transform: none;
  letter-spacing: -0.01em;
  color: #fff;
  margin: -6px auto 0 auto;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  width: 100%;
  line-height: 1.15;
  z-index: 1;
}

@media all and (min-width: 1920px) {
  .hero-heading {
    font-size: 60px;
    margin: -8px auto 0 auto;
  }
}

@media only screen and (max-width: 995px) {
  .hero-heading {
    font-size: 60px;
    margin: -6px auto 0 auto;
  }
}

@media only screen and (max-width: 880px) {
  .hero-heading {
    padding: 0 60px;
  }
}

@supports((text-stroke: 1px #fff) or (-webkit-text-stroke: 1px #fff)) {
  .hero-heading span {
    color: transparent;
    -webkit-text-stroke: 1px #fff;
    text-stroke: 1px #fff;
    text-shadow: none;
  }
}

.hero-heading.hero-heading-dark {
  color: #ffff;
}

@supports((text-stroke: 1px #111) or (-webkit-text-stroke: 1px #111)) {
  .hero-heading.hero-heading-dark span {
    color: transparent;
    -webkit-text-stroke: 1px #000;
    text-stroke: 1px #111;
    text-shadow: none;
  }
}

h2.hero-heading {
  position: relative;
  font-family: 'bellamy_signature', sans-serif;
  font-style: normal;
  font-weight: 700;
  font-size: 120px;
  text-align: center;
  text-transform: none;
  letter-spacing: 0px;
  color: #fff;
  margin: -6px auto -8px auto;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  width: 100%;
  line-height: 1.15;
  z-index: 1;
}

@media all and (min-width: 1920px) {
  h2.hero-heading {
    font-family: 'bellamy_signature', sans-serif;
    font-size: 80px;
    margin: -0px auto -9px auto;
  }
}

@media only screen and (max-width: 995px) {
  h2.hero-heading {
    font-family: 'bellamy_signature', sans-serif;
    font-size: 30px;
    margin: -6px auto;
  }
}

@media only screen and (max-width: 880px) {
  h2.hero-heading {
    font-family: 'bellamy_signature', sans-serif;
    padding: 0 30px;
  }
}

@supports((text-stroke: 1px #fff) or (-webkit-text-stroke: 1px #fff)) {
  h2.hero-heading span {
    color: transparent;
    -webkit-text-stroke: 1px #fff;
    text-stroke: 1px #fff;
    text-shadow: none;
  }
}

@supports((text-stroke: 1px #111) or (-webkit-text-stroke: 1px #111)) {
  h2.hero-heading.hero-heading-dark span {
    color: transparent;
    -webkit-text-stroke: 1px #111;
    text-stroke: 1px #111;
    text-shadow: none;
  }
}

.hero-subheading {
  position: relative;
  font-family: 'bellamy_signature', sans-serif;
  font-size: 24px;
  font-style: normal;
  font-weight: 700;
  text-transform: uppercase;
  text-align: center;
  letter-spacing: 0.05em;
  line-height: normal;
  color: #fff;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  margin: -1px auto;
  z-index: 1;
}

.hero-subheading.hero-subheading-dark {
  color: #111;
}

.hero-subheading span {
  position: relative;
  display: inline-block;
  padding-right: 60px;
  margin-right: 30px;
  line-height: 1;
  color: #fff;
}

@media only screen and (max-width: 880px) {
  .hero-subheading span {
    padding-right: 40px;
    margin-right: 20px;
  }
}

.hero-subheading.hero-subheading-dark span {
  color: #111;
}

.hero-subheading span::before {
  content: "";
  position: absolute;
  display: block;
  top: 50%;
  right: 0;
  width: 30px;
  height: 0;
  margin-top: -1px;
  border-top: 1px solid #fff;
}

@media only screen and (max-width: 880px) {
  .hero-subheading span::before {
    width: 20px;
  }
}

.hero-subheading.hero-subheading-dark span::before {
  border-top: 1px solid #111;
}

h4 {
  font-family: 'Satoshi-Regular', sans-serif;
  font-size: 15px;
  font-weight: 800;
  text-align: left;
  text-transform: uppercase;
  color: #9c9c9c;
  line-height: 1.8;
  letter-spacing: -0.04em;
}

h3 {
  font-family: 'bellamy_signature', sans-serif;
  font-size: 80px;
  font-weight: 50;
  text-align: center;
  text-transform: normal;
  color: #9c9c9c;
  line-height: 1.5;
  letter-spacing: 0.00em;
}

.color-switch {
  color: #9e1812;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

.col-all .color-switch {
  -webkit-transition: all 0.5s linear;
  -moz-transition: all 0.5s linear;
  -ms-transition: all 0.5s linear;
  -o-transition: all 0.5s linear;
  transition: all 0.5s linear;
}

.col-all:hover .color-switch {
  color: #5f5f5f;
  -webkit-transition: all 0.5s linear;
  -moz-transition: all 0.5s linear;
  -ms-transition: all 0.5s linear;
  -o-transition: all 0.5s linear;
  transition: all 0.5s linear;
}


/* 17. blockquote */
.testimonial {
  position: relative;
  text-align: left;
  margin: -5px 0 -30px 0;
}

.testimonial.testimonial-bottom {
  margin: -5px 0 -30px 0;
}

.testimonial .inner {
  margin: 0 auto;
  padding: 0;
}

.testimonial blockquote {
  position: relative;
  font-family: 'Satoshi-Bold', sans-serif;
  color: #5f5f5f;
  font-size: 20px;
  font-style: italic;
  font-weight: 600;
  line-height: 1.8;
  margin-bottom: 25px;
  padding: 0;
  z-index: 1;
}

q,
blockquote {
  quotes: none;
}

.quote-inner a,
.quote-inner a:hover {
  color: #5f5f5f;
  text-decoration: none;
}

.testimonial blockquote::before {
  content: "\201C";
  position: absolute;
  color: rgba(17, 17, 17, .15);
  font-family: Georgia, serif;
  font-size: 165px;
  font-style: normal;
  left: 0;
  top: -90px;
  z-index: -10;
}

@media only screen and (max-width: 768px) {
  .testimonial blockquote::before {
    font-size: 135px;
    top: -70px;
  }
}


/* 18. panel group */
.panel-wrapper {
  position: relative;
  background: none;
  width: 100%;
  height: calc(100% + 300px);
  margin: -25px auto -45px 0;
  z-index: 1;
}

.panel-title {
  position: relative;
  font-family: 'Satoshi-Bold', sans-serif;
  font-size: 13px;
  font-style: normal;
  font-weight: 800;
  text-transform: uppercase;
  padding: 0;
  text-align: left;
  letter-spacing: 0.02em;
  color: #9c9c9c;
  line-height: 1.8;
  margin-left: -15px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

@media only screen and (max-width: 1200px) {
  .panel-title {
    font-size: 14px;
  }
}

.panel-title-span {
  color: #FFFF00;
}

.panel-group .panel {
  border: none;
  background: none;
  box-shadow: none;
  -webkit-border-radius: 0;
  -moz-border-radius: 0;
  -ms-border-radius: 0;
  -o-border-radius: 0;
  border-radius: 0;
}

.panel-group .panel .panel-heading {
  border: none;
  background: none;
}

.panel-group .panel .panel-heading h4 a {
  display: block;
  background: none;
  padding: 15px;
  -webkit-transition: 0.15s all ease-in-out;
  -moz-transition: 0.15s all ease-in-out;
  -ms-transition: 0.15s all ease-in-out;
  -o-transition: 0.15s all ease-in-out;
  transition: 0.15s all ease-in-out;
}

.panel-group .panel .panel-heading h4 a:hover,
.panel-group .panel .panel-heading h4 a:not(.collapsed) {
  background: none;
  -webkit-transition: 0.15s all ease-in-out;
  -moz-transition: 0.15s all ease-in-out;
  -ms-transition: 0.15s all ease-in-out;
  -o-transition: 0.15s all ease-in-out;
  transition: 0.15s all ease-in-out;
}

.panel-group .panel .panel-heading h4 a:not(.collapsed) i:before {
  content: "\f209";
  font-family: "Ionicons";
  font-display: swap;
}

.ion {
  font-size: 15px;
  padding-right: 10px;
}

.panel-group .panel .panel-heading h4 a i {
  position: relative;
  display: block;
  top: 6px;
  left: -15px;
  color: #5f5f5f;
  text-align: center;
}

.panel-group .panel .panel-body {
  padding-top: 0;
}

.panel-group .panel .panel-heading+.panel-collapse>.list-group,
.panel-group .panel .panel-heading+.panel-collapse>.panel-body {
  border-top: none;
  background: none;
  text-align: center;
  padding: 25px 0;
}

.panel-group .panel+.panel {
  border: none;
  margin-top: 0;
}

.panel-body p {
  text-align: left;
  color: #5f5f5f;
}

/* Footer */

.sk-footer {
  background: #f7f7f7;
  padding: 26px 30px 12px;
  color: #8a8a8a;
  font-family: 'Satoshi-Regular', sans-serif;
}

.sk-footer-inner {
  max-width: 1500px;
  margin: 0 auto;
  text-align: center;
}

.sk-footer-cols {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 60px;
  margin-bottom: 30px;
}

.sk-footer-col {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.sk-footer-col h4 {
  margin: 0 0 22px;
  font-size: 13px;
  line-height: 1.4;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: #222;
  text-align: center;
}

.sk-footer-col p {
  margin: 0;
  text-align: center;
  font-size: 12px;
  line-height: 1.2;
  font-weight: 500;
  width: 100%;
}

.sk-footer-col a {
  display: block;
  font-size: 12px;
  line-height: 1.2;
  font-weight: 500;
  color: #9a9a9a;
  text-decoration: none;
  text-align: center;
  transition: color .25s ease;
}

.sk-footer-col p,
.sk-footer-col span {
  font-size: 12px;
  line-height: 1.2;
  font-weight: 500;
  color: #9a9a9a;
  text-align: center;
}

.sk-footer-col a:hover {
  color: #9e1812;
}

.sk-footer-seals {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 26px;
  flex-wrap: wrap;
  margin-bottom: 28px;
}

.sk-footer-seals img {
  display: block;
  max-height: 44px;
  max-width: 170px;
  width: auto;
  height: auto;
  object-fit: contain;
  transition:
    transform .25s ease,
    filter .25s ease,
    opacity .25s ease;
}

.sk-footer-seal-link {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
}

.sk-footer-seal-link:hover img {
  transform: translateY(-3px) scale(1.04);
  filter: drop-shadow(0 6px 10px rgba(0,0,0,.14));
  opacity: .95;
}

.sk-footer-divider,
.sk-footer-seal-divider {
  width: 1px;
  height: 34px;
  background: rgba(0,0,0,.15);
  display: inline-block;
  margin: 0 8px;
}

.sk-footer-copy {
  font-size: 9px;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: #aaaaaa;
}

/* Mobile */

@media only screen and (max-width: 768px) {

  .sk-footer {
    padding: 42px 20px 90px;
  }

  .sk-footer-cols {
    grid-template-columns: 1fr;
    gap: 35px;
    margin-bottom: 36px;
  }

  .sk-footer-col h4 {
    margin-bottom: 14px;
  }

  .sk-footer-seals {
    gap: 18px;
  }

  .sk-footer-seals img {
    max-height: 40px;
    max-width: 145px;
  }

  .sk-footer-divider,
  .sk-footer-seal-divider {
    display: none;
  }

}

/* social icons */
.social-icons {
  position: relative;
  font-family: 'Satoshi-Bold', sans-serif;
  font-size: 10px;
  font-weight: 50;
  letter-spacing: 0.05em;
  font-style: normal;
  text-transform: uppercase;
  color: #111;
  background: none;
  border: none;
  width: auto;
  height: auto;
  line-height: 1.8;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  -webkit-transition: all 1.5s ease;
  -moz-transition: all 1.5s ease;
  -ms-transition: all 1.5s ease;
  -o-transition: all 1.5s ease;
  transition: all 1.5s ease;
  margin: -5px auto -4px auto;
}

.social-icons a,
.social-icons a:hover {
  outline: none;
  text-decoration: none;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
}

.social-icons li a:hover,
.social-icons li a:visited,
.social-icons li a:active,
.social-icons li a:focus {
  font-family: 'Satoshi-Bold', sans-serif;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.05em;
  font-style: normal;
  text-transform: uppercase;
}

.social-icons li {
  display: inline;
  padding: 0;
}

.social-icons li span {
  color: #111;
  padding: 0 10px;
}


/* copyright */
.copyright {
  position: relative;
  text-align: center;
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin: -5px auto -8px auto;
  color: #111;
  font-weight: 800;
}


/* 21. link effect */
a.link-effect {
  color: #9e1812 !important;
  /* immer rot */
  position: relative;
  display: inline-block;
  text-decoration: none;
  text-transform: uppercase;
  transition: color 0.3s ease;
}

a.link-effect::after {
  content: "";
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 100%;
  height: 1px;
  background-color: #666;
  /* graue Linie */
  transform-origin: right center;
  /* Linie verschwindet von rechts */
  transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

a.link-effect:hover::after {
  transform: scaleX(0);
}


/* 23. extras */
.section-all {
  position: relative;
  height: auto;
  min-height: inherit;
  overflow: hidden;
  margin-left: 40px;
  margin-right: 40px;
}

@media only screen and (max-width: 880px) {
  .section-all {
    margin-left: 0;
    margin-right: 0;
  }
}


/* 24. menu selector */
.item-selector {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  margin: -5px 0 0 0;
  padding: 0;
}

.item-button {
  position: relative;
  font-family: 'Satoshi-Bold', sans-serif;
  font-size: 15px;
  font-weight: 300 !important;
  text-align: center;
  text-transform: uppercase;
  color: #5f5f5f !important;
  line-height: 1.8;
  letter-spacing: -0.04em;
  margin: 4px 0 0 0;
  padding: 0;
}

.menu {
  display: none;
}

@media (min-width: 768px) {
  .menu {
    grid-column-gap: 40px;
    grid-template-columns: repeat(2, 1fr);
  }
}

.menu-visible {
  display: grid;
}

.item-wrapper {
  display: flex;
  align-items: baseline;
}

.item-name {
  font-family: 'Satoshi-Bold', sans-serif;
  font-size: 13px;
  font-weight: 800;
  text-align: center;
  text-transform: uppercase;
  color: #5f5f5f;
  line-height: 1.8;
  letter-spacing: -0.04em;
}

.item-divider {
  flex: 1;
  border-bottom: 1px dashed #5f5f5f;
  margin: 0 15px;
}

.item-price {
  font-family: 'Satoshi-Bold', sans-serif;
  font-size: 13px;
  font-weight: 800;
  text-align: center;
  text-transform: uppercase;
  color: #5f5f5f;
  line-height: 1.8;
  letter-spacing: -0.04em;
}

.item-description {
  margin: 0 0 50px 0;
}


/* 25. carousel ALL */
.carousel-img-item-all {
  position: relative;
  width: 100%;
  height: 100%;
  min-height: 600px;
  background-position: center center;
  background-repeat: no-repeat;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -ms-background-size: cover;
  -o-background-size: cover;
  background-size: cover;
}

@media only screen and (max-width: 995px) {
  .carousel-img-item-all {
    min-height: 500px;
  }
}

/* 28. BG color */
.bg-light {
  background: #fff;
}

.bg-dark {
  background: #f7f7f7;
}


/* 29. hero bg */
.hero-bg {
  position: absolute;
  width: 100%;
  height: 100%;
  overflow: hidden;
  background-position: center center;
  background-repeat: no-repeat;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -ms-background-size: cover;
  -o-background-size: cover;
  background-size: cover;
}

.hero-bg,
.hero-bg-show {
  -webkit-transition: all 1.5s ease;
  -moz-transition: all 1.5s ease;
  -ms-transition: all 1.5s ease;
  -o-transition: all 1.5s ease;
  transition: all 1.5s ease;
}

.hero-bg,
.hero-bg-FIX {
  -webkit-transform: scale(1.08);
  -moz-transform: scale(1.08);
  -ms-transform: scale(1.08);
  -o-transform: scale(1.08);
  transform: scale(1.08);
  opacity: 1;
  -moz-opacity: 1;
  -webkit-opacity: 1;
  filter: alpha(opacity=100);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
}

.hero-bg-FIX {
  -webkit-transform: scale(1);
  -moz-transform: scale(1);
  -ms-transform: scale(1);
  -o-transform: scale(1);
  transform: scale(1);
}

.hero-bg-show {
  -webkit-transform: scale(1);
  -moz-transform: scale(1);
  -ms-transform: scale(1);
  -o-transform: scale(1);
  transform: scale(1);
  opacity: 1;
  -moz-opacity: 1;
  -webkit-opacity: 1;
  filter: alpha(opacity=100);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
}


/* 30. PhotoSwipe CUSTOM */
.pswp__bg {
  background: #fff;
}

.pswp__counter {
  color: #111;
  opacity: 1;
}

.pswp__caption__center {
  color: #111;
}

.pswp__share-modal {
  background: rgba(255, 255, 255, 0.5);
}

.pswp__img--placeholder--blank {
  background: #fff;
}

.pswp__top-bar,
.pswp__caption {
  background-color: rgba(255, 255, 255, 1);
}

.pswp__ui--fit .pswp__top-bar,
.pswp__ui--fit .pswp__caption {
  background-color: rgba(255, 255, 255, 1);
}

.pswp__button,
.pswp__button--arrow--left:before,
.pswp__button--arrow--right:before {
  background: url(../photoswipe/default-skin/default-skin-reverse.png) 0 0 no-repeat;
  background-size: 264px 88px;
  width: 44px;
  height: 44px;
}

@media (-webkit-min-device-pixel-ratio: 1.1),
(-webkit-min-device-pixel-ratio: 1.09375),
(min-resolution: 105dpi),
(min-resolution: 1.1dppx) {

  .pswp--svg .pswp__button,
  .pswp--svg .pswp__button--arrow--left:before,
  .pswp--svg .pswp__button--arrow--right:before {
    /* background-image: url(../photoswipe/default-skin/default-skin.svg); */
  }

  .pswp--svg .pswp__button--arrow--left,
  .pswp--svg .pswp__button--arrow--right {
    background: none;
  }
}

.pswp__button--close {
  background-position: 0 -44px;
}

.pswp__button--share {
  background-position: -44px -44px;
}

.pswp__button--fs {
  display: none;
}

.pswp--supports-fs .pswp__button--fs {
  display: block;
}

.pswp--fs .pswp__button--fs {
  background-position: -44px 0;
}

.pswp__button--zoom {
  display: none;
  background-position: -88px 0;
}

.pswp--zoom-allowed .pswp__button--zoom {
  display: block;
}

.pswp--zoomed-in .pswp__button--zoom {
  background-position: -132px 0;
}

.pswp--touch .pswp__button--arrow--left,
.pswp--touch .pswp__button--arrow--right {
  visibility: hidden;
}

.pswp__button--arrow--left,
.pswp__button--arrow--right {
  background: none;
  top: 50%;
  margin-top: -50px;
  width: 70px;
  height: 100px;
  position: absolute;
}

.pswp__button--arrow--left {
  left: 0;
}

.pswp__button--arrow--right {
  right: 0;
}

.pswp__button--arrow--left:before,
.pswp__button--arrow--right:before {
  content: '';
  top: 35px;
  background-color: rgba(255, 255, 255, 0.5);
  height: 30px;
  width: 32px;
  position: absolute;
}

.pswp__button--arrow--left:before {
  left: 6px;
  background-position: -138px -44px;
}

.pswp__button--arrow--right:before {
  right: 6px;
  background-position: -94px -44px;
}


/* 31. Owl Carousel CUSTOM */
.owl-carousel {
  cursor: grab;
}

.owl-nav-custom-rooms,
.owl-nav-custom-facilities,
.owl-nav-custom-all,
.owl-nav-custom-menu {
  position: relative;
  width: 114px !important;
  max-width: 114px;
  height: 50px;
  left: 2px;
  right: 0;
  margin-left: auto;
  margin-right: auto;
  margin: 2px auto;
  text-align: center;
  overflow: hidden;
}

.owl-buttons {
  position: static;
}

.owl-prev,
.owl-next {
  position: absolute;
  display: block;
  text-align: center;
}

.owl-prev {
  left: 0;
}

.owl-next {
  left: 60px;
}

.owl-prev,
.owl-next {
  width: 50px;
  height: 50px;
  line-height: 50px;
  -webkit-transition: all .4s ease-out;
  -moz-transition: all .4s ease-out;
  -ms-transition: all .4s ease-out;
  -o-transition: all .4s ease-out;
  transition: all .4s ease-out;
  -webkit-border-radius: 50%;
  -moz-border-radius: 50%;
  -ms-border-radius: 50%;
  -o-border-radius: 50%;
  border-radius: 50%;
  font-size: 12px;
  color: #fff;
  background: #111;
  cursor: pointer;
  z-index: 10;
}

.owl-prev:hover,
.owl-next:hover {
  -webkit-transition: all .4s ease-out;
  -moz-transition: all .4s ease-out;
  -ms-transition: all .4s ease-out;
  -o-transition: all .4s ease-out;
  transition: all .4s ease-out;
}

.owl-prev.disabled,
.owl-next.disabled {
  content: "";
  position: absolute;
  display: block;
  width: 50px;
  height: 50px;
  line-height: 50px;
  color: #fff;
  background: #ccc !important;
  -webkit-border-radius: 50%;
  -moz-border-radius: 50%;
  -ms-border-radius: 50%;
  -o-border-radius: 50%;
  border-radius: 50%;
  -webkit-transition: all 0.27s cubic-bezier(0.000, 0.000, 0.580, 1.000);
  -moz-transition: all 0.27s cubic-bezier(0.000, 0.000, 0.580, 1.000);
  -ms-transition: all 0.27s cubic-bezier(0.000, 0.000, 0.580, 1.000);
  -o-transition: all 0.27s cubic-bezier(0.000, 0.000, 0.580, 1.000);
  transition: all 0.27s cubic-bezier(0.000, 0.000, 0.580, 1.000);
  cursor: default !important;
}


/* 32. Swiper CUSTOM */
.swiper-container {
  width: 100%;
  height: 100%;
  margin: 0 auto;
}

.hero-slider-img .swiper-slide {
  position: relative;
  float: left;
  width: 100%;
  height: 100%;
  overflow: hidden;
}

.swiper-slide-txt {
  position: relative;
  width: 100% !important;
  padding: 0;
  left: 0;
  right: 0;
  margin-left: auto;
  margin-right: auto;
  z-index: 1;
}

@media only screen and (max-width: 995px) {
  .swiper-slide-txt {
    padding: 0 10px;
    left: 0;
  }
}

.swiper-slide-txt-inner {
  position: relative;
  max-width: 600px;
}

@media only screen and (max-width: 995px) {
  .swiper-slide-txt-inner {
    max-width: 100%;
  }
}

.hero-slider-bg-controls {
  position: absolute;
  right: 75px;
  bottom: 80px;
  z-index: 10;
}

@media only screen and (max-width: 880px) {
  .hero-slider-bg-controls {
    right: 25px;
    bottom: 15px;
  }
}

@media only screen and (max-width: 768px) {
  .hero-slider-bg-controls {
    right: 10px;
  }
}

.swiper-slide-controls {
  display: inline-block;
  width: 50px;
  height: 50px;
  line-height: 50px;
  -webkit-transition: all .4s ease-out;
  -moz-transition: all .4s ease-out;
  -ms-transition: all .4s ease-out;
  -o-transition: all .4s ease-out;
  transition: all .4s ease-out;
  font-size: 16px;
  color: #111;
  background: #fff;
  cursor: pointer;
}

.swiper-slide-controls.slide-prev,
.swiper-slide-controls.slide-next {
  position: relative;
  width: 50px !important;
  left: 0;
  right: 0;
  margin-left: auto;
  margin-right: 6px;
  text-align: center;
  -webkit-border-radius: 50%;
  -moz-border-radius: 50%;
  -ms-border-radius: 50%;
  -o-border-radius: 50%;
  border-radius: 50%;
}

.swiper-slide-controls:hover {
  -webkit-transition: all .4s ease-out;
  -moz-transition: all .4s ease-out;
  -ms-transition: all .4s ease-out;
  -o-transition: all .4s ease-out;
  transition: all .4s ease-out;
  background: #fff;
}

@media only screen and (max-width: 880px) {
  .swiper-slide-controls.slide-next {
    margin-top: 10px;
  }
}

.swiper-slide-pagination {
  position: absolute;
  width: 8px;
  left: 80px;
  bottom: 78px;
  z-index: 10;
}

@media only screen and (max-width: 880px) {
  .swiper-slide-pagination {
    left: 30px;
    bottom: 12px;
  }
}

@media only screen and (max-width: 768px) {
  .swiper-slide-pagination {
    left: 15px;
  }
}

.swiper-slide-pagination::before {
  content: "";
  position: absolute;
  top: -50px;
  left: 0;
  right: 0;
  bottom: -50px;
  background: none;
}

.swiper-slide-pagination .swiper-pagination-bullet {
  position: relative;
  width: 100%;
  height: 6px;
  background: none;
  opacity: 1;
  -moz-opacity: 1;
  -webkit-opacity: 1;
  filter: alpha(opacity=100);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
}

.swiper-slide-pagination .swiper-pagination-bullet:last-child {
  margin-bottom: 0;
}

.swiper-slide-pagination .swiper-pagination-bullet::before,
.swiper-slide-pagination .swiper-pagination-bullet::after {
  content: "";
  position: absolute;
  width: 6px;
  height: 6px;
  top: 0;
  left: 50%;
  background: #fff;
  margin: 0;
  -webkit-border-radius: 50%;
  -moz-border-radius: 50%;
  -ms-border-radius: 50%;
  -o-border-radius: 50%;
  border-radius: 50%;
}

.swiper-slide-pagination .swiper-pagination-bullet::after {
  content: "";
  position: absolute;
  width: 8px;
  height: 8px;
  top: 50%;
  left: 50%;
  margin: -4px 0 0 -1px;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-transition: all 0.5s linear;
  -moz-transition: all 0.5s linear;
  -ms-transition: all 0.5s linear;
  -o-transition: all 0.5s linear;
  transition: all 0.5s linear;
  -webkit-transform: scale(0);
  -moz-transform: scale(0);
  -ms-transform: scale(0);
  -o-transform: scale(0);
  transform: scale(0);
}

.swiper-slide-pagination .swiper-pagination-bullet.swiper-pagination-bullet-active::after {
  -webkit-transition: all 0.5s linear;
  -moz-transition: all 0.5s linear;
  -ms-transition: all 0.5s linear;
  -o-transition: all 0.5s linear;
  transition: all 0.5s linear;
  -webkit-transform: scale(1.8);
  -moz-transform: scale(1.8);
  -ms-transform: scale(1.8);
  -o-transform: scale(1.8);
  transform: scale(1.8);
  background: #fff;
}

.slider-progress-bar {
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}

.circle-svg {
  position: relative;
  -webkit-transform: scale(1) rotate(-90deg);
  -moz-transform: scale(1) rotate(-90deg);
  -ms-transform: scale(1) rotate(-90deg);
  -o-transform: scale(1) rotate(-90deg);
  transform: scale(1) rotate(-90deg);
  -webkit-transition: transform .4s ease;
  -moz-transition: transform .4s ease;
  -ms-transition: transform .4s ease;
  -o-transition: transform .4s ease;
  transition: transform .4s ease;
  -webkit-transition: -webkit-transform .4s ease;
  -moz-transition: -moz-transform .4s ease;
  -ms-transition: -ms-transform .4s ease;
  -o-transition: -o-transform .4s ease;
  transition: transform .4s ease;
}

.circle-svg circle,
.circle {
  fill: none;
  stroke: #fff;
  stroke-dasharray: 3;
  stroke-width: 1px;
}

.slider-progress-bar.slider-active .circle {
  stroke-dashoffset: 200px;
  -webkit-transition: linear 4s stroke-dashoffset;
  transition: linear 4s stroke-dashoffset;
}

.swiper-slide-controls-play-pause {
  position: absolute;
  width: 50px;
  height: 50px;
  line-height: 50px;
  right: 201px;
  bottom: 80px;
  -webkit-transition: all .4s ease-out;
  -moz-transition: all .4s ease-out;
  -ms-transition: all .4s ease-out;
  -o-transition: all .4s ease-out;
  transition: all .4s ease-out;
  -webkit-border-radius: 50%;
  -moz-border-radius: 50%;
  -ms-border-radius: 50%;
  -o-border-radius: 50%;
  border-radius: 50%;
  font-size: 16px;
  color: #fff;
  background: none;
  cursor: pointer;
  z-index: 10;
}

@media only screen and (max-width: 880px) {
  .swiper-slide-controls-play-pause {
    right: 150px;
    bottom: 15px;
  }
}

@media only screen and (max-width: 768px) {
  .swiper-slide-controls-play-pause {
    right: 135px;
  }
}

.swiper-slide-controls-play-pause:hover {
  -webkit-transition: all .4s ease-out;
  -moz-transition: all .4s ease-out;
  -ms-transition: all .4s ease-out;
  -o-transition: all .4s ease-out;
  transition: all .4s ease-out;
  background: none;
}

.swiper-slide-controls-play-pause i,
.swiper-slide-controls-play-pause i {
  -webkit-transition: all .4s ease-out;
  -moz-transition: all .4s ease-out;
  -ms-transition: all .4s ease-out;
  -o-transition: all .4s ease-out;
  transition: all .4s ease-out;

}

.swiper-slide-controls-play-pause.slider-on-off i::before,
.slider-on-off-switch {
  content: "\f478";
  position: relative;
  width: 50px !important;
  left: 0;
  right: 0;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}

.swiper-container-wrapper {
  padding-top: 0 !important;
  height: 100% !important;
}

.swiper-slide {
  overflow: hidden;
}

.swiper-slide-inner {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  background: #111;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

.swiper-slide-inner-bg {
  position: absolute;
  width: 100%;
  height: 100%;
  background-position: center center;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -ms-background-size: cover;
  -o-background-size: cover;
  background-size: cover;
  -webkit-transition: opacity .6s ease-in-out, transform 2s ease .7s;
  -moz-transition: opacity .6s ease-in-out, transform 2s ease .7s;
  -ms-transition: opacity .6s ease-in-out, transform 2s ease .7s;
  -o-transition: opacity .6s ease-in-out, transform 2s ease .7s;
  transition: opacity .6s ease-in-out, transform 2s ease .7s;
  -webkit-transform: scale(1.15);
  -moz-transform: scale(1.15);
  -ms-transform: scale(1.15);
  -o-transform: scale(1.15);
  transform: scale(1.15);
  opacity: 0.2;
  -moz-opacity: 0.2;
  -webkit-opacity: 0.2;
  filter: alpha(opacity=20);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=20)";
}

.swiper-slide-duplicate-active .swiper-slide-inner-bg,
.swiper-slide-active .swiper-slide-inner-bg {
  -webkit-transform: scale(1);
  -moz-transform: scale(1);
  -ms-transform: scale(1);
  -o-transform: scale(1);
  transform: scale(1);
  opacity: 1;
  -moz-opacity: 1;
  -webkit-opacity: 1;
  filter: alpha(opacity=100);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
}

.swiper-slide-inner-txt {
  position: absolute;
  width: 80% !important;
  margin-left: auto;
  margin-right: auto;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  -moz-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  -webkit-transition: opacity .4s ease;
  -moz-transition: opacity .4s ease;
  -ms-transition: opacity .4s ease;
  -o-transition: opacity .4s ease;
  transition: opacity .4s ease;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  opacity: 0;
  -moz-opacity: 0;
  -webkit-opacity: 0;
  filter: alpha(opacity=0);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  z-index: 15;
}

.swiper-slide-active .swiper-slide-inner-txt {
  -webkit-transition: opacity 1.8s ease 1.2s;
  -moz-transition: opacity 1.8s ease 1.2s;
  -ms-transition: opacity 1.8s ease 1.2s;
  -o-transition: opacity 1.8s ease 1.2s;
  transition: opacity 1.8s ease 1.2s;
  opacity: 1;
  -moz-opacity: 1;
  -webkit-opacity: 1;
  filter: alpha(opacity=100);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
}

video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}


/* 33. Magnific Popup CUSTOM */
.mfp-bg {
  background: rgba(0, 0, 0, .7);
}

.mfp-arrow-left:after {
  font-family: "Ionicons";
  font-display: swap;
  content: "\f124";
  font-size: 16px;
  font-weight: 500;
  color: #fff;
  margin-top: 22px;
  left: 15px;
}

.mfp-arrow-right:after {
  font-family: "Ionicons";
  font-display: swap;
  content: "\f125";
  font-size: 16px;
  font-weight: 500;
  color: #fff;
  margin-top: 22px;
  right: 15px;
}

.mfp-zoom-out-cur,
.mfp-zoom-out-cur .mfp-image-holder .mfp-close {
  cursor: crosshair;
}

.mfp-arrow-left:after,
.mfp-arrow-left:before {
  border-right: none;
}

.mfp-arrow-right:after,
.mfp-arrow-right:before {
  border-left: none;
}

.mfp-title,
.mfp-counter {
  font-family: 'Raleway', sans-serif;
  font-size: 13px;
  line-height: 1.5;
  font-style: normal;
  font-weight: 700;
  letter-spacing: 0.05em;
  color: #fff;
}

.mfp-close {
  font-weight: 500 !important;
  color: #fff !important;
  cursor: pointer !important;
}

.mfp-arrow-left,
.mfp-arrow-right {
  z-index: 99998 !important;
}

.mfp-bg {
  z-index: 99996 !important;
}

.mfp-wrap {
  z-index: 99997 !important;
}

.mfp-content {
  z-index: 99998 !important;
}

.mfp-close,
.mfp-arrow {
  color: #fff;
  opacity: 1;
  -moz-opacity: 1;
  -webkit-opacity: 1;
  filter: alpha(opacity=100);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
}


/* 34. Lity CUSTOM */
.lity {
  z-index: 99999;
  cursor: crosshair;
  background: rgba(0, 0, 0, .55);
}

.lity-close {
  top: 90px;
  right: 70px;
  font-weight: 500 !important;
}

@media only screen and (max-width: 880px) {
  .lity-close {
    top: 5px;
    right: 5px;
  }
}

.lity-close:active {
  top: 90px;
  right: 70px;
}

@media only screen and (max-width: 880px) {
  .lity-close:active {
    top: 5px;
    right: 5px;
  }
}

.lity-close,
.lity-close:hover,
.lity-close:focus,
.lity-close:active,
.lity-close:visited {
  text-shadow: none;
}


/* 35. contact */
/* contact modal */
.center-container-contact-modal {
  position: absolute;
  display: table;
  height: 100%;
  width: 100%;
  left: 0;
  top: 0;
  background: none;
}

.center-block-contact-modal {
  display: table-cell;
  vertical-align: middle;
}

.center-block-contact-modal-padding-top {
  padding: 100px 0 0 0;
}

.center-block-contact-modal-padding-bottom {
  padding: 0 0 100px 0;
}

.contact-modal-wrapper {
  position: relative;
  width: 50%;
  margin: 0 auto;
}

@media only screen and (max-width: 1200px) {
  .contact-modal-wrapper {
    width: 90%;
  }
}

.contact-modal {
  position: fixed;
  width: 100%;
  height: 100%;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  visibility: hidden;
  background: #111;
  opacity: 0;
  -moz-opacity: 0;
  -webkit-opacity: 0;
  filter: alpha(opacity=0);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  -webkit-transform: scale(0.75);
  -moz-transform: scale(0.75);
  -ms-transform: scale(0.75);
  -o-transform: scale(0.75);
  transform: scale(0.75);
  -webkit-transition: all 1s ease;
  -moz-transition: all 1s ease;
  -ms-transition: all 1s ease;
  -o-transition: all 1s ease;
  transition: all 1s ease;
  overflow-x: hidden;
  overflow-y: auto;
  z-index: 99999;
}

.contact-modal.open {
  width: 100%;
  height: 100%;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  visibility: visible;
  background: #111;
  opacity: 1;
  -moz-opacity: 1;
  -webkit-opacity: 1;
  filter: alpha(opacity=100);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
  -webkit-transform: scale(1);
  -moz-transform: scale(1);
  -ms-transform: scale(1);
  -o-transform: scale(1);
  transform: scale(1);
}

.contact-modal-closer {
  position: relative;
  width: 50px;
  height: auto;
  margin: -5px auto 0 auto;
  font-size: 20px;
  text-align: center;
  color: #fff;
  cursor: pointer;
}


/* contact form */
#contact-form {
  position: relative;
  width: 100%;
  top: -20px;
  padding: 0;
  text-align: center;
}

.arrangement-container {
  display: flex;
  align-items: center;
}

form {
  margin: 0;
  padding: 0;
}

#form input {
  position: relative;
  width: 100%;
  height: 40px;
  border-bottom: 1px solid #111;
  border-left: none;
  border-right: none;
  border-top: none;
  padding: 5px 5px;
  background: none;
  margin: 10px 0 20px 0;
  font-family: 'Satoshi-Regular', sans-serif;
  font-size: 13px;
  line-height: 1.8;
  font-style: normal;
  font-weight: 600;
  text-align: center;
  color: #111;
  -webkit-transition: all 0.5s linear;
  -moz-transition: all 0.5s linear;
  -ms-transition: all 0.5s linear;
  -o-transition: all 0.5s linear;
  transition: all 0.5s linear;
}

textarea {
  position: relative;
  width: 100%;
  height: 100px;
  border-bottom: 1px solid #111;
  border-left: none;
  border-right: none;
  border-top: none;
  padding: 5px 5px;
  background: none;
  margin: 5px;
  font-family: 'Raleway', sans-serif;
  font-size: 13px;
  line-height: 1.8;
  font-style: normal;
  font-weight: 600;
  text-align: center;
  -webkit-transition: all 0.5s linear;
  -moz-transition: all 0.5s linear;
  -ms-transition: all 0.5s linear;
  -o-transition: all 0.5s linear;
  transition: all 0.5s linear;
}

#form textarea {
  color: #111;
  margin: 16px 0 10px 0;
  -webkit-transition: all 0.5s linear;
  -moz-transition: all 0.5s linear;
  -ms-transition: all 0.5s linear;
  -o-transition: all 0.5s linear;
  transition: all 0.5s linear;
}

#form input:hover,
#form textarea:hover {
  border-color: rgba(17, 17, 17, .5);
  -webkit-transition: all 0.5s linear;
  -moz-transition: all 0.5s linear;
  -ms-transition: all 0.5s linear;
  -o-transition: all 0.5s linear;
  transition: all 0.5s linear;
}


#form input:focus,
#form textarea:focus {
  -webkit-transition: all 0.5s linear;
  -moz-transition: all 0.5s linear;
  -ms-transition: all 0.5s linear;
  -o-transition: all 0.5s linear;
  transition: all 0.5s linear;
}

.success {
  font-family: 'Raleway', sans-serif;
  font-size: 10px;
  font-style: normal;
  font-weight: 700;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  text-align: center;
  color: #5f5f5f;
  margin: 0 auto;
  padding: 50px 0 25px 0;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

#form .error {
  position: absolute;
  display: block;
  font-size: 9px;
  text-transform: uppercase;
  color: #5f5f5f;
  margin: -13px 0 0 0;
  padding: 0;
  letter-spacing: 0.15em;
  font-weight: 700 !important;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  left: 0;
  right: 0;
  margin-left: auto;
  margin-right: auto;
  width: 200px !important;
}

.make-space {
  margin-left: 15px;
  margin-right: 15px;
}

::-webkit-input-placeholder {
  font-size: 12px;
  color: #111;
}

:-ms-input-placeholder {
  font-size: 12px;
  color: #111;
}

::-moz-placeholder {
  font-size: 12px;
  color: #111;
}

input:-moz-placeholder {
  font-size: 12px;
  color: #111;
}

input:focus::-webkit-input-placeholder {
  color: transparent;
}

input:focus:-ms-input-placeholder {
  color: transparent;
}

input:focus::-moz-placeholder {
  color: transparent;
}

input:focus:-moz-placeholder {
  color: transparent;
}

textarea:focus::-webkit-input-placeholder {
  color: transparent;
}

textarea:focus:-ms-input-placeholder {
  color: transparent;
}

textarea:focus::-moz-placeholder {
  color: transparent;
}

textarea:focus:-moz-placeholder {
  color: transparent;
}

button {
  border: none;
  background: none;
  outline: none;
  font-family: 'Satoshi-Bold', sans-serif;
  font-size: 10px;
  font-style: normal;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: normal;
  line-height: normal;
  color: #9e1812;
  margin: 0 auto;
  cursor: pointer;
}


/* 36. blog news */
.news-modal .modal-content,
.post-wrapper .post-content {
  min-height: 100%;
  -webkit-border-radius: 0;
  -moz-border-radius: 0;
  border-radius: 0;
  -webkit-background-clip: border-box;
  background-clip: border-box;
  -webkit-box-shadow: none;
  box-shadow: none;
  margin: 0;
  padding: 0;
  border: none;
  background: #fff;
}


/* news quote */
.blog-quote {
  line-height: 100px;
  padding: 0 0 0 50px;
  border-left: 5px solid #5f5f5f;
  margin: 0;
}

@media only screen and (max-width: 880px) {
  .blog-quote {
    padding: 0 0 0 30px;
    margin: 0;
  }
}

.blog-quote p {
  position: relative;
  font-family: 'Satoshi-Bold', sans-serif;
  font-style: normal;
  font-weight: 100;
  font-size: 60px;
  text-align: left;
  text-transform: none;
  letter-spacing: 0px;
  color: #5f5f5f;
  margin: -12px 0 0 0;
  top: -2px;
  width: 100%;
  line-height: 1.8;
  text-shadow: none;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

@supports((text-stroke: 1px #5f5f5f) or (-webkit-text-stroke: 1px #5f5f5f)) {
  .blog-quote p {
    color: transparent;
    -webkit-text-stroke: 1px #5f5f5f;
    text-stroke: 1px #5f5f5f;
    text-shadow: none;
  }
}

@media only screen and (max-width: 995px) {
  .blog-quote p {
    font-size: 60px;
  }
}

@media only screen and (max-width: 880px) {
  .blog-quote p {
    font-size: 30px;
    margin: 0;
    top: 0;
  }
}

.blog-quote p span {
  color: #5f5f5f;
  -webkit-text-stroke: 1px #5f5f5f;
  text-stroke: 1px #5f5f5f;
  text-shadow: none;
}


/* news nopadding */
@media only screen and (max-width: 880px) {
  .nopadding {
    padding: 0 !important;
    margin: 0 !important;
  }
}

.nopadding.nopadding-xs {
  margin-left: -15px !important;
  margin-right: -15px !important;
}

@media only screen and (max-width: 1200px) {
  .nopadding.nopadding-xs {}
}

@media only screen and (max-width: 880px) {
  .nopadding.nopadding-xs {
    margin-left: -10px !important;
    margin-right: -10px !important;
  }
}


/* news lower page */
.lower-page.lower-page-modal,
.lower-page.lower-page-post {
  position: relative;
  height: auto;
  min-height: inherit;
  overflow: hidden;
  margin-left: 0;
  margin-right: 0;
}

@media only screen and (max-width: 880px) {

  .lower-page.lower-page-modal,
  .lower-page.lower-page-post {
    padding: 0;
  }
}


/* news img */
.section-item img {
  width: 33vw;
  height: 66vh;
  object-fit: cover;
}


/* 37. extras */
h2.hero-heading span,
/* h2.hero-heading.hero-heading-dark span, */
.hero-heading span,
.hero-heading.hero-heading-dark span,
.service-number,
.blog-quote p,
.blog-quote p span {
  -webkit-text-stroke: unset;
  text-stroke: unset;
}

h2.hero-heading span,
.hero-heading span {
  color: #fff;
}

/* h2.hero-heading.hero-heading-dark span */
.hero-heading.hero-heading-dark span,
.service-number {
  color: #111;
}

.blog-quote p,
.blog-quote p span {
  color: #5f5f5f;
}

h2.hero-heading,
h2.hero-heading.hero-heading-dark,
.hero-heading,
.hero-heading.hero-heading-dark,
.blog-item h2,
.news-modal .modal-content h2,
.post-wrapper .post-content h2,
.intro-years h3,
.blog-quote p,
.blog-quote p span {
  font-weight: 200;
}

.testimonial blockquote {
  font-weight: 700;
}

p,
p a,
p a:hover {
  font-weight: 600;
}

.hover-effect {
  -webkit-border-radius: 20px;
  -moz-border-radius: 20px;
  -ms-border-radius: 20px;
  -o-border-radius: 20px;
  border-radius: 20px;
}

.upper-page,
.legendary-gallery,
#google-maps-wrapper,
.footer-credits-logo {
  z-index: 2;
}

.footer-credits-logo {
  position: relative;
}

.testimonial.testimonial-2 {
  text-align: center !important;
}

@media only screen and (max-width: 995px) {
  .testimonial.testimonial-2 {
    text-align: left !important;
  }
}

.testimonial.testimonial-2 .inner {
  max-width: 1080px !important;
  margin: 0 auto;
  padding: 0;
}

@media only screen and (max-width: 1200px) {
  .testimonial.testimonial-2 .inner {
    max-width: 940px !important;
    padding: 0;
  }
}

@media only screen and (max-width: 995px) {
  .testimonial.testimonial-2 .inner {
    padding: 0 25px;
  }
}

@media only screen and (max-width: 880px) {
  .testimonial.testimonial-2 .inner {
    padding: 0 15px;
  }
}

.testimonial.testimonial-2 blockquote {
  color: #e0e0e0;
}

.testimonial.testimonial-2 blockquote::before {
  color: rgba(224, 224, 224, .15);
}

.more-button-bg-center {
  background: none;
  border: 2px dashed #fff;
}

.more-button-bg-center.more-button-bg-center-dark {
  background: none;
  border: 2px dashed #fff;
}

.more-button-txt-center span {
  color: #fff;
}

.more-button-bg-center.more-button-bg-center-dark.more-button-bg-center-dark-close {
  background: none;
  border: 2px dashed #111;
}

.more-button-txt-center.more-button-txt-center-close span {
  color: #111;
}

.contact-modal,
.contact-modal.open {
  background: #fff;
}

.contact-modal-closer {
  color: #111;
}


/* vertical lines */
.vertical-lines-wrapper {
  position: fixed;
  width: 100%;
  height: 100%;
  overflow: hidden;
  left: 0;
  top: 0;
  margin: 0;
  -webkit-pointer-events: none;
  -moz-pointer-events: none;
  pointer-events: none;
  z-index: 1;
}

.vertical-lines {
  position: fixed;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  opacity: 1;
  -moz-opacity: 1;
  -webkit-opacity: 1;
  filter: alpha(opacity=100);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
}

.vertical-effect {
  position: relative;
  width: 25%;
  height: 100%;
  float: left;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  border-right: 1px solid rgba(188, 188, 188, .2);
}

.vertical-effect::before {
  content: "";
  position: absolute;
  display: block;
  width: 3px;
  -webkit-animation-direction: normal;
  -moz-animation-direction: normal;
  -ms-animation-direction: normal;
  -o-animation-direction: normal;
  animation-direction: normal;
}

.vertical-effect:first-child::before,
.vertical-effect:last-child::before {
  content: "";
  position: absolute;
  right: -2px;
}

.vertical-effect:first-child::before {
  top: 0;
  -webkit-animation: raindrop 6s ease-out infinite;
  -moz-animation: raindrop 6s ease-out infinite;
  -ms-animation: raindrop 6s ease-out infinite;
  -o-animation: raindrop 6s ease-out infinite;
  animation: raindrop 6s ease-out infinite;
}

.vertical-effect:last-child::before {
  bottom: 0;
  -webkit-animation: raindrop-reverse 6s ease-out infinite;
  -moz-animation: raindrop-reverse 6s ease-out infinite;
  -ms-animation: raindrop-reverse 6s ease-out infinite;
  -o-animation: raindrop-reverse 6s ease-out infinite;
  animation: raindrop-reverse 6s ease-out infinite;
}

@-webkit-keyframes raindrop {
  0% {
    top: -10%;
    opacity: 0;
    height: 0;
  }

  50% {
    opacity: 1;
  }

  100% {
    top: 100%;
    height: 35%;
  }
}

@-ms-keyframes raindrop {
  0% {
    top: -10%;
    opacity: 0;
    height: 0;
  }

  50% {
    opacity: 1;
  }

  100% {
    top: 100%;
    height: 35%;
  }
}

@keyframes raindrop {
  0% {
    top: -10%;
    opacity: 0;
    height: 0;
  }

  50% {
    opacity: 1;
  }

  100% {
    top: 100%;
    height: 35%;
  }
}

@-webkit-keyframes raindrop-reverse {
  0% {
    bottom: -10%;
    opacity: 0;
    height: 0;
  }

  50% {
    opacity: 1;
  }

  100% {
    bottom: 100%;
    height: 35%;
  }
}

@-ms-keyframes raindrop-reverse {
  0% {
    bottom: -10%;
    opacity: 0;
    height: 0;
  }

  50% {
    opacity: 1;
  }

  100% {
    bottom: 100%;
    height: 35%;
  }
}

@keyframes raindrop-reverse {
  0% {
    bottom: -10%;
    opacity: 0;
    height: 0;
  }

  50% {
    opacity: 1;
  }

  100% {
    bottom: 100%;
    height: 35%;
  }
}


/* swiper */
.swiper-slide-inner-bg-2 {
  position: absolute;
  width: 100%;
  height: 100%;
  background-position: center center;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -ms-background-size: cover;
  -o-background-size: cover;
  background-size: cover;
  opacity: 1;
  -moz-opacity: 1;
  -webkit-opacity: 1;
  filter: alpha(opacity=100);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
}

.swiper-slide-duplicate-active .swiper-slide-inner-bg-2,
.swiper-slide-active .swiper-slide-inner-bg-2 {
  opacity: 1;
  -moz-opacity: 1;
  -webkit-opacity: 1;
  filter: alpha(opacity=100);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
}


/* swiper */
.swiper-slide-inner-txt-2 {
  position: absolute;
  width: 80% !important;
  margin-left: auto;
  margin-right: auto;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  -moz-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  /*
-webkit-user-select: none;
   -moz-user-select: none;
    -ms-user-select: none;
        user-select: none;
*/
  opacity: 1;
  -moz-opacity: 1;
  -webkit-opacity: 1;
  filter: alpha(opacity=100);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
  -webkit-pointer-events: auto;
  -moz-pointer-events: auto;
  pointer-events: auto;
  z-index: 15;
}


/* swiper */
.swiper-slide.swiper-slide-3 {
  height: auto;
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: -moz-flex;
  display: -webkit-flex;
  display: flex;
}

.swiper-slide-inner-txt-3 {
  position: absolute;
  width: 80% !important;
  margin-left: auto;
  margin-right: auto;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  -moz-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  /*
-webkit-user-select: none;
   -moz-user-select: none;
    -ms-user-select: none;
        user-select: none;
*/
  opacity: 1;
  -moz-opacity: 1;
  -webkit-opacity: 1;
  filter: alpha(opacity=100);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
  -webkit-pointer-events: none;
  -moz-pointer-events: none;
  pointer-events: none;
  z-index: 15;
}

.more-wraper-center.more-wraper-center-home {
  -webkit-pointer-events: auto;
  -moz-pointer-events: auto;
  pointer-events: auto;
}


/* 38. fullwidth box IMG */
.box-img {
  position: relative;
  display: block;
  width: 100%;
  height: 100%;
  margin: 0 auto -6px auto;
  overflow: hidden;
  z-index: 10;
}

.img-fullwidth-all img {
  position: relative;
  width: 100%;
  height: 100%;
  background-repeat: no-repeat;
  background-position: center center;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -ms-background-size: cover;
  -o-background-size: cover;
  background-size: cover;
}


/* 39. additionals */
/* vertical lines */
.vertical-effect::before {
  width: 1px;
}

.vertical-effect:first-child::before,
.vertical-effect:last-child::before {
  right: -1px;
}

.vertical-effect:first-child::before {
  background: #5f5f5f;
}

.vertical-effect:last-child::before {
  background: #5f5f5f;
}

@-webkit-keyframes raindrop {
  0% {
    top: 0;
    opacity: 0;
    height: 80px;
  }

  50% {
    opacity: 1;
  }

  100% {
    top: 100%;
    height: 80px;
  }
}

@-ms-keyframes raindrop {
  0% {
    top: 0;
    opacity: 0;
    height: 80px;
  }

  50% {
    opacity: 1;
  }

  100% {
    top: 100%;
    height: 80px;
  }
}

@keyframes raindrop {
  0% {
    top: 0;
    opacity: 0;
    height: 80px;
  }

  50% {
    opacity: 1;
  }

  100% {
    top: 100%;
    height: 80px;
  }
}

@-webkit-keyframes raindrop-reverse {
  0% {
    bottom: 0;
    opacity: 0;
    height: 80px;
  }

  50% {
    opacity: 1;
  }

  100% {
    bottom: 100%;
    height: 80px;
  }
}

@-ms-keyframes raindrop-reverse {
  0% {
    bottom: 0;
    opacity: 0;
    height: 80px;
  }

  50% {
    opacity: 1;
  }

  100% {
    bottom: 100%;
    height: 80px;
  }
}

@keyframes raindrop-reverse {
  0% {
    bottom: 0;
    opacity: 0;
    height: 80px;
  }

  50% {
    opacity: 1;
  }

  100% {
    bottom: 100%;
    height: 80px;
  }
}

@media all and (min-width: 1920px) {
  @-webkit-keyframes raindrop {
    0% {
      top: 0;
      opacity: 0;
      height: 90px;
    }

    50% {
      opacity: 1;
    }

    100% {
      top: 100%;
      height: 90px;
    }
  }

  @-ms-keyframes raindrop {
    0% {
      top: 0;
      opacity: 0;
      height: 90px;
    }

    50% {
      opacity: 1;
    }

    100% {
      top: 100%;
      height: 90px;
    }
  }

  @keyframes raindrop {
    0% {
      top: 0;
      opacity: 0;
      height: 90px;
    }

    50% {
      opacity: 1;
    }

    100% {
      top: 100%;
      height: 90px;
    }
  }

  @-webkit-keyframes raindrop-reverse {
    0% {
      bottom: 0;
      opacity: 0;
      height: 90px;
    }

    50% {
      opacity: 1;
    }

    100% {
      bottom: 100%;
      height: 90px;
    }
  }

  @-ms-keyframes raindrop-reverse {
    0% {
      bottom: 0;
      opacity: 0;
      height: 90px;
    }

    50% {
      opacity: 1;
    }

    100% {
      bottom: 100%;
      height: 90px;
    }
  }

  @keyframes raindrop-reverse {
    0% {
      bottom: 0;
      opacity: 0;
      height: 90px;
    }

    50% {
      opacity: 1;
    }

    100% {
      bottom: 100%;
      height: 90px;
    }
  }
}

@media only screen and (max-width: 995px) {
  @-webkit-keyframes raindrop {
    0% {
      top: 0;
      opacity: 0;
      height: 70px;
    }

    50% {
      opacity: 1;
    }

    100% {
      top: 100%;
      height: 70px;
    }
  }

  @-ms-keyframes raindrop {
    0% {
      top: 0;
      opacity: 0;
      height: 70px;
    }

    50% {
      opacity: 1;
    }

    100% {
      top: 100%;
      height: 70px;
    }
  }

  @keyframes raindrop {
    0% {
      top: 0;
      opacity: 0;
      height: 70px;
    }

    50% {
      opacity: 1;
    }

    100% {
      top: 100%;
      height: 70px;
    }
  }

  @-webkit-keyframes raindrop-reverse {
    0% {
      bottom: 0;
      opacity: 0;
      height: 70px;
    }

    50% {
      opacity: 1;
    }

    100% {
      bottom: 100%;
      height: 70px;
    }
  }

  @-ms-keyframes raindrop-reverse {
    0% {
      bottom: 0;
      opacity: 0;
      height: 70px;
    }

    50% {
      opacity: 1;
    }

    100% {
      bottom: 100%;
      height: 70px;
    }
  }

  @keyframes raindrop-reverse {
    0% {
      bottom: 0;
      opacity: 0;
      height: 70px;
    }

    50% {
      opacity: 1;
    }

    100% {
      bottom: 100%;
      height: 70px;
    }
  }
}


/* Swiper CUSTOM */
.hero-slider-bg-controls {
  right: 44px;
  bottom: 50px;
}

@media only screen and (max-width: 880px) {
  .hero-slider-bg-controls {
    right: 15px;
    bottom: 20px;
  }
}

@media only screen and (max-width: 768px) {
  .hero-slider-bg-controls {
    right: 15px;
    bottom: 20px;
  }
}

.swiper-slide-pagination {
  left: 50px;
  bottom: 48px;
}

@media only screen and (max-width: 880px) {
  .swiper-slide-pagination {
    left: 20px;
    bottom: 17px;
  }
}

@media only screen and (max-width: 768px) {
  .swiper-slide-pagination {
    left: 20px;
    bottom: 17px;
  }
}

.swiper-slide-controls-play-pause {
  right: 170px;
  bottom: 50px;
}

@media only screen and (max-width: 880px) {
  .swiper-slide-controls-play-pause {
    right: 140px;
    bottom: 20px;
  }
}

@media only screen and (max-width: 768px) {
  .swiper-slide-controls-play-pause {
    right: 140px;
    bottom: 20px;
  }
}


/* fullwidth IMG */
.img-fullwidth-wrapper {
  min-height: 650px;
}

.img-fullwidth {
  min-height: 650px;
}


/* extras */
.section-all {
  position: relative;
  height: auto;
  min-height: inherit;
  overflow: hidden;
  margin-left: 0;
  margin-right: 0;
}

@media only screen and (max-width: 880px) {
  .section-all {
    margin-left: 0;
    margin-right: 0;
  }
}


/* Owl Carousel CUSTOM */
.owl-nav-custom-news,
.owl-nav-custom-rooms,
.owl-nav-custom-facilities {
  position: relative;
  width: 114px !important;
  max-width: 114px;
  height: 50px;
  left: 2px;
  right: 0;
  margin-left: auto;
  margin-right: auto;
  margin: 2px auto;
  text-align: center;
  overflow: hidden;
}


/* hover effect */
.hover-effect-img:hover .hover-icons a {
  -webkit-transform: scale(1);
  -moz-transform: scale(1);
  -ms-transform: scale(1);
  -o-transform: scale(1);
  transform: scale(1);
}

.hover-icons a,
.hover-icons a:hover,
.hover-icons a:active,
.hover-icons a:focus {
  -webkit-transform: scale(0.75);
  -moz-transform: scale(0.75);
  -ms-transform: scale(0.75);
  -o-transform: scale(0.75);
  transform: scale(0.75);
}


/* headings */
@media all and (min-width: 1920px) {
  .hero-heading {
    font-size: 85px;
  }
}

@supports((text-stroke: 1px #fff) or (-webkit-text-stroke: 1px #fff)) {
  .hero-heading span {
    color: transparent;
    -webkit-text-stroke: 1px #fff;
    text-stroke: 1px #fff;
    text-shadow: none;
  }
}

h2.hero-heading.hero-heading-dark {
  color: #5f5f5f;
}

@supports((text-stroke: 1px #5f5f5f) or (-webkit-text-stroke: 1px #5f5f5f)) {
  h2.hero-heading.hero-heading-dark span {
    color: transparent;
    -webkit-text-stroke: 1px #5f5f5f;
    text-stroke: 1px #5f5f5f;
    text-shadow: none;
  }
}

h2.hero-heading {
  margin: -10px auto -5px auto;
}

@media only screen and (max-width: 995px) {
  h2.hero-heading {
    margin: -7px auto -3px auto;
  }
}

@media only screen and (max-width: 768px) {
  h2.hero-heading {
    margin: -7px auto -3px auto;
  }
}


/* overlay */
.overlay-dark::before {
  background: rgba(0, 0, 0, .25);
  -webkit-pointer-events: none;
  -moz-pointer-events: none;
  pointer-events: none;
}


/* blockquote */
.testimonial blockquote {
  font-family: 'Satoshi-Bold', sans-serif;
  font-size: 35px;
  font-style: normal;
  line-height: 1.8;
}

@media only screen and (max-width: 995px) {
  .testimonial blockquote {
    font-size: 30px;
  }
}

@media only screen and (max-width: 880px) {
  .testimonial blockquote {
    font-size: 25px;
  }
}

.testimonial blockquote::before {
  display: none;
  visibility: hidden;
}


/* hover effect */
.legendary-gallery {
  margin: -15px 25px 0 25px;
  z-index: 2;
}

@media only screen and (max-width: 880px) {
  .legendary-gallery {
    margin: 5px 20px 0 20px;
  }
}

.legendary-gallery figure {
  padding: 25px;
}

@media only screen and (max-width: 880px) {
  .legendary-gallery figure {
    padding: 0;
  }
}

.legendary-gallery figure:last-child {
  margin-bottom: 25px;
}

@media only screen and (max-width: 880px) {
  .legendary-gallery figure:last-child {
    margin-bottom: 20px;
  }
}

.move-down {
  margin-bottom: 0;
}

@media only screen and (max-width: 880px) {
  .move-down {
    margin-bottom: 20px;
  }
}


/* legendary gallery img FIX */
.legendary-gallery img {
  width: 50vw;
  height: 66vh;
  object-fit: cover;
}

@media only screen and (max-width: 995px) {
  .legendary-gallery img {
    width: 100%;
    height: 100%;
  }
}


/* h2.hero-heading.hero-heading-dark span */
.testimonial.testimonial-2 .inner {
  max-width: inherit !important;
  padding: 0 50px;
}

@media all and (min-width: 1920px) {
  .testimonial.testimonial-2 .inner {
    max-width: 1180px !important;
    padding: 0 20px;
  }
}

@media only screen and (max-width: 1200px) {
  .testimonial.testimonial-2 .inner {
    max-width: inherit !important;
    padding: 0 30px;
  }
}

@media only screen and (max-width: 995px) {
  .testimonial.testimonial-2 .inner {
    padding: 0 50px;
  }
}

@media only screen and (max-width: 880px) {
  .testimonial.testimonial-2 .inner {
    padding: 0 80px;
  }
}

@media only screen and (max-width: 768px) {
  .testimonial.testimonial-2 .inner {
    padding: 0 20px;
  }
}


/* to top arrow */
.to-top-arrow {
  right: 50px;
}

@media only screen and (max-width: 995px) {
  .to-top-arrow {
    right: 50px;
  }
}

@media only screen and (max-width: 880px) {
  .to-top-arrow {
    right: 20px;
  }
}

@media only screen and (max-width: 768px) {
  .to-top-arrow {
    right: 20px;
  }
}

.to-top-arrow.show {
  bottom: 30px;
}

@media only screen and (max-width: 995px) {
  .to-top-arrow.show {
    bottom: 30px;
  }
}

@media only screen and (max-width: 880px) {
  .to-top-arrow.show {
    bottom: 0;
  }
}

@media only screen and (max-width: 768px) {
  .to-top-arrow.show {
    bottom: 0;
  }
}


/* parallax button more */
.more-button-txt-center.more-button-txt-center-close span {
  font-family: 'Satoshi-Bold', sans-serif;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.05em;
  color: #111;
}

@media only screen and (max-width: 995px) {
  .more-button-txt-center.more-button-txt-center-close span {
    font-size: 12px;
    letter-spacing: -0.02em;
  }
}


/* parallax button more */
@media only screen and (max-width: 995px) {
  .more-button-txt-center {
    font-size: 12px;
    letter-spacing: -0.02em;
  }
}

.more-button-txt-center {
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.05em;
}


/* Swiper CUSTOM */
.swiper-slide-controls {
  color: #fff;
  background: none;
}

.swiper-slide-controls:hover {
  background: none;
}

.circle-svg {
  position: absolute;
  left: 0;
}


/* blog news */
/* news quote */
@media only screen and (max-width: 880px) {
  .blog-quote {
    padding: 0 0 0 20px;
  }
}

.blog-quote p {
  font-size: 70px;
  top: 2px;
  line-height: 1.00;
}

@media only screen and (max-width: 995px) {
  .blog-quote p {
    font-size: 30px;
  }
}

@media only screen and (max-width: 880px) {
  .blog-quote p {
    font-size: 25px;
  }
}

@media only screen and (max-width: 768px) {
  .blog-quote p {
    top: -2px;
  }
}


/* social icons */
.social-icons {
  font-size: 12px;
  font-weight: 500;
  letter-spacing: -0.02em;
}

.social-icons li a:hover,
.social-icons li a:visited,
.social-icons li a:active,
.social-icons li a:focus {
  font-size: 12px;
  font-weight: 500;
  letter-spacing: -0.02em;
}


/* blockquote */
.testimonial {
  margin: -15px 0 -37px 0;
}

@media only screen and (max-width: 995px) {
  .testimonial {
    margin: -10px 0 -30px 0;
  }
}


/* parallax */
.parallax {
  padding: 130px 0;
}

@media all and (min-width: 1920px) {
  .parallax {
    padding: 140px 0;
  }
}

@media only screen and (max-width: 880px) {
  .parallax {
    padding: 120px 0;
  }
}


/* Lity CUSTOM */
.lity-close {
  top: 40px;
  right: 40px;
}

@media only screen and (max-width: 880px) {
  .lity-close {
    top: 10px;
    right: 10px;
  }
}

.lity-close:active {
  top: 40px;
  right: 40px;
}

@media only screen and (max-width: 880px) {
  .lity-close:active {
    top: 10px;
    right: 10px;
  }
}


/* font weight */
h4,
.item-button,
/* .item-name,
.item-price, */


.intro-years h2,
.intro-years h4 {
  font-weight: 800 !important;
}


/* 40. finals */
/* section title */
.section-title h2 {
  font-family: 'bellamy_signature', sans-serif;
  font-size: 60px;
  font-weight: 50;
  text-align: center;
  text-transform: none;
  color: #fff;
  line-height: 1;
  letter-spacing: -0.00em;
  margin: 0 auto;
}

.section-title.section-title-dark h2 {
  color: #5f5f5f;
}

@media only screen and (max-width: 995px) {
  .section-title h2 {
    font-size: 13px;
  }
}

.section-title-line>span {
  position: relative;
  display: inline-block;
  line-height: 1px;
  padding: 0 30px;
}

.section-title-line>span::before,
.section-title-line>span::after {
  content: "";
  position: absolute;
  display: block;
  width: 15px;
  height: 1px;
  top: 0;
  background-color: #fff;
}

.section-title-line.section-title-line-dark>span::before,
.section-title-line.section-title-line-dark>span::after {
  background-color: #5f5f5f;
}

.section-title-line>span::before {
  left: 0;
}

.section-title-line>span::after {
  right: 0;
}


/* intro years */
.intro-years {
  position: relative;
  width: auto;
  height: auto;
  margin: 0 auto;
}

.intro-years h2,
.intro-years h4 {
  font-family: 'Satoshi-Bold', sans-serif;
  font-size: 15px;
  font-weight: 600;
  text-align: center;
  text-transform: uppercase;
  color: #5f5f5f;
  line-height: 1.8;
  letter-spacing: -0.02em;
}

.intro-years h2 {
  margin: 0 auto;
}

.intro-years h4 {
  margin: 0 auto;
}

.intro-years h3 {
  position: relative;
  font-family: 'Satoshi-Bold', sans-serif;
  font-style: normal;
  font-weight: 700;
  font-size: 150px;
  text-align: center;
  text-transform: uppercase;
  letter-spacing: -0.00em;
  color: #fff;
  width: 100%;
  line-height: 100%;
  margin: -18px auto;
  z-index: 0;
}


/* the line */
.the-line {
  position: relative;
  width: 1px;
  height: 80px;
  background: #5f5f5f;
  margin: 1px auto;
}

@media all and (min-width: 1920px) {
  .the-line {
    height: 90px;
  }
}

@media only screen and (max-width: 995px) {
  .the-line {
    height: 70px;
  }
}

.the-line.the-line-light {
  background: #e0e0e0;
}


/* IMG carousel */
.carousel-item-img-wrapper {
  position: relative;
  height: auto;
  margin: 0;
  padding: 0;
  overflow: hidden;
  cursor: grab;
}

@media only screen and (max-width: 995px) {
  .carousel-item-img-wrapper {
    width: 100%;
  }
}

.carousel-item-img-wrapper.carousel-item-img-wrapper-all {
  height: auto;
}

.carousel-item-all {
  position: relative;
  width: 100%;
  background-position: center center;
  background-repeat: no-repeat;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -ms-background-size: cover;
  -o-background-size: cover;
  background-size: cover;
}

.carousel-item-all {
  height: 70vh;
}


/* circle wrapper */
.circle-wrapper {
  position: relative;
  display: block;
  overflow: hidden;
  width: 50%;
  padding-bottom: 50%;
  height: auto;
  left: 0;
  right: 0;
  margin-left: auto;
  margin-right: auto;
}

@media only screen and (max-width: 995px) {
  .circle-wrapper {
    width: 100%;
    padding-bottom: 100%;
  }
}

.circle-wrapper img,
.circle-wrapper .mp4video {
  position: absolute;
  width: 100%;
  height: 100%;
  clip-path: circle(50% at 50% 50%);
  object-fit: cover;
}

.circle-wrapper-full {
  position: relative;
  display: block;
  overflow: hidden;
  width: 100%;
  padding-bottom: 100%;
  height: auto;
  left: 0;
  right: 0;
  margin-left: auto;
  margin-right: auto;
}

.circle-wrapper-full .carousel-item-all {
  position: absolute;
  width: 100%;
  height: 100%;
  clip-path: circle(50% at 50% 50%);
  object-fit: cover;
}

.circle-wrapper-half {
  position: relative;
  display: inline-block;
  overflow: hidden;
  width: 25%;
  padding-bottom: 25%;
  height: auto;
  left: -75px;
  right: 0;
  margin-left: 50px;
  margin-right: auto;
}

@media only screen and (max-width: 995px) {
  .circle-wrapper-half {
    width: 100%;
    padding-bottom: 100%;
    left: 0;
    margin-left: 0;
  }
}

.circle-wrapper-half img,
.circle-wrapper-half .mp4video {
  position: absolute;
  width: 100%;
  height: 100%;
  clip-path: circle(50% at 50% 50%);
  object-fit: cover;
}


/* h2 */
h2 {
  position: relative;
  font-family: 'Satoshi-Bold', sans-serif;
  font-style: normal;
  font-weight: 800;
  font-size: 45px;
  text-align: center;
  text-transform: none;
  letter-spacing: -0.04em;
  margin: -7px auto 5px auto;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  width: 100%;
  line-height: 1.8;
  z-index: 1;
}

@media only screen and (max-width: 995px) {
  h2 {
    font-size: 35px;
    margin: -4px auto 5px auto;
  }
}

@media only screen and (max-width: 880px) {
  h2 {
    padding: 0 25px;
  }
}

@media only screen and (max-width: 768px) {
  h2 {
    margin: -4px auto 5px auto;
  }
}


/* blog tag */
.blog-tag {
  font-family: 'Satoshi-Bold', sans-serif;
  font-size: 13px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  color: #5f5f5f;
  text-align: center;
  margin: -5px auto;
}

.blog-tag.blog-tag-rooms {
  text-align: left;
}

.blog-tag.blog-tag-rooms span {
  font-size: 20px;
  padding-left: 20px;
}

.blog-tag.blog-tag-light {
  color: #f3bf3d;
}


/* post bg all */
.post-bg-all {
  width: 100%;
  height: auto;
  background-position: center center;
  background-repeat: no-repeat;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -ms-background-size: cover;
  -o-background-size: cover;
  background-size: cover;
  -webkit-transition: all 1s ease;
  -moz-transition: all 1s ease;
  -ms-transition: all 1s ease;
  -o-transition: all 1s ease;
  transition: all 1s ease;
}

.halves:hover .post-bg-all {
  -webkit-transition: all 1s ease;
  -moz-transition: all 1s ease;
  -ms-transition: all 1s ease;
  -o-transition: all 1s ease;
  transition: all 1s ease;
}

.all-bg-right {
  -webkit-border-radius: 0 50px 0 0;
  -moz-border-radius: 0 50px 0 0;
  -ms-border-radius: 0 50px 0 0;
  -o-border-radius: 0 50px 0 0;
  border-radius: 0 50px 0 0;
}

.all-bg-left {
  -webkit-border-radius: 0 0 0 50px;
  -moz-border-radius: 0 0 0 50px;
  -ms-border-radius: 0 0 0 50px;
  -o-border-radius: 0 0 0 50px;
  border-radius: 0 0 0 50px;
}

@media only screen and (max-width: 995px) {

  .all-bg-right,
  .all-bg-left {
    -webkit-border-radius: 0;
    -moz-border-radius: 0;
    -ms-border-radius: 0;
    -o-border-radius: 0;
    border-radius: 0;
  }
}


/* halves */
.halves {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: -moz-flex;
  display: -webkit-flex;
  display: flex;
}

.halves {
  -webkit-box-orient: vertical;
  box-orient: vertical;
  -webkit-box-direction: normal;
  box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
}

.halves .half {
  min-height: 650px;
  -webkit-box-flex: 0;
  -ms-flex: none;
  flex: none;
}

.half.half-color {
  background: #fff;
  min-height: 100px;
}

.half.half-color.half-color-invert {
  background: #f7f7f7;
}


/* extra margin */
.extra-margin-owl {
  position: relative;
  height: auto;
  min-height: inherit;
  overflow: hidden;
  margin-left: 50px;
  margin-right: 50px;
  background: none;
}

@media only screen and (max-width: 880px) {
  .extra-margin-owl {
    margin-left: 20px;
    margin-right: 20px;
  }
}

.extra-margin-container {
  position: relative;
  height: auto;
  min-height: inherit;
  margin-left: 0;
  margin-right: 0;
  background: none;
}

@media only screen and (max-width: 1200px) {
  .extra-margin-container {
    margin-left: 0;
    margin-right: 0;
  }
}

@media only screen and (max-width: 995px) {
  .extra-margin-container {
    margin-left: -30px;
    margin-right: -30px;
  }
}

@media only screen and (max-width: 880px) {
  .extra-margin-container {
    margin-left: 0;
    margin-right: 0;
  }
}

@media only screen and (max-width: 768px) {
  .extra-margin-container {
    margin-left: 5px;
    margin-right: 5px;
  }
}

@media only screen and (max-width: 640px) {
  .extra-margin-container {
    margin-left: 5px;
    margin-right: 5px;
  }
}

@media only screen and (max-width: 1200px) {
  .extra-margin-container.extra-margin-container-modal {
    margin-left: -10px;
    margin-right: -10px;
  }
}

@media only screen and (max-width: 995px) {
  .extra-margin-container.extra-margin-container-modal {
    margin-left: -30px;
    margin-right: -30px;
  }
}

@media only screen and (max-width: 880px) {
  .extra-margin-container.extra-margin-container-modal {
    margin-left: 0;
    margin-right: 0;
  }
}

@media only screen and (max-width: 768px) {
  .extra-margin-container.extra-margin-container-modal {
    margin-left: 5px;
    margin-right: 5px;
  }
}

.extra-margin-halves {
  position: relative;
}

@media only screen and (max-width: 880px) {
  .extra-margin-halves {
    margin-left: 20px;
    margin-right: 20px;
  }
}


/* section title inner BLOG */
.section-title-inner,
.section-title-inner.section-title-inner-dark {
  display: block;
  font-family: 'Satoshi-Bold', sans-serif;
  font-size: 13px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  text-align: center;
  margin: -7px 0 -5px 0;
}

.section-title-inner {
  color: #5f5f5f;
}

.section-title-inner.section-title-inner-dark {
  color: #fff;
}


/* Swiper style 4 */
.swiper-scrollbar {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 74px;
  margin-left: auto;
  margin-right: auto;
  width: 300px !important;
  height: 1px;
  background: rgba(119, 119, 119, .75);
  -webkit-border-radius: 0;
  -moz-border-radius: 0;
  -ms-border-radius: 0;
  -o-border-radius: 0;
  border-radius: 0;
  z-index: 15;
}

@media only screen and (max-width: 995px) {
  .swiper-scrollbar {
    display: none;
    visibility: hidden;
  }
}

.swiper-scrollbar-drag {
  position: relative;
  width: 100%;
  height: 3px;
  top: -1px;
  left: 0;
  -webkit-border-radius: 0;
  -moz-border-radius: 0;
  -ms-border-radius: 0;
  -o-border-radius: 0;
  border-radius: 0;
  background: #fff;
}

@media only screen and (max-width: 995px) {
  .swiper-scrollbar-drag {
    display: none;
    visibility: hidden;
  }
}





/* colors */
a,
a:hover,
a:visited,
a:active,
a:focus {
  color: #fff;
}

p a,
p a:hover,
p a:visited,
p a:active,
p a:focus,
.social-icons li a {
  color: #5f5f5f !important;
}

body,
p,
p a,
p a:hover,
h2.hero-heading.hero-heading-dark,
.testimonial blockquote,
.section-title h2,
.intro-years h2,
.intro-years h3,
.intro-years h4,
/*
.item-button,
.item-name,
.item-price,
*/
h4,
.color-switch,
.col-all:hover .color-switch,
.skillbar-title,
.skill-bar-percent,
.skillbar-title-2,
.skill-bar-percent-2,
.blog-tag,
.social-icons li span,
.blog-quote p,
.more-button-bg-center,
.section-title-inner,
.section-title-inner.section-title-inner-dark,
.testimonial.testimonial-2 blockquote,
.contact-info-description,
.contact-info-description-img,
.contact-info-text a,
.contact-info-text a:hover,
.contact-info-text a:visited,
.contact-info-text a:active,
.contact-info-text a:focus,
h2.hero-heading,
.copyright {
  color: #5f5f5f;
}

.contact-info-text a,
.contact-info-text a:hover,
.testimonial.testimonial-2 .quote .quote-inner,
.contact-info-description,
.contact-info-description-img,
.contact-info-text,
.parallax-content .section-title .section-title-line {
  color: #e5e5e5;
}

.parallax-content .section-title .section-title-line>span::before,
.parallax-content .section-title .section-title-line>span::after {
  background-color: #e5e5e5;
}

.parallax-content .hero-heading {
  color: #e5e5e5;
}

@supports((text-stroke: 1px #e5e5e5) or (-webkit-text-stroke: 1px #e5e5e5)) {
  .parallax-content .hero-heading span {
    color: transparent;
    -webkit-text-stroke: 1px #e5e5e5;
    text-stroke: 1px #e5e5e5;
    text-shadow: none;
  }
}

.item-selector a {
  color: #5f5f5f;
}

.intro-years h3,
/*
.item-name,
.item-price,
*/
.color-switch,
.section-title-inner.section-title-inner-dark {
  color: #323232;
}

.section-title.section-title-home h2 {
  color: #e5e5e5;
}

.section-title-line.section-title-line-home>span::before,
.section-title-line.section-title-line-home>span::after {
  background-color: #e5e5e5;
}

@supports((text-stroke: 1px #5f5f5f) or (-webkit-text-stroke: 1px #5f5f5f)) {

  h2.hero-heading span,
  h2.hero-heading.hero-heading-dark span {
    color: transparent;
    -webkit-text-stroke: 1px #5f5f5f;
    text-stroke: 1px #5f5f5f;
    text-shadow: none;
  }
}

.section-title-line>span::before,
.section-title-line>span::after {
  background-color: #5f5f5f;
}

.section-title.section-title-dark h2 {
  color: #5f5f5f;
}

.section-title-line.section-title-line-dark>span::before,
.section-title-line.section-title-line-dark>span::after {
  background-color: #5f5f5f;
}

.skillbar-bar,
.skillbar-bar-2 {
  background: #ccc;
}

/*
.item-divider {
border-bottom: 1px dashed #4c4c4c;
}
*/

.blog-quote {
  border-left: 5px solid #5f5f5f;
}

@supports((text-stroke: 1px #5f5f5f) or (-webkit-text-stroke: 1px #5f5f5f)) {
  .blog-quote p span {
    color: transparent;
    -webkit-text-stroke: 1px #5f5f5f;
    text-stroke: 1px #5f5f5f;
    text-shadow: none;
  }
}

.the-line {
  background: #9c9c9c;
}

.the-line.the-line-light {
  background: #9c9c9c;
}

.more-button-bg-center {
  border: 2px dashed #9e1812;
}

.more-button-txt-center span {
  color: #fff;
}

.more-button-bg-center.more-button-bg-center-dark.more-button-bg-center-dark-close {
  border: 2px dashed #9c9c9c;
}

.more-button-txt-center.more-button-txt-center-close span {
  color: #9c9c9c;
}

.contact-modal-closer {
  color: #9c9c9c;
}


/* hover effect menu */
.hover-effect {
  width: -webkit-calc(100% - 100px);
  width: -moz-calc(100% - 100px);
  width: calc(100% - 100px);
  height: -webkit-calc(100% - 100px);
  height: -moz-calc(100% - 100px);
  height: calc(100% - 100px);
  top: 50px;
  left: 50px;
  bottom: 50px;
  right: 50px;
}

@media only screen and (max-width: 880px) {
  .hover-effect {
    width: -webkit-calc(100% - 40px);
    width: -moz-calc(100% - 40px);
    width: calc(100% - 40px);
    height: -webkit-calc(100% - 40px);
    height: -moz-calc(100% - 40px);
    height: calc(100% - 40px);
    top: 20px;
    left: 20px;
    bottom: 20px;
    right: 20px;
  }
}


/* paddings */
/* Swiper CUSTOM */
.hero-slider-bg-controls {
  right: 44px;
  bottom: 50px;
}

@media only screen and (max-width: 880px) {
  .hero-slider-bg-controls {
    right: 44px;
    bottom: 50px;
  }
}

@media only screen and (max-width: 768px) {
  .hero-slider-bg-controls {
    right: 15px;
    bottom: 20px;
  }
}

.swiper-slide-pagination {
  left: 50px;
  bottom: 47px;
}

@media only screen and (max-width: 880px) {
  .swiper-slide-pagination {
    left: 50px;
    bottom: 47px;
  }
}

@media only screen and (max-width: 768px) {
  .swiper-slide-pagination {
    left: 20px;
    bottom: 17px;
  }
}

.swiper-slide-controls-play-pause {
  right: 170px;
  bottom: 50px;
}

@media only screen and (max-width: 880px) {
  .swiper-slide-controls-play-pause {
    right: 170px;
    bottom: 50px;
  }
}

@media only screen and (max-width: 768px) {
  .swiper-slide-controls-play-pause {
    right: 140px;
    bottom: 20px;
  }
}


/* to top arrow */
.to-top-arrow {
  right: 50px;
}

@media only screen and (max-width: 995px) {
  .to-top-arrow {
    right: 50px;
  }
}

@media only screen and (max-width: 880px) {
  .to-top-arrow {
    right: 50px;
  }
}

@media only screen and (max-width: 768px) {
  .to-top-arrow {
    right: 20px;
  }
}

.to-top-arrow.show {
  bottom: 30px;
}

@media only screen and (max-width: 995px) {
  .to-top-arrow.show {
    bottom: 30px;
  }
}

@media only screen and (max-width: 880px) {
  .to-top-arrow.show {
    bottom: 30px;
  }
}

@media only screen and (max-width: 768px) {
  .to-top-arrow.show {
    bottom: 0;
  }
}


/* extra margin */
.extra-margin-owl {
  margin-left: 50px;
  margin-right: 50px;
}

@media only screen and (max-width: 880px) {
  .extra-margin-owl {
    margin-left: 50px;
    margin-right: 50px;
  }
}

@media only screen and (max-width: 768px) {
  .extra-margin-owl {
    margin-left: 20px;
    margin-right: 20px;
  }
}

.extra-margin-container {
  margin-left: 0;
  margin-right: 0;
}

@media only screen and (max-width: 1200px) {
  .extra-margin-container {
    margin-left: 0;
    margin-right: 0;
  }
}

@media only screen and (max-width: 995px) {
  .extra-margin-container {
    margin-left: -30px;
    margin-right: -30px;
  }
}

@media only screen and (max-width: 880px) {
  .extra-margin-container {
    margin-left: 10px;
    margin-right: 10px;
  }
}

@media only screen and (max-width: 768px) {
  .extra-margin-container {
    margin-left: 5px;
    margin-right: 5px;
  }
}

@media only screen and (max-width: 640px) {
  .extra-margin-container {
    margin-left: 5px;
    margin-right: 5px;
  }
}

@media only screen and (max-width: 1200px) {

  .extra-margin-container.extra-margin-container-modal,
  .extra-margin-container.extra-margin-container-post {
    margin-left: -10px;
    margin-right: -10px;
  }
}

@media only screen and (max-width: 995px) {

  .extra-margin-container.extra-margin-container-modal,
  .extra-margin-container.extra-margin-container-post {
    margin-left: -25px;
    margin-right: -25px;
  }
}

@media only screen and (max-width: 880px) {

  .extra-margin-container.extra-margin-container-modal,
  .extra-margin-container.extra-margin-container-post {
    margin-left: -30px;
    margin-right: -30px;
  }
}

@media only screen and (max-width: 768px) {

  .extra-margin-container.extra-margin-container-modal,
  .extra-margin-container.extra-margin-container-post {
    margin-left: 5px;
    margin-right: 5px;
  }
}


/* h2.hero-heading.hero-heading-dark span */
.testimonial.testimonial-2 .inner {
  padding: 0 50px;
}

@media all and (min-width: 1920px) {
  .testimonial.testimonial-2 .inner {
    padding: 0 20px;
  }
}

@media only screen and (max-width: 1200px) {
  .testimonial.testimonial-2 .inner {
    padding: 0 50px;
  }
}

@media only screen and (max-width: 995px) {
  .testimonial.testimonial-2 .inner {
    padding: 0 50px;
  }
}

@media only screen and (max-width: 880px) {
  .testimonial.testimonial-2 .inner {
    padding: 0 50px;
  }
}

@media only screen and (max-width: 768px) {
  .testimonial.testimonial-2 .inner {
    padding: 0 20px;
  }
}


/* post all txt */
.post-all-txt {
  padding: 0 35px;
}

@media all and (min-width: 1920px) {
  .post-all-txt {
    padding: 0 150px;
  }
}

@media only screen and (max-width: 1200px) {
  .post-all-txt {
    padding: 0 50px;
  }
}

@media only screen and (max-width: 995px) {
  .post-all-txt {
    padding: 0 35px;
  }
}

@media only screen and (max-width: 880px) {
  .post-all-txt {
    padding: 0 50px;
  }
}

@media only screen and (max-width: 768px) {
  .post-all-txt {
    padding: 0 20px;
  }
}


/* items img */
.menu-img {
  position: relative;
  padding: 0 0 0 95px;
  margin: -80px 0 0 0;
  width: 80px;
  height: 80px;
}

.menu-img .menu-img-inner {
  position: absolute;
  left: 0;
  top: 40px;
  width: 80px;
  height: 80px;
  -webkit-border-radius: 50%;
  -moz-border-radius: 50%;
  -ms-border-radius: 50%;
  -o-border-radius: 50%;
  border-radius: 50%;
  overflow: hidden;
}

.menu-img .menu-img-inner img {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
  -moz-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  -o-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  object-fit: cover;
  object-position: center;
}


/* corrections */
.hover-icons a,
.hover-icons a:hover,
.hover-icons a:visited,
.hover-icons a:active,
.hover-icons a:focus {
  color: #fff;
}

.hover-icons a {
  left: -10px;
}

@media only screen and (max-width: 880px) {
  .hover-icons a {
    left: -5px;
  }
}

@media only screen and (max-width: 768px) {
  .hover-icons a {
    left: 0;
  }
}

.hero-heading.hero-heading-home,
.hero-heading.hero-heading-home span,
.testimonial.testimonial-2 blockquote,
h2.hero-heading,
h2.hero-heading span {
  font-family: 'bellamy_signature', sans-serif;
  font-weight: 50;
  color: #fff !important;
  -webkit-text-stroke: unset !important;
  text-stroke: unset !important;
}

.hero-heading.hero-heading-dark,
.hero-heading.hero-heading-dark span,
.blog-quote p,
.blog-quote p span {
  font-family: 'bellamy_signature', sans-serif;
  font-weight: 50;
  color: #5f5f5f !important;
  -webkit-text-stroke: unset !important;
  text-stroke: unset !important;
}

.swiper-slide-pagination,
.swiper-slide-controls-play-pause {
  display: none;
  visibility: hidden;
}

.swiper-slide-controls.slide-prev,
.swiper-slide-controls.slide-next {
  margin-left: auto;
  margin-right: auto;
}

@media only screen and (max-width: 880px) {
  .swiper-slide-controls.slide-next {
    margin-top: 0;
  }
}

.swiper-slide-controls.slide-prev {
  position: absolute;
  width: 50px;
  top: 50%;
  left: 50px;
  right: auto;
  bottom: auto;
  -webkit-transform: translateY(-50%);
  -moz-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  z-index: 10;
}

@media only screen and (max-width: 880px) {
  .swiper-slide-controls.slide-prev {
    left: 50px;
    top: auto;
    bottom: 50px;
    -webkit-transform: none;
    -moz-transform: none;
    -ms-transform: none;
    transform: none;
  }
}

@media only screen and (max-width: 768px) {
  .swiper-slide-controls.slide-prev {
    left: 20px;
    bottom: 20px;
  }
}

.swiper-slide-controls.slide-next {
  position: absolute;
  width: 50px;
  top: 50%;
  right: 50px;
  left: auto;
  bottom: auto;
  -webkit-transform: translateY(-50%);
  -moz-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  z-index: 10;
}

@media only screen and (max-width: 880px) {
  .swiper-slide-controls.slide-next {
    right: 50px;
    top: auto;
    bottom: 50px;
    -webkit-transform: none;
    -moz-transform: none;
    -ms-transform: none;
    transform: none;
  }
}

@media only screen and (max-width: 768px) {
  .swiper-slide-controls.slide-next {
    right: 20px;
    bottom: 20px;
  }
}

.main-navigation .navbar-nav li a,
.more-button-txt-center span,
.more-button-txt-center.more-button-txt-center-close span,
.blog-tag,
.social-icons,
.social-icons li a,
.social-icons li a:hover,
.social-icons li a:visited,
.social-icons li a:active,
.social-icons li a:focus {
  font-weight: 800;
}

.more-button-txt-center span,
.more-button-txt-center.more-button-txt-center-close span {
  font-size: 11px;
}

.skillbar-title,
.skillbar-title-2,
.skill-bar-percent,
.skill-bar-percent-2,
.section-title-inner,
.section-title-inner.section-title-inner-dark {
  font-weight: 700;
}


/* input */
input[type="text"] {
  display: block;
  max-width: 100%;
  width: 100%;
  height: auto;
  font-family: 'Satoshi-Bold', sans-serif;
  font-size: 15px;
  color: #111;
  font-weight: 500;
  line-height: 1.5em;
}


/* reservation */
.reservation-form-wrapper {
  position: relative;
  width: 100% !important;
  max-width: 100%;
  /* height: 162.5px; */
  height: 62.5px;
  left: 0;
  right: 0;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
  background: #f7f7f7;
}

@media only screen and (max-width: 880px) {
  .reservation-form-wrapper {
    height: auto;
  }
}

.reservation-wrapper span {
  display: inline-block;
}

.reservation-wrapper {
  position: absolute;
  width: 100%;
  left: 0;
  bottom: 0;
  z-index: 2;
}

@media only screen and (max-width: 880px) {
  .reservation-wrapper {
    display: none;
    visibility: hidden;
  }
}

.reservation-inner {
  position: relative;
  height: 62.5px !important;
}


/* form */
#form-2 {
  position: relative;
  display: block;
  padding: 0;
}

#form-2 label {
  display: none;
}

#form-2 .col-1 {
  float: left;
  width: 16.66%;
}

#form-2 .col-2 {
  float: left;
  width: 16.66%;
}

@media only screen and (max-width: 1200px) {

  #form-2 .col-1,
  #form-2 .col-2 {
    width: 20%;
  }
}

@media only screen and (max-width: 880px) {

  #form-2 .col-1,
  #form-2 .col-2 {
    width: 100%;
  }
}

#form-2 .col-3 {
  float: left;
  width: 16.66%;
}

@media only screen and (max-width: 1200px) {
  #form-2 .col-3 {
    width: 100%;
  }
}

#form-2 .c-1,
#form-2 .c-2,
#form-2 .c-3,
#form-2 .c-4,
#form-2 .c-5 {
  height: 62.5px;
  margin: 0;
  text-align: left;
}

#form-2 .c-1,
#form-2 .c-2,
#form-2 .c-3,
#form-2 .c-4 {
  /* border-right: 1px solid #ececec; */
  border-right: none;
  height: 62.5px;
  margin: 0;
}

@media only screen and (max-width: 880px) {

  #form-2 .c-1,
  #form-2 .c-2,
  #form-2 .c-3,
  #form-2 .c-4 {
    border-right: none;
  }
}

#form-2 .c-5 {
  border-right: none;
}

.col-1.c-1,
.col-1.c-2 {
  margin-bottom: 10px !important;
}

@media only screen and (max-width: 1200px) {

  .col-1.c-1,
  .col-1.c-2 {
    margin-bottom: 43px !important;
  }
}

@media only screen and (max-width: 880px) {

  .col-1.c-1,
  .col-1.c-2 {
    margin-bottom: 43px !important;
  }
}

.col-2.c-3,
.col-2.c-4,
.col-2.c-5 {
  margin-bottom: 2px !important;
}

@media only screen and (max-width: 1200px) {

  .col-2.c-3,
  .col-2.c-4,
  .col-2.c-5 {
    margin-bottom: 35px !important;
  }
}

@media only screen and (max-width: 880px) {

  .col-2.c-3,
  .col-2.c-4,
  .col-2.c-5 {
    margin-bottom: 35px !important;
  }
}

/* reservation button */
.reservation-button {
  position: relative;
  display: block;
  width: 100%;
  line-height: 62.5px;
  margin: 0;
  padding: 0;
  border: none;
  background: #9e1812;
  color: #fff;
  -webkit-transition: all 0.5s linear;
  -moz-transition: all 0.5s linear;
  -ms-transition: all 0.5s linear;
  -o-transition: all 0.5s linear;
  transition: all 0.5s linear;
  cursor: pointer;
  font-family: 'Satoshi-Bold', sans-serif;
  font-size: 15px;
  font-weight: 600;
  text-align: center;
  text-transform: uppercase;
  letter-spacing: -0.02em;
}

@media only screen and (max-width: 995px) {
  .reservation-button {
    font-size: 13px;
  }
}

.reservation-button:hover {
  background: #9c9c9c;
  color: #fff;
  -webkit-transition: all 0.5s linear;
  -moz-transition: all 0.5s linear;
  -ms-transition: all 0.5s linear;
  -o-transition: all 0.5s linear;
  transition: all 0.5s linear;
}

@media only screen and (max-width: 880px) {
  .reservation-button:hover {
    background: #111;
  }
}

.reservation-button:focus {
  outline: none;
}

.reservation-button::after {
  content: "";
  position: absolute;
  display: block;
  width: 1px;
  height: 100%;
  left: 100%;
  top: 0;
  background: none;
}


/* input inner */
.input-inner {
  position: relative;
}

.input-inner::after {
  content: "";
  position: absolute;
  display: block;
  right: 20px;
  top: 23px;
  font-family: "Ionicons";
  font-display: swap;
  content: "\f3f3";
  font-size: 17px;
  color: #5f5f5f;
  line-height: 1;
  -webkit-pointer-events: none;
  -moz-pointer-events: none;
  pointer-events: none;
}

.input-inner.input-inner-email::after {
  content: "\f422";
}

.input-inner input {
  display: block;
  width: 100%;
  padding: 20px 40px 20px 20px;
  background: #fff;
  border: none;
  -webkit-box-shadow: none;
  box-shadow: none;
  -webkit-border-radius: 0;
  -moz-border-radius: 0;
  -ms-border-radius: 0;
  -o-border-radius: 0;
  border-radius: 0;
}

.input-inner input::placeholder {
  font-size: 15px;
  color: #111;
  font-weight: 500;
}

.input-inner input:focus {
  outline: none;
  background: #fff;
  border: none;
  -webkit-box-shadow: none;
  box-shadow: none;
  -webkit-border-radius: 0;
  -moz-border-radius: 0;
  -ms-border-radius: 0;
  -o-border-radius: 0;
  border-radius: 0;
}


/* select wrapper */
.select-wrapper {
  font-family: 'Satoshi-Bold', sans-serif;
  margin: 0;
}

.select-inner {
  position: relative;
}

.select-inner:after {
  content: "";
  position: absolute;
  display: block;
  top: 25px;
  right: 20px;
  font-family: "Ionicons";
  font-display: swap;
  content: "\f3d0";
  font-size: 16px;
  line-height: 16px;
  font-weight: 500;
  color: #5f5f5f;
  -webkit-pointer-events: none;
  -moz-pointer-events: none;
  pointer-events: none;
}


/* select2 */
.select2 {
  width: 100% !important;
  height: 62.5px !important;
  background: #fff;
  margin: 0;
}

.select2 *:focus {
  outline: none !important;
}

.select2-container--default .select2-results>.select2-results__options {
  max-height: 500px;
  border: 1px solid #ececec !important;
}

.select2-container--default .select2-selection--single {
  background: none;
  border-radius: 0;
  border: none;
  height: auto;
}

.select2-container--default .select2-selection--single .select2-selection__rendered {
  font-size: 15px;
  color: #111;
  font-weight: 500;
  line-height: 1;
  padding: 23px 49px 17px 20px;
}

.select2-container--default .select2-selection--single .select2-selection__arrow {
  display: none;
}

.select2-dropdown {
  background: none;
  border-radius: 0;
  z-index: 100;
  min-width: 0px;
  border: none;
}

.select2-container--open .select2-dropdown--above {
  border-bottom: 1px solid #ececec;
}

.select2-container--open .select2-dropdown--below {
  border-top: 1px solid #ececec;
}

.select2-results__option {
  background: #fff;
  font-size: 13px;
  font-weight: 500;
  line-height: 20px;
  color: #5f5f5f;
  border-top: 1px solid #ececec;
  text-align: center;
  padding: 10px 30px;
}

.select2-results__option:first-child {
  border-top: none;
}

.small .select2-results__option {
  padding-left: 0;
}

.select2-container--default .select2-results__option[aria-selected=true] {
  background: #5f5f5f;
  color: #fff;
}

.select2-container--default .select2-results__option--highlighted[aria-selected] {
  background: #5f5f5f;
  color: #fff;
}


/* reservation form */
.success-r {
  font-family: 'Raleway', sans-serif;
  font-size: 10px;
  font-style: normal;
  font-weight: 700;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  text-align: center;
  color: #5f5f5f;
  /* margin: 56px auto 0 auto; */
  margin: 28px auto 0 auto;
  padding: 0;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

@media only screen and (max-width: 1200px) {
  .success-r {
    margin: 0 auto;
  }
}

@media only screen and (max-width: 880px) {
  .success-r {
    margin: 0 auto;
    padding: 30px 0 25px 0;
  }
}

#form-2 .error-r {
  font-family: 'Raleway', sans-serif;
  position: absolute;
  display: block;
  font-size: 9px;
  text-transform: uppercase;
  text-align: left;
  color: #5f5f5f;
  margin: 10px 0 0 0;
  padding: 0;
  letter-spacing: 0.15em;
  font-weight: 700 !important;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  left: 0;
  right: 0;
  margin-left: auto;
  margin-right: auto;
  width: 100% !important;
}


/* reservation STYLE 02 */
.reservation-wrapper.reservation-wrapper-home {
  bottom: 200px;
}

@media only screen and (max-width: 880px) {
  .reservation-wrapper.reservation-wrapper-home {
    bottom: auto;
  }
}

#form-2.form-2 .error-r,
.reservation-wrapper.reservation-wrapper-home .success-r {
  color: #fff !important;
}

@media only screen and (max-width: 880px) {

  #form-2.form-2 .error-r,
  .reservation-wrapper.reservation-wrapper-home .success-r {
    color: #5f5f5f !important;
  }
}

.reservation-wrapper.reservation-wrapper-home .success-r {
  margin: 54px auto 0 auto !important;
}

@media only screen and (max-width: 1200px) {
  .reservation-wrapper.reservation-wrapper-home .success-r {
    margin: 54px auto 0 auto !important;
  }
}

@media only screen and (max-width: 880px) {
  .reservation-wrapper.reservation-wrapper-home .success-r {
    margin: -3px auto 0 auto !important;
    padding: 30px 0 25px 0;
  }
}

#reservation-form-wrapper.reservation-form-wrapper-home,
.scroll-indicator.scroll-indicator-home {
  display: none;
  visibility: hidden;
}

@media only screen and (max-width: 880px) {
  #reservation-form-wrapper.reservation-form-wrapper-home {
    display: block;
    visibility: visible;
  }
}


/* finals */

.post-box-inner {
  position: relative;
  width: 100% !important;
  height: auto;
  left: 0;
  right: 0;
  margin-left: auto;
  margin-right: auto;
  text-align: center !important;
  background: none;
}

/* 41. blog */
.bg-light.bg-light-blog {
  background: #f7f7f7;
}

.bg-dark.bg-dark-blog {
  background: #fff;
}


/* blog comment form */
.more-wraper-center.more-wraper-center-form-2 {
  margin: 15px auto -15px auto;
}

#comment-form {
  position: relative;
  left: 0;
  right: 0;
  margin-left: auto;
  margin-right: auto;
  width: 100% !important;
  text-align: center !important;
}

.extra-margin-blog {
  position: relative;
  margin-left: -15px;
  margin-right: -15px;
  background: none;
}

#comment-form {
  position: relative;
  width: 100%;
  top: -20px;
  padding: 0;
  text-align: center;
}

form {
  margin: 0;
  padding: 0;
}

#form-3 input {
  position: relative;
  width: 100%;
  height: 40px;
  border-bottom: 1px solid #111;
  border-left: none;
  border-right: none;
  border-top: none;
  padding: 5px 5px;
  background: none;
  margin: 10px 0 20px 0;
  font-family: 'Raleway', sans-serif;
  font-size: 13px;
  line-height: 1.5;
  font-style: normal;
  font-weight: 600;
  text-align: center;
  color: #111;
  -webkit-transition: all 0.5s linear;
  -moz-transition: all 0.5s linear;
  -ms-transition: all 0.5s linear;
  -o-transition: all 0.5s linear;
  transition: all 0.5s linear;
}

textarea {
  position: relative;
  width: 100%;
  height: 100px;
  border-bottom: 1px solid #111;
  border-left: none;
  border-right: none;
  border-top: none;
  padding: 5px 5px;
  background: none;
  margin: 5px;
  font-family: 'Raleway', sans-serif;
  font-size: 13px;
  line-height: 1.5;
  font-style: normal;
  font-weight: 600;
  text-align: center;
  -webkit-transition: all 0.5s linear;
  -moz-transition: all 0.5s linear;
  -ms-transition: all 0.5s linear;
  -o-transition: all 0.5s linear;
  transition: all 0.5s linear;
}

#form-3 textarea {
  color: #111;
  margin: 16px 0 10px 0;
  -webkit-transition: all 0.5s linear;
  -moz-transition: all 0.5s linear;
  -ms-transition: all 0.5s linear;
  -o-transition: all 0.5s linear;
  transition: all 0.5s linear;
}

#form-3 input:hover,
#form-3 textarea:hover {
  border-color: rgba(17, 17, 17, .5);
  -webkit-transition: all 0.5s linear;
  -moz-transition: all 0.5s linear;
  -ms-transition: all 0.5s linear;
  -o-transition: all 0.5s linear;
  transition: all 0.5s linear;
}


#form-3 input:focus,
#form-3 textarea:focus {
  -webkit-transition: all 0.5s linear;
  -moz-transition: all 0.5s linear;
  -ms-transition: all 0.5s linear;
  -o-transition: all 0.5s linear;
  transition: all 0.5s linear;
}

.success-c {
  font-family: 'Raleway', sans-serif;
  font-size: 10px;
  font-style: normal;
  font-weight: 700;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  text-align: center;
  color: #5f5f5f;
  margin: 0 auto;
  padding: 50px 0 25px 0;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

#form-3 .error-c {
  position: absolute;
  display: block;
  font-size: 9px;
  text-transform: uppercase;
  color: #5f5f5f;
  margin: -13px 0 0 0;
  padding: 0;
  letter-spacing: 0.15em;
  font-weight: 700 !important;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  left: 0;
  right: 0;
  margin-left: auto;
  margin-right: auto;
  width: 200px !important;
}

.make-space {
  margin-left: 15px;
  margin-right: 15px;
}

::-webkit-input-placeholder {
  font-size: 12px;
  color: #111;
}

:-ms-input-placeholder {
  font-size: 12px;
  color: #111;
}

::-moz-placeholder {
  font-size: 12px;
  color: #111;
}

input:-moz-placeholder {
  font-size: 12px;
  color: #111;
}

input:focus::-webkit-input-placeholder {
  color: transparent;
}

input:focus:-ms-input-placeholder {
  color: transparent;
}

input:focus::-moz-placeholder {
  color: transparent;
}

input:focus:-moz-placeholder {
  color: transparent;
}

textarea:focus::-webkit-input-placeholder {
  color: transparent;
}

textarea:focus:-ms-input-placeholder {
  color: transparent;
}

textarea:focus::-moz-placeholder {
  color: transparent;
}

textarea:focus:-moz-placeholder {
  color: transparent;
}

button {
  border: none;
  background: none;
  outline: none;
  font-family: 'Satoshi-Bold', sans-serif;
  font-size: 10px;
  font-style: normal;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: normal;
  line-height: normal;
  margin: 0 auto;
  cursor: pointer;
}


/* blog panel */
.panel-from-left-blog {
  position: fixed;
  width: 25%;
  height: 100vh;
  overflow-x: hidden;
  overflow-y: auto;
  top: 0;
  left: -100%;
  background: #fff;
  -webkit-transition: all .8s ease-in-out;
  -moz-transition: all .8s ease-in-out;
  -ms-transition: all .8s ease-in-out;
  -o-transition: all .8s ease-in-out;
  transition: all .8s ease-in-out;
  opacity: 1;
  -moz-opacity: 1;
  -webkit-opacity: 1;
  filter: alpha(opacity=100);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
  z-index: 99996 !important;
}

@media only screen and (max-width: 1200px) {
  .panel-from-left-blog {
    width: 50%;
  }
}

@media only screen and (max-width: 880px) {
  .panel-from-left-blog {
    width: 75%;
  }
}

.panel-from-left-blog.open {
  left: 0;
}

.panel-overlay-from-right-blog {
  position: fixed;
  width: 76%;
  height: 100vh;
  overflow: hidden;
  top: 0;
  right: -100%;
  background: rgba(255, 255, 255, .7);
  -webkit-transition: all .8s ease-in-out;
  -moz-transition: all .8s ease-in-out;
  -ms-transition: all .8s ease-in-out;
  -o-transition: all .8s ease-in-out;
  transition: all .8s ease-in-out;
  opacity: 0;
  -moz-opacity: 0;
  -webkit-opacity: 0;
  filter: alpha(opacity=0);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  cursor: crosshair;
  z-index: 99996 !important;
}

@media only screen and (max-width: 1200px) {
  .panel-overlay-from-right-blog {
    width: 51%;
  }
}

@media only screen and (max-width: 880px) {
  .panel-overlay-from-right-blog {
    width: 26%;
  }
}

.panel-overlay-from-right-blog.open {
  right: 0;
  opacity: 1;
  -moz-opacity: 1;
  -webkit-opacity: 1;
  filter: alpha(opacity=100);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
}

.blog-sidebar-wrapper {
  position: relative;
  margin: 0;
  padding: 100px 50px;
}

.blog-side-text a,
.blog-side-text a:hover,
.blog-side-text a:visited,
.blog-side-text a:active,
.blog-side-text a:focus {
  color: #5f5f5f;
  text-decoration: none;
  outline: none;
  font-weight: 600;
  -webkit-transition: all 0.5s linear;
  -moz-transition: all 0.5s linear;
  -ms-transition: all 0.5s linear;
  -o-transition: all 0.5s linear;
  transition: all 0.5s linear;
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}

.blog-side-text a:hover {
  color: #5f5f5f;
}

@media only screen and (max-width: 880px) {

  .blog-side-text a,
  .blog-side-text a:hover,
  .blog-side-text a:visited,
  .blog-side-text a:active,
  .blog-side-text a:focus {
    font-size: 14px;
  }
}

.blog-side-heading h3 {
  font-family: 'Satoshi-Bold', sans-serif;
  font-style: normal;
  font-weight: 700;
  font-size: 25px;
  text-align: left;
  text-transform: none;
  letter-spacing: -0.00em;
  color: #9e1812;
  margin: -5px 0 -2px 0;
  width: 100%;
  line-height: 1.8;
  text-shadow: none;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

@media only screen and (max-width: 880px) {
  .blog-side-heading h3 {
    font-size: 80px;
    margin: -5px 0 -2px 0;
  }
}

.blog-side-launcher {
  position: fixed;
  width: 50px;
  height: 50px;
  line-height: 50px;
  left: 50px;
  bottom: 50px;
  font-size: 16px;
  text-align: center;
  color: #9e1812;
  background: #fff;
  -webkit-border-radius: 50%;
  -moz-border-radius: 50%;
  -ms-border-radius: 50%;
  -o-border-radius: 50%;
  border-radius: 50%;
  -webkit-transition: all 1.5s ease;
  -moz-transition: all 1.5s ease;
  -ms-transition: all 1.5s ease;
  -o-transition: all 1.5s ease;
  transition: all 1.5s ease;
  cursor: pointer;
  z-index: 115;
}

@media only screen and (max-width: 768px) {
  .blog-side-launcher {
    left: 20px;
    bottom: 20px;
  }
}

.blog-side-launcher.blog-side-launcher-color {
  color: #fff;
  background: #111;
}


/* blog comments */
.blog-comments {
  width: 100%;
  margin: 0 auto;
  padding: 0;
  line-height: 1;
}

.comments {
  text-align: left;
}

.comments article {
  position: relative;
  margin: 0 auto;
}

.profile-photo {
  position: relative;
  display: block;
  text-align: left;
  margin: -8px 0 -22px 0;
  z-index: 10;
}

.comments article img {
  width: 80px;
  height: 80px;
  border-width: 0;
  -webkit-border-radius: 50%;
  -moz-border-radius: 50%;
  -ms-border-radius: 50%;
  -o-border-radius: 50%;
  border-radius: 50%;
  margin: 15px auto 30px auto;
}

.comment-time,
.comments a,
.comments a:hover,
.comments a:visited,
.comments a:active,
.comments a:focus,
.comment-responce h4 a,
.comment-responce h4 a:hover,
.comment-responce h4 a:visited,
.comment-responce h4 a:active,
.comment-responce h4 a:focus {
  color: #111 !important;
  font-size: 14px;
  text-transform: uppercase;
  font-weight: 700;
}

h4.h4-comments {
  font-size: 20px;
  color: #111 !important;
}

@media only screen and (max-width: 1200px) {
  h4.h4-comments {
    font-size: 20px;
  }
}

.comment-responce {
  padding-left: 75px;
}


/* blog search form */
.blog-search {
  width: 300px;
}

@media only screen and (max-width: 1200px) {
  .blog-search {
    width: 300px;
  }
}

@media only screen and (max-width: 880px) {
  .blog-search {
    width: 250px;
  }
}

.blog-search input,
#submit-btn {
  background: none;
  display: inline-block;
  outline: none;
  border: none;
  -webkit-border-radius: 0;
  -moz-border-radius: 0;
  -ms-border-radius: 0;
  -o-border-radius: 0;
  border-radius: 0;
  color: #111;
}

.blog-search input {
  width: 250px;
  height: 40px;
  line-height: 40px;
  border-bottom: 1px solid rgba(0, 0, 0, .5);
  font-size: 13px;
  color: #111;
  z-index: 1;
}

@media only screen and (max-width: 1200px) {
  .blog-search input {
    width: 250px;
  }
}

@media only screen and (max-width: 880px) {
  .blog-search input {
    width: 200px;
  }
}


/* reservation form FIX */
/* reservation */
@media only screen and (max-width: 880px) {
  .reservation-wrapper {
    position: relative;
    bottom: auto;
    padding: 50px 0;
    background: #f7f7f7;
    display: block;
    visibility: visible;
  }
}

@media only screen and (max-width: 768px) {
  .reservation-wrapper {
    padding: 20px 0;
  }
}


/* form */
.col-1.c-1,
.col-1.c-2 {
  margin-bottom: 0 !important;
}

@media only screen and (max-width: 1200px) {

  .col-1.c-1,
  .col-1.c-2 {
    margin-bottom: 20px !important;
  }
}

@media only screen and (max-width: 880px) {

  .col-1.c-1,
  .col-1.c-2 {
    margin-bottom: 20px !important;
  }
}

.col-2.c-3,
.col-2.c-4,
.col-2.c-5 {
  margin-bottom: 0 !important;
}

@media only screen and (max-width: 1200px) {

  .col-2.c-3,
  .col-2.c-4,
  .col-2.c-5 {
    margin-bottom: 20px !important;
  }
}

@media only screen and (max-width: 880px) {

  .col-2.c-3,
  .col-2.c-4,
  .col-2.c-5 {
    margin-bottom: 20px !important;
  }
}


/* reservation form */
#form-2 .error-r {
  margin: 2px 0 0 0;
}

@media only screen and (max-width: 1200px) {
  #form-2 .error-r {
    margin: -1px 0 0 0;
  }
}


/* copyright */
.copyright a,
.copyright a:hover,
.copyright a:visited,
.copyright a:active,
.copyright a:focus {
  color: #5f5f5f;
}


/* 42. section txt */
.section-txt p:last-child {
  padding-top: 25px;
}

.section-txt-2 p,
.section-txt-2 a,
.section-txt-2 a:hover,
.section-txt-2 a:visited,
.section-txt-2 a:active,
.section-txt-2 a:focus {
  text-align: center !important;
  color: #5f5f5f;
}


/* 43. button home */
.more-wraper-inner-home {
  width: 120px !important;
  height: 220px !important;
}

.more-wraper-center.more-wraper-center-home {
  width: 120px !important;
  height: 220px !important;
  text-align: center !important;
  left: auto;
  margin: 0 auto;
}

.more-wraper-center.more-wraper-center-home {
  /* margin: -30px auto 0 auto; */
  margin: -80px auto 0 auto;
}

.more-button-txt-center.more-button-txt-center-home {
  top: 110px;
}

.more-button-txt-center.more-button-txt-center-form {
  top: 105px;
}


/* button home effect */
a.button-effect,
.button-effect {
  padding: 0;
  background-color: transparent;
  cursor: pointer;
  overflow: visible;
}

@-webkit-keyframes pulse {
  0% {
    -webkit-transform: scale(0);
    transform: scale(0);
    opacity: 0
  }

  50% {
    -webkit-transform: scale(1);
    transform: scale(1);
    opacity: .2;
    opacity: .4;
  }

  to {
    -webkit-transform: scale(2);
    transform: scale(2);
    opacity: 0
  }
}

@keyframes pulse {
  0% {
    -webkit-transform: scale(0);
    transform: scale(0);
    opacity: 0
  }

  50% {
    -webkit-transform: scale(1);
    transform: scale(1);
    opacity: .2;
    opacity: .4;
  }

  to {
    -webkit-transform: scale(2);
    transform: scale(2);
    opacity: 0
  }
}

a.button-effect .pulse::after,
a.button-effect .pulse::before,
a.button-effect::after,
a.button-effect::before,
.button-effect .pulse::after,
.button-effect .pulse::before,
.button-effect::after,
.button-effect::before {
  content: "";
  position: absolute;
  width: 80px;
  height: 80px;
  top: -webkit-calc(50% - 40px);
  top: -moz-calc(50% - 40px);
  top: calc(50% - 40px);
  left: -webkit-calc(50% - 40px);
  left: -moz-calc(50% - 40px);
  left: calc(50% - 40px);
  right: auto;
  bottom: auto;
  -webkit-transform: none;
  transform: none;
  -webkit-transform-origin: center center;
  transform-origin: center center;
  -webkit-animation: pulse 4s linear infinite;
  animation: pulse 4s linear infinite;
  -webkit-pointer-events: none;
  -moz-pointer-events: none;
  pointer-events: none;
  opacity: 0;
  -moz-opacity: 0;
  -webkit-opacity: 0;
  filter: alpha(opacity=0);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  border: 1px solid #fff;
  border-radius: 50%;
  background-color: transparent;
}

a.button-effect::after,
.button-effect::after {
  -webkit-animation-delay: 1s;
  animation-delay: 1s;
}

a.button-effect .pulse::after,
.button-effect .pulse::after {
  -webkit-animation-delay: 3s;
  animation-delay: 3s;
}

a.button-effect .pulse::before,
.button-effect .pulse::before {
  -webkit-animation-delay: 2s;
  animation-delay: 2s;
}


/* 44. stars */
.star-wrapper {
  position: relative;
  display: inline-block;
  width: 100% !important;
  max-width: 100%;
  height: auto;
  left: 0;
  right: 0;
  margin-left: auto;
  margin-right: auto;
  text-align: center !important;
  color: #f3bf3d;
  font-size: 25px;
  z-index: 1;
}


/* 45. section heading */
h2.section-heading {
  position: relative;
  font-family: 'Satoshi-Bold', sans-serif;
  font-size: 14px;
  color: #5f5f5f;
  font-style: normal;
  font-weight: 800;
  text-transform: uppercase;
  text-align: center;
  letter-spacing: -0.02em;
  padding: 0;
  margin: 2px 0 0 0;
  z-index: 10;
}

h2.section-heading.section-heading-light {
  color: #fff;
}

h2.section-heading span {
  position: relative;
  display: inline-block;
  padding-right: 90px;
  margin-right: 30px;
  line-height: 1;
}

.hero-section-heading {
  position: relative;
  z-index: 2;

  margin: 18px auto 18px auto;

  text-align: center;

  font-family: 'Satoshi-Regular', sans-serif;
  font-size: 14px;
  font-weight: 400;
  letter-spacing: 0.22em;
  text-transform: uppercase;

  color: rgba(255, 255, 255, .78);
}

.copyrightpicture {
  color: #999;
  /* Helle Graufarbe */
  font-size: 10px;
  /* Schriftgröße */
  font-style: italic;
  /* Kursiv */
}

@media all and (min-width: 1920px) {
  h2.section-heading span {
    padding-right: 105px;
    margin-right: 35px;
  }
}

@media only screen and (max-width: 995px) {
  h2.section-heading span {
    padding-right: 75px;
    margin-right: 25px;
  }
}

@media only screen and (max-width: 768px) {
  h2.section-heading span {
    padding-right: 60px;
    margin-right: 20px;
  }
}

h2.section-heading span:before {
  content: "";
  position: absolute;
  display: block;
  top: 50%;
  right: 0;
  width: 60px;
  height: 0;
  margin-top: -1px;
}

@media all and (min-width: 1920px) {
  h2.section-heading span:before {
    width: 70px;
  }
}

@media only screen and (max-width: 995px) {
  h2.section-heading span:before {
    width: 50px;
  }
}

@media only screen and (max-width: 768px) {
  h2.section-heading span:before {
    width: 40px;
  }
}

h2.section-heading span:before {
  border-top: 1px solid #5f5f5f;
}

h2.section-heading-light span:before {
  border-top: 1px solid #fff;
}

h2.section-heading.section-heading-all {
  padding: 0;
}


h2.section-heading span:after {
  content: "";
  position: absolute;
  display: block;
  top: 50%;
  right: 0;
  width: 60px;
  height: 0;
  margin-top: -1px;
}

@media all and (min-width: 1920px) {
  h2.section-heading span:after {
    width: 70px;
  }
}


/* 46. parallax title content */
.parallax-title-content {
  position: relative;
  font-family: 'Satoshi-Bold', sans-serif;
  font-weight: 25;
  font-size: 25px;
  text-align: center;
  text-transform: uppercase;
  line-height: 1.8;
  letter-spacing: -0.08em;
  color: #2e2e2e;
  background: #fff;
  mix-blend-mode: lighten;
  overflow: hidden;
  margin: -20px auto -6px auto;
}

.parallax-title-content.parallax-title-content-dark {
  color: #fff;
  background: #000;
  mix-blend-mode: darken;
}

@media all and (min-width: 1920px) {
  .parallax-title-content {
    font-size: 60px;
    margin: -26px auto -6px auto;
  }
}

@media only screen and (max-width: 1200px) {
  .parallax-title-content {
    font-size: 50px;
    margin: -12px auto -3px auto;
  }
}

@media only screen and (max-width: 1024px) {
  .parallax-title-content {
    font-size: 40px;
    margin: -9px auto -2px auto;
    letter-spacing: -0.04em;
  }
}

@media only screen and (max-width: 995px) {
  .parallax-title-content {
    letter-spacing: -0.04em;
  }
}

@media only screen and (max-width: 880px) {
  .parallax-title-content {
    font-size: 40px;
    margin: -9px auto -2px auto;
  }
}

@media only screen and (max-width: 640px) {
  .parallax-title-content {
    font-size: 30px;
    margin: -7px auto 0 auto;
  }
}

.parallax-title {
  position: relative;
  background-repeat: no-repeat;
  background-position: center center;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -ms-background-size: cover;
  -o-background-size: cover;
  background-size: cover;
  border: none;
  z-index: 1;
}


/* 47. image caption */
.image-caption,
.image-caption-reverse {
  position: absolute;
  color: #fff;
  font-weight: 600;
  font-size: 13px;
  padding: 10px 20px;
  background: rgba(158, 24, 18, .7);
  -webkit-border-radius: 0 20px 0 20px;
  -moz-border-radius: 0 20px 0 20px;
  -ms-border-radius: 0 20px 0 20px;
  -o-border-radius: 0 20px 0 20px;
  border-radius: 0 20px 0 20px;
  z-index: 5;
}

.image-caption {
  right: 50px;
  bottom: 50px;
}

@media only screen and (max-width: 768px) {
  .image-caption {
    right: 20px;
    bottom: 20px;
  }
}

.image-caption-reverse {
  left: 50px;
  bottom: 50px;
}

@media only screen and (max-width: 768px) {
  .image-caption-reverse {
    left: 20px;
    bottom: 20px;
  }
}


/* 48. post list */
.post-list .post-list-wrapper {
  margin: -40px 0 0 0;
  padding: 0 0 150px 0;
}

@media only screen and (max-width: 1200px) {
  .post-list .post-list-wrapper {
    margin: -130px 0 0 0;
    padding: 0 0 60px 0;
  }
}

@media only screen and (max-width: 995px) {
  .post-list .post-list-wrapper {
    margin: -60px 0 0 0;
    padding: 0;
  }
}

.post-list .post-list-item {
  position: relative;
}

@media only screen and (max-width: 995px) {
  .post-list .post-list-item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse;
  }
}

.post-list .post-list-item:not(:first-of-type) {
  margin-top: 460px;
}

@media only screen and (max-width: 1200px) {
  .post-list .post-list-item:not(:first-of-type) {
    margin-top: 200px;
  }
}

@media only screen and (max-width: 995px) {
  .post-list .post-list-item:not(:first-of-type) {
    margin-top: 0;
  }
}

.post-list .post-list-item:nth-of-type(odd) .post-list-bg {
  left: 0;
}

.post-list .post-list-item:nth-of-type(odd) .post-list-bg.post-list-bg-all {
  left: auto;
  right: 0;
}

.post-list .post-list-item:nth-of-type(even) .post-list-bg {
  right: 0;
}

.post-list .post-list-item-container {
  max-width: 100%;
  -webkit-box-flex: 0;
  -ms-flex: 0 0 100%;
  flex: 0 0 100%;
}

.post-list .post-list-row {
  position: relative;
  z-index: 4;
}

.post-list .post-list-content {
  padding: 150px 150px;
  background: #fff;
  -webkit-border-radius: 50px 0 0 50px;
  -moz-border-radius: 50px 0 0 50px;
  -ms-border-radius: 50px 0 0 50px;
  -o-border-radius: 50px 0 0 50px;
  border-radius: 50px 0 0 50px;
}

@media only screen and (max-width: 1200px) {
  .post-list .post-list-content {
    padding: 50px 80px;
  }
}

@media only screen and (max-width: 995px) {
  .post-list .post-list-content {
    padding: 0 95px;
    margin: 0 auto;
  }
}

@media only screen and (max-width: 995px) {
  .post-list .post-list-content {
    -webkit-border-radius: 0;
    -moz-border-radius: 0;
    -ms-border-radius: 0;
    -o-border-radius: 0;
    border-radius: 0;
  }
}

@media only screen and (max-width: 880px) {
  .post-list .post-list-content {
    padding: 0 50px;
  }
}

@media only screen and (max-width: 768px) {
  .post-list .post-list-content {
    padding: 0 25px;
  }
}

.post-list .post-list-content.post-list-content-reverse {
  -webkit-border-radius: 0 50px 50px 0;
  -moz-border-radius: 0 50px 50px 0;
  -ms-border-radius: 0 50px 50px 0;
  -o-border-radius: 0 50px 50px 0;
  border-radius: 0 50px 50px 0;
}

@media only screen and (max-width: 995px) {
  .post-list .post-list-content.post-list-content-reverse {
    -webkit-border-radius: 0;
    -moz-border-radius: 0;
    -ms-border-radius: 0;
    -o-border-radius: 0;
    border-radius: 0;
  }
}

.post-list .post-list-bg {
  position: absolute;
  width: calc(50% + 150px);
  height: calc(100% + 300px);
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
  overflow: hidden;
  -webkit-border-radius: 0 50px 50px 0;
  -moz-border-radius: 0 50px 50px 0;
  -ms-border-radius: 0 50px 50px 0;
  -o-border-radius: 0 50px 50px 0;
  border-radius: 0 50px 50px 0;
  z-index: 3;
}

@media only screen and (max-width: 1200px) {
  .post-list .post-list-bg {
    width: calc(50% + 130px);
    height: calc(100% + 120px);
  }
}

@media only screen and (max-width: 995px) {
  .post-list .post-list-bg {
    position: relative;
    width: 100%;
    max-width: 100%;
    height: auto;
    min-height: 580px;
    -webkit-transform: none;
    transform: none;
    padding-top: 50%;
    -webkit-box-flex: 0;
    -ms-flex: 0 0 100%;
    flex: 0 0 100%;
  }
}


@media only screen and (max-width: 995px) {
  .post-list .post-list-bg {
    -webkit-border-radius: 0;
    -moz-border-radius: 0;
    -ms-border-radius: 0;
    -o-border-radius: 0;
    border-radius: 0;
  }
}

.post-list .post-list-bg.post-list-bg-reverse {
  -webkit-border-radius: 50px 0 0 50px;
  -moz-border-radius: 50px 0 0 50px;
  -ms-border-radius: 50px 0 0 50px;
  -o-border-radius: 50px 0 0 50px;
  border-radius: 50px 0 0 50px;
}

@media only screen and (max-width: 995px) {
  .post-list .post-list-bg.post-list-bg-reverse {
    -webkit-border-radius: 0;
    -moz-border-radius: 0;
    -ms-border-radius: 0;
    -o-border-radius: 0;
    border-radius: 0;
  }
}

.post-list-content-wrapper {
  padding-top: 190px;
  margin-top: -1px;
}

@media only screen and (max-width: 995px) {
  .post-list-content-wrapper {
    padding-top: 60px
  }
}

.container-custom {
  width: 100%;
  padding-left: 0;
  padding-right: 0;
  margin-right: auto;
  margin-left: auto;
}

@media only screen and (max-width: 995px) {
  .container-custom {
    padding: 0;
  }
}

.col-md-6-custom {
  position: relative;
  width: 100%;
  min-height: 1px;
  padding-left: 0;
  padding-right: 0;
}

@media only screen and (max-width: 995px) {
  .col-md-6-custom {
    padding-right: 15px;
    padding-left: 15px;
  }
}

@media only screen and (min-width: 995px) {
  .col-lg-4-custom {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 50%;
    flex: 0 0 50%;
    max-width: 50%;
  }

  .offset-lg-1-custom {
    margin-left: 0;
  }

  .offset-lg-7-custom {
    margin-left: 50%;
  }
}


/* 49. inner spacer */
.inner-spacer {
  position: relative;
  margin: 0 auto;
  padding: 0;
}

@media all and (min-width: 1920px) {
  .inner-spacer {
    padding: 0;
  }
}

@media only screen and (max-width: 1200px) {
  .inner-spacer {
    width: 100%;
    padding: 0 50px;
  }
}

@media only screen and (max-width: 995px) {
  .inner-spacer {
    padding: 0 50px;
  }
}

@media only screen and (max-width: 880px) {
  .inner-spacer {
    padding: 0 50px;
  }
}

@media only screen and (max-width: 768px) {
  .inner-spacer {
    padding: 0 20px;
  }
}


/* 50. divider */
.divider-s,
.divider-m,
.divider-m-2,
.divider-l,
.divider-xl {
  position: relative;
  width: 100%;
  margin: 0 auto;
  background: none;
  z-index: -1;
}

.divider-s {
  height: 25px;
}

.divider-m {
  height: 50px;
}

.divider-m-2 {
  height: 40px;
}

@media only screen and (max-width: 880px) {
  .divider-m-2 {
    height: 15px;
  }
}

.divider-l {
  height: 100px;
}

.divider-xl {
  height: 200px;
}

@media only screen and (max-width: 880px) {
  .divider-xl {
    height: 100px;
  }
}

.visible-mobile-devices,
.visible-mobile-devices-2 {
  display: none;
  visibility: hidden;
}

@media only screen and (max-width: 995px) {
  .visible-mobile-devices {
    display: block;
    visibility: visible;
  }
}

@media only screen and (max-width: 1200px) {
  .visible-mobile-devices-2 {
    display: block;
    visibility: visible;
  }
}

@media only screen and (max-width: 880px) {
  .visible-mobile-devices-2 {
    display: none;
    visibility: hidden;
  }
}

.hidden-mobile-devices {
  display: block;
  visibility: visible;
}

@media only screen and (max-width: 995px) {
  .hidden-mobile-devices {
    display: none;
    visibility: hidden;
  }
}

@media only screen and (max-width: 880px) {
  .hidden-mobile-devices {
    display: block;
    visibility: visible;
  }
}

h6 {
  display: none;
  visibility: hidden;
}

.social-icon-container {
  position: fixed;
  left: 0;
  z-index: 50;
}

.social-icon {
  width: 40px;
  height: 40px;
  max-width: 40px;
  max-height: 40px;
  margin-right: 10px;
  vertical-align: middle;
}

/* divider */
.divider-xl {
  height: 130px;
}

@media all and (min-width: 1920px) {
  .divider-xl {
    height: 140px;
  }
}

@media only screen and (max-width: 995px) {
  .divider-xl {
    height: 120px;
  }
}

.divider-xl.divider-xl-2 {
  height: 170px;
}

@media all and (min-width: 1920px) {
  .divider-xl.divider-xl-2 {
    height: 185px;
  }
}

@media only screen and (max-width: 995px) {
  .divider-xl.divider-xl-2 {
    height: 155px;
  }
}

.divider-l {
  height: 80px;
}

@media all and (min-width: 1920px) {
  .divider-l {
    height: 90px;
  }
}

@media only screen and (max-width: 995px) {
  .divider-l {
    height: 70px;
  }
}

.divider-l-2 {
  height: 71px;
}

@media all and (min-width: 1920px) {
  .divider-l-2 {
    height: 31px;
  }
}

@media only screen and (max-width: 995px) {
  .divider-l-2 {
    height: 71px;
  }
}

.gallery {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-gap: 20px;
}

.gallery-item {
  text-align: center;
}

.gallery-item img {
  max-width: 100%;
  height: auto;
  border-radius: 8px;
}

.gallery-item p {
  margin-top: 5px;
  font-family: 'Satoshi-Bold', sans-serif;
  font-size: 15px;
  color: #9c9c9c;
  text-align: center;
}

/* Stil für mobile Geräte */
@media only screen and (max-width: 600px) {
  .gallery {
    grid-template-columns: repeat(2, 1fr);
    grid-gap: 10px;
  }

  .gallery-item p {
    font-size: 12px;
    /* Verringerte Schriftgröße für mobile Geräte */
  }
}

.payment-options {
  display: flex;
  justify-content: center;
  gap: 20px;
  flex-wrap: wrap;
}

.payment-method {
  display: flex;
  align-items: center;
  font-size: 18px;
  gap: 8px;
  padding: 5px 10px;
  background: #f9f9f9;
  border-radius: 8px;
}

.payment-method i {
  color: #333;
  /* Standardfarbe */
}

/* Icons individuell anpassen */
.payment-method:nth-child(1) i {
  font-size: 30px;
}

/* PayPal */
.payment-method:nth-child(2) i {
  font-size: 25px;
}

/* Rechnung */
.payment-method:nth-child(3) i {
  font-size: 35px;
}

/* Visa */
.payment-method:nth-child(4) i {
  font-size: 28px;
}

/* Mastercard */
.payment-method:nth-child(5) i {
  font-size: 32px;
}

/* Alipay */
.payment-method:nth-child(6) i {
  font-size: 26px;
}

/* SEPA */

.eu-foerderung {
  background: #fff;
  padding: 40px 20px;
  border-top: 1px solid #eee;
}

.eu-foerderung .eu-box {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 30px;
  max-width: 700px;
  margin: 0 auto;
  text-decoration: none;
}

.eu-foerderung img {
  width: 240px;
  height: auto;
}

.eu-foerderung .eu-text {
  text-align: left;
}

.eu-foerderung strong {
  display: block;
  font-size: 16px;
  color: #111;
}

.eu-foerderung span {
  font-size: 13px;
  color: #666;
}

.eu-foerderung em {
  display: block;
  margin-top: 6px;
  font-style: normal;
  font-size: 13px;
  color: #591b20;
}

/* Mobile */
@media (max-width: 768px) {
  .eu-foerderung .eu-box {
    flex-direction: column;
    text-align: center;
  }

  .eu-foerderung .eu-text {
    text-align: center;
  }
}

.certificate-strip {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 40px;
  padding: 40px 20px;
  background: #f5f5f5;
}

.certificate-item {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 80px;
}

.certificate-item img {
  max-height: 100%;
  max-width: 160px;
  object-fit: contain;
  filter: grayscale(10%);
  opacity: 0.9;
  transition: all 0.3s ease;
}

.certificate-item img:hover {
  filter: none;
  opacity: 1;
  transform: scale(1.05);
}

/* Mobile Sticky Booking Bar */
#mobile-sticky-booking {
  display: none;
}

@media only screen and (max-width:768px) {

  #mobile-sticky-booking {
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 58px;

    display: flex;
    align-items: center;
    justify-content: space-between;

    background: #ffffff;
    box-shadow: 0 -4px 18px rgba(0, 0, 0, 0.18);

    z-index: 999999;
  }

  #mobile-sticky-booking a {
    flex: 1;
    height: 58px;

    display: flex;
    align-items: center;
    justify-content: center;

    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;

    color: #591b20;
    text-decoration: none;

    border-right: 1px solid rgba(0, 0, 0, 0.08);
  }

  #mobile-sticky-booking a:last-child {
    border-right: none;
  }

  #mobile-sticky-booking .booking-main {
    background: #9e1812;
    color: #fff;
    font-size: 13px;
  }

  body {
    padding-bottom: 58px;
  }

  .to-top-arrow {
    bottom: 75px !important;
  }
}

#mobile-sticky-booking a span {
  font-size: 35px;
  line-height: 1;
}

#mobile-sticky-booking .booking-main {
  font-size: 13px;
}

/* === PageSpeed / Mobile Optimierung === */

img {
  max-width: 100%;
  height: auto;
}

@media only screen and (max-width: 768px) {

  .navbar-bg-switch,
  .main-navigation-bg {
    min-height: 81px;
  }

  .upper-page {
    height: 100svh;
    min-height: 620px;
  }

  .hero-fullscreen,
  .hero-fullscreen-FIX,
  .hero-bg {
    height: 100%;
    min-height: 620px;
  }

  .divider-xl {
    height: 80px;
  }

  .divider-xl.divider-xl-2 {
    height: 90px;
  }

  .divider-l {
    height: 50px;
  }

  .divider-m {
    height: 35px;
  }

  .star-wrapper {
    font-size: 18px;
    line-height: 22px;
    height: 22px;
    overflow: hidden;
  }

  .to-top-arrow.show {
    bottom: 70px;
  }
}

.logo,
.navbar-bg-switch,
.main-navigation-bg,
.navbar-toggle {
  transition-property: opacity, background-color, box-shadow, transform;
}

.hero-bg,
.hero-bg-FIX {
  transform: scale(1.08);
}

}

@media only screen and (max-width: 768px) {

  .upper-page {
    min-height: 100svh;
    height: 100svh;
  }

  .hero-fullscreen,
  .hero-fullscreen-FIX,
  .hero-bg,
  .swiper-container,
  .swiper-slide,
  .swiper-slide-inner,
  .swiper-slide-inner-bg {
    min-height: 100svh;
    height: 100svh;
  }

}

@media only screen and (max-width: 768px) {

  .navbar-header {
    width: 100%;
    position: relative;
  }

}

.hero-stars {
  position: relative;
  z-index: 2;
  text-align: center;
  color: #f3bf3d;
  font-size: 28px;
  letter-spacing: 2px;
  margin-bottom: 18px;
  line-height: 1;
}

.hero-benefits {
  position: relative;
  z-index: 2;
  display: flex;
  justify-content: center;
  gap: 18px;
  flex-wrap: wrap;
  margin: 24px auto 28px auto;
}

.hero-benefits>span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 18px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.2);
  color: #fff;
  font-family: 'Satoshi-Regular', sans-serif;
  font-size: 14px;
  font-weight: 300;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  -webkit-backdrop-filter: blur(5px);
  backdrop-filter: blur(5px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, .14);
}

.hero-benefits-subtext {
  position: absolute;
  bottom: -20px;
  left: 50%;
  transform: translateX(-50%);
  font-size: 10px;
  color: rgba(255, 255, 255, 0.6);
  font-family: 'Satoshi-Regular', sans-serif;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  white-space: nowrap;
  pointer-events: none;
  display: block;
}

@media only screen and (max-width: 768px) {

  .hero-stars {
    font-size: 17px;
    letter-spacing: 2px;
    margin-bottom: 18px;
  }

  .hero-benefits {
    gap: 8px;
    margin: 20px auto 22px auto;
    padding: 0 18px;
  }

  .hero-benefits>span {
    font-size: 10px;
    padding: 8px 12px;
  }

  .hero-benefits-subtext {
    bottom: -20px;
    font-size: 8px;
  }

}

/* =========================
   BOOKING BUTTON NAVIGATION
   ========================= */

.nav-booking-item {
  height: 80px !important;
  display: flex !important;
  align-items: center !important;
}

.nav-booking-btn {
  position: relative;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  height: 42px !important;
  min-width: 150px;
  padding: 0 26px !important;
  margin: 0 40px 0 10px !important;
  border-radius: 999px;
  background: #a51610;
  color: #ffffff !important;
  font-family: 'Satoshi-Bold', sans-serif;
  font-size: 13px !important;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  line-height: 1.8 !important;
  border: 1px solid transparent;
  box-shadow:
    0 10px 24px rgba(165,22,16,.20),
    0 4px 12px rgba(0,0,0,.10);
  overflow: hidden;
  transition:
    transform .35s ease,
    box-shadow .35s ease,
    background .35s ease,
    color .35s ease,
    border-color .35s ease;
}

/* Hover */
.nav-booking-btn:hover,
.nav-booking-btn:focus {
  background: #b71b14 !important;
  color: #ffffff !important;
  transform: translateY(-3px) scale(1.02);
  box-shadow:
    0 18px 34px rgba(165,22,16,.28),
    0 8px 18px rgba(0,0,0,.12);
  border-color: transparent !important;
}

/* Klick */
.nav-booking-btn:active {
  transform: translateY(-1px) scale(.99);
}

/* Glanz-Effekt */
.nav-booking-btn::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: linear-gradient(
    120deg,
    rgba(255,255,255,0) 0%,
    rgba(255,255,255,.18) 50%,
    rgba(255,255,255,0) 100%
  );

  opacity: 0;
  transition: opacity .35s ease;
  pointer-events: none;
}

.nav-booking-btn:hover::after,
.nav-booking-btn:focus::after {
  opacity: 1;
}

.main-navigation-bg .nav-booking-item {
  height: 80px !important;
}

.main-navigation-bg .nav-booking-btn {
  height: 42px !important;
  min-width: 150px;
  margin: 0 40px 0 10px !important;
  font-size: 13px !important;
}

/* Mobile */
@media only screen and (max-width: 768px) {
  .nav-booking-item {
    display: none !important;
  }
}
/* =========================
   SECURITY TOPBAR
   ========================= */

.security-topbar {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  min-height: 30px;
  background: rgba(248, 248, 248, .96);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid rgba(0, 0, 0, .06);
  z-index: 99999;
  transition: transform .45s ease, opacity .35s ease;
}

.security-topbar.hide-bar {
  transform: translateY(-100%);
  opacity: 0;
}

.security-topbar-inner {
  min-height: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 4px 18px;
  font-family: 'Satoshi-Regular', sans-serif;
  font-size: 11px;
  color: #666;
  flex-wrap: wrap;
}

.security-topbar-icon {
  color: #2f8fff;
  font-size: 11px;
}

.security-topbar-text {
  line-height: 1.3;
}

.security-topbar-link {
  color: #9e1812 !important;
  text-decoration: underline;
  color: #666 !important;
}

.security-topbar-link:hover,
.security-topbar-link:focus,
.security-topbar-link:active {
  color: #9e1812 !important;
}

.navbar {
  top: 30px !important;
  transition: top .45s ease;
}

body.security-scrolled .navbar {
  top: 0 !important;
}

/* Navbar nur vertikal sauber ausrichten */
.navbar {
  top: 30px !important;
  transition: top .45s ease;
}

body.security-scrolled .navbar {
  top: 0 !important;
}

/* Mobile */
@media only screen and (max-width: 768px) {
  .security-topbar-inner {
    justify-content: center;
    padding: 4px 12px;
    font-size: 10px;
    line-height: 1.25;
    text-align: center;
  }
}

/* =========================
   SECURITY POPUP
   ========================= */

.security-popup {
  position: fixed;
  top: 0;
  right: 0;
  width: 100%;
  max-width: 560px;
  height: 100vh;
  background: #fff;
  overflow-y: auto;
  transform: translateX(100%);
  transition: transform .55s cubic-bezier(.77, 0, .18, 1);
  z-index: 999999;
  box-shadow: -12px 0 45px rgba(0, 0, 0, .18);
}
.security-popup.active {
  transform: translateX(0);
}

.security-popup-inner {
  padding: 52px 52px 38px;
}

.security-popup-close {
  position: absolute;
  top: 18px;
  right: 24px;
  border: 0;
  background: none;
  font-size: 38px;
  line-height: 1;
  color: #999;
  cursor: pointer;
}

.booking-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background: rgba(0,0,0,0.4);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease;
  z-index: 999998;
}

.booking-overlay.active {
  opacity: 1;
  visibility: visible;
}

/* =========================
   HEADLINE
   ========================= */

.security-popup-topline {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  margin-bottom: 24px;
  font-family: 'Satoshi-Regular', sans-serif;
  font-size: 10px;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: #999;
}

.security-popup-topline span {
  width: 30px;
  height: 1px;
  background: #d8d8d8;
}

.security-popup-title {
  margin: 0;
  text-align: center;
  font-family: 'Satoshi-Bold', sans-serif;
  font-size: 30px;
  line-height: 1.8;
  letter-spacing: -0.03em;
  text-transform: uppercase;
  color: #666;
}

.security-important {
  margin: 0 0 24px;
  text-align: center;
  font-family: 'bellamy_signature', cursive;
  font-size: 100px;
  line-height: 1;
  color: #b41a14;
}

/* =========================
   TEXT
   ========================= */

.security-popup-text p {
  margin: 0 0 18px;
  font-family: 'Satoshi-Regular', sans-serif;
  font-size: 15px;
  font-weight: 300;
  line-height: 1.8;
  color: #666;
}

.security-popup-text strong {
  font-family: 'Satoshi-Regular', sans-serif;
  color: #5f5f5f;
}

/* =========================
   POINTS
   ========================= */

.security-points {
  margin-top: 30px;
}

.security-point {
  display: grid;
  grid-template-columns: 24px 1fr;
  gap: 18px;
  align-items: flex-start;
  margin-bottom: 26px;
}

.security-point-icon {
  color: #5a5a5a;
  font-size: 24px;
  line-height: 1;
  letter-spacing: 0;
  margin-top: 2px;
  vertical-align: middle;
}

.security-point-content h3 {
  display: block;
  font-family: 'Satoshi-Bold', sans-serif;
  text-align: left;
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 0.1em;
  margin-bottom: 5px;
  color: #5f5f5f;
}

.security-point-content p {
  margin: 0;
  font-family: 'Satoshi', sans-serif !important;
  font-size: 14px;
  font-weight: 300 !important;
  -webkit-font-smoothing: antialiased;
  letter-spacing: 0.05em;
  line-height: 2;
  color: #666;
}

/* =========================
   BUTTONS
   ========================= */

.security-popup-buttons {
  display: flex;
  gap: 20px;
  margin-top: 36px;
  padding-top: 28px;
  border-top: 1px solid rgba(0, 0, 0, .08);
}

.security-btn {
  flex: 1;
  height: 52px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-family: 'Satoshi-Bold', sans-serif;
  font-size: 12px;
  letter-spacing: .10em;
  text-transform: uppercase;
  text-decoration: none;
  cursor: pointer;
  transition: opacity .25s ease;
}

.security-btn i {
  font-size: 18px;
  line-height: 1;
}

.security-btn-light {
  border: 2px solid #b41a14;
  color: #b41a14;
  background: #fff;
}

.security-btn-red {
  border: 0;
  background: #b41a14;
  color: #fff;
}

.security-btn:hover {
  opacity: .86;
}

/* =========================
   MOBILE
   ========================= */

@media only screen and (max-width: 768px) {

  .security-popup {
    max-width: 100%;
    height: 100vh;
  }

  .security-popup-inner {
    padding: 44px 24px 28px;
  }

  .security-popup-close {
    top: 12px;
    right: 18px;
    font-size: 34px;
  }

  .security-popup-title {
    font-size: 26px;
    line-height: 1.8;
  }

  .security-important {
    font-size: 44px;
    margin-bottom: 20px;
  }

  .security-popup-text p {
    font-size: 14px;
    line-height: 1.8;
  }

  /* Security Points */
  .security-points {
    margin-top: 30px;
  }

  .security-point {
    display: grid;
    grid-template-columns: 22px 1fr;
    gap: 14px;
    align-items: flex-start;
    margin-bottom: 22px;
  }

  .security-point-icon {
    font-size: 20px;
    color: #5a5a5a;
    margin-top: 2px;
  }

  .security-point-content h3 {
    font-size: 12px;
    font-family: 'Satoshi-Bold', sans-serif;
    font-weight: 700;
    letter-spacing: 0.1em;
    margin-bottom: 5px;
    color: #5f5f5f;
    text-align: left;
  }

  .security-point-content p {
    font-size: 13px;
    line-height: 1.55;
    font-family: 'Satoshi', sans-serif;
    font-weight: 300;
    color: #666;
    margin: 0;
  }

  /* Buttons */
  .security-popup-buttons {
    gap: 12px;
    margin-top: 30px;
    padding-top: 22px;
  }

  .security-btn {
    height: 46px;
    font-size: 11px;
    padding: 0 12px;
  }

}

/* =========================
   HERO TEXT CONTAINER
   ========================= */

.swiper-slide-inner-txt-2 {
  padding-top: 200px;
}

@media only screen and (max-width: 768px) {
  .swiper-slide-inner-txt-2 {
    padding-top: 48px;
  }
}

/* =========================
   HERO MAIN
   ========================= */

.hero-heading-main {
  font-family: 'bellamy_signature';
  font-size: 130px;
  font-weight: normal;
  min-height: 140px;
  line-height: 1.2;
  text-align: center;
  color: #fff;
  margin: 0 0 30px 0;
}

@media only screen and (max-width: 1024px) {
  .hero-heading-main {
    font-size: 80px;
    min-height: 80px;
  }
}

@media only screen and (max-width: 768px) {
  .hero-heading-main {
    font-size: 80px;
    min-height: 80px;
  }
}

@media only screen and (max-width: 480px) {
  .hero-heading-main {
    font-size: 60px;
    min-height: 80px;
  }
}

/* =========================
   BESTPRICE OVERLAY
   ========================= */

.direct-booker-overlay {
  position: fixed;
  bottom: 120px;
  right: 20px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  display: flex;
  align-items: center;
  gap: 10px;
  z-index: 10000;
}

.direct-booker-overlay .overlay-content {
  display: flex;
  align-items: center;
  background: #fff;
  border-radius: 0.5rem;
  padding: 0.5rem 1rem;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15);
  cursor: pointer;
}

.direct-booker-overlay .overlay-icon img {
  width: 32px;
  height: 32px;
  margin-right: 0.5rem;
}

.direct-booker-overlay .overlay-text {
  display: flex;
  flex-direction: column;
  line-height: 1.2;
}

.direct-booker-overlay .overlay-text span {
  font-size: 0.75rem;
  color: #666;
  text-transform: uppercase;
}

.direct-booker-overlay .overlay-text strong {
  font-size: 0.875rem;
  font-weight: 700;
  color: #000;
}

@media (max-width: 767px) {
  .direct-booker-overlay {
    bottom: 160px;
    right: 15px;
  }

  .direct-booker-overlay .overlay-icon img {
    height: 32px;
  }

  .direct-booker-overlay .overlay-text strong {
    font-size: 13px;
  }
}

/* =========================
   BODY SCROLL LOCK
   ========================= */

body.popup-open {
  overflow: hidden;
  height: 100vh;
}
/* =========================
   TRUST BAR
   ========================= */

.trust-bar {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 44px;
  padding: 32px 20px 28px;
  background: #fff;
}

.trust-item {
  display: inline-flex;
  align-items: flex-start;
  gap: 10px;
  text-decoration: none;
}

.trust-item strong {
  font-family: 'Satoshi-Regular', sans-serif;
  font-size: 21px;
  font-weight: 300;
  line-height: 1;
  color: #666;
  letter-spacing: -0.04em;
}

.trust-item span {
  font-family: 'Satoshi-Regular', sans-serif;
  font-size: 10px;
  font-weight: 400;
  line-height: 1.45;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: #aaa;
}

.trust-item:hover {
  opacity: .65;
}

@media only screen and (max-width: 768px) {

  .trust-bar {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
    padding: 22px 14px 20px;
  }

  .trust-item {
    justify-content: center;
    align-items: center;
    gap: 6px;
  }

  .trust-item strong {
    font-size: 18px;
    line-height: 1;
  }

  .trust-item span {
    font-size: 9px;
    line-height: 1.25;
    letter-spacing: .05em;
  }

}
/* =========================
   About
========================= */

.sk-about {
  position: relative;
  background: #f3efee;
  padding: 0;
  margin: 0;
  overflow: hidden;
}

.sk-about + .sk-about {
  margin-top: 0;
}

.sk-about-inner {
  position: relative;
  height: 960px;
  margin: 0;
}

/* Bildfläche */
.sk-about-image {
  position: absolute;
  top: 0;
  bottom: 0;
  width: 62%;
  height: auto;
  z-index: 1;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  overflow: hidden;
}

/* Standard: Bild rechts */
.sk-about:not(.reverse) .sk-about-image {
  right: 0;
  border-radius: 42px 0 0 42px;
}

/* Reverse: Bild links */
.sk-about.reverse .sk-about-image {
  left: 0;
  right: auto;
  border-radius: 0 42px 42px 0;
}

/* Card */
.sk-about-card {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 3;
  width: 52%;
  min-height: 520px;
  padding: 54px 68px 48px;
  background: #fff;
  border-radius: 42px;
  text-align: center;
  box-shadow: 0 25px 60px rgba(0,0,0,.04);
}

/* Standard: Card links */
.sk-about:not(.reverse) .sk-about-card {
  left: 7.5%;
}

/* Reverse: Card rechts */
.sk-about.reverse .sk-about-card {
  right: 7.5%;
}

/* Titel */
.sk-editorial-title {
  position: relative;
  margin: 18px 0 44px;
  font-family: 'Satoshi-Bold', sans-serif;
  font-size: 52px;
  line-height: 1.5;
  font-weight: 800;
  text-transform: uppercase;
  color: #111;
  z-index: 2;
}

.sk-editorial-title span {
  position: absolute;
  left: 50%;
  top: 52%;
  transform: translate(-50%, -50%);
  width: 100%;
  font-family: 'bellamy_signature', cursive;
  font-size: 110px;
  line-height: 1;
  font-weight: 400;
  text-transform: none;
  text-align: center;
  white-space: nowrap;
  color: #9e1812;
  pointer-events: none;
  z-index: 1;
}

.sk-editorial-title em {
  display: block;
  margin: -6px 0 -2px;
  font-style: normal;
  font-size: 42px;
  line-height: 1;
  position: relative;
  z-index: 2;
}

.sk-editorial-title strong {
  position: relative;
  z-index: 1;
}

/* Text */
.sk-about-text {
  max-width: 720px;
  margin: 0 auto;
}

.sk-about-text p {
  font-size: 15px;
  color: #666;
  font-family: 'Satoshi', sans-serif !important;
  font-weight: 300 !important;
  -webkit-font-smoothing: antialiased;
  letter-spacing: 0.05em;
  line-height: 2
}

.sk-about-text p span {
  font-weight: 700 !important; /* bold */
  font-family: 'Satoshi-Bold', sans-serif !important;
}

/* Links */
.sk-about-links {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 30px;
  margin-top: 34px;
}

.sk-about-links a {
  display: inline-block;
  font-family: 'Satoshi-Bold', sans-serif;
  font-size: 14px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: #9e1812 !important;
}

/* Button */
.sk-about-button {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 280px;
  height: 54px;
  margin-top: 30px;
  border-radius: 999px;
  background: #9e1812;
  color: #fff !important;
  font-family: 'Satoshi-Bold', sans-serif;
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
  box-shadow: 0 18px 34px rgba(158,24,18,.20);
  transition:
    transform .35s ease,
    box-shadow .35s ease,
    background .35s ease;
}

.sk-about-button:hover {
  transform: translateY(-4px) scale(1.02);
  background: #b11c15;
  box-shadow:
    0 28px 50px rgba(158,24,18,.28),
    0 8px 18px rgba(0,0,0,.10);
}

.sk-about-button:active {
  transform: translateY(-1px) scale(.99);
}

.sk-about-button::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: linear-gradient(
    120deg,
    rgba(255,255,255,0) 0%,
    rgba(255,255,255,.18) 50%,
    rgba(255,255,255,0) 100%
  );

	opacity: 0;
  transition: opacity .35s ease;
}

.sk-about-button:hover::after {
  opacity: 1;
}

/* Direktbuchung */
.sk-about-benefits-link {
  display: block;
  margin-top: 12px;
  font-size: 14px;
  color: #666 !important;
  text-decoration: underline;
}

/* Kontakt */
.sk-about-contact {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 34px;
  margin-top: 26px;
}

.sk-about-contact a {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  color: #8a8a8a !important;
}

.sk-about-contact span {
  font-size: 18px;
  color: #5a5a5a;
  line-height: 1;
}

.sk-about-contact a:hover,
.sk-about-contact a:hover span {
  color: #9e1812 !important;
  transition: color 0.3s ease;
}

/* =========================
   Mobile
========================= */

@media only screen and (max-width: 1100px) {

  .sk-about-inner {
    height: auto;
  }

  .sk-about-image {
    position: relative;
    top: auto;
    bottom: auto;
    left: auto !important;
    right: auto !important;
    width: 100%;
    height: 520px;

    border-radius: 0 0 38px 38px !important;
  }

  .sk-about-card {
    position: relative;
    top: auto;
    left: auto !important;
    right: auto !important;
    transform: none;
    width: calc(100% - 30px);
    min-height: auto;
    margin: -70px auto 0 !important;
    padding: 54px 28px;
    border-radius: 38px;
  }

  .sk-editorial-title {
    font-size: 38px;
  }

  .sk-editorial-title span {
    font-size: 80px;
  }

  .sk-about-button,
  .sk-about-benefits-link {
    display: none !important;
  }
}
/* =========================
   Erlebnis-Kacheln
========================= */

.editorial-grid-section {
  padding: 60px 20px;
  background: #f3efee;
}

.editorial-grid-header {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 40px;
}

.editorial-grid-container {
  position: relative;
}

.editorial-grid {
  display: flex;
  overflow-x: auto;
  scroll-behavior: smooth;
  gap: 32px;
  padding-bottom: 20px;
}

.editorial-grid::-webkit-scrollbar {
  height: 6px;
}

.editorial-grid::-webkit-scrollbar-track {
  background: #ddd;
  border-radius: 3px;
}

.editorial-grid::-webkit-scrollbar-thumb {
  background: #9e1812;
  border-radius: 3px;
}

.grid-item {
  flex: 0 0 490px;       
  height: 460px;         
  background: #fff;
  border-radius: 42px;
  padding: 40px 50px;
  box-shadow: 0 25px 60px rgba(0,0,0,.04);
  scroll-snap-align: start;
  text-align: center;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.grid-tag {
  font-family: 'Satoshi-Regular', sans-serif;
  font-size: 15px;
  text-align: left;
  font-weight: 300 !important;
  letter-spacing: 0.05em;
  color: #9e1812;
  margin-bottom: 8px;
}

.grid-title {
  font-family: 'Satoshi-Bold', sans-serif;
  font-size: 28px;
  line-height: 1.2;
  color: #111;
  margin-bottom: 12px;
}

.grid-text p {
  font-size: 15px;
  color: #666;
  font-family: 'Satoshi_Regular', sans-serif !important;
  font-weight: 300 !important;
  -webkit-font-smoothing: antialiased;
  letter-spacing: 0.05em;
  line-height: 2
}

.grid-link-effect {
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 2;
  text-transform: uppercase;
  color: #9e1812 !important;
  text-decoration: none;
  display: block;      /* gesamte Kachel */
  width: 100%;         /* gesamte Breite */
  position: relative;  /* für das ::after */
  text-align: left;    /* linksbündig */
  padding-bottom: 4px; /* Abstand zur Linie */
}

.grid-link-effect::after {
  content: "";
  position: absolute;
  bottom: 0;           
  left: 0;
  width: 100%;         
  height: 1px;         
  background-color: #666; 
  transform-origin: right center;
  transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.grid-link-effect:hover::after {
  transform: scaleX(0); 
}

/* Navigation Buttons */
.grid-nav-footer {
  position: absolute;
  top: 106%;
  left: -30px; 
  right: -30px; 
  display: flex;
  justify-content: space-between; 
  width: calc(100% + 60px); 
  pointer-events: none; 
  transform: translateY(-50%); 
}

.grid-nav-btn {
  pointer-events: all; 
  z-index: 10;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  border: none;
  background: #fff;
  color: #111;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.3s ease;
}

.grid-nav-btn i {
  font-size: 20px;
  color: #111;
}

.grid-nav-btn:hover {
  background: #9e1812;
}

.grid-nav-btn:hover i {
  color: #fff;
}
/* Responsive */
@media (max-width: 768px) {
  .grid-item { flex: 0 0 360px; padding: 35px 35px; }
  .editorial-headline { font-size: 36px; }
  .editorial-signature { font-size: 80px; }
  .grid-title { font-size: 24px; }
  .grid-text p { font-size: 14px; line-height: 1.6; }
}
/* =========================
   Editorial CTA unter Kacheln
========================= */
.editorial-cta-container {
  text-align: center;
  max-width: 900px;
  margin: 80px auto 0; /* Abstand zu den Kacheln */
  padding: 0 20px;
}

.editorial-cta-text {
  font-size: 18px;
  color: #666;
  font-family: 'Satoshi_Regular', sans-serif !important;
  font-weight: 400 !important;
  -webkit-font-smoothing: antialiased;
  letter-spacing: 0.05em;
  line-height: 2
}

.sk-about-button {
  display: inline-block;
  background-color: #9e1812;
  color: #fff;
  font-family: 'Satoshi-Bold', sans-serif;
  font-weight: 700;
  font-size: 16px;
  text-transform: uppercase;
  padding: 16px 36px;
  border-radius: 50px;
  box-shadow: 0 8px 20px rgba(0,0,0,0.2);
  text-decoration: none;
  transition: all 0.3s ease;
  margin-bottom: 12px;
}

.sk-about-button:hover {
  background-color: #7a0f0b;
  box-shadow: 0 10px 24px rgba(0,0,0,0.25);
}

.sk-about-benefits-link {
  display: block;
  font-family: 'Satoshi-Regular', sans-serif;
  font-size: 14px;
  color: #666;
  margin-bottom: 20px;
  text-decoration: underline;
}

.sk-about-contact {
  display: flex;
  justify-content: center;
  gap: 24px;
  font-family: 'Satoshi-Regular', sans-serif;
  font-size: 14px;
  color: #666;
}

.sk-about-contact a {
  color: #666;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.sk-about-contact a:hover {
  text-decoration: underline;
}

/* Mobile Anpassung */
@media (max-width: 768px) {
  .editorial-cta-text {
    font-size: 16px;
  }

  .sk-about-button {
    font-size: 14px;
    padding: 14px 28px;
  }

  .sk-about-benefits-link {
    font-size: 13px;
  }

  .sk-about-contact {
    flex-direction: column;
    gap: 12px;
  }
}
/* =========================
   Galerie
========================= */

.editorial-gallery-section {
  padding: 60px 20px;
  background: #f3efee;
  position: relative;
}

.editorial-grid-header {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 40px;
}

.editorial-gallery-strip {
  display: flex;
  overflow-x: auto;
  gap: 24px;
  padding-bottom: 20px;
  scroll-behavior: smooth;
}

.editorial-gallery-strip::-webkit-scrollbar {
  height: 6px;
}

.editorial-gallery-strip::-webkit-scrollbar-track {
  background: #ddd;
  border-radius: 3px;
}

.editorial-gallery-strip::-webkit-scrollbar-thumb {
  background: #9e1812;
  border-radius: 3px;
}

/* Kachel-Styles */
.gallery-strip-item {
  flex: 0 0 auto;
  height: 500px; 
  min-width: 350px;
  max-width: 700px;
  position: relative;
  border-radius: 42px;
  overflow: hidden;
}

.gallery-strip-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Overlay-Text */
.gallery-caption {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  background: linear-gradient(to top, rgba(0,0,0,0.6), rgba(0,0,0,0));
  color: #fff;
  font-family: 'Satoshi-Regular', sans-serif;
  font-size: 14px;
  font-weight: 400 !important;
  -webkit-font-smoothing: antialiased;
  letter-spacing: 0.05em;
  padding: 12px 18px;
  opacity: 0;
  transition: opacity 0.3s ease;
  text-transform: uppercase;
}

.gallery-strip-item:hover .gallery-caption {
  opacity: 1;
}

@media (max-width: 768px) {
  .gallery-strip-item {
    height: 350px;  
    min-width: 250px;
    max-width: 360px;
  }

  .gallery-caption {
    font-size: 12px;
    padding: 6px 10px;
  }
}

/* =========================
   Navigation Buttons
========================= */
.gallery-nav-footer {
  position: absolute;
  top: 94.3%;          
  left: -30px;        
  right: -30px;       
  display: flex;
  justify-content: space-between;
  width: calc(100% + 60px);  
  pointer-events: none;      
}

.gallery-nav-btn {
  pointer-events: all;  
  z-index: 10;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  border: none;
  background: #fff;
  color: #111;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.3s ease;
}

.gallery-nav-btn i {
  font-size: 20px;
  color: #111;
}

.gallery-nav-btn:hover {
  background: #9e1812;
}

.gallery-nav-btn:hover i {
  color: #fff;
}
/* =========================
   Landingpage / Story Page
========================= */

/* Basis-Styles */
body {
  background-color: #fdfcfb;
  color: #1a1a1a;
  font-family: 'Satoshi_Regular', sans-serif;
}

/* Header / Hero */
.story-header {
  padding: 140px 0 30px;
  text-align: center;
  color: #fff;
}

.story-header .container {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.story-header-emblem {
  width: 64px;
  height: auto;
  margin: 28px auto 0;
  opacity: 0.85;
}

.story-header-divider {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  margin-top: 28px;
}

.story-header-divider::before,
.story-header-divider::after {
  content: '';
  width: 50px;
  height: 1px;
  background: rgba(158, 24, 18, 0.3);
}

.story-header-divider span {
  font-size: 10px;
  letter-spacing: 0.35em;
  text-transform: uppercase;
  color: rgba(158, 24, 18, 0.6);
  font-family: 'Satoshi_Regular', sans-serif;
  font-weight: 500;
}

/* Story Content */
.story-content {
  max-width: 800px;
  margin: 0 auto;
  padding: 0 20px 40px;
}

.story-section {
  background: #fff;
  padding: 50px;
  border-radius: 40px;
  box-shadow: 0 20px 50px rgba(0,0,0,0.02);
  margin-bottom: 60px;
}

.story-title {
  font-size: 24px;
  font-weight: 700;
  margin-top: 40px;
  margin-bottom: 20px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #9e1812;
  border-bottom: 1px solid #f1eae6;
  padding-bottom: 10px;
}

.story-paragraph {
  font-size: 17px;
  line-height: 1.8;
  color: #4a4a4a;
  margin-bottom: 25px;
}

.story-quote {
  font-size: 20px;
  font-style: italic;
  color: #9e1812;
  border-left: 3px solid #9e1812;
  padding-left: 20px;
  margin: 35px 0;
  line-height: 1.6;
}

/* CTA Box (Next Best Action) */
.nba-box {
  background-color: #f9f6f4;
  padding: 80px 60px;
  border-radius: 60px;
  text-align: center;
  border: 1px solid rgba(158, 24, 18, 0.05);
  box-shadow: 0 20px 50px rgba(0,0,0,0.02);
  margin-top: 80px;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.nba-title {
  font-family: 'Satoshi_Bold', sans-serif !important;
  font-size: 32px !important;
  font-weight: 700 !important;
  color: #1a1a1a !important;
  margin-bottom: 10px;
  text-transform: uppercase;
  letter-spacing: 0.1em !important;
}

.nba-text {
  color: #4a4a4a;
  font-family: 'Satoshi_Regular', sans-serif !important;
  font-weight: 300 !important;
  font-size: 16px !important;
  line-height: 1.8 !important;
  max-width: 600px;
  margin: 0 auto 40px;
}

.badge-list {
  display: flex;
  justify-content: center;
  gap: 15px;
  flex-wrap: wrap;
  margin-bottom: 45px;
  width: 100%;
}

.badge-item {
  background: #fff;
  color: #1a1a1a;
  border: 1px solid rgba(0,0,0,0.05);
  padding: 10px 20px;
  border-radius: 50px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: 'Satoshi_Regular', sans-serif !important;
  font-weight: 500 !important;
  font-size: 14px;
  box-shadow: 0 4px 15px rgba(0,0,0,0.01);
  transition: all 0.3s ease;
}

.badge-item:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(0,0,0,0.03);
  border-color: rgba(158,24,18,0.1);
}

.badge-item i {
  color: #9e1812 !important;
  font-size: 18px;
  display: inline-flex;
  align-items: center;
}

.nba-footnote {
  font-size: 12px;
  color: #888;
  margin-top: 20px;
  font-family: 'Satoshi_Regular', sans-serif !important;
  font-weight: 300;
  letter-spacing: 0.02em;
}

.back-link {
  text-align: center;
  margin-top: 40px;
  margin-bottom: 80px;
}

/* ===== Responsive ===== */
@media only screen and (max-width: 1200px) {
  .nba-box { padding: 60px 40px; }
}

@media only screen and (max-width: 768px) {
  .nba-box { padding: 40px 20px; border-radius: 40px; margin-top: 60px; }
  .nba-title { font-size: 24px !important; }
  .badge-list { gap: 10px; margin-bottom: 35px; }
  .badge-item { font-size: 13px; padding: 8px 16px; }
  .story-section { padding: 28px 20px; border-radius: 24px; }
  .story-content { padding: 0 12px 40px; }
  .editorial-headline { font-size: 32px !important; line-height: 1.15 !important; }
}

@media only screen and (max-width: 768px) {
  .story-header {
    padding: 80px 0 20px;
  }
}
.sk-room-page,
.sk-room-page html,
.sk-room-page body {
  overflow-x: hidden;
}

.sk-room-hero-text {
  top: 42% !important;
}

.sk-room-hero-subline {
  max-width: 620px;
  margin: 0 auto 26px;
  color: #fff;
  font-family: 'Satoshi_Regular', sans-serif;
  font-size: 15px;
  line-height: 1.8;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.sk-room-main {
  background: #fff;
}

/* Filter */
.sk-room-filter {
  position: sticky;
  top: 80px;
  z-index: 1000;
  width: 100%;
  background: rgba(255,255,255,.96);
  border-bottom: 1px solid rgba(0,0,0,.06);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  transition: box-shadow .25s ease;
}

.sk-room-filter.is-sticky {
  box-shadow: 0 12px 35px rgba(0,0,0,.08);
}

.sk-room-filter-inner {
  max-width: 1180px;
  margin: 0 auto;
  padding: 13px 25px;
  display: flex;
  justify-content: center;
  gap: 14px;
  overflow-x: auto;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
}

.sk-room-filter-inner::-webkit-scrollbar {
  display: none;
}

.sk-room-filter a {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 7px 20px;
  border-radius: 999px;
  border: 1px solid rgba(158,24,18,.14);
  color: #222;
  background: #fff;
  font-family: 'Satoshi_Regular', sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  text-decoration: none !important;
  transition: all .25s ease;
}

.sk-room-filter a:hover,
.sk-room-filter a.active {
  background: #9e1812;
  border-color: #9e1812;
  color: #fff !important;
}

/* Sections */
.sk-room-intro-section {
  padding-top: 110px;
}

.sk-room-section,
.sk-room-extras {
  padding: 105px 0;
  background: #fff;
}

.sk-room-section-light {
  background: #faf7f5;
}

.sk-room-section-inner {
  width: min(1180px, calc(100% - 50px));
  margin: 0 auto;
}

.sk-room-editorial {
  display: grid;
  grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr);
  gap: 70px;
  align-items: center;
  margin-bottom: 65px;
}

.sk-room-editorial-reverse .sk-room-editorial-text {
  order: 2;
}

.sk-room-editorial-reverse .sk-room-editorial-image {
  order: 1;
}

.sk-room-editorial-image img,
.sk-room-arrangement-image img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 22px;
  box-shadow: 0 28px 60px rgba(0,0,0,.11);
}

.sk-room-editorial .sk-editorial-title,
.sk-room-center-head .sk-editorial-title,
.sk-room-arrangement-card .sk-editorial-title,
.sk-room-final-inner .sk-editorial-title {
  margin-bottom: 26px;
}

/* Cards */
.sk-room-grid {
  display: grid;
  gap: 34px;
}

.sk-room-grid-two {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.sk-room-card {
  position: relative;
  overflow: hidden;
  border-radius: 24px;
  background: #fff;
  box-shadow: 0 14px 42px rgba(0,0,0,.07);
  transition: transform .25s ease, box-shadow .25s ease;
}

.sk-room-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 22px 60px rgba(0,0,0,.11);
}

.sk-room-card-image {
  position: relative;
  display: block;
  overflow: hidden;
  height: 310px;
  background: #eee;
}

.sk-room-card-image img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .55s ease;
}

.sk-room-card:hover .sk-room-card-image img {
  transform: scale(1.045);
}

.sk-room-badge {
  position: absolute;
  top: 18px;
  right: 18px;
  z-index: 2;
  padding: 7px 12px;
  border-radius: 999px;
  background: rgba(0,0,0,.78);
  color: #fff;
  font-family: 'Satoshi_Regular', sans-serif;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
}

.sk-room-card-content {
  padding: 30px 28px 32px;
}

.sk-room-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 12px;
  font-family: 'Satoshi-Regular', sans-serif;
}

.sk-room-meta span {
  color: #9e1812;
  font-size: 17px;
  font-weight: 700;
}

.sk-room-meta small {
  color: #777;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.sk-room-card h3 {
  margin: 0 0 15px;
  color: #1a1a1a;
  font-family: 'bellamy_signature', 'Playfair Display', serif !important;
  font-size: 66px;
  font-weight: normal;
  line-height: .82;
  letter-spacing: normal;
}

.sk-room-card p {
  margin: 0 0 18px;
  color: #666;
  font-family: 'Satoshi_Regular', sans-serif;
  font-size: 14px;
  line-height: 1.75;
}

.sk-room-features {
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
  margin: 0 0 23px;
}

.sk-room-features span,
.sk-room-benefits span {
  display: inline-flex;
  align-items: center;
  min-height: 27px;
  padding: 6px 11px;
  border-radius: 999px;
  background: #faf4f2;
  color: #555;
  font-family: 'Satoshi_Regular', sans-serif;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.sk-room-card-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  flex-wrap: wrap;
}

.sk-room-book-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 8px 17px;
  border-radius: 999px;
  background: #9e1812;
  color: #fff !important;
  font-family: 'Satoshi_Regular', sans-serif;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  text-decoration: none !important;
  transition: background .25s ease, transform .25s ease;
}

.sk-room-book-link:hover {
  background: #1a1a1a;
  transform: translateY(-2px);
}

/* Arrangement */
.sk-room-arrangement {
  padding: 105px 0;
  background: #f9f4f1;
}

.sk-room-arrangement-inner {
  width: min(1180px, calc(100% - 50px));
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, .95fr);
  gap: 70px;
  align-items: center;
}

.sk-room-benefits {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 24px 0 28px;
}

/* Horizontal Zimmer */
.sk-room-scroll-wrap {
  position: relative;
}

.sk-room-grid-scroll {
  display: flex;
  flex-wrap: nowrap;
  gap: 30px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  padding: 10px 6px 35px;
  scrollbar-width: thin;
  scrollbar-color: #9e1812 rgba(0,0,0,.07);
}

.sk-room-grid-scroll::-webkit-scrollbar {
  height: 5px;
}

.sk-room-grid-scroll::-webkit-scrollbar-track {
  background: rgba(0,0,0,.07);
  border-radius: 999px;
}

.sk-room-grid-scroll::-webkit-scrollbar-thumb {
  background: #9e1812;
  border-radius: 999px;
}

.sk-room-grid-scroll .sk-room-card {
  flex: 0 0 380px;
  scroll-snap-align: start;
}

.sk-room-grid-scroll .sk-room-card-image {
  height: 260px;
}

.sk-room-grid-scroll .sk-room-card h3 {
  font-size: 56px;
}

.sk-room-scroll-btn {
  position: absolute;
  top: 43%;
  width: 44px;
  height: 44px;
  border: 0;
  border-radius: 50%;
  background: #fff;
  color: #9e1812;
  font-size: 34px;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 12px 30px rgba(0,0,0,.13);
  cursor: pointer;
  z-index: 5;
  transition: all .25s ease;
}

.sk-room-scroll-btn:hover {
  background: #9e1812;
  color: #fff;
}

.sk-room-scroll-prev { left: -22px; }
.sk-room-scroll-next { right: -22px; }

/* Extras */
.sk-room-center-head {
  max-width: 760px;
  margin: 0 auto 60px;
  text-align: center;
}

.sk-room-center-head .sk-section-label {
  justify-content: center;
}

.sk-room-extra-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 24px;
}

.sk-room-extra-tile {
  min-height: 220px;
  padding: 32px 24px;
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 22px;
  background: #fff;
  text-align: center;
  box-shadow: 0 12px 34px rgba(0,0,0,.045);
  transition: all .25s ease;
}

.sk-room-extra-tile:hover {
  transform: translateY(-5px);
  border-color: rgba(158,24,18,.35);
  box-shadow: 0 18px 48px rgba(0,0,0,.075);
}

.sk-room-extra-tile > span {
  display: block;
  margin-bottom: 17px;
  color: #9e1812;
  font-size: 36px;
}

.sk-room-extra-tile h3 {
  margin: 0 0 11px;
  color: #1a1a1a;
  font-family: 'Satoshi_Regular', sans-serif;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.sk-room-extra-tile p {
  margin: 0;
  color: #666;
  font-family: 'Satoshi_Regular', sans-serif;
  font-size: 13px;
  line-height: 1.65;
}

/* Final CTA */
.sk-room-final-cta {
  padding: 105px 25px;
  background: #111;
  color: #fff;
  text-align: center;
}

.sk-room-final-inner {
  max-width: 850px;
  margin: 0 auto;
}

.sk-room-final-inner .sk-section-label {
  justify-content: center;
  color: rgba(255,255,255,.75);
}

.sk-room-final-inner .sk-editorial-title {
  color: #fff;
}

.sk-room-final-inner .sk-editorial-title span {
  color: #fff;
}

/* Responsive */
@media (max-width: 1199px) {
  .sk-room-editorial,
  .sk-room-arrangement-inner {
    gap: 45px;
  }

  .sk-room-extra-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 991px) {
  .sk-room-filter {
    top: 60px;
  }

  .sk-room-intro-section,
  .sk-room-section,
  .sk-room-extras,
  .sk-room-arrangement,
  .sk-room-final-cta {
    padding-top: 75px;
    padding-bottom: 75px;
  }

  .sk-room-editorial,
  .sk-room-arrangement-inner {
    grid-template-columns: 1fr;
  }

  .sk-room-editorial-reverse .sk-room-editorial-text,
  .sk-room-editorial-reverse .sk-room-editorial-image {
    order: initial;
  }

  .sk-room-grid-two {
    grid-template-columns: 1fr;
  }

  .sk-room-card-image {
    height: 290px;
  }

  .sk-room-scroll-btn {
    display: none;
  }
}

@media (max-width: 768px) {
  .sk-room-hero-text {
    top: 38% !important;
  }

  .sk-room-hero-subline {
    padding: 0 25px;
    font-size: 12px;
    line-height: 1.7;
  }

  .sk-room-filter-inner {
    justify-content: flex-start;
    padding: 10px 15px;
    gap: 9px;
  }

  .sk-room-filter a {
    min-height: 31px;
    padding: 6px 14px;
    font-size: 9px;
  }

  .sk-room-section-inner,
  .sk-room-arrangement-inner {
    width: calc(100% - 30px);
  }

  .sk-room-intro-section,
  .sk-room-section,
  .sk-room-extras,
  .sk-room-arrangement,
  .sk-room-final-cta {
    padding-top: 58px;
    padding-bottom: 58px;
  }

  .sk-room-editorial {
    gap: 28px;
    margin-bottom: 38px;
  }

  .sk-room-editorial-image img,
  .sk-room-arrangement-image img {
    border-radius: 16px;
  }

  .sk-room-grid {
    gap: 18px;
  }

  .sk-room-card {
    border-radius: 18px;
  }

  .sk-room-card-image {
    height: 235px;
  }

  .sk-room-card-content {
    padding: 23px 20px 25px;
  }

  .sk-room-card h3 {
    font-size: 48px;
  }

  .sk-room-card p {
    font-size: 13px;
  }

  .sk-room-meta {
    align-items: flex-start;
    flex-direction: column;
    gap: 3px;
  }

  .sk-room-grid-scroll {
    margin: 0 -15px;
    padding: 5px 15px 25px;
    gap: 14px;
  }

  .sk-room-grid-scroll .sk-room-card {
    flex: 0 0 300px;
  }

  .sk-room-grid-scroll .sk-room-card-image {
    height: 210px;
  }

  .sk-room-grid-scroll .sk-room-card h3 {
    font-size: 43px;
  }

  .sk-room-extra-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .sk-room-extra-tile {
    min-height: auto;
    padding: 26px 20px;
  }
}
