/* PlayerCard styles — Fortified Fantasy */
:root {
  --pcard-bg: #0f1220;
  --pcard-ink: #e9ecf4;
  --pcard-dim: #a6afc3;
  --pcard-accent: #4a8cff;
  --pcard-accent-weak: rgba(74, 140, 255, 0.2);
  --pcard-surface: #161a2b;
  --pcard-line: rgba(255,255,255,0.08);
  --pcard-bad: #ff6b6b;
}

.pcard-no-scroll { overflow: hidden; }

.pcard-overlay {
  position: fixed; inset: 0; z-index: 1000;
  display: grid; place-items: center;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial;
  color: var(--pcard-ink);
}

.pcard-overlay.hidden { display: none; }

.pcard-backdrop {
  position: absolute; inset: 0; background: rgba(0,0,0,0.6); backdrop-filter: blur(2px);
}

.pcard-modal {
  position: relative;
  width: min(1100px, calc(100vw - 24px));
  max-height: calc(100vh - 24px);
  background: var(--pcard-bg);
  border: 1px solid var(--pcard-line);
  border-radius: 16px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.5);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.pcard-header {
  display: flex; align-items: center; gap: 8px;
  padding: 12px 14px; background: var(--pcard-surface);
  border-bottom: 1px solid var(--pcard-line);
}

.pcard-title { font-weight: 700; letter-spacing: 0.2px; }
.pcard-spacer { flex: 1; }

.pcard-btn {
  appearance: none; border: 1px solid var(--pcard-line);
  background: linear-gradient(180deg, rgba(255,255,255,0.03), rgba(0,0,0,0.08));
  color: var(--pcard-ink);
  padding: 6px 10px; border-radius: 10px; cursor: pointer; font-weight: 600;
}
.pcard-btn:hover { border-color: var(--pcard-accent); box-shadow: 0 0 0 3px var(--pcard-accent-weak) inset; }
.pcard-close { font-size: 20px; line-height: 1; padding: 4px 10px; }

.pcard-toolbar {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 14px; border-bottom: 1px solid var(--pcard-line);
}
.pcard-status { margin-left: auto; opacity: 0; transition: opacity .2s; color: var(--pcard-ink); }
.pcard-status.show { opacity: 1; }

.pcard-compare-area {
  display: grid; grid-template-columns: 1fr; gap: 0;
  overflow: auto;
}

.pcard-cards {
  display: grid; gap: 12px; padding: 14px;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

.pcard-card {
  background: var(--pcard-surface);
  border: 1px solid var(--pcard-line);
  border-radius: 14px; padding: 12px;
  display: flex; flex-direction: column; gap: 10px;
}

.pcard-headrow {
  display: grid; grid-template-columns: 52px 1fr 64px; gap: 10px; align-items: center;
}
.pcard-id {
  font-variant-numeric: tabular-nums; opacity: .6; font-size: 12px;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--pcard-line); border-radius: 8px; padding: 6px; text-align: center;
}
.pcard-nameblock { display: flex; flex-direction: column; gap: 4px; }
.pcard-name { font-weight: 800; letter-spacing: .2px; }
.pcard-sub { font-size: 12px; color: var(--pcard-dim); }
.pcard-headshot {
  width: 64px; height: 64px; object-fit: cover; border-radius: 10px; background: #0b0d18; border: 1px solid var(--pcard-line);
}

.pcard-grid {
  display: grid; gap: 8px; grid-template-columns: repeat(4, 1fr);
}
.pcard-cell {
  background: rgba(255,255,255,0.03); border: 1px solid var(--pcard-line);
  border-radius: 10px; padding: 8px;
}
.pcard-k { font-size: 11px; color: var(--pcard-dim); }
.pcard-v { font-weight: 700; letter-spacing: .2px; margin-top: 2px; }

.pcard-actions { display: flex; justify-content: flex-end; }
.pcard-remove { border-color: rgba(255,255,255,0.08); }
.pcard-remove:hover { border-color: var(--pcard-bad); box-shadow: 0 0 0 3px rgba(255, 107, 107, 0.15) inset; }

.pcard-search {
  border-top: 1px solid var(--pcard-line);
  display: none; padding: 10px 14px; background: rgba(10,10,20,0.6);
}
.pcard-search.show { display: block; }

.pcard-search-row { display: flex; gap: 8px; align-items: center; }
.pcard-input {
  width: 100%; padding: 10px 12px; border-radius: 10px;
  border: 1px solid var(--pcard-line); background: #0b0e1a; color: var(--pcard-ink);
  font-size: 14px; outline: none;
}
.pcard-input:focus { border-color: var(--pcard-accent); box-shadow: 0 0 0 3px var(--pcard-accent-weak); }
.pcard-search-clear { white-space: nowrap; }

.pcard-search-list { margin-top: 10px; display: grid; gap: 6px; }
.pcard-search-empty { color: var(--pcard-dim); font-size: 13px; padding: 8px 2px; }

.pcard-search-item {
  display: grid; grid-template-columns: 40px 1fr auto; gap: 10px; align-items: center;
  padding: 8px; border: 1px solid var(--pcard-line); border-radius: 10px; cursor: pointer;
  background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(0,0,0,0.06));
}
.pcard-search-item:hover { border-color: var(--pcard-accent); }
.pcard-search-item.disabled { opacity: .55; cursor: default; }
.pcard-search-item.disabled:hover { border-color: var(--pcard-line); }

.pcard-thumb {
  width: 40px; height: 40px; border-radius: 8px; border: 1px solid var(--pcard-line); background:#0b0d18; object-fit: cover;
}

.pcard-col { display: flex; flex-direction: column; gap: 2px; }
.pcard-pill {
  font-size: 12px; padding: 4px 8px; border-radius: 999px; border: 1px solid var(--pcard-line); color: var(--pcard-dim);
}
.pcard-pill.add { border-color: var(--pcard-accent); color: var(--pcard-ink); }
