/* =============================================================
   NIDUS HUB — Sistema de Formulários Reutilizável
   Arquivo: Public/assets/forms.css
   Carregar no layout após estilo.css
   =============================================================

   ÍNDICE
   1. Container da página de formulário (.pagina-form)
   2. Grid de campos (.form-grid)
   3. Campo base (.campo) + label
   4. Inputs de texto, e-mail, data, hora, número
   5. Moeda e máscara (.campo--moeda, .campo--cep, etc.)
   6. Select / Dropdown
   7. Textarea
   8. Checkbox e Radio (.campo--check, .campo--radio)
   9. Toggle (switch)
  10. Campo somente leitura / desabilitado
  11. Campo com ícone prefixo/sufixo
  12. Campo com botão inline
  13. Mensagem de ajuda e erro
  14. Rodapé do formulário (.form-footer)
  15. Responsividade
  ============================================================= */


/* ── 1. Container da página de formulário ─────────────────── */

/*
  Uso: <div class="pagina pagina-form page-max">
  Substitui pagina-compra, pagina-lancamento, etc.
  Todos os forms usam essa única classe.
*/
.pagina-form {
  padding: 0 2px;
}

.pagina-form .form-wide,
.pagina-form .card {
  margin-top: 12px;
}


/* ── 2. Grid de campos ────────────────────────────────────── */

/*
  Uso: <div class="form-grid">
  Padrão: 4 colunas. Ajuste com .grid-2, .grid-3 ou .cols-2, .cols-3 (aliases).
  Spans: .span-1 .span-2 .span-3 .span-4 (full)
*/
.form-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px 16px;
}

.form-grid.cols-1,
.form-grid.grid-1 { grid-template-columns: 1fr; }

.form-grid.cols-2,
.form-grid.grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }

.form-grid.cols-3,
.form-grid.grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }

/* grid-4 é o padrão — alias explícito para consistência com formCompra */
.form-grid.grid-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }

.form-grid .span-1 { grid-column: span 1; }
.form-grid .span-2 { grid-column: span 2; }
.form-grid .span-3 { grid-column: span 3; }
.form-grid .span-4 { grid-column: 1 / -1; }

/* Seção com título dentro do grid */
.form-grid .form-secao {
  grid-column: 1 / -1;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--cor-texto-fraco);
  padding-bottom: 4px;
  border-bottom: 1px solid var(--cor-borda);
  margin-top: 8px;
}

/* Divisor horizontal dentro do grid */
.form-grid .form-divisor {
  grid-column: 1 / -1;
  border: none;
  border-top: 1px solid var(--cor-borda);
  margin: 4px 0;
}


/* ── 3. Campo base ────────────────────────────────────────── */

/*
  Uso: <div class="campo">
          <label>Nome *</label>
          <input type="text" name="...">
       </div>
*/
.campo {
  display: flex;
  flex-direction: column;
  gap: 5px;
}

.campo label {
  font-size: 13px;
  font-weight: 700;
  color: var(--cor-texto);
  line-height: 1.3;
  user-select: none;
}

/* Asterisco obrigatório — automático via CSS quando label tem * */
.campo label .obrigatorio,
.campo label abbr {
  color: var(--cor-erro, #e53e3e);
  text-decoration: none;
  margin-left: 2px;
}


/* ── 4. Input base ────────────────────────────────────────── */

.campo input[type="text"],
.campo input[type="email"],
.campo input[type="tel"],
.campo input[type="url"],
.campo input[type="password"],
.campo input[type="number"],
.campo input[type="search"],
.campo input[type="date"],
.campo input[type="time"],
.campo input[type="datetime-local"],
.campo input[type="month"],
.campo input[type="week"],
.campo input:not([type]) {
  width: 100%;
  box-sizing: border-box;
  height: 42px;
  padding: 0 12px;
  border-radius: 10px;
  border: 1px solid var(--cor-borda);
  background: var(--cor-surface);
  color: var(--cor-texto);
  font-size: 14px;
  transition: border-color .15s, box-shadow .15s;
}

.campo input::placeholder {
  color: var(--cor-texto-fraco);
  font-size: 13px;
}

.campo input:focus {
  outline: none;
  border-color: var(--cor-primaria);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--cor-primaria) 18%, transparent);
}


/* ── 5. Variantes de input por tipo semântico ─────────────── */

/*
  Uso: <div class="campo campo--moeda">
         <label>Valor</label>
         <input type="text" data-mascara="moeda">
       </div>
  Idem para .campo--cpf, .campo--cnpj, .campo--cep, .campo--fone
*/

/* Moeda — alinha texto à direita */
.campo--moeda input,
.campo--numero input {
  text-align: right;
  font-variant-numeric: tabular-nums;
  letter-spacing: .01em;
}

/* Data — ícone nativo não interfere */
.campo--data input[type="date"],
.campo--hora input[type="time"] {
  cursor: pointer;
}

/* Senha — padding extra para o olhinho */
.campo--senha {
  position: relative;
}
.campo--senha input {
  padding-right: 44px;
}
.campo--senha .campo-olho {
  position: absolute;
  right: 12px;
  bottom: 11px;
  cursor: pointer;
  color: var(--cor-texto-fraco);
  font-size: 16px;
  background: none;
  border: none;
  padding: 0;
  line-height: 1;
}
.campo--senha .campo-olho:hover {
  color: var(--cor-texto);
}

/* Busca */
.campo--busca {
  position: relative;
}
.campo--busca input {
  padding-left: 38px;
}
.campo--busca::before {
  content: '\F52A'; /* bi-search */
  font-family: 'bootstrap-icons';
  position: absolute;
  left: 12px;
  bottom: 12px;
  color: var(--cor-texto-fraco);
  font-size: 15px;
  pointer-events: none;
}


/* ── 6. Select / Dropdown ─────────────────────────────────── */
/*
  O select base já é tratado no estilo.css (.campo select).
  Aqui só complementamos com focus e altura consistente.
*/
.campo select {
  width: 100%;
  box-sizing: border-box;
  height: 42px;
  padding: 0 12px;
  border-radius: 10px;
  border: 1px solid var(--cor-borda);
  background: var(--cor-surface);
  color: var(--cor-texto);
  font-size: 14px;
  cursor: pointer;
  transition: border-color .15s, box-shadow .15s;
}

.campo select:focus {
  outline: none;
  border-color: var(--cor-primaria);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--cor-primaria) 18%, transparent);
}

.campo select option {
  background: var(--cor-surface);
  color: var(--cor-texto);
}

/* Dark mode */
body[data-theme="dark"] .campo select {
  background: #0f172a;
  color: #e5e7eb;
  border-color: #1e293b;
}
body[data-theme="dark"] .campo select option {
  background: #0f172a;
  color: #e5e7eb;
}
body[data-theme="dark"] .campo input {
  background: #0f172a;
  color: #e5e7eb;
  border-color: #1e293b;
}

/* ── 7. Textarea ──────────────────────────────────────────── */

.campo textarea {
  width: 100%;
  box-sizing: border-box;
  min-height: 90px;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid var(--cor-borda);
  background: var(--cor-surface);
  color: var(--cor-texto);
  font-size: 14px;
  resize: vertical;
  transition: border-color .15s, box-shadow .15s;
}

.campo textarea::placeholder {
  color: var(--cor-texto-fraco);
  font-size: 13px;
}

.campo textarea:focus {
  outline: none;
  border-color: var(--cor-primaria);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--cor-primaria) 18%, transparent);
}

body[data-theme="dark"] .campo textarea {
  background: #0f172a;
  color: #e5e7eb;
  border-color: #1e293b;
}

/* Altura variantes */
.campo textarea.txt-sm  { min-height: 60px; }
.campo textarea.txt-lg  { min-height: 140px; }
.campo textarea.txt-xl  { min-height: 200px; }


/* ── 8. Checkbox e Radio ──────────────────────────────────── */

/*
  Uso checkbox:
  <div class="campo campo--check">
    <label class="check-label">
      <input type="checkbox" name="...">
      <span>Ativo</span>
    </label>
  </div>

  Uso radio group:
  <div class="campo">
    <label>Tipo</label>
    <div class="radio-group">
      <label class="radio-label"><input type="radio" name="tipo" value="A"> Opção A</label>
      <label class="radio-label"><input type="radio" name="tipo" value="B"> Opção B</label>
    </div>
  </div>
*/

.campo--check {
  flex-direction: row;
  align-items: center;
  gap: 0;
  padding-top: 22px; /* alinha com inputs na mesma linha do grid */
}

.check-label {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  font-size: 14px;
  font-weight: 600;
  color: var(--cor-texto);
  user-select: none;
}

.check-label input[type="checkbox"],
.check-label input[type="radio"] {
  width: 18px;
  height: 18px;
  border-radius: 5px;
  border: 1px solid var(--cor-borda);
  background: var(--cor-surface);
  accent-color: var(--cor-primaria);
  cursor: pointer;
  flex-shrink: 0;
}

/* Radio group horizontal */
.radio-group {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  align-items: center;
  min-height: 42px;
}

.radio-label {
  display: flex;
  align-items: center;
  gap: 6px;
  cursor: pointer;
  font-size: 14px;
  font-weight: 600;
  color: var(--cor-texto);
  user-select: none;
}

.radio-label input[type="radio"] {
  width: 16px;
  height: 16px;
  accent-color: var(--cor-primaria);
  cursor: pointer;
}


/* ── 9. Toggle (switch on/off) ────────────────────────────── */

/*
  Uso:
  <label class="toggle">
    <input type="checkbox" name="ativo" value="1">
    <span class="toggle-track"></span>
    <span class="toggle-label">Ativo</span>
  </label>
*/
.toggle {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  user-select: none;
}

.toggle input[type="checkbox"] {
  display: none;
}

.toggle-track {
  position: relative;
  width: 44px;
  height: 24px;
  border-radius: 12px;
  background: var(--cor-borda);
  transition: background .2s;
  flex-shrink: 0;
}

.toggle-track::after {
  content: '';
  position: absolute;
  top: 3px;
  left: 3px;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: #fff;
  transition: transform .2s;
  box-shadow: 0 1px 3px rgba(0,0,0,.2);
}

.toggle input:checked ~ .toggle-track {
  background: var(--cor-primaria);
}

.toggle input:checked ~ .toggle-track::after {
  transform: translateX(20px);
}

.toggle-label {
  font-size: 14px;
  font-weight: 600;
  color: var(--cor-texto);
}


/* ── 10. Campo somente leitura / desabilitado ─────────────── */

.campo input[readonly],
.campo textarea[readonly] {
  opacity: .85;
  background: color-mix(in srgb, var(--cor-surface) 85%, var(--cor-bg));
  cursor: default;
  border-style: dashed;
}

.campo input:disabled,
.campo select:disabled,
.campo textarea:disabled {
  opacity: .5;
  cursor: not-allowed;
}

/* Campo estático — exibe valor sem aparência de input */
.campo .campo-estatico {
  display: flex;
  align-items: center;
  min-height: 42px;
  padding: 0 12px;
  border-radius: 10px;
  border: 1px dashed var(--cor-borda);
  background: color-mix(in srgb, var(--cor-surface) 85%, var(--cor-bg));
  color: var(--cor-texto);
  font-size: 14px;
}


/* ── 11. Campo com ícone prefixo/sufixo ───────────────────── */

/*
  Uso:
  <div class="campo">
    <label>Valor</label>
    <div class="input-addon">
      <span class="input-prefix">R$</span>
      <input type="text">
    </div>
  </div>
*/
.input-addon {
  display: flex;
  align-items: stretch;
}

.input-addon input {
  border-radius: 0 10px 10px 0 !important;
  flex: 1;
  min-width: 0;
}

.input-prefix,
.input-suffix {
  display: flex;
  align-items: center;
  padding: 0 12px;
  border: 1px solid var(--cor-borda);
  background: color-mix(in srgb, var(--cor-surface) 85%, var(--cor-bg));
  color: var(--cor-texto-fraco);
  font-size: 13px;
  font-weight: 600;
  white-space: nowrap;
  flex-shrink: 0;
}

.input-prefix {
  border-right: none;
  border-radius: 10px 0 0 10px;
}

.input-suffix {
  border-left: none;
  border-radius: 0 10px 10px 0;
}

.input-suffix ~ input,
.input-addon input:has(~ .input-suffix) {
  border-radius: 10px 0 0 10px !important;
}


/* ── 12. Campo com botão inline ───────────────────────────── */

/*
  Uso: campo de busca de pessoa com botão "Pesquisar"
  <div class="campo">
    <label>Fornecedor</label>
    <div class="input-com-btn">
      <input type="text" readonly>
      <button type="button" class="btn btn-sec btn-sm">Pesquisar</button>
    </div>
  </div>
*/
.input-com-btn {
  display: flex;
  gap: 8px;
  align-items: center;
}

.input-com-btn input {
  flex: 1;
  min-width: 0;
}


/* ── 13. Mensagem de ajuda e erro ─────────────────────────── */

.campo .campo-ajuda {
  font-size: 12px;
  color: var(--cor-texto-fraco);
  line-height: 1.4;
}

.campo .campo-erro {
  font-size: 12px;
  color: var(--cor-erro, #e53e3e);
  font-weight: 600;
  line-height: 1.4;
}

/* Campo com estado de erro */
.campo.tem-erro input,
.campo.tem-erro select,
.campo.tem-erro textarea {
  border-color: var(--cor-erro, #e53e3e);
  background: color-mix(in srgb, var(--cor-surface) 94%, #e53e3e);
}

.campo.tem-erro input:focus,
.campo.tem-erro select:focus,
.campo.tem-erro textarea:focus {
  box-shadow: 0 0 0 3px color-mix(in srgb, #e53e3e 18%, transparent);
}

/* Campo com estado de sucesso */
.campo.tem-sucesso input,
.campo.tem-sucesso select,
.campo.tem-sucesso textarea {
  border-color: var(--cor-sucesso, #38a169);
}


/* ── 14. Rodapé do formulário ─────────────────────────────── */

/*
  Já existe como .card-footer — aqui reforçamos o padrão
  Uso: <div class="form-footer">
         <a class="btn btn-sec" href="...">Cancelar</a>
         <button class="btn btn-pri" type="submit">Salvar</button>
       </div>
*/
.form-footer {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 10px;
  padding: 16px 20px;
  border-top: 1px solid var(--cor-borda);
  background: color-mix(in srgb, var(--cor-surface) 96%, var(--cor-bg));
  border-radius: 0 0 14px 14px;
}

.form-footer .footer-info {
  flex: 1;
  font-size: 12px;
  color: var(--cor-texto-fraco);
}


/* ── 15. Responsividade ───────────────────────────────────── */

@media (max-width: 1024px) {
  .form-grid,
  .form-grid.grid-4 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .form-grid .span-3,
  .form-grid .span-4 { grid-column: 1 / -1; }
  .form-grid .span-2 { grid-column: span 2; }
  /* grid-3 mantém 2 colunas em tablet */
  .form-grid.cols-3,
  .form-grid.grid-3 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 640px) {
  .form-grid {
    grid-template-columns: 1fr;
    padding: 12px;
    gap: 10px;
  }
  .form-grid .span-1,
  .form-grid .span-2,
  .form-grid .span-3,
  .form-grid .span-4 { grid-column: 1 / -1; }

  .campo--check { padding-top: 0; }
  .radio-group { gap: 10px; }
  .form-footer { flex-wrap: wrap; }
}