h2 {
    margin: 0;
    font-size: 24px;
    margin-bottom: 32px;
}

.login-section {
    width: 368px;
    display: block;
    margin: 80px auto;
    background-color: #FFFFFF;
    box-shadow: 0px 7px 10px 0px rgba(0, 0, 0, 0.5);
    border-radius: 16px;
}

.login-section .container {
    padding: 48px;
}

.login-form {
    margin-bottom: 16px;
    font-size: 16px;
}

.login-form input[type="email"],
.login-form input[type="password"] {
    display: block;
    margin-bottom: 16px;
    width: -webkit-fill-available;
    height: 40px;
    border: none;
    background-color: #F6F6F6;
    border-radius: 4px;
    padding: 0 12px;
}

.login-form input[type="checkbox"] {
    width: auto;
    height: auto;
    margin: 0;
}

.btn-with-icon {
    position: relative;
    width: 100%;
}

.btn-with-icon .btn {
    width: 272px;
    margin: 0 auto;
    height: 40px;
}

.btn-with-icon img {
    position: absolute;
    right: .75rem;
}

.login-form a {
    text-align: center;
    display: block;
    margin-top: 12px;
    color: #0096E5;
    font-size: 14px;
}

.footer {
    width: 100%;
    background-color: #eeeeee;
}

.footer .container {
    background-color: #D4D4D4;
    max-width: none;
}

.character {
    width: 85px;
    height: 121px;
    margin-bottom: -6px;
    margin-left: 85%;
    max-width: 370px;
}

@media screen and (max-width: 640px) {
    .login-section {
        /* height: 320px; */
        width: 345px;
    }

    .login-section .container {
        padding: 32px;
    }

    .character {
        margin-left: 75%;
    }

    .footer {
        width: 100%;
        margin-top: 0;
    }
}
