.appointment-details-view.is-editing-summary {
    opacity: 0.8;
}

.appointment-details-view.is-editing-summary .edit-appointment-details,
.appointment-details-view .edit-appointment-details.disabled {
    pointer-events: none;
    cursor: not-allowed;
    opacity: 0.5;
}

/* store booking  */
* {
    transition: all .0s ease 0s;
}
.progress-steps {
    display: flex;
    justify-content: space-between;
    position: relative;
    margin: 2rem -4rem 3rem;
}
.appointment-wrapper {
    float: left;
    width: 100%;
    padding-bottom: 2rem;
}
button.btn-close {
    border: none;
    background-color: transparent;
    font-size: 14px;
    position: absolute;
    right: 20px;
    top: 15px;
    z-index: 2;
}
#selectServiceModal p {
    font-size: 15px;
}
.time-wrap h6 {
    color: #1B437E;
}
.time-btns button {
    border: 1px solid #1B437E;
    background-color: transparent;
    border-radius: 10px;
    padding: 4px 12px;
    font-size: 14px;
    text-transform: uppercase;
    color: #1B437E;
    font-weight: 700;
}
.date-time-wrap label.form-label {
    font-size: 16px;
    color: #1B437E;
    font-weight: 600;
}
.date-time-wrap h5 {
    color: #1B437E;
    margin-bottom: 30px;
    font-size: 18px;
}
div#appointmentModal h5.modal-title {
    color: #1B437E;
    font-size: 17px;
}
.confirm-wrap label, .confirm-wrap label:hover {
    color: #838383;
    font-size: 12px;
}
.search-location {
    width: 100%;
}

.search-bar input {
    color: #646566;
    border: 0;
    width: 85%;
    outline: none;
    border: 1px solid rgb(0 0 0 / 58%) !important;
    border-radius: 4px;
    padding: 3px 10px;
    font-size: 12px;
    font-weight: 500;
}
.search-bar input::placeholder {
    color: #646566;
}
.search-bar input:active {
    border: none;
    outline: none;
}

.current-location i {
    color: #0F3C80;
    font-size: 17px;
}
.current-location a {
    color: #0F3C80;
    text-decoration: underline;
    font-weight: 600;
    font-size: 15px;
}
.progress-steps::before {
    content: '';
    position: absolute;
    top: 20px;
    left: 0;
    right: 0;
    height: 2px;
    background: #0F3C80;
    z-index: 1;
}

.step {
    position: relative;
    z-index: 2;
    text-align: center;
    background: white;
    padding: 0 10px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.step-wrap > div > .card {
    border: 1px solid #C4C4C4;
    border-radius: 10px;
    padding: 10px 12px;
}

.step-number {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background: #e9ecef;
    color: #6c757d;
    display: flex;
    align-items: center;
    justify-content: center;
    /* margin: 0 auto 0.5rem; */
    margin: 0 0.5rem;
    font-weight: bold;
    transition: all 0.3s ease;
}
.step-number i {
    font-size: 19px;
}
.step.active .step-number {
    background: #0F3C80;
    color: white;
}

.step-title {
    font-size: 16px;
    color: #6c757d;
    transition: all 0.3s ease;
}

.step.active .step-title {
    color: #0F3C80;
    font-weight: bold;
}
.step-wrap h3 {
    color: #0F3C80;
    font-size: 15px;
}
.service-card {
    cursor: pointer;
    transition: all 0.3s ease;
}
.service-card .card-body h5 {
    color: #0F3C80;
    font-weight: 500;
    text-align: start;
    font-size: 15px;
    margin-bottom: 3px;
    display: flex;
    align-items: center;
    gap: 10px;
}
.service-card .card-body p {
    color: #1B437E;
    font-size: 13px;
    font-weight: 500;
}
.selected-option .card-body p.light-text {
    font-weight: 500 !important;
}
.service-card .card-body img {
    max-width: 44px;
}

.service-card .card-body {
    border: 1px solid #CFC6C6;
    border-radius: 10px;
}
.service-card.selected .card-body {
    border: 2px solid #0F3C80;
}
.test-text {
    display: flex;
    align-items: center;
    justify-content: start;
    gap: 24px;
}
.info-icon i {
    font-size: 27px;
    color: #0F3C80;
}
#step2 {
    display: none;
}
.continuediv {
    padding-top: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.continuediv button {
    background: #1B437E;
    color: #fff;
    font-size: 13px;
    font-weight: 500;
    padding: 5px 10px;
    border-radius: 5px;
    min-width: 100px;
    transition: all ease-in-out .3s;
    border: 0;
    text-transform: capitalize;
}
.step-modal .modal-dialog .btn-close {
    border: none;
    font-size: 14px;
    background-color: transparent;
}
button#eyetest-close:hover, button#eyetest-close:active,
button#eyetest-close:focus {
    border: none;
    outline: none;
}
div#eyetestModal h5.modal-title, div#eyetestModal ul,
div#eyetestModal ul {
    padding-left: 20px;
}
button.change-appointment-btn {
    background: #0F3C80;
    background: linear-gradient(90deg, rgba(15, 60, 128, 1) 56%, rgba(114, 146, 203, 1) 100%);
    padding: 6px 12px;
    border: 0;
    height: 40px;
    border-radius: 8px;
    color: #fff;
    font-size: 15px;
    max-width: 260px;
    width: 100%;
    font-weight: 700;
}
.store-item {
    border: 1px solid  #D9D9D9;
    margin-bottom: 10px;
    border-radius: 8px;
}
.store-item h6 {
    color: #0F3C80;
    font-weight: 700;
}
.store-item p.text-muted {
    font-size: 14px;
    color: #646566 !important;
}
.store-item button {
    background: #0F3C80;
    background: linear-gradient(90deg, rgba(15, 60, 128, 1) 30%, rgba(114, 146, 203, 1) 100%);
    color: #fff;
    font-size: 14px;
    padding: 4px 12px;
    border-radius: 8px;
    max-width: 300px;
    width: 100%;
    height: 30px;
}
.title-wrap label {
    font-size: 13px;
    color: #838383;
    font-weight: 500;
    padding-left: 2px !important;
}
div#step3Modal h5.modal-title, form#personalDetailsForm h5 {
    font-size: 18px;
    color: #0F3C80;
}
.inputs-wrap label {
    font-size: 12px;
    color: #838383;
    font-weight: 400;
    margin-bottom: 0;
}
.inputs-wrap input.form-control, .inputs-wrap textarea {
    font-size: 13px;
    /* color: #838383; */
    color: #0C2446;
    font-weight: 400;
    border: 1px solid #a2949452;
    height: 35px;
    border-radius: 5px;
    padding: 8px 10px;
}
.inputs-wrap input[type="checkbox"] + label:hover{
    color: #838383;
}
.inputs-wrap textarea {
    height: unset;
    text-align: left;
    width: 100%;
}
.title-wrap {
    display: flex;
}
form#personalDetailsForm  p {
    font-size: 13px;
    color: #838383;
    margin-bottom: 4px;
}
.wrapper-title {
    display: flex;
    align-items: center;
    gap: 35px;
}
.title-wrap input[type="radio"] {
    appearance: none;
    -webkit-appearance: none;
    background-color: #fff;
    border: 1px solid #838383;
    border-radius: 50%;
    width: 19px;
    height: 19px;
    cursor: pointer;
    position: relative;
}
.title-wrap input[type="radio"]:checked::before {
    content: "";
    display: block;
    background-color: #1B437E;
    border-radius: 50%;
    width: 13px;
    height: 13px;
    position: absolute;
    top: 2px;
    left: 2px;
}
.title-wrap input[type="radio"]::after,
.title-wrap label::after, .title-wrap label::before { 
display: none;
}
.date-time-erap h5 {
    color: #0F3C80;
}

.calendar-container {
    background: white;
    border-radius: 12px;
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.1);
    overflow: hidden;
    width: 100%;
    max-width: 400px;
    margin: 0 auto;
}

.calendar-header {
    background: white;
    padding: 15px 20px;
    border-bottom: 1px solid #e5e7eb;
    display: flex;
    justify-content: space-between;
    align-items: center;
}
button, button:focus {
    outline: none;
}
.month-select, .year-select {
    border: none;
    background: none;
    font-size: 16px;
    font-weight: 600;
    color: #1B437E;
    cursor: pointer;
    padding: 5px 10px;
    border-radius: 6px;
    transition: background 0.2s;
    outline: none;
}

.month-select:hover, .year-select:hover {
    background: #f3f4f6;
}

.month-select, .year-select {
    position: relative;
}

.month-select::after, .year-select::after {
    content: '▼';
    font-size: 12px;
    margin-left: 8px;
    color: #6b7280;
}

.calendar-body {
    padding: 20px;
}

.days-header {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 2px;
    margin-bottom: 15px;
}

.day-header {
    text-align: center;
    font-weight: 600;
    color: #6b7280;
    font-size: 14px;
    padding: 10px 0;
}

.days-grid {
    display: grid;
    grid-template-columns: repeat(10, 1fr) !important;
    gap: 2px;
}

.day {
    aspect-ratio: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.2s ease;
    color: #374151;
    font-weight: 500;
}

.day:hover {
    background: #e5e7eb;
    transform: scale(1.05);
}

.day.other-month {
    color: #d1d5db;
}

.day.selected {
    background: #0F3C80;
    color: white;
    /* transform: scale(1.1);
    box-shadow: 0 4px 12px rgba(15, 60, 128, 0.3); */
}

.day.today {
    background: #fef3c7;
    color: #d97706;
    font-weight: 700;
}

.day.selected.today {
    background: #0F3C80;
    color: white;
}

.day.disabled {
    color: #d1d5db;
    cursor: not-allowed;
    background: #f3f4f6;
}

.day.disabled:hover {
    transform: none;
    background: #f3f4f6;
}
.detail-list li.list-group-item {
    border: 0;
    padding: 6px 0px;
    color: rgb(0 0 0 / 80%);
    font-size: 14px;
}
.detail-list h5 {
    font-size: 17px;
    color: #0F3C80;
    font-weight: 600;
}
section#step4-section h6 {
    font-size: 18px !important;
    color: #0F3C7F;
}
.change-div a {
    font-size: 15px !important;
    color: #0F3C80;
    text-decoration: underline;
}
section#step4-section p {
    color: #0F3C80;
    font-weight: 600;
}
.thankyou-page {
    color: #0F3C80;
    text-align: center;
    padding-top: 35px;
}
.thankyou-page h5 {
    font-size: 20px;
    color: #0F3C80;
}
.checked-img img {
    max-width: 50px;
    margin-top: 10px;
    margin-bottom: 25px;
}
.checked-img h6 {
    font-size: 16px !important;
}
.checked-img p span.id-name {
    font-weight: 700;
}
.checked-img p {
    font-size: 14px;
    margin-bottom: 0;
    color: #0F3C80;
}
.edit-actions {
    display: flex;
    gap: 10px;
    justify-content: flex-end;
}

.edit-actions .btn {
    padding: 5px 12px;
    border-radius: 4px;
    height: auto;
    font-size: 12px;
}

.edit-actions .btn-primary {
    background: #0F3C80;
    background: linear-gradient(90deg, rgba(15, 60, 128, 1) 30%, rgba(114, 146, 203, 1) 100%);
    border: none;
}

.edit-actions .btn-secondary {
    background: #6c757d;
    border: none;
}

.user-details-edit, .appointment-details-edit, .appointment-type-edit {
    padding: 20px;
    background: #f8f9fa;
    border-radius: 8px;
    margin-top: 15px;
}
/* store booking end  */

/* van booking css */
.service-card .price {
    font-size: 1.25rem;
    font-weight: bold;
    color: #0d6efd;
    margin-top: 1rem;
}
.time-slot-btn {
    width: 100%;
    padding: 10px;
    border: 1px solid #0F3C80;
    background: white;
    color: #0F3C80;
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.3s ease;
}
.time-slot-btn:hover:not(.disabled) {
    background: #0F3C80;
    color: white;
}
.time-slot {
    padding: 0.5rem;
    margin: 0.5rem;
    border: 1px solid #dee2e6;
    border-radius: 0.25rem;
    cursor: pointer;
    text-align: center;
}

.time-slot:hover {
    background-color: #f8f9fa;
}

.time-slot.selected {
    background-color: #0d6efd;
    color: white;
    border-color: #0d6efd;
}

#cityResults:has(.city-result) {
    background-color: transparent;
    color: #646566;
    border: 1px solid #d9d9d9;
    border-radius: 8px;
    padding: 8px;
}

.time-slot.unavailable {
    background-color: #e9ecef;
    color: #6c757d;
    cursor: not-allowed;
}
.card-header {
    border-bottom: none;
}

.search-location h6 {
    font-size: 18px;
    color: #0F3C80;
    margin-bottom: 9px;
}

.selected-location button {
    width: 100%;
    align-items: center;
    border: 1px solid #0F3C80;
    border-radius: 4px;
    font-size: 14px;
    color: #0F3C80;
    font-weight: 700;
    background-color: transparent;
    padding: 3px 12px;
    transition: all ease-in-out .3s;
}

.selected-location button:hover {
    background-color: #2E5797;
    color: #fff;
    border: 1px solid #2E5797;
}

.selected-location {
    display: flex;
    width: 100%;
    gap: 10px;
    margin-bottom: 20px;
    margin-top: 10px;
}

form#locationForm label, 
form#locationForm textarea {
    color: #838383;
    font-size: 14px;
    margin: 0;
    display: block;
}

.form-control:focus {
    border-color: #838383;
}

form#locationForm input {
    font-size: 15px;
    padding: 5px 10px;
    height: 40px;
    color: #838383;
    height: auto;
}

.search-citywrap svg {
    color: #000;
    position: absolute;
    left: 13px;
    top: 50%;
    transform: translateY(-50%);
}

.search-citywrap > span {
    cursor: pointer;
    position: relative;
    width: 100%;
    background-color: transparent;
    border: 1px solid #D9D9D9;
    border-radius: 4px;
    padding: 4px 12px;
    height: 32px;
    display: block;
    overflow: hidden;
}

.search-citywrap input {
    position: absolute;
    left: 28px;
    width: 96%;
    border: 0;
    background-color: transparent;
    top: 50%;
    transform: translateY(-50%);
    font-size: 14px;
    height: auto;
}

form#locationForm {
    border: 1px solid #D9D9D9;
    padding: 11px;
    border-radius: 8px;
}

.search-citywrap select option:hover {
    background-color: #0F3C80;
}

.form-select, 
.form-control {
    border-radius: 0.375rem;
    border: 1px solid #ced4da;
    padding: 0.5rem 0.75rem;
}

.city-result {
    padding: 8px 12px;
    cursor: pointer;
    border-bottom: 1px solid #eee;
}

.city-result:hover {
    background-color: #f8f9fa;
}

.no-results {
    padding: 8px 12px;
    color: #6c757d;
}

#citySearchResults {
    position: absolute;
    width: 100%;
    background: white;
    border: 1px solid #ddd;
    border-radius: 4px;
    max-height: 200px;
    overflow-y: auto;
    z-index: 1000;
    box-shadow: 0 2px 4px rgba(0,0,0,0.1);
}

.van-bg-wrap {
    background-image: url("{% static service.icon|default:'desktop/images/bus-bg.png' %}");
    background-position: center;
    background-repeat: no-repeat;
    width: 100%;
    height: 100%;
    padding: 20px 20px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    max-height: 160px;
    margin-bottom: 25px;
}

.van-text {
    color: #fff;
}
.accessible-wrap {
    background: linear-gradient(90deg, #1B437E 12.5%, rgba(27, 67, 126, 0.6) 100%);
    color: #fff;
    padding: 10px 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    margin: 0 auto;
    border-radius: 4px;
}

.accessible-wrap img {
    max-width: 40px;
    margin-left: 20px;
    filter: brightness(0) invert(1);
}

.rta-wrap {
    width: 100%;
    margin: 20px auto 20px;
    padding: 15px 10px;
    border-top: 1px dashed #000;
    border-bottom: 1px dashed #000;
}

.rta-wrap > div {
    justify-content: space-between;
    align-items: center;
}

.rta-texts p {
    font-size: 14px;
    font-weight: 600;
    color: #1B437E;
}
.service-details h5 {
    font-size: 18px;
    color: #0F3C80;
    display: block;
}
.store-near-switch {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    margin-bottom: 10px;
}
.store-near-switch h5 {
    font-size: 14px;
    color: #0F3C80;
}
.store-near-switch label.form-check-label {
    margin: 0;
    color: #0F3C80;
    font-size: 13px;
}
.store-near-switch .form-check.form-switch {
    padding-left: 42px;
}
#map-card .card-body h5 {
    font-size: 18px;
    font-weight: 600;
    margin-bottom: 20px;
}
/* dialog ui changes */
.modal-backdrop {
    background-color: rgb(15 60 128 / 100%);
}
.modal-content {
    border-radius: 10px;
}
.modal-dialog.modal-lg {
    max-width: 670px;
}

/* msite-css */
html, body, .body-content,.appointment-wrapper {
    height: 100%;
    position: relative;
}
.step-wrap {
    border-top-left-radius: 40px;
    border-top-right-radius: 40px;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    margin: 0;
    background: #fff;
    transform: translateY(100%);
    opacity: 0;
    visibility: hidden;
    transition: transform 0.5s ease, opacity 0.5s ease;
    display: none;
    padding: 2rem 5px;
    /* margin-top: 4rem; */
    overflow-x: auto;
}
.step-wrap.show {
    transform: translateY(0);
    opacity: 1;
    visibility: visible;
    display: block !important;
    height: calc(100% - 80px);
    /* min-height: 370px;
    max-height: 422px; */
    animation: slideDown 0.5s ease forwards;
    z-index: 2;
}
@keyframes slideDown {
    from {
      opacity: 0;
      transform: translateY(20px);
    }
    to {
      opacity: 1;
      transform: translateY(0);
    }
  }
  
  @keyframes slideUp {
    from {
      opacity: 1;
      transform: translateY(0);
    }
    to {
      opacity: 0;
      transform: translateY(20px);
    }
  }
  
.selected-option .card-body h5 {
    font-size: 18px;
    font-weight: 600;
}
.selected-option .card-body p {
    font-size: 14px;
    color: #1B437E !important;
    font-weight: 600;
    margin-bottom: 10px;
}
.duration-time {
    color: #1B437E;
    font-size: 13px;
    font-weight: 600;
    text-transform: uppercase;
}
.duration-time span {
    text-transform: none;
}
.selected-option .test-text {
    font-size: 12px;
    text-align: center;
    display: block;
    /* width: 270px; */
    margin: 0 auto;
    margin-bottom: 12px;
}
.selected-option .test-text:has(p:not(:empty)) {
    padding: 10px;
    border: 1px solid #0C0C0C4D;
    border-radius: 10px;
}
.selected-option .test-text p {
    font-size: 12px;
    color: #1B437E;
    font-weight: 500;
    margin: 0;
}
.selected-option .test-text h5 {
    font-size: 14px;
}
.info-icon svg {
    width: 16px;
    height: 20px;
}
.info-icon {
    cursor: pointer;
}
div#driving-license p.dl-text-wrap {
    font-weight: 400;
}
.step-wrap .card-body p.dl-text-wrap {
    border: 1px solid #0C0C0C4D;
    border-radius: 10px;
    font-size: 12px;
    font-weight: 500;
    padding: 10px;
    margin: 0;
}
.search-location {
    display: flex;
    align-items: center;
    justify-content: space-between;
}
/* .store-location .search-location {
    padding: 15px 5px 0px;
}  */

.search-location .search-bar {
    width: 50%;
    display: flex;
    gap: 5px;
}
span.search-icon {
    background: #1B437E;
    color: #fff;
    padding: 2px 10px;
    border-radius: 4px;
}
a.current-location {
    background: #1B437E;
    color: #fff;
    border: 1px solid #A19292;
    border-radius: 4px;
    padding: 3px 10px;
    font-size: 12px;
}
/* store-location css */
.store-list ul li {
    border: 0.4px solid #A39999B2;
    display: flex;
    align-items: center;
    justify-content: space-around;
    margin-bottom: 10px;
    border-radius: 5px;
    padding: 6px 10px;
    gap: 15px;
    cursor: pointer;
}
.store-list ul li p {
    margin: 0;
    color: #1B437E;
    font-size: 12px;
}
.store-list {
    /* height: 200px;
    overflow-y: auto; */
    margin: 14px 0 8px;
    padding-right: 8px;
}
.store-list ul li h4 {
    font-size: 13px;
    margin-bottom: 2px;
}
.store-list ul li a {
    background: #1B437E;
    color: #fff !important;
    font-size: 10px;
    padding: 3px 5px;
    border-radius: 4px;
}
.store-list ul li img {
    min-height: 35px;
}
.store-location {
    padding: 0 12px;
}
.detail-form {
    padding: 2rem 20px 15px;
}
.detail-form h5 {
    font-size: 18px;
}
.detail-form .confirm-wrap input {
    margin-top: 5px;
    position: absolute;
    left: 20px;
}
.detail-form .confirm-wrap label {
    padding-left: 20px;
}
.confirm-booking {
    padding: 2rem 20px;
}
.confirm-booking h5 {
    border-bottom: 1px solid rgb(0 0 0 / 35%);
    padding-bottom: 5px;
    font-size: 16px;
    font-weight: 600;
}
.confirm-booking .test-wrap h5 {
    /* font-size: 18px; */
    border: 0;
}
.detail-list li.list-group-item > div {
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: 12px;
    color: rgb(0 0 0 / 60%);
}
.detail-list li.list-group-item > div a {
    color: #0651B9;
    text-decoration: underline;
    cursor: pointer;
}
.appointment-time {
    padding: 2.2rem 20px;
    display: none !important;
}
.appointment-time h5 {
    font-size: 18px;
}
.appointment-time p {
    color: #0F3C80;
    font-size: 14px;
    margin-bottom: 10px;
}
.date-wrap label {
    font-size: 15px;
    font-weight: 600;
    color: #1B437E;
}
.date-wrap .calendar-container {
    box-shadow: none;
    border: 1px solid #0000001F;
    border-radius: 10px;
    margin: 0;
    margin-bottom: 30px;
}
.date-wrap .calendar-header {
    border-bottom: 0;
    padding: 0 8px 0 0;
    background: transparent;
}
.month-select, .year-select {
    color: #1B437E;
    font-size: 13px;
    background: transparent !important;
}
.date-wrap .calendar-body {
    padding: 0;
}
.date-wrap .day-header, .day {
    padding: 5px 0;
    font-size: 12px;
}
.date-wrap .time-wrap h6 {
    font-size: 15px;
    font-weight: 600;
}

/* step modal css start */
/* Slide up animation */
@keyframes slideUp {
from {
    transform: translateY(100%);
    opacity: 0;
}
to {
    transform: translateY(0);
    opacity: 1;
}
}
.modal.step-modal.fade .modal-dialog {
transform: translateY(100%);
transition: transform 0.3s ease-out;
}
.modal.step-modal.fade.show .modal-dialog {
transform: translateY(0);
animation: slideUp 0.3s ease-out;
}
.step-modal .modal-dialog {position: absolute;bottom: 0;margin: 0; width: 100%;}
.step-modal .modal-dialog .modal-content {
    border-radius: 0;
    border-top-left-radius: 40px;
    border-top-right-radius: 40px;
}
.step-modal .modal-dialog .modal-header {align-items: center;-webkit-box-align: center;}
.step-modal .modal-dialog h6, .step-modal .modal-dialog li {
    font-size: 14px;
    color: #1B437E;
    list-style: disc;
}

/* van msite css */
.van-outer .step-wrap {
    padding: 20px;
}
/* .van-outer .step-wrap.top-space {
    max-height: 100%;
    padding-top: 102px;
} */

.van-outer .step-wrap.top-space {
    max-height: 100%;
    padding-top: 40px;
    border-radius: 0px;
}
.van-img img {
    margin-top: -2rem;
    margin-bottom: -20px;
    margin-left: auto;
    margin-right: auto;
    max-width: 200px;
}
.van-text h5 {
    text-align: center;
    font-size: 16px;
    font-weight: 600;
}
.van-img {
    text-align: center;
}
.van-img h5 {
    text-align: center;
}
.van-text p {
    color: #1B437E;
    font-size: 13px;
    font-weight: 500;
}
.van-text p strong {
    font-weight: 700;
}
.accessible-wrap h6 {
    color: #fff;
    font-size: 13px;
}
.rta-texts {
    text-align: center;
}
.step-wrap.van-map-screen {
    padding: 0 !important;
    top: 102px;
    border-radius: 0;
}
.top-map-outer h5 {
    color: #1B437E;
    font-size: 15px;
    margin: 12px 20px;
}
.bottom-search-section {
    border-top-left-radius: 40px;
    border-top-right-radius: 40px;
    margin-top: -3rem;
    background: #fff;
    padding: 20px;
    height: 100%;
    position: relative;
}
div#locationMap {
    background: #F4F4F4;
    border-radius: 7px;
}

.selected-location button:first-child {
    background: #1B437E99;
}
.selected-location button {
    border: 0;
    background: linear-gradient(90deg, #1B437E 42.79%, rgba(27, 67, 126, 0.6) 100%);
    color: #fff;
    text-transform: uppercase;
    font-weight: 500;
}
.search-citywrap {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 20px;
}
.search-citywrap button {
    background: linear-gradient(90deg, rgba(27, 67, 126, 0.6) 0%, #1B437E 0.01%);
    border: 0;
    color: #fff;
    padding: 5px 10px;
    border-radius: 4px;
}
form#locationForm button {
    background: linear-gradient(90deg, #1B437E 42.79%, rgba(27, 67, 126, 0.6) 100%);
    border: 0;
    color: #fff;
    padding: 2px 10px;
    border-radius: 4px;
}
.appointment-time ul.slot-list {
    display: flex;
    flex-wrap: wrap;
    border: 1px solid #0000001F;
    padding: 12px 0;
    border-radius: 10px;
    justify-content: center;
}
.appointment-time ul.slot-list li {
    margin: 3px;
    width: 30%;
}
.appointment-time ul.slot-list li button {
    padding: 2px 10px;
    border-radius: 10px;
}
.appointment-time ul.slot-list button.time-slot-btn.selected {
    background: #0F3C80;
    color: #fff;
}
/* new design */ 
.store-item-new .content-bottom h6, 
.store-item-new .content-bottom p {
    color: #1B437E;
}
.img-store a.view-map {
    background-color: #1B437E;
    padding: 3px 8px;
    border-radius: 3px;
    line-height: 1.9;
    color: #fff;
    font-weight: 500;
    position: relative;
    font-size: 12px;
    text-align: center;
    bottom: -22px;
    z-index: 22;
}
.store-item-map a.view-map {
    background-color: #1B437E;
    padding: 2px 5px;
    border-radius: 3px;
    color: #fff;
    font-weight: 500;
    position: absolute;
    font-size: 11px;
    text-align: center;
    z-index: 22;
    bottom: -10px;
    left: 20px;
    width: 50%;
    max-width: 95px;
}
.store-item-map {
    position: relative;
}
.store-item-new {
    border: 0.4px solid #A39999B2;
    border-radius: 5px;
    position: relative;
    margin-bottom: 30px;
    padding: 10px 5px;
}
.store-item-new.selected {
    border-color: #1B437E;
    box-shadow: 0 0 0 2px rgba(27, 67, 126, 0.15);
    background-color: #f0f5ff;
}
.img-store h6 {
    font-size: 14px;
}
.store-item-new .img-store {
    /* width: 80%; */
    min-width: 140px;
    max-width: 100%;
    text-align: center;
    padding-right: 10px;
}
.store-item-new .img-store .store-img {
    border-radius: 3px;
}
/*  */
button.date-btn-wrap {
    border: 0;
    background: #1B437E99;
    background: linear-gradient(90deg, rgba(27, 67, 126, 1) 35%, rgb(61 101 161) 100%);
    color: #fff;
    padding: 8px 12px;
    margin: 15px 0px;
    border-radius: 4px;
}
div#timeSlotContainer ul {
    border: 0 !important;
}
button.btn-close.close-form {
    background-image: none;
    align-items: center;
    justify-content: center;
    display: flex;
}
.all-types {
    background-color: #F4F4F4;
    padding: 18px 18px;
    border-radius: 4px;
    margin-bottom: 22px;
    display: flex;
    justify-content: space-evenly;
    align-items: center;
}
.eyetestwrap img {
    max-width: 33px;
    width: 100%;
    object-fit: cover;
    margin: 0 auto;
}
.eyetestwrap span {
    display: block;
    max-width: 110px;
    text-align: center;
    width: 100%;
    margin: 0 auto;
    font-size: 12px;
}
.eyetestwrap {
    text-align: center;
}
.continuediv.linear-wrap button {
    background: #1B437E99;
    background: linear-gradient(90deg, rgba(27, 67, 126, 1) 45%, rgba(27, 67, 126, 0.78) 100%);
    width: 100%;
    border-radius: 4px;
}
  .bottom-sheet-modal .modal-header button.btn-close {
    --bs-btn-close-opacity: 9;
    --bs-btn-close-bg: transparent;
    --bs-btn-close-color: #1B437E;
}

div#personalDetailsForm {
    height: calc(100% - 80px);
    z-index: 1111;
}
#step3-section {
    height: calc(100% - 150px);
    z-index: 1111;
}
 body.show-overlay {
    position: relative;
}
body.show-overlay::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: #000000;
    z-index: 1;
    opacity: 0.3;
} 
.test-wrap h6 {
    font-size: 15.8px;
}
button.cancel-appointment-btn {
    background-color: transparent;
    color: #1B437E;
    font-weight: 600;
    /* border-bottom: 1px solid #1B437E; */
    /* border-radius: 0px; */
    /* padding-bottom: 1px; */
    text-decoration: underline;
}
button.btn.btn-select {
    padding: 0;
    opacity: 0;
    width: 0;
    height: 0;
}
.van-outer .slot-list {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    padding: 12px 0;
}
.van-outer .slot-list li {
    width: 30%;
    margin: 3px;
}
.van-outer .slot-list li button {
    padding: 2px 10px;
    border-radius: 10px;
}
.van-outer .slot-list li button.selected {
    background: #0F3C80;
    color: #fff;
}
#van-step4-section {
    border-radius: 0;
    padding-top: 40px;
}

.confirm-booking form#personalDetailsForm p,
.confirm-booking .inputs-wrap label, .confirm-booking .title-wrap label {
    color: #0C2446;
    font-weight: 500;
}
button.date-btn-wrap.edit-btn {
    padding: 5px 10px;
    width: 120px;
    background: linear-gradient(90deg, #1B437E 42.79%, rgba(27, 67, 126, 0.6) 100%);
    margin-bottom: 0;
}
.appointment-wrapper #step3-section {
    height: calc(100% - 80px);
}
.continuediv {
    gap: 10px;
}
html[dir="rtl"] .search-citywrap input {
    left: 10px;
}
html[dir="rtl"] .form-label {
    text-align: right;
    display: block;
}
html[dir="rtl"] .title-wrap label {
    padding-left: unset !important;
    padding-right: 6px;
}
html[dir="rtl"] #personalDetailsForm .invalid-feedback {
    text-align: right;
}
html[dir="rtl"] #personalDetailsForm .form-control.is-invalid {
    background-position: left calc(.375em + .4375rem) center;
}
html[dir="rtl"] .step-modal .modal-dialog h6,
html[dir="rtl"] .step-modal .modal-dialog li {
    text-align: right;
}
html[dir="rtl"] .step-modal .modal-dialog .btn-close {
    right: unset;
    left: 20px;
    top: 30px;
}
html[dir="rtl"] button.btn-close {
    right: unset;
    left: 20px;
    top: 25px;
}
.msite-store-slot {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 5px;
    justify-content: center;
}

.msite-store-slot button.time-slot-btn {
    width: 32% !important;
    padding: 1px 0;
}

/* store msite listing css */
.msite-store .store-location {
    padding: 0;
}

.msite-store .store-near-switch h5 {
    font-size: 14px !important;
}

.msite-store .search-location h6 {
    display: none;
}

.msite-store .search-location {
    justify-content: flex-end;
    margin-bottom: 10px;
}
.msite-store .store-near-switch {
    margin: 0;
}
.msite-store .search-location input#searchLocation {
    height: 16px;
    margin-right: 45px;
}

.msite-store .search-location span.search-icon {
    position: absolute;
    right: 0;
    margin: 0;
    height: 24px;
}

.msite-store .current-location {
    position: absolute;
    top: 19px;
    background: #1B437E;
    padding: 0 8px;
    border-radius: 5px;
}

.msite-store .current-location button#currentLocationBtn {
    font-size: 11px;
    height: 25px;
    position: relative;
    color: #fff;
}

.msite-store .current-location svg {
    margin: 0 !important;
    width: 10px;
    position: relative;
}

.msite-store .current-location svg path {
    fill: #fff;
}

.msite-store .card-body.px-2 {
    padding-top: 0;
}
.msite-store .form-check-input:checked {
    background-color: #1b437e;
    border-color: #1b437e;
}

.msite-store .form-check-input:focus {
    box-shadow: none;
    border-color: #1b437e;
}
/* end store msite listing ui */