@import url('https://fonts.googleapis.com/css2?family=Karla:wght@400;700&family=Poppins:wght@400;500;700&display=swap');

.input-boxes input,
.input-boxes button {
    padding: 16px 24px !important;
    box-shadow: 0px 4px 8px 0px #E7E9F2;
}

p,
h1,
h2,
h3,
h4,
h5,
h6,
button,
div {
    font-family: Poppins, sans-serif !important;
}

h4.page-header {
    font-size: 32px;
    color: #333333;
}

h3.modal-header {
    font-size: 24px;
    line-height: 28px;
    letter-spacing: 0.16px;
    color: #333333;
    font-weight: 500;
}

h1.oc-heading1 {
    font-size: 40px;
    font-weight: 500;
    line-height: 100%;
    letter-spacing: 0px;
    vertical-align: middle;
    color: #333333;
}

p.large {
    font-family: Karla, sans-serif;
    font-weight: 400;
    font-size: 18px;
    line-height: 27px;
    letter-spacing: 0.13px;
}

p.desc {
    font-size: 16px;
    line-height: 28px;
    letter-spacing: 0.16px;
    color: #2D2C2C;
}

p.desc.bold {
    font-weight: 600;
}

.modalclosebtn svg {
    fill: #2D2C2C;
}

.margin-b-16 {
    margin-bottom: 16px;
}

.margin-b-24 {
    margin-bottom: 24px;
}

.margin-t-14 {
    margin-top: 14px;
}

p.info {
    font-size: 16px;
    line-height: 28px;
    font-family: Karla, sans-serif;
}

p.info.black {
    color: #2D2C2C;
}

p.info.bold {
    font-weight: 700;
}

p.info.blue {
    color: #1F64E5;
}

/* Button CSS  */
.primaryBtn.slds-button {
    background-color: #1F64E5;
    border-radius: 4px;
    color: #ffffff;
    font-size: 16px;
    font-weight: 500;
    letter-spacing: 0.6px;
    line-height: 17px;
    text-align: center;
    text-transform: uppercase;
    height: 56px;
    width: 300px;
    justify-content: center;
}

/* Radio button customiztion*/
.radion-inputs .slds-radio {
    position: relative;
    display: flex;
    align-items: center;
    border: 1px solid #d0cfcf;
    cursor: pointer;
    margin-bottom: 1rem;
    border-radius: 4px;
    background: #FFF;
    box-shadow: 0px 4px 8px 0px #E7E9F2;
}

.radion-inputs label {
    display: inline-block;
    width: 100%;
    padding-left: 16px;
    cursor: pointer;
    align-content: center;
    height: 56px;
}

.slds-radio span.slds-form-element__label {
    font-size: 16px !important;
    color: #333;
    font-family: Poppins, sans-serif;
    font-weight: 500;
    line-height: 24px;
    letter-spacing: 0.01px;
}

.email-input,
input {
    height: 59px;
}

.mobile-input,
input {
    height: 59px;
}

.language-input button {
    min-height: 59px;
    padding-top: 15px;
}

.region-dropdown button {
    min-height: 59px;
    padding-top: 15px;
}

.modal-input-field label {
    color: #333;
    font-family: Poppins, sans-serif;
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: 27px;
    /* 168.75% */
    letter-spacing: 0.129px;
}

.appointmentDetails-footer .homePage-btn {
    margin-right: 0;
}

.comm-page-custom-appointment-scheduler .slds-card {
    background-color: #F7F9FA;
    border: none;
}

.forceCommunityFlowCommunity {
    border: none;
}

.comm-page-custom-appointment-scheduler [lwc-3uma98d0eu4-host] {
    background-color: transparent;
}

.disclosure-options-checkbox .slds-form-element__control {
    display: flex;
    flex-direction: column;
    gap: 16px;
    margin-bottom: 36px;
}

.disclosure-options-checkbox .slds-form-element__control .slds-checkbox .slds-form-element__label {
    color: #333;
    font-family: Poppins, sans-serif;
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: 21px;
    /* 131.25% */
    letter-spacing: 0.114px;
}

.auth-sign-date button {
    display: none;
}

.italic-font {
    font-style: italic;
}

.virtual-btn .slds-button.slds-button_brand,
.buttons-wrapper .primaryButton {
    background-color: #1F64E5;
    font-family: Poppins, sans-serif !important;
    font-size: 16px;
    line-height: 17px;
    letter-spacing: 0.1px;
    text-align: center;
    padding: 16px 10px;
    border-radius: 4px;
    text-transform: uppercase;
}

.virtual-btn.full-width .slds-button.slds-button_brand {
    width: 100%;
}

.slds-has-error div.slds-form-element__help {
    color: #E91C1F;
}

.id-page .slds-has-error div.slds-form-element__help {
    color: #E91C1F;
    margin-top: 4px;
}
.id-page .lanClass .slds-has-error div.slds-form-element__help, .id-page .accoClass .slds-has-error div.slds-form-element__help{
    position: absolute;
}

.id-page div.slds-form-element__help {
    margin-top: 0;
}

.checkin-input .slds-input {
    border-radius: 4px;
    border: 1px solid #D0CFCF;
    background: #FFF;
    box-shadow: 0px 4px 8px 0px #E7E9F2;
    padding: 16px 30px;
}

.checkin-input.slds-has-error .slds-input {
    border: 1px solid #ea001e;
    box-shadow: 0 0 0 1px inset #ea001e;
}

.no-appt-style .mainContent {
    border: 2px dashed #D0CFCF;
}

.slds-progress-bar__value {
    background: #003D9C;
}

/* CTPS Fixes */

main {
    background: #eff0f2;
}

flowruntime-lwc-field>.container {
    margin: 0 10%;
    position: relative;
    background: transparent;
    background-clip: padding-box;

}

flowruntime-lwc-field .container .main-container {
    margin: 0;

}

flowruntime-lwc-field .container .main-content {
    border-radius: .25rem;
    -webkit-box-shadow: 0 2px 2px 0 rgba(0, 0, 0, .1);
    box-shadow: 0 2px 2px 0 rgba(0, 0, 0, .1);
}

flowruntime-lwc-field .container .main-content.appt-confirm {
    border-radius: none;
    -webkit-box-shadow: unset;
    box-shadow: unset
}

flowruntime-flow {
    background-color: #eff0f2 !important;
    margin-top: -60px;
}

.appt-time-combobox .slds-combobox__input {
    border: 0;
    border-radius: 4px;
}


.question .slds-checkbox span.slds-form-element__label,
.question .slds-radio span.slds-form-element__label {
    font-family: Poppins, sans-serif;
    font-weight: 400;
    font-size: 16px;
    line-height: 21px;
    letter-spacing: 0.11px;
}

.question .slds-checkbox,
.question .slds-radio {
    margin-top: 8px;
}

.question .slds-rich-text-editor__output span {
    font-family: Poppins, sans-serif;
    font-weight: 500;
    font-size: 16px;
    line-height: 100%;
    letter-spacing: 0.13px;
}

.error-block {
    visibility: hidden;
    width: 0;
    height: 0;
    overflow: hidden;
}


@media only screen and (max-width: 1023px) {
    h1.oc-heading1 {
        font-size: 32px !important;
    }

    .virtual-btn.full-width .slds-button.slds-button_brand {
        width: 100%;
    }
}

@media only screen and (max-width: 767px) {
    flowruntime-lwc-field>.container {
        margin: 0;
    }
}

.slds-spinner:before,
.slds-spinner:after,
.slds-spinner__dot-a:before,
.slds-spinner__dot-b:before,
.slds-spinner__dot-a:after,
.slds-spinner__dot-b:after {
    background-color: #3371E7;
}

.slds-assistive-text abbr[title] {
    display: none;
}