/* =============================================================================
   FORMS TUSKO — Identidade visual (uma folha de estilo para tudo)
   -----------------------------------------------------------------------------
   Por quê uma só: menos arquivos pra manter, e a marca fica consistente
   no formulário do cliente, no painel admin e na página inicial.
   Paleta e fontes vieram do site oficial tusko.com.br (mesma cara).
   ========================================================================== */

:root {
  /* Cores da marca */
  --preto:    #0E0E0E;   /* fundo escuro / texto forte */
  --dourado:  #F5B800;   /* cor de destaque da Tusko */
  --dourado-escuro: #c99700;
  --creme:    #F2EFE7;   /* claro, fundo das telas de leitura */
  --cinza:    #8A8880;   /* texto secundário */
  --cinza-claro: #e7e4da;/* bordas suaves */
  --branco:   #ffffff;
  --erro:     #c0392b;
  --ok:       #1e8a4c;

  --raio: 14px;          /* cantos arredondados */
  --sombra: 0 8px 30px rgba(14,14,14,.08);
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  font-family: 'DM Sans', system-ui, -apple-system, sans-serif;
  color: var(--preto);
  background: var(--creme);
  -webkit-font-smoothing: antialiased;
}

/* Títulos com a fonte de display da marca */
h1, h2, .display {
  font-family: 'Bebas Neue', sans-serif;
  font-weight: 400;
  letter-spacing: .02em;
  line-height: 1;
  margin: 0;
}

a { color: var(--dourado-escuro); }

/* ---- Marca / cabeçalho ---- */
.tusko-marca {
  font-family: 'Bebas Neue', sans-serif;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--dourado);
  font-size: .82rem;
}

/* ---- Cartão central (usado no formulário e no login) ---- */
.tela {
  min-height: 100dvh;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: 40px 16px 80px;
}
.cartao {
  width: 100%;
  max-width: 640px;       /* leitura confortável, mobile-first */
  background: var(--branco);
  border-radius: var(--raio);
  box-shadow: var(--sombra);
  border: 1px solid var(--cinza-claro);
  overflow: hidden;
}
.cartao-topo {
  background: var(--preto);
  color: var(--creme);
  padding: 26px 30px;
}
.cartao-topo h1 { font-size: 2.1rem; color: var(--creme); margin-top: 6px; }
.cartao-topo .sub { color: var(--cinza); font-size: .98rem; margin-top: 8px; line-height: 1.5; }
.cartao-corpo { padding: 30px; }

/* ---- Barra de progresso (formulário de várias páginas) ---- */
.progresso { height: 4px; background: var(--cinza-claro); }
.progresso > div { height: 100%; background: var(--dourado); width: 0; transition: width .3s ease; }
.passo-info { font-size: .82rem; color: var(--cinza); letter-spacing: .04em; text-transform: uppercase; margin-bottom: 4px; }

/* ---- Campos do formulário ---- */
.campo { margin-bottom: 22px; }
.campo > label {
  display: block;
  font-weight: 600;
  margin-bottom: 7px;
  font-size: 1.02rem;
}
.campo .obrig { color: var(--dourado-escuro); }
.campo .ajuda { font-size: .86rem; color: var(--cinza); margin: 2px 0 8px; }

input[type=text], input[type=email], input[type=tel], input[type=number],
input[type=date], input[type=url], textarea, select {
  width: 100%;
  padding: 13px 14px;
  border: 1.5px solid var(--cinza-claro);
  border-radius: 10px;
  font: inherit;
  background: #fcfbf8;
  transition: border-color .15s, box-shadow .15s;
}
textarea { min-height: 110px; resize: vertical; }
input:focus, textarea:focus, select:focus {
  outline: none;
  border-color: var(--dourado);
  box-shadow: 0 0 0 3px rgba(245,184,0,.18);
}

/* Opções (radio / checkbox) em "pílulas" clicáveis */
.opcoes { display: flex; flex-direction: column; gap: 8px; }
.opcao {
  display: flex; align-items: center; gap: 10px;
  border: 1.5px solid var(--cinza-claro); border-radius: 10px;
  padding: 11px 14px; cursor: pointer; background: #fcfbf8;
}
.opcao:hover { border-color: var(--dourado); }
.opcao input { width: auto; }

/* ---- Botões ---- */
.botoes { display: flex; gap: 12px; margin-top: 10px; }
button, .btn {
  font: inherit; font-weight: 600; cursor: pointer;
  border-radius: 10px; padding: 13px 22px; border: 1.5px solid transparent;
  transition: transform .05s, background .15s, border-color .15s;
}
button:active { transform: translateY(1px); }
.btn-primario { background: var(--dourado); color: var(--preto); }
.btn-primario:hover { background: var(--dourado-escuro); }
.btn-secundario { background: transparent; color: var(--preto); border-color: var(--cinza-claro); }
.btn-secundario:hover { border-color: var(--preto); }
.btn-fantasma { background: transparent; color: var(--cinza); border: none; padding: 8px; }
button[disabled] { opacity: .5; cursor: not-allowed; }
.cresce { flex: 1; }

/* ---- Mensagens ---- */
.aviso { padding: 12px 14px; border-radius: 10px; font-size: .92rem; margin: 10px 0; }
.aviso-erro { background: #fdecea; color: var(--erro); border: 1px solid #f5c6c0; }
.aviso-ok   { background: #e8f6ee; color: var(--ok);   border: 1px solid #bfe6cd; }
.erro-campo { color: var(--erro); font-size: .82rem; margin-top: 5px; }

/* ---- Tela de sucesso ---- */
.sucesso { text-align: center; padding: 30px 10px; }
.sucesso .marca-ok {
  width: 64px; height: 64px; border-radius: 50%;
  background: var(--dourado); color: var(--preto);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 2rem; margin-bottom: 16px;
}

/* ---- Rodapé discreto ---- */
.rodape { text-align: center; color: var(--cinza); font-size: .78rem; margin-top: 22px; letter-spacing: .04em; }

/* =========================== PAINEL ADMIN ================================= */
.admin-topo {
  background: var(--preto); color: var(--creme);
  padding: 14px 22px; display: flex; align-items: center; justify-content: space-between;
  position: sticky; top: 0; z-index: 10;
}
.admin-topo .tusko-marca { font-size: 1rem; }
.admin-wrap { max-width: 1100px; margin: 0 auto; padding: 26px 18px 80px; }
.abas { display: flex; gap: 6px; border-bottom: 2px solid var(--cinza-claro); margin-bottom: 24px; flex-wrap: wrap; }
.aba {
  padding: 12px 18px; cursor: pointer; border: none; background: none;
  font-weight: 600; color: var(--cinza); border-bottom: 3px solid transparent; margin-bottom: -2px;
}
.aba.ativa { color: var(--preto); border-bottom-color: var(--dourado); }

.painel { background: var(--branco); border: 1px solid var(--cinza-claro); border-radius: var(--raio); padding: 22px; box-shadow: var(--sombra); }
.painel + .painel { margin-top: 18px; }

.linha-flex { display: flex; gap: 12px; flex-wrap: wrap; align-items: end; }
.filtro label { display:block; font-size:.8rem; color:var(--cinza); margin-bottom:4px; text-transform:uppercase; letter-spacing:.04em;}

table { width: 100%; border-collapse: collapse; font-size: .94rem; }
th, td { text-align: left; padding: 11px 10px; border-bottom: 1px solid var(--cinza-claro); vertical-align: top; }
th { font-size: .78rem; text-transform: uppercase; letter-spacing: .04em; color: var(--cinza); }
tr:hover td { background: #faf8f2; }

.tag { display:inline-block; padding:3px 9px; border-radius:999px; font-size:.76rem; font-weight:600; background:var(--cinza-claro); }
.tag-ativo { background:#e8f6ee; color:var(--ok); }
.tag-inativo { background:#f0eee8; color:var(--cinza); }

.mini { font-size:.82rem; color:var(--cinza); }
.copia { cursor:pointer; border:1px dashed var(--cinza-claro); padding:6px 10px; border-radius:8px; background:#fcfbf8; font-size:.84rem; }
.copia:hover { border-color: var(--dourado); }

/* Janela modal (ver uma resposta / editor) */
.modal-fundo { position: fixed; inset: 0; background: rgba(14,14,14,.55); display:flex; align-items:flex-start; justify-content:center; padding: 30px 14px; overflow:auto; z-index: 50; }
.modal { background: var(--branco); border-radius: var(--raio); max-width: 760px; width: 100%; box-shadow: var(--sombra); }
.modal-topo { display:flex; justify-content:space-between; align-items:center; padding: 18px 22px; border-bottom: 1px solid var(--cinza-claro); }
.modal-corpo { padding: 22px; }
.oculto { display: none !important; }

/* Editor de formulário (construtor) */
.bloco-pagina { border: 1px solid var(--cinza-claro); border-radius: 10px; padding: 16px; margin-bottom: 14px; background:#fcfbf8; }
.bloco-pergunta { border: 1px solid var(--cinza-claro); border-radius: 8px; padding: 12px; margin: 10px 0; background:#fff; }
.grade-pergunta { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
@media (max-width: 560px){ .grade-pergunta { grid-template-columns: 1fr; } }
.spinner { display:inline-block; width:18px;height:18px;border:3px solid var(--cinza-claro);border-top-color:var(--dourado);border-radius:50%;animation:girar .7s linear infinite;vertical-align:middle;}
@keyframes girar { to { transform: rotate(360deg); } }
