/*** Multi dates ***/
.rp-multi-dates {
  font-size: 18px;
  line-height: 24px;
  color: #BA3C3C;
  text-align: center;
  padding: 20px 0;
}

.rp-multi-dates i {
  font-size: 45px;
  margin-bottom: 14px;
}

.select-title {
  text-transform: uppercase;
  color: #0D2440;
  font-size: 17px;
  font-weight: bold;
  padding-top: 30px;
  padding-bottom: 10px;
}

.custom-select {
  position: relative;
}

.custom-select .selected {
  background-color: #ffffff;
  padding: 20px 24px;
  border: 1px solid #707070;
  border-radius: 16px;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.1607843137);
  cursor: pointer;
  font-size: 16px;
  color: #707070;
  z-index: 10;
  position: relative;
}

.custom-select .selected.opened {
  border-radius: 16px 16px 0 0;
  border-bottom: none;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.1607843137);
}

.custom-select .options {
  list-style: none;
  padding: 0;
  margin: -14px 0 0;
  display: none;
  position: absolute;
  background: white;
  border: 1px solid #707070;
  border-radius: 0 0 16px 16px;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.1607843137);
  width: 100%;
}

.custom-select .options.opened {
  padding-top: 20px;
}

.custom-select .options li {
  padding: 14px 18px;
  cursor: pointer;
  display: flex;
  align-items: center;
  font-size: 16px;
  color: #707070;
  width: 100%;
  transition: all, 0.25s;
}

.custom-select .options li:hover {
  background-color: #f0f0f0;
  border-radius: 16px;
}

.custom-select .options .av-date,
.custom-select .selected .av-date {
  font-size: 20px;
  font-weight: bold;
  color: #0E2F54;
}

.custom-select .options li .text-sm,
.custom-select .selected .text-sm {
  font-size: 14px;
}

.custom-select [x-show=open] {
  display: block;
}

.custom-select .rotate-180 {
  transform: rotate(180deg);
  transition: transform 0.2s;
}

.custom-select .drop-icon {
  font-size: 22px;
  margin-bottom: 0;
  color: #707070;
}

/*** Flights ***/
.flight-element {
  display: flex;
  align-items: center;
  width: 100%;
  gap: 6px;
  margin-bottom: 10px;
  background: #fff;
  border-radius: 12px;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.1607843137);
  min-height: 104px;
  padding: 10px;
}

.flight-element .flight-content {
  display: flex;
  align-items: center;
  width: 100%;
  gap: 6px;
  padding: 10px;
  justify-content: space-between;
}

.flight-element .flight-content .flight-image {
  width: 130px;
  height: 40px;
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}

.flight-element .flight-content .flight-text {
  display: flex;
  align-items: flex-start;
  flex-direction: column;
  gap: 2px;
}

.flight-element .flight-content .flight-text .flight-codes {
  font-size: 24px;
  line-height: 24px;
  font-weight: bold;
  color: #0d2440;
  width: 100%;
}

.flight-element .flight-content .flight-text .flight-times {
  font-size: 18px;
  line-height: 18px;
  color: #000;
}

.flight-element .flight-content .flight-price {
  font-size: 24px;
  line-height: 24px;
  font-weight: bold;
  color: #0d2440;
  min-width: 110px;
}

.flight-element .flight-content .flight-price.not {
  min-width: 110px;
}

@media (max-width: 767px) {
  .flight-element .flight-content {
    flex-direction: column;
    align-items: flex-start;
  }
}
/*** Booking generale ***/
.general-labels-cnt {
  border-bottom: 1px solid var(--bs-primary);
  padding: 9px 0;
}

.accomodation-group-label,
.general-group-label {
  color: #000;
  font: normal normal 500 15px/17px var(--bs-font-sans-serif);
}

.detail-section-title {
  font-size: 20px;
  font-weight: 700;
  background-color: var(--bs-primary);
  color: var(--bs-white);
  padding: 10px 8px;
}

.detail-description-title {
  font-size: 22px;
  font-weight: bold;
  color: #0E2F54;
  margin-bottom: 20px;
}

.detail-room-img {
  height: 276px;
  width: 100%;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  margin-bottom: 15px;
}

.detail-room-name {
  font-size: 25px;
  color: #0E2F54;
}

.detail-room-description {
  font-size: 20px;
  color: #0E2F54;
}

.detail-amenities .detail-main-single {
  margin-bottom: 32px;
}

.detail-amenities .detail-main-single .detail-main-single-icon {
  font-size: 30px;
  --ei-font-size: 30px;
  --ei-line-height: 30px;
  max-height: 30px;
  max-width: 30px;
}

.detail-amenities .detail-main-single .detail-main-single-cont {
  font-size: 16px;
}

/* Config */
.detail-config section {
  padding: 0;
}

.room-config {
  background-color: #fff;
  margin-bottom: 14px;
}

.room-config .room-button {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 8px;
  cursor: pointer;
  transition: all, 0.25s;
  border-bottom: 2px solid var(--bs-primary);
}

.room-config .room-button .rb-left {
  display: flex;
  align-items: center;
  gap: 20px;
  color: #0d2440;
  font-size: 20px;
  line-height: 24px;
  font-weight: bold;
}

.room-config .room-button .rb-left .rb-icon {
  color: #0d2440;
  font-size: 45px;
  --ei-font-size: 45px;
  --ei-line-height: 45px;
  max-height: 45px;
  max-width: 45px;
}

.room-config .room-button .rb-left .rb-text span {
  color: #707070;
}

.room-config .room-button .rb-arrow {
  background-color: #0d2440;
  color: #fff;
  font-size: 18px;
  padding: 6px;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all, 0.25s;
}

.room-config .room-button.inner {
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.29);
  padding: 24px 20px;
  margin-bottom: 15px;
}

.room-config .room-button.inner .rb-left .rb-text span {
  text-transform: none;
  font-weight: 400;
}

.room-config .room-button.inner .rb-arrow {
  background-color: #fff;
  color: #0d2440;
}

.room-config .room-button.collapsed .rb-arrow {
  transform: rotate(180deg);
}

.type-selection {
  background-color: #fff;
  border-radius: 8px;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.29);
  padding: 24px 20px;
  margin-bottom: 15px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.room-element {
  display: flex;
  align-items: stretch;
  margin-bottom: 15px;
  gap: 20px;
}

.room-element:last-child {
  margin-bottom: 0;
}

.meal-options {
  display: flex;
  flex-direction: column;
  width: 100%;
  border-top: 1px solid #C9C9C9;
  margin-top: 12px;
  padding-top: 4px;
}

.meal-option-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 0;
  border-bottom: 1px solid #f0f0f0;
  flex-wrap: wrap;
}
.meal-option-row .meal-name {
  flex: 1 1 auto;
  font-size: 14px;
}
.meal-option-row .room-availability {
  flex-shrink: 0;
}
.meal-option-row .room-price-cnt {
  flex-shrink: 0;
}
.meal-option-row .room-select-btn-cnt {
  flex-shrink: 0;
}

.meal-option-row:last-child {
  border-bottom: none;
}

.room-element .room-img {
  border-radius: 8px;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  flex-grow: 1;
  width: 100%;
  max-width: 160px;
  min-height: 160px;
}

.room-element .room-data {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  padding: 10px 25px;
  width: 100%;
  flex-wrap: wrap;
}

@media (min-width: 992px) {
  .room-element .room-data {
    flex-wrap: nowrap;
  }
}
.room-element .room-data .room-info {
  display: flex;
  flex-direction: row;
  flex: 1;
  text-wrap: nowrap;
}
@media (max-width: 991px) {
  .room-element .room-data .room-info {
    margin-bottom: 8px;
    flex: 1 1 100%;
  }
}

.room-element .room-data .room-info .room-info-details {
  display: flex;
  flex-direction: column;
}

.room-element .room-data .room-info .room-name {
  color: #000;
  font: normal normal 700 16px/19px var(--bs-font-sans-serif);
  margin-bottom: 3px;
}

.room-element .room-data .room-info .room-description {
  font: normal normal 400 15px/18px var(--bs-font-sans-serif);
}

.room-element .room-data .room-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
}

.room-element .room-data .room-actions .room-link {
  flex: 1 1 100%;
  text-decoration: underline;
  font-size: 20px;
  color: #0d2440;
  cursor: pointer;
}

.room-element .room-data .room-availability .label-availability,
.meal-option-row .room-availability .label-availability {
  display: inline-block;
  font: normal normal 500 10px/12px var(--bs-font-sans-serif);
  padding: 4px 8px;
  margin-right: 12px;
}
@media (max-width: 991px) {
  .room-element .room-data .room-availability .label-availability,
  .meal-option-row .room-availability .label-availability {
    margin-right: 0;
  }
}

.room-element .room-data .room-availability .label-availability.label-availability-ok,
.meal-option-row .room-availability .label-availability.label-availability-ok {
  background-color: var(--bs-success);
  color: var(--bs-white);
}

.room-element .room-data .room-availability .label-availability.label-availability-rq,
.room-element .room-data .room-availability .label-availability.label-availability-general,
.meal-option-row .room-availability .label-availability.label-availability-rq,
.meal-option-row .room-availability .label-availability.label-availability-general {
  background-color: var(--bs-warning);
  color: var(--bs-black);
}

.history-other-type-row .room-cancellation-policy-label,
.room-element .room-data .room-cancellation-policy-cnt .room-cancellation-policy-label,
.meal-option-row .room-cancellation-policy-cnt .room-cancellation-policy-label {
  color: #000;
  font-size: 13px;
  line-height: 15px;
}

@media (max-width: 576px) {
  .room-element .room-data .room-cancellation-policy-cnt,
  .meal-option-row .room-cancellation-policy-cnt {
    flex: 1 1 100%;
    margin-bottom: 12px;
  }
}
@media (min-width: 576px) {
  .room-element .room-data .room-cancellation-policy-cnt,
  .meal-option-row .room-cancellation-policy-cnt {
    margin-right: 12px;
  }
}
@media (min-width: 1399px) {
  .room-element .room-data .room-cancellation-policy-cnt,
  .meal-option-row .room-cancellation-policy-cnt {
    margin-right: 40px;
  }
}
.room-element .room-data .room-price-cnt,
.meal-option-row .room-price-cnt {
  display: flex;
  flex-direction: column;
  min-width: 130px;
}
@media (max-width: 991px) {
  .room-element .room-data .room-price-cnt,
  .meal-option-row .room-price-cnt {
    min-width: unset;
    flex-direction: row;
    gap: 2px;
  }
  .room-element .room-data .room-price-cnt .price-label,
  .meal-option-row .room-price-cnt .price-label {
    font-size: 13px;
    line-height: 16px;
    font-weight: 400;
  }
  .room-element .room-data .room-price-cnt .room-price,
  .meal-option-row .room-price-cnt .room-price {
    flex: 1 1 0;
    justify-content: center;
  }
}

.room-element .room-data .room-price,
.meal-option-row .room-price {
  display: flex;
  align-items: center;
  flex: 1 1 100%;
  justify-content: flex-end;
  color: #0d2440;
  font: normal normal 700 22px/22px var(--bs-font-sans-serif);
}

@media (min-width: 992px) {
  .room-element .room-data .room-select-btn-cnt,
  .meal-option-row .room-select-btn-cnt {
    margin-left: 12px;
  }
}
.room-element .room-data .room-select-btn-cnt button,
.meal-option-row .room-select-btn-cnt button {
  background-color: #D5D5D5;
  height: 24px;
  width: 62px;
  font-size: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.room-element .room-data .room-select-btn-cnt button.btn-warning,
.meal-option-row .room-select-btn-cnt button.btn-warning {
  background-color: #ffc107;
}

.extra {
  background-color: #fff;
  margin-bottom: 15px;
}

.extra .extra-title {
  color: #000;
  text-transform: uppercase;
  background-color: #ebebeb;
  padding: 13px 22px;
  font: normal normal normal 15px/18px var(--bs-font-sans-serif);
}
.extra .extra-title small {
  text-transform: none;
}

.extra .extra-list {
  margin-bottom: 15px;
}

.extra .extra-list .extra-element {
  display: flex;
  align-items: center;
  width: 100%;
  gap: 6px;
}

.extra .extra-list .extra-element .form-switch {
  font-size: 20px;
}

.extra .extra-list .extra-element .extra-content {
  display: flex;
  align-items: center;
  width: 100%;
  gap: 6px;
}

.extra .extra-list .extra-element .extra-content .extra-text {
  font-size: 16px;
  color: #0d2440;
  display: flex;
  flex: 1 0 auto;
  flex-direction: column;
}

.extra .extra-list .extra-element .extra-content .extra-text .extra-link {
  text-decoration: underline;
  display: block;
  color: #0d2440;
}

.extra .extra-list .extra-element .extra-content .extra-line {
  flex: 1 1 100%;
  /* border-bottom: 1px dashed #707070; */
}

.extra .extra-list .extra-element .extra-content .extra-price {
  font-size: 20px;
  font-weight: bold;
  color: #0d2440;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  /* flex: 1 0 77px; */
}

.ts-group {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
}

.btn-group > .btn-room-selection.active {
  background-color: #0d2440;
  color: #fff;
  box-shadow: 0 0 0 rgba(0, 0, 0, 0.29);
}

.btn-group > .btn-room-selection {
  color: #0d2440;
  font-size: 18px;
  line-height: 20px;
  font-weight: bold;
  border-radius: 30px !important;
  background-color: #fff;
  padding: 11px 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: none;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.29);
  transition: all, 0.25s;
  min-width: 160px;
}

.form-check .form-check-input, .form-check.form-switch .form-check-input {
  background-color: #e6e6e6;
}

.form-check .form-check-input:focus, .form-check.form-switch .form-check-input:focus {
  outline: none;
  box-shadow: none;
}

.form-check .form-check-input:checked, .form-check.form-switch .form-check-input:checked {
  background-color: #0d2440;
}

/* Recap Panel */
.recap-panel {
  width: 100%;
  margin-top: 10px;
}

.recap-panel .rp-header {
  font-size: 20px;
  font-weight: 400;
  border-bottom: 1px solid var(--bs-primary);
  color: #000;
  line-height: 22px;
  margin-bottom: 20px;
  padding-bottom: 8px;
}

.recap-panel .rp-body .temp-cart-service-root-element {
  margin-top: 15px;
}

.recap-panel .rp-body .rp-nights {
  display: flex;
  align-items: center;
  font-size: 18px;
  font-style: italic;
  font-weight: 500;
  color: #707070;
  margin-bottom: 20px;
  gap: 6px;
}

.recap-panel .rp-body .rp-nights .rp-night-type {
  display: flex;
  flex: 1 0 auto;
}

.recap-panel .rp-body .rp-nights .rp-night-line {
  flex: 1 1 100%;
  border-bottom: 1px solid #707070;
}

.recap-panel .rp-body .rp-nights .rp-night-count {
  flex: 1 1 100%;
}

.recap-panel .rp-body .rp-hotel {
  font-size: 16px;
  line-height: 19px;
  font-weight: 700;
  color: var(--bs-primary);
  margin-bottom: 8px;
}

.recap-panel .rp-body .rp-hotel .rating {
  font-size: 14px;
}

.recap-panel .rp-body .rp-location {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 14px;
  font-weight: 300;
  font-style: italic;
  margin-bottom: 10px;
  color: #0e2f54;
}

.recap-panel .rp-body .rp-info {
  display: flex;
  gap: 2px;
  flex-direction: column;
}

.recap-panel .rp-body .rp-info .rp-info-element {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 400;
  line-height: 15px;
}

.recap-panel .rp-body .rp-separator {
  width: 100%;
  height: 1px;
  background-color: #0e2f54;
  margin: 30px auto;
}

.recap-panel .rp-body .rp-price {
  border-top: 11px solid #ebebeb;
  color: #000;
  font-size: 25px;
  font-weight: 700;
  line-height: 30px;
  margin-top: 15px;
  padding-top: 15px;
}

/* .recap-panel .rp-body .rp-price .price-title {
	color: #707070;
	font-size: 21px;
	text-transform: uppercase;
	font-weight: 500;
	text-align: center;
}
.recap-panel .rp-body .rp-price .price-number {
	font-size: 50px;
	color: #0e2f54;
	font-weight: 500;
	text-align: center;
	vertical-align: text-bottom;
} */
.recap-panel .rp-body .rp-price .price-number small {
  font-size: 20px;
}

.recap-panel .rp-body .rp-price .price-info {
  color: #707070;
  font-size: 15px;
  text-transform: uppercase;
  font-weight: 500;
  text-align: center;
}

.recap-panel .rp-body .rp-price .price-info span {
  color: #0e2f54;
  font-size: 21px;
}

.recap-panel .rp-body .rp-price .price-payment {
  color: #707070;
  font-size: 16px;
  text-transform: uppercase;
  font-weight: 500;
  text-align: center;
}

.recap-panel .rp-body .rp-price .price-payment span {
  color: #0e2f54;
}

.recap-panel .rp-body .rp-price .price-alert {
  text-align: center;
  font-size: 20px;
  cursor: pointer;
  color: #0e2f54;
  margin-top: 10px;
}

.recap-panel .rp-body .rp-actions {
  margin-top: 20px;
}

.recap-panel .rp-body .rp-actions .btn {
  width: 100%;
  margin-bottom: 20px;
  padding: 18px;
  font-size: 16px;
  font-weight: 600;
}

.recap-panel .rp-body .rp-actions .secondary-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

@media (max-width: 991px) {
  .ts-group {
    flex-direction: column;
  }
  .ts-group > .btn-room-selection {
    width: 100%;
    min-width: auto;
  }
  .type-selection {
    display: block;
  }
  .room-element {
    flex-direction: column;
  }
  .room-element .room-img {
    max-width: none;
  }
  .room-element .room-data {
    padding: 5px;
  }
  .room-element .room-data .room-actions {
    align-items: flex-start;
    flex-direction: column;
    gap: 12px;
    margin-top: 20px;
  }
  .extra .extra-list .extra-element {
    align-items: flex-start;
  }
  .extra .extra-list .extra-element .extra-content {
    display: block;
  }
  .extra .extra-list .extra-element .extra-content .extra-line {
    margin-top: 1px;
  }
  .extra .extra-list .extra-element .extra-content .extra-text .extra-link {
    margin-bottom: 4px;
  }
}
.extra .extra-title:empty {
  padding: 0;
}

.hotel-element {
  padding: 15px 5px;
  border-bottom: 1px solid #ddd;
}

.hotel-element .hotel-data {
  display: flex;
  align-items: start;
  justify-content: start;
}

@media (max-width: 1199px) {
  .hotel-element .hotel-data {
    flex-direction: column;
    align-items: stretch;
    justify-content: stretch;
  }
}
.hotel-element .hotel-data .hotel-info {
  flex: 1;
}

.hotel-element .hotel-data .hotel-info .hotel-name {
  color: #1e2b46;
  font: normal normal 600 20px/24px var(--bs-font-sans-serif);
  letter-spacing: 0;
  margin-bottom: 14px;
}

.hotel-element .hotel-data .hotel-info .hotel-name i {
  font-size: 15px;
  line-height: 18px;
}

.hotel-element .hotel-data .hotel-info .hotel-info-details {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
}

.hotel-element .hotel-data .hotel-info .hotel-info-details .hotel-carousel {
  height: 145px !important;
  width: 200px !important;
  position: relative;
}

.hotel-element .hotel-data .hotel-info .hotel-info-details .hotel-carousel .links-box {
  position: absolute;
  bottom: 0;
  left: 0;
  display: flex;
  justify-content: end;
}

.hotel-element .hotel-data .hotel-info .hotel-info-details .hotel-carousel .links-box button {
  background-color: rgba(0, 0, 0, 0.7);
  color: var(--bs-white);
  display: inline-block;
  font-size: 18px;
  line-height: 18px;
  padding: 8px 10px;
  text-align: center;
  text-decoration: none;
  width: 39px;
  border: 0;
}

.hotel-element .hotel-data .hotel-info .hotel-info-details .hotel-carousel .links-box button.active {
  background-color: #e3860d;
}

.hotel-element .hotel-data .hotel-info .hotel-info-details .hotel-carousel img {
  border-top-left-radius: 10px;
  border-top-right-radius: 10px;
}

.hotel-element .hotel-data .hotel-info .hotel-info-details .hotel-description {
  width: calc(100% - 200px);
  font: normal normal normal 15px/18px var(--bs-font-sans-serif);
  padding: 12px 35px 12px 24px;
}

@media (max-width: 1199px) {
  .hotel-element .hotel-data .hotel-info .hotel-info-details .hotel-description {
    width: 100%;
    padding: 12px;
  }
}
.hotel-element .hotel-data .hotel-price-cnt {
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
}

.hotel-element .hotel-data .hotel-price-cnt .hotel-price {
  color: #000;
  font: normal normal 700 22px/27px var(--bs-font-sans-serif);
}

.hotel-element .hotel-full-description {
  padding: 12px 35px;
  position: relative;
  border-top: 1px solid var(--bs-primary);
  margin-top: 1.5rem;
  width: 80%;
  margin-left: 3%;
  margin-right: auto;
}

.hotel-element .hotel-full-description .hotel-full-descr-title,
.hotel-element .hotel-gallery .hotel-gallery-title {
  background-color: var(--bs-white);
  position: absolute;
  top: -9px;
  color: var(--bs-primary);
  font: normal normal 600 12px/15px var(--bs-font-sans-serif);
  left: 35px;
  padding: 0 0.5rem;
}

.hotel-element .hotel-gallery {
  border-top: 1px solid var(--bs-primary);
  padding-top: 16px;
  position: relative;
  margin-top: 1.5rem;
  width: 80%;
  margin-left: 3%;
  margin-right: auto;
}

.mobile-cart-summary-cnt {
  z-index: 999999 !important;
}

.mobile-cart-summary .label,
.mobile-cart-summary .price {
  color: #000;
  font-size: 25px;
  font-weight: 700;
  line-height: 30px;
}

.mobile-cart-summary .mobile-cart-toggler {
  border: 0;
  background: transparent;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: var(--bs-primary);
}

.mobile-cart-summary .mobile-cart-toggler i {
  font-size: 30px;
  font-weight: 300;
  margin: 0;
}

.mobile-cart-summary .mobile-cart-toggler span {
  margin-top: -6px;
}

@media (max-width: 990px) {
  button.iubenda-tp-btn[data-tp-float]:not([data-tp-anchored]).iubenda-cs-preferences-link {
    margin-bottom: 90px !important;
  }
}
#scroll-on-search {
  scroll-margin-top: 70px;
}

.gallery-container {
  margin-bottom: 60px;
}

.gallery-img {
  border-radius: 20px;
  width: 100%;
  min-height: 200px;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  margin-bottom: 15px;
}

.gallery-img.full {
  min-height: 415px;
}

@media (max-width: 991px) {
  .gallery-img, .gallery-img.full {
    min-height: auto;
    height: 230px;
  }
}
.dhn-content {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 15px;
}

.dhn-left {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.dhn-left .det-title {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 28px;
  line-height: 32px;
  font-weight: bold;
  color: #0D2440;
  text-transform: uppercase;
}

.dhn-left .location {
  color: #0D2440;
  display: flex;
  align-items: center;
  gap: 8px;
}

.go_to_map {
  margin-left: 12px;
  color: #0D2440;
}

.dhn-right {
  display: flex;
  align-items: center;
  gap: 24px;
  font-size: 36px;
  color: #0D2440;
}

.dhn-right img {
  height: 36px;
}

.rating {
  display: flex;
  align-items: center;
  gap: 2px;
  font-size: 18px;
  color: #DA9426;
}

.show-more .btn {
  width: 25%;
}

@media (max-width: 991px) {
  .dhn-content {
    flex-direction: column;
    align-items: flex-start;
  }
  .go_to_map {
    display: block;
    margin-left: 17px;
    margin-top: 10px;
  }
  .dhn-right {
    justify-content: flex-end;
    width: 100%;
  }
  .dhn-left .det-title {
    flex-direction: column;
    align-items: flex-start;
  }
  .show-more .btn {
    width: 100%;
  }
}
.custom-icon {
  background: #bababa 0 0 no-repeat padding-box;
  border-radius: 14px;
  display: inline-block;
  height: 14px;
  margin-right: 8px;
  opacity: 1;
  position: relative;
  vertical-align: middle;
  width: 14px;
}

.custom-icon.active {
  background-color: #2A5469;
}

.custom-icon .inner {
  background: #fff 0 0 no-repeat padding-box;
  border-radius: 14px;
  display: block;
  height: 6px;
  left: 50%;
  opacity: 1;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 6px;
}

.cursor-pointer {
  cursor: pointer;
}

.custom-icon {
  background: #bababa 0 0 no-repeat padding-box;
  border-radius: 14px;
  display: inline-block;
  height: 14px;
  margin-right: 8px;
  opacity: 1;
  position: relative;
  vertical-align: middle;
  width: 14px;
}

.custom-icon.active {
  background-color: #2A5469;
}

.custom-icon .inner {
  background: #fff 0 0 no-repeat padding-box;
  border-radius: 14px;
  display: block;
  height: 6px;
  left: 50%;
  opacity: 1;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 6px;
}

.change-room-btn {
  cursor: pointer;
  color: #384145;
  font-size: 17px;
  line-height: 25px;
  font-weight: 500;
}

#history-cnt .history-row {
  margin-bottom: 12px;
  padding: 8px 0 16px;
  border-bottom: 1px solid #2A5469;
  /* &:last-child {
  	margin-bottom: 0;
  } */
}
#history-cnt .history-row:first-child {
  margin-top: 48px;
}
@media (max-width: 991px) {
  #history-cnt .history-row .history-other-type-row {
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
  }
  #history-cnt .history-row .history-other-type-row .history-service-price-cnt {
    flex-direction: row;
  }
  #history-cnt .history-row .history-other-type-row .other-container-info {
    flex: 1 1 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 2px;
  }
  #history-cnt .history-row .history-other-type-row .other-container-info .history-service-price-cnt {
    flex-direction: row !important;
    align-items: center;
    justify-content: end;
    column-gap: 4px;
    flex-wrap: wrap;
  }
  #history-cnt .history-row .history-other-type-row .other-container-info .history-service-price-cnt small {
    flex: 1 1 100%;
    text-align: right;
  }
}
#history-cnt .history-row .history-idx {
  width: 20px;
  height: 20px;
  background-color: #2A5469;
  color: #fff;
  font-size: 12px;
  line-height: 19px;
  font-weight: 800;
  border-radius: 50%;
  margin-right: 8px;
  display: flex;
  justify-content: center;
  align-items: center;
}
#history-cnt .history-row .history-title {
  color: #2A5469;
  font-size: 22px;
  line-height: 28px;
  font-weight: bold;
}
#history-cnt .history-row .history-service-price-cnt .history-service-price {
  font-size: 22px;
  font-weight: 700;
}
#history-cnt .history-row .room-select-btn-cnt button {
  background-color: #D5D5D5;
  height: 24px;
  width: 62px;
  font-size: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
}
#history-cnt .history-row .room-select-btn-cnt button.btn-warning {
  background-color: #ffc107;
}
#history-cnt .history-row .carousel-item img {
  height: 160px;
  object-fit: cover;
  border-radius: 8px;
  width: 100%;
}
#history-cnt .history-row .hotel-title span {
  font-size: 20px;
  line-height: 24px;
  font-weight: bold;
}
#history-cnt .history-row .room-availability .label-availability {
  display: inline-block;
  font: normal normal 500 10px/12px var(--bs-font-sans-serif);
  padding: 4px 8px;
  margin-right: 12px;
}
#history-cnt .history-row .room-availability .label-availability.label-availability-ok {
  background-color: transparent;
  color: var(--bs-success);
  font-weight: 700;
}
#history-cnt .history-row .room-availability .label-availability.label-availability-rq, #history-cnt .history-row .room-availability .label-availability.label-availability-general {
  background-color: transparent;
  color: var(--bs-warning);
  font-weight: 700;
}
#history-cnt .history-row .flight-row > .col-auto {
  width: 125px;
}
#history-cnt .history-row .flight-row > .col-auto.flight-icon {
  width: 40px;
}
#history-cnt .history-row .flight-row > .col-auto.flight-operative {
  width: 90px;
}
#history-cnt .history-row .flight-row > .col-auto.flight-long-text {
  width: 172px;
}
#history-cnt .history-row .flight-row .label,
#history-cnt .history-row .flight-row .value {
  font-size: 13px;
  line-height: 15px;
}
#history-cnt .history-row .flight-row .label {
  font-weight: bold;
}
#history-cnt .history-row .flight-row .flight-duration-separator {
  position: relative;
  width: 90px;
  margin: 6px auto 4px;
  border-top: 2px solid #FEB500;
}
#history-cnt .history-row .flight-row .flight-duration-separator::before,
#history-cnt .history-row .flight-row .flight-duration-separator::after {
  content: "";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 12px;
  height: 12px;
  background-color: #FEB500;
  border-radius: 50%;
}
#history-cnt .history-row .flight-row .flight-duration-separator::before {
  left: 0;
}
#history-cnt .history-row .flight-row .flight-duration-separator::after {
  right: 0;
}
#history-cnt .history-row .extra-step-cnt {
  padding-left: 25px;
  padding-right: 25px;
}
#history-cnt .history-row .extra-content {
  display: flex;
  align-items: center;
  width: 100%;
  gap: 6px;
}
@media (max-width: 768px) {
  #history-cnt .history-row .extra-content {
    flex-direction: column;
    align-items: end;
  }
}
#history-cnt .history-row .extra-title {
  color: #000;
  text-transform: uppercase;
  background-color: #ebebeb;
  padding: 13px 22px;
  font: normal normal normal 15px/18px var(--bs-font-sans-serif);
}
#history-cnt .history-row .extra-title small {
  text-transform: none;
}
#history-cnt .history-row .extra-content .extra-text {
  font-size: 16px;
  color: #0d2440;
  display: flex;
  flex: 1 0 auto;
  flex-direction: column;
}
#history-cnt .history-row .extra-content .extra-text .extra-link {
  text-decoration: underline;
  display: block;
  color: #0d2440;
}
#history-cnt .history-row .extra-content .extra-line {
  flex: 1 1 100%;
  /* border-bottom: 1px dashed #707070; */
}
#history-cnt .history-row .extra-content .extra-price {
  font-size: 20px;
  font-weight: bold;
  color: #0d2440;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  /* flex: 1 0 77px; */
}

.history-other-type-row-col-cnt .room-element, .room-config .room-element {
  flex-wrap: wrap;
  border-bottom: 1px solid #C9C9C9;
  padding-bottom: 18px;
  margin-bottom: 24px;
}
.history-other-type-row-col-cnt .room-element:last-child, .room-config .room-element:last-child {
  border-bottom: none;
}
.history-other-type-row-col-cnt .room-element .room-details, .room-config .room-element .room-details {
  padding-left: 18px;
  width: 100%;
  display: flex;
  justify-content: start;
  align-items: start;
}
.history-other-type-row-col-cnt .room-element .room-details .room-gallery, .room-config .room-element .room-details .room-gallery {
  position: relative;
}
.history-other-type-row-col-cnt .room-element .room-details .room-gallery .subservice-swiper, .room-config .room-element .room-details .room-gallery .subservice-swiper {
  width: 227px;
}
.history-other-type-row-col-cnt .room-element .room-details .room-gallery .subservice-swiper .gallery-element, .room-config .room-element .room-details .room-gallery .subservice-swiper .gallery-element {
  height: 165px;
  width: 227px;
}
.history-other-type-row-col-cnt .room-element .room-details .room-gallery .subservice-swiper .gallery-element img, .room-config .room-element .room-details .room-gallery .subservice-swiper .gallery-element img {
  height: 165px;
  width: 227px;
  object-fit: cover;
}
.history-other-type-row-col-cnt .room-element .room-details .room-gallery .subservice-swiper .subservice-pagination, .room-config .room-element .room-details .room-gallery .subservice-swiper .subservice-pagination {
  transform: translateX(20%);
  margin-top: 14px;
}
.history-other-type-row-col-cnt .room-element .room-details .room-gallery .gallery-lightbox-btn, .room-config .room-element .room-details .room-gallery .gallery-lightbox-btn {
  position: absolute;
  bottom: 0.5rem;
  right: 0.5rem;
  background: rgba(0, 0, 0, 0.55);
  border: none;
  border-radius: 6px;
  color: #fff;
  padding: 0.3rem 0.35rem;
  cursor: pointer;
  line-height: 0;
  transition: background 0.2s ease;
  z-index: 10;
}
.history-other-type-row-col-cnt .room-element .room-details .room-gallery .gallery-lightbox-btn:hover, .room-config .room-element .room-details .room-gallery .gallery-lightbox-btn:hover {
  background: rgba(0, 0, 0, 0.8);
}
.history-other-type-row-col-cnt .room-element .room-details .room-gallery .gallery-lightbox-btn svg, .room-config .room-element .room-details .room-gallery .gallery-lightbox-btn svg {
  width: 16px;
  height: 16px;
}
.history-other-type-row-col-cnt .room-element .room-details .room-subinfo, .room-config .room-element .room-details .room-subinfo {
  padding-left: 13px;
}
.history-other-type-row-col-cnt .room-element .room-details .room-subinfo .description, .history-other-type-row-col-cnt .room-element .room-details .room-subinfo .description *, .room-config .room-element .room-details .room-subinfo .description, .room-config .room-element .room-details .room-subinfo .description * {
  color: #384145;
  font-size: 17px;
  line-height: 25px;
  font-weight: 500;
  font-family: "Jost", sans-serif;
}
.history-other-type-row-col-cnt .room-element .room-details .room-subinfo .extra-info, .room-config .room-element .room-details .room-subinfo .extra-info {
  display: flex;
  flex-wrap: wrap;
  gap: 26px;
  align-items: center;
  justify-content: start;
  margin-top: 16px;
  margin-bottom: 20px;
}
.history-other-type-row-col-cnt .room-element .room-details .room-subinfo .extra-info .info, .room-config .room-element .room-details .room-subinfo .extra-info .info {
  display: flex;
  align-items: center;
  gap: 8px;
}
.history-other-type-row-col-cnt .room-element .room-details .room-subinfo .extra-info .info i, .room-config .room-element .room-details .room-subinfo .extra-info .info i {
  color: #384145;
  font-size: 22px;
}
.history-other-type-row-col-cnt .room-element .room-details .room-subinfo .extra-info .info span, .room-config .room-element .room-details .room-subinfo .extra-info .info span {
  color: #13243E;
  font-size: 14px;
  line-height: 21px;
  font-weight: 300;
}
.history-other-type-row-col-cnt .room-element .room-details .room-subinfo .amenities, .room-config .room-element .room-details .room-subinfo .amenities {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 12px;
}

.final-cart {
  color: #10556B;
  position: sticky;
  top: 90px;
}
.final-cart .cart-title {
  font-size: 20px;
  line-height: 30px;
  font-weight: bold;
  border-bottom: 1px solid #707070;
  padding-bottom: 8px;
  margin-bottom: 16px;
}
.final-cart .cart-service {
  display: flex;
  align-items: start;
  gap: 12px;
  margin-bottom: 35px;
}
.final-cart .cart-service i {
  font-size: 13px;
  color: #000;
  padding-top: 8px;
}
.final-cart .cart-service i.fa-star {
  color: #DA9426;
  font-size: 10px;
  padding-top: 0;
}
.final-cart .cart-service .service-info {
  flex: 1;
}
.final-cart .cart-service .service-info .service-title {
  font-size: 21px;
  line-height: 31px;
  font-weight: 600;
}
.final-cart .cart-service .service-info .service-subtitle {
  font-size: 13px;
  line-height: 20px;
  font-weight: 300;
  font-style: italic;
}
.final-cart .cart-service .service-info .flight-segment {
  max-width: 300px;
}
.final-cart .cart-service .service-info .flight-segment .segment-title {
  font-size: 13px;
  line-height: 20px;
  font-weight: 300;
  font-style: italic;
}
.final-cart .cart-service .service-info .flight-segment .segment-time {
  font-size: 20px;
  line-height: 30px;
  font-weight: 600;
}
.final-cart .cart-service .service-info .flight-segment .segment-code {
  font-size: 12px;
  line-height: 18px;
}
.final-cart .cart-service .service-info .flight-segment .segment-time-diff {
  font-size: 10px;
  line-height: 12px;
  text-align: center;
}
.final-cart .cart-service .service-info .flight-segment .segment-time-separator {
  position: relative;
  width: 90%;
  margin: 6px auto 4px;
  border-top: 2px solid #FEB500;
}
.final-cart .cart-service .service-info .flight-segment .segment-time-separator::before, .final-cart .cart-service .service-info .flight-segment .segment-time-separator::after {
  content: "";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 12px;
  height: 12px;
  background-color: #FEB500;
  border-radius: 50%;
}
.final-cart .cart-service .service-info .flight-segment .segment-time-separator::before {
  left: 0;
}
.final-cart .cart-service .service-info .flight-segment .segment-time-separator::after {
  right: 0;
}
.final-cart .cart-service .service-info .cart-row .row-name {
  font-size: 12px;
  line-height: 18px;
  font-weight: 600;
}
.final-cart .price-cnt {
  width: 100%;
  border: 1px solid #E8E8E8;
  border-radius: 10px;
  background-color: #F5F5F5;
  padding: 6px 12px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.final-cart .price-cnt .price-label {
  font-size: 17px;
  line-height: 26px;
}
.final-cart .price-cnt .price-total {
  font-size: 45px;
  line-height: 46px;
  font-weight: 600;
}
.final-cart .cancellation-policies-btn {
  margin-top: 8px;
  background-color: #EEE2EC;
  border-radius: 0px;
  padding: 12px;
}
.final-cart .cancellation-policies-btn:hover {
  background-color: #EEE2EC;
}
.final-cart .cancellation-policies-btn i {
  font-size: 17px;
  color: #FE6464;
}
.final-cart .cancellation-policies-btn span {
  font-size: 13px;
  line-height: 20px;
  font-weight: 400;
  color: #000;
}
.final-cart .cart-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 15px;
  margin-top: 20px;
}
.final-cart .cart-actions .btn {
  flex: 1;
  font-size: 9px;
  line-height: 13px;
  border: 1px solid #E8E8E8;
  border-radius: 10px;
  background-color: #F5F5F5;
}

.extra-details {
  padding-left: 2.5em;
  width: 100%;
  display: flex;
  justify-content: start;
  align-items: start;
  margin-bottom: 16px;
}
.extra-details .room-gallery {
  position: relative;
}
.extra-details .room-gallery .subservice-swiper {
  width: 227px;
}
.extra-details .room-gallery .subservice-swiper .gallery-element {
  height: 165px;
  width: 227px;
}
.extra-details .room-gallery .subservice-swiper .gallery-element img {
  height: 165px;
  width: 227px;
  object-fit: cover;
}
.extra-details .room-gallery .subservice-swiper .subservice-pagination {
  transform: translateX(40%);
  margin-top: 14px;
}
.extra-details .room-gallery .gallery-lightbox-btn {
  position: absolute;
  bottom: 0.5rem;
  right: 0.5rem;
  background: rgba(0, 0, 0, 0.55);
  border: none;
  border-radius: 6px;
  color: #fff;
  padding: 0.3rem 0.35rem;
  cursor: pointer;
  line-height: 0;
  transition: background 0.2s ease;
  z-index: 10;
}
.extra-details .room-gallery .gallery-lightbox-btn:hover {
  background: rgba(0, 0, 0, 0.8);
}
.extra-details .room-gallery .gallery-lightbox-btn svg {
  width: 16px;
  height: 16px;
}
.extra-details .room-subinfo {
  padding-left: 13px;
}
.extra-details .room-subinfo .description, .extra-details .room-subinfo .description * {
  color: #384145 !important;
  font-size: 17px !important;
  line-height: 25px !important;
  font-weight: 500 !important;
  font-family: "Jost", sans-serif !important;
}
.extra-details .room-subinfo .extra-info {
  display: flex;
  flex-wrap: wrap;
  gap: 26px;
  align-items: center;
  justify-content: start;
  margin-top: 16px;
  margin-bottom: 20px;
}
.extra-details .room-subinfo .extra-info .info {
  display: flex;
  align-items: center;
  gap: 8px;
}
.extra-details .room-subinfo .extra-info .info i {
  color: #384145;
  font-size: 22px;
}
.extra-details .room-subinfo .extra-info .info span {
  color: #13243E;
  font-size: 14px;
  line-height: 21px;
  font-weight: 300;
}
.extra-details .room-subinfo .amenities {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 12px;
}

.hotel-element .hotel-carousel .gallery-lightbox-btn {
  position: absolute;
  bottom: 0.5rem;
  right: 0.5rem;
  background: rgba(0, 0, 0, 0.55);
  border: none;
  border-radius: 6px;
  color: #fff;
  padding: 0.3rem 0.35rem;
  cursor: pointer;
  line-height: 0;
  transition: background 0.2s ease;
  z-index: 10;
}
.hotel-element .hotel-carousel .gallery-lightbox-btn:hover {
  background: rgba(0, 0, 0, 0.8);
}
.hotel-element .hotel-carousel .gallery-lightbox-btn svg {
  width: 16px;
  height: 16px;
}

.hotel-element .hotel-data .room-availability .label-availability {
  display: inline-block;
  font-size: 10px;
  line-height: 12px;
  font-weight: 500;
  padding: 4px 8px;
  margin-right: 12px;
}
.hotel-element .hotel-data .room-availability .label-availability-ok {
  background-color: var(--bs-success);
  color: var(--bs-white);
}
.hotel-element .hotel-data .room-availability .label-availability-rq,
.hotel-element .hotel-data .room-availability .label-availability-general {
  background-color: var(--bs-warning);
  color: var(--bs-black);
}

.hotel-element .hotel-data .room-select-btn-cnt {
  margin-left: 12px;
}
.hotel-element .hotel-data .room-select-btn-cnt button {
  background-color: #D5D5D5;
  height: 24px;
  width: 62px;
  font-size: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
}