/* ═══════════════════════════════════════════════════════
   BRISCA — Layout y estilos del tablero
═══════════════════════════════════════════════════════ */
/* ── Fondo de la pantalla (El tapete general) ── */
#screen-brisca-game {
  background: var(--felt, #1a6b35);
}

.brisca-layout {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  height: 100%;
  padding: 44px 16px 8px;
  gap: 6px;
}

/* ── Zona del oponente (arriba) ─────────────────────── */
.brisca-top {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  width: 100%;
}

/* ── Zona central ─────────────────────────────────────── */
.brisca-center {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 32px;
  /* --- LO NUEVO: Estilos de la mesa --- */
  background: var(--felt-dark, #124d27);
  border-radius: 20px;
  border: 3px solid var(--felt-edge, #0d3a1c);
  box-shadow: inset 0 0 40px rgba(0,0,0,0.38), 0 15px 30px rgba(0,0,0,0.4);
  padding: 150px 40px;
  margin: 15px auto;
  max-width: 950px; /* Más estrecho que el Cinquillo, ideal para la Brisca */
  width: 100%;
}

.brisca-side-player {
  display: none;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  flex-direction: column;
  align-items: center;
  gap: 6px;
}

.brisca-left-player { left: 16px; }
.brisca-right-player { right: 16px; }

.brisca-side-player.active {
  display: flex;
}

.player-badge.partner {
  border-color: rgba(96,180,255,0.55);
  box-shadow: 0 0 14px rgba(96,180,255,0.22);
}

/* ── Grupo triunfo + mazo ─────────────────────────────── */
.brisca-deck-trump {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Carta de triunfo girada horizontalmente */
.brisca-trump-rotated {
  transform: rotate(-90deg);
  pointer-events: none;
  flex-shrink: 0;
}

.brisca-trump-swappable {
  pointer-events: auto;
  cursor: pointer;
  border-color: #f0c040;
  box-shadow:
    0 0 0 2px rgba(240,192,64,0.35),
    0 0 18px rgba(240,192,64,0.34),
    3px 3px 8px rgba(0,0,0,0.45);
}

.brisca-trump-swappable:hover {
  transform: rotate(-90deg) scale(1.05);
}

/* Pila del mazo */
.brisca-deck-pile {
  width: 72px;
  height: 100px;
  border-radius: 7px;
  box-shadow:
    3px 3px 0 rgba(0,0,0,0.35),
    2px 2px 0 rgba(0,0,0,0.25),
    1px 1px 0 rgba(0,0,0,0.15);
  background-image: url('/images/cards/reverso_oro.png');
  background-size: 100% 100%;
  flex-shrink: 0;
}

.brisca-deck-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
}

.brisca-deck-label {
  font-size: 0.6rem;
  color: #608060;
  letter-spacing: 1.5px;
  text-transform: uppercase;
}

.brisca-trump-label {
  font-size: 0.6rem;
  color: #c09020;
  letter-spacing: 2px;
  text-align: center;
}

.brisca-trump-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
}

.brisca-trump-suit-badge {
  display: none;
  align-items: center;
  gap: 5px;
  background: rgba(0,0,0,0.35);
  border: 1px solid rgba(192,144,32,0.4);
  border-radius: 6px;
  padding: 3px 9px;
  font-size: 0.68rem;
  color: #e8b830;
  letter-spacing: 1px;
  text-transform: uppercase;
  font-weight: 600;
}

.brisca-trump-suit-badge img {
  width: 14px;
  height: 14px;
  object-fit: contain;
}

/* ── Zona de baza actual ─────────────────────────────── */
.brisca-trick-area {
  display: flex;
  gap: 20px;
  align-items: flex-end;
  min-width: 200px;
  min-height: 120px;
  justify-content: center;
  flex-wrap: wrap;
}

.brisca-trick-slot {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
}

.brisca-trick-label {
  font-size: 0.58rem;
  color: #608060;
  letter-spacing: 0.5px;
}

.brisca-table-card { pointer-events: none; }

.brisca-trick-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  width: var(--card-w, 91px);
  height: var(--card-h, 133px);
  /* Ajuste del texto para que quepa bien en vertical */
  font-size: 0.65rem;
  color: #5a8a5a;
  letter-spacing: 0.5px;
  line-height: 1.4;
  text-align: center;
  padding: 8px;
  
  /* Borde estilo "hueco vacío de carta" */
  border: 2px dashed rgba(255,255,255,0.2);
  border-radius: 7px; /* Mismo redondeo que las cartas */
  box-shadow: inset 0 0 10px rgba(0,0,0,0.2);
}


/* ── Cartas jugables (mano del jugador) ──────────────── */
.brisca-playable {
  cursor: pointer;
  transition: transform 0.12s ease, box-shadow 0.12s ease;
}
.brisca-playable:hover {
  transform: translateY(-12px) scale(1.04);
  box-shadow: 0 10px 28px rgba(240,192,64,0.32);
  z-index: 10;
}

/* ── Animación de reparto ───────────────────────────────  */
@keyframes briscaDealIn {
  from { opacity: 0; transform: translateY(-60px) scale(0.55); }
  to   { opacity: 1; transform: translateY(0)      scale(1); }
}
.brisca-deal-in {
  animation: briscaDealIn 0.35s cubic-bezier(0.22, 0.61, 0.36, 1) forwards;
  opacity: 0;
}

/* ── Animación de volteo del triunfo ────────────────────  */
@keyframes briscaTrumpFlip {
  0%   { opacity: 0; transform: rotate(-90deg) scaleX(0); }
  50%  { opacity: 0.6; transform: rotate(-90deg) scaleX(0.4); }
  100% { opacity: 1; transform: rotate(-90deg) scaleX(1); }
}
.brisca-trump-flip {
  animation: briscaTrumpFlip 0.55s cubic-bezier(0.22, 0.61, 0.36, 1) forwards;
}

/* ── Animación del rival (mini-cartas del oponente) ──────  */
@keyframes briscaMiniDeal {
  from { opacity: 0; transform: translateY(-40px) scale(0.4); }
  to   { opacity: 1; transform: translateY(0)      scale(1); }
}
.brisca-mini-deal {
  animation: briscaMiniDeal 0.3s ease-out forwards;
  opacity: 0;
}

/* ── Overlay de puntuación ─────────────────────────────  */
.brisca-score-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 14px;
  border-radius: 8px;
  background: rgba(255,255,255,0.04);
  font-size: 0.9rem;
  color: #b0c8b0;
}
.brisca-score-row.winner {
  background: rgba(240,192,64,0.12);
  color: #f0c040;
  font-weight: 700;
}
.bsr-name { flex: 1; }
.bsr-pts  { font-size: 1.1rem; font-weight: 700; letter-spacing: 1px; }

@media (max-width: 760px) {
  .brisca-center {
    gap: 14px;
    padding: 132px 18px;
  }

  .brisca-side-player {
    transform: translateY(-50%) scale(0.86);
  }

  .brisca-left-player { left: 2px; }
  .brisca-right-player { right: 2px; }
}

@media (max-width: 480px) {
  .brisca-layout {
    padding: 40px 6px 6px;
    gap: 4px;
  }
  .brisca-center {
    padding: 92px 8px;
    gap: 8px;
    margin: 4px auto;
    border-radius: 14px;
  }
  .brisca-side-player {
    transform: translateY(-50%) scale(0.75);
  }
  .brisca-left-player  { left: -2px; }
  .brisca-right-player { right: -2px; }
}
