@font-face {
    font-family: 'Stratos LC Web';
    src: url('../../fonts/Stratos LC Web/Stratos-SemiBold-Web.woff2') format('woff2'), 
        url('../../fonts/Stratos LC Web/Stratos-SemiBold-Web.woff') format('woff'),
        url('../../fonts/Stratos LC Web/Stratos-SemiBold-Web.ttf') format('truetype');
    font-weight: 600;
    font-style: normal;
}

@font-face {
    font-family: 'Stratos LC';
    src: url('../../fonts/Stratos LC/Stratos-SemiBold-Desktop.otf') format('opentype');
    font-weight: 600;
    font-style: normal;
}

@font-face {
    font-family: 'Graphik LC Medium';
    src: url('../../fonts/Graphik LC/Graphik-Medium-Web.woff2') format('woff2'), url('../../fonts/Graphik LC/Graphik-Medium-Web.woff') format('woff');
    font-weight: 500;
    font-style: normal;
}

@font-face {
    font-family: 'Graphik LC';
    src: url('../../fonts/Graphik LC/Graphik-Regular-Web.woff2') format('woff2'), url('../../fonts/Graphik LC/Graphik-Regular-Web.woff') format('woff');
    font-weight: 400;
    font-style: normal;
}

abbr, address, article, aside, audio, b, blockquote, body, button, canvas, cite, code, dd, del, details, dfn, div, dl, dt, em, fieldset, figcaption, figure, footer, form, h1, h2, h3, h4, h5, h6, header, hgroup, html, i, iframe, img, ins, kbd, label, legend, li, mark, menu, nav, object, ol, p, pre, q, samp, section, small, span, strong, summary, time, ul, var, video {
    margin: 0;
    padding: 0;
    border: 0;
    outline: 0;
    font-size: 100%;
    vertical-align: baseline;
    background: 0 0;
    -webkit-box-sizing: border-box;
    box-sizing: border-box
}

    abbr:after, abbr:before, address:after, address:before, article:after, article:before, aside:after, aside:before, audio:after, audio:before, b:after, b:before, blockquote:after, blockquote:before, body:after, body:before, button:after, button:before, canvas:after, canvas:before, cite:after, cite:before, code:after, code:before, dd:after, dd:before, del:after, del:before, details:after, details:before, dfn:after, dfn:before, div:after, div:before, dl:after, dl:before, dt:after, dt:before, em:after, em:before, fieldset:after, fieldset:before, figcaption:after, figcaption:before, figure:after, figure:before, footer:after, footer:before, form:after, form:before, h1:after, h1:before, h2:after, h2:before, h3:after, h3:before, h4:after, h4:before, h5:after, h5:before, h6:after, h6:before, header:after, header:before, hgroup:after, hgroup:before, html:after, html:before, i:after, i:before, iframe:after, iframe:before, img:after, img:before, ins:after, ins:before, kbd:after, kbd:before, label:after, label:before, legend:after, legend:before, li:after, li:before, mark:after, mark:before, menu:after, menu:before, nav:after, nav:before, object:after, object:before, ol:after, ol:before, p:after, p:before, pre:after, pre:before, q:after, q:before, samp:after, samp:before, section:after, section:before, small:after, small:before, span:after, span:before, strong:after, strong:before, summary:after, summary:before, time:after, time:before, ul:after, ul:before, var:after, var:before, video:after, video:before {
        -webkit-box-sizing: border-box;
        box-sizing: border-box
    }

sub, sup {
    margin: 0;
    padding: 0;
    border: 0;
    outline: 0;
    font-size: 100%;
    background: 0 0;
    -webkit-box-sizing: border-box;
    box-sizing: border-box
}

    sub:after, sub:before, sup:after, sup:before {
        -webkit-box-sizing: border-box;
        box-sizing: border-box
    }

a:after, a:before {
    -webkit-box-sizing: border-box;
    box-sizing: border-box
}

caption, table, tbody, td, tfoot, th, thead, tr {
    margin: 0;
    padding: 0;
    border: 0;
    outline: 0;
    font-size: 100%;
    background: 0 0
}

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
    display: block
}

li, ol, ul {
    list-style: none
}

blockquote, q {
    quotes: none
}

    blockquote:after, blockquote:before {
        content: none
    }

    q:after, q:before {
        content: none
    }

:focus {
    outline: 0 !important;
}

input[type=text], textarea {
    -webkit-appearance: none
}

    input[type=text]::-ms-clear, textarea::-ms-clear {
        display: none
    }

input, textarea {
    -webkit-border-radius: 0;
    border-radius: 0;
    -webkit-box-sizing: border-box;
    box-sizing: border-box
}

    input::-webkit-input-placeholder, textarea::-webkit-input-placeholder {
        color: inherit
    }

    input::-moz-placeholder, textarea::-moz-placeholder {
        color: inherit
    }

    input:-ms-input-placeholder, textarea:-ms-input-placeholder {
        color: inherit
    }

    input:focus::-webkit-input-placeholder, textarea:focus::-webkit-input-placeholder {
        color: transparent
    }

    input:focus::-moz-placeholder, textarea:focus::-moz-placeholder {
        color: transparent
    }

    input:focus:-ms-input-placeholder, textarea:focus:-ms-input-placeholder {
        color: transparent
    }

    input:focus, textarea:focus, select:focus {
        border: 1px solid #6951CC !important;
        background: #F9F8FF
    }

textarea {
    resize: none
}

ins {
    text-decoration: none
}

del {
    text-decoration: line-through
}

table {
    border-collapse: collapse;
    border-spacing: 0
}

* {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    word-wrap: break-word
}

.wow {
    visibility: hidden
}

.booking-step__card-header::after, .booking-step__card-header::before, .booking-step__number, .booking-step__number span, .booking-steps-check__icon, .booking-steps-check__shopping-counter, .booking-steps-check__shopping::before, .booking-steps-final__content::after, .booking-steps-final__content::before, .booking-steps-header__step {
    -webkit-border-radius: 50%;
    border-radius: 50%
}

html {
    font-size: 16px
}

body {
    position: relative
}

a {
    text-decoration: none !important;
    -webkit-transition: color .3s ease-in-out;
    -o-transition: color .3s ease-in-out;
    transition: color .3s ease-in-out;
    color: inherit
}

* {
    outline: 0;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    max-width: 100%
}

img {
    -o-object-fit: cover;
    object-fit: cover;
    max-width: 100%;
    max-height: 100%
}

svg {
    max-width: 100%;
    max-height: 100%
}

textarea {
    resize: none
}

.flex {
    display: flex
}

.justify-content-between {
    justify-content: space-between
}

p.flex {
    margin-bottom: 10px
}

.container {
    max-width: 100%;
    width: 100%;
    margin-inline: 0;
    padding-inline: 0;
}

.datepicker {
    width: 375px;
    border: none
}

.datepicker--days {
    min-height: 300px
}

.datepicker--nav {
    height: 54px;
    -webkit-border-radius: 5px;
    border-radius: 5px;
    background: #fdfdfd;
    border: 1px solid #d5dfe6;
    padding: 0;
    margin-bottom: 25px
}

.datepicker--nav-action {
    -webkit-border-radius: 5px;
    border-radius: 5px;
    border: 2px solid transparent;
    -webkit-transition: all .3s ease-in-out;
    -o-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out;
    width: 64px
}

    .datepicker--nav-action svg {
        width: 10px;
        height: 18px
    }

    .datepicker--nav-action:hover {
        border-color: #8365ff;
        background: 0 0
    }

.datepicker--nav-title, .datepicker--nav-title i {
    font-size: 18px;
    line-height: 24px;
    font-weight: 700;
    color: #42337e
}

.datepicker--nav-title {
    pointer-events: none
}

.datepicker--content {
    padding: 0
}

.datepicker--day-name {
    text-transform: none;
    font-size: 14px;
    line-height: 19px;
    color: #908f8f;
    margin-bottom: 15px
}

.datepicker--cell {
    -webkit-border-radius: 4px;
    border-radius: 4px;
    background: #fff;
    margin-right: 12px;
    width: 43px;
    height: 36px;
    margin-bottom: 9px;
    font-size: 12px;
    line-height: 18px;
    color: #50606b;
    -webkit-transition: all .3s ease-in-out;
    -o-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out;
    border: .8px solid #d5dfe6
}

    .datepicker--cell:nth-child(7n) {
        margin-right: 0
    }

    .datepicker--cell:hover {
        border: 1.6px solid #8365ff;
        background: #fff
    }

    .datepicker--cell.-current- {
        color: #8365ff
    }

    .datepicker--cell.-selected-, .datepicker--cell.-selected-.-focus- {
        background-color: #8365ff !important;
        color: #fff !important
    }

.datepicker--cell-day.-other-month- {
    color: #50606b
}

    .datepicker--cell-day.-other-month-:hover {
        color: #50606b
    }

.datepicker--cell--lock {
    position: relative;
    color: rgba(170,170,170,.3) !important
}

    .datepicker--cell--lock:hover {
        border: .8px solid #d5dfe6
    }

.datepicker--cell--disabled {
    position: relative;
    color: rgba(170,170,170,.3) !important
}

    .datepicker--cell--disabled:hover {
        border: .8px solid #d5dfe6
    }

    .datepicker--cell--disabled::before {
        content: "";
        display: block;
        position: absolute;
        height: 1px;
        background: #d5dfe6;
        width: -webkit-calc(100% + 12px);
        width: calc(100% + 12px);
        top: 50%;
        -webkit-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
        transform: translateY(-50%);
        left: 0
    }

    .datepicker--cell--disabled--last::before, .datepicker--cell--disabled:nth-child(7n)::before {
        width: 100%
    }

.timepicker_wrap {
    top: 0;
    display: block !important;
    width: 180px;
    background: 0 0;
    -webkit-box-shadow: none;
    box-shadow: none;
    border: none;
    padding: 0
}

    .timepicker_wrap .arrow_top {
        display: none
    }

    .timepicker_wrap .meridian, .timepicker_wrap .mins, .timepicker_wrap .time {
        padding: 0;
        margin: 0;
        width: 50%
    }

    .timepicker_wrap .next, .timepicker_wrap .prev {
        width: 90px;
        height: 55px;
        border: none;
        border-top: 1px solid #d5dfe6;
        border-bottom: 1px solid #d5dfe6;
        -webkit-border-radius: 0;
        border-radius: 0;
        -webkit-transition: all .3s ease-in-out;
        -o-transition: all .3s ease-in-out;
        transition: all .3s ease-in-out
    }

    .timepicker_wrap .prev {
        background: #fff url(/static/images/arrow_up.svg) no-repeat center center/20px
    }

    .timepicker_wrap .next {
        background: #fff url(/static/images/arrow_down.svg) no-repeat center center/20px
    }

    .timepicker_wrap .time .next, .timepicker_wrap .time .prev {
        -webkit-border-bottom-left-radius: 5px;
        border-bottom-left-radius: 5px;
        -webkit-border-top-left-radius: 5px;
        border-top-left-radius: 5px;
        border-left: 1px solid #d5dfe6;
        border-right: 1px solid transparent
    }

        .timepicker_wrap .time .next:hover, .timepicker_wrap .time .prev:hover {
            border: 2px solid #8365ff;
            -webkit-border-radius: 5px;
            border-radius: 5px;
            background-color: #fff
        }

    .timepicker_wrap .mins .next, .timepicker_wrap .mins .prev {
        -webkit-border-bottom-right-radius: 5px;
        border-bottom-right-radius: 5px;
        -webkit-border-top-right-radius: 5px;
        border-top-right-radius: 5px;
        border-right: 1px solid #d5dfe6;
        border-left: 1px solid transparent
    }

        .timepicker_wrap .mins .next:hover, .timepicker_wrap .mins .prev:hover {
            border: 2px solid #8365ff;
            -webkit-border-radius: 5px;
            border-radius: 5px;
            background-color: #fff
        }

    .timepicker_wrap .mi_tx input, .timepicker_wrap .ti_tx input {
        border: none;
        font-size: 33px;
        line-height: 45px;
        font-weight: 700
    }

    .timepicker_wrap .ti_tx {
        position: relative
    }

        .timepicker_wrap .ti_tx::before {
            content: "";
            display: block;
            position: absolute;
            content: '';
            left: 100%;
            top: 50%;
            -webkit-transform: translate(-50%,-50%);
            -ms-transform: translate(-50%,-50%);
            transform: translate(-50%,-50%)
        }

input.timepicki-input {
    width: 100%
}

.select2-container, .select2-selection {
    width: 615px !important;
    max-width: 100%
}

.select2-container-selection, .select2-selection-selection {
    padding: 15px 12px
}

.select2-container-container, .select2-selection-container {
    position: relative;
    display: block
}

.select2-container--single, .select2-container__rendered, .select2-selection--single, .select2-selection__rendered {
    height: 55px !important;
    width: 615px;
    max-width: 100%;
    font-size: 18px !important;
    letter-spacing: -.06px;
    color: #50606b;
    -webkit-transition: all .3s ease-in-out;
    -o-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out;
    display: -webkit-box !important;
    display: -webkit-flex !important;
    display: -ms-flexbox !important;
    display: flex !important;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center
}

    .select2-container--single:focus, .select2-container__rendered:focus, .select2-selection--single:focus, .select2-selection__rendered:focus {
        color: #323c47;
        border-color: #8365ff;
        -webkit-box-shadow: 0 0 3px 0 rgba(131,102,255,.14);
        box-shadow: 0 0 3px 0 rgba(131,102,255,.14)
    }

.select2-search--dropdown {
    display: none
}

.selection {
    width: 615px;
    height: 55px;
    max-width: 100%
}

.select2-container--default .select2-results__option--highlighted[aria-selected] {
    background-color: #8366ff
}

.select2-container--default .select2-selection--single::before {
    content: "";
    display: block;
    position: absolute;
    width: 18px;
    height: 24px;
    background: url(/static/images/loc.svg);
    left: 20px
}

.select2-container--default .select2-selection--single .select2-selection__arrow {
    border: none;
    background: url(/static/images/arrow_down_booking.svg) no-repeat center center/contain;
    width: 20px;
    height: 20px;
    right: 20px;
    top: 50%;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
    -webkit-transition: all .3s ease-in-out;
    -o-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out
}

    .select2-container--default .select2-selection--single .select2-selection__arrow b {
        display: none
    }

.select2-container--default.select2-container--open .select2-selection--single .select2-selection__arrow {
    -webkit-transform: translateY(-50%) rotate(180deg);
    -ms-transform: translateY(-50%) rotate(180deg);
    transform: translateY(-50%) rotate(180deg)
}

.select2-results__option {
    font-family: "Graphik LC",sans-serif
}

.select2-container--default .select2-selection--single .select2-selection__rendered {
    padding-left: 55px;
    padding-right: 0;
    margin-right: 45px;
    position: relative
}

.pilot-checkout-desk {
    display: block;
}

.pilot-checkout-mob {
    display: none;
}

.pilot-poscode_container {
    background-image: url('/static/images/new-checkout/pilot-banner.png');
    width: 100%;
    height: 100vh;
    background-size: cover;
    background-repeat: no-repeat;
}

    .pilot-poscode_container h1 {
        color: #fff;
        font-size: 68px;
        font-weight: 600;
        line-height: 74.8px;
        text-align: center;
        font-family: 'Stratos LC Web', sans-serif;
        text-transform: uppercase;
        padding-top: 110px
    }

    .pilot-poscode_container .enter-postcode {
        padding-inline: 16px;
        padding-top: 90%;
        position: relative;
    }

        .pilot-poscode_container .enter-postcode p {
            color: #fff;
            font-size: 20px;
            font-weight: 600;
            line-height: 26.4px;
            text-align: left;
        }

        .pilot-poscode_container .enter-postcode .form__point {
            position: relative;
            margin-top: 16px
        }

            .pilot-poscode_container .enter-postcode .form__point img {
                position: absolute;
                top: 14px;
                left: 14px;
            }

            .pilot-poscode_container .enter-postcode .form__point input {
                height: 58px;
                width: 100%;
                border: none;
                outline: 1px solid #6951cc;
                border-radius: 12px;
                padding-left: 40px
            }

                .pilot-poscode_container .enter-postcode .form__point input:focus {
                    border: none !important;
                }

                .pilot-poscode_container .enter-postcode .form__point input::placeholder {
                    font-family: 'Graphik LC', sans-serif;
                    color: #868F96;
                    font-size: 16px;
                    font-weight: 500;
                    line-height: 16px;
                }

        .pilot-poscode_container .enter-postcode button {
            position: absolute;
            width: 52px;
            height: 52px;
            bottom: 3px;
            right: 19px;
            border-radius: 12px;
            color: #fff;
            background: #6951cc
        }

    .pilot-poscode_container .trustpilot-context {
        position: absolute;
        bottom: -30px;
        left: 20px;
        width: 315px;
        background: unset
    }

.pilot-poscode_container .tp-widget-rating span {
    color: #fff !important;
    font-size: 16px !important;
}

#newFunnelModal {
    display: none;
}

.booking-steps_top {
    background: #fff
}

    .booking-steps_top a {
        cursor: pointer;
    }


.booking-steps__steper {
    height: 48px;
    width: 560px;
    background: #FDFDFD !important;
    position: fixed;
    top: 0;
    right: 0;
    z-index: 99;
    background: #fff;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-inline: 40px;
    color: #50606B;
    font-size: 16px;
    font-weight: 700;
    border-bottom: 1px solid #E6EBEF
}

    .booking-steps__steper p {
        font-family: 'Graphik LC Medium', sans-serif;
        font-weight: 500;
        color: #50606B;
        display: flex;
        align-items: center;
        margin-bottom: 0;
    }

        .booking-steps__steper p img {
            margin-right: 3px;
            margin-top: 3px;
        }

.booking-steps__steper_mobile {
    height: 48px;
    width: 560px;
    position: fixed;
    top: 0;
    z-index: 9;
    background: #fff;
    display: flex;
    justify-content: space-between;
    align-items: center;
    color: #50606B;
    font-size: 16px;
    font-weight: 700;
    border-bottom: 1px solid #E6EBEF;
    padding-inline: 24px;
}

    .booking-steps__steper_mobile p {
        margin: 0
    }

.close-funnel_btn {
    cursor: pointer;
    width: 12px;
    height: 12px;
}

.close-payment_btn {
    cursor: pointer;
    margin-bottom: 10px;
}

/* CSS for slide-in animation */
@keyframes slideIn {
    from {
        transform: translateY(100%);
        opacity: 0;
    }

    to {
        transform: translateY(0);
        opacity: 1;
    }
}

@keyframes slideOut {
    from {
        transform: translateY(0);
        opacity: 1;
    }

    to {
        transform: translateY(-100%);
        opacity: 0;
    }
}

.d-block-important {
    display: block !important;
}

.booking-steps__items > div {
    display: none;
    animation-duration: 800ms;
    animation-fill-mode: both;
}

    .booking-steps__items > div.active {
        display: block !important;
        animation-name: slideIn;
    }

    .booking-steps__items > div.inactive {
        animation-name: slideOut;
    }

#newFunnelModal .booking-step1_container {
    background: #fff;
    position: fixed;
    right: 0;
    top: 0;
    z-index: 9999;
    width: 560px;
}

.booking-step1_container, .booking-step_container, .booking-step5_container {
    overflow-y: auto;
    scrollbar-width: none;
}

.booking-step1_container {
    display: flex;
    flex-direction: column;
    height: calc(100vh - 58px);
    margin-top: 48px;
    transition: 300s ease-in-out;
}

    .booking-step1_container h2 {
        color: #323C47;
        font-size: 24px;
        font-weight: 600;
        font-family: 'Stratos LC Web', sans-serif;
        text-transform: uppercase;
        margin-bottom: 0;
    }

    .booking-step1_container .step1-postcode, .booking-step1_container .step1-title {
        background: #fff
    }

        .booking-step1_container .step1-title p {
            color: #323C47;
            font-size: 16px;
            font-weight: 400;
            line-height: 24px;
            margin-block: 10px 32px;
        }

        .booking-step1_container .step1-title div {
            width: 100%;
            display: flex;
            flex-direction: column;
            position: fixed;
            z-index: 9;
            background: #fff;
            padding: 24px 40px 0
        }

        .booking-step1_container .step1-postcode div {
            display: flex;
            flex-direction: column;
            align-items: start;
            margin-top: 105px;
            padding: 8px 40px 32px;
        }

        .booking-step1_container .step1-postcode label {
            font-family: "Graphik LC Medium", sans-serif;
            color: #323C47;
            font-size: 20px;
            font-weight: 500
        }

        .booking-step1_container .step1-postcode input {
            width: 100%;
            max-width: 480px;
            height: 45px;
            border: 1px solid #868F96;
            border-radius: 4px;
            padding: 15px;
            margin-top: 7px;
            font-family: "Graphik LC", sans-serif;
            font-size: 16px;
            font-weight: 400;
            opacity: 1;
            color: #323C47;
        }

            .booking-step1_container .step1-postcode input::placeholder {
                color: #323C47;
                font-size: 14px
            }

        .booking-step1_container .step1-postcode .form__error {
            color: #E93F3A;
            position: unset;
            margin-left: 40px;
            margin-top: -20px;
            padding-bottom: 20px;
        }

    .booking-step1_container .step1-rooms_count {
        background: #fff;
        margin-top: 0;
    }

.step1-rooms_card_container {
    height: 161px;
}

.booking-step1_container .step1-rooms_card {
    border-bottom: 1px solid #E6EBEF;
    padding: 12px 40px;
    display: flex;
    align-items: center;
    justify-content: space-between
}

    .booking-step1_container .step1-rooms_card .rooms-card_title {
        display: flex;
        align-items: center;
        gap: 5px
    }

        .booking-step1_container .step1-rooms_card h4 {
            font-family: 'Graphik LC Medium', sans-serif;
            color: #323C47;
            font-size: 16px;
            font-weight: 500;
            line-height: 16px;
            text-align: left;
        }

        .booking-step1_container .step1-rooms_card p {
            font-family: 'Graphik LC', sans-serif;
            color: #323C47;
            font-size: 14px;
            font-weight: 400;
            line-height: 22px;
            margin-top: 5px;
            margin-bottom: 0;
        }

        .booking-step1_container .step1-rooms_card img {
            width: 56px;
            height: 56px;
        }

        .booking-step1_container .step1-rooms_card .count {
            height: 32px;
            padding: 4px 15px;
            margin: 0;
            background: #F1F3F4;
            border-radius: 100px;
            z-index: 0;
            margin-top: 2px;
            user-select: none;
            color: #50606B;
            font-size: 14px;
            font-weight: 800;
        }

            .booking-step1_container .step1-rooms_card .count .minus {
                width: 18px;
                height: 20px;
                margin-bottom: 0;
            }

                .booking-step1_container .step1-rooms_card .count .minus:focus {
                    outline: none;
                }

            .booking-step1_container .step1-rooms_card .count .plus {
                width: 14px;
                height: 12px
            }

                .booking-step1_container .step1-rooms_card .count .plus:focus {
                    outline: none;
                }

            .booking-step1_container .step1-rooms_card .count input {
                user-select: none;
                color: rgb(80,96,107) !important;
                font-size: 16px;
                font-weight: 500;
                opacity: 1;
                font-family: 'Graphik LC', sans-serif;
            }

        .booking-step1_container .step1-rooms_card .form__button, .form__input {
            width: 50%;
            min-height: 32px;
        }

            .form__input.js-enter-post {
                width: 75%;
                min-height: 48px;
            }

        .booking-step1_container .edit-section {
            display: flex;
            justify-content: space-between;
            align-items: flex-start;
            padding: 24px 40px;
            border-top: 1px solid #E6EBEF;
        }

        .booking-step1_container .edit-section img {
            width:18px;
            height:18px;
            margin-top:6px
        }

        .booking-step1_container .edit-section p:first-child {
            color: #323C47;
            font-weight: 600;
            text-transform: uppercase;
            margin-bottom: 4px
        }

        .booking-step1_container .edit-section .edit-btn {
            color: #6951cc;
            font-weight: 500;
            cursor: pointer
        }
    
    .booking-step1_container .additional-info {
        background: #fff;
        padding-bottom: 90px
    }

    .booking-step1_container .need-extra {
        padding: 24px 40px 16px;
        font-family: 'Graphik LC Medium', sans-serif;
        color: #323C47;
        font-size: 20px;
        font-weight: 500;
        line-height: 26.4px;
        text-align: left;
        border-bottom: 1px solid #E6EBEF;
    }

    .booking-step1_container .moving-out h4 {
        font-family: 'Graphik LC', sans-serif;
        font-weight: 600;
        font-size: 18px
    }

    .booking-step1_container .moving-out p {
        font-family: 'Graphik LC', sans-serif;
        color: #323C47 !important;
        font-size: 14px !important;
        font-weight: 400;
        line-height: 16.8px;
    }

    .booking-step1_container .extra-service {
        height: 76px;
        display: flex;
        justify-content: space-between;
        align-items: center;
        padding-inline: 40px;
        padding-block: 12px;
        border-bottom: 1px solid #E6EBEF
    }

    .booking-step1_container .extra-service.move {
        height: 86px;
        padding-block: 16px;
    }

    .booking-step1_container .extra-service.hoover {
        height: 72px;
        padding-block: 16px;
    }

        .booking-step1_container .extra-service h4 {
            font-family: 'Graphik LC Medium', sans-serif;
            color: #323C47;
            margin-bottom: 8px;
            font-size: 16px;
            font-weight: 500;
            line-height: 16px;
        }

        .booking-step1_container .extra-service p {
            font-family: 'Graphik LC', sans-serif;
            font-size: 16px;
            font-weight: 400;
            color: #8365FF;
            margin-bottom: 0;
        }

        .booking-step1_container .extra-service span {
            font-family: "Graphik LC", sans-serif;
            color: #323C47;
            font-weight: 400;
        }

        .booking-step1_container .extra-service .extra-service_title {
            display: flex;
            align-items: center;
            gap: 10px
        }

    .booking-step1_container .extra-service_add {
        width: 38px;
        height: 32px;
        background: #F1F3F4;
        padding-block: 3px;
        padding-inline: 12px;
        border-radius: 100px;
        cursor: pointer;
    }

#noBeds, #noBaths, #noFridges {
    display: flex;
}

#manyBeds, #manyBaths, #manyFridges {
    display: none;
}

.booking-step_container h2 {
    position: fixed;
    top: 48px;
    width: 100%;
    background: #fff;
    padding: 32px 40px 10px;
    margin-bottom: 0;
    color: #323C47;
    font-family: 'Stratos LC Web', sans-serif;
    text-transform: uppercase;
    font-size: 24px;
    font-weight: 600;
    line-height: 30px;
    z-index: 1;
}

#step4 h2 {
    z-index: 9;
}

.booking-step_container.booking-step--four, .booking-step5_container.booking-step--five {
    overflow-y: auto;
    scrollbar-width: none;
}

.booking-step1_container.booking-step--six .booking-step__block--last {
    padding: 24px 24px 12px;
    background: #fff;
    overflow-y: auto;
    scrollbar-width: none;
    border-top-left-radius: 8px;
    border-top-right-radius: 8px;
}

#payment-btn {
    border-bottom-left-radius: 8px;
    border-bottom-right-radius: 8px;
}

.booking-step1_container .booking-last-descr {
    display: flex;
    align-items: center;
    gap: 14px;
    margin-block: 24px;
}

    .booking-step1_container .booking-last-descr p {
        font-family: 'Graphik LC', sans-serif;
        font-size: 14px;
        font-weight: 400;
        line-height: 16.8px;
        margin-bottom: 0;
    }

.booking-step_container #calendars {
    margin: 10px 40px 16px;
    padding-bottom: 40px;
}

.calendar-container {
    margin-bottom: 20px;
    border: 1px solid #ccc;
    border-radius: 6px;
    padding: 20px 8px 10px;
    width: 361px
}

.calendar-header {
    font-family: 'Graphik LC', sans-serif;
    color: #323C47;
    font-size: 20px;
    line-height: 20px;
    font-weight: 400;
    margin-bottom: 10px
}

.calendar-grid {
    display: grid;
    grid-template-columns: repeat(7,1fr);
    gap: 7px 6.17px;
}

.day {
    font-family: 'Graphik LC', sans-serif;
    height: 44px;
    width: 44px;
    padding: 8px 5px 4px;
    text-align: center;
    color: #868F96;
    font-size: 12px;
    font-weight: 400;
    line-height: 15px;
    border-radius: 4px;
    border: 1px solid #fff;
    cursor: pointer;
    user-select: none;
    transition: border-color 0.3s ease, background-color 0.3s ease;
}

.weekDays {
    height: 18px;
    margin-bottom: 4px
}

.day .date {
    font-family: 'Graphik LC', sans-serif;
    font-size: 16px;
    font-weight: 400;
    color: #323C47
}

.day .price {
    font-family: 'Graphik LC', sans-serif;
    font-size: 10px;
    font-weight: 400;
    color: #868F96;
    text-wrap: nowrap;
}

    .day .first-available-date {
        color: #6951CC;
    }

    .day:hover {
        border: 1px solid #6951CC;
        background: #F9F8FF
    }

    .weekDays:hover {
        border: 1px solid #fff;
        background: unset
    }

    .day.selected {
        background-color: #6951CC;
        border: 2px solid #6951CC;
        color: #fff;
        padding: 8px 5px 4px;
    }

        .day.selected .date, .day.selected .price {
            background-color: #6951CC;
            color: #fff
        }

    .day.disabled {
        border: 2px solid #fff;
        cursor: not-allowed;
        opacity: 0.6;
    }

        .day.disabled:hover {
            border: 2px solid #fff;
            background: #fff
        }

        .day.disabled .price {
            display: none
        }

.booking-step_container.booking-step--two p, .booking-step_container.booking-step--three p {
    padding-inline: 40px;
    margin-bottom: 0;
    margin-top: 8px
}

.duration-container {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    padding: 32px 40px;
    gap: 16px;
}

.cleaning-duration {
    max-width: 232px;
    width: 47.78%;
    height: 80px;
    border: 1px solid #868F96;
    border-radius: 6px;
    padding: 16px;
    cursor: pointer;
    transition: background-color 0.3s ease, border-color 0.3s ease;
}

    .cleaning-duration input, .what-time input {
        appearance: none;
        width: 16px;
        height: 16px;
        border: 2px solid #B6BFC6;
        border-radius: 50%;
        position: relative;
        cursor: pointer;
        transition: border-color 0.3s ease, background-color 0.3s ease;
    }

    .cleaning-duration input[type="radio"]:checked::before, .what-time input[type="radio"]:checked::before {
        content: "";
        width: 8px;
        height: 8px;
        border: 2px solid #6951CC;
        background-color: #6951CC;
        border-radius: 50%;
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        transition: border-color 0.3s ease, background-color 0.3s ease;
    }

    .cleaning-duration.active input[type="radio"]::before, .cleaning-duration:hover input[type="radio"]::before,
    .what-time.active input[type="radio"]::before, .what-time:hover input[type="radio"]::before {
        content: "";
        width: 8px;
        height: 8px;
        border: 2px solid #6951CC;
        background-color: #6951CC;
        border-radius: 50%;
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        transition: border-color 0.3s ease, background-color 0.3s ease;
    }


    input[type=radio], input[type=radio]:hover {
        accent-color: #6951CC;
        transition: border-color 0.3s ease, accent-color 0.3s ease;
    }

        input[type=radio]:checked, .cleaning-duration:hover input[type="radio"], .what-time:hover input[type="radio"] {
            accent-color: #6951CC;
            border: 2px solid #6951CC;
            transition: border-color 0.3s ease, accent-color 0.3s ease;
        }

    .cleaning-duration.active, .cleaning-duration:hover {
        border: 1px solid #6951CC;
        background: #F9F8FF;
        transition: background-color 0.3s ease, border-color 0.3s ease;
    }

    .cleaning-duration div {
        display: flex;
        justify-content: space-between;
        align-items: start;
    }

        .cleaning-duration div h4 {
            font-family: 'Graphik LC Medium', sans-serif;
            color: #323C47;
            font-size: 16px;
            font-weight: 500;
            line-height: 16px;
            margin-bottom: 0;
        }

    .cleaning-duration p {
        color: #50606B;
        font-weight: 400;
        margin-block: 0 !important;
        padding: 0 !important;
    }

.toggle-container {
    display: flex;
    justify-content: center;
    align-items: center;
}

.toggle-container:focus,
.toggle-container:focus-visible,
.toggle-container:focus-within,
.toggle-container:target,
.toggle-container:active {
    padding: 1px;
    outline: 2px solid #785ce8;
    border-radius: 20px;
}

.toggle-switch {
    display: none;
}

.toggle-label {
    width: 44px;
    height: 24px;
    background-color: #D5DFE6;
    border-radius: 12px;
    position: relative;
    cursor: pointer;
    transition: background-color 0.3s ease;
    margin-bottom: 0;
}

    .toggle-label::after {
        content: "";
        width: 20px;
        height: 20px;
        background-color: #ffffff;
        border-radius: 50%;
        position: absolute;
        top: 2px;
        left: 2px;
        transition: 0.3s ease;
        box-shadow: 0px 1px 2px 0px #0000000F;
    }

    .toggle-label:hover::after {
        box-shadow: 0px 1px 2px 0px #0000000F, 0px 1px 3px 0px #0000001A;
    }

.toggle-switch:checked + .toggle-label::after {
    left: 21px;
}

.toggle-switch:checked + .toggle-label {
    background-color: #6951cc;
}


.how-often_container {
    padding-inline: 16px;
}

    .how-often_container p {
        margin-bottom: 5px;
    }

.how-often {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    padding: 32px 40px;
    gap: 16px;
}

    .how-often div {
        font-family: 'Graphik LC Medium', sans-serif;
        color: #323C47;
        max-width: 232px;
        width: 100%;
        height: 40px;
        display: flex;
        justify-content: center;
        align-items: center;
        border: 1px solid #B6BFC6;
        border-radius: 6px;
        font-weight: 500;
        cursor: pointer;
        transition: background-color 0.3s ease, border-color 0.3s ease;
    }

        .how-often div:hover,
        .how-often div.clicked {
            border: 1px solid #8365FF;
            background: #F9F8FF;
        }

.booking-step5_container {
    background: #fff;
    padding-bottom: 220px;
    position: fixed;
    right: 0;
    top: 0;
    height: 100vh;
    z-index: 99;
    width: 560px;
    margin-top: 48px;
}

    .booking-step5_container h2 {
        width:100%;
        position: fixed;
        background: #fff;
        color: #323C47;
        font-family: 'Stratos LC Web', sans-serif;
        text-transform: uppercase;
        font-size: 24px;
        font-weight: 600;
        padding: 32px 40px 10px;
        margin-bottom: 0;
        z-index: 1;
    }

    .booking-step5_container .booking-times {
        margin-top: 90px
    }

    .booking-step5_container .what-time {
        height: 49px;
        padding-inline: 40px;
        margin-block: auto;
        border-top: 1px solid #E6EBEF;
        border-bottom: 1px solid #FFFFFF;
        display: flex;
        align-items: center;
        justify-content: space-between;
        cursor: pointer;
        transition: background 0.3s, border-color 0.3s;
    }

    .booking-step5_container .what-time:hover {
        border-block: 1px solid #6951CC !important;
        background: #f9f8ff !important;
    }

    .booking-step5_container .what-time p {
        font-family: 'Graphik LC Medium', sans-serif;
        width: 150px;
        color: #323C47;
        font-size: 16px;
        font-weight: 500;
        margin-bottom: 0;
    }

    .booking-step5_container .what-time span {
        font-family: 'Graphik LC', sans-serif;
        color: #6951CC;
        font-size: 14px;
        font-weight: 400;
        margin-left: 5px
    }

input[type=radio]#what-time {
    accent-color: #6951CC
}

.step6_title {
    padding: 32px 40px;
    position: fixed;
    z-index: 999;
    height: 70px;
    background: #fff;
    width: 100%
}

.existing-account {
    opacity: 0;
    max-height: 0;
    padding: 0;
    margin: 0;
    transform: translateY(-20px);
    overflow: hidden;
    transition: opacity 0.5s ease, max-height 0.5s ease, padding 0.5s ease, transform 0.5s ease;
    width: 480px;
    background: #FEF6EB;
    border: 1px solid #F3A537;
    border-radius: 12px;
    color: #50606B;
    padding: 0 16px;
    margin: 0 40px 0;
}

.existing-account.show {
    opacity: 1;
    max-height: 200px;
    padding: 16px;
    margin: 24px 40px 0;
    transform: translateY(0);
}

.existing-warning {
    display: flex;
    justify-content: space-between;
}

.existing-warning div {
    display: flex;
    gap: 12px;
}

.existing-warning div h4 {
    font-family: 'Graphik LC Medium', sans-serif;
    color: #323C47;
    font-size: 16px;
    font-weight: 500;
}

.existing-warning img{
    width: 24px;
    height: 24px;
}

.existing-account p {
    color: #50606B;
    font-size: 16px;
    font-weight: 400;
    margin: 0 36px;
}

.account-info {
    position: relative;
}

.account-info_1 {
    background: #fff;
    padding: 62px 40px 16px
}

.account-info_1 h3, .account-info_2 h3, .account-info_3 h3 {
    font-family: 'Graphik LC Medium', sans-serif;
    color: #323C47;
    font-size: 20px;
    font-weight: 500;
    line-height: 26.4px;
    text-align: left;
}

.account-details {
    display: flex;
    justify-content: space-between;
    margin-block: 32px 24px
}

    .account-details .have-account {
        font-family: 'Graphik LC Medium', sans-serif;
        color: #6951CC;
        font-weight: 500;
        cursor: pointer;
    }

    .account-details .have-account:hover, .account-details .have-account:focus {
        color: #21143F;
    }

    .account-details .have-account[disabled] {
        pointer-events: none;
        cursor: not-allowed;
    }

    .account-details .have-account[disabled]:hover {
        color: #6951CC;
    }

.personal-info {
    display: flex;
    gap: 18px;
}

    .personal-info div {
        display: flex;
        flex-direction: column;
        width: 50%;
        min-height: 80px;
        transition: min-height 0.3s ease;
    }

.account-error-input {
    border: 1px solid #E93F3A !important;
    color: #E93F3A !important;
}

    .account-error-text {
        color: #E93F3A;
        margin-bottom: 0;
        margin-top: 6px;
        font-size: 16px;
        line-height: 23.68px;
        transition: opacity 0.3s ease;
    }

    .personal-info_input .phone-wrap input {
        font-family: 'Graphik LC', sans-serif;
        font-weight: 400;
        color: #50606B;
        padding-left: 50px;
    }


    .personal-info div:hover input, .personal-info_input div:hover input {
        border: 1px solid #6951CC;
    }

    .personal-info input:focus, .personal-info_input input:focus {
        border: 1px solid #6951CC;
        background: unset;
        color: #323C47 !important;
        font-weight: 500;
        font-family: 'Graphik LC Medium';
    }

    .personal-info label, .personal-info_input label {
        color: #323C47;
        font-size: 12px;
        margin-bottom: 6px
    }

    .label-focus {
        color: #6951CC !important;
    }
.personal-info_input.country-DE .phone-wrap::before {
    content: '+49';
}
    .personal-info_input .phone-wrap::before {
    content: '+44';
    position: absolute;
    top: 45%;
    left: 9px;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
    font-size: 16px;
    width: fit-content;
    height: 20px;
    color: #50606B;
}

.personal-info_input .phone-focused::before {
    color: #323C47 !important;
    font-weight: 500;
    font-family: 'Graphik LC Medium';
}

.personal-info_input .phone-wrap::after {
    top: 64%;
}

.personal-info_input div {
    position: relative;
}

.personal-info div input, .personal-info_input input {
    font-family: 'Graphik LC', sans-serif;
    width: 100%;
    height: 44px;
    padding: 16px;
    border-radius: 6px;
    border: 1px solid #868F96;
    font-size: 16px;
    font-weight: 400;
    color: #323C47;
    transition: border 0.3s ease, color 0.3s ease, background-color 0.3s;
}

.personal-info div input::placeholder, .personal-info_input input::placeholder {
    color: #50606B;
    font-family: 'Graphik LC', sans-serif;
    font-weight: 400;
}

.personal-info div input:focus::placeholder, .personal-info_input input:focus::placeholder, .booking-notes textarea:focus::placeholder {
    color: transparent;
}

.personal-info_input {
    display: flex;
    flex-direction: column;
    min-height: 85px;
    transition: border 0.3s ease, color 0.3s ease;
}

.personal-info div input::placeholder, .personal-info_input input::placeholder {
    color: #50606B
}

.personal-info p, .personal-info_input p {
    margin-bottom: 0;
}

#togglePassword {
    position: absolute;
    top: 54%;
    right: 10px;
    transform: translateY(-50%);
    cursor: pointer;
    font-size: 18px;
    color: #888
}

.account-info_2 {
    background: #fff;
    padding-block: 32px;
   
}

    .account-info_2 h3 {
        padding-inline: 40px;
        padding-bottom:8px;
    }

    .account-info_2 .dateTime {
        padding-inline: 40px;
    }

    .account-info_2 select {
        position: relative;
        display: block;
        visibility: visible;
        width: -webkit-fill-available;
        height: 44px;
        padding: 8px 40px;
        border-radius: 6px;
        border: 1px solid #868F96 !important;
        margin: 16px 40px 40px;
        appearance: none;
        background-color: white;
        background-image: url('/static/images/new-checkout/location.svg'),
        url('/static/images/new-checkout/select-chevron.svg');
        background-repeat: no-repeat, no-repeat;
        background-position: left 10px center, right 10px center;
        background-size: 20px, 12px;
    }

    .account-info_2 select:hover {
        border: 1px solid #6951CC !important;
    }

    .account-info_2 select:focus {
        border: 1px solid #6951CC !important;
        color: #323C47;
        font-weight: 500;
        font-family: 'Graphik LC Medium';
    }

.booking-promo {
    display: flex;
    justify-content: space-between;
    padding: 26px 40px;
    border-block: 1px solid #E6EBEF;
    margin-block: 10px 40px;
}
.booking-promo-description{
    display:flex;
    flex-direction:column;
    align-items:flex-start !important;
}
.booking-promo div, .booking-date div {
    display: flex;
    align-items: center;
    gap: 6px;
    width: 80%
}

    .booking-promo p {
        color: #6951CC;
        font-weight: 700;
        margin-bottom: 0;
        cursor: pointer;
        user-select: none;
    }
.booking-promo-description #code-description {
    font-family: 'Graphik LC', sans-serif;
    font-weight: 400;
}

.booking-date p {
    color: #323C47;
    margin: 0;
}

.booking-promo div p, .booking-date div p {
    font-family: 'Graphik LC Medium', sans-serif;
    color: #323C47;
    font-weight: 500;
    margin-top: 0;
    font-size:16px;
}

.booking-date {
    padding: 16px 40px;
    border-block: 1px solid #E6EBEF;
    margin-block: 10px 0px;
    display: flex;
    gap: 6px;
}

.booking-date div {
    display: flex;
    align-items: flex-start;
    flex-direction: column;
    gap: 0
}

.booking-date #selected-time {
    font-family: 'Graphik LC', sans-serif;
    font-weight: 400;
}

.account-info_3 {
    background: #fff;
    padding: 24px 40px 160px
}

    .account-info_3 .priority-package {
        width: 100%;
        background: #fff;
        border: 2px solid #6951CC;
        box-shadow: 0px 4px 24px 12px #8365FF1A;
        border-radius: 6px;
        padding: 16px 16px 24px
    }

        .account-info_3 .priority-package div {
            display: flex;
            justify-content: space-between;
            align-items: start
        }
        .account-info_3 .priority-package ul {
            margin-bottom: 0px !important;
        }
        .account-info_3 .priority-package .toggle-container {
            margin-top: 5px
        }

        .account-info_3 .priority-package h3 {
            color: #323C47;
            font-family: 'Stratos LC Web', sans-serif;
            text-transform: uppercase;
            font-size: 24px;
            font-weight: 600
        }

        .account-info_3 .priority-package li {
            color: #323C47;
            line-height: 24px;
            margin-top: 12px;
            list-style-type: none;
            padding-left: 25px;
            background-image: url('/static/images/new-checkout/check.svg');
            background-repeat: no-repeat;
            background-position: 0 5px;
        }

.booking-notes {
    position: relative
}

    .booking-notes textarea {
        font-family: 'Graphik LC', sans-serif;
        color: #323C47;
        width: 100%;
        height: 100px;
        padding: 12px;
        border-radius: 6px;
        border-color: #868F96;
        margin-top: 8px
    }

        .booking-notes textarea::placeholder {
            font-family: 'Graphik LC', sans-serif;
            color: #50606B
        }

    .booking-notes span {
        position: absolute;
        bottom: 12px;
        right: 12px;
        font-size: 11px;
        color: #868F96
    }

.tooltip-container {
    position: relative;
    display: inline-block;
    margin-bottom: 5px;
}

.tooltip {
    visibility: hidden;
    width: 244px;
    height: 112px;
    background-color: #21143f;
    font-family: "Nunito Sans",sans-serif;
    color: #fff;
    text-align: center;
    border-radius: 5px;
    padding: 16px;
    position: fixed !important;
    z-index: 1;
    bottom: 48px;
    right: -53px;
    transform: translateX(-50%);
    opacity: 0;
    transition: opacity .3s;
    text-align: left;
}

    .tooltip::after {
        content: '';
        position: absolute;
        top: 50%;
        right: -14px;
        transform: translateY(-50%);
        border-width: 8px;
        border-style: solid;
        border-color: transparent transparent transparent #3c2066;
    }

.tooltip-container:hover .tooltip {
    visibility: visible;
    opacity: 1
}

.tooltip p:first-child {
    color: #fff !important;
    font-size: 16px;
    font-weight: 700;
    margin-bottom: 8px;
    margin-right: 0;
}

.tooltip p:nth-child(2) {
    color: #fff !important;
    font-size: 16px;
    font-weight: 400;
    margin-right: 0;
}

.booking-total {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    height: 52px;
    padding: 16px;
    border: 1px solid #B6BFC6;
    border-radius: 12px;
    margin: 0;
}

    .booking-total p {
        font-family: 'Nunito sans',sans-serif;
        font-size: 20px;
        font-weight: 400;
        color: #323C47;
        margin-right: 10px;
        margin-bottom: 0;
    }

.booking-step--four .booking-total {
    display: none;
}

.booking-steps_bottom {
    position: fixed;
    bottom: 0;
    width: 100%;
}

.btns-container {
    position: relative;
    display: flex;
    justify-content: center;
    gap: 10px;
    height: 80px;
    background: #fff;
    box-shadow: 0 4px 24px 0 #0000001A;
    width: 560px !important;
    padding: 16px 40px 24px;
    z-index: 99
}

    .btns-container.with-total {
        position: relative;
        flex-direction: column;
        height: unset;
        background: #fff;
        box-shadow: 0 4px 24px 0 #0000001A;
        width: 100% !important;
        padding-block: 16px;
        z-index: 99;
        gap: 16px;
    }

#newFunnelModal .btns-container.with-total {
    position: fixed;
    bottom: 0;
    right: 0;
    width: 560px !important;
}

.booking-step--payment {
    display: none;
    width: 542px !important;
    min-height: 523px;
}

.btns-container .btns {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px
}

.btns-container button {
    font-family: 'Graphik LC', sans-serif;
    height: 40px;
    width: 100%;
    background: #6951CC;
    border-radius: 8px;
    color: #fff;
    font-weight: 500;
    cursor: pointer;
    margin-inline: auto;
    user-select: none;
}

    .btns-container button:hover, .btns-container button:focus, .btns-container a:nth-child(2):hover, .btns-container a:nth-child(2):focus {
        background: #4F3D99
    }

.btns-container a {
    font-family: 'Graphik LC', sans-serif;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 40px;
    width: 235px;
    border-radius: 12px;
    font-weight: 500
}

    .btns-container a:first-child {
        border: 1px solid #6951CC;
        color: #6951CC
    }

    .btns-container a:nth-child(2), .btns-container #bookButton, .btns-container #sixthButton {
        font-family: 'Graphik LC';
        font-weight: 500;
        background: #6951CC;
        color: #fff;
        transition: ease-in-out .3s
    }

    .btns-container a:first-child:hover, .btns-container a:first-child:focus {
        border: 1px solid #4F3D99;
        color: #4F3D99;
        transition: ease-in-out .3s
    }

    .btns-container a:nth-child(2):hover,
    .btns-container #bookButton:hover,
    .btns-container #sixthButton:hover,
    .btns-container a:nth-child(2):focus,
    .btns-container #bookButton:focus,
    .btns-container #sixthButton:focus {
        background: #4F3D99
    }

#step1 {
    display: block;
    background: #FFF;
}

.paymentConfirmBtn {
    margin-inline: 16px;
    width: 100% !important;
}

    #step1Btn.disabled, .fourth-step_btn.disabled, .fifth-step_btn.disabled, .promo-btn.disabled, .paymentConfirmBtn.disabled, #step1Btn.disabled {
        pointer-events: none;
        background: #21143F !important;
        opacity: 56%;
        cursor: not-allowed;
    }

.booking-step_container {
    background: #F1F3F4;
    position: fixed;
    right: 0;
    top: 0;
    height: 100vh;
    background: #fff;
    padding: 58px 0 88px;
    z-index: 999;
    width: 560px;
    margin-top: 50px;
}

.booking-step_container.booking-step--four {
    padding-top: 76px
}

.booking-step-buttons {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center
}

.booking-step-buttons--left {
    justify-content: flex-start
}

.booking-step-buttons .booking-step-button {
    margin-left: 0;
    margin-right: 20px;
    min-width: 76px
}

.booking-step-button:disabled, .booking-step-button--disabled {
    background: gray !important
}

.booking-step-buttons .booking-step-button:last-child {
    margin-right: 0
}

.booking-step-button {
    height: 50px;
    -webkit-border-radius: 5px;
    border-radius: 5px;
    background: #35d073;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    border: none;
    -webkit-box-shadow: none;
    box-shadow: none;
    cursor: pointer;
    margin: 16px auto 0 0;
    -webkit-transition: all .3s ease-in-out;
    -o-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out;
    min-width: 200px
}

.booking-step-button--md {
    max-width: 340px
}

.booking-step-button:hover {
    background: rgba(53,208,115,.8)
}

.booking-step-button--grey {
    border: 2px solid grey;
    background: #fff
}

    .booking-step-button--grey span {
        color: #323c47
    }

    .booking-step-button--grey:hover {
        background: grey
    }

        .booking-step-button--grey:hover span {
            color: #fff
        }

.booking-step-button__text {
    text-transform: uppercase;
    padding: 13px 15px;
    color: #fff;
    font-size: 18px;
    line-height: 24px;
    display: block;
    text-align: center;
    letter-spacing: -.06px;
    font-weight: 700;
    -webkit-transition: all .3s ease-in-out;
    -o-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out
}

.booking-steps-header {
    position: fixed;
    max-width: 100%;
    top: 0;
    width: 100%;
    border-bottom: 1px solid #d5dfe6;
    z-index: 12;
    margin-bottom: 83px;
    background: #fff;
    -webkit-transition: all .3s ease-in-out;
    -o-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out
}

.booking-steps-header--scroll {
    -webkit-box-shadow: 0 0 5px 0 rgba(0,0,0,.3);
    box-shadow: 0 0 5px 0 rgba(0,0,0,.3)
}

    .booking-steps-header--scroll .booking-steps-header__item {
        padding-top: .5%;
        height: 50px
    }

    .booking-steps-header--scroll .booking-steps-header__logo {
        padding-bottom: 5px
    }

.booking-steps-header--top .booking-steps-header__item {
    width: 27%
}

.booking-steps-header__container {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    max-width: 98%;
    margin: 0 auto;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center
}

.booking-steps-header__logo span {
    display: none
}

.booking-steps-header__logo {
    width: 100px;
    font-size: 50px;
    display: flex;
    justify-content: center;
    align-items: center;
    overflow: hidden;
    height: 50px;
    -webkit-transition: all .3s ease-in-out;
    -o-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out
}

.booking-steps-header__items {
    width: 65%;
    margin-left: auto;
    margin-right: auto;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex
}

.booking-steps-header__item {
    width: -webkit-calc(100% / 3);
    width: calc(100% / 3);
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    padding-top: 2%;
    max-height: 100%;
    text-align: center;
    border: 1px solid #d5dfe6;
    border-top: none;
    height: 70px;
    -webkit-transition: all .3s ease-in-out;
    -o-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out;
    position: relative;
    cursor: pointer
}

.booking-steps-header__item--active {
    border-color: #8365ff;
    border-bottom-width: 3px !important;
    border-top: none;
    border-left: none;
    border-right: none
}

    .booking-steps-header__item--active h3 {
        color: #453283;
        font-weight: 800
    }

    .booking-steps-header__item--active .booking-steps-header__step .booking-steps-header__number {
        border: 1px solid #8365ff
    }

    .booking-steps-header__item--active .booking-steps-header__step:after {
        width: 150%;
        height: 150%;
        background-color: #fff;
        z-index: -1;
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%,-50%);
        content: "";
        border-radius: 50%
    }

    .booking-steps-header__item--active .booking-steps-header__number {
        font-size: 16px;
        color: #50606b
    }

.booking-steps-header__item--done .booking-steps-header__number {
    color: #fff
}

.booking-steps-header__item--done .booking-steps-header__step {
    background-color: #8365ff
}

    .booking-steps-header__item--done .booking-steps-header__step:after {
        display: none
    }

.booking-steps-header__item--done .booking-steps-header__step {
    width: 77px;
    height: 38px;
    -webkit-border-radius: 19px;
    border-radius: 19px;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between;
    padding: 0 19px
}

.booking-steps-header__item--done .booking-steps-header__icon {
    display: block
}

.booking-steps-header__title {
    -webkit-transition: all .3s ease-in-out;
    -o-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out;
    font-size: 18px;
    line-height: 14px;
    letter-spacing: -.43px;
    font-family: "Graphik LC",sans-serif;
    color: #50606b
}

    .booking-steps-header__title br {
        display: none
    }

.booking-steps-header__step {
    position: absolute;
    bottom: 0;
    left: 50%;
    -webkit-transform: translate(-50%,50%);
    -ms-transform: translate(-50%,50%);
    transform: translate(-50%,50%);
    background: #fff;
    width: 40px;
    height: 40px;
    border: 1px solid #d5dfe6;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center
}

.booking-steps-header__number {
    font-size: 18px;
    line-height: 24px;
    color: #50606b;
    width: 100%;
    max-width: 30px;
    max-height: 30px;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 50%;
    font-weight: 900;
    font-family: "Graphik LC",sans-serif
}

.booking-steps-header__icon {
    display: none
}

.booking-steps-check {
    padding: 4px 0 20px;
    display: none;
    border: 1px solid #f7e095;
    background-color: #ffffe2
}

.booking-steps-check--active {
    display: block
}

.booking-steps-check--date--hidden {
    position: absolute;
    opacity: 0
}

    .booking-steps-check--date--hidden p {
        font-size: 12px;
        margin-top: 5px
    }

        .booking-steps-check--date--hidden p span {
            font-size: 12px;
            display: inline-block;
            color: inherit;
            margin-left: 15px !important
        }

    .booking-steps-check--date--hidden div {
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: end;
        -webkit-align-items: flex-end;
        -ms-flex-align: end;
        align-items: flex-end
    }

    .booking-steps-check--date--hidden h3 {
        font-size: 25px
    }

    .booking-steps-check--date--hidden span {
        margin-left: auto !important
    }

.booking-steps-check-drop--active {
    display: block !important
}

.booking-steps-check--top {
    z-index: 10;
    border: none;
    padding: 0;
    -webkit-transition: all .3s ease-in-out;
    -o-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out;
    scrollbar-width: none
}

    .booking-steps-check--top::-webkit-scrollbar {
        display: none
    }

    .booking-steps-check--top .booking-steps-check-drop {
        display: none;
        scrollbar-width: none
    }

        .booking-steps-check--top .booking-steps-check-drop::-webkit-scrollbar {
            display: none
        }

    .booking-steps-check--top .booking-steps-check--date--hidden {
        position: relative;
        opacity: 1
    }

    .booking-steps-check--top .booking-steps-check__item {
        position: relative
    }

    .booking-steps-check--top .booking-steps-check__item--top {
        display: block;
        opacity: 1;
        z-index: 20;
        visibility: visible;
        position: relative;
        cursor: pointer
    }

        .booking-steps-check--top .booking-steps-check__item--top::before {
            content: "";
            display: block;
            position: absolute;
            width: 20px;
            height: 20px;
            top: 16px;
            right: 20px;
            -webkit-transform-origin: center center;
            -ms-transform-origin: center center;
            transform-origin: center center;
            -webkit-transition: all .3s ease-in-out;
            -o-transition: all .3s ease-in-out;
            transition: all .3s ease-in-out;
            background: #ffffe2 url(/static/images/arrow_down.svg) no-repeat center center/20px
        }

    .booking-steps-check--top .booking-steps-check__item--reverse::before {
        -webkit-transform: rotate(180deg);
        -ms-transform: rotate(180deg);
        transform: rotate(180deg)
    }

    .booking-steps-check--top .booking-steps-check__item--show {
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        -webkit-box-pack: justify;
        -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
        justify-content: space-between
    }

.booking-steps-check--scroll .booking-steps-check__item--top {
    padding: 0 16px;
    height: 50px
}

.booking-steps-check--mob-content .booking-steps-check__content {
    background: #ffffe2;
    border-bottom: none
}

.booking-steps-check__room_time-count .booking-step__box-row .js-time-text {
    min-width: 65px;
    max-width: 100px
}

.booking-steps-check__room_time-count .booking-step__box-row {
    margin-right: 58px
}

.booking-steps-check--ohidden {
    overflow-x: hidden
}

.booking-steps-check--mobile {
    display: none
}

.booking-steps-check--dropdown {
    z-index: 15;
    position: fixed;
    height: auto;
    padding-top: 20%;
    overflow: initial
}

.booking-steps-check--mobile.booking-steps-check--dropdown {
    top: 0
}

.booking-steps-check--dropdown .booking-steps-check__discount, .booking-steps-check--dropdown .booking-steps-check__promo {
    background: #ffffe2
}

.booking-steps-check--dropdown .booking-steps-check__item {
    border-color: #fff
}

.booking-steps-check--dropdown .booking-steps-check__shopping::before {
    background-color: #ffffe2;
    -webkit-animation: circle 1s ease;
    animation: circle 1s ease;
    -webkit-border-radius: 0;
    border-radius: 0
}

.booking-steps-check__icon {
    position: relative;
    width: 17px;
    height: 17px;
    border: 1px solid #8365ff;
    display: -webkit-inline-box;
    display: -webkit-inline-flex;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    cursor: pointer;
    margin-left: 7px
}

    .booking-steps-check__icon span {
        font-size: 12px !important;
        font-weight: 700;
        color: #8365ff
    }

.booking-steps-check__icon--big {
    border-color: #42337e
}

    .booking-steps-check__icon--big span {
        font-size: 12px;
        color: #42337e;
        font-weight: 700
    }

.booking-steps-check__icon:hover .booking-steps-check__tooltip {
    display: block;
    -webkit-transform-origin: 100% 0;
    -ms-transform-origin: 100% 0;
    transform-origin: 100% 0;
    -webkit-animation: fadeIn .3s ease-in-out;
    animation: fadeIn .3s ease-in-out
}

.booking-steps-check__tooltip {
    display: none;
    position: absolute;
    background: #fff;
    padding: 15px;
    -webkit-border-radius: 3px;
    border-radius: 3px;
    -webkit-box-shadow: 0 0 5px 0 rgba(0,0,0,.5);
    box-shadow: 0 0 5px 0 rgba(0,0,0,.5);
    top: -10px;
    left: 32px;
    min-width: 250px;
    max-width: 300px;
    z-index: 5
}

    .booking-steps-check__tooltip p {
        text-align: left !important
    }

.booking-steps-check__item {
    border-bottom: 1px solid #d5dfe6;
    padding: 16px;
    position: relative;
    -webkit-transition: all .3s ease-in-out;
    -o-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out
}

    .booking-steps-check__item:last-child {
        border-bottom: none;
        -webkit-box-align: end;
        -webkit-align-items: flex-end;
        -ms-flex-align: end;
        align-items: flex-end
    }

    .booking-steps-check__item h2 {
        font-size: 18px;
        line-height: 24px;
        letter-spacing: -.06px;
        font-weight: 800
    }

    .booking-steps-check__item span {
        font-size: 16px;
        line-height: 22px
    }

        .booking-steps-check__item span.color {
            font-weight: 700
        }

        .booking-steps-check__item span.dirty-light {
            color: #35d073
        }

        .booking-steps-check__item span.dirty-medium {
            color: #ffd66c
        }

        .booking-steps-check__item span.dirty-heavy {
            color: #ff786c
        }

        .booking-steps-check__item span.light {
            font-weight: 300;
            font-size: 12px;
            line-height: 19px
        }

.booking-steps-check__item--flex {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center
}

.booking-steps-check__item--blue {
    margin-top: 7px
}

    .booking-steps-check__item--blue span {
        color: #8B7FC1;
        font-size: 14px;
        margin-left: 0 !important
    }

.booking-steps-check__item a {
    color: #35d073;
    font-size: 16px;
    line-height: 22px;
    font-weight: 700;
    text-align: center;
    display: block;
    text-decoration: underline !important;
    padding: 4px 0;
    margin: 0 auto
}

.booking-steps-check__item h3 {
    font-size: 16px;
    font-weight: 700;
    line-height: 22px;
    display: inline-block
}

.booking-steps-check__item span.strong {
    font-size: 24px;
    line-height: 22px;
    font-weight: 800
}

.booking-steps-check__row {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end;
    -webkit-justify-content: flex-end;
    -ms-flex-pack: end;
    justify-content: flex-end;
    margin: 10px 20px;
    cursor: pointer
}

.booking-steps-check__shopping {
    position: relative;
    -webkit-transition: all .3s ease-in-out;
    -o-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out
}

    .booking-steps-check__shopping::before {
        content: "";
        display: block;
        position: absolute;
        width: 50px;
        height: 50px;
        background-color: #ffffe2;
        right: 0;
        top: 0;
        -webkit-transform: translate(25%,-25%);
        -ms-transform: translate(25%,-25%);
        transform: translate(25%,-25%)
    }

.booking-steps-check__shopping-counter {
    position: absolute;
    top: -10px;
    right: -10px;
    width: 20px;
    height: 20px;
    background: #ffe346;
    z-index: 10;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    font-size: 12px;
    font-weight: 600
}

.booking-steps-check__shopping--hide {
    height: 0
}

.booking-steps-check__shopping--reverse::before {
    background-color: rgba(247,224,149,.3);
    -webkit-animation: circle--off 1s ease;
    animation: circle--off 1s ease;
    -webkit-transform: scale(1) translate(25%,-25%);
    -ms-transform: scale(1) translate(25%,-25%);
    transform: scale(1) translate(25%,-25%)
}

.booking-steps-check__shopping--full::before {
    -webkit-transform: scale(15);
    -ms-transform: scale(15);
    transform: scale(15)
}

.booking-steps-check__shopping img {
    z-index: 1;
    position: relative
}

.booking-steps-check__content {
    display: none
}

.booking-steps-check__room {
    width: 100%;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    margin-bottom: 10px
}

    .booking-steps-check__room:last-child {
        margin-bottom: 0
    }

    .booking-steps-check__room .minus, .booking-steps-check__room .plus {
        width: 10px;
        height: 10px;
        opacity: .2
    }

        .booking-steps-check__room .plus::after {
            top: 95% !important
        }

.booking-steps-check__time {
    font-size: 16px;
    line-height: 22px;
    margin-left: 23px;
    white-space: nowrap
}

.booking-steps-check__price {
    font-size: 16px;
    line-height: 22px;
    white-space: nowrap
}

.booking-steps-check__remove {
    position: relative;
    width: 12px;
    height: 12px;
    margin-left: 15px;
    cursor: pointer
}

    .booking-steps-check__remove::after, .booking-steps-check__remove::before {
        content: "";
        display: block;
        position: absolute;
        background: #ff9090;
        width: 100%;
        height: 1px
    }

    .booking-steps-check__remove::before {
        -webkit-transform: rotate(45deg);
        -ms-transform: rotate(45deg);
        transform: rotate(45deg)
    }

    .booking-steps-check__remove::after {
        -webkit-transform: rotate(-45deg);
        -ms-transform: rotate(-45deg);
        transform: rotate(-45deg)
    }

.booking-steps-check__promo {
    position: absolute;
    width: 100%;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    z-index: -1;
    top: 0;
    background-color: rgba(247,224,149,.12);
    opacity: 0;
    margin-top: 5px;
    -webkit-transition: all .3s ease-in-out;
    -o-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out
}

.booking-steps-check__promo--active {
    opacity: 1;
    z-index: 1
}

.booking-steps-check__promo input {
    height: 50px;
    width: 229px;
    border: 1px solid #d5dfe6;
    -webkit-border-radius: 5px;
    border-radius: 5px;
    background-color: #f8f8f8;
    padding-left: 20px;
    font-size: 14px;
    line-height: 19px;
    color: rgba(80,96,107,.4);
    text-transform: uppercase;
    -webkit-transition: all .3s ease-in-out;
    -o-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out
}

    .booking-steps-check__promo input::placeholder {
        color: rgba(80,96,107,.8);
        opacity: 1
    }

    .booking-steps-check__promo input:-ms-input-placeholder {
        color: rgba(80,96,107,.8)
    }

    .booking-steps-check__promo input::-ms-input-placeholder {
        color: rgba(80,96,107,.8)
    }

    .booking-steps-check__promo input:focus {
        background: #fff
    }

.booking-steps-check__promo button {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-shadow: none;
    box-shadow: none;
    border: none;
    cursor: pointer;
    height: 50px;
    width: 78px;
    -webkit-border-radius: 5px;
    border-radius: 5px;
    margin-left: 10px;
    background: #35d073;
    -webkit-transition: all .3s ease-in-out;
    -o-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out
}

    .booking-steps-check__promo button.active-promo {
        background-color: #35d073
    }

    .booking-steps-check__promo button span {
        font-size: 18px;
        display: block;
        letter-spacing: -.06px;
        line-height: 24px;
        text-align: center;
        color: #fff
    }

.booking-steps-check__discount {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between;
    position: absolute;
    width: 93%;
    z-index: -1;
    opacity: 0;
    -webkit-transition: all .3s ease-in-out;
    -o-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out
}

.booking-steps-check__discount--active {
    z-index: 2;
    opacity: 1
}

@-webkit-keyframes circle {
    from {
        -webkit-transform: scale(0);
        transform: scale(0)
    }

    to {
        -webkit-transform: scale(50);
        transform: scale(50)
    }
}

@keyframes circle {
    from {
        -webkit-transform: scale(0);
        transform: scale(0)
    }

    to {
        -webkit-transform: scale(50);
        transform: scale(50)
    }
}

@-webkit-keyframes circle--off {
    from {
        -webkit-transform: scale(50);
        transform: scale(50)
    }

    to {
        -webkit-transform: scale(1) translate(22%,-25%);
        transform: scale(1) translate(22%,-25%)
    }
}

@keyframes circle--off {
    from {
        -webkit-transform: scale(50);
        transform: scale(50)
    }

    to {
        -webkit-transform: scale(1) translate(22%,-25%);
        transform: scale(1) translate(22%,-25%)
    }
}

@-webkit-keyframes fadeIn {
    from {
        opacity: 0
    }

    to {
        opacity: 1
    }
}

@keyframes fadeIn {
    from {
        opacity: 0
    }

    to {
        opacity: 1
    }
}

.booking-steps-faq {
    margin-top: 15px;
    padding-bottom: 100%
}

.booking-steps-faq--mobile {
    display: none
}

.booking-steps-faq__overlay {
    position: fixed;
    background-color: rgba(66,51,126,.5);
    height: 100%;
    z-index: 30;
    width: 100%
}

.booking-steps-faq__title {
    text-align: center;
    font-size: 20px;
    font-weight: 700;
    letter-spacing: -.06px;
    line-height: 27px
}

.booking-steps-faq__question {
    font-weight: 700
}

.booking-steps-faq__items {
    margin-top: 14px
}

    .booking-steps-faq__items a {
        text-decoration: underline !important;
        color: #42337e
    }

.booking-steps-faq__items--what, .booking-steps-faq__items--personal {
    display: none
}

.booking-steps-faq__items--show {
    display: block
}

.booking-steps-faq__items--hide {
    display: none
}

.booking-steps-faq__items--mobile {
    z-index: 3;
    background-color: rgba(66,51,126,.8);
    padding: 10px 30px;
    overflow: hidden;
    min-height: 50px;
    height: -webkit-calc(100% + 20px);
    height: calc(100% + 20px);
    margin-top: 0;
    position: relative
}

    .booking-steps-faq__items--mobile .booking-steps-faq__item {
        width: 80%;
        display: none;
        position: absolute;
        top: 50%;
        -webkit-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
        transform: translateY(-50%);
        left: 30px
    }

        .booking-steps-faq__items--mobile .booking-steps-faq__item p {
            color: #fff;
            font-size: 12px;
            font-weight: 400
        }

.booking-steps-faq__close {
    width: 15px;
    height: 15px;
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
    right: 20px;
    z-index: 4
}

    .booking-steps-faq__close::after, .booking-steps-faq__close::before {
        content: "";
        display: block;
        position: absolute;
        width: 100%;
        height: 2px;
        background: #fff;
        top: 50%
    }

    .booking-steps-faq__close::before {
        -webkit-transform: rotate(45deg);
        -ms-transform: rotate(45deg);
        transform: rotate(45deg)
    }

    .booking-steps-faq__close::after {
        -webkit-transform: rotate(-45deg);
        -ms-transform: rotate(-45deg);
        transform: rotate(-45deg)
    }

.booking-steps-faq__close--darken {
    top: 20px;
    right: 10px
}

    .booking-steps-faq__close--darken::after, .booking-steps-faq__close--darken::before {
        background: #000
    }

.booking-steps-faq__item {
    cursor: pointer
}

.booking-steps-faq__item--active .booking-steps-faq__icon::before {
    -webkit-transform: rotate(180deg);
    -ms-transform: rotate(180deg);
    transform: rotate(180deg)
}

.booking-steps-faq__item--active .booking-steps-faq__content {
    display: block
}

.booking-steps-faq__header {
    margin-bottom: 12px;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    padding-left: 5px
}

.booking-steps-faq__icon {
    width: 12px;
    height: 6px;
    position: relative;
    margin-right: 12px;
    -webkit-transform-origin: center center;
    -ms-transform-origin: center center;
    transform-origin: center center
}

    .booking-steps-faq__icon::before {
        content: "";
        display: block;
        position: absolute;
        width: 0;
        height: 0;
        border-left: 6px solid transparent;
        border-right: 6px solid transparent;
        border-top: 6px solid #323c47;
        margin-top: -2px;
        top: 6px;
        -webkit-transition: all .3s ease-in-out;
        -o-transition: all .3s ease-in-out;
        transition: all .3s ease-in-out
    }

.booking-steps-faq__content {
    display: none;
    margin-bottom: 26px;
    padding: 0 24px
}

.booking-steps-final {
    padding: 50px 19px 100px 35px;
    border: 1px solid #d5dfe6;
    -webkit-border-radius: 0 0 5px 5px;
    border-radius: 0 0 5px 5px;
    background-color: #fff;
    width: 1090px;
    max-width: 100%;
    margin: auto;
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0;
    visibility: hidden;
    z-index: -1;
    -webkit-transition: all .3s ease-in-out;
    -o-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out
}

.booking-steps-final--active {
    position: relative;
    opacity: 1;
    visibility: visible;
    z-index: 1
}

.booking-steps-final__container {
    max-width: 570px
}

.booking-steps-final__content {
    padding-left: 65px;
    position: relative
}

    .booking-steps-final__content::before {
        content: "";
        display: block;
        position: absolute;
        top: 0;
        left: 5px;
        width: 40px;
        height: 40px;
        background: #fff
    }

.booking-steps-final .booking-step__block {
    display: flex
}

.booking-steps-final__img {
    max-height: 386px;
    flex-shrink: 1
}

.booking-steps-final__content::after {
    top: 5px;
    left: 10px;
    content: "";
    display: block;
    position: absolute;
    width: 30px;
    height: 30px;
    background: #35d073
}

.booking-steps-final .booking-step__block {
    margin-bottom: 0;
    padding-bottom: 35px;
    margin-left: 65px
}

    .booking-steps-final .booking-step__block::before {
        border-color: #35d073;
        z-index: 2
    }

.booking-steps-final .booking-step__text {
    font-weight: 300;
    font-size: 18px
}

.booking-steps-final .booking-step__content {
    max-width: 455px
}

    .booking-steps-final .booking-step__content p {
        font-size: 18px;
        letter-spacing: -.06px;
        font-weight: 300
    }

.booking-steps-final .booking-step__content--app {
    margin-top: 10px;
    display: flex;
    max-width: 320px
}

    .booking-steps-final .booking-step__content--app a {
        width: 120px;
        height: 40px;
        margin-right: 10px
    }

.booking-steps-final .booking-step-button {
    margin: 0
}

.booking-step {
    background: #fff;
    margin-right: 30px;
    width: 100%;
    padding: 50px 25px 50px 70px;
    position: absolute;
    opacity: 0;
    z-index: -1;
    visibility: hidden;
    top: -100%
}

.booking-step__content--flex {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

.booking-step__flex {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

.booking-step--three .booking-step__error {
    margin: 20px 0 30px;
    min-height: 57px
}

    .booking-step--three .booking-step__error:last-child {
        margin-bottom: 0
    }

.booking-step--three .booking-step__label {
    display: table
}

.booking-step--active {
    border: 1px solid #d5dfe6;
    position: relative;
    opacity: 1;
    z-index: 11;
    visibility: visible;
    top: 0
}

.booking-step__number {
    position: absolute;
    width: 30px;
    height: 30px;
    background: #fff;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    left: -54px;
    z-index: 3
}

    .booking-step__number::before {
        content: "";
        display: block;
        position: absolute;
        width: 40px;
        height: 40px;
        background: #fff;
        left: -5px;
        top: -5px
    }

    .booking-step__number span {
        font-size: 14px;
        line-height: 19px;
        letter-spacing: -.04px;
        color: #8365ff;
        font-weight: 800;
        border: 2px solid #8365ff;
        padding: 5px;
        position: relative;
        width: 30px;
        height: 30px;
        text-align: center
    }

.booking-step__number--green span {
    border-color: #35d073;
    background: url(/static/images/check_green.svg) no-repeat center center
}

.booking-step__block {
    margin-bottom: 50px;
    position: relative
}

.booking-step__block--hidden {
    display: none
}

    .booking-step__block--hidden.active {
        display: block
    }

.booking-step__block--padding {
    margin-bottom: 0;
    padding-bottom: 50px
}

.booking-step__block::before {
    content: "";
    display: block;
    position: absolute;
    height: 100%;
    width: 3px;
    border-right: 3px dashed rgba(131,101,255,.6);
    left: -40px;
    top: 5px
}

.upholsteryStep, .carpetStep, .cardPreStep {
    opacity: 0;
    visibility: hidden !important;
    max-height: 0;
    transition: .3s
}

    .upholsteryStep.active, .carpetStep.active, .cardPreStep.active {
        opacity: 1;
        visibility: visible !important;
        max-height: 3000px
    }

.booking-step__block--last::before {
    display: none
}

.booking-step__header {
    margin-bottom: 27px
}

.booking-step__header-link {
    font-weight: 700;
    text-decoration: underline !important;
    color: #8365ff;
    -webkit-transition: all .3s ease-in-out;
    -o-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out
}

    .booking-step__header-link:hover {
        text-decoration: none !important
    }

.booking-step__name {
    font-weight: 700;
    letter-spacing: -.06px;
    font-family: "Graphik LC",sans-serif;
    color: #323c47
}

.booking-step__name--sm {
    font-size: 18px;
    line-height: 24px
}

.booking-step__name--md {
    font-size: 20px;
    line-height: 27px
}

.booking-step__name--lg {
    font-size: 28px;
    line-height: 38px
}

.booking-step__name--xs {
    font-size: 18px;
    line-height: 24px;
    letter-spacing: -.06px
}

.booking-step__text {
    font-size: 16px;
    line-height: 22px;
    margin-top: 22px;
    color: #323c47
}

    .booking-step__text a {
        font-weight: 700;
        text-decoration: underline !important;
        color: #8365ff;
        -webkit-transition: all .3s ease-in-out;
        -o-transition: all .3s ease-in-out;
        transition: all .3s ease-in-out
    }

        .booking-step__text a:hover {
            text-decoration: none !important
        }

.booking-step__buttons {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex
}

.booking-step__button {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    position: relative;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-shadow: none;
    box-shadow: none;
    outline: 0;
    background: #fff;
    width: 235px;
    height: 55px;
    border: 1px solid #d5dfe6;
    -webkit-border-radius: 4px;
    border-radius: 4px;
    -webkit-transition: all .3s ease-in-out;
    -o-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out;
    cursor: pointer
}

    .booking-step__button input {
        position: absolute;
        z-index: -1;
        opacity: 0
    }

.booking-step__button-content {
    text-align: center;
    display: block;
    font-size: 16px;
    line-height: 24px;
    letter-spacing: -.06px;
    font-family: "Graphik LC",sans-serif
}

.booking-step__button-cashback {
    padding: 3.75px 10px;
    position: absolute;
    bottom: 0;
    left: 50%;
    min-width: 128px;
    transition: .3s;
    transform: translate(-50%,50%)
}

    .booking-step__button-cashback, .booking-step__button-cashback span {
        background-color: #FFE39F;
        font-size: 15px;
        font-weight: 800;
        letter-spacing: -.11px;
        border-radius: 13.75px;
        line-height: 20px;
        text-align: center;
        color: #544121;
        font-family: "Graphik LC",sans-serif
    }

        .booking-step__button-cashback span {
            padding: 3.75px 10px;
            margin: -3.75px -10px
        }

.subscribe-container .booking-step__ps {
    color: #A2ABB1;
    font-family: "Graphik LC",sans-serif;
    font-size: 12px;
    margin-top: 32px;
    letter-spacing: 0;
    line-height: 16px
}

    .subscribe-container .booking-step__ps a {
        color: #A2ABB1;
        font-weight: 700;
        text-decoration: underline !important
    }

.booking-step__button input + span + .booking-step__button-cashback--sec {
    background-color: #F4C970
}

.booking-step__button input + span + .booking-step__button-cashback--third {
    background-color: #FFBC3E
}

.booking-step__button--active {
    border: 2px solid #8365ff;
    -webkit-box-shadow: 0 0 3px 0 rgba(131,102,255,.14);
    box-shadow: 0 0 3px 0 rgba(131,102,255,.14)
}

    .booking-step__button--active .booking-step__button-cashback {
        color: #544121
    }

    .booking-step__button--active span {
        font-weight: 700;
        color: #42337e
    }

.subscribe-container + .booking-step__choose-item {
    padding: 32px 0 16px
}

.booking-step__cards {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

.booking-step__card {
    height: 300px;
    -webkit-flex-basis: 48%;
    -ms-flex-preferred-size: 48%;
    flex-basis: 48%;
    width: 48%;
    background-color: #fdfdfd;
    border: 1px solid #d5dfe6;
    -webkit-border-radius: 3px;
    border-radius: 3px;
    padding: 25px 60px;
    margin-right: 2%;
    margin-bottom: 22px;
    cursor: pointer;
    position: relative;
    -webkit-transition: all .3s ease-in-out;
    -o-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out
}

.booking-step__card--active {
    border: 2px solid #8365ff;
    background: rgba(131,101,255,.05)
}

.booking-step__card:nth-child(2n) {
    margin-right: 0
}

.booking-step__card input {
    position: absolute;
    z-index: -1;
    opacity: 0
}

    .booking-step__card input:checked ~ .booking-step__card-header::before {
        border-color: #8365ff
    }

    .booking-step__card input:checked ~ .booking-step__card-header::after {
        opacity: 1
    }

.booking-step__card .booking-step__button-cashback {
    top: 0;
    left: 60px;
    bottom: auto;
    transform: translateY(-50%)
}

    .booking-step__card .booking-step__button-cashback:after {
        position: absolute;
        width: 110%;
        height: 51%;
        top: 0;
        left: 50%;
        transform: translateX(-50%);
        background-color: #fff;
        z-index: -1;
        content: ""
    }

.booking-step__card-icon {
    position: absolute;
    right: 17.5px;
    top: -17.5px;
    z-index: 2;
    background: #fff
}

.booking-step__card-header {
    margin-bottom: 17px;
    position: relative;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between
}

    .booking-step__card-header::after, .booking-step__card-header::before {
        content: "";
        display: block;
        position: absolute;
        -webkit-transition: all .3s ease-in-out;
        -o-transition: all .3s ease-in-out;
        transition: all .3s ease-in-out
    }

    .booking-step__card-header::before {
        width: 18px;
        height: 18px;
        background: #fff;
        border: 2px solid #d5dfe6;
        left: -37px;
        -webkit-transform: translateY(25%);
        -ms-transform: translateY(25%);
        transform: translateY(25%)
    }

    .booking-step__card-header::after {
        width: 8px;
        height: 8px;
        background-color: #8365ff;
        top: 10px;
        left: -32px;
        opacity: 0
    }

.booking-step__card-name {
    font-size: 22px;
    font-weight: 700;
    letter-spacing: -.07px;
    line-height: 30px
}

.booking-step__card-price {
    font-size: 18px;
    line-height: 24px;
    font-weight: 700;
    color: #8365ff;
    margin-top: 5px
}

.booking-step__card-item {
    list-style-type: disc;
    margin-bottom: 12px;
    font-size: 16px;
    line-height: 19px;
    letter-spacing: -.05px
}

.booking-step__card-item-nodisk {
    list-style-type: none;
    display: flex;
    justify-content: space-between;
    width: 100%;
    padding-bottom: 6px;
    margin-bottom: 6px;
    border-bottom: 1px solid #eee
}

.booking-step__card-item:last-child {
    margin-bottom: 0
}

.booking-step__card-item-right__block {
    display: flex;
    align-items: center
}

.booking-step__card-item-left__block {
    display: flex;
    flex-direction: column
}

    .booking-step__card-item-left__block span:first-child {
        color: #4f398c;
        font-weight: 700
    }

    .booking-step__card-item-left__block span:last-child {
        font-size: 13px
    }

.booking-step__card-item-nodisk:last-child {
    border-bottom: none
}

.booking-step__card-offer {
    font-size: 15px;
    line-height: 19px;
    letter-spacing: -.09px;
    color: #00d468
}

.booking-step__row {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex
}

.booking-step__time {
    margin-left: 75px
}

    .booking-step__time .time_pick {
        height: 180px;
        width: 177px
    }

.booking-step__time-text {
    margin-top: 16px;
    margin-left: 13px;
    font-weight: 300;
    font-size: 16px;
    letter-spacing: -.05px;
    line-height: 22px;
    display: block
}

.booking-step__time-link {
    font-weight: 300;
    font-size: 15px;
    font-style: italic;
    letter-spacing: -.05px;
    line-height: 22px;
    margin-top: 16px;
    margin-left: 13px;
    max-width: 215px
}

    .booking-step__time-link a {
        font-weight: 700;
        text-decoration: underline !important;
        color: #8365ff;
        -webkit-transition: all .3s ease-in-out;
        -o-transition: all .3s ease-in-out;
        transition: all .3s ease-in-out
    }

        .booking-step__time-link a:hover {
            text-decoration: none !important
        }

.booking-step__timepicker {
    position: absolute;
    z-index: -1;
    opacity: 0
}

.booking-step__error {
    margin-top: 25px;
    padding: 18px 16px 18px 37px;
    border: 1px solid #f7e095;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    flex-direction: column;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: flex-start;
    -webkit-border-radius: 4px;
    border-radius: 4px;
    background-color: rgba(247,224,149,.12);
    position: relative;
    height: auto
}

.booking-step__error--self {
    margin-bottom: 25px
}

.booking-step__error_flex {
    display: flex;
    align-items: center;
    flex-direction: row;
    justify-content: space-between
}

    .booking-step__error_flex .booking-step__table {
        margin-top: 0
    }

    .booking-step__error_flex .booking-step__error-text {
        margin-top: 0;
        max-width: 290px
    }

    .booking-step__error_flex .booking-step__table {
        max-width: 400px
    }

    .booking-step__error_flex .booking-step__table {
        max-width: 350px
    }

.booking-step__error::before {
    content: "";
    display: block;
    position: absolute;
    width: 11px;
    height: calc(100% - 6px);
    background-color: rgba(244,215,113,.7);
    top: 3px;
    left: 4px;
    -webkit-border-radius: 1.6px;
    border-radius: 1.6px
}

.booking-step__error-text {
    font-size: 16px;
    line-height: 22px;
    font-style: italic;
    color: #50606b
}

    .booking-step__error-text a {
        font-weight: 700;
        text-decoration: underline !important;
        color: #8365ff;
        -webkit-transition: all .3s ease-in-out;
        -o-transition: all .3s ease-in-out;
        transition: all .3s ease-in-out
    }

        .booking-step__error-text a:hover {
            text-decoration: none !important
        }

.booking-step__table {
    margin-top: 10px;
    width: 100%
}

.booking-step__table_tr {
    border-bottom: 1px solid rgba(151,151,151,0.3)
}

    .booking-step__table_tr:last-child {
        border-bottom: none
    }

.booking-step__table_td {
    padding: 5px 0;
    font-family: 'Graphik LC';
    font-weight: 700;
    font-size: 13px;
    line-height: 19px;
    color: #494949
}

    .booking-step__table_td:nth-child(2) {
        text-align: right;
        color: #8365FF
    }

.booking-step__boxes {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

.booking-step__rooms {
    padding-bottom: 78px
}

.booking-step__rooms--pb-0 {
    padding-bottom: 0
}

.booking-step__box {
    margin-right: 12px;
    margin-bottom: 12px;
    position: relative
}

.booking-step__box-checkbox {
    position: absolute;
    z-index: -1;
    opacity: 0
}

    .booking-step__box-checkbox:checked ~ .booking-step__box-label {
        border: 2px solid #8365ff;
        background: rgba(131,101,255,.05)
    }

        .booking-step__box-checkbox:checked ~ .booking-step__box-label .about_price {
            background-color: #fff
        }

.booking-step__box-label {
    width: 335px;
    height: 73px;
    border: 1px solid #d5dfe6;
    -webkit-border-radius: 5px;
    border-radius: 5px;
    background-color: #fdfdfd;
    -webkit-transition: all .3s ease-in-out;
    -o-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    padding: 20px 14px;
    position: relative
}

    .booking-step__box-label label {
        position: absolute;
        z-index: 0;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        cursor: pointer;
        display: none
    }

.booking-step__box-label--small {
    height: auto;
    padding: 11px 13px
}

    .booking-step__box-label--small .about_price {
        margin-left: 4px
    }

    .booking-step__box-label--small .booking-step__box-title {
        flex-direction: row;
        align-items: center
    }

.booking-step__box-image {
    margin-right: 10px;
    width: 48px;
    height: 34px
}

.booking-step__box-info > img {
    z-index: 2;
    position: relative;
    cursor: pointer
}

.booking-step__box-info .hidden-info:after {
    width: 10px;
    height: 10px;
    background-color: #F0F0F0;
    transform: translateY(-50%) rotate(45deg);
    position: absolute;
    content: "";
    right: 10px;
    top: 1px;
    border-radius: 2px
}

.booking-step__box-info .hidden-info {
    background-color: #F0F0F0;
    max-width: 285px;
    min-width: 300px;
    border-radius: 4px;
    position: absolute;
    visibility: hidden;
    opacity: 0;
    top: 100%;
    right: -6.5px;
    padding: 11px;
    transition: .3s;
    color: #374355;
    font-family: "Source Sans Pro",sans-serif;
    font-size: 12px;
    transform: translateY(5px);
    letter-spacing: -.04px;
    line-height: 15px
}

.booking-step__box-info:hover .hidden-info {
    opacity: 1;
    visibility: visible
}

.booking-step__box-info.info-hidden {
    background-color: #fff;
    width: 17px;
    height: 17px;
    position: absolute;
    right: 0;
    top: 0;
    transform: translate(7px,-7px);
    z-index: 2
}

.booking-step__box-title {
    font-size: 16px;
    line-height: 19px;
    font-weight: 700;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    justify-content: center;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column
}

.upholsteryStep .booking-step__box-title {
    flex-grow: 1;
    display: flex
}

    .upholsteryStep .booking-step__box-title span.about_price {
        margin-left: auto;
        margin-right: 8px
    }

.booking-step__box-title .about_price {
    color: #332855;
    font-family: "Graphik LC",sans-serif;
    font-size: 11px;
    letter-spacing: 0;
    padding: 2px 6px;
    background-color: #F1F3F4;
    max-width: 36px;
    display: flex;
    justify-content: center;
    line-height: 15px;
    text-align: center;
    border-radius: 5px;
    text-overflow: ellipsis
}

.booking-step__box-title .about_price--2 {
    justify-content: flex-start;
    max-width: none;
    background: none;
    padding: 0
}

    .booking-step__box-title .about_price--2 span {
        background-color: #F1F3F4;
        padding: 2px 6px
    }

.booking-step__box-title .about_times {
    font-size: 12px;
    line-height: 16px;
    font-weight: 400;
    letter-spacing: .38px;
    color: #332855
}

.booking-step__box-title .about_times--highlight {
    color: #8365ff;
    font-weight: 700
}

.booking-step__box-row {
    position: relative;
    z-index: 1;
    margin-left: auto;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center
}

    .booking-step__box-row input, .booking-step__box-row p.js-time-text {
        border: none;
        background: 0 0;
        -webkit-box-shadow: none;
        box-shadow: none;
        outline: 0;
        min-width: 25px;
        max-width: 40px;
        text-align: center;
        color: #50606b;
        font-size: 18px;
        line-height: 24px;
        font-weight: 800;
        margin: 0 5px
    }

.booking-steps__info--second .booking-step__box-row input, .booking-steps__info--second .booking-step__box-row p.js-time-text {
    font-size: 16px;
    font-weight: 700;
    letter-spacing: 0;
    line-height: 22px
}

.booking-steps__info--second .booking-step__box-row {
    margin-right: 16px
}

.booking-step__box-row p.js-time-text {
    min-width: 40px;
    max-width: 70px
}

.booking-steps-check-drop .booking-step__box-row p.js-time-text {
    margin: 0 10px
}

.booking-step__box-row button, .minus-btn, .plus-btn {
    width: 14px;
    height: 14px;
    display: flex;
    align-items: center;
    position: relative;
    cursor: pointer;
}

    .booking-step__box-row button:nth-child(3)::after, .minus-btn::after, .minus-btn::before, .plus-btn::after {
        content: url('/static/images/new-checkout/plus.svg');
        display: block;
        position: absolute;
        width: 100%;
        height: 100%;
        background: #F1F3F4;
        /*        background-image: url('/static/images/new-checkout/plus.svg');
        background-size: contain;
        background-repeat: no-repeat;*/
        top: -1px;
        left: -1px;
        -webkit-transform: none;
        -ms-transform: none;
        transform: none;
    }

    .plus-btn::after {
        top: -1px;
        left: -3px;
    }

    .booking-step__box-row button::before {
        height: 0
    }

    .minus-btn::before {
        content: "";
        display: block;
        position: absolute;
        width: 100%;
        height: 2px;
        top: 50%;
        background: #50606B;
        transform: translateY(-50%);
        left: 0;
    }

    .plus-btn:focus {
        outline: none;
    }

.booking-step__choose {
    margin-top: 60px
}

.booking-step__choose-item {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    margin-bottom: 16px;
    position: relative
}

.booking-steps__choose-carpet-upholstery {
    background: #D5CAFF;
    max-width: 682px;
    border: 1px solid #8365FF;
    border-radius: 4px;
    padding: 5px;
    font-size: 18px;
    font-weight: 700
}

    .booking-steps__choose-carpet-upholstery .booking-step__radios label input:checked ~ span {
        background-color: #453283;
        color: #fff
    }

.booking-step__choose-item--wrap {
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

.booking-step__choose-item--purple {
    background-color: #f2effe;
    padding: 6px;
    margin-left: -6px;
    border-radius: 5px
}

.booking-step__choose-name {
    margin-left: 25px;
    font-size: 16px;
    line-height: 19px;
    letter-spacing: .5px
}

    .booking-step__choose-name a {
        font-weight: 700;
        text-decoration: underline !important;
        color: #8365ff;
        -webkit-transition: all .3s ease-in-out;
        -o-transition: all .3s ease-in-out;
        transition: all .3s ease-in-out
    }

        .booking-step__choose-name a:hover {
            text-decoration: none !important
        }

.booking-step__choose-name--strong {
    font-weight: 700
}

    .booking-step__choose-name--strong span {
        font-weight: 400;
        color: #8365ff;
        white-space: nowrap
    }

.booking-step__choose .booking-step__error {
    margin: 48px 0
}

.booking-step__choose-msg {
    -webkit-flex-basis: 100%;
    -ms-flex-preferred-size: 100%;
    flex-basis: 100%;
    margin-top: 20px;
    position: relative;
    display: none
}

.booking-step__choose-msg-block {
    max-width: 685px;
    position: relative
}

.booking-step__choose-msg--active {
    display: block
}

.booking-step__choose-msg::after, .booking-step__choose-msg::before {
    content: "";
    display: block;
    position: absolute
}

.booking-step__choose-msg::before {
    top: -10px;
    left: 45px;
    content: "";
    display: block;
    position: absolute;
    width: 0;
    height: 0;
    border-left: 12px solid transparent;
    border-right: 12px solid transparent;
    border-bottom: 12px solid #8365ff;
    margin-bottom: -5px
}

.booking-step__choose-msg::after {
    top: -8px;
    left: 42px;
    content: "";
    display: block;
    position: absolute;
    width: 0;
    height: 0;
    border-left: 15px solid transparent;
    border-right: 15px solid transparent;
    border-bottom: 15px solid #fff;
    margin-bottom: -6px
}

.booking-step__choose-textarea {
    width: 685px;
    resize: none;
    min-height: 130px;
    padding: 16px 18px;
    font-size: 16px;
    line-height: 22px;
    letter-spacing: -.05px;
    color: #50606b;
    border: 2px solid #8365ff;
    background-color: #fff;
    -webkit-border-radius: 4px;
    border-radius: 4px
}

.booking-step__radios {
    min-width: 121px;
    height: 44px;
    -webkit-border-radius: 5px;
    border-radius: 5px;
    background-color: #fdfdfd;
    border: 1px solid #d5dfe6;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

    .booking-step__radios label {
        position: relative;
        width: 50%;
        height: 100%;
        text-align: center;
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        cursor: pointer
    }

        .booking-step__radios label span {
            width: 100%;
            height: 100%;
            display: block;
            font-size: 14px;
            font-weight: 700;
            line-height: 40px;
            border: 2px solid transparent;
            -webkit-transition: all .3s ease-in-out;
            -o-transition: all .3s ease-in-out;
            transition: all .3s ease-in-out
        }

        .booking-step__radios label input {
            position: absolute;
            z-index: -1;
            opacity: 0
        }

            .booking-step__radios label input:checked ~ span {
                -webkit-border-radius: 5px;
                border-radius: 5px;
                background-color: #fff;
                -webkit-box-shadow: 0 0 4px 0 rgba(131,102,255,.14);
                box-shadow: 0 0 4px 0 rgba(131,102,255,.14);
                border-color: #8365ff;
                color: #8365ff
            }

.booking-step__level {
    width: 682px;
    height: 54px;
    border: 1px solid #d5dfe6;
    -webkit-border-radius: 5px;
    border-radius: 5px;
    background-color: #fdfdfd;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex
}

.booking-step__level-item {
    position: relative;
    width: -webkit-calc(100% / 3);
    width: calc(100% / 3);
    text-align: center;
    height: 100%
}

    .booking-step__level-item input {
        position: absolute;
        z-index: -1;
        opacity: 0
    }

    .booking-step__level-item.disabled {
        pointer-events: none
    }

        .booking-step__level-item.disabled span {
            color: #D5DFE6
        }

.booking-step__level-item_with-lock {
    position: relative
}

    .booking-step__level-item_with-lock:before {
        content: '';
        position: absolute;
        left: -11px;
        top: 50%;
        transform: translateY(-50%);
        margin: 0 auto;
        width: 22px;
        height: 22px;
        background-image: url(/static/images/lock.png);
        background-size: 12px 16px;
        background-position: center center;
        background-repeat: no-repeat;
        background-color: #fff
    }

.booking-step__level-item input:checked ~ label.light {
    -webkit-box-shadow: 0 0 4px 0 rgba(53,208,115,0.17);
    box-shadow: 0 0 4px 0 rgba(53,208,115,0.17);
    border-color: #35D073;
    border-radius: 5px
}

    .booking-step__level-item input:checked ~ label.light span {
        color: #35D073
    }

.booking-step__level-item input:checked ~ label.medium {
    -webkit-box-shadow: 0 0 4px 0 rgba(255,214,108,.17);
    box-shadow: 0 0 4px 0 rgba(255,214,108,.17);
    border-color: #ffd66c
}

    .booking-step__level-item input:checked ~ label.medium span {
        color: #ffd66c
    }

.booking-step__level-item input:checked ~ label.heavy {
    -webkit-box-shadow: 0 0 4px 0 rgba(255,120,108,.17);
    box-shadow: 0 0 4px 0 rgba(255,120,108,.17);
    border-color: #ff786c
}

    .booking-step__level-item input:checked ~ label.heavy span {
        color: #ff786c
    }

.booking-step__level-item label {
    border: 2px solid transparent;
    -webkit-border-radius: 5px;
    border-radius: 5px;
    background-color: #fff;
    -webkit-transition: all .3s ease-in-out;
    -o-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out;
    height: 100%;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    cursor: pointer;
    width: 100%
}

    .booking-step__level-item label span {
        font-size: 18px;
        font-weight: 700;
        line-height: 24px;
        letter-spacing: -.06px;
        -webkit-transition: all .3s ease-in-out;
        -o-transition: all .3s ease-in-out;
        transition: all .3s ease-in-out
    }

.booking-step__label {
    display: block;
    margin-bottom: 15px;
    margin-right: 15px;
    position: relative
}

.booking-step__label--full {
    -webkit-flex-basis: 100%;
    -ms-flex-preferred-size: 100%;
    flex-basis: 100%
}

.booking-step__label-password {
    position: absolute;
    width: 24px;
    height: 16px;
    display: block;
    top: 55%;
    right: 10px;
    cursor: pointer
}

    .booking-step__label-password.close-eye {
        background: url(/static/images/eye_closed.svg) !important
    }

    .booking-step__label-password.open-eye {
        background: url(/static/images/eye_open.svg)
    }

.booking-step__label-row {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center
}

    .booking-step__label-row span {
        font-size: 18px !important;
        line-height: 24px !important
    }

    .booking-step__label-row input {
        width: 60px !important;
        margin-right: 11px
    }

        .booking-step__label-row input:last-child {
            margin-left: 11px
        }

.booking-step__label-phonecode {
    bottom: 0;
    left: 12px;
    position: absolute;
    display: flex;
    align-items: center;
    height: 55px;
    line-height: 55px;
    font-size: 18px;
    font-weight: 700;
    letter-spacing: -.06px;
    color: #50606b
}

    .booking-step__label-phonecode ~ input {
        padding-left: 58px !important
    }

.booking-step__label--cvc input {
    width: 80px !important
}

.booking-step__label span {
    font-size: 14px;
    line-height: 19px;
    letter-spacing: -.34px;
    display: block;
    margin-bottom: 5px;
    color: #50606b
}

.booking-step__label input, .booking-step__label textarea {
    padding: 15px 12px;
    width: 300px;
    height: 55px;
    border: 1px solid #a5b3bc;
    -webkit-border-radius: 3.75px;
    border-radius: 3.75px;
    background-color: #fdfdfd;
    -webkit-box-shadow: none;
    box-shadow: none;
    font-size: 18px;
    letter-spacing: -.06px;
    color: #50606b;
    -webkit-transition: all .3s ease-in-out;
    -o-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out
}

    .booking-step__label input:disabled, .booking-step__label textarea:disabled {
        cursor: default;
        background-color: rgba(170,170,170,.2);
        border-color: rgba(118,118,118,0.3)
    }

    .booking-step__label input:focus, .booking-step__label textarea:focus {
        font-weight: 700;
        color: #323c47;
        border-color: #8365ff;
        -webkit-box-shadow: 0 0 3px 0 rgba(131,102,255,.14);
        box-shadow: 0 0 3px 0 rgba(131,102,255,.14)
    }

.booking-step__label textarea {
    width: 615px;
    min-height: 100px;
    padding-bottom: 25px
}

.booking-step--three .booking-step__label textarea {
    width: 675px
}

.booking-step__card-block {
    border: 1px solid #d5dfe6;
    margin-bottom: 12px;
    -webkit-transition: all .3s ease-in-out;
    -o-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out
}

    .booking-step__card-block:first-child {
        position: relative;
        padding: 50px 15px 30px
    }

        .booking-step__card-block:first-child::before {
            display: none;
        }

.booking-step__card-block--checked {
    border: 1px solid #8365ff;
    background: rgba(131,101,255,.05)
}

.booking-step__card-block--checkbox {
    width: 30px;
    height: 30px;
    border: 2px solid #8365ff;
    -webkit-border-radius: 5px;
    border-radius: 5px;
    display: block;
    -webkit-transition: all .3s ease-in-out;
    -o-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out;
    background-color: #fff;
    margin-right: 15px;
    position: absolute;
    cursor: pointer
}

    .booking-step__card-block--checkbox::before {
        content: "";
        display: block;
        position: absolute;
        width: 19px;
        height: 13px;
        background: url(/static/images/check.svg) no-repeat center center;
        top: 50%;
        left: 50%;
        -webkit-transform: translate(-50%,-50%);
        -ms-transform: translate(-50%,-50%);
        transform: translate(-50%,-50%);
        opacity: 0;
        -webkit-transition: all .3s ease-in-out;
        -o-transition: all .3s ease-in-out;
        transition: all .3s ease-in-out
    }

.booking-step--six .booking-step__card-block {
    border: none;
}

.booking-step--six .booking-step__card-block--checkbox {
    width: 24px;
    height: 24px;
    margin: 2px 8px 0 0;
}

.booking-step__card-block--small {
    /*    padding: 16px 95px 42px 18px;*/
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        position: relative
    }

    .booking-step__card-block--small input {
        position: absolute;
        z-index: -1;
        opacity: 0
    }

    .booking-step__card-block--small #privacy_checkbox, .booking-step__card-block--small #info_checkbox {
        z-index: 1;
        width: 24px;
        height: 24px;
        cursor: pointer;
    }

    .booking-step__card-block--small input:checked ~ .booking-step__card-block--checkbox {
        background-color: #8365ff
    }

        .booking-step__card-block--small input:checked ~ .booking-step__card-block--checkbox::before {
            opacity: 1
        }

    .booking-step__card-block--small p {
        font-family: 'Graphik LC', sans-serif;
        margin-left: 34px;
        margin-bottom: 0;
        font-size: 14px;
        font-weight: 400;
        line-height: 16.8px;
    }

        .booking-step__card-block--small p a {
            font-family: 'Graphik LC', sans-serif;
            color: #8365FF !important;
            text-decoration: underline !important
        }

            .booking-step__card-block--small p a:hover {
                text-decoration: none !important
            }

.booking-step__level-info {
    position: relative;
    margin-top: 15px;
    margin-bottom: 15px
}

    .booking-step__level-info div {
        opacity: 0;
        display: none;
        visibility: hidden;
        -webkit-transition: .3s ease;
        -moz-transition: .3s ease;
        -ms-transition: .3s ease;
        -o-transition: .3s ease;
        transition: .3s ease;
        z-index: -1
    }

        .booking-step__level-info div.active {
            z-index: 1;
            visibility: visible;
            opacity: 1;
            display: block
        }

    .booking-step__level-info ul li {
        list-style: disc;
        font-size: 16px;
        line-height: 23px;
        letter-spacing: .5px
    }

.green-color p, .green-color span, .dirt-level span {
    color: #35D073
}

.booking-step__level-info--light ul li {
    color: #9cf67c
}

.booking-step__level-info--medium ul li {
    color: #ffd66c
}

.booking-step__level-info--heavy ul li {
    color: #ff786c
}

.booking-step__level-info ul li p {
    color: #323c47
}

.booking-step__card-container {
    width: 300px;
    margin: 42px auto 66px
}

.booking-step__card-container--flex {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

.booking-steps {
    font-family: 'Graphik LC', sans-serif;
    color: #323c47;
    background: #F1F3F4;
    overflow: hidden;
    position: relative;
    max-width: 100%;
    min-height: 100vh;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column
}

.booking-steps--hidden {
    height: 100vh;
    overflow: hidden !important
}

.booking-steps__container {
    margin: 0 auto;
    overflow-y: auto;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex
}

.booking-steps-check-rates span:not(:first-child) {
    margin-left: 5px
}

.booking-steps__items {
    width: 100%;
    font-family: 'Graphik LC', sans-serif;
}

.booking-steps__info {
    overflow: hidden;
    width: 30%;
    margin-left: 2%;
    height: 100%;
    max-width: 560px;
    -webkit-transition: all .3s ease-in-out;
    -o-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out
}

.booking-steps__info--scroll {
    position: fixed;
    top: 10%;
    right: 1.2%
}

    .booking-steps__info--scroll .booking-steps__info--container {
        position: absolute;
        overflow-y: scroll;
        overflow-x: hidden;
        width: 100%;
        height: 100%;
        top: 0;
        left: 0;
        scrollbar-width: none
    }

.booking-steps__info--container {
    overflow-y: auto;
    height: calc(100vh - 120px)
}

    .booking-steps__info--container::-webkit-scrollbar {
        display: none
    }

.booking-steps__form {
    width: 100%;
    /*position: fixed;
    top: 0;
    right: 0;
    width: 560px;*/
    /* height: 100vh; */
    /*background: #fff;
    z-index: 99;*/
}

.booking-steps__form--none {
    display: none
}

.counter {
    position: absolute;
    font-size: 14px;
    font-style: italic;
    letter-spacing: -.34px;
    line-height: 19px;
    bottom: 10px;
    right: 10px;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    color: rgba(80,96,107,.39)
}

    .counter p {
        padding: 0 2px
    }

.input-error {
    border-color: red !important;
    color: red !important
}

.oHidden {
    bottom: 0;
    left: 0;
    position: fixed;
    right: 0;
    top: 0
}

.overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 25;
    background-color: rgba(131,101,255,0.1);
    display: none
}

.error-modal {
    position: fixed;
    top: 50%;
    left: 50%;
    opacity: 0;
    visibility: hidden;
    transform: translateX(-50%) translateY(-50%);
    width: calc(100% - 30px);
    max-width: 600px;
    background-color: #fff;
    z-index: 31;
    border-radius: 12px;
    text-align: center;
    transition: all .4s;
    padding: 35px 15px
}

    .error-modal.show {
        opacity: 1;
        visibility: visible
    }

    .error-modal p {
        color: #737373;
        padding: 0 15px
    }

.error-modal__close {
    position: absolute;
    top: -15px;
    right: -15px;
    width: 30px;
    background: #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 30px;
    transform: rotate(45deg);
    cursor: pointer;
    font-size: 35px;
    font-weight: 100;
    font-family: serif;
    color: #323c47;
    transition: text-shadow .4s
}

.modal-waiting {
    position: fixed;
    display: flex;
    flex-direction: column;
    top: 30%;
    left: 50%;
    transform: translateX(-50%);
    z-index: 35;
    max-width: 550px;
    width: calc(100% - 30px);
    border-radius: 13px;
    padding: 37px 15px;
    font-size: 33.5px;
    text-align: center;
    visibility: hidden;
    opacity: 0;
    color: #fff;
    font-family: "Graphik LC",sans-serif;
    background-color: rgba(66,51,126,.9);
    transition: opacity .4s,visibility .4s
}

.top-error {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 35;
    background-color: #fff;
    box-shadow: 0 0 24px 0 rgba(0,0,0,0.16);
    transform: translateY(-100%);
    transition: .4s
}

    .top-error.show {
        transform: translateY(0)
    }

    .top-error .container {
        display: flex;
        align-items: center;
        justify-content: space-between;
        min-height: 56px;
        padding: 10px 15px
    }

    .top-error p {
        padding-left: 30px;
        color: #453283;
        font-family: "Graphik LC",sans-serif;
        font-size: 13px;
        letter-spacing: -.04px;
        line-height: 18px
    }

.top-error__left {
    display: flex;
    align-items: center
}

.top-error__close {
    margin-left: 50px;
    background-image: url(/static/images/close-button.svg);
    background-size: 100% 100%;
    width: 15px;
    height: 15px;
    transition: .4s
}

    .top-error__close:hover {
        opacity: .8
    }

.top-error__left img {
    max-width: 19px
}

.modal-waiting.show {
    visibility: visible;
    opacity: 1
}

.modal-waiting img {
    height: 30px;
    width: 30px;
    margin: auto auto 10px
}

.payment_form {
    max-width: 600px;
    margin: 0 auto
}

    .payment_form label {
        position: relative;
        margin-right: 16px;
        margin-bottom: 22px;
        color: initial;
        font-family: "Source Sans Pro",sans-serif;
        line-height: 20px;
        display: inline-block;
        font-size: 16px
    }

    .payment_form .card_name_wrap {
        display: block;
        width: 300px
    }

    .payment_form .card_name {
        width: 100%
    }

    .payment_form .card_cvv, .payment_form .card_expiry {
        width: 80px
    }

    .payment_form .card_number_wrap {
        width: 300px
    }

    .payment_form .card_number {
        letter-spacing: 3px
    }

    .payment_form .card_cvv, .payment_form .card_expiry, .payment_form .card_number {
        -moz-appearance: none;
        appearance: none;
        border: 1px solid #b7b7b7;
        border-radius: 6px;
        padding: 10px;
        color: #312852;
        outline-color: #f8e71c;
        -webkit-appearance: none
    }

    .payment_form .card_cvv, .payment_form .card_expiry, .payment_form .card_number, .payment_form input {
        display: block;
        min-height: 38px;
        margin-top: 5px;
        font-family: "Source Sans Pro",sans-serif;
        font-size: 18px;
        line-height: 23px;
        background-color: #FFF
    }

.payment_check .check label, .payment_check .lock {
    font-family: "Source Sans Pro",sans-serif;
    font-size: 16px;
    line-height: 24px;
    color: #354052
}

.card_cvv.not_valid, .card_expiry.not_valid, .card_number.not_valid {
    border: 1px solid red
}

.payment_form .card_number_img {
    position: absolute;
    right: 15px;
    bottom: 9px;
    width: 37px;
    height: 22px;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat
}

.payment_info {
    margin: 0 auto;
    max-width: 600px;
    display: flex;
    flex-direction: column
}

    .payment_info .card_holder, .payment_info .personal_info {
        display: flex;
        flex-direction: column
    }

    .payment_info label {
        position: relative;
        margin-right: 16px;
        margin-bottom: 22px;
        color: initial;
        font-family: "Source Sans Pro",sans-serif;
        line-height: 20px;
        font-size: 16px;
        width: 88%
    }

    .payment_info .card_holder_input, .payment_info .personal_info_input {
        -moz-appearance: none;
        appearance: none;
        border: 1px solid #b7b7b7;
        border-radius: 6px;
        padding: 10px;
        color: #312852;
        outline-color: #f8e71c;
        -webkit-appearance: none
    }

    .payment_info .billing_address {
        display: flex;
        font-family: "Source Sans Pro",sans-serif;
        color: #354052;
        width: 88%;
        justify-content: space-between;
        margin-bottom: 15px
    }

    .payment_info .radio-btns input {
        position: absolute;
        opacity: 0;
        cursor: pointer
    }

.billing_address .checkmark {
    position: absolute;
    top: 0;
    left: 0;
    height: 20px;
    width: 20px;
    background-color: #eee;
    border-radius: 50%
}

.billing_address label {
    position: relative;
    padding-left: 30px;
    cursor: pointer
}

    .billing_address label:hover input ~ .checkmark {
        background-color: #ccc
    }

.billing_address input:checked ~ .checkmark {
    background-color: #f8e71c
}

.billing_address .checkmark:after {
    content: "";
    position: absolute;
    display: none
}

.billing_address input:checked ~ .checkmark:after {
    display: block
}

.billing_address .checkmark:after {
    top: 7px;
    left: 7px;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: #fff
}

.with_billing_address, .without_billing_address {
    display: none
}

    .with_billing_address.show, .without_billing_address.show {
        display: block
    }

.card-mastercard, .card-visa {
    background-size: 32px
}

.card-visa {
    background-image: url(../images/admin/visa.svg)
}

.card-mastercard {
    background-image: url(../images/admin/mastercard.svg)
}

.card-amex {
    background-image: url(../images/admin/amex.svg)
}

.card-diners_club {
    background-image: url(../images/admin/diners-club.png)
}

.card-jcb {
    background-image: url(../images/admin/jcb.svg)
}

.card-discover {
    background-image: url(../images/admin/discover.png)
}

.card-unknown {
    background-color: #adadad;
    border-radius: 3px
}

.booking-step__choose-item_green {
    background-color: rgba(53,208,115,0.1);
    border-radius: 5px
}

.booking-step__choose-item_tenancy {
    background-color: rgba(131,102,250,0.1);
    border-radius: 5px;
    display: none
}

.booking-step__choose-item_studio {
    display: none
}

.booking-step__choose-item_errands {
    padding: 5px 10px;
    background-color: #FDFDFD;
    border: 1px solid #E9EFF4;
    border-radius: 5px
}

    .booking-step__choose-item_errands .info-hidden {
        height: 16px;
        margin-left: 8px
    }

    .booking-step__choose-item_errands .booking-step__choose-name {
        margin-left: 0
    }

    .booking-step__choose-item_errands .time-counter {
        margin-left: auto
    }

.booking-step__choose-item_errands {
    width: 100%
}

.booking-step__choose-desc {
    font-size: 16px;
    line-height: 19px;
    letter-spacing: .5px;
    padding-bottom: 16px;
    display: flex;
    margin-bottom: 5px;
    position: relative;
    align-items: center;
    overflow: hidden
}

    .booking-step__choose-desc .icon {
        margin-right: 12px;
        max-height: 40px;
        max-width: 40px
    }

    .booking-step__choose-desc .desc-line {
        width: 26px;
        height: 12px;
        margin-left: 78px;
        position: absolute;
        bottom: 0;
        background-size: contain;
        background-repeat: no-repeat;
        left: 0;
        background-image: url(../images/desk-arrow.svg)
    }

        .booking-step__choose-desc .desc-line:before {
            width: 85px;
            position: absolute;
            right: 100%;
            border-top: 3px solid #35d073;
            content: ""
        }

        .booking-step__choose-desc .desc-line:after {
            width: 100vw;
            position: absolute;
            left: 24px;
            border-top: 3px solid #35d073;
            content: ""
        }

.booking-step__choose-item_tenancy.show {
    display: flex
}

.booking-step__choose-item_studio.show {
    display: flex
}

.booking-step__choose-item_studio .booking-step__radios label input:checked ~ span {
    border-color: #0094ff;
    color: #0094ff
}

.booking-step__choose-item_studio .booking-step__choose-name--strong span {
    color: #0094ff
}

.booking-step__choose-item_green .booking-step__radios label input:checked ~ span {
    border-color: #35d073;
    color: #35d073
}

.booking-step__choose-item_green .booking-step__choose-name--strong span {
    color: #35d073
}

.booking-step__choose-name--strong span {
    font-weight: 700
}

    .booking-step__choose-name--strong span br {
        display: none
    }

    .booking-step__choose-name--strong span.thin {
        font-weight: 300;
        color: #323C47;
        white-space: normal
    }

.booking-steps-check__item--flex_highlight {
    background-color: #F5E6AB
}

.booking-steps-check__item--flex_green {
    background-color: #EAFAF1
}

.booking-steps-check__item--flex_blue {
    background-color: #edf8ff
}

.booking-steps-check__item--flex_purple {
    background-color: #F2EFFE
}

.booking-steps-check__item--flex_orange {
    background-color: #ffecdb
}

.booking-steps-check__item--flex_lightred {
    background-color: #ffdbd3
}

.booking-steps-check__item--flex_discount p {
    color: #43D37B
}

.booking-steps-check__item--flex_discount span {
    color: #43D37B
}

.booking-steps-check__item--priority_package {
    color: #544121;
    border: 1px solid #F7E095;
    background: linear-gradient(165.67deg,#FFE6A9 0%,#FFD980 28.13%,#FFD475 47.47%,#FECD6E 51.4%,#FFD277 51.51%,#EEAC32 100%)
}

    .booking-steps-check__item--priority_package p {
        font-weight: 700
    }

        .booking-steps-check__item--priority_package p span {
            font-weight: 400
        }

.booking-step__choose-item__with__eco .booking-step__choose-name {
    width: 275px
}

.booking-step__choose-item__with__eco .info-hidden {
    margin-left: 8px
}

.booking-step__choose-item__with__eco .ecover_mob {
    display: none
}

.booking-step__choose-item__with__eco .ecover_img {
    width: 58px;
    border: 1px solid #eee;
    border-radius: 3px;
    padding: 8px 10px
}

.fixed-header {
    top: 0;
    position: fixed;
    z-index: 0;
    transform: none;
    height: 100px;
    background-image: linear-gradient(90deg,rgba(254,244,0,0) 0%,rgba(252,230,0,0.15) 100%);
    background-color: #fff;
    left: 0;
    width: 100%;
    padding: 15px 20px;
    justify-content: flex-end;
    align-items: center;
    border: 1px solid #D5DFE6;
    display: none;
    transition: .25s ease
}

    .fixed-header.static {
        transform: translateY(-100%)
    }

    .fixed-header.fixed-on-top {
        z-index: 2
    }

    .fixed-header.fixed {
        left: 0;
        position: fixed;
        z-index: 10;
        height: 60px;
        justify-content: space-between;
        background-image: none;
        background-color: #F9F6D9
    }

        .fixed-header.fixed .fixed-header__right .fixed-header__row .fixed-header__view-details, .fixed-header.fixed .fixed-header__right .fixed-header__date {
            display: none
        }

        .fixed-header.fixed .fixed-header__left {
            display: block
        }

.fixed-header__left {
    margin-left: 5px;
    display: none
}

.fixed-header__title {
    color: #453283;
    font-family: "Graphik LC";
    font-size: 16px;
    font-weight: 700;
    letter-spacing: 0;
    line-height: 22px
}

.fixed-header__view-details {
    color: #8365FF;
    font-family: "Graphik LC";
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0;
    line-height: 18px
}

.fixed-header__row {
    display: flex;
    align-items: center;
    justify-content: flex-end
}

.fixed-header__price {
    margin-left: 30px;
    color: #8365FF;
    font-family: "Graphik LC";
    font-size: 16px;
    font-weight: 800;
    letter-spacing: 0;
    line-height: 22px
}

.fixed-header__date {
    margin-top: 2px;
    color: #453283;
    font-family: "Graphik LC";
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0;
    line-height: 18px;
    text-align: right
}

.fixed-header__close {
    display: none;
    width: 22px;
    height: 22px;
    background-image: url(../images/close-booking-icon.svg);
    background-size: 100% 100%
}

.fixed-header.show {
    transform: none
}

.fixed-header.opened .fixed-header__row .fixed-header__view-details {
    display: block
}

.fixed-header.opened .fixed-header__left {
    display: none
}

.fixed-header.opened .fixed-header__close {
    display: block
}

.booking-steps-check__shopping {
    top: -200px;
    width: 50px;
    height: 50px;
    opacity: 0;
    z-index: -1;
    position: absolute
}

    .booking-steps-check__shopping.open {
        opacity: 1
    }

.fixed-header.added {
    display: flex
}

.priority-package {
    max-width: 740px;
    margin-bottom: 40px;
    border-radius: 4px;
    padding: 34.5px 71.5px 30.5px 62px;
    background: linear-gradient(121deg,#FFE6A9 2.3%,#FFD980 28.13%,#FFD475 47.47%,#FECD6E 51.4%,#FFD277 51.51%,#EEAC32 100%)
}

.priority-package__title {
    font-size: 24px;
    line-height: 32px;
    color: #544121
}

.priority-package__content {
    display: flex;
    flex-wrap: wrap-reverse;
    margin-top: 22px
}

.priority-package__price {
    height: 142px;
    width: 238px;
    z-index: 5;
    position: relative;
    background-position: right top;
    background-repeat: no-repeat;
    background-image: url(/static/images/Group.png)
}

.priority-package__price-label {
    color: #FFEFC9;
    position: absolute;
    font-family: "Graphik LC",sans-serif;
    font-size: 12.15px;
    font-weight: 700;
    letter-spacing: 1.01px;
    line-height: 16px;
    transform: translateX(-60%) rotate(-10deg);
    top: 23%;
    left: 47%;
    text-transform: uppercase
}

.priority-package__price-text {
    position: absolute;
    top: 54px;
    left: 50%;
    transform: translateX(-60%) rotate(-10deg);
    color: #544121;
    font-family: "Graphik LC",sans-serif;
    font-size: 29.15px;
    font-weight: 700;
    letter-spacing: 0;
    line-height: 39px
}

.priority-package-list li {
    color: #544121;
    font-family: "Graphik LC",sans-serif;
    font-size: 14px;
    letter-spacing: -.04px;
    line-height: 19px
}

    .priority-package-list li:not(:last-child) {
        margin-bottom: 5px
    }

.priority-package__list {
    margin-right: auto
}

.priority-package .booking-step__number {
    top: 23px;
    transform: translateY(-50%)
}

    .priority-package .booking-step__number span {
        color: #544121;
        font-size: 16px;
        border-color: #544121;
        font-weight: 700
    }

    .priority-package .booking-step__number:before {
        background-color: transparent
    }

.priority-package.booking-step__block::before {
    top: 40px;
    z-index: 2
}

.priority-package__btns {
    display: flex;
    margin-right: 34px
}

    .priority-package__btns label:not(:last-child) {
        margin-right: 8px
    }

.priority-package__radio {
    display: none
}

    .priority-package__radio:checked + .priority-package__btn {
        border: 2px solid #FFF;
        font-weight: 700
    }

.priority-package__footer {
    display: flex;
    align-items: center
}

.priority-package__btn {
    transition: background-color 0.3s,border .3s;
    max-width: 230px;
    height: 56px;
    display: flex;
    width: 230px;
    align-items: center;
    justify-content: center;
    color: #544121;
    background-color: #E7B652;
    border-radius: 4px;
    border: 1px solid #E7B652;
    cursor: pointer;
    box-shadow: 0 0 3px 0 rgba(131,102,255,0.14);
    font-size: 18px;
    letter-spacing: -.06px
}

.priority-package__terms {
    color: #9B762A;
    font-family: "Graphik LC",sans-serif;
    font-size: 14px;
    font-weight: 300;
    letter-spacing: -.04px;
    line-height: 19px;
    text-decoration: underline !important
}

.time-counter {
    padding: 13.5px 7.5px;
    border: 1px solid #E9EFF4;
    background-color: #FDFDFD;
    border-radius: 5px;
    min-width: 114px;
    display: flex;
    justify-content: space-between;
    align-items: center
}

.time-counter__text {
    color: #323C47;
    font-family: "Graphik LC",sans-serif;
    font-size: 14px;
    font-weight: 900;
    letter-spacing: 0;
    text-align: center
}

.time-counter__plus, .time-counter__minus {
    height: 16px;
    width: 16px;
    position: relative;
    background: none;
    border: none;
    cursor: pointer;
    outline: none
}

    .time-counter__plus:before {
        position: absolute;
        height: 100%;
        top: 0;
        left: 50%;
        transform: translateX(-50%);
        border-left: 1px solid #323C47;
        content: ''
    }

    .time-counter__plus:after, .time-counter__minus:after {
        position: absolute;
        width: 100%;
        top: 50%;
        left: 0;
        transform: translateY(-50%);
        border-bottom: 1px solid #323C47;
        content: ''
    }

.js-time-count input {
    display: none
}

.info-hidden {
    position: relative
}

.info-hidden__text {
    position: absolute;
    top: 100%;
    right: -6px;
    transform: translateY(5px);
    min-width: 285px;
    padding: 11px;
    z-index: 2;
    border-radius: 4px;
    background-color: #FDF8ED;
    opacity: 0;
    border: 1px solid #F6DF95;
    visibility: hidden;
    color: #374355;
    font-family: "Source Sans Pro",sans-serif;
    font-size: 12px;
    letter-spacing: -.04px;
    line-height: 15px
}

    .info-hidden__text:after {
        width: 10px;
        height: 10px;
        border-left: 1px solid #F6DF95;
        border-top: 1px solid #F6DF95;
        background-color: #FDF8ED;
        transform: translateY(-50%) rotate(45deg);
        position: absolute;
        content: "";
        right: 10px;
        top: 1px;
        border-radius: 2px
    }

.info-hidden:hover .info-hidden__text {
    opacity: 1;
    visibility: visible
}

.booking-step--prestep .booking-step-button {
    margin-left: 0
}

.booking-step__radio {
    max-width: 340px
}

.booking-step-radio__item:not(:last-child) {
    margin-bottom: 12px
}

.cust-radio {
    display: block;
    cursor: pointer
}

.cust-radio__wrap {
    display: block;
    padding: 15px 5px;
    border: 1px solid #D5DFE6;
    border-radius: 4px;
    background-color: #FDFDFD;
    transition: border .3s
}

.cust-radio input {
    display: none
}

    .cust-radio input:checked ~ .cust-radio__wrap {
        box-shadow: 0 0 3px 0 rgba(131,102,255,0.14);
        border-color: #8365FF
    }

        .cust-radio input:checked ~ .cust-radio__wrap span {
            color: #323C47;
            text-shadow: .5px 0 0 #000
        }

        .cust-radio input:checked ~ .cust-radio__wrap .icon {
            opacity: 1
        }

.cust-radio .icon {
    opacity: .4;
    transition: .3s
}

.cust-radio .cust-radio__wrap span {
    color: #50606B;
    font-family: "Graphik LC";
    font-size: 16px;
    letter-spacing: -.06px;
    line-height: 24px;
    transition: color .3s
}

.booking-step-checks {
    display: flex;
    align-items: center;
    flex-wrap: wrap
}

.booking-step-checks__item:not(:last-child) {
    margin-right: 16px
}

.booking-step-checks__item {
    margin-bottom: 12px
}

.booking-step__choose--carpet {
    margin-top: 30px
}

.custom-check {
    display: flex;
    align-items: center;
    cursor: pointer
}

    .custom-check .text {
        color: #323C47;
        font-family: "Graphik LC";
        font-size: 16px;
        font-weight: 700;
        letter-spacing: -.29px;
        line-height: 18.2px;
        margin-right: auto
    }

    .custom-check .check {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 24px;
        height: 24px;
        border: 1.6px solid #E9EFF4;
        border-radius: 4px;
        margin-right: 12px;
        transition: .3s
    }

    .custom-check .custom-check__wrap {
        display: flex;
        align-items: center;
        border: 2px solid #E9EFF4;
        border-radius: 6px;
        background-color: #FFF;
        min-width: 240px;
        width: 100%;
        padding: 16px;
        -webkit-touch-callout: none;
        -webkit-user-select: none;
        -khtml-user-select: none;
        -moz-user-select: none;
        -ms-user-select: none;
        user-select: none
    }

.custom-check--clean .custom-check__wrap {
    border: none
}

.custom-check.custom-check--clean input:checked ~ .custom-check__wrap {
    border: none;
    background-color: transparent
}

.custom-check input:checked ~ .custom-check__wrap .check {
    background-color: #8365FF
}

.custom-check input:checked ~ .custom-check__wrap {
    border: 2px solid #835FFF;
    background-color: #F9F8FF
}

.custom-check__box-info {
    display: flex;
    align-items: center;
    margin-left: 5px
}

.custom-check input {
    display: none
}

.new-booking-steps {
    font-family: "Graphik LC",sans-serif;
    color: #323c47;
    background: #fff;
    overflow: hidden;
    position: relative;
    width: 450px;
    max-width: 100%;
    min-height: 100vh;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column
}

.booking-step-subchecks {
    border: 1px solid #E9EFF4;
    border-radius: 8px
}

.booking-step-subchecks__head {
    border-bottom: 1px solid #E9EFF4
}

.booking-step-subchecks__items {
    overflow: hidden;
    visibility: hidden;
    opacity: 0;
    max-height: 0;
    padding: 0;
    transition: .3s
}

    .booking-step-subchecks__items.active {
        padding: 18px;
        max-height: 3000px;
        visibility: visible;
        opacity: 1
    }

.booking-step-subchecks.booking-step__content {
    max-width: 345px;
    transition: .3s
}

    .booking-step-subchecks.booking-step__content.active {
        max-width: 100%
    }

.booking-step-material {
    padding-top: 12px;
    position: relative;
    z-index: 1
}

.booking-step-material__item:not(:last-child) {
    margin-bottom: 12px
}

.funnel-modal-bg {
    position: fixed;
    top: 0;
    right: 0;
    z-index: 99;
    background: #fff;
    height: 100vh;
    width: 409px;
    padding-bottom: 24px;
}


.booking-step__content {
    margin-top: 20px
}

.payment-form {
    width: 100% !important;
    padding-block: 20px;
}

    .payment-form input,
    .payment-form select {
        width: 100%;
        padding: 10px;
        margin: 10px 0;
        box-sizing: border-box;
    }

    .payment-form .payment-methods {
        display: flex;
        justify-content: space-between;
        margin-bottom: 20px;
    }

        .payment-form .payment-methods div {
            width: 99px;
            height: 78px;
            border: 1px solid #E6E6E6;
            border-radius: 5px;
            cursor: pointer;
            padding: 10px;
            border: 1px solid #ccc;
            border-radius: 8px;
        }

        .payment-form .payment-methods .selected {
            border-color: #000;
        }

.payment-warning {
    width: 100%;
    background: #FDECEB;
    border: 1px solid #E93F3A;
    border-radius: 12px;
    padding: 16px;
    opacity: 1;
    transition: opacity 0.5s ease, max-height 0.5s ease;
}

    .payment-warning div {
        display: flex;
        gap: 12px;
    }

    .payment-warning img {
        width: 24px;
        height: 24px;
    }

    .payment-warning h4 {
        font-family: "Graphik LC Medium", sans-serif;
        font-size: 16px;
        font-weight: 500;
        color: #323C47;
        line-height: 16px;
    }

    .payment-warning p {
        font-family: "Graphik LC", sans-serif;
        font-size: 16px;
        font-weight: 400;
        color: #50606B;
        line-height: 23.68px;
        margin: 8px 0 0 36px;
    }

.pilot-success {
    background: #F0ECFF;
    padding: 55px 128px;
}

.pilot-container {
    max-width: 500px;
    width: 100%;
    font-family: 'Graphik LC', sans-serif;
}

.pilot-header {
    display: flex;
    flex-direction: column;
}

    .pilot-header h1 {
        font-family: 'Stratos LC Web', sans-serif;
        color: #453283;
        font-size: 48px;
        font-weight: 600;
        line-height: 48px;
    }

    .pilot-header p {
        font-family: 'Stratos LC Web', sans-serif;
        color: #50606B;
        font-size: 24px;
        font-weight: 600;
        line-height: 28.8px;
        margin-block: 20px 40px
    }

    .pilot-header img {
        position: absolute;
        top: 55px;
        left: 740px
    }

.pilot-checkout_details div {
    margin-bottom: 40px;
}

.pilot-checkout_details p {
    color: #323C47;
    font-size: 14px;
    font-weight: 400;
    line-height: 16.8px;
    margin-bottom: 5px;
}

.pilot-checkout_details a {
    color: #6951CC;
    font-size: 16px;
    font-weight: 500;
    line-height: 16px;
}

.pilot-checkout_details span {
    font-family: 'Stratos LC Web', sans-serif;
    color: #323C47;
    font-size: 24px;
    font-weight: 600;
    line-height: 28.8px;
}

.mob-app-bedges {
    width: 361px;
    background: #fff;
    border-radius: 12px;
    padding: 24px;
}

.mob-app-bedges p {
    color: #323C47;
    font-size: 20px;
    font-weight: 500;
    line-height: 26.4px;
}

.mob-app-bedges div {
    display: flex;
    gap: 16px;
    margin-top: 24px;
}

.mob-app-bedges img {
    width: 140px;
}

.pilot-cleaners {
    width: 100%;
    background: #fff;
    border-radius: 12px;
    border: 1px solid #E6EBEF;
    padding: 24px 24px 10px;
}

    .pilot-cleaners h3, .pilot-booking_summary h3 {
        font-family: 'Graphik LC', sans-serif;
        color: #323C47;
        font-size: 20px;
        font-weight: 500;
        line-height: 26.4px;
        margin-bottom: 16px;
    }

    .pilot-booking_summary h3 {
        margin-bottom: 4px;
    }

    .pilot-cleaners .pilot-cleaner {
        display: flex;
        align-items: center;
        gap: 16px;
        padding: 16px;
        border-top: 1px solid #E6EBEF;
    }

        .pilot-cleaners .pilot-cleaner div {
            display: flex;
            flex-direction: column;
        }

        .pilot-cleaners .pilot-cleaner h4 {
            color: #50606B;
            font-size: 16px;
            font-weight: 500;
            line-height: 16px;
        }

        .pilot-cleaners .pilot-cleaner p {
            font-size: 14px;
            font-weight: 400;
            line-height: 16.8px;
            margin-bottom: 0;
        }

    .pilot-cleaners img {
        width: 48px;
        height: 48px;
        border-radius: 24px;
    }

.pilot-booking_summary {
    background: #fff;
    padding: 24px;
    border-radius: 12px;
    margin-top: 40px;
}

    .pilot-booking_summary p {
        font-family: 'Graphik LC', sans-serif;
        color: #323C47;
        font-size: 16px;
        font-weight: 400;
        line-height: 23.68px;
        padding-block: 12px;
        border-bottom: 1px solid #E6EBEF;
    }

    .pilot-booking_summary p span:first-child {
        font-family: 'Graphik LC Medium', sans-serif;
        font-weight: 500;
    }

    .pilot-booking_summary button {
        font-family: 'Graphik LC Medium', sans-serif;
        color: #6951CC;
        font-size: 16px;
        font-weight: 500;
        line-height: 16px;
        margin-top: 16px;
    }

#paymentStep {
    display: none !important;
    position: fixed;
    z-index: 9999;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    overflow: auto;
    background-color: rgb(0,0,0);
    background-color: rgba(0,0,0,0.4);
    display: flex;
    justify-content: center;
    align-items: center;
    opacity: 0;
    transition: opacity 0.5s ease, background-color 0.5s ease;
}

#promoModal {
    display: none !important;
    position: fixed;
    z-index: 9999;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    overflow: auto;
    background-color: rgb(0,0,0);
    background-color: rgba(0,0,0,0.4);
    display: flex;
    justify-content: center;
    align-items: center;
    opacity: 0;
    transition: opacity 0.5s ease, background-color 0.5s ease;
}

    #promoModal.show-modal {
        display: flex;
        background-color: rgba(0, 0, 0, 0.5);
        opacity: 1;
    }

.close {
    position: absolute;
    top: 10px;
    right: 20px;
    font-size: 24px;
    cursor: pointer;
}

#promoModal .modal-content {
    background-color: #fff;
    padding: 24px;
    border-radius: 10px;
    width: 409px;
    box-shadow: 0px 10px 10px -5px #0000000A;
    box-shadow: 0px 20px 25px -5px #0000001A;
}

#promoModal.show-modal .modal-content {
    transform: scale(1);
}

#promoModal h2 {
    color: #323C47;
    font-family: 'Stratos LC Web', sans-serif;
    text-transform: uppercase;
    font-size: 24px;
    font-weight: 600;
    line-height: 30px;
}

.promoError {
    display: none;
    color: #E93F3A;
    margin-bottom: 0;
}

#promoModal .close {
    color: #aaa;
    position: absolute;
    top: 10px;
    right: 20px;
    font-size: 28px;
    font-weight: bold;
    cursor: pointer;
}

    #promoModal .close:hover,
    #promoModal .close:focus {
        color: black;
        text-decoration: none;
    }

#promoModal .promo-input {
    width: 100%;
    height: 44px;
    padding: 10px;
    margin: 24px 0;
    font-size: 18px;
    border: 1px solid #ccc;
    border-radius: 4px;
}

    #promoModal .promo-input.error {
        border: 1px solid #E93F3A;
        margin-bottom: 0;
    }

    #promoModal .promo-input.error {
        color: #E93F3A !important;
    }

    #promoModal .promo-input::placeholder {
        color: #50606B;
        font-size: 16px;
        font-weight: 400;
    }

#promoModal .promo-btn {
    height: 40px;
    width: 100%;
    background-color: #6c5ce7;
    color: white;
    padding: 8px 20px;
    border-radius: 12px;
    border: none;
    cursor: pointer;
    font-size: 16px;
    font-weight: 600;
}

    #promoModal .promo-btn:hover {
        background-color: #5a4ec0;
    }

.booking-step--payment #card-number-element,
.booking-step--payment #card-expiry-element,
.booking-step--payment #card-cvc-element,
.booking-step--payment #country,
.booking-step--payment #postal_code {
    display: block;
    border: 1px solid #868F96 !important;
    padding: 12px;
    border-radius: 8px;
    color: #868F96;
    font-size: 16px;
}

    .booking-step--payment #card-number-element .input:focus,
    .booking-step--payment #card-expiry-element .input:focus,
    .booking-step--payment #card-cvc-element .input:focus,
    .booking-step--payment #country:focus,
    .booking-step--payment #postal_code:focus {
        border: 1px solid #6951cc !important;
    }

    .booking-step--payment #country::placeholder,
    .booking-step--payment #postal_code::placeholder {
        color: #868F96;
        font-size: 16px;
        font-family: "Graphik LC", sans-serif;
    }

.booking-step--payment #additional-fields {
    display: flex;
    gap: 16px;
}

    .booking-step--payment #payment-element .field, .booking-step--payment #additional-fields div {
        display: flex;
        flex-direction: column;
        margin-top: 12px
    }

    .booking-step--payment #payment-element label, .booking-step--payment #additional-fields label {
        font-family: "Graphik LC", sans-serif;
        font-size: 12px;
        font-weight: 400;
        line-height: 16.8px;
        margin-bottom: 4px;
    }

.booking-step--payment #payment-element {
    display: flex;
    flex-direction: column;
}

.booking-step--payment .booking-step__card-block {
    padding: 0;
}

.blocks_divider {
    height: 16px;
    width: 560px;
    background: #f1f3f4;
    margin-bottom: 0
}

.background-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #323C47;
    opacity: 0.8;
    z-index: 10;
}

.no-scroll {
    overflow: hidden;
    height: 100%;
}

.shadow-scrolled {
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}

.info-modal {
    position: fixed;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    top: 0;
    right: 0;
    width: 100%;
    max-width: 409px;
    height: 100%;
    background: #fff;
    box-shadow: 0 -2px 10px rgba(0, 0, 0, 0.1);
    transform: translateY(100%);
    transition: transform 0.3s ease;
    padding: 24px;
    z-index: 100;
}

.slide-up {
    transform: translateY(0);
}

.slide-down {
    transform: translateY(100%);
}

.info-modal_container {
    width: 361px;
    height: 285px;
    padding: 16px;
    border-radius: 12px;
    border: 1px solid #E6EBEF;
    margin-inline: auto;
}

.info-modal-header {
    display: flex;
    align-items: center;
}

.info-modal-header img {
    margin-inline: -8px 12px;
}

.chevron-icon {
    cursor: pointer;
    transition: transform 0.3s;
}

.chevron-icon.rotated {
    transform: rotate(180deg);
}

.info-modal-body {
    margin-top: 24px;
}

.info-modal-body div {
    display: flex;
    justify-content: space-between;
    margin-bottom: 16px;
}

.info-modal-body div:last-child p, .info-modal-header h2 {
    font-family: 'Graphik LC Medium', sans-serif;
    font-size: 20px;
    font-weight: 500;
    line-height: 26.4px;
    color: #323C47 !important;
}

.info-modal-body div p {
    font-family: 'Graphik LC', sans-serif;
    font-size: 16px;
    font-weight: 400;
    line-height: 23.68px;
    color: #323C47;
}

.info-modal-body div p:first-child {
    color: #50606B;
}

.info-modal-body hr {
    margin-block: 16px;
    height: 1px;
    border: none;
    background-color: #E6EBEF;
}

@media (max-width: 1800px) {
    .booking-steps-check__tooltip {
        top: 100%;
        left: 0;
        -webkit-transform: translate(-40%,10px);
        -ms-transform: translate(-40%,10px);
        transform: translate(-40%,10px)
    }
}

@media only screen and (max-width: 1440px) {
    /*    .container {
        max-width: none;
        padding: 0 65px
    }*/

    .booking-steps-header__items {
        width: 75%
    }

    .booking-steps-check__close {
        width: 30px;
        height: 30px;
        font-size: 45px;
        -webkit-border-radius: 50%;
        border-radius: 50%;
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
        -webkit-align-items: center;
        -ms-flex-align: center;
        align-items: center;
        -webkit-box-pack: center;
        -webkit-justify-content: center;
        -ms-flex-pack: center;
        justify-content: center;
        cursor: pointer;
        position: fixed;
        right: 15px;
        top: 10px;
        z-index: 11
    }

    .booking-step__error_flex .booking-step__table {
        max-width: 240px
    }
}

@media only screen and (max-width: 1281px) {
    .booking-steps__info {
        max-width: 375px
    }
}

@media only screen and (max-width: 1200px) {
    .booking-steps-faq {
        display: none;
        padding-bottom: 0
    }

    .booking-steps-faq--mobile {
        display: block;
        position: relative;
        width: 98%;
        margin-left: auto;
        margin-right: auto;
        margin-bottom: 30px
    }

    .booking-step__card {
        height: auto;
        padding: 25px 40px
    }

    .booking-step__card-header::before {
        left: -30px
    }

    .booking-step__time {
        margin-left: 50px
    }

    .booking-steps__items {
        width: 100%;
        min-width: 90%
    }

    .select2-container, .select2-selection {
        width: 100% !important
    }

    .booking-step--three .selection {
        width: 100%
    }

    .booking-step--three .booking-step__label textarea, .booking-step--three .booking-step__label.comments, .booking-step--three .booking-step__label.address {
        width: 100%;
        display: block
    }

    .booking-steps__info {
        display: none
    }

    .pilot-success {
        padding: 50px 30px;
    }

    .pilot-header img {
        left: 600px
    }
}

@media (max-width: 1125px) {
    .priority-package__footer {
        flex-wrap: wrap-reverse
    }

    .priority-package__btns {
        margin-right: 0;
        width: 100%
    }

        .priority-package__btns > label {
            width: 50%
        }

    .priority-package__btn {
        width: 100%
    }

    .priority-package__terms {
        margin: 18px 0
    }
}

@media only screen and (max-width: 1024px) {
    body {
        overflow-x: hidden
    }

    .priority-package {
        width: 92.5%;
        padding: 30px 40px 25px
    }

    .booking-steps-header__items {
        width: 100%;
        -webkit-box-pack: center;
        -webkit-justify-content: center;
        -ms-flex-pack: center;
        justify-content: center;
        border-bottom: none
    }

    .booking-steps-header__item--active {
        border: 1px solid #8365ff !important
    }

    .booking-steps-header__item--done .booking-steps-header__step {
        width: 60px;
        height: 30px;
        -webkit-box-pack: center;
        -webkit-justify-content: center;
        -ms-flex-pack: center;
        justify-content: center;
        padding: 0
    }

    .booking-steps-header__item--done .booking-steps-header__icon {
        margin-left: 10px
    }

    .booking-steps-header__item--done .booking-steps-header__title {
        color: rgba(131,101,255,.6)
    }

    .booking-steps-header__item {
        width: 20%;
        padding: 0;
        height: 55px;
        border-top: 1px solid #d5dfe6;
        margin-bottom: 15px;
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: center;
        -webkit-justify-content: center;
        -ms-flex-pack: center;
        justify-content: center;
        -webkit-box-align: center;
        -webkit-align-items: center;
        -ms-flex-align: center;
        align-items: center
    }

    .booking-steps-header__title {
        font-size: 16px;
        line-height: 18px;
        color: #757779
    }

    .booking-steps-header__step {
        width: 30px;
        height: 30px;
        -webkit-border-radius: 50%;
        border-radius: 50%
    }

    .booking-steps-header__number {
        font-size: 12px;
        font-weight: 700;
        color: #d5dfe6
    }

    .booking-steps-header {
        position: relative;
        left: 0;
        top: 0;
        -webkit-transform: none;
        -ms-transform: none;
        transform: none;
        padding: 5% 0;
        margin-left: auto;
        margin-right: auto;
        margin-bottom: 0;
        border-bottom: none
    }

    .booking-steps-check {
        display: none;
        border: none;
        background: 0 0
    }

    .booking-steps-check--desktop {
        display: none
    }

    .booking-steps-check--mob-content .booking-steps-check__item.booking-steps-check__rooms {
        padding: 5px 16px
    }

    .booking-steps-check--mob-content {
        position: absolute;
        width: 100%;
        top: 0;
        left: 0;
        z-index: 5
    }

        .booking-steps-check--mob-content .booking-steps-check__content {
            min-height: 100vh;
            border: 1px solid #d3dfe7;
            width: 100%
        }

    .booking-steps-check--mobile {
        -webkit-box-ordinal-group: 0;
        -webkit-order: -1;
        -ms-flex-order: -1;
        order: -1;
        width: 100%;
        height: auto;
        margin: auto 0;
        padding: 0;
        z-index: 10
    }

        .booking-steps-check--mobile.booking-steps-check--active {
            display: block
        }

    .booking-steps-check--dropdown {
        width: 100%
    }

        .booking-steps-check--dropdown .booking-steps-check--mob-content {
            height: 100vh;
            padding: 60px 16px;
            background-color: #fff
        }

        .booking-steps-check--dropdown .booking-steps-check__shopping::before {
            background-color: #fff
        }

        .booking-steps-check--dropdown .booking-steps-check__item {
            border-color: #d3dfe7
        }

    .booking-steps-check__icon:hover .booking-steps-check__tooltip {
        -webkit-animation: fadeIn .1s ease;
        animation: fadeIn .1s ease
    }

    .booking-steps-check__tooltip {
        top: 0;
        -webkit-transform: translate(0,-110%);
        -ms-transform: translate(0,-110%);
        transform: translate(0,-110%)
    }

    .booking-steps-check__item a {
        margin: 0
    }

    .booking-steps-check--mobile .booking-steps-check__item h2 {
        color: #483188
    }

    .booking-steps-check__room {
        margin-bottom: 0
    }

    .booking-step {
        padding: 20px;
        z-index: 10
    }

    .booking-step__block {
        width: 92.5%;
        margin-left: auto
    }

    .booking-step__rooms {
        padding-bottom: 0
    }

    .booking-steps__container {
        width: 100%
    }

    .booking-steps__info--scroll .booking-steps__info--container {
        position: relative
    }

    .booking-steps__info--scroll {
        position: relative
    }

    .booking-steps {
        padding-top: 0;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -webkit-flex-direction: column;
        -ms-flex-direction: column;
        flex-direction: column
    }

    .booking-step__choose-item_errands {
        margin-left: auto
    }

        .booking-step__choose-item_errands .booking-step__choose-name {
            width: auto
        }

        .booking-step__choose-item_errands .info-hidden, .booking-step__choose-item__with__eco .info-hidden {
            flex-shrink: 0;
            margin-left: 0;
            margin-right: 8px
        }

        .booking-step__choose-item_errands .info-hidden__text, .booking-step__choose-item__with__eco .info-hidden__text {
            right: auto;
            left: -6px;
            transform: translateY(10px)
        }

            .booking-step__choose-item_errands .info-hidden__text:after, .booking-step__choose-item__with__eco .info-hidden__text:after {
                left: 10px;
                right: auto
            }

    .pilot-header img {
        position: relative;
        left: 0;
        top: 0;
        width: 192px;
        height: 200px;
    }

    .pilot-success_banner {
        margin: -15px auto 40px auto;
    }
}

@media (max-width: 991px) {
    .booking-step__choose-name--strong span br {
        display: block
    }

    .booking-steps-final .booking-step__block {
        display: block
    }
}

@media only screen and (max-width: 976px) {
    .datepicker {
        width: 100%
    }

    .booking-step__card .booking-step__button-cashback {
        left: 25px;
        left: 40px
    }

        .booking-step__card .booking-step__button-cashback span {
            font-size: 12px
        }

    .booking-step__row {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -webkit-flex-direction: column;
        -ms-flex-direction: column;
        flex-direction: column
    }

    .booking-step__time .time_pick {
        width: 100%
    }

    .booking-step__time {
        margin-left: 0
    }
}

@media only screen and (max-width: 768px) {
    /*    .container {
        padding: 0 9%
    }*/

    .datepicker--cell {
        width: 53px
    }

    .booking-steps-header__item--active {
        border: none !important;
        border-bottom: 5px solid #8365ff !important
    }

    .booking-steps-header__item {
        width: -webkit-calc(100% / 3);
        width: calc(100% / 3);
        border: none !important
    }

    .booking-steps-check--top {
        overflow-y: scroll;
        overflow-x: hidden
    }

    .booking-steps-check__room_time-count .booking-step__box-row {
        margin-right: 0
    }

    .fixed-header__right .booking-steps-check__item--blue {
        margin-top: 0;
        justify-content: flex-end
    }

        .fixed-header__right .booking-steps-check__item--blue span {
            font-size: 10px;
            margin-left: 30px !important
        }

    .fixed-on-top .booking-steps-check__item--blue span:first-child {
        display: inline-block;
        margin-right: 5px
    }

    .booking-step__block {
        width: 100%
    }

    .booking-step--three .booking-step__block {
        width: 100%;
        padding-left: 40px
    }

    .booking-step--three .booking-step__number {
        left: 5px
    }

    .booking-step--three .booking-step__block::before {
        left: 18px
    }

    .booking-step--three .booking-step__block--last .booking-step__content {
        max-width: none;
        margin-left: -40px
    }

    .booking-step__header {
        margin-bottom: 10px
    }

    .booking-step__card-header::before {
        left: -25px
    }

    .booking-step__card-header::after {
        left: -20px
    }

    .booking-step__card-header {
        margin-left: 20px
    }

    .booking-step__card-list {
        margin-left: 20px
    }

    .booking-step__card {
        -webkit-flex-basis: 100%;
        -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
        height: auto;
        min-height: 250px;
        padding: 20px
    }

    .booking-step__time {
        margin-left: 0;
        min-height: 230px;
        margin-top: 20px
    }

    .booking-step__error_flex {
        flex-direction: column
    }

        .booking-step__error_flex .booking-step__table {
            margin-top: 10px
        }

    .booking-step__box-label--small .booking-step__box-title {
        font-size: 14px;
        font-weight: 600;
        letter-spacing: 0;
        line-height: 24px
    }

    .booking-step__box-title .about_price {
        font-size: 9px;
        letter-spacing: 0;
        line-height: 13px
    }

    .booking-step__choose-item {
        padding: 5px 0
    }

    .booking-step__choose-name {
        width: 140px
    }

    .booking-steps__choose-carpet-upholstery .booking-step__choose-name {
        width: auto
    }

    .booking-steps__items {
        width: 100%
    }

    .booking-step__choose-item_green .booking-step__choose-name {
        width: 200px;
        padding: 3px 0
    }

    .booking-step__choose-item_green .booking-step__choose-name--strong span {
        display: block
    }

    .booking-step__block.priority-package {
        margin-left: 40px;
        width: auto;
        padding: 30px 22.5px 23.5px;
        padding-left: 22.5px
    }

    .priority-package__title {
        font-size: 20px;
        line-height: 27px
    }

    .priority-package__content {
        margin-top: 18px
    }

    .priority-package__btn {
        font-size: 14px;
        line-height: 19px
    }

    .priority-package .booking-step__number {
        left: -36px
    }

    .priority-package.booking-step__block::before {
        left: -22px
    }

    .top-error .container {
        flex-direction: column;
        align-items: flex-start;
        position: relative
    }

    .top-error__left {
        align-items: flex-start
    }

    .top-error__close {
        position: absolute;
        top: 10px;
        right: 15px
    }

    .top-error p {
        padding-left: 15px;
        padding-right: 25px
    }

}

@media only screen and (max-width: 576px) {
    .pilot-checkout-desk {
        display: none;
    }

    .pilot-checkout-mob {
        display: block;
    }

    .pilot-success {
        padding: 50px 16px;
    }

    #promoModal {
        align-items: end;
        margin-bottom: -6px;
    }

        #promoModal .modal-content {
            border-bottom-left-radius: unset;
            border-bottom-right-radius: unset;
        }

    #paymentStep {
        position: unset;
        z-index: 9999;
        width: 100%;
        height: 100%;
        overflow: auto;
        background-color: unset;
        opacity: 1;
        transition: unset;
    }
    /*    .container {
        padding: 0 8%
    }*/

    .close-funnel_btn {
        width: 24px;
        height: 24px;
    }

    .booking-step1_container .step1-postcode div {
        margin-top: 112px;
    }

    .booking-step1_container .step1-title div {
        padding: 24px 16px 0
    }

    .booking-step1_container .step1-postcode div {
        padding: 24px 16px 24px;
    }

    .booking-step1_container .extra-service_add {
        padding-block: 9px
    }

    .booking-step_container h2 {
        padding: 24px 16px 14px;
    }

    .booking-step5_container h2 {
        padding: 24px 16px 10px;
    }

    .step6_title {
        padding: 24px 16px;
    }

    .booking-step_container.booking-step--two p, .booking-step_container.booking-step--three p {
        padding-inline: 16px;
    }

    .booking-step_container.booking-step--two {
        padding-top: 65px;
    }

    .booking-step_container.booking-step--three {
        padding-top: 96px;
    }

    .booking-step_container.booking-step--four {
        padding-top: 68px
    }

    .booking-step5_container .booking-times {
        margin-top: 108px
    }

    .booking-step1_container.booking-step--six .booking-step__block--last {
        padding: 16px;
    }

    .booking-step_container.booking-step--two p, .booking-step_container.booking-step--three p {
        margin-top: 0;
    }

    .booking-step1_container .step1-rooms_card {
        padding: 12px 16px;
    }

    .booking-step1_container .step1-title p {
        margin-bottom: 24px
    }

    .booking-step1_container .edit-section {
        padding: 24px 16px;
    }

    .booking-step1_container .need-extra {
        padding: 24px 16px 16px;
    }

    .booking-step1_container .extra-service {
        padding-inline: 16px;
    }

    .booking-step1_container .additional-info {
        margin-top: 0;
    }

    .duration-container {
        margin-bottom: 50px;
    }

    .duration-container, .how-often {
        padding: 24px 14.5px; 
    }

    .cleaning-duration {
        width: 47.5%;
        max-width: unset;
    }

    .how-often div {
        width: 47.67%;
    }

    .booking-step5_container .what-time {
        padding-inline: 16px;
    }

    .booking-step5_container .what-time p {
        margin-inline: 0;
    }

    .booking-step_container #calendars {
        margin: 10px auto 16px;
    }

    .account-details {
        margin-block: 24px
    }

    .account-info_1 {
        padding: 62px 16px 16px
    }

    .account-info_2 h3 {
        padding-inline: 16px
    }

    .account-info_2 select {
        margin: 10px 16px 40px;
    }

    .booking-promo {
        padding: 12px 16px;
    }

    .booking-date {
        padding: 12px 16px;
    }

    .personal-info_input .phone-wrap::before, #togglePassword {
        top: 50%;
    }

    .datepicker--days {
        min-height: 310px
    }

    .datepicker--cell {
        width: -webkit-calc(100% / 8);
        width: calc(100% / 8);
        margin-right: 2%
    }

    .timepicker_wrap {
        width: 100%
    }

    .timepicker_wrap .next, .timepicker_wrap .prev {
        width: 100%
    }

    .account-info_3, .account-info_2 .dateTime, .btns-container {
        padding-inline: 16px;
    }

    .booking-step1_container .carpet-upholstery {
        height: 92px;
    }

    .booking-step1_container .carpet-upholstery h4 {
        width: 190px;
    }

    .booking-step1_container .carpet-upholstery .carpet-img {
        margin-bottom: 16px;
    }

    .select2-container--single, .select2-container__rendered, .select2-selection--single, .select2-selection__rendered {
        width: 100%
    }

    .select2-container, .select2-selection {
        width: 100% !important
    }

    .selection {
        width: 100%
    }

    .select2-container--default .select2-selection--single .select2-selection__arrow {
        right: 15px
    }

    .booking-step-buttons {
        -webkit-box-pack: end;
        -webkit-justify-content: flex-end;
        -ms-flex-pack: end;
        justify-content: flex-end
    }

    .booking-steps__steper, .btns-container {
        width: 100% !important;
    }

    .booking-step__choose-item_errands .booking-step__choose-name {
        font-size: 14px
    }

    .booking-step-button__text {
        padding: 9px 15px;
        line-height: 18px;
        padding: 9px 15px;
        line-height: 18px
    }

    .booking-step-button {
        width: 100%;
        margin-right: 0;
        margin-left: auto
    }

    .booking-steps-header__logo {
        position: absolute;
        top: 20px;
        left: 10px;
        max-width: 50px
    }

        .booking-steps-header__logo span {
            display: block
        }

        .booking-steps-header__logo img {
            display: none
        }

    .booking-steps-header__item--active::before {
        height: 3px !important;
        top: 13px !important;
        background: #8365ff !important
    }

    .booking-steps-header__item--active .booking-steps-header__number {
        font-size: 12px
    }

    .booking-steps-header__item--done .booking-steps-header__icon {
        margin-left: 0
    }

    .booking-steps-header__item {
        height: 65px;
        -webkit-box-align: end;
        -webkit-align-items: flex-end;
        -ms-flex-align: end;
        align-items: flex-end;
        padding-top: 10px;
        position: relative
    }

        .booking-steps-header__item::before {
            content: "";
            display: block;
            position: absolute;
            width: 100%;
            height: 1px;
            background: #d5dfe6;
            top: 14px
        }

    .booking-steps-header__title br {
        display: block
    }

    .booking-steps-header__title {
        font-size: 14px;
        line-height: 16px;
        -webkit-transform: translateY(10px);
        -ms-transform: translateY(10px);
        transform: translateY(10px);
        max-width: 85px
    }

    .booking-steps-header__step {
        width: 26px;
        height: 26px;
        bottom: 100%;
        -webkit-transform: translate(-50%,100%);
        -ms-transform: translate(-50%,100%);
        transform: translate(-50%,100%)
    }

    .booking-steps-header {
        position: relative;
        left: 0;
        top: 0;
        -webkit-transform: none;
        -ms-transform: none;
        transform: none;
        padding: 85px 0 0;
        margin-bottom: 2%;
        z-index: 12
    }

    .booking-steps-header--mobile {
        padding: 85px 0 2%
    }

    .booking-steps-header--final {
        margin: 0;
        padding: 20% 0 0
    }

    .booking-step_container {
        width: 100%;
    }

    .booking-steps-check--mobile {
        position: fixed;
        top: 70px
    }

    .booking-steps-check__row {
        z-index: 5
    }

    .booking-steps-check__promo input {
        width: 62%
    }

    .booking-steps-check__promo {
        left: 5%
    }

    .booking-steps-check__shopping {
        top: -70px
    }

    .booking-steps-faq__title {
        text-align: left;
        padding-left: 24px
    }

    .booking-steps-final__content::before {
        left: -30px
    }

    .booking-steps-final__content::after {
        left: -25px
    }

    .booking-steps-final__content {
        padding-left: 30px
    }

    .booking-steps-final .booking-step__block {
        margin-left: 30px
    }

    .booking-step-buttons .booking-step-button:first-child {
        margin-right: 5px;
        min-width: 0
    }

    .booking-step-buttons .booking-step-button--grey {
        background: #c2c2c2;
        border: none
    }

    .booking-step-button--xs {
        max-width: 76px
    }

    .booking-step-buttons .booking-step-button .booking-step-button__text {
        color: #fff;
        padding: 9px
    }

    .booking-steps-final .booking-step-button {
        width: 100%
    }

    .booking-step__content {
        margin-top: 12px
    }

    .booking-step1_container .booking-last-descr {
        margin-block: 12px 24px;
    }

    .booking-step--one .booking-step__error {
        margin-left: auto
    }

    .booking-step__number span {
        border-width: 1.8px
    }

    .booking-step__number {
        left: -35px
    }

    .booking-step__block::before {
        left: -22px;
        border-right-width: 1.5px
    }

    .booking-step__block--last {
        padding-bottom: 0
    }

    .booking-step__name--sm {
        font-size: 17px;
        line-height: 19px
    }

    .booking-step__name--md {
        margin-bottom: 8px;
        font-size: 18px;
        line-height: 22px;
        color: #474747
    }

    .booking-step__name--lg {
        font-size: 22px;
        line-height: 25px
    }

    .booking-step__name--xs {
        line-height: 20px
    }

    .booking-step__text {
        font-size: 15px;
        line-height: 18px;
        color: #525557
    }

    .booking-step__button-cashback {
        font-size: 9.75px;
        font-weight: 800;
        letter-spacing: -.07px;
        line-height: 13px;
        min-width: 80px;
        padding: 2.5px 7px
    }

    .subscribe-container .booking-step__ps {
        font-size: 11px;
        margin-top: 21px;
        line-height: 15px
    }

    .booking-step__button {
        width: 200px;
        height: 40px
    }

    .booking-step__card {
        height: auto;
        padding: 25px 40px
    }

        .booking-step__card input {
            height: auto
        }

    .booking-step__time {
        margin-left: auto;
        margin-right: auto
    }

    .booking-step__time-link {
        text-align: center;
        margin-left: 0
    }

    .booking-step__error {
        height: auto !important;
        min-height: 100%;
        width: 100%;
        padding: 10px 25px 10px 35px
    }

    .booking-step__box-label {
        width: 100%;
        height: 80px;
        padding: 10px 15px;
        -webkit-box-align: center;
        -webkit-align-items: center;
        -ms-flex-align: center;
        align-items: center
    }

    .booking-step__box-label--small .booking-step__box-title {
        line-height: 18px
    }

    .booking-step__choose-name--strong {
        font-size: 15px
    }

    .booking-step__radios {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -webkit-flex-direction: column;
        -ms-flex-direction: column;
        flex-direction: column;
        order: 1;
        margin-left: 12px;
        margin-right: 0
    }

    .booking-step__level {
        width: calc(100% + 25px);
        max-width: calc(100% + 25px);
        transform: translateX(-25px);
        height: 44px
    }

    .booking-step__level-item label span {
        font-size: 14px
    }

    .booking-step__level-info ul li {
        font-size: 12px;
        line-height: 16px
    }

    .booking-step__level-info {
        margin-left: -8%;
        max-width: none;
        margin-right: -24px
    }

    .booking-step__label input, .booking-step__label textarea {
        width: 100%
    }

    .booking-step__label--cvc {
        width: auto !important
    }

    .booking-step__label--date {
        width: auto !important
    }

    .booking-step__label textarea, .booking-step__label textarea {
        width: 100%
    }

    .booking-step__label {
        width: 100%;
        margin-right: 0
    }

    .booking-step__card-block--small {
        padding: 10px;
        margin-top: 32px;
    }

        .booking-step__card-block--small p {
            font-size: 14px
        }

    .booking-step__card-container {
        width: 80%
    }

    .booking-steps__items {
        width: 100%;
        min-width: 90%
    }

    .booking-steps__info {
        display: none
    }

    .calendar-container {
        margin-inline: auto
    }

    .tooltip-container {
        margin-bottom: 0;
    }

    .mob-app-bedges {
        display: block;
    }

    .booking-step1_container .step1-postcode .form__error {
        margin-left: 16px;
    }

    .cleaning-duration.active input[type="radio"]::before, .cleaning-duration:hover input[type="radio"]::before,
    .what-time.active input[type="radio"]::before, .what-time:hover input[type="radio"]::before {
        width: 4px;
        height: 4px;
    }

    .cleaning-duration input[type="radio"]:checked::before, .what-time input[type="radio"]:checked::before {
        width: 4px;
        height: 4px;
    }

    .info-modal  {
        padding: 16px;
    }
/*    .booking-step1_container .step1-postcode label,
    .booking-step1_container .step1-rooms_card h4,
    .booking-step1_container .need-extra,
    .booking-step1_container .extra-service h4,
    .cleaning-duration div h4, .how-often div,
    .booking-step5_container .what-time p,
    .account-info_1 h3, .account-info_2 h3, .account-info_3 h3,
    .account-details .have-account,
    .booking-promo div p, .booking-date div p {
        font-family: "Graphik LC Medium", sans-serif;
    }*/

/*    .booking-step1_container .extra-service span,
    .booking-step5_container .what-time span {
        font-family: "Graphik LC", sans-serif;
    }*/
}

@media all and (max-width: 490px) {
    .booking-steps-check__tooltip {
        left: 50%;
        transform: translate(-50%,-100%)
    }
}

@media screen and (max-width: 480px) {
    .payment_form {
        display: block !important
    }

        .payment_form label {
            margin-right: 0
        }

        .payment_form .card_cvv_wrap, .payment_form .card_expiry_wrap {
            -webkit-box-ordinal-group: 2;
            -webkit-order: 1;
            -ms-flex-order: 1;
            order: 1;
            margin-right: 16px
        }

        .payment_form .card_name, .payment_form .card_name_wrap, .payment_form .card_number_wrap {
            width: 100%;
            min-height: 65px
        }

    .booking-steps-final__content::before {
        left: -3%
    }

    .booking-steps-final__content::after {
        left: -1%
    }

    .modal-waiting {
        font-size: 26px
    }
}

@media (max-width: 430px) {
    .booking-step__choose-item__with__eco .ecover_desk {
        display: none
    }

    .booking-step__choose-item__with__eco .ecover_mob {
        padding: 0;
        border: 0;
        width: 100px;
        margin-bottom: 7px;
        display: block
    }

    .existing-account {
        font-size: 14.5px;
    }
}

@media only screen and (max-width: 379px) {
    .booking-step_container #calendars {
        margin-top: 36px
    }
}

@media only screen and (max-width: 375px) {
    .booking-step-button__text {
        font-size: 16px
    }

    .booking-steps-header__item {
        width: -webkit-calc(100% / 3);
        width: calc(100% / 3)
    }

    .booking-steps-check--dropdown {
        padding-top: 15%
    }

    .booking-steps-check__date {
        font-size: 16px;
        font-weight: 700
    }

    .booking-steps-check__item .booking-steps-check__date--day, .booking-steps-check__date--day {
        font-size: 14px;
        font-weight: 400
    }

    .booking-steps-check__promo button {
        width: 28%
    }

    .booking-steps-final__content::before {
        left: 0
    }

    .booking-steps-final__content::after {
        left: 5px
    }

    .booking-steps-final__content {
        padding-left: 40px
    }

    .booking-steps-final .booking-step__block {
        margin-left: 40px
    }

    .booking-steps-final {
        padding: 20px
    }

    .booking-step__button {
        width: 200px;
        height: 40px
    }

    .booking-step__box-row {
        margin-right: 0
    }

        .booking-step__box-row input {
            font-size: 16px;
            line-height: 20px;
            color: #483188
        }

    .booking-step__label-row input {
        width: 50px !important
    }

    .booking-step__label input:focus, .booking-step__label textarea:focus {
        font-weight: 400
    }

    .booking-step__label input, .booking-step__label textarea {
        font-size: 16px;
        line-height: 20px
    }
}
