
@font-face {
    font-family: 'ro-sans';
    src: url('../font/ROsanswebtextregular.woff') format('woff');
}

html, body {
    height: 100%;
    width: 100%;
    padding: 0;
    margin: 0;

    font-family: 'ro-sans', sans-serif;
    font-size: 16px;
}

@media (min-width: 800px) and (min-height: 400px) {
    html, body {
        font-size: 20px;
    }
}

a {
    color: #01689b;
}
a:visited {
    color: #884488;
}

.rws-header-bar {
    background-color: #f3f3f3;
    width: 100%;
    padding: .25em 0;
    display: flex;  
    justify-content: flex-end;
}

.rws-header-bar > * {
    margin: 0 .5em 0 0;
}

#kc-locale {
    margin-right: auto;
}
#kc-locale ul {
    display: flex;  
    list-style: none;
    margin: 0 0 0 .25em;
    padding: 0;
}
#kc-locale li {
    margin: 0 .25em;
}

img.logo {
    width: 44px;
    height: 77px;
    display: block;
    margin: auto auto;
}

#kc-page-title {
    font-size: 1.5em;
    margin: .5em 0;
}

.rws-alert {
    padding: .25em;
    margin-bottom: 1em;
}

#kc-page-title {
    text-align: center;
}

#kc-content {
    width: 32em;
    max-width: 100%;
    margin: auto;
}

#kc-form-login {
    background-color: #f3f3f3;
    padding: 1em;
}

#kc-form-register {
    background-color: #f3f3f3;
    padding: 1em;
}

.rws-form-group {
    display: flex;
    flex-wrap: wrap;
    padding: .25em;
}

.rws-form-label {
    display: inline-flex;
    align-self: center;
    width: 15em;
}

.rws-form-input {
    display: inline-flex;
    align-self: center;
    flex-grow: 1;
    margin: .25em 0;
    padding: .25em;
    font-size: .75em;
}

.rws-button {
    background-color: #0073bf;
    color: white;
    min-width: 10em;
    font-size: .75em;
    padding: .5em;
    margin: .25em;
    border: none;
}
.rws-button:hover {
    background-color: #154273;
    cursor: pointer;
}

#kc-form-buttons {
    margin: auto;
    padding-top: 1em;
}

.kc-forgot-pwd {
    margin-left: auto;
    font-size: .75em;
}

.alert-error {
    background-color: #f9dfdd;
}
