/* ============================================================
   KIDS LAST GAME — Estilos específicos dos jogos
   ============================================================ */

/* ---------- Memória ---------- */
.mem-status { text-align: center; font-size: 22px; font-weight: 800; color: var(--verde-d); margin-bottom: 14px; }
.mem-grid {
  display: grid; gap: 12px; max-width: 640px; margin: 0 auto;
  grid-template-columns: repeat(var(--cols), 1fr);
}
.mem-card {
  position: relative; aspect-ratio: 1; border-radius: 18px; perspective: 600px; background: none;
}
.mem-face {
  position: absolute; inset: 0; display: grid; place-items: center;
  border-radius: 18px; font-size: clamp(34px, 9vw, 56px); backface-visibility: hidden;
  transition: transform .4s; box-shadow: var(--sombra);
}
.mem-back { background: linear-gradient(135deg, var(--azul), var(--azul-d)); color: #fff; }
.mem-front { background: #fff; transform: rotateY(180deg); }
.mem-card.open .mem-back { transform: rotateY(180deg); }
.mem-card.open .mem-front { transform: rotateY(360deg); }
.mem-card.done .mem-front { background: #dcfce7; animation: pop-in .4s; }
.mem-card.done { animation: matched .5s; }
@keyframes matched { 0%,100%{transform:scale(1)} 50%{transform:scale(1.08)} }

/* ---------- Colorir ---------- */
.color-gallery { display: grid; gap: 14px; grid-template-columns: repeat(auto-fill, minmax(130px,1fr)); max-width: 800px; margin: 0 auto; }
.color-thumb {
  background: #fff; border-radius: 18px; padding: 16px 8px; box-shadow: var(--sombra);
  display: flex; flex-direction: column; align-items: center; gap: 6px; transition: transform .15s; border: 3px solid var(--ceu1);
}
.color-thumb:hover { transform: translateY(-4px); border-color: var(--rosa); }
.ct-emoji { font-size: 60px; }
.color-thumb span:last-child { font-weight: 700; }

.color-stage { display: flex; flex-direction: column; align-items: center; gap: 14px; }
.color-toolbar, .palette { display: flex; gap: 8px; justify-content: center; flex-wrap: wrap; }
.tool-btn {
  width: 56px; height: 56px; border-radius: 16px; font-size: 26px; background: #fff;
  box-shadow: var(--sombra); display: grid; place-items: center; transition: transform .12s;
}
.tool-btn:hover { transform: translateY(-2px); }
.tool-btn.active { background: var(--azul); }
.tool-save { background: var(--verde); }
.canvas-wrap { background: #fff; border-radius: 20px; padding: 8px; box-shadow: var(--sombra); }
#paint { width: min(640px, 90vw); height: auto; aspect-ratio: 640/520; touch-action: none; border-radius: 14px; display: block; }
.palette { max-width: 640px; }
.swatch { width: 44px; height: 44px; border-radius: 50%; box-shadow: var(--sombra); transition: transform .12s; border: 3px solid #fff; }
.swatch:hover { transform: scale(1.15); }
.swatch.sel { transform: scale(1.2); border-color: var(--tinta); }

/* ---------- 7 Erros ---------- */
.timer-switch { font-weight: 700; font-size: 14px; display: inline-flex; gap: 4px; align-items: center; white-space: nowrap; }
.err-info { display: flex; align-items: center; gap: 14px; justify-content: center; flex-wrap: wrap; margin-bottom: 12px; font-weight: 800; }
.err-fase { color: var(--azul-d); } .err-count { color: var(--verde-d); } .err-time { color: var(--laranja); }
.err-scenes { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; max-width: 900px; margin: 0 auto; }
.err-panel {
  display: grid; grid-template-columns: repeat(var(--cols), 1fr); gap: 4px;
  border-radius: 18px; padding: 8px; box-shadow: var(--sombra);
}
.cena-fazenda  { background: linear-gradient(180deg,#bbf7d0,#fef9c3); }
.cena-selva    { background: linear-gradient(180deg,#bbf7d0,#fde68a); }
.cena-floresta { background: linear-gradient(180deg,#bbf7d0,#86efac); }
.cena-oceano   { background: linear-gradient(180deg,#bae6fd,#a5f3fc); }
.err-cell { aspect-ratio: 1; font-size: clamp(20px, 5vw, 38px); border-radius: 10px; display: grid; place-items: center; transition: transform .1s; }
.err-cell:hover { transform: scale(1.1); background: rgba(255,255,255,.4); }
.err-cell.found { background: rgba(52,211,153,.55); box-shadow: 0 0 0 3px var(--verde-d) inset; }
.err-cell.hint { animation: hint-pulse .6s 2; }
@keyframes hint-pulse { 0%,100%{ box-shadow:0 0 0 0 var(--laranja) inset } 50%{ box-shadow:0 0 0 5px var(--laranja) inset } }

/* ---------- Quebra-cabeça ---------- */
.puz-stage { text-align: center; }
.puz-hint { font-size: 22px; font-weight: 800; color: var(--azul-d); margin-bottom: 14px; }
.puz-grid {
  display: grid; grid-template-columns: repeat(var(--n), 1fr); gap: 3px;
  width: min(480px, 90vw); aspect-ratio: 1; margin: 0 auto;
  background: var(--azul-d); padding: 4px; border-radius: 16px; box-shadow: var(--sombra);
}
.puz-piece { aspect-ratio: 1; border-radius: 6px; background-repeat: no-repeat; transition: transform .1s, box-shadow .15s; }
.puz-piece:hover { transform: scale(.96); }
.puz-piece.sel { box-shadow: 0 0 0 4px var(--amarelo); transform: scale(.92); z-index: 2; }
.puz-grid.solved { animation: matched .6s; }
.puz-grid.solved .puz-piece { box-shadow: none; }

/* ---------- Sons ---------- */
.son-progress { text-align: center; font-weight: 800; color: var(--verde-d); font-size: 18px; margin-bottom: 10px; }
.son-play {
  display: flex; flex-direction: column; align-items: center; gap: 6px; margin: 0 auto 16px;
  background: linear-gradient(135deg, var(--amarelo), var(--laranja)); color: #fff;
  border-radius: 28px; padding: 24px 40px; box-shadow: var(--sombra); font-weight: 800; font-size: 18px;
  animation: pulse 1.6s ease-in-out infinite;
}
.son-play-emoji { font-size: 56px; }
@keyframes pulse { 0%,100%{transform:scale(1)} 50%{transform:scale(1.05)} }
.son-q { text-align: center; font-size: 22px; font-weight: 800; color: var(--azul-d); margin-bottom: 16px; }
.son-options { display: grid; grid-template-columns: repeat(2,1fr); gap: 14px; max-width: 480px; margin: 0 auto; }
.son-opt {
  background: #fff; border-radius: 20px; padding: 16px; box-shadow: var(--sombra);
  display: flex; flex-direction: column; align-items: center; gap: 6px; transition: transform .12s; border: 3px solid transparent;
}
.son-opt:hover { transform: translateY(-3px); }
.son-opt-emoji { font-size: 56px; }
.son-opt-name { font-weight: 800; font-size: 17px; }
.son-opt.correct { border-color: var(--verde-d); background: #dcfce7; animation: matched .5s; }
.son-opt.wrong { animation: shake .4s; }
@keyframes shake { 0%,100%{transform:translateX(0)} 25%{transform:translateX(-8px)} 75%{transform:translateX(8px)} }

/* ---------- Encontre o animal ---------- */
.enc-task { display: flex; align-items: center; justify-content: center; gap: 12px; flex-wrap: wrap; margin-bottom: 12px; }
.enc-progress { font-weight: 800; color: var(--verde-d); }
.enc-find { font-size: clamp(20px,4.5vw,28px); color: var(--azul-d); }
.enc-target { color: var(--laranja); }
.enc-field {
  display: flex; flex-wrap: wrap; gap: 6px; justify-content: center; align-items: center;
  background: linear-gradient(180deg,#bae6fd,#bbf7d0); border-radius: 20px; padding: 16px;
  box-shadow: var(--sombra); min-height: 50vh; max-width: 900px; margin: 0 auto;
}
.enc-animal { font-size: clamp(34px, 8vw, 60px); transition: transform .15s; line-height: 1; }
.enc-animal:hover { transform: scale(1.2) !important; z-index: 2; }
.enc-animal.found { animation: found-pop .6s forwards; }
.enc-animal.shake { animation: shake .4s; }
@keyframes found-pop { 0%{transform:scale(1)} 50%{transform:scale(1.6)} 100%{transform:scale(0)} }

/* ---------- Alfabeto ---------- */
.alf-hint { text-align: center; font-size: 20px; font-weight: 700; color: var(--verde-d); margin-bottom: 16px; }
.alf-grid { display: grid; gap: 10px; grid-template-columns: repeat(auto-fill, minmax(120px,1fr)); max-width: 1000px; margin: 0 auto; }
.alf-card {
  background: #fff; border-radius: 18px; padding: 12px 8px; box-shadow: var(--sombra);
  display: flex; flex-direction: column; align-items: center; gap: 2px; transition: transform .12s; border: 3px solid var(--ceu1);
}
.alf-card:hover { transform: translateY(-4px); border-color: var(--verde); }
.alf-letter { font-size: 38px; font-weight: 900; color: var(--azul-d); }
.alf-emoji { font-size: 44px; }
.alf-name { font-weight: 700; font-size: 14px; }
.alf-card.pop { animation: matched .5s; }

/* ---------- Números ---------- */
.num-progress { text-align: center; font-weight: 800; color: var(--verde-d); margin-bottom: 8px; }
.num-q { text-align: center; font-size: clamp(20px,4.5vw,28px); color: var(--azul-d); margin-bottom: 14px; }
.num-q b { color: var(--laranja); }
.num-scene {
  display: flex; flex-wrap: wrap; gap: 6px; justify-content: center; align-items: center;
  background: linear-gradient(180deg,#fef9c3,#bbf7d0); border-radius: 20px; padding: 18px;
  box-shadow: var(--sombra); max-width: 760px; margin: 0 auto 18px; min-height: 160px;
}
.num-animal { font-size: clamp(40px,9vw,64px); animation: drop-in .4s backwards; }
@keyframes drop-in { 0%{transform:translateY(-30px); opacity:0} 100%{transform:translateY(0); opacity:1} }
.num-options { display: grid; grid-template-columns: repeat(4,1fr); gap: 12px; max-width: 460px; margin: 0 auto; }
.num-opt { background: #fff; border-radius: 18px; padding: 18px 0; font-size: 32px; font-weight: 900; color: var(--azul-d); box-shadow: var(--sombra); transition: transform .12s; border: 3px solid transparent; }
.num-opt:hover { transform: translateY(-3px); }
.num-opt.correct { background: #dcfce7; border-color: var(--verde-d); animation: matched .5s; }
.num-opt.wrong { animation: shake .4s; }

/* ---------- Labirinto ---------- */
.lab-stage { display: flex; flex-direction: column; align-items: center; gap: 18px; }
.lab-grid {
  position: relative; display: grid; grid-template-columns: repeat(var(--n), 1fr);
  width: min(460px, 88vw); aspect-ratio: 1; background: #fef3c7;
  border: 4px solid var(--verde-d); border-radius: 12px; touch-action: none;
}
.lab-cell { position: relative; }
.lab-cell.wn { border-top: 4px solid var(--verde-d); }
.lab-cell.ws { border-bottom: 4px solid var(--verde-d); }
.lab-cell.ww { border-left: 4px solid var(--verde-d); }
.lab-cell.we { border-right: 4px solid var(--verde-d); }
.lab-goal { position: absolute; inset: 0; display: grid; place-items: center; font-size: 70%; }
.lab-cell { font-size: min(7vw, 36px); }
.lab-hero {
  position: absolute; width: calc(100% / var(--n)); height: calc(100% / var(--n));
  display: grid; place-items: center; font-size: min(6vw, 30px);
  transition: left .15s, top .15s; z-index: 3;
}
.lab-hero.arrived { animation: matched .6s; }
.dpad {
  display: grid; grid-template-columns: repeat(3, 64px); grid-template-rows: repeat(2, 64px);
  gap: 8px; justify-content: center;
}
.dbtn { background: #fff; border-radius: 16px; font-size: 30px; box-shadow: var(--sombra); display: grid; place-items: center; transition: transform .1s; }
.dbtn:active { transform: scale(.92); background: var(--azul); }
.dbtn.up { grid-column: 2; grid-row: 1; }
.dbtn.left { grid-column: 1; grid-row: 2; }
.dbtn.down { grid-column: 2; grid-row: 2; }
.dbtn.right { grid-column: 3; grid-row: 2; }

/* ---------- Balões ---------- */
.bal-hud { text-align: center; font-size: 24px; font-weight: 900; color: var(--azul-d); margin-bottom: 10px; }
.bal-field {
  position: relative; overflow: hidden; height: 64vh; max-width: 760px; margin: 0 auto;
  background: linear-gradient(180deg, #e0f2fe, #bae6fd); border-radius: 20px; box-shadow: var(--sombra);
}
.balloon {
  position: absolute; bottom: 0; width: 66px; height: 82px; will-change: transform;
}
.balloon-face {
  display: grid; place-items: center; width: 66px; height: 80px;
  background: radial-gradient(circle at 32% 28%, #fff7, var(--bc) 70%);
  border-radius: 50% 50% 48% 48%; box-shadow: var(--sombra);
  font-size: 28px; font-weight: 900; color: #fff;
}
.balloon-knot { position: absolute; left: 50%; bottom: -6px; width: 8px; height: 8px; transform: translateX(-50%) rotate(45deg); background: var(--bc); }
.balloon.popped { animation: balloon-pop .2s forwards; }
@keyframes balloon-pop { to { transform: scale(1.6); opacity: 0; } }

@media (max-width: 600px) {
  .num-options { grid-template-columns: repeat(2,1fr); }
}
