* { font-family: "DM Sans", sans-serif !important; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; outline: none; letter-spacing: 0.3px; }

body { background-image:url("../images/bg2.png"); background-size: 100%; background-repeat: no-repeat; width: 100%; height: 100%; background-color: #fff !important; position: relative; }

.step1 { width: 100%; height: 100dvh; display: flex; align-items: center; justify-content: center; flex-direction: column; position: relative; }
.step1 h1 { text-align: center; font-size: 35px; color: #fff; font-weight: 400; margin-bottom: 50px; }
.step1 small { color: #fff; position: absolute; bottom: 30px; box-shadow: inset 0 -32px 64px #cecefb14; background: #00000022; border: 1px solid rgb(206 206 251 / 10%); padding: 7px 20px; border-radius: 20px; font-size: 12px; font-weight: 500;}
.step1 img { margin-bottom: 60px; width: 170px; }
.step1 div { width: 30%; box-shadow: inset 0 -32px 64px #cecefb14; background: #ffffff0d; border: 1px solid rgb(206 206 251 / 10%); border-radius: 30px; padding: 25px; position: relative; }
.step1 div .form-control { padding: 12px 20px; border-radius: 20px; border: 1px solid transparent; font-size: 15px; margin-bottom: 10px;} 
.step1 div .form-control:focus { box-shadow: none; border: 1px solid transparent; }

.step1 div button { background: #6c3795; color: #fff; padding: 12px 20px; font-size: 15px; font-weight: 600; width: 100%; border-radius: 18px 18px 18px 18px; border: none; transition: all 0.3s; }
.step1 div button:hover { background: #532a72; }


.questions { width: 100%; height: 100dvh; display: flex; align-items: center; justify-content: center; flex-direction: column; position: relative; }
.questions small.desc { color: #fff; position: absolute; bottom: 30px; box-shadow: inset 0 -32px 64px #cecefb14; background: #00000033; border: 1px solid rgb(206 206 251 / 10%); padding: 7px 20px; border-radius: 20px; font-size: 12px; font-weight: 500;}

.questions .questionInfo { width: 35%; box-shadow: inset 0 -32px 64px #cecefb14; background: #0000002c; border: 1px solid rgb(206 206 251 / 10%);border-radius: 30px; padding: 25px; position: relative; }
.questions .questionInfo .divider { border-bottom: 1px solid rgba(255,255,255,0.1); margin-bottom: 10px; }
.questions .questionInfo .title { display: flex; justify-content: space-between; align-items: center; margin-bottom: 20px; }
.questions .questionInfo .title div:nth-child(1) { width: 70%; }
.questions .questionInfo .title div:nth-child(2) { width: 30%; gap: 10px; position: relative; }
.questions .questionInfo .title div:nth-child(2) small { color: rgba(255, 255, 255, 0.7); font-size: 12px; position: absolute; left: -90px; top: -4px; font-weight: 600; text-transform: uppercase;}

.questions .questionInfo .progress { width: 100% !important; height: 10px; font-weight: bold; background: #ffffff17; }
.questions .questionInfo .progress-bar { background: #badc58; }


.questions .questionInfo span { color: rgba(255,255,255,0.5); font-size: 14px; text-transform: uppercase; font-weight: 600; display: block; }
.questions .questionInfo h6 { color: rgba(255,255,255,0.4); font-size: 14px; text-transform: uppercase; font-weight: 500; margin-bottom: 10px; display: block; margin-top: 40px; }
.questions .questionInfo p { color: #fff; font-size: 30px; line-height: 30px; }


.questions .questionInfo .buttons button { padding: 8px; border: none; color: #fff; font-size: 18px; font-weight: bold; margin-top: 20px; transition: all 0.3s; }
.questions .questionInfo .buttons button:nth-child(1) { background: #6c3795; border-radius: 20px 0px 0px 20px; }
.questions .questionInfo .buttons button:nth-child(1):hover { background: #512970; }

.questions .questionInfo .buttons button:nth-child(2) { background: #c94848; border-radius: 0px 20px 20px 0px; }
.questions .questionInfo .buttons button:nth-child(2):hover { background: #a83b3b; }

/* REPORT */
.report { margin-top: 50px; }
.report .container { backdrop-filter: blur(16px); background: #000000; background: linear-gradient(180deg,rgb(255, 255, 255) 0%, rgba(0, 0, 0, 0) 100%); border-radius: 20px; padding: 45px; border: 1px solid rgb(206 206 251 / 10%); }
.report .container .titleMain { display: flex; gap: 30px; justify-content: space-between; align-items: center; }
.report .container .titleMain div { width: 50%; }
.report .container .titleMain p { font-size: 13px; line-height: 20px; opacity: 0.5; }

.report .container img { margin-bottom: 30px; width: 225px; }
.report .container .divider { border-bottom: 1px solid rgba(0,0,0,0.1); margin-bottom: 30px; }

.report .container h1 { font-size: 22px; font-weight: 500; color: #6c3795; }
.report .container h3 { font-size: 16px; color: rgba(0,0,0,0.4); margin-bottom: 30px; }
.report .container h5 { color: #000; font-size: 18px; margin-bottom: 30px; font-size: 25px; margin-top: 40px; }
.report .container p { color: #000; line-height: 25px; font-size: 15px; }
.report .container small { color: #000; line-height: 25px; font-size: 13px; margin-bottom: 30px; display: block; font-weight: 600;}

.report .container span { color: #1e0b2cb8; font-size: 13px; text-transform: uppercase; font-weight: 600; margin-bottom: 10px; display: block; }
.report .container ul { list-style: none; padding: 0; margin-top: 10px; }
.report .container ul li { color: #1e0b2cb8;  line-height: 25px; font-size: 15px; font-weight: 300;  }
.report .container ul li img { width: 23px; margin: 0; }
.report .container ul li span { font-size: 20px; text-transform: initial; color: #6c3795; }

.report .container .block { display: flex; }
.report .container .block div:nth-child(1) { border-right: 1px solid rgba(0, 0, 0, 0.1); width: 35%; }
.report .container .block div:nth-child(2) {  width: 60%; padding-left: 5%; }

.report .container .block h4 { color: #000; font-weight: 500; font-size: 20px; }
.report .container .block p { line-height: 23px; font-size: 15px; color: #1e0b2cb8;  }
.report .container .block p img { width: 20px; margin: 0; margin-left: -7px; margin-top: -3px; display: initial; opacity: 0.8; }
.report .container .block p strong.falha { color: #6c3795; }
.report .container .block p.desc { box-shadow: inset 0 -32px 64px #cecefb14; background: #a355e017; border: 1px solid rgb(206 206 251 / 10%); padding: 10px 16px; font-size: 12px; line-height: 20px; color: rgba(255,255,255,0.7); margin-top: 14px; border-radius: 15px; }

.report .container .tableMin { box-shadow: inset 0 -32px 64px #cecefb14; background: #a355e017; border: 1px solid #6c379522; padding: 20px; padding-bottom: 0px; border-radius: 20px; margin-top: 30px; }
.report .container .table th { background: transparent; padding: 10px 20px 25px 20px; color: #6c3795;  border-bottom: 1px solid #6c379522; font-weight: 500; font-size: 18px; }
.report .container .table td { background: rgba(0,0,0,0.1); border-bottom: 1px solid #6c379522; padding: 40px 20px; color: #43215d; background: transparent; font-size: 22px; }


.report .container .blockCenarios { display: flex; justify-content: space-between; gap: 20px; flex-wrap: wrap; margin-bottom: 30px; }
.report .container .blockCenarios div { padding: 35px; box-shadow: inset 0 -32px 64px #cecefb14; background: #a355e017; border: 1px solid rgb(206 206 251 / 10%); border-radius: 15px; margin-bottom: 5px; width: 49%; }
.report .container .blockCenarios div h6 { color: #fff; font-weight: 500; background: #6c3795; display: inline-block; padding: 6px 15px; font-size: 12px; border-radius: 20px; }
.report .container .blockCenarios div h6.error { color: #ff6b6b; font-weight: 500; background: #ff6b6b2b; display: inline-block; padding: 6px 15px; font-size: 12px; border-radius: 20px; }
.report .container .blockCenarios div h6.consequencia { color: #fff; font-weight: 500; background: #44225e; display: inline-block; padding: 6px 15px; font-size: 12px; border-radius: 20px; }
.report .container .blockCenarios div h6.embasamento { color: #fff; font-weight: 500; background: #9c48dc; display: inline-block; padding: 6px 15px; font-size: 12px; border-radius: 20px; margin-top: 20px; }
.report .container .blockCenarios div h6.juris { color: #fff; font-weight: 500; background: #6c3795; display: inline-block; padding: 6px 15px; font-size: 12px; border-radius: 20px; margin-top: 20px; }
.report .container .blockCenarios div h6.analise { color: #fff; font-weight: 500; background: #331749b5; display: inline-block; padding: 6px 15px; font-size: 12px; border-radius: 20px; margin-top: 20px; }


.report .container .blockCenarios div p { margin: 0; font-size: 14px; color: #1e0b2cb8;  margin: 0; line-height: 20px; }
.report .container .blockCenarios div img { width: 25px; margin: 0; margin-bottom: 10px; }

.report .container .blockInfo { display: flex; justify-content: space-between; gap: 20px; }
.report .container .blockInfo div { padding: 30px; box-shadow: inset 0 -32px 64px #cecefb14; background: #a355e017; border: 1px solid rgb(206 206 251 / 10%); border-radius: 15px; margin-bottom: 20px; width: 25%; }
.report .container .blockInfo div p { margin: 0; font-size: 14px; color: #1e0b2cb8; margin: 0; line-height: 20px; }
.report .container .blockInfo div img { width: 28px; margin: 0; margin-bottom: 15px; }

.report .container ul.rec { list-style: none; padding: 0; margin-top: 10px; }
.report .container ul.rec li { color: #1e0b2cb8; line-height: 35px; font-size: 15px; font-weight: 400; display: flex; align-items: center; gap: 10px; }
.report .container ul.rec li img { width: 23px; margin: 0; }

.report .container button.successBtn { background: #6c3795; color: #fff; padding: 12px 30px; font-size: 20px; font-weight: 600; width: 35%; border-radius: 20px; border: none; transition: all 0.3s; text-decoration: none; margin: 0 auto; display: block; text-align: center; margin-top: 50px; }
.report .container button.successBtn:hover { background: #4b2668;  box-shadow: 0px 22px 26px #6c37954d;}

/* FOOTER */
footer { padding: 120px 0; box-shadow: inset 0 -32px 64px #cecefb14; background: #000; border-top: 1px solid rgb(206 206 251 / 10%); margin-top: 70px; }
footer .whatsapp { background: #26d366; width: 60px; height: 60px; position: fixed; bottom: 40px; right: 40px; border-radius: 40px; z-index: 2;}
footer .whatsapp img { margin: 0 auto; display: block; position: relative; top: 13px; }
footer p { width: 70%; margin-top: 20px; color: #c2c2c2; }
footer hr { margin: 60px 0; opacity: 0.1;}
footer a { color: #c2c2c2; text-decoration: none; }

footer .box { display: flex; }
footer .box ul { margin: 0; padding: 0; list-style: none; margin-top: 20px; }
footer .box ul li { cursor:pointer; line-height: 50px; transition: all 0.3s; }
footer .box ul li img { margin-right: 15px; }
footer .box ul li:hover { opacity: 0.8; }
footer .box span { font-weight: bold; color: #fff; }

footer .box div:nth-child(1) { width: 30%; }
footer .box div:nth-child(1) img { width: 40%; }
footer .box div:nth-child(2) { width: 20%; }
footer .box div:nth-child(3) { width: 30%; }
footer .box div:nth-child(4) { width: 20%; }

footer .end { display: flex; justify-content: space-between; align-items: center; }
footer .end p { width: 100%; margin: 0;}
footer .end ul { margin: 0; padding: 0; list-style: none; }
footer .end ul li { cursor:pointer; line-height: 40px; transition: all 0.3s; display: inline-block; margin-right: 30px; }
footer .end ul li img { margin-right: 15px; }
footer .end ul li:last-child { margin-right: 0; }
footer .end ul li:hover { opacity: 0.8; }

/* ANIMATED */
.lines { position: absolute; top: -80px; left: -350px; height: 50%; margin: auto; width: 100%; }
.line { position: absolute; width: 1px; height: 100%; top: 0; left: 50%; background: rgba(255, 255, 255, 0.1); overflow: hidden; }
.line::after { content: ""; display: block; position: absolute; height: 15vh; width: 100%; top: -50%; left: 0; background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 0%, #ffffff 75%, #ffffff 100%); -webkit-animation: drop 7s 0s infinite; animation: drop 7s 0s infinite; -webkit-animation-fill-mode: forwards; animation-fill-mode: forwards; -webkit-animation-timing-function: cubic-bezier(0.4, 0.26, 0, 0.97); animation-timing-function: cubic-bezier(0.4, 0.26, 0, 0.97); }
.line:nth-child(1) { margin-left: -25%; }
.line:nth-child(1)::after { -webkit-animation-delay: 2s; animation-delay: 2s; }
.line:nth-child(3) { margin-left: 61%; }
.line:nth-child(3)::after { -webkit-animation-delay: 2.5s; animation-delay: 2.5s; }

@-webkit-keyframes drop {
  0% { top: -50%; }
  100% { top: 110%; }
}

@keyframes drop {
  0% { top: -50%; }
  100% { top: 110%; }
}

/* MODAL */
.modal { background: rgba(0,0,0,0.9) !important; }
.modal-content { padding: 30px; box-shadow: inset 0 -32px 64px #cecefb14; background-color: #ffffff0d !important; border: 1px solid rgb(206 206 251 / 10%); border-radius: 20px; }
.modal-content h2 { color: #fff; text-align: center; }
.modal-content p { text-align: center; color: rgba(255, 255, 255, 0.6); margin-bottom: 30px; }
.modal-content .form-control { padding: 12px 20px; border-radius: 20px; border: 1px solid transparent; font-size: 15px; margin-bottom: 20px; }
.modal-content .form-control:focus { box-shadow: none; border: 1px solid transparent; }
.modal-content button { background: #6c3795; color: #fff; padding: 12px 30px; font-size: 20px; font-weight: 600; width: 100%; border-radius: 20px; border: none; transition: all 0.3s; text-decoration: none; margin: 0 auto; display: block; text-align: center; margin-top: 50px; }
.modal-content button:disabled { opacity: 0.5; pointer-events: none; }
.modal-content button:hover { background: #4b2668; }

.slideBorder { border-radius: 20px; }

.inicialBtn { background: #6c3795; color: #fff; padding: 12px 30px; font-size: 20px; font-weight: 600; width: 30%; border-radius: 20px; border: none; transition: all 0.3s; text-decoration: none; margin: 0 auto; display: block; text-align: center; }
.inicialBtn:disabled { opacity: 0.5; pointer-events: none; }
.inicialBtn:hover { background: #4b2668; }