﻿body {
    margin: 0;
    padding: 0;
    line-height: 1;
    font-family: Roboto, sans-serif;
}

    body.all {
        background-color: #001349;
    }

.body-container {
    display: flex;
    justify-content: center;
}

.plusone-header {
    width: 100%;
    display: flex;
    justify-content: center;
    margin-bottom: 24px;
}

    .plusone-header > .title {
        background-image: url("../medadvisor.svg");
        background-repeat: no-repeat;
        width: 210px;
        height: 49px;
        opacity: 1;
    }


.error-page .title {
    text-align: center;
    font-weight: 600;
}

.error-page .body {
    text-align: center;
    margin-top: 10px;
}

.error-page-container {
    display: flex;
    justify-content: center;
    margin-top: 150px;
}

.error-page .link {
    text-align: center;
    margin-top: 30px;
    text-decoration: underline;
}

.navbar-header {
    position: relative;
    top: -4px;
}

#loading {
    display: none;
    background: rgba(0, 0, 0, .1) url('../ajax-loader.gif') no-repeat 50% 50%;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 9999999;
}

.navbar-brand > .icon-banner {
    position: relative;
    top: -2px;
    display: inline;
}

.icon {
    position: relative;
    top: -10px;
}

.icon-visibility {
    background-image: url("../visibility.svg");
    background-repeat: no-repeat;
    width: 24px;
    height: 24px;
}

.icon-visibility-off {
    background-image: url("../visibility_off.svg");
    background-repeat: no-repeat;
    width: 24px;
    height: 24px;
}

.icon-success {
    background-image: url("../success.svg");
    background-repeat: no-repeat;
    width: 80px;
    height: 80px;
    margin-bottom: 8px;
}

.logged-out iframe {
    display: none;
    width: 0;
    height: 0;
}

.form-group {
    margin-bottom: 26px;
}

.form-control {
    height: 43px;
    padding: 6px 12px;
    font-size: 16px;
    color: #222222;
    border: 1px solid #999999;
    margin-bottom: 4px;
}

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

.form-group > label {
    font-size: 16px;
    color: #222222;
    font-weight: 500;
    margin-bottom: 8px;
}

.form-group > .form-check {
    display: flex;
    align-items: center;
}

    .form-group > .form-check > .form-check-input {
        width: 18px;
        height: 18px;
    }

    .form-group > .form-check > .form-check-label {
        font-size: 16px;
        font-weight: 500;
        margin-left: 12px;
        margin-bottom: -7px;
    }

.validation-summary-errors ul, .validation-summary-valid ul {
    list-style: none;
    margin-left: -40px
}

input[type=checkbox] {
    accent-color: #00217F;
}

.btn, .btn:focus {
    outline: unset;
}

.btn-default, .btn-default:hover, .btn-default:active {
    width: 100%;
    height: 43px;
    font-size: 16px;
    color: #FFFFFF !important;
    background-color: #00217F !important;
    border-color: #00217F;
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
}

.btn-outline, .btn-outline:hover, .btn-outline:focus {
    width: 100%;
    height: 43px;
    font-size: 16px;
    color: #00217F;
    background-color: #FFFFFF;
    border: 2px solid #00217F;
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
}

.content {
    padding: 32px 44px;
    background: #FFFFFF 0% 0% no-repeat padding-box;
    box-shadow: 0px 3px 8px #00000029;
    border-radius: 16px;
    opacity: 1;
    min-width: 40%;
    max-width: 80%;
    margin-bottom: 24px;
    position: relative;
}

.login-page .lead, .logged-out-page .lead {
    color: #00217F;
    font-size: 18px;
    text-align: center;
    margin-bottom: 32px;
}

.login-page .login-instruction {
    font-size: 16px;
    margin-bottom: 16px;
    text-align: center;
    line-height: 1.4;
    width: 400px;
}

.login-page .forgot-password-section {
    margin: 26px 0 34px 0;
}

.login-page #forgot-password {
    color: #5586FF;
    font-size: 16px;
}

.login-page .help-section {
    font-size: 16px;
    color: #222222;
}

    .login-page .help-section a {
        color: #5586FF;
        cursor: pointer;
    }



.forgot-password-page .title, .forgot-password-confirmation-page .title, .enable-authenticator-page .title {
    color: #00217F;
    font-size: 22px;
    text-align: center;
    margin-bottom: 32px;
}

.forgot-password-page .description, .forgot-password-confirmation-page .description {
    color: #222222;
    font-size: 16px;
    text-align: center;
    margin-bottom: 24px;
}

.forgot-password-page .button-container {
    display: flex;
    align-items: center;
    width: 100%;
    gap: 12px;
}

.forgot-password-confirmation-page {
    display: flex;
    flex-direction: column;
    align-items: center;
}

    .forgot-password-confirmation-page .title {
        line-height: 1.2;
    }

.enable-authenticator-page .title {
    text-align: left !important;
}

.enable-authenticator-page .description {
    font-size: 16px;
    color: #222222;
    line-height: 1.3;
}

.enable-authenticator-page .list {
    font-size: 16px;
    color: #222222;
    padding: 26px 26px 0 26px;
}

    .enable-authenticator-page .list .instruction {
        display: flex;
        align-items: center;
        gap: 25px;
        justify-content: center;
    }

        .enable-authenticator-page .list .instruction .enter-key {
            display: flex;
            flex-direction: column;
            gap: 8px;
            align-items: center;
        }

            .enable-authenticator-page .list .instruction .enter-key .shared-key {
                background-color: #E5E8F2;
                color: #222222;
                padding: 8px 12px;
                border-radius: 4px;
            }

        .enable-authenticator-page .list .instruction .or {
            font-weight: bold;
        }

        .enable-authenticator-page .list .instruction .scan-barcode {
            gap: 16px;
            background-color: #E5E8F2;
            color: #222222;
            padding: 16px;
            border-radius: 4px;
        }

.enable-authenticator-page li {
    margin-bottom: 24px;
    line-height: 1.3;
}

.enable-authenticator-page ol {
    list-style-type: decimal-leading-zero;
}

    .enable-authenticator-page ol > li::marker {
        font-weight: bold;
    }

.enable-authenticator-page #send-code {
    margin-top: 24px;
}

.login-with-2fa-page h1, .login-with-recovery-code-page h1 {
    color: #00217F;
    font-size: 22px;
    text-align: center;
    margin: 0 0 32px 0;
    padding: 0 40px;
}

.login-with-2fa-page .recovery-code {
    color: #222222;
    font-size: 16px;
    line-height: 1.3;
    text-align: center;
}

.login-with-recovery-code-page .description {
    color: #222222;
    font-size: 16px;
    line-height: 1.3;
    text-align: center;
    margin-bottom: 26px;
}

.logged-out-page {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
}

    .logged-out-page h1 {
        margin-top: 10px
    }

    .logged-out-back-login {
        width: 100%;
    }

    .page-consent .client-logo {
        float: left;
    }

    .page-consent .client-logo img {
        width: 80px;
        height: 80px;
    }

.page-consent .consent-buttons {
    margin-top: 25px;
}

.page-consent .consent-form .consent-scopecheck {
    display: inline-block;
    margin-right: 5px;
}

.page-consent .consent-form .consent-description {
    margin-left: 25px;
}

    .page-consent .consent-form .consent-description label {
        font-weight: normal;
    }

.page-consent .consent-form .consent-remember {
    padding-left: 16px;
}

.grants .page-header {
    margin-bottom: 10px;
}

.grants .grant {
    margin-top: 20px;
    padding-bottom: 20px;
    border-bottom: 1px solid lightgray;
}

    .grants .grant img {
        width: 100px;
        height: 100px;
    }

    .grants .grant .clientname {
        font-size: 140%;
        font-weight: bold;
    }

    .grants .grant .granttype {
        font-size: 120%;
        font-weight: bold;
    }

    .grants .grant .created {
        font-size: 120%;
        font-weight: bold;
    }

    .grants .grant .expires {
        font-size: 120%;
        font-weight: bold;
    }

    .grants .grant li {
        list-style-type: none;
        display: inline;
    }

        .grants .grant li:after {
            content: ', ';
        }

        .grants .grant li:last-child:after {
            content: '';
        }

.toggle-icon {
    position: relative;
    top: -36px;
    float: right;
    margin-right: 12px;
}

.reset-password-page {
    font-family: Roboto, sans-serif;
}

    .reset-password-page .title {
        margin-bottom: 34px;
        color: #00217F;
        height: 27px;
        font-size: 22px;
        text-align: center;
    }

    .reset-password-page .instruction {
        color: #222222;
        font-size: 16px;
        text-align: center;
        line-height: 22px;
        margin-bottom: 24px;
        width: 390px;
    }

    .reset-password-page .btn-submit {
        margin: 32px 0 26px 0;
    }

    .reset-password-page .help-section {
        font-size: 16px;
        color: #222222;
    }

        .reset-password-page .help-section a {
            color: #5586FF;
            cursor: pointer;
        }

.reset-password-confirmation-page {
    font-family: Roboto, sans-serif;
    display: flex;
    flex-direction: column;
    align-items: center;
}

    .reset-password-confirmation-page .title {
        color: #00217F;
        font-size: 22px;
        line-height: 31px;
        height: 58px;
        margin: 8px 104px 34px 104px;
        display: grid;
        text-align: center;
    }

    .reset-password-confirmation-page .description {
        color: #222222;
        font-size: 16px;
        line-height: 22px;
        height: 41px;
        display: grid;
        text-align: center;
    }

.select-location-page {
    font-family: Roboto, sans-serif;
    max-width: 400px;
}

    .select-location-page .title {
        margin-bottom: 24px;
        color: #00217F;
        height: 58px;
        font-size: 22px;
        text-align: center;
        line-height: 31px;
        display: grid;
    }

    .select-location-page .description {
        color: #222222;
        font-size: 16px;
        line-height: 22px;
        height: 41px;
        text-align: center;
        margin-top: 34px;
    }

    .select-location-page .btn-default:disabled,
    .select-location-page .btn-default[disabled] {
        background-color: #E0E0E0 !important;
        color: #999999 !important;
        box-shadow: 0px 0px 8px #00000014;
        border-radius: 4px;
    }

    .select-location-page .btn-confirm {
        margin: 32px 0px 34px 0px
    }

    /* Removing the default arrow */
    .select-location-page select {
        -webkit-appearance: none;
        appearance: none;
    }

    .select-location-page #SelectedValue {
        background-image: url("../expand_more.svg");
        background-size: 24px;
        background-repeat: no-repeat;
        background-position: calc(100% - 8px) center;
    }

/*For Manage Account*/
.manage-account {
    font-family: Roboto, sans-serif;
}

    .manage-account .alert-success {
        color: #FFFFFF;
        background-color: #069B4F;
        height: 53px;
        line-height: 22px;
        margin: 24px 24px 43px 24px;
        font-size: 16px;
    }

    .manage-account .close {
        color: #FFFFFF;
        opacity: 1;
        font-weight: normal;
        font-size: 25px;
        text-shadow: none;
    }

        .manage-account .close:hover {
            color: #FFFFFF;
        }

.manage-account-plusone-header {
    width: 100%;
    display: flex;
    background-color: #001349;
}

    .manage-account-plusone-header > .title {
        background-image: url("../medadvisor.svg");
        background-repeat: no-repeat;
        width: 210px;
        height: 49px;
        margin-top: 13px;
        margin-left: 28px;
        margin-bottom: 9px;
    }

.two-factor-authentication-page {
    margin-top: 120px;
    margin-left: 256px;
}

    .two-factor-authentication-page > .title {
        height: 32px;
        text-align: left;
        letter-spacing: 0px;
        color: #222222;
        line-height: 36px;
        font-size: 26px;
    }

.authenticator-app-section {
    margin: 22px 0;
}

    .authenticator-app-section > span, .recovery-codes-section > span {
        height: 19px;
        text-align: left;
        font-size: 16px;
        letter-spacing: 0px;
        color: #222222;
        line-height: 22px;
    }

    .authenticator-app-section .btn-primary, .recovery-codes-section .btn-primary, .back-to-home .btn-primary {
        background-color: #00217F !important;
        border-color: #00217F !important;
    }

    .authenticator-app-section .btn, .recovery-codes-section .btn, .back-to-home .btn {
        letter-spacing: 0.16px;
        height: 43px;
        line-height: 2;
        box-shadow: 0px 0px 8px #00000014;
        min-width: 214px;
    }

    .authenticator-app-section .group, .recovery-codes-section .group {
        margin-top: 8px;
        display: flex
    }

    .authenticator-app-section .btn-outline-primary {
        background-color: #FFFFFF !important;
        border: 1px solid #00217F !important;
        color: #00217F !important;
    }

    .authenticator-app-section #enable-authenticator {
        margin-right: 12px;
    }

.navigation {
    border: 1px solid #E0E0E0;
    height: 107px;
    display: flex;
}

    .navigation .left {
        width: 48px;
        height: 43px;
        background-color: #00217F;
        box-shadow: 0px 0px 8px #00000014;
        border-radius: 4px;
        margin: 32px 12px 32px 24px;
    }

    .navigation .arrow-back {
        background-image: url(../arrow_back.svg);
        width: 24px;
        height: 24px;
        margin: 10px 12px;
    }


    .navigation .title {
        height: 31px;
        text-align: left;
        font-weight: bold;
        letter-spacing: 0px;
        color: #222222;
        font-size: 22px;
        font-family: Poppins, sans-serif;
        margin: 38px 0;
        line-height: 31px;
    }

.enable-authenticator-page {
    margin: 12px 282px 256px;
}

.reset-authenticator-page, .generate-recovery-page {
    margin: 12px 306px 0 256px;
}

    .reset-authenticator-page .btn-danger, .generate-recovery-page .btn-danger {
        background-color: #FF5153 !important;
        font-size: 16px !important;
        border-color: #FF5153 !important;
        line-height: 22px;
        width: 300px;
        height: 43px;
    }

    .reset-authenticator-page .warning-content, .generate-recovery-page .warning-content, .show-recovery-codes-page .warning-content {
        border-radius: 4px;
        background-color: #E5E8F2;
        display: flex;
        margin-bottom: 22px;
    }

    .reset-authenticator-page .warning-content {
        min-height: 163px;
    }

    .reset-authenticator-page .warning-icon, .generate-recovery-page .warning-icon, .show-recovery-codes-page .warning-icon {
        background-image: url(../warning-icon.svg);
        width: 80px;
        height: 80px;
        margin-top: 16px;
        margin-left: 16px;
        margin-right: 16px;
    }

    .reset-authenticator-page .warning-message, .generate-recovery-page .warning-message, .show-recovery-codes-page .warning-message {
        margin: 16px 32px 18px 0px;
        display: grid;
        font-size: 16px;
        color: #222222;
        line-height: 22px;
    }

    .generate-recovery-page .warning-content {
        min-height: 205px;
    }

.show-recovery-codes-page {
    margin: 0 306px 0 256px;
}

    .show-recovery-codes-page .warning-content {
        min-height: 117px;
        margin-bottom: 24px;
    }


    .show-recovery-codes-page .title {
        height: 32px;
        text-align: left;
        font-size: 26px;
        letter-spacing: 0px;
        color: #222222;
        opacity: 1;
        margin-bottom: 24px;
        line-height: 36px;
    }

    .show-recovery-codes-page .show-code {
        margin-bottom: 24px;
    }

    .show-recovery-codes-page .group-code {
        display: flex;
        margin-bottom: 16px;
    }

    .show-recovery-codes-page .recovery-code {
        background-color: #E5E8F2;
        border-radius: 4px;
        opacity: 1;
        margin-right: 10px;
        padding: 8px;
        color: #222222;
        font-size: 14px;
        width: 80px;
        height: 33px;
        text-align: center;
    }

.align-self-center {
    align-self: center;
}

@media (max-width: 1200px) {
    .enable-authenticator-page .list .instruction .enter-key,
    .enable-authenticator-page .list .instruction .enter-key .shared-key,
    .enable-authenticator-page .list .instruction .or {
        display: flex;
        flex-direction: column;
        flex-wrap: wrap;
    }

    .enable-authenticator-page .list .instruction .or {
        width: auto;
    }

    .enable-authenticator-page .list .instruction {
        display: flex;
        flex-direction: column;
    }
}

@media (max-width: 1024px) {
    .enable-authenticator-page {
        margin: 12px 120px 120px !important;
    }

    .content {
        min-width: 480px;
    }
}

@media (max-width: 600px) {
    .enable-authenticator-page {
        margin: 12px 12px 12px !important;
    }
}
