/*
   Nome do arquivo: home.css
   Autor: Matheus Arruda
   Data de criação: 30/03/2024
   Descrição: Contém estilo para a home do site.
*/
input::placeholder, textarea::placeholder {
    font-size: 0.9em; 
}
/* Para garantir compatibilidade com o Internet Explorer */
input:-ms-input-placeholder, textarea:-ms-input-placeholder {
    font-size: 0.9em;
}

body {
    margin: 0;
	font-size: 15px;
	display: flex;
	flex-direction: column;
}
.container {
    display: grid;
    grid-template-columns: 1fr 1fr;
    height: 100%;
	overflow: auto;
}
main{
	height: 97vh;
	overflow: hidden;
}
.rodape {
    background-color: var(--escuro1);
	color: var(--medio2);
	text-align: center;
	font-size: 1.8vh;
	line-height: 3vh;
    height: 3vh;
}
.logo {
    background-color: var(--claro1);
    position: relative;
	border-right: 2px solid var(--medio);
	/*display: flex;*/
    flex-direction: column;
    justify-content: center;
    align-items: center;
	padding: 5% 10% 25%;
}

.logo > div{
	display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    max-width: 1000px;
	height: 100%;
}
.logo img {
    max-height:  var(--altura-logo);
    max-width: var(--largura-logo);
	display: block;
}
.logo div>a {
	font-size: 1.2em;
	text-decoration: none;
	padding: 0.4em 1em;
    border-radius: 0.4em;
}
.logo div > a.link_home {
	display: block;
	padding: 0;
	margin-bottom: 2rem;
}

.logo p, p {
    color: var(--logo-p);
    text-align: center;
    font-size: 1em;
	font-size: 0.9em;
    margin-top: 0.5rem;
}

.logo h1,.logo h3  {
    color: var(--logo-h1);
}
.logo h1,.logo h2,.logo h3,.logo h4,.logo h5,.logo h6 {
    margin: 0.2rem 0;
	text-align: center;
}
.logo h1 {
	margin-bottom: 1rem;
	margin-top: 1rem;
}
.logo h2 {
	width: 80%;
}
.logo h3 {
	margin-bottom: 1rem;
	margin-top: 0.5rem;
}

.logo button{
    width: auto;
}

.logo #sac {
    position: absolute;
    left: 0;
    bottom: 0;
    background-color: var(--sac-fundo);
    width: 100%;
    padding: 1% 5%;
    text-align: center;
    box-sizing: border-box;
	border-top: 20px solid var(--sac-borda);
	border-bottom: 20px solid var(--sac-borda);
}
.logo #sac *{
    color: var(--sac-texto);
}
.logo #sac p{
    font-size: 0.8em;
    margin-bottom: 2px;
    margin-top: 2px;
}
.logo #sac a{
   
}
.logo #sac h3, .logo #sac h4{
    margin-bottom: 2px;
    margin-top: 8px;
    font-size: 0.9em;
}

.form {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    background-color: var(--medio);
	position: relative;
}
.container .logo #registerButton, 
.container .form #loginForm, 
.container .form #registerOptions, 
.container .form #medicosForm, 
.container .form #farmaceuticosForm, 
.container .form #distribuidoresForm, 
.container .form #validarInfo {
	display: none;
}
.container.login .logo #registerButton {
	display: block;
}
.container.login .form #loginForm {
	display: flex;
}
.container.options .form #registerOptions {
	display: flex;
}
.container.medico .form #medicosForm {
	display: flex;
}
.container.farmaceutico .form #farmaceuticosForm {
	display: flex;
}
.container.distribuidor .form #distribuidoresForm {
	display: flex;
}
.container.validar .form #validarInfo {
	display: flex;
}

p {
    color: var(--form-p);
}
.form > div {
	display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    align-content: center;
    justify-content: center;
    align-items: center;
	z-index: 1;
}

.form form{
    position: relative;
	padding: 2rem 0;
}
.form form{
    max-width: 400px;
}
.form #loginForm form,
#registerOptions button{
    max-width: 350px;
}

.form h2 {
    margin-bottom: 0.8em;
}
.form form div{
    height: auto;
    overflow: hidden;
    width: 100%;
}
.form form .openModal-label strong {
    text-decoration: underline;
	cursor: pointer;
}
.form form div.box-fields div {
    width: 49%;
    float: left;
}
.form form div.box-fields div:last-of-type{
    float: right;
}

.form form div.g-recaptcha{
	margin: 1rem auto;
}
.form form div.g-recaptcha div{
	float: none !important;
	width: auto !important;
}

a.recuperacao {
	cursor: pointer;
	font-size: 1em;
	padding: 0.4em 1em;
	transition: background-color 0.3s ease;
}
a.recuperacao.bt0 {
	background-color: transparent;
	border-color: var(--bt0-border);
	border-color: var(--neutro);
	color: var(--neutro);
	float: left;
	text-decoration: underline;
	width: auto;
}

div.openModal-label {
	cursor: default;
}
div.openModal-label,
label,
input,
button,
select{
    margin-bottom: 0.6em;
	font-size: 1.1em;
}

input,
button,
select{
    width: 100%;
    padding: 0.4em;
    border: 1px solid #ccc;
    border-radius: 0.4em;
    box-sizing: border-box;
	font-size: 0.9em;
}

button {
    cursor: pointer;
    transition: background-color 0.3s ease;
	font-size: 1.1em;
	padding: 0.4em 1em;
}

button.bt0{
	width: auto;
    float: left;
	font-size: 0.9em;
	border-color: var(--bt0-border);
	text-decoration: underline;
}

.openModal input.termsCheckbox {
	height: 1rem;
	pointer-events: none;
	width: 1rem;
}

/*modal*/
/* Estilo básico para o modal */
.modal {
    display: none;
    position: fixed; 
    z-index: 1;
    left: 0;
    top: 0;
    width: 100%; 
    height: 100%; 
    overflow: auto; 
    background-color: rgb(0,0,0); 
    background-color: rgba(0,0,0,0.4); 
}

.modal-content {
    background-color: var(--claro2);
    margin: 2% auto 2%; 
    padding: 5% 10%;
    border: 1px solid var(--medio2);
    width: 60%; 
	box-sizing: border-box;
}
.modal-content h2{
    text-align: center;
}
.modal-content h3, p{
    text-align: left;
}
.modal-content div.button{
    display: flex;
    margin: 3% auto; 
    justify-content: space-between;
    width: 60%; 
}
#termsModal .modal-content div.button{
    margin: 10% auto 2%; 
}
#termsModal .modal-content strong{
    text-align: center;
	display: block;
}
.modal-content div.button button{
   display: inline-block;
   width: auto;
    
}

/* Popin de recuperação de senha ******************************************* */
div.popin2, 
div.popin {
	background-color: rgba(0,0,0,0.7);
	display: none;
	height: 100%;
	left: 0;
	position: absolute;
	top: 0;
	width: 100%;
	z-index: 10000;
}
div.popin2.ativo, 
div.popin.ativo {
	display: block;
}
div.popin2 form, 
div.popin form {
	background-color: #f5f5f5;
	border: 1px solid #333333;
	border-radius: 9px;
	display: block;
	left: 50%;
	overflow: hidden;
	padding: 0;
	position: absolute;
	top: 45%;
	transform: translate(-50%, -50%);
}
div.popin2 form h1, 
div.popin form h1 {
	background-color: var(--destaque-medio);
	color: #ffffff;
	margin: 0 0 1.5rem 0;
	padding: 0.5rem 1rem;
	text-align: center;
}
div.popin2 form fieldset, 
div.popin form fieldset {
	margin: 0;
	padding: 1rem 1.5rem 1.5rem 1.5rem;
	border: none;
}
div.popin2 form fieldset label, 
div.popin form fieldset label {
	color: #333;
	display: block;
	font-size: 1.2rem;
	margin-bottom: 5px;
}
div.popin2 form fieldset input[type="password"], 
div.popin form fieldset input[type="password"] {
	width: 100%;
	padding: 8px;
	font-size: 1.1rem;
	line-height: 1.1rem;
	border: 1px solid #ccc;
	border-radius: 4px;
	box-sizing: border-box;
	font-weight: normal;
	height: 3rem;
}
div.popin2 form fieldset button, 
div.popin form fieldset button {
	border: none;
	border-radius: 4px;
	cursor: pointer;
	font-size: 1.4rem;
	margin: 1rem 0 0 0;
	padding: 10px 20px;
}
div.popin2 form fieldset button[type="submit"], 
div.popin form fieldset button[type="submit"] {
	float: right;
	width: auto;
}
div.popin2 form fieldset button[type="reset"], 
div.popin form fieldset button[type="reset"] {
	background-color: #ccc;
	color: var(--escuro1);
	float: left;
	text-decoration: none;
}
div.popin2 form fieldset button[type="reset"]:hover, 
div.popin form fieldset button[type="reset"]:hover {
	background-color: #BBB;
	color: var(--escuro1);
	float: left;
}


@media screen and (min-width: 2000px) {
	.form form,
	.form #loginForm form,
	#registerOptions button {
		max-width: 800px;
    }
	
}
@media screen and (max-width: 1140px) and (orientation: portrait) {
    body{
	    font-size: 1.5vw;
	}
}

@media screen and (max-width: 1024px) {
	body{
	    font-size: 1.2vw;
	}
}
@media screen and (max-width: 912px) {
	body{
	    font-size: 1.8vw;
	}
}
@media screen and (max-width: 820px) {
    .container {
        grid-template-columns: 1fr;
        grid-template-rows: auto auto;
    }
	.rodape {
		font-size: 0.6em;
	}

    .logo {
        order: 1;
		padding: 0 5% 50%;
		border-right: 0 none transparent;
		border-bottom: 2px solid gray;
    }

    .form {
		order: 2;
        padding: 5% 0;
    
    }
	.modal-content {
    background-color: var(--claro2);
    margin: 5% auto 2%;
    padding: 5% 10%;
    border: 1px solid var(--medio2);
    width: 90%; 
	box-sizing: border-box;
}
	.modal-content div.button{
    width: 100%; 
}
}
@media screen and (max-width: 430px) {
    body {
	    font-size: 3vw;
	}
	.form form,
	.form #loginForm form,
	#registerOptions button {
		max-width: 320px;
    }
	
}
@media screen and (max-width: 400px) {
    .logo {
		padding: 0 2% 6%;
    }
	.logo img{
		max-height: 50px;
		margin-top: 1rem;
	}
}

/*classes acessórias*/

.bd0{
	border: 0 none transparent;
}

/* Estilização geral da barra de rolagem */
/* Estilo para o Firefox 
* {
    scrollbar-width: thin; 
    scrollbar-color: #007BFF #f1f1f1;  
}*/
::-webkit-scrollbar {
    width: 8px; 
    height: 10px; 
	border-radius: 10px;
}

::-webkit-scrollbar-thumb {
    background-color: var(--destaque-medio); 
    border-radius: 10px;
    border: 2px solid transparent; 
    background-clip: content-box; 
}

::-webkit-scrollbar-track {
    background-color: transparent;
    border-radius: 10px; 
}
::-webkit-scrollbar-thumb:active {
  background-color: var(--destaque-claro); 
}
