.ts-form .ts-form-group .is-required, .ts-form .ts-form-group small {
    font-size: var(--e-global-typography-text-font-size);
    color: var(--ts-shade-3)
}

.inline-user-location, .ts-shortcut {
    top: 50%;
    transform: translateY(-50%)
}

.elementor-widget-ts-search-form {
    max-width: 100%
}

.ts-form .ts-filter-wrapper .ts-form-group:first-child {
    padding-top: 0
}

.ts-form .ts-filter-wrapper .ts-double-input {
    grid-gap: 0.75rem
}

.quick-search.ts-form .quick-search-keyword, .ts-form .ts-double-input.force-equal .ts-filter, .ts-form form {
    width: 100%
}

.ts-form .ts-form-group {
    flex-direction: column;
    position: relative
}

.quick-search.ts-form .ts-form-group, .ts-form .ts-form-group.ts-no-padding {
    padding: 0
}

.ts-form .ts-form-group > label {
    font-size: var(--e-global-typography-text-font-size);
    padding-bottom: 8px;
    display: flex;
    flex-wrap: wrap;
    text-overflow: ellipsis;
    font-weight: 600;
    overflow: hidden;
    white-space: normal;
    grid-gap: 5px;
    justify-content: space-between
}

.ts-form .ts-form-group > label:empty, .ts-search-portal .ts-form-submit {
    display: none !important
}

.ts-form .ts-form-group.ui-heading-field label {
    font-size: 30px
}

.ts-form .ts-form-group small {
    display: block;
    width: 100%
}

.quick-search.ts-form form-group, .ts-file .ts-select-file, .ts-file-img .ts-file-info, .ts-filter-wrapper .ts-filter > span:empty, .ts-form .ts-form-group small:empty, .ts-form-submit.ts-form-group:empty {
    display: none
}

.quick-search.ts-form, .ts-file.selected .ts-select-file, .ts-filter, .ts-filter-wrapper .ts-filter > span, .ts-form .ts-filter > span, .ts-form input > span, .ts-form select > span, .ts-form textarea > span, .ts-input-icon > span {
    display: flex
}

.ts-form textarea {
    max-width: 100%;
    min-width: 100%;
    white-space: pre-wrap;
    line-height: normal
}

.ts-file-info code, .ts-filter {
    text-overflow: ellipsis;
    white-space: nowrap
}

.ts-form .ts-form-group .ts-filter, .ts-form .ts-form-group input, .ts-form .ts-form-group select, .ts-form .ts-form-group textarea {
    border: 1px solid #d2d5db;
    border-radius: .375rem;
    background: #fff
}

.ts-form .ts-form-group .ts-filter.ts-filled, .ts-form .ts-form-group .ts-filter:focus, .ts-form .ts-form-group input.ts-filled, .ts-form .ts-form-group input:focus, .ts-form .ts-form-group select.ts-filled, .ts-form .ts-form-group select:focus, .ts-form .ts-form-group textarea.ts-filled, .ts-form .ts-form-group textarea:focus {
    outline: 0
}

.ts-form .ts-form-group .ts-filter.ts-filled .ts-filter-text, .ts-form .ts-form-group input.ts-filled .ts-filter-text, .ts-form .ts-form-group select.ts-filled .ts-filter-text, .ts-form .ts-form-group textarea.ts-filled .ts-filter-text {
    color: var(--ts-shade-1)
}

.ts-form .ts-form-group .ts-filter:hover, .ts-form .ts-form-group input:hover, .ts-form .ts-form-group select:hover, .ts-form .ts-form-group textarea:hover {
    border-color: var(--ts-shade-3)
}

.ts-form .ts-filter, .ts-form input, .ts-form select, .ts-form textarea {
    font-size: 14px;
    border-radius: 10px;
    padding: 16px;
    background: var(--ts-shade-6);
    color: var(--ts-shade-1);
    box-shadow: none;
    transition: background .2s, color .2s, border-color .2s;
    text-overflow: ellipsis;
    outline: 0;
    -moz-appearance: none;
    -webkit-appearance: none;
    width: 100%;
    border: 1px solid #e5e7eb
}

.wpcf7-form .ts-form input[type=submit] {
    border-radius: 6px;
    background: var(--ts-accent-1);
    color: #fff;
    font-size: 14px;
    font-weight: 700
}

.ts-form .ts-filter, .ts-form input, .ts-form select {
    height: 48px;
    min-width: 100px;
}

.ts-form .ts-filter::-webkit-input-placeholder, .ts-form input::-webkit-input-placeholder, .ts-form select::-webkit-input-placeholder, .ts-form textarea::-webkit-input-placeholder {
    color: var(--ts-shade-2)
}

.ts-form .ts-filter::-moz-placeholder, .ts-form input::-moz-placeholder, .ts-form select::-moz-placeholder, .ts-form textarea::-moz-placeholder {
    color: var(--ts-shade-2)
}

.ts-form .ts-filter:-ms-input-placeholder, .ts-form input:-ms-input-placeholder, .ts-form select:-ms-input-placeholder, .ts-form textarea:-ms-input-placeholder {
    color: var(--ts-shade-2)
}

.ts-form .ts-filter:-moz-placeholder, .ts-form input:-moz-placeholder, .ts-form select:-moz-placeholder, .ts-form textarea:-moz-placeholder {
    color: var(--ts-shade-2)
}

div.ts-filter {
    cursor: pointer;
    min-width: 0
}

.quick-search.ts-form .ts-filter-text, .ts-filter.ts-popup-target {
    -webkit-user-select: none;
    -moz-user-select: none;
    user-select: none
}

.elementor-editor-active .ts-filter-toggle, .ts-filter-text {
    pointer-events: none
}

.ts-form .ts-form-group.ui-heading > label {
    padding-bottom: 0 !important;
    font-size: 18px
}

.onoffswitch {
    position: relative;
    width: 42px;
    min-width: 42px;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none
}

.onoffswitch .onoffswitch-checkbox {
    position: absolute;
    opacity: 0;
    pointer-events: none;
    height: auto !important
}

.onoffswitch .onoffswitch-checkbox:checked + .onoffswitch-label {
    background: var(--ts-accent-1);
    border-color: var(--ts-accent-1)
}

.onoffswitch .onoffswitch-checkbox:checked + .onoffswitch-label:before {
    border-color: var(--ts-accent-1);
    background: #fff
}

.onoffswitch .onoffswitch-label {
    display: block;
    overflow: hidden;
    cursor: pointer;
    height: 26px;
    padding: 0;
    line-height: 21px;
    border-radius: 36px;
    transition: background-color .14s ease-in
}

.onoffswitch .onoffswitch-label:before {
    content: "";
    display: block;
    width: 18px;
    height: 18px;
    margin: 0;
    background: #fff;
    position: absolute;
    top: 4px;
    bottom: 0;
    right: 20px;
    border-radius: 36px;
    transition: .3s cubic-bezier(0, .23, .29, 1)
}

.onoffswitch-checkbox:checked + .onoffswitch-label:before {
    right: 4px
}

.ts-input-icon {
    position: relative;
    align-items: center;
    width: 100%
}

.ts-input-icon > i, .ts-input-icon > span > i {
    font-size: 20px;
    color: var(--ts-shade-3)
}

.ts-input-icon > i, .ts-input-icon > span, .ts-input-icon > svg {
    position: absolute;
    right: 15px
}

.ts-input-icon > img, .ts-input-icon > span > svg, .ts-input-icon > svg {
    width: 20px;
    height: 20px;
    margin-right: 10px;
    -o-object-fit: contain;
    object-fit: contain;
    fill: var(--ts-shade-3);
    transition: color .3s
}

.ts-input-icon > select {
    padding-left: 47px
}

.ts-form .ts-form-group .ts-filter.ts-filled {
    border-color: var(--ts-accent-1)
}

.ts-form .bg-primary_red-100 .ts-form-group .ts-filter.ts-filled {
    border-color: var(--e-global-color-accent-negative)
}

.ts-filter.ts-filled i, .ts-filter.ts-filled svg {
    color: var(--ts-accent-1);
    fill: var(--ts-accent-1)
}

.ts-form .ts-form-group .ts-filter.ts-filled .ts-filter-text {
    color: var(--ts-accent-1);
    font-weight: 600
}

.ts-form .bg-primary_red-100 .ts-form-group .ts-filter.ts-filled .ts-filter-text {
    color: var(--e-global-color-accent-negative)
}


.ts-selected-count {
    position: absolute;
    right: 15px;
    background: #e3e3e3;
    width: 25px;
    font-weight: 600;
    color: #525a6e;
    height: 25px;
    font-size: 13px;
    border-radius: 50%;
    align-items: center;
    justify-content: center
}

.inline-user-location {
    position: absolute;
    right: 10px
}

.pick-file-input, .ts-file {
    position: relative;
    aspect-ratio: 4/3
}

.ts-stepper-input {
    flex-wrap: nowrap !important;
    justify-content: space-between;
    align-items: center
}

.ts-stepper-input input {
    border: none !important;
    background: 0 0 !important;
    font-size: 18px;
    text-align: center;
    max-width: 120px;
    padding: 0 !important;
    min-width: auto !important;
    height: auto !important
}

.ts-stepper-input .ts-icon-btn {
    flex-shrink: 0
}

.inline-multilevel {
    overflow: hidden
}

.inline-terms-wrapper .flexify ~ .inline-multilevel {
    padding-top: 10px
}

.range-slider-wrapper .range-value {
    font-size: 14px;
    padding-bottom: 15px
}

.range-slider-wrapper .range-slider {
    margin-bottom: 15px;
    width: 95%;
    margin-left: auto;
    margin-right: auto
}

.ts-form-group input::-webkit-inner-spin-button, .ts-form-group input::-webkit-outer-spin-button {
    -webkit-appearance: none;
    margin: 0
}

.ts-form-group input[type=number] {
    -moz-appearance: textfield
}

.ts-term-heading p {
    color: #a0a4ad;
    padding: 10px;
    font-size: var(--e-global-typography-text-font-size)
}

.ts-form-submit.ts-form-group {
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: flex-end;
    grid-gap: 10px
}

.ts-form-submit.ts-form-group .ts-btn {
    height: 48px;
    width: auto
}

.ts-form-submit.ts-form-group button {
    border: none;
    cursor: pointer
}

.ts-form-submit.ts-form-group .ts-btn-2 {
    flex-grow: 1
}

.ts-form-submit.ts-form-group .ts-form-reset.resetting i, .ts-form-submit.ts-form-group .ts-form-reset.resetting svg {
    animation-name: vx-rotate;
    animation-duration: .5s;
    transition-timing-function: cubic-bezier(.1, .7, 1, .1)
}

@keyframes vx-rotate {
    0% {
        transform: rotate(0)
    }
    to {
        transform: rotate(180deg)
    }
}

.ts-filter {
    flex-wrap: nowrap;
    align-items: center;
    grid-gap: 10px
}

.ts-filter i {
    font-size: 22px;
    color: var(--ts-shade-1);
    transition: color .3s
}

.ts-filter img, .ts-filter svg {
    width: 22px;
    height: 22px;
    min-width: 22px;
    -o-object-fit: contain;
    object-fit: contain;
    transition: fill .3s
}

.ts-filter .ts-filter-text {
    text-overflow: ellipsis;
    overflow: hidden;
    transition: color .3s
}

.ts-filter-wrapper .ts-filter {
    user-select: none;
    -moz-user-select: none;
    -webkit-user-select: none;
    -ms-user-select: none
}

.ts-form .ts-double-input {
    justify-content: space-between;
    flex-wrap: nowrap;
    width: 100%;
    grid-gap: 15px
}

.ts-form .ts-double-input.force-equal {
    display: grid;
    grid-template-columns:1fr 1fr
}

.ts-form .ts-double-input .ts-filter {
    width: auto;
    flex-grow: 1
}

.pick-file-input a, .ts-file-info {
    color: var(--ts-shade-2);
    font-size: var(--e-global-typography-text-font-size);
    text-align: center;
    justify-content: center;
    width: 100%;
    height: 100%
}

.ts-booking-date .is-endrange .pika-button, .ts-booking-date .is-startrange .pika-button {
    background: var(--ts-accent-1);
    color: #fff;
    font-weight: 600
}

.ts-booking-date .is-inrange .pika-button {
    background: var(--ts-shade-5);
    color: var(--ts-shade-1);
    font-weight: 600
}

.ts-booking-date .pika-button {
    margin: 1px auto
}

.ts-booking-date .is-disable .pika-button {
    color: #85415c;
    text-decoration: inherit
}

.ts-booking-date .is-unavailable .pika-button {
    background: #f7f3f4;
    color: #a4174f
}

.ts-booking-date .pika-table th {
    padding-bottom: 15px
}

.ts-booking-date.ts-booking-date-range .pika-single {
    display: grid;
    grid-gap: 15px;
    grid-template-columns:1fr 1fr
}

.ts-booking-date.ts-booking-date-single .is-selected .pika-button {
    background: var(--e-global-color-accent);
    color: #fff;
    font-weight: 600
}

.ts-booking-range-wrapper .ts-field-popup {
    min-width: 660px
}

.pick-file-input {
    border-radius: 8px;
    transition: .15s;
    border: 1px dashed var(--ts-shade-3)
}

.pick-file-input:hover {
    border-color: var(--ts-shade-2)
}

.pick-file-input a {
    position: absolute;
    display: flex;
    flex-direction: column;
    align-items: center
}

.pick-file-input a i {
    font-size: 28px;
    color: var(--ts-shade-2)
}

.pick-file-input a svg {
    width: 28px;
    height: 28px;
    -o-object-fit: contain;
    object-fit: contain;
    fill: var(--ts-shade-2)
}

.pick-file-input a i, .pick-file-input a svg {
    transition: color .3s;
    margin-bottom: 10px
}

.ts-file-list {
    display: grid;
    grid-gap: 15px;
    margin-bottom: 15px;
    grid-template-columns:repeat(3, 1fr)
}

.ts-file {
    background-size: cover;
    background-position: 50%;
    background-color: var(--ts-shade-6);
    border-radius: 8px;
    display: grid;
    width: 100%;
    overflow: hidden
}

.ts-file-info {
    position: absolute;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 15px
}

.ts-file-info code {
    font-family: inherit;
    overflow: hidden;
    width: 100%
}

.ts-file-info i {
    font-size: 28px;
    margin-bottom: 10px
}

.ts-remove-file {
    font-size: 20px;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    justify-content: center;
    display: flex;
    align-items: center;
    background: #fff;
    color: #525a6e;
    box-shadow: 0 1px 6px rgba(0, 0, 0, .1);
    position: absolute;
    bottom: 10px;
    right: 10px;
    z-index: 1
}

.ts-remove-file svg {
    width: 18px;
    height: 18px
}

.ts-file.selected:after {
    position: absolute;
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background: rgba(0, 0, 0, .4)
}

.ts-search-btn {
    position: relative
}

.ts-search-btn.ts-loading-btn {
    color: transparent !important
}

.ts-search-btn.ts-loading-btn i, .ts-search-btn.ts-loading-btn svg {
    opacity: 0
}

.ts-search-btn .ts-loader-wrapper {
    position: absolute;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center
}

.ts-save-changes span.ts-loader, .ts-search-btn span.ts-loader {
    border-color: #fff #fff hsla(0, 0%, 100%, .2784313725);
    width: 20px;
    height: 20px;
    border-width: 2px
}

.ts-search-portal .ts-field-popup {
    max-width: 600px
}

.ts-search-portal .ts-popup-content-wrapper {
    max-height: 600px
}

.ts-search-portal .ts-popup-root {
    position: fixed !important
}

.ts-search-portal .elementor-element.ts-form {
    width: unset !important;
    max-width: unset !important
}

.ts-filter-toggle .ts-filter-count {
    background: #fff;
    color: #fff;
    background: var(--ts-accent-1);
    width: 22px;
    height: 22px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    text-transform: uppercase;
    position: absolute;
    font-weight: 600;
    right: 10px
}

input[type=time]::-webkit-calendar-picker-indicator {
    background: 0 0
}

.container-checkbox, .container-radio {
    display: flex;
    align-items: center;
    position: relative;
    line-height: normal;
    cursor: pointer;
    -webkit-user-select: none;
    -moz-user-select: none;
    user-select: none;
    color: #000;
    font-size: var(--e-global-typography-text-font-size)
}

.container-checkbox.ts-three-columns, .container-radio.ts-three-columns {
    width: 50%
}

.container-checkbox p, .container-radio p {
    margin: 0 0 0 12px;
    font-size: var(--e-global-typography-text-font-size);
    color: var(--ts-shade-2)
}

.container-checkbox input, .container-radio input {
    position: absolute;
    opacity: 0;
    cursor: pointer;
    z-index: -10
}

.container-checkbox input:checked ~ .checkmark, .container-radio input:checked ~ .checkmark {
    background-color: var(--ts-accent-1);
    border-color: var(--ts-accent-1)
}

.container-checkbox input:checked ~ .checkmark:after, .container-radio input:checked ~ .checkmark:after {
    opacity: 1
}

.container-checkbox .checkmark, .container-radio .checkmark {
    height: 18px;
    width: 18px;
    min-width: 18px;
    border: 1.5px solid var(--ts-shade-4);
    border-radius: 5px;
    transition: .15s;
    display: flex;
    align-items: center;
    justify-content: center
}

.container-checkbox .checkmark:after, .container-radio .checkmark:after {
    opacity: 0;
    content: "";
    display: inline-block;
    transform: rotate(45deg);
    height: 9px;
    width: 4px;
    border-bottom: 2px solid #fff;
    border-right: 2px solid #fff;
    position: relative;
    top: -1px
}

body.rtl .container-checkbox .checkmark:after, body.rtl .container-radio .checkmark:after, body.rtl .ts-checkbox-container .checkmark:after {
    transform: rotate(-45deg) scaleX(-1)
}

body.rtl .noUi-horizontal .noUi-origin {
    right: 0;
    left: auto
}

body.rtl .noUi-horizontal .noUi-handle {
    right: -10px;
    left: auto
}

.container-radio .checkmark {
    border-radius: 50%
}

.ts-filter-presets .ts-filled {
    background: #fff;
    border: 2px solid var(--e-global-color-accent)
}

@media (max-width: 767px) {
    .ts-booking-date.ts-booking-date-range .pika-single {
        grid-template-columns:1fr
    }
}

.ts-shortcut {
    background: var(--ts-shade-5);
    position: absolute;
    color: var(--ts-shade-2);
    right: 10px;
    padding: 7px 10px;
    border-radius: 5px;
    font-size: 12px;
    text-transform: uppercase;
    -webkit-user-select: none;
    -moz-user-select: none;
    user-select: none
}

@media (max-width: 1024px) {
    .ts-shortcut {
        display: none !important
    }
}