.SystemNotifications {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 0;
    overflow: hidden;
    z-index: 2;
}

.SystemNotifications .wrapper {
    position: absolute;
    width: 100%;
    bottom: 0
}

.SystemNotification {
    position: relative;
    height: auto;
    overflow: hidden;
    transition: height .4s linear;
}

.SystemNotification.error {
    background-color: var(--c-red);
    margin-bottom: 0;
}

.SystemNotification.warning {
    background-color: var(--c-yellow)
}

.SystemNotification.information {
    background-color: var(--c-warm-grey)
}

.SystemNotification.success {
    background-color: var(--c-green)
}

.SystemNotification .wrapper {
    padding: var(--s4) var(--s8);
    font-weight: var(--font-weight-bold);
    position: inherit;
}

.SystemNotification.error .wrapper,
.SystemNotification.success .wrapper {
    color: var(--c-white)
}

.notification-content {
    display: flex;
    flex-direction: column;
    margin-right: var(--s4)
}

@media (min-width: 1056px) {
    .notification-content {
        flex-direction: row
    }
}

.notification-text {
    flex: 1
}

.notification-link {
    white-space: nowrap
}

.SystemNotification .wrapper .close-button {
    position: absolute;
    top: 12px;
    right: 12px;
    padding: 0;
    border: none;
    background: transparent;
    cursor: pointer
}

.SystemNotification.error .wrapper .close-button,
.SystemNotification.success .wrapper .close-button {
    color: var(--c-white)
}

.fullscreen {
    min-height: 100vh;
    width: 100vw;
    display: flex
}

.fullscreen>* {
    width: 100%
}

.fullscreen .wrapper {
    background-color: var(--c-dark-green);
}

.fullscreen .wrapper .content {
    display: flex;
    flex-direction: column;
    margin: 0 auto;
    max-width: 1312px;
    height: 100vh
}

.fullscreen .wrapper .content.animate {
    overflow: hidden
}

@media (min-width: 1056px) {
    .fullscreen .wrapper .content {
        height: 100vh;
        flex-direction: row
    }
}

@media (min-width: 1056px) {
    .fullscreen .wrapper .content.animate {
        overflow: auto
    }
}

.fullscreen .wrapper .content .welcome {
    display: flex;
    flex-direction: column;
    padding: 96px var(--s4) var(--s8);
    transition: margin 1s
}

@media (min-width: 672px) {
    .fullscreen .wrapper .content .welcome {
        padding: 160px 112px 96px
    }
}

@media (min-width: 1056px) {
    .fullscreen .wrapper .content .welcome {
        height: 100%;
        flex: 1;
        padding: 160px var(--s10) var(--s10)
    }
}

@media (min-width: 1312px) {
    .fullscreen .wrapper .content .welcome {
        padding-left: 0
    }
}

.fullscreen .wrapper .content .welcome.hidden {
    display: none;
}

.fullscreen .wrapper .content .welcome-mobile {
    height: 1px;
    transition: margin 1s;
    padding: 0;
}

@media (min-width: 320px) {
    .fullscreen .wrapper .content .welcome.animate {
        margin-bottom: 100vh
    }
}

@media (min-width: 1056px) {
    .fullscreen .wrapper .content .welcome.animate {
        margin-bottom: 0
    }
}

.fullscreen .wrapper .content .login {
    position: relative;
    display: flex;
    flex-direction: column;
    overflow: auto;
    width: 100%;
    height: 100%;
    background-color: var(--c-white);
    padding: var(--s8) var(--s4) var(--s4);
    transition: width 1.5s, padding .25s linear .75s
}

@media (min-width: 672px) {
    .fullscreen .wrapper .content .login {
        padding: 96px 112px 48px
    }
}

@media (min-width: 1056px) {
    .fullscreen .wrapper .content .login {
        padding: 160px 64px 64px;
        max-width: 416px
    }
}

@media (min-width: 1312px) {
    .fullscreen .wrapper .content .login {
        max-width: 544px;
        padding: 160px 80px 64px
    }
}

@media (min-width: 1584px) {
    .fullscreen .wrapper .content .login {
        padding: 160px 96px 55px
    }
}

@media (min-width: 1056px) {
    .fullscreen .wrapper .content .login.animate {
        width: 0;
        padding: 0
    }
}

.fullscreen .wrapper .content .login .inner {
    transition: opacity .5s, visibility .5s;
    display: flex;
    flex-direction: column;
    height: 100%
}

@media (min-width: 1056px) {
    .fullscreen .wrapper .content .login .inner.animate {
        opacity: 0;
        visibility: hidden
    }
}

.fullscreen .wrapper .content .login .inner .support {
    margin-top: auto;
    display: flex;
    flex-direction: column;
    padding-bottom: var(--s4);
    padding-top: 60px
}

.fullscreen .wrapper .content .login .inner .support .logo {
    align-self: end;
    margin-top: 56px;
    width: 120px
}

@media (min-width: 1056px) {
    .fullscreen .wrapper .content .login .inner .support .logo.animate {
        visibility: hidden
    }
}

.TextInput .note {
    display: block;
    font-size: 15px;
    line-height: 20px;
    padding-left: var(--s2)
}

.note.white {
    color: var(--c-dark-grey);
}

.sanitas-button {
    display: inline-flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    height: 50px;
    width: auto;
    min-width: 120px;
    line-height: 24px;
    padding: 10px 36px 10px 26px;
    background: none;
    border-radius: 25px;
    font-weight: 700;
    font-size: 15px;
    font-stretch: normal;
    font-style: normal;
    letter-spacing: .25px;
    outline: none;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    font-family: Open Sans, sans-serif;
    border: 2px solid darkred;
    background-color: #90ee90;
    color: darkred
}

.sanitas-button:not(.has-text) {
    padding-right: 26px
}

.sanitas-button:not(.is-spinning):not(.has-icon):not(.is-link) {
    padding-left: 36px
}

.submit {
    margin: var(--s4) 0
}

.sanitas-button.is-fullwidth {
    width: 100%
}

.sanitas-button.is-primary {
    background-color: var(--c-light-green);
    border: 2px solid var(--c-light-green);
    color: var(--c-white);
    fill: var(--c-white)
}

.sanitas-button.is-primary.is-disabled,
.sanitas-button.is-primary:disabled {
    background-color: var(--c-light-grey);
    border: 2px solid var(--c-light-grey);
    color: #F1F1F1
        /* equals rgba(255, 255, 255, 0.6) on #DDDDDD background */
}

.sanitas-button.is-primary.is-disabled:hover,
.sanitas-button.is-primary:disabled:hover {
    cursor: default;
    background-color: var(--c-light-grey);
    border: 2px solid var(--c-light-grey);
    color: #F1F1F1
        /* equals rgba(255, 255, 255, 0.6) on #DDDDDD background */
}

.sanitas-button.is-primary:hover {
    cursor: pointer;
    border-color: var(--c-light-green-hover);
    background-color: var(--c-light-green-hover);
    color: var(--c-white);
    fill: var(--c-white)
}

.sanitas-button.is-secondary {
    background-color: transparent;
    border: 1px solid var(--c-light-green);
    color: var(--c-light-green);
    fill: var(--c-light-green)
}

.sanitas-button.is-secondary.is-disabled,
.sanitas-button.is-secondary:disabled {
    background-color: transparent;
    opacity: .5
}

.sanitas-button.is-secondary:hover {
    cursor: pointer;
    color: var(--c-light-green-hover);
    fill: var(--c-light-green-hover);
    border: 1px solid var(--c-light-green-hover)
}

.links {
    list-style-type: none;
    margin-top: var(--s8)
}

.input.isPassword~.actions button {
    margin-left: 0;
    width: 48px;
    height: 50px
}

.icon {
    background-color: transparent;
    border: none;
    padding: 0;
    overflow: hidden
}

.input.isPassword~.actions {
    background-color: var(--c-light-grey)
}

.actions {
    position: absolute;
    display: flex;
    align-items: center;
    justify-content: center;
    top: 0;
    right: 0;
    bottom: 0;
    height: 50px;
    padding-right: var(--s1)
}

.input.hasValue~.label,
.input:focus~.label {
    top: 4px;
    font-size: 12px
}

.label.hasActions {
    padding-right: 50px
}

.label {
    color: var(--c-dark-grey);
    position: absolute;
    font-size: 15px;
    transition: all .25s ease;
    top: 20px;
    line-height: 1.5;
    left: 10px;
    pointer-events: none;
    overflow: hidden;
    text-overflow: ellipsis;
    width: calc(100% - 20px);
    white-space: nowrap
}

.label.errors {
    color: var(--c-red)
}

.error {
    color: var(--c-red)
}

.input.hasActions {
    padding-right: 60px
}

.input.white {
    background-color: var(--c-warm-grey)
}

.input {
    border: none;
    box-shadow: 0 1px 0 var(--c-dark-grey);
    padding: 20px 0 5px 10px;
    height: 50px;
    width: 100%;
    font-size: 18px;
    line-height: 1
}

.input:focus {
    outline: none;
    box-shadow: 0 2px 0 var(--c-dark-grey)
}

.input:-moz-read-only {
    box-shadow: none;
    color: var(--c-dark-grey)
}

.input:disabled,
.input:read-only {
    box-shadow: none;
    color: var(--c-dark-grey)
}

.input::-moz-placeholder {
    color: var(--c-dark-grey)
}

.input::placeholder {
    color: var(--c-dark-grey)
}

.input::-ms-clear {
    display: none;
    height: 0;
    width: 0
}

.TextInput {
    margin-bottom: 20px;
    width: 100%
}

.TextInput :not(input).error {
    display: block;
    font-size: 15px;
    line-height: 20px;
    padding-left: var(--s2);
    width: 100%;
}

.TextInput .inner {
    position: relative;
    display: flex;
    align-items: center
}

.error {
    margin-bottom: var(--s5)
}

.message--error {
    background-color: var(--c-red-25)
}

.message--info {
    background-color: var(--c-warm-grey)
}

.message {
    padding: var(--s4);
    position: relative;
    cursor: default;
    color: var(--c-black);
    display: flex;
    flex-flow: row nowrap;
    justify-content: flex-start;
    align-items: flex-start
}

.severity-icon {
    margin-top: var(--s2);
    margin-right: var(--s4)
}

.s-16 {
    font-size: 16px
}

.s-18 {
    font-size: 18px
}

.s-24 {
    font-size: 24px
}

.c-lightGreen {
    color: var(--c-light-green)
}

.c-darkGrey {
    color: var(--c-dark-grey)
}

.heading {
    margin-bottom: var(--s4)
}

.heading3 {
    font-family: var(--font-family-open-sans);
    font-weight: var(--font-weight-light);
    color: var(--c-black);
    font-size: 20px;
    line-height: 24px
}

@media (min-width: 672px) {
    .heading3 {
        font-size: 25px;
        line-height: 32px
    }
}

.modal-mask {
    position: fixed;
    z-index: 9998;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(25, 25, 25, .5);
    display: flex;
    align-items: center;
    transition: opacity .3s ease;
}

.modal-mask.thin .modal-container {
    max-width: 620px
}

@media (min-width: 1056px) {
    .modal-mask.thin .modal-container {
        max-width: 620px
    }
}

.modal-mask.no-padding .modal-container {
    padding: 0
}

@media screen {
    @media (min-width: 0px) {
        .modal-mask.fit-content .modal-container {
            width: fit-content
        }
    }
}

.modal-wrapper {
    flex: 1;
    height: 100%;
    overflow: scroll;
}

@media (min-width: 672px) {
    .modal-wrapper {
        overflow: visible
    }
}

@media (min-width: 1056px) {
    .modal-wrapper {
        height: auto
    }
}

.modal-container {
    margin: 0 auto;
    background-color: var(--c-white);
    transition: all .3s ease;
    position: relative;
    height: 100%;
    padding: var(--s5) var(--s2);
    overflow: var(--c877962a);
}

.modal-container .modal-body {
    transition: height .3s ease-in-out;
    height: calc(100% - 30px);
}

.modal-container .modal-body .content {
    display: flex;
    flex-direction: column;
    height: auto;
}

.modal-container .close-icon-container {
    position: absolute;
    top: var(--s6);
    right: var(--s6);
    cursor: pointer;
}

.modal-container .close-icon-container.withHeader {
    top: var(--s3);
    right: var(--s3)
}

@media (min-width: 1056px) {
    .modal-container {
        width: 930px;
        max-width: 90%;
        max-height: 80vh;
        padding: var(--s5) var(--s7)
    }
}

@media (min-width: 1312px) {
    .modal-container {
        width: 960px
    }
}

.modal-default-button {
    float: right
}

.modal-enter,
.modal-leave-active {
    opacity: 0
}

.modal-enter .modal-container,
.modal-leave-active .modal-container {
    transform: scale(1.1)
}

.insurance-card-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    height: 100%
}

.insurance-card {
    margin-top: var(--s5);
    max-width: 500px;
    max-height: 300px;
    width: 100%
}

.insurance-card-text {
    margin-top: var(--s4)
}

.s-20 {
    font-size: 20px
}

.buttons {
    margin-top: var(--s9);
    display: flex;
    flex-direction: column-reverse;
    margin-bottom: var(--s4)
}

@media (min-width: 1056px) {
    .buttons {
        justify-content: space-between;
        flex-direction: row;
    }
}

@media (min-width: 543px) {
    .sanitas-button.is-fullwidth-sm {
        width: auto;
    }
}

.cancel {
    margin-top: var(--s4);
}

@media (min-width: 1056px) {
    .cancel {
        margin: 0;
    }
}

.has-account-note {
    background-color: var(--c-warm-grey);
    padding: var(--s4);
    margin-bottom: var(--s4);
}

/* ~~~~~~~~~~~~~ custom styles for keycloak-template start 👇🏼 ~~~~~~~~~~~~~ */

.svg-inline--fa.hidden {
    display: none;
}

.TextInput .note.hidden {
    display: none;
}

.TextInput :not(input).error.hidden {
    display: none;
}

.hidden {
    display: none;
}

.resentOtp {
    margin-top: var(--s8);
    display: block;
}



/* ~~~~~~~~~~~~~ custom styles for keycloak-template end 👆🏼 ~~~~~~~~~~~~~~~ */
