/* Reset simples */
* {
  font-family: "Century Gothic", CenturyGothic, AppleGothic, sans-serif;
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

.bady_cont {
    margin-bottom: 10%;
}
.bady_cont > .principal .img {
  width: 100%;
  height: 500px;
  background-color: #FFFFFF;
}

.bady_cont  > .principal img{
    width: 100%;
    height: 100%;
    object-fit: cover;   /* mantém proporção e cobre todo espaço */
  object-position: center; /* centraliza a imagem (não fica puxada para direita ou esquerda) */
  display: block;
  z-index: 2;
}
/* overlay */


.img-wrapper {
  position: relative;
  display: block;
}

.img-wrapper img {
  width: 100%;
  height: 400px;
  object-fit: cover;
  object-position: top;
  display: block;

}

/* pseudo-elemento para sombra/gradiente */
.img-wrapper::after {
  content: "";
  position: absolute;
  inset: 0;


  /* Gradiente de sombra da cor #357186: escuro em cima, claro embaixo */
  background: linear-gradient(
    to bottom,
    rgba(38, 85, 102, 0.7) 0%,   /* topo escuro */
    rgba(26, 105, 134, 0.507) 50%,  /* meio */
    rgba(15, 136, 180, 0.959) 100%  /* base clara */
  );

  z-index: 1;
  pointer-events: none; /* não interfere em cliques */
}




.principal {
  position: relative;
}

.bady_cont .principal h1 {
  position: absolute;
  top: 45%;
  left: 50%;
  transform: translate(-50%, -50%);
font-family: "Poppins", sans-serif;
  color: #000;
  font-weight: 600;
  font-size: 4rem;
  z-index: 2;
}
.bady_cont .principal p {
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  margin: 25px 0 0 0;
  color: #353434;
  font-weight: 300;
  font-size: 1rem;
  z-index: 3;
    font-family: "Poppins", sans-serif;
    text-align: center;
}


/* BOLA (pagina ativa) centralizada com o h1 */
.contacto .info {
  display: flex;
  flex-direction: column; /* coluna: bola em cima, h1 embaixo */
  align-items: center;    /* centraliza horizontalmente */
  text-align: center;     /* centraliza texto */
  margin-bottom: 10px;
  gap: 15px;              /* espaço entre bola e título */
}

.contacto .info h1 {
  font-size: 2rem;
  font-family: "Poppins", sans-serif;
  font-weight: 500;
}

.pagina {
  width: 90px;
  height: 90px;
  background: #F36D53;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
   gap: 10px;
  text-align: center;
}


/* Remove o position absolute do modal-overlay */
.modal-overlay {
  position: relative; /* fica no fluxo normal */
  background: transparent; /* fundo transparente, não cobre tudo */
  display: flex;
  justify-content: center;
  margin-top: -500px; /* espaço entre o conteúdo p e o modal */
  z-index: 2;
}

/* Modal central */
.modal {
  margin-top: 50px;
  background: #fff;
  padding: 30px 80px; /* padding interno */
  border-radius: 10px;
  width: 1000px;
  max-width: 100%;
  box-shadow: 0 20px 60px rgba(0,0,0,0.3);
  height: auto; /* altura ajusta ao conteúdo */
}


/* FORMULÁRIO */
.contacto form {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

/* Inputs lado a lado (nome e email) */
.dados {
  display: flex;
  gap: 20px; /* espaço entre os inputs */
}

.dados label {
  display: block;
  font-weight: 300;
  margin-bottom: 1px;
  font-size: 1rem;
  font-family: "Poppins", sans-serif;
}

.dados input {
  width: 100%; /* ocupa todo o espaço da coluna */
  padding: 10px;
  border: 1px solid #b9b9b9;
  height: 35px;
  box-sizing: border-box;
font-family: "Poppins", sans-serif;
}

/* Coluna esquerda e direita */
.dados > div {
  flex: 1; /* divide igualmente */
  display: flex;
  flex-direction: column;
}

/* Textarea (mensagem) com label acima */
.contacto textarea {
  width: 100%;
  border: 1px solid #b9b9b9;
  font-family: "Poppins", sans-serif;
  resize: vertical;
  box-sizing: border-box;
  height: 86px;
}

.contacto label{
    font-weight: 300;
  margin-bottom: 1px;
  font-size: 1rem;
  font-family: "Poppins", sans-serif;
}


/* Botão enviar */
.contacto .lin {
  font-family: "Poppins", sans-serif;
  font-weight: 300;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-top: 6px;
  background-color: #F36D53;
  text-decoration: none;
  color: #fff;
  padding: 7px 25px;
  font-size: 1.2rem;
  width: 20%;
  transition: 0.2s;
  border: none;
  border-radius: 5px;
}

.contacto .lin:hover {
  background-color: #585757;
}
.mapa-container {
  display: flex;
  flex-direction: column; /* empilha visite e mapas */
  align-items: center;
  gap: 40px; /* espaço entre visite e mapas */

}

.visite {
      margin: 70px 0 30px 0;
  font-family: "Poppins", sans-serif;
  font-weight: 300;
  text-align: center; /* centraliza o texto */
}

.visite h1 {
     font-family: "Poppins", sans-serif;
  font-size: 2.2rem;
  font-weight: 550;
  margin-bottom: 6px;
}

.visite p {
  font-size: 1rem;
  line-height: 1.5;
  font-weight: 300;
}

/* Container dos dois mapas lado a lado */
.mapas {
  display: flex;
  justify-content: center; /* centraliza os dois blocos */
  gap: 25px; /* espaço entre Huambo e Luanda */
  flex-wrap: wrap; /* quebra em telas menores */
  width: 75%;
  margin-bottom: 100px;
 

}

.map {
  display: flex;
  flex-direction: column; /* h1 em cima do iframe */
  align-items: center;
  flex: 1; /* ocupa igualmente o espaço */
  min-width: 300px; /* evita blocos muito pequenos */
}

.map h1 {
  font-family: "Poppins", sans-serif;
  font-size: 2rem;
  margin-bottom: 10px;
  text-align: center;
  font-weight: 550;
}

.map iframe {
  width: 100%;
  height: 450px;
  border: 0;
  border-radius: 10px;
    border: solid 3px #d4cdcdb7;
}



