#gameScreen {
  height: 100%;
  min-height: 0;
  grid-template-rows: minmax(0, 1fr) auto;
  gap: 12px;
}

.game-layout {
  display: grid;
  grid-template-columns: 340px minmax(0, 1fr);
  gap: 14px;
  min-height: 0;
}

.sidebar-panel {
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr) auto;
  min-height: 0;
}

.info-card {
  margin: 12px 0;
  padding: 14px;
  border-radius: 20px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.07), rgba(255, 255, 255, 0.02));
  border: 3px solid rgba(0, 0, 0, 0.28);
}

.info-label {
  display: block;
  color: var(--text-dim);
  margin-bottom: 8px;
  font-weight: 800;
}

.papayoo-badge {
  min-height: 58px;
  border-radius: 18px;
  display: grid;
  place-items: center;
  font-family: var(--font-display);
  font-size: 1.35rem;
  color: #1f221f;
  border: 4px solid var(--line-dark);
  background: linear-gradient(180deg, #ffe66a, #ffd21a);
  box-shadow: var(--shadow-hard);
}

.table-panel {
  min-height: 0;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
}

.table-head {
  margin-bottom: 12px;
}

.game-table {
  position: relative;
  min-height: 0;
  height: 100%;
  border-radius: 38px;
  border: 5px solid rgba(20, 28, 20, 0.72);
  background:
    radial-gradient(circle at 50% 46%, rgba(255, 255, 255, 0.18), transparent 24%),
    radial-gradient(circle at 50% 50%, rgba(255, 255, 255, 0.08), transparent 40%),
    linear-gradient(180deg, #31c38a, #1ca76c 46%, #148458);
  box-shadow:
    inset 0 0 0 8px rgba(255, 255, 255, 0.14),
    inset 0 -18px 36px rgba(0, 0, 0, 0.16),
    var(--shadow-soft);
  overflow: hidden;
}

.game-table::before {
  content: "";
  position: absolute;
  inset: 18px;
  border-radius: 28px;
  border: 3px dashed rgba(255, 255, 255, 0.22);
  pointer-events: none;
}

.player-seats {
  position: absolute;
  inset: 0;
}

.player-seat {
  position: absolute;
  min-width: 132px;
  max-width: 200px;
  padding: 10px 12px;
  border-radius: 24px;
  background: linear-gradient(180deg, rgba(49, 56, 49, 0.96), rgba(35, 41, 35, 0.96));
  border: 4px solid var(--line-dark);
  box-shadow: var(--shadow-hard);
  text-align: center;
  z-index: 5;
  overflow: visible;
}

.player-seat .seat-name,
.player-seat .seat-meta {
  position: relative;
  z-index: 1;
}

.player-seat.has-played .seat-name,
.player-seat.has-played .seat-meta {
  opacity: 0.18;
}

.seat-played-card {
  position: absolute;
  left: 50%;
  top: 50%;
  width: clamp(66px, 6.7vw, 96px);
  transform: translate(-50%, -50%);
  z-index: 10;
  pointer-events: none;
  filter: drop-shadow(0 10px 10px rgba(0, 0, 0, 0.26));
}

.trick-center {
  display: none;
}

.trick-card {
  position: absolute;
  width: clamp(66px, 6.7vw, 96px);
  transition: transform 180ms ease, left 180ms ease, top 180ms ease;
  filter: drop-shadow(0 10px 10px rgba(0, 0, 0, 0.26));
}

.hand-panel {
  margin-top: 0;
  min-height: 0;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  overflow: visible;
}

.hand-cards {
  display: flex;
  gap: 8px;
  flex-wrap: nowrap;
  align-items: flex-end;
  margin-top: 14px;
  padding-top: 14px;
  min-height: 0;
  overflow-x: hidden;
  overflow-y: visible;
}

.scoreboard {
  margin-top: 12px;
  padding: 14px;
  min-height: 0;
  overflow: hidden;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
}

#scoreboardList {
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
  padding-right: 6px;
  scrollbar-width: thin;
  scrollbar-color: rgba(255, 255, 255, 0.35) rgba(0, 0, 0, 0.15);
}

#scoreboardList::-webkit-scrollbar {
  width: 8px;
}

#scoreboardList::-webkit-scrollbar-track {
  background: rgba(0, 0, 0, 0.14);
  border-radius: 999px;
}

#scoreboardList::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.28);
  border-radius: 999px;
}

#scoreboardList::-webkit-scrollbar-thumb:hover {
  background: rgba(255, 255, 255, 0.4);
}

.score-row {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 8px;
  align-items: center;
  padding: 8px 0;
  border-bottom: 2px solid rgba(255, 255, 255, 0.08);
  font-variant-numeric: tabular-nums lining-nums;
}

.score-row:last-child {
  border-bottom: none;
}

.score-name {
  font-weight: 800;
  font-size: 0.92rem;
}

.score-pill {
  min-width: 58px;
  text-align: center;
  padding: 5px 8px;
  border-radius: 999px;
  border: 3px solid var(--line-dark);
  background: linear-gradient(180deg, #fffef8, #f3e8d0);
  color: #1f221f;
  font-weight: 800;
  font-size: 0.82rem;
}

.table-message {
  position: fixed;
  left: 50%;
  top: 8%;
  transform: translateX(-50%);
  z-index: 30;
  min-width: min(72vw, 420px);
  max-width: min(86vw, 560px);
  padding: 12px 18px;
  border-radius: 22px;
  border: 4px solid var(--line-dark);
  background:
    radial-gradient(circle at 30% 28%, rgba(255, 255, 255, 0.28), transparent 22%),
    radial-gradient(circle at 72% 72%, rgba(255, 255, 255, 0.14), transparent 28%),
    linear-gradient(180deg, #ffe66a, #ffd21a 62%, #f0b900);
  color: #1f221f;
  text-align: center;
  box-shadow:
    0 16px 28px rgba(0, 0, 0, 0.22),
    0 8px 0 rgba(0, 0, 0, 0.24);
  font-family: var(--font-display);
  font-size: clamp(0.98rem, 1.5vw, 1.18rem);
  font-weight: 700;
  letter-spacing: 0.01em;
  animation: popBanner 220ms ease;
}

.table-message::before {
  content: "";
  position: absolute;
  inset: 5px;
  border-radius: 16px;
  border: 3px solid rgba(255, 255, 255, 0.92);
  pointer-events: none;
}

.table-message.info {
  background:
    radial-gradient(circle at 30% 28%, rgba(255, 255, 255, 0.28), transparent 22%),
    radial-gradient(circle at 72% 72%, rgba(255, 255, 255, 0.14), transparent 28%),
    linear-gradient(180deg, #ffe66a, #ffd21a 62%, #f0b900);
  color: #1f221f;
  box-shadow:
    0 18px 40px rgba(0, 0, 0, 0.28),
    0 0 0 6px rgba(255, 210, 26, 0.16);
}

.table-message.error {
  background:
    radial-gradient(circle at 30% 28%, rgba(255, 255, 255, 0.20), transparent 22%),
    radial-gradient(circle at 72% 72%, rgba(255, 255, 255, 0.10), transparent 28%),
    linear-gradient(180deg, #ff8b7f, #ef4036 70%, #cf2e24);
  color: #fffdfb;
  box-shadow:
    0 18px 40px rgba(0, 0, 0, 0.28),
    0 0 0 6px rgba(239, 64, 54, 0.16);
}

@keyframes popBanner {
  from {
    opacity: 0;
    transform: translateX(-50%) scale(0.92);
  }

  to {
    opacity: 1;
    transform: translateX(-50%) scale(1);
  }
}

.player-seat[data-relative-index="0"] .seat-played-card {
  transform: translate(-50%, -112%) rotate(-2deg);
}

.player-seat[data-relative-index="1"] .seat-played-card {
  transform: translate(18%, -50%) rotate(-8deg);
}

.player-seat[data-relative-index="2"] .seat-played-card {
  transform: translate(-50%, 20%) rotate(0deg);
}

.player-seat[data-relative-index="3"] .seat-played-card {
  transform: translate(-118%, -50%) rotate(8deg);
}

.seat-played-card.is-winning-card {
  box-shadow:
    0 18px 30px rgba(0, 0, 0, 0.30),
    0 0 0 5px rgba(255, 210, 26, 0.72);
}

.trick-flying {
  transition:
    transform 520ms cubic-bezier(0.22, 1, 0.36, 1),
    filter 520ms ease;
  transform:
    translate(-50%, -50%) translate(var(--fly-x), var(--fly-y)) rotate(var(--fly-rot, 0deg)) scale(0.72) !important;
  opacity: 1;
  filter: none;
}