@charset "UTF-8";

:root {
    --azul-escuro: #103042;
    --azul-meio-escuro: #1f5677;
    --cinza-claro: #ebebeb;
    --azul-claro: #238ac6;
    --fonte-tituloh2: clamp(3em, 4vw, 4em);
    --fonte-tituloh3: 
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    font-family: Arial, Helvetica, sans-serif;
}

a {
    text-decoration: none;
}

header {
    position: sticky;
    top: 0;
    z-index: 5;
}

header > nav {
    background-color: var(--azul-escuro);
    display: flex;
    justify-content: space-between;
    align-self: flex-start;
    align-items: center;
    p#nome {
        color: var(--cinza-claro);
        font-size: clamp(1.3em, 3vw, 1.8em);
        font-family: 'Times New Roman', Times, serif;
        margin: 15px 0px 15px 15px;
    }
    ul {
        list-style: none;
        display: flex;
        li {
            height: 100%;
            a {
                background-color: var(--azul-escuro);
                display: block;
                padding: 25px;
                height: 100%;
                color: var(--cinza-claro);
                transition: background .3s;
            }
            a:hover {
                background-color: var(--azul-meio-escuro);
            }
        }
    }
    #menuIcone {
        display: none;
        font-size: 2.1em;
        color: var(--cinza-claro);
        padding: 12px;
        cursor: pointer;
    }
}

main {
    overflow: hidden;
}

/*Início section#inicio-container*/
section#inicio-container {
    background-image:  url(../images/fundo-inicio.jpg);
    display: grid;
    grid-template-rows: 1fr 12fr 3fr;
    min-height: calc(105vh - 68.4px);
}

/*Início div#conteudo-inicio*/
div#conteudo-inicio {
    grid-row: 2;
    display: grid;
    grid-template-columns: 360px 350px;
    justify-content: center;
    align-items: center;
    gap: 40px;

    #texto-inicio {
        background-color: var(--azul-claro);
        padding: 30px;
        border: 3px solid white;
        max-width: 360px;
        
        h2 {
            grid-column: 1;
            font-size: clamp(1.4em, 2.5vw, 2em);
            font-family: 'Times New Roman', Times, serif;
            margin-bottom: 10px;
            color: var(--azul-escuro);

            span {
                font-size: 1.2em;
                color: var(--cinza-claro);
            }
        }
        p {
            color: var(--azul-escuro);
            font-family: 'Times New Roman', Times, serif;
            font-size: clamp(1em, 2vw, 1.2em);
            font-weight: bold;
        }
    }

    picture > img {
        grid-column: 2;
        max-width: 350px;
        animation: saltar 5s ease-in-out infinite;
    }
}

@keyframes saltar {
    0%   { transform: translate(0, 0); }

    4%  { transform: translate(15px, -20px); }
    8%  { transform: translate(30px, 0); }
    12%  { transform: translate(30px, 0); }

    16%  { transform: translate(45px, -20px); }
    20%  { transform: translate(60px, 0); }
    24%  { transform: translate(60px, 0); }

    28%  { transform: translate(75px, -20px); }
    32%  { transform: translate(90px, 0); }
    36%  { transform: translate(90px, 0); }

    40%  { transform: translate(105px, -20px); }
    44% { transform: translate(120px, 0);}
    48% { transform: translate(120px, 0);}

    52% { transform: translate(105px, -20px); }
    56% { transform: translate(90px, 0)}
    60% { transform: translate(90px, 0)}

    64% { transform: translate(75px, -20px);}
    68% { transform: translate(60px, 0);}
    72% { transform: translate(60px, 0);}

    76% { transform: translate(45px, -20px);}
    80% { transform: translate(30px, 0);}
    84% { transform: translate(30px, 0);}

    88% { transform: translate(15px, -20px);}
    92% { transform: translate(0, 0);}
    100% { transform: translate(0, 0);}
}
/*Fim section#inicio-container*/

#conteudo-container h2 {
    position: absolute;
    margin-top: -37px;
    color: var(--azul-escuro);
    font-size: var(--fonte-tituloh2);
    text-shadow: 0px 0px 20px var(--cinza-claro);
}

#projetos, #contatos {
    display: grid;
    grid-template-columns: 1fr 70vw 1fr;
}

/*Início #sobre-mim*/
#container-title-sobre-mim {
    width: 70vw;
    height: 4em;
    margin: auto;
}

#sobre-mim {
    display: grid;
    grid-template-columns: 1fr 70vw 1fr;
    #inicio-sobre-mim {
        grid-column: 2;
        display: flex;
        justify-content: space-between;
        #stacks-sobre-mim {
            display: flex;
            flex-direction: column;
            gap: 40px;
            .stacks-item {
                h4 {
                    color: var(--azul-escuro);
                    margin-bottom: 15px;
                    font-size: 1.6em;
                }
                .stacks-tags {
                    display: flex;
                    flex-flow: row wrap;
                    gap: 12px;
                    p {
                        padding: 10px;
                        border: 2px solid var(--azul-escuro);
                        border-radius: 8px;
                        color: var(--azul-escuro);
                    }
                }
            }
        } /* Fim div#stacks-sobre-mim */
        #info-sobre-mim {
            background-color: var(--azul-escuro);
            color: var(--cinza-claro);
            border-radius: 50% 0 0 50%;
            display: grid;
            align-content: center;
            text-align: end;
            padding-left: 50px;
            max-width: 500px;
            margin-top: -4em;
            h3 {
                font-size: clamp(2em, 3.5vw, 2.8em);
            }
            p {
                margin: 20px 0;
                font-size: clamp(1em, 2vw, 1.2em);
            }
            #icones-sociais {
                font-size: clamp(2.4rem, 4vw, 3rem);
                display: flex;
                justify-content: right;
                gap: 20px;
                a {
                    color: var(--cinza-claro);
                }
            }
        } /* Fim div#info-sobre-mim*/
    }
}

article#sobre-mim > div#fundo-azul {
    background-color: var(--azul-escuro);
    columns: 3;
    margin-left: -1px;
    margin-top: -4em;
    z-index: -1;
}

div.linha {
    grid-column: 2;
    width: 100%;
    height: 2px;
    background-color: var(--azul-escuro);
    border-radius: 1px;
    margin: 90px 0px;
}
/*Fim #sobre-mim*/

/*Início div#cards-container*/
article#sobre-mim > div#cards-container {
    grid-column: 2;
    display: flex;
    flex-flow: row wrap;
    gap: 20px;
    text-align: center;
    margin-bottom: 150px;
    .card {
        justify-content: space-between;
        background-color: var(--azul-escuro);
        color: var(--cinza-claro);
        padding: 40px;
        box-shadow: 0px 0px 15px rgba(0, 0, 0, 0.350);
        border-radius: 8px;
        flex: 1 1 300px;
        
        i {
            font-size: 5em;
        }
        h4 {
            padding: 20px 0px;
            font-size: 1.3em;
        }
        p {
            font-size: 1em;
        }
    }
} /*Fim div#card-container*/

/*Início #projetos*/
#projetos {
    background-color: var(--azul-claro);
    #conteudo-projetos {
        grid-column: 2;
        display: flex;
        flex-flow: row wrap;
        justify-content: space-between;
        gap: 20px;
        margin-top: 4em;
        h2 {
            margin-top: -100px;
        }

        .projeto-info {
            background-color: var(--azul-escuro);
            flex: 1 1 340px;
            border-radius: 8px;
            color: var(--cinza-claro);
            overflow: hidden;
            box-shadow: 0px 0px 15px rgba(0, 0, 0, 0.350);
            img {
                width: 100%;
            }

            .descricao-projeto {
                margin: 0 20px 20px;
                h3 {
                    margin-top: 20px;
                }
                .tags-projeto {
                    display: flex;
                    flex-flow: row wrap;
                    gap: 10px;
                    margin: 20px 0;
                    
                    p {
                        flex: 0 0 auto;
                        padding: 10px;
                        border: 2px solid var(--cinza-claro);
                        border-radius: 8px;
                    }
                }
                a#link-repo-projeto {
                    background-color: var(--cinza-claro);
                    font-size: clamp(1.2rem, 2vw, 1.4rem);
                    text-align: center;
                    display: block;
                    padding: 20px;
                    color: var(--azul-escuro);
                    border: 2px solid var(--cinza-claro);
                    border-radius: 30px;
                    transition: background .3s, color .3s;
                }
                a#link-repo-projeto:hover {
                    background-color: #091a24;
                    color: var(--cinza-claro);
                }
            }
        }
    }
}

#botao-projetos {
    grid-column: 2;
    background-color: var(--azul-escuro);
    padding: 25px;
    margin: 40px auto 120px auto;
    border-radius: 40px;
    font-size: clamp(1.2em, 3vw, 1.6em);
    text-decoration: none;
    color: var(--cinza-claro);
    box-shadow: 0px 0px 15px rgba(0, 0, 0, 0.350);
    transition: background .3s;
}

#botao-projetos:hover {
    background-color: var(--azul-meio-escuro);
}

#botao-projetos:visited {
    text-decoration: none;
    color: var(--cinza-claro);
}
/*Fim #projetos*/

/*Início contatos*/
#contatos > #conteudo-contatos > h2 {
    margin-top: -36px;
}

#contatos {
    background-color: var(--cinza-claro);
    #conteudo-contatos {
        grid-column: 2;
        #entrar-em-contato {
            margin: 4em 0;
            background-color: var(--azul-escuro);
            display: grid;
            grid-template-columns: 1fr 55%;
            justify-content: space-between;
            gap: 40px;
            color: var(--cinza-claro);
            padding: clamp(20px, 5vw, 40px);
            border-radius: 10px;
            h3 {
                font-size: 2.6em;
                margin-bottom: 10px;
                span {
                    color: var(--azul-claro);
                    font-size: 3rem;
                }
            }
            #redes-sociais {
                display: flex;
                flex-flow: row wrap;
                gap: 10px;
                a {
                    color: var(--cinza-claro);
                    font-size: 1.4rem;
                    text-decoration: underline;
                }
            }
            form {
                display: flex;
                flex-direction: column;
                gap: 10px;
                margin-top: 10px;
                .form-info, #botao-enviar {
                    width: 100%;
                    padding: 10px;
                    background-color: transparent;
                    font-size: 1.1rem;
                    color: var(--cinza-claro);
                    border: 2px solid var(--cinza-claro);
                    border-radius: 8px;
                    outline: none;
                    transition: border .3s;
                }
                .form-info:focus, .form-info:hover {
                    border-color: #091a24;
                }
                textarea {
                    height: 250px;
                    resize: none;
                }
                #botao-enviar {
                    background-color: var(--cinza-claro);
                    color: var(--azul-escuro);
                    padding: 15px;
                    cursor: pointer;
                    transition: background-color .3s, color .3s;
                }
                #botao-enviar:hover {
                    background-color: #091a24;
                    color: var(--cinza-claro);
                }
            }
        }
    }
} /*Fim #contatos*/

footer {
    background-color: var(--azul-escuro);
    text-align: center;
    color: var(--cinza-claro);
    font-size: 1.2rem;
    padding: 12px;
    a {
        color: var(--cinza-claro);
        font-weight: bold;
        transition: color .3s;
    }
}

footer > a:hover {
    color: var(--azul-claro);
}