/*
 * CAMPOS DE FORMULÁRIO
 * Invólucro .field (label + controle empilhados), e estilo de input,
 * select, textarea. Full-width, foco com borda destacada, estado de erro.
 * Consome apenas tokens semânticos — respeita o tema.
 */

/* Invólucro de um campo: rótulo acima, controle abaixo. */
.field {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-bottom: var(--space-4);
}

/* Rótulo do campo. `.field__label` é o rótulo de um GRUPO (ex.: conjunto de
   checkboxes) que não se prende a um único <input>; compartilha o estilo. */
.field label,
.field__label {
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  color: var(--color-text);
}

/* Texto de ajuda abaixo do controle. */
.field small,
.field__help {
  font-size: var(--text-xs);
  color: var(--color-text-subtle);
}

/* Asterisco de campo obrigatório, junto ao rótulo. */
.field__required {
  margin-left: 2px;
  color: var(--color-danger);
}

/* Controles de entrada. */
.field input,
.field select,
.field textarea,
input[type="text"],
input[type="email"],
input[type="password"],
input[type="number"],
input[type="date"],
input[type="tel"],
input[type="search"],
select,
textarea {
  width: 100%;
  padding: var(--space-3);
  background-color: var(--color-surface);
  color: var(--color-text);
  border: var(--border-width) solid var(--color-border);
  border-radius: var(--radius-md);
  font-family: inherit;
  font-size: var(--text-base);
  line-height: var(--leading-normal);
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

/* Foco: borda escurece e um realce sutil aparece ao redor. */
.field input:focus,
.field select:focus,
.field textarea:focus,
input[type="text"]:focus,
input[type="email"]:focus,
input[type="password"]:focus,
input[type="number"]:focus,
input[type="date"]:focus,
input[type="tel"]:focus,
input[type="search"]:focus,
select:focus,
textarea:focus {
  outline: none;
  border-color: var(--color-text);
  box-shadow: 0 0 0 3px var(--color-hover);
}

/* Textarea: altura mínima confortável e redimensionável na vertical. */
textarea {
  min-height: 6rem;
  resize: vertical;
}

/* Placeholder discreto (3º nível de texto, mais claro que muted). */
input::placeholder,
textarea::placeholder {
  color: var(--color-text-placeholder);
}

/* Desabilitado. */
input:disabled,
select:disabled,
textarea:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* Estado de erro: borda em danger. Aplicar .field--error no invólucro. */
.field--error input,
.field--error select,
.field--error textarea {
  border-color: var(--color-danger);
}

.field--error label {
  color: var(--color-danger);
}

.field__error {
  font-size: var(--text-sm);
  color: var(--color-danger);
}

/* Autofill do navegador: por padrão o Chrome/Safari pintam um fundo
   azul/amarelo que ignora nosso tema. Cobrimos o fundo com um box-shadow
   interno (truque conhecido — o navegador não respeita background-color
   no autofill) e forçamos a cor do texto. Mantém o visual do tema. */
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus {
  -webkit-text-fill-color: var(--color-text);
  -webkit-box-shadow: 0 0 0 1000px var(--color-surface) inset;
  box-shadow: 0 0 0 1000px var(--color-surface) inset;
  caret-color: var(--color-text);
  transition: background-color 9999s ease-in-out 0s;
}

/* Grupo de opções (checkboxes/radios) em grade compacta. Usado para
   campos de múltipla escolha, como categorias do cliente. */
.choice-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(10rem, 1fr));
  gap: var(--space-2);
}

/* Cada opção: checkbox + rótulo lado a lado, clicável. */
.choice {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  cursor: pointer;
}

.choice input {
  width: auto;
  margin: 0;
  cursor: pointer;
}

.choice span {
  font-size: var(--text-sm);
}

/* Lista dinâmica de seletores (locatários, fiadores).
   Cada linha: um select que cresce + botão remover ao lado. */
.people-select__row {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-2);
}

.people-select__row select {
  flex: 1;
}

/* Botão de remover linha: discreto, quadrado, alinhado ao select. */
.people-select__remove {
  flex-shrink: 0;
  width: 2.5rem;
  height: 2.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border: var(--border-width) solid var(--color-border);
  border-radius: var(--radius-md);
  background: none;
  color: var(--color-text-muted);
  cursor: pointer;
  font-size: var(--text-lg);
  line-height: 1;
}

.people-select__remove:hover {
  color: var(--color-text);
  border-color: var(--color-text-muted);
}
