/* ============================================================
   Vampires vs. Werewolves — Cards
   ============================================================ */

.card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  box-shadow: var(--shadow-card);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.card:hover {
  border-color: var(--color-accent);
}

.card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-md);
  padding-bottom: var(--space-sm);
  border-bottom: 1px solid var(--color-border);
}

.card-title {
  font-family: var(--font-gothic);
  font-size: var(--text-lg);
  font-weight: 700;
  letter-spacing: 0.04em;
}

.card-body { /* default */ }

.card-footer {
  margin-top: var(--space-md);
  padding-top: var(--space-sm);
  border-top: 1px solid var(--color-border);
  display: flex;
  gap: var(--space-sm);
}

/* ── Race cards (landing page) ── */
.race-card {
  background: var(--color-surface);
  border: 2px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-xl);
  text-align: center;
  cursor: pointer;
  transition: all var(--transition-base);
  position: relative;
  overflow: hidden;
}

.race-card::before {
  content: '';
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity var(--transition-base);
}

.race-card.vampire::before {
  background: radial-gradient(ellipse at top, rgba(139,0,0,0.15), transparent 70%);
}
.race-card.werewolf::before {
  background: radial-gradient(ellipse at top, rgba(45,90,39,0.15), transparent 70%);
}

.race-card:hover::before { opacity: 1; }

.race-card.vampire:hover {
  border-color: var(--color-vampire);
  box-shadow: 0 8px 32px var(--color-vampire-glow);
  transform: translateY(-4px);
}
.race-card.werewolf:hover {
  border-color: var(--color-werewolf);
  box-shadow: 0 8px 32px var(--color-werewolf-glow);
  transform: translateY(-4px);
}

.race-card.selected.vampire {
  border-color: var(--color-vampire);
  box-shadow: 0 0 0 2px var(--color-vampire), 0 8px 32px var(--color-vampire-glow);
}
.race-card.selected.werewolf {
  border-color: var(--color-werewolf);
  box-shadow: 0 0 0 2px var(--color-werewolf), 0 8px 32px var(--color-werewolf-glow);
}

.race-icon {
  font-size: 80px;
  display: block;
  margin-bottom: var(--space-md);
  filter: drop-shadow(0 4px 12px currentColor);
}

.race-name {
  font-family: var(--font-gothic);
  font-size: var(--text-2xl);
  font-weight: 700;
  letter-spacing: 0.08em;
  margin-bottom: var(--space-sm);
}

.race-card.vampire .race-name { color: var(--color-vampire); }
.race-card.werewolf .race-name { color: var(--color-werewolf); }

.race-desc {
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  margin-bottom: var(--space-md);
  line-height: 1.6;
}

.race-stats {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
  text-align: left;
  margin-bottom: var(--space-md);
}

.race-stat-row {
  display: flex;
  justify-content: space-between;
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}

.race-stat-bar-wrap {
  flex: 1;
  height: 4px;
  background: var(--color-surface-2);
  border-radius: 2px;
  margin: 0 var(--space-sm);
  overflow: hidden;
}

.race-stat-bar {
  height: 100%;
  border-radius: 2px;
  transition: width 0.6s ease;
}

/* ── Item cards ── */
.item-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-sm);
  text-align: center;
  cursor: pointer;
  transition: all var(--transition-fast);
  position: relative;
}

.item-card:hover {
  border-color: var(--color-accent);
  transform: scale(1.03);
}

.item-icon {
  font-size: 36px;
  display: block;
  margin-bottom: var(--space-xs);
  height: 44px;
  line-height: 44px;
}

.item-name {
  font-size: var(--text-xs);
  font-weight: 600;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Rarity border */
.item-card.common    { border-color: var(--color-common); }
.item-card.uncommon  { border-color: var(--color-uncommon); }
.item-card.rare      { border-color: var(--color-rare); }
.item-card.epic      { border-color: var(--color-epic); }
.item-card.legendary {
  border-color: var(--color-legendary);
  animation: legendaryGlow 2s ease-in-out infinite;
}

@keyframes legendaryGlow {
  0%, 100% { box-shadow: 0 0 8px rgba(249,115,22,0.3); }
  50%       { box-shadow: 0 0 20px rgba(249,115,22,0.6); }
}

/* Monster card */
.monster-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  display: flex;
  align-items: center;
  gap: var(--space-md);
  transition: all var(--transition-fast);
}
.monster-card:hover {
  border-color: var(--color-danger);
  background: var(--color-surface-2);
}
.monster-icon { font-size: 48px; min-width: 56px; text-align: center; }
.monster-info { flex: 1; }
.monster-name { font-family: var(--font-gothic); font-weight: 700; }
.monster-level { font-size: var(--text-xs); color: var(--color-text-muted); }
