/* games-rps.css — comic-styled Rock-Paper-Scissors with chunky pill buttons
 * and a shake-then-reveal animation. Hand emojis are oversized inside a
 * frosted circle so the throw is the visual hero of the screen.
 */
.rps-stage { max-width: 720px; margin: 0 auto; padding: 22px; }

.rps-tally {
  display: flex;
  gap: 10px;
  align-items: center;
  font-family: 'Bangers', cursive;
  font-size: 1.25em;
  letter-spacing: 0.04em;
}
.rps-tally-you { color: var(--gm-accent-1); }
.rps-tally-ai  { color: var(--gm-accent-2); }
.rps-tally-d   { color: var(--gm-muted); }

.rps-arena {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 20px;
  align-items: center;
  justify-items: center;
  margin: 28px 0 20px;
}
.rps-hand-stage { display: flex; flex-direction: column; align-items: center; gap: 8px; }

.rps-hand {
  width: clamp(110px, 22vw, 180px);
  aspect-ratio: 1;
  border-radius: 50%;
  background:
    radial-gradient(circle at 30% 25%, rgba(255, 255, 255, 0.18), transparent 55%),
    var(--gm-bg-alt);
  border: 3px solid var(--gm-border);
  display: grid;
  place-items: center;
  font-size: clamp(60px, 12vw, 100px);
  box-shadow: 0 16px 28px -16px rgba(0, 0, 0, 0.6);
  transform-origin: 50% 100%;
}
.rps-hand-you { border-color: var(--gm-accent-1); }
.rps-hand-ai  { border-color: var(--gm-accent-2); }

.rps-hand.is-shaking { animation: rps-shake 0.7s cubic-bezier(0.4, 0, 0.2, 1) 3; }
@keyframes rps-shake {
  0%, 100% { transform: translateY(0)   rotate(0); }
  25%      { transform: translateY(-12px) rotate(-8deg); }
  50%      { transform: translateY(0)   rotate(0); }
  75%      { transform: translateY(-12px) rotate(8deg); }
}
.rps-hand.is-throw { animation: rps-throw 0.32s ease-out forwards; }
@keyframes rps-throw {
  0%   { transform: scale(0.85) translateY(0); }
  60%  { transform: scale(1.18) translateY(-6px); }
  100% { transform: scale(1) translateY(0); }
}
.rps-hand.is-win  { border-color: var(--gm-success); box-shadow: 0 0 0 4px rgba(107, 255, 142, 0.25), 0 16px 28px -16px rgba(107, 255, 142, 0.7); }
.rps-hand.is-lose { border-color: var(--gm-error);   box-shadow: 0 0 0 4px rgba(255, 85, 119, 0.25);   filter: brightness(0.7); }

.rps-label {
  font-family: 'Bangers', cursive;
  letter-spacing: 0.06em;
  font-size: 1.2em;
  color: var(--gm-muted);
}
.rps-hand-stage[data-side="you"] .rps-label { color: var(--gm-accent-1); }
.rps-hand-stage[data-side="ai"]  .rps-label { color: var(--gm-accent-2); }

.rps-divider {
  font-family: 'Bangers', cursive;
  font-size: clamp(28px, 6vw, 44px);
  color: var(--gm-text);
  letter-spacing: 0.06em;
  text-shadow: 0 0 14px rgba(255, 121, 242, 0.55);
}

.rps-result {
  min-height: 40px;
  text-align: center;
  font-family: 'Bangers', cursive;
  font-size: 1.4em;
  letter-spacing: 0.06em;
  color: var(--gm-text);
  margin: 8px 0 22px;
}
.rps-result[data-result="win"]  { color: var(--gm-success); }
.rps-result[data-result="lose"] { color: var(--gm-error); }
.rps-result[data-result="draw"] { color: var(--gm-warn); }

.rps-choices {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  max-width: 540px;
  margin: 0 auto;
}
.rps-choice {
  background: var(--gm-bg);
  border: 2px solid var(--gm-border);
  border-radius: 14px;
  color: var(--gm-text);
  font-family: 'Bangers', cursive;
  letter-spacing: 0.06em;
  font-size: 1.1em;
  padding: 14px 8px 18px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  cursor: pointer;
  transition: transform 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease;
}
.rps-choice .rps-emoji { font-size: clamp(34px, 6vw, 52px); }
.rps-choice:hover {
  transform: translateY(-3px);
  border-color: var(--gm-accent-1);
  box-shadow: 0 12px 24px -10px rgba(107, 247, 255, 0.45);
}
.rps-choice:active { transform: translateY(0); }
.rps-choice:disabled { opacity: 0.5; cursor: not-allowed; }
.rps-choice.is-picked { border-color: var(--gm-accent-1); box-shadow: 0 0 0 3px rgba(107, 247, 255, 0.35); }

.rps-banner {
  margin-top: 18px;
  padding: 18px 22px;
  background: linear-gradient(135deg, rgba(107, 247, 255, 0.18), rgba(255, 121, 242, 0.18));
  border: 1px solid var(--gm-border);
  border-radius: 14px;
  text-align: center;
  font-family: 'Bangers', cursive;
  font-size: 1.6em;
  letter-spacing: 0.05em;
}
.rps-banner[data-result="win"]  { color: var(--gm-success); }
.rps-banner[data-result="lose"] { color: var(--gm-error); }
