:root{
	--cor-principal: #3e57d0;
	--cor-secundaria: #5e87eb;
	--cor-link: #555;
	--cor-button: #fff;
}

body{
    margin:0;
    padding:0;
    font-family: 'Cabin', sans-serif;
    font-size: 15px;
}
*{
    box-sizing: border-box;
}
a{
	color: var(--cor-link);
	text-decoration:none;
	transition: 0.4s;
}
a.btn{
	display:inline-block;
	padding: 8px 25px;
	font-size: 14px;
	font-weight: 500;
	box-shadow: 0 2px 15px rgb(218, 34, 35, 0.15);
	border: none;
	text-align: center;
	background: var(--cor-principal);
	color: var(--cor-button);
	border-radius:30px;
	margin: 0 5px;
}
a.btn:hover{
	background: var(--cor-secundaria);
}

a.btn_light{
	display:inline-block;
	padding: 8px 25px;
	font-size: 14px;
	font-weight: 500;
	box-shadow: 0 2px 15px rgb(218, 34, 35, 0.05);
	border: none;
	text-align: center;
	background: white;
	color: var(--cor-principal);
	border-radius:30px;
	margin: 0 5px;
}
a.btn_light:hover{
	background: var(--cor-principal);
	color: var(--cor-button);
}

.geral{
    width:100%;
	max-width: 1140px;
	margin: 0 auto;
}
.geral_wrapper{
	float:left;
	width:100%;
	z-index: 0;
}
.centralizado{
	width:100%;
}

.topo_wrapper.home{
	float:left;
	position: relative;
	width:100%;
	height: auto;
	z-index:1;
}
.topo_wrapper.page{
	float:left;
	position: relative;
	width:100%;
	height: 325px;
	background: url(../../templates/vocatus/imagens/home-bg.jpg);
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center;
	z-index:1;
}
.topo_wrapper.page .page-title{
	float:left;
	width:100%;
	text-align: center;
	font-size:42px;
	margin-top:85px;
}

.topo_wrapper .grey-mark{
	height: 500px;
	width: 500px;
	border-radius: 500px;
	position: absolute;
	bottom: -20%;
	left:-10%;
	z-index:-1;
	background: rgb(215, 215, 215, 0.17);
}

.topo_wrapper .backdrop{
	position: absolute;
	top: 0;
	bottom: 0;
	left: calc((100% - 99vw) / 2);
	right: calc((100% - 99vw) / 2);
	background: silver;
	z-index: -5;
	overflow: hidden;
	
	background: url(../../templates/vocatus/imagens/home-bg.jpg);
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center;
}

.topo_menu_wrapper{
	display: flex;
	width: 100%;
	padding-top: 15px;
	padding-bottom: 15px;	
}

.logo{}

.menu_principal{
	width: 100%;
	text-align: center;
}
.menu_principal a{
	display: inline-block;
	text-align: center;
}
.menu_principal_mobile{
	position: relative;
	width:100%;
	display:none;
	text-align:center;
}
.menu_principal_mobile a{
	display: inline-block;
	margin: 5px;
}
.menu_principal_mobile i{
	font-size: 26px;
}
.menu_mobile_tree{
	border: 1px solid #ccc;
	position: absolute;
	width: 400px;
	height: auto;
	top: 45px;
	left: 50%;
	margin-left: -200px;
	z-index:1;
	background:white;
	border-radius: 3px;
	display:none;
}
.menu_mobile_tree a{
	text-align: center;
}

.menu_principal a{
	font-weight: 500;
	text-transform: capitalize;
	margin: 5px;
	padding: 10px 15px;
}

.topo_menu_wrapper .login{
	position: relative;
}
.topo_menu_wrapper .login a{
	border-radius: 3px !important;
}
/* box login */
.box_login{
	display:none;
	position: absolute;
	top: 35px;
	right: 5px;
	width: 250px;
	background: var(--cor-principal);
	padding: 10px;
	border-radius: 5px 0 0 5px;
	z-index:1;
	color: var(--cor-button);
	text-align:center;
}
.box_login a{
	color: var(--cor-button);
}
.loginvocatus_insite_wrapper_title{
	text-transform: uppercase;
	float:left;
	width:100%;
	margin: 10px 0;
	text-align: center;
}
.box_login form span .label_form{
	display:none;
}

.box_login input{
	all: initial;
	padding: 5px 10px;
	background: white;
	border-radius: 5px;
	color: #505060;
	border-left: 2px solid #b4b7bd;
	font-size:15px;
	height:30px;
}
.box_login input[type=submit]{
	all: initial;
	background: white;
	color: #505060;
	width:50%;
	text-align:center;
	padding: 5px 10px;
	border-radius: 5px;
	border-left: 2px solid #b4b7bd;
	border-right: 2px solid #b4b7bd;
}

/* banner */
.topo_banner_wrapper .descricao{
	color: #555;
	font-size:16px;
	width: 450px !important;
	margin-top: 100px;
	line-height: 1.8;
}

/* modulos */
.modules_wrapper{
	float:left;
	width:100%;
}
.modules_wrapper .module{
	float:left;
	width:100%;
	padding: 65px 0;
	line-height: 1.8;
}
.modules_wrapper .backdrop_even{
	background: rgb(215, 215, 215, 0.17);
}

.modules_wrapper .module .title .title_content{
	text-align: center;
	font-size:33px;
	color: #505060;
	margin-bottom:65px;
}

/** module topics right*/
.modules_wrapper .module_topics-right .title .title_content{
	text-align: left;
	margin-bottom: 20px;
}

.modules_wrapper .module.module_topics-right .module_content{
	position:relative !important;
}

.modules_wrapper .module.module_topics-right .middle{
	width:50%;
}

.modules_wrapper .module.module_topics-right .middle img.imgbox-right{
	position:absolute;
	top:-120px;
	right:0;
	width:470px;
	max-width:100%;
	height:auto;
}

/** module topics left*/
.modules_wrapper .module_topics-left .title .title_content{
	text-align: left;
	margin-bottom: 20px;
	text-indent:50%;
}

.modules_wrapper .module.module_topics-left .module_content{
	position:relative !important;
}

.modules_wrapper .module.module_topics-left .middle{
	width:50%;
	float:right;
}

.modules_wrapper .module.module_topics-left .middle img{
	position:absolute;
	top:-120px;
	left:0;
	width:470px;
	height:auto;
}

/** module bg img */
.modules_wrapper .module table.imgbg-module{
	display:none;
}
.modules_wrapper .module_backdrop.module-bgimg{
	background-image: var(--banner-bg);
	background-position: center center;
	background-size: cover;
	background-repeat: no-repeat;
}
.modules_wrapper .module.module-bgimg-format .title .title_content{
	color:white;
	margin-bottom:20px;
}
.modules_wrapper .module.module-bgimg-format{
	color:white;
}

/** rodape */
.rodape{
	float:left;
	position: relative;
	width:100%;
	min-height:50px;
}

.rodape .backdrop{
	position: absolute;
	top: 0;
	bottom: 0;
	left: calc((100% - 99vw) / 2);
	right: calc((100% - 99vw) / 2);
	
	background-image: var(--banner-bg);
	background-position: center center;
	background-size: cover;
	
	z-index: -5;
}

.rodape .centralizado .wrapper{
	width:100%;
	padding: 100px 0;
	display:flex;
	flex-wrap: wrap;
}

.rodape .centralizado .wrapper .box_rodape{
	float:left;
	width: calc(30% - 40px);
	margin: 0 20px;	
}
.rodape .centralizado .wrapper .box_rodape:nth-child(2),
.rodape .centralizado .wrapper .box_rodape:nth-child(3){
	width: calc(20% - 40px);
}

.rodape .centralizado .wrapper .box_rodape .titulo{
	color: white;
	font-size: 20px;
	font-weight:bold;
	margin-bottom: 25px;
	border-bottom: 1px solid #fff;
	padding-bottom: 10px;
}

.rodape .centralizado .wrapper .box_rodape .conteudo{
	color: #ececec;
	line-height:2;
}
.rodape .centralizado .wrapper .box_rodape .conteudo a{
	color: #ececec;
}

.rodape_tarja{
	float:left;
	position: relative;
	width:100%;
	color: white;
	padding: 35px 0;
}

.rodape_tarja .backdrop{
	position: absolute;
	top: 0;
	bottom: 0;
	left: calc((100% - 99vw) / 2);
	right: calc((100% - 99vw) / 2);
	background: #0e1326;
	z-index: -5;
}

/* mensagem de sucesso, aviso e erro */
.confirmMessage{
    float: left;
    width: 100%;
    padding: 12px;
    background: #4bbf99;
    color: white;
    border-radius: 5px;
    margin: 3px 0;
}
.warningMessage{
    float: left;
    width: 100%;
    padding: 12px;
    background: #dbac65;
    color: white;
    border-radius: 5px;
    margin: 3px 0;
}
.errorMessage{
    float: left;
    width: 100%;
    padding: 12px;
    background: #db4620;
    color: white;
    border-radius: 5px;
    margin: 3px 0;
}