#funciona
{
    width: 100%;
    margin: 0;
    padding: 0;
}
.banner
{
    background: url('../img/oqueesperar.webp') no-repeat top center;
    background-size: cover; /* Faz a imagem preencher toda a largura */
}

.banner h1 {
    position: absolute; /* Fixa o h1 sobre a imagem */
    color: var(--branco); /* Garante contraste */
    font-weight: bold;
    text-shadow: 2px 2px 5px rgba(0, 0, 0, 0.5); /* Adiciona um efeito para melhorar a leitura */
    margin: 130px 0 0 100px;
    font-size: 4.5rem;
    width:400px;
    line-height: 1;

}

.banner p
{
  position: absolute; /* Fixa o h1 sobre a imagem */
  color: var(--branco); /* Garante contraste */
  font-size: 1.5rem;
  text-shadow: 2px 2px 5px rgba(0, 0, 0, 0.5); /* Adiciona um efeito para melhorar a leitura */
  margin: 400px 0 0 0;
  padding: 15px 100px 15px 100px;
  width:1000px;
  line-height: 1.2;
  background: rgba(47, 47, 47, 0.5);
}

.bloco-funciona {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center; /* Centraliza os elementos filhos */
    text-align: center; /* Garante alinhamento do texto */
}

.bloco-funciona h2 {
    font-size: 1.5rem;
    text-align: center;
    max-width: 800px; /* Ajuste conforme necessário */
    margin: 50px 0;
    font-weight: normal;
}

.step {
    margin: auto;
    margin-top: 80px;
    width: 300px;

}
.stepfinal
{
    display: flex;
    margin: auto;
    width: 150px;
}
.bloco-funciona .box {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(350px, 1fr)); /* Ajusta automaticamente */
    gap: 100px;

    width: 100%;
    max-width: 900px; /* Mantém um limite */
    padding: 20px;
}

.bloco-funciona .box div {
    display: flex;
    flex-direction: column;
    align-items: center; /* Centraliza imagem e texto */
}

.bloco-funciona .box img {
    width: 100%; /* Ajusta automaticamente à largura da div */
    max-width: 400px;
    border-radius: 30px;
}

.bloco-funciona .box p {
    max-width: 360px;
    text-align: center;
    font-size: 1.2rem;
    margin-top: 10px;
}
