/* =============================================================
   cards.css — Ornate weapon & spell cards (Phase 10 UI Overhaul)
   These override/enhance the base card styles from components.css.
   Cards are designed to look like entries in a magical tome.
   fracturedveildnd.com
   ============================================================= */

/* ── Shared card base ─────────────────────────────────────── */

.weapon-card,
.spell-card,
.feature-card {
  background: var(--surface);
  border: var(--border-ornate);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  margin-bottom: var(--spacing-sm);
  overflow: hidden;
  transition: box-shadow var(--transition), transform var(--transition);
}

.weapon-card:hover,
.spell-card:hover,
.feature-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-1px);
}

/* ── Weapon card — blood-red left accent ──────────────────── */

.weapon-card {
  border-left: 3px solid var(--blood);
}

/* ── Spell card — gold left accent ───────────────────────── */

.spell-card {
  border-left: 3px solid var(--gold);
  /* border-left-color overridden per-school via inline style in JS */
}

/* ── Feature card — gold left accent ─────────────────────── */

.feature-card {
  border-left: 3px solid var(--gold);
}

/* ── Card name ────────────────────────────────────────────── */

.wc-name {
  font-family: var(--font-display);
  font-size: 1.05rem;
  color: var(--blood);
  margin: 0;
  line-height: 1.2;
}

.sc-name {
  font-family: var(--font-display);
  font-size: 1rem;
  color: var(--gold-dark);
  margin: 0;
  line-height: 1.2;
}

.feat-name {
  font-family: var(--font-display);
  font-size: 0.95rem;
  color: var(--ink);
  margin: 0;
  line-height: 1.2;
}

/* ── Stat pills (damage dice, type, range) ────────────────── */

.card-stat-pill,
.wc-meta span,
.sc-meta-item {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  background: var(--surface-deep);
  border: var(--border-ornate);
  font-size: 0.7rem;
  font-family: var(--font-body);
  color: var(--ink-muted);
  padding: 2px 7px;
  border-radius: 2px;
}

/* Damage dice gets slightly stronger emphasis */
.wc-dice {
  font-weight: 700;
  color: var(--ink);
  font-size: 0.95rem;
  background: none;
  border: none;
  padding: 0;
}

/* ── Roll buttons ─────────────────────────────────────────── */

.wc-btn--attack,
.wc-btn--damage,
.sc-btn--attack,
.sc-btn--damage,
.sc-btn--save,
.feat-btn--roll,
.feat-btn--use {
  font-family: var(--font-body);
  font-weight: 700;
  font-size: 0.78rem;
  padding: 0.4rem 1rem;
  border-radius: 2px;
  border: none;
  cursor: pointer;
  transition: background var(--transition), transform var(--transition);
}

.wc-btn--attack,
.wc-btn--damage,
.feat-btn--roll {
  background: var(--blood);
  color: var(--parchment);
}

.wc-btn--attack:hover,
.wc-btn--damage:hover,
.feat-btn--roll:hover {
  background: var(--blood-dark);
}

.wc-btn--attack:active,
.wc-btn--damage:active,
.feat-btn--roll:active {
  transform: scale(0.97);
}

.wc-btn--attack:disabled,
.wc-btn--damage:disabled,
.feat-btn--roll:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  transform: none;
}

.sc-btn--attack,
.sc-btn--damage {
  background: var(--blood);
  color: var(--parchment);
}

.sc-btn--attack:hover,
.sc-btn--damage:hover {
  background: var(--blood-dark);
}

.sc-btn--attack:active,
.sc-btn--damage:active {
  transform: scale(0.97);
}

.sc-btn--save,
.feat-btn--use {
  background: var(--done-green);
  color: var(--parchment);
}

.sc-btn--save:hover {
  background: #1A4D2C;
}

.feat-btn--use:hover {
  background: #8B6914;
}

.feat-btn--use {
  background: var(--gold);
}

.feat-btn--use:active,
.sc-btn--save:active {
  transform: scale(0.97);
}

.feat-btn--use:disabled,
.sc-btn--save:disabled,
.sc-btn--attack:disabled,
.sc-btn--damage:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  transform: none;
}

/* ── Source badge ─────────────────────────────────────────── */

.card-source-badge {
  display: inline-block;
  font-size: 0.6rem;
  font-family: var(--font-body);
  font-weight: 700;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  padding: 1px 5px;
  border-radius: 2px;
  vertical-align: middle;
}

.card-source-badge--srd {
  background: rgba(26, 77, 110, 0.12);
  color: var(--archive-blue);
  border: 1px solid rgba(26, 77, 110, 0.25);
}

.card-source-badge--homebrew {
  background: rgba(196, 146, 42, 0.12);
  color: var(--gold-dark);
  border: var(--border-gold);
}

.card-source-badge--manual {
  background: rgba(107, 87, 64, 0.1);
  color: var(--ink-muted);
  border: 1px solid rgba(107, 87, 64, 0.2);
}

/* ── Property tags (Finesse, Versatile, Light, etc.) ─────── */

.card-properties,
.wc-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-top: 4px;
}

.badge-pill,
.card-prop-tag {
  display: inline-block;
  background: var(--surface-deep);
  color: var(--ink-muted);
  border: var(--border-ornate);
  border-radius: 2px;
  padding: 1px 6px;
  font-size: 0.65rem;
  font-family: var(--font-body);
  font-weight: 700;
  letter-spacing: 0.03em;
  text-transform: capitalize;
  white-space: nowrap;
}

.badge-pill--magical {
  background: rgba(46, 26, 78, 0.15);
  color: #7A50C8;
  border-color: rgba(122, 80, 200, 0.3);
}

.badge-pill--prof {
  background: rgba(46, 107, 62, 0.12);
  color: var(--done-green);
  border-color: rgba(46, 107, 62, 0.3);
}

.badge-pill--noprof {
  background: rgba(139, 26, 26, 0.08);
  color: var(--blood);
  border-color: rgba(139, 26, 26, 0.2);
}

/* ── Active effects panel overrides ──────────────────────── */

.aep-row {
  background: var(--surface-deep);
  border: var(--border-ornate);
  border-radius: var(--radius);
  transition: background var(--transition);
}

.aep-modifier {
  color: var(--gold-dark);
}

/* ── Initiative tracker row enhancements ─────────────────── */

.it-row {
  border: var(--border-ornate);
  border-radius: var(--radius);
  background: var(--surface);
  transition: border-color var(--transition), background var(--transition), box-shadow var(--transition);
}

.it-row--active {
  border-color: var(--gold);
  background: rgba(196, 146, 42, 0.06);
  box-shadow: 0 0 0 2px rgba(196, 146, 42, 0.2);
}

.it-type-badge--pc {
  background: rgba(46, 107, 62, 0.12);
  color: var(--done-green);
  border: 1px solid rgba(46, 107, 62, 0.3);
}

.it-type-badge--npc {
  background: rgba(139, 26, 26, 0.1);
  color: var(--blood);
  border: 1px solid rgba(139, 26, 26, 0.25);
}
