/* Allgemeines Layout */
/* ------------------------------------------- */

.login-body {
    display: flex;
    justify-content: center;
    align-items: center;
}

.login-content {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    margin: 0;
    box-sizing: border-box;
    height: 100vh;    
    width: 80%;
    max-width: 35rem;
}


/* Willkommenszitat */
/* ------------------------------------------- */

.quote-block {
    text-align: center;
    font-family: 'Georgia', serif; 
    margin-bottom: 5em;
}

.quote-block blockquote {
    font-size: 2.5em;
    font-style: italic;
    margin: 0;
    padding: 0;
}

.quote-block figcaption {
    font-size: 0.9em;
    margin-top: 0.5em;
    text-align: right; 
    font-style: normal;
}


/* Formularelemente */
/* ------------------------------------------- */

.login-form {
    width: 100%;
    margin: 1em 0;
    display: flex;
    flex-direction: row;
    gap: 1em;
}

.password-input {
    flex: 1;
}

/* Login-Button */
.login-button {
    min-width: 130px;
    position: relative;
    display: inline-flex;
    overflow: hidden;
    align-items: center;
    justify-content: center;
}
.login-text, .login-icon {
    position: absolute;
    transition: all 0.3s ease;
}
.login-icon {
    transform: translateX(-150%); /* Startposition außerhalb */
    opacity: 0;
}

.login-button:hover .login-text {
    /* transform: translateX(150%);  */
    opacity: 0;
}

.login-button:hover .login-icon {
    transform: translateX(0); /* Icon reinfahren */
    opacity: 1;
}
