* {
  box-sizing: border-box;
  padding: 0;
  margin: 0;
}

body {
  font-family: "Lato", sans-serif;
  background: url(../img/Maputo-cidade.jpg);
  background-repeat: no-repeat;

  width: 100%;
  height: auto;
}

.sidepanel {
  width: 0;
  position: fixed;
  z-index: 1;
  height: 100vh;
  top: 0;
  left: 0;
  background-color: #1e5d2f;
  overflow-x: hidden;
  transition: 0.5s;
  padding-top: 60px;
}

.sidepanel a {
  padding-bottom: 30px;
  text-decoration: none;
  font-size: 20px;
  color: #fff;
  display: block;
  transition: 0.3s;
}

.sidepanel a:hover {
  color: #f1f1f1;
}

.sidepanel .closebtn {
  position: absolute;
  top: 0;
  right: 25px;
  font-size: 36px;
}

.openbtn {
  font-size: 20px;
  cursor: pointer;
  background-color: #1e5d2f;
  contain: #fff;
  color: white;
  padding: 10px 15px;
  border: none;
}
header {
  background: #fff;
  padding-left: 30px;
  display: flex;
  flex-direction: row;
  justify-content: space-between;
}

.openbtn:hover {
  background-color: #444;
}

.menu {
  background-color: #1e5d2f;
  margin: 0;
  padding: 0;
}

.logo {
  border-radius: 50%;
  height: 50px;
  width: 50px;
  padding-bottom: 10px;
  padding-top: 5px;
  margin: 0;
}

#mz_flag {
  border-radius: 50%;
  height: 70px;
  width: 70px;
  margin-bottom: 50px;
  padding-top: 5px;
}

#mySidepanel {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-direction: column;
}

h3 {
  padding: 10px;
  font-family: Tahoma, Geneva, sans-serif;
}

.fas {
  margin-right: 20px;
  font-size: 20px;
  color: #fff;
}
.btsLogin {
  margin-right: 15px;
  margin-top: 15px;
  margin-bottom: 10px;
  color: #1e5d2f;
  font-weight: bold;
  text-align: center;
  padding: 5px;
  border: 0;
  padding-left: 20px;
  cursor: pointer;
  background: #fff;
}

@media screen and (max-width: 350px) {
  h3 {
    font-size: 15px;
  }
}

/* Medium devices (landscape tablets, 768px and up) */
@media (min-width: 700px) and (max-width: 850px) {
}

.fa-lock {
  text-align: center;
}

.denunciar {
  position: absolute;
  bottom: 0;
  right: 0;
  margin: 20px;
  height: 50px;
  width: 50px;
  border-radius: 50%;
  padding: 10px;
  background-color: #1e5d2f;
  color: #fff;
  font-weight: bold;
  position: fixed;
}

/*=====================FormulArio de denuncia================================*/
/*Overlay of  form*/
.overlay {
  height: 100%;
  width: 100%;
  display: none;
  position: fixed;
  z-index: 1;
  top: 0;
  left: 0;
  background-color: rgb(0, 0, 0);
  background-color: rgba(0, 0, 0, 0.7);
  overflow-x: hidden;
  transition: 0.5s;
}

.overlay a {
  padding: 8px;
  text-decoration: none;
  font-size: 36px;
  color: #818181;
  display: block;
  transition: 0.3s;
}

.overlay a:hover,
.overlay a:focus {
  color: #f1f1f1;
}

.overlay .closebtn {
  position: absolute;
  top: 20px;
  right: 45px;
  font-size: 60px;
}

@media screen and (max-height: 450px) {
  .overlay a {
    font-size: 20px;
  }
  .overlay .closebtn {
    font-size: 40px;
    top: 15px;
    right: 35px;
  }
}

label {
  color: #fff;
  font-weight: bold;
}

.entradas {
  padding: 10px;
}

input[type="text"] {
  padding: 12px;
  width: 100%;
}

label {
  left: 0;
}

.overlay-content {
  height: 100vh;
  display: flex;
  justify-content: center;
  align-items: center;
}

.lado {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
}

@media screen and (max-width: 450px) {
  .overlay .closebtn {
    position: absolute;
    top: 0;
    right: 25px;
    font-size: 36px;
  }
}

/*==================CSS de Formulario stapstap===========*/

#regForm {
  background-color: #ffffff;
  margin: 100px auto;
  font-family: Raleway;
  padding: 40px;
  width: 70%;
  min-width: 300px;
  width: 700px;
  padding-top: 50px;
  padding-bottom: 30px;
  border: 5px double #1e5d2f;
}

h1 {
  text-align: center;
}

input {
  padding: 10px;
  width: 100%;
  font-size: 17px;
  font-family: Raleway;
  border: 0px solid #003300;
  background-color: #e8e8e8;
  border-radius: 5px;
  margin-bottom: 16px; /* Bottom margin */
}



/*Validacao de formulario*/
.invalid {
  background-color: #ffdddd;
  border: 1px solid #000 !important;
  animation: shake 0.5s ease-in-out;

}

@keyframes shake {
  0%, 100% { transform: translateX(0); }
  20%, 60% { transform: translateX(-5px); }
  40%, 80% { transform: translateX(5px); }
}

select.campo{ background-colo: #ffdddd; color: rd;}

/* Hide all steps by default: */
.tab {
  display:none;
}

button {
  background-color: #4caf50;
  color: #ffffff;
  border: none;
  padding: 10px 20px;
  font-size: 17px;
  font-family: Raleway;
  cursor: pointer;
}

button:hover {
  opacity: 0.8;
}

#prevBtn {
  background-color: #bbbbbb;
}

/* Make circles that indicate the steps of the form: */
.step {
  height: 15px;
  width: 15px;
  margin: 0 2px;
  background-color: #bbbbbb;
  border: none;
  border-radius: 50%;
  display: inline-block;
  opacity: 0.5;
}

.step.active {
  opacity: 1;
}

/* Mark the steps that are finished and valid: */
.step.finish {
  background-color: #003300;
}

/* Style inputs with type="text", select elements and textareas */
input[type="text"],
input[type="file"],
select,
textarea {
  width: 100%; /* Full width */
  padding: 12px; /* Some padding */
  border: 1px solid #ccc; /* Gray border */
  border-radius: 5px; /* Rounded borders */
  box-sizing: border-box; /* Make sure that padding and width stays in place */
  margin-top: 6px; /* Add a top margin */
  margin-bottom: 16px; /* Bottom margin */
  resize: vertical; /* Allow the user to vertically resize the textarea (not horizontally) */
  background-color: #e8e8e8;
  font-size:17px;
}

textarea {
  width: 100%;
}

.anexos{
  display: flex;
  align-items: center;
  align-content: center;
  flex-direction: column;
  padding-bottom: 20px;
}

.anexo {
  text-align: center;
  padding: 15px;
  border: 5px double #003300;
  width: 200px;
  height: 200px;
  box-shadow: 2px 0px 5px blue;
  background: #ddd;
  margin-bottom: 20px;
  padding-top: 10px;

}

input[type="file"] {
  display: none;
}

.anexo_label{
    display: flex;
    align-items: center;
    justify-content:center;

    height:100%;
 }
.fa-camera,
.fa-video {
  font-size: 100px;;
  color: #003300;
  cursor: pointer;
}

.labeles {
  display: block;
  padding-bottom: 5px;
}

#titulo_form {
  padding-bottom: 30px;
}

@media screen and (max-width: 450px) {
  #titulo_form {
    font-size: 25px;
  }
}

h3 {
  font-size: 30px;
}

@media screen and (max-width: 600px) {
  h3 {
    font-size: 20px;
  }
}

@media screen and (max-height: 450px) {
  #regForm {
    padding-top: 200px;
    width: 80%;
    height: auto;
  }

  .overlay .closebtn {
    top: -3;
    right: 5px;
    color: #888;
  }

  h1 {
    font-size: 20px;
  }

  h3 {
    font-size: 18px;
  }
}




/*=====Modal de Exibicao de Instalacao de app====*/

#installModal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0,0,0,0.7);
  display: none;
  justify-content: center;
  align-items: center;
  z-index: 10000;
}

#installModal > div {
  background: white;
  padding: 20px;
  border-radius: 10px;
  max-width: 90%;
  box-shadow: 0 0 20px rgba(0,0,0,0.5);
}

#modalInstallBtn, #modalCancelBtn {
  padding: 8px 16px;
  margin: 5px;
  border: none;
  border-radius: 4px;
  cursor: pointer;
}

#modalInstallBtn {
  background: #1E5D2F;
  color: white;
}

#modalCancelBtn {
  background: #f44336;
  color: white;
}

