@charset "UTF-8";
/*
desktop.scss
Copyright (C) 2019 Nexteam S.r.l., All rights reserved.
*/
/*
main.scss
Copyright (C) 2019 Nexteam S.r.l., All rights reserved.
*/
/* ===================================
   GENERIC RULES
=================================== */
* {
  box-sizing: border-box;
}
*:focus {
  outline: none;
}

::-moz-focus-inner {
  border: 0;
}

html,
body {
  height: 100%;
}

body {
  line-height: 22px;
  font-family: "Circular";
  font-size: 14px;
  background-color: var(--backgroundValue);
  color: #102a43;
  margin: 0;
  padding: 0;
}

body.sviluppo {
  position: relative;
}
body.sviluppo:before {
  content: "SVILUPPO";
  position: absolute;
  left: -200px;
  top: -30px;
  background: red;
  z-index: 999999999;
  padding: 60px 60px 0px 60px;
  color: white;
  font-size: bold;
  font-weight: bold;
  transform: rotate(-45deg);
  width: 300px;
  text-align: center;
  font-size: 12px;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  margin: 0;
}

figure {
  margin: 0;
}
figure img,
figure figcaption {
  display: none;
}

p:first-child {
  margin-top: 0;
}
p:last-child {
  margin-bottom: 0;
}

input,
select,
textarea {
  font-family: "Circular";
  font-size: 14px !important;
  border-radius: 0;
  box-shadow: none;
  appearance: none;
  -webkit-appearance: none;
}

input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
textarea:-webkit-autofill,
textarea:-webkit-autofill:hover,
textarea:-webkit-autofill:focus,
select:-webkit-autofill,
select:-webkit-autofill:hover,
select:-webkit-autofill:focus {
  background-color: #ffffff;
  background-image: none;
  color: #102a43;
  -webkit-box-shadow: 0 0 0px 1000px #ffffff inset;
  -webkit-text-fill-color: #102a43 !important;
}

input::-ms-clear {
  display: none;
}

select::-ms-expand {
  display: none;
}

a[href^=tel] {
  color: inherit;
  text-decoration: none;
}

.bg-cover, .wallpaper {
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}

.bg-shadow, #banners {
  box-shadow: rgba(123, 135, 148, 0.5) 0 2px 8px;
}

.fa-phone {
  transform: scaleX(-1);
}

.hide {
  display: none !important;
}

.show-detail {
  cursor: pointer;
}

.hidden {
  display: none;
  visibility: hidden;
  opacity: 0;
}

.letter-normal, .content-list ul li {
  letter-spacing: normal;
}

.letter-reset, .popup-map .popup-map-info .popup-map-info-container .popup-map-info-contacts, .noavail-request, .social-frames, .paymode-info .paymode-img, .form-fields, #pricewidget .pw-ota .pw-items, .reservation, .feedback .feedback-total, .card-persuasive, .sidebar-left .sidebar-left-actions, .content-list ul {
  letter-spacing: -0.31em;
}

.load-map {
  cursor: pointer;
  text-decoration: underline;
  text-transform: lowercase;
}

.set-position, .wallpaper, .alert,
.error-popup, .popup-filters, .popup-map #map, .popup-map, #noavail-popup, .feedback .feedback-outer span, .card-type-emotional .card-image:before,
.card-type-emotionalcompact .card-image:before, .card-type-emotional .card-image,
.card-type-emotionalcompact .card-image, #banners .banner-image, .search-btn > div:last-child, .search-mask, #country {
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}

.wrapper {
  max-width: 1440px;
  margin: auto;
  padding: 0 40px;
}

/* ===================================
   HEADER
=================================== */
#country {
  display: none;
  background: rgba(0, 0, 0, 0.7);
  padding: 0 20px;
  position: fixed;
  z-index: 999;
  overflow-x: hidden;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
#country .country-table {
  display: table;
  width: 100%;
  height: 100%;
}
#country .country-table > div {
  display: table-cell;
  vertical-align: middle;
}
#country .country-wrap {
  max-width: 408px;
  background: #ffffff;
  box-shadow: rgba(131, 151, 178, 0.24) 0 3px 6px;
  margin: 60px auto;
  position: relative;
}
#country .country-close {
  width: 24px;
  height: 24px;
  line-height: 24px;
  font-size: 16px;
  text-align: center;
  cursor: pointer;
  position: absolute;
  top: 30px;
  right: 16px;
}
#country .country-tab {
  display: flex;
  border-bottom: 1px solid #d9e2ec;
}
#country .country-tab > div {
  display: inline-block;
  font-size: 18px;
  color: #d9e2ec;
  margin: 30px 0 0 24px;
  padding-bottom: 12px;
  position: relative;
  cursor: pointer;
}
#country .country-tab > div.active {
  font-weight: 900;
  color: var(--blueValue);
}
#country .country-tab > div.active:after {
  content: "";
  height: 3px;
  background: var(--blueValue);
  border-radius: 2px;
  position: absolute;
  right: 0;
  bottom: -2px;
  left: 0;
}
#country .country-list {
  margin-top: 30px;
  padding-bottom: 26px;
}
#country .country-list > div {
  display: none;
}
#country .country-list > div.active {
  display: block;
}
#country .country-list a {
  display: block;
  height: 24px;
  line-height: 24px;
  color: #102a43;
  margin-top: 24px;
  padding: 0 24px;
  position: relative;
  text-decoration: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}
#country .country-list a.active {
  color: var(--blueValue);
}
#country .country-list a.active:before {
  background: #d9e2ec;
}
#country .country-list a.active:after {
  opacity: 1;
}
#country .country-list a:before {
  content: "";
  width: 24px;
  height: 24px;
  border: 1px solid #d9e2ec;
  border-radius: 50%;
  box-sizing: border-box;
  position: absolute;
  top: 4px;
  right: 24px;
}
#country .country-list a:after {
  content: "";
  width: 10px;
  height: 10px;
  background: var(--blueValue);
  border-radius: 50%;
  position: absolute;
  top: 11px;
  right: 31px;
  opacity: 0;
}
#country .country-list a img {
  display: inline-block;
  width: 36px;
  margin: -4px 16px 0 0;
  vertical-align: middle;
}
#country .country-list a label {
  display: block;
  height: 26px;
  padding-right: 40px;
  overflow: hidden;
  cursor: pointer;
  vertical-align: middle;
}
#country .country-list a label span {
  display: inline-block;
  width: 36px;
  height: 36px;
  margin: -2px 16px 0 0;
  text-align: center;
  vertical-align: middle;
}
#country .country-list a label span i {
  display: block;
  height: 24px;
  line-height: 24px;
  font-size: 12px;
  font-style: normal;
  font-weight: 700;
  background: #ecf1f7;
  color: var(--textValue);
  margin-top: 6px;
}

#navigator {
  padding: 16px 0;
}
#navigator a {
  font-weight: 700;
  color: var(--textValue);
  margin-left: 24px;
  text-decoration: none;
  text-transform: uppercase;
}
#navigator a:first-child {
  margin-left: 0;
}
#navigator a:hover span:first-child i {
  background: #bcccdc;
}
#navigator a.active {
  color: var(--blueValue);
}
#navigator a.active span:first-child i {
  background: var(--blueValue);
  color: #ffffff;
}
#navigator a span {
  display: table-cell;
  line-height: 32px;
  vertical-align: middle;
}
#navigator a span:first-child {
  width: 38px;
}
#navigator a span:first-child i {
  display: block;
  width: 32px;
  height: 32px;
  line-height: 32px;
  font-size: 16px;
  background: #d9e2ec;
  color: #ffffff;
  border-radius: 50%;
  text-align: center;
}

/* ===================================
   MAIN
=================================== */
.container {
  background: #ffffff;
  padding: 0 16px;
}
.container.p16 {
  padding: 16px;
}

.content-intro {
  background: #ffffff;
  margin-bottom: 24px;
  box-shadow: rgba(123, 135, 148, 0.5) 0 2px 8px;
}
.content-intro > div {
  padding: 24px 30px 24px 16px;
}
.content-intro > div > div {
  color: var(--textValue);
  margin-top: 12px;
}

.content-cross-intro {
  background: #ffffff;
  color: var(--blueValue);
  margin-bottom: 24px;
  padding: 16px 90px;
  text-align: center;
  position: relative;
  box-shadow: rgba(123, 135, 148, 0.5) 0 2px 8px;
}
.content-cross-intro > i {
  display: block;
  width: 48px;
  height: 48px;
  line-height: 48px;
  background: #e4f0fa;
  font-size: 24px;
  border-radius: 50%;
  position: absolute;
  top: 50%;
  left: 12px;
  transform: translateY(-50%);
}
.content-cross-intro > i:last-child {
  right: 12px;
  left: auto;
}

.page-action-simple-step2 .content-intro,
.page-action-simple-step3 .content-intro,
.page-action-offer-rates .content-intro,
.page-action-services-index .content-intro {
  margin-bottom: 0;
}

.content-desc {
  color: var(--textValue);
}

.content-desc-continue {
  display: inline-block;
  color: var(--blueValue);
  cursor: pointer;
  text-decoration: underline;
  text-transform: lowercase;
  margin: 0 5px;
}

.content-title {
  font-size: 18px;
  font-weight: 900;
}
.content-title.md {
  font-size: 16px;
}
.content-title.xl {
  line-height: 30px;
  font-size: 24px;
}
.content-title.mb0 {
  margin-bottom: 0 !important;
}
.content-title.pt30 {
  padding-top: 30px;
}

.content-price {
  font-size: 20px;
  font-weight: 900;
  color: var(--blueValue);
  text-transform: uppercase;
}
.content-price.gross {
  margin-top: 6px;
  white-space: nowrap;
}
.content-price.gross > b {
  display: block;
  font-size: 11px;
  font-weight: 500;
  color: var(--textValue);
  text-transform: lowercase;
}
.content-price span {
  font-size: 12px;
  font-weight: 400;
}

.content-price-net {
  font-size: 11px;
  font-weight: 500;
  color: var(--textValue);
  text-transform: lowercase;
}

.content-price-rack {
  font-size: 12px;
  color: var(--textValue);
  text-decoration: line-through;
}

.content-button {
  display: table;
  height: 100%;
}
.content-button.content-button-compact a {
  background: #d9e2ec !important;
  color: var(--textValue) !important;
}
.content-button.content-button-compact a:before {
  visibility: hidden;
}
.content-button.content-button-compact a i:before {
  content: "\f106";
}
.content-button a {
  display: table-cell;
  line-height: 18px;
  font-size: 12px;
  font-weight: 900;
  background: var(--blueValue);
  color: #ffffff;
  cursor: pointer;
  text-align: center;
  text-decoration: none;
  text-transform: uppercase;
  vertical-align: middle;
}
.content-button a:hover {
  background: var(--blueValueRgbLighten);
}
.content-button a.full {
  background: #009c12;
}
.content-button a.full:before {
  background: #00c016;
}
.content-button a.full:hover {
  background: #00b615;
}
.content-button a span {
  display: block;
  width: 162px;
  padding: 0 16px;
  position: relative;
}
.content-button a span i {
  margin-left: 4px;
}

.content-button-select .select-hidden {
  display: none;
  visibility: hidden;
}
.content-button-select .select-styled {
  line-height: 62px;
  font-size: 12px;
  font-weight: 900;
  background: var(--blueValue);
  color: #ffffff;
  padding: 0 16px;
  cursor: pointer;
  overflow: hidden;
  text-align: center;
  text-overflow: ellipsis;
  text-transform: uppercase;
  white-space: nowrap;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}
.content-button-select .select-styled:hover {
  background: var(--blueValueRgbLighten);
}
.content-button-select .select-styled.full {
  background: #009c12;
}
.content-button-select .select-styled.full:hover {
  background: #00b615;
}
.content-button-select .select-styled.full:before {
  background: #00c016;
}
.content-button-select .select-styled span {
  position: relative;
}
.content-button-select .select-styled i {
  margin-left: 6px;
}
.content-button-select .select-options {
  display: none;
  list-style: none;
  background: #ffffff;
  margin: 0;
  padding: 0;
  position: absolute;
  top: 100%;
  right: 0;
  left: 0;
  z-index: 100;
  box-shadow: rgba(123, 135, 148, 0.5) 0 2px 8px;
}
.content-button-select .select-options li {
  font-size: 14px;
  color: #102a43;
  border-top: 1px solid #d9e2ec;
  padding: 9px 0;
  cursor: pointer;
  text-align: center;
}
.content-button-select .select-options li:hover {
  background: #f0f4f8;
}
.content-button-select .select-options li[rel=hide] {
  display: none;
}

.content-add,
.content-add-newsletter {
  display: table;
  width: 130px;
  font-size: 12px !important;
  font-weight: 900;
  background: var(--blueValue);
  color: #ffffff;
  border: 0;
  border-top: 1px solid #74afe8;
  text-transform: uppercase;
  cursor: pointer;
  text-align: center;
  text-decoration: none;
  position: relative;
}
.content-add:hover,
.content-add-newsletter:hover {
  background: var(--blueValueRgbLighten);
}
.content-add.inbl,
.content-add-newsletter.inbl {
  display: inline-block;
  width: auto;
  height: 36px;
  line-height: 36px;
  padding: 0 24px;
}
.content-add span,
.content-add-newsletter span {
  display: table-cell;
  width: 140px;
  padding: 9px 16px;
  word-break: break-all;
  vertical-align: middle;
  position: relative;
}
.content-add.borders,
.content-add-newsletter.borders {
  border: 1px solid;
}
.content-add.back,
.content-add-newsletter.back {
  background: #ffffff;
  color: var(--blueValue);
  border-color: var(--blueValue);
}
.content-add.back:hover,
.content-add-newsletter.back:hover {
  text-decoration: underline;
}
.content-add.back:before,
.content-add-newsletter.back:before {
  background: var(--blueValue);
}
.content-add.back i,
.content-add-newsletter.back i {
  margin-right: 6px;
}
.content-add.cancel,
.content-add-newsletter.cancel {
  background: #ffe8e8;
  color: #ab2727;
  border-color: rgba(171, 39, 39, 0.2);
}
.content-add.cancel:hover,
.content-add-newsletter.cancel:hover {
  background: #ffc9c9;
}
.content-add.cancel i,
.content-add-newsletter.cancel i {
  margin-right: 4px;
}
.content-add.change,
.content-add-newsletter.change {
  background: #fffae6;
  color: #9c7e00;
  border-color: #9c7e00;
}
.content-add.change:hover,
.content-add-newsletter.change:hover {
  background: #fff5cd;
}
.content-add.change i,
.content-add-newsletter.change i {
  margin-right: 4px;
}
.content-add.edit,
.content-add-newsletter.edit {
  background: #e4f0fa;
  color: var(--blueValue);
  border-color: var(--blueValue);
}
.content-add.edit:hover,
.content-add-newsletter.edit:hover {
  background: #cee4f6;
}
.content-add.edit i,
.content-add-newsletter.edit i {
  margin-right: 4px;
}
.content-add.ghost,
.content-add-newsletter.ghost {
  display: none !important;
}
.content-add.locked,
.content-add-newsletter.locked {
  background: #009c12;
  border-color: #e6ffe8;
}
.content-add.locked span i,
.content-add-newsletter.locked span i {
  margin-right: 6px;
}
.content-add.locked:before,
.content-add-newsletter.locked:before {
  background: #00c016;
}
.content-add.locked:hover,
.content-add-newsletter.locked:hover {
  background: #00b615;
}
.content-add.onrequest,
.content-add-newsletter.onrequest {
  background: #f06f00;
  border-color: #ffe2b4;
  /*width: 110px;*/
}
.content-add.onrequest:hover,
.content-add-newsletter.onrequest:hover {
  background: #ff7c0b;
}
.content-add.onrequest:before,
.content-add-newsletter.onrequest:before {
  background: #ff8115;
}
.content-add.logout,
.content-add-newsletter.logout {
  background: #f0f4f8;
  color: var(--textValue);
  border-color: #d0def0;
}
.content-add.logout:hover,
.content-add-newsletter.logout:hover {
  background: #f7f7f7;
}
.content-add.logout i,
.content-add-newsletter.logout i {
  margin-right: 4px;
}
.content-add.print i,
.content-add-newsletter.print i {
  margin-right: 4px;
}
.content-add.mt16,
.content-add-newsletter.mt16 {
  margin-top: 16px;
}

.content-blur {
  text-shadow: 0 0 8px #102a43;
  color: transparent !important;
  pointer-events: none;
  -webkit-user-select: none;
  -khtml-user-select: none;
  -moz-user-select: -moz-none;
  -o-user-select: none;
  user-select: none;
}

.content-list.popup-beds ul {
  margin-right: 0;
}
.content-list.popup-beds ul li {
  width: 100%;
  margin-right: 0;
}
.content-list ul {
  list-style: none;
  margin: 0 -16px 0 0;
  padding: 0 !important;
}
.content-list ul li {
  display: none;
  width: calc(50% - 17px);
  line-height: 15px;
  font-size: 12px;
  color: var(--textValue);
  margin: 10px 16px 0 0;
  vertical-align: top;
}
.content-list ul li.visible {
  display: inline-block;
}
.content-list ul li.card-services-more {
  color: var(--blueValue);
  cursor: pointer;
}
.content-list ul li.card-services-more > div:first-child i {
  display: block;
  width: 20px;
  height: 20px;
  line-height: 20px;
  font-size: 10px;
  font-style: normal;
  font-weight: 900;
  background: var(--blueValue);
  color: #ffffff;
  border-radius: 50%;
}
.content-list ul li.card-services-more > div:last-child {
  text-decoration: underline;
}
.content-list ul li.card-services-more a {
  color: var(--blueValue);
}
.content-list ul li > div {
  display: table-cell;
  word-break: break-word;
  vertical-align: top;
}
.content-list ul li > div:first-child {
  width: 20px;
  color: var(--blueValue);
  text-align: center;
}
.content-list ul li > div:last-child {
  padding-left: 8px;
}
.content-list ul li img,
.content-list ul li svg {
  width: auto;
  height: 14px;
  transform: translateY(2px);
}
.content-list ul li img path,
.content-list ul li svg path {
  fill: var(--blueValue);
}
.content-list ul li svg {
  width: 20px;
}

.content-data > div {
  display: flex;
}
.content-data > div > div {
  text-align: left;
  padding-top: 16px;
  padding-bottom: 16px;
}
.content-data > div > div:first-child {
  width: 30%;
  font-weight: 700;
  color: var(--textValue);
  padding-right: 16px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.content-data > div > div:last-child {
  width: 70%;
  border-bottom: 1px solid #d9e2ec;
  word-break: break-word;
}
.content-data > div:last-child > div:last-child {
  border: 0;
  padding-bottom: 0;
}

.content-category {
  font-size: 18px;
  font-weight: 900;
  background: var(--darkblueValue);
  color: #ffffff;
  padding: 16px;
}
.content-category.content-grouped {
  display: flex;
  cursor: pointer;
}
.content-category.content-grouped:hover {
  background: var(--blueValue);
}
.content-category.content-grouped.open:after {
  content: "\f077";
}
.content-category.content-grouped:after {
  content: "\f078";
  font-family: "Font Awesome 5 Pro";
  font-size: 10px;
  font-weight: 300;
  margin-left: 12px;
}
.content-category.content-grouped > span {
  width: 18px;
  height: 18px;
  line-height: 18px;
  font-size: 10px;
  background: #ffffff;
  color: var(--blueValue);
  border-radius: 50%;
  margin-left: auto;
  text-align: center;
  transform: translateY(1px);
}

.content-separator {
  display: block;
  height: 1px;
  background: #d9e2ec;
  margin: 30px 0;
}

.content-back-list {
  display: inline-block;
  height: 48px;
  line-height: 48px;
  font-size: 12px;
  background: #ffffff;
  color: var(--darkblueValue);
  padding: 0 24px;
  cursor: pointer;
  text-decoration: none;
  text-transform: uppercase;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
}
.content-back-list i {
  font-size: 16px;
  margin-right: 8px;
  transform: translateY(2px);
}

.content-blocked.disabled {
  cursor: not-allowed;
}
.content-blocked.disabled .select-styled {
  background: #cbd2d9;
  pointer-events: none;
}
.content-blocked.disabled .select-styled:before {
  display: none;
}

.content-margin.mb24 {
  margin-bottom: 24px;
}

.book-confirm {
  display: block;
  width: calc(100% + 32px);
  height: 60px;
  line-height: 60px;
  font-size: 12px;
  font-weight: 900;
  background: #009c12;
  color: #ffffff;
  cursor: pointer;
  margin: 24px -16px 0 -16px;
  text-align: center;
  text-decoration: none;
  text-transform: uppercase;
}
.book-confirm:hover {
  background: #00b615;
}
.book-confirm span {
  position: relative;
  z-index: 2;
}
.book-confirm:before {
  background: #00c016 !important;
}

.cta-toggle i {
  margin-left: 4px;
}

.cta-anim {
  overflow: hidden;
  position: relative;
}
.cta-anim.mri i {
  margin-left: 4px;
}
.cta-anim:before {
  content: "";
  width: 36px;
  background: var(--blueValueRgbLighten);
  transform: skewX(-30deg);
  position: absolute;
  top: 0;
  bottom: 0;
  left: -100%;
  opacity: 0;
  animation: ctaAnim 4s 2s infinite;
}

/* ===================================
KEYFRAMES
=================================== */
@keyframes ctaAnim {
  0% {
    opacity: 1;
  }
  25% {
    left: 120%;
    opacity: 1;
  }
  25.1%, 25.2% {
    opacity: 0;
  }
}
@keyframes showMsg {
  0% {
    transform: translateY(12px);
  }
  12.5% {
    transform: translateY(0);
  }
  87.5% {
    transform: translateY(0);
  }
  100% {
    transform: translateY(12px);
  }
}
/* ===================================
   SEARCH
=================================== */
.sticky {
  z-index: 11;
}

.sidebar {
  max-width: 350px;
  box-shadow: rgba(123, 135, 148, 0.5) 0 2px 8px;
}

#search {
  background: rgba(255, 255, 255, 0.9);
  padding: 24px 16px 0 16px;
  position: relative;
  z-index: 12;
}
#search.indexed {
  z-index: 999;
}
#search .search-title {
  font-size: 16px;
  margin-bottom: 8px;
}
#search.search-compact-mode .search-compact {
  display: block;
}
#search.search-compact-mode .search-container {
  display: none;
}
#search .search-modify {
  float: right;
  font-size: 14px;
  font-weight: 400;
  color: var(--textValue);
  cursor: pointer;
  text-transform: lowercase;
}
#search .search-modify:hover {
  text-decoration: underline;
}
#search .search-modify i {
  margin-left: 8px;
}

.search-mask {
  background: rgba(0, 0, 0, 0.7);
  position: fixed;
  z-index: -1;
  opacity: 0;
  visibility: hidden;
}
.search-mask.visible {
  opacity: 1;
  z-index: 11;
  visibility: visible;
}

.search-compact {
  display: none;
  max-width: 317px;
  margin-top: 16px;
  padding-bottom: 16px;
}
.search-compact > div {
  height: 48px;
  line-height: 48px;
  background: #ffffff;
  border: 1px solid #d9e2ec;
  margin-top: 8px;
  padding: 0 16px 0 48px;
  cursor: pointer;
  position: relative;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.search-compact > div:first-child:before {
  content: "\f073";
}
.search-compact > div.scr:before {
  content: "\f236";
}
.search-compact > div.search-compact-guests:before {
  content: "\f007";
}
.search-compact > div.search-compact-coupon:before {
  content: "\f02b";
}
.search-compact > div:nth-child(4) {
  padding-right: 48px;
}
.search-compact > div:nth-child(4):before {
  content: "\f02b";
}
.search-compact > div:nth-child(4):after {
  content: "\f00c";
  width: 19px;
  height: 19px;
  line-height: 19px;
  font-family: "Font Awesome 5 Pro";
  font-size: 12px;
  background: #f0f4f8;
  color: #009c12;
  border-radius: 50%;
  text-align: center;
  position: absolute;
  top: 50%;
  right: 16px;
  transform: translateY(-50%);
}
.search-compact > div:before {
  font-family: "Font Awesome 5 Pro";
  font-size: 16px;
  color: var(--blueValue);
  position: absolute;
  top: 50%;
  left: 16px;
  transform: translateY(-50%);
}

.search-fields {
  display: flex;
  flex-flow: row wrap;
  align-content: space-between;
  justify-content: space-between;
}

.search-options {
  height: 48px;
  background: #ffffff;
  border: 1px solid #d9e2ec;
  margin-top: 8px;
  position: relative;
}
.search-options select {
  display: block;
  width: 100%;
  height: 48px;
  background: transparent;
  color: #102a43;
  border: 0;
  box-sizing: border-box;
  padding: 0 42px;
  cursor: pointer;
  vertical-align: top;
  position: relative;
  z-index: 2;
}
.search-options i {
  width: 14px;
  color: var(--blueValue);
  position: absolute;
  top: 50%;
  text-align: center;
  transform: translateY(-50%);
}
.search-options i:first-child {
  font-size: 16px;
  left: 16px;
}
.search-options i:last-child {
  right: 16px;
}

.search-field {
  display: flex;
  width: 100%;
  line-height: 48px;
  background: #ffffff;
  border: 1px solid #d9e2ec;
  cursor: pointer;
  margin-top: 8px;
  padding: 0 16px;
  position: relative;
}
.search-field:nth-child(2) {
  order: 3;
}
.search-field:nth-child(2).active {
  order: 0;
}
.search-field.active {
  background: #d9e2ec;
  border-color: #bcccdc;
}
.search-field.active:after {
  content: "";
  display: block;
  position: absolute;
  top: 43px;
  left: 50%;
  width: 12px;
  height: 12px;
  background: #d9e2ec;
  border-right: 1px solid #bcccdc;
  border-bottom: 1px solid #bcccdc;
  transform: translateX(-50%) rotate(45deg);
}
.search-field.active > div:last-child:after {
  content: "\f106";
}
.search-field.active .search-input {
  font-weight: 700;
}
.search-field > div:first-child {
  font-size: 16px;
}
.search-field > div:first-child i {
  color: var(--blueValue);
  margin-right: 8px;
  transform: translateY(-1px);
}
.search-field > div:last-child {
  margin-left: auto;
}
.search-field > div:last-child:after {
  content: "\f107";
  font-family: "Font Awesome 5 Pro";
  font-weight: 300;
  color: var(--blueValue);
  margin-left: 8px;
}

/*
datepicker.scss
Copyright (C) 2018 Nexteam S.r.l., All rights reserved.
*/
#calendarbook {
  margin-top: 10px;
}

.calendardate {
  display: none;
  letter-spacing: normal;
  margin-top: 47px;
  position: absolute;
  z-index: 10;
}
.calendardate .ui-datepicker {
  max-width: 317px;
  border: 1px solid #d0def0;
  box-sizing: border-box;
  box-shadow: rgba(123, 135, 148, 0.24) 0 6px 24px;
}

.ui-datepicker {
  display: none;
  margin: 0 auto;
  background: #ffffff;
  color: #102a43;
  border: 1px solid #bcccdc;
  overflow: hidden;
}
.ui-datepicker table {
  width: 100%;
  border-spacing: 0;
  border-collapse: collapse;
  margin: 0 auto;
  table-layout: fixed;
}
.ui-datepicker .ui-datepicker-header {
  height: 52px;
  line-height: 52px;
  font-size: 16px;
  font-weight: 700;
  border-bottom: 1px solid #bcccdc;
  position: relative;
  text-align: center;
  -webkit-user-select: none;
  -moz-user-select: none;
  -khtml-user-select: none;
  -ms-user-select: none;
}
.ui-datepicker .ui-datepicker-header .ui-datepicker-title select {
  line-height: 30px;
  font-size: 12px !important;
  font-weight: 700;
  color: var(--textValue);
  background-color: transparent;
  background-image: url(data:image/svg+xml;utf8;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCA0NDggNTEyIj48cGF0aCBmaWxsPSIjOTk5IiBkPSJNNDQxLjkgMTY3LjNsLTE5LjgtMTkuOGMtNC43LTQuNy0xMi4zLTQuNy0xNyAwTDIyNCAzMjguMiA0Mi45IDE0Ny41Yy00LjctNC43LTEyLjMtNC43LTE3IDBMNi4xIDE2Ny4zYy00LjcgNC43LTQuNyAxMi4zIDAgMTdsMjA5LjQgMjA5LjRjNC43IDQuNyAxMi4zIDQuNyAxNyAwbDIwOS40LTIwOS40YzQuNy00LjcgNC43LTEyLjMgMC0xN3oiLz48L3N2Zz4=);
  background-position-x: calc(100% - 12px);
  background-position-y: 11px;
  background-repeat: no-repeat;
  background-size: 7px;
  border: 1px solid #d9e2ec;
  cursor: pointer;
  margin: 10px 0 0 0;
  padding: 0 30px 0 12px;
  vertical-align: top;
}
.ui-datepicker .ui-datepicker-header .ui-datepicker-title select:last-child {
  border-left: 0;
}
.ui-datepicker th {
  font-size: 14px;
  font-weight: 700;
  color: #102a43;
  height: 32px;
  line-height: 32px;
  border-right: 1px solid #bcccdc;
  border-bottom: 1px solid #bcccdc;
  text-align: center;
  text-transform: uppercase;
}
.ui-datepicker th:last-child {
  border-right: 0;
}
.ui-datepicker th span {
  pointer-events: none;
}
.ui-datepicker td {
  padding: 0;
  position: relative;
}
.ui-datepicker td span,
.ui-datepicker td a {
  display: block;
  width: 100%;
  height: 45px;
  line-height: 45px;
  font-size: 14px;
  text-align: center;
  position: relative;
}

.page-action-offer-details #calendarbook.loading .ui-datepicker-calendar {
  position: relative;
}
.page-action-offer-details #calendarbook.loading .ui-datepicker-calendar:before {
  content: "";
  background: rgba(255, 255, 255, 0.8);
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 3;
}
.page-action-offer-details #calendarbook.loading .ui-datepicker-calendar:after {
  content: "";
  width: 30px;
  height: 30px;
  background: none;
  border: 3px solid var(--blueValue);
  border-top-color: transparent;
  border-radius: 100%;
  margin: -15px 0 0 -15px;
  animation: spin 1s infinite linear;
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 3;
}

@keyframe spin {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}
.ui-datepicker-prev,
.ui-datepicker-next {
  display: block;
  overflow: hidden;
  text-align: center;
  cursor: pointer;
  text-decoration: none !important;
  position: absolute;
  top: 0;
  color: var(--textValue);
}
.ui-datepicker-prev.ui-state-disabled,
.ui-datepicker-next.ui-state-disabled {
  opacity: 0.3;
}
.ui-datepicker-prev:before,
.ui-datepicker-next:before {
  display: block;
  width: 52px;
  height: 52px;
  line-height: 52px;
  font-family: "Font Awesome 5 Pro";
  font-size: 16px;
  font-weight: 300;
  color: #102a43;
}
.ui-datepicker-prev span,
.ui-datepicker-next span {
  display: none;
}

.ui-datepicker-prev {
  left: 0;
}
.ui-datepicker-prev:before {
  content: "\f104";
}

.ui-datepicker-next {
  right: 0;
}
.ui-datepicker-next:before {
  content: "\f105";
}

.ui-datepicker-calendar td:hover {
  background: #e4f0fa;
  color: var(--blueValue);
}
.ui-datepicker-calendar td a {
  color: #102a43;
  text-decoration: none !important;
}

.ui-datepicker-today a {
  border: 0 !important;
}

.ui-datepicker-unselectable:hover {
  background: none !important;
}
.ui-datepicker-unselectable .ui-state-default {
  color: #dce3f5;
  cursor: default;
  pointer-events: none;
}

.ui-datepicker-other-month a,
.ui-datepicker-other-month span {
  color: #dce3f5 !important;
}

.ui-tooltip {
  line-height: 18px;
  background: rgba(0, 0, 0, 0.8);
  color: #ffffff;
  font-size: 12px;
  padding: 6px 12px;
  text-align: center;
  position: absolute;
  z-index: 9999;
  max-width: 240px;
}
.ui-tooltip.pct-tooltip {
  background: #e6ffe8;
  color: #009c12;
  border: 1px solid rgba(0, 156, 18, 0.2);
}
.ui-tooltip.pct-tooltip:before {
  display: none;
}
.ui-tooltip:before {
  content: "";
  position: absolute;
  top: -4px;
  left: 50%;
  box-sizing: border-box;
  border: 4px solid;
  border-color: transparent transparent rgba(0, 0, 0, 0.8) rgba(0, 0, 0, 0.8);
  margin-left: -4px;
  transform: rotate(135deg);
}

.ui-helper-hidden-accessible {
  display: none;
}

.ui-datepicker .restricted:after, .ui-datepicker .festivity:after,
.ui-datepicker .special:after {
  display: block;
  line-height: 12px;
  font-weight: 700;
  color: var(--blueValue);
  text-align: center;
  cursor: pointer;
  position: absolute;
  top: 7px;
  right: 9px;
  z-index: 2;
}

.ui-datepicker .festivity:after,
.ui-datepicker .special:after {
  content: "\f005";
  font-family: "Font Awesome 5 Pro";
  font-size: 8px;
}
.ui-datepicker .restricted:after {
  content: "R";
  font-size: 10px;
}
.ui-datepicker .closed,
.ui-datepicker .noavail {
  background: url("../_images/noavail.svg") center;
}
.ui-datepicker .closed:before,
.ui-datepicker .noavail:before {
  content: "";
  display: block;
  width: 24px;
  height: 24px;
  background: #ffffff;
  border-radius: 50%;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.ui-datepicker .closed:after,
.ui-datepicker .noavail:after {
  display: none;
}
.ui-datepicker .closed.firstNoavail:before,
.ui-datepicker .noavail.firstNoavail:before {
  z-index: 2;
  background-color: #d9e2ec;
}
.ui-datepicker .closed.firstNoavail:after,
.ui-datepicker .noavail.firstNoavail:after {
  z-index: 1;
  content: "";
  display: block;
  width: 0;
  height: 0;
  position: absolute;
  top: 0;
  left: 0;
  border-left: 0;
  border-right: 45px solid transparent;
  border-top: 45px solid #ffffff;
  border-bottom: 0;
}
.ui-datepicker .closed.firstNoavail a,
.ui-datepicker .noavail.firstNoavail a {
  z-index: 2;
}
.ui-datepicker .closed:not(.firstNoavail) a,
.ui-datepicker .noavail:not(.firstNoavail) a {
  color: #bcccdc;
}
.ui-datepicker .date-range-start.festivity:after, .ui-datepicker .date-range-start.special:after, .ui-datepicker .date-range-start.restricted:after,
.ui-datepicker .date-range-selected.festivity:after,
.ui-datepicker .date-range-selected.special:after,
.ui-datepicker .date-range-selected.restricted:after {
  color: #ffffff;
}

.ui-datepicker .date-range-start a,
.ui-datepicker .date-range-start span {
  background-color: var(--blueValue) !important;
  color: #ffffff !important;
}

.ui-datepicker .date-range-end a,
.ui-datepicker .date-range-end span {
  background-color: #e4f0fa !important;
  color: var(--blueValue) !important;
}

.ui-datepicker .date-range-selected a,
.ui-datepicker .date-range-selected span {
  background: var(--blueValue) !important;
  color: #ffffff !important;
}

.ui-datepicker .date-range-hover a,
.ui-datepicker .date-range-hover span {
  background: #e4f0fa;
  color: var(--blueValue);
}

.ui-datepicker-other-month.date-range-selected a {
  color: var(--blueValue);
}

.ui-datepicker .date-range-start a:after,
.ui-datepicker .date-range-start span:after,
.ui-datepicker .date-range-end a:after,
.ui-datepicker .date-range-end span:after {
  content: "";
  display: block;
  width: 10px;
  height: 10px;
  background: var(--blueValue);
  position: absolute;
  top: 50%;
  z-index: 2;
  transform: translateY(-50%) rotate(45deg);
}

.ui-datepicker .date-range-start a:after,
.ui-datepicker .date-range-start span:after {
  right: -5px;
}

.ui-datepicker .date-range-end a:after,
.ui-datepicker .date-range-end span:after {
  left: -5px;
}

/* --- SLIDE --- */
.ui-slider {
  height: 1px;
  background: #d0def0;
  position: relative;
  margin: 24px 12px 0 12px;
  text-align: left;
}

.ui-slider-handle {
  width: 24px;
  height: 24px;
  background: #d0def0;
  border-radius: 50%;
  margin-left: -12px;
  position: absolute;
  top: -12px;
  z-index: 2;
  cursor: pointer;
}
.ui-slider-handle:before {
  content: "";
  width: 20px;
  height: 20px;
  background: var(--blueValue);
  border-radius: 50%;
  position: absolute;
  top: 2px;
  left: 2px;
}

.ui-slider-range {
  height: 100%;
  background: var(--blueValue);
  border: 0;
  position: absolute;
  top: 0;
}

.search-nights {
  font-size: 12px;
  font-style: italic;
  margin: 8px 2px 0 0;
  text-align: right;
}

.search-rooms-wrap {
  position: relative;
}
.search-rooms-wrap .search-rooms > div {
  margin-top: 18px;
  position: relative;
}
.search-rooms-wrap .search-rooms > div .room-label {
  font-size: 16px;
  padding: 0 16px;
  white-space: nowrap;
}
.search-rooms-wrap .search-rooms > div .room-label i {
  color: var(--blueValue);
  margin-right: 8px;
}
.search-rooms-wrap .search-rooms > div .room-guests {
  max-width: 328px;
  height: 48px;
  line-height: 48px;
  background: #ffffff;
  border: 1px solid #d9e2ec;
  margin-top: 8px;
  padding: 0 37px 0 16px;
  cursor: pointer;
  position: relative;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}
.search-rooms-wrap .search-rooms > div .room-guests.open {
  font-weight: 900;
}
.search-rooms-wrap .search-rooms > div .room-guests.open:after {
  content: "\f106";
}
.search-rooms-wrap .search-rooms > div .room-guests:after {
  content: "\f107";
  font-family: "Font Awesome 5 Pro";
  font-weight: 300;
  color: var(--blueValue);
  position: absolute;
  top: 50%;
  right: 16px;
  transform: translateY(-50%);
}
.search-rooms-wrap .search-rooms > div .room-guesttypes {
  display: none;
  background: #ffffff;
  border: 1px solid #d9e2ec;
  border-top: 0;
}
.search-rooms-wrap .search-rooms > div .room-guesttypes.open {
  display: block;
}
.search-rooms-wrap .search-rooms > div .room-guesttypes > div {
  border-bottom: 1px solid #d9e2ec;
  padding: 16px;
  text-align: right;
  overflow: hidden;
}
.search-rooms-wrap .search-rooms > div .room-guesttypes > div:last-child {
  border: 0;
}
.search-rooms-wrap .search-rooms > div .room-guesttypes > div label {
  max-width: 183px;
  float: left;
  text-align: left;
}
.search-rooms-wrap .search-rooms > div .room-guesttypes > div a {
  display: inline-block;
  width: 24px;
  height: 24px;
  line-height: 24px;
  font-size: 12px;
  background: var(--blueValue);
  color: #ffffff;
  cursor: pointer;
  text-align: center;
  vertical-align: top;
}
.search-rooms-wrap .search-rooms > div .room-guesttypes > div a:hover {
  background: var(--blueValueRgbLighten);
}
.search-rooms-wrap .search-rooms > div .room-guesttypes > div a.disabled {
  cursor: default;
  background: #dce3f5;
  pointer-events: none;
}
.search-rooms-wrap .search-rooms > div .room-guesttypes > div input {
  width: 36px;
  height: 24px;
  font-size: 18px;
  color: #102a43;
  border: 0;
  text-align: center;
}
.search-rooms-wrap .search-rooms > div .room-guesttypes > div input.disabled {
  color: var(--textValue);
}
.search-rooms-wrap .search-rooms > div .room-guesttypes > div > div {
  padding: 16px 0 0 16px;
}
.search-rooms-wrap .search-rooms > div.search-rowadd {
  font-size: 12px;
  color: var(--blueValue);
  margin: 8px 0 32px 0;
  padding: 0 16px;
  cursor: pointer;
}
.search-rooms-wrap .search-rooms > div.search-rowadd span {
  margin-left: 8px;
  text-decoration: underline;
}
.search-rooms-wrap .search-rooms .delete-room {
  font-size: 14px;
  color: #ab2727;
  text-align: center;
  cursor: pointer;
  position: absolute;
  top: 0;
  right: 16px;
  left: auto;
  height: 22px;
}

.search-coupon {
  margin: 12px 0;
  text-align: center;
}
.search-coupon label {
  display: inline-block;
  font-size: 14px;
  font-weight: 500;
  color: var(--blueValue);
  margin: auto;
  cursor: pointer;
}
.search-coupon label i {
  margin-right: 8px;
  transform: translateY(1px);
}
.search-coupon label span {
  text-decoration: underline;
}
.search-coupon > div {
  display: none;
  background: #ffffff;
  border: 1px solid #d9e2ec;
  position: relative;
}
.search-coupon > div.search-coupon-agency {
  margin-top: 12px;
}
.search-coupon > div > i {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}
.search-coupon > div > i:first-child {
  font-size: 16px;
  color: var(--blueValue);
  left: 16px;
}
.search-coupon > div > i:last-child {
  display: none;
  width: 19px;
  height: 19px;
  line-height: 19px;
  font-size: 12px;
  background: #f0f4f8;
  color: #009c12;
  border-radius: 50%;
  right: 16px;
}
.search-coupon > div input {
  width: 100%;
  height: 48px;
  line-height: 48px;
  font-size: 14px;
  background: transparent;
  color: #102a43;
  border: 0;
  box-sizing: border-box;
  padding: 0 51px 0 45px;
  position: relative;
}

.search-coupon input::-webkit-input-placeholder {
  color: #bcccdc;
  opacity: 1;
}

.search-coupon input::-moz-placeholder,
.search-coupon input:-moz-placeholder {
  color: #bcccdc;
  opacity: 1;
}

.search-coupon input:-ms-input-placeholder {
  color: #bcccdc;
  opacity: 1;
}

.search-btn {
  width: calc(100% + 32px);
  margin: 24px -16px 0 -16px;
  background: var(--darkblueValue);
  text-align: center;
  position: relative;
}
.search-btn:hover {
  background: var(--darkblueValueRgbLighten);
}
.search-btn.changed > div:first-child {
  animation: bellring 1s infinite ease-in-out;
}
.search-btn > div:first-child {
  width: 32px;
  height: 32px;
  line-height: 32px;
  font-size: 16px;
  background: #ffffff;
  color: var(--darkblueValue);
  border-radius: 50%;
  position: absolute;
  top: 18px;
  left: 24px;
}
.search-btn > div:last-child {
  display: table;
  width: 100%;
  font-size: 16px;
  font-weight: 700;
  color: #ffffff;
  text-transform: uppercase;
  position: absolute;
}
.search-btn > div:last-child > span {
  display: table-cell;
  height: 66px;
  vertical-align: middle;
}
.search-btn input {
  display: block;
  width: 100%;
  height: 66px;
  background: transparent;
  border: 0;
  cursor: pointer;
  position: relative;
  z-index: 2;
}

@keyframes bellring {
  0% {
    transform: rotate(0deg);
  }
  10% {
    transform: rotate(10deg);
  }
  20% {
    transform: rotate(-10deg);
  }
  30% {
    transform: rotate(10deg);
  }
  40% {
    transform: rotate(-10deg);
  }
  50% {
    transform: rotate(0deg);
  }
}
.page-action-services-index .sidebar {
  margin-bottom: 24px;
}

/* ===================================
   CART
=================================== */
#cart {
  background: rgba(255, 255, 255, 0.9);
  padding: 0 16px;
}
#cart.modify {
  margin-top: 24px;
  padding-top: 16px;
}
#cart .search-title {
  font-size: 16px;
}
#cart .cart-item {
  background: #ffffff;
  border: 1px solid #d9e2ec;
  margin-top: 8px;
  position: relative;
}
#cart .cart-item.excluded {
  margin-right: -16px;
  margin-left: -16px;
  padding: 0 16px;
  background: none;
}
#cart .cart-item.excluded .cart-table > div.price {
  padding-right: 0;
}
#cart .cart-item .cart-table {
  display: table;
  width: 100%;
}
#cart .cart-item .cart-table > div {
  display: table-cell;
  padding-top: 16px;
  padding-bottom: 16px;
  vertical-align: top;
}
#cart .cart-item .cart-table > div.type {
  width: 48px;
  position: relative;
}
#cart .cart-item .cart-table > div.type i {
  display: block;
  font-size: 16px;
  color: var(--blueValue);
  position: absolute;
  top: 15px;
  left: 16px;
}
#cart .cart-item .cart-table > div.type i:before {
  font-family: "Font Awesome 5 Pro";
  font-style: normal;
}
#cart .cart-item .cart-table > div.type i.ico0:before {
  content: "\f005";
}
#cart .cart-item .cart-table > div.type i.ico1:before {
  content: "\f236";
}
#cart .cart-item .cart-table > div.type i.ico2:before {
  content: "\f06b";
}
#cart .cart-item .cart-table > div.type i.ico3:before {
  content: "\f3a5";
}
#cart .cart-item .cart-table > div.type i.ico4:before {
  content: "\f005";
}
#cart .cart-item .cart-table > div.type i.ico5:before {
  content: "\f2f7";
}
#cart .cart-item .cart-table > div.name {
  padding-right: 12px;
}
#cart .cart-item .cart-table > div.price {
  font-weight: 900;
  padding-right: 16px;
  text-align: right;
  white-space: nowrap;
}
#cart .cart-item .cart-table > div.price .content-price-rack {
  display: block;
  line-height: 10px;
  font-size: 10px;
  font-weight: 400;
  color: var(--textValue);
}
#cart .cart-item .cart-table > div .subtitle {
  line-height: 18px;
  font-size: 12px;
  color: var(--textValue);
}
#cart .cart-item .cart-item-remove {
  width: 18px;
  height: 18px;
  background: #ffe8e8;
  color: #ab2727;
  position: absolute;
  top: 50%;
  right: -9px;
  z-index: 2;
  border: 1px solid rgba(171, 39, 39, 0.3);
  border-radius: 50%;
  cursor: pointer;
  transform: translateY(-50%);
}
#cart .cart-item .cart-item-remove:hover {
  background: #ab2727;
  color: #ffffff;
}
#cart .cart-item .cart-item-remove:before {
  display: block;
  content: "\f00d";
  height: 18px;
  line-height: 16px;
  font-family: "Font Awesome 5 Pro";
  font-size: 10px;
  text-align: center;
}
#cart .cart-amount {
  display: table;
  width: calc(100% + 32px);
  background: #e6ffe8;
  border: 1px solid rgba(0, 156, 18, 0.2);
  margin: 16px -16px 0 -16px;
}
#cart .cart-amount > div {
  display: table-cell;
  font-size: 12px;
  color: var(--textValue);
  padding: 16px;
  vertical-align: top;
}
#cart .cart-amount > div:last-child {
  text-align: right;
}
#cart .cart-amount > div b {
  font-size: 16px;
  font-weight: 900;
  color: #009c12;
}
#cart .cart-amount .cart-tip {
  font-size: 14px;
  color: #f06f00;
  margin-left: 2px;
  cursor: pointer;
}
#cart .cart-amount .editing > div b {
  color: #627d98;
}
#cart .cart-amount .price > div:last-child {
  font-size: 16px;
  font-weight: 900;
  color: #009c12;
}
#cart .cart-continue {
  height: 48px;
  line-height: 48px;
  font-size: 12px;
  font-weight: 900;
  background: #009c12;
  color: #ffffff;
  margin: 0 -16px;
  cursor: pointer;
  text-align: center;
  text-transform: uppercase;
}
#cart .cart-continue:hover {
  background: #00b615;
}
#cart .cart-continue:before {
  background: #00c016;
}
#cart .cart-continue > span {
  position: relative;
}
#cart .cart-continue > span i {
  font-size: 16px;
  margin-left: 3px;
  transform: translateY(2px);
}
#cart .cart-info {
  font-size: 12px;
  color: var(--textValue);
  padding: 16px 0;
}
#cart .cart-hotel {
  font-weight: 500;
  margin-top: 3px;
}

.page-action-services-confirm #cart {
  padding-top: 16px;
}

/* ===================================
   SIDEBAR
=================================== */
.sidebar-left {
  max-width: 349px;
}
.sidebar-left > div {
  background: #ffffff;
  padding: 24px 16px;
}
.sidebar-left .sidebar-left-info {
  color: var(--textValue);
}
.sidebar-left .sidebar-left-actions > div {
  margin: 24px 8px 0 0;
  letter-spacing: normal;
}

.sidebar-right {
  width: 384px;
  padding-left: 40px;
}
.sidebar-right .pricewidget-adv {
  margin-top: 0;
  margin-bottom: 12px;
}
.sidebar-right .sidebar-msg {
  display: flex;
  align-items: center;
  max-width: 350px;
  background: #e6ffe8;
  color: #009c12;
  border: 1px solid rgba(0, 156, 18, 0.2);
  padding: 12px;
  text-align: left;
}
.sidebar-right .sidebar-msg > div:first-child {
  width: 32px;
  height: 32px;
  line-height: 30px;
  background: #ffffff;
  color: #009c12;
  border: 1px solid rgba(0, 156, 18, 0.2);
  border-radius: 50%;
  text-align: center;
}
.sidebar-right .sidebar-msg > div:nth-child(2) {
  flex: 1;
  line-height: 18px;
  font-size: 12px;
  padding: 0 12px;
}
.sidebar-right .sidebar-msg > div:last-child svg,
.sidebar-right .sidebar-msg > div:last-child img {
  max-width: 50px;
}

/* ===================================
   BANNER
=================================== */
#banners {
  margin-bottom: 24px;
  position: relative;
}
#banners .swiper-slide {
  height: 320px;
  background: #d9e2ec;
  position: relative;
}
#banners .banner-type {
  height: 36px;
  line-height: 36px;
  font-size: 16px;
  background: var(--blueValue);
  color: #ffffff;
  padding: 0 32px 0 16px;
  white-space: nowrap;
  position: absolute;
  top: 8px;
  left: -4px;
  z-index: 2;
}
#banners .banner-image {
  background-size: cover;
  position: absolute;
}
#banners .banner-bottom {
  display: table;
  width: 100%;
  table-layout: fixed;
  position: absolute;
  bottom: 0;
  right: 0;
  left: 0;
}
#banners .banner-bottom > div {
  display: table-cell;
  height: 62px;
  background: #ffffff;
  overflow: hidden;
  vertical-align: middle;
}
#banners .banner-bottom > div:first-child {
  width: 33%;
  background: none;
}
#banners .banner-bottom > div:nth-child(2) {
  padding: 0 16px;
}
#banners .banner-bottom > div.banner-price {
  width: 160px;
  padding: 0 16px;
  color: var(--textValue);
  text-align: right;
  text-transform: lowercase;
}
#banners .banner-bottom > div.banner-price .content-price {
  margin-left: 4px;
}
#banners .banner-bottom > div:last-child {
  width: 160px;
}

.swiper-pagination {
  height: 12px;
  top: 16px;
  right: 16px;
  left: auto !important;
  transform: none !important;
  white-space: nowrap;
}
.swiper-pagination .swiper-pagination-bullet {
  width: 12px;
  height: 12px;
  background: #ffffff;
  border: 1px solid rgba(var(--textValueRGB), 0.2);
  margin: 0 6px;
  opacity: 0.7;
  transform: scale(0.5) !important;
}
.swiper-pagination .swiper-pagination-bullet.swiper-pagination-bullet-active {
  opacity: 1;
}
.swiper-pagination .swiper-pagination-bullet.swiper-pagination-bullet-active-main {
  transform: scale(1) !important;
}
.swiper-pagination .swiper-pagination-bullet.swiper-pagination-bullet-active-prev, .swiper-pagination .swiper-pagination-bullet.swiper-pagination-bullet-active-next {
  transform: scale(0.88) !important;
}

/* ===================================
   CARDS
=================================== */
.card {
  margin-bottom: 24px;
  box-shadow: rgba(123, 135, 148, 0.5) 0 2px 8px;
}
.card .swiper-lazy-preloader {
  width: 36px !important;
  height: 36px;
  margin-left: -18px;
  margin-top: -18px;
}
.card .card-description ul,
.card .card-description p {
  margin: 0;
}
.card .stars {
  font-size: 12px;
  transform: translateY(-1px);
}

.card-type-list,
.card-type-normal,
.card-type-compact {
  display: table;
  width: 100%;
  background: #ffffff;
  table-layout: fixed;
  position: relative;
  z-index: 2;
}
.card-type-list.indexed,
.card-type-normal.indexed,
.card-type-compact.indexed {
  z-index: 3;
}
.card-type-list > div,
.card-type-normal > div,
.card-type-compact > div {
  display: table-cell;
  height: 240px;
  vertical-align: top;
}
.card-type-list > div.card-type-list-row,
.card-type-normal > div.card-type-list-row,
.card-type-compact > div.card-type-list-row {
  height: 62px;
}
.card-type-list .card-content,
.card-type-normal .card-content,
.card-type-compact .card-content {
  border-left: 1px solid #d9e2ec;
}
.card-type-list .card-content > div,
.card-type-normal .card-content > div,
.card-type-compact .card-content > div {
  display: table;
  width: 100%;
}
.card-type-list .card-content > div > div,
.card-type-normal .card-content > div > div,
.card-type-compact .card-content > div > div {
  display: table-cell;
  width: 50%;
  height: 178px;
  padding: 16px;
  vertical-align: top;
  position: relative;
}
.card-type-list .card-content > div > div:first-child:after,
.card-type-normal .card-content > div > div:first-child:after,
.card-type-compact .card-content > div > div:first-child:after {
  content: "";
  width: 1px;
  background: #d9e2ec;
  position: absolute;
  top: 48px;
  right: 0;
  bottom: 16px;
}
.card-type-list .card-content > div.card-bottom,
.card-type-normal .card-content > div.card-bottom,
.card-type-compact .card-content > div.card-bottom {
  background: #f0f4f8;
}
.card-type-list .card-content > div.card-bottom.card-discount-block,
.card-type-normal .card-content > div.card-bottom.card-discount-block,
.card-type-compact .card-content > div.card-bottom.card-discount-block {
  display: none;
}
.card-type-list .card-content > div.card-bottom.card-discount-block.open,
.card-type-normal .card-content > div.card-bottom.card-discount-block.open,
.card-type-compact .card-content > div.card-bottom.card-discount-block.open {
  display: table;
}
.card-type-list .card-content > div.card-bottom > div,
.card-type-normal .card-content > div.card-bottom > div,
.card-type-compact .card-content > div.card-bottom > div {
  width: auto;
  height: 62px;
  font-size: 12px;
  color: var(--textValue);
  padding: 0;
  vertical-align: middle;
}
.card-type-list .card-content > div.card-bottom > div:first-child,
.card-type-normal .card-content > div.card-bottom > div:first-child,
.card-type-compact .card-content > div.card-bottom > div:first-child {
  padding: 0 16px;
}
.card-type-list .card-content > div.card-bottom > div:first-child:after,
.card-type-normal .card-content > div.card-bottom > div:first-child:after,
.card-type-compact .card-content > div.card-bottom > div:first-child:after {
  display: none;
}
.card-type-list .card-content > div.card-bottom > div:first-child i,
.card-type-normal .card-content > div.card-bottom > div:first-child i,
.card-type-compact .card-content > div.card-bottom > div:first-child i {
  font-size: 14px;
  color: #bcccdc;
  margin-right: 8px;
}
.card-type-list .card-content > div.card-bottom > div:first-child i.fa-clock,
.card-type-normal .card-content > div.card-bottom > div:first-child i.fa-clock,
.card-type-compact .card-content > div.card-bottom > div:first-child i.fa-clock {
  transform: translateY(2px);
}
.card-type-list .card-content > div.card-bottom > div:first-child .card-unit-value,
.card-type-normal .card-content > div.card-bottom > div:first-child .card-unit-value,
.card-type-compact .card-content > div.card-bottom > div:first-child .card-unit-value {
  margin-left: 5px;
}
.card-type-list .card-content > div.card-bottom > div.card-price,
.card-type-normal .card-content > div.card-bottom > div.card-price,
.card-type-compact .card-content > div.card-bottom > div.card-price {
  width: 162px;
  padding: 0 16px;
  text-align: right;
  text-transform: lowercase;
}
.card-type-list .card-content > div.card-bottom > div.card-price .content-price,
.card-type-normal .card-content > div.card-bottom > div.card-price .content-price,
.card-type-compact .card-content > div.card-bottom > div.card-price .content-price {
  margin-left: 4px;
}
.card-type-list .card-content > div.card-bottom > div.card-price .content-price-rack,
.card-type-normal .card-content > div.card-bottom > div.card-price .content-price-rack,
.card-type-compact .card-content > div.card-bottom > div.card-price .content-price-rack {
  text-transform: uppercase;
}
.card-type-list .card-content > div.card-bottom > div:last-child,
.card-type-normal .card-content > div.card-bottom > div:last-child,
.card-type-compact .card-content > div.card-bottom > div:last-child {
  width: 160px;
}
.card-type-list .card-content .content-title,
.card-type-normal .card-content .content-title,
.card-type-compact .card-content .content-title {
  margin-bottom: 8px;
}
.card-type-list .card-content .card-address,
.card-type-normal .card-content .card-address,
.card-type-compact .card-content .card-address {
  margin-top: -8px;
  margin-bottom: 8px;
}
.card-type-list .card-content .card-address .load-map,
.card-type-normal .card-content .card-address .load-map,
.card-type-compact .card-content .card-address .load-map {
  color: var(--blueValue);
  text-decoration: underline;
}
.card-type-list .card-content .card-dependency,
.card-type-normal .card-content .card-dependency,
.card-type-compact .card-content .card-dependency {
  margin: -8px 0 8px 0;
}
.card-type-list .card-content .card-description,
.card-type-normal .card-content .card-description,
.card-type-compact .card-content .card-description {
  display: block;
  display: -webkit-box;
  height: 66px;
  color: var(--textValue);
  text-overflow: ellipsis;
  overflow: hidden;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
}
.card-type-list .card-content .content-list > h3,
.card-type-normal .card-content .content-list > h3,
.card-type-compact .card-content .content-list > h3 {
  font-size: 16px;
  font-weight: 500;
}
.card-type-list .card-score,
.card-type-normal .card-score,
.card-type-compact .card-score {
  display: inline-flex;
  line-height: 20px;
  text-decoration: none;
}
.card-type-list .card-score:hover .card-score-count,
.card-type-normal .card-score:hover .card-score-count,
.card-type-compact .card-score:hover .card-score-count {
  text-decoration: underline;
}
.card-type-list .card-score i,
.card-type-normal .card-score i,
.card-type-compact .card-score i {
  display: block;
  width: 38px;
  height: 38px;
  line-height: 36px;
  font-size: 18px !important;
  background: #ffffff;
  color: #009c12 !important;
  border: 1px solid rgba(0, 156, 18, 0.2);
  border-radius: 50%;
  margin-right: 12px;
  text-align: center;
}
.card-type-list .card-score .card-score-avg,
.card-type-normal .card-score .card-score-avg,
.card-type-compact .card-score .card-score-avg {
  font-size: 18px;
  font-weight: 900;
  color: #009c12;
}
.card-type-list .card-score .card-score-count,
.card-type-normal .card-score .card-score-count,
.card-type-compact .card-score .card-score-count {
  font-size: 12px;
  color: var(--textValue);
}
.card-type-list .card-free-canc,
.card-type-normal .card-free-canc,
.card-type-compact .card-free-canc {
  display: inline-block;
  font-size: 12px;
  background: rgba(0, 0, 0, 0.9);
  color: #ffffff;
  padding: 8px;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 3;
}
.card-type-list .content-button-select,
.card-type-normal .content-button-select,
.card-type-compact .content-button-select {
  width: 162px;
}

.card-type-emotional,
.card-type-emotionalcompact {
  color: #ffffff;
  padding-left: 16px;
  text-shadow: rgba(0, 0, 0, 0.2) 0 2px 4px;
  position: relative;
  z-index: 2;
}
.card-type-emotional.indexed,
.card-type-emotionalcompact.indexed {
  z-index: 3;
}
.card-type-emotional .card-image,
.card-type-emotionalcompact .card-image {
  background-color: #d9e2ec;
  background-size: cover;
  position: absolute;
}
.card-type-emotional .card-image:before,
.card-type-emotionalcompact .card-image:before {
  content: "";
  background-image: linear-gradient(to right, rgba(0, 0, 0, 0.4), rgba(255, 255, 255, 0));
  position: absolute;
}
.card-type-emotional .card-content,
.card-type-emotionalcompact .card-content {
  display: table;
  width: calc(50% - 76px);
  height: 300px;
  position: relative;
}
.card-type-emotional .card-content > div,
.card-type-emotionalcompact .card-content > div {
  display: table-row;
  height: 50%;
  vertical-align: top;
}
.card-type-emotional .card-content .content-title,
.card-type-emotionalcompact .card-content .content-title {
  line-height: 28px;
  font-size: 22px;
  margin-top: 16px;
}
.card-type-emotional .card-content .content-title .card-unit,
.card-type-emotionalcompact .card-content .content-title .card-unit {
  display: inline-block;
  font-size: 14px;
  font-weight: 400;
  margin-left: 8px;
}
.card-type-emotional .card-content .card-description,
.card-type-emotionalcompact .card-content .card-description {
  margin-top: 8px;
}
.card-type-emotional .card-content .card-description .content-continue,
.card-type-emotionalcompact .card-content .card-description .content-continue {
  color: #ffffff;
}
.card-type-emotional .card-content .content-desc-continue,
.card-type-emotionalcompact .card-content .content-desc-continue {
  color: #ffffff;
}
.card-type-emotional .card-content .content-list > div,
.card-type-emotionalcompact .card-content .content-list > div {
  display: table-cell;
  padding: 24px 0;
}
.card-type-emotional .card-content .content-list > div > h3,
.card-type-emotionalcompact .card-content .content-list > div > h3 {
  font-size: 16px;
  font-weight: 500;
}
.card-type-emotional .card-content .content-list ul li,
.card-type-emotionalcompact .card-content .content-list ul li {
  color: #ffffff;
}
.card-type-emotional .card-content .content-list ul li.card-services-more,
.card-type-emotionalcompact .card-content .content-list ul li.card-services-more {
  color: #ffffff;
}
.card-type-emotional .card-content .content-list ul li.card-services-more > div:first-child i,
.card-type-emotionalcompact .card-content .content-list ul li.card-services-more > div:first-child i {
  background: #ffffff;
  color: #102a43;
}
.card-type-emotional .card-content .content-list ul li > div:first-child,
.card-type-emotionalcompact .card-content .content-list ul li > div:first-child {
  color: #ffffff;
}
.card-type-emotional .card-content .content-list ul li img path,
.card-type-emotional .card-content .content-list ul li svg path,
.card-type-emotionalcompact .card-content .content-list ul li img path,
.card-type-emotionalcompact .card-content .content-list ul li svg path {
  fill: #ffffff;
}
.card-type-emotional .card-content .content-list ul li a,
.card-type-emotionalcompact .card-content .content-list ul li a {
  color: #ffffff;
}
.card-type-emotional .card-content .card-actions-services > div,
.card-type-emotionalcompact .card-content .card-actions-services > div {
  display: table-cell;
  padding-bottom: 16px;
  vertical-align: bottom;
}
.card-type-emotional .card-action,
.card-type-emotionalcompact .card-action {
  display: flex;
  text-shadow: none;
  position: absolute;
  top: 0;
  right: 0;
}
.card-type-emotional .card-action > div,
.card-type-emotionalcompact .card-action > div {
  display: inline-block;
  height: 32px;
  line-height: 32px;
  font-size: 12px;
  background: rgba(0, 0, 0, 0.7);
  padding: 0 8px;
  cursor: pointer;
}
.card-type-emotional .card-action > div.card-best-rate,
.card-type-emotionalcompact .card-action > div.card-best-rate {
  margin-right: 1px;
}
.card-type-emotional .card-action > div.card-action-gallery,
.card-type-emotionalcompact .card-action > div.card-action-gallery {
  margin-left: 1px;
}
.card-type-emotional .card-action > div.card-action-gallery:hover,
.card-type-emotionalcompact .card-action > div.card-action-gallery:hover {
  text-decoration: underline;
}
.card-type-emotional .card-action > div.card-action-gallery a,
.card-type-emotionalcompact .card-action > div.card-action-gallery a {
  color: #ffffff;
  text-decoration: none;
}
.card-type-emotional .card-action > div.card-score:hover,
.card-type-emotionalcompact .card-action > div.card-score:hover {
  text-decoration: underline;
}
.card-type-emotional .card-action > div.card-score a,
.card-type-emotionalcompact .card-action > div.card-score a {
  color: #ffffff;
  text-decoration: none;
}
.card-type-emotional .card-action > div i,
.card-type-emotionalcompact .card-action > div i {
  font-size: 14px;
  margin-right: 6px;
  transform: translateY(1px);
}
.card-type-emotional .card-free-canc,
.card-type-emotionalcompact .card-free-canc {
  display: inline-block;
  font-size: 12px;
  background: rgba(0, 0, 0, 0.7);
  color: #ffffff;
  padding: 8px;
  position: absolute;
  top: 0;
  right: 0;
  z-index: 3;
}
.card-type-emotional .card-bottom,
.card-type-emotionalcompact .card-bottom {
  max-width: 50%;
  text-shadow: none;
  position: absolute;
  bottom: 0;
  right: 0;
}
.card-type-emotional .card-bottom.card-discount-block,
.card-type-emotionalcompact .card-bottom.card-discount-block {
  display: none;
}
.card-type-emotional .card-bottom.card-discount-block.open,
.card-type-emotionalcompact .card-bottom.card-discount-block.open {
  display: table;
}
.card-type-emotional .card-bottom > div,
.card-type-emotionalcompact .card-bottom > div {
  display: table-cell;
  height: 70px;
  vertical-align: middle;
}
.card-type-emotional .card-bottom > div.card-price,
.card-type-emotionalcompact .card-bottom > div.card-price {
  min-width: 160px;
  background: rgba(0, 0, 0, 0.7);
  padding: 12px 16px;
  text-shadow: rgba(0, 0, 0, 0.6) 0 3px 6px;
  text-transform: lowercase;
}
.card-type-emotional .card-bottom > div.card-price > span,
.card-type-emotionalcompact .card-bottom > div.card-price > span {
  color: #ffffff;
}
.card-type-emotional .card-bottom > div.card-price > span.content-blur,
.card-type-emotionalcompact .card-bottom > div.card-price > span.content-blur {
  text-shadow: 0 0 8px #ffffff;
}
.card-type-emotional .card-bottom > div.card-price > div,
.card-type-emotionalcompact .card-bottom > div.card-price > div {
  text-transform: initial;
}
.card-type-emotional .card-bottom > div.card-price > div.card-unit-cross .card-unit-value,
.card-type-emotionalcompact .card-bottom > div.card-price > div.card-unit-cross .card-unit-value {
  margin-left: 5px;
}
.card-type-emotional .card-bottom > div .card-conditions,
.card-type-emotionalcompact .card-bottom > div .card-conditions {
  white-space: nowrap;
}
.card-type-emotional .card-bottom > div .content-button-compact a,
.card-type-emotionalcompact .card-bottom > div .content-button-compact a {
  background: rgba(188, 204, 220, 0.7);
  color: #102a43;
}
.card-type-emotional .content-button-select .select-styled,
.card-type-emotionalcompact .content-button-select .select-styled {
  width: 162px;
  line-height: 70px;
  left: auto;
}
.card-type-emotional .content-button-select .select-options,
.card-type-emotionalcompact .content-button-select .select-options {
  width: 162px;
  left: auto;
}

.card-slider {
  width: 33%;
  background-color: #e4f0fa;
  cursor: pointer;
  position: relative;
}
.card-slider:hover .card-slider-controls {
  opacity: 1;
  visibility: visible;
}
.card-slider .swiper-container {
  height: 100%;
}
.card-slider .swiper-slide {
  background-size: cover;
}
.card-slider .card-slider-controls {
  opacity: 0;
  visibility: hidden;
}
.card-slider .card-slider-controls i {
  display: block;
  width: 90px;
  font-size: 16px;
  color: #ffffff;
  cursor: pointer;
  position: absolute;
  top: 0;
  bottom: 0;
  z-index: 2;
}
.card-slider .card-slider-controls i:first-child {
  background: linear-gradient(to right, rgba(0, 0, 0, 0.6), rgba(255, 255, 255, 0));
  left: 0;
}
.card-slider .card-slider-controls i:first-child:before {
  left: 16px;
}
.card-slider .card-slider-controls i:last-child {
  background: linear-gradient(to left, rgba(0, 0, 0, 0.6), rgba(255, 255, 255, 0));
  right: 0;
}
.card-slider .card-slider-controls i:last-child:before {
  right: 16px;
}
.card-slider .card-slider-controls i:before {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}
.card-slider .card-size {
  height: 31px;
  line-height: 31px;
  font-size: 12px;
  background: #ffffff;
  color: var(--textValue);
  padding: 0 8px;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 3;
}
.card-slider .card-size i {
  font-size: 14px;
  color: var(--blueValue);
  margin-right: 6px;
  transform: translateY(1px);
}
.card-slider .card-best-rate {
  height: 31px;
  line-height: 29px;
  font-size: 14px;
  background: #ffffff;
  color: #009c12;
  padding: 0 14px;
  position: absolute;
  top: 0;
  right: 0;
  z-index: 3;
}
.card-slider .card-best-rate i {
  margin-right: 3px;
  transform: translateY(1px);
}
.card-slider .card-best-rate span {
  font-size: 12px;
  color: var(--textValue);
}
.card-slider .card-slider-link {
  display: block;
  width: 100%;
  height: 100%;
  background-position: 50% 50%;
  background-size: cover;
}

@-moz-document url-prefix() {
  .card-slider .swiper-container {
    min-height: 240px;
    position: absolute !important;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
  }
}
.card-table-separator, .card-rates .card-service-table > div:after, .card-rates .card-sale-table:after, .card-rates .card-sale-table:before, .card-rates .card-rate-table > div:first-child:after, .card-rates .card-rates-head > div:after {
  content: "";
  width: 1px;
  background: #bcccdc;
  position: absolute;
  right: 0;
}

.card-rates {
  margin: -24px 0 24px 0;
  box-shadow: rgba(123, 135, 148, 0.5) 0 2px 8px;
}
.card-rates.card-compact, .card-rates.card-hidden {
  display: none;
}
.card-rates .card-rates-head {
  display: table;
  width: 100%;
  table-layout: fixed;
}
.card-rates .card-rates-head > div {
  display: table-cell;
  font-size: 12px;
  background: #d9e2ec;
  padding: 10px 16px;
  vertical-align: middle;
  position: relative;
}
.card-rates .card-rates-head > div.nb:after {
  display: none;
}
.card-rates .card-rates-head > div:first-child {
  width: 33%;
}
.card-rates .card-rates-head > div:nth-child(3), .card-rates .card-rates-head > div:nth-child(4) {
  width: 160px;
}
.card-rates .card-rates-head > div:last-child:after {
  display: none;
}
.card-rates .card-rates-head > div:last-child .triangle {
  position: relative;
}
.card-rates .card-rates-head > div:last-child .triangle:after {
  content: "";
  position: absolute;
  width: 0;
  height: 0;
  top: -35px;
  left: 50%;
  z-index: 2;
  border: 8px solid;
  border-color: transparent transparent #d9e2ec #d9e2ec;
  box-shadow: rgba(123, 135, 148, 0.3) -4px 4px 4px 0;
  transform: rotate(-45deg) translateX(-50%);
}
.card-rates .card-rates-head > div:last-child .details {
  text-align: center;
  text-transform: lowercase;
  position: absolute;
  top: 10px;
  right: 0;
  left: 0;
}
.card-rates .card-rates-head > div:last-child .details i {
  position: relative;
  top: auto;
  right: auto;
  transform: translateY(1px);
}
.card-rates .card-rates-head > div:after {
  top: 8px;
  bottom: 8px;
}
.card-rates .card-rates-toggle {
  cursor: pointer;
}
.card-rates .card-rates-toggle.toggled > div:first-child:after, .card-rates .card-rates-toggle.toggled > div:nth-child(2):after, .card-rates .card-rates-toggle.toggled > div:nth-child(3):after {
  display: none;
}
.card-rates .card-rates-toggle.toggled > div:first-child i, .card-rates .card-rates-toggle.toggled > div:nth-child(2) i, .card-rates .card-rates-toggle.toggled > div:nth-child(3) i {
  display: none;
}
.card-rates .card-rates-toggle.toggled > div:nth-child(2), .card-rates .card-rates-toggle.toggled > div:nth-child(3) {
  color: #d9e2ec;
}
.card-rates .card-rates-toggle.odd.toggled > div:nth-child(2), .card-rates .card-rates-toggle.odd.toggled > div:nth-child(3) {
  color: #bcccdc;
}
.card-rates .card-rates-toggle.odd > div {
  background: #bcccdc;
}
.card-rates .card-rates-toggle > div i {
  font-size: 14px;
  color: var(--textValue);
  margin-left: 8px;
  position: absolute;
  top: 14px;
  right: 16px;
}
.card-rates .card-rate-table {
  display: table;
  width: 100%;
  table-layout: fixed;
  border-bottom: 1px solid #d0def0;
}
.card-rates .card-rate-table:nth-child(odd) > div {
  background: #f0f4f8;
}
.card-rates .card-rate-table:nth-child(odd) .card-sale-table > div:before {
  background: #f0f4f8;
}
.card-rates .card-rate-table:last-child {
  border: 0;
}
.card-rates .card-rate-table.card-rate-table-best:nth-child(2) {
  border: 1px solid #b7ecbd;
}
.card-rates .card-rate-table.card-rate-table-best:nth-child(2) > div {
  background: #e6ffe8;
}
.card-rates .card-rate-table.card-rate-table-best:nth-child(2) > div:first-child:after {
  background: #b7ecbd;
}
.card-rates .card-rate-table.card-rate-table-best:nth-child(2) .card-sale-table:before, .card-rates .card-rate-table.card-rate-table-best:nth-child(2) .card-sale-table:after {
  background: #b7ecbd;
}
.card-rates .card-rate-table.card-rate-table-best:nth-child(2) .card-sale-table:first-child .card-best-rate {
  display: block;
}
.card-rates .card-rate-table.card-rate-table-best:nth-child(2) .card-sale-table > div:before {
  background: #e6ffe8;
}
.card-rates .card-rate-table.card-rate-table-best:nth-child(2) .popup-best-rate-best-rate {
  display: block;
}
.card-rates .card-rate-table > div {
  display: table-cell;
  background: #ffffff;
  vertical-align: middle;
  position: relative;
}
.card-rates .card-rate-table > div:first-child {
  width: 33%;
  padding: 16px;
  vertical-align: top;
}
.card-rates .card-rate-table > div:first-child:after {
  top: 12px;
  bottom: 12px;
}
.card-rates .card-rate-table .card-cross-room {
  padding-left: 0;
}
.card-rates .card-rate-table .card-cross-room:first-child {
  margin-top: 0;
}
.card-rates .card-rate-table .card-cross-room .card-date {
  color: var(--textValue);
}
.card-rates .card-rate-table .room-solution-title {
  cursor: pointer;
}
.card-rates .card-rate-table .content-price {
  cursor: pointer;
}
.card-rates .card-sale-table {
  display: table;
  width: 100%;
  line-height: 18px;
}
.card-rates .card-sale-table:first-child > div {
  padding-top: 16px;
}
.card-rates .card-sale-table:first-child > div:before {
  display: none;
}
.card-rates .card-sale-table:before {
  top: 12px;
  right: 160px;
  bottom: 12px;
}
.card-rates .card-sale-table:after {
  top: 12px;
  right: 320px;
  bottom: 12px;
}
.card-rates .card-sale-table > div {
  display: table-cell;
  padding: 4px 16px 16px 16px;
  position: relative;
  vertical-align: middle;
}
.card-rates .card-sale-table > div:nth-child(2), .card-rates .card-sale-table > div:last-child {
  width: 160px;
}
.card-rates .card-sale-table > div:before {
  content: "";
  height: 12px;
  background: #ffffff;
  position: absolute;
  top: -12px;
  right: 0;
  left: -1px;
  z-index: 2;
}
.card-rates .card-sale-table .content-add {
  display: block;
}
.card-rates .card-sale-table .card-best-rate {
  display: none;
  font-size: 14px;
  color: #009c12;
}
.card-rates .card-sale-table .card-best-rate i {
  margin-right: 3px;
  transform: translateY(1px);
}
.card-rates .card-sale-table .card-best-rate span {
  font-size: 12px;
}
.card-rates .card-sale-mealplan {
  cursor: pointer;
}
.card-rates .card-sale-label {
  line-height: 22px;
  font-size: 12px;
  color: var(--textValue);
}
.card-rates .card-free-canc {
  font-size: 12px;
  color: #009c12;
  margin-top: 2px;
}
.card-rates .card-services.closed {
  display: none;
}
.card-rates .card-service-table {
  display: table;
  width: 100%;
  table-layout: fixed;
  border-bottom: 1px solid #d0def0;
}
.card-rates .card-service-table:last-child {
  border: 0;
}
.card-rates .card-service-table:nth-child(even) > div {
  background: #f0f4f8;
}
.card-rates .card-service-table > div {
  display: table-cell;
  background: #ffffff;
  padding: 15px 16px;
  vertical-align: middle;
  position: relative;
  white-space: nowrap;
}
.card-rates .card-service-table > div.nb:after {
  display: none;
}
.card-rates .card-service-table > div:first-child {
  width: 33%;
}
.card-rates .card-service-table > div:nth-child(3), .card-rates .card-service-table > div:nth-child(4) {
  width: 160px;
}
.card-rates .card-service-table > div:last-child:after {
  display: none;
}
.card-rates .card-service-table > div:after {
  top: 8px;
  bottom: 8px;
}
.card-rates .card-service-table .content-button-select {
  width: auto;
}
.card-rates .card-service-table .content-button-select .select-styled {
  height: 30px;
  line-height: 30px;
  top: 9px;
  right: 16px;
  left: 16px;
}
.card-rates .card-service-table .content-button-select .select-styled span i {
  display: none;
}
.card-rates .card-service-table .content-button-select .select-options {
  top: calc(100% - 13px);
  right: 16px;
  left: 16px;
}
.card-rates .card-conditions {
  display: inline-block;
  font-size: 11px;
  font-style: italic;
  margin-top: 2px;
  cursor: pointer;
  position: relative;
}
.card-rates .card-conditions:hover:after {
  border-bottom-style: solid;
}
.card-rates .card-conditions:after {
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  left: 14px;
}
.card-rates .card-conditions i {
  margin-right: 2px;
}
.card-rates .content-price {
  color: #102a43;
}

.card-details {
  font-size: 12px;
  color: var(--blueValue);
  cursor: pointer;
  text-decoration: underline;
}

.card-insurance-info,
.card-insurance {
  color: #009c12;
  line-height: 14px;
  font-size: 12px;
  margin: 2px 0;
}

.card-insurance {
  cursor: pointer;
}
.card-insurance:hover {
  text-decoration: underline;
}

.card-persuasive.mb {
  margin-bottom: 4px;
}
.card-persuasive.mb > div {
  margin-top: 0;
  margin-bottom: 4px;
}
.card-persuasive > div {
  display: inline-block;
  line-height: 14px;
  font-size: 12px;
  background: #e6ffe8;
  color: #009c12;
  border: 1px solid rgba(0, 156, 18, 0.2);
  border-radius: 20px;
  margin: 4px 8px 0 0;
  padding: 2px 6px;
  letter-spacing: normal;
  vertical-align: top;
}
.card-persuasive > div.blue {
  background: #e6f3ff;
  color: #00529c;
  border-color: rgba(0, 82, 156, 0.2);
}
.card-persuasive > div.brown {
  background: #edcf9e;
  color: #533c17;
  border-color: rgba(83, 60, 23, 0.2);
}
.card-persuasive > div.yellow {
  background: #fffae6;
  color: #9c7e00;
  border-color: rgba(156, 126, 0, 0.2);
}
.card-persuasive > div.magenta {
  background: #ffd6ed;
  color: #f00f66;
  border-color: rgba(240, 15, 102, 0.2);
}
.card-persuasive > div.orange {
  background: #ffe2b4;
  color: #f06f00;
  border-color: rgba(240, 111, 0, 0.2);
}
.card-persuasive > div.red {
  background: #ffe8e8;
  color: #ab2727;
  border-color: rgba(171, 39, 39, 0.2);
}
.card-persuasive > div.white {
  background: #ffffff;
  color: var(--textValue);
  border-color: rgba(var(--textValueRGB), 0.2);
}

.card-discount {
  display: inline-block;
  background: #e6ffe8;
  color: #009c12;
  border: 1px solid rgba(0, 156, 18, 0.2);
  margin-top: 8px;
  overflow: hidden;
  position: relative;
}
.card-discount.change {
  background: #d9e2ec;
  color: var(--textValue);
}
.card-discount.change select {
  color: var(--textValue);
}
.card-discount:after {
  content: "\f107";
  font-family: "Font Awesome 5 Pro";
  font-size: 14px;
  font-weight: 300;
  position: absolute;
  top: 50%;
  right: 8px;
  transform: translateY(-50%);
}
.card-discount select {
  display: block;
  font-size: 14px;
  background: transparent;
  color: #009c12;
  padding: 6px 30px 6px 8px;
  border: 0;
  box-sizing: border-box;
  cursor: pointer;
  position: relative;
  z-index: 2;
}
.card-discount option {
  background: #ffffff;
  color: #000;
}

.card-cross .card-slider {
  cursor: default;
  overflow: hidden;
}
.card-cross .card-slider > div {
  width: 100%;
  height: 100%;
  position: absolute;
  overflow: hidden;
  transform: skewX(-52.2deg);
}
.card-cross .card-slider > div:first-child {
  left: -1px;
  transform-origin: 100% 0;
}
.card-cross .card-slider > div:last-child {
  right: -1px;
  transform-origin: 0 100%;
}
.card-cross .card-slider > div > div {
  background-size: cover;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  transform: skewX(52.2deg);
  transform-origin: inherit;
}
.card-cross .card-cross-room {
  margin-top: 16px;
  padding-left: 9px;
  position: relative;
}
.card-cross .card-cross-line {
  border-left: 1px dashed #d9e2ec;
  position: absolute;
  top: 12px;
  left: 0;
  bottom: -28px;
}
.card-cross .card-cross-line:before, .card-cross .card-cross-line:after {
  content: "";
  width: 5px;
  height: 5px;
  background: #ffffff;
  border: 1px solid #d9e2ec;
  border-radius: 50%;
  position: absolute;
  left: -4px;
}
.card-cross .card-cross-line:before {
  top: -3px;
}
.card-cross .card-cross-line:after {
  bottom: -3px;
}
.card-cross.card-type-normal .card-cross-room:first-child, .card-cross.card-type-compact .card-cross-room:first-child {
  margin-top: 0;
}
.card-cross.card-type-normal .card-content .card-date, .card-cross.card-type-compact .card-content .card-date {
  color: var(--textValue);
}
.card-cross.card-type-normal .card-content .content-title, .card-cross.card-type-compact .card-content .content-title {
  margin-bottom: 0;
}
.card-cross.card-type-emotional .card-cross-line, .card-cross.card-type-emotionalcompact .card-cross-line {
  border-color: #ffffff;
}
.card-cross.card-type-emotional .card-cross-line:before, .card-cross.card-type-emotional .card-cross-line:after, .card-cross.card-type-emotionalcompact .card-cross-line:before, .card-cross.card-type-emotionalcompact .card-cross-line:after {
  border-color: #ffffff;
}
.card-cross.card-type-emotional .card-content .content-title, .card-cross.card-type-emotionalcompact .card-content .content-title {
  margin-top: 0;
}
.card-cross.card-type-emotional .card-content .card-details, .card-cross.card-type-emotionalcompact .card-content .card-details {
  color: #ffffff;
}

.card-offers {
  margin: -24px 0 24px 0;
  box-shadow: rgba(123, 135, 148, 0.5) 0 2px 8px;
}
.card-offers.card-compact {
  display: none;
}
.card-offers .triangle {
  position: relative;
}
.card-offers .triangle:after {
  content: "";
  position: absolute;
  width: 0;
  height: 0;
  top: -15px;
  right: 66px;
  z-index: 2;
  border: 8px solid;
  border-color: transparent transparent #d9e2ec #d9e2ec;
  box-shadow: rgba(123, 135, 148, 0.3) -4px 4px 4px 0;
  transform: rotate(-45deg) translateX(-50%);
}
.card-offers .card-offer {
  display: table;
  width: 100%;
  background: #ffffff;
  border-bottom: 1px solid #d0def0;
}
.card-offers .card-offer:last-child {
  border-bottom: 0;
}
.card-offers .card-offer > div {
  display: table-cell;
  padding: 16px;
  vertical-align: middle;
}
.card-offers .card-offer > div .content-add {
  width: auto;
  margin-left: auto;
}
.card-offers .card-offer > div .content-add span {
  width: auto;
}
.card-offers .card-offer > div .content-add i {
  margin-left: 4px;
}

.page-action-simple-step3 .services .card-type-list .card-conditions,
.page-action-simple-step3 .services .card-type-normal .card-conditions,
.page-action-simple-step3 .services .card-type-compact .card-conditions,
.page-action-services-index .services .card-type-list .card-conditions,
.page-action-services-index .services .card-type-normal .card-conditions,
.page-action-services-index .services .card-type-compact .card-conditions {
  font-size: 10px;
  color: #102a43;
  cursor: pointer;
}
.page-action-simple-step3 .services .card-type-list .card-conditions i,
.page-action-simple-step3 .services .card-type-normal .card-conditions i,
.page-action-simple-step3 .services .card-type-compact .card-conditions i,
.page-action-services-index .services .card-type-list .card-conditions i,
.page-action-services-index .services .card-type-normal .card-conditions i,
.page-action-services-index .services .card-type-compact .card-conditions i {
  font-size: 10px !important;
  color: #102a43 !important;
  margin-right: 4px !important;
}
.page-action-simple-step3 .services .card-type-list .card-service-title,
.page-action-simple-step3 .services .card-type-normal .card-service-title,
.page-action-simple-step3 .services .card-type-compact .card-service-title,
.page-action-services-index .services .card-type-list .card-service-title,
.page-action-services-index .services .card-type-normal .card-service-title,
.page-action-services-index .services .card-type-compact .card-service-title {
  max-width: 45%;
}
.page-action-simple-step3 .services .card-type-list .card-service-title h2,
.page-action-simple-step3 .services .card-type-normal .card-service-title h2,
.page-action-simple-step3 .services .card-type-compact .card-service-title h2,
.page-action-services-index .services .card-type-list .card-service-title h2,
.page-action-services-index .services .card-type-normal .card-service-title h2,
.page-action-services-index .services .card-type-compact .card-service-title h2 {
  font-size: 18px;
  font-weight: 900;
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
}
.page-action-simple-step3 .services .card-type-list .card-service-title h2.card-service-title-cliccable,
.page-action-simple-step3 .services .card-type-normal .card-service-title h2.card-service-title-cliccable,
.page-action-simple-step3 .services .card-type-compact .card-service-title h2.card-service-title-cliccable,
.page-action-services-index .services .card-type-list .card-service-title h2.card-service-title-cliccable,
.page-action-services-index .services .card-type-normal .card-service-title h2.card-service-title-cliccable,
.page-action-services-index .services .card-type-compact .card-service-title h2.card-service-title-cliccable {
  cursor: pointer;
}
.page-action-simple-step3 .services .card-type-list .card-service-title h2 i,
.page-action-simple-step3 .services .card-type-normal .card-service-title h2 i,
.page-action-simple-step3 .services .card-type-compact .card-service-title h2 i,
.page-action-services-index .services .card-type-list .card-service-title h2 i,
.page-action-services-index .services .card-type-normal .card-service-title h2 i,
.page-action-services-index .services .card-type-compact .card-service-title h2 i {
  margin-left: 4px;
}
.page-action-simple-step3 .services .card-type-list .card-unit,
.page-action-simple-step3 .services .card-type-normal .card-unit,
.page-action-simple-step3 .services .card-type-compact .card-unit,
.page-action-services-index .services .card-type-list .card-unit,
.page-action-services-index .services .card-type-normal .card-unit,
.page-action-services-index .services .card-type-compact .card-unit {
  font-size: 14px;
}
.page-action-simple-step3 .services .card-type-emotional .card-conditions,
.page-action-simple-step3 .services .card-type-emotionalcompact .card-conditions,
.page-action-services-index .services .card-type-emotional .card-conditions,
.page-action-services-index .services .card-type-emotionalcompact .card-conditions {
  font-size: 12px;
  color: #ffffff;
  cursor: pointer;
  text-shadow: rgba(0, 0, 0, 0.6) 0 3px 6px;
}
.page-action-simple-step3 .services .card-type-emotional .card-conditions i,
.page-action-simple-step3 .services .card-type-emotionalcompact .card-conditions i,
.page-action-services-index .services .card-type-emotional .card-conditions i,
.page-action-services-index .services .card-type-emotionalcompact .card-conditions i {
  font-size: 12px !important;
  color: #ffffff !important;
  margin-right: 4px !important;
}
.page-action-simple-step3 .services .card-type-emotional .cart-gross,
.page-action-simple-step3 .services .card-type-emotional .content-price,
.page-action-simple-step3 .services .card-type-emotional .content-price-rack,
.page-action-simple-step3 .services .card-type-emotionalcompact .cart-gross,
.page-action-simple-step3 .services .card-type-emotionalcompact .content-price,
.page-action-simple-step3 .services .card-type-emotionalcompact .content-price-rack,
.page-action-services-index .services .card-type-emotional .cart-gross,
.page-action-services-index .services .card-type-emotional .content-price,
.page-action-services-index .services .card-type-emotional .content-price-rack,
.page-action-services-index .services .card-type-emotionalcompact .cart-gross,
.page-action-services-index .services .card-type-emotionalcompact .content-price,
.page-action-services-index .services .card-type-emotionalcompact .content-price-rack {
  display: inline-block;
  color: #ffffff;
}
.page-action-simple-step3 .services .card-price-noqnt,
.page-action-services-index .services .card-price-noqnt {
  padding-right: 210px !important;
}

.page-action-simple-step3 .services .card-type-list .card-bottom-list,
.page-action-services-index .services .card-type-list .card-bottom-list {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: space-between;
  align-content: center;
  align-items: center;
  width: 100%;
  padding-right: 0 !important;
}
.page-action-simple-step3 .services .card-type-list .card-bottom-list > div,
.page-action-services-index .services .card-type-list .card-bottom-list > div {
  display: inline-flex;
  flex-direction: column;
}
.page-action-simple-step3 .services .card-type-list .card-bottom-list > div:nth-child(2),
.page-action-services-index .services .card-type-list .card-bottom-list > div:nth-child(2) {
  flex-direction: column;
  margin-left: auto;
  margin-right: 8px;
}
.page-action-simple-step3 .services .card-type-list .card-bottom-list > div:nth-child(2) div,
.page-action-services-index .services .card-type-list .card-bottom-list > div:nth-child(2) div {
  margin: auto 2px;
}
.page-action-simple-step3 .services .card-type-list .card-bottom-list > div .card-discount,
.page-action-services-index .services .card-type-list .card-bottom-list > div .card-discount {
  margin-top: 0;
  margin-left: 8px;
}

@media (min-width: 1401px) {
  .page-action-simple-step3 .services .card-type-list .card-bottom-list > div:nth-child(2),
.page-action-services-index .services .card-type-list .card-bottom-list > div:nth-child(2) {
    flex-direction: row;
  }
  .page-action-simple-step3 .services .card-type-list .card-bottom-list > div:nth-child(2) div,
.page-action-services-index .services .card-type-list .card-bottom-list > div:nth-child(2) div {
    margin: auto 4px;
  }
}
/* ===================================
   HOTEL DETAILS
=================================== */
.hotel-details-gallery {
  background: #f0f4f8;
}
.hotel-details-gallery .swiper-slide {
  height: 390px;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}

.hotel-details-thumbs {
  background: rgba(255, 255, 255, 0.8);
  padding: 5px !important;
}
.hotel-details-thumbs .swiper-slide {
  width: 80px;
  height: 60px;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  cursor: pointer;
}

.hotel-details {
  padding: 16px 16px 30px 16px;
}
.hotel-details .stars {
  font-size: 12px;
  margin-left: 4px;
  transform: translateY(-1px);
}
.hotel-details .hotel-details-address {
  margin: 8px 0 12px 0;
}
.hotel-details .hotel-details-address .load-map {
  color: var(--blueValue);
  text-decoration: underline;
}
.hotel-details .content-desc.truncated {
  height: 110px;
  overflow: hidden;
  position: relative;
}
.hotel-details .content-desc.truncated:after {
  content: "";
  height: 36px;
  background: linear-gradient(rgba(255, 255, 255, 0), #ffffff);
  position: absolute;
  bottom: 0;
  right: 0;
  left: 0;
}

.hotel-details-facilities {
  background: #ffffff;
  margin-bottom: 24px;
}
.hotel-details-facilities .hotel-details-wrap.truncated {
  height: 220px;
  overflow: hidden;
  position: relative;
}
.hotel-details-facilities .hotel-details-wrap.truncated:after {
  content: "";
  height: 36px;
  background: linear-gradient(rgba(255, 255, 255, 0), #ffffff);
  position: absolute;
  bottom: 0;
  right: 0;
  left: 0;
}
.hotel-details-facilities .expand-content {
  margin: 0 16px;
  padding: 16px 0 30px 0;
}
.hotel-details-facilities .hotel-details-grid {
  padding-top: 30px;
}
.hotel-details-facilities .hotel-details-grid .gutter-sizer {
  width: 30px;
}
.hotel-details-facilities .content-list {
  width: 50%;
  padding: 0 16px 30px 16px;
}
.hotel-details-facilities .content-list h2 {
  font-size: 14px;
  font-weight: 500;
}
.hotel-details-facilities .content-list ul li {
  display: inline-block;
}

.expand-content {
  display: block;
  color: var(--blueValue);
  cursor: pointer;
  margin-top: 12px;
  text-decoration: underline;
}
.expand-content:first-letter {
  text-transform: uppercase;
}

.view-on-map {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100px;
  font-size: 16px;
  font-weight: 700;
  background: url("../_images/view-on-map.jpg") no-repeat center center;
  background-size: cover;
  color: var(--blueValue);
  cursor: pointer;
  margin: 24px 0;
  text-decoration: none;
  text-transform: none;
  position: relative;
}
.view-on-map:before {
  content: "";
  background: rgba(255, 255, 255, 0.7);
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}
.view-on-map > div {
  position: relative;
}
.view-on-map i {
  font-size: 18px;
  margin-right: 12px;
}

/* ===================================
   SERVICES - PACKAGES & OFFERS
=================================== */
.filters {
  display: flex;
  background: #ffffff;
  border-top: 1px solid #d9e2ec;
  padding: 16px;
  position: relative;
}
.filters:before {
  content: "";
  box-shadow: rgba(123, 135, 148, 0.5) 0 2px 8px;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}
.filters > div {
  display: flex;
  line-height: 34px;
  margin-left: 48px;
}
.filters > div:first-child {
  margin-left: 0;
}
.filters > div.filter-count {
  display: inline-block;
  color: var(--textValue);
  margin-left: auto;
}
.filters > div.filter-count em {
  font-style: normal;
}
.filters > div > div {
  position: relative;
}
.filters > div .filter-select {
  height: 36px;
  border: 1px solid #d9e2ec;
  cursor: pointer;
  margin: 0 8px;
  padding: 0 8px;
}
.filters > div .filter-select.open i:before {
  content: "\f106";
}
.filters > div .filter-select .filter-num {
  display: none;
  width: 18px;
  height: 18px;
  line-height: 18px;
  font-size: 10px;
  background: #f0f4f8;
  color: var(--blueValue);
  border-radius: 50%;
  margin-left: 2px;
  text-align: center;
  transform: translateY(-2px);
}
.filters > div .filter-select .filter-num.active {
  display: inline-block;
}
.filters > div .filter-select i {
  margin-left: 8px;
}
.filters > div .filter-list {
  display: none;
  min-width: 250px;
  max-width: 600px;
  background: #ffffff;
  border: 1px solid #d9e2ec;
  box-shadow: rgba(123, 135, 148, 0.5) 0 6px 8px;
  white-space: nowrap;
  position: absolute;
  top: 42px;
  left: 8px;
  z-index: 3;
}
.filters > div .filter-list.open {
  display: block;
}
.filters > div .filter-list > ul {
  max-height: 309px;
  list-style: none;
  margin: 0;
  padding: 0 16px 16px 16px;
  overflow-y: auto;
}
.filters > div .filter-list > ul:after {
  content: "";
  height: 16px;
  background: linear-gradient(to top, #ffffff, rgba(255, 255, 255, 0));
  position: absolute;
  bottom: 61px;
  right: 0;
  left: 0;
}
.filters > div .filter-list > ul li {
  margin-top: 16px;
  position: relative;
}
.filters > div .filter-list > ul li label {
  display: table-cell;
  height: 24px;
  line-height: 18px;
  color: var(--textValue);
  margin: 0;
  padding: 0 0 0 36px;
  cursor: pointer;
  position: relative;
  vertical-align: middle;
}
.filters > div .filter-list > ul li label:before {
  content: "";
  width: 24px;
  height: 24px;
  background: #ffffff;
  border: 1px solid #d0def0;
  box-sizing: border-box;
  position: absolute;
  top: 0;
  left: 0;
}
.filters > div .filter-list > ul li label:after {
  content: "\f00c";
  font-family: "Font Awesome 5 Pro";
  font-size: 12px;
  color: var(--blueValue);
  position: absolute;
  top: 3px;
  left: 7px;
  opacity: 0;
}
.filters > div .filter-list > ul li input {
  width: auto;
  height: auto;
  padding: 0;
  border: 0;
  position: absolute;
  top: 0;
  left: 0;
  visibility: hidden;
}
.filters > div .filter-list > ul li input:checked + label {
  color: #102a43;
}
.filters > div .filter-list > ul li input:checked + label:before {
  background: #f0f4f8;
}
.filters > div .filter-list > ul li input:checked + label:after {
  opacity: 1;
}
.filters > div .filter-list .filter-apply {
  height: 62px;
  line-height: 62px;
  font-size: 12px;
  font-weight: 900;
  background: var(--blueValue);
  color: #ffffff;
  cursor: pointer;
  margin: -1px;
  position: relative;
  text-align: center;
  text-transform: uppercase;
}
.filters > div .filter-list .filter-apply:hover {
  background: var(--blueValueRgbLighten);
}

.services:first-child .content-category {
  margin-top: 0;
}
.services .content-category {
  margin: 30px 0 16px 0;
}
.services .services-wrap.services-grouped {
  display: none;
}
.services .services-wrap.services-grouped.open {
  display: block;
}
.services .countdown {
  width: auto !important;
}

.service-details {
  position: relative;
}
.service-details .swiper-container {
  overflow: visible;
}
.service-details .swiper-slide {
  height: 480px;
  background-color: #d9e2ec;
  background-size: cover;
}
.service-details .service-details-wrap {
  background: #ffffff;
  color: var(--textValue);
  padding: 24px;
}
.service-details .service-details-wrap .content-title {
  color: #102a43;
}
.service-details .service-details-wrap .service-details-desc {
  margin-top: 8px;
}
.service-details .service-details-wrap ul {
  padding: 0 0 0 16px;
}
.service-details .service-details-wrap.offer-without-gallery {
  margin-top: 68px;
}
.service-details .service-details-info {
  background: #e6ffe8;
  color: #009c12;
  border: 1px solid rgba(0, 156, 18, 0.2);
  margin-top: 24px;
  padding: 12px 16px;
  cursor: pointer;
}
.service-details .service-details-info > i {
  display: table-cell;
  font-size: 48px;
  padding-right: 18px;
  vertical-align: middle;
}
.service-details .service-details-info > div {
  display: table-cell;
  max-width: 700px;
  vertical-align: middle;
}
.service-details .countdown {
  color: var(--blueValue);
}
.service-details .service-details-price {
  color: var(--blueValue);
  text-transform: lowercase;
}

/* ===================================
   FEEDBACKS / REVIEWS
=================================== */
.feedback-hotel {
  display: flex;
  align-items: center;
  background: var(--darkblueValue);
  color: #ffffff;
  cursor: pointer;
  margin-bottom: 24px;
  padding: 8px 16px;
}
.feedback-hotel:hover {
  background: var(--darkblueValueRgbLighten);
}
.feedback-hotel > div:first-child {
  font-size: 18px;
  font-weight: 900;
}
.feedback-hotel > div:first-child .stars {
  font-size: 12px;
  margin-left: 4px;
  transform: translateY(-1px);
}
.feedback-hotel > div.feedback-hotel-avg {
  line-height: 18px;
  margin-left: auto;
  text-align: right;
  white-space: nowrap;
}
.feedback-hotel > div.feedback-hotel-avg > div:first-child {
  font-size: 18px;
  font-weight: 900;
}
.feedback-hotel > div.feedback-hotel-avg > div:last-child {
  font-size: 12px;
  text-transform: lowercase;
}
.feedback-hotel > div.feedback-hotel-icon {
  width: 38px;
  height: 38px;
  line-height: 38px;
  font-size: 18px;
  background: rgba(255, 255, 255, 0.3);
  border: 1px solid rgba(255, 255, 255, 0.5);
  border-radius: 50%;
  margin: 0 16px 0 12px;
  text-align: center;
}
.feedback-hotel > div.feedback-hotel-icon i {
  width: 38px;
}

.feedbacks.closed {
  display: none;
}

.feedback {
  background: #ffffff;
  margin-bottom: 24px;
  padding: 24px 16px;
  box-shadow: rgba(123, 135, 148, 0.5) 0 2px 8px;
}
.feedback .feedback-head {
  display: flex;
  align-items: center;
}
.feedback .feedback-head > div.feedback-flag > div {
  width: 44px;
  height: 44px;
  background: #f0f4f8;
  border-radius: 50%;
  margin-right: 12px;
  overflow: hidden;
  position: relative;
}
.feedback .feedback-head > div.feedback-flag > div > img {
  position: absolute;
  width: 67px;
  top: -12px;
  left: -12px;
}
.feedback .feedback-head > div.feedback-detail {
  color: var(--blueValue);
  margin-right: 16px;
  margin-left: auto;
  cursor: pointer;
  text-transform: lowercase;
}
.feedback .feedback-head > div.feedback-detail:hover {
  text-decoration: underline;
}
.feedback .feedback-head > div.feedback-detail > i {
  margin-left: 8px;
  transform: translateY(1px);
}
.feedback .feedback-head > div.feedback-avg {
  width: 65px;
  height: 44px;
  line-height: 44px;
  font-size: 18px;
  font-weight: 900;
  background: #f0f4f8;
  color: var(--blueValue);
  border-radius: 4px;
  text-align: center;
}
.feedback .feedback-head > div .feedback-name {
  font-size: 18px;
  font-weight: 900;
}
.feedback .feedback-text {
  color: var(--textValue);
  margin-top: 16px;
}
.feedback .feedback-total {
  display: none;
  background: #f0f4f8;
  border-radius: 4px;
  margin-top: 16px;
  padding: 0 24px 24px 24px;
}
.feedback .feedback-total > div {
  display: inline-block;
  width: 50%;
  width: calc(50% - 24px);
  margin-top: 24px;
  letter-spacing: normal;
  vertical-align: top;
}
.feedback .feedback-total > div:nth-child(odd) {
  margin-right: 24px;
}
.feedback .feedback-total > div:nth-child(even) {
  margin-left: 24px;
}
.feedback .feedback-total > div label {
  display: table;
  width: 100%;
  line-height: 15px;
}
.feedback .feedback-total > div label > span {
  display: table-cell;
  vertical-align: top;
}
.feedback .feedback-total > div label > span:first-child {
  font-weight: 900;
}
.feedback .feedback-total > div label > span:last-child {
  color: var(--blueValue);
  padding-left: 16px;
  text-align: right;
  white-space: nowrap;
}
.feedback .feedback-outer {
  height: 2px;
  background: #d0def0;
  border-radius: 1px;
  margin-top: 12px;
  position: relative;
}
.feedback .feedback-outer span {
  background: var(--blueValue);
  position: absolute;
}

.feedbacks-more > .feedbacks-more {
  display: inline-block;
  background-color: white;
  text-decoration: none;
  padding: 12px 16px;
  color: var(--blueValue);
  cursor: pointer;
  width: 100%;
  text-align: right;
}

.survey {
  background: #ffffff;
  margin-top: 24px;
  padding: 30px;
}
.survey .content-desc {
  margin-top: 12px;
}
.survey .questions {
  list-style: none;
  margin: 0;
  padding: 0;
}
.survey .questions > li {
  border-top: 1px solid #d0def0;
  margin-top: 30px;
  padding-top: 30px;
}
.survey .questions > li:first-child {
  border: 0;
  padding-top: 0;
}
.survey .questions > li:last-child {
  margin-bottom: 30px;
}
.survey .questions > li > h3 {
  font-size: 14px;
}
.survey .questions > li > h3 i {
  font-size: 12px;
  font-style: normal;
}
.survey .questions > li .content-desc {
  margin-top: 3px;
}
.survey .questions .form-fields {
  letter-spacing: normal;
}
.survey .questions .form-field input {
  padding-top: 9px;
}
.survey .questions .form-check {
  margin-top: 18px;
}
.survey .questions .form-check label {
  color: var(--textValue);
}
.survey .questions .form-check label:hover {
  text-decoration: underline;
}
.survey .questions .form-check label:after {
  font-size: 12px;
  color: var(--blueValue);
  left: 7px;
}
.survey .questions .form-check input:checked + label {
  color: #102a43;
}
.survey .questions .form-check input:checked + label:before {
  background: #d0def0;
}

/* ===================================
   THANK YOU PAGE
=================================== */
.thank-you {
  max-width: 600px;
  margin: 24px auto;
}
.thank-you .thank-you-head {
  background: #ffffff;
  margin-bottom: 24px;
  padding: 36px;
  text-align: center;
  box-shadow: rgba(123, 135, 148, 0.5) 0 2px 8px;
}
.thank-you .thank-you-head .logo {
  display: block;
  margin-bottom: 16px;
}
.thank-you .thank-you-head .logo img {
  max-height: 48px;
}
.thank-you .thank-you-head .content-desc {
  color: var(--textValue);
  margin-top: 16px;
}
.thank-you .thank-you-head .reservation-details-buttons {
  margin-top: 8px;
}
.thank-you .thank-you-head .reservation-details-buttons a {
  margin-top: 16px;
}
.thank-you .thank-you-data {
  background: #ffffff;
  padding-bottom: 32px;
  box-shadow: rgba(123, 135, 148, 0.5) 0 2px 8px;
}
.thank-you .thank-you-data > div {
  border-top: 1px solid #d9e2ec;
  margin-bottom: 16px;
  padding-top: 16px;
}
.thank-you .thank-you-data > div > div {
  display: table;
  width: 100%;
}
.thank-you .thank-you-data > div > div:nth-child(even) {
  background: #f0f4f8;
}
.thank-you .thank-you-data > div > div > div {
  display: table-cell;
  padding: 16px 24px;
}
.thank-you .thank-you-data > div > div > div:first-child {
  width: 210px;
  font-weight: 700;
}
.thank-you .thank-you-data > div > div > div:last-child {
  color: var(--textValue);
}
.thank-you .thank-you-location {
  background: #ffffff;
  margin-top: 24px;
  box-shadow: rgba(123, 135, 148, 0.5) 0 2px 8px;
}
.thank-you .thank-you-location #thank-you-map {
  height: 400px;
  background: #f0f4f8;
}
.thank-you .thank-you-location .thank-you-location-text {
  padding: 24px;
}

/* ===================================
   RESERVED AREA
=================================== */
.content-login {
  background: #f0f4f8;
  color: var(--textValue);
  margin-top: 16px;
  border: 1px solid #d0def0;
}
.content-login > a {
  display: none;
  width: 100%;
  cursor: pointer;
}
.content-login > a.visible {
  display: table;
}
.content-login > a > div {
  display: table-cell;
  height: 48px;
  padding: 6px 16px;
  vertical-align: middle;
}
.content-login > a > div:last-child {
  font-size: 15px;
  text-align: right;
  white-space: nowrap;
}
.content-login > a > div:last-child i {
  margin-left: 9px;
}

.password-criteria {
  font-size: 12px;
}
.password-criteria ul {
  color: var(--textValue);
  margin: 0;
  padding-left: 18px;
}

.reservation {
  display: flex;
  align-items: center;
  background: #ffffff;
  color: var(--textValue);
  box-shadow: rgba(123, 135, 148, 0.5) 0 2px 8px;
  margin-top: 24px;
  position: relative;
  z-index: 2;
}
.reservation > div {
  letter-spacing: normal;
  padding: 16px 24px;
  position: relative;
}
.reservation > div:first-child {
  min-width: 180px;
  background: #f0f4f8;
  border-right: 1px solid #d0def0;
  padding-left: 16px;
}
.reservation > div.reservation-date {
  padding-left: 57px;
}
.reservation > div.reservation-date:after {
  content: "\f133";
  font-family: "Font Awesome 5 Pro";
  font-size: 24px;
  font-weight: 400;
  color: var(--blueValue);
  position: absolute;
  top: 50%;
  left: 24px;
  transform: translateY(-50%);
}
.reservation > div.reservation-status {
  height: 76px;
  line-height: 76px;
  margin-left: auto;
  padding-top: 0;
  padding-bottom: 0;
}
.reservation > div.reservation-status:before {
  content: "";
  width: 1px;
  background: #d0def0;
  position: absolute;
  top: 12px;
  left: 0;
  bottom: 12px;
}
.reservation > div.reservation-status > div {
  position: relative;
}
.reservation > div.reservation-status > div.confirmed {
  color: #009c12;
}
.reservation > div.reservation-status > div.confirmed:before {
  background: #e6ffe8;
  border-color: rgba(0, 156, 18, 0.2);
}
.reservation > div.reservation-status > div.optionated {
  color: #9c7e00;
}
.reservation > div.reservation-status > div.optionated:before {
  background: #fffae6;
  border-color: rgba(156, 126, 0, 0.2);
}
.reservation > div.reservation-status > div.deleted {
  color: #ab2727;
}
.reservation > div.reservation-status > div.deleted:before {
  background: #ffe8e8;
  border-color: rgba(171, 39, 39, 0.2);
}
.reservation > div.reservation-status > div:before {
  display: inline-block;
  content: "";
  width: 16px;
  height: 16px;
  border: 1px solid;
  border-radius: 50%;
  margin-right: 9px;
  transform: translateY(4px);
}
.reservation > div.reservation-btn {
  height: 76px;
  line-height: 76px;
  color: var(--blueValue);
  cursor: pointer;
  padding-top: 0;
  padding-bottom: 0;
}
.reservation > div.reservation-btn:hover {
  text-decoration: underline;
}
.reservation > div.reservation-btn:before {
  content: "";
  width: 1px;
  background: #d0def0;
  position: absolute;
  top: 12px;
  left: 0;
  bottom: 12px;
}
.reservation > div.reservation-btn > i {
  margin-left: 6px;
  transform: translateY(1px);
}
.reservation .reservation-id {
  font-size: 18px;
  font-weight: 900;
  color: #102a43;
}

.reservation-details {
  display: none;
  background: #f0f4f8;
  padding: 18px 30px 30px 30px;
  box-shadow: rgba(123, 135, 148, 0.5) 0 2px 8px;
}
.reservation-details .reservation-details-table {
  padding-right: 30px;
}
.reservation-details .reservation-details-table > div {
  display: table;
  width: 100%;
}
.reservation-details .reservation-details-table > div:last-child > div:last-child {
  border: 0;
}
.reservation-details .reservation-details-table > div > div {
  display: table-cell;
  padding: 12px 0;
  vertical-align: top;
}
.reservation-details .reservation-details-table > div > div:first-child {
  width: 210px;
  font-weight: 700;
}
.reservation-details .reservation-details-table > div > div:last-child {
  color: var(--textValue);
  border-bottom: 1px solid #d0def0;
}
.reservation-details .reservation-details-buttons {
  text-align: right;
}
.reservation-details .reservation-details-buttons a,
.reservation-details .reservation-details-buttons span {
  margin: 24px 0 0 8px;
}

.reservations-pager {
  text-align: center;
}
.reservations-pager ul {
  list-style: none;
  margin: 24px 0 0 0;
  padding: 0;
}
.reservations-pager ul li {
  display: inline-block;
  vertical-align: top;
}
.reservations-pager ul li.active a {
  background: var(--darkblueValue);
  color: #ffffff;
}
.reservations-pager ul li.active a:hover {
  background: var(--darkblueValue);
}
.reservations-pager ul li.disabled {
  display: none;
}
.reservations-pager ul li a {
  display: block;
  width: 24px;
  height: 24px;
  line-height: 24px;
  font-size: 12px;
  background: #ffffff;
  color: var(--textValue);
  border-radius: 50%;
  cursor: pointer;
  margin: 0 4px;
  text-decoration: none;
  vertical-align: top;
  box-shadow: rgba(123, 135, 148, 0.5) 0 2px 8px;
}
.reservations-pager ul li a:hover {
  background: #f0f4f8;
}

/* ===================================
   PRICE CHECK WIDGET
=================================== */
#pricewidget.loaded .pw-loading {
  display: none;
}
#pricewidget.loaded .pw-ota {
  display: block;
}
#pricewidget .pw-ota {
  display: none;
  background: #f0f4f8;
  border: 1px solid rgba(0, 156, 18, 0.2);
  margin-top: 24px;
}
#pricewidget .pw-ota > h2 {
  height: 52px;
  line-height: 52px;
  font-size: 16px;
  font-weight: 700;
  background: #009c12;
  color: #ffffff;
  margin: -1px;
  padding: 0 16px;
}
#pricewidget .pw-ota .pw-site > div {
  background: #e6ffe8;
  color: #009c12;
  border: 1px solid rgba(0, 156, 18, 0.2);
  margin: 16px 16px 0 16px;
  padding: 12px 75px 12px 16px;
  position: relative;
}
#pricewidget .pw-ota .pw-site > div > div:last-child {
  font-size: 20px;
  font-weight: 900;
}
#pricewidget .pw-ota .pw-site > div > div:last-child span {
  font-size: 12px;
  font-weight: 400;
}
#pricewidget .pw-ota .pw-site > div > div:last-child:after {
  content: "\f164";
  display: block;
  width: 43px;
  height: 43px;
  line-height: 43px;
  font-family: "Font Awesome 5 Pro";
  font-size: 18px;
  font-weight: 400;
  background: #ffffff;
  border: 1px solid rgba(0, 156, 18, 0.2);
  border-radius: 50%;
  text-align: center;
  position: absolute;
  top: 50%;
  right: 16px;
  transform: translateY(-50%);
}
#pricewidget .pw-ota .pw-discount {
  margin-top: -1px;
  padding: 0 16px;
  position: relative;
}
#pricewidget .pw-ota .pw-discount > div {
  font-weight: 900;
  background: rgba(0, 156, 18, 0.2);
  color: #009c12;
  border: 1px solid rgba(0, 156, 18, 0.2);
  padding: 10px 16px;
}
#pricewidget .pw-ota .pw-items {
  display: none;
  margin-right: -8px;
  padding: 8px 16px 16px 16px;
}
#pricewidget .pw-ota .pw-items > div {
  display: inline-block;
  width: calc(33.333% - 8px);
  background: #ffe8e8;
  color: #ab2727;
  border: 1px solid rgba(171, 39, 39, 0.2);
  letter-spacing: normal;
  margin: 8px 8px 0 0;
  text-align: center;
  vertical-align: top;
}
#pricewidget .pw-ota .pw-items > div > div:first-child {
  background: rgba(171, 39, 39, 0.2);
  border: 1px solid rgba(171, 39, 39, 0.2);
  margin: -1px;
  padding: 6px 12px;
}
#pricewidget .pw-ota .pw-items > div > div:last-child {
  font-weight: 900;
  padding: 12px;
}
#pricewidget .pw-loading {
  height: 52px;
  line-height: 52px;
  font-size: 16px;
  font-weight: 700;
  background: #009c12;
  background-image: linear-gradient(-45deg, rgba(255, 255, 255, 0.125) 25%, rgba(255, 255, 255, 0) 25%, rgba(255, 255, 255, 0) 50%, rgba(255, 255, 255, 0.125) 50%, rgba(255, 255, 255, 0.125) 75%, rgba(255, 255, 255, 0) 75%, rgba(255, 255, 255, 0));
  background-size: 35px 35px;
  color: #ffffff;
  margin-top: 24px;
  padding: 0 16px;
  position: relative;
  overflow: hidden;
  text-align: center;
  animation: loadingBar 2s linear infinite;
}

@keyframes loadingBar {
  0% {
    background-position: 0 0;
  }
  100% {
    background-position: 35px 35px;
  }
}
.pricewidget-adv {
  max-width: 350px;
  background: #e6ffe8;
  color: var(--textValue);
  border: 1px solid rgba(0, 156, 18, 0.2);
  margin-top: 24px;
  margin-bottom: 24px;
  padding: 24px 16px;
  text-align: left;
}
.pricewidget-adv h2 {
  font-size: 16px;
  color: #009c12;
}
.pricewidget-adv ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
.pricewidget-adv ul li {
  display: table;
  width: 100%;
  border-bottom: 1px solid rgba(0, 156, 18, 0.2);
}
.pricewidget-adv ul li:last-child {
  border: 0;
}
.pricewidget-adv ul li:last-child i,
.pricewidget-adv ul li:last-child span {
  padding-bottom: 0;
}
.pricewidget-adv ul li i,
.pricewidget-adv ul li span {
  display: table-cell;
  padding: 16px 0;
  vertical-align: top;
}
.pricewidget-adv ul li i {
  width: 28px;
  font-size: 16px;
  color: #009c12;
}
.pricewidget-adv ul li i:before {
  display: block;
  transform: translateY(3px);
}

/* ===================================
   RECOVERY TOOL
=================================== */
.recovery-coupon {
  display: inline-block;
  min-width: 300px;
  font-weight: 900;
  background: #e6ffe8;
  color: #009c12;
  border: 1px solid rgba(0, 156, 18, 0.2);
  border-radius: 9px;
  margin: 8px 0 16px 0;
  padding: 12px 24px;
  vertical-align: top;
  text-align: center;
  text-transform: uppercase;
}

.recovery-actions {
  display: flex;
  margin-top: 8px;
}
.recovery-actions > div:last-child {
  background: #ffffff;
  color: var(--textValue);
  border: 1px solid var(--textValue);
  margin-left: 16px;
}
.recovery-actions > div:last-child i {
  margin-left: 8px;
}

#recovery-form {
  display: none;
  margin-top: 24px;
}

/* ===================================
   PRICE CHECK TOOL
=================================== */
.pct-icon {
  width: 20px;
  height: 20px;
  font-size: 16px;
  color: #009c12;
  margin-left: 2px;
  cursor: pointer;
  transform: translateY(-2px);
  text-align: center;
}

/* ===================================
   ADDTHIS --> SHARE THIS
=================================== */
/*FIX per la pagina di caricamento*/
#sharethis > div {
  z-index: 888 !important;
}

/*#addthis,*/
#sharethis {
  display: flex;
  align-items: center;
  background: rgba(255, 255, 255, 0.9);
  box-shadow: rgba(123, 135, 148, 0.5) 0 2px 8px;
  margin-top: 24px;
  padding: 19px 16px;
  /*    .at-share-tbx-element .at-share-btn {
              background: $whiteValue !important;
              border: 1px solid $grayValue;
              margin: 0 12px 0 0;

              &:focus,
                  &:hover {
                  transform: none;
                  outline-offset: 0;

                  path {
                      fill: var(--blueValue);
                  }
              }

              &.at-svc-compact {
                  background: $lightBlackValue !important;

                  &:hover {
                      path {
                          fill: $whiteValue;
                      }
                  }

                  path {
                      fill: $whiteValue;
                  }
              }

              .at-icon-wrapper {
                  width: 30px !important;
                  height: 30px !important;
                  line-height: 30px !important;

                  svg {
                      height: 20px !important;
                      margin: 4px 0 0 -1px;
                  }
              }

              path {
                  fill: $lightBlackValue;
              }
          }*/
}
#sharethis h3 {
  font-size: 16px;
  font-weight: 700;
  margin-right: 18px;
}

.page-action-services-index #sharethis,
.page-action-services-index #addthis {
  margin-top: 0;
}

/* ===================================
   STEPBAR & STEPROOM
=================================== */
.steproom {
  display: flex;
  background: #ffffff;
  border-top: 1px solid #d9e2ec;
  margin-bottom: 24px;
  padding: 16px;
  position: relative;
}
.steproom:before {
  content: "";
  box-shadow: rgba(123, 135, 148, 0.5) 0 2px 8px;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}
.steproom > div:last-child {
  color: var(--textValue);
  margin-left: auto;
}
.steproom.room_noavail > div {
  display: flex;
  justify-content: space-between;
}

.stepbar {
  height: 62px;
  background: #ffffff;
  box-shadow: rgba(123, 135, 148, 0.5) 0 2px 8px;
  text-align: center;
  position: fixed;
  bottom: 0;
  right: 0;
  left: 0;
  z-index: 99;
}
.stepbar > div {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.stepbar > div:last-child {
  margin-left: auto;
}
.stepbar a {
  display: inline-block;
  height: 46px;
  line-height: 46px;
  font-size: 12px;
  font-weight: 900;
  margin-top: 8px;
  padding: 0 24px;
  cursor: pointer;
  vertical-align: top;
  text-transform: uppercase;
}
.stepbar a.stepbar-prev {
  color: var(--textValue);
  border: 1px solid #d9e2ec;
}
.stepbar a.stepbar-prev i {
  margin-right: 8px;
}
.stepbar a.stepbar-next {
  min-width: 220px;
  background: #009c12;
  color: #ffffff;
  transition: all 0.3s;
}
.stepbar a.stepbar-next.disabled {
  opacity: 0.4;
}
.stepbar a.stepbar-next:hover {
  background: #00b615;
}
.stepbar a.stepbar-next:before {
  background: #00c016;
}
.stepbar a.stepbar-next i {
  margin-left: 8px;
}
.stepbar a span {
  position: relative;
  z-index: 2;
}
.stepbar a i {
  font-size: 16px;
  transform: translateY(2px);
}
.stepbar .stepbar-price {
  font-size: 26px;
  font-weight: 900;
  color: #009c12;
  margin-top: 6px;
}
.stepbar .stepbar-price span {
  font-size: 14px;
}
.stepbar .stepbar-price-rack {
  line-height: 12px;
  font-size: 12px;
  color: var(--textValue);
  text-decoration: line-through;
}

.stepbar-mask {
  height: 42px;
}

/* ===================================
   FOOTER
=================================== */
#footer {
  display: flex;
  height: 54px;
  line-height: 30px;
  font-size: 12px;
  background: #ffffff;
  color: var(--textValue);
  margin-top: 60px;
  margin-bottom: 36px;
  padding: 12px 16px;
}
#footer > div {
  align-items: center;
}
#footer > div:last-child {
  margin-left: auto;
}
#footer > div:last-child img,
#footer > div:last-child svg {
  margin-left: 24px;
}
#footer img,
#footer svg {
  display: block;
  height: 100%;
  max-height: 30px;
}
#footer img#brand,
#footer svg#brand {
  max-height: 20px;
  margin-top: 6px;
}
#footer .footer-bottom {
  display: flex;
  align-items: center;
}
#footer .footer-bottom > div {
  margin-left: 16px;
  padding-left: 16px;
  position: relative;
  vertical-align: middle;
  white-space: nowrap;
}
#footer .footer-bottom > div:first-child {
  margin-left: 0;
  padding-left: 0;
}
#footer .footer-bottom > div:first-child:before {
  display: none;
}
#footer .footer-bottom > div > span {
  cursor: pointer;
}
#footer .footer-bottom > div > span:hover {
  text-decoration: underline;
}
#footer .footer-bottom > div a.accessibility-declaration-link {
  color: var(--textValue);
}
#footer .footer-bottom > div:before {
  content: "";
  display: inline-block;
  width: 1px;
  height: 16px;
  background: #d9e2ec;
  vertical-align: top;
  position: absolute;
  top: 11px;
  left: 0;
}
#footer .footer-bottom > div.iubenda-link a {
  text-decoration: none;
  color: var(--textValue);
}
#footer .footer-bottom > div.iubenda-link a:hover {
  text-decoration: underline;
}
#footer .footer-bottom > svg {
  width: 100%;
}
#footer .footer-bottom .cls-1 {
  fill: #fff;
}
#footer .footer-bottom .cls-2 {
  fill: #c7c8ca;
}
#footer .footer-bottom .cls-3 {
  fill: #231f20;
}
#footer .footer-bottom .cls-4 {
  fill: #a7a9ac;
}
#footer .footer-bottom .cls-5 {
  fill: #ffc20e;
}
#footer .footer-bottom .cls-6 {
  fill: #a30046;
}

/* ===================================
   FORMS
=================================== */
.form-fields {
  margin-right: -16px;
}

.form-field {
  display: inline-block;
  width: calc(50% - 16px);
  height: 48px;
  line-height: 46px;
  background-color: #ffffff;
  color: #102a43;
  margin: 16px 16px 0 0;
  position: relative;
  letter-spacing: normal;
  text-align: left;
  vertical-align: top;
}
.form-field.form-field-full {
  width: calc(100% - 16px);
}
.form-field.form-field-block {
  display: block;
  width: calc(100% - 16px);
}
.form-field.form-field-33 {
  width: calc(33.333% - 16px);
}
.form-field.form-field-textarea {
  min-height: 180px;
}
.form-field.pre-filled label, .form-field.focused label {
  font-size: 10px;
  transform: translateY(-11px);
  z-index: 1;
}
.form-field.valid:after {
  content: "\f00c";
  width: 19px;
  height: 19px;
  line-height: 19px;
  font-family: "Font Awesome 5 Pro";
  font-size: 12px;
  background: #f0f4f8;
  color: #009c12;
  border-radius: 50%;
  text-align: center;
  position: absolute;
  top: 50%;
  right: 16px;
  transform: translateY(-50%);
}
.form-field.invalid {
  background-color: #ffe8e8;
}
.form-field.invalid:after {
  content: "\f00d";
  width: 19px;
  height: 19px;
  line-height: 18px;
  font-family: "Font Awesome 5 Pro";
  font-size: 12px;
  background: #ffffff;
  color: #ab2727;
  border-radius: 50%;
  text-align: center;
  position: absolute;
  top: 50%;
  right: 16px;
  transform: translateY(-50%);
}
.form-field.invalid input,
.form-field.invalid select,
.form-field.invalid textarea {
  border-color: rgba(171, 39, 39, 0.2);
}
.form-field.invalid select {
  background-image: none;
}
.form-field.invalid input:-webkit-autofill,
.form-field.invalid input:-webkit-autofill:hover,
.form-field.invalid input:-webkit-autofill:focus,
.form-field.invalid textarea:-webkit-autofill,
.form-field.invalid textarea:-webkit-autofill:hover,
.form-field.invalid textarea:-webkit-autofill:focus,
.form-field.invalid select:-webkit-autofill,
.form-field.invalid select:-webkit-autofill:hover,
.form-field.invalid select:-webkit-autofill:focus {
  background-color: #ffe8e8;
  -webkit-box-shadow: 0 0 0px 1000px #ffe8e8 inset;
}
.form-field.mt0 {
  margin-top: 0;
}
.form-field label {
  display: block;
  line-height: 15px;
  color: var(--textValue);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  position: absolute;
  top: 17px;
  right: 48px;
  left: 16px;
  transition: all 0.3s;
}
.form-field input,
.form-field select {
  width: 100%;
  height: 48px;
  background: transparent;
  color: #102a43;
  border: 1px solid #d0def0;
  margin: 0;
  padding: 20px 51px 9px 16px;
  position: relative;
}
.form-field.form-type-phone.form-field-prefix {
  width: calc(25% - 16px);
  margin: 16px 0 0 0;
}
.form-field.form-type-phone.form-field-number {
  width: 25%;
}
.form-field.form-type-phone.form-field-number input {
  border-left: 0;
}
.form-field textarea {
  width: 100%;
  height: 100%;
  font-size: 14px;
  background: transparent;
  color: #102a43;
  border: 1px solid #d0def0;
  padding: 20px 16px 9px 16px;
  resize: none;
  position: relative;
}
.form-field select {
  background-image: url(data:image/svg+xml;utf8;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCA0NDggNTEyIj48cGF0aCBmaWxsPSIjOTk5IiBkPSJNNDQxLjkgMTY3LjNsLTE5LjgtMTkuOGMtNC43LTQuNy0xMi4zLTQuNy0xNyAwTDIyNCAzMjguMiA0Mi45IDE0Ny41Yy00LjctNC43LTEyLjMtNC43LTE3IDBMNi4xIDE2Ny4zYy00LjcgNC43LTQuNyAxMi4zIDAgMTdsMjA5LjQgMjA5LjRjNC43IDQuNyAxMi4zIDQuNyAxNyAwbDIwOS40LTIwOS40YzQuNy00LjcgNC43LTEyLjMgMC0xN3oiLz48L3N2Zz4=);
  background-position-x: calc(100% - 16px);
  background-position-y: 19px;
  background-repeat: no-repeat;
  background-size: 11px;
  cursor: pointer;
  z-index: 2;
}

.form-check {
  margin-top: 12px;
  text-align: left;
  position: relative;
}
.form-check label {
  display: table-cell;
  height: 24px;
  line-height: 18px;
  font-size: 14px;
  margin: 0;
  padding: 0 0 0 40px;
  cursor: pointer;
  position: relative;
  vertical-align: middle;
}
.form-check label:before {
  content: "";
  width: 24px;
  height: 24px;
  background: #f0f4f8;
  border: 1px solid #d0def0;
  box-sizing: border-box;
  position: absolute;
  top: 0;
  left: 0;
}
.form-check label:after {
  content: "\f00c";
  font-family: "Font Awesome 5 Pro";
  font-size: 18px;
  color: #009c12;
  position: absolute;
  top: 3px;
  left: 3px;
  opacity: 0;
}
.form-check label.form-check-label-fix {
  display: table-cell;
  padding: 0 0 0 37px;
}
.form-check .form-check-span-fix {
  cursor: pointer;
  display: table-cell;
}
.form-check input {
  width: auto;
  height: auto;
  padding: 0;
  border: 0;
  position: absolute;
  top: 0;
  left: 0;
  visibility: hidden;
}
.form-check.form-radio label:before {
  background: transparent;
  border-radius: 50%;
}
.form-check.form-radio label:after {
  content: "";
  width: 10px;
  height: 10px;
  background: var(--blueValue);
  border-radius: 50%;
  top: 7px;
  left: 7px;
}

.form-radios-inline {
  display: flex;
  flex-wrap: wrap;
  margin-right: -16px;
}
.form-radios-inline .form-radio {
  width: calc(33% - 16px);
  margin-right: 16px;
}

.form-compact-request {
  color: var(--blueValue);
  cursor: pointer;
  letter-spacing: normal;
  margin: 6px 0 24px 0;
}

.form-check input:checked + label:before,
.form-check.invalid input:checked + label:before {
  background: #f0f4f8;
  border-color: #d0def0;
}
.form-check input:checked + label:after,
.form-check.invalid input:checked + label:after {
  opacity: 1;
}

.form-check.invalid input + label:before {
  background-color: #ffe8e8;
  border-color: rgba(171, 39, 39, 0.2);
}

.form-actions {
  display: flex;
  align-items: center;
  margin-top: 12px;
}
.form-actions > div:last-child {
  margin-left: auto;
}
.form-actions > div.recoverPassword {
  font-size: 12px;
  color: var(--textValue);
  cursor: pointer;
}
.form-actions > div.recoverPassword:hover {
  text-decoration: underline;
}

/* ===================================
   PAYMODES
=================================== */
.choose-paymode {
  display: table;
  width: 100%;
  border: 1px solid #d0def0;
  margin-top: 16px;
  cursor: pointer;
}
.choose-paymode:hover .checkButton label:after {
  opacity: 1;
}
.choose-paymode > div {
  display: table-cell;
  height: 48px;
  line-height: 18px;
  vertical-align: middle;
  position: relative;
}
.choose-paymode > div:last-child {
  padding: 3px 16px 3px 50px;
}
.choose-paymode > div:last-child.custom-payment-icon {
  padding-left: 14px;
}
.choose-paymode.button2 {
  border-color: var(--blueValue);
}
.choose-paymode.button2 .checkButton label {
  background: var(--blueValue);
  border-color: var(--blueValue);
}
.choose-paymode.button2 .checkButton label:after {
  color: #ffffff;
}
.choose-paymode .checkButton {
  width: 48px;
  position: relative;
}
.choose-paymode .checkButton label {
  width: 100%;
  height: 100%;
  background: #f0f4f8;
  border-right: 1px solid #d0def0;
  position: absolute;
  top: 0;
  left: 0;
}
.choose-paymode .checkButton label:after {
  content: "\f00c";
  font-family: "Font Awesome 5 Pro";
  font-size: 18px;
  font-weight: 400;
  color: var(--blueValue);
  position: absolute;
  top: 50%;
  left: 15px;
  opacity: 0;
  transform: translateY(-50%);
}
.choose-paymode .checkButton input {
  display: none;
}
.choose-paymode .checkButton input:checked + label:after {
  opacity: 1;
}
.choose-paymode .paymode-icon {
  font-size: 18px;
  color: var(--blueValue);
  position: absolute;
  top: 50%;
  left: 16px;
  transform: translateY(-50%);
}

.paymode-info {
  display: none;
  padding: 24px 16px;
  border: 1px solid var(--blueValue);
  overflow: hidden;
}
.paymode-info.open {
  display: block;
  border-top: 0;
}
.paymode-info .paymode-img img {
  height: 24px;
  margin-right: 12px;
  margin-bottom: 8px;
}
.paymode-info .paymode-img img.amex {
  max-width: 44px;
}

.paymode-extra {
  font-size: 16px;
  background: #e6ffe8;
  color: #009c12;
  border: 1px solid rgba(0, 156, 18, 0.2);
  margin-top: 16px;
  padding: 16px;
}
.paymode-extra .paymode-extra-table {
  display: flex;
  font-weight: 900;
}
.paymode-extra .paymode-extra-table > div:last-child {
  margin-left: auto;
}
.paymode-extra .paymode-expire {
  font-size: 12px;
  font-weight: 400;
  color: var(--textValue);
}
.paymode-extra .paymode-expire.hidden {
  display: none;
}

/* ===================================
   CANCELLATION TERMS
=================================== */
.cancTermRefs {
  width: 100%;
  font-size: 12px;
  border-spacing: 0;
  border-collapse: separate;
  margin: 24px auto;
}
.cancTermRefs tr:nth-child(odd) td {
  background: #f0f4f8;
}
.cancTermRefs td {
  padding: 6px !important;
}
.cancTermRefs td:first-child {
  width: 200px;
}

/* ===================================
   SOCIAL
=================================== */
.social-frames iframe,
.social-frames > a {
  width: calc(50% - 8px) !important;
  margin-top: 16px;
  letter-spacing: normal;
  vertical-align: top;
}
.social-frames iframe:nth-child(odd),
.social-frames > a:nth-child(odd) {
  margin-right: 8px;
}
.social-frames iframe:nth-child(even),
.social-frames > a:nth-child(even) {
  margin-left: 8px;
}
.social-frames > a {
  display: inline-block;
  height: 48px;
  line-height: 48px;
  font-family: Helvetica, Arial, "Lucida Grande", sans-serif;
  font-size: 13px;
  font-weight: 400;
  background: #f0f4f8;
  color: var(--textValue) !important;
  border: 1px solid #d0def0;
  border-radius: 0;
  box-sizing: border-box;
  padding: 0 16px;
  text-align: left;
  text-shadow: none;
  cursor: pointer;
  position: relative;
}
.social-frames > a i {
  font-size: 16px;
  color: #2867b2;
  position: absolute;
  top: 50%;
  right: 16px;
  transform: translateY(-50%);
}

/* ===================================
   FILTERS CHAIN
=================================== */
.sort-list li,
.filters-list li {
  display: inline-block;
  width: calc(50% - 12px);
  margin-top: 16px;
  vertical-align: top;
}
.sort-list li:nth-child(odd),
.filters-list li:nth-child(odd) {
  margin-right: 12px;
}
.sort-list li:nth-child(even),
.filters-list li:nth-child(even) {
  margin-left: 12px;
}

.sort-list {
  list-style: none;
  margin: 6px 0 0 0;
  padding: 0;
}
.sort-list li {
  position: relative;
}
.sort-list li a {
  display: block;
  line-height: 24px;
  color: var(--textValue);
  cursor: pointer;
  padding-left: 36px;
  text-decoration: none !important;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}
.sort-list li a.selected {
  color: #102a43;
}
.sort-list li a.selected:before {
  background: #d0def0;
}
.sort-list li a.selected:after {
  opacity: 1;
}
.sort-list li a:hover {
  text-decoration: underline !important;
}
.sort-list li a:before {
  content: "";
  width: 24px;
  height: 24px;
  border: 1px solid #d0def0;
  border-radius: 50%;
  box-sizing: border-box;
  position: absolute;
  top: 0;
  left: 0;
}
.sort-list li a:after {
  content: "";
  width: 10px;
  height: 10px;
  background: var(--blueValue);
  border-radius: 50%;
  position: absolute;
  top: 7px;
  left: 7px;
  opacity: 0;
}

.filters-list {
  list-style: none;
  margin: 6px 0 0 0;
  padding: 0;
}
.filters-list li {
  position: relative;
}
.filters-list li.hidden {
  display: none;
}
.filters-list li.visible {
  display: inline-block;
}
.filters-list li label {
  display: block;
  line-height: 24px;
  color: var(--textValue);
  padding-left: 36px;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}
.filters-list li label:hover {
  text-decoration: underline;
}
.filters-list li label:before {
  content: "";
  width: 24px;
  height: 24px;
  border: 1px solid #d0def0;
  box-sizing: border-box;
  position: absolute;
  top: 0;
  left: 0;
}
.filters-list li label:after {
  content: "\f00c";
  font-family: "Font Awesome 5 Pro";
  font-size: 12px;
  font-weight: 400;
  color: var(--blueValue);
  position: absolute;
  top: 1px;
  left: 7px;
  opacity: 0;
}
.filters-list li input {
  width: auto;
  height: auto;
  padding: 0;
  border: 0;
  position: absolute;
  top: 0;
  left: 0;
  visibility: hidden;
}
.filters-list li input:checked + label {
  color: #102a43;
}
.filters-list li input:checked + label:before {
  background: #d0def0;
}
.filters-list li input:checked + label:after {
  opacity: 1;
}

.filters-list-toggle {
  color: var(--blueValue);
  margin-top: 16px;
  cursor: pointer;
}
.filters-list-toggle:hover {
  text-decoration: underline;
}

.chain-filters {
  display: flex;
  background: #ffffff;
  margin-bottom: 24px;
  box-shadow: rgba(123, 135, 148, 0.5) 0 2px 8px;
}
.chain-filters > div {
  padding: 16px;
}
.chain-filters > div:first-child {
  font-weight: 500;
  cursor: pointer;
}
.chain-filters > div:first-child:hover {
  text-decoration: underline;
}
.chain-filters > div:first-child i {
  color: var(--blueValue);
  margin-right: 6px;
}
.chain-filters > div:first-child span {
  display: none;
  font-weight: 400;
  color: var(--textValue);
}
.chain-filters > div:last-child {
  color: var(--textValue);
  margin-left: auto;
}

.content-price-range {
  margin-top: 11px;
  text-align: center;
}
.content-price-range input {
  display: none;
}
.content-price-range .content-price-range-value {
  display: flex;
  margin-top: 20px;
}
.content-price-range .content-price-range-value > div {
  min-width: 60px;
  height: 24px;
  line-height: 22px;
  border: 1px solid #d0def0;
  padding: 0 10px;
  vertical-align: top;
}
.content-price-range .content-price-range-value > div:last-child {
  margin-left: auto;
}

/* ===================================
   NO AVAIL
=================================== */
.noavail-head {
  display: flex;
  background: #ffffff;
  box-shadow: rgba(123, 135, 148, 0.5) 0 2px 8px;
}
.noavail-head > div:first-child {
  width: 300px;
}
.noavail-head > div:first-child img {
  width: 100%;
}
.noavail-head > div:last-child {
  flex: 1;
  padding: 24px 30px;
}
.noavail-head .content-desc {
  margin-top: 8px;
}
.noavail-head .content-desc a {
  color: var(--blueValue);
}
.noavail-head .noavail-head-cta {
  font-weight: 700;
  color: var(--blueValue);
  cursor: pointer;
  text-decoration: underline;
}
.noavail-head .noavail-head-contacts {
  margin-top: 24px;
}
.noavail-head .noavail-head-contacts a {
  display: inline-block;
  height: 46px;
  line-height: 46px;
  background: #f0f4f8;
  color: var(--blueValue);
  border: 1px solid #d0def0;
  border-radius: 30px;
  margin: 16px 15px 0 1px;
  padding: 0 24px 0 58px;
  text-decoration: none;
  position: relative;
}
.noavail-head .noavail-head-contacts a:hover {
  text-decoration: underline;
}
.noavail-head .noavail-head-contacts a i {
  display: block;
  width: 46px;
  height: 46px;
  line-height: 46px;
  font-size: 20px;
  background: var(--blueValue);
  color: #ffffff;
  border-radius: 50%;
  text-align: center;
  position: absolute;
  top: -1px;
  left: -1px;
}

.alternatives {
  background: #ffffff;
  margin-top: 24px;
  padding: 24px 16px;
  box-shadow: rgba(123, 135, 148, 0.5) 0 2px 8px;
}
.alternatives .alternatives-txt {
  color: var(--textValue);
  margin-top: 8px;
}
.alternatives .alternatives-txt.fail {
  display: none;
  color: #ab2727;
}
.alternatives .alternatives-loader > div {
  width: calc(25% - 12px);
  height: 103px;
  margin: 12px 12px 0 0;
  background: #f0f4f8;
  border: 1px solid #d9e2ec;
  text-align: center;
}
.alternatives .alternatives-loader > div span {
  display: block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  box-shadow: 0 16px 0 var(--textValue);
  margin: -15px auto 0 auto;
  position: relative;
  animation: alternativesLoading 0.8s ease-in-out alternate infinite;
  animation-delay: 0.32s;
  top: 50%;
}
.alternatives .alternatives-loader > div span:before, .alternatives .alternatives-loader > div span:after {
  content: "";
  position: absolute;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  box-shadow: 0 16px 0 var(--textValue);
  animation: alternativesLoading 0.8s ease-in-out alternate infinite;
}
.alternatives .alternatives-loader > div span:before {
  left: -16px;
  animation-delay: 0.48s;
}
.alternatives .alternatives-loader > div span:after {
  right: -16px;
  animation-delay: 0.16s;
}
.alternatives .alternatives-wrap {
  margin: 6px -12px 0 0;
  position: relative;
}
.alternatives .alternatives-wrap > div {
  display: flex;
  flex-wrap: wrap;
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
}
.alternatives #alternatives-list {
  z-index: 2;
}
.alternatives #alternatives-list .alternative-card {
  width: calc(25% - 12px);
  height: 103px;
  margin: 12px 12px 0 0;
  background: #f0f4f8;
  border: 1px solid #d9e2ec;
  cursor: pointer;
  padding: 12px 16px;
}
.alternatives #alternatives-list .alternative-card-date {
  font-weight: 900;
  text-transform: capitalize;
}
.alternatives #alternatives-list .alternative-card-search {
  color: var(--textValue);
}
.alternatives #alternatives-list .alternative-card-price {
  font-weight: 900;
  color: var(--blueValue);
  margin-top: 10px;
  text-decoration: underline;
  text-transform: lowercase;
}
.alternatives #alternatives-list .view-on-map {
  display: none !important;
}
.alternatives .alternatives-hotels {
  display: flex;
  flex-wrap: wrap;
  margin: 6px -12px 0 0;
}
.alternatives .alternatives-hotels a {
  width: calc(25% - 12px);
  margin: 12px 12px 0 0;
  background: #f0f4f8;
  color: #102a43;
  border: 1px solid #d9e2ec;
  cursor: pointer;
  text-decoration: none;
}
.alternatives .alternatives-hotels a .alternatives-hotel-img {
  height: 140px;
  background: #d9e2ec;
  position: relative;
}
.alternatives .alternatives-hotels a .alternatives-hotel-img > div {
  background-size: cover;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}
.alternatives .alternatives-hotels a .alternatives-hotel-txt {
  padding: 16px 12px;
}
.alternatives .alternatives-hotels a .alternatives-hotel-txt > h2 {
  font-size: 14px;
  font-weight: 500;
}
.alternatives .alternatives-hotels a .alternatives-hotel-txt .stars {
  font-size: 12px;
}
.alternatives .alternatives-hotels a .alternatives-hotel-txt .alternatives-hotel-address {
  color: var(--textValue);
  margin-top: 8px;
}
.alternatives .alternatives-hotels a .alternatives-hotel-txt .alternatives-hotel-price {
  font-weight: 900;
  color: var(--blueValue);
  margin-top: 16px;
  text-decoration: underline;
  text-transform: lowercase;
}

.noavail-planner {
  font-size: 12px;
  background: #ffffff;
  margin-top: 24px;
  padding: 24px 16px;
  box-shadow: rgba(123, 135, 148, 0.5) 0 2px 8px;
}
.noavail-planner .noavail-planner-head {
  display: flex;
  margin-bottom: 24px;
}
.noavail-planner .noavail-planner-head > div {
  display: flex;
  align-items: center;
  margin-left: auto;
}
.noavail-planner .noavail-planner-head > div > div {
  line-height: 16px;
  font-weight: 900;
  margin-left: 30px;
  padding-left: 26px;
  position: relative;
  text-transform: uppercase;
}
.noavail-planner .noavail-planner-head > div > div:before {
  content: "";
  width: 16px;
  height: 16px;
  background: #b8ebbd;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
}
.noavail-planner .noavail-planner-head > div > div.closed:before {
  background: #ffc9c9;
}
.noavail-planner .noavail-planner-head > div > div.restrict:after {
  content: "R";
  font-size: 10px;
  font-weight: 700;
  color: #009c12;
  position: absolute;
  top: 50%;
  left: 4px;
  transform: translateY(-50%);
}
.noavail-planner .noavail-planner-head > div > div span {
  display: block;
  font-size: 10px;
  font-weight: 400;
  text-transform: initial;
}
.noavail-planner table {
  width: 100%;
  border-spacing: 0;
  border-collapse: collapse;
  table-layout: fixed;
}
.noavail-planner table thead td {
  height: 32px;
  line-height: 32px;
  font-weight: 900;
  background: #f0f4f8;
  border: 1px solid #ffffff;
  padding: 0 8px;
  overflow: hidden;
  text-align: center;
  text-overflow: ellipsis;
  text-transform: capitalize;
  vertical-align: middle;
  white-space: nowrap;
}
.noavail-planner table thead td.nap-month {
  background: #d9e2ec;
  text-align: left;
}
.noavail-planner table tbody tr td:first-child {
  padding: 0 8px;
}
.noavail-planner table tbody tr:nth-child(odd) td:first-child {
  background: #f0f4f8 !important;
}
.noavail-planner table tbody td {
  height: 45px;
  line-height: 16px;
  outline: 1px solid #ffffff;
  cursor: pointer;
  position: relative;
  text-align: center;
  vertical-align: middle;
}
.noavail-planner table tbody td:first-child {
  cursor: default;
  text-align: left;
}
.noavail-planner table tbody td:after {
  content: attr(data-price);
  font-size: 11px;
  color: #00690c;
  white-space: nowrap;
}
.noavail-planner table tbody td.checkin, .noavail-planner table tbody td.checkout {
  background: #b8ebbd !important;
}
.noavail-planner table tbody td.closed {
  background: #ffc9c9 !important;
  pointer-events: none;
}
.noavail-planner table tbody td.closed:after {
  display: none;
}
.noavail-planner table tbody td.open {
  background: #b8ebbd;
}
.noavail-planner table tbody td.incstay, .noavail-planner table tbody td.minadv, .noavail-planner table tbody td.maxadv, .noavail-planner table tbody td.minstay, .noavail-planner table tbody td.maxstay, .noavail-planner table tbody td.restrict {
  background: #b8ebbd !important;
}
.noavail-planner table tbody td.incstay:before, .noavail-planner table tbody td.minadv:before, .noavail-planner table tbody td.maxadv:before, .noavail-planner table tbody td.minstay:before, .noavail-planner table tbody td.maxstay:before, .noavail-planner table tbody td.restrict:before {
  display: block;
  content: "R";
  font-weight: 700;
  color: #009c12;
}
.noavail-planner table tbody td.selectedDay {
  background: var(--blueValue) !important;
}
.noavail-planner table tbody td.selectedDay:before, .noavail-planner table tbody td.selectedDay:after {
  color: #ffffff;
}
.noavail-planner table tbody td.selectedDayRange {
  border-right-color: var(--blueValue);
  border-left-color: var(--blueValue);
}
.noavail-planner table tbody td.selectedDayOut {
  background: #e4f0fa !important;
  border-right-color: #ffffff;
  position: relative;
}
.noavail-planner table tbody td.selectedDayOut:before, .noavail-planner table tbody td.selectedDayOut:after {
  color: var(--blueValue);
}
.noavail-planner table tbody td.selectedDayOut .selectedChild {
  display: block;
  width: 10px;
  height: 10px;
  background: var(--blueValue);
  position: absolute;
  top: 17px;
  left: -6px;
  z-index: 2;
  transform: rotate(45deg);
}
.noavail-planner table tbody td i {
  font-size: 10px;
  margin-right: 6px;
}
.noavail-planner .nap-day {
  font-weight: 400;
  background: #ffffff;
}
.noavail-planner .nap-name {
  width: 222px;
  background: transparent !important;
}
.noavail-planner .nap-room:hover {
  cursor: pointer;
  text-decoration: underline;
}
.noavail-planner .nap-space {
  width: 16px;
  background: #ffffff !important;
}

#noavail-popup {
  display: none;
  background: rgba(0, 0, 0, 0.7);
  padding: 0 20px;
  position: fixed;
  z-index: 999;
  overflow-x: hidden;
  overflow-y: auto;
}
#noavail-popup .noavail-popup-table {
  display: table;
  width: 100%;
  height: 100%;
}
#noavail-popup .noavail-popup-table > div {
  display: table-cell;
  vertical-align: middle;
}
#noavail-popup .noavail-popup-wrap {
  width: 408px;
  background: #ffffff;
  box-shadow: rgba(131, 151, 178, 0.24) 0 3px 6px;
  margin: 60px auto;
  position: relative;
}
#noavail-popup .noavail-popup-close {
  width: 24px;
  height: 24px;
  line-height: 24px;
  font-size: 16px;
  text-align: center;
  cursor: pointer;
  position: absolute;
  top: 30px;
  right: 16px;
}
#noavail-popup .noavail-popup-data {
  padding: 30px 24px 24px 24px;
}
#noavail-popup .noavail-popup-data .noavail-popup-room {
  color: var(--blueValue);
  padding-right: 60px;
}
#noavail-popup .noavail-popup-data .msg {
  font-weight: 700;
  margin: 8px 0 16px 0;
}
#noavail-popup .noavail-popup-data .in,
#noavail-popup .noavail-popup-data .out {
  display: none;
  height: 48px;
  line-height: 48px;
  border: 1px solid #d9e2ec;
  margin-top: 8px;
  padding: 0 16px;
  vertical-align: top;
}
#noavail-popup .noavail-popup-data .in.btn,
#noavail-popup .noavail-popup-data .out.btn {
  background: var(--blueValue);
  color: #ffffff;
  cursor: pointer;
  text-align: center;
}
#noavail-popup .noavail-popup-data .go {
  display: none;
  margin-top: 8px;
}
#noavail-popup .noavail-popup-data .go a {
  display: block;
  width: auto;
  height: 48px;
  line-height: 48px;
}
#noavail-popup .noavail-popup-data .detail ul {
  list-style: none;
  color: var(--textValue);
  margin: 24px 0 0 0;
  padding: 0;
}
#noavail-popup .noavail-popup-data .detail ul i {
  display: inline-block;
  width: 20px;
  color: var(--blueValue);
  margin-right: 8px;
  text-align: center;
}

.noavail-request > div {
  display: inline-block;
  width: calc(50% - 12px);
  background: #ffffff;
  margin-top: 24px;
  padding: 16px;
  letter-spacing: normal;
  vertical-align: top;
  box-shadow: rgba(123, 135, 148, 0.5) 0 2px 8px;
}
.noavail-request > div:first-child {
  margin-right: 24px;
}
.noavail-request > div.open {
  padding-top: 24px;
  padding-bottom: 24px;
}
.noavail-request > div.open .noavail-toggle {
  margin-bottom: 8px;
}
.noavail-request .noavail-toggle {
  cursor: pointer;
}
.noavail-request .noavail-toggle i {
  float: right;
}
.noavail-request form {
  display: none;
}

@keyframes alternativesLoading {
  100% {
    box-shadow: 0 8px 0 var(--textValue);
  }
}
/* ===================================
   POPUP
=================================== */
.popup {
  background: rgba(0, 0, 0, 0.7);
  padding: 0 40px;
  position: fixed;
  top: 0;
  right: -20px;
  bottom: 0;
  left: -20px;
  z-index: -1;
  opacity: 0;
  overflow-x: hidden;
  overflow-y: auto;
  visibility: hidden;
}
.popup.visible {
  z-index: 999;
  opacity: 1;
  visibility: visible;
  -webkit-overflow-scrolling: touch;
}
.popup .popup-table {
  display: table;
  width: 100%;
  height: 100%;
}
.popup .popup-table > div {
  display: table-cell;
  vertical-align: middle;
}
.popup .popup-wrap {
  width: 736px;
  background: #ffffff;
  box-shadow: rgba(131, 151, 178, 0.24) 0 3px 6px;
  margin: 60px auto;
  padding: 36px 24px;
  position: relative;
}
.popup .popup-wrap .popup-close {
  top: 16px;
  right: 16px;
}
.popup .popup-wrap .content-title {
  margin-bottom: 8px;
  padding-right: 120px;
}
.popup .popup-wrap a {
  color: var(--blueValue);
}

.popup-room {
  display: table;
  width: 100%;
  height: 100%;
  background: #000;
  position: fixed;
  top: 0;
  right: 0;
  bottom: 200px;
  left: 0;
  opacity: 0;
  z-index: -1;
  visibility: hidden;
}
.popup-room.visible {
  opacity: 1;
  z-index: 1000;
  visibility: visible;
}
.popup-room > div {
  display: table-cell;
  position: relative;
  vertical-align: top;
}
.popup-room > div:last-child {
  width: 440px;
}
.popup-room .popup-close {
  top: 16px;
  right: 16px;
}
.popup-room .popup-container {
  padding-top: 64px;
}
.popup-room .content-title.xl {
  margin-bottom: 16px;
}
.popup-room .content-list ul li {
  font-size: 14px;
}

.popup-sale {
  display: table;
  table-layout: fixed;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.7);
  position: fixed;
  top: 0;
  right: 0;
  bottom: 200px;
  left: 0;
  opacity: 0;
  z-index: -1;
  visibility: hidden;
}
.popup-sale.visible {
  opacity: 1;
  z-index: 1000;
  visibility: visible;
}
.popup-sale > div {
  display: table-cell;
  position: relative;
  vertical-align: top;
}
.popup-sale > div:last-child {
  width: 440px;
}
.popup-sale .popup-close {
  top: 16px;
  right: 16px;
}
.popup-sale .popup-container {
  padding-top: 0;
  padding-bottom: 0;
}
.popup-sale .popup-container > div:last-child {
  margin-bottom: 60px;
}
.popup-sale .popup-container .content-title.xl {
  margin-bottom: 6px;
}
.popup-sale .card-slider {
  width: calc(100% + 48px);
  height: 293px;
  cursor: default;
  margin: 0 -24px 30px -24px;
}
.popup-sale .card-slider .swiper-container {
  width: 100%;
}

.popup-visual.popup-priceckeck .content-title {
  padding-right: 80px;
}
.popup-visual.popup-priceckeck .content-title i {
  color: #009c12;
  margin-left: 4px;
  transform: translateY(1px);
}
.popup-visual.popup-priceckeck .content-add {
  min-width: 140px;
  color: #ffffff;
}
.popup-visual.popup-psw.visible {
  z-index: 1000;
}
.popup-visual.popup-cancel .content-add {
  color: #ffffff;
  margin: 24px 8px 0 0;
}
.popup-visual.popup-cancel .content-add.cancel {
  color: #ab2727;
}
.popup-visual.popup-fast-message .popup-wrap > div.popup-last-div {
  background-color: #fffae6;
  padding-top: 20px;
}
.popup-visual.popup-fast-message .popup-wrap > div h2 {
  color: #9c7e00;
}
.popup-visual.popup-fast-message .popup-wrap > div .popup-close {
  color: #9c7e00;
  background-color: rgba(156, 126, 0, 0.2);
  border-radius: 32px;
  line-height: 33px;
}
.popup-visual.popup-fast-message .popup-wrap > div .popup-close i {
  margin-left: 1px;
}
.popup-visual .popup-wrap {
  width: 960px;
  display: table;
  padding: 0;
}
.popup-visual .popup-wrap > div {
  display: table-cell;
  width: 50%;
  position: relative;
  vertical-align: top;
}
.popup-visual .popup-wrap > div.popup-first-div {
  background: #d9e2ec;
}
.popup-visual .popup-wrap > div.popup-first-div > div {
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}
.popup-visual .popup-wrap > div.popup-last-div {
  padding: 36px 24px;
}
.popup-visual .popup-close {
  width: 32px;
  background: none;
  color: #102a43;
  border-radius: 0;
  padding: 0;
  text-align: center;
}
.popup-visual .popup-close i {
  margin: 0;
}
.popup-visual .popup-separator {
  display: block;
  height: 1px;
  background: #d9e2ec;
  margin: 24px 0;
}
.popup-visual .social-frames {
  margin-top: -16px;
}

.popup-close {
  height: 32px;
  line-height: 32px;
  font-size: 12px;
  background: #000;
  color: #ffffff;
  border-radius: 16px;
  box-shadow: rgba(255, 255, 255, 0.2) 0 0 16px;
  padding: 0 16px;
  cursor: pointer;
  text-transform: uppercase;
  position: absolute;
  z-index: 2;
}
.popup-close i {
  font-size: 16px;
  margin-right: 6px;
  transform: translateY(1px);
}

.popup-gallery {
  position: fixed !important;
  top: 12px;
  right: 452px;
  bottom: 120px;
  left: 12px;
}
.popup-gallery .swiper-wrapper {
  align-items: center;
}
.popup-gallery .swiper-slide {
  height: auto !important;
  text-align: center;
}
.popup-gallery .swiper-slide.portrait {
  background-size: contain;
  height: inherit !important;
}
.popup-gallery .swiper-slide img {
  max-width: 100%;
  max-height: 100%;
  height: inherit !important;
}
.popup-gallery .swiper-slide .swiper-caption {
  display: flex;
  position: absolute;
  right: 0;
  bottom: -48px;
  left: 0;
}
.popup-gallery .swiper-slide .swiper-caption > div {
  max-width: 800px;
  background: rgba(255, 255, 255, 0.9);
  margin: auto;
  padding: 16px 24px;
}
.popup-gallery .swiper-slide .swiper-caption > div > h2 {
  font-size: 16px;
  font-weight: 900;
  color: #000;
}
.popup-gallery .swiper-slide .swiper-caption > div > div {
  color: var(--textValue);
  margin-top: 6px;
}

.popup-gallery-thumbs {
  position: absolute !important;
  bottom: 0;
  right: 0;
  left: 0;
}
.popup-gallery-thumbs .swiper-slide {
  width: 96px;
  height: 96px;
  margin-top: 12px;
  margin-bottom: 12px;
  border: 2px solid transparent;
  border-radius: 4px;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  cursor: pointer;
}
.popup-gallery-thumbs .swiper-slide.swiper-slide-thumb-active {
  border-color: var(--blueValue);
}

.popup-gallery-controls i {
  display: block;
  width: 25%;
  font-size: 60px;
  font-weight: 300;
  color: rgba(255, 255, 255, 0.8);
  cursor: pointer;
  position: absolute;
  top: 12px;
  bottom: 120px;
  z-index: 2;
}
.popup-gallery-controls i:hover:first-child {
  background: linear-gradient(to right, rgba(0, 0, 0, 0.5), rgba(255, 255, 255, 0));
}
.popup-gallery-controls i:hover:last-child {
  background: linear-gradient(to left, rgba(0, 0, 0, 0.5), rgba(255, 255, 255, 0));
}
.popup-gallery-controls i:first-child {
  left: 0;
}
.popup-gallery-controls i:first-child:before {
  left: 30px;
}
.popup-gallery-controls i:last-child {
  right: 0;
}
.popup-gallery-controls i:last-child:before {
  right: 30px;
}
.popup-gallery-controls i:before {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}
.popup-gallery-controls i.swiper-button-disabled {
  opacity: 0;
}

.popup-container {
  width: 440px;
  background: #f7f7f7;
  padding: 40px 24px 60px 24px;
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
.popup-container .popup-subtitle {
  color: var(--blueValue);
  margin-top: 8px;
  position: relative;
  padding-left: 28px;
}
.popup-container .popup-subtitle i {
  position: absolute;
  top: 4px;
  left: 0;
}
.popup-container .popup-beds {
  color: var(--blueValue);
  margin-top: 8px;
  position: relative;
}
.popup-container .popup-beds > i {
  position: absolute;
  top: 4px;
  left: 0;
}
.popup-container .popup-beds > div {
  padding-left: 28px;
}
.popup-container .popup-beds > div > span {
  font-style: italic;
  color: var(--textValue);
}
.popup-container .popup-required {
  color: var(--blueValue);
}
.popup-container .popup-description {
  color: var(--textValue);
  margin-top: 16px;
}
.popup-container .popup-separator {
  height: 1px;
  background: #d9e2ec;
  margin: 30px 0;
}
.popup-container .content-list li {
  display: inline-block;
}
.popup-container ul {
  padding-left: 16px;
}

.popup-daily-details {
  display: table;
  width: 100%;
  margin-top: 8px;
}
.popup-daily-details > div {
  display: table-row;
}
.popup-daily-details > div:nth-child(odd) {
  background: #f0f4f8;
}
.popup-daily-details > div > div {
  display: table-cell;
  padding: 6px 8px;
  vertical-align: middle;
}
.popup-daily-details > div > div:last-child {
  text-align: right;
}

.popup-daily-notes {
  list-style: none;
  margin: 16px 0 0 0;
  padding: 0 !important;
  font-size: 12px;
  color: var(--textValue);
}

.popup-best-rate {
  display: flex;
  width: 440px;
  background: #ffffff;
  box-shadow: rgba(123, 135, 148, 0.24) 0 -4px 8px;
  position: fixed;
  bottom: 0;
  right: 0;
  z-index: 2;
}
.popup-best-rate.no-search {
  display: block;
  padding: 16px;
  text-align: center;
}
.popup-best-rate > div {
  padding: 24px;
}
.popup-best-rate > div:last-child {
  margin-left: auto;
  text-align: right;
}
.popup-best-rate .popup-best-rate-field {
  display: inline-block;
  font-size: 12px;
  color: var(--textValue);
  margin: 9px 16px 0 0;
  vertical-align: top;
}
.popup-best-rate .popup-best-rate-field i {
  font-size: 14px;
  color: var(--blueValue);
  margin-right: 3px;
}
.popup-best-rate .popup-best-rate-best-rate {
  display: none;
  font-size: 12px;
  color: #009c12;
}
.popup-best-rate .popup-best-rate-best-rate i {
  font-size: 14px;
  margin-right: 6px;
  transform: translateY(1px);
}
.popup-best-rate .content-add {
  display: block;
  margin-top: 6px;
  text-align: center;
}
.popup-best-rate .content-add span {
  display: block;
  width: auto;
}

.popup-map {
  background: #ffffff;
  position: fixed;
  z-index: -1;
  opacity: 0;
  visibility: hidden;
}
.popup-map.visible {
  z-index: 999;
  opacity: 1;
  visibility: visible;
}
.popup-map .popup-close {
  top: 16px;
  right: 16px;
  z-index: 999;
}
.popup-map #map {
  position: absolute;
  right: 440px;
}
.popup-map #popup-map-list {
  position: fixed;
  right: 440px;
  bottom: 8px;
  left: 0;
  z-index: 1001;
}
.popup-map #popup-map-list .swiper-container {
  z-index: 1001;
}
.popup-map #popup-map-list .swiper-wrapper {
  height: auto;
}
.popup-map #popup-map-list .swiper-slide {
  display: flex;
  width: calc(25% - 36px);
  background: #ffffff;
  border: 1px solid transparent;
  box-shadow: rgba(123, 135, 148, 0.24) 0 3px 6px;
  cursor: pointer;
}
.popup-map #popup-map-list .swiper-slide:hover .swiper-slide-btn {
  text-decoration: underline;
}
.popup-map #popup-map-list .swiper-slide.active {
  border-color: var(--darkblueValue);
}
.popup-map #popup-map-list .swiper-slide > div {
  display: table-cell;
  height: 116px;
  vertical-align: top;
}
.popup-map #popup-map-list .swiper-slide .swiper-slide-img {
  width: 150px;
  background: #f0f4f8;
  position: relative;
}
.popup-map #popup-map-list .swiper-slide .swiper-slide-img > div {
  min-height: 112px;
  background-size: cover;
  position: absolute;
  top: 2px;
  right: 2px;
  bottom: 2px;
  left: 2px;
}
.popup-map #popup-map-list .swiper-slide .swiper-slide-content {
  padding: 12px 16px 12px 12px;
}
.popup-map #popup-map-list .swiper-slide .swiper-slide-content > div {
  display: table;
  width: 100%;
}
.popup-map #popup-map-list .swiper-slide .swiper-slide-content > div > div {
  display: table-cell;
  vertical-align: top;
}
.popup-map #popup-map-list .swiper-slide .swiper-slide-content > div > div:last-child {
  line-height: 16px;
  font-size: 12px;
  color: var(--textValue);
  padding-left: 12px;
  text-align: right;
  text-transform: lowercase;
}
.popup-map #popup-map-list .swiper-slide .swiper-slide-content > div > div > h2 {
  font-size: 14px;
  font-weight: 500;
}
.popup-map #popup-map-list .swiper-slide .swiper-slide-content > div > div > h2 .stars {
  display: block;
  font-size: 12px;
  margin-top: 4px;
}
.popup-map #popup-map-list .swiper-slide .swiper-slide-content > div .swiper-slide-place {
  max-width: 200px;
  font-size: 12px;
  color: var(--textValue);
  margin-top: 8px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.popup-map #popup-map-list .swiper-slide .swiper-slide-content > div .content-price {
  font-size: 16px;
  color: var(--darkblueValue);
  white-space: nowrap;
}
.popup-map #popup-map-list .swiper-slide .swiper-slide-content > div .swiper-slide-btn {
  display: inline-block;
  color: var(--blueValue);
  white-space: nowrap;
  position: absolute;
  right: 12px;
  bottom: 12px;
  text-transform: uppercase;
}
.popup-map #popup-map-list .popup-map-list-controls i {
  width: 40px;
  height: 40px;
  line-height: 40px;
  font-size: 30px;
  background: #ffffff;
  box-shadow: rgba(123, 135, 148, 0.24) 0 3px 6px;
  border-radius: 50%;
  cursor: pointer;
  text-align: center;
  position: absolute;
  top: 50%;
  z-index: 1003;
  transform: translateY(-50%);
}
.popup-map #popup-map-list .popup-map-list-controls i:hover {
  background: #f0f4f8;
}
.popup-map #popup-map-list .popup-map-list-controls i.fa-angle-right {
  right: 16px;
}
.popup-map #popup-map-list .popup-map-list-controls i.fa-angle-left {
  left: 16px;
}
.popup-map .popup-map-info {
  display: none;
  width: 440px;
  background: #f0f4f8;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  overflow-y: auto;
}
.popup-map .popup-map-info .popup-map-info-img {
  height: 293px;
  background: #ffffff;
  position: relative;
}
.popup-map .popup-map-info .popup-map-info-img > div {
  background-size: cover;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}
.popup-map .popup-map-info .popup-map-info-container {
  padding: 24px 16px;
}
.popup-map .popup-map-info .popup-map-info-container .popup-map-info-contacts {
  margin-top: 4px;
}
.popup-map .popup-map-info .popup-map-info-container .popup-map-info-contacts > div {
  display: inline-block;
  line-height: 20px;
  margin: 8px 24px 0 0;
  padding-left: 28px;
  letter-spacing: normal;
  position: relative;
  vertical-align: top;
}
.popup-map .popup-map-info .popup-map-info-container .popup-map-info-contacts > div a {
  display: block;
  color: #102a43;
  text-decoration: none;
  vertical-align: top;
}
.popup-map .popup-map-info .popup-map-info-container .popup-map-info-contacts > div a span {
  text-decoration: underline;
}
.popup-map .popup-map-info .popup-map-info-container .popup-map-info-contacts > div i {
  display: block;
  width: 20px;
  height: 20px;
  color: var(--blueValue);
  text-align: center;
  position: absolute;
  top: 3px;
  left: 0;
}
.popup-map .popup-map-info .popup-map-info-container .card-description {
  color: var(--textValue);
}
.popup-map .popup-map-info .popup-map-info-container .card-description.truncated {
  height: 110px;
  overflow: hidden;
  position: relative;
}
.popup-map .popup-map-info .popup-map-info-container .card-description.truncated:after {
  content: "";
  height: 36px;
  background: linear-gradient(rgba(240, 244, 248, 0), #f0f4f8);
  position: absolute;
  bottom: 0;
  right: 0;
  left: 0;
}
.popup-map .popup-map-info .popup-map-info-container .card-services .content-title {
  margin-bottom: 4px;
}
.popup-map .popup-map-info .popup-best-rate > div:first-child > div {
  line-height: 18px;
  margin-top: 6px;
}
.popup-map .popup-map-info .popup-best-rate > div:first-child > div:nth-child(2) {
  font-weight: 500;
}
.popup-map .popup-map-info .popup-best-rate .best-price-nights {
  line-height: 18px;
  color: var(--textValue);
  margin-top: 6px;
}
.popup-map .popup-map-info .popup-best-rate .content-add {
  width: auto;
  white-space: nowrap;
}

.popup-legal {
  /*top: inherit;*/
  /*background: transparent;*/
}
.popup-legal .popup-table > div {
  vertical-align: bottom;
}
.popup-legal .popup-table > div .popup-wrap {
  border: 4px solid var(--blueValue);
  margin: 0 auto 20px auto;
}

.map-marker {
  width: auto !important;
  height: 36px !important;
  line-height: 36px;
  font-size: 14px;
  font-weight: 700;
  background: #ffffff;
  color: var(--blueValue);
  box-shadow: rgba(0, 0, 0, 0.2) 0 6px 9px;
  padding: 0 12px;
  text-align: center;
  white-space: nowrap;
}
.map-marker:hover {
  background: var(--blueValue);
  color: #ffffff;
}
.map-marker:hover:before, .map-marker:hover:after {
  background: var(--blueValue);
}
.map-marker:before {
  content: "";
  height: 7px;
  background: #ffffff;
  position: absolute;
  bottom: 0;
  right: 0;
  left: 0;
  z-index: 2;
}
.map-marker:after {
  display: block;
  content: "";
  width: 12px;
  height: 12px;
  background: #ffffff;
  box-shadow: rgba(0, 0, 0, 0.2) 0 6px 9px;
  position: absolute;
  bottom: -6px;
  left: 50%;
  transform: translateX(-50%) rotate(45deg);
}
.map-marker i {
  font-size: 18px;
}

.popup-filters {
  display: none;
  background: rgba(0, 0, 0, 0.7);
  padding: 0 20px;
  position: fixed;
  z-index: 999;
}
.popup-filters .popup-table {
  display: table;
  width: 100%;
  height: 100%;
}
.popup-filters .popup-table > div {
  display: table-cell;
  vertical-align: middle;
}
.popup-filters .popup-wrap {
  width: 408px;
  max-height: 60vh;
  background: #ffffff;
  box-shadow: rgba(131, 151, 178, 0.24) 0 3px 6px;
  padding: 30px 24px 0 24px;
  margin: 0 auto;
  position: relative;
  overflow-x: hidden;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
.popup-filters .popup-chain-close {
  width: 24px;
  height: 24px;
  line-height: 24px;
  font-size: 16px;
  text-align: center;
  cursor: pointer;
  position: absolute;
  top: 30px;
  right: 16px;
}
.popup-filters .popup-filters-last {
  height: 30px;
}
.popup-filters .popup-filters-btn {
  width: 408px;
  height: 60px;
  line-height: 60px;
  font-size: 12px;
  font-weight: 900;
  background: var(--blueValue);
  color: #ffffff;
  cursor: pointer;
  margin: 0 auto;
  text-align: center;
  text-transform: uppercase;
}
.popup-filters .popup-filters-btn:hover {
  background: var(--blueValueRgbLighten);
}

.page-action-simple-step5 .leaflet-touch .leaflet-bar {
  margin: 16px 0 0 16px !important;
}

html .leaflet-touch .leaflet-bar {
  border: 0;
  margin: 16px 0 0 16px;
}
html .leaflet-touch .leaflet-bar a {
  line-height: 28px;
  font-family: "Circular";
  font-size: 20px;
  font-weight: 300;
  background: #ffffff;
  color: #102a43;
  border: 0;
}
html .leaflet-touch .leaflet-bar a:hover {
  background: #f0f4f8;
}
html .leaflet-touch .leaflet-bar a:first-child {
  border-radius: 0;
}
html .leaflet-touch .leaflet-bar a:last-child {
  border-radius: 0;
  border-top: 1px solid #d0def0;
}
html .leaflet-touch .leaflet-bar a.leaflet-disabled {
  color: #d0def0;
}
html .leaflet-popup {
  transition: none !important;
}
html .leaflet-popup-content-wrapper,
html .leaflet-popup-tip {
  background: #ffffff;
  border-radius: 0;
  box-shadow: rgba(0, 0, 0, 0.2) 0 6px 9px;
}
html .leaflet-popup-tip-container {
  margin-top: -1px;
}
html .leaflet-popup-tip {
  width: 12px;
  height: 12px;
  margin-top: -6px;
}
html .leaflet-popup-content {
  width: 130px;
  margin: 11px;
  text-align: center;
}
html .leaflet-popup-content img {
  display: block;
  width: 100%;
  margin: auto;
  vertical-align: top;
}
html .leaflet-popup-content div {
  font-size: 14px;
  font-weight: 500;
  color: var(--blueValue);
}
html .leaflet-popup-close-button {
  display: none;
}

.step5-changesummary table.change-summary tr th.change-summary-label,
.step5-changesummary table.change-summary tr th.change-summary-icon,
.step5-changesummary table.change-summary tr td.change-summary-label,
.step5-changesummary table.change-summary tr td.change-summary-icon {
  display: none;
}
.step5-changesummary table.change-summary tr:nth-child(even) {
  background-color: #eff0f2;
}
.step5-changesummary table.change-summary tr th,
.step5-changesummary table.change-summary tr td {
  text-align: left;
  padding: 16px 24px;
}
.step5-changesummary table.change-summary tr th.change-summary-new,
.step5-changesummary table.change-summary tr td.change-summary-new {
  background-color: #e6ffe8;
}

.personalurl {
  float: right;
  color: white;
  text-decoration: underline;
  font-weight: normal;
  font-size: small;
  cursor: pointer;
}

/* ===================================
   POPUP CHANGE BOOKING
=================================== */
.navigator-btn6 {
  text-decoration: underline !important;
}

#popup-change {
  top: 100px;
  padding: 0;
}
#popup-change.visible {
  overflow: auto;
}
#popup-change .change-summary-scroller {
  overflow: auto;
  max-height: calc(100vh - 144px);
  display: inline-flex;
}
#popup-change .change-summary-wrapper {
  position: relative;
}
#popup-change .change-summary-wrapper:before {
  box-sizing: border-box;
  position: absolute;
  content: "";
  top: -24px;
  left: 0;
  width: 52px;
  height: 24px;
  border-style: solid;
  border-width: 0 26px 12px 26px;
  border-color: transparent transparent #ffffff transparent;
}
#popup-change table.change-summary {
  background-color: #ffffff;
  border-collapse: collapse;
}
#popup-change table.change-summary th,
#popup-change table.change-summary td {
  padding: 16px;
  text-align: left;
  vertical-align: top;
}
#popup-change table.change-summary tr th.change-summary-label {
  display: none;
}
#popup-change table.change-summary tr th.change-summary-old,
#popup-change table.change-summary tr th.change-summary-new {
  border-left: 1px solid #d0def0;
}
#popup-change table.change-summary tr td.change-summary-label {
  display: none;
}
#popup-change table.change-summary tr td.change-summary-icon {
  border-top: 1px solid #d0def0;
  text-align: center;
  width: 52px;
  font-size: 16px;
  color: var(--blueValue);
}
#popup-change table.change-summary tr td.change-summary-icon.no-show {
  border-top: 0;
}
#popup-change table.change-summary tr td.change-summary-old,
#popup-change table.change-summary tr td.change-summary-new {
  border-top: 1px solid #d0def0;
  border-left: 1px solid #d0def0;
  width: 232px;
}
#popup-change table.change-summary .change-summary-new {
  background-color: #e6ffe8;
}

#popup-change .wrapper {
  padding: 20px 40px;
}

@media (min-width: 1401px) {
  #popup-change .wrapper {
    max-width: 100%;
  }
}
@media (min-width: 1440px) {
  #popup-change .wrapper {
    max-width: 1440px;
  }
}
.changed {
  color: var(--blueValue);
  font-weight: 900;
}

.change-item-title {
  font-weight: 900;
  margin-bottom: 4px;
}

.change-item-description {
  color: #8397b2;
  font-size: 12px;
}

.change-item-price {
  margin-top: 8px;
  font-weight: 900;
}

.change-item-price-old {
  font-size: 10px;
  color: #8397b2;
  text-decoration: line-through;
}

.change-price-old {
  color: var(--blueValue);
  font-weight: 900;
}

.change-price-new {
  color: #009c12;
  font-weight: 900;
}

#popup-change-confirm .popup-wrap {
  width: 408px;
  padding: 30px 24px;
}
#popup-change-confirm .popup-wrap .popup-change-close {
  position: absolute;
  background: transparent;
  top: 12px;
  right: 16px;
  box-shadow: none;
}
#popup-change-confirm .popup-wrap .popup-change-close i {
  margin-right: 0;
  color: #102a43;
}
#popup-change-confirm .popup-wrap .popup-change-close span {
  display: none;
}
#popup-change-confirm .popup-wrap .popup-content {
  margin-top: 10px;
}
#popup-change-confirm .popup-wrap .popup-change-confirm {
  background-color: var(--blueValue);
  color: #ffffff;
  font-weight: 900;
  text-transform: uppercase;
  text-align: center;
  margin-top: 26px;
  padding: 10px 24px;
}
#popup-change-confirm .popup-wrap .popup-change-confirm span {
  display: none;
}
#popup-change-confirm .popup-wrap .popup-change-cancel {
  margin-top: 14px;
  padding: 10px 24px;
  font-weight: 900;
  text-transform: uppercase;
  text-align: center;
  color: var(--blueValue);
}
#popup-change-confirm .popup-wrap .popup-change-cancel span {
  display: none;
}

#popup-fee-accept .popup-wrap {
  width: 408px;
  padding: 30px 24px;
}
#popup-fee-accept .popup-wrap .popup-accept-close {
  position: absolute;
  background: transparent;
  top: 12px;
  right: 16px;
  box-shadow: none;
}
#popup-fee-accept .popup-wrap .popup-accept-close i {
  margin-right: 0;
  color: #102a43;
}
#popup-fee-accept .popup-wrap .popup-accept-close span {
  display: none;
}
#popup-fee-accept .popup-wrap .popup-content {
  margin-top: 10px;
}
#popup-fee-accept .popup-wrap .popup-accept-confirm {
  background-color: var(--blueValue);
  color: #ffffff;
  font-weight: 900;
  text-transform: uppercase;
  text-align: center;
  margin-top: 26px;
  padding: 10px 24px;
}
#popup-fee-accept .popup-wrap .popup-accept-confirm span {
  display: none;
}
#popup-fee-accept .popup-wrap .popup-accept-cancel {
  margin-top: 14px;
  padding: 10px 24px;
  font-weight: 900;
  text-transform: uppercase;
  text-align: center;
  color: var(--blueValue);
}
#popup-fee-accept .popup-wrap .popup-accept-cancel span {
  display: none;
}

#popup-fee-customize .popup-wrap {
  width: 408px;
  padding: 30px 24px;
}
#popup-fee-customize .popup-wrap .popup-customize-close {
  position: absolute;
  background: transparent;
  top: 12px;
  right: 16px;
  box-shadow: none;
}
#popup-fee-customize .popup-wrap .popup-customize-close i {
  margin-right: 0;
  color: #102a43;
}
#popup-fee-customize .popup-wrap .popup-customize-close span {
  display: none;
}
#popup-fee-customize .popup-wrap .popup-content {
  margin-top: 10px;
}
#popup-fee-customize .popup-wrap .popup-customize-confirm {
  background-color: var(--blueValue);
  color: #ffffff;
  font-weight: 900;
  text-transform: uppercase;
  text-align: center;
  margin-top: 26px;
  padding: 10px 24px;
}
#popup-fee-customize .popup-wrap .popup-customize-confirm span {
  display: none;
}
#popup-fee-customize .popup-wrap .popup-customize-cancel {
  margin-top: 14px;
  padding: 10px 24px;
  font-weight: 900;
  text-transform: uppercase;
  text-align: center;
  color: var(--blueValue);
}
#popup-fee-customize .popup-wrap .popup-customize-cancel span {
  display: none;
}
#popup-fee-customize.mobile .popup-wrap {
  width: 100%;
}

/* ===================================
   PERSUASIVE MESSAGES
=================================== */
#persuasive-messages {
  display: flex;
  flex-direction: column-reverse;
  padding-left: 12px;
  position: fixed;
  right: 12px;
  bottom: 12px;
  z-index: 10;
}
#persuasive-messages > div {
  max-width: 360px;
  background: rgba(0, 0, 0, 0.85);
  color: #ffffff;
  border-radius: 6px;
  margin-top: 12px;
  padding: 16px 54px 16px 68px;
  opacity: 0;
  position: relative;
  transform: translateY(12px);
  animation: showMsg 8s 1;
}
#persuasive-messages > div .pm-img {
  width: 36px;
  height: 36px;
  background-repeat: no-repeat;
  background-size: contain;
  position: absolute;
  top: 50%;
  left: 16px;
  transform: translateY(-50%);
}
#persuasive-messages > div .pm-close {
  width: 22px;
  height: 22px;
  font-size: 13px;
  background: rgba(255, 255, 255, 0.1);
  color: #888;
  border-radius: 50%;
  cursor: pointer;
  position: absolute;
  top: 50%;
  right: 16px;
  text-align: center;
  transform: translateY(-50%);
}

.page-action-simple-step3 #persuasive-messages {
  bottom: 74px;
}

/* ===================================
   LOADING MESSAGE
=================================== */
.ajaxloading {
  display: none;
  background: #ffffff;
  text-align: center;
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 9999;
}
.ajaxloading > img {
  display: block;
  max-width: 300px;
  max-height: 90px;
  margin: 60px auto 0 auto;
}
.ajaxloading > div {
  margin: auto;
  position: absolute;
  top: 50%;
  right: 0;
  left: 0;
  transform: translateY(-50%);
}
.ajaxloading .ajaxloading-loader {
  height: 20px;
  overflow: hidden;
}
.ajaxloading .ajaxloading-loader svg {
  display: inline-block;
  width: 160px;
  height: 160px;
  transform: translate(36px, -70px);
}
.ajaxloading .ajaxloading-loader svg circle {
  fill: var(--blueValue);
}
.ajaxloading .ajaxloading-text {
  font-size: 24px;
  font-weight: 700;
  margin-top: 36px;
  padding: 0 20px;
}
.ajaxloading .ajaxloading-list {
  max-width: 1024px;
  list-style: none;
  margin: 0 auto;
  padding: 0;
}
.ajaxloading .ajaxloading-list li {
  display: inline-block;
  color: var(--textValue);
  opacity: 0;
  margin: 36px 36px 0 36px;
  transform: translateY(12px);
  transition: all 1s;
}
.ajaxloading .ajaxloading-list li.faded {
  opacity: 1;
  transform: translateY(0);
}
.ajaxloading .ajaxloading-list li > i {
  font-size: 18px;
  color: #009c12;
  margin-right: 9px;
  transform: translateY(2px);
}

/* ===================================
   THUMBSTYLES
=================================== */
.thumbstyle0 {
  background-repeat: repeat;
}

.thumbstyle1 {
  background-repeat: no-repeat;
  background-position: center top;
}

.thumbstyle2 {
  background-repeat: no-repeat;
  background-position: left center;
}

.thumbstyle3 {
  background-repeat: no-repeat;
  background-position: center center;
}

.thumbstyle4 {
  background-repeat: no-repeat;
  background-position: right center;
}

.thumbstyle5 {
  background-repeat: no-repeat;
  background-position: center bottom;
}

/* ===================================
   STARS
=================================== */
.stars {
  display: inline-block;
  color: #ffce00;
  letter-spacing: 4px;
  vertical-align: middle;
}

.star-1:before {
  content: "\f005";
}

.star-2:before {
  content: "\f005\f005";
}

.star-3:before {
  content: "\f005\f005S";
}

.star-4:before {
  content: "\f005\f005\f005";
}

.star-5:before {
  content: "\f005\f005\f005S";
}

.star-6:before {
  content: "\f005\f005\f005\f005";
}

.star-7:before {
  content: "\f005\f005\f005\f005";
}

.star-7:after {
  content: "S";
  font-family: "Circular";
}

.star-8:before {
  content: "\f005\f005\f005\f005\f005";
}

.star-9:before {
  content: "\f005\f005\f005\f005\f005";
}

.star-9:after {
  content: "L";
  font-family: "Circular";
}

/* ===================================
   INSURANCE
=================================== */
.alert,
.error-popup {
  background: rgba(0, 0, 0, 0.7);
  position: fixed;
  z-index: 999;
}
.alert > div,
.error-popup > div {
  max-width: 400px;
  background: #ffffff;
  color: var(--textValue);
  margin: auto;
  padding: 24px 16px;
  text-align: center;
  position: absolute;
  top: 50%;
  right: 20px;
  left: 20px;
  transform: translateY(-50%);
}
.alert .alert-close,
.error-popup .alert-close {
  display: inline-block;
  font-weight: 900;
  color: var(--blueValue);
  cursor: pointer;
  margin-top: 16px;
  vertical-align: top;
}

.g-recaptcha {
  margin-top: 12px !important;
}

.choose-insurance {
  display: table;
  width: 100%;
  border: 1px solid white;
  margin-top: 16px;
  cursor: pointer;
}
.choose-insurance:hover .checkButton label:after {
  opacity: 1;
}
.choose-insurance > div {
  display: table-cell;
  height: 48px;
  line-height: 18px;
  vertical-align: middle;
  position: relative;
}
.choose-insurance > div:last-child {
  padding: 3px 16px 3px 50px;
}
.choose-insurance.button2 {
  border-color: #03ff20;
}
.choose-insurance.button2 .checkButton label {
  background: #f0f4f8;
  border-color: #03ff20;
}
.choose-insurance.button2 .checkButton label:after {
  color: #009c12;
}
.choose-insurance .checkButton {
  width: 48px;
  position: relative;
}
.choose-insurance .checkButton label {
  width: 100%;
  height: 100%;
  background: #f0f4f8;
  border-right: 1px solid #d0def0;
  position: absolute;
  top: 0;
  left: 0;
}
.choose-insurance .checkButton label:after {
  content: "\f00c";
  font-family: "Font Awesome 5 Pro";
  font-size: 18px;
  font-weight: 400;
  color: #009c12;
  position: absolute;
  top: 50%;
  left: 15px;
  opacity: 0;
  transform: translateY(-50%);
}
.choose-insurance .checkButton input {
  display: none;
}
.choose-insurance .checkButton input:checked + label {
  background: #009c12;
}
.choose-insurance .checkButton input:checked + label:after {
  opacity: 1;
  color: #ffffff;
}
.choose-insurance .insurance-icon {
  font-size: 18px;
  color: #009c12;
  position: absolute;
  top: 50%;
  left: 16px;
  transform: translateY(-50%);
}

.insurance-info {
  display: none;
  padding: 24px 16px;
  border: 1px solid #03ff20;
  overflow: hidden;
}
.insurance-info .content-title {
  margin-bottom: 10px;
}
.insurance-info.open {
  display: block;
  border-top: 0;
}

.insurance-extra {
  font-size: 16px;
  background: #f0f4f8;
  color: #009c12;
  border: 1px solid rgba(0, 156, 18, 0.2);
  margin-top: 16px;
  padding: 16px;
}

.card-insurance-detail {
  cursor: pointer;
}

/* ===================================
HOLIPAY, SCALAPAY
=================================== */
.gateway-logo-svg {
  width: 120px;
  height: auto;
  margin-top: 6px;
}

.gateway-widget-wrapper {
  margin-bottom: 0.5em;
  font-weight: bold;
}

.gateway-widget-paymode-extra {
  width: 100%;
  font-weight: normal;
}

.gateway-widget-wrapper-rate {
  font-size: xx-small;
}

/* ===================================
SCALAPAY
=================================== */
.scalapay-logo-png {
  width: 120px;
  height: auto;
}

/* ===================================
RTL definitions
=================================== */
.sp--nowrap {
  white-space: normal !important;
}

/* ===================================
FIX ADD THIS --- da rivedere
=================================== */
#addthis span.at-label {
  display: none !important;
}

#addthis .at-icon-wrapper {
  transform: scale(0.75);
  margin: 0;
}

/* ===================================
VALIDAZIONE ERRORI ETÀ UTENTI
=================================== */
.hasError {
  color: #d23131 !important;
}

.validationErrorMessage {
  color: #d23131 !important;
  text-align: start;
  font-style: italic;
}

/*
DESKTOP
default.scss
Copyright (C) 2019 Nexteam S.r.l., All rights reserved.
*/
/* ===================================
   WALLPAPER
=================================== */
.wallpaper {
  position: fixed;
  z-index: -1;
}

/* ===================================
   HEADER
=================================== */
#header {
  font-size: 12px;
}
#header .header-fixed {
  height: 100px;
  box-shadow: rgba(131, 151, 178, 0.24) 0 6px 24px;
  position: relative;
  z-index: 99;
}
#header .wrapper {
  display: flex;
}
#header .wrapper > div:last-child {
  margin-left: auto;
}
#header .header-top {
  height: 36px;
  line-height: 36px;
  background: rgba(0, 0, 0, 0.7);
  color: #ffffff;
}
#header .header-top .header-name .stars {
  margin-left: 8px;
  transform: translateY(-1px);
}
#header .header-top .header-country {
  cursor: pointer;
  text-transform: uppercase;
}
#header .header-top .header-country i {
  font-size: 13px;
  margin-left: 6px;
}
#header .header-top a {
  color: #ffffff;
  margin-left: 30px;
  text-decoration: none;
  display: inline-block;
}
#header .header-top a:hover {
  text-decoration: underline;
}
#header .header-middle {
  height: 64px;
  background: #ffffff;
}
#header .header-middle .header-logo a {
  display: block;
  height: 64px;
  padding: 8px 0;
}
#header .header-middle .header-logo a img {
  display: block;
  height: 100%;
}
#header .header-middle .change-info {
  padding: 12px 0;
}
#header .header-middle .change-info span {
  display: block;
  color: var(--blueValue);
  cursor: pointer;
}
#header .header-middle .change-info span > i {
  margin-left: 8px;
}
#header .header-middle .change-step {
  display: flex;
  padding: 17px 0;
}
#header .header-middle .change-step .step {
  height: 30px;
  position: relative;
  display: flex;
  align-items: center;
}
#header .header-middle .change-step .step:nth-child(n+2) {
  margin-left: 50px;
}
#header .header-middle .change-step .step:nth-child(n+2):before {
  content: "";
  width: 30px;
  height: 1px;
  background-color: #bcccdc;
  position: absolute;
  left: -40px;
  top: 14px;
}
#header .header-middle .change-step .step > div {
  background-color: #d9e2ec;
  color: #829ab1;
  border-radius: 30px;
  width: 30px;
  height: 30px;
  line-height: 30px;
  text-align: center;
}
#header .header-middle .change-step .step > div span {
  font-weight: 900;
}
#header .header-middle .change-step .step > span {
  margin-left: 8px;
  font-weight: 900;
  color: #829ab1;
  line-height: 12px;
}
#header .header-middle .change-step .step.done > div {
  background-color: #e6ffe8;
  border: 1px solid rgba(0, 156, 18, 0.2);
  color: #009c12;
}
#header .header-middle .change-step .step.done > span {
  color: #009c12;
}
#header .header-middle .change-step .step.done:before {
  background-color: rgba(0, 156, 18, 0.2);
}
#header .header-middle .change-step .step.doing > div {
  background-color: var(--blueValue);
  color: #ffffff;
}
#header .header-middle .change-step .step.doing > span {
  color: var(--blueValue);
}
#header .header-bottom {
  color: #ffffff;
  padding: 24px 0;
  text-shadow: rgba(0, 0, 0, 0.4) 0 0 4px;
  position: relative;
}
#header .header-bottom:before {
  content: "";
  height: 70px;
  background: linear-gradient(rgba(0, 0, 0, 0.7), rgba(0, 0, 0, 0));
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
}
#header .header-bottom.dark-mode {
  color: var(--textValue);
  text-shadow: none;
}
#header .header-bottom.dark-mode:before {
  display: none;
}
#header .header-bottom.dark-mode a {
  color: var(--textValue);
}
#header .header-bottom .wrapper {
  display: flex;
  position: relative;
  z-index: 2;
}
#header .header-bottom .wrapper > div:first-child {
  width: 421px;
}
#header .header-bottom .wrapper > div:last-child {
  text-align: right;
}
#header .header-bottom a {
  color: #ffffff;
  margin-right: 30px;
  text-decoration: none;
  display: inline-block;
}
#header .header-bottom a:hover {
  text-decoration: underline;
}
#header .header-bottom i {
  margin-right: 8px;
}
#header .header-bottom .load-map {
  text-transform: initial;
}

/* ===================================
   AGENCY
=================================== */
.agency-ghost {
  height: 48px;
}

.agency-box {
  width: 100%;
  background: #000;
  color: #ffffff;
  position: fixed;
  top: 0;
  right: 0;
  left: 0;
  z-index: 100;
}
.agency-box .wrapper {
  display: flex;
  align-items: center;
  height: 48px;
  line-height: 18px;
}
.agency-box .wrapper > div {
  display: flex;
  align-items: center;
  font-size: 12px;
}
.agency-box .wrapper > div:first-child > div {
  margin-left: 12px;
}
.agency-box .wrapper > div:first-child > div > b {
  display: block;
  font-size: 14px;
}
.agency-box .wrapper > div:last-child {
  margin-left: auto;
}
.agency-box i {
  font-size: 24px;
}
.agency-box .agency-logout {
  cursor: pointer;
  margin-left: 30px;
}
.agency-box .agency-logout i {
  font-size: 12px;
  margin-left: 6px;
}
.agency-box .agency-commission {
  cursor: pointer;
}

/* ===================================
   MAIN CONTAINER
=================================== */
body {
  min-width: 1200px;
  overflow-x: auto;
}

#main > .wrapper {
  display: table;
  width: 100%;
  table-layout: fixed;
}
#main > .wrapper > div {
  display: table-cell;
  vertical-align: top;
  padding-bottom: 60px;
}
#main > .wrapper > div.sticky-wrap {
  width: 389px;
  padding-right: 40px;
}

/* ===================================
   FAST MESSAGE
=================================== */
#fast-message {
  display: flex;
  flex-direction: column;
  background-color: #fffae6;
  border: 1px solid rgba(156, 126, 0, 0.2);
  color: var(--textValue);
  margin-bottom: 24px;
  padding: 16px;
  position: relative;
}
#fast-message h2 {
  color: #9c7e00;
  position: relative;
  cursor: pointer;
}
#fast-message h2:after {
  content: "\f107";
  font-family: "Font Awesome 5 Pro";
  font-weight: 300;
  position: absolute;
  right: 0;
}
#fast-message .content-body {
  display: none;
}
#fast-message .content-body .read-more-popup {
  text-decoration: underline;
  color: #9c7e00;
  cursor: pointer;
}
#fast-message.active h2 {
  margin-bottom: 8px;
}
#fast-message.active h2:after {
  content: "\f106";
}
#fast-message.active .content-body {
  display: block;
}

/* ===================================
   RESPONSIVE
=================================== */
@media (max-width: 2559px) {
  .popup-map #popup-map-list .swiper-slide {
    width: calc(33.333% - 36px);
  }
}
@media (max-width: 1919px) {
  .popup-map #popup-map-list .swiper-slide {
    width: calc(50% - 36px);
  }
}
@media (max-width: 1439px) {
  #main .wrapper > div.sticky-wrap {
    width: 369px;
    padding-right: 20px;
  }
  #main .wrapper > div.sticky-wrap:last-child {
    display: none;
  }
  .wrapper {
    padding: 0 20px;
  }
}
@media (max-width: 1199px) {
  .popup-map #popup-map-list {
    display: none !important;
  }
}
@media (max-width: 1023px) {
  .popup-map #map {
    right: 0;
  }
  .popup-map .popup-map-info {
    display: none !important;
  }
}
/* ===================================
   ON REQUEST
=================================== */
.onrequest-button {
  background: orange;
  color: #fff;
}
.onrequest-button:after {
  border-color: transparent transparent transparent orange;
}

.onrequest-icon {
  border-radius: 30px;
  display: inline-block;
  font-size: 20px;
  /*vertical-align: sub;*/
  cursor: pointer;
  position: relative;
  left: -25px;
  top: 31px;
  background-color: white;
  z-index: 3;
}

.onrequest-popup {
  display: none;
  position: fixed;
  left: 0;
  right: 0;
  z-index: 2;
  max-width: 300px;
  padding: 20px 20px 20px 20px;
  background: rgba(0, 0, 0, 0.7);
  color: #fff;
  text-align: right;
}
.onrequest-popup:after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-top: 14px solid transparent;
  border-bottom: 14px solid transparent;
  border-left: 14px solid rgba(0, 0, 0, 0.7);
  position: absolute;
  top: 50%;
  right: -14px;
  margin-top: -7px;
}
.onrequest-popup .icon {
  position: absolute;
  top: 15px;
  right: 15px;
  cursor: pointer;
  font-size: 20px;
}

/*@import "./_rtl/desktop.RTL.scss";*/
.pipeline {
  display: block;
}

body.test-enviroment::after {
  position: absolute;
  background-color: red;
  color: white;
  content: "TEST";
  font-size: 40px;
  z-index: 99999999;
  top: -40px;
  right: -80px;
  padding: 90px 60px 18px;
  transform: rotate(45deg);
}
