/* ============================================================
   MUNDO DO PEDRO — tema "arcade rubro-negro"
   Estádio à noite + fliperama: fundo quase preto, vermelho
   Flamengo vibrante, brilhos neon e detalhes pixelados.
   ============================================================ */

@font-face {
  font-family: Bungee;
  src: url('/core/fonts/bungee.woff2') format('woff2');
  font-display: swap;
}

@font-face {
  font-family: 'Chakra Petch';
  src: url('/core/fonts/chakra-petch-400.woff2') format('woff2');
  font-weight: 400;
  font-display: swap;
}

@font-face {
  font-family: 'Chakra Petch';
  src: url('/core/fonts/chakra-petch-700.woff2') format('woff2');
  font-weight: 700;
  font-display: swap;
}

@font-face {
  font-family: 'Press Start 2P';
  src: url('/core/fonts/press-start-2p.woff2') format('woff2');
  font-display: swap;
}

:root {
  --vermelho: #e3262e;
  --vermelho-vivo: #ff3b44;
  --vermelho-escuro: #8e1318;
  --fundo: #0a0a0e;
  --cartao: #15151d;
  --cartao2: #1d1d28;
  --borda: #2c2c3a;
  --texto: #f2ede4;
  --titulo: #fff;
  --destaque: #ffd166;
  --ativo: rgb(227 38 46 / 18%);
  --veu: rgb(8 8 12 / 82%);
  --botao: var(--vermelho);
  --botao-sombra: var(--vermelho-escuro);
  --raio: 16px;
  --raio-botao: 12px;
  --fonte-titulo: Bungee, 'Chakra Petch', sans-serif;
  --fonte-corpo: 'Chakra Petch', system-ui, sans-serif;
  --fonte-placar: 'Press Start 2P', monospace;
}

body {
  background:
    radial-gradient(1200px 500px at 50% -150px, rgb(227 38 46 / 22%), transparent 70%),
    radial-gradient(800px 400px at 85% 110%, rgb(227 38 46 / 10%), transparent 70%),
    var(--fundo);
  background-attachment: fixed;
}

/* Scanlines de fliperama por cima de tudo, bem sutis */
body::after {
  content: '';
  position: fixed; inset: 0; z-index: 9998; pointer-events: none;
  background: repeating-linear-gradient(0deg, rgb(0 0 0 / 14%) 0 1px, transparent 1px 3px);
  mix-blend-mode: multiply;
}

/* ---------- Topo das páginas internas ---------- */
.jogo-topo { padding-top: 6px; }

/* ---------- Home ---------- */
.home {
  max-width: 1060px; margin: 0 auto;
  padding: 0 16px 40px;
}

.home-topo {
  display: flex; justify-content: space-between; align-items: center;
  padding: 14px 0 0;
}

.home-topo .marca {
  font-family: var(--fonte-placar);
  font-size: 0.7rem; color: var(--destaque);
  letter-spacing: 0.08em;
}

.heroi {
  position: relative;
  text-align: center;
  padding: clamp(28px, 6vw, 64px) 12px clamp(22px, 4vw, 44px);
}

.heroi-escudo { font-size: clamp(2.4rem, 8vw, 4rem); animation: balanca 3s ease-in-out infinite; }

@keyframes balanca {
  0%, 100% { transform: rotate(-6deg); }
  50% { transform: rotate(6deg); }
}

.heroi h1 {
  margin: 6px 0 4px;
  font-family: var(--fonte-titulo);
  font-size: clamp(2.2rem, 9vw, 5rem);
  line-height: 0.95;
  color: var(--titulo);
  text-shadow:
    3px 3px 0 var(--vermelho),
    6px 6px 0 rgb(227 38 46 / 35%),
    0 0 38px rgb(227 38 46 / 55%);
  animation: entra-titulo 0.7s cubic-bezier(0.34, 1.56, 0.64, 1) both;
}

.heroi .sub {
  font-size: clamp(0.95rem, 3vw, 1.15rem);
  opacity: 0.85; margin: 10px auto 0; max-width: 560px;
  animation: entra-titulo 0.7s 0.15s cubic-bezier(0.34, 1.56, 0.64, 1) both;
}

@keyframes entra-titulo {
  from { transform: translateY(26px); opacity: 0; }
  to { transform: none; opacity: 1; }
}

/* Listras diagonais rubro-negras atrás do herói */
.heroi::before {
  content: '';
  position: absolute; inset: 10% 0 12%; z-index: -1;
  background: repeating-linear-gradient(125deg,
    rgb(227 38 46 / 14%) 0 26px,
    transparent 26px 52px,
    rgb(255 255 255 / 3%) 52px 78px,
    transparent 78px 104px);
  mask-image: radial-gradient(70% 80% at 50% 50%, #000 30%, transparent 100%);
}

/* Letreiro que corre (grito de torcida) */
.letreiro {
  overflow: hidden; white-space: nowrap;
  border-block: 2px solid var(--borda);
  background: rgb(227 38 46 / 7%);
  font-family: var(--fonte-placar);
  font-size: 0.65rem; line-height: 2.6;
  color: var(--vermelho-vivo);
  margin: 4px -16px 26px;
}

.letreiro span {
  display: inline-block;
  animation: correr 22s linear infinite;
}

@keyframes correr {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}

/* Grade de jogos */
.secao-titulo {
  font-family: var(--fonte-titulo);
  font-size: clamp(1.1rem, 4vw, 1.5rem);
  margin: 30px 0 14px;
  display: flex; align-items: center; gap: 10px;
}

.secao-titulo::after {
  content: ''; flex: 1; height: 3px;
  background: repeating-linear-gradient(90deg, var(--vermelho) 0 14px, transparent 14px 22px);
  opacity: 0.5;
}

.grade-jogos {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(230px, 1fr));
  gap: 16px;
}

.cartao-jogo {
  position: relative;
  display: flex; flex-direction: column; gap: 8px;
  background: linear-gradient(160deg, var(--cartao2), var(--cartao));
  border: 2px solid var(--borda);
  border-radius: var(--raio);
  padding: 18px 16px 16px;
  text-decoration: none;
  overflow: hidden;
  transition: transform 0.18s, border-color 0.18s, box-shadow 0.18s;
  animation: entra-titulo 0.5s both;
}

.grade-jogos .cartao-jogo:nth-child(2) { animation-delay: 0.06s; }
.grade-jogos .cartao-jogo:nth-child(3) { animation-delay: 0.12s; }
.grade-jogos .cartao-jogo:nth-child(4) { animation-delay: 0.18s; }
.grade-jogos .cartao-jogo:nth-child(5) { animation-delay: 0.24s; }
.grade-jogos .cartao-jogo:nth-child(6) { animation-delay: 0.3s; }

.cartao-jogo::before {
  content: '';
  position: absolute; inset: 0 0 auto;
  height: 4px;
  background: linear-gradient(90deg, var(--vermelho), transparent);
}

.cartao-jogo:hover, .cartao-jogo:focus-visible {
  transform: translateY(-5px) rotate(-0.5deg);
  border-color: var(--vermelho);
  box-shadow: 0 10px 34px rgb(227 38 46 / 28%);
}

.cartao-jogo .icone {
  font-size: 2.6rem; line-height: 1;
  filter: drop-shadow(0 4px 10px rgb(227 38 46 / 40%));
}

.cartao-jogo h3 {
  margin: 0; font-family: var(--fonte-titulo);
  font-size: 1.05rem; color: var(--titulo); letter-spacing: 0.02em;
}

.cartao-jogo p { margin: 0; font-size: 0.85rem; opacity: 0.8; flex: 1; }

.cartao-jogo .etiquetas { display: flex; gap: 6px; flex-wrap: wrap; }

.etiqueta {
  font-size: 0.62rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.08em;
  background: rgb(227 38 46 / 16%); color: var(--vermelho-vivo);
  border: 1px solid rgb(227 38 46 / 40%);
  padding: 3px 8px; border-radius: 99px;
}

.etiqueta.dourada { background: rgb(255 209 102 / 12%); color: var(--destaque); border-color: rgb(255 209 102 / 45%); }

.cartao-jogo .jogar {
  align-self: flex-start;
  font-family: var(--fonte-titulo); font-size: 0.8rem;
  color: var(--destaque);
}

.cartao-jogo:hover .jogar::after { content: ' ▶'; }

/* Recordes na home */
.faixa-recordes {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 10px; margin-top: 8px;
}

.recorde {
  background: var(--cartao); border: 2px solid var(--borda);
  border-radius: 12px; padding: 12px 14px;
  font-family: var(--fonte-placar); font-size: 0.6rem; line-height: 1.9;
}

.recorde b { color: var(--destaque); font-size: 0.85rem; display: block; }

.rodape {
  margin-top: 48px; text-align: center;
  font-size: 0.8rem; opacity: 0.6; line-height: 1.8;
}

/* ---------- Páginas de conteúdo (favoritos/oficina) ---------- */
.pagina {
  max-width: 860px; margin: 0 auto;
  padding: 10px 16px 60px;
}

.pagina-topo { display: flex; align-items: center; gap: 10px; padding: 8px 0 18px; }

.pagina-topo h1 {
  flex: 1; margin: 0; text-align: center;
  font-family: var(--fonte-titulo);
  font-size: clamp(1.2rem, 5vw, 1.9rem);
}

.caixa {
  background: var(--cartao); border: 2px solid var(--borda);
  border-radius: var(--raio); padding: clamp(14px, 3vw, 22px);
  margin-bottom: 18px;
}

.caixa h2 { margin: 0 0 12px; font-family: var(--fonte-titulo); font-size: 1.05rem; }

.campo { display: flex; flex-direction: column; gap: 4px; margin-bottom: 12px; text-align: left; }

.campo span { font-size: 0.8rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; opacity: 0.75; }

.campo input, .campo select, .campo textarea {
  font: inherit; color: inherit;
  background: var(--cartao2);
  border: 2px solid var(--borda); border-radius: 10px;
  padding: 11px 12px; min-height: 44px;
}

.campo textarea { min-height: 120px; font-family: monospace; font-size: 0.8rem; }

.campo input:focus, .campo select:focus, .campo textarea:focus { border-color: var(--vermelho); outline: none; }

.escolha-emoji { display: flex; flex-wrap: wrap; gap: 6px; }

.escolha-emoji button {
  font-size: 1.3rem; min-width: 46px; min-height: 46px;
  background: var(--cartao2); border: 2px solid var(--borda); border-radius: 10px;
}

.escolha-emoji button.ativo { border-color: var(--destaque); background: var(--ativo); }

.fileira-categorias { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 16px; }

.ficha-categoria {
  border: 2px solid var(--borda); background: var(--cartao);
  color: inherit; border-radius: 99px; padding: 8px 14px; font-size: 0.85rem; font-weight: 700;
}

.ficha-categoria.ativa { border-color: var(--vermelho); background: var(--ativo); color: var(--vermelho-vivo); }

.grade-favoritos { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 12px; }

.cartao-favorito {
  position: relative;
  background: var(--cartao); border: 2px solid var(--borda); border-radius: 14px;
  padding: 14px; display: flex; gap: 12px; align-items: flex-start;
  animation: entra-titulo 0.35s both;
}

.cartao-favorito .emoji { font-size: 1.9rem; line-height: 1.1; }

.cartao-favorito h3 { margin: 0; font-size: 1rem; }

.cartao-favorito p { margin: 2px 0 0; font-size: 0.82rem; opacity: 0.75; }

.cartao-favorito .categoria { font-size: 0.65rem; text-transform: uppercase; letter-spacing: 0.08em; color: var(--vermelho-vivo); font-weight: 700; }

.cartao-favorito .apagar {
  position: absolute; top: 8px; right: 8px;
  background: none; border: 0; color: inherit; opacity: 0.4;
  font-size: 0.95rem; min-width: 34px; min-height: 34px; border-radius: 8px;
}

.cartao-favorito .apagar:hover { opacity: 1; background: rgb(227 38 46 / 18%); }

.vazio {
  text-align: center; opacity: 0.7; padding: 30px 10px; font-size: 0.95rem;
  border: 2px dashed var(--borda); border-radius: var(--raio);
}

.aviso {
  background: rgb(255 209 102 / 8%); border: 2px solid rgb(255 209 102 / 30%);
  border-radius: 12px; padding: 12px 14px; font-size: 0.85rem; margin-bottom: 16px;
}

.aviso code, .bloco-prompt {
  display: block; white-space: pre-wrap;
  background: #0d0d12; border: 1px solid var(--borda); border-radius: 8px;
  padding: 10px; font-size: 0.75rem; margin-top: 8px;
}

.toast {
  position: fixed; left: 50%; bottom: 24px; transform: translateX(-50%);
  background: var(--cartao2); color: var(--texto);
  border: 2px solid var(--destaque); border-radius: 12px;
  padding: 12px 18px; font-weight: 700; z-index: 10000;
  animation: entra-titulo 0.3s both;
  max-width: min(420px, 90vw); text-align: center;
}

.toast.erro { border-color: var(--vermelho); }

/* Lista de jogos da oficina */
.lista-oficina { display: flex; flex-direction: column; gap: 10px; }

.item-oficina {
  display: flex; align-items: center; gap: 12px;
  background: var(--cartao); border: 2px solid var(--borda); border-radius: 12px;
  padding: 12px 14px;
}

.item-oficina .nome { flex: 1; min-width: 0; }

.item-oficina h3 { margin: 0; font-size: 1rem; overflow: hidden; text-overflow: ellipsis; }

.item-oficina small { opacity: 0.6; }

.item-oficina .botao { width: auto; margin: 0; padding: 10px 16px; font-size: 0.85rem; }

.item-oficina .apagar-jogo {
  background: none; border: 2px solid var(--borda); border-radius: 10px;
  color: inherit; min-width: 42px; min-height: 42px;
}
