body {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-family: -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, Oxygen,
    Ubuntu, Cantarell, Fira Sans, Droid Sans, Helvetica Neue, sans-serif;
  margin: 0;
}
code {
  font-family: source-code-pro, Menlo, Monaco, Consolas, Courier New, monospace;
}
a:not([class*="btn"]) {
  text-decoration: none;
}
    a:not([class*="btn"]):hover {
        text-decoration: none;
    }

.form-control[disabled],
.form-control[readonly],
fieldset[disabled] .form-control {
    cursor: not-allowed;
    background-color: #eee;
    opacity: 1;
}

.actions {
  display: flex;
  justify-content: flex-start;
  gap: 1rem;
}
.alert.thick {
  border-bottom-width: 0.4rem;
}
.alert-success {
  --bs-alert-border-color: var(--bs-success);
}
.alert-success svg {
  color: var(--bs-success);
}
.range-slider {
  -webkit-tap-highlight-color: transparent;
  background: #ddd;
  border-radius: 4px;
  cursor: pointer;
  display: block;
  height: 8px;
  position: relative;
  touch-action: none;
  -webkit-user-select: none;
  user-select: none;
  width: 100%;
}
.range-slider[data-vertical] {
  height: 100%;
  width: 8px;
}
.range-slider[data-disabled] {
  cursor: not-allowed;
  opacity: 0.5;
}
.range-slider .range-slider__thumb {
  background: #2196f3;
  border-radius: 50%;
  height: 24px;
  position: absolute;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  width: 24px;
  z-index: 3;
}
.range-slider .range-slider__thumb:focus-visible {
  box-shadow: 0 0 0 6px rgba(33, 150, 243, 0.5);
  outline: 0;
}
.range-slider[data-vertical] .range-slider__thumb {
  left: 50%;
}
.range-slider .range-slider__thumb[data-disabled] {
  z-index: 2;
}
.range-slider .range-slider__range {
  background: #51adf6;
  height: 100%;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 100%;
  z-index: 1;
}
.range-slider[data-vertical] .range-slider__range {
  left: 50%;
  -webkit-transform: translate(-50%);
  transform: translate(-50%);
}
.range-slider input[type="range"] {
  -webkit-appearance: none;
  background-color: initial;
  height: 0;
  left: 0;
  pointer-events: none;
  position: absolute;
  top: 0;
  width: 0;
  z-index: 2;
}
.range-slider input[type="range"]::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
}
.range-slider input[type="range"]::-moz-range-thumb {
  border: 0;
  height: 0;
  width: 0;
}
.range-slider input[type="range"]:focus {
  outline: 0;
}
.btn-white {
  background-color: var(--bs-body-bg);
  border: var(--bs-border-width) solid var(--bs-border-color);
  color: var(--bs-body-color);
}
.btn-white:hover {
  background-color: #fff;
}
.action-bar {
  align-items: center;
  display: flex;
  flex-direction: row;
  justify-content: space-between;
}
.action-bar button > svg {
  margin-right: 0.5rem;
}
@media (max-width: 991.98px) {
  .action-bar {
    grid-gap: 1rem;
    background: #fff;
    border-bottom: 1px solid #d9d9d9;
    bottom: 0;
    box-shadow: 0 -0.125rem 0.25rem rgba(0, 0, 0, 0.075);
    display: grid;
    gap: 1rem;
    grid-template-columns: 1fr 1fr;
    left: 0;
    padding: 1rem;
    position: fixed;
    right: 0;
    z-index: 1;
  }
  .action-bar > div > button {
    border-width: 3px;
    flex-grow: 1;
    height: 3rem;
  }
}
.filter.rating .btn-check:checked + .btn svg {
  color: var(--bs-btn-active-color);
}
.filter.rating svg {
  color: #00bcd4;
  margin-right: 3px;
}
.filter .filter__label {
  display: flex;
  font-weight: 600;
  justify-content: space-between;
  padding: 1.5rem 0;
}
.filter .filter__label span.filter__label-title svg {
  margin-right: 0.5rem;
}
.filter .filter__label span.filter__label-value {
  background: hsla(0, 0%, 45%, 0.102);
  border-radius: 6px;
  color: #737373;
  font-size: 1rem;
  font-weight: 600;
  padding: 3px 8px;
}
.filter .range-slider .range-slider__range {
  background: #0d6efd;
}
.filter .range-slider .range-slider__thumb {
  background: #0257d5;
  border: 6px solid #0d6efd;
}
.filter .range-slider.single-thumb .range-slider__thumb[data-disabled] {
  display: none;
}
.filter .range-slider.single-thumb .range-slider__range {
  border-radius: 6px;
}
.filter
  .range-slider.single-thumb
  .range-slider__thumb[data-lower][data-disabled]
  ~ .range-slider__range:before {
  background: #0d6efd;
  border-radius: 6px;
  content: "";
  height: 100%;
  left: -10px;
  position: absolute;
  width: 1rem;
}
.filter .filter__minmax {
  display: flex;
  font-weight: 600;
  justify-content: space-between;
  padding: 1.5rem 0;
}
.filter .filter__minmax span.filter__minmax-value {
  border-radius: 6px;
  color: #727272;
  font-size: 1rem;
  font-weight: 600;
  padding: 3px 8px;
}
.filter .list-group {
  gap: 0.5rem;
}
.filter .list-group .list-group-item {
  align-items: center;
  background: #e4e6e7;
  border: none;
  border-radius: 50px;
  display: flex;
  flex-direction: row;
  padding: 0 1rem;
}
.filter .list-group .list-group-item:hover {
  background: #d6d8d9;
  cursor: pointer;
}
.filter .list-group .list-group-item input {
  margin: 0;
}
.filter .list-group .list-group-item label {
  color: var(--bs-body-color);
  cursor: pointer;
  flex-grow: 1;
  padding: 0.75rem;
}
.filter .list-group .list-group-item label svg {
  padding-right: 0.5rem;
}

.amenities {
  align-items: center;
  display: flex;
  flex-direction: row;
  gap: 16px;
  justify-content: flex-start;
}
.amenities.vertical {
  align-items: flex-start;
  flex-direction: column;
  gap: 8px;
}
.amenities.vertical .amenities-item {
  display: grid;
  grid-template-columns: 2rem 1fr;
}
.amenities.vertical .amenities-item svg {
  font-size: 1rem;
  grid-column: 1/2;
  padding-top: 3px;
}
.amenities.vertical .amenities-item span {
  grid-column: 2/3;
}

    .amenities:not(.vertical):not(.pilled) .amenities-item:first-child {
        padding: 0;
    }

        .amenities:not(.vertical):not(.pilled) .amenities-item:first-child:after {
            display: none;
        }
.amenities:not(.vertical):not(.pilled) .amenities-item:not(:first-child) svg {
  font-size: 1.2rem;
}
.amenities:not(.vertical):not(.pilled) .amenities-item:not(:first-child) span {
  display: none;
}
.amenities.pilled {
  flex-wrap: wrap;
}
.amenities.pilled .amenities-item {
  align-items: center;
  background: #f5f6f7;
  border-radius: 40px;
  display: flex;
  padding: 0.5rem 1rem;
  white-space: nowrap;
}
.amenities.pilled .amenities-item svg {
  font-size: 1.2rem;
}
.amenities .amenities-item {
  position: relative;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
.amenities .amenities-item svg + span {
  padding-left: 0.5rem;
}
.amenities .amenities-item span {
  font-size: 15px;
  font-weight: 600;
}
.top {
  background: #f5f6f7;
  border-bottom: 1px solid #dee2e6;
}
.top .left {
  margin-bottom: -3rem;
  padding: 1rem 1rem 0;
}
.top .left .carousel {
  border-radius: 8px;
  box-shadow: 0 2px 12px 5px hsla(0, 0%, 61%, 0.47);
  overflow: hidden;
}
.top .left .carousel img {
  height: 304px;
  object-fit: cover;
}
.top .right {
  padding-bottom: 3rem;
  padding-right: 1rem;
  padding-top: 1.5rem;
  position: relative;
}
.top .right .nav {
  border-bottom: 0;
  bottom: 0;
  left: 0;
  position: absolute;
  right: 0;
}
.top .right .nav .nav-link:not(.active):hover {
  background: var(--bs-gray-100);
}
.bottom .left {
  flex-direction: column;
  padding-top: 3rem;
}
.bottom .left > div {
  padding: 1rem;
}
.bottom .left .highlights {
  grid-column: 1/3;
  grid-row: 1/2;
}
.bottom .right {
  padding-left: 0;
  padding-top: 1rem;
}
.modal-fullscreen {
  margin: 0 auto;
  width: 1000px;
}
.modal-fullscreen .modal-body {
  padding: 0;
}
.highlights {
  display: flex;
  flex-direction: row;
  font-size: 0.925rem;
  justify-content: space-between;
  padding: 1.5rem;
  position: relative;
}
.highlights:after {
  background: #f8f5f5;
  bottom: 0;
  content: "";
  height: 1px;
  left: 1.5rem;
  position: absolute;
  right: 1.5rem;
}
.highlights .higlight {
  align-items: center;
  display: flex;
  flex-direction: row;
  position: relative;
}
.highlights .higlight svg {
  font-size: 1.5rem;
  margin-right: 1rem;
}
.highlights .higlight .hotel-address-1 {
  display: block;
}
.highlights .higlight:not(:first-child):before {
  background: rgba(0, 0, 0, 0.2);
  border-radius: 50%;
  content: "";
  display: block;
  height: 5px;
  left: -30px;
  position: absolute;
  width: 5px;
}
.description {
  font-size: 0.95rem;
  padding-left: 1.5rem;
  padding-right: 3rem;
}
.waitlist-confirmation {
  background: #fdfbf8;
  border: 2px solid #f0ad4e;
  border-radius: 8px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-left: 1rem;
  margin-right: 1rem;
  padding: 1rem;
}
.hotel-details {
  display: flex;
}
.hotel-details .nav-tabs {
  background: #f5f6f7;
}
.hotel-details .nav-tabs li:first-child {
  margin-left: 1rem;
}
.hotel-details
  .hotel-details__left-pane
  .hotel-details__left-pane-top
  .hotel-details__left-pane-top--image {
  background: #fff;
  background-size: cover;
  height: 400px;
  width: 100%;
}
.hotel-details .hotel-details__left-pane .highlights {
  display: flex;
  flex-direction: row;
  font-size: 0.925rem;
  grid-column: 1/3;
  grid-row: 1/2;
  justify-content: space-between;
  padding: 1.5rem;
}
.hotel-details .hotel-details__left-pane .highlights .higlight {
  align-items: center;
  display: flex;
  flex-direction: row;
  position: relative;
}
.hotel-details .hotel-details__left-pane .highlights .higlight svg {
  font-size: 1.5rem;
  margin-right: 1rem;
}
.hotel-details
  .hotel-details__left-pane
  .highlights
  .higlight
  .hotel-address-1 {
  display: block;
}
.hotel-details
  .hotel-details__left-pane
  .highlights
  .higlight:not(:first-child):before {
  background: rgba(0, 0, 0, 0.2);
  border-radius: 50%;
  content: "";
  display: block;
  height: 5px;
  left: -30px;
  position: absolute;
  width: 5px;
}
.hotel-details .hotel-details__left-pane .description {
  padding-left: 1.5rem;
  padding-right: 3rem;
}
.hotel-details__right-pane {
  width: 100%;
}
.hotel-details__right-pane .hotel-details__right-pane-top {
  background: #f5f6f7;
  padding: 1rem;
}
.hotel-details__right-pane
  .hotel-details__right-pane-top
  .hotel-details__right-pane-top--rating {
  color: #d9a60b;
  margin-bottom: 6px;
}
.room-selection {
  padding: 1rem;
}
    .room-selection .room-card {
        align-items:center;
        display: flex;
        flex-direction: row;
        justify-content: space-between;
        transition: all 0.1s cubic-bezier(0.6, -0.28, 0.735, 0.045);
    }
.room-selection .room-card:not(.available) {
  cursor: not-allowed;
}
.room-selection .room-card.available:hover {
  border-color: #000;
  border-width: 1px;
  box-shadow: 0 0.25rem 0.5rem rgba(0, 0, 0, 0.075) !important;
  cursor: pointer;
}
.room-selection .room-card .room-name {
  font-size: 15px;
  font-weight: 600;
}
.room-selection .room-card .room-price {
  display: flex;
  flex-direction: column;
}
.room-selection .room-card .room-price .room-price--amount {
  font-size: 18px;
  font-weight: 600;
}
.room-selection .room-card:not(:last-child) {
  margin-bottom: 1rem;
}
@media (max-width: 992px) {
    .modal-fullscreen {
    width: 100%;
  }
    .modal-fullscreen .modal-body > .container {
        margin: 0;
        max-width: 100%;
        padding-right: 1rem;
        width: 100%;
        background: #fff;
    }
  .top .left {
    margin-bottom: 0;
    padding-bottom: 1rem;
  }
  .nav .nav-item:first-of-type {
    margin-left: 1rem;
  }
}
@media (min-width: 993px) {
    .modal-fullscreen .modal-header {
        background: #f5f6f7;
        border-radius: 50% !important;
        padding: 0.5rem;
        position: fixed;
        right: 1rem;
        top: 0.5rem;
        z-index: 1;
    }
        .modal-fullscreen .modal-header .btn-close {
            margin: 0;
        }
}
body {
  background: #f1f3f4;
}

#checkout {
  padding: 1.5rem 0;
}
.form-control,
.form-select,
.h3,
h3 {
  font-weight: 600;
}
.content-area {
  background: #fff;
  border-radius: 5px;
  padding: 1.5rem;
}
.modal .content-area {
    padding: 0;
}
.content-area + .content-area:not(:first-child) {
    margin-top: 1.5rem;
}
.content-area
  .accordion
  .accordion-item
  .accordion-header
  .accordion-header_check {
  align-items: center;
  bottom: 0;
  display: flex;
  justify-content: center;
  left: 0;
  position: absolute;
  top: 0;
  width: 64px;
}
.content-area
  .accordion
  .accordion-item
  .accordion-header
  .accordion-header_check
  .accordion-header_check-label {
  bottom: 0;
  left: 0;
  position: absolute;
  right: 0;
  top: 0;
}
.content-area
  .accordion
  .accordion-item
  .accordion-header
  .accordion-header_check
  + .accordion-header_title {
  padding-left: 40px;
}
.content-area .content-area_actions {
  align-items: center;
  display: flex;
  justify-content: space-between;
}
    /*TODO
.content-area .list-group-item {
  align-items: center;
  padding: 20px;
}
.content-area
  .list-group-item
  div
  > div:first-child:not(.list-group-item_quantity) {
  padding-left: 40px;
}
.content-area .list-group-item .list-group-item_quantity {
  align-items: center;
  display: flex;
  padding-left: 8px;
  width: 40px;
}
.content-area .list-group-item > div:not(:last-child) {
  display: flex;
}
.content-area .list-group-item > div:last-child {
  text-align: right;
}
*/
.content-area .hotel-selection {
  display: grid;
  grid-template-columns: 1fr;
}
.content-area .hotel-selection.confirmed {
  gap: 1rem;
  grid-template-columns: 250px 1fr;
  grid-template-rows: 1fr;
}
.content-area .hotel-selection.confirmed .hotel-selection__image {
  width: 100%;
  grid-column: 1/2;
  grid-row: 1/3;
}
.content-area .hotel-selection .hotel-selection__image {
  background-position: 50%;
  background-size: cover;
  border-radius: 8px;
  padding-bottom: 48.5%;
}
.content-area .hotel-selection .hotel-selection__title {
  font-size: 18px;
  font-weight: 700;
  padding: 18px 0 0;
  text-align: center;
}
/*add bottom border if NOT last OR only child within parent*/
.content-area_form:not(:last-child):not(:only-child) {
    border-bottom: 1px solid #e0e0e0;
    margin-bottom: 1.5rem;
    padding-bottom: 1.5rem;
}
.content-area_form.bottom-border {
    border-bottom: 1px solid #e0e0e0;
    margin-bottom: 1.5rem;
    padding-bottom: 1.5rem;
}
.content-area_form .form-value {
  display: none;
  font-weight: 600;
}
.content-area_form .btn-change {
  display: none;
}
.content-area_form .btn-save {
  display: block;
  margin-left: 1rem;
}
.content-area_form .btn-revert {
  display: block;
  margin-left: 1rem;
}

.content-area_form.display-mode .btn-change {
  display: block;
}
.content-area_form.display-mode .btn-save {
  display: none;
}
.content-area_form.display-mode .btn-revert {
  display: none;
}
.content-area_form.display-mode .form-value {
  display: block;
}
.content-area_form.display-mode .form-input {
  display: none;
}
.content-area_form.display-mode .form-label {
  --bs-text-opacity: 1;
  color: var(--bs-secondary-color);
  margin-bottom: 0.1rem;
  font-weight: normal;
}

.content-area_form .content-area_form-header {
  align-items: center;
  display: flex;
  justify-content: space-between;
  margin-bottom: 1rem;
}
.content-area_form .content-area_form-header.content-area_form-header--inline {
  justify-content: flex-start;
}
.content-area_form
  .content-area_form-header
  .content-area_form-header--actions {
  display: flex;
}
.content-area_form .content-area_form-header .btn-link {
  padding-right: 0;
  text-decoration: none;
}
.content-area_form .content-area_form-header .h1,
.content-area_form .content-area_form-header .h2,
.content-area_form .content-area_form-header .h3,
.content-area_form .content-area_form-header .h4,
.content-area_form .content-area_form-header .h5,
.content-area_form .content-area_form-header .h6,
.content-area_form .content-area_form-header h1,
.content-area_form .content-area_form-header h2,
.content-area_form .content-area_form-header h3,
.content-area_form .content-area_form-header h4,
.content-area_form .content-area_form-header h5,
.content-area_form .content-area_form-header h6 {
  margin: 0;
}
.selected-dates {
  align-items: center;
  background-color: var(--bs-list-group-bg);
  border: var(--bs-border-width) solid var(--bs-border-color);
  border-radius: var(--bs-border-radius);
  display: flex;
  justify-content: space-around;
  padding: 1rem;
}
.bd-callout {
  border: 1px solid transparent;
  border-left-width: 0.25rem;
  border-radius: 0.25rem;
  font-size: 1rem;
  margin-bottom: 1.25rem;
  margin-top: 1rem;
  padding: 1rem;
}
.bd-callout h4 {
  margin-bottom: 0.25rem;
}
.bd-callout p:last-child {
  margin-bottom: 0;
}
.bd-callout code {
  border-radius: 0.25rem;
}
.bd-callout + .bd-callout {
  margin-top: -0.25rem;
}
.bd-callout-info {
  background: rgba(91, 192, 222, 0.22);
  border-left-color: #5bc0de;
}
.bd-callout-warning {
  background: rgba(240, 173, 78, 0.22);
  border-left-color: #f0ad4e;
}
.bd-callout-danger {
  background: rgba(217, 83, 79, 0.22);
  border-left-color: #d9534f;
}
.show-branding {
  background-position: 50%;
  background-repeat: no-repeat;
  background-size: cover;
  height: 210px;
}
@media (max-width: 575px) {
  .show-branding {
    border-radius: 0;
  }
}
input[data-spargo-date-picker] {
  text-align: center;
  height: 90px;
}
.datepicker--inline {
  box-shadow: none !important;
}

.releaseinfo {
    text-align: center;
    background-color: red;
    color: white;
}

    .releaseinfo table {
        font-size: .8em;
        background-color: black;
        margin: 0 auto;
        width: 30%;
    }

.footer-icon {
    display: block;
    width: 80px;
    height: 33px;
    background: url("../../Images/Template/footer-icon.png") no-repeat;
}

/* input validator */
.JSAValidatorCalloutStyle div,
.JSAValidatorCalloutStyle td {
    border: solid 1px #666;
    background-color: #ef462b;
    color: #FFF;
}

.JSAValidatorCalloutStyle img {
    display: none;
}

/*progress indicator*/
div.progressIndicator {
    display: none;
    width: 100%;
    height: 100%;
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 9999999;
    filter: alpha(opacity=60); /* For IE8 and earlier */
    background: #000;
    opacity: 0.6;
}

img.progressIndicator {
    width: 40px;
    height: 40px;
    margin-left: -20px;
    margin-top: -20px;
    position: relative;
    opacity: 1.0;
    top: 50%;
    left: 50%;
    border-radius: 5px;
    text-align: center;
    z-index: 99999999;
    overflow: auto;
}

/* Block Style Hotel Listing */

h2.block-label {
    padding: 10px;
    font-weight: bold;
    background: rgb(238,238,238); /* Old browsers */
    background: -moz-linear-gradient(top, rgba(238,238,238,1) 0%, rgba(204,204,204,1) 100%); /* FF3.6+ */
    background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,rgba(238,238,238,1)), color-stop(100%,rgba(204,204,204,1))); /* Chrome,Safari4+ */
    background: -webkit-linear-gradient(top, rgba(238,238,238,1) 0%,rgba(204,204,204,1) 100%); /* Chrome10+,Safari5.1+ */
    background: -o-linear-gradient(top, rgba(238,238,238,1) 0%,rgba(204,204,204,1) 100%); /* Opera 11.10+ */
    background: linear-gradient(to bottom, rgba(238,238,238,1) 0%,rgba(204,204,204,1) 100%); /* W3C */
    border: 1px solid #ccc;
    cursor: pointer;
}

.distance-to-venue-on-card, .distance-to-airport-on-card {
    font-size: 0.75em;
    color: #666;
    margin-top: 5px;
}
