/* ============================================================
   style.css — Taberna dos Bits
   Estética: Pixel Art 8-bit/16-bit, paleta de taberna medieval
   ============================================================ */

/* ---------- VARIÁVEIS DE COR ---------- */
:root {
  --cor-fundo:         #1a0e00;   /* marrom escuro (madeira queimada) */
  --cor-pergaminho:    #2e1a00;   /* marrom médio (madeira de taberna) */
  --cor-borda:         #8b5e1a;   /* dourado velho */
  --cor-borda-alt:     #000000;   /* preto sólido */
  --cor-primaria:      #1db954;   /* verde esmeralda (Supabase) */
  --cor-primaria-hover:#17a347;   /* verde mais escuro no hover */
  --cor-texto:         #f5deb3;   /* trigo / pergaminho claro */
  --cor-texto-dim:     #a07840;   /* dourado apagado */
  --cor-dourado:       #ffd700;   /* dourado brilhante */
  --cor-erro:          #e74c3c;   /* vermelho RPG */
  --cor-sucesso:       #1db954;   /* verde RPG */
  --cor-aba-inativa:   #1a0e00;   /* fundo das abas inativas */
  --cor-aba-ativa:     #3d2200;   /* fundo da aba ativa */
}

/* ---------- RESET BÁSICO ---------- */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

/* ---------- BODY / FUNDO ---------- */
body {
  font-family: 'Press Start 2P', monospace;
  background-color: var(--cor-fundo);
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px 16px;

  /* Padrão de grade pixel no fundo */
  background-image:
    repeating-linear-gradient(
      0deg,
      transparent,
      transparent 31px,
      rgba(139, 94, 26, 0.08) 31px,
      rgba(139, 94, 26, 0.08) 32px
    ),
    repeating-linear-gradient(
      90deg,
      transparent,
      transparent 31px,
      rgba(139, 94, 26, 0.08) 31px,
      rgba(139, 94, 26, 0.08) 32px
    );
}

/* ---------- PIXELS DECORATIVOS DE FUNDO ---------- */
.bg-pixels {
  position: fixed;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
  z-index: 0;
}

.bg-pixels span {
  position: absolute;
  display: block;
  width: 8px;
  height: 8px;
  background: var(--cor-dourado);
  opacity: 0.15;
  animation: floatPixel 8s infinite linear;
}

/* Posições e delays diferentes para cada pixel flutuante */
.bg-pixels span:nth-child(1)  { left: 10%; top: 20%; animation-duration: 7s;  animation-delay: 0s;   }
.bg-pixels span:nth-child(2)  { left: 30%; top: 80%; animation-duration: 9s;  animation-delay: 1s;   }
.bg-pixels span:nth-child(3)  { left: 60%; top: 10%; animation-duration: 6s;  animation-delay: 2s;   }
.bg-pixels span:nth-child(4)  { left: 80%; top: 50%; animation-duration: 10s; animation-delay: 0.5s; }
.bg-pixels span:nth-child(5)  { left: 50%; top: 70%; animation-duration: 8s;  animation-delay: 3s;   }
.bg-pixels span:nth-child(6)  { left: 90%; top: 30%; animation-duration: 7s;  animation-delay: 1.5s; }
.bg-pixels span:nth-child(7)  { left: 20%; top: 60%; animation-duration: 11s; animation-delay: 0.8s; }
.bg-pixels span:nth-child(8)  { left: 70%; top: 90%; animation-duration: 6s;  animation-delay: 4s;   }

@keyframes floatPixel {
  0%   { transform: translateY(0)   rotate(0deg);   opacity: 0.15; }
  50%  { transform: translateY(-40px) rotate(180deg); opacity: 0.35; }
  100% { transform: translateY(0)   rotate(360deg); opacity: 0.15; }
}

/* ---------- CONTAINER PERGAMINHO ---------- */
.scroll-container {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 460px;
  background-color: var(--cor-pergaminho);
  border: 4px solid var(--cor-borda);
  outline: 4px solid var(--cor-borda-alt);  /* borda dupla estilo pixel */
  padding: 32px 28px 24px;
  image-rendering: pixelated;

  /* Sombra estilo pixel (sem blur, apenas offset sólido) */
  box-shadow:
    8px  8px 0 0 #000,
    12px 12px 0 0 rgba(139, 94, 26, 0.4);

  animation: aparecer 0.3s steps(6, end) both;
}

@keyframes aparecer {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ---------- CABEÇALHO ---------- */
.tavern-header {
  text-align: center;
  margin-bottom: 24px;
  padding-bottom: 20px;
  border-bottom: 4px solid var(--cor-borda);
}

.tavern-icon {
  font-size: 32px;
  display: block;
  margin-bottom: 12px;
  /* Animação de pulso suave */
  animation: pulsarEspada 2s steps(2, end) infinite;
}

@keyframes pulsarEspada {
  0%, 100% { transform: scale(1)   rotate(-5deg); }
  50%       { transform: scale(1.1) rotate(5deg);  }
}

.tavern-title {
  font-size: 18px;
  color: var(--cor-dourado);
  line-height: 1.6;
  letter-spacing: 2px;
  /* Sombra de texto estilo pixel */
  text-shadow:
    2px  2px 0 #000,
    4px  4px 0 rgba(139, 94, 26, 0.6);
}

.tavern-subtitle {
  margin-top: 10px;
  font-size: 7px;
  color: var(--cor-texto-dim);
  letter-spacing: 3px;
}

/* ---------- ABAS ---------- */
.tab-nav {
  display: grid;
  grid-template-columns: 1fr 1fr;
  margin-bottom: 24px;
  border: 4px solid var(--cor-borda);
  outline: 4px solid #000;
}

.tab-btn {
  font-family: 'Press Start 2P', monospace;
  font-size: 9px;
  padding: 12px 8px;
  border: none;
  cursor: pointer;
  background-color: var(--cor-aba-inativa);
  color: var(--cor-texto-dim);
  letter-spacing: 1px;
  transition: none; /* sem transição suave — estilo pixel */
}

/* Divisor entre abas */
.tab-btn:first-child {
  border-right: 4px solid var(--cor-borda);
}

.tab-btn.active {
  background-color: var(--cor-aba-ativa);
  color: var(--cor-dourado);
}

.tab-btn:not(.active):hover {
  background-color: #261500;
  color: var(--cor-texto);
}

/* ---------- BANNER DE MISSÃO ---------- */
.quest-banner {
  background-color: #0a0600;
  border: 4px solid var(--cor-borda-alt);
  border-left: 4px solid var(--cor-primaria);
  padding: 10px 12px;
  font-size: 7px;
  color: var(--cor-texto-dim);
  margin-bottom: 24px;
  line-height: 1.8;
}

.quest-label {
  color: var(--cor-primaria);
}

/* ---------- GRUPOS DE CAMPOS ---------- */
.field-group {
  margin-bottom: 20px;
}

.field-label {
  display: block;
  font-size: 8px;
  color: var(--cor-texto);
  margin-bottom: 10px;
  letter-spacing: 1px;
}

/* ---------- INPUTS ---------- */
.pixel-input {
  font-family: 'Press Start 2P', monospace;
  font-size: 9px;
  width: 100%;
  padding: 12px 14px;
  background-color: #0f0800;
  color: var(--cor-primaria);
  border: 4px solid var(--cor-borda);
  outline: none;
  caret-color: var(--cor-primaria);
  letter-spacing: 1px;
}

.pixel-input::placeholder {
  color: #4a3010;
  font-size: 8px;
}

/* Foco: borda dourada sem outline do browser */
.pixel-input:focus {
  border-color: var(--cor-dourado);
  background-color: #150c00;
}

/* Animação de cursor piscante estilo terminal */
.pixel-input:focus::after {
  content: '█';
  animation: piscar 1s steps(1, end) infinite;
}

@keyframes piscar {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0; }
}

/* ---------- BOTÃO PRINCIPAL ---------- */
.btn-primary {
  font-family: 'Press Start 2P', monospace;
  font-size: 10px;
  width: 100%;
  padding: 16px 12px;
  margin-top: 8px;
  background-color: var(--cor-primaria);
  color: #000;
  border: 4px solid #000;
  cursor: pointer;
  letter-spacing: 1px;

  /* Sombra sólida pixel */
  box-shadow: 4px 4px 0 0 #000;

  transition: none;
}

.btn-primary:hover {
  background-color: var(--cor-primaria-hover);
  transform: translate(2px, 2px);
  box-shadow: 2px 2px 0 0 #000;
}

.btn-primary:active {
  transform: translate(4px, 4px);
  box-shadow: none;
}

/* ---------- LINK ALTERNATIVO ---------- */
.switch-link {
  text-align: center;
  font-size: 7px;
  color: var(--cor-texto-dim);
  margin-top: 20px;
  line-height: 2;
}

.switch-link a {
  color: var(--cor-dourado);
  text-decoration: none;
}

.switch-link a:hover {
  color: var(--cor-primaria);
  text-decoration: underline;
}

/* ---------- PAINÉIS DE FORMULÁRIO (controle de visibilidade) ---------- */
.form-panel {
  display: none;
}

.form-panel.active {
  display: block;
  animation: aparecer 0.2s steps(4, end) both;
}

/* ---------- TOAST (mensagem de feedback) ---------- */
.toast {
  display: none;
  margin-top: 16px;
  padding: 12px 14px;
  font-size: 8px;
  border: 4px solid #000;
  line-height: 1.8;
  text-align: center;
}

.toast.show       { display: block; }
.toast.toast-ok   { background-color: #0a2e14; color: var(--cor-primaria); border-color: var(--cor-primaria); }
.toast.toast-erro { background-color: #2e0a0a; color: var(--cor-erro);     border-color: var(--cor-erro);     }

/* ---------- RODAPÉ ---------- */
.tavern-footer {
  margin-top: 24px;
  padding-top: 16px;
  border-top: 4px solid var(--cor-borda);
  text-align: center;
  font-size: 6px;
  color: var(--cor-texto-dim);
  letter-spacing: 1px;
}

/* ---------- RESPONSIVIDADE MOBILE ---------- */
@media (max-width: 480px) {
  .scroll-container {
    padding: 24px 16px 20px;
    box-shadow: 6px 6px 0 0 #000;
  }

  .tavern-title {
    font-size: 14px;
  }

  .btn-primary {
    font-size: 8px;
    padding: 14px 10px;
  }

  .tab-btn {
    font-size: 7px;
    padding: 10px 6px;
  }
}