                    @font-face {
            font-family: 'AlegreSans-Regular';
            font-style: normal;
            font-weight: 400;
                                                            src: url("https://d1t1qzzb2zwrre.cloudfront.net/master/system/fonts/64a81b428f964130142845.woff") format("woff");
                    }
                            @font-face {
            font-family: 'Viceroy-Light';
            font-style: normal;
            font-weight: 400;
                                                            src: url("https://d1t1qzzb2zwrre.cloudfront.net/master/system/fonts/64a81b54b5190650885245.woff") format("woff");
                    }
                            @font-face {
            font-family: 'Viceroy-Regular';
            font-style: normal;
            font-weight: 400;
                                                            src: url("https://d1t1qzzb2zwrre.cloudfront.net/master/system/fonts/64a81b692d502445993311.woff") format("woff");
                    }
                            @font-face {
            font-family: 'Romie-Regular';
            font-style: normal;
            font-weight: 400;
                                                            src: url("https://d1t1qzzb2zwrre.cloudfront.net/master/system/fonts/6726ae15889bd942051285.woff") format("woff");
                    }
            
            @font-face {
        font-family: 'AZDS-main';
        font-style: normal;
        font-weight: 400;
                                            src: url("https://d1t1qzzb2zwrre.cloudfront.net/master/system/fonts/673655dc3078b259576160.woff2") format("woff2");
                }
            @font-face {
        font-family: 'AZDS-second';
        font-style: normal;
        font-weight: 400;
                                            src: url("https://d1t1qzzb2zwrre.cloudfront.net/master/system/fonts/673655dc3078b259576160.woff2") format("woff2");
                }
            @font-face {
        font-family: 'AZDS-third';
        font-style: normal;
        font-weight: 400;
                                            src: url("https://d1t1qzzb2zwrre.cloudfront.net/master/system/fonts/673655dc3078b259576160.woff2") format("woff2");
                }
            @font-face {
        font-family: 'AZDS-fourth';
        font-style: normal;
        font-weight: 400;
                                            src: url("https://d1t1qzzb2zwrre.cloudfront.net/master/system/fonts/673655dc3078b259576160.woff2") format("woff2");
                }
            @font-face {
        font-family: 'AZDS-fifth';
        font-style: normal;
        font-weight: 400;
                                            src: url("https://d1t1qzzb2zwrre.cloudfront.net/master/system/fonts/673655dc3078b259576160.woff2") format("woff2");
                }
            @font-face {
        font-family: 'AZDS-sixth';
        font-style: normal;
        font-weight: 400;
                                            src: url("https://d1t1qzzb2zwrre.cloudfront.net/master/system/fonts/673655dc3078b259576160.woff2") format("woff2");
                }
            @font-face {
        font-family: 'AZDS-room-third';
        font-style: normal;
        font-weight: 400;
                                            src: url("https://d1t1qzzb2zwrre.cloudfront.net/master/system/fonts/673655dc3078b259576160.woff2") format("woff2");
                }
            @font-face {
        font-family: 'AZDS-room-rate-fourth';
        font-style: normal;
        font-weight: 400;
                                            src: url("https://d1t1qzzb2zwrre.cloudfront.net/master/system/fonts/673655dc3078b259576160.woff2") format("woff2");
                }
            @font-face {
        font-family: 'AZDS-language-dropdown-second';
        font-style: normal;
        font-weight: 400;
                                            src: url("https://d1t1qzzb2zwrre.cloudfront.net/master/system/fonts/6738df9a48935376269124.woff2") format("woff2");
                }
            @font-face {
        font-family: 'AZDS-modify-layout-third';
        font-style: normal;
        font-weight: 400;
                                            src: url("https://d1t1qzzb2zwrre.cloudfront.net/master/system/fonts/6738df9a48935376269124.woff2") format("woff2");
                }
            @font-face {
        font-family: 'AZDS-modify-search-second';
        font-style: normal;
        font-weight: 400;
                                            src: url("https://d1t1qzzb2zwrre.cloudfront.net/master/system/fonts/6738df9a48935376269124.woff2") format("woff2");
                }
            @font-face {
        font-family: 'AZDS-room-main';
        font-style: normal;
        font-weight: 400;
                                            src: url("https://d1t1qzzb2zwrre.cloudfront.net/master/system/fonts/6738df9a48935376269124.woff2") format("woff2");
                }
            @font-face {
        font-family: 'AZDS-room-third';
        font-style: normal;
        font-weight: 400;
                                            src: url("https://d1t1qzzb2zwrre.cloudfront.net/master/system/fonts/6738df9a48935376269124.woff2") format("woff2");
                }
            @font-face {
        font-family: 'AZDS-order-form-main';
        font-style: normal;
        font-weight: 400;
                                            src: url("https://d1t1qzzb2zwrre.cloudfront.net/master/system/fonts/6738df9a48935376269124.woff2") format("woff2");
                }
    
    :root {
    --azds-theme-main-color: #bf8753 !important;
    }
    .b-main-bcolor {
    background-color: #bf8753 !important;
    }
    .b-main-bcolor-hover:hover {
    background-color: #bf8753 !important;
    }
    .b-main-fcolor {
    color: #bf8753 !important;
    }
    .b-main-fcolor-hover:hover {
    color: #bf8753 !important;
    }
    .b-main-border-color{
    border-color: #bf8753 !important;
    }
    .b-main-border-color-hover:hover {
    border-color: #bf8753 !important;
    }
    .b-main-border-color::after{
    border-color: #bf8753 !important;
    }

    :root {
    --azds-theme-second-color: #ffffff !important
    }
    .b-second-bcolor {
    background-color: #ffffff !important;
    }
    .b-second-bcolor-hover:hover {
    background-color: #ffffff !important;
    }
    .b-second-fcolor {
    color: #ffffff !important;
    }
    .b-second-fcolor-hover:hover {
    color: #ffffff !important;
    }
    .swiper-pagination .swiper-pagination-handle .swiper-pagination-bullet-active {
    background-color: #ffffff !important;
    }
    .b-second-border-color{
    border-color: #ffffff !important;
    }
    .b-second-border-color-hover:hover {
    border-color: #ffffff !important;
    }
    .b-second-border-color::after{
    border-color: #ffffff !important;
    }

    :root {
    --azds-theme-third-color: #000000 !important
    }
    .b-third-bcolor {
    background-color: #000000 !important;
    }
    .b-third-bcolor-hover:hover {
    background-color: #000000 !important;
    }
    .b-third-fcolor {
    color: #000000 !important;
    }
    .b-third-border-color{
    border-color: #000000 !important;
    }
    .b-third-border-color-hover:hover {
    border-color: #000000 !important;
    }
    .b-third-border-color::after{
    border-color: #000000 !important;
    }

    .b-main-background {
        background-image: url(https://d1t1qzzb2zwrre.cloudfront.net/master/upload/67/672be4d46053c889831742.jpg) !important;
        background-position: center;
        background-size: cover;
    }

.azds-booking-section .calendar-month .cal-month-view .cal-days .cal-cell.azds-calendar-day-noArrival,
.azds-booking-section .calendar-month .cal-month-view .cal-days .cal-cell.azds-calendar-day-selected,
.azds-booking-section .calendar-month .cal-month-view .cal-days .cal-cell.azds-calendar-day-green,
.azds-booking-section .calendar-month .cal-month-view .cal-days .cal-cell.azds-calendar-day-notAvailable {
  color: #fff !important;
}

.nightly-price-wrap .day {
  top: 6px !important;
  font-size: 14px !important;
}

.azds-booking-section .booking-section-header .logo img {
  max-height: 40px !important;
  min-height: 40px !important;
}

.azds-booking-section .nightly-price-wrap .price {
  margin-top: 12px !important;
  font-size: 12px !important;
}

.azds-contact-block {
  background-color: #000 !important;
}

.azds-booking-section .booking-section-header .btn-close {
  width: 25px !important;
}

@media screen and (min-width: 1440px) {
  boutique-multi-room .azds-multi-room {
    display: flex !important;
    flex-direction: column !important;
  }
}

.azds-booking-section .reserve-form .reserve-btn:hover {
  background-color: #BF8753 !important;
  color: #fff !important;
  border: 1px solid #BF8753 !important;
}

.login-bar a:nth-child(2n) {
  display: none !important;
}

boutique-room-rate .left .title {
  text-transform: uppercase !important;
  font-variant: none !important;
  font-size: 29px !important;
}

boutique-room-rate .le a {
  font-variant: none !important;
  text-transform: uppercase !important;
}

.login-bar .person-icon {
  background: url(https://newbooking.azds.com/assets-web/themes/boutique/arrow-1.svg) no-repeat;
}

/* Start of BEA-595 */
.azds-booking-section .reserve-form .reserve-row.azds-form-login-group {
  display: none !important;
}

.azds-booking-section .reserve-form .reserve-row.azds-form-terms-group+.reserve-row {
  display: none !important;
}

/* End of BEA-595 */

/* Integration start*/
html.booking-overlay-open,
html.booking-overlay-open body {
  font-size: 16px !important;
  line-height: normal !important;
}

.azds-booking-section .reserve-form .reserve-box .sel,
.azds-booking-section .reserve-form .reserve-box .sel select,
.azds-booking-section .reserve-form .reserve-box .sel ng-select,
.azds-booking-section .reserve-form .reserve-box .inp,
.azds-booking-section .reserve-form .reserve-box .inp input,
.azds-booking-section .reserve-form .reserve-box .t-area,
.azds-booking-section .reserve-form .reserve-box .t-area textarea,
.azds-booking-section .reserve-form .reserve-box .sel ng-select .ng-select-container,
.azds-booking-section .reserve-form .sel .ng-select,
.azds-booking-section .reserve-form .ng-select .ng-select-container .ng-value-container {
  height: 100%;
}

@media screen and (max-width: 470px) {

  booking-layout .azds-booking-section boutique-language-dropdown .ng-select-container,
  booking-layout .azds-booking-section boutique-currency-dropdown .ng-select-container,
  booking-layout .azds-booking-section boutique-language-dropdown .ng-select-container .ng-value,
  booking-layout .azds-booking-section boutique-currency-dropdown .ng-select-container .ng-value {
    font-size: 12px !important;
  }

  .azds-top-menu> :not(:first-child) {
    margin-left: 10px !important;
  }

  .azds-top-menu {
    right: 30px !important;
  }
}

.azds-booking-section .reserve-form .reserve-btn {
  background-color: #000 !important;
  border: 1px solid #000 !important;
  color: #fff !important;
  border-radius: 0 !important;
  padding: 4px 10px 2px !important;
  line-height: 32px;
}

.azds-promo-popover[class*="booking-lang-es"] .azds-code-row button,
.azds-promo-popover[class*="booking-lang-es"] .azds-code-row button {
  width: 110px !important;
}

.azds-promo-popover[class*="booking-lang-es"] .azds-code-row input {
  width: calc(100% - 120px) !important;
}

@media screen and (min-width: 690px) and (max-width: 1023px) {
  .azds-promo-popover[class*="booking-lang-es"] .azds-code-row button {
    width: 90px !important;
  }

  .azds-promo-popover[class*="booking-lang-es"] .azds-code-row input {
    width: calc(100% - 100px) !important;
  }
}

@media screen and (min-width: 601px) and (max-width: 689px) {
  .azds-promo-popover[class*="booking-lang-es"] .azds-code-row button {
    width: 90px !important;
  }

  .azds-promo-popover[class*="booking-lang-es"] .azds-code-row input {
    width: 100% !important;
    margin-right: 0 !important;
  }
}

html.booking-overlay-open:not(.no-js):not(.keyboard-navigation) .select-wrapper::after {
  display: none !important;
}

[class*="booking-lang-es"] .long-description>div {
  white-space: pre-line !important;
}

@-moz-document url-prefix() {
  .long-description>div>li {
    margin-left: 17px;
  }

  .room-info .room-description span li {
    margin-left: 17px;
  }

  .info>li {
    margin-left: 17px;
  }
}

.room-info p.room-description>li {
  margin-left: 17px !important;
  list-style: disc !important;
}

.enhance-stay-block__heading h2 {
  margin-top: 20px !important;
}

[class*="booking-lang-es"] .room-info .room-description {
  white-space: pre-line;
}

[class*="booking-lang-es"] .room-info .room-description span {
  white-space: pre-line;
}

@media screen and (min-width: 1024px) and (max-width: 1235px) {
  .room-main-info[class*="booking-lang-es"] .room-info .room-content {
    display: block !important;
  }

  .room-main-info[class*="booking-lang-es"] .room-info .room-price {
    float: right !important;
  }
}

.enhance-stay-block[class*="booking-lang-es"] .add-button,
.enhance-stay-block[class*="booking-lang-es"] .remove-button {
  min-width: 148px !important;
}

@media screen and (max-width: 640px) {

  .enhance-stay-block[class*="booking-lang-es"] .add-button,
  .enhance-stay-block[class*="booking-lang-es"] .remove-button {
    max-width: 148px !important;
    height: auto !important;
    line-height: 1.5 !important;
    padding: 5px !important;
  }

  [class*="booking-lang-es"] boutique-mobile-dynamic-package-list .mobile-dynamic-packages .panel.mobile-dynamic-packages-category .panel-default>.panel-heading {
    padding-left: 5px !important;
    padding-right: 5px !important;
  }
}

@media screen and (min-width: 641px) {

  .enhance-stay-block[class*="booking-lang-es"] boutique-dynamic-package-form .add-button,
  .enhance-stay-block[class*="booking-lang-es"] boutique-dynamic-package-form .remove-button {
    height: auto !important;
    font-size: 14px;
    line-height: 30px;
  }
}

@media screen and (min-width: 1280px) {

  .booking-confirmation-wrap .booking-confirmation-info [class*="booking-lang-es"] .btn-cancel-reservation-search,
  .booking-confirmation-wrap .booking-confirmation-info .azds-buttons[class*="booking-lang-es"] .btn-cancel-reservation-search {
    font-size: 20px !important;
    white-space: nowrap;
  }
}

@media screen and (max-width: 600px) {

  .azds-promo-popover[class*="booking-lang-es"] .azds-code-row input,
  .azds-promo-popover[class*="booking-lang-es"] .azds-code-row button {
    width: 100% !important;
  }
}

@media screen and (min-width: 1280px) {
  .azds-booking-section boutique-modify-reservation boutique-modify-search .reserve-form .inp input {
    min-width: 245px !important;
  }

  .azds-booking-section boutique-modify-layout .booking-confirmation-wrap .booking-confirmation-info .booking-confirmation-info-title boutique-modify-search .reserve-form:not(.modify-form) {
    min-width: 530px !important;
  }
}

@media screen and (max-width: 1060px) and (min-width: 769px) {
  .azds-booking-section boutique-modify-reservation boutique-modify-search .reserve-form .inp input {
    font-size: 12px !important;
    letter-spacing: normal !important;
  }

  .azds-booking-section boutique-modify-layout .booking-confirmation-wrap .booking-confirmation-info .booking-confirmation-info-title boutique-modify-search .reserve-form:not(.modify-form) {
    min-width: 400px !important;
  }
}

.amenities-button-container span {
  font-size: 14px !important;
}

@media screen and (min-width: 1024px) {
  boutique-room .room-info .room-price .room-reserve-btn {
    white-space: nowrap !important;
  }
}

/* Integration end */

@media screen and (max-width: 900px) and (min-width: 601px) {
  .azds-top-menu> :not(:first-child) {
    margin-left: 10px !important;
  }

  .azds-top-menu .ng-select .ng-select-container .ng-value-label {
    letter-spacing: normal !important;
    font-size: 14px !important;
  }

  .azds-top-menu .ng-select .ng-value-container {
    padding-left: 3px !important;
  }

  .azds-booking-section .azds-top-menu .ng-select .ng-arrow-wrapper {
    width: 20px !important;
    padding-right: 0px !important;
  }

  .azds-booking-section .booking-section-header .btn-close {
    right: 2% !important;
  }

  .azds-top-menu {
    right: 30px !important;
  }
}

@media screen and (max-width: 400px) {
  .azds-booking-section .booking-section-header .logo img {
    min-height: 33px;
    max-height: 33px;
  }
}

modal-container .modal-dialog.image .modal-header {
  position: static !important;
}

@media screen and (min-width: 1280px) {
  .booking-overlay-open .booking-confirmation-wrap .booking-confirmation-info .btn-cancel-reservation-search {
    white-space: nowrap !important;
  }

  .booking-overlay-open [class*="booking-lang-es"] .booking-confirmation-wrap .booking-confirmation-info .btn-cancel-reservation-search {
    font-size: 22px !important;
  }
}

@media screen and (max-width: 428px) {
  .booking-lang-en .info-section .section-cols .entity {
    min-width: 100px !important;
  }

  .booking-lang-en .info-section .section-cols .value {
    max-width: calc(100% - 100px) !important;
  }

  [class*="booking-lang-es"] .info-section .section-cols .entity {
    min-width: 120px !important;
  }

  [class*="booking-lang-es"] .info-section .section-cols .value {
    max-width: calc(100% - 120px) !important;
  }

  .booking-lang-de .info-section .section-cols .entity {
    min-width: 105px !important;
  }

  .booking-lang-de .info-section .section-cols .value {
    max-width: calc(100% - 105px) !important;
  }
}

@media screen and (min-width: 1024px) {

  .azds-promo-popover.booking-lang-de button,
  .azds-promo-popover[class*="booking-lang-es"] button {
    width: 110px !important;
  }

  .azds-promo-popover.booking-lang-de .azds-code-row input,
  .azds-promo-popover[class*="booking-lang-es"] .azds-code-row input {
    width: calc(100% - 120px) !important;
  }
}

@media screen and (min-width: 601px) and (max-width: 676px) {
  .azds-promo-popover.booking-lang-en button {
    width: 112px !important;
  }

  .azds-promo-popover.booking-lang-en .azds-code-row input {
    width: 100% !important;
    margin-right: 0 !important;
  }
}

@media screen and (min-width: 769px) and (max-width: 930px) {

  .azds-promo-popover input:disabled,
  .azds-promo-popover[class*="booking-lang-es"] .azds-code-row input:disabled {
    width: 100% !important;
    margin-right: 0 !important;
  }
}

@media screen and (min-width: 1024px) and (max-width: 1280px) {
  .amenities-button-container span {
    font-size: 13px !important;
  }
}

@media screen and (min-width: 769px) {
  .azds-multi-room-item__content-promo .azds-button {
    padding-top: 2px !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  .azds-multi-room-item__content-promo .azds-button .azds-multi-room-item__content-promo-ellipsis {
    padding-left: 25px !important;
    padding-right: 25px !important;
  }
}

@media screen and (max-width: 768px) {
  .azds-multi-room-item__content-promo .azds-button {
    padding-top: 1px !important;
  }
}

@media screen and (max-width: 428px) {

  boutique-mobile-dynamic-package-list .mobile-dynamic-packages .panel.mobile-dynamic-packages-category .mobile-dynamic-packages-categories-pack .panel-title .accordion-toggle .btn-link,
  boutique-dynamic-package-form .enhance-stay-block__item_content-block .enhance-stay-block__item_description {
    font-size: 18px !important;
  }
}

[class*="booking-lang-es"] .info-section .section-cols .entity {
  min-width: 120px !important;
}

[class*="booking-lang-es"] .info-section .section-cols .value {
  max-width: calc(100% - 120px) !important;
}

@media screen and (min-width: 769px) {
  .booking-lang-en .info-section .section-cols .entity {
    min-width: 100px !important;
  }

  .booking-lang-en .info-section .section-cols .value {
    max-width: calc(100% - 100px) !important;
  }

  [class*="booking-lang-es"] .info-section .section-cols .entity {
    min-width: 120px !important;
  }

  [class*="booking-lang-es"] .info-section .section-cols .value {
    max-width: calc(100% - 120px) !important;
  }

  .booking-lang-de .info-section .section-cols .entity {
    min-width: 105px !important;
  }

  .booking-lang-de .info-section .section-cols .value {
    max-width: calc(100% - 105px) !important;
  }
}

#sb-express #sb-express-powered-by {
  display: none !important;
}

/* Integration start */
@media screen and (min-width: 601px) {
  boutique-multi-room .azds-promo-popover {
    transform: translateY(2px) !important;
  }

  .azds-multi-room-item__content-promo button .azds-multi-room-item__content-promo-ellipsis {
    display: inline-flex !important;
    height: 100% !important;
    align-items: center;
    justify-content: center;
  }
}

html.booking-overlay-open,
html.booking-overlay-open body {
  font-size: 16px !important;
  line-height: normal !important;
}

@media screen and (max-width: 510px) {
  .azds-multi-room {
    padding-left: 5px !important;
    padding-right: 5px !important;
  }

  .azds-multi-room-item__content-promo .azds-button {
    padding-left: 5px !important;
    padding-right: 5px !important;
  }
}

@media screen and (max-width: 414px) {
  .azds-multi-room-item__content-promo {
    grid-template-columns: 1fr !important;
  }
}

@media screen and (min-width: 769px) and (max-width: 1279px) {
  app-boutique-cancellation .booking-confirmation-wrap .booking-confirmation-info .booking-confirmation-info-title .reserve-form {
    min-width: 75%;
  }
}

.azds-booking-section .booking-section-wrap .dates-step .ng-select .ng-select-container .ng-value-container .ng-value .ng-value-label,
.azds-booking-section .booking-section-wrap .dates-step .ng-select .ng-select-container .ng-value-container .ng-value .ng-value-label *,
.azds-booking-section .booking-section-wrap .dates-step .ng-dropdown-panel .ng-dropdown-panel-items .ng-option,
.azds-booking-section .booking-section-wrap .dates-step .ng-dropdown-panel .ng-dropdown-panel-items .ng-option span,
.dates-step .reserve-box .promo-wrap .promo-block input[type="text"] {
  font-size: 12px !important;
}

.dates-step .reserve-box .promo-wrap .promo-block input[type="text"] {
  font-size: 12px !important;
}

.dates-step .reserve-box .promo-wrap .promo-block input[type="text"]::placeholder {
  font-size: 12px !important;
}

.dates-step .reserve-box .promo-wrap .promo-block input[type="text"]::-webkit-input-placeholder {
  font-size: 12px !important;
}

.dates-step .reserve-box .promo-wrap .promo-block input[type="text"]::-moz-placeholder {
  font-size: 12px !important;
}

.room-text-feature-section>h5+span {
  display: inline-block !important;
}

@media (max-width: 414px) and (min-width: 0px) {

  app-boutique-cancellation .booking-confirmation-wrap .booking-confirmation-info .btn-cancel-reservation-search,
  boutique-modify-reservation .booking-confirmation-wrap .booking-confirmation-info .btn-cancel-reservation-search,
  .booking-confirmation-wrap .booking-confirmation-info .btn-cancel-reservation-search {
    font-size: 20px !important;
  }
}

.azds-multi-room-item__content-promo button .azds-multi-room-item__content-promo-ellipsis {
  width: 100% !important;
  padding-top: 1px !important;
}

@media screen and (max-width: 1100px) and (min-width: 601px) {
  .azds-promo-popover {
    min-width: 0 !important;
    width: auto !important;
  }

  .azds-promo-popover button {
    width: auto !important;
  }

  .azds-promo-popover .azds-code-row input {
    width: 100% !important;
    margin-right: 0 !important;
    margin-bottom: 10px !important;
  }
}

@media screen and (max-width: 1460px) and (min-width: 769px) {
  .booking-overlay-open .azds-promo-popover {
    min-width: 200px !important;
    max-width: 280px !important;
  }
}

@media screen and (max-width: 550px) and (min-width: 0px) {
  .booking-overlay-open .offers-wrap {
    padding-left: 3% !important;
    padding-right: 3% !important;
  }

  boutique-room-rate .rate-row .left {
    float: none !important;
    margin-bottom: 0 !important;
    padding-bottom: 15px !important;
    width: 100% !important;
    padding-left: 15px !important;
    text-align: center !important;
    display: block !important;
  }

  boutique-room-rate .rate-row .descr-wrap {
    margin-left: 0 !important;
    padding-bottom: 25px !important;
    padding-top: 0 !important;
    display: block !important;
    width: 100% !important;
    text-align: center !important;
  }
}

.reserve-box .reserve-box-btn,
.reserve-box .reserve-box-btn-mob {
  padding-top: 15px !important;
}

boutique-room .room-info .room-price .room-reserve-btn {
  padding-bottom: 4px !important;
}

.descr-wrap .ri .btn-book {
  line-height: 1.8 !important;
  height: auto !important;
  padding-bottom: 4px !important;
  padding-top: 6px !important;
}

.long-description {
  white-space: pre-line;
}

.long-description ul>li {
  list-style-type: disc !important;
  margin-left: 17px !important;
  line-height: normal;
}

.long-description ul {
  margin-bottom: 1rem !important;
  line-height: 0;
}

@media screen and (min-width: 769px) {
  .azds-multi-room-item__content-promo .azds-button {
    padding-top: 2px !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  .azds-multi-room-item__content-promo .azds-button .azds-multi-room-item__content-promo-ellipsis {
    padding-left: 25px !important;
    padding-right: 25px !important;
  }
}

@media screen and (max-width: 1366px) {

  app-boutique-cancellation .booking-confirmation-wrap .booking-confirmation-info .btn-cancel-reservation-search,
  boutique-modify-reservation .booking-confirmation-wrap .booking-confirmation-info .btn-cancel-reservation-search,
  .booking-confirmation-wrap .booking-confirmation-info .btn-cancel-reservation-search {
    font-size: 20px !important;
  }
}

/* Integration end */

/* Integration round 3 start */
.booking-overlay-open * {
  text-shadow: 0px 0px 0px #000 !important;
  font-family: "AZDS-main", var(--default-font-family), serif !important;
}

@media screen and (min-width: 1024px) {
  .booking-overlay-open .azds-promo-popover.booking-lang-pt .azds-code-row button {
    min-width: 115px;
  }

  .booking-overlay-open .azds-promo-popover.booking-lang-pt .azds-code-row input.azds-code {
    max-width: calc(100% - 125px);
  }
}

html.booking-overlay-open,
html.booking-overlay-open body {
  font-size: 16px !important;
  line-height: normal !important;
  letter-spacing: normal !important;
  text-transform: none !important;
  font-variant: none;
  font-family: "AZDS-main", sans-serif !important;
  color: #282828;
}

.booking-overlay-open * {
  font-variant-numeric: lining-nums !important;
}

.azds-booking-section .booking-section-wrap progress-bar * {
  font-variant-numeric: lining-nums !important;
}

.azds-booking-section .reserve-form .reserve-box .sel,
.azds-booking-section .reserve-form .reserve-box .sel select,
.azds-booking-section .reserve-form .reserve-box .sel ng-select,
.azds-booking-section .reserve-form .reserve-box .inp,
.azds-booking-section .reserve-form .reserve-box .inp input,
.azds-booking-section .reserve-form .reserve-box .t-area,
.azds-booking-section .reserve-form .reserve-box .t-area textarea,
.azds-booking-section .reserve-form .reserve-box .sel ng-select .ng-select-container,
.azds-booking-section .reserve-form .sel .ng-select,
.azds-booking-section .reserve-form .ng-select .ng-select-container .ng-value-container {
  height: 100%;
}

@media screen and (max-width: 580px) {
  .azds-booking-section .ng-select.ng-select-rooms-filter {
    flex: 1 1 100% !important;
  }

  boutique-room-rate .left .title {
    font-size: 16px !important;
  }

  .azds-multi-room-item__content-promo {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }
}

@media screen and (max-width: 528px) {
  .offers-wrap[class*="booking-lang-es"] boutique-room-rate .descr-wrap .ri .btn-book {
    height: auto !important;
    line-height: 1.8 !important;
    padding: 8px 5px !important;
  }
}

@media screen and (min-width: 769px) {
  .offers-wrap[class*="booking-lang-es"] boutique-room-rate .descr-wrap .ri .btn-book {
    white-space: nowrap !important;
  }
}

.reserve-form ng-select:not(.ng-touched):not(.ng-dirty) .ng-value,
.reserve-form ng-select.ng-dirty.ng-touched.form-input-error.ng-invalid .ng-value {
  color: #080808;
  opacity: 0.43;
}

.booking-overlay-open ng-select.ng-touched.ng-dirty .ng-value,
.booking-overlay-open ng-select.form-country.ng-dirty.ng-valid .ng-value,
.booking-overlay-open ng-select.ng-dirty.ng-valid[class*="form-prefix"] .ng-value {

  color: #181818 !important;
}

@media screen and (min-width: 601px) {
  boutique-multi-room .azds-promo-popover {
    transform: translateY(2px) !important;
  }

  .azds-multi-room-item__content-promo button .azds-multi-room-item__content-promo-ellipsis {
    display: inline-flex !important;
    height: 100% !important;
    align-items: center;
    justify-content: center;
  }
}

/* Integration round 3 end */

/* Integration round 4 start */
body:has(.azds-booking-section) {
  font-size: 16px !important;
  line-height: normal !important;
  letter-spacing: normal !important;
  text-transform: none !important;
  font-variant: none !important;
  position: static !important;
  padding: 0 !important;
  margin: 0 !important;
}

body:has(.azds-booking-section) * {
  font-variant-numeric: lining-nums !important;
}

.azds-booking-section .booking-section-wrap progress-bar * {
  font-variant-numeric: lining-nums !important;
}

azds-booking-section .reserve-form .reserve-box .sel,
.azds-booking-section .reserve-form .reserve-box .sel select,
.azds-booking-section .reserve-form .reserve-box .sel ng-select,
.azds-booking-section .reserve-form .reserve-box .inp,
.azds-booking-section .reserve-form .reserve-box .inp input,
.azds-booking-section .reserve-form .reserve-box .t-area,
.azds-booking-section .reserve-form .reserve-box .t-area textarea,
.azds-booking-section .reserve-form .reserve-box .sel ng-select .ng-select-container,
.azds-booking-section .reserve-form .sel .ng-select,
.azds-booking-section .reserve-form .ng-select .ng-select-container .ng-value-container {
  height: 100%;
}

body:has(.azds-booking-section) .long-description b {
  font-weight: bold !important;
}

@-moz-document url-prefix() {
  .info-wrapper .info>li {
    margin-left: 17px;
  }

  .long-description div>li {
    margin-left: 17px;
  }

  .long-description div>b>li {
    margin-left: 17px;
  }

  .ds-step3-right .room-description span>li {
    margin-left: 17px;
  }

  boutique-policies-block p>li {
    margin-left: 17px;
  }

  .policy-wrapper .policy-block-desc>li {
    margin-left: 17px;
  }

  .room-description>li {
    margin-left: 17px;
  }
}

@media screen and (min-width: 769px) and (max-width: 1023px) {
  boutique-modify-reservation .booking-confirmation-wrap {
    padding-left: 5% !important;
    padding-right: 5% !important;
  }
}

@media (max-width: 768px) and (min-width: 0px) {
  .booking-overlay-open modal-container .modal-dialog.image .modal-header {
    position: static !important;
    height: auto !important;
  }

  .booking-overlay-open modal-container .modal-dialog.image .modal-header .close {
    padding: 0 !important;
    margin-right: 0 !important;
    margin-left: auto !important;
    margin-bottom: 5px !important;
  }
}

@media (max-width: 768px) and (min-width: 0px) {
  .booking-overlay-open modal-container .image.modal-dialog .modal-content {
    height: auto;
  }
}

@media screen and (min-width: 769px) and (max-width: 1120px) {

  boutique-modify-reservation .booking-confirmation-wrap,
  app-boutique-cancellation .booking-confirmation-wrap {
    padding-left: 2% !important;
    padding-right: 2% !important;
  }

  boutique-modify-reservation .booking-confirmation-wrap .booking-confirmation-info .booking-confirmation-info-title .reserve-form:not(.modify-form),
  app-boutique-cancellation .booking-confirmation-wrap .booking-confirmation-info .booking-confirmation-info-title .reserve-form:not(.modify-form) {
    min-width: 80% !important;
  }
}

@media screen and (min-width: 1236px) {

  boutique-modify-reservation .booking-confirmation-wrap .booking-confirmation-info .booking-confirmation-info-title .reserve-form:not(.modify-form),
  app-boutique-cancellation .booking-confirmation-wrap .booking-confirmation-info .booking-confirmation-info-title .reserve-form:not(.modify-form) {
    min-width: 600px !important;
  }
}

@media screen and (min-width: 601px) {
  boutique-multi-room .azds-promo-popover {
    transform: translateY(2px) !important;
  }

  body:has(.azds-booking-section) .azds-multi-room-item__content-promo button {
    padding: 0 !important;
  }

  .azds-multi-room-item__content-promo button .azds-multi-room-item__content-promo-ellipsis {
    display: inline-flex !important;
    height: 100% !important;
    align-items: center;
    justify-content: center;
    padding: 0 25px !important;
  }
}

@media screen and (max-width: 560px) {
  .azds-multi-room-item__content-promo {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }
}

.room-text-feature-section>h5+span {
  display: inline-block !important;
}

@media screen and (min-width: 769px) and (max-width: 1023px) {
  boutique-modify-reservation .booking-confirmation-wrap {
    padding-left: 5% !important;
    padding-right: 5% !important;
  }
}

@media screen and (min-width: 1024px) and (max-width: 1400px) {
  body:has(.azds-booking-section) .amenities-button-container span {
    font-size: 11px !important;
  }

  body:has(.azds-booking-section) .room-info .room-price .current-price {
    font-size: 18px !important;
  }

  body:has(.azds-booking-section) boutique-room .room-info .room-content {
    grid-template-columns: 1fr 180px !important;
  }
}

@media screen and (min-width: 901px) and (max-width: 1023px) {
  body:has(.azds-booking-section) app-boutique-order-step .booking-section-form {
    padding-left: 2%;
    padding-right: 2%;
  }
}

@media screen and (max-width: 1279px) and (min-width: 1024px) {
  .special-requests-text>div:not(.title) .reserve-col {
    width: 100% !important;
    margin-left: 0 !important;
  }

  .booking-section-form {
    padding-left: 3% !important;
    padding-right: 3% !important;
  }

  .azds-booking-section .reserve-form .reserve-row {
    padding-left: 2% !important;
    padding-right: 2% !important;
  }
}

@media screen and (max-width: 1023px) and (min-width: 901px) {
  .special-requests-text>div:not(.title) .reserve-col {
    width: 100% !important;
    margin-left: 0 !important;
  }
}

@media screen and (max-width: 414px) {
  boutique-room-rate .info-wrapper {
    width: 100% !important;
  }

  body:has(.azds-booking-section) .price-info {
    padding: 0 !important;
  }
}

.booking-confirmation-wrap .booking-confirmation-info .row.submit {
  display: block;
}

@media screen and (max-width: 1279px) and (min-width: 901px) {
  .azds-booking-section .reserve-form .reserve-row .reserve-col {
    margin-bottom: 15px !important;
    width: 100% !important;
  }

  .azds-booking-section .reserve-form .reserve-row .reserve-col+.reserve-col {
    margin-left: 0 !important;
  }

  .azds-booking-section app-boutique-order-step .booking-section-form-wrap boutique-form-wrapper .reserve-form .reserve-col.prefix-form-col {
    width: 24% !important;
  }

  .azds-booking-section app-boutique-order-step .booking-section-form-wrap boutique-form-wrapper .reserve-form .reserve-col.prefix-form-col+.firstname-form-col {
    width: 76% !important;
  }

  boutique-form-wrapper .reserve-form .reserve-col.prefix-form-col,
  .azds-booking-section boutique-form-wrapper .reserve-form .reserve-col.prefix-form-col {
    width: 24% !important;
  }

  boutique-form-wrapper .reserve-form .reserve-row .reserve-col.prefix-form-col+.firstname-form-col,
  .azds-booking-section boutique-form-wrapper .reserve-form .reserve-row .reserve-col.prefix-form-col+.firstname-form-col {
    width: 76% !important;
  }
}

@media screen and (min-width: 601px) and (max-width: 767px) {
  .azds-booking-section app-boutique-order-step .booking-section-form-wrap boutique-form-wrapper .reserve-form .reserve-col.prefix-form-col {
    min-width: 110px !important;
  }

  .azds-booking-section app-boutique-order-step .booking-section-form-wrap boutique-form-wrapper .reserve-form .reserve-col.prefix-form-col+.firstname-form-col {
    max-width: calc(100% - 110px) !important;
  }
}

@media screen and (max-width: 460px) {
  .azds-booking-section app-boutique-order-step .booking-section-form-wrap boutique-form-wrapper .reserve-form .reserve-col.prefix-form-col {
    min-width: 110px !important;
  }

  .azds-booking-section app-boutique-order-step .booking-section-form-wrap boutique-form-wrapper .reserve-form .reserve-col.prefix-form-col+.firstname-form-col {
    max-width: calc(100% - 110px) !important;
  }
}

@media screen and (min-width: 1280px) {
  .azds-booking-section app-boutique-order-step .booking-section-form-wrap boutique-form-wrapper .reserve-form .reserve-col.prefix-form-col {
    min-width: 110px !important;
  }

  .azds-booking-section app-boutique-order-step .booking-section-form-wrap boutique-form-wrapper .reserve-form .reserve-col.prefix-form-col+.firstname-form-col {
    max-width: calc(47% - 110px) !important;
  }
}

@media screen and (max-width: 768px) {
  body:has(.azds-booking-section) .long-description {
    padding-top: 20px !important;
  }
}

.azds-booking-section .booking-section-wrap .dates-step .ng-select .ng-select-container .ng-value-container .ng-value .ng-value-label,
.azds-booking-section .booking-section-wrap .dates-step .ng-select .ng-select-container .ng-value-container .ng-value .ng-value-label *,
.azds-booking-section .booking-section-wrap .dates-step .ng-dropdown-panel .ng-dropdown-panel-items .ng-option,
.azds-booking-section .booking-section-wrap .dates-step .ng-dropdown-panel .ng-dropdown-panel-items .ng-option span,
.dates-step .reserve-box .promo-wrap .promo-block input[type="text"] {
  font-size: 12px !important;
}

.dates-step .reserve-box .promo-wrap .promo-block input[type="text"] {
  font-size: 12px !important;
}

.dates-step .reserve-box .promo-wrap .promo-block input[type="text"]::placeholder {
  font-size: 12px !important;
}

.dates-step .reserve-box .promo-wrap .promo-block input[type="text"]::-webkit-input-placeholder {
  font-size: 12px !important;
}

.dates-step .reserve-box .promo-wrap .promo-block input[type="text"]::-moz-placeholder {
  font-size: 12px !important;
}

@media screen and (min-width: 1024px) and (max-width: 1280px) {
  body:has(.azds-booking-section) boutique-room .room-info .room-content {
    display: grid !important;
    grid-template-rows: 1fr !important;
  }

  body:has(.azds-booking-section) .room-main-info .room-info .tax-info {
    font-size: 10px !important;
  }
}

@media screen and (min-width: 1281px) {
  body:has(.azds-booking-section) boutique-room .room-info .room-content {
    display: grid !important;
    grid-template-rows: 1fr !important;
    grid-template-columns: 1fr 240px !important;
  }
}

body:has(.azds-booking-section) boutique-room .room-info.room-description-shown[class*="clearfix"] {
  border-bottom: 1px solid transparent !important;
}

@media screen and (max-width: 460px) {
  body:has(.azds-booking-section) .legend-block strong {
    width: auto !important;
  }
}

@media screen and (min-width: 1024px) and (max-width: 1280px) {
  body:has(.azds-booking-section) .azds-promo-popover:has(.azds-code[disabled]) {
    min-width: 0 !important;
  }

  body:has(.azds-booking-section) .azds-promo-popover:has(.azds-code[disabled]) input:disabled {
    width: 100% !important;
    margin-right: 0 !important;
    margin-bottom: 10px !important;
  }

  body:has(.azds-booking-section) .azds-promo-popover:has(.azds-code[disabled]) .azds-code-row button {
    width: auto !important;
  }
}

.booking-overlay-open .reserve-box [class*="promo-wrap"] [class*="promo-block"] .promo-disabled[placeholder] {
  background-color: #eeedeb !important;
  color: #040404 !important;
  opacity: 1 !important;
}

.booking-overlay-open .reserve-box [class*="promo-wrap"] [class*="promo-block"] .promo-disabled[placeholder]::-webkit-input-placeholder {
  background-color: #eeedeb !important;
  color: #040404 !important;
  opacity: 1 !important;
}

.booking-overlay-open .reserve-box [class*="promo-wrap"] [class*="promo-block"] .promo-disabled::-moz-placeholder {
  background-color: #eeedeb !important;
  color: #040404 !important;
  opacity: 1 !important;
}

.booking-overlay-open .reserve-box [class*="promo-wrap"] [class*="promo-block"] .promo-disabled::placeholder {
  background-color: #eeedeb !important;
  color: #040404 !important;
  opacity: 1 !important;
}

@media screen and (max-width: 414px) {
  boutique-room-rate .info-wrapper {
    width: 100% !important;
  }

  body:has(.azds-booking-section) .price-info {
    padding: 0 !important;
  }
}

@media (max-width: 414px) and (min-width: 0px) {
  body:has(.azds-booking-section) boutique-room-rate .info ul>p {
    text-align: left !important;
  }
}

@media screen and (max-width: 414px) {
  body:has(.azds-booking-section) .room-info .room-facilities boutique-room-amenity .room-amenities-list {
    display: grid !important;
    grid-template-rows: auto !important;
    grid-template-columns: repeat(3, 33%) !important;
  }

  body:has(.azds-booking-section) .room-info .room-facilities boutique-room-amenity .room-amenities-list li {
    width: 100% !important;
  }
}

@media screen and (min-width: 769px) and (max-width: 1023px) {
  .azds-booking-section .nightly-price-wrap .price {
    font-size: 11px !important;
  }
}

@media screen and (min-width: 1024px) and (max-width: 1400px) {
  body:has(.azds-booking-section) .dates-step {
    padding-left: 4% !important;
    padding-right: 4% !important;
  }

  .azds-booking-section .nightly-price-wrap .price {
    font-size: 10px !important;
  }
}

@media screen and (min-width: 769px) and (max-width: 1280px) {
  body:has(.azds-booking-section) .azds-promo-popover:has(.azds-code[disabled]) {
    min-width: 0 !important;
  }

  body:has(.azds-booking-section) .azds-promo-popover:has(.azds-code[disabled]) input:disabled {
    width: 100% !important;
    margin-right: 0 !important;
    margin-bottom: 10px !important;
  }

  body:has(.azds-booking-section) .azds-promo-popover:has(.azds-code[disabled]) .azds-code-row button {
    width: auto !important;
  }
}

body:has(.azds-booking-section) p.room-description {
  margin-bottom: 10px !important;
}

@media (max-width: 660px) and (min-width: 600px) {
  body:has(.azds-booking-section) .azds-promo-popover .azds-code-row button {
    width: 90px !important;
  }

  body:has(.azds-booking-section) .azds-promo-popover .azds-code-row input {
    width: calc(100% - 100px) !important;
  }
}

@media (min-width: 576px) {
  body:has(.azds-booking-section) .modal-dialog {
    max-width: none !important;
  }
}

.azds-booking-section .reserve-form:not(.modify-form) .ng-select:not(.form-input-selected).ng-untouched.ng-dirty.ng-valid .ng-select-container {
  color: inherit !important;
}

@media (max-width: 768px) and (min-width: 0) {
  .azds-booking-section .reserve-form .reserve-col {
    margin-bottom: 15px !important;
    width: 100%;
  }
}

@media screen and (max-width: 414px) {
  body:has(.azds-booking-section) .info-wrapper .info>li {
    text-align: left;
  }
}

body:has(.azds-booking-section) .descr-wrap .ri .btn-book {
  text-transform: uppercase !important;
}

@media (max-width: 600px) and (min-width: 0px) {
  body:has(.azds-booking-section) .azds-promo-popover .azds-code-row button.azds-promo-popover__apply-button#promoButton {
    font-size: 18px !important;
  }
}

body:has(.azds-booking-section) .nightly-rates ul {
  line-height: 1.2;
}

body:has(.azds-booking-section) modal-container .modal-dialog.info-popup .charge-block dt,
body:has(.azds-booking-section) modal-container .modal-dialog.info-popup .charge-block dd {
  line-height: 1.3 !important;
}

body:has(.azds-booking-section):not(.isKeyDown) :focus-visible {
  outline: none;
}

body:has(.azds-booking-section) .azds-booking-section .reserve-form .hint.error {
  margin-top: 3px;
}

body:has(.azds-booking-section),
body:has(.azds-booking-section) *,
body:has(.azds-booking-section) .booking-confirmation-wrap .booking-confirmation-info .booking-confirmation-info-title h1 {
  font-family: Romie, "AZDS-main", var(--default-font-family), serif !important;
}

body:has(.azds-booking-section) .booking-confirmation-wrap .booking-confirmation-info .booking-confirmation-info-title h1 {
  font-size: calc(1.438rem + 10 * (100vw - 22.5rem) / 1560) !important;
}

body:has(.azds-booking-section) .azds-booking-section app-boutique-calendar .title-monthes {
  font-size: calc(.938rem + 1 * (100vw - 22.5rem) / 1560) !important;
  letter-spacing: .03rem !important;
}

@media screen and (min-width: 360px) {
  body:has(.azds-booking-section) p {
    font-size: calc(.9rem + 1 * (100vw - 22.5rem) / 1560) !important;
  }
}

@media screen and (min-width: 1920px) {
  body:has(.azds-booking-section) p {
    font-size: 0.99rem !important;
  }
}

body:has(.azds-booking-section) .login-bar a,
body:has(.azds-booking-section) .room-info .room-price .room-reserve-btn {
  font-size: 0.99rem !important;
}

@media screen and (min-width: 769px) {
  body:has(.azds-booking-section) .azds-multi-room-item__content-promo .azds-button {
    font-size: 1.14rem !important;
  }

  body:has(.azds-booking-section) .room-info .room-price .room-reserve-btn {
    font-size: 1.14rem !important;
  }

  body:has(.azds-booking-section) h3.room-title {
    font-size: calc(1.438rem + 9 * (100vw - 22.5rem) / 1560) !important;
  }

  body:has(.azds-booking-section) boutique-room-rate .left .title {
    font-size: calc(1.438rem + 9 * (100vw - 22.5rem) / 1560) !important;
  }
}

body:has(.azds-booking-section) .offers-wrap .step-2-rates .rates-title {
  font-size: 1.14rem !important;
}

body:has(.azds-booking-section) .descr-wrap .ri .btn-book {
  font-size: 0.99rem !important;
}

body:has(.azds-booking-section) boutique-form-wrapper .reserve-form .title, .azds-booking-section boutique-form-wrapper .reserve-form .title {
  font-size: 1.14rem !important;
}

body:has(.azds-booking-section) .azds-booking-section boutique-modify-guest-info boutique-form-wrapper .reserve-form .ng-select.ng-untouched.ng-pristine.ng-valid .ng-value {
  opacity: 1 !important;
  font-weight: 500 !important;
  color: #181818 !important;
}

/* Integration round 4 end */
