.label-before, .field input:focus + label::before, .field input:valid + label::before, .field input:disabled + label::before {
  line-height: 20px;
  font-size: 12px;
  top: -10px;
  background: #fff;
  padding: 0 6px;
  left: 9px;
}

.container {
  width: 80%;
  margin: 30px 10%;
}

.field {
  position: relative;
  margin-bottom: 15px;
}
.field label::before {
  content: attr(title);
  position: absolute;
  top: 0;
  left: 15px;
  line-height: 40px;
  font-size: 14px;
  color: #777;
  transition: 300ms all;
}
.field input {
  width: 100%;
  line-height: 40px;
  padding: 0 15px;
  box-sizing: border-box;
  font-size: 14px;
  color: #222;
  border: 1px solid #ccc;
  border-radius: 8px;
}

/* Define a transição suave para a borda quando o textarea estiver focado */
.field textarea {
  width: calc(100% - 30px);
  padding: 10px 15px;
  box-sizing: border-box;
  font-size: 14px;
  color: #222;
  border: 1px solid #ccc;
  border-radius: 8px;
  resize: vertical;
  transition: border-color 0.3s ease-in-out; /* Transição suave de 0.3 segundos para a cor da borda */
}

/* Define a cor da borda quando o textarea estiver focado */
.field textarea:focus {
  border-color: #007bff; /* Altere para a cor desejada */
  outline: none; /* Remove a borda padrão do navegador */
}

/* Define o estilo para o label do textarea */
.field textarea + label::before {
  content: attr(title);
  position: absolute;
  top: 0;
  left: 15px;
  line-height: 40px;
  font-size: 14px;
  color: #777;
  transition: 300ms all;
}

/* Define a transição suave para o label quando o textarea estiver focado */
.field textarea:focus + label::before {
  line-height: 20px;
  font-size: 12px;
  top: -10px;
  background: #fff;
  padding: 0 6px;
  left: 9px;
}

/* Define a transição suave para o label quando o textarea estiver desativado */
.field textarea:disabled + label::before {
  line-height: 20px;
  font-size: 12px;
  top: -10px;
  background: #fff;
  padding: 0 6px;
  left: 9px;
}


/* Estilo para o container */
.container {
  width: 80%; /* Largura do container */
  margin: 30px auto; /* Margem superior e inferior de 30px e centraliza horizontalmente */
}

/* Estilo para o input */
.field input {
  width: calc(100% - 30px); /* Define a largura do input */
  line-height: 40px;
  padding: 0 15px;
  box-sizing: border-box;
  font-size: 14px;
  color: #222;
  border: 1px solid #ccc;
  border-radius: 8px;
}


