/*
Generated time: April 17, 2026 11:27
This file was created by the app developer. Feel free to contact the original developer with any questions. It was minified (compressed) by AVADA. AVADA do NOT own this script.
*/
.hidden {
    display: none !important
}

.hidden,
.hidden * {
    animation-play-state: paused !important
}

.available-service-section__skeleton-card :empty {
    display: block !important
}

.available-service-section__skeleton {
    width: 100%
}

.available-service-section__skeleton-carousel.swiper {
    padding: 14px 0 12px 20px
}

.available-service-section__skeleton-carousel:not(.swiper-initialized) .swiper-wrapper {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: calc((100% - 16px * 0.4)/ 1.4);
    gap: 16px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 16px
}

.available-service-section__skeleton-carousel:not(.swiper-initialized) .swiper-wrapper::-webkit-scrollbar {
    display: none
}

.available-service-section__skeleton-carousel:not(.swiper-initialized) .swiper-wrapper {
    -ms-overflow-style: none;
    scrollbar-width: none
}

.available-service-section__skeleton-carousel:not(.swiper-initialized) .swiper-slide {
    scroll-snap-align: start;
    min-width: 0
}

.available-service-section__skeleton-card {
    height: 100%;
    display: flex;
    flex-direction: column;
    border-radius: 16px;
    background-color: #fff;
    box-shadow: 0 4px 14px rgba(0, 0, 0, .06);
    overflow: hidden;
    animation: skeleton-pulse 1.5s ease-in-out infinite
}

.available-service-section__skeleton-header {
    width: 100%;
    min-height: 154px;
    padding: 20px 25px;
    background-color: #f3f8ff;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    box-sizing: border-box
}

.available-service-section__skeleton-image {
    width: 54px;
    height: 54px;
    background: linear-gradient(90deg, #e0e0e0 25%, #d0d0d0 50%, #e0e0e0 75%);
    background-size: 200% 100%;
    border-radius: 4px;
    animation: skeleton-shimmer 1.5s infinite
}

.available-service-section__skeleton-title {
    width: 60%;
    height: 22px;
    background: linear-gradient(90deg, #e0e0e0 25%, #d0d0d0 50%, #e0e0e0 75%);
    background-size: 200% 100%;
    border-radius: 4px;
    animation: skeleton-shimmer 1.5s infinite
}

.available-service-section__skeleton-body {
    display: flex;
    flex-direction: column;
    gap: 0
}

.available-service-section__skeleton-included {
    padding: 16px 20px;
    display: flex;
    flex-direction: column;
    gap: 12px
}

.available-service-section__skeleton-included-heading {
    width: 40%;
    height: 14px;
    background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
    background-size: 200% 100%;
    border-radius: 4px;
    animation: skeleton-shimmer 1.5s infinite
}

.available-service-section__skeleton-included-list {
    display: flex;
    flex-direction: column;
    gap: 10px
}

.available-service-section__skeleton-included-item {
    width: 100%;
    height: 20px;
    background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
    background-size: 200% 100%;
    border-radius: 4px;
    animation: skeleton-shimmer 1.5s infinite
}

.available-service-section__skeleton-view-details {
    width: 30%;
    height: 14px;
    background: linear-gradient(90deg, #e0e0e0 25%, #d0d0d0 50%, #e0e0e0 75%);
    background-size: 200% 100%;
    border-radius: 4px;
    animation: skeleton-shimmer 1.5s infinite;
    align-self: flex-start
}

.available-service-section__skeleton-pricing {
    padding: 15px 24px;
    border-top: 1px solid #ededed;
    display: flex;
    flex-direction: column;
    gap: 10px
}

.available-service-section__skeleton-price-wrapper {
    display: flex;
    align-items: center;
    gap: 4px;
    flex-wrap: wrap
}

.available-service-section__skeleton-price {
    width: 80px;
    height: 20px;
    background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
    background-size: 200% 100%;
    border-radius: 4px;
    animation: skeleton-shimmer 1.5s infinite
}

.available-service-section__skeleton-discount-badge {
    width: 60px;
    height: 20px;
    background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
    background-size: 200% 100%;
    border-radius: 4px;
    animation: skeleton-shimmer 1.5s infinite
}

.available-service-section__skeleton-booking-advance {
    width: 50%;
    height: 16px;
    background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
    background-size: 200% 100%;
    border-radius: 4px;
    animation: skeleton-shimmer 1.5s infinite
}

.available-service-section__skeleton-button {
    width: 100%;
    height: auto;
    min-height: 40px;
    margin-top: 0;
    background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
    background-size: 200% 100%;
    border-radius: 8px;
    animation: skeleton-shimmer 1.5s infinite
}

@keyframes skeleton-pulse {

    0%,
    100% {
        opacity: 1
    }

    50% {
        opacity: .8
    }
}

@keyframes skeleton-shimmer {
    0% {
        background-position: -200% 0
    }

    100% {
        background-position: 200% 0
    }
}

@media screen and (min-width:769px) {
    .available-service-section__skeleton-carousel.swiper {
        padding: 30px 0 30px 24px
    }

    .available-service-section__skeleton-carousel:not(.swiper-initialized) .swiper-wrapper {
        grid-auto-columns: calc((100% - 16px * 1.5)/ 2.5)
    }

    .available-service-section__skeleton-image {
        width: 62px;
        height: 62px
    }

    .available-service-section__skeleton-pricing {
        gap: 10px
    }
}

@media screen and (min-width:1024px) {
    .available-service-section__skeleton-carousel:not(.swiper-initialized) .swiper-wrapper {
        grid-auto-columns: calc((100% - 16px * 2.5)/ 3.5)
    }
}

@media screen and (min-width:1200px) {
    .available-service-section__skeleton-carousel:not(.swiper-initialized) .swiper-wrapper {
        grid-auto-columns: calc((100% - 16px * 3.2)/ 4.2)
    }
}

.available-service-section__inner {
    display: flex;
    flex-direction: column;
    gap: 24px
}

.available-service-section__header-wrapper {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: start;
    gap: 10px
}

.available-service-section__toggle-group {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    width: 100%
}

.available-service-section__toggle {
    padding: 10px 24px;
    border-radius: 8px;
    border: 1px solid #ed2427;
    background-color: #fff;
    color: #ed2427;
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
    transition: background-color .2s ease, color .2s ease, box-shadow .2s ease;
    box-shadow: 0 0 2px 0 #ed2427;
    line-height: 1.375
}

.available-service-section__toggle.is-active {
    background-color: #ed2427;
    color: #fff
}

.available-service-section__toggle:hover {
    background-color: #fbe9e7;
    box-shadow: 0 2px 9px 0 #ed2427
}

.available-service-section__toggle.is-active:hover {
    background-color: #ed2427;
    color: #fff
}

.available-service-section__filters {
    display: flex;
    flex-direction: column;
    gap: 12px;
    width: 100%;
    padding: 20px 20px 0 20px
}

.available-service-section__filters-label {
    display: flex;
    flex-direction: column
}

.available-service-section__filters-label p {
    font-size: 16px;
    font-weight: 700;
    line-height: 1.35;
    color: #183761;
    text-transform: uppercase;
    letter-spacing: 0
}

.available-service-section__filters-label-mandatory {
    color: #ed2427;
    font-size: 12px;
    font-weight: 700;
    line-height: 1.5;
    text-transform: none
}

.available-service-section__filters-row {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 10px
}

.available-service-section__select-wrapper {
    position: relative;
    flex: 1;
    display: flex
}

@media screen and (max-width:768px) {
    .available-service-section__filters-row {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 10px
    }

    .available-service-section__select-wrapper--species {
        order: 1
    }

    .available-service-section__select-wrapper--age {
        order: 2
    }

    .available-service-section__select-wrapper--breed {
        order: 3;
        grid-column: 1/-1
    }
}

.available-service-section__select-label {
    display: block;
    margin-bottom: 4px;
    font-size: 13px;
    font-weight: 600;
    color: #183761;
    display: none
}

.available-service-section__select {
    position: absolute;
    opacity: 0;
    pointer-events: none;
    width: 0;
    height: 0
}

.available-service-section__custom-select {
    position: relative;
    width: 100%
}

.available-service-section__select-trigger {
    width: 100%;
    min-width: 100px;
    height: 36px;
    padding: 12px 16px;
    border-radius: 6px;
    border: 1px solid #777;
    background-color: #fff;
    display: flex;
    align-items: center;
    justify-content: space-between;
    cursor: pointer;
    font-size: 12px;
    font-weight: 400;
    color: #000;
    text-align: left;
    transition: border-color .2s ease;
    white-space: nowrap;
    overflow: hidden
}

.available-service-section__select-trigger span {
    font-size: 12px;
    line-height: 1;
    font-weight: 700
}

.available-service-section__select-trigger:hover {
    border-color: #777
}

.available-service-section__select-text {
    flex: 1;
    color: #777;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis
}

.available-service-section__select-text.has-value {
    color: #000
}

.available-service-section__select-arrow {
    width: 24px;
    height: 24px;
    flex-shrink: 0;
    transition: transform .2s ease
}

.available-service-section__custom-select.is-open .available-service-section__select-arrow {
    transform: scaleY(-1)
}

.available-service-section__select-dropdown {
    position: absolute;
    top: 50px;
    left: 0;
    right: 0;
    min-width: 160px;
    background-color: #fff;
    border-radius: 6px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, .15);
    z-index: 1000;
    max-height: 300px;
    overflow-y: auto;
    opacity: 0;
    transform: translateY(-6px);
    pointer-events: none;
    visibility: hidden;
    transition: opacity .2s ease, transform .2s ease, visibility 0s linear .2s
}

.available-service-section__select-dropdown::-webkit-scrollbar {
    width: 6px
}

.available-service-section__select-dropdown::-webkit-scrollbar-track {
    background: #f5f5f5;
    border-radius: 3px
}

.available-service-section__select-dropdown::-webkit-scrollbar-thumb {
    background: #cfd8dc;
    border-radius: 3px
}

.available-service-section__select-dropdown::-webkit-scrollbar-thumb:hover {
    background: #90a4ae
}

.available-service-section__custom-select.is-open .available-service-section__select-dropdown {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
    visibility: visible;
    transition: opacity .2s ease, transform .2s ease, visibility 0s linear 0s
}

.available-service-section__select-search {
    padding: 8px;
    border-bottom: 1px solid #e0e0e0
}

.available-service-section__select-search-input {
    width: 100%;
    padding: 8px 12px;
    font-size: 14px;
    border: 1px solid #e0e0e0;
    border-radius: 4px;
    background-color: #fff;
    color: #000;
    outline: 0;
    box-shadow: none
}

.available-service-section__select-search-input:active,
.available-service-section__select-search-input:focus {
    outline: 0;
    box-shadow: none;
    border-color: #e0e0e0
}

.available-service-section__select-list {
    list-style: none;
    margin: 0;
    padding: 0
}

.available-service-section__select-item {
    padding: 8px 16px;
    font-size: 14px;
    font-weight: 700;
    color: #000;
    cursor: pointer;
    transition: background-color .2s ease
}

.available-service-section__select-item:hover {
    background-color: #f3f8ff
}

.available-service-section__select-item:active,
.available-service-section__select-item:focus {
    outline: 0;
    background-color: #f3f8ff
}

.available-service-section__select-item.is-selected {
    background-color: #f3f8ff;
    font-weight: 700;
    color: #183761
}

.available-service-section__select-item--no-results {
    color: #999;
    font-style: italic;
    cursor: default
}

.available-service-section__select-item--no-results:hover {
    background-color: transparent
}

.available-service-section__search-input {
    width: 100%;
    padding: 8px 16px;
    border: none;
    border-bottom: 1px solid #e0e0e0;
    font-size: 14px;
    outline: 0;
    background-color: #fff;
    box-sizing: border-box
}

.available-service-section__search-input:focus {
    outline: 0;
    box-shadow: none;
    border: none
}

.available-service-section__search-input::placeholder {
    color: #999
}

.available-service-section__products-wrapper {
    margin-top: 8px;
    background-color: #e7f1ff;
    border-radius: 8px
}

.available-service-section__error-message {
    display: none
}

.available-service-section__carousel.swiper {
    padding: 14px 0 12px 20px
}

.available-service-section__carousel .swiper-slide {
    height: auto;
    padding-right: 12px
}

.available-service-section__carousel .swiper-pagination {
    bottom: 0
}

.available-service-section__carousel .swiper-button-next,
.available-service-section__carousel .swiper-button-prev {
    color: #183761
}

.available-service-section__carousel:not(.swiper-initialized) .swiper-wrapper {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: calc((100% - 16px * 0.4)/ 1.4);
    gap: 16px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 16px
}

.available-service-section__carousel:not(.swiper-initialized) .swiper-wrapper::-webkit-scrollbar {
    display: none
}

.available-service-section__carousel:not(.swiper-initialized) .swiper-wrapper {
    -ms-overflow-style: none;
    scrollbar-width: none
}

.available-service-section__carousel:not(.swiper-initialized) .swiper-slide {
    scroll-snap-align: start;
    min-width: 0
}

.available-service-section__carousel-empty {
    padding: 24px 16px;
    border-radius: 12px;
    background-color: #fff;
    text-align: center;
    font-size: 14px;
    color: #607d8b
}

@media screen and (min-width:950px) {
    .available-service-section__inner {
        gap: 30px
    }

    .available-service-section__header-wrapper {
        flex-direction: row;
        justify-content: space-between;
        align-items: center
    }

    .available-service-section__toggle-group {
        width: auto
    }

    .available-service-section__toggle {
        padding: 11px 24px
    }

    .available-service-section__filters-label p {
        font-size: 20px
    }

    .available-service-section__filters-label-mandatory {
        font-size: 14px
    }

    .available-service-section__filters {
        flex-direction: row;
        padding: 28px 24px 0 24px
    }

    .available-service-section__carousel.swiper {
        padding: 30px 0 15px 24px
    }

    .available-service-section__carousel .swiper-slide {
        padding-right: 20px
    }

    .available-service-section__select-trigger {
        min-width: 200px;
        font-size: 16px;
        padding: 12px 16px;
        height: 44px
    }

    .available-service-section__select-trigger span {
        font-size: 16px;
        font-weight: 700
    }

    .available-service-section__select-dropdown {
        min-width: 220px
    }

    .available-service-section__carousel:not(.swiper-initialized) .swiper-wrapper {
        grid-auto-columns: calc((100% - 16px * 1.5)/ 2.5)
    }
}

@media screen and (min-width:1024px) {
    .available-service-section__carousel:not(.swiper-initialized) .swiper-wrapper {
        grid-auto-columns: calc((100% - 16px * 2.5)/ 3.5)
    }
}

@media screen and (min-width:1200px) {
    .available-service-section__carousel:not(.swiper-initialized) .swiper-wrapper {
        grid-auto-columns: calc((100% - 16px * 3.2)/ 4.2)
    }
}

@media screen and (max-width:768px) {
    .available-service-section__carousel.single-card {
        padding-left: 0
    }

    .available-service-section__carousel.single-card .swiper-wrapper {
        justify-content: center
    }
}

.available-service-card {
    height: 100%;
    display: flex;
    flex-shrink: 0;
    flex-direction: column;
    border-radius: 16px;
    background-color: #fff;
    box-shadow: 0 4px 14px rgba(0, 0, 0, .06);
    overflow: hidden;
    contain: layout style
}

.available-service-card__image {
    width: 100%;
    height: 154px;
    max-height: 154px;
    padding: 20px 25px;
    background-color: #f3f8ff;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    box-sizing: border-box
}

.available-service-card__image img {
    width: 140px;
    height: 140px;
    object-fit: contain;
    display: block
}

.available-service-card__title {
   
    font-weight: 800;
    font-style: normal;
    font-size: 16px;
    line-height: 22px;
    letter-spacing: 0;
    text-align: center;
    text-transform: uppercase;
    color: #183761;
    margin: 8px 0 0
}

.available-service-card__body {
    display: flex;
    flex-direction: column;
    gap: 0;
    justify-content: space-between;
    align-items: stretch;
    flex: 1
}

.available-service-card__included-container {
    padding: 14px 12px
}

.available-service-card__included {
    display: flex;
    flex-direction: column;
    gap: 12px
}

.available-service-card__included-heading {
    font-size: 1.5rem;
    font-weight: 600;
    color: #181d27;
    margin: 0;
    line-height: 1.5
}

.available-service-card__included-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 10px
}

.available-service-card__included-item {
    display: flex;
    align-items: center;
    gap: 5px;
    cursor: pointer;
    transition: opacity .2s ease
}

.available-service-card__included-item:hover {
    opacity: .8
}

.available-service-card__check-icon {
    flex-shrink: 0;
    width: 21px;
    height: 21px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%
}

.available-service-card__service-name {
    flex: 1;
    font-size: 13px;
    font-weight: 400;
    color: #50535b;
    display: flex;
    align-items: center;
    gap: 4px;
    justify-content: flex-start;
    line-height: 1.5
}

.available-service-card__arrow-icon {
    flex-shrink: 0;
    width: 16px;
    height: 16px;
    display: flex;
    align-items: center;
    justify-content: center
}

.available-service-card__view-details {
    font-size: 12px;
    font-weight: 500;
    color: #4a7ec4;
    text-decoration: underline;
    align-self: flex-start;
    cursor: pointer;
    transition: opacity .2s ease
}

.available-service-card__view-details:hover {
    opacity: .8;
    text-decoration: underline
}

.available-service-card__pricing-container {
    padding: 15px 24px;
    border-top: 1px solid #ededed
}

.available-service-card__pricing {
    display: flex;
    flex-direction: column;
    gap: 6px
}

.available-service-card__price-wrapper {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 4px
}

.available-service-card__price-wrapper-inner {
    display: flex;
    align-items: center;
    justify-content: start;
    flex-wrap: wrap;
    gap: 4px
}

.available-service-card__price-discounted-price {
    font-size: 14px;
    font-weight: 700;
    color: #000;
    line-height: 1.2
}

.available-service-card__price-discounted-compare-price {
    font-size: 12px;
    font-weight: 400;
    color: #777;
    line-height: 1.2;
    text-decoration: line-through
}

.available-service-card__discount-badge {
    padding: 4px 10px;
    background-color: #ed2427;
    color: #fff;
    font-size: 12px;
    line-height: 1;
    font-weight: 700;
    border-radius: 4px;
    white-space: nowrap
}

.available-service-card__booking-advance {
    font-size: 14px;
    font-weight: 600;
    color: #181d27;
    line-height: 1.5
}

.available-service-card__book-button {
    width: 100%;
    padding: 6px 16px;
    border-radius: 8px;
    border: 1px solid #ed2427;
    background-color: #fff;
    color: #ed2427;
    font-size: 16px;
    font-weight: 600;
    line-height: 1.5;
    text-transform: uppercase;
    text-align: center;
    cursor: pointer;
    transition: background-color .2s ease, color .2s ease
}

.available-service-card__book-button:hover {
    background-color: #ed2427;
    color: #fff
}

@media screen and (min-width:769px) {
    .available-service-card__title {
        font-size: 20px
    }

    .available-service-card__check-icon {
        height: 25px;
        width: 25px
    }

    .available-service-card__included-item {
        gap: 5px
    }

    .available-service-card__view-details {
        font-size: 14px
    }

    .available-service-card__price-discounted-price {
        font-size: 16px
    }

    .available-service-card__pricing {
        gap: 6px
    }
}

.available-service-popup {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    z-index: 9999 !important;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 20px;
    overflow: hidden;
    pointer-events: none;
    margin: 0 !important
}

.available-service-popup.is-open {
    display: flex;
    pointer-events: auto
}

.available-service-popup__overlay {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    background-color: rgba(0, 0, 0, .2);
    cursor: pointer;
    z-index: 1;
    margin: 0 !important;
    display: flex !important
}

.available-service-popup__content {
    position: relative;
    background-color: #fff;
    border-radius: 16px;
    max-width: 100%;
    width: 100%;
    max-height: 85vh;
    overflow-y: auto;
    box-shadow: 0 8px 32px rgba(0, 0, 0, .2);
    z-index: 2;
    animation: popupFadeIn .3s ease
}

@keyframes popupFadeIn {
    from {
        opacity: 0;
        transform: scale(.95)
    }

    to {
        opacity: 1;
        transform: scale(1)
    }
}

.available-service-popup__close {
    position: absolute;
    top: 18px;
    right: 18px;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: transparent;
    border: none;
    cursor: pointer;
    z-index: 2;
    padding: 0;
    transition: opacity .2s ease
}

.available-service-popup__close:hover {
    opacity: .7
}

.available-service-popup__close svg {
    width: 10px;
    height: 10px
}

.available-service-popup__body {
    padding: 30px
}

.available-service-popup__title {
    font-size: 24px;
    font-weight: 700;
    color: #183761;
    margin-bottom: 16px;
    text-align: center
}

.available-service-popup__details {
    font-size: 16px;
    font-weight: 500;
    line-height: 1.4;
    color: #00000080
}

.available-service-popup__details p {
    margin: 0 0 12px 0;
    font-size: 14px;
    font-weight: 500;
    line-height: 1.4;
    color: #00000080;
    text-align: center;
    padding-bottom: 8px
}

.available-service-popup__details ul {
    list-style: disc;
    text-align: center
}

.available-service-popup__details ul li {
    width: fit-content;
    text-align: left;
    margin: 0 auto;
    letter-spacing: 0
}

.available-service-popup__details p:last-child {
    margin-bottom: 0
}

@media screen and (min-width:769px) {
    .available-service-popup__content {
        max-width: 650px;
        max-height: 90vh
    }

    .available-service-popup__title {
        font-size: 16px
    }

    .available-service-popup__details {
        font-size: 14px
    }

    .available-service-popup__details ul li {
        text-align: center
    }
}

.available-service-drawer {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    z-index: 9999 !important;
    display: none;
    overflow: hidden;
    pointer-events: none;
    margin: 0 !important
}

.available-service-drawer.is-open {
    display: block;
    pointer-events: auto
}

.available-service-drawer__overlay {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    background-color: rgba(0, 0, 0, .2);
    cursor: pointer;
    z-index: 1;
    animation: overlayFadeIn .3s ease;
    margin: 0 !important;
    display: flex !important
}

@keyframes overlayFadeIn {
    from {
        opacity: 0
    }

    to {
        opacity: 1
    }
}

.available-service-drawer__panel {
    position: fixed !important;
    top: 0 !important;
    right: 0 !important;
    width: 100%;
    max-width: 100%;
    height: 100% !important;
    max-height: 100vh;
    background-color: #fff;
    box-shadow: -4px 0 24px rgba(0, 0, 0, .15);
    display: flex;
    flex-direction: column;
    animation: drawerSlideIn .3s ease;
    overflow: hidden;
    z-index: 2;
    margin: 0 !important;
    padding: 20px 24px;
    box-sizing: border-box
}

@keyframes drawerSlideIn {
    from {
        transform: translateX(100%)
    }

    to {
        transform: translateX(0)
    }
}

.available-service-drawer__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    border-bottom: 1px solid #e0e0e0;
    padding-bottom: 16px;
    margin-bottom: 20px
}

.available-service-drawer__loading {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 12px;
    font-size: 14px;
    color: #666
}

.available-service-drawer__loading-spinner {
    display: flex;
    align-items: center;
    justify-content: center
}

.available-service-drawer__title {
    font-size: 20px;
    font-weight: 600;
    line-height: 1.2;
    color: #333
}

.available-service-drawer__close {
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: transparent;
    border: none;
    cursor: pointer;
    padding: 0;
    transition: opacity .2s ease
}

.available-service-drawer__close:hover {
    opacity: .7
}

.available-service-drawer__close svg {
    width: 10px;
    height: 10px
}

.available-service-drawer__body {
    flex: 1;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    min-height: 0;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box
}

.available-service-drawer__form {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    flex: 1;
    min-height: 0;
    gap: 20px;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box
}

.available-service-drawer__form-container {
    flex: 1;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    gap: 20px;
    -webkit-overflow-scrolling: touch;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    box-sizing: border-box
}

.available-service-drawer__form-container {
    scrollbar-width: none
}

.available-service-drawer__form-container::-webkit-scrollbar {
    display: none
}

.available-service-drawer__form-group {
    display: flex;
    flex-direction: column;
    gap: 4px
}

.available-service-drawer__label {
    font-size: 14px;
    font-weight: 600;
    color: #1c1b1f;
    margin-bottom: 4px
}

.available-service-drawer__required {
    color: #ed2427
}

input[name=reason_for_visit] {
    display: none !important
}

.available-service-drawer__input,
.available-service-drawer__textarea {
    width: 100%;
    padding: 12px 16px;
    border: 1px solid #00000080;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 400;
    font-family: inherit;
    color: grey;
    background-color: #fff;
    transition: border-color .2s ease;
    box-sizing: border-box
}

.available-service-drawer__input-info {
    font-size: 12px;
    font-weight: 400;
    color: #183761;
    line-height: 1.5
}

.available-service-drawer__input:focus,
.available-service-drawer__textarea:focus {
    outline: 0;
    border-color: none;
    box-shadow: none
}

.available-service-drawer__input:disabled,
.available-service-drawer__input[readonly] {
    border-color: #00000033;
    background-color: #f2f2f2;
    cursor: not-allowed
}

.available-service-drawer__textarea {
    resize: vertical;
    min-height: 100px
}

.available-service-drawer__select {
    width: 100%;
    height: 44px;
    padding: 12px 16px;
    padding-right: 40px;
    border-radius: 6px;
    border: 1px solid rgba(0, 0, 0, .5);
    background-color: #fff;
    font-size: 14px;
    line-height: 1;
    font-weight: 400;
    font-family: inherit;
    color: #666;
    cursor: pointer;
    transition: border-color .2s ease;
    box-sizing: border-box;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none'%3E%3Cpath d='M7.37207 9.68604L12 14.3139L16.6279 9.68604' stroke='%23000000' stroke-width='1.54264'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    background-size: 24px 24px
}

.available-service-drawer__select:hover:not(:disabled) {
    border-color: #777
}

.available-service-drawer__select:focus {
    outline: 0;
    border-color: #777;
    box-shadow: 0 0 0 2px rgba(0, 0, 0, .1)
}

.available-service-drawer__select:disabled {
    border-color: #00000033;
    background-color: #f2f2f2;
    cursor: not-allowed;
    opacity: 1;
    color: #666
}

.available-service-drawer__select option {
    padding: 12px 16px;
    font-size: 14px;
    font-weight: 400;
    color: #666;
    background-color: #fff
}

.available-service-drawer__select option:hover {
    background-color: #f5f5f5
}

@-moz-document url-prefix() {
    .available-service-drawer__select {
        text-indent: .01px;
        text-overflow: ''
    }
}

@media screen and (-ms-high-contrast:active),
(-ms-high-contrast:none) {
    .available-service-drawer__select {
        padding-right: 16px
    }

    .available-service-drawer__select::-ms-expand {
        display: none
    }
}

.available-service-drawer__date-wrapper {
    position: relative;
    width: 100%;
    min-width: 0;
    max-width: 100%;
    cursor: pointer;
    overflow: visible
}

.available-service-drawer__date-wrapper:hover {
    opacity: .9
}

.available-service-drawer__date-input {
    width: 100%;
    min-width: 0;
    padding-right: 48px;
    pointer-events: auto;
    cursor: pointer;
    max-width: 100%;
    box-sizing: border-box
}

.available-service-drawer__date-input[type=date]::-webkit-calendar-picker-indicator {
    display: none;
    -webkit-appearance: none
}

.available-service-drawer__date-input[type=date] {
    -moz-appearance: textfield;
    appearance: textfield
}

.available-service-drawer__date-input[type=date]::-webkit-inner-spin-button {
    display: none
}

@supports (-webkit-touch-callout:none) {
    .available-service-drawer__date-wrapper {
        min-width: 0;
        width: 100%;
        max-width: 100%;
        box-sizing: border-box
    }

    .available-service-drawer__date-input {
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
        box-sizing: border-box !important
    }

    .available-service-drawer__date-input[type=date] {
        width: 100% !important;
        min-width: 0 !important;
        max-width: 100% !important
    }
}

.available-service-drawer__date-icon {
    position: absolute;
    right: 12px;
    top: 50%;
    transform: translateY(-50%);
    width: 20px;
    height: 20px;
    color: #777;
    pointer-events: auto;
    cursor: pointer;
    z-index: 1
}

.available-service-drawer__date-icon:hover {
    color: #183761
}

.available-service-drawer__info-text {
    margin: -8px 0 8px 0
}

.available-service-drawer__info-text p {
    font-size: 12px;
    color: #4a7ec4;
    line-height: 1.4;
    margin: 0
}

.available-service-drawer__checkbox-group {
    margin-top: 8px
}

.available-service-drawer__checkbox-label {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    cursor: pointer;
    font-size: 14px;
    line-height: 1.5;
    color: #1c1b1f;
    position: relative
}

.available-service-drawer__checkbox {
    position: absolute;
    opacity: 0;
    width: 0;
    height: 0;
    cursor: pointer
}

.available-service-drawer__checkbox-icon-wrapper {
    flex-shrink: 0;
    position: relative;
    display: inline-block;
    width: 20px;
    height: 20px;
    cursor: pointer
}

.available-service-drawer__checkbox-icon-wrapper .checkbox-icon {
    position: absolute;
    top: 0;
    left: 0;
    width: 20px;
    height: 20px;
    transition: opacity .2s ease
}

.available-service-drawer__checkbox-icon-wrapper .checkbox-icon--checked {
    opacity: 0
}

.available-service-drawer__checkbox:checked+.available-service-drawer__checkbox-icon-wrapper .checkbox-icon--unchecked {
    opacity: 0
}

.available-service-drawer__checkbox:checked+.available-service-drawer__checkbox-icon-wrapper .checkbox-icon--checked {
    opacity: 1
}

.available-service-drawer__checkbox-text {
    flex: 1;
    color: #666
}

.available-service-drawer__link {
    text-decoration: underline;
    transition: opacity .2s ease;
    font-size: 14px
}

.available-service-drawer__link:hover {
    opacity: .8
}

.available-service-drawer__submit {
    width: 100%;
    padding: 14px 20px;
    border: none;
    border-radius: 8px;
    background-color: #ed2427;
    color: #fff;
    font-size: 16px;
    font-weight: 700;
    text-transform: uppercase;
    cursor: pointer;
    transition: background-color .2s ease;
    margin-top: 8px;
    position: relative;
    height: 46px;
    display: flex;
    align-items: center;
    justify-content: center
}

.available-service-drawer__submit:hover:not(:disabled) {
    background-color: #d11e21
}

.available-service-drawer__submit:active:not(:disabled) {
    transform: scale(.98)
}

.available-service-drawer__submit:disabled {
    background-color: #ed242799;
    cursor: not-allowed;
    transition: none;
    transform: none
}

.available-service-drawer__submit-text {
    display: inline-block
}

.loading__spinner {
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%)
}

.loading__spinner.hidden {
    display: none
}

.loading__spinner .spinner {
    width: 24px;
    height: 24px;
    animation: spinner-rotate 1.4s linear infinite
}

.loading__spinner .spinner .path {
    stroke: #ffffff;
    stroke-linecap: round;
    animation: spinner-dash 1.4s ease-in-out infinite
}

@keyframes spinner-rotate {
    100% {
        transform: rotate(360deg)
    }
}

@keyframes spinner-dash {
    0% {
        stroke-dasharray: 1, 150;
        stroke-dashoffset: 0
    }

    50% {
        stroke-dasharray: 90, 150;
        stroke-dashoffset: -35
    }

    100% {
        stroke-dasharray: 90, 150;
        stroke-dashoffset: -124
    }
}

.available-service-drawer__cart-message {
    font-size: 14px;
    font-weight: 600;
    color: #ed2427;
    margin-bottom: 5px
}

.available-service-drawer__cart-message p {
    font-size: 14px;
    margin: 0;
    line-height: 1.5
}

.available-service-drawer__cart-message a {
    font-size: 14px;
    color: #ed2427;
    text-decoration: underline;
    font-weight: 600
}

.available-service-drawer__cart-message a:hover {
    color: #d11e21;
    text-decoration: underline
}

.available-service-drawer__error-message {
    font-size: 14px;
    font-weight: 600;
    color: #ed2427;
    margin-bottom: 12px;
    padding: 12px;
    background-color: #fff5f5;
    border: 1px solid #ed2427;
    border-radius: 8px
}

.available-service-drawer__error-message p {
    margin: 0;
    line-height: 1.5
}

.available-service-drawer__error-message a {
    color: #ed2427;
    text-decoration: underline;
    font-weight: 600
}

.available-service-drawer__error-message a:hover {
    color: #183761;
    text-decoration: underline
}

.available-service-drawer__form-new-pet {
    gap: 10px;
    flex-direction: column
}

@media screen and (max-width:749px) {
    .available-service-section__toggle {
        font-weight: 500
    }

    .available-service-drawer__panel {
        padding: 16px;
        width: 100vw;
        max-width: 100vw;
        box-sizing: border-box
    }

    .available-service-drawer__form-container {
        width: 100%;
        min-width: 0;
        max-width: 100%;
        padding-right: 0;
        padding-left: 0;
        -webkit-overflow-scrolling: touch;
        box-sizing: border-box
    }

    .available-service-drawer__form-group {
        width: 100%;
        min-width: 0;
        max-width: 100%;
        box-sizing: border-box;
        flex-shrink: 1
    }

    .available-service-drawer__date-wrapper {
        width: 100% !important;
        min-width: 0 !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
        overflow: visible;
        flex-shrink: 1
    }

    .available-service-drawer__date-input {
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
        box-sizing: border-box !important;
        padding: 12px 48px 12px 16px !important;
        font-size: 14px !important;
        line-height: 1.5 !important;
        min-height: 44px !important
    }

    .available-service-drawer__date-input[type=date] {
        width: 100% !important;
        min-width: 0 !important;
        max-width: 100% !important;
        box-sizing: border-box !important
    }

    @supports (-webkit-touch-callout:none) {
        .available-service-drawer__date-input[type=date] {
            width: 100% !important;
            min-width: 0 !important;
            max-width: 100% !important;
            box-sizing: border-box !important;
            -webkit-appearance: none;
            appearance: none
        }
    }
}

@media screen and (min-width:750px) {
    .available-service-drawer__panel {
        max-width: 500px
    }
}

@media screen and (max-width:340px) {
    .available-service-section__select-trigger span {
        font-size: 10px
    }
}

.available-service-drawer__form-group-container {
    display: flex;
    flex-direction: column;
    gap: 10px
}

.available-service-drawer__select-trigger {
    display: none
}

.available-service-card__pricing-container.price-label {
    font-weight: 600;
    color: #181d27;
    margin: 0;
    font-size: 14px;
    margin-bottom: .2rem;
    line-height: 1.5
}