.login-wrapper {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #ffffff;
}

.login-card {
    background: #ffffff;
    padding: 25px 30px;
    width: 620px;
    border-radius: 0; /* sharp */
}

.login-logo {
    width: 100px;
    height: 100px;
    display: flex;
    justify-content: center;
    justify-self: center;
    font-weight: 800;
    margin-bottom: 5%;
}

.login-card h2 {
    margin: 0 0 5px;
    justify-self: center;
    color: #5f0f0f;
    font-size: 32px;
    text-align: center;
}

.login-subtitle {
    margin: 0 0 15px;
    justify-self: center;
    color: #777;
    font-size: 16px;
    text-align: center;
}

.login-error {
    background: #ffe5e5;
    color: #a30000;
    padding: 8px 10px;
    margin-bottom: 10px;
    border: 1px solid #f5b5b5;
    font-size: 0.9rem;
}

.login-card label {
    display: block;
    margin-top: 10px;
    margin-bottom: 4px;
    font-size: 0.9rem;
    color: #333;
}

.login-card input {
    width: 100%;
    padding: 8px 10px;
    border: 1px solid #987575;
    border-radius: 0;
    box-sizing: border-box;
}

.btn-login {
    margin-top: 15px;
    width: 100%;
    padding: 9px 0;
    border: 1px solid #5f0f0f;
    background: #5f0f0f;
    color: #fff;
    cursor: pointer;
    border-bottom-left-radius: 20px;
    box-shadow: 23px -31px 400px -28px rgba(138,0,0,0.39) inset;
-webkit-box-shadow: 23px -31px 400px -28px rgba(138,0,0,0.39) inset;
-moz-box-shadow: 23px -31px 400px -28px rgba(138,0,0,0.39) inset;
}
