
.transition-fade {
  padding-top: 3px;
}
#loading_modal {
    width: 50% !important;
}
#loading_modal.animate,
#cart_selectDateTime #loading_modal,
#body_cart_showServices #loading_modal.open {
    width: 100% !important;
}
#loading_modal.open {
    height: 100%;
}

#navbarSupportedContent {
    position: absolute;
    top: 25px;
    right: 4%;
}
#navbarSupportedContent .cart_icon .dropdown-menu.dropdown-menu-end.show {
    width: 400px;
    right: 0px
}
#navbarSupportedContent a.select_item, 
#navbarSupportedContent a.select_item button {
    width: 100% !important;
    text-align: center;
    margin-bottom: 15px;
}

.full_width #loading_msg {
    width: 50%;
}
.card-footer {
    background-color: transparent !important;
}
@media (min-width:451px){
    body {
        overflow: hidden;
    }
    body, div#app_div {
        width: 100% !important;
        max-width: unset;
        height: 100%;
    }
    
    div#app_div {
        margin: 0 auto;
        width: 500px;
        max-width: 100vw;
        display: flex;
        flex-direction: column;
        height: 100vh;
        max-height: 100vh;
        animation: none !important;
        position: relative !important;
        transform: translateX(0%) !important;
    }

    #body_cart_checkout #app_div,
    #body_cart_manageAppointments #app_div,
    body.confirmation, 
    .confirmation div#app_div {
        height: unset !important;
        max-height: unset !important;
    }
    .full_width .full_width .py-4 {
        padding: 3px 0 !important;
    }
    .full_width .container {
        max-width: unset !important;
        padding: 0 !important;
        margin: 0 !important;
    }
    .full_width main .card .card-body {
        display: flex;
        flex-direction: row;
        flex-wrap: wrap;
    }
    .full_width .card {
        border-radius: unset !important;
        max-height: calc(100vh - 86px);
    }
    .full_width .card-body {
        display: flex !important;
        padding: 0 !important;
    }
    .full_width .card-body #main {
        width: 50%;
        padding: 10px;
        overflow-y: auto;
        height: calc(100vh - 86px) !important;
    }
    #cart_selectDateTime #main {
        width: 100%;
    }
    .full_width .card-header {
        padding: 0 !important;
    }
    .full_width .card .card-body .section {
        margin-top: 0px;
    }
    .full_width .section.locations, #location_map {
        width: 50%;
        display: flex;
        flex-direction: column;
    }
    .full_width #confirm_edit_location .container {
        max-width: 520px !important;
        margin: 50px auto !important;
    }
    .full_width .right_side_image {
        height: calc(100vh - 86px) !important;
        background-position: 0 0;
        background-repeat: no-repeat;
        background-size: cover;
        width: 50%;
    }
    .full_width #inline_login .card {
        height: calc(100vh - 160px) !important;
    }
    .full_width .select_staff {
        margin: 0 4%;
    }
    .full_width #cart_selectDateTime #datepicker,
    .full_width #cart_selectDateTime #timepicker_div{
        width: 50%;
    }
    .full_width #cart_selectDateTime #time_info {
        padding: 0 4%;
    }
    .full_width #timepicker .btn-time {
        flex-basis: 19%;
        display: flex;
        justify-content: center;
        align-items: center;
        height: 45px;
        border-radius: 35px;
        padding: 5px;
        margin: 2px;
    }

    .full_width .timepicker-text {
        text-align: left;
        margin-top: 0px;
    }
    .full_width .datepicker th.dow, 
    .full_width .datepicker td {
        width: 9% !important;
    }

    #datetimepicker_div {
        flex-direction: row !important;
        width: 100% !important;
    }

    .full_width #cart_showRegistrationForm form .row {
        margin: 0;
    }
    .confirmation .card {
        max-width: 600px;
        margin: 0 auto;
    }

    .service_title.staff, .service_title.location {
        flex-basis: 50% !important;
        max-width: 50%;
    }
    #cart_selectDateTime .service_utilities {
        width: 45%;
    }
    .dropdown-menu.dropdown-menu-end.show {
        max-width: 463px;
        flex-direction: column;
    }
    .card.cart-dropdown .card-body {
        flex-direction: column !important;
        padding: 10px !important;
    }
}
@media (max-width:450px){
    
    body {
        overflow-x: hidden;
        overflow-y: scroll;

    }
    .full_width .right_side_image {
        display: none;
    }
    .full_width .section.locations, 
    .full_width #location_map {
        width: 100%;
        height: 100%;
    }
    #loading_modal {
        width: 100%;
    }
    #loading_modal.open {
        height: 100%;
        width: 100% !important;
    }
    .full_width #loading_msg {
        width: 100%;
    }
    .full_width .select_staff {
        margin: 0 2%;
    }
    .full_width #timepicker .btn-time {
        border-radius: 35px;
        flex-basis: 30%;
    }

    #datetimepicker_div {
        flex-direction: column !important;
        width: unset !important;
    }
    div#timepicker {
        margin-top: 20px;
    }
    div#time_info {
        padding: 0;
    }

    .card-body #location_map {
        width: 100%;
        height: calc(100vh - 170px);
    }
    .service_utilities {
        width: 100%;
        flex-direction: row;
    }
    #navbarSupportedContent .cart_icon .dropdown-menu.dropdown-menu-end.show {
        width: 90vw;
        right: 0px;
    }
}