.screen {
  min-height: 100vh;
}

.screen.game-screen {
  height: 100vh;
  overflow: hidden;
}

/* Lobby Styles - Throne Room Aesthetic */
.lobby-container {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 2rem;
  background:
    radial-gradient(ellipse at top, rgba(107, 45, 91, 0.3) 0%, transparent 50%),
    radial-gradient(ellipse at bottom, rgba(212, 175, 55, 0.1) 0%, transparent 50%),
    linear-gradient(135deg, var(--bg-primary) 0%, var(--bg-secondary) 50%, var(--bg-tertiary) 100%);
}

.game-title {
  font-size: 5rem;
  font-weight: 700;
  color: var(--gold-light);
  text-shadow:
    0 0 40px rgba(212, 175, 55, 0.6),
    0 0 80px rgba(212, 175, 55, 0.3),
    2px 2px 0 var(--gold-dark);
  letter-spacing: 0.3em;
  margin-bottom: 2rem;
  font-family: 'MedievalSharp', serif;
}

.room-code-display {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 3rem;
  padding: 2rem;
  background: rgba(30, 20, 40, 0.6);
  border: 3px solid var(--gold);
  border-radius: 8px;
  box-shadow:
    inset 0 0 30px rgba(212, 175, 55, 0.1),
    0 0 30px rgba(0, 0, 0, 0.5);
}

.room-label {
  font-size: 1.2rem;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.3em;
  font-family: 'Cinzel', serif;
}

.room-code {
  font-size: 6rem;
  font-weight: 700;
  color: var(--gold-light);
  letter-spacing: 0.3em;
  text-shadow:
    0 0 30px rgba(212, 175, 55, 0.5),
    2px 2px 0 var(--gold-dark);
  font-family: 'MedievalSharp', serif;
}

.qr-code {
  margin-top: 1.5rem;
  padding: 1rem;
  background: var(--parchment);
  border-radius: 8px;
  display: inline-block;
  border: 3px solid var(--gold);
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.4);
}

.qr-code canvas {
  display: block;
}

.qr-hint {
  display: block;
  margin-top: 0.75rem;
  font-size: 1rem;
  color: var(--text-muted);
  font-family: 'Cinzel', serif;
}

.lobby-content {
  text-align: center;
  max-width: 600px;
}

.lobby-content h2 {
  color: var(--gold-light);
  margin-bottom: 1rem;
  font-family: 'MedievalSharp', serif;
  text-shadow: 0 0 10px rgba(212, 175, 55, 0.3);
}

.player-list {
  min-height: 150px;
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  justify-content: center;
  margin-bottom: 2rem;
}

.waiting-text {
  color: var(--text-muted);
  font-style: italic;
  font-family: 'Cinzel', serif;
}

.lobby-player {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 1rem 1.5rem;
  background: linear-gradient(145deg, rgba(107, 45, 91, 0.4) 0%, rgba(45, 27, 61, 0.6) 100%);
  border: 2px solid var(--border-gold);
  border-radius: 8px;
  font-size: 1.2rem;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.3);
}

.lobby-player.host::after {
  content: 'HOST';
  font-size: 0.7rem;
  background: linear-gradient(135deg, var(--gold-light) 0%, var(--gold) 100%);
  color: #1a0a0a;
  padding: 4px 8px;
  border-radius: 4px;
  margin-left: 0.5rem;
  font-family: 'Cinzel', serif;
  font-weight: 700;
  border: 1px solid var(--gold-dark);
}

.lobby-player.ai::before {
  content: '\265E'; /* Chess knight unicode */
  margin-right: 0.5rem;
  color: var(--royal-purple-light);
  font-size: 1.4rem;
}

.lobby-actions {
  display: flex;
  gap: 1rem;
  justify-content: center;
  margin-bottom: 2rem;
}

.instructions {
  color: var(--text-muted);
  font-size: 1.1rem;
  font-family: 'Cinzel', serif;
}

.instructions strong {
  color: var(--gold-light);
}

/* Game Screen Styles - Royal Banner Header */
.game-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1rem 2rem;
  background: linear-gradient(180deg, rgba(45, 27, 61, 0.9) 0%, rgba(26, 10, 26, 0.95) 100%);
  border-bottom: 3px solid var(--gold);
  box-shadow:
    inset 0 -10px 30px rgba(0, 0, 0, 0.3),
    0 4px 20px rgba(0, 0, 0, 0.5);
}

.header-left {
  display: flex;
  align-items: center;
  gap: 2rem;
}

.game-logo {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--gold-light);
  letter-spacing: 0.2em;
  font-family: 'MedievalSharp', serif;
  text-shadow: 0 0 15px rgba(212, 175, 55, 0.4);
}

.room-badge {
  background: rgba(107, 45, 91, 0.5);
  padding: 0.5rem 1rem;
  border-radius: 4px;
  font-size: 0.9rem;
  border: 1px solid var(--border-gold);
  font-family: 'Cinzel', serif;
}

.turn-indicator {
  font-size: 1.3rem;
  font-weight: 600;
  color: var(--gold-light);
  padding: 0.5rem 1.5rem;
  background: linear-gradient(145deg, rgba(107, 45, 91, 0.6) 0%, rgba(45, 27, 61, 0.8) 100%);
  border-radius: 4px;
  border: 2px solid var(--gold);
  font-family: 'MedievalSharp', serif;
  box-shadow:
    inset 0 0 15px rgba(212, 175, 55, 0.1),
    0 0 15px rgba(212, 175, 55, 0.2);
}

/* Game Board Layout - Horizontal: Players | Cards | Gems */
.game-board {
  display: flex;
  flex-direction: row;
  align-items: stretch;
  justify-content: center;
  gap: 1.5rem;
  padding: 1rem 1.5rem;
  height: calc(100vh - 70px);
  overflow: hidden;
  background:
    radial-gradient(ellipse at center, rgba(107, 45, 91, 0.15) 0%, transparent 70%),
    linear-gradient(135deg, var(--bg-primary) 0%, var(--bg-secondary) 50%, var(--bg-tertiary) 100%);
}

.gems-section h3 {
  color: var(--gold);
  font-size: 1rem;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  margin-bottom: 0.75rem;
  font-family: 'Cinzel', serif;
  text-shadow: 0 0 5px rgba(212, 175, 55, 0.2);
}

/* Market Section - Center, takes most space */
.market-section {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  align-items: center;
  justify-content: center;
  flex: 1;
  max-width: 900px;
}

.tier {
  display: flex;
  gap: 1rem;
  align-items: center;
}

.deck-indicator {
  width: min(110px, 10vw);
  height: min(180px, 24vh);
  border-radius: 8px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  border: 3px solid var(--gold);
  position: relative;
  overflow: hidden;
}

/* Tier 1 - Green - Common Folk / Merchants */
.tier-1 .deck-indicator {
  background:
    radial-gradient(ellipse at 30% 20%, rgba(46, 204, 113, 0.25) 0%, transparent 50%),
    radial-gradient(ellipse at 70% 80%, rgba(39, 174, 96, 0.2) 0%, transparent 50%),
    linear-gradient(160deg,
      rgba(30, 80, 50, 0.95) 0%,
      rgba(20, 60, 35, 0.97) 40%,
      rgba(15, 45, 25, 1) 100%);
  border-color: #2ecc71;
  box-shadow:
    inset 0 0 30px rgba(46, 204, 113, 0.2),
    inset 0 0 60px rgba(0, 0, 0, 0.4),
    0 4px 15px rgba(0, 0, 0, 0.5),
    0 0 20px rgba(46, 204, 113, 0.2);
}

.tier-1 .deck-indicator::before {
  content: '\2618'; /* Shamrock/Clover */
  position: absolute;
  top: 8px;
  left: 50%;
  transform: translateX(-50%);
  font-size: 1.2rem;
  color: rgba(46, 204, 113, 0.4);
  text-shadow: 0 0 10px rgba(46, 204, 113, 0.3);
}

.tier-1 .deck-indicator::after {
  content: '\2698'; /* Flower */
  position: absolute;
  bottom: 8px;
  left: 50%;
  transform: translateX(-50%);
  font-size: 1rem;
  color: rgba(46, 204, 113, 0.3);
}

.tier-1 .tier-label {
  color: #2ecc71;
  text-shadow: 0 0 10px rgba(46, 204, 113, 0.5);
}

/* Tier 2 - Blue - Nobility / Knights */
.tier-2 .deck-indicator {
  background:
    radial-gradient(ellipse at 30% 20%, rgba(52, 152, 219, 0.25) 0%, transparent 50%),
    radial-gradient(ellipse at 70% 80%, rgba(41, 128, 185, 0.2) 0%, transparent 50%),
    linear-gradient(160deg,
      rgba(30, 60, 100, 0.95) 0%,
      rgba(20, 45, 80, 0.97) 40%,
      rgba(15, 30, 60, 1) 100%);
  border-color: #3498db;
  box-shadow:
    inset 0 0 30px rgba(52, 152, 219, 0.2),
    inset 0 0 60px rgba(0, 0, 0, 0.4),
    0 4px 15px rgba(0, 0, 0, 0.5),
    0 0 20px rgba(52, 152, 219, 0.2);
}

.tier-2 .deck-indicator::before {
  content: '\2694'; /* Crossed Swords */
  position: absolute;
  top: 8px;
  left: 50%;
  transform: translateX(-50%);
  font-size: 1.2rem;
  color: rgba(52, 152, 219, 0.5);
  text-shadow: 0 0 10px rgba(52, 152, 219, 0.3);
}

.tier-2 .deck-indicator::after {
  content: '\269C'; /* Fleur-de-lis */
  position: absolute;
  bottom: 8px;
  left: 50%;
  transform: translateX(-50%);
  font-size: 1.2rem;
  color: rgba(52, 152, 219, 0.4);
}

.tier-2 .tier-label {
  color: #3498db;
  text-shadow: 0 0 10px rgba(52, 152, 219, 0.5);
}

/* Tier 3 - Gold - Royalty / Crown */
.tier-3 .deck-indicator {
  background:
    radial-gradient(ellipse at 30% 20%, rgba(241, 196, 15, 0.25) 0%, transparent 50%),
    radial-gradient(ellipse at 70% 80%, rgba(212, 175, 55, 0.2) 0%, transparent 50%),
    linear-gradient(160deg,
      rgba(100, 75, 30, 0.95) 0%,
      rgba(70, 50, 20, 0.97) 40%,
      rgba(50, 35, 15, 1) 100%);
  border-color: var(--gold-light);
  box-shadow:
    inset 0 0 30px rgba(241, 196, 15, 0.25),
    inset 0 0 60px rgba(0, 0, 0, 0.4),
    0 4px 15px rgba(0, 0, 0, 0.5),
    0 0 25px rgba(212, 175, 55, 0.3);
}

.tier-3 .deck-indicator::before {
  content: '\265B'; /* Chess Queen / Crown */
  position: absolute;
  top: 8px;
  left: 50%;
  transform: translateX(-50%);
  font-size: 1.3rem;
  color: rgba(241, 196, 15, 0.6);
  text-shadow: 0 0 15px rgba(241, 196, 15, 0.4);
}

.tier-3 .deck-indicator::after {
  content: '\2654'; /* Chess King */
  position: absolute;
  bottom: 8px;
  left: 50%;
  transform: translateX(-50%);
  font-size: 1.2rem;
  color: rgba(241, 196, 15, 0.5);
}

.tier-3 .tier-label {
  color: var(--gold-light);
  text-shadow: 0 0 15px rgba(241, 196, 15, 0.6);
}

.tier-label {
  font-size: 1.8rem;
  font-weight: bold;
  position: relative;
  z-index: 1;
  color: var(--gold);
  font-family: 'MedievalSharp', serif;
  text-shadow: 0 0 5px rgba(212, 175, 55, 0.3);
}

.deck-count {
  font-size: 1rem;
  color: var(--text-muted);
  font-family: 'Cinzel', serif;
  position: relative;
  z-index: 1;
}

.card-row {
  display: flex;
  gap: 0.75rem;
}

.market-card {
  width: min(145px, 13vw);
  height: min(200px, 26vh);
  background:
    radial-gradient(ellipse at 30% 20%, rgba(212, 175, 55, 0.08) 0%, transparent 50%),
    radial-gradient(ellipse at 70% 80%, rgba(107, 45, 91, 0.15) 0%, transparent 50%),
    linear-gradient(160deg,
      rgba(55, 35, 60, 0.95) 0%,
      rgba(40, 25, 50, 0.97) 40%,
      rgba(30, 18, 38, 1) 100%);
  border-radius: 8px;
  padding: 0.5rem;
  position: relative;
  border: 2px solid var(--border-gold);
  transition: all 0.2s;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.05),
    inset 0 0 30px rgba(212, 175, 55, 0.05),
    0 4px 15px rgba(0, 0, 0, 0.5);
  overflow: hidden;
}

.market-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background:
    linear-gradient(135deg, transparent 40%, rgba(255, 255, 255, 0.02) 50%, transparent 60%);
  pointer-events: none;
}

/* Tier 1 - Merchant/Common Folk Portrait (Green Background) */
.tier-1 .market-card::before {
  background:
    linear-gradient(135deg, rgba(46, 204, 113, 0.12) 0%, rgba(39, 174, 96, 0.08) 50%, transparent 100%),
    linear-gradient(135deg, transparent 40%, rgba(255, 255, 255, 0.02) 50%, transparent 60%);
}

.tier-1 .market-card::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 75px;
  height: 90px;
  background:
    /* Hair - Top and sides */
    radial-gradient(ellipse 28px 18px at 50% 22%, rgba(101, 67, 33, 0.5) 0%, transparent 65%),
    radial-gradient(ellipse 22px 15px at 50% 20%, rgba(139, 69, 19, 0.4) 0%, transparent 70%),
    radial-gradient(ellipse 18px 24px at 35% 24%, rgba(101, 67, 33, 0.4) 0%, transparent 70%),
    radial-gradient(ellipse 18px 24px at 65% 24%, rgba(101, 67, 33, 0.4) 0%, transparent 70%),
    /* Ears */
    radial-gradient(ellipse 6px 8px at 30% 38%, rgba(210, 180, 140, 0.3) 0%, transparent 70%),
    radial-gradient(ellipse 6px 8px at 70% 38%, rgba(210, 180, 140, 0.3) 0%, transparent 70%),
    /* Face with forehead highlight */
    radial-gradient(ellipse 26px 32px at 50% 38%, rgba(210, 180, 140, 0.35) 0%, transparent 70%),
    radial-gradient(ellipse 20px 14px at 50% 30%, rgba(220, 190, 150, 0.2) 0%, transparent 70%),
    /* Cheeks */
    radial-gradient(circle 8px at 38% 42%, rgba(210, 180, 140, 0.25) 0%, transparent 70%),
    radial-gradient(circle 8px at 62% 42%, rgba(210, 180, 140, 0.25) 0%, transparent 70%),
    /* Eyebrows */
    radial-gradient(ellipse 8px 3px at 42% 32%, rgba(80, 50, 30, 0.5) 0%, transparent 70%),
    radial-gradient(ellipse 8px 3px at 58% 32%, rgba(80, 50, 30, 0.5) 0%, transparent 70%),
    /* Eyes */
    radial-gradient(circle 2px at 42% 35%, rgba(60, 40, 20, 0.6) 0%, transparent 70%),
    radial-gradient(circle 2px at 58% 35%, rgba(60, 40, 20, 0.6) 0%, transparent 70%),
    radial-gradient(circle 1px at 41.5% 34.5%, rgba(255, 255, 255, 0.4) 0%, transparent 70%),
    radial-gradient(circle 1px at 57.5% 34.5%, rgba(255, 255, 255, 0.4) 0%, transparent 70%),
    /* Nose with nostrils */
    radial-gradient(ellipse 4px 8px at 50% 41%, rgba(180, 150, 120, 0.3) 0%, transparent 70%),
    radial-gradient(ellipse 5px 7px at 50% 42%, rgba(180, 150, 120, 0.25) 0%, transparent 70%),
    radial-gradient(circle 1.5px at 47% 44%, rgba(150, 120, 90, 0.3) 0%, transparent 70%),
    radial-gradient(circle 1.5px at 53% 44%, rgba(150, 120, 90, 0.3) 0%, transparent 70%),
    /* Mouth */
    radial-gradient(ellipse 10px 4px at 50% 48%, rgba(160, 100, 80, 0.3) 0%, transparent 70%),
    radial-gradient(ellipse 8px 3px at 50% 47%, rgba(180, 110, 90, 0.25) 0%, transparent 70%),
    radial-gradient(ellipse 6px 2px at 50% 49%, rgba(140, 80, 60, 0.2) 0%, transparent 70%),
    /* Chin definition */
    radial-gradient(ellipse 12px 8px at 50% 52%, rgba(190, 160, 130, 0.2) 0%, transparent 70%),
    /* Neck */
    radial-gradient(ellipse 18px 15px at 50% 56%, rgba(210, 180, 140, 0.3) 0%, transparent 65%),
    /* Collar */
    radial-gradient(ellipse 24px 8px at 50% 60%, rgba(101, 67, 33, 0.35) 0%, transparent 70%),
    radial-gradient(ellipse 22px 6px at 50% 59%, rgba(139, 69, 19, 0.25) 0%, transparent 70%),
    /* Tunic/Shirt */
    radial-gradient(ellipse 38px 28px at 50% 72%, rgba(46, 204, 113, 0.4) 0%, transparent 70%),
    radial-gradient(ellipse 34px 24px at 50% 71%, rgba(39, 174, 96, 0.3) 0%, transparent 70%),
    /* Sleeves */
    radial-gradient(ellipse 18px 20px at 30% 72%, rgba(46, 204, 113, 0.35) 0%, transparent 70%),
    radial-gradient(ellipse 18px 20px at 70% 72%, rgba(46, 204, 113, 0.35) 0%, transparent 70%),
    /* Arms/Shoulders */
    radial-gradient(ellipse 45px 25px at 50% 68%, rgba(39, 174, 96, 0.3) 0%, transparent 70%),
    /* Belt with buckle */
    radial-gradient(ellipse 30px 8px at 50% 80%, rgba(101, 67, 33, 0.35) 0%, transparent 70%),
    radial-gradient(circle 4px at 50% 80%, rgba(139, 69, 19, 0.4) 0%, transparent 70%);
  opacity: 0.6;
  z-index: 0;
  pointer-events: none;
}

/* Tier 2 - Noble/Knight Portrait (Blue Background) */
.tier-2 .market-card::before {
  background:
    linear-gradient(135deg, rgba(52, 152, 219, 0.15) 0%, rgba(41, 128, 185, 0.1) 50%, transparent 100%),
    linear-gradient(135deg, transparent 40%, rgba(255, 255, 255, 0.02) 50%, transparent 60%);
}

.tier-2 .market-card::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 80px;
  height: 95px;
  background:
    /* Helmet Plume/Crest */
    radial-gradient(ellipse 12px 16px at 50% 8%, rgba(231, 76, 60, 0.5) 0%, transparent 70%),
    radial-gradient(ellipse 10px 14px at 50% 7%, rgba(192, 57, 43, 0.4) 0%, transparent 70%),
    /* Helmet Top - Crown piece */
    radial-gradient(ellipse 24px 14px at 50% 16%, rgba(192, 192, 192, 0.5) 0%, transparent 70%),
    radial-gradient(ellipse 18px 10px at 50% 15%, rgba(212, 175, 55, 0.4) 0%, transparent 65%),
    radial-gradient(ellipse 22px 12px at 50% 17%, rgba(169, 169, 169, 0.35) 0%, transparent 70%),
    /* Helmet Sides */
    radial-gradient(ellipse 14px 20px at 32% 26%, rgba(169, 169, 169, 0.4) 0%, transparent 70%),
    radial-gradient(ellipse 14px 20px at 68% 26%, rgba(169, 169, 169, 0.4) 0%, transparent 70%),
    /* Helmet Visor Area */
    radial-gradient(ellipse 26px 18px at 50% 28%, rgba(169, 169, 169, 0.4) 0%, transparent 70%),
    radial-gradient(ellipse 20px 14px at 50% 27%, rgba(192, 192, 192, 0.3) 0%, transparent 70%),
    /* Visor Opening */
    radial-gradient(ellipse 18px 20px at 50% 35%, rgba(40, 40, 50, 0.5) 0%, transparent 70%),
    radial-gradient(ellipse 16px 18px at 50% 34%, rgba(30, 30, 40, 0.4) 0%, transparent 70%),
    /* Face through opening with glowing eyes */
    radial-gradient(ellipse 16px 22px at 50% 38%, rgba(210, 180, 140, 0.3) 0%, transparent 70%),
    radial-gradient(ellipse 12px 16px at 50% 37%, rgba(190, 160, 120, 0.25) 0%, transparent 70%),
    /* Intense Blue Eyes with glow */
    radial-gradient(circle 3px at 43% 36%, rgba(52, 152, 219, 0.9) 0%, transparent 70%),
    radial-gradient(circle 3px at 57% 36%, rgba(52, 152, 219, 0.9) 0%, transparent 70%),
    radial-gradient(circle 2px at 43% 36%, rgba(135, 206, 250, 0.8) 0%, transparent 70%),
    radial-gradient(circle 2px at 57% 36%, rgba(135, 206, 250, 0.8) 0%, transparent 70%),
    radial-gradient(circle 5px at 43% 36%, rgba(52, 152, 219, 0.3) 0%, transparent 70%),
    radial-gradient(circle 5px at 57% 36%, rgba(52, 152, 219, 0.3) 0%, transparent 70%),
    /* Nose bridge */
    radial-gradient(ellipse 4px 8px at 50% 40%, rgba(180, 150, 120, 0.25) 0%, transparent 70%),
    /* Jaw definition */
    radial-gradient(ellipse 14px 10px at 50% 44%, rgba(190, 160, 130, 0.2) 0%, transparent 70%),
    /* Gorget (neck armor) - detailed */
    radial-gradient(ellipse 28px 12px at 50% 48%, rgba(192, 192, 192, 0.4) 0%, transparent 65%),
    radial-gradient(ellipse 24px 10px at 50% 49%, rgba(169, 169, 169, 0.3) 0%, transparent 70%),
    radial-gradient(ellipse 20px 8px at 50% 48%, rgba(212, 175, 55, 0.2) 0%, transparent 70%),
    /* Chest Armor/Breastplate with detail */
    radial-gradient(ellipse 42px 32px at 50% 70%, rgba(52, 152, 219, 0.45) 0%, transparent 70%),
    radial-gradient(ellipse 38px 28px at 50% 68%, rgba(169, 169, 169, 0.35) 0%, transparent 70%),
    radial-gradient(ellipse 34px 24px at 50% 69%, rgba(192, 192, 192, 0.25) 0%, transparent 70%),
    /* Center chest plate ridge */
    radial-gradient(ellipse 6px 26px at 50% 68%, rgba(220, 220, 220, 0.3) 0%, transparent 70%),
    /* Shoulder Pauldrons */
    radial-gradient(ellipse 48px 22px at 50% 58%, rgba(192, 192, 192, 0.3) 0%, transparent 70%),
    radial-gradient(ellipse 24px 18px at 32% 58%, rgba(169, 169, 169, 0.35) 0%, transparent 70%),
    radial-gradient(ellipse 24px 18px at 68% 58%, rgba(169, 169, 169, 0.35) 0%, transparent 70%),
    /* Armor Rivets and Details */
    radial-gradient(circle 2.5px at 50% 62%, rgba(212, 175, 55, 0.4) 0%, transparent 70%),
    radial-gradient(circle 2px at 38% 65%, rgba(192, 192, 192, 0.35) 0%, transparent 70%),
    radial-gradient(circle 2px at 62% 65%, rgba(192, 192, 192, 0.35) 0%, transparent 70%),
    radial-gradient(circle 1.8px at 40% 72%, rgba(192, 192, 192, 0.3) 0%, transparent 70%),
    radial-gradient(circle 1.8px at 60% 72%, rgba(192, 192, 192, 0.3) 0%, transparent 70%),
    radial-gradient(circle 1.5px at 35% 78%, rgba(169, 169, 169, 0.3) 0%, transparent 70%),
    radial-gradient(circle 1.5px at 65% 78%, rgba(169, 169, 169, 0.3) 0%, transparent 70%),
    /* Belt buckle */
    radial-gradient(ellipse 12px 6px at 50% 82%, rgba(212, 175, 55, 0.35) 0%, transparent 70%);
  opacity: 0.65;
  z-index: 0;
  pointer-events: none;
}

/* Tier 3 - Royalty Portrait (Gold Background) */
.tier-3 .market-card::before {
  background:
    linear-gradient(135deg, rgba(241, 196, 15, 0.18) 0%, rgba(212, 175, 55, 0.12) 50%, transparent 100%),
    linear-gradient(135deg, transparent 40%, rgba(255, 255, 255, 0.02) 50%, transparent 60%);
}

.tier-3 .market-card::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 85px;
  height: 100px;
  background:
    /* Crown - Elaborate with points */
    radial-gradient(ellipse 32px 18px at 50% 13%, rgba(241, 196, 15, 0.6) 0%, transparent 70%),
    radial-gradient(ellipse 28px 14px at 50% 12%, rgba(255, 215, 0, 0.5) 0%, transparent 65%),
    radial-gradient(ellipse 24px 12px at 50% 11%, rgba(212, 175, 55, 0.4) 0%, transparent 70%),
    /* Crown points */
    radial-gradient(ellipse 6px 10px at 35% 8%, rgba(241, 196, 15, 0.5) 0%, transparent 70%),
    radial-gradient(ellipse 6px 10px at 50% 6%, rgba(241, 196, 15, 0.55) 0%, transparent 70%),
    radial-gradient(ellipse 6px 10px at 65% 8%, rgba(241, 196, 15, 0.5) 0%, transparent 70%),
    /* Crown Jewels - Large gems */
    radial-gradient(circle 4px at 38% 10%, rgba(231, 76, 60, 1.0) 0%, transparent 70%),
    radial-gradient(circle 3px at 38% 10%, rgba(255, 150, 150, 0.6) 0%, transparent 70%),
    radial-gradient(circle 4.5px at 50% 7%, rgba(46, 204, 113, 0.95) 0%, transparent 70%),
    radial-gradient(circle 3px at 50% 7%, rgba(144, 238, 144, 0.5) 0%, transparent 70%),
    radial-gradient(circle 4px at 62% 10%, rgba(52, 152, 219, 1.0) 0%, transparent 70%),
    radial-gradient(circle 3px at 62% 10%, rgba(135, 206, 250, 0.6) 0%, transparent 70%),
    radial-gradient(circle 2.5px at 44% 11%, rgba(138, 43, 226, 0.8) 0%, transparent 70%),
    radial-gradient(circle 2.5px at 56% 11%, rgba(138, 43, 226, 0.8) 0%, transparent 70%),
    /* Hair - Detailed layers */
    radial-gradient(ellipse 32px 25px at 50% 25%, rgba(139, 69, 19, 0.45) 0%, transparent 70%),
    radial-gradient(ellipse 28px 22px at 45% 24%, rgba(101, 67, 33, 0.4) 0%, transparent 70%),
    radial-gradient(ellipse 28px 22px at 55% 24%, rgba(101, 67, 33, 0.4) 0%, transparent 70%),
    radial-gradient(ellipse 24px 18px at 40% 26%, rgba(139, 69, 19, 0.35) 0%, transparent 70%),
    radial-gradient(ellipse 24px 18px at 60% 26%, rgba(139, 69, 19, 0.35) 0%, transparent 70%),
    /* Golden Earrings */
    radial-gradient(circle 3px at 28% 38%, rgba(241, 196, 15, 0.6) 0%, transparent 70%),
    radial-gradient(circle 3px at 72% 38%, rgba(241, 196, 15, 0.6) 0%, transparent 70%),
    /* Face - Detailed with forehead and cheekbones */
    radial-gradient(ellipse 28px 36px at 50% 42%, rgba(210, 180, 140, 0.45) 0%, transparent 70%),
    radial-gradient(ellipse 24px 30px at 50% 41%, rgba(220, 190, 150, 0.35) 0%, transparent 70%),
    /* Forehead highlight */
    radial-gradient(ellipse 18px 12px at 50% 32%, rgba(230, 200, 160, 0.25) 0%, transparent 70%),
    /* Cheekbones */
    radial-gradient(ellipse 12px 10px at 38% 44%, rgba(220, 190, 150, 0.3) 0%, transparent 70%),
    radial-gradient(ellipse 12px 10px at 62% 44%, rgba(220, 190, 150, 0.3) 0%, transparent 70%),
    /* Eyebrows */
    radial-gradient(ellipse 9px 3px at 43% 37%, rgba(80, 50, 30, 0.5) 0%, transparent 70%),
    radial-gradient(ellipse 9px 3px at 57% 37%, rgba(80, 50, 30, 0.5) 0%, transparent 70%),
    /* Eyes with highlights */
    radial-gradient(circle 3px at 43% 40%, rgba(60, 40, 20, 0.8) 0%, transparent 70%),
    radial-gradient(circle 3px at 57% 40%, rgba(60, 40, 20, 0.8) 0%, transparent 70%),
    radial-gradient(circle 1.5px at 42.5% 39.5%, rgba(255, 255, 255, 0.5) 0%, transparent 70%),
    radial-gradient(circle 1.5px at 56.5% 39.5%, rgba(255, 255, 255, 0.5) 0%, transparent 70%),
    /* Nose - Detailed with nostrils */
    radial-gradient(ellipse 5px 10px at 50% 46%, rgba(180, 150, 120, 0.35) 0%, transparent 70%),
    radial-gradient(ellipse 6px 9px at 50% 45%, rgba(190, 160, 130, 0.25) 0%, transparent 70%),
    radial-gradient(ellipse 4px 7px at 50% 47%, rgba(170, 140, 110, 0.2) 0%, transparent 70%),
    /* Nostrils */
    radial-gradient(circle 1.5px at 47% 48%, rgba(140, 110, 80, 0.4) 0%, transparent 70%),
    radial-gradient(circle 1.5px at 53% 48%, rgba(140, 110, 80, 0.4) 0%, transparent 70%),
    /* Mouth - Detailed lips */
    radial-gradient(ellipse 12px 5px at 50% 52%, rgba(180, 100, 90, 0.35) 0%, transparent 70%),
    radial-gradient(ellipse 10px 4px at 50% 51%, rgba(200, 120, 110, 0.3) 0%, transparent 70%),
    radial-gradient(ellipse 8px 3px at 50% 53%, rgba(160, 80, 70, 0.25) 0%, transparent 70%),
    /* Chin */
    radial-gradient(ellipse 14px 10px at 50% 56%, rgba(200, 170, 140, 0.25) 0%, transparent 70%),
    /* Neck - Detailed */
    radial-gradient(ellipse 20px 18px at 50% 60%, rgba(210, 180, 140, 0.35) 0%, transparent 65%),
    radial-gradient(ellipse 16px 14px at 50% 59%, rgba(220, 190, 150, 0.25) 0%, transparent 70%),
    /* Royal Necklace - Elaborate with multiple gems */
    radial-gradient(ellipse 34px 12px at 50% 64%, rgba(241, 196, 15, 0.55) 0%, transparent 70%),
    radial-gradient(ellipse 30px 10px at 50% 63%, rgba(255, 215, 0, 0.4) 0%, transparent 70%),
    /* Necklace center emerald */
    radial-gradient(circle 3.5px at 50% 64%, rgba(46, 204, 113, 0.9) 0%, transparent 70%),
    radial-gradient(circle 2.5px at 50% 64%, rgba(144, 238, 144, 0.5) 0%, transparent 70%),
    /* Side gems on necklace */
    radial-gradient(circle 2px at 42% 65%, rgba(231, 76, 60, 0.8) 0%, transparent 70%),
    radial-gradient(circle 2px at 58% 65%, rgba(231, 76, 60, 0.8) 0%, transparent 70%),
    radial-gradient(circle 1.5px at 38% 65%, rgba(52, 152, 219, 0.8) 0%, transparent 70%),
    radial-gradient(circle 1.5px at 62% 65%, rgba(52, 152, 219, 0.8) 0%, transparent 70%),
    /* Ermine Trim - White with spots */
    radial-gradient(ellipse 52px 28px at 50% 72%, rgba(255, 255, 255, 0.3) 0%, transparent 70%),
    radial-gradient(ellipse 48px 24px at 50% 71%, rgba(245, 245, 245, 0.25) 0%, transparent 70%),
    /* Ermine spots */
    radial-gradient(circle 1.5px at 38% 72%, rgba(40, 40, 40, 0.4) 0%, transparent 70%),
    radial-gradient(circle 1.5px at 50% 74%, rgba(40, 40, 40, 0.4) 0%, transparent 70%),
    radial-gradient(circle 1.5px at 62% 72%, rgba(40, 40, 40, 0.4) 0%, transparent 70%),
    radial-gradient(circle 1.2px at 44% 70%, rgba(40, 40, 40, 0.35) 0%, transparent 70%),
    radial-gradient(circle 1.2px at 56% 70%, rgba(40, 40, 40, 0.35) 0%, transparent 70%),
    /* Royal Robe - Purple with folds */
    radial-gradient(ellipse 48px 38px at 50% 84%, rgba(107, 45, 91, 0.55) 0%, transparent 70%),
    radial-gradient(ellipse 44px 34px at 50% 82%, rgba(138, 43, 226, 0.4) 0%, transparent 70%),
    radial-gradient(ellipse 40px 30px at 50% 83%, rgba(107, 45, 91, 0.35) 0%, transparent 70%),
    /* Robe folds */
    radial-gradient(ellipse 8px 32px at 44% 82%, rgba(80, 30, 70, 0.3) 0%, transparent 70%),
    radial-gradient(ellipse 8px 32px at 56% 82%, rgba(80, 30, 70, 0.3) 0%, transparent 70%),
    /* Golden Embroidery on Robe */
    radial-gradient(ellipse 40px 8px at 50% 76%, rgba(241, 196, 15, 0.35) 0%, transparent 70%),
    radial-gradient(circle 2.5px at 50% 76%, rgba(241, 196, 15, 0.5) 0%, transparent 70%),
    radial-gradient(circle 2px at 42% 78%, rgba(212, 175, 55, 0.4) 0%, transparent 70%),
    radial-gradient(circle 2px at 58% 78%, rgba(212, 175, 55, 0.4) 0%, transparent 70%),
    radial-gradient(circle 1.8px at 38% 80%, rgba(241, 196, 15, 0.35) 0%, transparent 70%),
    radial-gradient(circle 1.8px at 62% 80%, rgba(241, 196, 15, 0.35) 0%, transparent 70%),
    radial-gradient(circle 1.5px at 46% 82%, rgba(212, 175, 55, 0.3) 0%, transparent 70%),
    radial-gradient(circle 1.5px at 54% 82%, rgba(212, 175, 55, 0.3) 0%, transparent 70%),
    /* Center Brooch with Ruby */
    radial-gradient(circle 4px at 50% 76%, rgba(212, 175, 55, 0.5) 0%, transparent 70%),
    radial-gradient(circle 3px at 50% 76%, rgba(231, 76, 60, 0.8) 0%, transparent 70%);
  opacity: 0.7;
  z-index: 0;
  pointer-events: none;
}

.market-card:hover {
  border-color: var(--gold-light);
  box-shadow:
    inset 0 0 20px rgba(212, 175, 55, 0.15),
    0 8px 25px rgba(0, 0, 0, 0.5),
    0 0 20px rgba(212, 175, 55, 0.3);
  transform: translateY(-3px);
}

.market-card.empty {
  background: rgba(30, 20, 40, 0.4);
  border-style: dashed;
  border-color: rgba(212, 175, 55, 0.3);
  box-shadow: none;
}

.market-card .points {
  position: absolute;
  top: 8px;
  left: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  font-size: 1.3rem;
  color: var(--gold-light);
  text-shadow: 0 0 8px rgba(212, 175, 55, 0.5), 1px 1px 2px rgba(0, 0, 0, 0.8);
  z-index: 1;
}

.market-card .points.zero {
  display: none;
}

.market-card .bonus {
  position: absolute;
  top: 8px;
  right: 8px;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: 2px solid var(--gold);
  box-shadow: inset 0 0 5px rgba(0, 0, 0, 0.3);
  z-index: 1;
}

/* Unique gem shapes for market card bonus */
.market-card .bonus.gem-diamond {
  border-radius: 4px;
  transform: rotate(45deg);
  border-color: rgba(200, 200, 200, 0.6);
  box-shadow:
    inset 0 -3px 8px rgba(0, 0, 0, 0.2),
    inset 0 3px 8px rgba(255, 255, 255, 0.5),
    0 2px 6px rgba(0, 0, 0, 0.3),
    0 0 10px rgba(255, 255, 255, 0.3);
}

.market-card .bonus.gem-sapphire {
  border-radius: 50% / 40%;
  border-color: rgba(100, 149, 237, 0.6);
  box-shadow:
    inset 0 -4px 8px rgba(0, 0, 0, 0.4),
    inset 0 4px 8px rgba(135, 206, 250, 0.4),
    0 2px 6px rgba(0, 0, 0, 0.3),
    0 0 8px rgba(65, 105, 225, 0.4);
}

.market-card .bonus.gem-emerald {
  clip-path: polygon(30% 0%, 70% 0%, 100% 30%, 100% 70%, 70% 100%, 30% 100%, 0% 70%, 0% 30%);
  border: none;
  box-shadow:
    0 2px 6px rgba(0, 0, 0, 0.4),
    0 0 10px rgba(46, 204, 113, 0.3);
}

.market-card .bonus.gem-ruby {
  border-radius: 50% 50% 50% 50% / 60% 60% 40% 40%;
  border-color: rgba(255, 100, 100, 0.5);
  box-shadow:
    inset 0 -4px 8px rgba(0, 0, 0, 0.4),
    inset 0 4px 6px rgba(255, 150, 150, 0.3),
    0 2px 6px rgba(0, 0, 0, 0.3),
    0 0 8px rgba(231, 76, 60, 0.4);
}

.market-card .bonus.gem-onyx {
  clip-path: polygon(25% 0%, 75% 0%, 100% 50%, 75% 100%, 25% 100%, 0% 50%);
  border: none;
  box-shadow:
    0 2px 6px rgba(0, 0, 0, 0.5),
    0 0 8px rgba(0, 0, 0, 0.3);
}

.market-card .cost {
  z-index: 1;
  position: absolute;
  bottom: 6px;
  left: 6px;
  right: 6px;
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}

.market-card .cost-item {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  font-size: 0.9rem;
  font-weight: bold;
  border: 2px solid rgba(255, 255, 255, 0.3);
  box-shadow:
    inset 0 -3px 6px rgba(0, 0, 0, 0.3),
    inset 0 3px 6px rgba(255, 255, 255, 0.2),
    0 2px 4px rgba(0, 0, 0, 0.3);
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.5);
}

/* Diamond - classic diamond/rhombus shape */
.market-card .cost-item.gem-diamond {
  border-radius: 4px;
  transform: rotate(45deg);
  border-color: rgba(200, 200, 200, 0.6);
  box-shadow:
    inset 0 -3px 8px rgba(0, 0, 0, 0.2),
    inset 0 3px 8px rgba(255, 255, 255, 0.5),
    0 2px 6px rgba(0, 0, 0, 0.3),
    0 0 10px rgba(255, 255, 255, 0.3);
}
.market-card .cost-item.gem-diamond .gem-count {
  display: inline-block;
  transform: rotate(-45deg);
}

/* Sapphire - oval/cushion cut */
.market-card .cost-item.gem-sapphire {
  border-radius: 50% / 40%;
  border-color: rgba(100, 149, 237, 0.6);
  box-shadow:
    inset 0 -4px 8px rgba(0, 0, 0, 0.4),
    inset 0 4px 8px rgba(135, 206, 250, 0.4),
    0 2px 6px rgba(0, 0, 0, 0.3),
    0 0 8px rgba(65, 105, 225, 0.4);
}

/* Emerald - octagon/emerald cut */
.market-card .cost-item.gem-emerald {
  clip-path: polygon(30% 0%, 70% 0%, 100% 30%, 100% 70%, 70% 100%, 30% 100%, 0% 70%, 0% 30%);
  border: none;
  box-shadow:
    0 2px 6px rgba(0, 0, 0, 0.4),
    0 0 10px rgba(46, 204, 113, 0.3);
}

/* Ruby - teardrop/pear shape */
.market-card .cost-item.gem-ruby {
  border-radius: 50% 50% 50% 50% / 60% 60% 40% 40%;
  border-color: rgba(255, 100, 100, 0.5);
  box-shadow:
    inset 0 -4px 8px rgba(0, 0, 0, 0.4),
    inset 0 4px 6px rgba(255, 150, 150, 0.3),
    0 2px 6px rgba(0, 0, 0, 0.3),
    0 0 8px rgba(231, 76, 60, 0.4);
}

/* Onyx - hexagon */
.market-card .cost-item.gem-onyx {
  clip-path: polygon(25% 0%, 75% 0%, 100% 50%, 75% 100%, 25% 100%, 0% 50%);
  border: none;
  box-shadow:
    0 2px 6px rgba(0, 0, 0, 0.5),
    0 0 8px rgba(0, 0, 0, 0.3);
}

/* Gold - circle with shine */
.market-card .cost-item.gem-gold {
  border-radius: 50%;
  border-color: rgba(255, 215, 0, 0.6);
  box-shadow:
    inset 0 -3px 6px rgba(0, 0, 0, 0.3),
    inset 0 3px 8px rgba(255, 255, 200, 0.4),
    0 2px 6px rgba(0, 0, 0, 0.3),
    0 0 12px rgba(241, 196, 15, 0.5);
}

/* Gems Section - Right side vertical panel */
.gems-section {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  background: linear-gradient(145deg, rgba(107, 45, 91, 0.2) 0%, rgba(30, 20, 40, 0.6) 100%);
  border-radius: 8px;
  border: 2px solid rgba(212, 175, 55, 0.3);
  min-width: 100px;
}

.gems-section h3 {
  margin-bottom: 1rem;
  white-space: nowrap;
}

.gem-bank {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  align-items: center;
}

.bank-gem {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 0.5rem;
}

.bank-gem .gem-token {
  width: min(44px, 5vh);
  height: min(44px, 5vh);
  font-size: 1.1rem;
}

.bank-gem .gem-label {
  font-size: 0.65rem;
  color: var(--text-muted);
  text-transform: uppercase;
  font-family: 'Cinzel', serif;
  letter-spacing: 0.05em;
  min-width: 50px;
}

/* Players Section - Left side vertical panel */
.players-section-game {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 1rem;
  background: linear-gradient(145deg, rgba(107, 45, 91, 0.2) 0%, rgba(30, 20, 40, 0.6) 100%);
  border-radius: 8px;
  border: 2px solid rgba(212, 175, 55, 0.3);
  min-width: 200px;
  max-width: 280px;
  overflow-y: auto;
}

.players-section-game h3 {
  color: var(--gold);
  font-size: 1rem;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  margin-bottom: 0.75rem;
  font-family: 'Cinzel', serif;
  text-shadow: 0 0 5px rgba(212, 175, 55, 0.2);
}

.players-display {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  width: 100%;
}

.player-card {
  width: 100%;
  background: linear-gradient(145deg, rgba(107, 45, 91, 0.3) 0%, rgba(30, 20, 40, 0.8) 100%);
  border-radius: 6px;
  padding: 0.5rem 0.6rem;
  border: 2px solid rgba(212, 175, 55, 0.3);
  transition: all 0.3s;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

.player-card.active-turn {
  border-color: var(--gold);
  background: linear-gradient(145deg, rgba(212, 175, 55, 0.15) 0%, rgba(107, 45, 91, 0.4) 100%);
  box-shadow:
    inset 0 0 30px rgba(212, 175, 55, 0.1),
    0 0 25px rgba(212, 175, 55, 0.3),
    0 4px 20px rgba(0, 0, 0, 0.4);
  animation: activeTurnGlow 2s ease-in-out infinite;
}

@keyframes activeTurnGlow {
  0%, 100% { box-shadow: inset 0 0 30px rgba(212, 175, 55, 0.1), 0 0 25px rgba(212, 175, 55, 0.3), 0 4px 20px rgba(0, 0, 0, 0.4); }
  50% { box-shadow: inset 0 0 40px rgba(212, 175, 55, 0.15), 0 0 35px rgba(212, 175, 55, 0.4), 0 4px 20px rgba(0, 0, 0, 0.4); }
}

.player-card .player-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0.35rem;
}

.player-card .player-name {
  font-weight: 600;
  font-size: 0.85rem;
  font-family: 'Cinzel', serif;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 120px;
}

.player-card .player-name.ai::before {
  content: '\265E '; /* Chess knight */
  color: var(--royal-purple-light);
}

.player-card .player-points {
  font-size: 1rem;
  font-weight: bold;
  color: var(--gold-light);
  font-family: 'MedievalSharp', serif;
  text-shadow: 0 0 8px rgba(212, 175, 55, 0.4);
}

.player-card .player-gems-section {
  margin-bottom: 0.35rem;
}

.player-card .player-gems {
  display: flex;
  gap: 4px;
  padding: 2px;
  flex-wrap: wrap;
  justify-content: center;
}

.player-card .player-gems .gem-count-display {
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.7rem;
  font-weight: bold;
  border: 1.5px solid rgba(255, 255, 255, 0.3);
  box-shadow:
    inset 0 -2px 4px rgba(0, 0, 0, 0.3),
    inset 0 2px 4px rgba(255, 255, 255, 0.2),
    0 1px 3px rgba(0, 0, 0, 0.3);
  text-shadow: 0 1px 1px rgba(0, 0, 0, 0.5);
}

/* Diamond - classic diamond/rhombus shape */
.player-card .player-gems .gem-count-display.gem-diamond {
  border-radius: 4px;
  transform: rotate(45deg);
  background: linear-gradient(135deg, #ffffff 0%, #e8e8e8 25%, #b8b8b8 50%, #e8e8e8 75%, #ffffff 100%);
  color: #333;
  border-color: rgba(200, 200, 200, 0.6);
  box-shadow:
    inset 0 -3px 8px rgba(0, 0, 0, 0.2),
    inset 0 3px 8px rgba(255, 255, 255, 0.5),
    0 2px 6px rgba(0, 0, 0, 0.3),
    0 0 10px rgba(255, 255, 255, 0.3);
}
.player-card .player-gems .gem-count-display.gem-diamond span {
  transform: rotate(-45deg);
}

/* Sapphire - oval/cushion cut */
.player-card .player-gems .gem-count-display.gem-sapphire {
  border-radius: 50% / 40%;
  background: linear-gradient(135deg, #6495ed 0%, #4169e1 30%, #1e3a8a 60%, #4169e1 100%);
  color: #fff;
  border-color: rgba(100, 149, 237, 0.6);
  box-shadow:
    inset 0 -4px 8px rgba(0, 0, 0, 0.4),
    inset 0 4px 8px rgba(135, 206, 250, 0.4),
    0 2px 6px rgba(0, 0, 0, 0.3),
    0 0 8px rgba(65, 105, 225, 0.4);
}

/* Emerald - octagon/emerald cut */
.player-card .player-gems .gem-count-display.gem-emerald {
  clip-path: polygon(30% 0%, 70% 0%, 100% 30%, 100% 70%, 70% 100%, 30% 100%, 0% 70%, 0% 30%);
  background: linear-gradient(135deg, #50c878 0%, #2ecc71 30%, #145a32 60%, #2ecc71 100%);
  color: #fff;
  border: none;
  box-shadow:
    0 2px 6px rgba(0, 0, 0, 0.4),
    0 0 10px rgba(46, 204, 113, 0.3);
}

/* Ruby - teardrop/pear shape */
.player-card .player-gems .gem-count-display.gem-ruby {
  border-radius: 50% 50% 50% 50% / 60% 60% 40% 40%;
  background: linear-gradient(135deg, #ff6b6b 0%, #e74c3c 30%, #7b1113 60%, #e74c3c 100%);
  color: #fff;
  border-color: rgba(255, 100, 100, 0.5);
  box-shadow:
    inset 0 -4px 8px rgba(0, 0, 0, 0.4),
    inset 0 4px 6px rgba(255, 150, 150, 0.3),
    0 2px 6px rgba(0, 0, 0, 0.3),
    0 0 8px rgba(231, 76, 60, 0.4);
}

/* Onyx - hexagon */
.player-card .player-gems .gem-count-display.gem-onyx {
  clip-path: polygon(25% 0%, 75% 0%, 100% 50%, 75% 100%, 25% 100%, 0% 50%);
  background: linear-gradient(135deg, #4a4a4a 0%, #2c3e50 30%, #1a1a2e 60%, #2c3e50 100%);
  color: #fff;
  border: none;
  box-shadow:
    0 2px 6px rgba(0, 0, 0, 0.5),
    0 0 8px rgba(0, 0, 0, 0.3);
}

/* Gold - circle with shine */
.player-card .player-gems .gem-count-display.gem-gold {
  border-radius: 50%;
  background: linear-gradient(135deg, #ffd700 0%, #f1c40f 30%, #b8860b 60%, #f1c40f 100%);
  color: #333;
  border-color: rgba(255, 215, 0, 0.6);
  box-shadow:
    inset 0 -3px 6px rgba(0, 0, 0, 0.3),
    inset 0 3px 8px rgba(255, 255, 200, 0.4),
    0 2px 6px rgba(0, 0, 0, 0.3),
    0 0 12px rgba(241, 196, 15, 0.5);
}

.player-card .player-stats {
  display: flex;
  gap: 0.75rem;
  font-size: 0.75rem;
  color: var(--text-muted);
  font-family: 'Cinzel', serif;
}

.player-card .player-reserved {
  margin-top: 0.5rem;
  padding-top: 0.5rem;
  border-top: 1px solid rgba(212, 175, 55, 0.2);
}

.player-card .reserved-label {
  font-size: 0.65rem;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-bottom: 0.35rem;
  font-family: 'Cinzel', serif;
}

.player-card .reserved-cards-mini {
  display: flex;
  gap: 0.35rem;
  flex-wrap: wrap;
  justify-content: center;
}

.mini-card {
  width: 40px;
  height: 52px;
  background:
    radial-gradient(ellipse at 25% 15%, rgba(212, 175, 55, 0.1) 0%, transparent 50%),
    radial-gradient(ellipse at 75% 85%, rgba(107, 45, 91, 0.2) 0%, transparent 50%),
    linear-gradient(160deg,
      rgba(55, 35, 60, 0.95) 0%,
      rgba(40, 25, 50, 0.97) 40%,
      rgba(30, 18, 38, 1) 100%);
  border-radius: 4px;
  border: 2px solid var(--border-gold);
  padding: 0.25rem;
  position: relative;
  box-shadow:
    0 2px 4px rgba(0, 0, 0, 0.3),
    inset 0 0 10px rgba(212, 175, 55, 0.05);
  overflow: hidden;
}

.mini-card .mini-points {
  position: absolute;
  top: 2px;
  left: 2px;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--gold-light) 0%, var(--gold) 100%);
  color: #1a0a0a;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  font-size: 0.5rem;
  border: 1px solid var(--gold-dark);
}

.mini-card .mini-points.zero {
  background: rgba(80, 50, 70, 0.8);
  color: var(--text-muted);
  border-color: rgba(142, 69, 133, 0.5);
}

.mini-card .mini-bonus {
  position: absolute;
  top: 2px;
  right: 2px;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  border: 1px solid rgba(212, 175, 55, 0.6);
}

.mini-card .mini-cost {
  position: absolute;
  bottom: 2px;
  left: 2px;
  right: 2px;
  display: flex;
  flex-wrap: wrap;
  gap: 1px;
}

.mini-card .mini-cost-item {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.4rem;
  font-weight: bold;
  border: 1px solid rgba(212, 175, 55, 0.3);
}

/* Game Over Modal */
.game-over-content {
  text-align: center;
  min-width: 400px;
}

.winner-display {
  font-size: 2rem;
  margin-bottom: 1.5rem;
  font-family: 'MedievalSharp', serif;
}

.winner-display .winner-name {
  color: var(--gold-light);
  font-weight: bold;
  text-shadow: 0 0 15px rgba(212, 175, 55, 0.5);
}

.final-scores {
  text-align: left;
}

.final-score-row {
  display: flex;
  justify-content: space-between;
  padding: 0.75rem;
  border-bottom: 1px solid rgba(212, 175, 55, 0.2);
  font-family: 'Cinzel', serif;
}

.final-score-row:first-child {
  background: linear-gradient(90deg, rgba(212, 175, 55, 0.2) 0%, transparent 100%);
  border-radius: 4px;
  border-left: 3px solid var(--gold);
}

/* Responsive - horizontal layout adjustments */
@media (max-width: 1400px) {
  .game-board {
    gap: 1rem;
    padding: 0.75rem 1rem;
  }

  .tier {
    gap: 0.75rem;
  }

  .card-row {
    gap: 0.5rem;
  }

  .players-section-game {
    min-width: 180px;
    max-width: 220px;
  }

  .gems-section {
    min-width: 90px;
  }
}

@media (max-width: 1100px) {
  .game-board {
    gap: 0.75rem;
    padding: 0.5rem;
  }

  .tier {
    gap: 0.5rem;
  }

  .card-row {
    gap: 0.4rem;
  }

  .market-card .points {
    font-size: 1rem;
  }

  .market-card .bonus {
    width: 28px;
    height: 28px;
  }

  .players-section-game {
    min-width: 160px;
    max-width: 200px;
    padding: 0.75rem;
  }

  .gems-section {
    min-width: 80px;
    padding: 0.75rem;
  }

  .bank-gem .gem-token {
    width: min(36px, 4vh);
    height: min(36px, 4vh);
    font-size: 0.9rem;
  }

  .bank-gem .gem-label {
    font-size: 0.55rem;
    min-width: 40px;
  }
}
