@charset "UTF-8";

@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,700;1,700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Poppins&display=swap');

:root {
    --fonte1: 'Poppins', sans-serif;
    --fonte2: Arial, Helvetica, sans-serif;

    --cor1: #210291;
    --cor2: #FFFF00; 
    --cor3: #6a7cf5;
    --cor4: #555973;

}

/* AVISO DE COOKIES */

.cookieConsentContainer {
    z-index:999;
    width:350px;
    min-height:20px;
    box-sizing:border-box;   
    padding: 25px;
    background: rgba(0, 0, 0, 0.952);
    overflow: hidden;
    position: fixed;
    bottom: 65px;
    left: 25px;
    display: none;
}

.cookieConsentContainer .cookieTitle a {
    font-family: OpenSans,arial,sans-serif;
    color:#fff;
    font-size: 16px;
    line-height: 20px;
    display: block;
}
.cookieConsentContainer .cookieDesc p {
    margin:0;
    padding:0;
    font-family: OpenSans,arial,sans-serif;
    color:#fff;
    font-size: 14px;
    line-height: 20px;
    display: block;
    margin-top: 10px;
}
.cookieConsentContainer .cookieDesc a {
    font-family:OpenSans,arial,sans-serif;
    color:#fff;
    text-decoration: underline;
}

.cookieConsentContainer .cookieDesc a:hover {
    color: var(--cor3);
}

.cookieConsentContainer .cookieButton a {
    display: inline-block;
    font-family: OpenSans,arial,sans-serif;
    color:#fff;
    border-radius: 5px;
    font-size: 14px;
    font-weight: 700;
    margin-top: 14px;
    background:var(--cor4);
    box-sizing: border-box;
    padding: 10px 15px;
    text-align: center;
    transition: 0.3s;
}
.cookieConsentContainer .cookieButton a:hover {
    cursor:pointer;
    background:var(--cor3);
}

@media (max-width:500px) {
    .cookieConsentContainer {
        bottom:0!important;
        left:0!important;
        width:100%!important;
    }
    }

/* GERAIS */

* {
    margin: 0px;
    padding: 0px;
    box-sizing: border-box;
}

body {
    font-family: var(--fonte1);
    margin: 0;
    padding: 0;
}

#home, #sobre, #livros, #diagramacao, #contato, #agradecimento {
    display: flex;
    padding: 0px 25px;
    margin: 25px auto;
    margin-bottom: 50px;
}

h1 {
    margin-bottom: 15px;
}

a {
    color: white;
    font-weight: bold;
    text-decoration: none;
}

a:hover {
    color: var(--cor3);
    transition: 0.3s;
}

p {
    font-weight: 400;
    margin-bottom: 15px;
}

/* ESTILOS MENU PRINCIPAL */

.container-menu {
    max-width: 1550px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

header {
    background-color: #fff;
    padding: 15px 0;
    border-bottom: 1px solid #b6b9c2;
}

.logo img {
    max-width: 150px;
    padding-top: 10px;
    text-align: center;
}

span#burguer {
    color: var(--cor4);
    display: block;
    text-align: center;
    padding: 10px;
    cursor: pointer;
}

span#burguer:hover {
    color: var(--cor3);
}

nav > ul {
    list-style-type: none;
    margin: 0;
    padding: 0;
}

nav a {
    display: block;
    padding: 10px;
    text-decoration: none;
    background-color: var(--cor4);
    color: white;
    text-align: center;
    border-top: 2px solid #4e4b55;
    font-family: var(--fonte1);
    font-weight: bolder;
}

nav > ul > li > a:hover {
    color: var(--cor2);
    transition: 0.3s;
}

ul#itens li {
    letter-spacing: 1px;
    margin-left: 32px;
}

/* ESTILOS MAIN, HTML E BODY */

main {
    flex: 1;
    font-family: var(--fonte1);
    line-height: 1.3;
    height: 92vh;
    min-width: 300px;
    max-width: 1200px;
    margin: auto;
}

main h1 {
    font-size: 2em;
}

main h2 {
    font-size: 1em;
    margin-bottom: 25px;
}

html, body {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

.container-botao {
    display: flex;
    justify-content: center;
}

.embed-container {
    display: flex;
    position: relative;
    padding-bottom: 56.25%;
    height: 0;
    overflow: hidden;
    max-width: 100%;
    height: auto;
    margin-top: 30px;
    margin-bottom: 30px;
}
.embed-container iframe, .embed-container object, .embed-container embed {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.container-home button {
    margin: 25px 0px;
    border: var(--cor3);
}

.container-home button a {
    padding: 15px;
    margin: 25px 0px;
    color: white;
    background-color: var(--cor3);
    border: none;
    border-radius: 10px;
    cursor: pointer;
}

.container-home button a:hover {
    color: var(--cor4);
    background-color: var(--cor2);
    transition: 0.3s;
}

/* VÍDEO HOME*/

.video {
    margin-bottom: 25px;
}

.video p {
    text-align: center;
}

.video h2 {
    text-align: center;
}

/* HOME */

main#home {
    display: flex;
    flex-direction: column;
    align-items: left;
}

section.home {
    display: flex;
    text-align: center;
    flex-direction: column;
    margin: 40px 20px;
    width: 300px;
    padding: 0px 15px;
    align-items: center;
}

section.home h2 {
    font-size: 1.2em;
}

/* DIAGRAMAÇÃO */

section.diagramacao {
    margin: 40px 0px;
}

.diagramacao h2 {
    margin-top: 40px;
    margin-bottom: 15px;
    font-size: 1.2em;
}

.diagramacao button {
    color: white;
    background-color: #6a7cf5;
    font-weight: bold;
    padding: 15px 10px;
    border: none;
    border-radius: 10px;
    cursor: pointer;
    margin-top: 25px;
}

.diagramacao button:hover {
    color: black;
    background-color: var(--cor2);
    transition: 0.3s;
}

/* ESTILOS GERAIS CONTAINERS */

.container-home img, .container-sobre img, .container-diagramacao img, .container-contato img {
    width: 100%;
    border-radius: 25px;
    margin-bottom: 25px;
}

/* ESTILOS CONTATO */

.container-contato {
    min-width: 300px;
}

.container-contato p {
    text-align: left;
}

#formulario {
    display: flex;
    justify-content: center;
    min-width: 290px;
    font-size: 1em;
}

#formulario form {
    width: 100%;
}

#formulario fieldset {
    padding: 25px 15px;
    border-radius: 10px;
    margin-top: 15px;
}

#formulario label {
    display: flex;
    margin-top: 5px;
}

#formulario input {
    display: flex;
    padding: 10px 15px;
    border-radius: 10px;
    width: 85%;
    border-style: double;  
}

#formulario textarea {
    border-radius: 10px;
    padding: 10px 15px;
}


#formulario button {
    color: white;
    font-weight: bold;
    background-color: var(--cor3);
    margin-top: 50px;
    font-size: 1.2em;
    padding: 15px 40px;
    border: none;
    border-radius: 10px;
    cursor: pointer;
}

#formulario button:hover {
    background-color: var(--cor2);
    color: black;
    transition: 0.3s;
}

#container-botao {
    display: flex;
    justify-content: center;
}

/* PÁGINA AGRADECIMENTO */

.container-agradecimento {
    margin-top: 20%;
    text-align: center;
    font-size: x-large;
}

/* PÁGINA LIVROS */

.container-livros {
    margin: 40px 0px;
    display: block;
    flex-wrap: wrap;
    max-width: 1200px;
    margin: 0 auto;
    padding: 20px;
    gap: 20px;
}

.box-livro img {
    width: 200px;
    height: auto;
    border-radius: 5px;
}

.box-livro h2 {
    margin-top: 15px;
    margin-bottom: 15px;
    font-size: 1.2em;
}

.box-livro p {
    font-size: 0.9em;
}

.botao button {
    color: white;
    background-color: #6a7cf5;
    font-weight: bold;
    padding: 15px 10px;
    border: none;
    border-radius: 10px;
    cursor: pointer;
}

.botao button:hover {
    color: black;
    background-color: var(--cor2);
    transition: 0.3s;
}

.container {
    display: flex;
    max-width: 1200px;
    margin: 0 auto;
    padding: 20px;
    gap: 20px
}

.box-livro {
    flex: 1;
    padding: 20px;
    background-color: #ffffff;
}

.box-video {
    flex: 1;
    padding: 20px;
    background-color: #ffffff;
}

@media (min-width: 768px) {
    .box-livro, .box-video {
        flex: 1 1 48%;
    }
}

@media screen and (max-width: 992px) {

    .container-livros {
        padding: 5px;

    }

    .container {
        display: flex;
        flex-direction: column;
        padding: 0px;
    }

    .box-livro, .box-video {
        flex: 1;
        padding: 0px;
    }

    .embed-container {
        position: relative;
        padding-bottom: 56.25%; /* Proporção de 16:9 (altura/largura * 100) */
        height: 0;
        overflow: hidden;
        max-width: 100%;
        background: #000;
    }
    
    .embed-container iframe {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        border: 0;
    }

}


/* ESTILOS FOOTER */

footer {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    font-family: var(--fonte1);
}

footer a:hover {
    color: var(--cor3);
}

footer#primario {
    background-color: var(--cor4);
    color: white;
    font-size: 0.7em;
    border-bottom: 1px solid #434149;
}

.logo-footer-primario img {
    max-width: 200px;
    height: auto;
    padding-bottom: 5px;
}

.logo-footer-primario p {
    margin-bottom: 10px;
}

footer#secundario {
    background-color: var(--cor4);
    color: white;
    text-align: center;
    font-size: 0.8em;
    padding-top: 8px;
    padding-bottom: 4px;
}

.conteudo-footer-primario {
    display: flex;
    flex-direction: column;
    text-align: center;
    padding: 15px 0px;
}

.conteudo-footer-secundario {
    display: flex;
    flex-direction: column;
    gap: 15px;
    margin: auto;
    width: 90%;
    justify-content: center;
    padding: 15px 0px;
}

.texto-footer-secundario-juridico {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.texto-footer-secundario-direitos {
    margin-top: 10px;
    margin-bottom: 5px;
}

.texto-footer-secundario-direitos a, .texto-footer-secundario-juridico a {
    color: white;
    font-weight: bolder;
    text-decoration: none;
}

footer .texto-footer-secundario-direitos span {
    color: rgb(243, 74, 74);
}

/* SEÇÃO SOCIAL */

.social {
    display: flex;
    margin: auto;
}

.social > button {
    width: 25px;
    height: 25px;
    margin-left: 10px;
    background-color: var(--cor4);
    border: none;
    border-radius: 50%;
    cursor: pointer;
}

.social > button a {
    text-decoration: none;
}

.social > button i {
    font-size: 15px;
    color: white;
}

.social > button i:hover {
    color: var(--cor3);
}

/* ESTILOS JURÍDICO */

main#juridico {
    background-color: white;
}

.docs-juridicos {
    padding: 0px 25px;
}

.docs-juridicos h1 {
    font-size: 1em;
    line-height: 25px;
}

.docs-juridicos h2 {
    font-size: 0.8em;
    line-height: 25px;
}

.docs-juridicos h3 {
    font-size: 0.8em;
    line-height: 25px;
}

.docs-juridicos p {
    font-size: 0.8em;
    line-height: 25px;
    text-align: justify;
}

.texto-juridico {
    width: 90%;
    margin: 0px auto;
    color: black;
    text-align: justify;
    
}

main > .container-juridico {
    padding: 25px 0px;
}

main > .container-juridico h1 {
    padding: 20px 0px;
    font-size: 1.5em;
    text-align: left;
}

main > .container-juridico h3 {
    font-size: 0.9em;
    padding-bottom: 15px;
}

main > .container-juridico p {
    padding-bottom: 20px;
}

main > .container-juridico a {
    font-weight: bolder;
    color: var(--cor3);
}

main > .container-juridico a:hover {
    color: var(--cor3);
}

main > .container-juridico button {
    padding: 15px;
    margin-bottom: 25px;
    background-color: red;
    border: none;
    border-radius: 10px;
    cursor: pointer;
}

main > .container-juridico button a {
    color: white;
    text-decoration: bold;
}

main > .container-juridico button a:hover {
    color: black;
    transition: 0.3s;
}