:root {
    --keycloak-logo-url: url('../img/logo-el.png');
    --keycloak-bg-logo-url: none;
    --keycloak-logo-height: 71px;
    --keycloak-logo-width: 101px;
    --keycloak-card-top-color: hsl(159, 39%, 35%);

    --uni-color-primary: hsl(159, 39%, 35%);
    --uni-color-primary-dark: hsl(159, 38%, 27%);
    --uni-color-secondary: hsl(159, 39%, 35%);
    --uni-color-secondary-dark: hsl(159, 38%, 27%);

    --border-color-light: hsl(210, 14%, 73%);
    --border-color-dark: hsl(210, 14%, 94%);
    --border-radius-input: 10px;

}

/* Browser Defaults removed for Input fields */
.login-pf input,
.login-pf textarea,
.login-pf select {
    height: 40px;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;

    border: 0;
    outline: 0;
    box-shadow: none;

    background: transparent;
}

:where(body) {
    font-family: 'Roboto', sans-serif;
}

.login-pf body {
    background-color: var(--pf-v5-global--palette--black-200);
}

.pf-v5-c-login__container {
    grid-template-columns: 40rem;
}

.pf-v5-c-login__main {
    padding: 2rem 2.5rem;
    border-radius: var(--border-radius-input);
}

/* Make card a little above center */
.pf-v5-c-login {
    display: flex;
    align-items: flex-start;
    padding-top: 10vh;

}

.pf-v5-c-login__main-body {
    padding-top: var(--pf-v5-global--spacer--md);
}

.pf-v5-c-button {
    --pf-v5-c-button--m-primary--BackgroundColor: var(--uni-color-primary);
    --pf-v5-c-button--m-primary--after--BorderColor: var(--uni-color-primary);
    --pf-v5-c-button--m-secondary--Color: var(--uni-color-primary);
    --pf-v5-c-button--m-secondary--after--BorderColor: var(--uni-color-primary);
    --pf-v5-c-button--m-link--Color: var(--uni-color-primary);
    --pf-v5-c-button--m-link--m-inline--Color: var(--uni-color-primary);
    --pf-v5-c-button--after--BorderColor: var(--uni-color-primary);

    --pf-v5-c-button--BorderRadius: var(--border-radius-input);
    --pf-v5-c-button--after--BorderRadius: var(--border-radius-input);
    --pf-v5-c-button--FontWeight: 500;
    --pf-v5-c-button--FontSize: 1.125rem;
    height: 40px;


    /* Hover State */
    --pf-v5-c-button--hover--after--BorderWidth: var(--pf-v5-global--BorderWidth--sm);
    --pf-v5-c-button--m-primary--hover--BackgroundColor: transparent;
    --pf-v5-c-button--m-primary--hover--Color: var(--uni-color-primary);
    --pf-v5-c-button--m-secondary--hover--Color: var(--uni-color-primary);
    --pf-v5-c-button--m-secondary--hover--after--BorderColor: var(--uni-color-primary);
    --pf-v5-c-button--m-control--hover--after--BorderBottomColor: var(--uni-color-primary);

    /* Focus State */
    --pf-v5-c-button--m-primary--focus--BackgroundColor: var(--uni-color-primary);
    --pf-v5-c-button--m-secondary--focus--Color: var(--uni-color-primary);
    --pf-v5-c-button--m-secondary--focus--after--BorderColor: var(--uni-color-primary);
    --pf-v5-c-button--m-control--focus--after--BorderBottomColor: var(--uni-color-primary);


    /* Active State */
    --pf-v5-c-button--m-primary--active--BackgroundColor: var(--uni-color-primary);
    --pf-v5-c-button--m-secondary--active--Color: var(--uni-color-primary);
    --pf-v5-c-button--m-secondary--active--after--BorderColor: var(--uni-color-primary);
    --pf-v5-c-button--m-control--active--after--BorderBottomColor: var(--uni-color-primary);

    /* Box Shadow Transition */
    transition: box-shadow 0.2s ease;

}

.pf-v5-c-button.pf-m-primary:hover,
.pf-v5-c-button.pf-m-primary:focus-visible,
.pf-v5-c-button.pf-m-secondary:hover,
.pf-v5-c-button.pf-m-secondary:focus-visible {
    box-shadow: var(--pf-v5-global--BoxShadow--lg);
}

.pf-v5-c-button.pf-m-control.kc-login-tooltip {
    background: transparent;
    position: absolute;
    right: 0;
    bottom: 0;
}

.pf-v5-c-button.pf-m-control.kc-login-tooltip::after {
    content: none;
}

.pf-v5-c-button.pf-m-control.kc-login-tooltip:hover {
    opacity: 80%;
}

.pf-v5-c-input-group:has(.pf-v5-c-input-group__item button#password-show-password) {
    position: relative;
}

.pf-v5-c-input-group__item>button#password-show-password {
    position: absolute;
    right: 0;
    bottom: 0;
    background: transparent;
}

.pf-v5-c-input-group__item>button#password-show-password:hover>i {
    opacity: 80%;
}

.pf-v5-c-input-group__item>button#password-show-password::after {
    content: none;
}

/* Input Fields */
input.pf-v5-c-form-control {
    border-radius: var(--border-radius-input);
    border: 1px var(--pf-v5-global--BorderColor--200) solid;
    padding-block-end: var(--pf-v5-c-form-control--PaddingBottom);
    padding-block-start: var(--pf-v5-c-form-control--PaddingTop);
    padding-inline-end: var(--pf-v5-c-form-control--PaddingRight);
    padding-inline-start: var(--pf-v5-c-form-control--PaddingLeft);
}

input.pf-v5-c-form-control:hover,
input.pf-v5-c-form-control:focus-within {
    border-width: var(--pf-v5-global--BorderWidth--md);
    border-color: var(--uni-color-primary);
}

input.pf-v5-c-button {
    border: 1px var(--uni-color-primary) solid;
    color: var(--uni-color-primary);
    cursor: pointer;
    transition: top 0.2s, font-size 0.2s, opacity 0.2s;
    -webkit-transition: top 0.2s, font-size 0.2s, opacity 0.2s;
}

input.pf-v5-c-button:hover,
input.pf-v5-c-button:focus-within {
    box-shadow: var(--pf-v5-global--BoxShadow--lg);

    transition: top 0.2s, font-size 0.2s, opacity 0.2s;
    -webkit-transition: top 0.2s, font-size 0.2s, opacity 0.2s;
}

.pf-v5-c-form-control {
    --pf-v5-c-form-control--hover--after--BorderBottomColor: var(--uni-color-primary);
    --pf-v5-c-form-control--focus--after--BorderBottomColor: var(--uni-color-primary);
    --pf-v5-c-form-control--focus--before--BorderTopColor: var(--uni-color-primary);
    --pf-v5-c-form-control--m-expanded--after--BorderBottomColor: var(--uni-color-primary);
}

.pf-v5-c-form-control:has(select[aria-label="languages"]) {
    display: none;
}

.pf-v5-c-form-control::before {
    border-color: var(--pf-v5-global--BorderColor--200);
    border-radius: var(--border-radius-input);
}

.pf-v5-c-form-control::after {
    border-radius: var(--border-radius-input);
}

.pf-v5-c-form-control:hover::after,
.pf-v5-c-form-control:focus-within::after,
.pf-v5-c-form-control:hover::before,
.pf-v5-c-form-control:focus-within::before {
    border-color: var(--uni-color-primary);
}

.pf-v5-c-form-control:focus-within::after,
.pf-v5-c-form-control:focus-within::before {
    border-width: var(--pf-v5-global--BorderWidth--md);
}

/* Input Fields Error Handling */
.pf-v5-c-form-control.pf-m-error::before,
.pf-v5-c-form-control.pf-m-error::after,
.pf-v5-c-form-control.pf-m-error:focus-within::before,
.pf-v5-c-form-control.pf-m-error:focus-within::after {
    border-color: var(--pf-v5-global--danger-color--100);
}

.pf-v5-c-form-control.pf-m-error::before {
    border-width: var(--pf-v5-global--BorderWidth--md);
}

.pf-v5-c-form-control.pf-m-readonly {
    border-radius: var(--border-radius-input);
}

/* Labels */

.pf-v5-c-form__group:has(input[name="username"]),
.pf-v5-c-form__group:has(input[name="password"]) {
    position: relative;
}

.pf-v5-c-form__label {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-size: 1.125rem;
}

.pf-v5-c-form__group:has(input[name="username"])>.pf-v5-c-form__group-label,
.pf-v5-c-form__group:has(input[name="password"])>.pf-v5-c-form__group-label {
    position: absolute;
    z-index: 2;
    text-align: left;
    margin-left: 6px;
    pointer-events: none;
    opacity: 0.5;
    padding: 0 !important;
    transition: top 0.2s, font-size 0.2s, opacity 0.2s;
    -webkit-transition: top 0.2s, font-size 0.2s, opacity 0.2s;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    top: calc(40px / 2);
}

.pf-v5-c-form__group:has(input[name="username"])>.pf-v5-c-form__group-label>.pf-v5-c-form__label,
.pf-v5-c-form__group:has(input[name="password"])>.pf-v5-c-form__group-label>.pf-v5-c-form__label {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    padding-left: 2px;
    vertical-align: middle;
    transition: top 0.2s, font-size 0.2s, opacity 0.2s;
    -webkit-transition: top 0.2s, font-size 0.2s, opacity 0.2s;
}

.pf-v5-c-form__group:has(input[name="username"])>.pf-v5-c-form__group-label>.pf-v5-c-form__label i,
.pf-v5-c-form__group:has(input[name="password"])>.pf-v5-c-form__group-label>.pf-v5-c-form__label i {
    font-size: 20px;
    width: 20px;
    text-align: center;
    
    padding-bottom: 2px;
}

.pf-v5-c-form__group:has(input[name="username"])>.pf-v5-c-form__group-label>.pf-v5-c-form__label .pf-v5-c-form__label-text,
.pf-v5-c-form__group:has(input[name="password"])>.pf-v5-c-form__group-label>.pf-v5-c-form__label .pf-v5-c-form__label-text {
    color: var(--uni-color-primary);
    letter-spacing: 0.009375em;
    font-weight: var(--pf-v5-global--FontWeight--normal);
}

/* Focus state for Username and Password fields */

.pf-v5-c-form__group:has(input[name="username"]):focus-within>.pf-v5-c-form__group-label,
.pf-v5-c-form__group:has(input[name="password"]):focus-within>.pf-v5-c-form__group-label,
.pf-v5-c-form__group:has(input[name="username"]:not(:placeholder-shown))>.pf-v5-c-form__group-label,
.pf-v5-c-form__group:has(input[name="password"]:not(:placeholder-shown))>.pf-v5-c-form__group-label {
    opacity: 1;
    background: white;
    top: 0;
    transition: top 0.2s, font-size 0.2s, opacity 0.2s;
    -webkit-transition: top 0.2s, font-size 0.2s, opacity 0.2s;
}

.pf-v5-c-form__group:has(input[name="username"]):focus-within>.pf-v5-c-form__group-label .pf-v5-c-form__label,
.pf-v5-c-form__group:has(input[name="password"]):focus-within>.pf-v5-c-form__group-label .pf-v5-c-form__label,
.pf-v5-c-form__group:has(input[name="username"]:not(:placeholder-shown))>.pf-v5-c-form__group-label .pf-v5-c-form__label,
.pf-v5-c-form__group:has(input[name="password"]:not(:placeholder-shown))>.pf-v5-c-form__group-label .pf-v5-c-form__label {
    font-size: 1rem;
    transition: top 0.2s, font-size 0.2s, opacity 0.2s;
    -webkit-transition: top 0.2s, font-size 0.2s, opacity 0.2s;
}

/* Help-texts */
.pf-v5-c-form__group:has(input[name="password"]) .pf-v5-c-form__helper-text {
    margin-block-start: 0.5rem;
}

.pf-v5-c-form__group:has(input[name="password"]) .pf-v5-c-helper-text {
    font-size: 1rem;
}

header#kc-header {
    margin-block-start: auto;
    padding: 0;
}

header#kc-header>.pf-v5-c-brand {
    margin-block-end: auto;
}

:where(a) {
    color: var(--uni-color-primary);
}

.pf-v5-c-login__main-header {
    border-top: none;
}


#kc-social-providers svg:not(.google) {
    color: var(--uni-color-primary);
}

/* PrivacyIDEA Labels */
#alternateToken {
    text-align: center;
    border-block-start: 1px solid hsl(0, 0%, 82%);
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

#alternateTokenHeader {
    font-size: var(--pf-v5-global--FontSize--sm);
    color: var(--pf-v5-global--Color--200);
    padding-block-end: 1.5rem;
    padding-block-start: 1.5rem;
    padding-inline-end: 1rem;
    padding-inline-start: 1rem;
}

@media (max-width: 420px) {
    .pf-v5-c-login {
        background: var(--pf-v5-c-login__main--BackgroundColor);
        padding: 0;
        align-items: center;


        padding-top: var(--pf-v5-global--spacer--sm);
        --pf-v5-c-login__main-body--PaddingRight: var(--pf-v5-global--spacer--sm);
        --pf-v5-c-login__main-body--PaddingLeft: var(--pf-v5-global--spacer--sm);
        --pf-v5-c-login__main-body--PaddingBottom: var(--pf-v5-global--spacer--sm);
    }

    .pf-v5-c-login__main {
        border-radius: 0;
        box-shadow: none;
        margin: 0;
        height: 100%;
    }

    .pf-v5-c-login__main-header {
        padding-right: var(--pf-v5-global--spacer--sm);
        padding-left: var(--pf-v5-global--spacer--sm);
        padding-bottom: var(--pf-v5-global--spacer--sm);
    }
}

@media (max-width: 768px) {
    .pf-v5-c-login__main {
        padding: 2rem 0;
    }
}

@media (min-width: 1200px) {
    header#kc-header {
        margin-block-start: auto;
    }
}

@media (prefers-color-scheme: dark) {
    #kc-social-providers svg:not(.google) {
        filter: invert(32%) sepia(29%) saturate(720%) hue-rotate(118deg) brightness(92%) contrast(92%);
    }
}