/* ===================== DEADMAN'S CROSS - theme ===================== */
:root {
  --bg: #0a0a0d;
  --panel: #16131a;
  --ink: #e7e2d8;
  --muted: #8a8275;
  --blood: #8e1c20;
  --gold: #c8a45a;

  --r-common: #6b6b6b;
  --r-rare:   #3f7fb0;
  --r-super:  #8a4fb0;
  --r-ultra:  #c8a45a;
  --r-legend: #cf5a2a;

  --aff-spirit: #6fb6c9;
  --aff-flesh:  #b07a5a;
  --aff-blood:  #b03442;
  --aff-void:   #9b8fb0;
}

* { box-sizing: border-box; }
html, body {
  margin: 0; height: 100%;
  background: #000 url('art/board-bg.png') center/cover no-repeat;
  background-color: var(--bg);
  color: var(--ink);
  font-family: "Trebuchet MS", "Segoe UI", system-ui, sans-serif;
}
body::before {
  content: ""; position: fixed; inset: 0;
  background: radial-gradient(ellipse at center, rgba(0,0,0,0.45), rgba(0,0,0,0.85));
  pointer-events: none; z-index: 0;
}

.screen { position: relative; z-index: 1; min-height: 100vh; }
.hidden { display: none !important; }

/* ---------- Lobby ---------- */
#lobby, #gameover { display: flex; align-items: center; justify-content: center; }
.lobby-box {
  background: rgba(12,10,14,0.85);
  border: 1px solid #2a242f;
  border-radius: 10px;
  padding: 32px 40px; max-width: 520px; text-align: center;
  box-shadow: 0 0 60px rgba(142,28,32,0.25);
}
#logo { max-width: 280px; margin-bottom: 8px; }
.title {
  font-size: 44px; letter-spacing: 6px; margin: 6px 0;
  color: var(--ink); text-shadow: 0 0 18px var(--blood);
  font-family: "Georgia", serif; font-weight: 700;
}
.subtitle { color: var(--muted); margin-top: 0; }
#nameInput {
  display: block; width: 100%; margin: 18px 0; padding: 12px;
  background: #0c0a0e; border: 1px solid #3a3340; color: var(--ink);
  border-radius: 6px; font-size: 16px; text-align: center;
}
button {
  background: linear-gradient(180deg, #b3262b, #6e1417);
  color: #fff; border: 1px solid #d8b27a40; padding: 12px 28px;
  font-size: 16px; letter-spacing: 2px; border-radius: 6px; cursor: pointer;
  font-weight: 700; transition: filter .15s, transform .05s;
}
button:hover { filter: brightness(1.15); }
button:active { transform: translateY(1px); }
button:disabled { filter: grayscale(.8) brightness(.6); cursor: default; }
.status { color: var(--gold); min-height: 22px; margin-top: 14px; }
.rules { margin-top: 18px; text-align: left; color: var(--muted); font-size: 13px; }
.rules summary { cursor: pointer; color: var(--gold); }
.rules li { margin: 4px 0; }

/* ---------- Game layout ---------- */
#game { display: flex; flex-direction: column; gap: 6px; padding: 8px; min-height: 100vh; }
.hero-row { display: flex; align-items: center; justify-content: center; gap: 16px; }
.hero {
  display: flex; align-items: center; gap: 12px;
  background: rgba(14,12,16,0.7); border: 1px solid #2a242f;
  border-radius: 10px; padding: 6px 14px; min-width: 320px;
}
.hero.targetable { outline: 2px solid var(--blood); cursor: crosshair; box-shadow: 0 0 16px var(--blood); }
.hero-portrait { width: 56px; height: 56px; border-radius: 50%; overflow: hidden;
  background: #241b22 url('art/skull.png') center/cover; border: 2px solid #4a3f33; }
.hero-portrait img { width: 100%; height: 100%; object-fit: cover; }
.hero-stats { display: flex; flex-direction: column; line-height: 1.3; }
.hero-name { font-weight: 700; color: var(--gold); }
.hero-life { color: #e06a6a; font-weight: 700; }
.hero-life::before { content: "♥ "; }
.hero-mana { color: var(--aff-spirit); }
.hero-mana::before { content: "✦ "; }
.hero-cards { color: var(--muted); font-size: 12px; }

.divider { text-align: center; color: var(--muted); letter-spacing: 4px; font-size: 12px; opacity: .8; }
#turnBanner.my-turn { color: var(--gold); text-shadow: 0 0 10px var(--gold); }

.board {
  display: flex; gap: 8px; justify-content: center; align-items: center;
  min-height: 130px; padding: 6px; flex-wrap: wrap;
}

#endTurnBtn { margin-left: 10px; }

/* ---------- Cards ---------- */
.hand { display: flex; gap: 8px; justify-content: center; flex-wrap: wrap; padding-top: 6px; }

.card {
  position: relative; width: 120px; height: 168px; border-radius: 10px;
  background: #14111a; border: 2px solid var(--r-common);
  overflow: hidden; cursor: pointer; user-select: none;
  box-shadow: 0 4px 12px rgba(0,0,0,.6); transition: transform .1s;
}
.card:hover { transform: translateY(-6px); }
.card.rarity-rare   { border-color: var(--r-rare); }
.card.rarity-super  { border-color: var(--r-super); }
.card.rarity-ultra  { border-color: var(--r-ultra); box-shadow: 0 0 16px var(--r-ultra); }
.card.rarity-legend { border-color: var(--r-legend); box-shadow: 0 0 20px var(--r-legend); }

.card-art { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 1; }
.card-art-fallback { position: absolute; inset: 0; z-index: 0;
  background: linear-gradient(160deg, #2a1f2b, #0c0a0e); }
.card-frame { position: absolute; inset: 0; z-index: 2; background-size: 100% 100%;
  background-repeat: no-repeat; pointer-events: none; }

.card-cost, .card-atk, .card-hp {
  position: absolute; z-index: 3; width: 26px; height: 26px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center; font-weight: 800;
  font-size: 15px; color: #fff; text-shadow: 0 1px 2px #000;
  border: 1px solid rgba(0,0,0,.5);
}
.card-cost { top: 4px; left: 4px; background: radial-gradient(circle, #4a7fc0, #1b3a66); }
.card-atk  { bottom: 4px; left: 4px; background: radial-gradient(circle, #d8b048, #7a5b14); }
.card-hp   { bottom: 4px; right: 4px; background: radial-gradient(circle, #d85a5a, #6e1414); }

.card-name {
  position: absolute; z-index: 3; bottom: 34px; left: 0; right: 0; text-align: center;
  font-size: 11px; font-weight: 700; color: #fff; text-shadow: 0 1px 3px #000;
  padding: 0 4px;
}
.card-aff {
  position: absolute; z-index: 3; top: 4px; right: 4px; width: 20px; height: 20px;
  border-radius: 50%; border: 1px solid rgba(0,0,0,.6);
}
.aff-SPIRIT { background: var(--aff-spirit); }
.aff-FLESH  { background: var(--aff-flesh); }
.aff-BLOOD  { background: var(--aff-blood); }
.aff-VOID   { background: var(--aff-void); }

.card-kw { position: absolute; z-index: 3; top: 28px; left: 0; right: 0; text-align: center;
  font-size: 9px; letter-spacing: 1px; color: var(--gold); text-shadow: 0 1px 2px #000; }

/* ---------- Board minions ---------- */
.minion { width: 96px; height: 128px; }
.minion.can-attack { box-shadow: 0 0 10px 2px #6fc97a; }
.minion.selected { outline: 3px solid var(--gold); box-shadow: 0 0 18px var(--gold); }
.minion.targetable { outline: 2px solid var(--blood); cursor: crosshair; }
.minion .card-name { bottom: 30px; font-size: 9px; }
.minion .card-cost { display: none; }
.minion.taunt::after {
  content: "GUARDIAN"; position: absolute; z-index: 3; top: 2px; left: 0; right: 0;
  text-align: center; font-size: 8px; letter-spacing: 1px; color: #cdb27a;
  text-shadow: 0 1px 2px #000;
}

/* ---------- Card back (opponent hand, decorative) ---------- */
.cardback {
  width: 40px; height: 56px; border-radius: 6px;
  background: #1a1420 url('art/card-back.png') center/cover; border: 1px solid #3a3340;
}

/* ---------- Toast ---------- */
.toast {
  position: fixed; top: 14px; left: 50%; transform: translateX(-50%); z-index: 50;
  background: rgba(120,20,24,0.95); color: #fff; padding: 10px 20px; border-radius: 6px;
  box-shadow: 0 4px 20px rgba(0,0,0,.7); font-weight: 600;
}
