/* ============================================================
   Vampires vs. Werewolves — Badges, Tags, Modals, Tables
   ============================================================ */

/* ── Badges ── */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 10px;
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.badge-vampire  { background: rgba(139,0,0,0.25);   color: #ff6666; border: 1px solid var(--color-vampire); }
.badge-werewolf { background: rgba(45,90,39,0.25);  color: #66cc66; border: 1px solid var(--color-werewolf); }
.badge-common   { background: rgba(154,154,154,0.2); color: var(--color-common); }
.badge-uncommon { background: rgba(76,175,125,0.2);  color: var(--color-uncommon); }
.badge-rare     { background: rgba(74,128,192,0.2);  color: var(--color-rare); }
.badge-epic     { background: rgba(168,85,247,0.2);  color: var(--color-epic); }
.badge-legendary{ background: rgba(249,115,22,0.2);  color: var(--color-legendary); }
.badge-level    { background: var(--color-surface-2); color: var(--color-gold); border: 1px solid var(--color-gold); }
.badge-success  { background: rgba(76,175,125,0.2);  color: var(--color-success); }
.badge-danger   { background: rgba(207,68,68,0.2);   color: var(--color-danger); }

/* ── Toast Notifications ── */
.toast-container {
  position: fixed;
  top: calc(var(--header-height) + 12px);
  right: var(--space-md);
  z-index: 9999;
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  pointer-events: none;
}

.toast {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-sm) var(--space-md);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-modal);
  min-width: 260px;
  max-width: 340px;
  pointer-events: all;
  animation: toastEnter 0.3s ease-out;
  font-size: var(--text-sm);
}

.toast.exit { animation: toastExit 0.3s ease-in forwards; }

.toast.success { border-left: 4px solid var(--color-success); }
.toast.error   { border-left: 4px solid var(--color-danger);  }
.toast.warning { border-left: 4px solid var(--color-warning); }
.toast.info    { border-left: 4px solid var(--color-info);    }

.toast-icon { font-size: var(--text-lg); }
.toast-msg  { flex: 1; }
.toast-close {
  background: none; border: none; cursor: pointer;
  color: var(--color-text-muted); font-size: var(--text-lg);
  padding: 0 4px; line-height: 1;
}

@keyframes toastEnter {
  from { opacity: 0; transform: translateX(100%); }
  to   { opacity: 1; transform: translateX(0); }
}
@keyframes toastExit {
  from { opacity: 1; transform: translateX(0); }
  to   { opacity: 0; transform: translateX(100%); }
}

/* ── Modal ── */
.modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.75);
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-md);
  animation: fadeIn 0.2s ease;
}

.modal-backdrop.hidden { display: none; }

.modal {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-xl);
  max-width: 480px;
  width: 100%;
  box-shadow: var(--shadow-modal);
  animation: modalSlideIn 0.25s ease-out;
}

@keyframes fadeIn    { from { opacity: 0; } to { opacity: 1; } }
@keyframes modalSlideIn {
  from { opacity: 0; transform: scale(0.9) translateY(-20px); }
  to   { opacity: 1; transform: scale(1) translateY(0); }
}

.modal-title {
  font-family: var(--font-gothic);
  font-size: var(--text-xl);
  margin-bottom: var(--space-md);
  letter-spacing: 0.04em;
}

.modal-body  { margin-bottom: var(--space-lg); color: var(--color-text-muted); }
.modal-footer {
  display: flex;
  gap: var(--space-sm);
  justify-content: flex-end;
}

/* ── Tables ── */
.table-wrap { overflow-x: auto; }

table {
  width: 100%;
  font-size: var(--text-sm);
}

thead tr {
  background: var(--color-surface-2);
  border-bottom: 2px solid var(--color-border);
}

th {
  font-family: var(--font-gothic);
  font-size: var(--text-xs);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  padding: var(--space-sm) var(--space-md);
  text-align: left;
}

td {
  padding: var(--space-sm) var(--space-md);
  border-bottom: 1px solid var(--color-border);
}

tbody tr {
  transition: background var(--transition-fast);
}

tbody tr:hover { background: var(--color-surface-2); }

tbody tr:nth-child(even) { background: rgba(255,255,255,0.015); }

/* ── Forms ── */
.form-group { margin-bottom: var(--space-md); }

label {
  display: block;
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin-bottom: var(--space-xs);
  font-family: var(--font-gothic);
  letter-spacing: 0.04em;
}

input[type="text"],
input[type="email"],
input[type="password"],
select, textarea {
  width: 100%;
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 10px var(--space-md);
  color: var(--color-text);
  font-size: var(--text-base);
  transition: border-color var(--transition-fast);
  min-height: 44px;
}

input:focus, select:focus, textarea:focus {
  outline: none;
  border-color: var(--color-accent);
  box-shadow: 0 0 0 2px var(--color-accent-glow);
}

input.error { border-color: var(--color-danger); }
.form-error {
  color: var(--color-danger);
  font-size: var(--text-xs);
  margin-top: var(--space-xs);
}

/* ── Damage float numbers ── */
.damage-float {
  position: fixed;
  font-weight: 700;
  font-size: var(--text-lg);
  pointer-events: none;
  z-index: 999;
  animation: floatUp 1.2s ease-out forwards;
  text-shadow: 0 1px 4px rgba(0,0,0,0.8);
}
.damage-float.damage  { color: var(--color-danger); }
.damage-float.crit    { color: #ff9900; font-size: var(--text-xl); }
.damage-float.heal    { color: var(--color-success); }
.damage-float.miss    { color: var(--color-text-muted); font-style: italic; font-size: var(--text-sm); }

@keyframes floatUp {
  0%   { opacity: 1; transform: translateY(0) scale(1); }
  30%  { opacity: 1; transform: translateY(-30px) scale(1.1); }
  100% { opacity: 0; transform: translateY(-70px) scale(0.8); }
}

/* ── Level Up Splash ── */
.level-up-splash {
  position: fixed;
  inset: 0;
  z-index: 9998;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  background: rgba(0,0,0,0.7);
  animation: levelUpShow 2.8s ease-in-out forwards;
  pointer-events: none;
}

.level-up-text {
  font-family: var(--font-gothic);
  font-size: 56px;
  font-weight: 700;
  color: var(--color-gold);
  text-shadow: 0 0 40px var(--color-gold-glow), 0 0 80px var(--color-gold-glow);
  letter-spacing: 0.1em;
  text-align: center;
}

@keyframes levelUpShow {
  0%   { opacity: 0; }
  15%  { opacity: 1; }
  70%  { opacity: 1; }
  100% { opacity: 0; }
}
