/* Shared card-game layout and Spanish-card rendering */

:root {
  --felt: #1a6b35;
  --felt-dark: #124d27;
  --felt-edge: #0d3a1c;
  --card-w: 91px;
  --card-h: 133px;
  --card-w-sm: 91px;
  --card-h-sm: 133px;
}

.status-bar {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  background: rgba(0,0,0,0.62);
  backdrop-filter: blur(4px);
  padding: 4px 16px;
  font-size: 0.74rem;
  color: #80b080;
  text-align: center;
  z-index: 20;
}

.game-layout {
  display: grid;
  grid-template-areas:
    "top-player top-player top-player"
    "left-player table right-player"
    "bottom-hand bottom-hand bottom-hand";
  grid-template-rows: 70px 1fr 175px;
  grid-template-columns: 112px 1fr 112px;
  width: 100%;
  height: 100%;
  gap: 4px;
  padding: 30px 8px 8px;
}

.player-area {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
}
.player-area.top { grid-area: top-player; flex-direction: row; justify-content: center; gap: 16px; }
.player-area.left { grid-area: left-player; }
.player-area.right { grid-area: right-player; }

.player-badge {
  background: rgba(0,0,0,0.38);
  border: 2px solid rgba(255,255,255,0.12);
  border-radius: 10px;
  padding: 6px 12px;
  text-align: center;
  min-width: 86px;
  transition: border-color 0.25s, box-shadow 0.25s;
}
.player-badge.active-turn {
  border-color: #f0c040;
  box-shadow: 0 0 14px rgba(240,192,64,0.55);
}
.player-badge .p-name {
  font-size: 0.76rem;
  font-weight: 700;
  color: #c8e8c8;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 80px;
}
.player-badge .p-cards { font-size: 0.68rem; color: #78a878; }
.player-badge.active-turn .p-name { color: #f0c040; }

.mini-hand {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 2px;
  max-width: 100px;
}
.mini-card {
  width: 13px;
  height: 18px;
  background: #fff;
  border-radius: 2px;
  border: 1px solid #ccc;
}

.table-area {
  grid-area: table;
  background: var(--felt-dark);
  border-radius: 20px;
  border: 3px solid var(--felt-edge);
  box-shadow: inset 0 0 40px rgba(0,0,0,0.38);
  padding: 10px 12px;
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: flex-start;
  gap: 18px;
  overflow: visible;
}

.card-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: fill;
  display: block;
  pointer-events: none;
}

.card-corner-tl,
.card-fig-lbl-tl {
  position: absolute;
  top: 5%;
  left: 7%;
  font-size: 0.9rem;
  font-weight: 900;
  color: #fff;
  line-height: 1;
  text-shadow: 0 1px 4px rgba(0,0,0,0.9);
  pointer-events: none;
}

.card-corner-br,
.card-fig-lbl-br {
  position: absolute;
  bottom: 5%;
  right: 7%;
  font-size: 0.9rem;
  font-weight: 900;
  color: #fff;
  line-height: 1;
  text-shadow: 0 1px 4px rgba(0,0,0,0.9);
  transform: rotate(180deg);
  pointer-events: none;
}

.card-single-ico {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 50%;
  height: auto;
  pointer-events: none;
}

.card-figure {
  position: absolute;
  inset: 9%;
  width: 82%;
  height: 82%;
  object-fit: contain;
  pointer-events: none;
}

.bottom-area {
  grid-area: bottom-hand;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding: 0 8px;
}

.bottom-info {
  display: flex;
  align-items: center;
  gap: 12px;
  height: 26px;
}

.my-name-badge {
  font-size: 0.82rem;
  font-weight: 700;
  color: #c8e8c8;
  background: rgba(0,0,0,0.32);
  border: 1.5px solid rgba(255,255,255,0.18);
  border-radius: 6px;
  padding: 3px 12px;
}
.my-name-badge.active-turn {
  border-color: #f0c040;
  color: #f0c040;
  box-shadow: 0 0 10px rgba(240,192,64,0.45);
}

.turn-indicator {
  font-size: 0.72rem;
  color: #f0c040;
  font-weight: 700;
  letter-spacing: 1px;
  animation: pulse 1s infinite;
}

.countdown-display {
  font-size: 0.88rem;
  font-weight: 900;
  letter-spacing: 1px;
  padding: 3px 12px;
  border-radius: 6px;
  background: rgba(0,0,0,0.45);
  border: 2px solid #f0c040;
  color: #f0c040;
  min-width: 52px;
  text-align: center;
  transition: color 0.4s, border-color 0.4s;
}
.countdown-display.low { color: #ff8040; border-color: #ff8040; }
.countdown-display.crit { color: #ff3030; border-color: #ff3030; }

.player-timer {
  font-size: 0.68rem;
  font-weight: 900;
  letter-spacing: 1px;
  color: #f0c040;
  margin-top: 3px;
  transition: color 0.4s;
}
.player-timer.low { color: #ff8040; }
.player-timer.crit { color: #ff3030; }

.hand-container {
  display: flex;
  gap: 4px;
  align-items: flex-end;
  justify-content: center;
  overflow-x: auto;
  max-width: 100%;
  padding: 20px 24px 8px 24px;
  scrollbar-width: thin;
  scrollbar-color: #2a5430 #0a1a0f;
}

.hand-card {
  width: var(--card-w);
  height: var(--card-h);
  background: #fff;
  border-radius: 7px;
  border: 2px solid #bbb;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  flex-shrink: 0;
  font-weight: 700;
  box-shadow: 2px 2px 8px rgba(0,0,0,0.5);
  transition: transform 0.14s, box-shadow 0.14s, border-color 0.14s;
  user-select: none;
  position: relative;
  overflow: hidden;
}
.hand-card:hover { transform: translateY(-10px); box-shadow: 2px 12px 16px rgba(0,0,0,0.6); }

.hand-card.hand-dragging {
  opacity: 0.45;
}

.hand-card.hand-drag-over {
  border-color: #f0c040;
  transform: translateY(-12px) scale(1.03);
}

.hand-card.Oros { color: #b07800; }
.hand-card.Copas { color: #c00020; }
.hand-card.Espadas { color: #102040; }
.hand-card.Bastos { color: #104010; }

.hand-card.not-my-turn { cursor: default; opacity: 0.82; }
.hand-card.not-my-turn:hover { transform: none; box-shadow: 2px 2px 8px rgba(0,0,0,0.5); }

.hand-card .hcv { font-size: 1rem; line-height: 1; }
.hand-card .hcs { font-size: 0.7rem; opacity: 0.72; margin-top: 2px; }
.hand-card .corner-tl,
.hand-card .corner-br {
  position: absolute;
  font-size: 0.58rem;
  font-weight: 700;
  line-height: 1;
}
.hand-card .corner-tl { top: 3px; left: 4px; }
.hand-card .corner-br { bottom: 3px; right: 4px; transform: rotate(180deg); }

@keyframes urgent-glow {
  0%, 100% {
    border-color: #f0c040;
    box-shadow: 0 0 8px rgba(240,192,64,0.4), 2px 2px 8px rgba(0,0,0,0.5);
  }
  50% {
    border-color: #fff8a0;
    box-shadow: 0 0 28px rgba(240,192,64,1), 0 0 50px rgba(240,192,64,0.35), 2px 2px 8px rgba(0,0,0,0.5);
  }
}

@media (max-width: 680px) {
  :root {
    --card-w: 58px;
    --card-h: 84px;
    --card-w-sm: 58px;
    --card-h-sm: 84px;
  }
  .game-layout { grid-template-rows: 60px 1fr 125px; }
  .hand-container {
    padding: 16px 4px 6px 4px;
    justify-content: flex-start;
  }
}

@media (max-width: 480px) {
  :root {
    --card-w: 42px;
    --card-h: 60px;
    --card-w-sm: 42px;
    --card-h-sm: 60px;
  }
  .game-layout {
    grid-template-rows: 44px 1fr 105px;
    grid-template-columns: 80px 1fr 80px;
    padding: 26px 4px 6px;
    gap: 3px;
  }
  .player-badge { min-width: 64px; padding: 4px 8px; }
  .hand-container {
    padding: 12px 2px 4px 2px;
    justify-content: flex-start;
  }
}
