@font-face {
    font-display: swap;
    font-family: 'Roboto Condensed';
    font-style: normal;
    font-weight: 300;
    src: url('../../fonts/roboto-condensed-v27-latin-300.woff2') format('woff2');
}

@font-face {
    font-display: swap;
    font-family: 'Roboto Condensed';
    font-style: normal;
    font-weight: 400;
    src: url('../../fonts/roboto-condensed-v27-latin-regular.woff2') format('woff2');
}

:root {
    --base: #3c3e44;
    --base80: #54575f;
    --base60: #858993;
    --base40: #d6d8db;
    --base20: #f4f2f1;
    --base0: #ffffff;

    --font: 'Roboto Condensed';

    --theme: #ee1c25;
    --true: #2ecc40;
    --false: var(--base60);
    --error: #ee1c25;
    --shadow: 1px 1px #000000;

    --m-radius: .25rem;
    --m-color: var(--base0);
    --m-error: var(--theme);
    --m-success: var(--true);
    --m-font: var(--font);
}

/*
-----------------------------
INIT
-----------------------------
*/
* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

main, footer, input {
    font-family: var(--font), sans-serif;
    font-size: 1.25rem;
    color: var(--base80);
}

a {
    cursor: pointer;
    text-decoration: none;
}

.full-screen {
    width: 100%;
    height: 100%;
}

body, button, input {
    font-family: 'Roboto Condensed', sans-serif;
    font-size: 1.25rem;
}

input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus {
    -webkit-text-fill-color: #ffffff;
    -webkit-box-shadow: 0 0 0 40rem #000000 inset;
}

.flex-centered {
    display: flex;
    align-items: center;
    justify-content: center;
}

.background-full {
    background-image: url("../../images/ssl/background.jpg");
    background-size: cover;
    background-position: center;
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    overflow: hidden;
}

.login-screen {
    flex-direction: column;
}

.login-form-section {
    width: 16rem;
    height: 16rem;
}

.login-form-section h1 {
    color: var(--theme);
    font-family: 'Roboto Condensed', sans-serif;
    font-size: 2rem;
    font-weight: 300;
    text-shadow: var(--shadow);
    margin: .75rem 0 0 0;
}

.login-form-section:first-child {
    flex-direction: column;
    background-color: rgba(0,0,0, .75);
    border-radius: .5rem .5rem 0 0;
    border-bottom: 1px solid #000000;
}

.login-form-section:last-child {
    flex-direction: column;
    border-radius: 0 0 .5rem .5rem;
    background-color: rgba(0, 0, 0, .75);
    padding: 2rem;
}

.login-form .form-row {
    display: grid;
    grid-template-columns: 2rem 10rem;
    border-bottom: 1px solid var(--base0);
    margin-bottom: 1.25rem;
}

.login-form .form-row i {
    font-size: 1.5rem;
    color: var(--base0);
    padding-bottom: .125rem;
}

.login-form .form-row input {
    background-color: transparent;
    color: var(--base0);
    border: none;
    outline: none;
    padding-bottom: .125rem;
}

.login-form .form-row input::placeholder {
    color: var(--theme);
    font-weight: 300;
}

.login-form button {
    margin-top: 1rem;
    color: var(--theme);
    border: 1px solid var(--theme);
}

.login-form button::before {
    background-color: var(--theme);
}

@media only screen and (min-width: 36em) {

    .login-screen {
        flex-direction: row;
    }

    .login-form-section:first-child {
        border-radius: .5rem 0 0 .5rem;
        border-right: 1px solid #000000;
        border-bottom: none;
    }

    .login-form-section:last-child {
        border-radius: 0 .5rem .5rem 0;
    }
}

/*
-----------------------------
BUTTONS
-----------------------------
*/
form button {
    display: grid;
    grid-template-columns: 2.5rem 1fr;
    align-items: center;
    justify-content: center;
    background-color: transparent;
    cursor: pointer;
    overflow: hidden;
    position: relative;
    transition: .5s all;
    line-height: 2.25rem;
    z-index: 1;
    color: var(--base60);
    border: 1px solid var(--base60);
    border-radius: .25rem;
}

form button:hover {
    color: var(--base0);
    text-shadow: var(--shadow);
}

form button i {
    color: var(--base0);
    text-shadow: var(--shadow);
    font-size: 1.5rem;
}

form button span {
    display: flex;
    padding: 0 1.25rem;
}

form button::before {
    background-color: var(--base60);
    content: " ";
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    width: 2.5rem;
    z-index: -1;
    transition: .5s all;
}

form button:hover::before {
    width: 100%;
    color: var(--base0);
}

/*
-----------------------------
FOOTER
-----------------------------
*/
footer {
    position: fixed;
    width: 100%;
    bottom: 0;
    background-color: rgba(0, 0, 0, .5);
    font-size: 1rem;
    color: var(--base40);
    text-shadow: var(--shadow);
    text-align: center;
    padding: .75rem;
    z-index: 95;
}

footer span {
    display: block;
    color: transparent;
    text-shadow: none;
    height: .25rem ;
    padding: 0;
}

@media only screen and (min-width: 50rem) {

    footer span {
        display: inline-block;
        color: var(--base40);
        text-shadow: var(--shadow);
        padding: 0 .5rem;
    }
}