@charset "UTF-8";

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400..900;1,400..900&display=swap');



:root {
    --color1: #4b0082;
    --color2: #0D0D0D;
    --color3: #F7DF1E;

    --font1: "Playfair Display", serif;

}

* {
    font-family: var(--font1);

    margin: 0px;
    padding: 0px;
    box-sizing: border-box;
}

body,
html {
    background: rgb(1, 1, 1) url(../Estilos/imagens/fundo_black.jpg);
    background-size: cover;
    background-repeat: no-repeat;
    height: 100vh;
    width: 100vw;
}

main {
    position: relative;
    min-height: 95vh;
    width: 100vw;
}

section#login-cadastro {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);

    background-color: white;
    width: 300px;
    height: 580px;
    border-radius: 20px;
    box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.4);

    display: flex;
    justify-content: center;
    align-items: center;
}

/*botoes dentro de login-cadastro*/

.btn-login-cadastro {

    background-color: var(--color2);
    width: 100%;

    color: var(--color3);


    position: absolute;
    top: 15px;

    display: flex;
    justify-content: center;
    gap: 55px;
}

.btn-login-cadastro button {
    background-color: var(--color2);
    border: none;
    color: var(--color3);
}

.btn-login-cadastro button:hover {
    text-decoration: underline;
    cursor: pointer;
}

section#login-cadastro{
    background-color: var(--color2);
    
}


section#login-cadastro input{
    color: #0D0D0D;
}

section#login {

    margin-top: 35px;

    position: absolute;
    top: 45%;
    left: 50%;

    overflow: hidden;

    background-color: var(--color2);
    width: 250px;
    height: 515px;
    border-radius: 20px;



    transition: width .3s, height .3s;
    transition-timing-function: ease;
    transform: translate(-50%, -50%);


}

#container-forms {
    margin-top: 190px;
    position: relative;
    width: 100%;
    height: 100%;
    overflow: hidden;
    transition: all 0.6s ease-in-out;

    z-index: 2;
}

.form-box {
    position: absolute;
    top: 0;
    width: 100%;
    height: 100%;
    padding: 20px;
    color: white;
    background-color: var(--color2);
    transition: all 0.6s ease-in-out;
}

section#login #img {
    position: absolute;
    height: 200%;
    width: 100%;
    top: 0;
    right: 0;
    background: url(../Estilos/imagens/pexels-bao-dang-1259885-3700369.jpg) center/cover no-repeat;
    transition: all 0.6s ease-in-out;
    background-size: cover;
    background-position: bottom center;

    z-index: 1;
    
}

section#login.active #img {
    top: 100%;
}




section#login>div#form-login {
    padding: 10px;
    display: block;
}

div#form-login {
    margin-top: 5px;
    background-color: #0D0D0D;
    color: white;
}

div#form-login>h1 {
    text-align: center;
    margin-bottom: 10px;
}

div#form-login>p {
    font-size: 0.8em;
}

div#form-cadas>h1 {
    text-align: center;
    margin-bottom: 10px;
}

div#form-cadas>p {
    font-size: 0.8em;
}

form>div.campo {
    background-color: var(--color1);
    border-radius: 4px;
    height: 30px;
    margin-top: 4px;
    padding: 4px;
}

div.campo>input {
    height: 100%;
    width: 90%;
    border-radius: 4px;
    padding: 10px;
    font-size: 0.8em;
}

div.campo i {
    color: white;
}

#btn-entrar {
    margin-top: 5px;
    font-size: 1em;
    width: 100%;
    height: 35px;
    border: 2px solid black;
    border-radius: 5px;
    cursor: pointer;
}

#btn-entrar:hover {
    border: 3px solid var(--color1);
    color: var(--color3);
    background-color: var(--color2);
}

form>a.botao {
    padding-top: 3px;
    margin-top: 4px;
    display: block;
    text-align: center;
    font-size: 1em;
    width: 100%;
    height: 35px;
    background-color: white;
    border: 2px solid black;
    border-radius: 5px;
    text-decoration: none;
    color: black;
}

form>a.botao:hover {
    border: 3px solid var(--color1);
    color: var(--color3);
    background-color: var(--color2);
}

/*Form de cadastro*/

/* --- Login e Cadastro alternam posição --- */
#form-cadas {
    left: 100%;
    opacity: 0;
}

#form-login {
    left: 0;
    opacity: 1;
    color: #0D0D0D;
}


section#login.active #form-login {
    left: -100%;
    opacity: 0;
}

section#login.active #form-cadas {
    left: 0;
    opacity: 1;
}



section#login.active #img {
    right: 50%; 

}



/*Se o email ja estiver cadastrado*/

.input-erro{
    border: 1px solid red;
}


.erro{
    color: var(--color3);
    font-size: 13px;
    display: block;
    margin-top: 4px;
}
