.banner--title, .banner--subtitle {
    color: var(--white);
    overflow: hidden;
}

.banner-homepage {
    position: relative;
    height: 100vh;
}

.banner-homepage .banner--video {
    position: absolute;
    width: 100%;
    opacity: 0;
}

.banner-homepage .banner--video .plyr {
    height: 100vh;
}

.banner-homepage .banner--video .plyr__controls {
    visibility: hidden;
}

.banner-homepage .banner--video .plyr__video-embed iframe, .plyr__video-wrapper--fixed-ratio video {
    left: -200%;
    width: 500%;
    height: 175%;
}

.banner-homepage .banner--background {
    height: 100vh;
    transition: all ease 400ms;
}

.banner-homepage .banner--background img {
    width: 100%;
    object-fit: cover;
}

.banner-homepage--wrapper {
    position: absolute;
    left: 0;
    top: 0;
    width: 100vw;
    z-index: 98;
    transition: all ease 400ms;
}

.banner-homepage .banner--container {
    width: 100%;
    text-align: center;
    height: 100vh;
    display: flex;
    justify-content: center;
    flex-direction: column;
    opacity: 0;
    visibility: hidden;
}

.banner-homepage .banner--container.show, .banner-internal .banner--container.show, .banner-single .banner--container.show, .banner-search .banner--container.show {
    opacity: 1;
    visibility: visible;
}

.banner-homepage .banner--subtitle {
    margin-bottom: 60px;
}

.banner-homepage .banner--video-player__wrapper {
    display: inline-block;
    cursor: pointer;
}

.banner--search {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    font-family: var(--font-family-paragraph);
    visibility: hidden;
    opacity: 0;
    pointer-events: auto;
}

.banner--search.show-desktop {
    visibility: visible;
    opacity: 1;
}

.banner--search .animation-wrapper.finished {
    overflow: visible;
}

.banner--search__wrapper {
    display: flex;
    justify-content: flex-end;
    width: 100%;
    box-shadow: none;
}

.banner--search .animation-wrapper.finished .banner--search__wrapper {
    box-shadow: 0px 2px 30px rgb(0 0 0 / 10%);
    transition: all ease 500ms, overflow 0s 500ms;
}

.banner--search__wrapper.shrink-first {
    height: 82px;
    overflow: hidden;
    background: transparent;
    box-shadow: none !important;
}

.banner--search__categories {
    flex: 1;
    display: flex;
    max-height: 82px;
    background: var(--white);
    transition: all ease 500ms;
}

.banner--search__wrapper.shrink-first .banner--search__categories {
    width: 0;
    flex: 0;
}

.banner--search__category {
    flex: 0.15;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 27px 0 31px;
    margin-bottom: 0;
}

.banner--search__category:after {
    content: '';
    position: absolute;
    z-index: 65;
    top: 50%;
    right: 0;
    width: 1px;
    height: 60%;
    background: var(--black);
    transform: translateY(-50%);
    opacity: 0.1;
}

.banner--search__category:last-child:after {
    opacity: 0;
}

.banner--search__category label {
    position: relative;
    z-index: 65;
    margin-bottom: 0;
    pointer-events: none;
    transition: all ease 500ms;
}

.banner--search__wrapper.shrink-first .banner--search__category label.p {
    font-size: 0;
}

.banner--search__category label svg {
    transition: all ease 500ms;
}

.banner--search__wrapper.shrink-first .banner--search__category label svg {
    width: 2px !important;
}

.banner--search__category label svg path, .banner--search__category label svg circle, .banner--search__category label.gold-label svg rect, .banner--search__category label.gold-label svg path[stroke] {
    transition: all ease 500ms;
}

.banner--search__category label.gold-label {
    color: var(--gold);
}

.banner--search__category label.gold-label svg path {
    fill: var(--gold);
}

.banner--search__category label.gold-label svg circle, .banner--search__category label.gold-label svg rect, .banner--search__category label.gold-label svg path[stroke] {
    stroke: var(--gold);
}

.banner--search__category .select-info {
    position: absolute;
    z-index: 65;
    bottom: 10px;
    margin-bottom: 0;
    font-size: 12px;
    pointer-events: none;
}

.banner--search__category select {
    width: 0;
    height: 0;
    opacity: 0;
}

.banner--search__category .choices {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    overflow: visible;
    background-color: var(--white);
}

.banner--search__category .choices__inner {
    height: 100%;
    border: none;
    cursor: pointer !important;
    background-color: var(--white);
}

.banner--search__category .choices__list--multiple, .banner--search__category .choices__input {
    visibility: hidden;
    opacity: 0;
}

.banner--search__category .choices__list--dropdown, .banner--search__category .choices__list[aria-expanded] {
    top: unset;
    bottom: 100%;
    width: 175%;
    height: 0;
    max-height: 300px;
    border: none;
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
    box-shadow: 0px 2px 30px rgba(0, 0, 0, 0.1);
    transition: all ease 500ms;
}

.banner--search__category .choices__list--dropdown .choices__item, .banner--search__category .choices__list[aria-expanded] .choices__item {
    border-bottom: 1px solid rgba(0, 0, 0, 0.05);
    font-size: 14px;
    line-height: 20px;
    letter-spacing: var(--letter-spacing-paragraph);
    font-weight: var(--font-weight-thin);
    overflow: hidden;
    transition: all ease 500ms;
}

.banner--search__category .choices__list--dropdown .choices__item--selectable, .banner--search__category .choices__list[aria-expanded] .choices__item--selectable {
    padding: 10px 35px;
    word-break: break-word;
}

.banner--search__category .choices__list--dropdown .choices__item--selectable.is-highlighted, .banner--search__category .choices__list[aria-expanded] .choices__item--selectable.is-highlighted {
    background: none;
}

.banner--search__category .choices__list--dropdown .choices__item--selectable.is-selected, .banner--search__category .choices__list--dropdown .choices__item--selectable.is-selected.choices__item--selectable.is-highlighted {
    color: var(--white);
    background-color: var(--gold);
}

.banner--search__category svg {
    margin-right: 8px;
}

.banner--search__calendar--wrapper {
    position: absolute;
    z-index: 1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    cursor: pointer;
}

.banner--search__calendar {
    position: absolute;
    bottom: 100%;
    width: 250%;
    height: 0;
    display: flex;
    justify-content: center;
    background: var(--white);
    box-shadow: 0px 2px 30px rgb(0 0 0 / 10%);
    overflow: hidden;
    transition: all ease 500ms;
}

.banner--search__calendar.is-open {
    height: 258px;
}

.banner--search__each-year {
    border-bottom: 1px solid rgba(0, 0, 0, 0.05);
    padding: 20px 20px 35px;
    width: 100%;
}

.banner--search__year {
    margin-bottom: 10px;
    font-size: 18px;
    line-height: 25px;
    letter-spacing: var(--letter-spacing-heading);
    font-family: var(--font-family-paragraph);
    text-align: center;
}

.banner--search__months {
    margin: 0 -2px;
}

.banner--search__month {
    padding: 2px;
}

.banner--search__month--wrapper {
    position: relative;
    padding: 14px 0;
    cursor: pointer;
}

.banner--search__month.disabled .banner--search__month--wrapper {
    cursor: default;
}

.banner--search__month label {
    position: absolute;
    top: 0;
    left: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    border-radius: 3px;
    font-size: 10px;
    line-height: 14px;
    letter-spacing: var(--letter-spacing-subtitle);
    font-weight: 600;
    font-family: var(--font-family-paragraph);
    color: var(--white);
    text-transform: uppercase;
    background: #D1B966;
    transition: all ease 200ms;
}

.banner--search__month.checked label {
    background-color: var(--gold);
}

.banner--search__month.disabled label {
    color: #999;
    background: var(--grey);
}

.banner--search__month--wrapper input {
    position: relative;
    z-index: -1;
}

.banner--search__button {
    position: relative;
    z-index: 66;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 15%;
    background: var(--gold);
    border: none;
    color: var(--white);
    transition: all ease 500ms;
}

.banner--search__button.shrink-first {
    width: 80px;
}

.banner--search__button svg {
    margin-right: 8px;
    transition: all ease 500ms;
}

.banner--search__button.shrink-first svg {
    margin-right: 0;
}

.banner--search__button span {
    width: auto;
    overflow: hidden;
    transition: all ease 500ms;
}

.banner--search__button.shrink-first span {
    width: 0;
}

.banner--search__button .button-first-wrapper {
    width: 0;
    height: 0;
}

.banner--search__button.shrink-first .button-first-wrapper {
    position: absolute;
    z-index: 66;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: none;
}

.banner-internal, .banner-search, .banner-single {
    position: relative;
}

.banner-internal .banner--background, .banner-single .banner--background {
    position: relative;
    height: 640px;
    overflow: hidden;
}

.banner-internal .banner--background img, .banner-single .banner--background img {
    width: 100%;
    object-fit: cover;
}

.banner-internal .banner--background__gradient, .banner-single .banner--background__gradient {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    background: linear-gradient(0deg, rgba(0, 0, 0, 0.4), rgba(0, 0, 0, 0.4));
}

.banner-internal--wrapper, .banner-single--wrapper {
    position: absolute;
    bottom: 0;
    width: 100%;
}

.banner-internal .banner--container, .banner-single .banner--container {
    position: relative;
    bottom: 150px;
    text-align: center;
    opacity: 0;
    visibility: hidden;
}

.banner-internal .banner--title, .banner-internal .banner--subtitle, .banner-single .banner--title {
    margin-bottom: 0;
}

.banner-search--wrapper, .banner-search .banner--background__gradient {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.banner-search .banner--background {
    height: 510px;
}

.banner-search img {
    object-fit: cover;
}

.banner-search .container, .banner-search .banner--container {
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.banner-search .banner--container {
    opacity: 0;
    visibility: hidden;
}

.banner-search .banner--title {
    margin-bottom: 10px;
}

.banner-search .banner--subtitle {
    margin-bottom: 0;
    text-transform: uppercase;
}

.banner-single .banner--link__button {
    display: inline-block;
    padding: 12px 34px;
    border: 1px solid var(--white);
    margin-top: 25px;
    color: var(--white);
    text-transform: uppercase;
}

.banner-single .banner--link__button:hover {
    border: 1px solid transparent;
}

@media (max-width: 1199px) {
    .banner .banner--search__wrapper {
        width: auto;
        margin: 0 -60px;
    }
}

@media (max-width: 1024px) {
    .banner--search--mobile {
        position: absolute;
        bottom: -1px;
        left: 0;
        width: 100%;
        height: 60px;
    }

    .banner--search--mobile .banner--search__button {
        width: 100%;
        height: 100%;
        font-size: 18px;
        line-height: 30px;
        letter-spacing: var(--letter-spacing-paragraph);
    }

    .form--mobile {
        position: fixed;
        z-index: 100;
        top: 0;
        left: 0;
        height: 100vh;
        width: 100%;
        background: var(--white);
        transform: translateX(101%);
        transition: all ease 500ms;
    }

    .form--mobile.opened {
        transform: translateX(0);
    }

    .form--mobile--wrapper {
        display: flex;
        flex-direction: column;
        justify-content: center;
        height: calc(100vh - 60px);
    }

    .form--mobile--close {
        position: absolute;
        top: 20px;
        right: 25px;
        display: flex;
        justify-content: center;
        align-items: center;
        width: 35px;
        height: 35px;
        border: 1px solid var(--gold);
        border-radius: 100%;
    }

    .form--mobile--close__inner {
        width: 20px;
        height: 2px;
        background: var(--gold);
        transform: rotate(45deg);
    }

    .form--mobile--close__inner:after {
        content: '';
        position: absolute;
        width: 20px;
        height: 2px;
        background: var(--gold);
        transform: rotate(90deg);
    }

    .form--mobile--title {
        margin-bottom: 20px;
        color: var(--gold);
    }

    .form--mobile .banner--search__wrapper {
        flex-direction: column;
        box-shadow: none;
    }

    .form--mobile .banner--search__categories {
        flex-direction: column;
        max-height: 100%;
    }

    .form--mobile .banner--search__category {
        flex: 0;
        justify-content: flex-start;
        width: 100%;
        margin-bottom: 10px;
        border: 1px solid rgba(0, 0, 0, 0.2);
        border-radius: 3px;
        padding: 17px 15px;
    }

    .form--mobile .banner--search__category:last-child {
        margin-bottom: 20px;
    }

    .form--mobile .banner--search__category:after {
        display: none;
    }

    .form--mobile .banner--search__category .triple-dots {
        position: absolute;
        z-index: 10;
        right: 18px;
    }

    .form--mobile .banner--search__button {
        width: 100%;
        padding: 14px 0;
        font-size: 18px;
        line-height: 30px;
        letter-spacing: var(--letter-spacing-paragraph);
    }

    .form--mobile .banner--mobile__data {
        position: absolute;
        z-index: 105;
        top: 0;
        left: 0;
        flex-direction: column;
        justify-content: center;
        height: 100%;
        padding: 0;
        background: var(--white);
        transform: translateX(101%);
        transition: all ease 500ms;
    }

    .form--mobile .banner--mobile__data.opened {
        transform: translateX(0);
    }

    .form--mobile .banner--mobile__data--title {
        margin-bottom: 14px;
        padding: 0 25px;
        align-self: flex-start;
        color: var(--gold);
    }

    .form--mobile .banner--search__category .choices {
        position: static;
        display: inherit;
        flex-direction: column;
        height: auto;
        overflow: hidden;
        background: none;
    }

    .form--mobile .banner--search__category .choices__inner {
        background: none;
        height: 0;
        min-height: 0;
        padding: 0;
    }

    .form--mobile .banner--search__category .choices__list--multiple, .form--mobile .banner--search__category .choices__input {
        height: 0px;
        padding: 0px;
        margin: 0px;
    }

    .form--mobile .banner--search__category .choices__list--dropdown, .form--mobile .banner--search__category .choices__list[aria-expanded] {
        position: static;
        display: flex;
        align-items: center;
        height: auto;
        width: 100%;
        padding: 0 25px;
        background: none;
        box-shadow: none;
        visibility: visible;
    }

    .form--mobile .choices__list--dropdown .choices__list, .form--mobile .choices__list[aria-expanded] .choices__list {
        width: 100%;
        max-height: 100%;
    }

    .form--mobile .banner--search__category .choices__list--dropdown .choices__item--selectable, .form--mobile .banner--search__category .choices__list[aria-expanded] .choices__item--selectable {
        position: relative;
        padding: 16px 0;
        font-size: 16px;
    }

    .form--mobile .banner--search__category .choices__list--dropdown .choices__item--selectable.is-selected, .form--mobile .banner--search__category .choices__list--dropdown .choices__item--selectable.is-selected.choices__item--selectable.is-highlighted {
        color: var(--black);
        background-color: var(--white);
    }

    .form--mobile .banner--search__category .choices__list--dropdown .choices__item--selectable .checkbox, .form--mobile .banner--search__category .choices__list[aria-expanded] .choices__item--selectable .checkbox {
        position: absolute;
        right: 0;
        top: 50%;
        display: flex;
        align-items: center;
        justify-content: center;
        width: 12px;
        height: 12px;
        border: 1px solid rgba(0, 0, 0, 0.4);
        border-radius: 2px;
        transform: translateY(-50%);
    }

    .form--mobile .banner--search__category .choices__list--dropdown .choices__item--selectable .checkbox--inner, .form--mobile .banner--search__category .choices__list[aria-expanded] .choices__item--selectable .checkbox--inner {
        width: 8px;
        height: 8px;
        border-radius: 2px;
    }

    .form--mobile .banner--search__category .choices__list--dropdown .choices__item--selectable.is-selected .checkbox--inner {
        background: var(--green);
    }

    .form--mobile .banner--mobile__data--button-done--wrapper {
        width: 100%;
        margin-bottom: 30px;
        padding: 0 25px;
    }

    .form--mobile .banner--mobile__data--button-done {
        width: 100%;
        border: none;
        border-radius: 3px;
        padding: 15px 0;
        font-size: 18px;
        line-height: 30px;
        letter-spacing: var(--letter-spacing-paragraph);
        color: var(--white);
        background: var(--gold);
        box-shadow: 0px 4px 30px rgb(0 0 0 / 10%);
    }

    .form--mobile .banner--mobile__data--button-back--text {
        border: none;
        background: none;
    }

    .form--mobile .banner--mobile__data--button-back--text span {
        color: var(--gold);
    }

    .form--mobile .banner--search__calendar--wrapper {
        position: relative;
        height: auto;
    }

    .form--mobile .banner--search__calendar {
        position: static;
        height: auto;
        width: 100%;
        box-shadow: none;
    }

    .form--mobile .banner--search__each-year {
        height: auto;
        border-bottom: 0;
    }

    .form--mobile .select-info {
        top: 0;
        left: 44px;
        display: flex;
        align-items: center;
        height: 100%;
        width: 50%;
        font-size: 15px;
        line-height: 22px;
        color: var(--gold);
        background: var(--white);
    }

    .form--mobile .banner--search__category[data-menu="price"] .select-info, .form--mobile .banner--search__category[data-menu="purpose"] .select-info {
        left: 40px;
    }
}

@media (max-width: 991px) {
    .banner-search .banner--background .img-wrapper.parallax img {
        top: -20%;
    }
}

@media (max-width: 767px) {
    .banner-homepage, .banner-homepage .banner--video .plyr, .banner-homepage .banner--background, .banner-homepage .banner--container {
        height: calc(100vh - 60px);
    }

    .banner-homepage--wrapper .banner--title {
        margin-bottom: 15px;
    }

    .banner-homepage .banner--subtitle {
        margin-bottom: 20px;
    }

    .form--mobile .banner--search__category .choices__list--dropdown .choices__item, .banner--search__category .choices__list[aria-expanded] .choices__item {
        font-size: 16px;
    }

    .banner-search img {
        height: 400px;
    }

    .banner-search .banner--container {
        text-align: center;
    }

    .banner-search .banner--subtitle {
        text-transform: none;
    }

    .banner-internal .banner--background, .banner-single .banner--background, .banner-internal .banner--background img, .banner-single .banner--background img {
        height: 560px;
    }

    .banner-internal .banner--title, .banner-single .banner--title {
        margin-bottom: 10px;
        overflow-wrap: break-word;
        word-wrap: break-word;
    }

    .banner-single .banner--link__button {
        margin-top: 10px;
    }
    .banner--title.xl{
        font-size: 50px;
        line-height: 60px;
    }
}

@media (max-width: 375px) {
    .banner--title.xl{
        font-size: 48px;
    }
}