/* Variáveis de cores */
:root {
  --cor-fundo: #1a1a2e;
  --cor-primaria: #7b2cbf;
  --cor-secundaria: #c77dff;
  --cor-texto: #ffffff;
  --cor-borda: #9d4edd;
  --cor-destaque: rgba(255, 255, 255, 0.05);
}

/* Reset básico e box-sizing */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

/* Corpo da página */
body {
  background: var(--cor-fundo);
  color: var(--cor-texto);
  font-family: Arial, sans-serif;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 20px;
}

/* Header */
header {
  margin-bottom: 20px;
  text-align: center;
}

header h1 {
  color: var(--cor-secundaria);
  font-size: 2rem;
}

/* Main container */
main {
  width: 100%;
  max-width: 600px;
  background: var(--cor-destaque);
  padding: 20px;
  border-radius: 10px;
  box-shadow: 0 0 10px rgba(199, 125, 255, 0.2);
}

/* Seções */
section {
  margin-bottom: 20px;
}

/* Labels das configurações e perguntas */
#area-configuracoes label,
#area-perguntas label {
  margin-bottom: 5px;
  display: block;
  font-weight: bold;
}

/* Inputs, selects e textarea */
input[type="password"],
select,
textarea {
  width: 100%;
  padding: 10px;
  border: 2px solid var(--cor-secundaria);
  background: transparent;
  color: var(--cor-texto);
  border-radius: 5px;
  font-size: 1rem;
}

/* Textarea com tamanho controlado */
textarea {
  min-height: 100px;
  max-height: 200px;
  font-family: monospace, monospace;
  resize: vertical;
}

/* Área das perguntas: organiza textarea + botão */
#area-perguntas {
  display: flex;
  flex-direction: column; /* empilha verticalmente */
  align-items: center;    /* centraliza horizontalmente */
  gap: 10px;              /* espaçamento entre textarea e botão */
}

/* Botão Perguntar */
#botao-enviar {
  max-width: 200px;
  width: 100%;
  padding: 10px;
  border: none;
  background: var(--cor-primaria);
  color: var(--cor-texto);
  cursor: pointer;
  font-size: 16px;
  border-radius: 5px;
  transition: background 0.3s ease;
}

#botao-enviar:hover {
  background: var(--cor-secundaria);
}

/* Botão Limpar */
#botao-limpar {
  max-width: 200px;
  width: 100%;
  padding: 10px;
  margin-top: 10px;
  border: none;
  background: var(--cor-borda);
  color: var(--cor-texto);
  cursor: pointer;
  font-size: 16px;
  border-radius: 5px;
  transition: background 0.3s ease;
  display: none; /* começa oculto, vai aparecer via JS */
}

#botao-limpar:hover {
  background: var(--cor-secundaria);
}

/* Área da resposta */
#area-resposta h2 {
  margin-bottom: 10px;
  color: var(--cor-secundaria);
}

#texto-resposta {
  padding: 10px;
  border: 1px solid var(--cor-borda);
  background: var(--cor-destaque);
  min-height: 60px;
  border-radius: 5px;
  white-space: pre-wrap;
}

/* Spinner */
.spinner {
  border: 4px solid rgba(255, 255, 255, 0.15);
  border-left-color: var(--cor-primaria);
  border-radius: 50%;
  width: 36px;
  height: 36px;
  animation: spin 1s linear infinite;
  margin: 20px auto;
}

@keyframes spin {
  to { transform: rotate(360deg); }
}

/* Transições suaves para inputs e botões */
input, select, textarea, button {
  transition: border-color 0.3s ease, background-color 0.3s ease;
}

/* Footer */
footer {
  margin-top: auto;
  padding: 20px 0;
  text-align: center;
  color: var(--cor-texto);
  font-size: 0.9rem;
  width: 100%;
}
