:root {
    --white: #fff;
    --acsent: #fb8d69;
    --dark-txt: #1c4a66;
    --dark-blue: #0e2838;
    --bg: #061b28;
    --black: #252525;
    --font-family: "Aleo", sans-serif;
    --second-family: "Montserrat", sans-serif;
    --third-family: "Noto Sans", sans-serif;
}

.contact_wrapper {
    display: flex;
    gap: 20px;
    margin: 20px auto;
}

.contact_link {
    display: flex;
    justify-content: center;
    align-items: center;
    flex: 1 1 48%;
    border-radius: 14px;
    background: var(--acsent);
    transition: background 0.3s ease;
    padding: 20px 0;
}

.contact_link img {
    filter: brightness(0) saturate(100%) invert(18%) sepia(13%) saturate(2546%) hue-rotate(164deg) brightness(93%) contrast(93%);
}

.contact_link:hover {
    background: linear-gradient(90deg, #ffc6b3 0%, #fb8d69 50%, #ffc6b3 100%);
}

.booking-gallery {
    margin-top: 50px;
}
.slider{
    width: auto!important;
}
.booking-content-container{
    display: block;
}
/*Booking form*/
.booking-form {
    display: flex;
    gap: 20px;
    width: 100%;
    max-width: 100%;
    margin: 0 auto;
}

.booking-form input {
    flex: 0 0;
}

.left,
.right {
    flex: 1;
}

.field {
    margin-bottom: 10px;
}

.tabs {
    display: flex;
    justify-content: center;
    gap: 20px;
    margin-bottom: 20px;
}

.tab-btn {
    padding: 0 20px;
    background: rgba(28, 74, 102, 0.44);
    cursor: pointer;
    border: none;
    height: 50px;
    border-radius: 14px;
    flex: 0 0 133px;
    width: 133px;
    font-family: var(--font-family);
    font-style: normal;
    font-weight: 700;
    font-size: 18px;
    line-height: 22px;
    color: var(--white);
}

.tab-btn.active {
    background: var(--acsent);
    color: var(--black);
}

.tab-body {
    display: none;
}

.tab-body.active {
    display: flex;
}

.address-field.hidden {
    display: none;
}

.booking-form {
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    gap: 20px 30px;
}

.booking-form .form-input-group {
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    gap: 20px;
    width: 100%;
}

.booking-form input,
.booking-form select,
.booking-form textarea {
    width: 100%;
    height: 50px;
    border-radius: 14px;
    background: rgba(28, 74, 102, 44%);
    border: none;
    box-shadow: none;
    padding: 10px 20px;
    font-family: var(--font-family);
    font-style: normal;
    font-weight: 500;
    font-size: 16px;
    line-height: 19px;
    color: rgba(255, 255, 255, 1);
    margin-bottom: 0;
}
.booking-form textarea{
    padding: 15px;
    min-height: 50px;
    width: 100%;
    max-width: 570px;
}
.booking-form select option{
    background: rgba(28, 74, 102, 44%);
}
.booking-form input::placeholder,
.booking-form select::placeholder,
.booking-form textarea::placeholder{
    color: rgba(255, 255, 255, 34%);

}
.booking-form input:focus-visible,
.booking-form select:focus-visible,
.booking-form textarea:focus-visible{
    outline: none;
    box-shadow: none;
    border: none;
}
.booking-form input[type="date"],
.booking-form input[type="time"] {
  position: relative;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
}

/* Chrome/Safari — прибираємо стандартну іконку */
.booking-form input[type="date"]::-webkit-calendar-picker-indicator,
.booking-form input[type="time"]::-webkit-calendar-picker-indicator {
  opacity: 0;
  display: none;
  -webkit-appearance: none;
}
.booking-form .field {
  position: relative;
  display: inline-block;
}

.booking-form .field::after {
  content: '';
  position: absolute;
  top: 50%;
  right: 20px;
  width: 24px;
  height: 24px;
  transform: translateY(-50%);
  pointer-events: none;
  background-size: contain;
  background-repeat: no-repeat;
}

.booking-form .field.date::after {
  background-image: url('../../images/front/calendar.svg');
}

.booking-form .field.time::after {
  background-image: url('../../images/front/clock.svg');
}

.custom-select,.prices-dropdown{
    position: relative;
}
.custom-select::after {
  content: "";
  display: block;
  background: url('../../images/front/chevron-down.svg') no-repeat;
  position: absolute;
  right: 15px;
  top: 50%;
  transform: translateY(-50%);
  width: 24px;
  height: 24px;
  pointer-events: none;
  transition: transform 0.3s ease;
}
.prices-dropdown .dropdown-selected::after{
  background: url('../../images/front/chevron-down.svg') no-repeat!important;
}
.prices-dropdown.open .dropdown-selected::after,
.custom-dropdown.open .dropdown-selected::after{
    transform: translateY(-50%) rotate(-180deg);
}
.custom-select select:focus + .custom-select::after,
.custom-select.open::after {
  transform: translateY(-50%) rotate(-180deg);
}
.booking-form select{
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background-image: none;
}
.booking-form .field {
    flex: 0 0 calc(50% - 10px);
    width: 100%;
    margin-bottom: 0;
}

.booking-form .field.address-field,
.booking-form .field.msg-field {
    flex: 0 0 100%;
    width: 100%;
    max-width: 100%;
}
.booking-form .field.address-field.hidden{
    display: none;
}
.booking-form input:active,
.booking-form input:focus {
    background: rgba(28, 74, 102, 94%);
}

.booking-form__item {
    background: var(--dark-blue);
    border-radius: 30px;
    padding: 30px;
    flex: 0 0 calc(50% - 15px);
    min-height: 320px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.booking-form__item-title {
    font-family: var(--font-family);
    font-style: normal;
    font-weight: 500;
    font-size: 28px;
    line-height: 34px;
    text-align: center;
    color: #FFFFFF;
    margin-bottom: 30px;
}
.custom-dropdown {
  position: relative;
  cursor: pointer;
  user-select: none;
  width: 100%;
}

.dropdown-selected {
    width: 100%;
    height: 50px;
    border-radius: 14px;
    background: rgba(28, 74, 102, 44%);
    border: none;
    box-shadow: none;
    padding: 10px 20px;
    font-family: var(--font-family);
    font-style: normal;
    font-weight: 500;
    font-size: 16px;
    line-height: 19px;
    color: rgba(255, 255, 255, 1);
    position: relative;
    display: flex;
    align-items: center;
    justify-content: flex-start;
}
.custom-dropdown.open .dropdown-selected{
    border-radius: 14px 14px 0 0;
}
.dropdown-selected::after {
  content: "";
  display: block;
  background: url('../../images/front/filter-light.svg');
  position: absolute;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
  width: 24px;
  height: 24px;
  pointer-events: none;
  transition: transform 0.3s ease;
}
.dropdown-options {
  display: none;
  position: absolute;
  width: 100%;
  background: white;
  border-top: none;
  max-height: 200px;
  overflow-y: auto;
  z-index: 10;
  margin: 0;
  left: 0;
  background: rgba(28, 74, 102,1);
  border-radius: 0 0 14px 14px;
}

.dropdown-options li {
    padding: 8px 10px 8px 20px;
    font-family: var(--font-family);
    font-style: normal;
    font-weight: 500;
    font-size: 16px;
    line-height: 19px;
    color: rgba(255, 255, 255, 1);
}
.dropdown-options .selected {
    color: red;
}
.dropdown-options li:hover {
}
.custom-dropdown.open .dropdown-options {
  display: block;
}

#submitBtn {
    flex: 0 0 100%;
    width: auto;
    max-width: max-content;
    height: 60px;
    border-radius: 14px;
    padding: 0 30px;
    background: linear-gradient(90deg, #FFC6B3 0%, #FB8D69 50%, #FFC6B3 100%);
    font-family: var(--font-family);
    font-style: normal;
    font-weight: 500;
    font-size: 20px;
    line-height: 24px;
    text-align: center;
    color: #252525;
    border: none;
    box-shadow: none;
    margin: 0 auto;
}

/*Booking text content*/
.booking-content {
    display: flex;
    flex-flow: row;
    justify-content: space-between;
    align-items: flex-start;
    gap: 30px;
    margin-bottom: 70px;
    margin-top: 70px;
}

.booking-content__title {
    flex: 0 0 410px;
    font-family: var(--font-family);
    font-style: normal;
    font-weight: 700;
    font-size: 52px;
    line-height: 62px;
    color: #0E2838;
}

.booking-content__description {
    flex: 1;
    width: 100%;
    max-width: 100%;
}
.booking-content__description p strong{
    font-family: var(--second-family);
    font-style: normal;
    font-weight: 700;
    font-size: 17px;
    line-height: 32px;
    color: var(--acsent);
}
.booking-content__description h3 {
    font-family: var(--second-family);
    font-style: normal;
    font-weight: 700;
    font-size: 28px;
    line-height: 32px;
    color: #0E2838;
    margin-top: 50px;
    margin-bottom: 20px;
}

.booking-content__description ul,
.booking-content__description ol {
    display: flex;
    flex-flow: column;
    align-items: flex-start;
    gap: 20px;
}

.booking-content__description ul {
    list-style-type: none;
    margin-left: 0;
    padding-left: 0;
}

.booking-content__description ul>li {
    position: relative;
    margin-bottom: 0;
    padding-left: 20px;

}

.booking-content__description ul>li::before {
    width: 5px;
    height: 5px;
    content: '';
    display: block;
    position: absolute;
    background: var(--acsent);
    border-radius: 50%;
    left: 0;
    top: 15px;
}

.booking-content__description p,
.booking-content__description ul>li,
.booking-content__description ol>li {
    margin-bottom: 20px;
    font-family: var(--second-family);
    font-style: normal;
    font-weight: 500;
    font-size: 17px;
    line-height: 32px;
    color: #0E2838;
}

.booking-content__description ul>li strong,
.booking-content__description ol>li strong {
    color: var(--acsent);
}

.empty{
    display: none;
}

@media (max-width: 1024px) {
}
@media (max-width: 900px) {
.booking-content{
    flex-flow: column;
    gap: 20px;
    align-items: flex-start;
    margin: 50px auto;
}
.booking-content__description *:last-child{
    margin-bottom: 0;
}
.booking-form{
    flex-flow: column;
}
.booking-form__item{
    flex: 0 0 100%;
    max-width: 100%;
}
.booking-content__title{
    flex: 0 0 auto;
}
#submitBtn{
    flex: 0 0 auto;
}
}
@media (max-width: 768px) {
    .booking-gallery{
        margin-top: 30px;
    }
    .booking-content-container,.booking-gallery{
        padding: 0!important;
    }
    .booking-content__title{
        font-size: 44px;
        line-height: 53px;
    }
    .booking-content__description h3{
        font-size: 28px;
        line-height: 32px;
    }
}
@media (max-width: 650px) {
    .booking-gallery{
        margin-top: 15px;
    }
    .slider_track{
        min-height: auto;
    }
}
@media (max-width: 560px) {
    .contact_wrapper,.booking-content{
        padding: 0 10px;
    }
    .booking-content{
        margin: 40px auto;
    }
    .booking-content__description p, .booking-content__description ul>li, .booking-content__description ol>li{
        margin-bottom: 0;
    }
        .booking-content__title{
        font-size: 32px;
        line-height: 38px;
    }
        .booking-content__description h3{
        font-size: 24px;
        line-height: 28px;
        margin-top: 20px;
    }
}
@media (max-width: 475px) {
}