body {
    font-family: "Open Sans", sans-serif;
    color: #444;
    font-size: 13px;
    background: #fff;    
}

h1, h2, h3, h4, h5 {
    padding: 0;
    margin: 0;
    font-weight: normal;
}

.displayFlex {
    display: flex;
}

.marginAuto {
    margin: auto;
}

a:visited, a:hover, a:link {
    color: #e52;
}

a:link {
    text-decoration: none;
}

a:hover {
    text-decoration: underline;
}

a:active {
    color: #e52;
}

a, a:active, a:focus, li, li:active, li:focus, li:hover, button, button:active, button:focus, button:hover {
    outline: 0 !important;
}

img {
    vertical-align: middle;
}

input:-webkit-autofill {
    -webkit-box-shadow: 0 0 0px 1000px #fff inset;
}

.ui-state-highlight, .ui-state-active {
    color: #444 !important;
}

.ui-selectonemenu, .ui-selectonemenu-label, .ui-autocomplete-input, .ui-inputtext, .ui-button, .ui-inputtextarea, .ui-password, .hasDatepicker, .ui-datepicker, .ui-autocomplete-panel, .ui-selectonemenu-panel, .ui-selectonemenu-items-wrapper {
    border-radius: 8px !important;
}

.ui-selectonemenu-trigger {
    border-radius: 0 8px 8px 0 !important;
}

input {
    width: 150px !important;
    background-color: #fff !important;
}

input:hover {
    border: 1px #e52 solid !important;
}

.ui-selectonemenu {
    width: 132px !important;
    background-color: #fff !important;
}

.ui-selectonemenu:hover {
    border: 1px #e52 solid !important;
}

.loginSuccess, .loginBody, .loginSuccess {
    display: none;
}

.ui-growl {
    display: flex;
    position: absolute !important;
    top: auto !important;
    bottom: 20px !important;
    left: 5vw !important;
    width: 90vw !important;
    background: #333 !important;  
    opacity: 0.95;
    border-radius: 20px;
}

.ui-growl-item-container.ui-state-highlight {
    margin: auto !important;
    background: none !important;
    border: none !important;
    color: #fff !important;
    -webkit-box-shadow: none !important;
    -moz-box-shadow: none !important;
    box-shadow: none !important;
}

.ui-growl-item {
    padding: 5px !important;
}

.ui-growl-message {
    width: auto !important;
    font-size: 1em !important;
}

.ui-growl-title {
    text-transform: uppercase;
    font-size: 1.1em !important;
    font-weight: normal !important;
}

.ui-growl-image {
    margin: 7px 10px !important;
}

.ui-growl-image.ui-growl-image-info {
    background: url("https://app.heroh.africa/dev2/resources/images/messages/messageInfo.png") no-repeat !important;
}

.ui-growl-image.ui-growl-image-warn {
    background: url("https://app.heroh.africa/dev2/resources/images/messages/messageWarn.png") no-repeat !important;
}

.ui-growl-image.ui-growl-image-error {
    background: url("https://app.heroh.africa/dev2/resources/images/messages/messageError.png") no-repeat !important;    
}

/* *****************************************************************
   *****************************************************************
   MOBILE FIRST LAYOUT
   *****************************************************************
   ***************************************************************** */

.pc-only {
    display: none;
}

.tablet-pc {
    display: none;
}

.tablet-only {
    display: none;
}

.loginPage {
    display: flex;
    position: absolute;
    top: 0;
    left: 0;
    height: 100vh;
    width: 100vw;
    overflow-x: hidden;
}

.loginContainer {
    margin: auto;
    text-align: center;    
}

.loginHeader {
    margin: auto;
    max-width: 100%;
    overflow: hidden;
    position: relative;
}

.loginHeader img { 
    max-width: 100%;
}

.loginHeaderLogo {    
    margin: 25px auto 20px;
    max-width: 100%;
    font-size: 3.1vw;
}

.loginHeaderLogo img {
    padding-right: 20px;
    max-height: 50vh;
    max-width: 80%;
    margin-bottom: 10px;
}

.loginText {    
    margin: 0 auto 25px;
    max-width: 400px;
}

.loginPanelGrid {
    margin: auto;
    width: 90%;
}

.loginPanelLeftColumn {
    width: 50%;
    text-align: left;
}

.loginPanelRightColumn {
    width: 50%;
}

.ui-button {
    width: 160px;
    background: none;
    border-color: #e52 !important;
    text-transform: uppercase;
}

.ui-button:hover, .ui-button:focus, .ui-button:active {
    background: #e52;
    color: #fff;  
    transition: ease-in;
    transition-duration: 150ms;
}

.loginFooterContainer {
    margin: auto;
    width: 90%;
    border-top: 1px solid #ddd;
}

.loginFooter {
    padding: 5px;
    font-size: 0.8em;
}

.footerUnihealth img {
    height: 15px;
    margin: -3px 10px 0;
    opacity: 0.7;
}

.footerUnihealth img:hover {
    opacity: 1;
}

.footerSmartAfrica img {
    height: 20px;
    margin: -3px 10px 0;
}

.incompatibleBrowser {
    position: fixed;    
    top: 0px;
    left: 0px;
    height: 100vh;
    width: 100vw;    
    background: #ffffff;
    z-index: 999999;
}

.incompatibleBrowserContainer {
    width: 80vw;
    text-align: center;
    margin: 50vh auto 0;
    transform: translatey(-50%);
}

.incompatibleBrowserHeader img {
    width: 90%;
}

.incompatibleBrowserText {
    margin: 50px 0;
    font-size: 1.2em;
}

.incompatibleBrowserAltBrowsers {
    font-size: 1.2em;
}
/* *****************************************************************
   *****************************************************************
   MEDIA QUERIES - 641 and Up
   *****************************************************************
   ***************************************************************** */
@media only screen and (min-width: 641px) {

    .pc-only {
        display: none;
    }

    .tablet-pc {
        display: unset;
    }

    .tablet-only {
        display: unset;
    }

    .mobile-only {
        display: none;
    }

    .loginContainer {
        padding: 0 50px;
    }

    .loginHeader {
        max-width: 90%;
        border-radius: 15px;
        -webkit-box-shadow: 0px 0px 7px rgba(0,0,0,0.7);
        -moz-box-shadow: 0px 0px 7px rgba(0,0,0,0.7);
        box-shadow: 0px 0px 7px rgba(0,0,0,0.7);
    }

    .loginHeaderLogo {
        margin: 25px auto 35px;
        max-width: 90%;
        font-size: 2vw;
    }

    .loginHeaderLogo img { 
        max-width: 65%;
    }

    .loginText {    
        margin: 0 auto 35px;
    }

    .loginFooter {
        font-size: 1em;
    }

    .incompatibleBrowserContainer {
        width: 50vw;
    }

    .incompatibleBrowserText {
        margin: 30px 0;
    }
}

/* *****************************************************************
   *****************************************************************
   MEDIA QUERIES - 1025 and Up
   *****************************************************************
   ***************************************************************** */
@media only screen and (min-width: 1025px) {


    .pc-only {
        display: unset;
    }

    .tablet-pc {
        display: unset;
    }

    .tablet-only {
        display: none;
    }

    .tablet-mobile {
        display: none;
    }

    .mobile-only {
        display: none;
    }

    .loginHeader {
        max-width: 75%; 
    }    

    .loginHeaderLogo {
        max-width: 85%;
        font-size: 1.4vw;
    }

    .loginHeaderLogo img {
        max-width: 40%;
    }

    .loginFooterContainer {
        width: 75%;
    }

    .incompatibleBrowserHeader img {
        width: 80%;
    }

    .incompatibleBrowserText {
        font-size: 1.4em;
    }
}