@charset "UTF-8";

.d-grid {
    display: grid
}

.px-0 {
    padding-left: 0 !important;
    padding-right: 0 !important
}

.iti__flag {
    background-image: url(https://cdnjs.cloudflare.com/ajax/libs/intl-tel-input/17.0.12/img/flags.png)
}

@media (-webkit-min-device-pixel-ratio: 2),
(min-resolution: 192dpi) {
    .iti__flag {
        background-image: url(https://cdnjs.cloudflare.com/ajax/libs/intl-tel-input/17.0.12/img/flags@2x.png)
    }
}

.iti__country {
    display: flex;
    justify-content: space-between
}

@media only screen and (max-width: 767px) {
    .c-row>.inner {
        flex-direction: column
    }

    .desktop-only {
        display: none
    }

    .c-row {
        width: 100% !important
    }

    .image-container {
        text-align: center !important
    }

    .c-column {
        width: 100% !important
    }

    .c-section,
    .c-section>.inner,
    .c-row>.inner,
    .c-column,
    .c-column>.inner {
        padding-left: 0 !important;
        padding-right: 0 !important
    }

    .c-row {
        padding-left: 10px !important;
        padding-right: 10px !important;
        margin-left: 0 !important;
        margin-right: 0 !important
    }
}

@media only screen and (min-width: 768px) {
    .mobile-only {
        display: none
    }
}

.c-button button {
    outline: none;
    position: relative
}

.fa,
.fab,
.fal,
.far,
.fas {
    -webkit-font-smoothing: antialiased;
    display: inline-block;
    font-style: normal;
    font-variant: normal;
    text-rendering: auto;
    line-height: 1
}

.c-column {
    flex: 1 1 auto !important
}

.c-column>.inner.horizontal>div {
    flex: 1
}

.c-row>.inner {
    width: 100%;
    display: flex
}

.bgCover.bg-fixed:before {
    background-size: cover !important;
    -webkit-background-size: cover !important;
    background-attachment: fixed !important;
    background-repeat: repeat repeat !important;
    background-position: center center !important
}

.bgCover100.bg-fixed:before {
    background-size: 100% auto !important;
    -webkit-background-size: 100% auto !important;
    background-repeat: no-repeat !important
}

.bgNoRepeat.bg-fixed:before {
    background-repeat: no-repeat !important
}

.bgRepeatX.bg-fixed:before {
    background-repeat: repeat-x !important
}

.bgRepeatY.bg-fixed:before {
    background-repeat: repeat-y !important
}

.bgRepeatXTop.bg-fixed:before {
    background-repeat: repeat-x !important;
    background-position: top !important
}

.bgRepeatXBottom.bg-fixed:before {
    background-repeat: repeat-x !important;
    background-position: bottom !important
}

.bgCover {
    background-size: cover !important;
    -webkit-background-size: cover !important;
    background-attachment: fixed !important;
    background-repeat: repeat repeat !important;
    background-position: center center !important
}

.bgCover100 {
    background-size: 100% auto !important;
    -webkit-background-size: 100% auto !important;
    background-repeat: no-repeat !important
}

.bgNoRepeat {
    background-repeat: no-repeat !important
}

.bgRepeatX {
    background-repeat: repeat-x !important
}

.bgRepeatY {
    background-repeat: repeat-y !important
}

.bgRepeatXTop {
    background-repeat: repeat-x !important;
    background-position: top !important
}

.bgRepeatXBottom {
    background-repeat: repeat-x !important;
    background-position: bottom !important
}

.cornersTop {
    border-bottom-left-radius: 0 !important;
    border-bottom-right-radius: 0 !important
}

.cornersBottom {
    border-top-left-radius: 0 !important;
    border-top-right-radius: 0 !important
}

.radius0 {
    border-radius: 0
}

.radius1 {
    border-radius: 1px
}

.radius2 {
    border-radius: 2px
}

.radius3 {
    border-radius: 3px
}

.radius4 {
    border-radius: 4px
}

.radius5 {
    border-radius: 5px
}

.radius10 {
    border-radius: 10px
}

.radius15 {
    border-radius: 15px
}

.radius20 {
    border-radius: 20px
}

.radius25 {
    border-radius: 25px
}

.radius50 {
    border-radius: 50px
}

.radius75 {
    border-radius: 75px
}

.radius100 {
    border-radius: 100px
}

.radius125 {
    border-radius: 125px
}

.radius150 {
    border-radius: 150px
}

.borderTopBottom {
    border-top-color: #000000b3;
    border-bottom-color: #000000b3;
    border-left: none !important;
    border-right: none !important
}

.borderTop {
    border-top-color: #000000b3;
    border-bottom: none !important;
    border-left: none !important;
    border-right: none !important
}

.borderBottom {
    border-top: none !important;
    border-left: none !important;
    border-right: none !important;
    border-bottom-color: #000000b3
}

.borderFull {
    border-color: #000000b3
}

.noBorder {
    border: none !important
}

@-webkit-keyframes rocking {
    0% {
        transform: rotate(0)
    }

    25% {
        transform: rotate(0)
    }

    50% {
        transform: rotate(2deg)
    }

    75% {
        transform: rotate(-2deg)
    }

    to {
        transform: rotate(0)
    }
}

@keyframes rocking {
    0% {
        transform: rotate(0)
    }

    25% {
        transform: rotate(0)
    }

    50% {
        transform: rotate(2deg)
    }

    75% {
        transform: rotate(-2deg)
    }

    to {
        transform: rotate(0)
    }
}

.buttonRocking {
    -webkit-animation: rocking 2s infinite;
    animation: rocking 2s infinite;
    -webkit-animation-timing-function: cubic-bezier(0, 0, .58, 1);
    animation-timing-function: cubic-bezier(0, 0, .58, 1);
    transition: .2s
}

.buttonPulseGlow {
    -webkit-animation: pulseGlow 2s infinite;
    animation: pulseGlow 2s infinite;
    -webkit-animation-timing-function: ease-in-out;
    animation-timing-function: ease-in-out
}

@-webkit-keyframes pulseGlow {
    0% {
        box-shadow: 0 0 #fff0
    }

    25% {
        box-shadow: 0 0 2.5px 1px #ffffff40
    }

    50% {
        box-shadow: 0 0 5px 2px #ffffff80
    }

    85% {
        box-shadow: 0 0 5px 5px #fff0
    }

    to {
        box-shadow: 0 0 #fff0
    }
}

@keyframes pulseGlow {
    0% {
        box-shadow: 0 0 #fff0
    }

    25% {
        box-shadow: 0 0 2.5px 1px #ffffff40
    }

    50% {
        box-shadow: 0 0 5px 2px #ffffff80
    }

    85% {
        box-shadow: 0 0 5px 5px #fff0
    }

    to {
        box-shadow: 0 0 #fff0
    }
}

.buttonBounce {
    -webkit-animation: bounce 1.5s infinite;
    animation: bounce 1.5s infinite;
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
    transition: .2s
}

@-webkit-keyframes bounce {
    15% {
        transform: translateY(0);
        box-shadow: 0 0 0 0 transparent
    }

    35% {
        transform: translateY(-35%);
        box-shadow: 0 8px 5px -5px #00000040
    }

    45% {
        transform: translateY(0);
        box-shadow: 0 0 0 0 transparent
    }

    55% {
        transform: translateY(-20%);
        box-shadow: 0 5px 4px -4px #00000040
    }

    70% {
        transform: translateY(0);
        box-shadow: 0 0 0 0 transparent
    }

    80% {
        transform: translateY(-10%);
        box-shadow: 0 4px 3px -3px #00000040
    }

    90% {
        transform: translateY(0);
        box-shadow: 0 0 0 0 transparent
    }

    95% {
        transform: translateY(-2%);
        box-shadow: 0 2px 3px -3px #00000040
    }

    99% {
        transform: translateY(0);
        box-shadow: 0 0 0 0 transparent
    }

    to {
        transform: translateY(0);
        box-shadow: 0 0 0 0 transparent
    }
}

@keyframes bounce {
    15% {
        transform: translateY(0);
        box-shadow: 0 0 0 0 transparent
    }

    35% {
        transform: translateY(-35%);
        box-shadow: 0 8px 5px -5px #00000040
    }

    45% {
        transform: translateY(0);
        box-shadow: 0 0 0 0 transparent
    }

    55% {
        transform: translateY(-20%);
        box-shadow: 0 5px 4px -4px #00000040
    }

    70% {
        transform: translateY(0);
        box-shadow: 0 0 0 0 transparent
    }

    80% {
        transform: translateY(-10%);
        box-shadow: 0 4px 3px -3px #00000040
    }

    90% {
        transform: translateY(0);
        box-shadow: 0 0 0 0 transparent
    }

    95% {
        transform: translateY(-2%);
        box-shadow: 0 2px 3px -3px #00000040
    }

    99% {
        transform: translateY(0);
        box-shadow: 0 0 0 0 transparent
    }

    to {
        transform: translateY(0);
        box-shadow: 0 0 0 0 transparent
    }
}

.buttonElevate:hover {
    transform: translateY(-10px);
    box-shadow: 0 8px 5px -5px #00000040
}

.buttonElevate {
    transition: .2s;
    box-shadow: 0 0 0 0 transparent
}

.buttonWobble {
    transition: .3s
}

.buttonWobble:hover {
    -webkit-animation: wobble .5s 1;
    animation: wobble .5s 1;
    -webkit-animation-timing-function: ease-in-out;
    animation-timing-function: ease-in-out
}

@-webkit-keyframes wobble {
    0% {
        transform: skew(0)
    }

    25% {
        transform: skew(10deg)
    }

    50% {
        transform: skew(0)
    }

    75% {
        transform: skew(-10deg)
    }

    to {
        transform: skew(0)
    }
}

@keyframes wobble {
    0% {
        transform: skew(0)
    }

    25% {
        transform: skew(10deg)
    }

    50% {
        transform: skew(0)
    }

    75% {
        transform: skew(-10deg)
    }

    to {
        transform: skew(0)
    }
}

.image-container img {
    max-width: 100%;
    vertical-align: middle
}

.sub-text ::-moz-placeholder {
    color: #000;
    opacity: 1
}

.sub-text :-ms-input-placeholder {
    color: #000;
    opacity: 1
}

.sub-text ::placeholder {
    color: #000;
    opacity: 1
}

.image-container {
    width: 100%;
    height: 100%
}

.shadow5inner {
    box-shadow: 0 1px 3px #0000000d inset
}

.shadow10inner {
    box-shadow: 0 1px 5px #0000001a inset
}

.shadow20inner {
    box-shadow: 0 1px 5px #0003 inset
}

.shadow30inner {
    box-shadow: 0 2px 5px 2px #0000004d inset
}

.shadow40inner {
    box-shadow: 0 2px 5px 2px #0006 inset
}

.shadow5 {
    box-shadow: 0 1px 3px #0000000d
}

.shadow10 {
    box-shadow: 0 1px 5px #0000001a
}

.shadow20 {
    box-shadow: 0 1px 5px #0003
}

.shadow30 {
    box-shadow: 0 2px 5px 2px #0000004d
}

.shadow40 {
    box-shadow: 0 2px 5px 2px #0006
}

.sub-heading-button {
    text-align: center;
    color: #fff;
    line-height: normal;
    opacity: .8;
    font-weight: 400
}

.wideSection {
    max-width: 1120px;
    margin-left: auto !important;
    margin-right: auto !important
}

.midWideSection {
    max-width: 960px;
    margin-left: auto !important;
    margin-right: auto !important
}

.midSection {
    max-width: 720px;
    margin-left: auto !important;
    margin-right: auto !important
}

.c-section>.inner {
    max-width: 1170px;
    width: 100%;
    margin-right: auto;
    margin-left: auto
}

.c-column {
    padding-right: 15px;
    padding-left: 15px
}

.img-circle,
.feature-img-circle img {
    border-radius: 50% !important
}

.img-round-corners,
.feature-img-round-corners img {
    border-radius: 5px
}

.image-dark-border,
.feature-image-dark-border img {
    border: 3px solid rgba(0, 0, 0, .7)
}

.image-white-border,
.feature-image-white-border img {
    border: 3px solid #fff
}

.img-grey {
    filter: grayscale(100%);
    filter: gray;
    -webkit-transition: all .6s ease
}

.button-shadow1 {
    box-shadow: 0 1px 5px #0003
}

.button-shadow2 {
    box-shadow: 0 1px 5px #0006
}

.button-shadow3 {
    box-shadow: 0 1px 5px #000000b3
}

.button-shadow4 {
    box-shadow: 0 8px 1px #0000001a
}

.button-shadow5 {
    box-shadow: 0 0 25px #0003, 0 0 15px #0003, 0 0 3px #0006
}

.button-shadow6 {
    box-shadow: 0 0 25px #0006, 0 0 15px #fff3, 0 0 3px #fff6
}

.button-shadow-sharp1 {
    box-shadow: inset 0 1px #fff3
}

.button-shadow-sharp2 {
    box-shadow: inset 0 0 0 1px #fff3
}

.button-shadow-sharp3 {
    box-shadow: inset 0 0 0 2px #fff3
}

.button-shadow-highlight {
    box-shadow: none
}

.button-shadow-highlight:hover {
    box-shadow: inset 0 0 #ffffff38, 0 233px 233px #ffffff1f inset
}

.button-flat-line {
    background-color: transparent !important;
    border-width: 2px
}

.button-vp-5 {
    padding-top: 5px !important;
    padding-bottom: 5px !important
}

.button-vp-10 {
    padding-top: 10px !important;
    padding-bottom: 10px !important
}

.button-vp-15 {
    padding-top: 15px !important;
    padding-bottom: 15px !important
}

.button-vp-20 {
    padding-top: 20px !important;
    padding-bottom: 20px !important
}

.button-vp-25 {
    padding-top: 25px !important;
    padding-bottom: 25px !important
}

.button-vp-30 {
    padding-top: 30px !important;
    padding-bottom: 30px !important
}

.button-vp-40 {
    padding-top: 40px !important;
    padding-bottom: 40px !important
}

.button-vp-0 {
    padding-top: 0 !important;
    padding-bottom: 0 !important
}

.button-hp-5 {
    padding-left: 5px !important;
    padding-right: 5px !important
}

.button-hp-10 {
    padding-left: 10px !important;
    padding-right: 10px !important
}

.button-hp-15 {
    padding-left: 15px !important;
    padding-right: 15px !important
}

.button-hp-20 {
    padding-left: 20px !important;
    padding-right: 20px !important
}

.button-hp-25 {
    padding-left: 25px !important;
    padding-right: 25px !important
}

.button-hp-30 {
    padding-left: 30px !important;
    padding-right: 30px !important
}

.button-hp-40 {
    padding-left: 40px !important;
    padding-right: 40px !important
}

.button-hp-0 {
    padding-left: 0 !important;
    padding-right: 0 !important
}

.vs__dropdown-toggle {
    height: 43px !important;
    border: none !important;
    background: #f3f8fb !important
}

.row-align-center {
    margin: 0 auto
}

.row-align-left {
    margin: 0 auto;
    margin-left: 0 !important
}

.row-align-right {
    margin: 0 auto;
    margin-right: 0 !important
}

input,
button,
select,
optgroup,
textarea {
    margin: unset;
    font-family: unset;
    font-size: unset;
    line-height: unset;
    border-radius: unset;
    text-transform: unset
}

body {
    line-height: unset !important;
    font-weight: unset !important;
    -moz-osx-font-smoothing: grayscale;
    word-wrap: break-word
}

*,
:before,
:after {
    box-sizing: border-box
}

.main-heading-group>div {
    display: inline-block
}

.c-button span.main-heading-group,
.c-button span.sub-heading-group {
    display: block
}

.time-grid-3 {
    display: grid;
    grid-template-columns: repeat(3, 100px);
    text-align: center
}

.time-grid-4 {
    display: grid;
    grid-template-columns: repeat(4, 100px);
    text-align: center
}

@media screen and (max-width: 767px) {
    .time-grid-3 {
        grid-template-columns: repeat(3, 80px)
    }

    .time-grid-4 {
        grid-template-columns: repeat(4, 70px)
    }
}

.time-grid .timer-box {
    display: grid;
    grid-template-columns: 1fr;
    text-align: center;
    font-size: 15px
}

.timer-box .label {
    font-weight: 300
}

.c-button button {
    cursor: pointer
}

.c-button>a {
    display: inline-block;
    text-decoration: none
}

.c-button>a span {
    display: inline-block
}

.nav-menu-wrapper {
    display: flex;
    justify-content: space-between
}

.nav-menu-wrapper.default {
    flex-direction: row
}

.nav-menu-wrapper.reverse {
    flex-direction: row-reverse
}

.nav-menu-wrapper .branding {
    display: flex;
    align-items: center
}

.nav-menu-wrapper.default .branding {
    flex-direction: row
}

.nav-menu-wrapper.reverse .branding {
    flex-direction: row-reverse
}

.nav-menu-wrapper.default .branding .logo,
.nav-menu-wrapper.reverse .branding .title {
    margin-right: 18px
}

.nav-menu-wrapper .branding .title {
    min-width: 50px;
    min-height: 50px;
    display: flex;
    align-items: center
}

.nav-menu {
    display: flex;
    list-style: none;
    margin: 0;
    padding: 0;
    align-items: center;
    justify-content: space-around
}

.nav-menu a {
    text-decoration: none
}

.dropdown {
    display: inline-block;
    position: relative
}

.dropdown .dropdown-menu {
    border: none;
    box-shadow: 0 8px 16px 5px #0000001a
}

.dropdown-menu {
    position: absolute;
    top: 100%;
    left: 0;
    z-index: 1000;
    display: none;
    float: left;
    min-width: 10rem;
    padding: .5rem 0;
    margin: .125rem 0 0;
    font-size: 1rem;
    color: #607179;
    text-align: left;
    list-style: none;
    background-color: #fff;
    background-clip: padding-box;
    border: 1px solid rgba(0, 0, 0, .15);
    border-radius: .3125rem
}

.nav-menu .nav-menu-item.dropdown:hover>.dropdown-menu {
    display: block
}

.nav-menu .dropdown-menu {
    margin: 0;
    padding: 0;
    display: none;
    list-style: none
}

.nav-menu-mobile {
    display: flex;
    align-items: center
}

.nav-menu-mobile i {
    font-size: 24px;
    cursor: pointer
}

#nav-menu-popup {
    position: fixed;
    display: none;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 100;
    opacity: 0;
    transition: opacity .3s ease;
    background: var(--overlay)
}

#nav-menu-popup.show {
    opacity: 1
}

#nav-menu-popup .nav-menu-body {
    position: absolute;
    background-color: #fff;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    padding: 45px;
    overflow: auto
}

#nav-menu-popup .nav-menu-body .close-menu {
    cursor: pointer;
    position: absolute;
    top: 20px;
    left: 20px;
    z-index: 100
}

#nav-menu-popup .nav-menu-body .close-menu:before {
    content: "\f00d"
}

#nav-menu-popup .nav-menu {
    display: flex;
    flex-direction: column;
    list-style: none;
    padding: 0;
    margin: 0;
    align-items: center
}

#nav-menu-popup .nav-menu .nav-menu-item {
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    width: 100%;
    text-align: left;
    list-style: none
}

#nav-menu-popup .nav-menu .nav-menu-item .nav-menu-item-content {
    display: flex;
    position: relative
}

#nav-menu-popup .nav-menu-item .nav-menu-item-title {
    margin: 0 1rem;
    max-width: calc(100% - 2rem);
    flex-grow: 1
}

#nav-menu-popup .nav-menu .nav-menu-item .nav-menu-item-content .nav-menu-item-toggle {
    position: absolute;
    top: calc(50% - 12px);
    right: 0;
    font-size: 24px;
    cursor: pointer
}

#nav-menu-popup .nav-menu .nav-menu-item .nav-menu-item-content .nav-menu-item-toggle i {
    font-size: 24px;
    transition: transform .2s ease
}

#nav-menu-popup .nav-menu .nav-menu-item .nav-menu-item-content .nav-menu-item-toggle i:before {
    content: "\f107"
}

#nav-menu-popup .nav-menu .nav-menu-item.active .nav-menu-item-content .nav-menu-item-toggle i {
    transform: rotate(-180deg)
}

#nav-menu-popup .nav-menu .nav-menu-item .nav-dropdown-menu {
    padding: 0;
    display: none;
    opacity: 0;
    max-height: 0;
    overflow: auto;
    visibility: hidden;
    transition: all .3s ease-in-out
}

#nav-menu-popup .nav-menu .nav-menu-item.active .nav-dropdown-menu {
    display: block;
    opacity: 1;
    max-height: 600px;
    visibility: visible
}

.form-error {
    border: 2px solid var(--red);
    border-radius: 8px;
    color: var(--red);
    font-size: 20px;
    padding: 6px 12px;
    cursor: pointer;
    text-align: center;
    margin-bottom: 10px
}

.form-error i {
    color: var(--red)
}

.c-bullet-list ul li {
    line-height: inherit
}

.c-bullet-list ul li.ql-indent-1 {
    padding-left: 4.5em
}

.c-bullet-list ul li.ql-indent-2 {
    padding-left: 7.5em
}

.c-bullet-list ul li.ql-indent-3 {
    padding-left: 10.5em
}

.c-bullet-list ul li.ql-indent-4 {
    padding-left: 13.5em
}

.c-bullet-list ul li.ql-indent-5 {
    padding-left: 16.5em
}

.c-bullet-list ul li.ql-indent-6 {
    padding-left: 19.5em
}

.c-bullet-list ul li.ql-indent-7 {
    padding-left: 22.5em
}

.c-bullet-list ul li.ql-indent-8 {
    padding-left: 25.5em
}

.text-output ul,
.text-output ol {
    list-style-type: none;
    padding: 0;
    margin: 0
}

.text-output ol li p:before {
    content: counter(list-item) ". "
}

.text-output ul li {
    padding-left: 1.5em
}

.text-output ul li:before {
    font-weight: 700;
    margin-right: .3em;
    margin-left: -1.5em;
    text-align: right;
    display: inline-block;
    width: 1.2em;
    white-space: nowrap
}

.svg-component svg {
    max-width: 100%;
    max-height: 100%
}

.border1 {
    border-bottom: solid 3px rgba(0, 0, 0, .2) !important
}

.border2 {
    border: 2px solid rgba(0, 0, 0, .55)
}

.border3 {
    border: 1px solid rgba(0, 0, 0, .15);
    border-bottom: 2px solid rgba(0, 0, 0, .15);
    padding: 5px
}

.border4 {
    border: 1px solid rgba(0, 0, 0, .35);
    border-bottom: 2px solid rgba(0, 0, 0, .35);
    padding: 1px !important
}

.shadow1 {
    box-shadow: 0 10px 6px -6px #00000026
}

.shadow2 {
    box-shadow: 0 4px 3px #00000026, 0 0 2px #00000026
}

.shadow3 {
    box-shadow: 0 10px 6px -6px #999
}

.shadow4 {
    box-shadow: 3px 3px 15px #212121a8
}

.shadow6 {
    box-shadow: 0 10px 1px #ddd, 0 10px 20px #ccc
}

.background {
    background-color: unset !important
}

@-webkit-keyframes progress-bar-animation {
    to {
        background-position: 0px -3000px
    }
}

@keyframes progress-bar-animation {
    to {
        background-position: 0px -3000px
    }
}

@-webkit-keyframes gradient {
    0% {
        background-position: 0% 50%
    }

    50% {
        background-position: 100% 50%
    }

    to {
        background-position: 0% 50%
    }
}

@keyframes gradient {
    0% {
        background-position: 0% 50%
    }

    50% {
        background-position: 100% 50%
    }

    to {
        background-position: 0% 50%
    }
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-weight: 500;
    margin: unset
}

.c-heading,
.c-paragraph,
.c-sub-heading,
.c-bullet-list,
.c-image-feature {
    word-break: break-word
}

p:empty:after {
    content: "\a0"
}

.image-container[data-v-5d0761c8] {
    width: 100%;
    height: 100%
}

.v-spinner .v-moon1 {
    -webkit-animation: v-moonStretchDelay .6s 0s infinite linear;
    animation: v-moonStretchDelay .6s 0s infinite linear;
    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards;
    position: relative
}

.v-spinner .v-moon2 {
    -webkit-animation: v-moonStretchDelay .6s 0s infinite linear;
    animation: v-moonStretchDelay .6s 0s infinite linear;
    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards;
    opacity: .8;
    position: absolute
}

.v-spinner .v-moon3 {
    opacity: .1
}

@-webkit-keyframes v-moonStretchDelay {
    to {
        transform: rotate(360deg)
    }
}

@keyframes v-moonStretchDelay {
    to {
        transform: rotate(360deg)
    }
}

.button-disabled[data-v-3e12c334] {
    cursor: default
}

.btn-visibility-none[data-v-3e12c334] {
    visibility: hidden
}

.btn-loader-position[data-v-3e12c334] {
    position: absolute;
    left: 50%;
    transform: translate(-50%, -50%);
    top: 50%
}

.button-icon-start[data-v-3e12c334] {
    margin-right: 5px
}

.button-icon-end[data-v-3e12c334] {
    margin-left: 5px
}

.video-container[data-v-337fd95c] {
    width: 100%;
    margin: auto;
    text-align: center;
    position: relative;
    background-position: 50% !important;
    background-size: cover !important
}

.video-overlay[data-v-337fd95c],
.thumbnail-container[data-v-337fd95c] {
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 1;
    z-index: 1
}

.iframe-container[data-v-337fd95c] {
    width: 100%;
    position: relative;
    margin: auto;
    background-color: #000
}

iframe[data-v-337fd95c] {
    margin: auto;
    border: none;
    box-shadow: none;
    z-index: 2;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #000
}

.figure[data-v-337fd95c] {
    margin: auto
}

.figure span[data-v-337fd95c] {
    display: block;
    position: relative;
    text-decoration: none;
    cursor: pointer
}

.figure span[data-v-337fd95c]:focus:after,
.figure span[data-v-337fd95c]:hover:after {
    background-color: #87cefa;
    opacity: 1
}

.figure.youtube span[data-v-337fd95c]:focus:after,
.figure.youtube span[data-v-337fd95c]:hover:after {
    background-color: red
}

.figure span[data-v-337fd95c]:after {
    background-color: #00000080;
    border-radius: 10px;
    bottom: 0;
    color: #fff;
    content: "\25b6";
    display: block;
    font-size: 25px;
    height: 50px;
    left: 0;
    line-height: 2;
    opacity: .75;
    margin: auto;
    position: absolute;
    right: 0;
    text-align: center;
    top: 0;
    transition: background-color .25s, opacity .25s;
    width: 75px
}

.video-icon[data-v-337fd95c]:before {
    color: #fff;
    content: "\f03d";
    font-family: "Font Awesome 5 Free";
    margin-right: 5px;
    font-weight: 700;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: 20px
}

.bg[data-v-2f09a02e] {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none
}

.full-center[data-v-2f09a02e] {
    background-position: center center !important;
    background-size: cover !important;
    background-repeat: repeat repeat !important
}

.fill-width[data-v-2f09a02e] {
    background-size: 100% auto !important;
    background-repeat: no-repeat !important
}

.fill-width-height[data-v-2f09a02e] {
    background-size: 100% 100% !important;
    background-repeat: no-repeat !important
}

.no-repeat[data-v-2f09a02e] {
    background-repeat: no-repeat !important
}

.repeat-x[data-v-2f09a02e] {
    background-repeat: repeat-x !important
}

.repeat-y[data-v-2f09a02e] {
    background-repeat: repeat-y !important
}

.repeat-x-fix-top[data-v-2f09a02e] {
    background-repeat: repeat-x !important;
    background-position: top !important
}

.repeat-x-fix-bottom[data-v-2f09a02e] {
    background-repeat: repeat-x !important;
    background-position: bottom !important
}

.custom-code-container iframe[data-v-436e1a9e] {
    width: 100%;
    height: 100%
}

* {
    box-sizing: border-box
}

body {
    margin: 0
}

.hl-app {
    font-family: Roboto, Helvetica Neue, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", Segoe UI Symbol;
    color: #607179;
    line-height: 1.7;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    padding: 0 !important;
    min-height: 100%;
    margin: 0;
    font-size: .875rem;
    font-weight: 400;
    line-height: 1.8
}

.hl-app h1,
.hl-app h2,
.hl-app h3,
.hl-app h4,
.hl-app h5,
.hl-app h6 {
    color: #2a3135;
    font-weight: 400;
    margin: 0;
    line-height: 1.2
}

.hl-app .h1,
.hl-app .h3,
.hl-app .h6 h1,
.hl-app h3,
.hl-app h6 {
    margin-bottom: 0rem;
    font-family: inherit;
    font-weight: 500;
    line-height: 1.2;
    color: inherit;
    margin-top: 0
}

.hl-app .h1,
.hl-app h1 {
    font-size: 2.5rem
}

.hl-app .h2,
.hl-app h2 {
    font-size: 2rem
}

.hl-app .h3,
.hl-app h3 {
    font-size: 1.75rem
}

.hl-app .h4,
.hl-app h4 {
    font-size: 1.5rem
}

.hl-app .h5,
.hl-app h5 {
    font-size: 1.25rem
}

.hl-app .h6,
.hl-app h6 {
    font-size: 1rem
}

.hl-app .row {
    display: flex;
    flex-wrap: wrap;
    margin-right: -15px;
    margin-left: -15px
}

.hl-app .cal-row {
    display: flex;
    flex-wrap: wrap
}

.hl-app .col-12,
.hl-app .col-6,
.hl-app .col-8,
.hl-app .col-sm-3,
.hl-app .col-sm-6,
.hl-app .col-md-3,
.hl-app .col-md-12 {
    position: relative;
    width: 100%;
    min-height: 1px
}

.hl-app .col-sm-3 {
    flex: 0 0 25%;
    max-width: 25%
}

.hl-app .col-sm-6 {
    flex: 0 0 50%;
    max-width: 50%
}

.hl-app .col-md-3 {
    flex: 0 0 25%;
    max-width: 25%
}

.hl-app .col-md-12 {
    flex: 0 0 100%;
    max-width: 100%
}

.hl-app .col-8 {
    flex: 0 0 66.6666666667%;
    max-width: 66.6666666667%
}

.hl-app .mb-1,
.hl-app .my-1 {
    margin-bottom: .25rem !important
}

.hl-app .mb-2,
.hl-app .my-2 {
    margin-bottom: .5rem !important
}

.hl-app .ml-2,
.hl-app .mx-2 {
    margin-left: .5rem !important
}

.hl-app .mr-2,
.hl-app .mx-2 {
    margin-right: .5rem !important
}

.hl-app .pr-3,
.hl-app .px-3 {
    padding-right: 1rem !important
}

.hl-app .px-2 {
    padding-right: 15px !important;
    padding-left: 15px !important
}

.hl-app .p-0 {
    padding: 0 !important
}

.hl-app .pl-0,
.hl-app .px-0 {
    padding-left: 0 !important
}

.hl-app .d-flex {
    display: flex !important
}

.hl-app .align-items-center {
    align-items: center !important
}

.hl-app a {
    color: #188bf6;
    text-decoration: none;
    background-color: transparent;
    -webkit-text-decoration-skip: objects;
    transition: all .2s ease-in-out
}

.hl-app a:hover,
.hl-app a:active,
.hl-app a:focus {
    color: #0871d3;
    text-decoration: none;
    outline: none
}

.hl-app a:active:focus {
    outline: none
}

.hl-app .text-light {
    font-weight: 400
}

.hl-app .hl_widget {
    box-sizing: border-box;
    margin: auto;
    z-index: 9999999;
    background: rgba(0, 0, 0, .5)
}

.hl-app .hl_widget>* {
    box-sizing: border-box
}

.hl-app .hl_widget.popup {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    overflow: auto
}

.hl-app .hl_widget-inner {
    background-color: #fff;
    max-width: 800px;
    position: relative;
    border-radius: 4px;
    margin-left: auto;
    margin-right: auto;
    box-shadow: 5px 8.7px 20px #0000001a
}

.hl-app .hl_widget.--small .hl_widget-inner {
    max-width: 700px
}

.hl-app .white-bg {
    background-color: #fff
}

.hl-app .no-shadow {
    box-shadow: none
}

.hl-app .hl_widget-header {
    padding: 25px 50px 25px 30px;
    border-bottom: 1px solid #e6edf2
}

.hl-app .hl_widget-header h2 {
    margin: 0;
    color: #2a3135;
    line-height: 1.2;
    font-weight: 500
}

.hl-app .hl_widget-header h2 span {
    color: #607179;
    font-weight: 300;
    font-size: 14px
}

.hl-app .hl_widget-close {
    position: absolute;
    top: 10px;
    right: 20px;
    padding: 0;
    border: none;
    font-size: 30px;
    font-weight: 300;
    transition: all .2s ease-out;
    cursor: pointer;
    background: none
}

.hl-app .hl_widget-close:hover {
    opacity: .5
}

.hl-app .hl_widget-close:focus,
.hl-app .hl_widget-close:active {
    outline: none
}

.hl-app .hl_widget-body {
    padding: 20px 30px
}

.hl-app .hl_widget-body p {
    margin-top: 0
}

.hl-app .hl_widget-wrapper {
    box-sizing: border-box
}

.hl-app .hl_wrapper {
    overflow: visible
}

.hl-app .hl_wrapper.d-flex {
    align-items: stretch
}

.hl-app .hl_widget-form {
    margin-left: auto;
    margin-right: auto
}

.hl-app .pick-date-title {
    display: flex;
    align-items: center;
    margin-bottom: 1rem
}

.hl-app .btn-back {
    border: none;
    background-color: transparent
}

.hl-app .back_button,
.hl-app .hl_select_button {
    display: none
}

.hl-app .hl_widget-step1 h3 {
    font-size: 18px;
    color: #2a3135;
    font-weight: 500;
    margin-top: 0;
    margin-bottom: 25px
}

.hl-app .hl_widget-step1 p {
    font-size: 14px
}

.hl-app .hl_widget--pick-date {
    position: relative;
    word-wrap: initial
}

.hl-app .hl_widget-step1 .hl_widget--pick-date {
    margin-bottom: 40px
}

.hl-app .hl_widget-step1 .hl_widget--pick-date-time {
    display: flex;
    margin-left: -15px;
    margin-right: -15px
}

.hl-app .hl_widget-step1 .hl_widget--pick-date-time>* {
    margin-left: 15px;
    margin-right: 15px
}

.hl-app .hl_widget-step1 .hl_widget--pick-hours {
    position: relative
}

.hl-app .hl_widget-step1 .hl_widget--pick-hours h3 {
    font-size: 16px;
    color: #607179;
    font-weight: 400;
    margin-top: 0;
    margin-bottom: 20px
}

.hl-app .hl_widget-step1 .hl_widget--pick-hours h3 strong {
    color: #2a3135
}

.hl-app .hl_widget-step1 .pick-hours--wrap {
    display: flex;
    align-items: flex-start;
    margin-left: -15px;
    margin-right: -15px;
    text-align: center
}

.hl-app .hl_widget-step1 .pick-hours--wrap>* {
    flex: 1 0 0;
    margin-left: 15px;
    margin-right: 15px
}

.hl-app .hl_widget-step1 .pick-hours--wrap h4 {
    font-size: 18px;
    text-align: center;
    color: #2a3135;
    margin-top: 0;
    margin-bottom: 10px
}

.hl-app #pick-hours--am,
.hl-app #pick-hours--pm {
    max-height: 305px;
    overflow: hidden
}

.hl-app .hl_widget-step1 .hour-select {
    margin-bottom: 10px
}

.hl-app .hl_widget-step1 .hl_widget--pick-hours .loader {
    display: flex;
    justify-content: center
}

.hl-app .hl_widget-step1 .hour-select input {
    display: none;
    opacity: 0;
    visibility: hidden
}

.hl-app .hl_widget-step1 .hour-select input:checked+label {
    background-color: #188bf6;
    border-color: #188bf6;
    color: #fff
}

.hl-app .hl_widget-step1 .hour-select label {
    display: block;
    cursor: pointer;
    transition: all .2s ease-in-out;
    padding: 7px 20px;
    border: 1px solid #e6edf2;
    border-radius: 4px;
    max-width: 150px;
    margin: 0 auto;
    font-weight: 500
}

.hl-app .hl_widget-step1 .hour-select label:hover {
    background-color: #188bf61a;
    border-color: #188bf61a
}

.hl-app .hl_widget label {
    display: block;
    margin-bottom: 10px;
    font-size: 14px;
    color: #2a3135
}

.hl-app .hl_widget .hl_form-group.--select {
    position: relative
}

.hl-app .hl_widget .hl_form-group.--select:after {
    content: "";
    display: block;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 4px 4px 0 4px;
    border-color: #607179 transparent transparent transparent;
    position: absolute;
    bottom: 20px;
    right: 15px
}

.hl-app .hl_widget .hl_form-name>*:nth-child(1) {
    margin-bottom: 20px
}

.hl-app .hl_widget .hl_input:focus,
.hl-app .hl_widget .hl_input:active {
    border-color: #188bf6;
    outline: none
}

.hl-app .hl_widget .hl_input::-webkit-input-placeholder,
.hl-app .hl_widget .hl_input:-moz-placeholder,
.hl-app .hl_widget .hl_input::-moz-placeholder,
.hl-app .hl_widget .hl_input:-ms-input-placeholder {
    color: #788b94
}

.hl-app .hl_widget textarea.hl_input {
    height: auto
}

.hl-app .hl_widget .hl_input-option {
    display: inline-flex;
    align-items: center;
    margin-right: 20px
}

.hl-app .hl_widget .hl_input-option input {
    margin-right: 10px
}

.hl-app .hl_widget .hl_input-option span {
    display: inline-block;
    font-size: 14px
}

.hl-app .hl_widget-calendar {
    min-width: 700px;
    padding: 15px 35px;
    border: 1px solid #e6edf2;
    margin-left: auto;
    margin-right: auto;
    position: relative
}

.hl-app .hl_widget .calendar-prev,
.hl-app .hl_widget .calendar-next {
    display: block;
    width: 20px;
    height: 20px;
    line-height: 20px;
    border-radius: 50%;
    color: #fff;
    background-color: #a3bdcf;
    text-align: center;
    text-decoration: none;
    position: absolute
}

.hl-app .hl_widget .calendar-prev {
    top: 50%;
    left: 7px
}

.hl-app .hl_widget .calendar-next {
    top: 50%;
    right: 7px
}

.hl-app .hl_widget .hl_calendar-slide-item {
    outline: none
}

.hl-app .hl_widget-step3 h3,
.hl-app .hl_widget-step4 h3 {
    font-size: 18px;
    color: #2a3135;
    font-weight: 500;
    margin-top: 0;
    margin-bottom: 15px
}

.hl-app .hl_widget-step3 p,
.hl-app .hl_widget-step4 p {
    margin-top: 0;
    font-size: 14px
}

.hl-app .hl_services-select,
.hl-app .hl_provider-select {
    list-style: none;
    margin: 0 0 30px;
    padding: 0
}

.hl-app .hl_services-select li,
.hl-app .hl_provider-select li {
    display: block;
    margin: 0
}

.hl-app .hl_services-select input,
.hl-app .hl_provider-select input {
    display: none;
    opacity: 0;
    visibility: hidden
}

.hl-app .hl_services-select input:checked+label,
.hl-app .hl_provider-select input:checked+label {
    background-color: #188bf60d;
    color: #188bf6
}

.hl-app .hl_services-select input:checked+label:before,
.hl-app .hl_provider-select input:checked+label:before {
    border-color: #188bf6
}

.hl-app .hl_services-select label,
.hl-app .hl_provider-select label {
    display: block;
    width: 100%;
    margin: -1px 0 0;
    padding: 12px 15px;
    line-height: 1.5;
    border-top: 1px solid #e7f0f6;
    border-bottom: 1px solid #e7f0f6;
    cursor: pointer !important;
    transition: all .2s ease-in-out;
    position: relative
}

.hl-app .hl_services-select label:before,
.hl-app .hl_provider-select label:before {
    width: 8px;
    height: 8px;
    border-right: 1px solid #607179;
    border-bottom: 1px solid #607179;
    position: absolute;
    right: 15px;
    content: " ";
    top: 20px;
    transform: rotate(-45deg);
    transition: all .2s ease-in-out
}

.hl-app .hl_services-select label:hover,
.hl-app .hl_provider-select label:hover {
    background-color: #188bf60d;
    color: #188bf6
}

.hl-app .hl_services-select label:hover:before,
.hl-app .hl_provider-select label:hover:before {
    border-color: #188bf6
}

.hl-app .loader-container {
    position: absolute;
    left: 0;
    right: 0;
    width: 50px;
    margin: 0 auto;
    z-index: 99;
    top: 30%
}

.hl-app .load-more {
    display: block;
    margin-top: 10px;
    cursor: pointer;
    font-size: 14px
}

.hl-app .slot-loader {
    position: absolute;
    height: 100%;
    width: 100%;
    top: 0;
    left: 0
}

.hl-app .slot-loader .loader {
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, .4)
}

.hl-app .my-datepicker_calendar {
    max-width: 300px;
    width: 100% !important
}

.hl-app .vdp-datepicker__calendar {
    box-shadow: none !important;
    border: none !important;
    padding: 1rem !important;
    margin-bottom: 3rem !important
}

.hl-app .vdp-datepicker__calendar .cell.selected {
    background: #188bf6 !important;
    color: #fff
}

.hl-app .vdp-datepicker__calendar .cell.selected.disabled {
    background: white !important;
    color: #ddd !important
}

.hl-app .hl_events-buttons {
    display: flex;
    justify-content: space-between;
    width: 80%;
    margin: 20px auto
}

.hl-app .calendar-button {
    display: flex;
    justify-content: center;
    align-items: center;
    cursor: pointer;
    color: #737373;
    border-radius: 5px;
    white-space: nowrap;
    border: 1px solid #e1e1e1;
    transition-duration: .15s;
    transition-timing-function: ease-in-out;
    padding: 10px 15px;
    text-decoration: none
}

.hl-app .google-button:focus,
.hl-app .google-button:hover {
    box-shadow: 1px 4px 5px 1px #0000001a
}

.hl-app .calendar-button__text {
    margin-left: 10px;
    font-weight: 700
}

.hl-app .details-item {
    display: flex;
    align-items: center;
    margin-left: 10px;
    margin-right: 10px;
    justify-content: space-between;
    border-bottom: 1px solid #e1e1e1;
    padding-bottom: 10px;
    margin-bottom: 10px
}

.hl-app .details-item div {
    flex: 1;
    display: flex;
    justify-content: space-between
}

.hl-app .timezone-picker {
    margin-top: 20px
}

.hl-app .timezone-picker .dropdown-toggle {
    font-size: 14px;
    color: #2a3135;
    text-decoration: none
}

.hl-app .timezone-actions {
    padding: 10px 20px
}

.hl-app .timezone-search {
    display: block;
    width: 100%;
    margin-bottom: 15px;
    padding: 10px 15px;
    font-family: Roboto, Helvetica Neue, Helvetica, Arial, sans-serif;
    color: #607179;
    font-size: 14px;
    border-radius: 4px;
    border: 1px solid #e6edf2
}

.hl-app .timezone-search:focus,
.hl-app .timezone-search:active {
    outline: none
}

.hl-app .timezone-actions-bottom {
    display: flex;
    justify-content: space-between
}

.hl-app .timezone-actions-bottom h4 {
    margin-top: 0;
    margin-bottom: 0;
    color: #2a3135;
    text-transform: uppercase;
    font-size: 12px
}

.hl-app .timezones-wrap {
    height: 190px;
    overflow-y: scroll;
    min-width: 350px;
    border-top: 1px solid rgba(230, 237, 242, .5);
    padding-top: 10px
}

.hl-app .timezones {
    list-style: none;
    padding: 0;
    margin: 0
}

.hl-app .timezones .label {
    font-weight: 500;
    font-size: 14px;
    padding-left: 20px
}

.hl-app .timezones .group {
    list-style: none;
    padding: 0;
    margin: 0 0 20px;
    -webkit-padding-start: 0;
    padding-inline-start: 0
}

.hl-app .timezones .group .timezone {
    font-size: 13px;
    color: #607179;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 20px;
    line-height: 1;
    transition: all .2s ease-in-out;
    cursor: pointer
}

.hl-app .timezones .group .timezone:hover {
    color: #188bf6;
    background-color: #188bf633
}

.hl-app .timezones .group .timezone.current {
    color: #fff;
    background-color: #188bf6
}

.hl-app .timezones .group .timezone .current-time {
    font-size: 11px
}

.hl-app .toggle {
    height: 20px !important;
    display: flex;
    align-items: center
}

.hl-app .toggle p {
    margin: 0;
    color: #607179
}

.hl-app .tgl-btn {
    margin-left: 10px;
    margin-right: 10px
}

.hl-app .tgl {
    display: none;
    box-sizing: border-box
}

.hl-app .tgl:after,
.hl-app .tgl:before {
    box-sizing: border-box
}

.hl-app .tgl * {
    box-sizing: border-box
}

.hl-app .tgl *:after,
.hl-app .tgl *:before {
    box-sizing: border-box
}

.hl-app .tgl+.tgl-btn {
    box-sizing: border-box
}

.hl-app .tgl::-moz-selection,
.hl-app .tgl:after::-moz-selection,
.hl-app .tgl:before::-moz-selection {
    background: none
}

.hl-app .tgl+.tgl-btn::-moz-selection,
.hl-app .tgl::selection,
.hl-app .tgl:after::selection,
.hl-app .tgl:before::selection {
    background: none
}

.hl-app .tgl *::-moz-selection,
.hl-app .tgl *:after::-moz-selection,
.hl-app .tgl *:before::-moz-selection {
    background: none
}

.hl-app .tgl *::selection,
.hl-app .tgl *:after::selection,
.hl-app .tgl *:before::selection {
    background: none
}

.hl-app .tgl+.tgl-btn {
    outline: 0;
    display: block;
    width: 36px;
    height: 20px;
    position: relative;
    cursor: pointer;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    margin-bottom: 0
}

.hl-app .tgl+.tgl-btn::-moz-selection {
    background: none
}

.hl-app .tgl+.tgl-btn::selection {
    background: none
}

.hl-app .tgl+.tgl-btn:after,
.hl-app .tgl+.tgl-btn:before {
    position: relative;
    display: block;
    content: "";
    width: 50%;
    height: 100%
}

.hl-app .tgl+.tgl-btn:after {
    left: 0
}

.hl-app .tgl+.tgl-btn:before {
    display: none
}

.hl-app .tgl:checked+.tgl-btn:after {
    left: 50%
}

.hl-app .tgl-light+.tgl-btn {
    background: rgba(175, 184, 188, .2);
    border-radius: 2em;
    padding: 2px;
    transition: all .4s ease
}

.hl-app .tgl-light+.tgl-btn:after {
    border-radius: 50%;
    background: #afb8bc;
    transition: all .2s ease
}

.hl-app .tgl-light:checked+.tgl-btn {
    background: rgba(175, 184, 188, .2)
}

.hl-app #form-builder {
    width: 100%
}

.hl-app .hl_wrapper--inner {
    padding-top: 25px;
    padding-bottom: 0
}

.hl-app .hl_wrapper--inner.form-builder {
    flex: 1 0 0;
    min-height: 100%
}

.hl-app .hl_form-builder--main {
    padding: 40px 20px;
    margin-top: -25px
}

.hl-app .form-builder--wrap {
    position: relative;
    max-width: 550px;
    margin: 0 auto;
    border-radius: 4px;
    background-color: #fff;
    margin-bottom: 20px !important
}

.hl-app .form-builder--item {
    margin-bottom: 16px;
    border-radius: 4px;
    border: 1px solid transparent;
    transition: border .2s ease-in-out;
    padding: 0 15px
}

.hl-app .form-builder--img-wrap {
    display: flex
}

.hl-app .fields-container.row {
    margin: 0
}

.hl-app .hl_form-builder--main .form-builder--wrap .form-builder--item,
.hl-app .menu-field-wrap {
    position: relative;
    width: 100%
}

.hl-app .builder-form-name.text-center {
    margin: 0;
    padding: 0
}

.hl-app .validation-error {
    padding: 0 15px
}

.hl-app .builder-inline .menu-field-wrap .col-6 .f-even .form-builder--item {
    padding-right: 4px
}

.hl-app .builder-inline .menu-field-wrap .col-6 .f-odd .form-builder--item {
    padding-left: 4px
}

.hl-app .hl_widget .hl_form-group {
    margin-bottom: 20px
}

.hl-app .hl_widget .hl_form-group.has-error .hl_input {
    border: 1px solid #cb3837
}

.hl-app .hl_widget .hl_form-group.has-error .error,
.hl-app .error,
.hl-app .validation-error.error {
    color: #cb3837;
    display: block;
    width: 100%
}

.hl-app .form-builder--item label {
    font-size: .875rem
}

.hl-app label {
    display: inline-block;
    margin-bottom: .5rem
}

.hl-app button,
.hl-app input,
.hl-app optgroup,
.hl-app select,
.hl-app textarea {
    font-family: inherit;
    line-height: inherit;
    outline: 0
}

.hl-app input[type=email],
.hl-app input[type=number],
.hl-app input[type=password],
.hl-app input[type=text],
.hl-app textarea {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    width: 100%;
    background-color: #f3f8fb;
    border: none;
    border-radius: .25rem;
    padding: .5rem .75rem
}

.hl-app input::-webkit-input-placeholder,
.hl-app textarea::-webkit-input-placeholder {
    color: #9fa1a3 !important
}

.hl-app .custom-vue-select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background-repeat: no-repeat;
    background-color: #f3f8fb;
    border-radius: .25rem;
    background-position: right .5rem center;
    background-size: 1.5em 1.5em
}

.hl-app input[type=checkbox],
.hl-app input[type=radio] {
    display: inline-block;
    vertical-align: middle;
    background-origin: border-box;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    flex-shrink: 0;
    border-radius: 100%;
    height: 1em;
    width: 1em;
    color: #4299e1;
    background: #f3f8fb;
    border-color: #e2e8f0;
    border-width: 1px;
    box-sizing: border-box;
    padding: 0
}

.hl-app .input-group {
    position: relative;
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
    width: 100%
}

.hl-app .input-group>.custom-file,
.hl-app .input-group>.custom-select,
.hl-app .input-group>.form-control {
    position: relative;
    flex: 1 1 auto;
    width: 1%;
    margin-bottom: 0
}

.hl-app .input-group>.custom-file:focus,
.hl-app .input-group>.custom-select:focus,
.hl-app .input-group>.form-control:focus {
    z-index: 3
}

.hl-app .input-group>.custom-file+.custom-file,
.hl-app .input-group>.custom-select,
.hl-app .input-group>.form-control {
    margin-left: -1px
}

.hl-app .input-group>.custom-select+.custom-file,
.hl-app .input-group>.custom-select,
.hl-app .input-group>.form-control {
    margin-left: -1px
}

.hl-app .input-group>.form-control+.custom-file,
.hl-app .input-group>.custom-select,
.hl-app .input-group>.form-control {
    margin-left: -1px
}

.hl-app .input-group>.custom-select:not(:last-child),
.hl-app .input-group>.form-control:not(:last-child) {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0
}

.hl-app .input-group>.custom-select:not(:first-child),
.hl-app .input-group>.form-control:not(:first-child) {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
    border-top-right-radius: .3125rem;
    border-bottom-right-radius: .3125rem
}

.hl-app .input-group>.custom-file {
    display: flex;
    align-items: center
}

.hl-app .input-group>.custom-file:not(:last-child) .custom-file-label {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0
}

.hl-app .input-group>.custom-file:not(:last-child) .custom-file-label:before {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0
}

.hl-app .input-group>.custom-file:not(:first-child) .custom-file-label {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0
}

.hl-app .input-group>.custom-file:not(:first-child) .custom-file-label:before {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0
}

.hl-app .input-group-append,
.hl-app .input-group-prepend {
    display: flex
}

.hl-app .input-group-append .btn,
.hl-app .input-group-prepend .btn {
    position: relative;
    z-index: 2
}

.hl-app .input-group-append .btn+.btn,
.hl-app .input-group-append .input-group-text {
    margin-left: -1px
}

.hl-app .input-group-append .input-group-text+.btn,
.hl-app .input-group-append .input-group-text {
    margin-left: -1px
}

.hl-app .input-group-prepend {
    margin-right: -1px
}

.hl-app .input-group-prepend .btn+.btn,
.hl-app .input-group-prepend .input-group-text {
    margin-left: -1px
}

.hl-app .input-group-prepend .input-group-text+.btn,
.hl-app .input-group-prepend .input-group-text {
    margin-left: -1px
}

.hl-app .input-group-append {
    margin-left: -1px
}

.hl-app .input-group-text {
    display: flex;
    align-items: center;
    padding: .375rem .75rem;
    margin-bottom: 0;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.5;
    color: #495057;
    text-align: center;
    white-space: nowrap;
    background-color: #e9ecef;
    border: 1px solid #ced4da;
    border-radius: .3125rem
}

.hl-app .input-group-text input[type=checkbox],
.hl-app .input-group-text input[type=radio] {
    margin-top: 0
}

.hl-app .input-group>.input-group-append:last-child>.btn:not(:last-child):not(.dropdown-toggle) {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0
}

.hl-app .input-group>.input-group-append:last-child>.input-group-text:not(:last-child) {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0
}

.hl-app .input-group>.input-group-append:not(:last-child)>.btn {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0
}

.hl-app .input-group>.input-group-append:not(:last-child)>.input-group-text {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0
}

.hl-app .input-group>.input-group-prepend>.btn {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0
}

.hl-app .input-group>.input-group-prepend>.input-group-text {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0
}

.hl-app .hide,
.hl-app .hide-whole-container {
    display: none
}

.hl-app .invisible {
    opacity: 0
}

.hl-app .survey-form-wrapper .form-builder--wrap {
    min-height: 0
}

.hl-app .input-group-prepend {
    margin-right: 0 !important
}

.hl-app .input-group-text {
    border-left: unset !important;
    border-bottom: unset !important;
    border-top: unset !important;
    border-right: 1px solid #dee5e8;
    background-color: #f3f8fb !important
}

.hl-app .btn {
    font-size: 100%;
    font-weight: 600;
    color: #000;
    padding: .5rem 1rem;
    border-radius: .25rem;
    transition: all .2s ease-in-out 0s;
    min-width: 85px;
    cursor: pointer;
    background: 0 0
}

.hl-app .btn-dark {
    color: #fff;
    background-color: #000
}

.hl-app a,
.hl-app button {
    transition: all .2s ease-in-out 0s;
    cursor: pointer
}

.hl-app .form-control {
    display: block;
    width: 100%;
    padding: 15px 20px !important;
    font-size: .875rem;
    line-height: 1.5;
    color: #2a3135;
    background: #f3f8fb;
    background-clip: padding-box;
    border: none;
    border-radius: .3125rem;
    transition: all .2s ease-in-out 0s;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none
}

.hl-app .form-control:active:focus,
.hl-app .form-control:focus {
    outline: none;
    box-shadow: none !important;
    background-color: #ecf0f3 !important
}

.hl-app .g-recaptcha {
    transform: scale(.77);
    transform-origin: 0 0
}

.hl-app .hl_form-builder--main .form-builder--wrap .form-builder--item .captcha-vlue {
    float: left;
    width: auto;
    font-size: 29px;
    font-weight: 700;
    line-height: 42px;
    color: #999
}

.hl-app .hl_form-builder--main .form-builder--wrap .form-builder--item .captcha-vlue input {
    border: 0;
    width: 20px;
    font-size: 29px;
    font-weight: 700;
    color: #999
}

.hl-app .hl_form-builder--main .form-builder--wrap .form-builder--item #captchaInput {
    width: 75px;
    margin-left: .5em;
    border: 0;
    background: #f2f7fa;
    height: 45px;
    padding: 0 10px;
    outline: 0;
    font-size: 32px;
    font-weight: 700;
    line-height: 45px;
    color: #999
}

.hl-app .hl_form-builder--main .form-builder--wrap .form-builder--item .captcha-vlue span {
    font-weight: 400;
    font-size: 36px;
    color: #ccc
}

.hl-app #the-form-builder .menu-field-wrap .close-icon {
    position: absolute;
    right: 10px;
    top: 5px;
    opacity: 0;
    transition: all .5s ease-in;
    font-size: 10px;
    background: #f5f5f5;
    padding: 5px 7px;
    border-radius: 50%;
    height: 25px;
    cursor: pointer
}

.hl-app #the-form-builder .menu-field-wrap:hover .close-icon {
    opacity: 1;
    transition: all .5s ease-in
}

.hl-app .animated .close-icon {
    opacity: 0
}

.hl-app .hl_form-builder--sidebar .dragdrop-items li {
    padding: 0
}

.hl-app .hl_form-builder--sidebar .dragdrop-items li .drag {
    padding: 10px 15px;
    width: 100%
}

.hl-app .hl_form-builder--sidebar .dragdrop-items li .drag i {
    position: relative;
    float: right;
    top: 8px
}

.hl-app .form-builder-drop {
    min-height: 400px;
    padding: 30px 15px
}

.hl-app .custom-vue-select.form-control {
    padding: 10px 15px !important
}

.hl-app .custom-vue-select ul.vs__dropdown-menu li.vs__dropdown-option {
    white-space: normal !important;
    word-wrap: break-word !important
}

.hl-app div#the-form-builder.drag-enter {
    background-color: #f9f3de !important
}

.hl-app .form-builder--image img {
    width: 100%
}

.hl-app .branding-wrap {
    position: relative;
    padding: 30px 16px 10px
}

.hl-app .branding-url {
    display: block;
    padding: 0;
    text-align: left
}

.hl-app .branding-url>img {
    width: 100px
}

.hl-app .branding-url .cmp-name {
    color: #607179;
    font-size: 12px;
    display: block
}

.hl-app [v-cloak]>* {
    display: none
}

.hl-app .radio-image-option-set label:before {
    opacity: 0
}

.hl-app [type=radio]+div {
    cursor: pointer
}

.hl-app [type=radio]:checked+.radio-image-option-set {
    border-color: #51b05e
}

.hl-app .radio-image-option-set img {
    position: relative;
    height: 100%;
    width: 100%;
    margin-bottom: 5px
}

.hl-app .container-group-image .radio-image-option-set {
    margin-bottom: 8px;
    border: 2px solid rgba(120, 127, 130, .1294117647);
    padding: 0;
    border-radius: 6px
}

.hl-app .container-group-image .radio-image-option-set label img {
    width: 100%;
    margin: 0 auto;
    display: block;
    padding: .5rem
}

.hl-app .container-group-image .radio-image-option-set .opt-container-img-label label {
    min-width: 100px;
    min-height: 95px
}

.hl-app .container-group-image .img-opt-title {
    background: #444444;
    color: #fff;
    text-align: center;
    text-transform: capitalize;
    font-weight: 800;
    border-radius: 0 0 4px 4px
}

.hl-app .container-group-image .radio-image-option-set label {
    min-width: 100px;
    min-height: 95px;
    padding: 2px 8px 2px 0
}

.hl-app .row .container-group-image {
    margin: 0 auto
}

@media (min-wdith: 400px) {
    .hl-app .hl_widget-form {
        min-width: 300px
    }

    .hl-app .hl_widget .hl_form-name {
        display: flex;
        align-items: flex-start;
        margin-left: -10px;
        margin-right: -10px
    }

    .hl-app .hl_widget .hl_form-name>* {
        flex: 1 0 0;
        margin-left: 10px;
        margin-right: 10px;
        margin-bottom: 0
    }
}

@media only screen and (max-width: 649px) {
    .hl-app .hl_widget-step1 .hour-select input+label {
        transition: all .3s ease
    }

    .hl-app .hl_widget-step1 .hour-select input:checked+label {
        width: 45%
    }

    .hl-app .hl_widget-step1 .hour-select input:checked+label+button {
        display: block;
        border: 1px solid #e6edf2;
        border-radius: 4px;
        max-width: 45%;
        padding: 7px 30px;
        cursor: pointer;
        font-size: 14px;
        font-weight: 500;
        transform: translate(0);
        visibility: visible
    }

    .hl-app .hl_widget-step1 .hour-select input+label+button {
        display: block;
        visibility: hidden;
        width: 45%;
        width: 100%;
        transform: translate(100%);
        right: 0;
        position: absolute;
        transition: none;
        transition: transform .3s ease;
        top: 0;
        white-space: nowrap
    }
}

@media (min-width: 940px) {
    .hl-app .hl_widget-wrapper .hl_widget-form {
        box-sizing: border-box;
        padding-left: 15px;
        padding-right: 15px
    }

    .hl-app .hl_widget .hl_form-group.--date-time {
        display: none;
        visibility: hidden;
        opacity: 0
    }
}

.hl-app .menu-field-wrap.col-sm-6 .option-radio.col-md-3 {
    max-width: 50%
}

@media only screen and (max-width: 649px) {

    .hl-app .menu-field-wrap.col-sm-6,
    .hl-app .menu-field-wrap.col-sm-6 .col-8 {
        flex: 0 0 100%;
        max-width: 100%
    }
}

.hl-app input[type=checkbox],
.hl-app input[type=radio] {
    width: 20px;
    height: 20px
}

.hl-app .in-r-c {
    display: flex;
    align-items: center;
    margin-bottom: 5px
}

.hl-app .in-r-c label {
    margin-left: 10px;
    margin-bottom: 0
}

.hl-app .option-radio-image input[type=radio] {
    display: none
}

.hl-app .v-spinner .v-moon1 {
    -webkit-animation: v-moonStretchDelay .6s 0s infinite linear;
    animation: v-moonStretchDelay .6s 0s infinite linear;
    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards;
    position: relative
}

.hl-app .v-spinner .v-moon2 {
    -webkit-animation: v-moonStretchDelay .6s 0s infinite linear;
    animation: v-moonStretchDelay .6s 0s infinite linear;
    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards;
    opacity: .8;
    position: absolute
}

.hl-app .v-spinner .v-moon3 {
    opacity: .1
}

.hl-app #notfound {
    position: relative;
    height: 100vh
}

.hl-app #notfound .notfound {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%)
}

.hl-app .notfound {
    max-width: 460px;
    width: 100%;
    text-align: center;
    line-height: 1.4
}

.hl-app .notfound .notfound-404 {
    position: relative;
    width: 180px;
    height: 180px;
    margin: 0 auto
}

.hl-app .notfound .notfound-404>div:first-child {
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    background: #ffa200;
    transform: rotate(45deg);
    border: 5px dashed #000;
    border-radius: 5px
}

.hl-app .notfound .notfound-404>div:first-child:before {
    content: "";
    position: absolute;
    left: -5px;
    right: -5px;
    bottom: -5px;
    top: -5px;
    box-shadow: 0 0 0 5px #0000001a inset;
    border-radius: 5px
}

.hl-app .notfound .notfound-404 h1 {
    font-family: Cabin, sans-serif;
    color: #000;
    font-weight: 700;
    margin: 0;
    font-size: 90px;
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
    left: 50%;
    text-align: center;
    height: 40px;
    line-height: 40px
}

.hl-app .notfound h2 {
    font-family: Cabin, sans-serif;
    font-size: 33px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 7px
}

.hl-app .notfound p {
    font-family: Cabin, sans-serif;
    font-size: 16px;
    color: #000;
    font-weight: 400
}

.hl-app .notfound a {
    font-family: Cabin, sans-serif;
    display: inline-block;
    padding: 10px 25px;
    background-color: #8f8f8f;
    border: none;
    border-radius: 40px;
    color: #fff;
    font-size: 14px;
    font-weight: 700;
    text-transform: uppercase;
    text-decoration: none;
    transition: .2s all
}

.hl-app .notfound a:hover {
    background-color: #2c2c2c
}

.hl-app .h2-override {
    letter-spacing: 5px !important;
    font-size: 18px !important
}

@-webkit-keyframes rotateSlideOutNext {
    0% {
        position: absolute
    }

    25% {
        opacity: .5;
        -webkit-transform: translateZ(-500px)
    }

    to,
    75% {
        opacity: .5;
        -webkit-transform: translateZ(-500px) translateX(-200%)
    }
}

@keyframes rotateSlideOutNext {
    0% {
        position: absolute
    }

    25% {
        opacity: .5;
        transform: translateZ(-500px)
    }

    to,
    75% {
        opacity: .5;
        transform: translateZ(-500px) translate(-200%)
    }
}

@-webkit-keyframes rotateSlideInNext {

    0%,
    25% {
        position: relative;
        opacity: .5;
        -webkit-transform: translateZ(-500px) translateX(200%)
    }

    75% {
        opacity: .5;
        -webkit-transform: translateZ(-500px)
    }

    to {
        opacity: 1;
        -webkit-transform: translateZ(0) translateX(0)
    }
}

@keyframes rotateSlideInNext {

    0%,
    25% {
        position: relative;
        opacity: .5;
        transform: translateZ(-500px) translate(200%)
    }

    75% {
        opacity: .5;
        transform: translateZ(-500px)
    }

    to {
        opacity: 1;
        transform: translateZ(0) translate(0)
    }
}

@-webkit-keyframes rotateSlideOutPrev {
    0% {
        position: absolute
    }

    25% {
        opacity: .5;
        -webkit-transform: translateZ(-500px)
    }

    to,
    75% {
        opacity: .5;
        -webkit-transform: translateZ(-500px) translateX(200%)
    }
}

@keyframes rotateSlideOutPrev {
    0% {
        position: absolute
    }

    25% {
        opacity: .5;
        transform: translateZ(-500px)
    }

    to,
    75% {
        opacity: .5;
        transform: translateZ(-500px) translate(200%)
    }
}

@-webkit-keyframes rotateSlideInPrev {

    0%,
    25% {
        position: relative;
        opacity: .5;
        -webkit-transform: translateZ(-500px) translateX(-200%)
    }

    75% {
        opacity: .5;
        -webkit-transform: translateZ(-500px)
    }

    to {
        opacity: 1;
        -webkit-transform: translateZ(0) translateX(0)
    }
}

@keyframes rotateSlideInPrev {

    0%,
    25% {
        position: relative;
        opacity: .5;
        transform: translateZ(-500px) translate(-200%)
    }

    75% {
        opacity: .5;
        transform: translateZ(-500px)
    }

    to {
        opacity: 1;
        transform: translateZ(0) translate(0)
    }
}

@-webkit-keyframes v-moonStretchDelay {
    to {
        transform: rotate(360deg)
    }
}

@keyframes v-moonStretchDelay {
    to {
        transform: rotate(360deg)
    }
}

.hl-app .ghl-footer {
    background: #222;
    position: absolute;
    bottom: 0;
    top: initial;
    left: 0;
    right: 0;
    width: 100%;
    margin: 0;
    padding: 6px 0;
    height: 60px;
    box-shadow: 0 0 7px #323232bf;
    z-index: 0;
    overflow: none;
    text-align: center;
    display: block
}

.hl-app .ghl-footer .ghl-btn-align {
    float: right;
    right: 0;
    position: relative;
    top: -2px
}

.hl-app .ghl-body.in-iframe .ghl-footer {
    z-index: 1
}

.hl-app .ghl-button-bar {
    display: inline;
    margin: 0 10px 2px;
    position: relative;
    z-index: 2;
    direction: rtl;
    text-align: center
}

.hl-app .ghl-button-bar input {
    position: relative;
    cursor: pointer
}

.hl-app .ghl-button-bar .ghl-next-button {
    float: right;
    height: 40px;
    width: auto;
    min-width: 50px;
    margin: 10px;
    text-align: center;
    border: 0;
    border-radius: 4px;
    padding: 0 15px;
    font-weight: 600
}

.hl-app .ghl-button-bar .ghl-next-button:focus {
    outline: 0
}

.hl-app .ghl-button-bar .ghl-next-button .right-pointing-triangle:after {
    content: "\25b6\fe0e"
}

.hl-app .ghl-button-bar .ghl-submit-button {
    float: right;
    height: 40px;
    width: auto;
    min-width: 50px;
    margin: 10px;
    text-align: center;
    border: 0;
    border-radius: 4px;
    padding: 0 15px;
    font-weight: 600
}

.hl-app .ghl-button-bar .ghl-back-button {
    float: left;
    margin: 10px 0 0 10px;
    height: 40px;
    min-width: 50px;
    width: auto;
    text-align: center;
    text-indent: -4px;
    border: 0;
    border-radius: 4px
}

.hl-app .ghl-button-bar .ghl-back-button:focus {
    outline: 0
}

.hl-app .ghl-button-bar .ghl-back-button .left-pointing-triangle:after {
    content: "\25c0\fe0e"
}

.hl-app input#sg_NextButton {
    padding-left: 15px;
    padding-right: 15px
}

.hl-app .ghl-button,
.hl-app .ghl-file-field input[type=button],
.hl-app .ghl-next-button {
    color: #fff;
    background-color: #3a8ea8
}

.hl-app .ghl-next-button:disabled {
    opacity: .7;
    cursor: none
}

.hl-app .ghl-back-button,
.hl-app .ghl-submit-button,
.hl-app .ghl-browse-btn,
.hl-app .ghl-configurator-btn,
.hl-app .ghl-add-another-button {
    color: #fff;
    background-color: #3a8ea8
}

.hl-app .ghl-progress-bar {
    position: absolute;
    bottom: 15px;
    width: 160px;
    left: 50%;
    margin: 0 0 0 -80px;
    clear: both;
    height: 20px;
    zoom: 1;
    line-height: 20px
}

.hl-app .ghl-progress-bar-text {
    color: #fff;
    background-color: #3a8ea8;
    font-size: 14px;
    width: 45px;
    text-align: center;
    border-radius: 10px 0 0 10px;
    display: inline-block;
    float: left
}

.hl-app .ghl-progress-bar-background {
    width: 115px;
    background-color: #bfc5ca;
    border-left: 1px solid #ffffff;
    float: left;
    border-radius: 0 10px 10px 0
}

.hl-app .ghl-progress-bar-inner {
    background-color: #3a8ea8;
    height: 20px;
    border-radius: 0
}

.hl-app .ghl-question-set {
    perspective: 1200px;
    transform-style: preserve-3d;
    margin-top: 12px;
    position: relative;
    overflow-y: visible;
    zoom: 1;
    z-index: 2
}

.hl-app .ghl-question-set .ghl-question {
    width: 100%;
    top: 0;
    left: 0;
    visibility: hidden;
    transform: translateZ(0);
    overflow: hidden;
    line-height: 1;
    clear: both;
    display: none
}

.hl-app .ghl-question-set .ghl-question.ghl-page-current {
    visibility: visible;
    overflow: visible;
    padding-bottom: 0;
    display: block
}

.hl-app .ghl-question-set .form-field-container label {
    color: #000
}

.hl-app .ghl-survey-form {
    width: 100%;
    height: auto;
    background-color: #fff;
    padding: 1.5em 30px 2em;
    overflow-y: visible;
    height: 100%;
    margin-bottom: 50px
}

.hl-app .ghl-survey-form .ghl-page-description p {
    font-size: 1.1em;
    line-height: 1.72222;
    margin: 0 0 .833em
}

.hl-app .ghl-survey-form .alert {
    color: #792020;
    border-radius: 0;
    border-left: 9px solid #ff4747;
    transition: all .3s ease-in
}

.hl-app .ghl-survey-form .alert ul {
    margin-bottom: 0;
    padding-left: 20px
}

.hl-app .ghl-survey-form-banner {
    width: 80%;
    height: auto;
    margin: 0 auto;
    background-color: #fff;
    padding: 1.5em 30px 2em;
    overflow-y: visible;
    overflow-x: hidden;
    height: 100%
}

.hl-app .ghl-body {
    background-color: transparent
}

.hl-app .ghl-body .img-opt-title {
    padding: 5px
}

.hl-app .form-builder--wrap-questions .row,
.hl-app .form-builder--wrap-questions .col-6,
.hl-app .form-builder--wrap-questions .col-12,
.hl-app .form-builder--wrap-questions .form-builder--item {
    padding: 0
}

.hl-app .ghl-page-rotateSlideOutNext {
    -webkit-animation: rotateSlideOutNext 1s both ease;
    animation: rotateSlideOutNext 1s both ease
}

.hl-app .ghl-page-rotateSlideInNext {
    -webkit-animation: rotateSlideInNext 1s both ease;
    animation: rotateSlideInNext 1s both ease
}

.hl-app .ghl-page-rotateSlideOutPrev {
    -webkit-animation: rotateSlideOutPrev 1s both ease;
    animation: rotateSlideOutPrev 1s both ease
}

.hl-app .ghl-page-rotateSlideInPrev {
    -webkit-animation: rotateSlideInPrev 1s both ease;
    animation: rotateSlideInPrev 1s both ease
}

.hl-app .ghl-progress-bar-background.percent-100 .ghl-progress-bar-inner {
    border-radius: 0 10px 10px 0
}

.hl-app .ghl-footer-wrap {
    width: 80%;
    margin: 0 auto 4%;
    padding: 26px 10px 5px;
    text-align: center
}

.hl-app .ghl-form-wrap {
    margin: 0 auto
}

.hl-app .ghl-banner {
    margin: auto
}

.hl-app .ghl-banner img {
    width: 100%;
    max-width: 100%;
    display: block
}

.hl-app .ghl-banner.ghl-survey-form-banner {
    padding: 0;
    height: auto;
    min-height: auto
}

.hl-app table.table.table-borderless th {
    border: 0;
    padding: .75rem
}

.hl-app table.table.table-borderless tr th:first-child {
    padding-right: 0;
    text-align: right;
    vertical-align: middle;
    max-width: 150px
}

.hl-app .ghl-question-set.ghl-ques-wrap-big input[type=text],
.hl-app .ghl-question-set.ghl-ques-wrap-big input[type=email],
.hl-app .ghl-question-set.ghl-ques-wrap-big input[type=number],
.hl-app .ghl-question-set.ghl-ques-wrap-big input[type=phone],
.hl-app .ghl-question-set.ghl-ques-wrap-big textarea,
.hl-app .ghl-question-set.ghl-ques-wrap-big .custom-vue-select.form-control {
    width: 50%
}

.hl-app .ghl-question-set.ghl-ques-wrap-big .form-builder--item-input {
    margin-bottom: 17px
}

.hl-app .ghl-question-set.ghl-ques-wrap-big .form-builder--item-input input,
.hl-app .ghl-question-set.ghl-ques-wrap-big .form-builder--item-input textarea,
.hl-app .ghl-question-set.ghl-ques-wrap-big .form-builder--item-input .custom-vue-select.form-control {
    width: 100%
}

.hl-app .setOverflow {
    overflow: hidden
}

.hl-app .hl_widget-footer {
    border-top: 1px solid #e6edf2;
    padding: 20px 100px 10px 30px;
    text-align: right
}

.hl-app .no-shadow .hl_widget-footer {
    border-top: none !important;
    padding-top: 0
}

.hl-app .hl_widget-footer .v-spinner {
    display: inline-block
}

.hl-app .hl_button {
    border: 1px solid #e6edf2;
    border-radius: 4px;
    padding: 15px 30px;
    min-width: 130px;
    cursor: pointer;
    font-size: 14px;
    font-weight: 500;
    max-width: 550px;
    transition: all .2s ease-in-out
}

.hl-app .hl_button:hover,
.hl-app .hl_button:focus,
.hl-app .hl_button:active {
    background-color: #e6edf2
}

.hl-app .hl_button:focus,
.hl-app .hl_button:active {
    outline: none
}

.hl-app .hl_button:disabled {
    opacity: .6
}

.hl-app .hl_button:active:focus {
    outline: none
}

.hl-app .hl_button.--primary {
    border-color: #188bf6;
    background-color: #188bf6;
    color: #fff
}

.hl-app .hl_button.--first-step {
    min-width: 200px
}

.hl-app .hl_button.--primary:hover,
.hl-app .hl_button.--primary:focus,
.hl-app .hl_button.--primary:active {
    background-color: #0871d3
}

.hl-app .Header-purchaseDescription {
    white-space: normal !important
}

.hl-app .StripeElement {
    background: #f3f8fb;
    font-family: Roboto, system, -apple-system, BlinkMacSystemFont, ".SFNSDisplay-Regular", Helvetica Neue, Helvetica, Arial, sans-serif;
    font-size: .875rem;
    color: #2a3135;
    border: none;
    border-radius: .3125rem;
    padding: 15px 20px;
    transition: all .2s ease-in-out 0s;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none
}

.hl-app .StripeElement--invalid {
    border-color: #fa755a
}

.hl-app .StripeElement--webkit-autofill {
    background-color: #fefde5 !important
}

.hl-app .payform .group {
    background: white;
    box-shadow: 0 2px 4px #31315d1a, 0 1px 2px #00000014;
    border-radius: 4px;
    margin-bottom: 20px
}

.hl-app .payform label {
    position: relative;
    height: 40px;
    color: #2a3135;
    line-height: 40px;
    margin-left: 20px;
    display: flex;
    flex-direction: row;
    font-size: 14px
}

.hl-app .payform .group label {
    border-bottom: 1px solid #f0f5fa
}

.hl-app .payform label>span {
    width: 120px;
    text-align: right;
    margin-right: 30px;
    font-size: 14px
}

.hl-app .payform .field {
    background: transparent;
    border: 0;
    color: #000;
    outline: none;
    flex: 1;
    padding-right: 10px;
    padding-left: 10px;
    font-weight: 500;
    font-size: 14px;
    cursor: text
}

.hl-app .payform .field::-webkit-input-placeholder,
.hl-app .payform .field::-moz-placeholder {
    color: #cfd7e0
}

.hl-app .payform button {
    background: #188bf6;
    color: #fff;
    box-shadow: 0 2px 4px #31315d1a, 0 1px 2px #00000014;
    border-radius: 4px;
    border: 0;
    margin-top: 20px;
    font-size: 15px;
    font-weight: 400;
    width: 230px;
    height: 40px;
    line-height: 38px;
    outline: none
}

.hl-app .payform .success.visible {
    display: inline
}

.hl-app .payform .error {
    color: #e4584c
}

.hl-app .payform .error.visible {
    display: inline
}

.hl-app .payform .success {
    color: #666ee8
}

.hl-app .payform .success .token {
    font-weight: 500;
    font-size: 13px
}

@media (max-width: 320px) {
    .hl-app .hl_widget-header {
        padding: 25px 50px 25px 20px
    }

    .hl-app .hl_widget-body {
        padding: 20px
    }
}

@media (max-width: 450px) {
    .hl-app .no-shadow .hl_widget-body.step-form {
        padding: 10px 0
    }

    .hl-app .payform .group {
        padding: 10px 10px 5px
    }

    .hl-app .payform label {
        width: auto;
        height: auto;
        margin-left: 0;
        line-height: 30px;
        flex-direction: column
    }

    .hl-app .payform label span {
        text-align: left
    }

    .hl-app .payform .field {
        padding-left: 0
    }

    .hl-app .col-6 {
        flex: 0 0 50%;
        max-width: 50%
    }
}

@media (min-width: 700px) {
    .hl-app .hl_widget-step1 .hl_widget--pick-date-time {
        display: flex;
        margin-left: -15px;
        margin-right: -15px
    }

    .hl-app .hl_widget-step1 .hl_widget--pick-date-time>* {
        margin-left: 15px;
        margin-right: 15px
    }

    .hl-app .hl_widget-step1 .hl_widget--pick-hours .loader {
        position: absolute;
        top: 40%;
        left: 50%;
        transform: translate(-50%, -50%)
    }
}

@media (max-width: 700px) {
    .hl-app .hl_events-buttons {
        display: block;
        width: 100%
    }

    .hl-app .hl_events-buttons .calendar-button:first-child {
        margin-bottom: 10px
    }
}

@media (max-width: 939px) {
    .hl-app .hl_widget-calendar {
        display: none;
        visibility: hidden;
        opacity: 0
    }
}

@media (min-width: 940px) {
    .hl-app .hl_widget-wrapper {
        display: flex;
        flex-wrap: wrap;
        align-items: flex-start;
        margin-left: -15px;
        margin-right: -15px
    }

    .hl-app .hl_widget-wrapper .hl_widget-form,
    .hl-app .hl_widget-wrapper .hl_widget-calendar {
        flex: 1 0 0
    }

    .hl-app .hl_widget-wrapper .hl_widget-calendar {
        box-sizing: border-box;
        margin-left: 15px;
        margin-right: 15px
    }
}

@media only screen and (max-width: 649px) {

    .hl-app .selected-date .hl_widget-body .hl_widget--pick-date,
    .hl-app .d_none {
        display: none
    }

    .hl-app .selected-date .d_none,
    .hl-app .selected-date .back_button,
    .hl-app .details-item div {
        display: block
    }

    .hl-app .selected-date .hl_select_button,
    .hl-app .hl_button.--first-step {
        display: none
    }

    .hl-app .--primary {
        border-color: #46637e;
        background-color: #46637e;
        color: #fff
    }

    .hl-app .my-datepicker_calendar {
        margin: auto
    }

    .hl-app .selected-date .hl_widget-step1 .pick-hours--wrap {
        flex-direction: column;
        overflow: scroll;
        max-height: calc(100vh - 220px)
    }

    .hl-app .selected-date .hl_widget-step1 .pick-hours--wrap>* {
        width: 100%;
        margin-left: 0;
        margin-right: 0
    }

    .hl-app .selected-date .pick-hours--wrap h4,
    .hl-app .selected-date .pick-hours--wrap p,
    .hl-app .selected-date .load-more {
        display: none
    }

    .hl-app .selected-date .hl_widget-step1 .hour-select {
        overflow: hidden;
        text-align: left;
        position: relative
    }

    .hl-app .selected-date .hl_widget-step1 .hour-select label {
        max-width: 100%;
        width: 100%;
        margin: 0;
        align-self: start;
        display: inline-block;
        text-align: center
    }

    .hl-app #pick-hours--am,
    .hl-app #pick-hours--pm {
        max-height: 100%;
        overflow: hidden;
        margin-left: 15px;
        margin-right: 15px
    }
}

.text-capitalize {
    text-transform: capitalize
}

.appointment_widgets-xl {
    background: #ffffff;
    display: flex;
    padding-top: 1rem !important;
    height: 100%;
    justify-content: center;
    align-items: center;
    overflow-y: auto;
    align-items: flex-start
}

@media screen and (min-height: 800px) {
    .appointment_widgets-xl {
        padding-top: 4rem !important
    }
}

@media screen and (min-height: 1100px) {
    .appointment_widgets-xl {
        padding-top: 6rem !important
    }
}

.appointment_widgets-xl::-webkit-scrollbar {
    width: 5px;
    position: absolute;
    top: 0;
    left: 0;
    border-radius: 4px;
    background: #ffffff;
    opacity: 0;
    cursor: default;
    outline: none;
    z-index: 1;
    will-change: transform
}

.appointment_widgets-xl::-webkit-scrollbar-thumb {
    background: var(--appointment_widgets-gray-text-color);
    border-radius: 10px;
    padding: 2px
}

.appointment_widgets-xl .appointment_widgets--inner {
    margin: 0 auto;
    border-radius: .5rem;
    max-height: 100%;
    width: 100%;
    overflow-y: auto;
    border: 1px solid var(--appointment_widgets-border-color)
}

@media only screen and (min-device-height: 900px) {
    .appointment_widgets-xl .appointment_widgets--inner {
        min-height: 850px !important
    }
}

@media only screen and (min-device-height: 800px) {
    .appointment_widgets-xl .appointment_widgets--inner {
        min-height: 800px !important
    }
}

.appointment_widgets-xl .appointment_widgets--inner.direct-widget {
    border: none;
    box-shadow: 0 7px 27px #0000001c;
    width: 90%;
    max-width: 768px;
    max-height: 95%;
    min-height: 100%;
    width: 90%;
    max-width: 1024px;
    width: 96%;
    max-width: 1220px;
    max-height: 880px
}

.appointment_widgets-xl .appointment_widgets--inner.direct-widget .form-builder--wrap {
    max-height: 680px;
    overflow: auto
}

.appointment_widgets-xl .appointment_widgets--inner.direct-widget .form-builder--wrap::-webkit-scrollbar {
    width: 5px;
    position: absolute;
    top: 0;
    right: 0;
    border-radius: 4px;
    background: #ffffff;
    opacity: 0;
    cursor: default;
    outline: none;
    z-index: 1;
    will-change: transform
}

.appointment_widgets-xl .appointment_widgets--inner.direct-widget .form-builder--wrap::-webkit-scrollbar-thumb {
    background: var(--appointment_widgets-gray-text-color);
    border-radius: 10px;
    padding: 2px
}

@media only screen and (device-width: 375px) and (device-height: 812px) and (-webkit-device-pixel-ratio: 3) {
    .appointment_widgets-xl .appointment_widgets--inner {
        max-height: none !important
    }
}

@media only screen and (device-width: 414px) and (device-height: 896px) and (-webkit-device-pixel-ratio: 2) {
    .appointment_widgets-xl .appointment_widgets--inner {
        max-height: none !important
    }
}

@media only screen and (device-width: 414px) and (device-height: 896px) and (-webkit-device-pixel-ratio: 3) {
    .appointment_widgets-xl .appointment_widgets--inner {
        max-height: none !important
    }
}

.appointment_widgets-xl .appointment_widgets--inner .appointment_service--list {
    text-align: center;
    padding: 1.5rem;
    padding: 2rem
}

.appointment_widgets-xl .appointment_widgets--inner .appointment_service--list .appointment_widgets--branding {
    padding: 1.5rem;
    padding: 2rem 0
}

.appointment_widgets-xl .appointment_widgets--inner .appointment_service--list .appointment_widgets--branding .branding--logo {
    height: 5rem;
    width: auto
}

.appointment_widgets-xl .appointment_widgets--inner .appointment_service--list .appointment_widgets--branding .branding-name {
    font-size: 1.5rem
}

.appointment_widgets-xl .appointment_widgets--inner .appointment_service--list .appointment_widgets--branding .branding-detail {
    border-top: 1px solid #e1e1e1;
    padding-top: 1rem;
    max-width: 800px;
    width: 80%;
    margin: 1.5rem auto;
    opacity: 1;
    transition: all ease .1s
}

.appointment_widgets-xl .appointment_widgets--inner .appointment_service--list .appointment_widgets--branding .branding-detail .pointer {
    cursor: pointer;
    font-weight: 700;
    color: var(--appointment_widgets-primary-color)
}

.appointment_widgets-xl .appointment_widgets--inner .appointment_service--list .appointment_widgets--branding .branding-detail.show-more {
    max-height: 10rem;
    overflow: auto;
    border: 2px solid #e1e1e1;
    opacity: .8;
    border: 1px solid #e9e9e9;
    box-sizing: border-box;
    box-shadow: 0 1px 17px #00000017;
    border-radius: 6px;
    padding: 10px 20px;
    z-index: 2;
    cursor: pointer;
    transition: all ease .1s;
    margin-bottom: 2rem;
    margin-bottom: auto
}

.appointment_widgets-xl .appointment_widgets--inner .appointment_service--list .appointment_widgets--branding .branding-detail.show-more::-webkit-scrollbar {
    width: 5px;
    position: absolute;
    top: 0;
    right: 0;
    border-radius: 4px;
    background: #ffffff;
    opacity: 0;
    cursor: default;
    outline: none;
    z-index: 1;
    will-change: transform
}

.appointment_widgets-xl .appointment_widgets--inner .appointment_service--list .appointment_widgets--branding .branding-detail.show-more::-webkit-scrollbar-thumb {
    background: var(--appointment_widgets-gray-text-color);
    border-radius: 10px;
    padding: 2px
}

.appointment_widgets-xl .appointment_widgets--inner .appointment_service--list .appointment_widgets--services {
    display: flex;
    flex-wrap: wrap
}

.appointment_widgets-xl .appointment_widgets--inner .appointment_service--list .appointment_widgets--services .appointment_widgets--service-col {
    width: 100%;
    display: flex;
    flex-direction: column;
    flex: 0 0 50%;
    max-width: 50%;
    padding: 1rem 2rem;
    flex: 0 0 33.333333%;
    max-width: 33.333333%;
    padding: 1rem
}

.appointment_widgets-xl .appointment_widgets--inner .appointment_service--list .appointment_widgets--services .appointment_widgets--service-col .appointment_widgets--service {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    text-align: left;
    height: 100%;
    border-left-style: solid;
    border-left-width: 3px;
    border-left: 3px solid rgba(0, 0, 0, .3);
    padding: 1rem;
    padding-top: calc(1rem + 3px);
    -moz-background-clip: padding;
    -webkit-background-clip: padding;
    background-clip: padding-box
}

.appointment_widgets-xl .appointment_widgets--inner .appointment_service--list .appointment_widgets--services .appointment_widgets--service-col .appointment_widgets--service .appointment_service--name {
    font-size: 20px;
    margin-bottom: 1rem;
    margin-bottom: 2rem
}

.appointment_widgets-xl .appointment_widgets--inner .appointment_service--list .appointment_widgets--services .appointment_widgets--service-col .appointment_widgets--service:hover {
    cursor: pointer;
    padding-top: 1rem;
    border-top-width: 3px;
    border-top-style: solid;
    border-bottom-right-radius: 1rem;
    box-shadow: 3px 3px 5px #00000026
}

.appointment_widgets-xl .appointment_widgets--inner .appointment_service--list .appointment_widgets--services .appointment_widgets--service-col .appointment_widgets--service:hover .appointment_service--name {
    color: #000c
}

.appointment_widgets-lg {
    background: #ffffff;
    display: flex;
    padding-top: 1rem !important;
    height: 100%;
    justify-content: center;
    align-items: center;
    overflow-y: auto;
    align-items: flex-start
}

@media screen and (min-height: 800px) {
    .appointment_widgets-lg {
        padding-top: 4rem !important
    }
}

@media screen and (min-height: 1100px) {
    .appointment_widgets-lg {
        padding-top: 6rem !important
    }
}

.appointment_widgets-lg::-webkit-scrollbar {
    width: 5px;
    position: absolute;
    top: 0;
    left: 0;
    border-radius: 4px;
    background: #ffffff;
    opacity: 0;
    cursor: default;
    outline: none;
    z-index: 1;
    will-change: transform
}

.appointment_widgets-lg::-webkit-scrollbar-thumb {
    background: var(--appointment_widgets-gray-text-color);
    border-radius: 10px;
    padding: 2px
}

.appointment_widgets-lg .appointment_widgets--inner {
    margin: 0 auto;
    border-radius: .5rem;
    max-height: 100%;
    width: 100%;
    overflow-y: auto;
    border: 1px solid var(--appointment_widgets-border-color)
}

@media only screen and (min-device-height: 900px) {
    .appointment_widgets-lg .appointment_widgets--inner {
        min-height: 850px !important
    }
}

@media only screen and (min-device-height: 800px) {
    .appointment_widgets-lg .appointment_widgets--inner {
        min-height: 800px !important
    }
}

.appointment_widgets-lg .appointment_widgets--inner.direct-widget {
    border: none;
    box-shadow: 0 7px 27px #0000001c;
    max-width: 768px;
    max-height: 95%;
    min-height: 100%;
    width: 90%;
    max-width: 1024px;
    max-height: 880px
}

.appointment_widgets-lg .appointment_widgets--inner.direct-widget .form-builder--wrap {
    max-height: 680px;
    overflow: auto
}

.appointment_widgets-lg .appointment_widgets--inner.direct-widget .form-builder--wrap::-webkit-scrollbar {
    width: 5px;
    position: absolute;
    top: 0;
    right: 0;
    border-radius: 4px;
    background: #ffffff;
    opacity: 0;
    cursor: default;
    outline: none;
    z-index: 1;
    will-change: transform
}

.appointment_widgets-lg .appointment_widgets--inner.direct-widget .form-builder--wrap::-webkit-scrollbar-thumb {
    background: var(--appointment_widgets-gray-text-color);
    border-radius: 10px;
    padding: 2px
}

@media only screen and (device-width: 375px) and (device-height: 812px) and (-webkit-device-pixel-ratio: 3) {
    .appointment_widgets-lg .appointment_widgets--inner {
        max-height: none !important
    }
}

@media only screen and (device-width: 414px) and (device-height: 896px) and (-webkit-device-pixel-ratio: 2) {
    .appointment_widgets-lg .appointment_widgets--inner {
        max-height: none !important
    }
}

@media only screen and (device-width: 414px) and (device-height: 896px) and (-webkit-device-pixel-ratio: 3) {
    .appointment_widgets-lg .appointment_widgets--inner {
        max-height: none !important
    }
}

.appointment_widgets-lg .appointment_widgets--inner .appointment_service--list {
    text-align: center;
    padding: 1.5rem
}

.appointment_widgets-lg .appointment_widgets--inner .appointment_service--list .appointment_widgets--branding {
    padding: 1.5rem;
    padding: 2rem 0
}

.appointment_widgets-lg .appointment_widgets--inner .appointment_service--list .appointment_widgets--branding .branding--logo {
    height: 5rem;
    width: auto
}

.appointment_widgets-lg .appointment_widgets--inner .appointment_service--list .appointment_widgets--branding .branding-name {
    font-size: 1.5rem
}

.appointment_widgets-lg .appointment_widgets--inner .appointment_service--list .appointment_widgets--branding .branding-detail {
    border-top: 1px solid #e1e1e1;
    padding-top: 1rem;
    max-width: 800px;
    width: 80%;
    margin: 1.5rem auto;
    opacity: 1;
    transition: all ease .1s
}

.appointment_widgets-lg .appointment_widgets--inner .appointment_service--list .appointment_widgets--branding .branding-detail .pointer {
    cursor: pointer;
    font-weight: 700;
    color: var(--appointment_widgets-primary-color)
}

.appointment_widgets-lg .appointment_widgets--inner .appointment_service--list .appointment_widgets--branding .branding-detail.show-more {
    max-height: 10rem;
    overflow: auto;
    border: 2px solid #e1e1e1;
    opacity: .8;
    border: 1px solid #e9e9e9;
    box-sizing: border-box;
    box-shadow: 0 1px 17px #00000017;
    border-radius: 6px;
    padding: 10px 20px;
    z-index: 2;
    cursor: pointer;
    transition: all ease .1s;
    margin-bottom: 2rem
}

.appointment_widgets-lg .appointment_widgets--inner .appointment_service--list .appointment_widgets--branding .branding-detail.show-more::-webkit-scrollbar {
    width: 5px;
    position: absolute;
    top: 0;
    right: 0;
    border-radius: 4px;
    background: #ffffff;
    opacity: 0;
    cursor: default;
    outline: none;
    z-index: 1;
    will-change: transform
}

.appointment_widgets-lg .appointment_widgets--inner .appointment_service--list .appointment_widgets--branding .branding-detail.show-more::-webkit-scrollbar-thumb {
    background: var(--appointment_widgets-gray-text-color);
    border-radius: 10px;
    padding: 2px
}

.appointment_widgets-lg .appointment_widgets--inner .appointment_service--list .appointment_widgets--services {
    display: flex;
    flex-wrap: wrap
}

.appointment_widgets-lg .appointment_widgets--inner .appointment_service--list .appointment_widgets--services .appointment_widgets--service-col {
    width: 100%;
    display: flex;
    flex-direction: column;
    flex: 0 0 50%;
    max-width: 50%;
    padding: 1rem 2rem;
    flex: 0 0 33.333333%;
    max-width: 33.333333%
}

.appointment_widgets-lg .appointment_widgets--inner .appointment_service--list .appointment_widgets--services .appointment_widgets--service-col .appointment_widgets--service {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    text-align: left;
    height: 100%;
    border-left-style: solid;
    border-left-width: 3px;
    border-left: 3px solid rgba(0, 0, 0, .3);
    padding: 1rem;
    padding-top: calc(1rem + 3px);
    -moz-background-clip: padding;
    -webkit-background-clip: padding;
    background-clip: padding-box
}

.appointment_widgets-lg .appointment_widgets--inner .appointment_service--list .appointment_widgets--services .appointment_widgets--service-col .appointment_widgets--service .appointment_service--name {
    font-size: 20px;
    margin-bottom: 1rem;
    margin-bottom: 2rem
}

.appointment_widgets-lg .appointment_widgets--inner .appointment_service--list .appointment_widgets--services .appointment_widgets--service-col .appointment_widgets--service:hover {
    cursor: pointer;
    padding-top: 1rem;
    border-top-width: 3px;
    border-top-style: solid;
    border-bottom-right-radius: 1rem;
    box-shadow: 3px 3px 5px #00000026
}

.appointment_widgets-lg .appointment_widgets--inner .appointment_service--list .appointment_widgets--services .appointment_widgets--service-col .appointment_widgets--service:hover .appointment_service--name {
    color: #000c
}

.appointment_widgets-md {
    background: #ffffff;
    display: flex;
    padding-top: 1rem !important;
    height: 100%;
    justify-content: center;
    align-items: center;
    overflow-y: auto
}

.appointment_widgets-md::-webkit-scrollbar {
    width: 5px;
    position: absolute;
    top: 0;
    left: 0;
    border-radius: 4px;
    background: #ffffff;
    opacity: 0;
    cursor: default;
    outline: none;
    z-index: 1;
    will-change: transform
}

.appointment_widgets-md::-webkit-scrollbar-thumb {
    background: var(--appointment_widgets-gray-text-color);
    border-radius: 10px;
    padding: 2px
}

.appointment_widgets-md .appointment_widgets--inner {
    margin: 0 auto;
    border-radius: .5rem;
    max-height: 100%;
    width: 100%;
    overflow-y: auto;
    border: 1px solid var(--appointment_widgets-border-color)
}

@media only screen and (min-device-height: 900px) {
    .appointment_widgets-md .appointment_widgets--inner {
        min-height: 850px !important
    }
}

@media only screen and (min-device-height: 800px) {
    .appointment_widgets-md .appointment_widgets--inner {
        min-height: 800px !important
    }
}

.appointment_widgets-md .appointment_widgets--inner.direct-widget {
    border: none;
    box-shadow: 0 7px 27px #0000001c;
    width: 90%;
    max-width: 768px;
    max-height: 95%
}

@media only screen and (device-width: 375px) and (device-height: 812px) and (-webkit-device-pixel-ratio: 3) {
    .appointment_widgets-md .appointment_widgets--inner {
        max-height: none !important
    }
}

@media only screen and (device-width: 414px) and (device-height: 896px) and (-webkit-device-pixel-ratio: 2) {
    .appointment_widgets-md .appointment_widgets--inner {
        max-height: none !important
    }
}

@media only screen and (device-width: 414px) and (device-height: 896px) and (-webkit-device-pixel-ratio: 3) {
    .appointment_widgets-md .appointment_widgets--inner {
        max-height: none !important
    }
}

.appointment_widgets-md .appointment_widgets--inner .appointment_service--list {
    text-align: center
}

.appointment_widgets-md .appointment_widgets--inner .appointment_service--list .appointment_widgets--branding {
    padding: 1.5rem;
    padding: 2rem 0
}

.appointment_widgets-md .appointment_widgets--inner .appointment_service--list .appointment_widgets--branding .branding--logo {
    height: 5rem;
    width: auto
}

.appointment_widgets-md .appointment_widgets--inner .appointment_service--list .appointment_widgets--branding .branding-name {
    font-size: 1.5rem
}

.appointment_widgets-md .appointment_widgets--inner .appointment_service--list .appointment_widgets--branding .branding-detail {
    border-top: 1px solid #e1e1e1;
    padding-top: 1rem;
    max-width: 800px;
    margin: 1.5rem auto;
    width: 80%;
    opacity: 1;
    transition: all ease .1s
}

.appointment_widgets-md .appointment_widgets--inner .appointment_service--list .appointment_widgets--branding .branding-detail .pointer {
    cursor: pointer;
    font-weight: 700;
    color: var(--appointment_widgets-primary-color)
}

.appointment_widgets-md .appointment_widgets--inner .appointment_service--list .appointment_widgets--branding .branding-detail.show-more {
    max-height: 10rem;
    overflow: auto
}

.appointment_widgets-md .appointment_widgets--inner .appointment_service--list .appointment_widgets--branding .branding-detail.show-more::-webkit-scrollbar {
    width: 5px;
    position: absolute;
    top: 0;
    right: 0;
    border-radius: 4px;
    background: #ffffff;
    opacity: 0;
    cursor: default;
    outline: none;
    z-index: 1;
    will-change: transform
}

.appointment_widgets-md .appointment_widgets--inner .appointment_service--list .appointment_widgets--branding .branding-detail.show-more::-webkit-scrollbar-thumb {
    background: var(--appointment_widgets-gray-text-color);
    border-radius: 10px;
    padding: 2px
}

.appointment_widgets-md .appointment_widgets--inner .appointment_service--list .appointment_widgets--services {
    display: flex;
    flex-wrap: wrap
}

.appointment_widgets-md .appointment_widgets--inner .appointment_service--list .appointment_widgets--services .appointment_widgets--service-col {
    width: 100%;
    display: flex;
    flex-direction: column;
    flex: 0 0 50%;
    max-width: 50%;
    padding: 1rem 2rem
}

.appointment_widgets-md .appointment_widgets--inner .appointment_service--list .appointment_widgets--services .appointment_widgets--service-col .appointment_widgets--service {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    text-align: left;
    height: 100%;
    border-left-style: solid;
    border-left-width: 3px;
    border-left: 3px solid rgba(0, 0, 0, .3);
    padding: 1rem;
    padding-top: calc(1rem + 3px);
    -moz-background-clip: padding;
    -webkit-background-clip: padding;
    background-clip: padding-box
}

.appointment_widgets-md .appointment_widgets--inner .appointment_service--list .appointment_widgets--services .appointment_widgets--service-col .appointment_widgets--service .appointment_service--name {
    font-size: 20px;
    margin-bottom: 1rem;
    margin-bottom: 2rem
}

.appointment_widgets-md .appointment_widgets--inner .appointment_service--list .appointment_widgets--services .appointment_widgets--service-col .appointment_widgets--service:hover {
    cursor: pointer;
    padding-top: 1rem;
    border-top-width: 3px;
    border-top-style: solid;
    border-bottom-right-radius: 1rem;
    box-shadow: 3px 3px 5px #00000026
}

.appointment_widgets-md .appointment_widgets--inner .appointment_service--list .appointment_widgets--services .appointment_widgets--service-col .appointment_widgets--service:hover .appointment_service--name {
    color: #000c
}

.appointment_widgets-sm {
    background: #ffffff;
    display: flex
}

.appointment_widgets-sm::-webkit-scrollbar {
    width: 5px;
    position: absolute;
    top: 0;
    left: 0;
    border-radius: 4px;
    background: #ffffff;
    opacity: 0;
    cursor: default;
    outline: none;
    z-index: 1;
    will-change: transform
}

.appointment_widgets-sm::-webkit-scrollbar-thumb {
    background: var(--appointment_widgets-gray-text-color);
    border-radius: 10px;
    padding: 2px
}

.appointment_widgets-sm .appointment_widgets--inner {
    margin: 0 auto;
    border-radius: .5rem;
    max-height: 100%;
    width: 100%;
    overflow-y: auto;
    border: 1px solid var(--appointment_widgets-border-color)
}

.appointment_widgets-sm .appointment_widgets--inner.direct-widget {
    border: none
}

@media only screen and (device-width: 375px) and (device-height: 812px) and (-webkit-device-pixel-ratio: 3) {
    .appointment_widgets-sm .appointment_widgets--inner {
        max-height: none !important
    }
}

@media only screen and (device-width: 414px) and (device-height: 896px) and (-webkit-device-pixel-ratio: 2) {
    .appointment_widgets-sm .appointment_widgets--inner {
        max-height: none !important
    }
}

@media only screen and (device-width: 414px) and (device-height: 896px) and (-webkit-device-pixel-ratio: 3) {
    .appointment_widgets-sm .appointment_widgets--inner {
        max-height: none !important
    }
}

.appointment_widgets-sm .appointment_widgets--inner .appointment_service--list {
    text-align: center
}

.appointment_widgets-sm .appointment_widgets--inner .appointment_service--list .appointment_widgets--branding {
    padding: 1.5rem
}

.appointment_widgets-sm .appointment_widgets--inner .appointment_service--list .appointment_widgets--branding .branding--logo {
    height: 5rem;
    width: auto
}

.appointment_widgets-sm .appointment_widgets--inner .appointment_service--list .appointment_widgets--branding .branding-name {
    font-size: 1.5rem
}

.appointment_widgets-sm .appointment_widgets--inner .appointment_service--list .appointment_widgets--branding .branding-detail {
    border-top: 1px solid #e1e1e1;
    padding-top: 1rem;
    max-width: 800px;
    opacity: 1;
    transition: all ease .1s
}

.appointment_widgets-sm .appointment_widgets--inner .appointment_service--list .appointment_widgets--branding .branding-detail .pointer {
    cursor: pointer;
    font-weight: 700;
    color: var(--appointment_widgets-primary-color)
}

.appointment_widgets-sm .appointment_widgets--inner .appointment_service--list .appointment_widgets--branding .branding-detail.show-more::-webkit-scrollbar {
    width: 5px;
    position: absolute;
    top: 0;
    right: 0;
    border-radius: 4px;
    background: #ffffff;
    opacity: 0;
    cursor: default;
    outline: none;
    z-index: 1;
    will-change: transform
}

.appointment_widgets-sm .appointment_widgets--inner .appointment_service--list .appointment_widgets--branding .branding-detail.show-more::-webkit-scrollbar-thumb {
    background: var(--appointment_widgets-gray-text-color);
    border-radius: 10px;
    padding: 2px
}

.appointment_widgets-sm .appointment_widgets--inner .appointment_service--list .appointment_widgets--services {
    display: flex;
    flex-wrap: wrap
}

.appointment_widgets-sm .appointment_widgets--inner .appointment_service--list .appointment_widgets--services .appointment_widgets--service-col {
    padding: 1rem 2rem;
    width: 100%;
    display: flex;
    flex-direction: column
}

.appointment_widgets-sm .appointment_widgets--inner .appointment_service--list .appointment_widgets--services .appointment_widgets--service-col .appointment_widgets--service {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    text-align: left;
    height: 100%;
    border-left-style: solid;
    border-left-width: 3px;
    border-left: 3px solid rgba(0, 0, 0, .3);
    padding: 1rem;
    padding-top: calc(1rem + 3px);
    -moz-background-clip: padding;
    -webkit-background-clip: padding;
    background-clip: padding-box
}

.appointment_widgets-sm .appointment_widgets--inner .appointment_service--list .appointment_widgets--services .appointment_widgets--service-col .appointment_widgets--service .appointment_service--name {
    font-size: 20px;
    margin-bottom: 1rem
}

.appointment_widgets-sm .appointment_widgets--inner .appointment_service--list .appointment_widgets--services .appointment_widgets--service-col .appointment_widgets--service:hover {
    cursor: pointer;
    padding-top: 1rem;
    border-top-width: 3px;
    border-top-style: solid;
    border-bottom-right-radius: 1rem;
    box-shadow: 3px 3px 5px #00000026
}

.appointment_widgets-sm .appointment_widgets--inner .appointment_service--list .appointment_widgets--services .appointment_widgets--service-col .appointment_widgets--service:hover .appointment_service--name {
    color: #000c
}

:root {
    --appointment_widgets-bg-color: #e5e5e5;
    --appointment_widgets-border-color: #e3e3e3;
    --appointment_widgets-gray-text-color: #9d9d9d;
    --appointment_widgets-black-text-color: #525252;
    --appointment_widgets-label-text-color: #b1b7be;
    --appointment_widgets-semibold-text-color: rgba(0, 0, 0, .5);
    --appointment_widgets-primary-color: #178af6;
    --blue: #188bf6
}

.fade-enter-active,
.fade-leave-active {
    transition: opacity .5s
}

.fade-enter,
.fade-leave-to {
    opacity: 0
}

.appointment_widgets-xl .appointment_widgets--booking {
    display: flex;
    flex-direction: column-reverse;
    height: 100%;
    flex-direction: column
}

@media only screen and (min-device-height: 900px) {
    .appointment_widgets-xl .appointment_widgets--booking {
        min-height: 850px !important
    }
}

@media only screen and (min-device-height: 800px) {
    .appointment_widgets-xl .appointment_widgets--booking {
        min-height: 800px !important
    }
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--container {
    flex: 1;
    height: 100%
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--container.v1 .appointment_widgets--steps {
    padding: 1.8rem 3.5rem
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--container.v1 .widgets-date-block {
    display: flex;
    justify-content: space-between
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--container.v1 .widgets-date-block .widgets-time-slots {
    width: 35rem
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--container.v1 .vdpCell {
    padding: 1rem 0
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--container.v1 .widgets-time-slots {
    width: 12rem
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--info {
    border-right: 1px solid var(--appointment_widgets-border-color);
    flex-direction: column;
    justify-content: space-between;
    display: flex;
    padding: 1rem;
    width: 100%;
    padding: 1.5rem;
    flex: 0 0 33.33333%;
    max-width: 33.33333%;
    padding: 1.8rem 2rem
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--info .appointment_widgets--service-info {
    color: var(--appointment_widgets-black-text-color)
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--info .appointment_widgets--service-info .provider-branding {
    display: none;
    align-items: center;
    margin-bottom: 1rem;
    display: flex
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--info .appointment_widgets--service-info .branding--logo {
    margin-right: 1rem
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--info .appointment_widgets--service-info .provider-name {
    font-size: 1rem;
    font-weight: 400;
    display: 1.5rem
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--info .appointment_widgets--service-info .widgets--service-name {
    color: #222;
    font-weight: 700;
    font-size: 1.7rem
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--info .appointment_widgets--service-info .widgets--service-description {
    margin-top: 1rem;
    color: var(--appointment_widgets-gray-text-color);
    opacity: 1;
    transition: all ease .1s
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--info .appointment_widgets--service-info .widgets--service-description .pointer {
    font-weight: 700;
    cursor: pointer;
    color: var(--appointment_widgets-primary-color)
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--info .appointment_widgets--service-info .widgets--service-description.show-more {
    max-height: 17rem;
    overflow: auto;
    border: 2px solid #e1e1e1;
    opacity: .8;
    border: 1px solid #e9e9e9;
    box-sizing: border-box;
    box-shadow: 0 1px 17px #00000017;
    border-radius: 6px;
    padding: 10px 20px;
    z-index: 2;
    cursor: pointer;
    transition: all ease .1s;
    margin-bottom: 2rem;
    margin-left: -20px;
    margin-right: -20px;
    margin-bottom: auto
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--info .appointment_widgets--service-info .widgets--service-description.show-more::-webkit-scrollbar {
    width: 5px;
    position: absolute;
    top: 0;
    right: 0;
    border-radius: 4px;
    background: #ffffff;
    opacity: 0;
    cursor: default;
    outline: none;
    z-index: 1;
    will-change: transform
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--info .appointment_widgets--service-info .widgets--service-description.show-more::-webkit-scrollbar-thumb {
    background: var(--appointment_widgets-gray-text-color);
    border-radius: 10px;
    padding: 2px
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps {
    position: relative;
    padding: 0 1rem;
    padding: 1.5rem 1.5rem 0;
    flex: 0 0 66.666667%;
    max-width: 66.666667%;
    padding: 1.8rem 2rem
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps.selected-date {
    width: 100%
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps.selected-date .widgets-date-block {
    display: none;
    display: flex
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps.step-form {
    padding: 0;
    padding: 1rem;
    padding: 1.8rem 2rem
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps h4.text-info {
    font-size: 1.2rem;
    font-weight: 700;
    padding: 0 1rem;
    color: var(--appointment_widgets-gray-text-color)
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .appointment-error {
    padding: 1rem 1rem 0
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .label-select-date {
    font-size: .8rem;
    font-weight: 700;
    color: var(--appointment_widgets-gray-text-color);
    font-size: 1.1rem
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-step-1 {
    display: flex;
    height: 100%
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-step-1 .widgets-date-timezone-wrapper {
    height: 100%;
    display: flex;
    flex-direction: column-reverse;
    justify-content: space-between;
    flex-direction: column
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block {
    margin-top: 1rem;
    display: flex;
    position: relative;
    flex-direction: column-reverse;
    justify-content: space-between;
    flex-direction: column;
    height: 100%
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .date-picker-calendar {
    margin-top: 1rem;
    margin-top: 0
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .datepick-info {
    position: absolute;
    top: 7rem;
    left: 0;
    height: 100%;
    width: 100%;
    z-index: 5;
    background: rgba(255, 255, 255, .17);
    -webkit-backdrop-filter: blur(3px);
    backdrop-filter: blur(3px);
    justify-content: center;
    align-items: center;
    display: flex;
    top: 4rem;
    height: calc(100% - 10rem)
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .datepick-info>div {
    color: var(--appointment_widgets-gray-text-color);
    padding: 1.5rem 4rem;
    background: rgba(255, 255, 255, .55);
    border: 1px solid #d2d2d2;
    box-sizing: border-box;
    border-radius: 10px;
    text-align: center
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .datepick-info>div a {
    background: var(--appointment_widgets-primary-color);
    opacity: .8;
    cursor: pointer;
    color: #fff;
    padding: .3rem 1rem;
    border-radius: 17px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 1rem
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .datepick-info>div a svg {
    fill: #fff;
    margin-left: .5rem
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpInnerWrap {
    box-shadow: none;
    padding: 0
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpInnerWrap .vdpHeader {
    display: flex;
    margin: 0;
    padding-left: 0;
    padding-right: 0;
    flex-direction: row-reverse;
    justify-content: space-between;
    align-items: center
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpInnerWrap .vdpHeader .arrowPrevious,
.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpInnerWrap .vdpHeader .arrowNext {
    background: none;
    color: inherit;
    border: none;
    padding: 0;
    font: inherit;
    cursor: pointer;
    outline: inherit
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpInnerWrap .vdpHeader .arrowPrevious,
.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpInnerWrap .vdpHeader .arrowNext {
    margin-right: 2rem
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpInnerWrap .vdpPeriodControls {
    text-align: left
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpInnerWrap .vdpHeadCellContent {
    font-weight: 700
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpInnerWrap .vdpPeriodControl button {
    font-weight: 700;
    padding: 0
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpHeadCell {
    text-align: left
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpCell {
    border-radius: 25%;
    text-align: left;
    cursor: auto
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpCell:hover .vdpCellContent {
    background: #ffffff
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpCell.today .vdpCellContent:after {
    content: ".";
    position: absolute;
    bottom: -5px;
    left: 0;
    right: 0;
    font-size: 30px;
    line-height: 30px;
    color: var(--appointment_widgets-primary-color)
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpCell.selectable .vdpCellContent:hover,
.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpCell.selectable.selected .vdpCellContent {
    background: var(--appointment_widgets-primary-color);
    color: #fff !important
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpCell.selectable.selected.today .vdpCellContent:after {
    content: ""
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpCell .vdpCellContent {
    position: relative;
    border: 1px solid #d6d6d6;
    width: 55px;
    height: 55px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--appointment_widgets-primary-color);
    cursor: pointer;
    margin: 0
}

@media (max-width: 480px) {
    .appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpCell .vdpCellContent {
        width: 35px;
        height: 35px
    }
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-slot-block {
    width: 100%;
    margin-top: 1rem;
    width: auto;
    margin-top: 7rem
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-slot-block .widgets-time-slots {
    -webkit-padding-start: 0;
    padding-inline-start: 0;
    list-style: none;
    -webkit-margin-before: 0;
    margin-block-start: 0;
    -webkit-margin-after: 0;
    margin-block-end: 0;
    padding: 0;
    padding-right: .5rem;
    padding-bottom: .5rem;
    overflow: hidden;
    max-height: 35rem;
    overflow-y: auto;
    display: block;
    width: 10rem;
    padding-left: .5rem;
    width: 12rem
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-slot-block .widgets-time-slots::-webkit-scrollbar {
    width: 5px;
    position: absolute;
    top: 0;
    left: 0;
    border-radius: 4px;
    background: #ffffff;
    opacity: 0;
    cursor: default;
    outline: none;
    z-index: 1;
    will-change: transform
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-slot-block .widgets-time-slots::-webkit-scrollbar-thumb {
    background: var(--appointment_widgets-gray-text-color);
    border-radius: 10px;
    padding: 2px
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-slot-block .widgets-time-slots .widgets-time-slot {
    position: relative
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-slot-block .widgets-time-slots .widgets-time-slot:not(:last-child) {
    margin-bottom: .5rem;
    margin-bottom: 1.2rem
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-slot-block .widgets-time-slots .widgets-time-slot>span {
    display: block;
    padding: .5rem;
    text-align: center;
    border: 1px solid #d6d6d6;
    box-sizing: border-box;
    border-radius: 6px;
    color: var(--appointment_widgets-primary-color);
    font-weight: 700;
    cursor: pointer;
    transition: ease all .3s;
    width: 100%
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-slot-block .widgets-time-slots .widgets-time-slot>span:hover {
    border-color: var(--appointment_widgets-primary-color)
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-slot-block .widgets-time-slots .widgets-time-slot button {
    transform: translate(100%);
    transition: transform .3s ease;
    visibility: hidden;
    position: absolute;
    right: 0
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-slot-block .widgets-time-slots .widgets-time-slot.actived>span {
    background: var(--appointment_widgets-primary-color);
    color: #fff
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-slot-block .widgets-time-slots .widgets-time-slot.actived button {
    visibility: visible;
    transform: translate(0);
    z-index: 2;
    width: 40%;
    margin-left: 1rem;
    padding: .5rem 1rem;
    font-size: .8rem;
    background: var(--appointment_widgets-primary-color);
    color: #fff;
    border-color: var(--appointment_widgets-primary-color);
    border-style: solid
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-timezone-picker {
    background: #f3f8fb;
    color: #525252;
    width: 100%;
    width: 70%;
    margin-bottom: 1rem;
    width: 20rem;
    margin-bottom: 0;
    width: 30rem
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-timezone-picker .multiselect__single,
.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-timezone-picker .multiselect__input {
    background: #f3f8fb !important;
    color: #525252
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-timezone-picker .multiselect__single {
    display: flex;
    align-items: center
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-timezone-picker .multiselect__single svg {
    margin-right: 10px
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-timezone-picker .multiselect__content-wrapper {
    padding: 0;
    left: 0;
    transform: none;
    -webkit-transform: none;
    width: 100%
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-timezone-picker .multiselect__option {
    color: var(--appointment_widgets-gray-text-color)
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-timezone-picker .multiselect__option--highlight {
    background: var(--appointment_widgets-primary-color) !important;
    color: #fff
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-timezone-picker .option__desc {
    display: flex;
    padding: .2rem 0
}

.appointment_widgets-xl .appointment_widgets--booking .appointment_widgets--steps .widgets-timezone-picker .option__desc .option__title {
    flex: 1
}

.appointment_widgets-xl .appointment_widgets--booking .widgets-action-buttons>div {
    display: flex;
    align-items: center;
    padding: 1rem;
    border-bottom: 1px solid var(--appointment_widgets-border-color);
    padding: 1.3rem;
    border-top: 1px solid var(--appointment_widgets-border-color);
    border-bottom: none;
    padding: 1.3rem 2rem
}

.appointment_widgets-xl .appointment_widgets--booking .widgets-action-buttons>div:first-child {
    flex: 0 0 33.33333%;
    max-width: 33.33333%
}

.appointment_widgets-xl .appointment_widgets--booking .widgets-action-buttons .action-back-link {
    display: flex;
    align-items: center;
    color: var(--appointment_widgets-primary-color);
    cursor: pointer;
    font-weight: 700
}

.appointment_widgets-xl .appointment_widgets--booking .widgets-action-buttons .action-back-link:disabled {
    opacity: .7
}

.appointment_widgets-xl .appointment_widgets--booking .widgets-action-buttons .action-back-link svg {
    height: .8rem;
    margin-right: .3rem
}

.appointment_widgets-xl .appointment_widgets--booking .widgets-action-buttons .widgets-action {
    justify-content: flex-end;
    flex: 0 0 66.666667%;
    max-width: 66.666667%
}

.appointment_widgets-xl .appointment_widgets--booking .widgets-action-buttons .widgets-action button {
    padding: .3rem 2.5rem;
    border-radius: 5px;
    background: var(--appointment_widgets-primary-color);
    border: none;
    color: #fff;
    padding: .5rem 2rem
}

.appointment_widgets-xl .appointment_widgets--booking .widgets-action-buttons .widgets-action button:disabled {
    opacity: .7
}

.appointment_widgets-xl .appointment_widgets--booking .form-builder--wrap {
    max-width: initial
}

.appointment_widgets-xl .appointment_widgets--booking .form-builder--wrap .menu-field-wrap.calendar_notes,
.appointment_widgets-xl .appointment_widgets--booking .form-builder--wrap .payment-block {
    max-width: 100%;
    flex: 0 0 100%
}

.appointment_widgets-xl .appointment_widgets--booking .form-builder--wrap textarea[name=calendar_notes] {
    resize: none;
    height: 5rem
}

.appointment_widgets-xl .appointment_widgets--booking .form-builder--wrap .form-builder--btn-submit {
    display: block;
    display: none
}

.appointment_widgets-xl .appointment_widgets--booking .form-builder--wrap .form-builder--btn-submit>div,
.appointment_widgets-xl .appointment_widgets--booking .form-builder--wrap .form-builder--btn-submit button {
    width: 80% !important
}

.appointment_widgets-xl .appointment_widgets--booking .form-builder--wrap .form-builder--btn-submit>div,
.appointment_widgets-xl .appointment_widgets--booking .form-builder--wrap .form-builder--btn-submit button {
    width: auto !important
}

.appointment_widgets-xl .appointment_widgets--booking.appointment_widgets--confirmation {
    width: 90%;
    max-width: 60rem;
    margin: 2rem auto;
    display: flex;
    align-items: center
}

.appointment_widgets-xl .appointment_widgets--booking.appointment_widgets--confirmation .widgets-confirmation-icon,
.appointment_widgets-xl .appointment_widgets--booking.appointment_widgets--confirmation .confirmation-message,
.appointment_widgets-xl .appointment_widgets--booking.appointment_widgets--confirmation .confirmation-invite-text {
    text-align: center
}

.appointment_widgets-xl .appointment_widgets--booking.appointment_widgets--confirmation .widgets-confirmation-icon {
    margin-bottom: 2rem
}

.appointment_widgets-xl .appointment_widgets--booking.appointment_widgets--confirmation .confirmation-message {
    margin-bottom: 1.5rem !important;
    font-weight: 700
}

.appointment_widgets-xl .appointment_widgets--booking.appointment_widgets--confirmation .confirmation-invite-text {
    margin-bottom: 3rem
}

.appointment_widgets-xl .appointment_widgets--booking.appointment_widgets--confirmation .confirmation-invite-text a {
    color: var(--appointment_widgets-primary-color);
    display: block;
    font-weight: 700
}

.appointment_widgets-xl .appointment_widgets--booking.appointment_widgets--confirmation .confirmation-details {
    border: 1px solid var(--appointment_widgets-border-color)
}

.appointment_widgets-xl .appointment_widgets--booking.appointment_widgets--confirmation .hl_events-buttons {
    margin-top: 3rem;
    width: 100%;
    justify-content: center;
    padding: .5rem 2rem;
    width: 80%
}

.appointment_widgets-xl .appointment_widgets--booking.appointment_widgets--confirmation .hl_events-buttons .calendar-button {
    margin-right: 0;
    margin-right: 1rem;
    margin-right: 2rem
}

.appointment_widgets-xl .appointment_widgets--booking.appointment_widgets--confirmation .hl_events-buttons .calendar-button:last-child {
    margin-right: 0
}

.appointment_widgets-xl .appointment_widgets--booking-info {
    padding-bottom: .8rem;
    border-radius: 5px;
    padding-bottom: 0;
    border: 1px solid var(--appointment_widgets-border-color);
    width: auto
}

.appointment_widgets-xl .appointment_widgets--booking-info:not(.--horizontal) {
    border-bottom: 1px solid var(--appointment_widgets-border-color)
}

.appointment_widgets-xl .appointment_widgets--booking-info>div {
    padding: .5rem 0;
    display: flex;
    display: block;
    padding: 1rem
}

.appointment_widgets-xl .appointment_widgets--booking-info>div .booking-info-label {
    display: none;
    display: inline-block
}

.appointment_widgets-xl .appointment_widgets--booking-info>div.booking-info--location,
.appointment_widgets-xl .appointment_widgets--booking-info>div.booking-info--timezone {
    display: none;
    display: block
}

.appointment_widgets-xl .appointment_widgets--booking-info>div .booking-info-value {
    display: inline-block;
    margin-left: 1rem;
    display: block;
    margin-left: auto
}

.appointment_widgets-xl .appointment_widgets--booking-info.--horizontal {
    border: 1px solid var(--appointment_widgets-border-color);
    border-radius: 5px;
    display: flex;
    flex-wrap: wrap
}

.appointment_widgets-xl .appointment_widgets--booking-info.--horizontal>div {
    padding: 1rem;
    flex: 0 0 50%;
    max-width: 50%
}

.appointment_widgets-xl .appointment_widgets--booking-info.--horizontal>div.booking-info--location,
.appointment_widgets-xl .appointment_widgets--booking-info.--horizontal>div.booking-info--timezone {
    display: flex;
    display: block
}

.appointment_widgets-xl .appointment_widgets--booking-info.--horizontal>div.booking-info--timezone {
    padding-bottom: 0
}

.appointment_widgets-xl .appointment_widgets--booking-info.--horizontal>div.booking-info--timezone {
    padding-bottom: 1rem
}

.appointment_widgets-xl .appointment_widgets--booking-info label {
    color: var(--appointment_widgets-label-text-color);
    display: flex;
    align-items: center;
    margin-bottom: 0
}

.appointment_widgets-xl .appointment_widgets--booking-info label span {
    padding-left: .5rem
}

.appointment_widgets-xl .appointment_widgets--booking-info .booking-info-value {
    color: var(--appointment_widgets-black-text-color);
    font-weight: 700
}

.appointment_widgets-lg .appointment_widgets--booking {
    display: flex;
    flex-direction: column-reverse;
    height: 100%;
    flex-direction: column
}

@media only screen and (min-device-height: 900px) {
    .appointment_widgets-lg .appointment_widgets--booking {
        min-height: 850px !important
    }
}

@media only screen and (min-device-height: 800px) {
    .appointment_widgets-lg .appointment_widgets--booking {
        min-height: 800px !important
    }
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--container {
    flex: 1;
    height: 100%
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--container.v1 .appointment_widgets--steps {
    padding: 1.8rem 3.5rem
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--container.v1 .widgets-date-block {
    display: flex;
    justify-content: space-between
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--container.v1 .widgets-date-block .widgets-time-slots {
    width: 35rem
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--container.v1 .vdpCell {
    padding: 1rem 0
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--container.v1 .widgets-time-slots {
    width: 12rem
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--info {
    border-right: 1px solid var(--appointment_widgets-border-color);
    flex-direction: column;
    justify-content: space-between;
    display: flex;
    padding: 1rem;
    width: 100%;
    padding: 1.5rem;
    flex: 0 0 33.33333%;
    max-width: 33.33333%
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--info .appointment_widgets--service-info {
    color: var(--appointment_widgets-black-text-color)
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--info .appointment_widgets--service-info .provider-branding {
    display: none;
    align-items: center;
    margin-bottom: 1rem;
    display: flex
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--info .appointment_widgets--service-info .branding--logo {
    margin-right: 1rem
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--info .appointment_widgets--service-info .provider-name {
    font-size: 1rem;
    font-weight: 400;
    display: 1.5rem
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--info .appointment_widgets--service-info .widgets--service-name {
    color: #222;
    font-weight: 700;
    font-size: 1.7rem
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--info .appointment_widgets--service-info .widgets--service-description {
    margin-top: 1rem;
    color: var(--appointment_widgets-gray-text-color);
    opacity: 1;
    transition: all ease .1s
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--info .appointment_widgets--service-info .widgets--service-description .pointer {
    font-weight: 700;
    cursor: pointer;
    color: var(--appointment_widgets-primary-color)
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--info .appointment_widgets--service-info .widgets--service-description.show-more {
    max-height: 17rem;
    overflow: auto;
    margin-left: -10px;
    margin-right: -10px;
    border: 2px solid #e1e1e1;
    opacity: .8;
    border: 1px solid #e9e9e9;
    box-sizing: border-box;
    box-shadow: 0 1px 17px #00000017;
    border-radius: 6px;
    padding: 10px 20px;
    z-index: 2;
    cursor: pointer;
    transition: all ease .1s;
    margin-bottom: 2rem
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--info .appointment_widgets--service-info .widgets--service-description.show-more::-webkit-scrollbar {
    width: 5px;
    position: absolute;
    top: 0;
    right: 0;
    border-radius: 4px;
    background: #ffffff;
    opacity: 0;
    cursor: default;
    outline: none;
    z-index: 1;
    will-change: transform
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--info .appointment_widgets--service-info .widgets--service-description.show-more::-webkit-scrollbar-thumb {
    background: var(--appointment_widgets-gray-text-color);
    border-radius: 10px;
    padding: 2px
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps {
    position: relative;
    padding: 0 1rem;
    padding: 1.5rem 1.5rem 0;
    flex: 0 0 66.666667%;
    max-width: 66.666667%
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps.selected-date {
    width: 100%
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps.selected-date .widgets-date-block {
    display: none;
    display: flex
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps.step-form {
    padding: 0;
    padding: 1rem
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps h4.text-info {
    font-size: 1.2rem;
    font-weight: 700;
    padding: 0 1rem;
    color: var(--appointment_widgets-gray-text-color)
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .appointment-error {
    padding: 1rem 1rem 0
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .label-select-date {
    font-size: .8rem;
    font-weight: 700;
    color: var(--appointment_widgets-gray-text-color);
    font-size: 1.1rem
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-step-1 {
    display: flex;
    height: 100%
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-step-1 .widgets-date-timezone-wrapper {
    height: 100%;
    display: flex;
    flex-direction: column-reverse;
    justify-content: space-between;
    flex-direction: column
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block {
    margin-top: 1rem;
    display: flex;
    position: relative;
    flex-direction: column-reverse;
    justify-content: space-between;
    flex-direction: column;
    height: 100%
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .date-picker-calendar {
    margin-top: 1rem;
    margin-top: 0
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .datepick-info {
    position: absolute;
    top: 7rem;
    left: 0;
    height: 100%;
    width: 100%;
    z-index: 5;
    background: rgba(255, 255, 255, .17);
    -webkit-backdrop-filter: blur(3px);
    backdrop-filter: blur(3px);
    justify-content: center;
    align-items: center;
    display: flex;
    top: 4rem;
    height: calc(100% - 10rem)
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .datepick-info>div {
    color: var(--appointment_widgets-gray-text-color);
    padding: 1.5rem 4rem;
    background: rgba(255, 255, 255, .55);
    border: 1px solid #d2d2d2;
    box-sizing: border-box;
    border-radius: 10px;
    text-align: center
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .datepick-info>div a {
    background: var(--appointment_widgets-primary-color);
    opacity: .8;
    cursor: pointer;
    color: #fff;
    padding: .3rem 1rem;
    border-radius: 17px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 1rem
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .datepick-info>div a svg {
    fill: #fff;
    margin-left: .5rem
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpInnerWrap {
    box-shadow: none;
    padding: 0
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpInnerWrap .vdpHeader {
    display: flex;
    margin: 0;
    padding-left: 0;
    padding-right: 0;
    flex-direction: row-reverse;
    justify-content: space-between;
    align-items: center
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpInnerWrap .vdpHeader .arrowPrevious,
.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpInnerWrap .vdpHeader .arrowNext {
    background: none;
    color: inherit;
    border: none;
    padding: 0;
    font: inherit;
    cursor: pointer;
    outline: inherit
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpInnerWrap .vdpHeader .arrowPrevious,
.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpInnerWrap .vdpHeader .arrowNext {
    margin-right: 2rem
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpInnerWrap .vdpPeriodControls {
    text-align: left
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpInnerWrap .vdpHeadCellContent {
    font-weight: 700
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpInnerWrap .vdpPeriodControl button {
    font-weight: 700;
    padding: 0
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpHeadCell {
    text-align: left
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpCell {
    border-radius: 25%;
    text-align: left;
    cursor: auto
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpCell:hover .vdpCellContent {
    background: #ffffff
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpCell.today .vdpCellContent:after {
    content: ".";
    position: absolute;
    bottom: -5px;
    left: 0;
    right: 0;
    font-size: 30px;
    line-height: 30px;
    color: var(--appointment_widgets-primary-color)
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpCell.selectable .vdpCellContent:hover,
.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpCell.selectable.selected .vdpCellContent {
    background: var(--appointment_widgets-primary-color);
    color: #fff !important
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpCell.selectable.selected.today .vdpCellContent:after {
    content: ""
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpCell .vdpCellContent {
    position: relative;
    border: 1px solid #d6d6d6;
    width: 55px;
    height: 55px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--appointment_widgets-primary-color);
    cursor: pointer;
    margin: 0
}

@media (max-width: 480px) {
    .appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpCell .vdpCellContent {
        width: 35px;
        height: 35px
    }
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-slot-block {
    width: 100%;
    margin-top: 1rem;
    width: auto;
    margin-top: 7rem
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-slot-block .widgets-time-slots {
    -webkit-padding-start: 0;
    padding-inline-start: 0;
    list-style: none;
    -webkit-margin-before: 0;
    margin-block-start: 0;
    -webkit-margin-after: 0;
    margin-block-end: 0;
    padding: 0;
    padding-right: .5rem;
    padding-bottom: .5rem;
    overflow: hidden;
    max-height: 35rem;
    overflow-y: auto;
    display: block;
    width: 10rem;
    padding-left: .5rem
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-slot-block .widgets-time-slots::-webkit-scrollbar {
    width: 5px;
    position: absolute;
    top: 0;
    left: 0;
    border-radius: 4px;
    background: #ffffff;
    opacity: 0;
    cursor: default;
    outline: none;
    z-index: 1;
    will-change: transform
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-slot-block .widgets-time-slots::-webkit-scrollbar-thumb {
    background: var(--appointment_widgets-gray-text-color);
    border-radius: 10px;
    padding: 2px
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-slot-block .widgets-time-slots .widgets-time-slot {
    position: relative
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-slot-block .widgets-time-slots .widgets-time-slot:not(:last-child) {
    margin-bottom: .5rem;
    margin-bottom: 1.2rem
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-slot-block .widgets-time-slots .widgets-time-slot>span {
    display: block;
    padding: .5rem;
    text-align: center;
    border: 1px solid #d6d6d6;
    box-sizing: border-box;
    border-radius: 6px;
    color: var(--appointment_widgets-primary-color);
    font-weight: 700;
    cursor: pointer;
    transition: ease all .3s;
    width: 100%
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-slot-block .widgets-time-slots .widgets-time-slot>span:hover {
    border-color: var(--appointment_widgets-primary-color)
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-slot-block .widgets-time-slots .widgets-time-slot button {
    transform: translate(100%);
    transition: transform .3s ease;
    visibility: hidden;
    position: absolute;
    right: 0
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-slot-block .widgets-time-slots .widgets-time-slot.actived>span {
    background: var(--appointment_widgets-primary-color);
    color: #fff
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-slot-block .widgets-time-slots .widgets-time-slot.actived button {
    visibility: visible;
    transform: translate(0);
    z-index: 2;
    width: 40%;
    margin-left: 1rem;
    padding: .5rem 1rem;
    font-size: .8rem;
    background: var(--appointment_widgets-primary-color);
    color: #fff;
    border-color: var(--appointment_widgets-primary-color);
    border-style: solid
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-timezone-picker {
    background: #f3f8fb;
    color: #525252;
    width: 100%;
    width: 70%;
    margin-bottom: 0;
    margin-bottom: 1rem;
    width: 20rem
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-timezone-picker .multiselect__single,
.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-timezone-picker .multiselect__input {
    background: #f3f8fb !important;
    color: #525252
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-timezone-picker .multiselect__single {
    display: flex;
    align-items: center
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-timezone-picker .multiselect__single svg {
    margin-right: 10px
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-timezone-picker .multiselect__content-wrapper {
    padding: 0;
    left: 0;
    transform: none;
    -webkit-transform: none;
    width: 100%
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-timezone-picker .multiselect__option {
    color: var(--appointment_widgets-gray-text-color)
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-timezone-picker .multiselect__option--highlight {
    background: var(--appointment_widgets-primary-color) !important;
    color: #fff
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-timezone-picker .option__desc {
    display: flex;
    padding: .2rem 0
}

.appointment_widgets-lg .appointment_widgets--booking .appointment_widgets--steps .widgets-timezone-picker .option__desc .option__title {
    flex: 1
}

.appointment_widgets-lg .appointment_widgets--booking .widgets-action-buttons>div {
    display: flex;
    align-items: center;
    padding: 1rem;
    border-bottom: 1px solid var(--appointment_widgets-border-color);
    padding: 1.3rem;
    border-top: 1px solid var(--appointment_widgets-border-color);
    border-bottom: none
}

.appointment_widgets-lg .appointment_widgets--booking .widgets-action-buttons>div:first-child {
    flex: 0 0 33.33333%;
    max-width: 33.33333%
}

.appointment_widgets-lg .appointment_widgets--booking .widgets-action-buttons .action-back-link {
    display: flex;
    align-items: center;
    color: var(--appointment_widgets-primary-color);
    cursor: pointer;
    font-weight: 700
}

.appointment_widgets-lg .appointment_widgets--booking .widgets-action-buttons .action-back-link:disabled {
    opacity: .7
}

.appointment_widgets-lg .appointment_widgets--booking .widgets-action-buttons .action-back-link svg {
    height: .8rem;
    margin-right: .3rem
}

.appointment_widgets-lg .appointment_widgets--booking .widgets-action-buttons .widgets-action {
    justify-content: flex-end;
    flex: 0 0 66.666667%;
    max-width: 66.666667%
}

.appointment_widgets-lg .appointment_widgets--booking .widgets-action-buttons .widgets-action button {
    padding: .3rem 2.5rem;
    border-radius: 5px;
    background: var(--appointment_widgets-primary-color);
    border: none;
    color: #fff;
    padding: .5rem 2rem
}

.appointment_widgets-lg .appointment_widgets--booking .widgets-action-buttons .widgets-action button:disabled {
    opacity: .7
}

.appointment_widgets-lg .appointment_widgets--booking .form-builder--wrap {
    max-width: initial
}

.appointment_widgets-lg .appointment_widgets--booking .form-builder--wrap .menu-field-wrap.calendar_notes,
.appointment_widgets-lg .appointment_widgets--booking .form-builder--wrap .payment-block {
    max-width: 100%;
    flex: 0 0 100%
}

.appointment_widgets-lg .appointment_widgets--booking .form-builder--wrap textarea[name=calendar_notes] {
    resize: none;
    height: 5rem
}

.appointment_widgets-lg .appointment_widgets--booking .form-builder--wrap .form-builder--btn-submit {
    display: block;
    display: none
}

.appointment_widgets-lg .appointment_widgets--booking .form-builder--wrap .form-builder--btn-submit>div,
.appointment_widgets-lg .appointment_widgets--booking .form-builder--wrap .form-builder--btn-submit button {
    width: 80% !important
}

.appointment_widgets-lg .appointment_widgets--booking .form-builder--wrap .form-builder--btn-submit>div,
.appointment_widgets-lg .appointment_widgets--booking .form-builder--wrap .form-builder--btn-submit button {
    width: auto !important
}

.appointment_widgets-lg .appointment_widgets--booking.appointment_widgets--confirmation {
    width: 90%;
    max-width: 60rem;
    margin: 2rem auto;
    display: flex;
    align-items: center
}

.appointment_widgets-lg .appointment_widgets--booking.appointment_widgets--confirmation .widgets-confirmation-icon,
.appointment_widgets-lg .appointment_widgets--booking.appointment_widgets--confirmation .confirmation-message,
.appointment_widgets-lg .appointment_widgets--booking.appointment_widgets--confirmation .confirmation-invite-text {
    text-align: center
}

.appointment_widgets-lg .appointment_widgets--booking.appointment_widgets--confirmation .widgets-confirmation-icon {
    margin-bottom: 2rem
}

.appointment_widgets-lg .appointment_widgets--booking.appointment_widgets--confirmation .confirmation-message {
    margin-bottom: 1.5rem !important;
    font-weight: 700
}

.appointment_widgets-lg .appointment_widgets--booking.appointment_widgets--confirmation .confirmation-invite-text {
    margin-bottom: 3rem
}

.appointment_widgets-lg .appointment_widgets--booking.appointment_widgets--confirmation .confirmation-invite-text a {
    color: var(--appointment_widgets-primary-color);
    display: block;
    font-weight: 700
}

.appointment_widgets-lg .appointment_widgets--booking.appointment_widgets--confirmation .confirmation-details {
    border: 1px solid var(--appointment_widgets-border-color)
}

.appointment_widgets-lg .appointment_widgets--booking.appointment_widgets--confirmation .hl_events-buttons {
    margin-top: 3rem;
    width: 100%;
    justify-content: center;
    padding: .5rem 2rem;
    width: 80%
}

.appointment_widgets-lg .appointment_widgets--booking.appointment_widgets--confirmation .hl_events-buttons .calendar-button {
    margin-right: 0;
    margin-right: 1rem;
    margin-right: 2rem
}

.appointment_widgets-lg .appointment_widgets--booking.appointment_widgets--confirmation .hl_events-buttons .calendar-button:last-child {
    margin-right: 0
}

.appointment_widgets-lg .appointment_widgets--booking-info {
    padding-bottom: .8rem;
    border-radius: 5px;
    padding-bottom: 0;
    border: 1px solid var(--appointment_widgets-border-color);
    width: auto
}

.appointment_widgets-lg .appointment_widgets--booking-info:not(.--horizontal) {
    border-bottom: 1px solid var(--appointment_widgets-border-color)
}

.appointment_widgets-lg .appointment_widgets--booking-info>div {
    padding: .5rem 0;
    display: flex;
    display: block;
    padding: 1rem
}

.appointment_widgets-lg .appointment_widgets--booking-info>div .booking-info-label {
    display: none;
    display: inline-block
}

.appointment_widgets-lg .appointment_widgets--booking-info>div.booking-info--location,
.appointment_widgets-lg .appointment_widgets--booking-info>div.booking-info--timezone {
    display: none;
    display: block
}

.appointment_widgets-lg .appointment_widgets--booking-info>div .booking-info-value {
    display: inline-block;
    margin-left: 1rem;
    display: block;
    margin-left: auto
}

.appointment_widgets-lg .appointment_widgets--booking-info.--horizontal {
    border: 1px solid var(--appointment_widgets-border-color);
    border-radius: 5px;
    display: flex;
    flex-wrap: wrap
}

.appointment_widgets-lg .appointment_widgets--booking-info.--horizontal>div {
    padding: 1rem;
    flex: 0 0 50%;
    max-width: 50%
}

.appointment_widgets-lg .appointment_widgets--booking-info.--horizontal>div.booking-info--location,
.appointment_widgets-lg .appointment_widgets--booking-info.--horizontal>div.booking-info--timezone {
    display: flex;
    display: block
}

.appointment_widgets-lg .appointment_widgets--booking-info.--horizontal>div.booking-info--timezone {
    padding-bottom: 0
}

.appointment_widgets-lg .appointment_widgets--booking-info.--horizontal>div.booking-info--timezone {
    padding-bottom: 1rem
}

.appointment_widgets-lg .appointment_widgets--booking-info label {
    color: var(--appointment_widgets-label-text-color);
    display: flex;
    align-items: center;
    margin-bottom: 0
}

.appointment_widgets-lg .appointment_widgets--booking-info label span {
    padding-left: .5rem
}

.appointment_widgets-lg .appointment_widgets--booking-info .booking-info-value {
    color: var(--appointment_widgets-black-text-color);
    font-weight: 700
}

.appointment_widgets-md .appointment_widgets--booking {
    display: flex;
    flex-direction: column-reverse
}

@media only screen and (min-device-height: 900px) {
    .appointment_widgets-md .appointment_widgets--booking {
        min-height: 850px !important
    }
}

@media only screen and (min-device-height: 800px) {
    .appointment_widgets-md .appointment_widgets--booking {
        min-height: 800px !important
    }
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--container {
    flex: 1;
    height: 100%
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--container.v1 .appointment_widgets--steps {
    padding: 1.8rem 3.5rem
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--container.v1 .widgets-date-block {
    display: flex;
    justify-content: space-between
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--container.v1 .widgets-date-block .widgets-time-slots {
    width: 35rem
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--container.v1 .vdpCell {
    padding: 1rem 0
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--container.v1 .widgets-time-slots {
    width: 12rem
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--info {
    border-right: 1px solid var(--appointment_widgets-border-color);
    flex-direction: column;
    justify-content: space-between;
    display: flex;
    padding: 1rem;
    width: 100%;
    padding: 1.5rem
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--info .appointment_widgets--service-info {
    color: var(--appointment_widgets-black-text-color)
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--info .appointment_widgets--service-info .provider-branding {
    display: none;
    align-items: center;
    margin-bottom: 1rem;
    display: flex
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--info .appointment_widgets--service-info .branding--logo {
    margin-right: 1rem
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--info .appointment_widgets--service-info .provider-name {
    font-size: 1rem;
    font-weight: 400;
    display: 1.5rem
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--info .appointment_widgets--service-info .widgets--service-name {
    color: #222;
    font-weight: 700;
    font-size: 1.7rem
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--info .appointment_widgets--service-info .widgets--service-description {
    margin-top: 1rem;
    color: var(--appointment_widgets-gray-text-color);
    opacity: 1;
    transition: all ease .1s
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--info .appointment_widgets--service-info .widgets--service-description .pointer {
    font-weight: 700;
    cursor: pointer;
    color: var(--appointment_widgets-primary-color)
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--info .appointment_widgets--service-info .widgets--service-description.show-more {
    max-height: 17rem;
    overflow: auto
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--info .appointment_widgets--service-info .widgets--service-description.show-more::-webkit-scrollbar {
    width: 5px;
    position: absolute;
    top: 0;
    right: 0;
    border-radius: 4px;
    background: #ffffff;
    opacity: 0;
    cursor: default;
    outline: none;
    z-index: 1;
    will-change: transform
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--info .appointment_widgets--service-info .widgets--service-description.show-more::-webkit-scrollbar-thumb {
    background: var(--appointment_widgets-gray-text-color);
    border-radius: 10px;
    padding: 2px
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps {
    position: relative;
    padding: 0 1rem;
    padding: 0 1.5rem
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps.selected-date {
    width: 100%
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps.selected-date .widgets-date-block {
    display: none;
    display: flex
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps.step-form {
    padding: 0
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps h4.text-info {
    font-size: 1.2rem;
    font-weight: 700;
    padding: 0 1rem;
    color: var(--appointment_widgets-gray-text-color)
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .appointment-error {
    padding: 1rem 1rem 0
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .label-select-date {
    font-size: .8rem;
    font-weight: 700;
    color: var(--appointment_widgets-gray-text-color);
    font-size: 1.1rem
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-step-1 {
    display: flex
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-step-1 .widgets-date-timezone-wrapper {
    height: 100%;
    display: flex;
    flex-direction: column-reverse;
    justify-content: space-between;
    flex-direction: column
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block {
    margin-top: 1rem;
    display: flex;
    position: relative;
    flex-direction: column-reverse;
    justify-content: space-between
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .date-picker-calendar {
    margin-top: 1rem
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .datepick-info {
    position: absolute;
    top: 7rem;
    left: 0;
    height: 100%;
    width: 100%;
    z-index: 5;
    background: rgba(255, 255, 255, .17);
    -webkit-backdrop-filter: blur(3px);
    backdrop-filter: blur(3px);
    justify-content: center;
    align-items: center;
    display: flex
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .datepick-info>div {
    color: var(--appointment_widgets-gray-text-color);
    padding: 1.5rem 4rem;
    background: rgba(255, 255, 255, .55);
    border: 1px solid #d2d2d2;
    box-sizing: border-box;
    border-radius: 10px;
    text-align: center
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .datepick-info>div a {
    background: var(--appointment_widgets-primary-color);
    opacity: .8;
    cursor: pointer;
    color: #fff;
    padding: .3rem 1rem;
    border-radius: 17px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 1rem
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .datepick-info>div a svg {
    fill: #fff;
    margin-left: .5rem
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpInnerWrap {
    box-shadow: none;
    padding: 0
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpInnerWrap .vdpHeader {
    display: flex;
    margin: 0;
    padding-left: 0;
    padding-right: 0;
    flex-direction: row-reverse;
    justify-content: space-between;
    align-items: center
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpInnerWrap .vdpHeader .arrowPrevious,
.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpInnerWrap .vdpHeader .arrowNext {
    background: none;
    color: inherit;
    border: none;
    padding: 0;
    font: inherit;
    cursor: pointer;
    outline: inherit
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpInnerWrap .vdpHeader .arrowPrevious,
.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpInnerWrap .vdpHeader .arrowNext {
    margin-right: 2rem
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpInnerWrap .vdpPeriodControls {
    text-align: left
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpInnerWrap .vdpHeadCellContent {
    font-weight: 700
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpInnerWrap .vdpPeriodControl button {
    font-weight: 700;
    padding: 0
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpHeadCell {
    text-align: left
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpCell {
    border-radius: 25%;
    text-align: left;
    cursor: auto
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpCell:hover .vdpCellContent {
    background: #ffffff
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpCell.today .vdpCellContent:after {
    content: ".";
    position: absolute;
    bottom: -5px;
    left: 0;
    right: 0;
    font-size: 30px;
    line-height: 30px;
    color: var(--appointment_widgets-primary-color)
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpCell.selectable .vdpCellContent:hover,
.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpCell.selectable.selected .vdpCellContent {
    background: var(--appointment_widgets-primary-color);
    color: #fff !important
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpCell.selectable.selected.today .vdpCellContent:after {
    content: ""
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpCell .vdpCellContent {
    position: relative;
    border: 1px solid #d6d6d6;
    width: 55px;
    height: 55px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--appointment_widgets-primary-color);
    cursor: pointer;
    margin: 0
}

@media (max-width: 480px) {
    .appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpCell .vdpCellContent {
        width: 35px;
        height: 35px
    }
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-slot-block {
    width: 100%;
    margin-top: 1rem
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-slot-block .widgets-time-slots {
    -webkit-padding-start: 0;
    padding-inline-start: 0;
    list-style: none;
    -webkit-margin-before: 0;
    margin-block-start: 0;
    -webkit-margin-after: 0;
    margin-block-end: 0;
    padding: 0;
    padding-right: .5rem;
    padding-bottom: .5rem;
    overflow: hidden;
    max-height: 35rem;
    overflow-y: auto;
    display: block;
    width: 10rem;
    padding-left: .5rem
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-slot-block .widgets-time-slots::-webkit-scrollbar {
    width: 5px;
    position: absolute;
    top: 0;
    left: 0;
    border-radius: 4px;
    background: #ffffff;
    opacity: 0;
    cursor: default;
    outline: none;
    z-index: 1;
    will-change: transform
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-slot-block .widgets-time-slots::-webkit-scrollbar-thumb {
    background: var(--appointment_widgets-gray-text-color);
    border-radius: 10px;
    padding: 2px
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-slot-block .widgets-time-slots .widgets-time-slot {
    position: relative
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-slot-block .widgets-time-slots .widgets-time-slot:not(:last-child) {
    margin-bottom: .5rem;
    margin-bottom: 1.2rem
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-slot-block .widgets-time-slots .widgets-time-slot>span {
    display: block;
    padding: .5rem;
    text-align: center;
    border: 1px solid #d6d6d6;
    box-sizing: border-box;
    border-radius: 6px;
    color: var(--appointment_widgets-primary-color);
    font-weight: 700;
    cursor: pointer;
    transition: ease all .3s;
    width: 100%
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-slot-block .widgets-time-slots .widgets-time-slot>span:hover {
    border-color: var(--appointment_widgets-primary-color)
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-slot-block .widgets-time-slots .widgets-time-slot button {
    transform: translate(100%);
    transition: transform .3s ease;
    visibility: hidden;
    position: absolute;
    right: 0
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-slot-block .widgets-time-slots .widgets-time-slot.actived>span {
    background: var(--appointment_widgets-primary-color);
    color: #fff
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-slot-block .widgets-time-slots .widgets-time-slot.actived button {
    visibility: visible;
    transform: translate(0);
    z-index: 2;
    width: 40%;
    margin-left: 1rem;
    padding: .5rem 1rem;
    font-size: .8rem;
    background: var(--appointment_widgets-primary-color);
    color: #fff;
    border-color: var(--appointment_widgets-primary-color);
    border-style: solid
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-timezone-picker {
    background: #f3f8fb;
    color: #525252;
    width: 100%;
    width: 70%;
    margin-bottom: 0
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-timezone-picker .multiselect__single,
.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-timezone-picker .multiselect__input {
    background: #f3f8fb !important;
    color: #525252
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-timezone-picker .multiselect__single {
    display: flex;
    align-items: center
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-timezone-picker .multiselect__single svg {
    margin-right: 10px
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-timezone-picker .multiselect__content-wrapper {
    padding: 0;
    left: 0;
    transform: none;
    -webkit-transform: none;
    width: 100%
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-timezone-picker .multiselect__option {
    color: var(--appointment_widgets-gray-text-color)
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-timezone-picker .multiselect__option--highlight {
    background: var(--appointment_widgets-primary-color) !important;
    color: #fff
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-timezone-picker .option__desc {
    display: flex;
    padding: .2rem 0
}

.appointment_widgets-md .appointment_widgets--booking .appointment_widgets--steps .widgets-timezone-picker .option__desc .option__title {
    flex: 1
}

.appointment_widgets-md .appointment_widgets--booking .widgets-action-buttons>div {
    display: flex;
    align-items: center;
    padding: 1rem;
    border-bottom: 1px solid var(--appointment_widgets-border-color)
}

.appointment_widgets-md .appointment_widgets--booking .widgets-action-buttons>div:first-child {
    flex: 0 0 33.33333%;
    max-width: 33.33333%
}

.appointment_widgets-md .appointment_widgets--booking .widgets-action-buttons .action-back-link {
    display: flex;
    align-items: center;
    color: var(--appointment_widgets-primary-color);
    cursor: pointer;
    font-weight: 700
}

.appointment_widgets-md .appointment_widgets--booking .widgets-action-buttons .action-back-link:disabled {
    opacity: .7
}

.appointment_widgets-md .appointment_widgets--booking .widgets-action-buttons .action-back-link svg {
    height: .8rem;
    margin-right: .3rem
}

.appointment_widgets-md .appointment_widgets--booking .widgets-action-buttons .widgets-action {
    justify-content: flex-end;
    flex: 0 0 66.666667%;
    max-width: 66.666667%
}

.appointment_widgets-md .appointment_widgets--booking .widgets-action-buttons .widgets-action button {
    padding: .3rem 2.5rem;
    border-radius: 5px;
    background: var(--appointment_widgets-primary-color);
    border: none;
    color: #fff
}

.appointment_widgets-md .appointment_widgets--booking .widgets-action-buttons .widgets-action button:disabled {
    opacity: .7
}

.appointment_widgets-md .appointment_widgets--booking .form-builder--wrap {
    max-width: initial
}

.appointment_widgets-md .appointment_widgets--booking .form-builder--wrap .menu-field-wrap.calendar_notes,
.appointment_widgets-md .appointment_widgets--booking .form-builder--wrap .payment-block {
    max-width: 100%;
    flex: 0 0 100%
}

.appointment_widgets-md .appointment_widgets--booking .form-builder--wrap textarea[name=calendar_notes] {
    resize: none;
    height: 5rem
}

.appointment_widgets-md .appointment_widgets--booking .form-builder--wrap .form-builder--btn-submit {
    display: block;
    display: none
}

.appointment_widgets-md .appointment_widgets--booking .form-builder--wrap .form-builder--btn-submit>div,
.appointment_widgets-md .appointment_widgets--booking .form-builder--wrap .form-builder--btn-submit button {
    width: 80% !important
}

.appointment_widgets-md .appointment_widgets--booking .form-builder--wrap .form-builder--btn-submit>div,
.appointment_widgets-md .appointment_widgets--booking .form-builder--wrap .form-builder--btn-submit button {
    width: auto !important
}

.appointment_widgets-md .appointment_widgets--booking.appointment_widgets--confirmation {
    width: 90%;
    max-width: 60rem;
    margin: 2rem auto;
    display: flex;
    align-items: center
}

.appointment_widgets-md .appointment_widgets--booking.appointment_widgets--confirmation .widgets-confirmation-icon,
.appointment_widgets-md .appointment_widgets--booking.appointment_widgets--confirmation .confirmation-message,
.appointment_widgets-md .appointment_widgets--booking.appointment_widgets--confirmation .confirmation-invite-text {
    text-align: center
}

.appointment_widgets-md .appointment_widgets--booking.appointment_widgets--confirmation .widgets-confirmation-icon {
    margin-bottom: 2rem
}

.appointment_widgets-md .appointment_widgets--booking.appointment_widgets--confirmation .confirmation-message {
    margin-bottom: 1.5rem !important;
    font-weight: 700
}

.appointment_widgets-md .appointment_widgets--booking.appointment_widgets--confirmation .confirmation-invite-text {
    margin-bottom: 3rem
}

.appointment_widgets-md .appointment_widgets--booking.appointment_widgets--confirmation .confirmation-invite-text a {
    color: var(--appointment_widgets-primary-color);
    display: block;
    font-weight: 700
}

.appointment_widgets-md .appointment_widgets--booking.appointment_widgets--confirmation .confirmation-details {
    border: 1px solid var(--appointment_widgets-border-color)
}

.appointment_widgets-md .appointment_widgets--booking.appointment_widgets--confirmation .hl_events-buttons {
    margin-top: 3rem;
    width: 100%;
    justify-content: center
}

.appointment_widgets-md .appointment_widgets--booking.appointment_widgets--confirmation .hl_events-buttons .calendar-button {
    margin-right: 0;
    margin-right: 1rem
}

.appointment_widgets-md .appointment_widgets--booking.appointment_widgets--confirmation .hl_events-buttons .calendar-button:last-child {
    margin-right: 0
}

.appointment_widgets-md .appointment_widgets--booking-info {
    padding-bottom: .8rem
}

.appointment_widgets-md .appointment_widgets--booking-info:not(.--horizontal) {
    border-bottom: 1px solid var(--appointment_widgets-border-color)
}

.appointment_widgets-md .appointment_widgets--booking-info>div {
    padding: .5rem 0;
    display: flex
}

.appointment_widgets-md .appointment_widgets--booking-info>div .booking-info-label {
    display: none
}

.appointment_widgets-md .appointment_widgets--booking-info>div.booking-info--location,
.appointment_widgets-md .appointment_widgets--booking-info>div.booking-info--timezone {
    display: none
}

.appointment_widgets-md .appointment_widgets--booking-info>div .booking-info-value {
    display: inline-block;
    margin-left: 1rem
}

.appointment_widgets-md .appointment_widgets--booking-info.--horizontal {
    border: 1px solid var(--appointment_widgets-border-color);
    border-radius: 5px
}

.appointment_widgets-md .appointment_widgets--booking-info.--horizontal>div {
    padding: 1rem
}

.appointment_widgets-md .appointment_widgets--booking-info.--horizontal>div.booking-info--location,
.appointment_widgets-md .appointment_widgets--booking-info.--horizontal>div.booking-info--timezone {
    display: flex
}

.appointment_widgets-md .appointment_widgets--booking-info.--horizontal>div.booking-info--timezone {
    padding-bottom: 0
}

.appointment_widgets-md .appointment_widgets--booking-info label {
    color: var(--appointment_widgets-label-text-color);
    display: flex;
    align-items: center;
    margin-bottom: 0
}

.appointment_widgets-md .appointment_widgets--booking-info label span {
    padding-left: .5rem
}

.appointment_widgets-md .appointment_widgets--booking-info .booking-info-value {
    color: var(--appointment_widgets-black-text-color);
    font-weight: 700
}

.appointment_widgets-sm .appointment_widgets--booking {
    display: flex;
    flex-direction: column-reverse
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--container {
    flex: 1;
    height: 100%
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--container.v1 .appointment_widgets--steps {
    padding: 1.8rem 3.5rem
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--container.v1 .widgets-date-block {
    display: flex;
    justify-content: space-between
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--container.v1 .widgets-date-block .widgets-time-slots {
    width: 35rem
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--container.v1 .vdpCell {
    padding: 1rem 0
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--container.v1 .widgets-time-slots {
    width: 12rem
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--info {
    border-right: 1px solid var(--appointment_widgets-border-color);
    flex-direction: column;
    justify-content: space-between;
    display: flex;
    padding: 1rem;
    width: 100%
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--info .appointment_widgets--service-info {
    color: var(--appointment_widgets-black-text-color)
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--info .appointment_widgets--service-info .provider-branding {
    display: none;
    align-items: center;
    margin-bottom: 1rem
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--info .appointment_widgets--service-info .branding--logo {
    margin-right: 1rem
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--info .appointment_widgets--service-info .provider-name {
    font-size: 1rem;
    font-weight: 400
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--info .appointment_widgets--service-info .widgets--service-name {
    color: #222;
    font-weight: 700;
    font-size: 1.7rem
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--info .appointment_widgets--service-info .widgets--service-description {
    margin-top: 1rem;
    color: var(--appointment_widgets-gray-text-color);
    opacity: 1;
    transition: all ease .1s
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--info .appointment_widgets--service-info .widgets--service-description .pointer {
    font-weight: 700;
    cursor: pointer;
    color: var(--appointment_widgets-primary-color)
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--info .appointment_widgets--service-info .widgets--service-description.show-more::-webkit-scrollbar {
    width: 5px;
    position: absolute;
    top: 0;
    right: 0;
    border-radius: 4px;
    background: #ffffff;
    opacity: 0;
    cursor: default;
    outline: none;
    z-index: 1;
    will-change: transform
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--info .appointment_widgets--service-info .widgets--service-description.show-more::-webkit-scrollbar-thumb {
    background: var(--appointment_widgets-gray-text-color);
    border-radius: 10px;
    padding: 2px
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps {
    position: relative;
    padding: 0 1rem
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps.selected-date {
    width: 100%
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps.selected-date .widgets-date-block {
    display: none
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps.step-form {
    padding: 0
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps h4.text-info {
    font-size: 1.2rem;
    font-weight: 700;
    padding: 0 1rem;
    color: var(--appointment_widgets-gray-text-color)
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .appointment-error {
    padding: 1rem 1rem 0
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .label-select-date {
    font-size: .8rem;
    font-weight: 700;
    color: var(--appointment_widgets-gray-text-color);
    margin-bottom: 1rem
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block {
    margin-top: 1rem;
    display: flex;
    position: relative;
    flex-direction: column-reverse;
    justify-content: space-between
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .date-picker-calendar {
    margin-top: 1rem
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .datepick-info {
    position: absolute;
    top: 7rem;
    left: 0;
    height: 100%;
    width: 100%;
    z-index: 5;
    background: rgba(255, 255, 255, .17);
    -webkit-backdrop-filter: blur(3px);
    backdrop-filter: blur(3px);
    justify-content: center;
    align-items: center;
    display: flex
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .datepick-info>div {
    color: var(--appointment_widgets-gray-text-color);
    padding: 1.5rem 4rem;
    background: rgba(255, 255, 255, .55);
    border: 1px solid #d2d2d2;
    box-sizing: border-box;
    border-radius: 10px;
    text-align: center
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .datepick-info>div a {
    background: var(--appointment_widgets-primary-color);
    opacity: .8;
    cursor: pointer;
    color: #fff;
    padding: .3rem 1rem;
    border-radius: 17px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 1rem
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .datepick-info>div a svg {
    fill: #fff;
    margin-left: .5rem
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpInnerWrap {
    box-shadow: none;
    padding: 0
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpInnerWrap .vdpHeader {
    display: flex;
    margin: 0;
    padding-left: 0;
    padding-right: 0;
    flex-direction: row-reverse;
    justify-content: space-between;
    align-items: center
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpInnerWrap .vdpHeader .arrowPrevious,
.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpInnerWrap .vdpHeader .arrowNext {
    background: none;
    color: inherit;
    border: none;
    padding: 0;
    font: inherit;
    cursor: pointer;
    outline: inherit
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpInnerWrap .vdpHeader .arrowPrevious {
    margin-right: 2rem
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpInnerWrap .vdpPeriodControls {
    text-align: left
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpInnerWrap .vdpHeadCellContent {
    font-weight: 700
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpInnerWrap .vdpPeriodControl button {
    font-weight: 700;
    padding: 0
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpHeadCell {
    text-align: left
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpCell {
    border-radius: 25%;
    text-align: left;
    cursor: auto
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpCell:hover .vdpCellContent {
    background: #ffffff
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpCell.today .vdpCellContent:after {
    content: ".";
    position: absolute;
    bottom: -5px;
    left: 0;
    right: 0;
    font-size: 30px;
    line-height: 30px;
    color: var(--appointment_widgets-primary-color)
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpCell.selectable .vdpCellContent:hover,
.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpCell.selectable.selected .vdpCellContent {
    background: var(--appointment_widgets-primary-color);
    color: #fff !important
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpCell.selectable.selected.today .vdpCellContent:after {
    content: ""
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpCell .vdpCellContent {
    position: relative;
    border: 1px solid #d6d6d6;
    width: 55px;
    height: 55px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--appointment_widgets-primary-color);
    cursor: pointer;
    margin: 0
}

@media (max-width: 480px) {
    .appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .widgets-date-block .vdpCell .vdpCellContent {
        width: 35px;
        height: 35px
    }
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .widgets-slot-block {
    width: 100%
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .widgets-slot-block .widgets-time-slots {
    -webkit-padding-start: 0;
    padding-inline-start: 0;
    list-style: none;
    -webkit-margin-before: 0;
    margin-block-start: 0;
    -webkit-margin-after: 0;
    margin-block-end: 0;
    padding: 0;
    padding-right: .5rem;
    padding-bottom: .5rem;
    overflow: hidden
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .widgets-slot-block .widgets-time-slots::-webkit-scrollbar {
    width: 5px;
    position: absolute;
    top: 0;
    left: 0;
    border-radius: 4px;
    background: #ffffff;
    opacity: 0;
    cursor: default;
    outline: none;
    z-index: 1;
    will-change: transform
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .widgets-slot-block .widgets-time-slots::-webkit-scrollbar-thumb {
    background: var(--appointment_widgets-gray-text-color);
    border-radius: 10px;
    padding: 2px
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .widgets-slot-block .widgets-time-slots .widgets-time-slot {
    position: relative
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .widgets-slot-block .widgets-time-slots .widgets-time-slot:not(:last-child) {
    margin-bottom: .5rem
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .widgets-slot-block .widgets-time-slots .widgets-time-slot>span {
    display: block;
    padding: .5rem;
    text-align: center;
    border: 1px solid #d6d6d6;
    box-sizing: border-box;
    border-radius: 6px;
    color: var(--appointment_widgets-primary-color);
    font-weight: 700;
    cursor: pointer;
    transition: ease all .3s;
    width: 100%
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .widgets-slot-block .widgets-time-slots .widgets-time-slot>span:hover {
    border-color: var(--appointment_widgets-primary-color)
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .widgets-slot-block .widgets-time-slots .widgets-time-slot button {
    transform: translate(100%);
    transition: transform .3s ease;
    visibility: hidden;
    position: absolute;
    right: 0
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .widgets-slot-block .widgets-time-slots .widgets-time-slot.actived {
    display: flex
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .widgets-slot-block .widgets-time-slots .widgets-time-slot.actived>span {
    border: none;
    text-align: center;
    border: 1px solid #d6d6d6;
    box-sizing: border-box;
    border-radius: 6px;
    color: var(--appointment_widgets-primary-color);
    font-weight: 700;
    cursor: pointer;
    width: calc(60% - 1rem)
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .widgets-slot-block .widgets-time-slots .widgets-time-slot.actived button {
    visibility: visible;
    transform: translate(0);
    z-index: 2;
    width: 40%;
    margin-left: 1rem;
    padding: .5rem 1rem;
    font-size: .8rem;
    background: var(--appointment_widgets-primary-color);
    color: #fff;
    border-color: var(--appointment_widgets-primary-color);
    border-style: solid
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .widgets-timezone-picker {
    background: #f3f8fb;
    color: #525252;
    width: 100%;
    margin-bottom: 0
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .widgets-timezone-picker .multiselect__single,
.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .widgets-timezone-picker .multiselect__input {
    background: #f3f8fb !important;
    color: #525252
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .widgets-timezone-picker .multiselect__single {
    display: flex;
    align-items: center
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .widgets-timezone-picker .multiselect__single svg {
    margin-right: 10px
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .widgets-timezone-picker .multiselect__content-wrapper {
    padding: 0;
    left: 0;
    transform: none;
    -webkit-transform: none;
    width: 100%
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .widgets-timezone-picker .multiselect__option {
    color: var(--appointment_widgets-gray-text-color)
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .widgets-timezone-picker .multiselect__option--highlight {
    background: var(--appointment_widgets-primary-color) !important;
    color: #fff
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .widgets-timezone-picker .option__desc {
    display: flex;
    padding: .2rem 0
}

.appointment_widgets-sm .appointment_widgets--booking .appointment_widgets--steps .widgets-timezone-picker .option__desc .option__title {
    flex: 1
}

.appointment_widgets-sm .appointment_widgets--booking .widgets-action-buttons>div {
    display: flex;
    align-items: center;
    padding: 1rem;
    border-bottom: 1px solid var(--appointment_widgets-border-color)
}

.appointment_widgets-sm .appointment_widgets--booking .widgets-action-buttons>div:first-child {
    flex: 0 0 33.33333%;
    max-width: 33.33333%
}

.appointment_widgets-sm .appointment_widgets--booking .widgets-action-buttons .action-back-link {
    display: flex;
    align-items: center;
    color: var(--appointment_widgets-primary-color);
    cursor: pointer;
    font-weight: 700
}

.appointment_widgets-sm .appointment_widgets--booking .widgets-action-buttons .action-back-link:disabled {
    opacity: .7
}

.appointment_widgets-sm .appointment_widgets--booking .widgets-action-buttons .action-back-link svg {
    height: .8rem;
    margin-right: .3rem
}

.appointment_widgets-sm .appointment_widgets--booking .widgets-action-buttons .widgets-action {
    justify-content: flex-end;
    flex: 0 0 66.666667%;
    max-width: 66.666667%
}

.appointment_widgets-sm .appointment_widgets--booking .widgets-action-buttons .widgets-action button {
    padding: .3rem 2.5rem;
    border-radius: 5px;
    background: var(--appointment_widgets-primary-color);
    border: none;
    color: #fff
}

.appointment_widgets-sm .appointment_widgets--booking .widgets-action-buttons .widgets-action button:disabled {
    opacity: .7
}

.appointment_widgets-sm .appointment_widgets--booking .widgets-action-buttons .widgets-action button.btn-schedule {
    display: none
}

.appointment_widgets-sm .appointment_widgets--booking .form-builder--wrap {
    max-width: initial
}

.appointment_widgets-sm .appointment_widgets--booking .form-builder--wrap .menu-field-wrap.calendar_notes,
.appointment_widgets-sm .appointment_widgets--booking .form-builder--wrap .payment-block {
    max-width: 100%;
    flex: 0 0 100%
}

.appointment_widgets-sm .appointment_widgets--booking .form-builder--wrap textarea[name=calendar_notes] {
    resize: none;
    height: 5rem
}

.appointment_widgets-sm .appointment_widgets--booking .form-builder--wrap .form-builder--btn-submit {
    display: block
}

.appointment_widgets-sm .appointment_widgets--booking .form-builder--wrap .form-builder--btn-submit>div,
.appointment_widgets-sm .appointment_widgets--booking .form-builder--wrap .form-builder--btn-submit button {
    width: 80% !important
}

.appointment_widgets-sm .appointment_widgets--booking.appointment_widgets--confirmation {
    width: 90%;
    max-width: 60rem;
    margin: 2rem auto;
    display: flex;
    align-items: center
}

.appointment_widgets-sm .appointment_widgets--booking.appointment_widgets--confirmation .widgets-confirmation-icon,
.appointment_widgets-sm .appointment_widgets--booking.appointment_widgets--confirmation .confirmation-message,
.appointment_widgets-sm .appointment_widgets--booking.appointment_widgets--confirmation .confirmation-invite-text {
    text-align: center
}

.appointment_widgets-sm .appointment_widgets--booking.appointment_widgets--confirmation .widgets-confirmation-icon {
    margin-bottom: 2rem
}

.appointment_widgets-sm .appointment_widgets--booking.appointment_widgets--confirmation .confirmation-message {
    margin-bottom: 1.5rem !important;
    font-weight: 700
}

.appointment_widgets-sm .appointment_widgets--booking.appointment_widgets--confirmation .confirmation-invite-text {
    margin-bottom: 3rem
}

.appointment_widgets-sm .appointment_widgets--booking.appointment_widgets--confirmation .confirmation-invite-text a {
    color: var(--appointment_widgets-primary-color);
    display: block;
    font-weight: 700
}

.appointment_widgets-sm .appointment_widgets--booking.appointment_widgets--confirmation .confirmation-details {
    border: 1px solid var(--appointment_widgets-border-color)
}

.appointment_widgets-sm .appointment_widgets--booking.appointment_widgets--confirmation .hl_events-buttons {
    margin-top: 3rem;
    width: 100%;
    justify-content: center
}

.appointment_widgets-sm .appointment_widgets--booking.appointment_widgets--confirmation .hl_events-buttons .calendar-button {
    margin-right: 0
}

.appointment_widgets-sm .appointment_widgets--booking.appointment_widgets--confirmation .hl_events-buttons .calendar-button:last-child {
    margin-right: 0
}

.appointment_widgets-sm .appointment_widgets--booking-info {
    padding-bottom: .8rem
}

.appointment_widgets-sm .appointment_widgets--booking-info:not(.--horizontal) {
    border-bottom: 1px solid var(--appointment_widgets-border-color)
}

.appointment_widgets-sm .appointment_widgets--booking-info>div {
    padding: .5rem 0;
    display: flex
}

.appointment_widgets-sm .appointment_widgets--booking-info>div .booking-info-label {
    display: none
}

.appointment_widgets-sm .appointment_widgets--booking-info>div.booking-info--location,
.appointment_widgets-sm .appointment_widgets--booking-info>div.booking-info--timezone {
    display: none
}

.appointment_widgets-sm .appointment_widgets--booking-info>div .booking-info-value {
    display: inline-block;
    margin-left: 1rem
}

.appointment_widgets-sm .appointment_widgets--booking-info.--horizontal {
    border: 1px solid var(--appointment_widgets-border-color);
    border-radius: 5px
}

.appointment_widgets-sm .appointment_widgets--booking-info.--horizontal>div {
    padding: 1rem
}

.appointment_widgets-sm .appointment_widgets--booking-info.--horizontal>div.booking-info--location,
.appointment_widgets-sm .appointment_widgets--booking-info.--horizontal>div.booking-info--timezone {
    display: flex
}

.appointment_widgets-sm .appointment_widgets--booking-info label {
    color: var(--appointment_widgets-label-text-color);
    display: flex;
    align-items: center;
    margin-bottom: 0
}

.appointment_widgets-sm .appointment_widgets--booking-info label span {
    padding-left: .5rem
}

.appointment_widgets-sm .appointment_widgets--booking-info .booking-info-value {
    color: var(--appointment_widgets-black-text-color);
    font-weight: 700
}

.thank-you-message[data-v-e08795fa] {
    text-align: center
}

.signature-container {
    text-align: right;
    display: block !important
}

.signature-container canvas {
    height: 100%
}

.signature-container .clear-button {
    text-align: right;
    width: 100%
}

.padding-10 {
    padding: 10px
}

.mb-10 {
    margin-bottom: 10px
}

.mb-6 {
    margin-bottom: 6px
}

.form-builder--item .item-description {
    display: block
}

.form-builder--item .error {
    margin-top: 10px
}

@-webkit-keyframes vdpSlideFromLeft {
    0% {
        opacity: 0;
        transform: translate3d(-.5em, 0, 0)
    }

    to {
        opacity: 1;
        transform: translateZ(0)
    }
}

@keyframes vdpSlideFromLeft {
    0% {
        opacity: 0;
        transform: translate3d(-.5em, 0, 0)
    }

    to {
        opacity: 1;
        transform: translateZ(0)
    }
}

@-webkit-keyframes vdpSlideFromRight {
    0% {
        opacity: 0;
        transform: translate3d(.5em, 0, 0)
    }

    to {
        opacity: 1;
        transform: translateZ(0)
    }
}

@keyframes vdpSlideFromRight {
    0% {
        opacity: 0;
        transform: translate3d(.5em, 0, 0)
    }

    to {
        opacity: 1;
        transform: translateZ(0)
    }
}

@-webkit-keyframes vdpToggleCalendar {
    0% {
        opacity: 0;
        transform: scale(.5)
    }

    to {
        opacity: 1;
        transform: scale(1)
    }
}

@keyframes vdpToggleCalendar {
    0% {
        opacity: 0;
        transform: scale(.5)
    }

    to {
        opacity: 1;
        transform: scale(1)
    }
}

@-webkit-keyframes vdpFadeCalendar {
    0% {
        opacity: 0
    }

    to {
        opacity: 1
    }
}

@keyframes vdpFadeCalendar {
    0% {
        opacity: 0
    }

    to {
        opacity: 1
    }
}

.vdp-toggle-calendar-enter-active.vdpPositionReady {
    transform-origin: top left;
    -webkit-animation: vdpToggleCalendar .2s;
    animation: vdpToggleCalendar .2s
}

.vdp-toggle-calendar-leave-active {
    animation: vdpToggleCalendar .15s reverse
}

.vdp-toggle-calendar-enter-active.vdpPositionFixed {
    -webkit-animation: vdpFadeCalendar .3s;
    animation: vdpFadeCalendar .3s
}

.vdp-toggle-calendar-leave-active.vdpPositionFixed {
    animation: vdpFadeCalendar .3s reverse
}

.vdpComponent {
    position: relative;
    display: inline-block;
    font-size: 10px;
    color: #303030
}

.vdpComponent.vdpWithInput>input {
    padding-right: 30px
}

.vdpClearInput {
    font-size: 1em;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    width: 3em
}

.vdpClearInput:before {
    content: "\d7";
    width: 1.4em;
    height: 1.4em;
    line-height: 1.1em;
    box-sizing: border-box;
    position: absolute;
    left: 50%;
    top: 50%;
    margin: -.7em 0 0 -.7em;
    color: #0000004d;
    border: 1px solid rgba(0, 0, 0, .15);
    border-radius: 50%;
    background-color: #fff
}

.vdpClearInput:hover:before {
    box-shadow: 0 .2em .5em #00000026
}

.vdpOuterWrap.vdpFloating {
    position: absolute;
    padding: .5em 0;
    z-index: 220
}

.vdpOuterWrap.vdpPositionFixed {
    position: fixed;
    left: 0;
    top: 0;
    bottom: 0;
    right: 0;
    padding: 2em;
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: #0000004d
}

.vdpFloating .vdpInnerWrap {
    max-width: 30em
}

.vdpPositionFixed .vdpInnerWrap {
    max-width: 30em;
    margin: 0 auto;
    border: 0;
    -webkit-animation: vdpToggleCalendar .3s;
    animation: vdpToggleCalendar .3s
}

.vdpFloating.vdpPositionTop {
    top: 100%
}

.vdpFloating.vdpPositionBottom {
    bottom: 100%
}

.vdpFloating.vdpPositionLeft {
    left: 0
}

.vdpFloating.vdpPositionRight {
    right: 0
}

.vdpPositionTop.vdpPositionLeft {
    transform-origin: top left
}

.vdpPositionTop.vdpPositionRight {
    transform-origin: top right
}

.vdpPositionBottom.vdpPositionLeft {
    transform-origin: bottom left
}

.vdpPositionBottom.vdpPositionRight {
    transform-origin: bottom right
}

.vdpInnerWrap {
    overflow: hidden;
    min-width: 28em;
    box-sizing: border-box;
    padding: 1em;
    background: #fff;
    box-shadow: 0 .2em 1.5em #0000000f;
    border-radius: .5em;
    border: 1px solid rgba(0, 0, 0, .15)
}

.vdpHeader {
    position: relative;
    padding: 0 1em 2.5em;
    margin: -1em -1em -2.5em;
    text-align: center;
    background: #f5f5f5
}

.vdpClearInput,
.vdpArrow,
.vdpPeriodControl>button {
    margin: 0;
    padding: 0;
    border: 0;
    cursor: pointer;
    background: none
}

.vdpArrow::-moz-focus-inner,
.vdpClearInput::-moz-focus-inner,
.vdpPeriodControl>button::-moz-focus-inner {
    padding: 0;
    border: 0
}

.vdpArrow {
    font-size: 1em;
    width: 5em;
    text-indent: -999em;
    overflow: hidden;
    position: absolute;
    top: 0;
    bottom: 2.5em;
    text-align: left
}

.vdpArrow:before {
    content: "";
    width: 2.2em;
    height: 2.2em;
    position: absolute;
    left: 50%;
    top: 50%;
    margin: -1.1em 0 0 -1.1em;
    border-radius: 100%;
    transition: background-color .2s
}

.vdpArrow:hover,
.vdpArrow:focus,
.vdpArrow:active {
    outline: 0
}

.vdpArrow:hover:before,
.vdpArrow:focus:before {
    background-color: #00000008
}

.vdpArrow:active:before {
    background-color: #00000012
}

.vdpArrowNext:before {
    margin-left: -1.4em
}

.vdpArrow:after {
    content: "";
    position: absolute;
    left: 50%;
    top: 50%;
    margin-top: -.5em;
    width: 0;
    height: 0;
    border: .5em solid transparent
}

.vdpArrowNextDisable,
.vdpArrowPrevDisable {
    cursor: default !important
}

.vdpArrowNextDisable:after,
.vdpArrowNextDisable:after {
    border-left-color: #cecece !important;
    background-color: unset !important
}

.vdpArrowPrevDisable:after,
.vdpArrowPrevDisable:after {
    border-right-color: #cecece !important
}

.vdpArrowPrevDisable:hover:before,
.vdpArrowPrevDisable:focus:before,
.vdpArrowPrevDisable:active:before,
.vdpArrowNextDisable:hover:before,
.vdpArrowNextDisable:focus:before,
.vdpArrowNextDisable:active:before {
    background-color: unset
}

.vdpArrowPrev {
    left: -.3em
}

.vdpArrowPrev:after {
    margin-left: -.8em;
    border-right-color: #188bf6
}

.vdpArrowNext {
    right: -.6em
}

.vdpArrowNext:after {
    margin-left: -.5em;
    border-left-color: #188bf6
}

.vdpPeriodControl {
    display: inline-block;
    position: relative
}

.vdpPeriodControl>button {
    font-size: 1.5em;
    padding: 1em .4em;
    display: inline-block
}

.vdpPeriodControl>select {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    cursor: pointer;
    opacity: 0;
    font-size: 1.6em
}

.vdpTable {
    width: 100%;
    table-layout: fixed;
    position: relative;
    z-index: 5
}

.vdpNextDirection {
    -webkit-animation: vdpSlideFromRight .5s;
    animation: vdpSlideFromRight .5s
}

.vdpPrevDirection {
    -webkit-animation: vdpSlideFromLeft .5s;
    animation: vdpSlideFromLeft .5s
}

.vdpCell,
.vdpHeadCell {
    text-align: center;
    box-sizing: border-box
}

.vdpCell {
    padding: .5em 0
}

.vdpHeadCell {
    padding: .3em .4em 1.8em
}

.vdpHeadCellContent {
    font-size: 1.3em;
    font-weight: 400;
    color: #848484
}

.vdpCellContent {
    font-size: 1.4em;
    display: block;
    margin: 0 auto;
    width: 1.857em;
    height: 1.857em;
    line-height: 1.857em;
    text-align: center;
    border-radius: 100%;
    transition: background .1s, color .1s
}

.vdpPeriodControlDisable {
    pointer-events: none
}

.vdpPeriodControlDisable,
.vdpPeriodControl>button {
    cursor: default
}

.vdpCell.outOfRange {
    color: #c7c7c7
}

.vdpCell.today {
    color: #188bf6
}

.vdpCell.selected .vdpCellContent {
    color: #fff;
    background: rgba(46, 145, 252, .7)
}

@media (hover: hover) {
    .vdpCell.selectable:hover .vdpCellContent {
        color: #fff;
        background: rgba(46, 145, 252, .7)
    }
}

.vdpCell.selectable {
    cursor: pointer
}

.vdpCell.disabled {
    opacity: .5
}

.vdpTimeControls {
    padding: 1.2em 2em;
    position: relative;
    margin: 1em -1em -1em;
    text-align: center;
    background: #f5f5f5
}

.vdpTimeUnit {
    display: inline-block;
    position: relative;
    vertical-align: middle
}

.vdpTimeUnit>pre,
.vdpTimeUnit>input {
    font-size: 1.7em;
    line-height: 1.3;
    padding: .1em;
    word-wrap: break-word;
    white-space: pre-wrap;
    resize: none;
    margin: 0;
    box-sizing: border-box;
    color: #000;
    border: 0;
    border-bottom: 1px solid transparent;
    text-align: center
}

.vdpTimeUnit>pre {
    visibility: hidden;
    font-family: inherit
}

.vdpTimeUnit>input {
    position: absolute;
    top: 0;
    left: 0;
    overflow: hidden;
    height: 100%;
    width: 100%;
    outline: none;
    padding: 0;
    border-radius: 0;
    background: transparent;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none
}

.vdpTimeUnit>input:hover,
.vdpTimeUnit>input:focus {
    border-bottom-color: #188bf6
}

.vdpTimeUnit>input::-webkit-inner-spin-button,
.vdpTimeUnit>input::-webkit-outer-spin-button {
    margin: 0;
    -webkit-appearance: none
}

.vdpTimeSeparator,
.vdpTimeCaption {
    display: inline-block;
    vertical-align: middle;
    font-size: 1.3em;
    color: #848484
}

.vdpTimeCaption {
    margin-right: .5em
}

.vdpCell .vdpCellContent {
    display: inline-block;
    padding: 0 5px;
    width: 100%;
    height: 35px;
    line-height: 35px;
    text-align: center;
    vertical-align: middle;
    border: 1px solid transparent
}

.vdpPeriodControl {
    margin-right: 5px
}

.form-builder--item .item-description {
    display: block
}

.form-builder--item .error {
    margin-top: 10px
}

fieldset[disabled] .multiselect {
    pointer-events: none
}

.multiselect__spinner {
    position: absolute;
    right: 1px;
    top: 1px;
    width: 48px;
    height: 35px;
    background: #fff;
    display: block
}

.multiselect__spinner:after,
.multiselect__spinner:before {
    position: absolute;
    content: "";
    top: 50%;
    left: 50%;
    margin: -8px 0 0 -8px;
    width: 16px;
    height: 16px;
    border-radius: 100%;
    border-color: #41b883 transparent transparent;
    border-style: solid;
    border-width: 2px;
    box-shadow: 0 0 0 1px transparent
}

.multiselect__spinner:before {
    -webkit-animation: spinning 2.4s cubic-bezier(.41, .26, .2, .62);
    animation: spinning 2.4s cubic-bezier(.41, .26, .2, .62);
    -webkit-animation-iteration-count: infinite;
    animation-iteration-count: infinite
}

.multiselect__spinner:after {
    -webkit-animation: spinning 2.4s cubic-bezier(.51, .09, .21, .8);
    animation: spinning 2.4s cubic-bezier(.51, .09, .21, .8);
    -webkit-animation-iteration-count: infinite;
    animation-iteration-count: infinite
}

.multiselect__loading-enter-active,
.multiselect__loading-leave-active {
    transition: opacity .4s ease-in-out;
    opacity: 1
}

.multiselect__loading-enter,
.multiselect__loading-leave-active {
    opacity: 0
}

.multiselect,
.multiselect__input,
.multiselect__single {
    font-family: inherit;
    font-size: 16px;
    touch-action: manipulation
}

.multiselect {
    box-sizing: content-box;
    display: block;
    position: relative;
    width: 100%;
    min-height: 40px;
    text-align: left;
    color: #35495e
}

.multiselect * {
    box-sizing: border-box
}

.multiselect:focus {
    outline: none
}

.multiselect--disabled {
    background: #ededed;
    pointer-events: none;
    opacity: .6
}

.multiselect--active {
    z-index: 50
}

.multiselect--active:not(.multiselect--above) .multiselect__current,
.multiselect--active:not(.multiselect--above) .multiselect__input,
.multiselect--active:not(.multiselect--above) .multiselect__tags {
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0
}

.multiselect--active .multiselect__select {
    transform: rotate(180deg)
}

.multiselect--above.multiselect--active .multiselect__current,
.multiselect--above.multiselect--active .multiselect__input,
.multiselect--above.multiselect--active .multiselect__tags {
    border-top-left-radius: 0;
    border-top-right-radius: 0
}

.multiselect__input,
.multiselect__single {
    position: relative;
    display: inline-block;
    min-height: 20px;
    line-height: 20px;
    border: none;
    border-radius: 5px;
    background: #fff;
    padding: 0 0 0 5px;
    width: 100%;
    transition: border .1s ease;
    box-sizing: border-box;
    margin-bottom: 8px;
    vertical-align: top
}

.multiselect__input::-moz-placeholder {
    color: #35495e
}

.multiselect__input:-ms-input-placeholder {
    color: #35495e
}

.multiselect__input::placeholder {
    color: #35495e
}

.multiselect__tag~.multiselect__input,
.multiselect__tag~.multiselect__single {
    width: auto
}

.multiselect__input:hover,
.multiselect__single:hover {
    border-color: #cfcfcf
}

.multiselect__input:focus,
.multiselect__single:focus {
    border-color: #a8a8a8;
    outline: none
}

.multiselect__single {
    padding-left: 5px;
    margin-bottom: 8px
}

.multiselect__tags-wrap {
    display: inline
}

.multiselect__tags {
    min-height: 40px;
    display: block;
    padding: 8px 40px 0 8px;
    border-radius: 5px;
    border: 1px solid #e8e8e8;
    background: #fff;
    font-size: 14px
}

.multiselect__tag {
    position: relative;
    display: inline-block;
    padding: 4px 26px 4px 10px;
    border-radius: 5px;
    margin-right: 10px;
    color: #fff;
    line-height: 1;
    background: #41b883;
    margin-bottom: 5px;
    white-space: nowrap;
    overflow: hidden;
    max-width: 100%;
    text-overflow: ellipsis
}

.multiselect__tag-icon {
    cursor: pointer;
    margin-left: 7px;
    position: absolute;
    right: 0;
    top: 0;
    bottom: 0;
    font-weight: 700;
    font-style: normal;
    width: 22px;
    text-align: center;
    line-height: 22px;
    transition: all .2s ease;
    border-radius: 5px
}

.multiselect__tag-icon:after {
    content: "\d7";
    color: #266d4d;
    font-size: 14px
}

.multiselect__tag-icon:focus:after,
.multiselect__tag-icon:hover:after {
    color: #fff
}

.multiselect__current {
    min-height: 40px;
    overflow: hidden;
    padding: 8px 30px 0 12px;
    white-space: nowrap;
    border-radius: 5px;
    border: 1px solid #e8e8e8
}

.multiselect__current,
.multiselect__select {
    line-height: 16px;
    box-sizing: border-box;
    display: block;
    margin: 0;
    text-decoration: none;
    cursor: pointer
}

.multiselect__select {
    position: absolute;
    width: 40px;
    height: 38px;
    right: 1px;
    top: 1px;
    padding: 4px 8px;
    text-align: center;
    transition: transform .2s ease
}

.multiselect__select:before {
    position: relative;
    right: 0;
    top: 65%;
    color: #999;
    margin-top: 4px;
    border-style: solid;
    border-width: 5px 5px 0 5px;
    border-color: #999 transparent transparent transparent;
    content: ""
}

.multiselect__placeholder {
    color: #adadad;
    display: inline-block;
    margin-bottom: 10px;
    padding-top: 2px
}

.multiselect--active .multiselect__placeholder {
    display: none
}

.multiselect__content-wrapper {
    position: absolute;
    display: block;
    background: #fff;
    width: 100%;
    max-height: 240px;
    overflow: auto;
    border: 1px solid #e8e8e8;
    border-top: none;
    border-bottom-left-radius: 5px;
    border-bottom-right-radius: 5px;
    z-index: 50;
    -webkit-overflow-scrolling: touch
}

.multiselect__content {
    list-style: none;
    display: inline-block;
    padding: 0;
    margin: 0;
    min-width: 100%;
    vertical-align: top
}

.multiselect--above .multiselect__content-wrapper {
    bottom: 100%;
    border-radius: 5px 5px 0 0;
    border-bottom: none;
    border-top: 1px solid #e8e8e8
}

.multiselect__content::-webkit-scrollbar {
    display: none
}

.multiselect__element {
    display: block
}

.multiselect__option {
    display: block;
    padding: 12px;
    min-height: 40px;
    line-height: 16px;
    text-decoration: none;
    text-transform: none;
    vertical-align: middle;
    position: relative;
    cursor: pointer;
    white-space: nowrap
}

.multiselect__option:after {
    top: 0;
    right: 0;
    position: absolute;
    line-height: 40px;
    padding-right: 12px;
    padding-left: 20px;
    font-size: 13px
}

.multiselect__option--highlight {
    background: #41b883;
    outline: none;
    color: #fff
}

.multiselect__option--highlight:after {
    content: attr(data-select);
    background: #41b883;
    color: #fff
}

.multiselect__option--selected {
    background: #f3f3f3;
    color: #35495e;
    font-weight: 700
}

.multiselect__option--selected:after {
    content: attr(data-selected);
    color: silver
}

.multiselect__option--selected.multiselect__option--highlight {
    background: #ff6a6a;
    color: #fff
}

.multiselect__option--selected.multiselect__option--highlight:after {
    background: #ff6a6a;
    content: attr(data-deselect);
    color: #fff
}

.multiselect--disabled .multiselect__current,
.multiselect--disabled .multiselect__select {
    background: #ededed;
    color: #a6a6a6
}

.multiselect__option--disabled {
    background: #ededed !important;
    color: #a6a6a6 !important;
    cursor: text;
    pointer-events: none
}

.multiselect__option--group {
    background: #ededed;
    color: #35495e
}

.multiselect__option--group.multiselect__option--highlight {
    background: #35495e;
    color: #fff
}

.multiselect__option--group.multiselect__option--highlight:after {
    background: #35495e
}

.multiselect__option--disabled.multiselect__option--highlight {
    background: #dedede
}

.multiselect__option--group-selected.multiselect__option--highlight {
    background: #ff6a6a;
    color: #fff
}

.multiselect__option--group-selected.multiselect__option--highlight:after {
    background: #ff6a6a;
    content: attr(data-deselect);
    color: #fff
}

.multiselect-enter-active,
.multiselect-leave-active {
    transition: all .15s ease
}

.multiselect-enter,
.multiselect-leave-active {
    opacity: 0
}

.multiselect__strong {
    margin-bottom: 8px;
    line-height: 20px;
    display: inline-block;
    vertical-align: top
}

[dir=rtl] .multiselect {
    text-align: right
}

[dir=rtl] .multiselect__select {
    right: auto;
    left: 1px
}

[dir=rtl] .multiselect__tags {
    padding: 8px 8px 0 40px
}

[dir=rtl] .multiselect__content {
    text-align: right
}

[dir=rtl] .multiselect__option:after {
    right: auto;
    left: 0
}

[dir=rtl] .multiselect__clear {
    right: auto;
    left: 12px
}

[dir=rtl] .multiselect__spinner {
    right: auto;
    left: 1px
}

@-webkit-keyframes spinning {
    0% {
        transform: rotate(0)
    }

    to {
        transform: rotate(2turn)
    }
}

@keyframes spinning {
    0% {
        transform: rotate(0)
    }

    to {
        transform: rotate(2turn)
    }
}

.form-builder--item .item-description {
    display: block
}

.form-builder--item .error {
    margin-top: 10px
}

fieldset[disabled] .multiselect {
    pointer-events: none
}

.multiselect__spinner {
    position: absolute;
    right: 1px;
    top: 1px;
    width: 48px;
    height: 35px;
    background: #fff;
    display: block
}

.multiselect__spinner:after,
.multiselect__spinner:before {
    position: absolute;
    content: "";
    top: 50%;
    left: 50%;
    margin: -8px 0 0 -8px;
    width: 16px;
    height: 16px;
    border-radius: 100%;
    border-color: #41b883 transparent transparent;
    border-style: solid;
    border-width: 2px;
    box-shadow: 0 0 0 1px transparent
}

.multiselect__spinner:before {
    -webkit-animation: spinning 2.4s cubic-bezier(.41, .26, .2, .62);
    animation: spinning 2.4s cubic-bezier(.41, .26, .2, .62);
    -webkit-animation-iteration-count: infinite;
    animation-iteration-count: infinite
}

.multiselect__spinner:after {
    -webkit-animation: spinning 2.4s cubic-bezier(.51, .09, .21, .8);
    animation: spinning 2.4s cubic-bezier(.51, .09, .21, .8);
    -webkit-animation-iteration-count: infinite;
    animation-iteration-count: infinite
}

.multiselect__loading-enter-active,
.multiselect__loading-leave-active {
    transition: opacity .4s ease-in-out;
    opacity: 1
}

.multiselect__loading-enter,
.multiselect__loading-leave-active {
    opacity: 0
}

.multiselect,
.multiselect__input,
.multiselect__single {
    font-family: inherit;
    font-size: 16px;
    touch-action: manipulation
}

.multiselect {
    box-sizing: content-box;
    display: block;
    position: relative;
    width: 100%;
    min-height: 40px;
    text-align: left;
    color: #35495e
}

.multiselect * {
    box-sizing: border-box
}

.multiselect:focus {
    outline: none
}

.multiselect--disabled {
    background: #ededed;
    pointer-events: none;
    opacity: .6
}

.multiselect--active {
    z-index: 50
}

.multiselect--active:not(.multiselect--above) .multiselect__current,
.multiselect--active:not(.multiselect--above) .multiselect__input,
.multiselect--active:not(.multiselect--above) .multiselect__tags {
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0
}

.multiselect--active .multiselect__select {
    transform: rotate(180deg)
}

.multiselect--above.multiselect--active .multiselect__current,
.multiselect--above.multiselect--active .multiselect__input,
.multiselect--above.multiselect--active .multiselect__tags {
    border-top-left-radius: 0;
    border-top-right-radius: 0
}

.multiselect__input,
.multiselect__single {
    position: relative;
    display: inline-block;
    min-height: 20px;
    line-height: 20px;
    border: none;
    border-radius: 5px;
    background: #fff;
    padding: 0 0 0 5px;
    width: 100%;
    transition: border .1s ease;
    box-sizing: border-box;
    margin-bottom: 8px;
    vertical-align: top
}

.multiselect__input::-moz-placeholder {
    color: #35495e
}

.multiselect__input:-ms-input-placeholder {
    color: #35495e
}

.multiselect__input::placeholder {
    color: #35495e
}

.multiselect__tag~.multiselect__input,
.multiselect__tag~.multiselect__single {
    width: auto
}

.multiselect__input:hover,
.multiselect__single:hover {
    border-color: #cfcfcf
}

.multiselect__input:focus,
.multiselect__single:focus {
    border-color: #a8a8a8;
    outline: none
}

.multiselect__single {
    padding-left: 5px;
    margin-bottom: 8px
}

.multiselect__tags-wrap {
    display: inline
}

.multiselect__tags {
    min-height: 40px;
    display: block;
    padding: 8px 40px 0 8px;
    border-radius: 5px;
    border: 1px solid #e8e8e8;
    background: #fff;
    font-size: 14px
}

.multiselect__tag {
    position: relative;
    display: inline-block;
    padding: 4px 26px 4px 10px;
    border-radius: 5px;
    margin-right: 10px;
    color: #fff;
    line-height: 1;
    background: #41b883;
    margin-bottom: 5px;
    white-space: nowrap;
    overflow: hidden;
    max-width: 100%;
    text-overflow: ellipsis
}

.multiselect__tag-icon {
    cursor: pointer;
    margin-left: 7px;
    position: absolute;
    right: 0;
    top: 0;
    bottom: 0;
    font-weight: 700;
    font-style: normal;
    width: 22px;
    text-align: center;
    line-height: 22px;
    transition: all .2s ease;
    border-radius: 5px
}

.multiselect__tag-icon:after {
    content: "\d7";
    color: #266d4d;
    font-size: 14px
}

.multiselect__tag-icon:focus:after,
.multiselect__tag-icon:hover:after {
    color: #fff
}

.multiselect__current {
    min-height: 40px;
    overflow: hidden;
    padding: 8px 30px 0 12px;
    white-space: nowrap;
    border-radius: 5px;
    border: 1px solid #e8e8e8
}

.multiselect__current,
.multiselect__select {
    line-height: 16px;
    box-sizing: border-box;
    display: block;
    margin: 0;
    text-decoration: none;
    cursor: pointer
}

.multiselect__select {
    position: absolute;
    width: 40px;
    height: 38px;
    right: 1px;
    top: 1px;
    padding: 4px 8px;
    text-align: center;
    transition: transform .2s ease
}

.multiselect__select:before {
    position: relative;
    right: 0;
    top: 65%;
    color: #999;
    margin-top: 4px;
    border-style: solid;
    border-width: 5px 5px 0 5px;
    border-color: #999 transparent transparent transparent;
    content: ""
}

.multiselect__placeholder {
    color: #adadad;
    display: inline-block;
    margin-bottom: 10px;
    padding-top: 2px
}

.multiselect--active .multiselect__placeholder {
    display: none
}

.multiselect__content-wrapper {
    position: absolute;
    display: block;
    background: #fff;
    width: 100%;
    max-height: 240px;
    overflow: auto;
    border: 1px solid #e8e8e8;
    border-top: none;
    border-bottom-left-radius: 5px;
    border-bottom-right-radius: 5px;
    z-index: 50;
    -webkit-overflow-scrolling: touch
}

.multiselect__content {
    list-style: none;
    display: inline-block;
    padding: 0;
    margin: 0;
    min-width: 100%;
    vertical-align: top
}

.multiselect--above .multiselect__content-wrapper {
    bottom: 100%;
    border-radius: 5px 5px 0 0;
    border-bottom: none;
    border-top: 1px solid #e8e8e8
}

.multiselect__content::-webkit-scrollbar {
    display: none
}

.multiselect__element {
    display: block
}

.multiselect__option {
    display: block;
    padding: 12px;
    min-height: 40px;
    line-height: 16px;
    text-decoration: none;
    text-transform: none;
    vertical-align: middle;
    position: relative;
    cursor: pointer;
    white-space: nowrap
}

.multiselect__option:after {
    top: 0;
    right: 0;
    position: absolute;
    line-height: 40px;
    padding-right: 12px;
    padding-left: 20px;
    font-size: 13px
}

.multiselect__option--highlight {
    background: #41b883;
    outline: none;
    color: #fff
}

.multiselect__option--highlight:after {
    content: attr(data-select);
    background: #41b883;
    color: #fff
}

.multiselect__option--selected {
    background: #f3f3f3;
    color: #35495e;
    font-weight: 700
}

.multiselect__option--selected:after {
    content: attr(data-selected);
    color: silver
}

.multiselect__option--selected.multiselect__option--highlight {
    background: #ff6a6a;
    color: #fff
}

.multiselect__option--selected.multiselect__option--highlight:after {
    background: #ff6a6a;
    content: attr(data-deselect);
    color: #fff
}

.multiselect--disabled .multiselect__current,
.multiselect--disabled .multiselect__select {
    background: #ededed;
    color: #a6a6a6
}

.multiselect__option--disabled {
    background: #ededed !important;
    color: #a6a6a6 !important;
    cursor: text;
    pointer-events: none
}

.multiselect__option--group {
    background: #ededed;
    color: #35495e
}

.multiselect__option--group.multiselect__option--highlight {
    background: #35495e;
    color: #fff
}

.multiselect__option--group.multiselect__option--highlight:after {
    background: #35495e
}

.multiselect__option--disabled.multiselect__option--highlight {
    background: #dedede
}

.multiselect__option--group-selected.multiselect__option--highlight {
    background: #ff6a6a;
    color: #fff
}

.multiselect__option--group-selected.multiselect__option--highlight:after {
    background: #ff6a6a;
    content: attr(data-deselect);
    color: #fff
}

.multiselect-enter-active,
.multiselect-leave-active {
    transition: all .15s ease
}

.multiselect-enter,
.multiselect-leave-active {
    opacity: 0
}

.multiselect__strong {
    margin-bottom: 8px;
    line-height: 20px;
    display: inline-block;
    vertical-align: top
}

[dir=rtl] .multiselect {
    text-align: right
}

[dir=rtl] .multiselect__select {
    right: auto;
    left: 1px
}

[dir=rtl] .multiselect__tags {
    padding: 8px 8px 0 40px
}

[dir=rtl] .multiselect__content {
    text-align: right
}

[dir=rtl] .multiselect__option:after {
    right: auto;
    left: 0
}

[dir=rtl] .multiselect__clear {
    right: auto;
    left: 12px
}

[dir=rtl] .multiselect__spinner {
    right: auto;
    left: 1px
}

@-webkit-keyframes spinning {
    0% {
        transform: rotate(0)
    }

    to {
        transform: rotate(2turn)
    }
}

@keyframes spinning {
    0% {
        transform: rotate(0)
    }

    to {
        transform: rotate(2turn)
    }
}

.form-builder--item .item-description {
    display: block
}

.form-builder--item .error {
    margin-top: 10px
}

.option-radio {
    display: flex;
    align-items: center;
    position: relative
}

.option-radio input.add-custom-opt {
    background: #fff;
    border: none;
    width: 50%;
    border-bottom: 1px solid #e1e1e1;
    border-radius: 3px;
    padding: 3px;
    font-size: 14px;
    margin-left: 10px;
    margin-bottom: 0px px
}

.form-builder--item .item-description {
    display: block
}

.form-builder--item .error {
    margin-top: 10px
}

.date-picker-custom-style {
    display: block;
    width: 100%;
    padding: 7px 5px;
    font-size: .875rem;
    line-height: 1.5;
    color: #2a3135;
    background: #f3f8fb;
    background-clip: padding-box;
    border: none;
    border-radius: .3125rem;
    transition: all .2s ease-in-out 0s;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none
}

.vdpInnerWrap {
    font-size: 10px !important
}

.hl-app .multi_select_form .multiselect__single,
.hl-app .multi_select_form .multiselect__option {
    font-size: .875rem !important;
    color: #2a3135;
    text-decoration: none
}

.hl-app .multi_select_form .multiselect__select {
    top: 7px
}

.hl-app .multi_select_form .multiselect__single {
    padding: 7px 40px 7px 0
}

.hl-app .multi_select_form .multiselect__input,
.hl-app .multi_select_form .multiselect__single {
    vertical-align: 0%
}

.hl-app .multi_select_form .multiselect__input {
    padding: 7px 40px 7px 0;
    line-height: normal !important
}

.hl-app .multi_select_form .option__desc {
    display: grid;
    grid-template-columns: 220px auto;
    white-space: normal
}

.hl-app .multi_select_form .multiselect__option {
    white-space: normal;
    padding: 2px 10px;
    min-height: 25px;
    line-height: 25px
}

.hl-app .multi_select_form .multiselect__option--highlight,
.hl-app .multi_select_form .multiselect__option--selected.multiselect__option--highlight {
    background: rgba(24, 139, 246, .2);
    color: #333
}

.hl-app .multi_select_form .multiselect__option--highlight:hover {
    color: #188bf6;
    background-color: #188bf633
}

.hl-app .multi_select_form .multiselect__option--highlight:focus {
    color: #000
}

.hl-app .multi_select_form .multiselect__placeholder {
    color: #adadad;
    display: inline-block;
    margin-bottom: 0;
    padding: 6px 40px 10px 0;
    min-height: 32px
}

.hl-app .multi_select_calendar .noResult {
    font-size: 12px
}

#_builder-form .fields-container {
    margin: 12px 0 0
}

.form-top-padding {
    padding-top: 6px
}

.file-input {
    display: none
}

.custom-file-upload {
    border: 1px solid #ccc;
    border-radius: 4px;
    display: block !important;
    cursor: pointer;
    width: 100%;
    min-height: 5rem;
    text-align: center
}

.custom-file-upload svg {
    width: 30px;
    display: block;
    margin: 5px auto
}

#_builder-form .custom-file-upload {
    color: #6e7d84 !important
}

.bi-upload {
    font-size: 20px
}

#_builder-form button {
    border: none
}

#_builder-form .signature-button {
    border: 1px solid #ccc !important;
    width: 100%;
    cursor: pointer;
    border-radius: 4px
}

.form-builder--item .signature-container {
    display: flex !important;
    flex-direction: column;
    align-items: flex-end;
    width: 100%
}

.form-builder--item .signature-container a {
    color: #6e7d84;
    text-decoration: underline
}

.hl-app .iti {
    width: 100%
}

.countryphone {
    background-color: #f3f8fb;
    border: none;
    height: 51px;
    border-radius: 5px;
    width: 100%
}

.extra-top-padding {
    padding-top: 1rem
}

.d-none {
    display: none !important
}

.test-mode-badge {
    color: #bb5504;
    background-color: #ffde92;
    text-transform: uppercase;
    font-weight: 700;
    font-size: 10px;
    padding: 2px 4px;
    border-radius: 4px;
    margin: 0 .2rem
}

.disabled[data-v-02a1f6b2] {
    background-color: #00000080;
    pointer-events: none
}

.form-action button[data-v-02a1f6b2] {
    cursor: pointer
}

.invisible[data-v-02a1f6b2] {
    opacity: 0
}

.flex {
    display: flex
}

.radioBtn {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin-top: 4px;
    display: block
}

.d-flex {
    display: flex
}

.test-mode-badge {
    color: #bb5504;
    background-color: #ffde92;
    text-transform: uppercase;
    font-weight: 700;
    font-size: 10px;
    padding: 2px 4px;
    border-radius: 4px;
    margin: 0 .5rem
}

.order-form-v2 .paypal-container {
    text-align: center;
    padding: 8px 0
}

.order-form-v2 .paypal-container-disabled {
    opacity: .5;
    bottom: 2.5em;
    pointer-events: none;
    cursor: not-allowed
}

.order-form-v2 .payment-mode-container {
    display: flex;
    justify-content: flex-end
}

.order-form-v2 .payment-mode-container .test-mode-badge {
    color: #bb5504;
    background-color: #ffde92;
    text-transform: uppercase;
    font-weight: 700;
    font-size: 10px;
    padding: 2px 4px;
    border-radius: 4px;
    margin: 0 .5rem
}

.order-form-v2 .divider {
    position: relative;
    display: flex;
    align-items: center;
    overflow: hidden
}

.order-form-v2 .divider hr {
    width: 100%;
    height: 1px;
    border: none;
    background-color: #1a1a1a1a
}

.order-form-v2 .divider .text {
    position: absolute;
    left: 50%;
    transform: translate(-50%);
    padding: 0 8px;
    white-space: nowrap;
    background-color: #fff;
    color: #1a1a1a80;
    font-weight: 400;
    font-size: 14px;
    margin: 0
}

.order-form-v2 #card-element {
    margin: 5px 0 10px;
    box-shadow: 0 0 0 1px #e0e0e0, 0 2px 4px #00000012, 0 1px 1.5px #0000000d;
    transition: box-shadow .08s ease-in, color .08s ease-in, filter 50000s
}

.order-form-v2 .card-element-label {
    text-transform: unset
}

.order-form-v2 .card-details-v2 {
    padding: 5px 0 15px
}

.order-form-v2 .card-el-error-msg {
    text-align: left
}

.product-name {
    margin-left: 5px
}

.item-description {
    font-size: 12px;
    margin-left: 5px;
    color: gray
}

.error-message {
    color: #f87171
}

.container-order-form-two-step .is-danger {
    border: 1px solid rgba(248, 113, 113, 1)
}

.product-bump-divider {
    margin-bottom: 10px
}

.caret-up:before {
    content: "\f0d8"
}

.order-form-footer {
    text-align: center;
    margin-top: 10px;
    color: #9c9c9c;
    font-size: 12px;
    word-break: break-word
}

.form-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 7px 14px #32325d1a, 0 3px 6px #00000014
}

.form-btn {
    display: block;
    color: #fff;
    border-radius: 4px;
    font-weight: 700;
    width: 100%;
    outline: none;
    cursor: pointer;
    transition: all .15s ease
}

.form-btn .sub-text {
    font-size: 13px;
    font-weight: 400
}

.form-btn {
    padding: 8px;
    position: relative;
    width: 100%;
    color: #fff;
    border: 1px solid rgba(0, 0, 0, .1);
    box-shadow: inset 0 1px #fff3;
    border-radius: 4px
}

.form-btn .main-text {
    font-weight: 700;
    font-size: 1.2rem
}

.form-btn i {
    font-weight: 900;
    margin-right: 5px;
    font-size: 1.26rem
}

.container-order-form-two-step .cc-holder {
    height: 50px;
    background: #f1f1f1;
    line-height: 50px;
    box-shadow: 0 0 0 3px #0000000d !important;
    border: 1px solid rgba(0, 0, 0, .2);
    font-size: 14px;
    outline: none;
    padding: 0 18px;
    margin-top: 10px;
    color: #dcdcdc
}

.container-order-form-two-step .cc-holder span {
    float: right;
    color: #dcdcdc
}

.card-el-error-msg {
    display: flex;
    align-items: center
}

.card-el-error-msg svg {
    margin-right: 2px
}

.card-el-error-msg,
.card-el-error-msg svg {
    font-size: 12px;
    color: #f87171
}

.StripeElement {
    box-sizing: border-box;
    height: 40px;
    padding: 10px 12px;
    border: 1px solid transparent;
    border-radius: 4px;
    background-color: #fff;
    box-shadow: 0 1px 3px #e6ebf1;
    transition: box-shadow .15s ease
}

.StripeElement--focus {
    box-shadow: 0 1px 3px #cfd7df
}

.StripeElement--invalid {
    border-color: #fa755a
}

.StripeElement--webkit-autofill {
    background-color: #fefde5 !important
}

.bp-container {
    padding: 5px 0
}

.separator {
    display: flex;
    align-items: center;
    text-align: center;
    font-size: 13px;
    font-weight: 500px;
    padding: 1px 0;
    margin: 10px 0
}

.separator:before,
.separator:after {
    content: "";
    flex: 1;
    border-bottom: 1px solid #cfd7df
}

.separator:before {
    margin-right: .25em
}

.separator:after {
    margin-left: .25em
}

.card-errors {
    font-size: 14px
}

.card-el-error-msg {
    font-size: 13px;
    text-align: center;
    padding: 10px 0;
    display: flex;
    justify-content: flex-start;
    color: #e25950
}

.card-el-error-msg svg .base {
    fill: #e25950
}

.card-el-error-msg svg {
    margin: 0 5px
}

#card-element {
    margin: 15px 0 10px
}

.card-element-label {
    text-transform: uppercase;
    color: #32325d;
    letter-spacing: .3px;
    font-size: 13px;
    font-weight: 500
}

.item-price {
    color: #1571a8;
    font-weight: 700
}

.payment-form-row {
    background: rgba(18, 91, 152, .05);
    border-radius: 8px;
    padding: 15px 20px
}

.flex-text {
    display: flex;
    justify-content: center;
    justify-items: center;
    align-items: center
}

.cart-icon:before {
    content: "\f07a";
    font-family: "Font Awesome 5 Free";
    margin-right: 5px;
    font-weight: 700
}

.disable-btn {
    pointer-events: none;
    cursor: not-allowed
}

.card-details {
    padding: 20px 0
}

.product-title {
    display: grid;
    grid-template-columns: 8fr 1fr 1fr
}

.product-title .item {
    font-size: 13px;
    font-weight: 700
}

.product-title .item:last-child {
    text-align: right
}

.product-description {
    display: grid;
    grid-template-columns: 8fr 1fr 1fr;
    margin-bottom: 10px
}

.product-description .item {
    font-size: 13px
}

.product-description .item:last-child {
    text-align: right
}

.product-detail {
    margin-top: 20px
}

.divider-product {
    width: 100%;
    height: 2px;
    background-color: #888;
    opacity: .3;
    margin: 6px 0
}

.container-order-form-two-step {
    max-width: 100%;
    background-color: #fff;
    padding: 2px;
    border-radius: 5px;
    box-shadow: 0 1px 3px #0000001a, 0 1px 2px #0000000f
}

.container-order-form-two-step .form-title {
    display: grid;
    grid-template-columns: 1fr 1fr;
    padding: 7px
}

.container-order-form-two-step .form-title div {
    text-align: center
}

.divider-form {
    height: 5px;
    width: 100%;
    background: #1571a8;
    position: relative;
    z-index: 1
}

.divider-form i {
    position: absolute;
    font-size: 30px;
    top: -18px;
    color: #1571a8;
    left: 25%
}

.step2 i {
    position: absolute;
    font-size: 30px;
    top: -18px;
    color: #1571a8;
    right: 25% !important;
    left: unset
}

.form-heading {
    font-size: 14px;
    font-weight: 700;
    word-break: break-word
}

.form-sub-heading {
    font-size: 12px;
    color: #607179;
    word-break: break-word
}

.form-step {
    display: grid;
    grid-template-columns: 1fr
}

.form-title div:first-child {
    box-shadow: 10px 0 4px -8px #00000047
}

.form-step .active {
    color: #1571a8
}

.form-body {
    padding: 15px;
    background-color: #fff
}

.shipping-input-split {
    display: grid;
    grid-template-columns: 3fr 1fr;
    grid-column-gap: 20px
}

.shipping-title-wrapp,
.payment-title-wrapp {
    width: 100%;
    position: relative;
    padding: 8px 0
}

.address-title,
.payment-title {
    position: absolute;
    text-transform: uppercase;
    font-weight: 700;
    color: #626262;
    font-size: 12px;
    background-color: #fff;
    padding-right: 10px;
    z-index: 1;
    margin-top: -9px
}

.shipping-bar,
.payment-bar {
    position: absolute;
    width: 100%;
    height: 2px;
    background-color: #e5e7eb;
    top: 7px
}

.forward-shopping-details {
    display: block;
    color: #888 !important;
    font-size: 12px
}

.forward-shopping-details span:hover {
    text-decoration: underline;
    color: #007bff;
    cursor: pointer
}

.form-payment {
    padding: 10px
}

.info,
.shipping {
    display: grid;
    grid-template-columns: 1fr;
    grid-row-gap: 15px;
    margin-bottom: 15px
}

.container-card span {
    color: #888;
    padding-bottom: 10px
}

.form-action {
    width: 100%;
    margin-top: 5px
}

.form-input {
    border-radius: 5px;
    background-position: 97%;
    border: 1px solid rgb(209, 213, 219);
    box-shadow: #0000 0 0, #0000 !important;
    -moz-box-shadow: rgba(0, 0, 0, 0) 0px 0px 0px 0px, rgba(0, 0, 0, 0) !important;
    -webkit-box-shadow: rgba(0, 0, 0, 0) 0px 0px 0px 0px, rgba(0, 0, 0, 0) !important;
    font-size: 14px;
    line-height: 24px;
    padding: 8px 12px;
    outline: none !important;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    width: 100%
}

.form-button-subtle {
    box-shadow: inset 0 1px #fff3;
    border-radius: 4px
}

.form-button-subtle-border {
    border-bottom: 3px solid rgba(0, 0, 0, .2);
    border-left: none !important;
    border-right: none !important
}

.order-bump-container {
    padding: 8px;
    border: 2px dashed #c7c7c7;
    background-color: #fbf8e3;
    border-radius: 5px
}

.order-bump-container .main-section {
    background-color: #fefcbf;
    padding: 2px;
    text-align: left;
    border-radius: 5px
}

.order-bump-container .headline {
    color: #090;
    line-height: 30px;
    font-size: 16px;
    font-weight: 700;
    margin-left: 2px;
    word-wrap: break-word
}

.oto-headline {
    color: #c30;
    font-weight: 700;
    text-decoration: underline
}

.order-bump-container p {
    margin-top: 10px
}

.bump-image {
    width: 100%;
    height: auto;
    max-width: 100%
}

.main-section {
    display: flex;
    align-items: center
}

.bump--flashing-arrow {
    padding: 0 9px;
    width: 40px
}

.bump--checkbox {
    margin: 0 4px
}

.order-total {
    color: #333;
    font-size: 13px;
    font-weight: 700
}

.order-total {
    display: flex;
    justify-content: space-between;
    margin-bottom: 10px
}

.qtyDropDown {
    display: inline-block;
    width: 45px !important;
    padding: 2px 4px;
    height: 22px;
    font-size: 12px;
    -webkit-appearance: auto;
    -moz-appearance: auto;
    appearance: auto
}

.max-qty-text {
    font-size: 10px
}

.--mobile-product-title {
    display: grid;
    grid-template-columns: 3fr 1fr 1fr
}

.--mobile-product-title .item {
    font-size: 13px;
    font-weight: 700
}

.--mobile-product-title .item:last-child {
    text-align: right
}

.--mobile-product-description {
    display: grid;
    grid-template-columns: 3fr 1fr 1fr;
    margin-bottom: 10px
}

.--mobile-product-description .item {
    font-size: 13px
}

.--mobile-product-description .item:last-child {
    text-align: right
}

@media (max-width: 450px) {

    .product-title,
    .product-description {
        grid-template-columns: 2fr 1fr 1fr
    }
}

.d-flex {
    display: flex
}

.test-mode-badge {
    color: #bb5504;
    background-color: #ffde92;
    text-transform: uppercase;
    font-weight: 700;
    font-size: 10px;
    padding: 2px 4px;
    border-radius: 4px;
    margin: 0 .5rem
}

.product-name {
    margin-left: 5px
}

.item-description {
    font-size: 12px;
    margin-left: 5px;
    color: gray
}

.error-message {
    color: #f87171
}

.container-order-form-two-step .is-danger {
    border: 1px solid rgba(248, 113, 113, 1)
}

.product-bump-divider {
    margin-bottom: 10px
}

.caret-up:before {
    content: "\f0d8"
}

.order-form-footer {
    text-align: center;
    margin-top: 10px;
    color: #9c9c9c;
    font-size: 12px;
    word-break: break-word
}

.form-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 7px 14px #32325d1a, 0 3px 6px #00000014
}

.form-btn {
    display: block;
    color: #fff;
    border-radius: 4px;
    font-weight: 700;
    width: 100%;
    outline: none;
    cursor: pointer;
    transition: all .15s ease
}

.form-btn .sub-text {
    font-size: 13px;
    font-weight: 400
}

.form-btn {
    padding: 8px;
    position: relative;
    width: 100%;
    color: #fff;
    border: 1px solid rgba(0, 0, 0, .1);
    box-shadow: inset 0 1px #fff3;
    border-radius: 4px
}

.form-btn .main-text {
    font-weight: 700;
    font-size: 1.2rem
}

.form-btn i {
    font-weight: 900;
    margin-right: 5px;
    font-size: 1.26rem
}

.container-order-form-two-step .cc-holder {
    height: 50px;
    background: #f1f1f1;
    line-height: 50px;
    box-shadow: 0 0 0 3px #0000000d !important;
    border: 1px solid rgba(0, 0, 0, .2);
    font-size: 14px;
    outline: none;
    padding: 0 18px;
    margin-top: 10px;
    color: #dcdcdc
}

.container-order-form-two-step .cc-holder span {
    float: right;
    color: #dcdcdc
}

.card-el-error-msg {
    display: flex;
    align-items: center
}

.card-el-error-msg svg {
    margin-right: 2px
}

.card-el-error-msg,
.card-el-error-msg svg {
    font-size: 12px;
    color: #f87171
}

.StripeElement {
    box-sizing: border-box;
    height: 40px;
    padding: 10px 12px;
    border: 1px solid transparent;
    border-radius: 4px;
    background-color: #fff;
    box-shadow: 0 1px 3px #e6ebf1;
    transition: box-shadow .15s ease
}

.StripeElement--focus {
    box-shadow: 0 1px 3px #cfd7df
}

.StripeElement--invalid {
    border-color: #fa755a
}

.StripeElement--webkit-autofill {
    background-color: #fefde5 !important
}

.bp-container {
    padding: 5px 0
}

.separator {
    display: flex;
    align-items: center;
    text-align: center;
    font-size: 13px;
    font-weight: 500px;
    padding: 1px 0;
    margin: 10px 0
}

.separator:before,
.separator:after {
    content: "";
    flex: 1;
    border-bottom: 1px solid #cfd7df
}

.separator:before {
    margin-right: .25em
}

.separator:after {
    margin-left: .25em
}

.card-errors {
    font-size: 14px
}

.card-el-error-msg {
    font-size: 13px;
    text-align: center;
    padding: 10px 0;
    display: flex;
    justify-content: flex-start;
    color: #e25950
}

.card-el-error-msg svg .base {
    fill: #e25950
}

.card-el-error-msg svg {
    margin: 0 5px
}

#card-element {
    margin: 15px 0 10px
}

.card-element-label {
    text-transform: uppercase;
    color: #32325d;
    letter-spacing: .3px;
    font-size: 13px;
    font-weight: 500
}

.item-price {
    color: #1571a8;
    font-weight: 700
}

.payment-form-row {
    background: rgba(18, 91, 152, .05);
    border-radius: 8px;
    padding: 15px 20px
}

.flex-text {
    display: flex;
    justify-content: center;
    justify-items: center;
    align-items: center
}

.cart-icon:before {
    content: "\f07a";
    font-family: "Font Awesome 5 Free";
    margin-right: 5px;
    font-weight: 700
}

.disable-btn {
    pointer-events: none;
    cursor: not-allowed
}

.card-details {
    padding: 20px 0
}

.product-title {
    display: grid;
    grid-template-columns: 8fr 1fr 1fr
}

.product-title .item {
    font-size: 13px;
    font-weight: 700
}

.product-title .item:last-child {
    text-align: right
}

.product-description {
    display: grid;
    grid-template-columns: 8fr 1fr 1fr;
    margin-bottom: 10px
}

.product-description .item {
    font-size: 13px
}

.product-description .item:last-child {
    text-align: right
}

.product-detail {
    margin-top: 20px
}

.divider-product {
    width: 100%;
    height: 2px;
    background-color: #888;
    opacity: .3;
    margin: 6px 0
}

.container-order-form-two-step {
    max-width: 100%;
    background-color: #fff;
    padding: 2px;
    border-radius: 5px;
    box-shadow: 0 1px 3px #0000001a, 0 1px 2px #0000000f
}

.container-order-form-two-step .form-title {
    display: grid;
    grid-template-columns: 1fr 1fr;
    padding: 7px
}

.container-order-form-two-step .form-title div {
    text-align: center
}

.divider-form {
    height: 5px;
    width: 100%;
    background: #1571a8;
    position: relative;
    z-index: 1
}

.divider-form i {
    position: absolute;
    font-size: 30px;
    top: -18px;
    color: #1571a8;
    left: 25%
}

.step2 i {
    position: absolute;
    font-size: 30px;
    top: -18px;
    color: #1571a8;
    right: 25% !important;
    left: unset
}

.form-heading {
    font-size: 14px;
    font-weight: 700;
    word-break: break-word
}

.form-sub-heading {
    font-size: 12px;
    color: #607179;
    word-break: break-word
}

.form-step {
    display: grid;
    grid-template-columns: 1fr
}

.form-title div:first-child {
    box-shadow: 10px 0 4px -8px #00000047
}

.form-step .active {
    color: #1571a8
}

.form-body {
    padding: 15px;
    background-color: #fff
}

.shipping-input-split {
    display: grid;
    grid-template-columns: 3fr 1fr;
    grid-column-gap: 20px
}

.shipping-title-wrapp,
.payment-title-wrapp {
    width: 100%;
    position: relative;
    padding: 8px 0
}

.address-title,
.payment-title {
    position: absolute;
    text-transform: uppercase;
    font-weight: 700;
    color: #626262;
    font-size: 12px;
    background-color: #fff;
    padding-right: 10px;
    z-index: 1;
    margin-top: -9px
}

.shipping-bar,
.payment-bar {
    position: absolute;
    width: 100%;
    height: 2px;
    background-color: #e5e7eb;
    top: 7px
}

.forward-shopping-details {
    display: block;
    color: #888 !important;
    font-size: 12px
}

.forward-shopping-details span:hover {
    text-decoration: underline;
    color: #007bff;
    cursor: pointer
}

.form-payment {
    padding: 10px
}

.info,
.shipping {
    display: grid;
    grid-template-columns: 1fr;
    grid-row-gap: 15px;
    margin-bottom: 15px
}

.container-card span {
    color: #888;
    padding-bottom: 10px
}

.form-action {
    width: 100%;
    margin-top: 5px
}

.form-input {
    border-radius: 5px;
    background-position: 97%;
    border: 1px solid rgb(209, 213, 219);
    box-shadow: #0000 0 0, #0000 !important;
    -moz-box-shadow: rgba(0, 0, 0, 0) 0px 0px 0px 0px, rgba(0, 0, 0, 0) !important;
    -webkit-box-shadow: rgba(0, 0, 0, 0) 0px 0px 0px 0px, rgba(0, 0, 0, 0) !important;
    font-size: 14px;
    line-height: 24px;
    padding: 8px 12px;
    outline: none !important;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    width: 100%
}

.form-button-subtle {
    box-shadow: inset 0 1px #fff3;
    border-radius: 4px
}

.form-button-subtle-border {
    border-bottom: 3px solid rgba(0, 0, 0, .2);
    border-left: none !important;
    border-right: none !important
}

.order-bump-container {
    padding: 8px;
    border: 2px dashed #c7c7c7;
    background-color: #fbf8e3;
    border-radius: 5px
}

.order-bump-container .main-section {
    background-color: #fefcbf;
    padding: 2px;
    text-align: left;
    border-radius: 5px
}

.order-bump-container .headline {
    color: #090;
    line-height: 30px;
    font-size: 16px;
    font-weight: 700;
    margin-left: 2px;
    word-wrap: break-word
}

.oto-headline {
    color: #c30;
    font-weight: 700;
    text-decoration: underline
}

.order-bump-container p {
    margin-top: 10px
}

.bump-image {
    width: 100%;
    height: auto;
    max-width: 100%
}

.main-section {
    display: flex;
    align-items: center
}

.bump--flashing-arrow {
    padding: 0 9px;
    width: 40px
}

.bump--checkbox {
    margin: 0 4px
}

.order-total {
    color: #333;
    font-size: 13px;
    font-weight: 700
}

.order-total {
    display: flex;
    justify-content: space-between;
    margin-bottom: 10px
}

.qtyDropDown {
    display: inline-block;
    width: 45px !important;
    padding: 2px 4px;
    height: 22px;
    font-size: 12px;
    -webkit-appearance: auto;
    -moz-appearance: auto;
    appearance: auto
}

.max-qty-text {
    font-size: 10px
}

.--mobile-product-title {
    display: grid;
    grid-template-columns: 3fr 1fr 1fr
}

.--mobile-product-title .item {
    font-size: 13px;
    font-weight: 700
}

.--mobile-product-title .item:last-child {
    text-align: right
}

.--mobile-product-description {
    display: grid;
    grid-template-columns: 3fr 1fr 1fr;
    margin-bottom: 10px
}

.--mobile-product-description .item {
    font-size: 13px
}

.--mobile-product-description .item:last-child {
    text-align: right
}

@media (max-width: 450px) {

    .product-title,
    .product-description {
        grid-template-columns: 2fr 1fr 1fr
    }
}

.order-form-v2 .paypal-container[data-v-309bd9a1] {
    text-align: center;
    padding: 8px 0
}

.order-form-v2 .paypal-container-disabled[data-v-309bd9a1] {
    opacity: .5;
    bottom: 2.5em;
    pointer-events: none;
    cursor: not-allowed
}

.order-form-v2 .payment-mode-container[data-v-309bd9a1] {
    display: flex;
    justify-content: flex-end
}

.order-form-v2 .payment-mode-container .test-mode-badge[data-v-309bd9a1] {
    color: #bb5504;
    background-color: #ffde92;
    text-transform: uppercase;
    font-weight: 700;
    font-size: 10px;
    padding: 2px 4px;
    border-radius: 4px;
    margin: 0 .5rem
}

.order-form-v2 .divider[data-v-309bd9a1] {
    position: relative;
    display: flex;
    align-items: center;
    overflow: hidden
}

.order-form-v2 .divider hr[data-v-309bd9a1] {
    width: 100%;
    height: 1px;
    border: none;
    background-color: #1a1a1a1a
}

.order-form-v2 .divider .text[data-v-309bd9a1] {
    position: absolute;
    left: 50%;
    transform: translate(-50%);
    padding: 0 8px;
    white-space: nowrap;
    background-color: #fff;
    color: #1a1a1a80;
    font-weight: 400;
    font-size: 14px;
    margin: 0
}

.order-form-v2 #card-element[data-v-309bd9a1] {
    margin: 5px 0 10px;
    box-shadow: 0 0 0 1px #e0e0e0, 0 2px 4px #00000012, 0 1px 1.5px #0000000d;
    transition: box-shadow .08s ease-in, color .08s ease-in, filter 50000s
}

.order-form-v2 .card-element-label[data-v-309bd9a1] {
    text-transform: unset
}

.order-form-v2 .card-details-v2[data-v-309bd9a1] {
    padding: 5px 0 15px
}

.product-name {
    margin-left: 5px
}

.item-description {
    font-size: 12px;
    margin-left: 5px;
    color: gray
}

.error-message {
    color: #f87171
}

.container-order-form-two-step .is-danger {
    border: 1px solid rgba(248, 113, 113, 1)
}

.product-bump-divider {
    margin-bottom: 10px
}

.caret-up:before {
    content: "\f0d8"
}

.order-form-footer {
    text-align: center;
    margin-top: 10px;
    color: #9c9c9c;
    font-size: 12px;
    word-break: break-word
}

.form-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 7px 14px #32325d1a, 0 3px 6px #00000014
}

.form-btn {
    display: block;
    color: #fff;
    border-radius: 4px;
    font-weight: 700;
    width: 100%;
    outline: none;
    cursor: pointer;
    transition: all .15s ease
}

.form-btn .sub-text {
    font-size: 13px;
    font-weight: 400
}

.form-btn {
    padding: 8px;
    position: relative;
    width: 100%;
    color: #fff;
    border: 1px solid rgba(0, 0, 0, .1);
    box-shadow: inset 0 1px #fff3;
    border-radius: 4px
}

.form-btn .main-text {
    font-weight: 700;
    font-size: 1.2rem
}

.form-btn i {
    font-weight: 900;
    margin-right: 5px;
    font-size: 1.26rem
}

.container-order-form-two-step .cc-holder {
    height: 50px;
    background: #f1f1f1;
    line-height: 50px;
    box-shadow: 0 0 0 3px #0000000d !important;
    border: 1px solid rgba(0, 0, 0, .2);
    font-size: 14px;
    outline: none;
    padding: 0 18px;
    margin-top: 10px;
    color: #dcdcdc
}

.container-order-form-two-step .cc-holder span {
    float: right;
    color: #dcdcdc
}

.card-el-error-msg {
    display: flex;
    align-items: center
}

.card-el-error-msg svg {
    margin-right: 2px
}

.card-el-error-msg,
.card-el-error-msg svg {
    font-size: 12px;
    color: #f87171
}

.StripeElement {
    box-sizing: border-box;
    height: 40px;
    padding: 10px 12px;
    border: 1px solid transparent;
    border-radius: 4px;
    background-color: #fff;
    box-shadow: 0 1px 3px #e6ebf1;
    transition: box-shadow .15s ease
}

.StripeElement--focus {
    box-shadow: 0 1px 3px #cfd7df
}

.StripeElement--invalid {
    border-color: #fa755a
}

.StripeElement--webkit-autofill {
    background-color: #fefde5 !important
}

.bp-container {
    padding: 5px 0
}

.separator {
    display: flex;
    align-items: center;
    text-align: center;
    font-size: 13px;
    font-weight: 500px;
    padding: 1px 0;
    margin: 10px 0
}

.separator:before,
.separator:after {
    content: "";
    flex: 1;
    border-bottom: 1px solid #cfd7df
}

.separator:before {
    margin-right: .25em
}

.separator:after {
    margin-left: .25em
}

.card-errors {
    font-size: 14px
}

.card-el-error-msg {
    font-size: 13px;
    text-align: center;
    padding: 10px 0;
    display: flex;
    justify-content: flex-start;
    color: #e25950
}

.card-el-error-msg svg .base {
    fill: #e25950
}

.card-el-error-msg svg {
    margin: 0 5px
}

#card-element {
    margin: 15px 0 10px
}

.card-element-label {
    text-transform: uppercase;
    color: #32325d;
    letter-spacing: .3px;
    font-size: 13px;
    font-weight: 500
}

.item-price {
    color: #1571a8;
    font-weight: 700
}

.payment-form-row {
    background: rgba(18, 91, 152, .05);
    border-radius: 8px;
    padding: 15px 20px
}

.flex-text {
    display: flex;
    justify-content: center;
    justify-items: center;
    align-items: center
}

.cart-icon:before {
    content: "\f07a";
    font-family: "Font Awesome 5 Free";
    margin-right: 5px;
    font-weight: 700
}

.disable-btn {
    pointer-events: none;
    cursor: not-allowed
}

.card-details {
    padding: 20px 0
}

.product-title {
    display: grid;
    grid-template-columns: 8fr 1fr 1fr
}

.product-title .item {
    font-size: 13px;
    font-weight: 700
}

.product-title .item:last-child {
    text-align: right
}

.product-description {
    display: grid;
    grid-template-columns: 8fr 1fr 1fr;
    margin-bottom: 10px
}

.product-description .item {
    font-size: 13px
}

.product-description .item:last-child {
    text-align: right
}

.product-detail {
    margin-top: 20px
}

.divider-product {
    width: 100%;
    height: 2px;
    background-color: #888;
    opacity: .3;
    margin: 6px 0
}

.container-order-form-two-step {
    max-width: 100%;
    background-color: #fff;
    padding: 2px;
    border-radius: 5px;
    box-shadow: 0 1px 3px #0000001a, 0 1px 2px #0000000f
}

.container-order-form-two-step .form-title {
    display: grid;
    grid-template-columns: 1fr 1fr;
    padding: 7px
}

.container-order-form-two-step .form-title div {
    text-align: center
}

.divider-form {
    height: 5px;
    width: 100%;
    background: #1571a8;
    position: relative;
    z-index: 1
}

.divider-form i {
    position: absolute;
    font-size: 30px;
    top: -18px;
    color: #1571a8;
    left: 25%
}

.step2 i {
    position: absolute;
    font-size: 30px;
    top: -18px;
    color: #1571a8;
    right: 25% !important;
    left: unset
}

.form-heading {
    font-size: 14px;
    font-weight: 700;
    word-break: break-word
}

.form-sub-heading {
    font-size: 12px;
    color: #607179;
    word-break: break-word
}

.form-step {
    display: grid;
    grid-template-columns: 1fr
}

.form-title div:first-child {
    box-shadow: 10px 0 4px -8px #00000047
}

.form-step .active {
    color: #1571a8
}

.form-body {
    padding: 15px;
    background-color: #fff
}

.shipping-input-split {
    display: grid;
    grid-template-columns: 3fr 1fr;
    grid-column-gap: 20px
}

.shipping-title-wrapp,
.payment-title-wrapp {
    width: 100%;
    position: relative;
    padding: 8px 0
}

.address-title,
.payment-title {
    position: absolute;
    text-transform: uppercase;
    font-weight: 700;
    color: #626262;
    font-size: 12px;
    background-color: #fff;
    padding-right: 10px;
    z-index: 1;
    margin-top: -9px
}

.shipping-bar,
.payment-bar {
    position: absolute;
    width: 100%;
    height: 2px;
    background-color: #e5e7eb;
    top: 7px
}

.forward-shopping-details {
    display: block;
    color: #888 !important;
    font-size: 12px
}

.forward-shopping-details span:hover {
    text-decoration: underline;
    color: #007bff;
    cursor: pointer
}

.form-payment {
    padding: 10px
}

.info,
.shipping {
    display: grid;
    grid-template-columns: 1fr;
    grid-row-gap: 15px;
    margin-bottom: 15px
}

.container-card span {
    color: #888;
    padding-bottom: 10px
}

.form-action {
    width: 100%;
    margin-top: 5px
}

.form-input {
    border-radius: 5px;
    background-position: 97%;
    border: 1px solid rgb(209, 213, 219);
    box-shadow: #0000 0 0, #0000 !important;
    -moz-box-shadow: rgba(0, 0, 0, 0) 0px 0px 0px 0px, rgba(0, 0, 0, 0) !important;
    -webkit-box-shadow: rgba(0, 0, 0, 0) 0px 0px 0px 0px, rgba(0, 0, 0, 0) !important;
    font-size: 14px;
    line-height: 24px;
    padding: 8px 12px;
    outline: none !important;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    width: 100%
}

.form-button-subtle {
    box-shadow: inset 0 1px #fff3;
    border-radius: 4px
}

.form-button-subtle-border {
    border-bottom: 3px solid rgba(0, 0, 0, .2);
    border-left: none !important;
    border-right: none !important
}

.order-bump-container {
    padding: 8px;
    border: 2px dashed #c7c7c7;
    background-color: #fbf8e3;
    border-radius: 5px
}

.order-bump-container .main-section {
    background-color: #fefcbf;
    padding: 2px;
    text-align: left;
    border-radius: 5px
}

.order-bump-container .headline {
    color: #090;
    line-height: 30px;
    font-size: 16px;
    font-weight: 700;
    margin-left: 2px;
    word-wrap: break-word
}

.oto-headline {
    color: #c30;
    font-weight: 700;
    text-decoration: underline
}

.order-bump-container p {
    margin-top: 10px
}

.bump-image {
    width: 100%;
    height: auto;
    max-width: 100%
}

.main-section {
    display: flex;
    align-items: center
}

.bump--flashing-arrow {
    padding: 0 9px;
    width: 40px
}

.bump--checkbox {
    margin: 0 4px
}

.order-total {
    color: #333;
    font-size: 13px;
    font-weight: 700
}

.order-total {
    display: flex;
    justify-content: space-between;
    margin-bottom: 10px
}

.qtyDropDown {
    display: inline-block;
    width: 45px !important;
    padding: 2px 4px;
    height: 22px;
    font-size: 12px;
    -webkit-appearance: auto;
    -moz-appearance: auto;
    appearance: auto
}

.max-qty-text {
    font-size: 10px
}

.--mobile-product-title {
    display: grid;
    grid-template-columns: 3fr 1fr 1fr
}

.--mobile-product-title .item {
    font-size: 13px;
    font-weight: 700
}

.--mobile-product-title .item:last-child {
    text-align: right
}

.--mobile-product-description {
    display: grid;
    grid-template-columns: 3fr 1fr 1fr;
    margin-bottom: 10px
}

.--mobile-product-description .item {
    font-size: 13px
}

.--mobile-product-description .item:last-child {
    text-align: right
}

@media (max-width: 450px) {

    .product-title,
    .product-description {
        grid-template-columns: 2fr 1fr 1fr
    }
}

.date-picker-calendar[data-v-43a415f1] {
    margin-top: 0;
    max-width: 280px;
    min-height: 365px
}

.hl_widget--pick-date[data-v-43a415f1] {
    text-align: center
}

.option__title[data-v-43a415f1] {
    font-size: 13px;
    color: #607179
}

.hl-app .timezone-actions[data-v-43a415f1] {
    padding: unset
}

.option_sub_title[data-v-43a415f1] {
    font-size: 11px;
    text-align: right;
    white-space: normal
}

.timezone-picker-group[data-v-43a415f1] {
    padding: 0;
    box-shadow: 0 .2em 1.5em #0000;
    border-radius: .5em
}

.hl_widget-footer[data-v-43a415f1] {
    text-align: center;
    padding: 20px 30px
}

@media only screen and (max-width: 600px) {
    .hl-app .hl_widget-step1 .hl_widget--pick-date-time>*[data-v-43a415f1] {
        margin: auto
    }

    .hl_widget-footer[data-v-43a415f1] {
        text-align: center
    }
}

.multiselect__content-wrapper {
    overflow-x: hidden
}

.multi_select_calendar .multiselect__single {
    font-size: 14px !important;
    color: #2a3135;
    text-decoration: none;
    overflow: hidden;
    max-width: 280px;
    text-overflow: ellipsis;
    white-space: nowrap
}

.multi_select_calendar .multiselect__option--highlight,
.multiselect__option--selected.multiselect__option--highlight {
    background: rgba(24, 139, 246, .2) !important;
    color: #333
}

.multi_select_calendar .multiselect__option--highlight:hover {
    color: #188bf6;
    background-color: #188bf633
}

.multi_select_calendar .multiselect__option--highlight:focus {
    color: #000
}

.date-picker-calendar .vdpInnerWrap {
    border: unset !important
}

.date-picker-calendar .vdpHeader {
    background: #fff
}

.multiple-cal-container {
    margin-bottom: 20px
}

.multiselect__input {
    background-color: #fff !important;
    padding: 0;
    border-radius: 0
}

.vdpInnerWrap {
    border: 1px solid #d8d8d8 !important;
    margin-bottom: 15px !important;
    border-radius: 5px;
    background: #ffffff
}

.hl-app .multi_select_calendar .multiselect__input {
    padding: 0 !important;
    line-height: normal !important
}

.hl-app .multiselect__content-wrapper {
    box-shadow: #0000001a 0 8px 16px 5px;
    max-height: 300px;
    width: 350px;
    padding: 8px;
    margin-top: 1px
}

.hl-app .multi_select_calendar .option__desc {
    display: grid;
    grid-template-columns: 220px auto;
    white-space: normal
}

.hl-app .multi_select_calendar .multiselect__option {
    white-space: normal;
    padding: 2px 10px;
    min-height: 25px;
    line-height: 25px
}

.details-item-step2 {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-bottom: 10px
}

.form-payment-item {
    padding: 0 15px
}

td.vdpCell.outOfRange {
    visibility: hidden
}

td.vdpCell.disabled {
    color: #ddd;
    opacity: 1
}

.timezone-picker-group .multiselect__tags {
    border: none
}

.step3-btns {
    font-size: 14px;
    font-weight: 600 !important
}

.hl-app .multi_select_calendar .multiselect__content-wrapper {
    left: 50%;
    transform: translate(-50%)
}

.multi_select_calendar .noResult {
    font-size: 12px
}

.selectable .vdpCellContent {
    color: #00a2ff;
    border-radius: 50%;
    font-weight: 500
}

.disabled .vdpCellContent {
    color: #ddd !important;
    background: #fff !important
}

.hl-app .btn-back svg {
    cursor: pointer
}

.hl-app .disable-back-btn svg {
    color: gray;
    fill: #e1e1e1;
    cursor: auto
}

.hl-app .multi_select_calendar .multiselect__tags {
    background: transparent
}

.no-slots-block {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: white;
    z-index: 99;
    width: 90%;
    padding: 10px;
    border: 1px solid #ccc;
    border-radius: 10px;
    box-shadow: 0 0 3px #ccc
}

.hl-app-mobile .hl_widget-step1 .hl_widget--pick-date-time .hl_widget--pick-date {
    margin: 0 auto
}

.hl-app-mobile .selected-date .hl_widget-step1 .hl_widget--pick-date-time .hl_widget--pick-date,
.hl-app-mobile #appointmentSlots,
.hl-app-mobile .hl_widget-footer {
    display: none
}

.hl-app-mobile .selected-date #appointmentSlots {
    display: block;
    margin: 0 auto
}

.hl-app-mobile .details-item-step2 .back_button,
.hl-app-mobile .selected-date .hl_widget-footer {
    display: block
}

.no-slots-block a {
    font-size: 1.2rem;
    font-weight: 700
}

.no-slots-block div {
    color: gray;
    font-size: .8rem
}

.bi-chevron-right {
    stroke: #188bf6;
    stroke-width: 2
}

.ghl-footer.ghl-footer-preview[data-v-d8588804] {
    position: fixed;
    z-index: 9
}

.hl-app .ghl-survey-form .multi_select_form .multiselect__placeholder {
    padding-top: 3px
}

.date-picker-field-survey .vdpInnerWrap {
    border: 1px solid #d8d8d8 !important;
    margin-bottom: 65px !important
}

.form-builder--item .item-description {
    display: block
}

.map-element[data-v-04fdafd3] {
    max-width: 100%
}

.svg-component-action svg {
    cursor: pointer
}

.progress-outer[data-v-12cf17a9] {
    height: 35px;
    line-height: 36px;
    font-size: 14px;
    overflow: hidden;
    width: 100%;
    background-color: #f5f5f5;
    box-shadow: inset 0 1px 2px #0000001a;
    padding-top: 0;
    padding-bottom: 0;
    border-radius: inherit
}

.progress-inner[data-v-12cf17a9] {
    float: left;
    width: 0;
    height: 100%;
    font-size: 14px;
    color: #fff;
    padding-left: 10px;
    padding-right: 10px;
    box-shadow: inset 0 -1px #00000026;
    transition: width .6s ease
}

.progress0[data-v-12cf17a9] {
    width: 0%
}

.progress10[data-v-12cf17a9] {
    width: 10%
}

.progress20[data-v-12cf17a9] {
    width: 20%
}

.progress30[data-v-12cf17a9] {
    width: 30%
}

.progress40[data-v-12cf17a9] {
    width: 40%
}

.progress50[data-v-12cf17a9] {
    width: 50%
}

.progress60[data-v-12cf17a9] {
    width: 60%
}

.progress70[data-v-12cf17a9] {
    width: 70%
}

.progress80[data-v-12cf17a9] {
    width: 80%
}

.progress90[data-v-12cf17a9] {
    width: 90%
}

.progress100[data-v-12cf17a9] {
    width: 100%
}

.progressbarOffsetWhite[data-v-12cf17a9] {
    background: #f5f5f5
}

.progressbarOffsetTransparentWhite[data-v-12cf17a9] {
    background-color: #ffffff80
}

.progressbarOffsetBlack[data-v-12cf17a9] {
    background: #333333
}

.progressbarOffsetTransparentBlack[data-v-12cf17a9] {
    background-color: #7e7e7e80
}

.text-bold[data-v-12cf17a9] {
    font-weight: 700
}

.text-italic[data-v-12cf17a9] {
    font-style: italic
}

.text-bold-italic[data-v-12cf17a9] {
    font-weight: 700;
    font-style: italic
}

.progressbarSmall[data-v-12cf17a9] {
    height: 35px;
    line-height: 36px;
    font-size: 14px
}

.progressbarMedium[data-v-12cf17a9] {
    height: 45px;
    line-height: 45px;
    font-size: 19px
}

.progressbarLarge[data-v-12cf17a9] {
    height: 65px;
    line-height: 65px;
    font-size: 21px
}

.oc-product-title {
    display: grid;
    grid-template-columns: 8fr 1fr 1fr
}

.oc-product-title .item {
    font-weight: 700
}

.oc-product-title .item:last-child {
    text-align: right
}

.oc-product-description {
    display: grid;
    grid-template-columns: 8fr 1fr 1fr;
    margin-bottom: 10px
}

.oc-product-description .item:last-child {
    text-align: right
}

.container-order-confirmation {
    max-width: 100%
}

.order-confirmation-body {
    padding: 15px;
    background-color: unset
}

.shipping-details-title {
    padding: 5px 0
}

.oc-product-total {
    display: flex;
    justify-content: space-between
}

.--mobile-oc-product-title {
    display: grid;
    grid-template-columns: 3fr 1fr 1fr
}

.--mobile-oc-product-title .item {
    font-size: 13px;
    font-weight: 700
}

.--mobile-oc-product-title .item:last-child {
    text-align: right
}

.--mobile-oc-product-description {
    display: grid;
    grid-template-columns: 3fr 1fr 1fr;
    margin-bottom: 10px
}

.--mobile-oc-product-description .item {
    font-size: 13px
}

.--mobile-oc-product-description .item:last-child {
    text-align: right
}

@media (max-width: 500px) {

    .oc-product-title,
    .oc-product-description {
        grid-template-columns: 2fr 1fr 1fr
    }
}

.blog-author-container {
    display: flex;
    justify-content: center;
    max-width: 400px;
    margin: 1em auto
}

.social-icon {
    height: 13px;
    width: 13px
}

.blog-author {
    display: flex;
    align-items: center;
    margin: auto
}

.blog-author .blog-author-image {
    width: 36px;
    height: 36px;
    border-radius: 100px
}

.blog-author .blog-author-name {
    font-weight: 600;
    font-size: 14px;
    line-height: 20px;
    margin-left: .5em
}

.blog-author-description {
    font-style: normal;
    font-weight: 400;
    font-size: 12px;
    line-height: 16px;
    text-align: center;
    color: #6b7280
}

.blog-author-social-icons {
    text-align: center
}

.blog-author-social-icons a {
    text-decoration: none !important;
    color: #6b7280 !important;
    margin: .5em
}

.social-icon.facebook:before {
    content: "\f39e";
    font-family: "Font Awesome 5 Brands";
    font-weight: 700;
    font-style: normal
}

.social-icon.instagram:before {
    content: "\f16d";
    font-family: "Font Awesome 5 Brands";
    font-weight: 700;
    font-style: normal
}

.social-icon.twitter:before {
    content: "\f099";
    font-family: "Font Awesome 5 Brands";
    font-weight: 700;
    font-style: normal
}

.social-icon.linkedin:before {
    content: "\f0e1";
    font-family: "Font Awesome 5 Brands";
    font-weight: 700;
    font-style: normal
}

.social-icon.youtube:before {
    content: "\f167";
    font-family: "Font Awesome 5 Brands";
    font-weight: 700;
    font-style: normal
}

.blog-html-container * {
    max-width: 100%
}

.category-separator {
    margin: 0 !important
}

.blog-info-dot {
    font-size: 17px !important
}

.meta-section-1 span {
    margin-right: .5em;
    font-size: 14px;
    color: #556c79
}

.meta-section-2 {
    margin-top: .3em
}

.meta-section-2 span {
    font-size: 14px;
    color: #556c79
}

.header-image {
    max-height: 400px;
    width: 100%;
    -o-object-fit: cover;
    object-fit: cover
}

.blog-html-container {
    max-width: 700px;
    line-height: 1.375
}

.blog-html {
    margin-top: 3em
}

.blog-html-container {
    font-family: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, Helvetica Neue, Arial, Noto Sans, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", Segoe UI Symbol, "Noto Color Emoji"
}

.blog-html-container ul {
    display: block;
    list-style-type: disc;
    margin-top: 1em;
    margin-bottom: 1 em;
    margin-left: 0;
    margin-right: 0;
    padding-left: 40px
}

.blog-html-container ol {
    display: block;
    list-style-type: decimal;
    margin: 1em 0;
    padding-left: 40px
}

.blog-html-container h1 {
    display: block;
    font-size: 2em;
    margin: .67em 0;
    font-weight: 700
}

.blog-html-container h2 {
    display: block;
    font-size: 1.5em;
    margin: .83em 0;
    font-weight: 700
}

.blog-html-container h3 {
    display: block;
    font-size: 1.17em;
    margin: 1em 0;
    font-weight: 700
}

.blog-html-container h4 {
    display: block;
    font-size: 1em;
    margin: 1.33em 0;
    font-weight: 700
}

.blog-html-container h5 {
    display: block;
    font-size: .83em;
    margin: 1.67em 0;
    font-weight: 700
}

.blog-html-container h6 {
    display: block;
    font-size: .67em;
    margin: 2.33em 0;
    font-weight: 700
}

.blog-html-container p {
    display: block;
    margin: 1em 0
}

.blog-html-container code {
    background-color: #6161611a;
    color: #616161
}

.blog-html-container pre {
    background: #0d0d0d;
    color: #fff;
    font-family: JetBrainsMono, monospace;
    padding: .75rem 1rem;
    border-radius: .5rem
}

.blog-html-container pre code {
    color: inherit;
    padding: 0;
    background: none;
    font-size: .8rem
}

.blog-html-container mark {
    background-color: #faf594
}

.blog-html-container img,
.blog-html-container video {
    max-width: 100%;
    height: auto
}

.blog-html-container img.blog-html-container-selectednode,
.blog-html-container video.blog-html-container-selectednode {
    outline: 2px solid #188bf6
}

.blog-html-container div.blog-html-container-selectednode iframe {
    outline: 2px solid #188bf6
}

.blog-html-container blockquote {
    padding-left: 1rem;
    border-left: 2px solid rgba(13, 13, 13, .1)
}

.blog-html-container hr {
    border: none;
    border-top: 2px solid rgba(13, 13, 13, .1);
    margin: 2rem 0
}

.blog-html-container a {
    color: #335dff;
    text-decoration: underline
}

.blog-html-container ul[data-type=taskList] {
    list-style: none;
    padding-left: 24px
}

.blog-html-container ul[data-type=taskList] p {
    margin: 0
}

.blog-html-container ul[data-type=taskList] li {
    display: flex;
    border-radius: .25rem
}

.blog-html-container ul[data-type=taskList] li>label {
    flex: 0 0 auto;
    margin-right: .5rem;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none
}

.blog-html-container ul[data-type=taskList] li>div {
    flex: 1 1 auto
}

.blog-html-container input[type=checkbox] {
    border-radius: 4px;
    width: 1rem;
    height: 1rem
}

.blog-left-arrow {
    margin-right: .5em
}

.blog-left-arrow:before {
    content: "\f060";
    font-family: "Font Awesome 5 Free";
    font-weight: 700;
    font-style: normal
}

.blog-back-button {
    color: #6b7280 !important;
    margin-top: 1em;
    font-size: 13px;
    text-decoration: none !important;
    cursor: pointer;
    display: block
}

.blog-tags {
    padding: 1em 0
}

.blog-tags .tag {
    background-color: #e5e7eb;
    border-radius: 10px;
    padding: 5px 10px;
    font-size: 13px;
    color: #6b7280;
    margin-right: 5px
}

.blog-author-details {
    border-style: solid;
    border-color: #e5e7eb;
    border-left: 1px;
    border-right: 1px
}

.blog-html mark {
    color: inherit !important
}

.more-actions-button-container {
    width: 100%;
    display: flex;
    justify-content: center;
    padding: 1em
}

.more-actions {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 8px 36px;
    gap: 10px;
    min-width: 169px;
    min-height: 32px;
    border-radius: 43px
}

.blog-items.compact .blog-item-box-2 {
    display: flex
}

.blog-items.standard .blog-item-box-2 {
    display: block;
    margin-top: 10px
}

.blog-items.standard .blog-item {
    padding: 1em
}

.hl-blog h1 {
    font-size: 2em !important
}

.hl-blog h2 {
    font-size: 1.5em !important
}

.hl-blog h3 {
    font-size: 1.17em !important
}

.hl-blog h4 {
    font-size: 1em !important
}

.hl-blog h5 {
    font-size: .83em !important
}

.hl-blog h6 {
    font-size: .67em !important
}

.blog-row {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: flex-start
}

.blog-items.standard .blog-column {
    float: left;
    width: 33.33%
}

.blog-items.compact .blog-column {
    float: left;
    width: 100%;
    padding: 1em
}

.blog-items.compact .blog-column .blog-item-texts {
    width: 85%
}

.blog-items.compact .blog-column img {
    width: 15%;
    margin-left: .25em
}

.blog-items.standard .blog-column img {
    width: 100%
}

.blog-item {
    text-decoration: none;
    color: #607179 !important
}

.blog-item-description {
    margin-top: .5em;
    font-size: .875rem;
    cursor: text
}

.empty-blogs {
    text-align: center;
    padding: 1em;
    width: 100%
}

.blog-column img {
    -o-object-fit: cover;
    object-fit: cover;
    max-height: 200px
}

.blog-items.standard .blog-column img,
.blog-items.standard .blog-item-heading,
.more-actions {
    cursor: pointer
}

.blog-item-content {
    padding: 1em
}

.blog-item-texts h3 a,
.blog-item-texts h2 a,
.blog-item-texts p {
    color: #111827 !important
}

.blog-item-texts p {
    margin: 5px 0
}

.blog-item-subtexts span {
    margin-right: 5px;
    color: #556c79;
    font-size: 13px
}

.blog-items.standard .blog-column .blog-column-container {
    border: 1px solid #eee;
    background: #fafbfb
}

.blog-items.standard .blog-column .blog-column-container .blog-item-texts {
    padding: .5em
}

.blog-items.standard .blog-column .blog-column-container:hover {
    border: 1px solid #eee;
    background: #f1f1f1
}

.blog-items-container {
    max-width: 800px;
    width: 100%
}

.blog-column-container {
    height: 100%
}

.hl-blog {
    display: flex;
    justify-content: center
}

.blog-item-heading a {
    text-decoration: none !important
}

.compact-more-button {
    text-decoration: none !important;
    color: #188bf6 !important
}

@media (max-width: 768px) {
    .blog-items.standard .blog-column {
        width: 50%
    }
}

@media (max-width: 650px) {
    .blog-items.compact .blog-column .blog-item-texts {
        width: 70%
    }

    .blog-items.compact .blog-column img {
        width: 30%
    }
}

@media (max-width: 500px) {
    .blog-items.standard .blog-column {
        width: 100%
    }
}

.hl-faq-child-heading {
    cursor: pointer;
    padding: 15px;
    width: 100%;
    border: none;
    outline: none;
    display: flex;
    justify-content: space-between;
    align-items: center
}

.hl-faq-child-head {
    display: flex;
    align-items: center
}

.v-enter-active,
.v-leave-active {
    transition: opacity .2s ease-out
}

.v-enter-from,
.v-leave-to {
    opacity: 0
}

.faq-separated-child {
    margin-bottom: 10px
}

.hl-faq-child-panel img {
    border-radius: 15px;
    cursor: pointer
}

.hl-faq-child-heading-icon.left {
    margin-right: 1em
}

.expand-collapse-all-button {
    font-weight: 400;
    font-size: 12px;
    line-height: 16px;
    color: #3b82f6;
    padding: 5px 15px;
    border: 1px solid #d1d5db;
    border-radius: 15px;
    background-color: transparent;
    margin: 1em 0;
    cursor: pointer
}

.hl-faq-child-panel {
    transition: padding .2s ease
}

.empty-component-min-height[data-v-2f491720] {
    min-height: 100px
}

.c-section>.inner[data-v-0bad29cf] {
    margin: auto;
    display: flex;
    justify-content: center;
    flex-direction: column;
    z-index: 2
}

.c-row>.inner[data-v-0bad29cf] {
    width: 100%;
    display: flex
}

.c-column>.inner[data-v-0bad29cf] {
    display: flex;
    flex-direction: column;
    justify-content: inherit;
    width: 100%;
    height: 100%
}

.c-wrapper[data-v-0bad29cf] {
    position: relative
}

.previewer[data-v-0bad29cf] {
    --vw: 100vh / 100;
    overflow: scroll;
    overflow-y: scroll;
    overflow-x: hidden;
    height: calc(100vh - 170px);
    width: 100%;
    margin: auto
}

.c-element[data-v-0bad29cf] {
    position: relative
}

.c-column[data-v-0bad29cf] {
    flex: 1
}

.c-row[data-v-0bad29cf],
.c-column[data-v-0bad29cf] {
    position: relative
}

p+p[data-v-0bad29cf] {
    margin-top: auto
}

.hl_page-creator--row.active[data-v-0bad29cf] {
    border-color: #188bf6
}

.flip-list-move[data-v-0bad29cf] {
    transition: transform .5s
}

.page-wrapper .sortable-ghost[data-v-0bad29cf]:before {
    position: absolute;
    width: 100%;
    height: 4px;
    top: 50%;
    left: 50%;
    background: #188bf6 !important;
    content: "";
    border-radius: 4px;
    transform: translate(-50%, -50%)
}

.page-wrapper .sortable-ghost[data-v-0bad29cf] {
    position: relative;
    border: none !important
}

.active-drop-area[data-v-0bad29cf]:before {
    content: "";
    position: absolute;
    color: gray;
    font-size: 12px;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    pointer-events: none
}

.active-drop-area[data-v-0bad29cf] {
    border: 1px dashed grey
}

.active-drop-area.is-empty[data-v-0bad29cf] {
    min-height: 60px
}

.empty-component[data-v-0bad29cf] {
    border: 1px dashed #d7dde9;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    min-height: 100px;
    justify-content: center;
    align-items: center;
    display: flex;
    pointer-events: none;
    z-index: 2
}

.empty-component-min-height[data-v-0bad29cf] {
    min-height: 100px;
    pointer-events: none
}

p {
    margin: unset
}

#overlay {
    position: fixed;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 999;
    opacity: 0;
    transition: opacity .3s ease;
    overflow-y: scroll;
    -webkit-overflow-scrolling: touch
}

#overlay.show {
    opacity: 1
}

.popup-body {
    position: absolute;
    min-height: 180px;
    height: auto;
    background-color: #fff;
    top: 10%;
    left: 50%;
    transform: translate(-50%, -100vh);
    z-index: 20;
    transition: transform .25s ease-in-out
}

.popup-body.mobile {
    width: calc(100% - 10px) !important;
    top: 10px
}

.popup-body.show {
    transform: translate(-50%)
}

.closeLPModal {
    position: absolute;
    right: -10px;
    top: -10px;
    cursor: pointer;
    z-index: 21
}

.settingsPModal {
    top: -40px;
    left: 40%;
    position: absolute;
    width: 32px;
    padding: 10px;
    font-size: 18px
}

#faq-overlay {
    position: fixed;
    background: var(--overlay);
    width: 100vw;
    height: 100vh;
    opacity: .8;
    z-index: 1000
}

#faq-popup {
    position: fixed;
    top: 50%;
    left: 50%;
    background: #fff;
    width: 500px;
    height: auto;
    margin-left: -250px;
    margin-top: -250px;
    z-index: 1000
}

#popupclose {
    float: right;
    padding: 10px;
    cursor: pointer
}

.popupcontent {
    width: 100%
}

#button {
    cursor: pointer
}

.mobile #faq-popup {
    left: 5px;
    margin-left: 0;
    width: 98%
}

.h-100 {
    height: 100%
}

@font-face {
    font-family: Magicons;
    src: url(https://stcdn.leadconnectorhq.com/_preview/~assets/icons/Magicons.woff), url(https://stcdn.leadconnectorhq.com/_preview/~assets/icons/Magicons.ttf)
}

.text-white {
    color: #fff
}

.dark {
    background-color: #000
}

.antialiased {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale
}

.spotlight {
    background: linear-gradient(45deg, #00dc82, #36e4da 50%, #0047e1);
    bottom: -30vh;
    filter: blur(20vh);
    height: 40vh
}

.z-10 {
    z-index: 10
}

.right-0 {
    right: 0
}

.left-0 {
    left: 0
}

.fixed {
    position: fixed
}

.text-black {
    --tw-text-opacity: 1;
    color: rgba(0, 0, 0, var(--tw-text-opacity))
}

.overflow-hidden {
    overflow: hidden
}

.min-h-screen {
    min-height: 100vh
}

.font-sans {
    font-family: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, Helvetica Neue, Arial, Noto Sans, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", Segoe UI Symbol, "Noto Color Emoji"
}

.place-content-center {
    place-content: center
}

.grid {
    display: -ms-grid;
    display: grid
}

.bg-white {
    --tw-bg-opacity: 1;
    background-color: rgba(255, 255, 255, var(--tw-bg-opacity))
}

.z-20 {
    z-index: 20
}

.max-w-520px {
    max-width: 520px
}

.text-center {
    text-align: center
}

.mb-8 {
    margin-bottom: 2rem
}

.text-8xl {
    font-size: 6rem;
    line-height: 1
}

.font-medium {
    font-weight: 500
}

.mb-16 {
    margin-bottom: 4rem
}

.leading-tight {
    line-height: 1.25
}

.text-xl {
    font-size: 1.25rem;
    line-height: 1.75rem
}

.font-light {
    font-weight: 300
}

@media (min-width: 640px) {
    .sm-text-10xl {
        font-size: 10rem;
        line-height: 1
    }

    .sm-text-4xl {
        font-size: 2.25rem;
        line-height: 2.5rem
    }

    .sm-px-0 {
        padding-left: 0;
        padding-right: 0
    }

    .sm-px-8 {
        padding-left: 2rem;
        padding-right: 2rem
    }
}