/* ═══════════════════════════════════════════
   ECLIPSORIAN BATTLE LINES — STYLES V3
   ═══════════════════════════════════════════ */

*, *::before, *::after {
  box-sizing: border-box; margin: 0; padding: 0;
  -webkit-tap-highlight-color: transparent;   /* sin destello azul al tocar en móvil */
  -webkit-user-select: none; user-select: none;   /* sin selección de texto accidental (juego) */
  -webkit-touch-callout: none;                 /* sin menú "guardar imagen" al mantener pulsado */
}
/* Re-habilitar selección/edición SOLO en campos de texto (p. ej. el nombre en el lobby) */
input, textarea, select, [contenteditable="true"] { -webkit-user-select: text; user-select: text; }

:root {
  --bg:     #07070f;
  --bg2:    #0d0d1a;
  --bg3:    #14142a;
  --border: #1e1e35;
  --gold:   #c9a227;
  --gold2:  #6a4e0f;
  --text:   #ccc8e0;
  --dim:    #555370;
  --r:      8px;
}

html, body {
  height: 100%; background: var(--bg); color: var(--text);
  font-family: 'Segoe UI', system-ui, sans-serif;
  overflow: hidden; user-select: none;
}
.hidden { display: none !important; }


/* ════════════════════════════════════════════
   DECK BUILDER
   ════════════════════════════════════════════ */

#screen-builder {
  display: flex; flex-direction: column; height: 100vh;
  position: relative; overflow: hidden;
}

/* ─── Pool controls (filtros + orden) ─── */
#pool-controls {
  display: flex; flex-direction: column; align-items: center; gap: 7px;
  padding: 10px 14px 8px; border-bottom: 1px solid var(--border); margin-bottom: 10px;
}
.filter-bar { display: flex; gap: 5px; flex-wrap: wrap; justify-content: center; }
.filter-btn {
  padding: 4px 11px; border: 1px solid var(--border); background: var(--bg3);
  color: var(--dim); font-size: .7rem; border-radius: 20px; cursor: pointer; transition: all .15s;
}
.filter-btn:hover, .filter-btn.active { border-color: var(--gold); color: var(--gold); }

.sort-bar { display: flex; align-items: center; gap: 6px; }
.sort-label { font-size: .62rem; color: var(--dim); letter-spacing: .06em; }
.sort-btn {
  padding: 3px 10px; border: 1px solid var(--border); background: var(--bg3);
  color: var(--dim); font-size: .63rem; border-radius: 20px; cursor: pointer; transition: all .15s;
}
.sort-btn:hover, .sort-btn.active { border-color: var(--gold2); color: var(--gold); }

/* ═══════════ FILTROS NUEVOS (#6) — barra grande + radial móvil ═══════════ */
.pf-bar { display: flex; flex-wrap: wrap; justify-content: center; gap: .7rem 1.4rem; width: 100%; }
.pf-grp { display: flex; align-items: center; gap: .5rem; flex-wrap: wrap; justify-content: center; }
.pf-lbl { font-size: .6rem; letter-spacing: .16em; text-transform: uppercase; color: var(--dim); }
.pf-chips { display: flex; flex-wrap: wrap; gap: .4rem; }
.pf-sort, .pf-reg, .pf-tier {
  padding: .5rem .95rem; border: 1px solid var(--border); background: var(--bg3);
  color: #cfc9b6; font-size: .8rem; border-radius: 9px; cursor: pointer;
  transition: all .15s; font-family: inherit; letter-spacing: .02em;
}
.pf-sort:hover, .pf-reg:hover, .pf-tier:hover { border-color: rgba(201,162,39,.55); color: #e8dcc8; }
.pf-sort.active, .pf-tier.active { background: rgba(201,162,39,.18); border-color: var(--gold); color: var(--gold); font-weight: 700; }
/* Flecha de dirección — solo en el criterio activo; rota 180° al invertir el orden */
.pf-arrow {
  display: inline-flex; align-items: center; justify-content: center;
  width: .62em; height: .62em; margin-left: .4em; vertical-align: middle;
  transition: transform .28s cubic-bezier(.34,1.45,.5,1);
}
.pf-arrow svg { width: 100%; height: 100%; display: block; }
.pf-arrow.desc { transform: rotate(180deg); }
.pf-reg { display: inline-flex; align-items: center; gap: .4rem; }
.pf-reg[data-r]:not([data-r="all"])::before {
  content: ''; width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0;
  background: var(--rc, #888); box-shadow: 0 0 6px var(--rc, #888);
}
.pf-reg.active { border-color: var(--rc, var(--gold)); color: #fff; background: rgba(255,255,255,.06); box-shadow: 0 0 10px -2px var(--rc, var(--gold)); }

/* Tira de tier — solo en móvil */
.pf-tier-strip {
  display: none;
}

/* Radial flotante — oculto en escritorio */
.pf-radial { display: none; }

@media (max-width: 600px) {
  .pf-bar { display: none; }
  #pool-controls { padding: 0; border: none; margin: 0; min-height: 0; }
  .pf-tier-strip {
    display: flex; overflow-x: auto; gap: .35rem;
    scrollbar-width: none; margin-bottom: 8px; -webkit-overflow-scrolling: touch;
  }
  .pf-tier-strip::-webkit-scrollbar { display: none; }
  .pf-tier-strip .pf-tier { flex-shrink: 0; padding: .38rem .5rem; font-size: .72rem; border-radius: 7px; }

  .pf-radial { display: block; position: fixed; right: 34px; top: 46%; z-index: 6000; width: 0; height: 0; }
  .pf-fab {
    position: absolute; left: -27px; top: -27px; width: 54px; height: 54px; border-radius: 50%;
    background: radial-gradient(circle at 34% 28%, #f5e07a, #c9a227 72%);
    border: 1px solid rgba(245,224,122,.7); color: #07070d; cursor: pointer; z-index: 3;
    display: flex; align-items: center; justify-content: center;
    box-shadow: 0 0 18px rgba(201,162,42,.55), 0 4px 14px rgba(0,0,0,.55);
    transition: transform .25s, box-shadow .2s;
  }
  .pf-fab svg { width: 24px; height: 24px; }
  .pf-radial.open .pf-fab { transform: rotate(90deg); }
  .pf-radial.filtered .pf-fab { box-shadow: 0 0 26px rgba(245,224,122,.9), 0 4px 14px rgba(0,0,0,.55); }

  .pf-opt {
    position: absolute; left: -23px; top: -23px; width: 46px; height: 46px; border-radius: 50%;
    background: rgba(18,16,28,.96); border: 1px solid rgba(201,162,39,.5); color: var(--gold);
    font-size: .56rem; font-weight: 700; letter-spacing: .02em; text-transform: uppercase;
    display: flex; align-items: center; justify-content: center; text-align: center; cursor: pointer;
    opacity: 0; pointer-events: none; transform: translate(0,0) scale(.4);
    transition: transform .3s cubic-bezier(.34,1.45,.5,1), opacity .2s, background .15s, border-color .15s;
    backdrop-filter: blur(6px); box-shadow: 0 0 12px rgba(0,0,0,.6); z-index: 2;
  }
  .pf-radial.open .pf-opt { opacity: 1; pointer-events: auto; }
  .pf-radial.open.regions .pf-opt { opacity: 0; pointer-events: none; transform: translate(0,0) scale(.4); }
  .pf-radial.open .pf-opts .pf-opt:nth-child(1) { transform: translate(-60px, -82px); }
  .pf-radial.open .pf-opts .pf-opt:nth-child(2) { transform: translate(-92px, -42px); }
  .pf-radial.open .pf-opts .pf-opt:nth-child(3) { transform: translate(-104px, 0); }
  .pf-radial.open .pf-opts .pf-opt:nth-child(4) { transform: translate(-92px, 42px); }
  .pf-radial.open .pf-opts .pf-opt:nth-child(5) { transform: translate(-60px, 82px); }
  .pf-opt.pf-sort.active { background: rgba(201,162,39,.3); border-color: var(--gold); color: #fff; }
  .pf-opt { white-space: nowrap; }
  .pf-opt .pf-arrow { width: .58em; height: .58em; margin-left: .22em; }
  .pf-opt.pf-tipo { border-color: rgba(245,224,122,.7); color: #f5e07a; }

  .pf-regs {
    position: absolute; right: 30px; top: -118px; width: 170px; padding: 12px;
    display: none; flex-wrap: wrap; gap: 7px; justify-content: center;
    background: rgba(14,12,20,.98); border: 1px solid rgba(201,162,39,.45); border-radius: 14px;
    box-shadow: 0 0 24px rgba(0,0,0,.7); z-index: 4;
  }
  .pf-radial.regions .pf-regs { display: flex; }
  .pf-regs .pf-reg { padding: .4rem .55rem; font-size: .64rem; border-radius: 7px; }
}

/* ─── Deck Slots Bar ─── */
#deck-slots-bar {
  padding: 10px 16px 6px; background: var(--bg2);
  border-bottom: none; flex-shrink: 0;
  overflow-x: auto;
}

#deck-slots {
  display: flex; gap: 6px;
  justify-content: center;
  min-width: max-content; margin: 0 auto;
}

/* ─── Cost bar row ─── */
#cost-bar-row {
  display: flex; align-items: center; gap: 12px;
  padding: 6px 16px 10px; background: var(--bg2);
  border-bottom: 2px solid var(--border); flex-shrink: 0;
  justify-content: center;
}
#cost-bar-wrap {
  width: min(360px, 55vw); height: 8px;
  background: var(--bg3); border-radius: 4px; overflow: hidden;
  flex-shrink: 0;
}
#cost-bar-fill {
  height: 100%; width: 0%;
  border-radius: 4px;
  transition: width .35s ease, background .4s ease;
  background: linear-gradient(90deg,#388e3c,#66bb6a);
}
#meta-cost { font-size: .75rem; color: var(--dim); white-space: nowrap; flex-shrink: 0; }

.deck-slot {
  width: 86px; height: 118px; border-radius: var(--r);
  border: 2px dashed var(--border); background: var(--bg3);
  position: relative; overflow: hidden; flex-shrink: 0;
  transition: border-color .2s, transform .2s, box-shadow .2s;
}
.deck-slot.empty {
  display: flex; align-items: center; justify-content: center;
  color: var(--border); font-size: 1.1rem;
}
.deck-slot.filled { border-style: solid; cursor: pointer; }
.deck-slot.filled:hover {
  transform: translateY(-6px) scale(1.05);
  z-index: 20;
  box-shadow: 0 8px 18px rgba(0,0,0,.6), 0 0 8px var(--c, transparent);
}
.deck-slot.filled:hover::after {
  content: '✕'; position: absolute; inset: 0;
  background: rgba(120,0,0,.72);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.4rem; color: #ef9a9a; font-weight: 700;
}
.deck-slot img {
  width: 100%; height: 100%; object-fit: cover; object-position: top;
}
@keyframes slotStatsDrop {
  from { opacity: 0; transform: translateY(-2px) scale(.92); }
  to   { opacity: 1; transform: none; }
}
@keyframes slotNameRise {
  from { opacity: 0; transform: translateY(3px) scale(.94); }
  to   { opacity: 1; transform: none; }
}
/* Entrada inmediata al rellenar un slot (nodo nuevo → corre desde frame 0, sin rAF) */
.deck-slot-stats.anim-in { animation: slotStatsDrop .22s ease both; }
.deck-slot-name.anim-in  { animation: slotNameRise  .24s ease .05s both; }
.deck-slot-stats {
  position: absolute; top: 3px; left: 0; right: 0;
  display: flex; justify-content: space-between; padding: 0 4px;
  font-size: .48rem; font-weight: 700;
  text-shadow: 0 1px 3px rgba(0,0,0,.9);
}
.deck-slot-stats .cstat { gap: 1px; }
.deck-slot-stats .stat-ico { width: .92em; height: .92em; }
.deck-slot-name {
  position: absolute; bottom: 0; left: 0; right: 0;
  background: linear-gradient(transparent, rgba(0,0,0,.9));
  padding: 8px 3px 2px; font-size: .5rem; color: #fff;
  text-align: center; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

#btn-listo {
  padding: 9px 24px; background: var(--gold2); border: 1px solid var(--gold);
  color: var(--gold); font-size: .78rem; font-weight: 700; letter-spacing: .15em;
  border-radius: 6px; cursor: pointer; transition: all .2s; white-space: nowrap;
}
#btn-listo:hover:not(:disabled) { background: var(--gold); color: #000; }
#btn-listo:disabled { opacity: .3; cursor: not-allowed; }

/* ─── Card Pool ─── */
#pool-scroll { flex: 1; overflow-y: auto; padding: 0 14px 14px; }
#card-pool {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(118px, 1fr));
  gap: 10px;
}

/* Pool card — gira solo al pulsar el ojo (no hover) */
.pool-card {
  width: 100%; aspect-ratio: 9/13; border-radius: var(--r);
  border: 2px solid var(--border);
  position: relative; cursor: pointer;
  transform-style: preserve-3d;
  transition: transform .55s cubic-bezier(.4,0,.2,1), box-shadow .2s,
              opacity .3s ease, filter .3s ease, border-color .3s ease;
}
.pool-card:not(.flipped):not(.in-deck):not(.viewing):hover {
  transform: translateY(-4px);
  box-shadow: 0 10px 26px rgba(0,0,0,.7), 0 0 10px var(--c, transparent);
}
.pool-card.viewing { pointer-events: none; }
.pool-card.flipped {
  transform: rotateY(180deg) translateY(-6px);
  box-shadow: 0 14px 32px rgba(0,0,0,.9), 0 0 18px var(--c, transparent);
}
/* En el mazo: claramente más grises que las disponibles */
.pool-card.in-deck { opacity: .82; filter: grayscale(.5); }
.pool-card.in-deck:hover { opacity: 1; filter: grayscale(.1); }
/* Sin puntos suficientes: casi negras (máximo contraste con las usables) */
.pool-card.blocked {
  filter: grayscale(1) brightness(.2);
  opacity: .6; pointer-events: none;
}
.pool-card.dimmed {
  filter: grayscale(.65) brightness(.55);
  opacity: .45;
}
.pool-card.dimmed:hover { opacity: .7; filter: grayscale(.4) brightness(.7); }

/* Caras */
.card-face {
  position: absolute; inset: 0;
  backface-visibility: hidden;
  border-radius: calc(var(--r) - 1px);
  overflow: hidden;
}
.card-front { display: flex; flex-direction: column; background: var(--bg2); }
.card-back  { transform: rotateY(180deg); }

/* Frente */
.card-front img {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; object-position: top; display: block;
}
/* Sombra interna superior de la carta → contraste para TODOS los stats de arriba (sin text-shadow por stat) */
.card-front::before, .card-viewer-card .cv-front::before {
  content: ''; position: absolute; left: 0; right: 0; top: 0; height: 32%;
  background: linear-gradient(180deg, rgba(0,0,0,.7), rgba(0,0,0,.28) 55%, transparent);
  pointer-events: none; z-index: 1;
}
.pool-card-footer { padding: 5px 6px; background: rgba(0,0,0,.85); flex-shrink: 0; }
.pool-card-name {
  font-size: .62rem; font-weight: 600; color: #fff;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  text-shadow: 0 1px 3px rgba(0,0,0,.9); padding-right: 18px;
}
/* Badge del tier (número romano) al inicio del nombre */
.name-tier {
  display: inline-block; vertical-align: middle; margin-right: 4px;
  font-size: .5rem; font-weight: 800; color: #000;
  padding: 1px 4px; border-radius: 3px; letter-spacing: .02em; text-shadow: none;
}
.pool-card-stats { display: flex; justify-content: space-between; margin-top: 2px; font-size: .6rem; }
/* Stats SIEMPRE visibles ARRIBA (vida·poder·defensa), sobre la imagen — como en los slots del mazo */
.pool-card-statbar {
  position: absolute; top: 4px; left: 5px; right: 5px; z-index: 4;
  display: flex; align-items: center; gap: 4px;
}
.pool-card-statbar .cstat { font-size: .58rem; }
/* Overlay inferior: solo el nombre (con badge de tier al inicio) */
.pool-card-bottom {
  position: absolute; left: 0; right: 0; bottom: 0;
  background: linear-gradient(transparent, rgba(0,0,0,.9));
  padding: 14px 6px 5px;
}
.pool-card-rango {
  position: absolute; top: 5px; left: 5px;
  font-size: .5rem; font-weight: 700; padding: 2px 5px;
  border-radius: 4px; color: #000; letter-spacing: .04em; text-transform: uppercase;
}
.pool-card-cost {
  position: absolute; top: 5px; right: 6px; z-index: 4;
  font-size: .58rem;
}
.card-remove-overlay {
  position: absolute; inset: 0;
  background: rgba(120,0,0,.78); color: #ef9a9a;
  font-size: .8rem; font-weight: 700; letter-spacing: .05em;
  display: none; align-items: center; justify-content: center;
}
.pool-card.in-deck:hover .card-remove-overlay { display: flex; }

/* Dorso */
.card-back {
  background: linear-gradient(155deg, #0a0a18 0%, #16082a 60%, #0a0a18 100%);
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  padding: 10px 8px; gap: 5px; text-align: center;
}
.card-back-name {
  font-size: .68rem; font-weight: 700; color: var(--gold); letter-spacing: .06em;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; width: 100%;
}
.card-back-region { font-size: .52rem; color: var(--dim); letter-spacing: .04em; }
.card-back-divider { width: 55%; height: 1px; background: var(--border); margin: 2px 0; flex-shrink: 0; }
.card-back-stats {
  display: flex; align-items: center; gap: 4px;
  font-size: .62rem; font-weight: 700; letter-spacing: .04em;
}
.cbstat-sep { color: var(--dim); font-weight: 400; }
.card-back-pattern {
  font-size: .64rem; font-weight: 800; letter-spacing: .04em; text-align: center; width: 100%;
}
.card-back-pdetail {
  font-size: .5rem; color: var(--dim); letter-spacing: .05em;
}
.card-back-ability {
  font-size: .56rem; color: var(--text); line-height: 1.5; text-align: center;
  padding: 0 4px;
}
.card-back-unlock {
  font-size: .48rem; color: var(--dim); font-style: italic; margin-top: 1px;
}
.card-enlarge-btn {
  margin-top: 5px; padding: 3px 10px; font-size: .6rem;
  background: var(--bg3); border: 1px solid var(--border);
  color: var(--dim); border-radius: 12px; cursor: pointer; transition: all .15s;
}
.card-enlarge-btn:hover { border-color: var(--gold); color: var(--gold); }

/* ─── Botón ojo — solo en cartas con habilidades únicas ─── */
.card-eye-btn {
  position: absolute;
  bottom: 4px; right: 4px;
  width: 21px; height: 21px;
  background: rgba(0,0,0,.42);
  border: none;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  padding: 0;
  color: #fff;                                     /* ojo blanco por defecto */
  filter: drop-shadow(0 1px 2px rgba(0,0,0,.95));  /* sombra negra que resalta */
  transition: transform .15s, color .15s, background .15s;
  z-index: 12;
}
.card-eye-btn:hover { background: rgba(0,0,0,.7); transform: scale(1.18); }
.card-eye-btn.developed { color: #ffd23f; }        /* amarillo: tiene golpe propio */

/* ─── Card Viewer cinemático ─── */
.card-viewer-overlay { }   /* solo para selector */

.card-viewer-card .card-back-name   { font-size: 1rem;  }
.card-viewer-card .card-back-region { font-size: .72rem; }
.card-viewer-card .card-back-divider{ margin: 4px 0; }
.card-viewer-card .cb-unique-list   { gap: 10px; }
.card-viewer-card .cb-unique-type   { font-size: .62rem; }
.card-viewer-card .cb-unique-name   { font-size: .82rem; }
.card-viewer-card .cb-unique-desc   { font-size: .68rem; line-height: 1.5; }
.card-viewer-card .card-enlarge-btn { display: none; }

/* ═══ Stats con iconos SVG (vida · poder · defensa) ═══ */
.cstat { display: inline-flex; align-items: center; gap: 2px; font-weight: 700; line-height: 1; }
.cstat .stat-ico { width: .9em; height: .9em; flex-shrink: 0; }
.cstat.big { font-size: .95rem; gap: 4px; }
.s-vida  { color: #ef9a9a; }
.s-poder { color: #ffb74d; }
.s-def   { color: #7fb0ff; }
.s-cost  { color: var(--gold); }
.pool-card-stats { gap: 4px; justify-content: space-around; }
.pool-card-stats .cstat { font-size: .62rem; }
/* Nombre + stats SIEMPRE visibles en el grid (también antes de seleccionar) */
.pool-card .pool-card-footer { display: block; }
.pool-card .pool-card-name { font-size: .66rem; }

/* El ojito funciona incluso en cartas bloqueadas: ver ficha siempre disponible */
.pool-card.blocked .card-eye-btn { pointer-events: auto; cursor: pointer; opacity: .9; }

/* ═══ Viewer de ficha: caras (flip 3D real) ═══ */
.card-viewer-card .cv-face {
  position: absolute; inset: 0;
  backface-visibility: hidden; -webkit-backface-visibility: hidden;
  border: 2px solid var(--gold); border-radius: 14px; overflow: hidden;
  box-shadow: 0 28px 80px rgba(0,0,0,.92);
}
.card-viewer-card .cv-front { display: flex; flex-direction: column; background: var(--bg2); }
.card-viewer-card .cv-front img { width: 100%; flex: 1; object-fit: cover; object-position: top; display: block; }
.card-viewer-card .cv-back {
  transform: rotateY(180deg);
  background: linear-gradient(160deg, #0a0a18 0%, #16082a 58%, #0a0a18 100%);
  display: flex; flex-direction: column; align-items: center; text-align: center;
  padding: 16px 13px 14px; overflow-y: auto; overflow-x: hidden; scrollbar-width: none;
}
.card-viewer-card .cv-back::-webkit-scrollbar { display: none; }
.card-viewer-card .cv-front .pool-card-name  { font-size: .92rem; }
.card-viewer-card .cv-front .pool-card-rango { font-size: .7rem; padding: 3px 8px; top: 8px; left: 8px; }
.card-viewer-card .cv-front .pool-card-cost     { font-size: .82rem; top: 8px; right: 9px; }
.card-viewer-card .cv-front .pool-card-statbar  { top: 8px; left: 8px; gap: 8px; }
.card-viewer-card .cv-front .pool-card-statbar .cstat { font-size: .82rem; }
.card-viewer-card .cv-front .pool-card-stats { font-size: .8rem; padding: 2px 2px 0; }

/* ═══ Ficha (reverso del viewer) ═══ */
.fic-name   { font-size: 1.1rem; font-weight: 800; color: #fff; letter-spacing: .03em; }
.fic-tier   { font-size: .66rem; font-weight: 700; letter-spacing: .09em; text-transform: uppercase; margin-top: 3px; }
.fic-region { font-size: .62rem; color: var(--dim); letter-spacing: .06em; margin-top: 1px; }
.fic-stats  { display: flex; gap: 13px; justify-content: center; align-items: center; margin: 9px 0 4px; }
.fic-divider{ width: 80%; height: 2px; border-radius: 2px; margin: 6px 0 11px; flex-shrink: 0; }
.fic-blocks { display: flex; flex-direction: column; gap: 9px; width: 100%; }
.fic-block  { text-align: left; background: rgba(255,255,255,.04); border-radius: 8px; padding: 7px 10px; border-left: 2px solid var(--gold); }
.fic-bhead  { display: flex; align-items: baseline; gap: 7px; flex-wrap: wrap; margin-bottom: 3px; }
.fic-btype  { font-size: .56rem; font-weight: 800; letter-spacing: .1em; }
.fic-bname  { font-size: .82rem; font-weight: 700; color: #f0e6d2; }
.fic-bdesc  { font-size: .7rem; color: var(--text); line-height: 1.5; }

/* ═══ Botón "Armar mazo" ═══ */
.btn-armar {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 7px 14px; background: var(--gold2);
  border: 1px solid var(--gold); color: var(--gold);
  font-size: .72rem; font-weight: 700; letter-spacing: .05em;
  border-radius: 7px; cursor: pointer; transition: all .18s; white-space: nowrap;
}
.btn-armar:hover { background: rgba(201,162,39,.26); box-shadow: 0 0 14px -3px var(--gold); }
.btn-armar svg { width: 15px; height: 15px; }
.btn-limpiar { background: rgba(183,28,28,.12); border-color: #b85c5c; color: #ef9a9a; }
.btn-limpiar:hover { background: rgba(183,28,28,.26); box-shadow: 0 0 14px -3px #b71c1c; }

/* ═══ Botón flotante de Batalla (esquina inferior derecha del builder) ═══ */
#btn-batalla {
  position: fixed; right: 22px; bottom: 60px; z-index: 5000;
  display: inline-flex; align-items: center; gap: 9px;
  padding: 12px 26px; border-radius: var(--r); border: 1px solid var(--gold);
  background: linear-gradient(150deg, #161024 0%, #0d0d1a 60%, #161024 100%);
  color: var(--gold);
  font-size: .82rem; font-weight: 800; letter-spacing: .16em; text-transform: uppercase; cursor: pointer;
  box-shadow: 0 8px 26px rgba(0,0,0,.6), 0 0 18px -6px var(--gold), inset 0 0 0 1px rgba(201,162,39,.18);
  transition: transform .18s, box-shadow .18s, color .18s, border-color .18s;
  animation: bb-pop .32s cubic-bezier(.34,1.5,.5,1), bb-pulse 1.5s ease-in-out .32s infinite;
}
#btn-batalla:hover { transform: translateY(-2px) scale(1.03); color: #f0d574; border-color: #f0d574; box-shadow: 0 12px 32px rgba(0,0,0,.7), 0 0 26px -2px var(--gold); animation-play-state: paused; }
#btn-batalla:active { transform: translateY(0) scale(.99); }
#btn-batalla svg { width: 18px; height: 18px; }
#btn-batalla.hidden { display: none; }
#btn-batalla.waiting { color: var(--dim); border-color: var(--border); box-shadow: 0 6px 18px rgba(0,0,0,.5); cursor: default; animation: none; }
#btn-batalla:disabled { opacity: .85; cursor: default; transform: none; }
@keyframes bb-pop { from { transform: translateY(22px) scale(.6); opacity: 0; } to { transform: translateY(0) scale(1); opacity: 1; } }
@keyframes bb-pulse {
  0%, 100% { box-shadow: 0 8px 26px rgba(0,0,0,.6), 0 0 18px -6px var(--gold), inset 0 0 0 1px rgba(201,162,39,.18); border-color: var(--gold); }
  50%      { box-shadow: 0 8px 26px rgba(0,0,0,.6), 0 0 30px 2px var(--gold), inset 0 0 0 1px rgba(201,162,39,.4);  border-color: #f0d574; }
}
@media (max-width: 640px) {
  #btn-batalla { right: 12px; bottom: 52px; padding: 11px 20px; font-size: .82rem; }
}

/* ═══ Ficha: botón "ver golpe" + overlay del patrón en el tablero ═══ */
.fic-golpe-btn {
  display: inline-flex; align-items: center; gap: 4px; margin-left: auto;
  padding: 2px 8px; font-size: .56rem; font-weight: 700; letter-spacing: .04em;
  background: rgba(255,255,255,.05); border: 1px solid currentColor; border-radius: 12px;
  cursor: pointer; opacity: .92;
}
.fic-golpe-btn svg { width: 12px; height: 12px; }
.fic-golpe-btn:hover { background: rgba(255,255,255,.13); }

.golpe-overlay {
  position: fixed; inset: 0; z-index: 9800; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  background: rgba(0,0,0,0); backdrop-filter: blur(0);
  opacity: 0; transition: opacity .2s, background .2s, backdrop-filter .2s;
  user-select: none; -webkit-user-select: none; -webkit-tap-highlight-color: transparent; -webkit-touch-callout: none;
}
.golpe-overlay.show { opacity: 1; background: rgba(0,0,0,.72); backdrop-filter: blur(5px); }
.go-panel {
  background: linear-gradient(160deg,#0d0b18,#141026); border: 2px solid var(--gold);
  border-radius: 14px; padding: 15px 18px 13px; width: min(300px, 84vw); text-align: center;
  box-shadow: 0 24px 70px rgba(0,0,0,.85); transform: scale(.92);
  transition: transform .22s cubic-bezier(.34,1.3,.5,1);
}
.golpe-overlay.show .go-panel { transform: scale(1); }
.go-title { font-size: .95rem; font-weight: 800; letter-spacing: .03em; }
.go-sub   { font-size: .54rem; color: var(--dim); letter-spacing: .1em; text-transform: uppercase; margin-top: 2px; }
.go-grid  { display: grid; grid-template-columns: repeat(3, 1fr); gap: 5px; width: 150px; aspect-ratio: 3 / 4; margin: 10px auto 6px; transition: opacity .45s ease; }
.go-frame-label { font-size: .6rem; font-weight: 700; letter-spacing: .03em; min-height: .9em; margin-bottom: 4px; }
.go-cell  {
  aspect-ratio: 10 / 12;   /* slots verticales (forma de carta) */
  border: 1px solid rgba(255,255,255,.12); border-radius: 5px; background: rgba(255,255,255,.03);
  display: flex; align-items: center; justify-content: center; overflow: hidden;
}
.go-card-img { width: 100%; height: 100%; object-fit: cover; object-position: top; display: block;
  pointer-events: none; user-select: none; -webkit-user-select: none; -webkit-user-drag: none; -webkit-touch-callout: none; }
.go-cell.go-target   { background: var(--gc); border-color: transparent; box-shadow: 0 0 6px -2px var(--gc); }
.go-cell.go-reach    { background: rgba(255,255,255,.34); border-color: transparent; }
.go-cell.go-splash   { background: rgba(210,45,45,.2); border: 1px dashed rgba(230,80,80,.45); }   /* salpicadura: rojo débil y punteado */
.go-cell.go-attacker { box-shadow: inset 0 0 0 2px rgba(255,255,255,.6); }
.go-legend { display: flex; gap: 12px; justify-content: center; align-items: center; font-size: .56rem; color: var(--text); margin-top: 2px; }
.go-legend .go-key { display: inline-flex; width: 13px; height: 13px; border-radius: 3px; vertical-align: middle; align-items: center; justify-content: center; font-size: .5rem; }
.go-legend .go-key-atk { box-shadow: inset 0 0 0 1.5px rgba(255,255,255,.7); }
.go-legend .go-key-reach  { background: rgba(255,255,255,.34); }
.go-legend .go-key-splash { background: rgba(210,45,45,.22) !important; border: 1px dashed rgba(230,80,80,.5) !important; opacity: 1; }
.go-desc { font-size: .66rem; color: var(--text); line-height: 1.5; margin-top: 9px; }
.go-hint { font-size: .5rem; color: var(--dim); margin-top: 9px; font-style: italic; }

/* ─── Preview INTERACTIVO del golpe: tablero + carta movible ─── */
.go-board {
  position: relative;
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 3px; width: min(156px, 54vw); margin: 10px auto 8px;
  touch-action: none; user-select: none; -webkit-user-select: none;
  -webkit-tap-highlight-color: transparent;
}
.go-token {
  position: absolute; left: 0; top: 0;
  width: calc(100% / 3); height: calc(100% / 4); box-sizing: border-box; padding: 2px;
  border: 2px solid var(--gold); border-radius: 6px; overflow: hidden; background: #0a0a14;
  pointer-events: none; z-index: 6; box-shadow: 0 5px 16px rgba(0,0,0,.75);
  transition: left .15s cubic-bezier(.3,1,.4,1), top .15s cubic-bezier(.3,1,.4,1);
}
.go-token img { width: 100%; height: 100%; object-fit: cover; object-position: top; border-radius: 4px; display: block; }
.go-token-tier { position: absolute; top: 2px; left: 2px; font-size: .42rem; font-weight: 800; color: #000; padding: 0 3px; border-radius: 3px; }
.go-hint-move {
  position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%);
  background: rgba(0,0,0,.8); color: #fff; font-size: .62rem; font-weight: 700; white-space: nowrap;
  padding: 4px 11px; border-radius: 20px; pointer-events: none; z-index: 9; box-shadow: 0 2px 10px rgba(0,0,0,.6);
  animation: go-move-hint 4s ease-in-out infinite;
}
@keyframes go-move-hint {
  0%   { opacity: 0; transform: translate(-50%,-50%) scale(.9); }
  12%  { opacity: 1; transform: translate(-50%,-50%) scale(1); }
  40%  { opacity: 1; transform: translate(-50%,-50%) scale(1); }
  60%  { opacity: 0; transform: translate(-50%,-50%) scale(1); }
  100% { opacity: 0; transform: translate(-50%,-50%) scale(.95); }
}
.go-legend .go-key-tok { background: #0a0a14; box-shadow: inset 0 0 0 1.5px var(--gold); }

/* ═══ Diálogo de confirmación de Armar mazo ═══ */
.armar-confirm-overlay {
  position: fixed; inset: 0; z-index: 9700;
  background: rgba(0,0,0,0); backdrop-filter: blur(0);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transition: opacity .22s, background .22s, backdrop-filter .22s;
}
.armar-confirm-overlay.show { opacity: 1; background: rgba(0,0,0,.6); backdrop-filter: blur(4px); }
.armar-confirm {
  background: linear-gradient(160deg,#13101f,#0c0a16); border: 1px solid var(--gold);
  border-radius: 14px; padding: 20px 22px; width: min(340px, 86vw); text-align: center;
  box-shadow: 0 24px 70px rgba(0,0,0,.85); transform: translateY(12px) scale(.96);
  transition: transform .25s cubic-bezier(.34,1.2,.4,1);
}
.armar-confirm-overlay.show .armar-confirm { transform: translateY(0) scale(1); }
.armar-confirm-title { font-size: 1rem; font-weight: 800; color: var(--gold); letter-spacing: .05em; }
.armar-confirm-text  { font-size: .76rem; color: var(--text); margin: 8px 0 16px; }
.armar-confirm-btns  { display: flex; flex-direction: column; gap: 8px; }
.armar-btn { padding: 9px 12px; border-radius: 8px; font-size: .76rem; font-weight: 700; cursor: pointer; border: 1px solid transparent; transition: all .15s; }
.armar-replace { background: var(--gold); color: #1a1408; }
.armar-replace:hover { box-shadow: 0 0 16px -3px var(--gold); }
.armar-fill { background: rgba(255,255,255,.06); border-color: var(--border); color: var(--text); }
.armar-fill:hover { border-color: var(--gold); color: var(--gold); }
.armar-cancel { background: transparent; color: var(--dim); }
.armar-cancel:hover { color: #ef9a9a; }

/* Móvil: el botón Armar mazo se compacta a solo icono para no apretar la topbar */
@media (max-width: 640px) {
  .btn-armar { padding: 6px 9px; gap: 0; }
  .btn-armar-label { display: none; }
}

/* ─── Dorso con habilidades únicas ─── */
.cb-unique-list {
  width: 100%; display: flex; flex-direction: column; gap: 5px;
  overflow-y: auto; flex: 1;
  scrollbar-width: none;
}
.cb-unique-list::-webkit-scrollbar { display: none; }
.cb-unique-block { text-align: left; width: 100%; }
.cb-unique-head {
  display: flex; align-items: baseline; gap: 4px;
  margin-bottom: 1px;
}
.cb-unique-type {
  font-size: .42rem; font-weight: 800;
  letter-spacing: .07em; text-transform: uppercase;
  flex-shrink: 0;
}
.cb-unique-name {
  font-size: .52rem; font-weight: 700;
  color: var(--text); white-space: nowrap;
  overflow: hidden; text-overflow: ellipsis;
}
.cb-unique-desc {
  font-size: .44rem; color: var(--dim);
  line-height: 1.45; padding-left: 1px;
}

/* ─── Modal — habilidades únicas ─── */
.modal-ab-list {
  width: 100%; display: flex; flex-direction: column;
  gap: 10px; padding: 6px 0; overflow-y: auto;
  max-height: 100%; flex: 1;
}
.modal-ab-block { text-align: left; width: 100%; }
.modal-ab-head {
  display: flex; align-items: baseline; gap: 6px; margin-bottom: 3px;
}
.modal-ab-type {
  font-size: .5rem; font-weight: 800;
  letter-spacing: .1em; text-transform: uppercase; flex-shrink: 0;
}
.modal-ab-name {
  font-size: .7rem; font-weight: 700; color: var(--text);
}
.modal-ab-desc {
  font-size: .6rem; color: var(--dim); line-height: 1.5;
}

/* Ghost card — vuela por la pantalla */
.flying-ghost {
  position: fixed; border-radius: var(--r); overflow: hidden;
  border: 2px solid; pointer-events: none; z-index: 6000;
  transition: left .38s cubic-bezier(.4,0,.2,1),
              top  .38s cubic-bezier(.4,0,.2,1),
              width  .38s cubic-bezier(.4,0,.2,1),
              height .38s cubic-bezier(.4,0,.2,1),
              opacity .38s;
  background: var(--bg2);
}
.flying-ghost img { width: 100%; height: 100%; object-fit: cover; object-position: top; }


/* ════════════════════════════════════════════
   GAME SCREEN
   ════════════════════════════════════════════ */

#screen-game { display: flex; flex-direction: column; height: 100vh; overflow: hidden; }

/* Top bar */
#game-top {
  display: flex; flex-direction: column; gap: 4px;
  padding: 6px 16px 8px; background: var(--bg2);
  border-bottom: 1px solid var(--border); flex-shrink: 0;
}
#round-label {
  text-align: center; font-size: .72rem; font-weight: 800;
  letter-spacing: .25em; color: var(--gold); text-transform: uppercase;
}
#hp-row { display: flex; align-items: center; gap: 12px; }
.bar-track {
  flex: 1; height: 8px; background: var(--bg3);
  border-radius: 4px; overflow: hidden; min-width: 80px;
}
.bar-fill { height: 100%; border-radius: 4px; transition: width .5s; }
.player-fill { background: linear-gradient(90deg, #1a5c2a, #43a047); }
.enemy-fill  { background: linear-gradient(90deg, #7a0000, #e53935); }
.hp-label { font-size: .62rem; letter-spacing: .12em; color: var(--dim); text-transform: uppercase; white-space: nowrap; }
#e-hp-num, #p-hp-num { font-size: .8rem; font-weight: 700; color: var(--gold); min-width: 24px; }
#enemy-hpbar, #player-hpbar { display: flex; align-items: center; gap: 8px; flex: 1; }
/* Barra del jugador: se vacía de derecha a izquierda */
#player-hpbar .bar-track { transform: scaleX(-1); }

/* Body */
#game-body { flex: 1; display: flex; overflow: hidden; }

/* Enemy hand — oculta (no se muestra la mano del enemigo) */
#enemy-hand-wrap { display: none !important; }
.side-label {
  font-size: .55rem; letter-spacing: .15em; color: var(--dim);
  text-transform: uppercase; text-align: center;
  padding-bottom: 5px; border-bottom: 1px solid var(--border); margin-bottom: 4px;
}
.enemy-card-back {
  width: 52px; height: 70px; border-radius: 6px;
  border: 1px solid var(--border); background: var(--bg3);
  display: flex; align-items: center; justify-content: center;
  color: var(--dim); font-size: .9rem; flex-shrink: 0;
}

/* Board */
#board-wrap {
  flex: 1; display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 8px; padding: 12px;
}
#turn-banner {
  font-size: .72rem; letter-spacing: .12em; color: var(--gold);
  text-transform: uppercase; min-height: 18px;
}
#board {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: repeat(4, 1fr);
  gap: 6px;
  width: min(calc(100% - 16px), 360px);
  aspect-ratio: 9 / 16;   /* vertical (celdas en retrato, como las cartas) */
  max-height: 74vh;
}

/* Board cell */
.board-cell {
  border-radius: var(--r); border: 2px solid var(--border);
  background: var(--bg2); position: relative; overflow: hidden;
  transition: border-color .2s;
}
.board-cell.empty { cursor: pointer; }
.board-cell.empty:hover {
  border-color: var(--gold);
  background: var(--bg3);
}
.board-cell.drag-over {
  border-color: var(--gold) !important;
  border-style: dashed !important;
  background: rgba(201,162,39,.1) !important;
  animation: player-hover-pulse .6s ease-in-out infinite;
}
@keyframes player-hover-pulse {
  0%,100% { box-shadow: inset 0 0 10px rgba(201,162,39,.15); }
  50%      { box-shadow: inset 0 0 24px rgba(201,162,39,.45); }
}
.board-cell.player-cell { border-color: #43a047; }
.board-cell.enemy-cell  { border-color: #e53935; }

/* Carta boca abajo (turno simultáneo) */
.board-cell.face-down {
  border-color: #c62828; border-style: dashed;
  background: var(--bg3);
  display: flex; align-items: center; justify-content: center;
  animation: facedown-pulse 1.4s ease-in-out infinite;
}
.cell-facedown {
  font-size: 1.8rem; color: #c62828; opacity: .7;
  text-shadow: 0 0 12px rgba(198,40,40,.6);
}
@keyframes facedown-pulse {
  0%, 100% { box-shadow: inset 0 0 10px rgba(198,40,40,.1); }
  50%       { box-shadow: inset 0 0 22px rgba(198,40,40,.35); }
}

/* HP damage overlay */
.cell-img-wrap { position: absolute; inset: 0; overflow: hidden; }
.cell-img-wrap img {
  width: 100%; height: 100%; object-fit: cover; object-position: top;
}
.cell-damage-layer {
  position: absolute; top: 0; left: 0; right: 0;
  background: rgba(15,15,30,.82);
  pointer-events: none; transition: height .35s;
}

.cell-info {
  position: absolute; bottom: 0; left: 0; right: 0;
  background: linear-gradient(transparent, rgba(0,0,0,.9));
  padding: 10px 4px 3px;
  display: flex; justify-content: space-between; align-items: flex-end;
}
.cell-name { font-size: .48rem; color: #ccc; flex: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.cell-hp   { font-size: .58rem; color: #ef9a9a; font-weight: 700; }
.cell-atk  { font-size: .58rem; color: #ffb74d; font-weight: 700; }

.cell-hit { animation: hit-flash .2s ease !important; }
@keyframes hit-flash {
  0%   { filter: none;                                                          transform: translateX(0); }
  18%  { filter: brightness(1.8) sepia(1) saturate(18) hue-rotate(-38deg);     transform: translateX(-4px); }
  40%  { filter: brightness(1.5) sepia(1) saturate(14) hue-rotate(-38deg);     transform: translateX(4px); }
  62%  { filter: brightness(1.2) sepia(1) saturate(8)  hue-rotate(-38deg);     transform: translateX(-3px); }
  82%  { transform: translateX(2px); }
  100% { filter: none;                                                          transform: translateX(0); }
}
/* Impacto de salpicadura: igual que hit-flash pero tintado naranja */
.cell-splash-hit { animation: splash-flash .2s ease !important; }
@keyframes splash-flash {
  0%   { filter: none;                                                       transform: translateX(0); }
  18%  { filter: brightness(1.8) sepia(.8) saturate(4) hue-rotate(-20deg);  transform: translateX(-4px); }
  40%  { filter: brightness(1.4) sepia(.6) saturate(3) hue-rotate(-20deg);  transform: translateX(4px); }
  62%  { transform: translateX(-3px); }
  82%  { transform: translateX(2px); }
  100% { filter: none;                                                       transform: translateX(0); }
}

/* Glow de color sobre una celda cuando recibe daño / cura / buff (showFloatText).
   Capa fija independiente del re-render del tablero; no cubre la carta. */
.cell-glow-pulse {
  position: fixed; pointer-events: none; z-index: 170; border-radius: 10px;
  border: 1.5px solid var(--glow, #fff);
  box-shadow: 0 0 22px 5px var(--glow, #fff);
  animation: cellGlowPulse .55s ease-out forwards;
}
@keyframes cellGlowPulse {
  0%   { opacity: 0;  transform: scale(.92); }
  25%  { opacity: .9; }
  100% { opacity: 0;  transform: scale(1.14); }
}

/* Watchdog de barrera: aviso en pantalla cuando la sincronización tarda/cuelga.
   Solo visible al añadir .show (en cuelgues) → cero impacto en partidas sanas. */
#sync-watchdog {
  position: fixed; left: 50%; top: 7%; transform: translateX(-50%);
  z-index: 6000; pointer-events: none;
  background: rgba(20,10,30,.92); color: #fde68a;
  border: 1px solid rgba(251,191,36,.5); border-radius: 8px;
  padding: 8px 16px; font-size: .8rem; letter-spacing: .04em; white-space: nowrap;
  box-shadow: 0 4px 20px rgba(0,0,0,.6);
  opacity: 0; transition: opacity .3s;
}
#sync-watchdog.show { opacity: 1; }

/* ─── Insignia de dueño (▲ jugador / ▼ enemigo) ─── */
.cell-badge {
  position: absolute; z-index: 8;
  width: 15px; height: 15px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: .42rem; font-weight: 900;
  border: 1.5px solid rgba(0,0,0,.45);
  pointer-events: none;
}
.badge-player {
  bottom: 22px; left: 3px;
  background: rgba(56,142,60,.92);
  color: #c8e6c9;
  box-shadow: 0 0 6px rgba(67,160,71,.55);
}
.badge-enemy {
  top: 3px; right: 3px;
  background: rgba(183,28,28,.92);
  color: #ffcdd2;
  box-shadow: 0 0 6px rgba(229,57,53,.55);
}

/* ─── Cartas bloqueadas en mano (despertar por ronda) ─── */
.hand-card.locked {
  opacity: .32; filter: grayscale(.85); pointer-events: none;
}
.hand-lock-overlay {
  position: absolute; inset: 0;
  background: rgba(0,0,0,.62);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 2px;
}
.hand-lock-icon { font-size: .9rem; }
.hand-lock-round { font-size: .52rem; font-weight: 700; color: var(--gold); letter-spacing: .08em; }

/* Timer bar */
#timer-bar-wrap {
  width: min(calc(100% - 16px), 400px); height: 5px;
  background: var(--bg3); border-radius: 3px; overflow: hidden;
  opacity: 0; transition: opacity .3s;
}
#timer-bar-wrap.visible { opacity: 1; }
#timer-bar {
  height: 100%; width: 0%;
  background: linear-gradient(90deg, var(--gold2), var(--gold));
  border-radius: 3px; transition: width .05s linear;
}
#timer-bar.quick   { transition: width .28s ease-out; }
#timer-bar.warning { background: linear-gradient(90deg, #e65100, #ff9800); }
#timer-bar.critical {
  background: #f44336;
  animation: timer-blink .45s ease-in-out infinite;
}
@keyframes timer-blink {
  0%,100% { opacity: 1; }
  50%      { opacity: .25; }
}

/* Combat flash */
#combat-flash {
  position: fixed; inset: 0; pointer-events: none; z-index: 200;
  display: flex; align-items: center; justify-content: center;
  opacity: 0; text-align: center; padding: 0 20px;
}
#combat-flash.show { animation: cflash 1.4s ease forwards; }
#combat-flash-text {
  font-size: 2.4rem; font-weight: 900; letter-spacing: .25em;
  color: var(--gold); text-transform: uppercase;
  text-shadow: 0 0 40px rgba(201,162,39,.9), 0 0 80px rgba(201,162,39,.4);
  max-width: 100%; word-break: break-word; line-height: 1.2;
}
@keyframes cflash {
  0%   { opacity: 0; transform: scale(.82); }
  18%  { opacity: 1; transform: scale(1.04); }
  60%  { opacity: 1; transform: scale(1);   }
  100% { opacity: 0; transform: scale(1.08); }
}

#btn-pass {
  padding: 5px 18px; background: var(--bg3); border: 1px solid var(--border);
  color: var(--dim); font-size: .72rem; border-radius: 6px; cursor: pointer; transition: all .2s;
}
#btn-pass:hover { border-color: var(--gold); color: var(--gold); }

/* Log */
#log-panel {
  position: fixed; right: 0; top: 0; bottom: 0;
  width: 168px;
  background: rgba(14,12,10,.96);
  border-left: 1px solid var(--border);
  box-shadow: -6px 0 24px rgba(0,0,0,.55);
  display: flex; flex-direction: column; overflow: hidden;
  transition: width .28s ease, padding .28s ease;
  z-index: 200;
}
#log-panel.collapsed { width: 28px; }
#log-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 8px 4px; flex-shrink: 0; gap: 6px;
}
#log-panel.collapsed #log-header { padding: 8px 4px 4px; }
#log-toggle {
  padding: 2px 5px; font-size: .66rem; flex-shrink: 0;
  background: var(--bg3); border: 1px solid var(--border);
  color: var(--dim); cursor: pointer; border-radius: 4px; transition: all .15s;
  line-height: 1;
}
#log-toggle:hover { border-color: var(--gold); color: var(--gold); }
#log-entries {
  flex: 1; overflow-y: auto; display: flex; flex-direction: column; gap: 3px;
  padding: 0 8px 8px; opacity: 1; transition: opacity .2s;
}
#log-panel.collapsed #log-entries { opacity: 0; pointer-events: none; }
#log-panel.collapsed .side-label { display: none; }
.log-entry { font-size: .63rem; color: var(--dim); border-bottom: 1px solid var(--border); padding-bottom: 3px; line-height: 1.4; }
.log-entry.dmg { color: #ef9a9a; }
.log-entry.key { color: var(--gold); }
.log-entry.round { color: var(--gold); font-weight: 700; text-align: center; letter-spacing: .04em;
  margin-top: 6px; padding-top: 6px; border-top: 1px solid var(--gold); }

/* Player hand */
#game-bottom {
  flex-shrink: 0;
  padding: 6px 14px 4px;
  display: flex; flex-direction: row; flex-wrap: wrap;
  align-items: flex-end; justify-content: center; gap: 5px;
  position: relative;
}
#player-hand {
  display: flex; justify-content: center; align-items: flex-end;
  position: relative; height: 128px; width: 100%;
}
#phase-label { width: 100%; text-align: center; font-size: .62rem; color: var(--dim); letter-spacing: .06em; }

/* Hand card — más grande, hover más dramático */
.hand-card {
  width: 82px; height: 116px; border-radius: 8px; border: 2px solid;
  position: relative; overflow: hidden; cursor: grab; flex-shrink: 0;
  transition: transform .22s cubic-bezier(.2,0,.2,1.4), box-shadow .22s;
  transform-origin: bottom center;
}
.hand-card img { width: 100%; height: 100%; object-fit: cover; object-position: top; }
.hand-card-label {
  position: absolute; bottom: 0; left: 0; right: 0;
  background: linear-gradient(transparent, rgba(0,0,0,.92));
  padding: 10px 3px 3px; font-size: .52rem; color: #fff;
  text-align: center; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
/* "Sacar carta de la mano" — se endereza y sube sobre las demás */
.hand-card:not(.inactive):not(.dragging):hover {
  transform: rotate(calc(var(--rot, 0deg) * 0.12)) translateY(calc(var(--dy, 0px) - 84px));
  z-index: 50 !important;
  filter: brightness(1.1);
  box-shadow:
    0 34px 56px rgba(0,0,0,.96),
    0 8px 20px rgba(0,0,0,.72),
    0 0 28px var(--c, transparent),
    0 0 0 1px rgba(255,255,255,.07);
  transition: transform .24s cubic-bezier(.18,.08,.14,1.55), box-shadow .24s, filter .24s;
}
.hand-card.dragging { opacity: .3; transform: scale(.95); }
.hand-card.inactive { pointer-events: none; opacity: .45; }

/* ─── Sinergia potencial: parpadeo dorado en mano ─── */
@keyframes synergyHint {
  0%, 100% { box-shadow: 0 0 0 0 transparent;            border-color: rgba(251,191,36,0); }
  50%       { box-shadow: 0 0 9px 3px rgba(251,191,36,.65); border-color: rgba(251,191,36,.8); }
}
.hand-card.synergy-hint {
  animation: synergyHint 1.1s ease-in-out infinite;
  border-color: rgba(251,191,36,.5) !important;
}


/* ════════════════════════════════════════════
   GAME OVER
   ════════════════════════════════════════════ */

#screen-gameover {
  position: fixed; inset: 0; background: rgba(0,0,0,.88);
  display: flex; align-items: center; justify-content: center; z-index: 300;
}
.over-box {
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: 12px; padding: 48px 64px; text-align: center;
}
#over-title { font-size: 3rem; letter-spacing: .3em; font-weight: 900; margin-bottom: 10px; }
#over-title.victoria { color: var(--gold); }
#over-title.derrota  { color: #e53935; }
#over-title.empate   { color: var(--dim); }
#over-score { font-size: .88rem; color: var(--dim); margin-bottom: 28px; }
.over-box button {
  padding: 11px 30px; background: var(--bg3); border: 1px solid var(--gold);
  color: var(--gold); font-size: .8rem; letter-spacing: .12em;
  border-radius: 6px; cursor: pointer; transition: all .2s;
}
.over-box button:hover { background: var(--gold); color: #000; }

/* Toast */
#toast {
  position: fixed; bottom: 18px; left: 50%; transform: translateX(-50%);
  background: var(--bg3); border: 1px solid var(--border); color: var(--text);
  padding: 7px 18px; border-radius: 20px; font-size: .76rem;
  opacity: 0; transition: opacity .2s; pointer-events: none; z-index: 500;
}
#toast.show { opacity: 1; }

/* ── Botón pantalla completa ── */
#corner-btns {
  position: fixed; bottom: 10px; right: 10px; z-index: 8000;
  display: flex; gap: 6px; align-items: center;
}
#corner-btns button {
  width: 32px; height: 32px; border-radius: 6px;
  background: rgba(13,13,26,.75); border: 1px solid var(--border);
  color: var(--dim); font-size: 1rem; line-height: 1;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: color .15s, border-color .15s, background .15s;
  backdrop-filter: blur(4px);
}
#corner-btns button:hover { color: var(--gold); border-color: var(--gold); background: rgba(13,13,26,.92); }
#btn-fullscreen.is-fullscreen { color: var(--gold); border-color: var(--gold); }
#btn-music.is-muted { color: #f87171; border-color: rgba(248,113,113,.5); }

/* ─── Texto flotante de daño / curación / armadura ─── */
@keyframes floatUp {
  0%   { transform: translateX(-50%) translateY(0);    opacity: 1; }
  100% { transform: translateX(-50%) translateY(-38px); opacity: 0; }
}
@keyframes floatDown {
  0%   { transform: translateX(-50%) translateY(0);   opacity: 1; }
  100% { transform: translateX(-50%) translateY(32px); opacity: 0; }
}
.float-text {
  position: fixed;
  pointer-events: none;
  z-index: 6000;
  font-size: .82rem;
  font-weight: 800;
  letter-spacing: .03em;
  text-shadow:
    -1px -1px 0 #000, 1px -1px 0 #000, -1px 1px 0 #000, 1px 1px 0 #000,
    0 2px 6px rgba(0,0,0,.95);
  animation: floatUp .85s ease-out forwards;
  white-space: nowrap;
}
.float-text.down { animation: floatDown .85s ease-out forwards; }

/* ─── Tríada Primordial — glow pulsante en cartas ─── */
@keyframes triadaPulse {
  from { box-shadow: 0 0 18px 6px rgba(251,191,36,.5), 0 0 40px 12px rgba(251,191,36,.2); }
  to   { box-shadow: 0 0 32px 14px rgba(251,191,36,.9), 0 0 70px 24px rgba(251,191,36,.5); }
}

/* ─── Indicadores de ataque en cartas enemigas ─── */

/* Naranja: ya será atacada por cartas propias en tablero */
.board-cell.existing-target {
  border-color: #f97316 !important;
  border-style: solid !important;
  animation: existing-target-pulse .85s ease-in-out infinite;
}
@keyframes existing-target-pulse {
  0%,100% { box-shadow: inset 0 0 8px rgba(249,115,22,.22), 0 0 8px rgba(249,115,22,.28); }
  50%      { box-shadow: inset 0 0 16px rgba(249,115,22,.42), 0 0 14px rgba(249,115,22,.45); }
}

/* Rojo: será atacada por la carta nueva que arrastro — MÁXIMA prioridad visual */
.board-cell.attackable,
.board-cell.existing-target.attackable,
.board-cell.in-zone.attackable,
.board-cell.in-zone.existing-target.attackable {
  border-color: #ff1744 !important;
  border-style: solid !important;
  border-width: 3px !important;
  background: rgba(255,23,68,.18) !important;
  animation: attackable-pulse .32s ease-in-out infinite !important;
  outline: 2px solid rgba(255,23,68,.6) !important;
  outline-offset: 1px !important;
  z-index: 10;
}
@keyframes attackable-pulse {
  0%,100% {
    border-color: #ff1744;
    box-shadow: inset 0 0 14px rgba(255,23,68,.5), 0 0 18px rgba(255,23,68,.55);
    background: rgba(255,23,68,.12);
  }
  50% {
    border-color: #ff4569;
    box-shadow: inset 0 0 28px rgba(255,23,68,.8), 0 0 28px rgba(255,23,68,.75);
    background: rgba(255,23,68,.26);
  }
}

/* ─── AI deliberación en tablero ─── */
.board-cell.ai-hover {
  border-color: #888 !important; border-style: dashed !important;
  background: rgba(120,120,120,.12) !important;
  transition: border-color .15s, background .15s;
}
.board-cell.ai-placing {
  border-color: #e53935 !important; border-style: solid !important;
  background: rgba(229,57,53,.18) !important;
  animation: ai-place-pulse .25s ease infinite;
}
@keyframes ai-place-pulse {
  0%,100% { box-shadow: inset 0 0 10px rgba(229,57,53,.2); }
  50%      { box-shadow: inset 0 0 24px rgba(229,57,53,.55); }
}

/* ─── Custom drag ghost ─── */
.drag-custom-ghost {
  position: fixed; left: -9999px; top: -9999px;
  border-radius: 8px; overflow: hidden; border: 2px solid;
  box-shadow: 0 10px 30px rgba(0,0,0,.9);
  pointer-events: none;
}
.drag-custom-ghost img { width: 100%; height: 100%; object-fit: cover; object-position: top; }

/* ─── Modal carta ampliada ─── */
#card-modal {
  position: fixed; inset: 0; background: rgba(0,0,0,.88);
  z-index: 800; display: flex; align-items: center; justify-content: center;
  cursor: pointer;
}
#card-modal.hidden { display: none !important; }
#modal-inner { position: relative; cursor: default; }

#modal-card {
  width: 280px; height: 400px;
  border-radius: 16px; border: 3px solid;
  transform-style: preserve-3d;
  transition: transform .75s cubic-bezier(.4,0,.2,1);
}
#modal-card.modal-flipped { transform: rotateY(180deg); }

.modal-face {
  position: absolute; inset: 0;
  backface-visibility: hidden;
  border-radius: 14px; overflow: hidden;
}
.modal-front { background: var(--bg2); }
.modal-front img { width: 100%; height: 70%; object-fit: cover; object-position: top; display: block; }
.modal-front .modal-info {
  padding: 12px 14px; background: var(--bg2);
}
.modal-front .modal-name { font-size: .9rem; font-weight: 700; color: var(--gold); }
.modal-front .modal-rango { font-size: .62rem; color: var(--dim); margin-top: 2px; }
.modal-front .modal-stats { font-size: .72rem; color: var(--text); margin-top: 6px; letter-spacing: .06em; }

.modal-back {
  transform: rotateY(180deg);
  background: linear-gradient(155deg, #0a0a18, #1a082e);
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  padding: 32px 28px; gap: 14px; text-align: center;
}
.modal-ability-label {
  font-size: .9rem; font-weight: 900; letter-spacing: .08em;
  text-align: center;
}
.modal-ability-detail {
  font-size: .6rem; color: var(--dim); letter-spacing: .1em;
  text-transform: uppercase; margin-top: -4px;
}
.modal-ability-divider {
  width: 60%; height: 1px; background: var(--border); margin: 4px 0;
}
.modal-ability-text {
  font-size: .82rem; color: var(--text); line-height: 1.7;
  text-align: center; padding: 0 8px;
}
.modal-ability-unlock {
  font-size: .62rem; color: var(--dim); font-style: italic; margin-top: 6px;
}

.modal-close-btn {
  position: absolute; top: -14px; right: -14px;
  width: 32px; height: 32px; border-radius: 50%;
  background: var(--bg3); border: 1px solid var(--border);
  color: var(--dim); cursor: pointer; font-size: .85rem;
  display: flex; align-items: center; justify-content: center;
  transition: all .15s;
}
.modal-close-btn:hover { border-color: var(--gold); color: var(--gold); }

/* Scrollbar */
::-webkit-scrollbar { width: 4px; height: 4px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--border); border-radius: 2px; }


/* ════════════════════════════════════════════
   COMBAT PROMPT (overlay al completar mazo)
   ════════════════════════════════════════════ */

#combat-prompt {
  position: fixed; inset: 0; background: rgba(0,0,0,.86);
  z-index: 400; display: flex; align-items: center; justify-content: center;
}
#combat-prompt.hidden { display: none !important; }
.cp-box {
  background: var(--bg2); border: 1px solid var(--gold);
  border-radius: 14px; padding: 42px 56px; text-align: center;
  display: flex; flex-direction: column; gap: 16px; align-items: center;
  box-shadow: 0 0 80px rgba(201,162,39,.2);
  max-width: 90vw;
}
.cp-title { font-size: 1.6rem; font-weight: 900; color: var(--gold); letter-spacing: .22em; }
.cp-info  { font-size: .8rem; color: var(--dim); letter-spacing: .06em; }
.cp-btn-go {
  width: 100%; padding: 13px 0;
  background: var(--gold2); border: 1px solid var(--gold);
  color: var(--gold); font-size: .82rem; font-weight: 700; letter-spacing: .12em;
  border-radius: 6px; cursor: pointer; transition: all .2s;
}
.cp-btn-go:hover { background: var(--gold); color: #000; }
.cp-btn-back {
  padding: 8px 24px; background: transparent; border: 1px solid var(--border);
  color: var(--dim); font-size: .72rem; border-radius: 6px; cursor: pointer;
  transition: all .15s;
}
.cp-btn-back:hover { border-color: var(--gold); color: var(--gold); }

/* ════════════════════════════════════════════
   PASS OVERLAY (cartas bloqueadas en turno)
   ════════════════════════════════════════════ */

#pass-overlay {
  position: absolute; inset: 0;
  background: rgba(7,7,15,.88);
  display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 10px;
  z-index: 30; border-radius: var(--r);
}
#pass-overlay.hidden { display: none !important; }
.pass-ov-label {
  font-size: .68rem; color: var(--dim); letter-spacing: .06em; text-align: center;
}
#pass-ov-bar-wrap {
  width: 160px; height: 4px; background: var(--bg3);
  border-radius: 2px; overflow: hidden;
}
#pass-ov-bar {
  height: 100%; width: 100%;
  background: linear-gradient(90deg, #e65100, #ff9800);
  border-radius: 2px; transition: width .05s linear;
}
.pass-ov-btn {
  padding: 7px 22px; background: var(--bg3); border: 1px solid var(--border);
  color: var(--dim); font-size: .72rem; border-radius: 6px; cursor: pointer;
  transition: all .2s;
}
.pass-ov-btn:hover { border-color: var(--gold); color: var(--gold); }

/* ════════════════════════════════════════════
   PASS NOTICE (notificación de turno pasado)
   ════════════════════════════════════════════ */

#pass-notice {
  position: fixed; top: 30%; left: 50%; transform: translateX(-50%);
  background: rgba(13,13,26,.92); border: 1px solid var(--gold);
  color: var(--gold); font-size: .82rem; font-weight: 700; letter-spacing: .1em;
  padding: 10px 28px; border-radius: 8px; z-index: 250;
  pointer-events: none;
  animation: pass-notice-in .25s ease;
}
#pass-notice.hidden { display: none !important; }
@keyframes pass-notice-in {
  from { opacity: 0; transform: translateX(-50%) translateY(-8px); }
  to   { opacity: 1; transform: translateX(-50%) translateY(0); }
}

/* ════════════════════════════════════════════
   MOBILE — rediseño completo ≤ 600 px
   ════════════════════════════════════════════ */
@media (max-width: 600px) {

  /* ── Builder: step screens (móvil) ── */
  .step-screen { gap: 28px; padding: 40px 18px 32px; }
  .step-brand-sub   { font-size: .4rem;  letter-spacing: .38em; }
  .brand-ornament { gap: 12px; margin-bottom: 10px; }
  .brand-ornament span { width: 56px; }
  .brand-ornament i { font-size: 15px; }
  .step-section-tag { font-size: .5rem; letter-spacing: .24em; }
  .step-back-btn { top: 14px; left: 14px; font-size: .6rem; padding: 4px 10px; }
  .step-opt { padding: 16px 18px 16px 24px; border-radius: 9px; }
  .step-opt-name { font-size: .8rem; }
  .step-opt-info { font-size: .56rem; }
  .step-options { gap: 10px; max-width: 100%; }

  /* ── Builder: slots del mazo ── */
  #deck-slots-bar { padding: 5px 8px 3px; }
  #deck-slots { gap: 4px; }
  .deck-slot { width: 54px; height: 74px; border-radius: 6px; }
  .deck-slot-stats { font-size: .4rem; padding: 0 3px; }
  .deck-slot-name  { font-size: .42rem; padding: 5px 2px 2px; }
  .deck-slot.filled:hover { transform: translateY(-5px) scale(1.05); }

  /* ── Builder: barra de costo ── */
  #cost-bar-row { padding: 3px 10px 5px; gap: 8px; }
  #cost-bar-wrap { width: min(140px, 36vw); height: 7px; }
  #meta-cost { font-size: .65rem; }
  #btn-listo { padding: 7px 14px; font-size: .68rem; letter-spacing: .08em; }

  /* ── Builder: build topbar ── */
  #build-topbar { padding: 5px 10px 6px; gap: 8px; }
  #build-topbar #meta-cost { font-size: .66rem; }

  /* ── Builder: filtros — scroll horizontal ── */
  #pool-controls { padding: 5px 0 4px; gap: 3px; align-items: stretch; }
  .filter-bar {
    flex-wrap: nowrap; overflow-x: auto; gap: 4px;
    padding: 0 6px 3px; justify-content: flex-start;
    -webkit-overflow-scrolling: touch; scrollbar-width: none;
  }
  .filter-bar::-webkit-scrollbar { display: none; }
  .filter-btn { flex-shrink: 0; padding: 3px 7px; font-size: .58rem; }
  .sort-bar { padding: 0 6px; gap: 5px; justify-content: center; }
  .sort-btn  { padding: 2px 7px; font-size: .56rem; }
  .sort-label { font-size: .54rem; }

  /* ── Combat prompt (móvil) ── */
  .cp-box { padding: 30px 22px; gap: 13px; }
  .cp-title { font-size: 1.3rem; letter-spacing: .15em; }
  .cp-info  { font-size: .72rem; }
  .cp-btn-go   { padding: 12px 0; font-size: .76rem; }
  .cp-btn-back { padding: 8px 18px; font-size: .67rem; }

  /* ── Pass overlay (móvil) ── */
  .pass-ov-label { font-size: .6rem; }
  .pass-ov-btn { padding: 6px 18px; font-size: .66rem; }

  /* ── Builder: grid de cartas → mínimo 4 columnas en pantallas chicas ── */
  #pool-scroll { padding: 0 6px 12px; }
  #card-pool {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 6px;
  }

  /* Contenido carta del pool */
  .pool-card-rango { font-size: .4rem; padding: 1px 3px; top: 3px; left: 3px; }
  .pool-card-cost  { font-size: .58rem; width: 15px; height: 15px; top: 3px; right: 3px; }
  .pool-card-footer { padding: 3px 4px; }
  .pool-card-name   { font-size: .56rem; }
  .pool-card-stats  { font-size: .52rem; margin-top: 1px; }

  /* Dorso carta pool: también más pequeño */
  .card-back-name    { font-size: .58rem; }
  .card-back-region  { font-size: .46rem; }
  .card-back-stats   { font-size: .54rem; gap: 3px; }
  .card-back-pattern { font-size: .56rem; }
  .card-back-pdetail { font-size: .44rem; }
  .card-back-ability { font-size: .48rem; }
  .card-back-unlock  { font-size: .42rem; }
  .card-enlarge-btn  { font-size: .52rem; padding: 2px 7px; }

  /* ── Juego: top bar ── */
  #game-top { padding: 4px 10px 4px; gap: 2px; }
  #round-label { font-size: .58rem; letter-spacing: .1em; }
  .wc { font-size: .66rem; }
  #hp-row { gap: 7px; }
  .hp-label { font-size: .5rem; letter-spacing: .05em; }
  #e-hp-num, #p-hp-num { font-size: .68rem; min-width: 18px; }
  .bar-track { height: 6px; min-width: 55px; }

  /* ── Juego: cadena flex → los contenedores deben poder encogerse ── */
  #game-body  { min-height: 0; }
  #board-wrap {
    min-height: 0; overflow: hidden;
    padding: 5px; gap: 4px;
    justify-content: flex-start; align-items: center;
  }

  /* ── Juego: tablero móvil ────────────────────────────────────────
     La ALTURA la maneja el flex (flex:1 → llena el espacio que queda
     en board-wrap después de banner y timer).
     El ANCHO lo calcula fitBoard() para forzar ratio 9:16:
       width = height × (9/16)
     Así el tablero siempre ocupa todo el largo disponible de pantalla.
  ── */
  #turn-banner { font-size: .58rem; min-height: 13px; letter-spacing: .08em; }
  #board {
    flex: 1;           /* ← llena el alto restante en board-wrap  */
    min-height: 0;
    align-self: center;/* ← se centra cuando JS reduce el ancho    */
    width: 100%;       /* punto de partida; JS sobreescribe         */
    aspect-ratio: unset !important;
    max-height: unset !important;
    max-width:  unset !important;
    gap: 3px;
  }
  #timer-bar-wrap { width: calc(100% - 4px); height: 4px; }

  /* Celda del tablero */
  .cell-info { padding: 7px 3px 2px; }
  .cell-name { font-size: .38rem; }
  .cell-hp, .cell-atk { font-size: .46rem; }
  .cell-facedown { font-size: 1.4rem; }

  /* ── Juego: log oculto en móvil ── */
  #log-panel { display: none; }

  /* ── Juego: bottom (mano + siguiente) ── */
  #game-bottom { padding: 4px 8px 3px; gap: 3px; }
  #player-hand { height: 94px; min-width: 170px; }
  .hand-card {
    width: 58px; height: 82px; border-radius: 6px;
  }
  .hand-card:not(.inactive):not(.dragging):hover {
    transform: rotate(calc(var(--rot, 0deg) * 0.12)) translateY(calc(var(--dy, 0px) - 56px));
    transition: transform .22s cubic-bezier(.18,.08,.14,1.55), box-shadow .22s, filter .22s;
  }
  .hand-card-label { font-size: .42rem; padding: 7px 2px 2px; }
  .hand-lock-icon  { font-size: .7rem; }
  .hand-lock-round { font-size: .4rem; }

  /* Siguiente carta */
  #next-card-mini { width: 34px; height: 48px; border-radius: 5px; }
  .next-label { font-size: .4rem; }

  /* Phase label y pass */
  #phase-label { font-size: .56rem; }
  #btn-pass { padding: 4px 12px; font-size: .6rem; }

  /* ── Combat flash (móvil) ── */
  #combat-flash-text { font-size: 1.6rem; letter-spacing: .15em; }

  /* ── Game Over ── */
  .over-box { padding: 28px 18px; border-radius: 10px; }
  #over-title { font-size: 2rem; letter-spacing: .18em; margin-bottom: 8px; }
  #over-score { font-size: .75rem; margin-bottom: 20px; }
  .over-box button { padding: 9px 18px; font-size: .7rem; }

  /* ── Modal carta ampliada ── */
  #modal-card { width: 220px; height: 314px; }
  .modal-front .modal-name  { font-size: .78rem; }
  .modal-front .modal-stats { font-size: .62rem; }
  .modal-ability-label { font-size: .78rem; }
  .modal-ability-text  { font-size: .72rem; }
}


/* ════════════════════════════════════════════
   STEP SCREENS (modo → dificultad → mazo)
   ════════════════════════════════════════════ */

.step-screen {
  position: absolute; inset: 0;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 36px; padding: 48px 28px;
  background:
    radial-gradient(ellipse 90% 50% at 50% 18%, rgba(201,162,39,.13) 0%, transparent 68%),
    var(--bg);
}
.step-screen.hidden { display: none !important; }

/* Marca en paso 1 */
.step-brand { text-align: center; max-width: 100%; overflow: visible; padding: 6px 18px; }
.brand-ornament { display: flex; align-items: center; justify-content: center; gap: 16px; margin-bottom: 14px; }
.brand-ornament span { display: block; height: 1px; width: 100px; background: linear-gradient(to right, transparent, var(--gold)); }
.brand-ornament span:last-child { background: linear-gradient(to left, transparent, var(--gold)); }
.brand-ornament i { font-style: normal; color: var(--gold); font-size: 18px; }
.step-brand-title {
  font-family: 'Cinzel', serif;
  font-size: clamp(1.2rem, 7vw, 2.6rem); letter-spacing: .1em; font-weight: 900; line-height: 1;
  background: linear-gradient(135deg, #c9a22a 0%, #f5e07a 40%, #c9a22a 70%, #f0c84a 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
  filter: drop-shadow(0 0 30px rgba(201,162,42,.4));
}
.step-brand-sub {
  font-family: 'Cinzel', serif;
  font-size: .52rem; letter-spacing: .68em; color: var(--dim);
  margin-top: 10px; text-transform: uppercase;
}

/* Botón volver en paso 2 */
.step-back-btn {
  position: absolute; top: 18px; left: 18px;
  padding: 5px 12px; background: transparent;
  border: 1px solid var(--border); color: var(--dim);
  font-size: .65rem; border-radius: 6px; cursor: pointer; transition: all .15s;
}
.step-back-btn:hover { border-color: var(--gold); color: var(--gold); }

/* Etiqueta de sección */
.step-section-tag {
  font-size: .56rem; letter-spacing: .34em; color: var(--gold);
  text-transform: uppercase; font-weight: 700; opacity: .72;
}

/* Contenedor de opciones */
.step-options { display: flex; flex-direction: column; gap: 12px; width: 100%; max-width: 420px; }

/* Botón de opción */
.step-opt {
  width: 100%; padding: 20px 24px 20px 30px;
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: 10px; cursor: pointer; text-align: left;
  position: relative; overflow: hidden;
  transition: border-color .18s, background .18s, transform .18s;
}
/* Línea dorada izquierda */
.step-opt::before {
  content: ''; position: absolute; left: 0; top: 12%; bottom: 12%;
  width: 2px; background: var(--gold); border-radius: 1px;
  transform: scaleY(0); transform-origin: center;
  transition: transform .22s cubic-bezier(.4,0,.2,1);
}
.step-opt:hover::before { transform: scaleY(.6); }
.step-opt.active::before { transform: scaleY(1); }
.step-opt:hover {
  border-color: rgba(201,162,39,.4);
  background: rgba(201,162,39,.04);
  transform: translateX(5px);
}
.step-opt.active {
  border-color: rgba(201,162,39,.65);
  background: rgba(201,162,39,.07);
}
.step-opt-name {
  font-size: .88rem; font-weight: 700; letter-spacing: .08em;
  color: var(--text); margin-bottom: 4px;
  transition: color .18s;
}
.step-opt.active .step-opt-name { color: var(--gold); }
.step-opt-info { font-size: .6rem; color: var(--dim); letter-spacing: .04em; }

/* ── Build panel ── */
#build-panel { flex: 1; display: flex; flex-direction: column; overflow: hidden; }

#build-topbar {
  display: flex; align-items: center; gap: 10px;
  padding: 6px 14px 8px; background: var(--bg2);
  border-bottom: 1px solid var(--border); flex-shrink: 0;
}
#build-topbar #cost-bar-wrap { flex: 1; }
#build-topbar #meta-cost { font-size: .75rem; color: var(--dim); white-space: nowrap; flex-shrink: 0; }

.build-back-btn {
  padding: 4px 10px; background: var(--bg3); border: 1px solid var(--border);
  color: var(--dim); font-size: .68rem; border-radius: 6px; cursor: pointer;
  transition: all .15s; flex-shrink: 0; white-space: nowrap;
}
.build-back-btn:hover { border-color: var(--gold); color: var(--gold); }



/* ════════════════════════════════════════════
   ROUND ROW + WIN CIRCLES
   ════════════════════════════════════════════ */

#round-row {
  display: flex; align-items: center; justify-content: center;
}
/* Círculos de victoria — inline junto a la barra de vida de cada jugador */
.wc-group { display: flex; align-items: center; gap: 3px; flex-shrink: 0; }
.wc-group.hidden { display: none !important; }
.wc {
  font-size: .78rem; font-weight: 700; line-height: 1;
  transition: color .3s, text-shadow .3s;
}
.wc-enemy  { color: #e53935; }
.wc-player { color: #43a047; }
.wc.filled.wc-enemy  { text-shadow: 0 0 6px rgba(229,57,53,.8); }
.wc.filled.wc-player { text-shadow: 0 0 6px rgba(67,160,71,.8); }


/* ════════════════════════════════════════════
   NEXT CARD PREVIEW
   ════════════════════════════════════════════ */

#next-card-wrap {
  position: absolute; left: 14px; top: 50%; transform: translateY(-50%);
  display: flex; flex-direction: column; align-items: center; gap: 3px;
}
.next-label {
  font-size: .48rem; color: var(--dim);
  letter-spacing: .12em; text-transform: uppercase;
}
#next-card-mini {
  width: 46px; height: 64px; border-radius: 6px;
  border: 1px solid var(--border); background: var(--bg3);
  overflow: hidden; position: relative;
}
.next-card-img {
  width: 100%; height: 100%; object-fit: cover; object-position: top; display: block;
}
.next-empty {
  display: flex; align-items: center; justify-content: center;
  height: 100%; color: var(--border); font-size: .8rem;
}


/* ════════════════════════════════════════════
   ATTACK ZONE INDICATOR (gris = rango alcanza)
   ════════════════════════════════════════════ */

.board-cell.in-zone {
  border-color: rgba(255,70,70,.6) !important;
  border-style: dashed !important;
  background: rgba(210,30,30,.13) !important;
}
/* Salpicadura en tablero: rojo aún más suave */
.board-cell.in-zone-splash {
  border-color: rgba(255,100,100,.32) !important;
  border-style: dashed !important;
  background: rgba(210,45,45,.06) !important;
}
/* in-zone + existente → naranja */
.board-cell.in-zone.existing-target {
  border-color: #f97316 !important;
  border-style: solid !important;
  background: transparent !important;
  animation: existing-target-pulse .85s ease-in-out infinite;
}
/* in-zone real objetivo → manejado por el bloque atacable de arriba */

/* Dorado Solmira: celda donde caerá el "dúo del alba" de Helior (Llamado del
   Alba). Análogo al gris (zona) y rojo (objetivo): telegrafía temáticamente el
   slot antes de materializar al aliado. Amarillo brillante muy "Solmira". */
.board-cell.cell-dawn-target {
  border-color: #ffd54a !important;
  border-style: solid !important;
  border-width: 3px !important;
  background: rgba(255,213,74,.16) !important;
  animation: dawn-target-pulse .5s ease-in-out infinite !important;
  outline: 2px solid rgba(255,213,74,.55) !important;
  outline-offset: 1px !important;
  z-index: 12;
}
@keyframes dawn-target-pulse {
  0%,100% {
    border-color: #ffe082;
    box-shadow: inset 0 0 14px rgba(255,213,74,.5), 0 0 18px rgba(255,193,7,.55);
    background: rgba(255,213,74,.12);
  }
  50% {
    border-color: #fff3c4;
    box-shadow: inset 0 0 22px rgba(255,213,74,.8), 0 0 30px rgba(255,193,7,.85);
    background: rgba(255,213,74,.24);
  }
}

/* Helior "llama al alba": su propia celda irradia dorado mientras invoca al dúo. */
.board-cell.cell-dawn-caller {
  animation: dawn-caller-glow .7s ease-in-out;
  z-index: 30;
}
@keyframes dawn-caller-glow {
  0%,100% { box-shadow: 0 0 0 rgba(255,213,74,0); transform: scale(1); }
  45%     { box-shadow: 0 0 26px 6px rgba(255,213,74,.85), inset 0 0 18px rgba(255,236,150,.7); transform: scale(1.07); }
}

/* Rayo dorado de Helior → celda del dúo (origen anclado en el centro de Helior). */
.dawn-beam {
  position: fixed; height: 4px; z-index: 180; pointer-events: none;
  transform-origin: 0 50%; border-radius: 4px;
  background: linear-gradient(90deg, rgba(255,236,150,.95), rgba(255,213,74,.6), rgba(255,213,74,0));
  box-shadow: 0 0 12px rgba(255,213,74,.85);
  animation: dawn-beam-fade .7s ease-out forwards;
}
@keyframes dawn-beam-fade {
  0%   { opacity: 0; filter: brightness(1.6); }
  25%  { opacity: 1; }
  100% { opacity: 0; }
}

/* Juicio Radiante (fase 1): baño de luz Solmira sobre cada enemigo golpeado. */
.board-cell.cell-solmira-judge {
  animation: solmira-judge .62s ease-out;
}
@keyframes solmira-judge {
  0%   { box-shadow: inset 0 0 0 rgba(255,213,74,0); }
  35%  { box-shadow: inset 0 0 26px 6px rgba(255,213,74,.9), 0 0 22px rgba(255,193,7,.8); filter: brightness(1.5) saturate(1.2); }
  100% { box-shadow: inset 0 0 0 rgba(255,213,74,0); filter: none; }
}

/* 🔒 Protección de Padre (Vharokh cubre a Khetu) — café Khar-Dur */
.father-slot-reserved {
  position: fixed; z-index: 150; pointer-events: none; border-radius: 8px;
  border: 2px dashed var(--cafe, #5d4037);
  background: rgba(93,64,55,.38);
  box-shadow: inset 0 0 18px var(--cafe,#5d4037), 0 0 12px var(--cafe,#5d4037);
  animation: father-slot-pulse 1s ease-in-out infinite;
}
@keyframes father-slot-pulse { 0%,100%{opacity:.55;} 50%{opacity:.9;} }
.father-shield-clone {
  position: fixed; z-index: 185; pointer-events: none; border-radius: 8px;
  overflow: hidden; border: 2px solid var(--cafe,#5d4037);
  box-shadow: 0 0 20px var(--cafe,#5d4037), 0 6px 18px rgba(0,0,0,.6);
}
.father-shield-clone img { width:100%; height:100%; object-fit:cover; object-position:top; }
.father-clone-hp {
  position: absolute; bottom: 0; left: 0; right: 0;
  background: linear-gradient(transparent, rgba(0,0,0,.92));
  padding: 9px 3px 3px; text-align: center;
  font-size: .62rem; font-weight: 700; color: #ef9a9a;
  text-shadow: 0 1px 3px #000;
}
/* El clon del padre tiembla al recibir daño, como cualquier carta golpeada. */
.father-shield-clone.clone-hit { animation: hit-flash .2s ease; }

/* Slot de Vharokh mientras está interpuesto: marca café BIEN visible (sin su carta). */
.board-cell.cell-father-away {
  border: 3px dashed #8d6e63 !important;
  background: rgba(93,64,55,.7) !important;
  box-shadow: inset 0 0 26px rgba(141,110,99,.85), 0 0 14px rgba(93,64,55,.7) !important;
  animation: father-slot-pulse 1.1s ease-in-out infinite;
}

/* Khetu cubierto por su padre: sin contorno, para que el clon se vea limpio encima. */
.board-cell.cell-father-covered {
  border-color: transparent !important;
  box-shadow: none !important;
  outline: none !important;
}

/* Título dramático de la Protección de Padre (estilo familia dracónica). */
.father-shield-title {
  position: fixed; left: 50%; top: 36%; transform: translate(-50%,-50%) scale(.6);
  z-index: 4100; pointer-events: none; text-align: center; opacity: 0;
  transition: transform .3s cubic-bezier(.17,.67,.3,1.3), opacity .3s;
}
.father-shield-title.show { transform: translate(-50%,-50%) scale(1); opacity: 1; }
.father-shield-title .fst-main {
  font-size: 1rem; color: #d7a06a; letter-spacing: .2em; margin-bottom: .3rem;
  text-shadow: 0 0 20px #5d4037, 0 0 45px #3e2a22;
}
.father-shield-title .fst-sub {
  font-size: .56rem; color: #c9a98a; letter-spacing: .12em; text-shadow: 0 0 8px #5d4037;
}

/* ☀ Helior — Juicio Radiante: destello de sol que crece desde el centro del tablero */
.helior-sun-flare {
  position: fixed; z-index: 178; pointer-events: none;
  width: 40px; height: 40px; margin: -20px 0 0 -20px; border-radius: 50%;
  background: radial-gradient(circle, rgba(255,236,150,.95) 0%, rgba(255,213,74,.6) 35%, rgba(255,193,7,.18) 65%, transparent 75%);
  animation: helior-flare .9s ease-out forwards;
}
@keyframes helior-flare {
  0%   { transform: scale(.2); opacity: 0; }
  22%  { opacity: 1; }
  100% { transform: scale(14); opacity: 0; }
}

/* ════════════════════════════════════════════
   REGION BOARD EFFECTS — ambiente por región
   ════════════════════════════════════════════ */
.region-board-flash {
  position: fixed; pointer-events: none; z-index: 55;
  border-radius: 10px; opacity: 0;
  animation: regionBoardFlash .7s ease-out forwards;
}
@keyframes regionBoardFlash {
  0%   { opacity: 0; }
  25%  { opacity: 1; }
  100% { opacity: 0; }
}

/* ════════════════════════════════════════════
   SYNERGY EFFECTS — tiers 1-4
   ════════════════════════════════════════════ */

/* Tier 1 — Chispa: borde de celda */
/* ── Sinergia de región: parpadeo en color de región ── */
.board-cell.cell-syn-region {
  border-color: var(--syn-color, #c9a227) !important;
  border-width: 2px !important;
  animation: synRegionPulse 0.5s ease-in-out 3 !important;
}
@keyframes synRegionPulse {
  0%,100% {
    box-shadow: 0 0 6px 2px var(--syn-color, #c9a227),
                inset 0 0 8px rgba(255,255,255,.04);
    filter: brightness(1);
  }
  50% {
    box-shadow: 0 0 20px 7px var(--syn-color, #c9a227),
                inset 0 0 16px rgba(255,255,255,.1);
    filter: brightness(1.25);
  }
}

/* ── Sinergia de línea/posición: parpadeo dorado ── */
.board-cell.cell-syn-line {
  border-color: #fbbf24 !important;
  border-width: 2px !important;
  animation: synLinePulse 0.55s ease-in-out 3 !important;
}
@keyframes synLinePulse {
  0%,100% {
    box-shadow: 0 0 8px 3px rgba(251,191,36,.4),
                inset 0 0 8px rgba(251,191,36,.08);
    filter: brightness(1);
  }
  50% {
    box-shadow: 0 0 22px 8px rgba(251,191,36,.72),
                inset 0 0 18px rgba(251,191,36,.18);
    filter: brightness(1.3);
  }
}

/* Legado — clases antiguas (se conservan por si se referencian) */
.cell-synergy-glow {
  box-shadow: 0 0 0 3px var(--syn-color, #c9a227),
              0 0 18px var(--syn-color, #c9a227),
              inset 0 0 8px rgba(255,255,255,.05) !important;
  transition: box-shadow .15s !important;
}
.cell-synergy-lift {
  transform: translateY(-5px) scale(1.04) !important;
  transition: transform .18s cubic-bezier(.2,.8,.3,1.4) !important;
  z-index: 15 !important;
}
.cell-synergy-burst {
  animation: cellBurst .4s ease-out forwards;
}
@keyframes cellBurst {
  0%   { filter: brightness(1); }
  40%  { filter: brightness(2.2); }
  100% { filter: brightness(1); }
}

/* Anillo expansivo desde celda */
.synergy-ring {
  position: fixed; border-radius: 50%; pointer-events: none; z-index: 160;
  transform: translate(-50%, -50%) scale(0);
  border: 3px solid;
  animation: synergyRingExpand .8s ease-out forwards;
}
@keyframes synergyRingExpand {
  0%   { transform: translate(-50%,-50%) scale(0); opacity: .95; }
  100% { transform: translate(-50%,-50%) scale(5); opacity: 0; }
}

/* Label de sinergia */
.synergy-label {
  position: fixed; pointer-events: none; z-index: 210;
  font-size: .68rem; letter-spacing: .14em; font-weight: 700; text-transform: uppercase;
  white-space: nowrap; text-align: center;
  animation: synergyLabelAnim .9s ease-out forwards;
}
@keyframes synergyLabelAnim {
  0%   { opacity: 0; transform: translate(-50%, 6px); }
  25%  { opacity: 1; transform: translate(-50%, 0); }
  70%  { opacity: 1; transform: translate(-50%, 0); }
  100% { opacity: 0; transform: translate(-50%, -10px); }
}

/* Rayo SVG entre cartas */
.synergy-svg-ray {
  position: fixed; top: 0; left: 0; pointer-events: none; z-index: 165;
  animation: synRayFade .6s ease-out forwards;
}
@keyframes synRayFade {
  0%   { opacity: 1; }
  100% { opacity: 0; }
}

/* Flash de bordes de pantalla */
.screen-edge-flash {
  position: fixed; inset: 0; pointer-events: none; z-index: 50;
  animation: screenEdge .5s ease-out forwards;
}
@keyframes screenEdge {
  0%   { opacity: 0; }
  30%  { opacity: 1; }
  100% { opacity: 0; }
}

/* Overlay épico Tier 4 */
.synergy-epic-overlay {
  position: fixed; inset: 0; pointer-events: none; z-index: 155;
  background: rgba(0,0,0,.78);
  animation: epicOverlayAnim 1.7s ease-out forwards;
}
@keyframes epicOverlayAnim {
  0%   { opacity: 0; }
  12%  { opacity: 1; }
  60%  { opacity: .75; }
  100% { opacity: 0; }
}

/* Board shake */
@keyframes boardShakeAnim {
  0%,100% { transform: translate(0,0); }
  15% { transform: translate(-4px, 2px); }
  30% { transform: translate(4px,-3px); }
  45% { transform: translate(-3px, 4px); }
  60% { transform: translate(3px,-2px); }
  80% { transform: translate(-2px, 1px); }
}
@keyframes boardShakeHeavy {
  0%,100% { transform: translate(0,0); }
  10% { transform: translate(-6px, 4px); }
  25% { transform: translate(6px,-5px); }
  40% { transform: translate(-5px, 6px); }
  55% { transform: translate(5px,-4px); }
  70% { transform: translate(-3px, 3px); }
  85% { transform: translate(2px,-2px); }
}
.board-shake       { animation: boardShakeAnim  .32s ease-in-out; }
.board-shake-heavy { animation: boardShakeHeavy .45s ease-in-out; }

/* ════════════════════════════════════════════
   PRIMORDIAL REVEAL — carta sale en 3D
   ════════════════════════════════════════════ */
#titan-reveal {
  position: fixed; inset: 0; z-index: 8900; pointer-events: none;
  background: transparent;
  transition: background .22s ease;
}
#titan-reveal.dimmed { background: rgba(0,0,0,.8); }

#titan-card-clone {
  position: fixed; z-index: 8901; pointer-events: none;
  border-radius: 10px; overflow: hidden;
  transform-origin: center center;
  will-change: transform, left, top, width, height;
}

.titan-impact-ring {
  position: fixed; border-radius: 50%; pointer-events: none; z-index: 8902;
  transform: translate(-50%,-50%) scale(0);
  animation: titanRing .6s ease-out forwards;
}
@keyframes titanRing {
  0%   { transform: translate(-50%,-50%) scale(0); opacity: .85; }
  100% { transform: translate(-50%,-50%) scale(6); opacity: 0; }
}

.titan-cell-flash {
  animation: titanCellFlash .28s ease-out;
}
@keyframes titanCellFlash {
  0%   { filter: brightness(1); }
  45%  { filter: brightness(2.4); }
  100% { filter: brightness(1); }
}

#primordial-reveal {
  position: fixed; inset: 0; z-index: 9000; pointer-events: none;
  background: transparent;
  transition: background .28s ease;
}
#primordial-reveal.darkened { background: rgba(0,0,0,.9); }

#primordial-card-clone {
  position: fixed; z-index: 9001; pointer-events: none;
  border-radius: 10px; overflow: hidden;
  transform-origin: center center;
  will-change: transform, left, top, width, height;
}
#primordial-card-clone.pulse { animation: primordialPulse .54s ease-in-out; }
@keyframes primordialPulse { 0%,100% { filter: brightness(1); } 50% { filter: brightness(1.55) saturate(1.3); } }

/* Aura de rayos giratoria detrás de la carta Primordial */
.primordial-aura {
  position: fixed; z-index: 9000; pointer-events: none;
  width: 150vmax; height: 150vmax; left: 50%; top: 50%;
  margin-left: -75vmax; margin-top: -75vmax;
  opacity: 0; transition: opacity .5s;
  background: repeating-conic-gradient(from 0deg,
    transparent 0deg, var(--auraCol) 3deg, transparent 8deg, transparent 24deg);
  -webkit-mask-image: radial-gradient(circle, transparent 20%, #000 30%, #000 46%, transparent 62%);
          mask-image: radial-gradient(circle, transparent 20%, #000 30%, #000 46%, transparent 62%);
  animation: primordialAuraSpin 11s linear infinite;
}
.primordial-aura.show { opacity: .5; }
@keyframes primordialAuraSpin { to { transform: rotate(360deg); } }

/* Título PRIMORDIAL + nombre */
.primordial-title {
  position: fixed; z-index: 9003; pointer-events: none; text-align: center;
  transform: translate(-50%, 16px); opacity: 0;
  transition: opacity .4s, transform .4s;
}
.primordial-title.show { opacity: 1; transform: translate(-50%, 0); }
.primordial-title .pt-rank { font-size: 1.15rem; font-weight: 900; letter-spacing: .38em; }
.primordial-title .pt-name { font-size: .82rem; color: #fff; letter-spacing: .12em; margin-top: 5px; text-shadow: 0 0 10px #000, 0 2px 6px #000; }

/* Destello radial que entra desde TODOS los bordes (por encima del overlay) */
.primordial-burst { position: fixed; inset: 0; z-index: 9002; pointer-events: none; opacity: 0; }
.primordial-burst.go { animation: primordialBurst .55s ease-out forwards; }
@keyframes primordialBurst { 0% { opacity: 0; } 28% { opacity: 1; } 100% { opacity: 0; } }

/* Ondas de impacto desde celda Primordial */
.primordial-impact-ring {
  position: fixed; border-radius: 50%; pointer-events: none; z-index: 9002;
  transform: translate(-50%,-50%) scale(0);
  animation: primordialRing .7s ease-out forwards;
}
@keyframes primordialRing {
  0%   { transform: translate(-50%,-50%) scale(0); opacity: .9; }
  100% { transform: translate(-50%,-50%) scale(8); opacity: 0; }
}

/* Vornyx: carta corrompida (contorno morado pulsante) + humo */
/* 👑 Primordial: contorno con el color de su REGIÓN (no el del jugador) */
.board-cell.cell-region-aura {
  border-color: var(--rc, #fff) !important;
  box-shadow: 0 0 14px var(--rc, #fff), inset 0 0 10px var(--rc, #fff);
  animation: cellRegionAura 1.5s ease-in-out infinite;
}
@keyframes cellRegionAura {
  0%,100% { box-shadow: 0 0 12px var(--rc,#fff), inset 0 0 8px var(--rc,#fff); }
  50%     { box-shadow: 0 0 24px var(--rc,#fff), inset 0 0 16px var(--rc,#fff); }
}

.board-cell.cell-infected {
  border-color: #c64bff !important;
  outline: 2px solid rgba(198,75,255,.85);
  outline-offset: -2px;
  animation: cellInfected 1.3s ease-in-out infinite;
}
@keyframes cellInfected {
  0%,100% { box-shadow: inset 0 0 16px rgba(155,48,201,.55), 0 0 12px rgba(155,48,201,.7); }
  50%     { box-shadow: inset 0 0 32px rgba(155,48,201,.9),  0 0 26px rgba(198,75,255,1); }
}
/* Humo morado PERSISTENTE en la carta corrompida (se repite mientras dure) */
.board-cell.cell-infected .infect-smoke {
  position: absolute; bottom: 14%; width: 16px; height: 16px; border-radius: 50%;
  pointer-events: none; z-index: 8;
  background: radial-gradient(circle, rgba(198,75,255,.85), rgba(123,31,162,0) 70%);
  filter: blur(1px);
  animation: infectSmoke 1.8s ease-out infinite;
}
@keyframes infectSmoke {
  0%   { opacity: 0;  transform: translateY(0) scale(.5); }
  25%  { opacity: .85; }
  100% { opacity: 0;  transform: translateY(-40px) scale(1.8); }
}
.vornyx-smoke {
  position: fixed; z-index: 9004; pointer-events: none;
  width: 18px; height: 18px; border-radius: 50%;
  background: radial-gradient(circle, rgba(155,48,201,.85), rgba(123,31,162,0) 70%);
  animation: vornyxSmoke 1s ease-out forwards;
}
@keyframes vornyxSmoke {
  0%   { opacity: 0;  transform: translateY(0) scale(.5); }
  30%  { opacity: .9; }
  100% { opacity: 0;  transform: translateY(-46px) scale(1.7); }
}

/* Titanes: efectos genéricos por celda (coloreados por región) */
.titan-fx { position: fixed; z-index: 9005; pointer-events: none; }
.tfx-ripple {
  width: 18px; height: 18px; border-radius: 50%; border: 3px solid var(--c);
  box-shadow: 0 0 12px var(--c); transform: translate(-50%,-50%) scale(.3);
  animation: tfxRipple .55s ease-out forwards;
}
@keyframes tfxRipple {
  0%   { opacity: .95; transform: translate(-50%,-50%) scale(.3); }
  100% { opacity: 0;   transform: translate(-50%,-50%) scale(5); }
}
.tfx-shatter {
  border-radius: 8px; overflow: hidden;
  background: radial-gradient(circle, var(--c) 0%, transparent 62%);
  filter: drop-shadow(0 0 6px var(--c));
  animation: tfxShatter .44s ease-out forwards;
}
@keyframes tfxShatter {
  0%   { opacity: 0;  transform: scale(.5); }
  35%  { opacity: .9; }
  100% { opacity: 0;  transform: scale(1.25); }
}

/* Draegor: zarpazos rojos sobre la celda golpeada */
.draegor-claw {
  position: fixed; z-index: 9005; pointer-events: none; overflow: hidden; border-radius: 8px;
  background: linear-gradient(122deg,
    transparent 36%, var(--clawcol) 36% 37.6%, transparent 37.6% 45%,
    var(--clawcol) 45% 46.6%, transparent 46.6% 53%,
    var(--clawcol) 53% 54.6%, transparent 54.6% 62%,
    var(--clawcol) 62% 63.6%, transparent 63.6%);
  -webkit-mask-image: linear-gradient(122deg, transparent 30%, #000 42%, #000 58%, transparent 70%);
          mask-image: linear-gradient(122deg, transparent 30%, #000 42%, #000 58%, transparent 70%);
  filter: drop-shadow(0 0 4px var(--clawcol));
  animation: draegorClaw .42s ease-out forwards;
}
@keyframes draegorClaw {
  0%   { opacity: 0; transform: scale(.55) rotate(-7deg); }
  35%  { opacity: 1; }
  100% { opacity: 0; transform: scale(1.2) rotate(-7deg); }
}
/* Zarpazo invertido (otra diagonal) — junto al normal forma una CRUZ */
.draegor-claw.claw-inv {
  background: linear-gradient(58deg,
    transparent 36%, var(--clawcol) 36% 37.6%, transparent 37.6% 45%,
    var(--clawcol) 45% 46.6%, transparent 46.6% 53%,
    var(--clawcol) 53% 54.6%, transparent 54.6% 62%,
    var(--clawcol) 62% 63.6%, transparent 63.6%);
  -webkit-mask-image: linear-gradient(58deg, transparent 30%, #000 42%, #000 58%, transparent 70%);
          mask-image: linear-gradient(58deg, transparent 30%, #000 42%, #000 58%, transparent 70%);
  animation: draegorClawInv .42s ease-out forwards;
}
@keyframes draegorClawInv {
  0%   { opacity: 0; transform: scale(.55) rotate(7deg); }
  35%  { opacity: 1; }
  100% { opacity: 0; transform: scale(1.2) rotate(7deg); }
}

/* Nyrakk: estallido morado simultáneo en cada celda golpeada */
.board-cell.nyrakk-blast { animation: nyrakkBlast .48s ease-out; z-index: 25; }
@keyframes nyrakkBlast {
  0%   { filter: brightness(1); box-shadow: inset 0 0 0 rgba(123,31,162,0); }
  35%  { filter: brightness(2.2) saturate(1.4); box-shadow: inset 0 0 30px #7b1fa2, 0 0 26px #7b1fa2; }
  100% { filter: brightness(1); box-shadow: inset 0 0 0 rgba(123,31,162,0); }
}

/* Solvyrn (Solmira): contenedor que recorta el destello al tablero */
.solvyrn-clip {
  position: fixed; z-index: 9004; pointer-events: none;
  overflow: hidden; border-radius: 10px;
}
/* Solvyrn (Solmira): irradiar luz desde el centro */
.solvyrn-radiance {
  position: fixed; z-index: 9005; pointer-events: none;
  width: 24px; height: 24px; margin: -12px 0 0 -12px; border-radius: 50%;
  background: radial-gradient(circle, #fff 0%, var(--c) 38%, transparent 72%);
  filter: drop-shadow(0 0 30px var(--c));
  --sc: 16;
  animation: solvyrnRadiance .9s ease-out forwards;
}
@keyframes solvyrnRadiance {
  0%   { opacity: 0; transform: scale(.3); }
  20%  { opacity: 1; }
  100% { opacity: 0; transform: scale(var(--sc)); }
}
/* Rayos de sol giratorios que barren la pantalla desde Solvyrn */
.solvyrn-rays {
  position: fixed; z-index: 9004; pointer-events: none;
  width: 220vmax; height: 220vmax; margin: -110vmax 0 0 -110vmax; border-radius: 50%;
  background: repeating-conic-gradient(from 0deg,
    transparent 0deg 7deg, color-mix(in srgb, var(--c) 70%, transparent) 7deg 11deg, transparent 11deg 18deg);
  -webkit-mask-image: radial-gradient(circle, #000 0%, #000 18%, transparent 55%);
          mask-image: radial-gradient(circle, #000 0%, #000 18%, transparent 55%);
  filter: drop-shadow(0 0 14px var(--c));
  animation: solvyrnRays 1.4s ease-out forwards;
}
@keyframes solvyrnRays {
  0%   { opacity: 0; transform: scale(.1) rotate(0deg); }
  25%  { opacity: .95; }
  100% { opacity: 0; transform: scale(1) rotate(48deg); }
}
/* Enemigo bañado en luz por Solvyrn — PARPADEA brillando varias veces */
.board-cell.cell-radiant { animation: cellRadiant 1.4s ease-out; z-index: 22; }
@keyframes cellRadiant {
  0%   { filter: brightness(1);   box-shadow: 0 0 0 rgba(251,192,45,0); }
  12%  { filter: brightness(2.6) saturate(1.4); box-shadow: 0 0 34px #fbc02d, inset 0 0 26px #fff7d6; }
  28%  { filter: brightness(1.2); box-shadow: 0 0 8px rgba(251,192,45,.3); }
  44%  { filter: brightness(2.4) saturate(1.4); box-shadow: 0 0 30px #fbc02d, inset 0 0 22px #fff7d6; }
  60%  { filter: brightness(1.2); box-shadow: 0 0 8px rgba(251,192,45,.3); }
  76%  { filter: brightness(2.1) saturate(1.3); box-shadow: 0 0 26px #fbc02d, inset 0 0 20px #fff7d6; }
  100% { filter: brightness(1);   box-shadow: 0 0 0 rgba(251,192,45,0); }
}

/* Sylvrakh (Sylvel): malla de zarcillos vivientes (CSS) sobre la banda */
.sylvrakh-roots {
  position: fixed; z-index: 9003; pointer-events: none; border-radius: 10px;
  overflow: hidden; opacity: 0; transition: opacity .4s ease;
  background:
    repeating-conic-gradient(from 12deg at 28% 110%,
      transparent 0deg 16deg, rgba(95,209,122,.22) 16deg 18deg, transparent 18deg 34deg),
    repeating-conic-gradient(from -6deg at 74% 120%,
      transparent 0deg 14deg, rgba(46,125,50,.28) 14deg 16deg, transparent 16deg 30deg),
    radial-gradient(120% 80% at 50% 120%, rgba(46,125,50,.25), transparent 60%);
  animation: sylvRootsBreathe 1.6s ease-in-out infinite;
}
@keyframes sylvRootsBreathe {
  0%, 100% { filter: brightness(1); }
  50%      { filter: brightness(1.35); }
}

/* Eldrian (Sylvel): raíces vivas Physarum (canvas puro) que avanzan desde su posición.
   Mezcla 'screen' → el negro del canvas se vuelve invisible y solo brilla el verde. */
canvas.physarum-fx {
  position: fixed; z-index: 9003; pointer-events: none; border-radius: 10px;
  opacity: 1; transition: opacity .5s ease;
  mix-blend-mode: screen;
}

/* ── Impacto PRIMORDIAL (carga + azote previo al poder) ── */
.primordial-vignette {
  position: fixed; inset: 0; pointer-events: none; z-index: 9000;
  background: radial-gradient(circle at center, transparent 28%, rgba(0,0,0,.62) 100%);
  opacity: 0; transition: opacity .3s ease;
}
.converge-ring {
  position: fixed; pointer-events: none; z-index: 9008;
  border: 3px solid; border-radius: 50%;
  transform: translate(-50%, -50%) scale(1);
  filter: drop-shadow(0 0 8px currentColor);
  animation: convergeRing .58s ease-in forwards;
}
@keyframes convergeRing {
  0%   { opacity: 0;  transform: translate(-50%, -50%) scale(1); }
  25%  { opacity: .95; }
  100% { opacity: 0;  transform: translate(-50%, -50%) scale(.08); }
}
.primordial-slam-flash {
  position: fixed; inset: 0; pointer-events: none; z-index: 9009;
  background: radial-gradient(circle at center, var(--c), transparent 62%);
  mix-blend-mode: screen;
  animation: pSlamFlash .42s ease-out forwards;
}
@keyframes pSlamFlash {
  0%   { opacity: 0; }
  14%  { opacity: .9; }
  100% { opacity: 0; }
}
.primordial-shock {
  position: fixed; width: 44px; height: 44px; margin: -22px 0 0 -22px;
  border-radius: 50%; border: 6px solid var(--c);
  pointer-events: none; z-index: 9008;
  box-shadow: 0 0 30px var(--c), inset 0 0 18px var(--c);
  animation: pShock .68s ease-out forwards;
}
@keyframes pShock {
  0%   { opacity: .9; transform: scale(.2); }
  100% { opacity: 0;  transform: scale(15); }
}

/* ── FUSIÓN PRIMORDIAL (3 Primordiales) — cataclismo ── */
.fusion-vignette {
  position: fixed; inset: 0; z-index: 9000; pointer-events: none;
  background: radial-gradient(circle at center, transparent 18%, rgba(0,0,0,.82) 100%);
  opacity: 0; transition: opacity .4s ease;
}
.fusion-card {
  position: fixed; z-index: 9008; pointer-events: none;
  border-radius: 8px; overflow: hidden;
  box-shadow: 0 0 30px #ffd54a, 0 0 70px rgba(255,255,255,.7);
}
.fusion-orb {
  position: fixed; z-index: 9009; width: 64px; height: 64px; margin: -32px 0 0 -32px;
  border-radius: 50%; pointer-events: none;
  background: radial-gradient(circle, #fff 0%, #ffe08a 38%, #ff9d3a 68%, transparent 80%);
  box-shadow: 0 0 55px #ffd54a, 0 0 130px rgba(255,255,255,.85);
}
/* Orbe CARGANDO energía: late rápido antes de estallar */
.fusion-orb.fusion-charge { animation: fusionCharge .42s ease-in-out infinite; }
@keyframes fusionCharge {
  0%,100% { transform: scale(.85); box-shadow: 0 0 40px #ffd54a, 0 0 90px rgba(255,255,255,.7); }
  50%     { transform: scale(1.25); box-shadow: 0 0 70px #ffd54a, 0 0 150px #fff; }
}
/* Singularidad (agujero negro) — núcleo negro con halo de acreción */
.bh-core {
  position: fixed; z-index: 9009; width: 92px; height: 92px; margin: -46px 0 0 -46px;
  border-radius: 50%; pointer-events: none;
  background: radial-gradient(circle, #000 0%, #000 54%, rgba(30,0,45,.55) 68%, transparent 78%);
  box-shadow: 0 0 26px 5px rgba(255,213,74,.65), 0 0 56px 10px rgba(155,48,201,.55), 0 0 90px 18px rgba(58,208,106,.3);
  transform: translate(-50%,-50%) scale(0); transition: transform .5s ease-out;
}
/* Disco de acreción: anillo de colores girando alrededor del núcleo */
.bh-disk {
  position: fixed; z-index: 9008; width: 260px; height: 260px; margin: -130px 0 0 -130px;
  border-radius: 50%; pointer-events: none; opacity: 0; transition: opacity .4s ease;
  background: conic-gradient(from 0deg,
    transparent 0deg, rgba(255,213,74,.8) 40deg, rgba(155,48,201,.7) 130deg,
    transparent 180deg, rgba(58,208,106,.7) 250deg, rgba(255,213,74,.6) 320deg, transparent 360deg);
  -webkit-mask-image: radial-gradient(circle, transparent 28%, #000 36%, #000 60%, transparent 72%);
          mask-image: radial-gradient(circle, transparent 28%, #000 36%, #000 60%, transparent 72%);
  filter: blur(2px) drop-shadow(0 0 12px rgba(255,213,74,.6));
  transform: translate(-50%,-50%);
  animation: bhSpin 1.1s linear infinite;
}
@keyframes bhSpin {
  from { transform: translate(-50%,-50%) rotate(0deg); }
  to   { transform: translate(-50%,-50%) rotate(360deg); }
}

.fusion-slam-flash {
  position: fixed; inset: 0; z-index: 9011; pointer-events: none;
  background: radial-gradient(circle at center, #fff 0%, #ffe08a 40%, transparent 72%);
  animation: fusionFlash .52s ease-out forwards;
}
@keyframes fusionFlash { 0% { opacity: 0; } 12% { opacity: 1; } 100% { opacity: 0; } }
.fusion-shock {
  position: fixed; z-index: 9010; width: 50px; height: 50px; margin: -25px 0 0 -25px;
  border-radius: 50%; pointer-events: none;
  border: 8px solid #ffd54a;
  box-shadow: 0 0 40px #ffd54a, inset 0 0 26px #fff;
  animation: fusionShock .78s ease-out forwards;
}
@keyframes fusionShock {
  0%   { opacity: .95; transform: scale(.2); }
  100% { opacity: 0;   transform: scale(22); }
}

/* Eldrian: nube de partículas (estilo particle-love). Mezcla 'screen' → el negro
   del canvas es invisible y solo brilla el verde aditivo sobre el tablero. */
canvas.eldrian-particles {
  position: fixed; z-index: 9003; pointer-events: none; border-radius: 10px;
  opacity: 1; transition: opacity .5s ease;
  mix-blend-mode: screen;
}

/* Vornyx (Umbryss): ramas del Velo (canvas puro) emanando de su centro. */
canvas.trunk-fx {
  position: fixed; z-index: 9003; pointer-events: none;
  opacity: 1; transition: opacity .5s ease;
  mix-blend-mode: screen;
}
/* Zarcillo que brota desde la base de una carta enemiga */
.root-vine {
  position: fixed; z-index: 9006; pointer-events: none;
  width: 3px; transform-origin: bottom center;
  background: linear-gradient(to top, #2e7d32, #5fd17a 60%, transparent);
  border-radius: 3px;
  filter: drop-shadow(0 0 3px #5fd17a);
  transform: rotate(var(--rot, 0deg)) scaleY(0);
  animation: rootGrow var(--d, .6s) ease-out forwards;
}
@keyframes rootGrow {
  0%   { transform: rotate(var(--rot,0deg)) scaleY(0);  opacity: 0; }
  20%  { opacity: 1; }
  70%  { transform: rotate(var(--rot,0deg)) scaleY(1);  opacity: 1; }
  100% { transform: rotate(var(--rot,0deg)) scaleY(1);  opacity: 0; }
}
/* Carta ENREDADA por Sylvrakh — tinte vegetal mientras dura */
.board-cell.cell-rooted { animation: cellRooted 1.5s ease-out; z-index: 21; }
@keyframes cellRooted {
  0%   { filter: brightness(1) saturate(1) hue-rotate(0deg); }
  25%  { filter: brightness(1.1) saturate(1.35) hue-rotate(-12deg); }
  75%  { filter: brightness(1.06) saturate(1.3) hue-rotate(-12deg); }
  100% { filter: brightness(1) saturate(1) hue-rotate(0deg); }
}

/* ── Korrathul (Khar-Dur): furia telúrica — picos de roca + polvo ── */
.rock-spike {
  position: fixed; z-index: 9006; pointer-events: none;
  transform-origin: bottom center;
  background: linear-gradient(to top, #4a3527, #8d6e57 55%, #b89274 90%);
  clip-path: polygon(50% 0%, 78% 38%, 64% 100%, 36% 100%, 22% 38%);
  box-shadow: inset 0 0 6px rgba(0,0,0,.5);
  filter: drop-shadow(0 0 3px rgba(255,122,51,.5));
  transform: rotate(var(--rot,0deg)) scaleY(0);
  animation: rockErupt .55s cubic-bezier(.2,1.2,.35,1) forwards;
}
@keyframes rockErupt {
  0%   { transform: rotate(var(--rot,0deg)) scaleY(0);   opacity: 0; }
  25%  { opacity: 1; }
  70%  { transform: rotate(var(--rot,0deg)) scaleY(1.08); opacity: 1; }
  100% { transform: rotate(var(--rot,0deg)) scaleY(1);   opacity: 0; }
}
.quake-dust {
  position: fixed; z-index: 9005; pointer-events: none;
  width: 14px; height: 14px; border-radius: 50%;
  background: radial-gradient(circle, rgba(180,146,116,.6), rgba(120,95,70,.25) 60%, transparent 75%);
  filter: blur(2px);
  animation: quakeDust .9s ease-out forwards;
}
@keyframes quakeDust {
  0%   { opacity: 0; transform: translateY(0) scale(.5); }
  25%  { opacity: .8; }
  100% { opacity: 0; transform: translateY(-30px) scale(1.8); }
}
.board-cell.cell-quaked { animation: cellQuaked .7s ease-out; z-index: 21; }
@keyframes cellQuaked {
  0%   { filter: brightness(1) sepia(0); }
  30%  { filter: brightness(1.15) sepia(.4) saturate(1.3); box-shadow: inset 0 0 16px rgba(255,122,51,.5); }
  100% { filter: brightness(1) sepia(0); box-shadow: none; }
}

/* ── Aethmaris (Aetharion): tormenta del éter — orbes, rayos y glifos ── */
.aether-orb {
  position: fixed; z-index: 9006; pointer-events: none;
  width: 12px; height: 12px; margin: -6px 0 0 -6px; border-radius: 50%;
  background: radial-gradient(circle, #fff, #2fd6c4 60%, transparent 75%);
  filter: drop-shadow(0 0 6px #2fd6c4);
  animation: aetherOrb .65s ease-in forwards;
}
@keyframes aetherOrb {
  0%   { opacity: 0; transform: rotate(var(--a)) translateX(46px) scale(.6); }
  35%  { opacity: 1; }
  100% { opacity: 0; transform: rotate(var(--a)) translateX(0) scale(1.3); }
}
/* Tormenta del Éter: cielo oscuro (las gotas son hijos .rain-drop) */
.aether-storm {
  position: fixed; z-index: 9002; pointer-events: none; border-radius: 10px;
  overflow: hidden; opacity: 0; transition: opacity .35s ease;
  background: linear-gradient(rgba(8,26,30,.42), rgba(8,26,30,.26));
}
/* Gota de lluvia: trazo fino que cae y se repite */
.rain-drop {
  position: absolute; top: 0; width: 1.6px; border-radius: 1px;
  background: linear-gradient(to bottom, rgba(220,250,247,0), rgba(220,250,247,.9));
  transform: translateY(-36px) rotate(8deg); transform-origin: top center;
  animation-name: rainFall; animation-timing-function: linear; animation-iteration-count: infinite;
}
@keyframes rainFall {
  0%   { transform: translateY(-36px) rotate(8deg); }
  100% { transform: translateY(var(--fall, 320px)) rotate(8deg); }
}
/* Cartas enemigas TIRITANDO de frío (temblor rápido) — random por carta */
.board-cell.cell-shiver {
  z-index: 20;
  animation: cellShiver var(--sv, .09s) steps(2, end) infinite;
}
@keyframes cellShiver {
  0%   { transform: translate(calc(-1 * var(--svx, 2px)), 0); }
  25%  { transform: translate(var(--svx, 2px), calc(-1 * var(--svy, 1px))); }
  50%  { transform: translate(calc(-1 * var(--svx, 2px)), var(--svy, 1px)); }
  75%  { transform: translate(var(--svx, 2px), 0); }
  100% { transform: translate(calc(-1 * var(--svx, 2px)), 0); }
}

/* RELÁMPAGO en zigzag (clip-path) que cae sobre la carta */
.aether-bolt {
  position: fixed; z-index: 9006; pointer-events: none; transform-origin: top center;
  background: linear-gradient(to bottom, rgba(174,247,239,0), #aef7ef 14%, #2fd6c4 55%, #ffffff 96%);
  filter: drop-shadow(0 0 6px #2fd6c4) drop-shadow(0 0 12px #2fd6c4);
  clip-path: polygon(
    54% 0%, 64% 0%, 47% 23%, 60% 25%,
    40% 50%, 55% 52%, 44% 74%, 58% 76%,
    46% 100%, 38% 100%, 50% 75%, 34% 73%,
    47% 51%, 31% 49%, 50% 24%, 44% 22%);
  animation: aetherBolt .5s steps(1, end) forwards;
}
@keyframes aetherBolt {
  0%   { opacity: 0; transform: scaleY(0); }
  10%  { opacity: 1; transform: scaleY(1); }
  30%  { opacity: .3; }
  45%  { opacity: 1; }          /* flicker como rayo */
  65%  { opacity: .5; }
  80%  { opacity: 1; }
  100% { opacity: 0; transform: scaleY(1); }
}
/* Destello brillante del impacto */
.aether-flash {
  position: fixed; z-index: 9007; pointer-events: none;
  width: 14px; height: 14px; margin: -7px 0 0 -7px; border-radius: 50%;
  background: radial-gradient(circle, #fff 0%, #aef7ef 35%, rgba(47,214,196,.4) 60%, transparent 75%);
  filter: drop-shadow(0 0 10px #2fd6c4);
  animation: aetherFlash .34s ease-out forwards;
}
@keyframes aetherFlash {
  0%   { opacity: 0; transform: scale(.3); }
  25%  { opacity: 1; }
  100% { opacity: 0; transform: scale(6); }
}
/* Chispas que saltan del impacto */
.aether-spark {
  position: fixed; z-index: 9007; pointer-events: none;
  width: 4px; height: 4px; border-radius: 50%;
  background: #eafffb; box-shadow: 0 0 6px #2fd6c4;
  --sx: 0px; --sy: 0px;
  animation: aetherSpark .42s ease-out forwards;
}
@keyframes aetherSpark {
  0%   { opacity: 0; transform: translate(0,0) scale(1.3); }
  20%  { opacity: 1; }
  100% { opacity: 0; transform: translate(var(--sx), var(--sy)) scale(.2); }
}
.aether-glyph {
  position: fixed; z-index: 9007; pointer-events: none;
  width: var(--gs,40px); height: var(--gs,40px); margin: calc(var(--gs,40px) / -2) 0 0 calc(var(--gs,40px) / -2);
  border-radius: 50%;
  border: 2px solid rgba(47,214,196,.85);
  background:
    repeating-conic-gradient(from 0deg, rgba(47,214,196,.5) 0deg 4deg, transparent 4deg 30deg);
  -webkit-mask-image: radial-gradient(circle, transparent 56%, #000 60%, #000 84%, transparent 92%);
          mask-image: radial-gradient(circle, transparent 56%, #000 60%, #000 84%, transparent 92%);
  filter: drop-shadow(0 0 5px #2fd6c4);
  animation: aetherGlyph .7s ease-out forwards;
}
@keyframes aetherGlyph {
  0%   { opacity: 0; transform: scale(.3) rotate(0deg); }
  35%  { opacity: 1; }
  100% { opacity: 0; transform: scale(1.15) rotate(140deg); }
}
.board-cell.cell-aether { animation: cellAether .8s ease-out; z-index: 21; }
@keyframes cellAether {
  0%   { filter: brightness(1) saturate(1); }
  25%  { filter: brightness(1.5) saturate(1.3) hue-rotate(-8deg); box-shadow: inset 0 0 18px rgba(47,214,196,.6); }
  100% { filter: brightness(1) saturate(1); box-shadow: none; }
}

/* Khar'Zhul (hielo): vapor helado que se eleva ondulando desde cada carta */
.frost-vapor {
  position: fixed; z-index: 9006; pointer-events: none;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255,255,255,.55), rgba(191,233,255,.26) 55%, transparent 72%);
  filter: blur(2px);
  --dx: 0px; --sway: 0px; --rise: -42px; --rot: 0deg;
  animation: frostVapor 1.25s ease-out forwards;
}
@keyframes frostVapor {
  0%   { opacity: 0; transform: translate(0, 0) scale(.4) rotate(0deg); }
  20%  { opacity: .75; }
  55%  { opacity: .65; transform: translate(var(--sway), calc(var(--rise) * .5)) scale(1.15) rotate(calc(var(--rot) * .5)); }
  100% { opacity: 0;   transform: translate(var(--dx), var(--rise)) scale(1.85) rotate(var(--rot)); }
}
/* Escarcha que crece cubriendo una carta enemiga — translúcida (la carta se sigue viendo) */
.frost-overlay {
  position: fixed; z-index: 9006; pointer-events: none; border-radius: 6px; overflow: hidden;
  opacity: 0;
  background:
    radial-gradient(120% 90% at 10% 0%,   rgba(255,255,255,.4), transparent 42%),
    radial-gradient(120% 90% at 95% 12%,  rgba(214,242,255,.38), transparent 44%),
    radial-gradient(120% 110% at 50% 100%, rgba(160,210,240,.34), transparent 50%),
    repeating-conic-gradient(from 0deg at 50% 50%,
      rgba(255,255,255,.16) 0deg 6deg, transparent 6deg 24deg);
  box-shadow: inset 0 0 14px rgba(255,255,255,.45), inset 0 0 5px rgba(140,200,235,.4);
  -webkit-mask-image: radial-gradient(circle at 50% 60%, #000 0%, #000 var(--g,0%), transparent calc(var(--g,0%) + 16%));
          mask-image: radial-gradient(circle at 50% 60%, #000 0%, #000 var(--g,0%), transparent calc(var(--g,0%) + 16%));
  animation: frostGrow 1.6s ease-out forwards;
}
@keyframes frostGrow {
  0%   { --g: 0%;   opacity: 0; }
  20%  { opacity: .55; }
  55%  { --g: 120%; opacity: .55; }
  80%  { opacity: .5; }
  100% { --g: 120%; opacity: 0; }
}
/* Carta congelada: leve tinte azulado frío (sin tapar la carta) */
.board-cell.cell-frosted { animation: cellFrosted 1.6s ease-out; z-index: 21; }
@keyframes cellFrosted {
  0%   { filter: brightness(1) saturate(1); }
  25%  { filter: brightness(1.08) saturate(.78) hue-rotate(6deg); box-shadow: 0 0 14px rgba(191,233,255,.55), inset 0 0 10px rgba(191,233,255,.4); }
  75%  { filter: brightness(1.05) saturate(.82) hue-rotate(6deg); box-shadow: 0 0 11px rgba(191,233,255,.45), inset 0 0 8px rgba(191,233,255,.32); }
  100% { filter: brightness(1) saturate(1);     box-shadow: none; }
}
@property --g { syntax: '<percentage>'; inherits: false; initial-value: 0%; }
/* Variante "lock": la escarcha cuaja rápido al congelar al enemigo */
.frost-overlay.frost-lock { animation: frostLock .8s ease-out forwards; }
@keyframes frostLock {
  0%   { --g: 0%;   opacity: 0; }
  30%  { opacity: .6; }
  100% { --g: 120%; opacity: .6; }
}
/* Enemigo CONGELADO mientras dura el aturdimiento (saltará su ataque).
   Queda como ESTATUA de hielo: el mismo patrón estrellado de la animación,
   pero ESTÁTICO + brillo helado, mantenido toda la congelación.
   Sin resplandor exterior: no tapa el grid. */
.board-cell.cell-frozen {
  filter: brightness(1.14) saturate(.7) contrast(1.05) hue-rotate(6deg);
}
/* Capa de hielo: div hijo real (no ::after) → por encima de la capa de daño, persiste al bajar la vida */
.board-cell .frost-lock-layer {
  position: absolute; inset: 0; border-radius: inherit; pointer-events: none; z-index: 30;
  overflow: hidden;
  background:
    /* capa de hielo uniforme y OPACA sobre TODA la carta (visible aunque la carta se oscurezca) */
    linear-gradient(rgba(214,240,255,.62), rgba(176,216,242,.6)),
    /* brillos/escarcha repartidos por toda la superficie */
    radial-gradient(60% 50% at 22% 18%, rgba(255,255,255,.85), transparent 60%),
    radial-gradient(55% 45% at 80% 30%, rgba(255,255,255,.6), transparent 60%),
    radial-gradient(60% 50% at 35% 78%, rgba(220,240,255,.65), transparent 62%),
    radial-gradient(55% 45% at 85% 85%, rgba(200,228,248,.65), transparent 62%),
    /* grietas estrelladas radiando desde el centro (toda la carta) */
    repeating-conic-gradient(from 0deg at 50% 50%,
      rgba(255,255,255,.45) 0deg 1.6deg, transparent 1.6deg 24deg),
    /* finas estrías diagonales de escarcha */
    repeating-linear-gradient(58deg, transparent 0 9px, rgba(255,255,255,.22) 9px 10px, transparent 10px 20px);
  box-shadow: inset 0 0 24px rgba(255,255,255,.8), inset 0 0 9px rgba(140,200,235,.7);
  border: 2px solid rgba(220,244,255,.8);
}

/* Flash de celda Primordial al colocar */
.primordial-cell-flash {
  animation: primordialCellFlash .3s ease-out;
}
@keyframes primordialCellFlash {
  0%   { filter: brightness(1); }
  50%  { filter: brightness(3); }
  100% { filter: brightness(1); }
}

/* Celda bloqueada por Nyrakk — grieta permanente */
/* Grieta de Nyrakk — base limpia (relleno morado profundo + marco). El efecto de
   "células" lo aporta Vanta CELLS por encima (ver initNyrakkVantaGrietas en game.js).
   Si Vanta no cargara, queda este relleno como respaldo limpio (sin el CSS recargado). */
.cell-nyrakk-crack {
  position: relative;
  overflow: hidden;
}
.cell-nyrakk-crack::before {
  content: ''; position: absolute; inset: 0; z-index: 6; pointer-events: none;
  border-radius: inherit;
  background: radial-gradient(circle at 50% 45%, #2a0a45 0%, #160322 70%, #0d0118 100%);
}
.cell-nyrakk-crack::after {
  content: ''; position: absolute; inset: 0; z-index: 7; pointer-events: none;
  border-radius: inherit;
  border: 1px solid rgba(192,132,252,.55);
  box-shadow: inset 0 0 13px rgba(123,31,162,.85), 0 0 9px rgba(123,31,162,.5);
}
.cell-nyrakk-crack.empty { pointer-events: none !important; cursor: not-allowed !important; }

/* Eldrian — Raíces Profundas: celda bloqueada (temporal) cubierta de raíces verdes */
.cell-eldrian-root {
  position: relative;
  overflow: hidden;
}
.cell-eldrian-root::before {
  content: ''; position: absolute; inset: 0; z-index: 6; pointer-events: none;
  border-radius: inherit;
  background:
    radial-gradient(circle at 50% 55%, #123d1a 0%, #0a2410 70%, #061806 100%),
    /* zarcillos/raíces entrelazadas */
    repeating-conic-gradient(from 18deg at 32% 110%, transparent 0deg 16deg, rgba(95,209,122,.5) 16deg 18deg, transparent 18deg 34deg),
    repeating-conic-gradient(from -8deg at 72% 118%, transparent 0deg 14deg, rgba(46,125,50,.55) 14deg 16deg, transparent 16deg 30deg);
}
.cell-eldrian-root::after {
  content: ''; position: absolute; inset: 0; z-index: 7; pointer-events: none;
  border-radius: inherit;
  border: 1px solid rgba(120,235,140,.6);
  box-shadow: inset 0 0 13px rgba(46,125,50,.85), 0 0 9px rgba(95,209,122,.5);
  animation: eldrianRootPulse 1.8s ease-in-out infinite;
}
@keyframes eldrianRootPulse {
  0%,100% { box-shadow: inset 0 0 11px rgba(46,125,50,.7), 0 0 7px rgba(95,209,122,.4); }
  50%     { box-shadow: inset 0 0 18px rgba(46,125,50,.95), 0 0 14px rgba(95,209,122,.7); }
}
.cell-eldrian-root.empty { pointer-events: none !important; cursor: not-allowed !important; }

/* Capa de lienzos Vanta (uno por grieta) — sobrevive a los re-render del tablero */
#vanta-grieta-layer {
  position: fixed; inset: 0; z-index: 6; pointer-events: none;
}
.vanta-grieta {
  position: fixed; pointer-events: none; overflow: hidden;
  border-radius: 8px;
  box-shadow: inset 0 0 12px rgba(123,31,162,.85), 0 0 8px rgba(123,31,162,.5);
}
.vanta-grieta canvas { border-radius: 8px; display: block; }

/* Oleada de Aquarokh — overlay Vanta CELLS azul, SOLO sobre el tablero (posición
   y tamaño los fija game.js con el rect del tablero), barrido izq→der. */
.aquarokh-wave-vanta {
  position: fixed;         /* left/top/width/height los pone game.js */
  z-index: 175;            /* sobre el tablero y FX, bajo cinemáticas y modales */
  pointer-events: none;
  overflow: hidden;
  border-radius: 12px;
  opacity: .85;
  /* Barrido horizontal con borde de avance SUAVE — game.js anima mask-position */
  -webkit-mask-image: linear-gradient(to right, #000 46%, transparent 56%);
          mask-image: linear-gradient(to right, #000 46%, transparent 56%);
  -webkit-mask-size: 200% 100%;
          mask-size: 200% 100%;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: 100% 0;
          mask-position: 100% 0;
}
/* Viñeta: oscurece hacia las orillas para que no se vean duras sobre el tablero */
.aquarokh-wave-vanta::after {
  content: ''; position: absolute; inset: 0; z-index: 2; pointer-events: none;
  border-radius: 12px;
  background: radial-gradient(ellipse 118% 112% at 50% 50%, transparent 52%, rgba(2,10,25,.9) 100%);
}
.aquarokh-wave-vanta canvas { display: block; border-radius: 12px; }

/* Carta aturdida — Aquarokh Oleada */
.cell-stunned::after {
  content: ''; position: absolute; top: 3px; right: 4px;
  width: 10px; height: 10px; z-index: 7;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%230ea5e9'%3E%3Cpath d='M13 2 4.5 13.5H11l-1 8.5 8.5-11.5H12z'/%3E%3C/svg%3E") no-repeat center / contain;
  filter: drop-shadow(0 0 4px #0ea5e9);
  pointer-events: none;
}

/* Bloqueada por Enredadera (Eldrian) */
.cell-blocked-vine {
  position: relative; pointer-events: none;
}
.cell-blocked-vine::after {
  content: ''; position: absolute; inset: 0; border-radius: inherit;
  background: repeating-linear-gradient(
    45deg, rgba(46,125,50,.35) 0px, rgba(46,125,50,.35) 4px,
    transparent 4px, transparent 10px
  );
  pointer-events: none; z-index: 5;
}

/* Passive heal visual on card */
@keyframes cardHealPulse {
  0%   { box-shadow: 0 0 0 0 rgba(67,160,71,.7); }
  60%  { box-shadow: 0 0 0 8px rgba(67,160,71,0); }
  100% { box-shadow: 0 0 0 0 rgba(67,160,71,0); }
}
.card-heal-pulse { animation: cardHealPulse .5s ease-out; }

/* ══════════════════════════════════════════════════════
   TITLE SCREEN — VS IA / MULTIJUGADOR
   ══════════════════════════════════════════════════════ */
#screen-title {
  display: flex; flex-direction: column; align-items: center;
  justify-content: center; min-height: 100vh;
  background: var(--bg-deep, #0a0a0f);
  gap: 2.5rem;
}
.title-mode-btns {
  display: flex; gap: 1.4rem; flex-wrap: wrap; justify-content: center;
}
.title-mode-btn {
  background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.12);
  border-radius: 12px; padding: 1.6rem 2rem; width: 220px; cursor: pointer;
  text-align: center; transition: background .2s, border-color .2s, transform .15s;
  color: var(--text-primary, #e8dcc8);
}
.title-mode-btn:hover {
  background: rgba(255,255,255,.08); border-color: rgba(201,162,39,.5);
  transform: translateY(-2px);
}
.title-mode-icon { font-size: 2rem; margin-bottom: .6rem; }
.title-mode-name { font-size: .85rem; font-weight: 700; letter-spacing: .06em; margin-bottom: .4rem; }
.title-mode-info { font-size: .65rem; opacity: .55; }

/* ══════════════════════════════════════════════════════
   LOBBY
   ══════════════════════════════════════════════════════ */
#screen-lobby {
  display: flex; align-items: flex-start; justify-content: center;
  min-height: 100vh; background: var(--bg-deep, #0a0a0f);
  padding: 2rem 1rem;
}
/* ════════ LOBBY / SALAS — rediseño móvil apilado ════════ */
.lobby-wrap { width: 100%; max-width: 480px; margin: 0 auto; }
.lobby-header {
  display: flex; align-items: center; justify-content: center; gap: .8rem; margin-bottom: 1.2rem;
}
.lobby-brand { margin-bottom: 1rem; }
.lobby-title {
  font-family: 'Cinzel', var(--font-display, serif); font-size: .95rem;
  letter-spacing: .2em; color: var(--gold, #c9a227); opacity: .8;
}
.lobby-section { margin-bottom: 1.4rem; }
.lobby-section-label {
  font-size: .65rem; letter-spacing: .14em; opacity: .5;
  margin-bottom: .55rem; text-transform: uppercase;
}
.lobby-name-input-row { display: flex; gap: .6rem; }
.lobby-input {
  flex: 1; background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.15);
  border-radius: 10px; padding: .75rem .9rem; color: #e8dcc8;
  font-size: .9rem; outline: none; transition: border-color .2s;
}
.lobby-input:focus { border-color: rgba(201,162,39,.6); }
.lobby-name-btn {
  background: rgba(201,162,39,.15); border: 1px solid rgba(201,162,39,.4);
  border-radius: 10px; padding: .75rem 1.3rem; color: #c9a227;
  font-size: .82rem; letter-spacing: .08em; font-weight: 600; cursor: pointer;
  white-space: nowrap; transition: background .2s;
}
.lobby-name-btn:hover, .lobby-name-btn:active { background: rgba(201,162,39,.28); }

/* Layout apilado (una columna, mobile-first) */
.lobby-columns { display: flex; flex-direction: column; gap: 1.5rem; }
.lobby-col-title {
  font-size: .66rem; letter-spacing: .14em; opacity: .55;
  margin-bottom: .7rem; text-transform: uppercase;
}

/* CTA: Crear sala — estilo Eclipsorian dorado resplandeciente, al fondo */
.lobby-create-btn {
  order: 5; width: 100%; margin: .2rem 0 0; display: flex; align-items: center; justify-content: center; gap: .55rem;
  padding: .95rem; border-radius: 13px;
  background: linear-gradient(135deg, #c9a22a 0%, #f0c84a 50%, #c9a22a 100%);
  border: 1px solid rgba(245,224,122,.6); color: #07070d;
  font-family: 'Cinzel', var(--font-display, serif); font-size: .9rem; font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase; cursor: pointer; transition: all .18s;
  box-shadow: 0 0 22px rgba(201,162,42,.45), 0 4px 14px rgba(0,0,0,.4);
}
.lobby-create-btn:hover, .lobby-create-btn:active {
  box-shadow: 0 0 34px rgba(245,224,122,.75), 0 4px 14px rgba(0,0,0,.4); transform: translateY(-1px);
}
.lobby-create-btn svg { width: 18px; height: 18px; stroke: #07070d; }

/* Lista de salas: tarjetas apiladas */
.lobby-rooms {
  background: none; border: none; padding: 0; min-height: 0; max-height: none;
  overflow: visible; display: flex; flex-direction: column; gap: .6rem;
}
.lobby-room-row {
  cursor: pointer; display: flex; align-items: center; justify-content: space-between; gap: .8rem;
  border: 1px solid rgba(255,255,255,.1); background: rgba(255,255,255,.035);
  border-radius: 13px; padding: .8rem .85rem; margin: 0; font-size: .8rem;
  transition: transform .15s, background .15s, border-color .15s;
}
.lobby-room-row::before {
  content: ''; flex-shrink: 0; width: 36px; height: 36px; border-radius: 10px;
  background: rgba(129,140,248,.12) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23a5b4fc' stroke-width='1.6' stroke-linejoin='round'%3E%3Cpath d='M12 2 21 7v10l-9 5-9-5V7z'/%3E%3C/svg%3E") no-repeat center / 20px;
}
.lobby-room-row:hover, .lobby-room-row:active {
  background: rgba(99,102,241,.14); border-color: rgba(129,140,248,.55); transform: translateY(-1px);
}
.lobby-room-row > div:not([class]) { flex: 1; min-width: 0; }
.lobby-room-name { font-weight: 700; color: #ece2cf; font-size: .92rem; }
.lobby-room-mode { font-size: .72rem; opacity: .55; margin-top: 2px; }
.lobby-room-join {
  flex-shrink: 0; display: flex; align-items: center;
  font-size: .72rem; color: #07070d; font-weight: 700; letter-spacing: .04em;
  background: #818cf8; padding: .45rem .8rem; border-radius: 9px; text-transform: uppercase;
}
.lobby-empty {
  opacity: .4; font-size: .76rem; padding: 1rem; text-align: center;
  border: 1px dashed rgba(255,255,255,.1); border-radius: 12px;
}

/* En línea: chips horizontales */
.lobby-players {
  background: none; border: none; padding: 0; min-height: 0; max-height: none;
  overflow: visible; display: flex; flex-wrap: wrap; gap: .5rem;
}
.lobby-player-row {
  width: auto; margin: 0; padding: .42rem .8rem; gap: .45rem; font-size: .76rem;
  display: flex; align-items: center; color: #c8d8c0;
  background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.1); border-radius: 20px;
}
.lobby-player-dot {
  width: 6px; height: 6px; border-radius: 50%; background: #4ade80; flex-shrink: 0;
  box-shadow: 0 0 5px #4ade80;
}
.lobby-player-me { border-color: rgba(251,191,36,.5); background: rgba(251,191,36,.1); color: #fde68a; }
.lobby-player-me .lobby-player-dot { background: #fbbf24; box-shadow: 0 0 5px #fbbf24; }

/* Esperando rival */
#lobby-waiting { margin-top: 0; display: flex; justify-content: center; }
.lobby-waiting-box {
  width: 100%; background: rgba(255,255,255,.04); border: 1px solid rgba(201,162,39,.25);
  border-radius: 14px; padding: 1.8rem 1.5rem; text-align: center;
}
.lobby-waiting-title {
  font-size: .9rem; font-weight: 700; letter-spacing: .12em; color: #c9a227; margin-bottom: .4rem;
}
.lobby-waiting-info { font-size: .78rem; opacity: .55; margin-bottom: .6rem; }
.lobby-waiting-dots span {
  display: inline-block; animation: dotPulse 1.2s infinite;
  font-size: 1.6rem; color: #c9a227; margin: 0 2px;
}
.lobby-waiting-dots span:nth-child(2) { animation-delay: .2s; }
.lobby-waiting-dots span:nth-child(3) { animation-delay: .4s; }
@keyframes dotPulse { 0%,80%,100% { opacity: .2; } 40% { opacity: 1; } }
.lobby-cancel-btn {
  margin-top: 1.2rem; padding: .6rem 1.4rem; background: rgba(239,68,68,.1);
  border: 1px solid rgba(239,68,68,.3); border-radius: 9px; color: #f87171;
  font-size: .78rem; cursor: pointer; transition: background .2s;
}
.lobby-cancel-btn:hover, .lobby-cancel-btn:active { background: rgba(239,68,68,.2); }

/* ══════════════════════════════════════════════════════
   HOVER DEL OPONENTE — celda que está considerando
   ══════════════════════════════════════════════════════ */
.board-cell.opponent-hover {
  border-color: rgba(255,255,255,.55) !important;
  border-style: dashed !important;
  border-width: 2px !important;
  animation: opponentHoverPulse .7s ease-in-out infinite !important;
}
@keyframes opponentHoverPulse {
  0%,100% { box-shadow: 0 0 5px 1px rgba(255,255,255,.2); }
  50%      { box-shadow: 0 0 14px 4px rgba(255,255,255,.45); }
}

/* ══════════════════════════════════════════════════════
   MP — Overlay "esperando rival"
   ══════════════════════════════════════════════════════ */
#mp-waiting-overlay {
  position: fixed; inset: 0; z-index: 6000;
  background: rgba(0,0,0,.82); backdrop-filter: blur(6px);
  display: flex; align-items: center; justify-content: center;
}
.mp-waiting-box { text-align: center; }
.mp-waiting-title {
  font-family: var(--font-display, serif); font-size: 1.1rem;
  letter-spacing: .2em; color: var(--gold, #c9a227);
  margin-bottom: .6rem;
}
.mp-waiting-sub { font-size: .8rem; opacity: .6; margin-bottom: 1rem; }

/* ══════════════════════════════════════════════════════
   MP — Cuenta regresiva épica
   ══════════════════════════════════════════════════════ */
#mp-countdown-overlay {
  position: fixed; inset: 0; z-index: 7000;
  background: rgba(0,0,0,.92);
  display: flex; align-items: center; justify-content: center;
}
.mp-countdown-inner { text-align: center; }
#mp-countdown-title {
  font-family: var(--font-display, serif);
  font-size: clamp(1rem, 4vw, 1.6rem);
  letter-spacing: .22em; color: #fbbf24;
  text-shadow: 0 0 30px #fbbf24, 0 0 60px #f59e0b;
  margin-bottom: 1.2rem;
  animation: mpTitlePulse 1s ease-in-out infinite alternate;
}
@keyframes mpTitlePulse {
  from { text-shadow: 0 0 20px #fbbf24, 0 0 40px #f59e0b; }
  to   { text-shadow: 0 0 40px #fbbf24, 0 0 80px #f59e0b, 0 0 120px #d97706; }
}
#mp-countdown-num {
  font-family: var(--font-display, serif);
  font-size: clamp(4rem, 16vw, 9rem); font-weight: 900;
  color: #fff; line-height: 1;
  text-shadow: 0 0 40px rgba(255,255,255,.6);
  transition: transform .15s, opacity .15s;
}
#mp-countdown-vs {
  font-size: clamp(.65rem, 2vw, .9rem); letter-spacing: .18em;
  color: rgba(255,255,255,.45); margin-top: .8rem;
}

/* MP dentro del combat prompt */
.cp-mp-waiting {
  text-align: center; padding: .4rem 0;
}
.cp-mp-waiting-text {
  font-size: .8rem; color: rgba(232,220,200,.65);
  margin-bottom: .2rem;
}
.cp-mp-rival-ready {
  font-size: .7rem; color: #4ade80;
  text-align: center; margin-bottom: .5rem;
  animation: rivalReadyPulse 1.2s ease-in-out infinite alternate;
}
@keyframes rivalReadyPulse {
  from { opacity: .7; } to { opacity: 1; }
}

/* ═══════════════════════════════════════════════════
   MP: Lobby polish — abandon overlay, rematch, room status
   ═══════════════════════════════════════════════════ */

/* ── Overlay de abandono y notificaciones ── */
#mp-abandon-overlay {
  position: fixed; inset: 0; z-index: 9500;
  background: rgba(0,0,0,.85); backdrop-filter: blur(6px);
  display: flex; align-items: center; justify-content: center;
}
#mp-abandon-overlay.hidden { display: none; }
.mp-abandon-box {
  text-align: center; display: flex; flex-direction: column;
  gap: 16px; align-items: center;
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: 14px; padding: 40px 56px;
  min-width: 280px;
}
.mp-abandon-title { font-size: 1rem; letter-spacing: .12em; color: #f87171; }
.mp-abandon-num {
  font-size: 3.5rem; font-weight: 900; color: var(--gold);
  font-family: var(--font-display, serif); line-height: 1;
}
.mp-abandon-cancel {
  padding: 8px 28px; border-radius: 6px; font-size: .8rem; letter-spacing: .1em;
  background: rgba(255,255,255,.06); border: 1px solid var(--border);
  color: var(--dim); cursor: pointer; transition: background .15s, color .15s;
}
.mp-abandon-cancel:hover { background: rgba(255,255,255,.14); color: var(--text); }

/* ── Game over MP: zona revancha ── */
#over-mp-zone { width: 100%; margin-top: 10px; }
.mp-go-actions {
  display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; margin-bottom: 14px;
}
.mp-go-rematch {
  padding: 11px 26px; background: rgba(250,189,0,.1);
  border: 1px solid var(--gold); color: var(--gold);
  font-size: .8rem; letter-spacing: .12em; border-radius: 6px;
  cursor: pointer; transition: background .2s;
}
.mp-go-rematch:hover:not(:disabled) { background: var(--gold); color: #000; }
.mp-go-rematch:disabled { opacity: .5; cursor: default; pointer-events: none; }
.mp-go-lobby {
  padding: 11px 26px; background: var(--bg3); border: 1px solid var(--border);
  color: var(--dim); font-size: .8rem; letter-spacing: .12em;
  border-radius: 6px; cursor: pointer; transition: background .2s;
}
.mp-go-lobby:hover { background: rgba(255,255,255,.08); color: var(--text); }

/* ── Invitación a revancha recibida ── */
.mp-go-invite-box {
  background: rgba(99,102,241,.1); border: 1px solid rgba(99,102,241,.3);
  border-radius: 8px; padding: 16px 22px; margin-top: 4px;
}
.mp-go-invite-title { font-size: .82rem; color: var(--text); margin-bottom: 6px; }
.mp-go-invite-countdown {
  font-size: 1.6rem; font-weight: 800; color: var(--gold); margin-bottom: 12px;
}
.mp-go-invite-btns { display: flex; gap: 10px; justify-content: center; }
.mp-go-accept {
  padding: 8px 22px; background: rgba(74,222,128,.1); border: 1px solid #4ade80;
  color: #4ade80; border-radius: 6px; cursor: pointer; font-size: .78rem;
  transition: background .15s;
}
.mp-go-accept:hover { background: rgba(74,222,128,.22); }
.mp-go-decline {
  padding: 8px 22px; background: rgba(239,68,68,.07); border: 1px solid #ef4444;
  color: #ef4444; border-radius: 6px; cursor: pointer; font-size: .78rem;
  transition: background .15s;
}
.mp-go-decline:hover { background: rgba(239,68,68,.18); }
.mp-go-waiting {
  font-size: .78rem; color: var(--dim); margin-top: 6px;
  font-style: italic;
}

/* ── Lobby: salas activas (en juego) ── */
.lobby-room-active { opacity: .75; cursor: default !important; }
.lobby-room-active:hover { background: var(--bg2) !important; border-color: var(--border) !important; }
.lobby-room-status {
  font-size: .68rem; padding: 3px 9px;
  background: rgba(239,68,68,.1); border: 1px solid rgba(239,68,68,.25);
  color: #f87171; border-radius: 10px; white-space: nowrap;
}

/* Pantallas muy chicas: el grid de selección baja a mínimo 3 columnas (sobre la regla de 4 de ≤600px) */
@media (max-width: 430px) {
  #card-pool { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

/* ═══════════════════════════════════════════
   SANDBOX — laboratorio de pruebas
   ═══════════════════════════════════════════ */

/* Botón de título: oculto hasta desbloquear con "eclipse" + clave */
#title-mode-sandbox { display: none; }
body.sandbox-unlocked #title-mode-sandbox { display: block; }
.title-mode-sandbox { border-color: rgba(201,162,42,.4); }

/* Overlay de contraseña */
.sb-pw-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,.85); z-index: 9600;
  display: flex; align-items: center; justify-content: center;
  opacity: 0; pointer-events: none; transition: opacity .2s; backdrop-filter: blur(6px);
}
.sb-pw-overlay.open { opacity: 1; pointer-events: all; }
.sb-pw-box { background: var(--bg2); border: 1px solid rgba(255,255,255,.1); border-top: 2px solid var(--gold); border-radius: 6px; padding: 32px 36px; width: 320px; text-align: center; }
.sb-pw-title { font-size: .8rem; letter-spacing: .3em; color: var(--gold); margin-bottom: 8px; font-weight: 800; }
.sb-pw-sub { font-size: .72rem; color: var(--dim); margin-bottom: 20px; }
.sb-pw-input { width: 100%; background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.12); color: #fff; font-size: 1rem; text-align: center; letter-spacing: .2em; padding: 10px 14px; border-radius: 3px; outline: none; transition: border-color .2s; margin-bottom: 14px; }
.sb-pw-input:focus { border-color: rgba(201,162,42,.5); }
.sb-pw-input.error { border-color: #ef5350; animation: shake .3s; }
.sb-pw-btn { width: 100%; font-size: .72rem; letter-spacing: .2em; padding: 10px; background: rgba(201,162,42,.08); border: 1px solid rgba(201,162,42,.4); color: var(--gold); border-radius: 3px; cursor: pointer; transition: all .2s; font-weight: 700; }
.sb-pw-btn:hover { background: rgba(201,162,42,.15); }
.sb-pw-cancel { display: block; margin-top: 10px; font-size: .68rem; color: var(--dim); cursor: pointer; }
@keyframes shake { 0%,100%{transform:translateX(0)} 25%{transform:translateX(-6px)} 75%{transform:translateX(6px)} }

/* Toolbar, paneles: ocultos salvo en sandbox-mode */
#sb-toolbar, #sb-left, #sb-right { display: none; }
body.sandbox-mode #sb-toolbar { display: flex; }
body.sandbox-mode #sb-left,
body.sandbox-mode #sb-right { display: flex; }

/* En sandbox-mode: ocultar la UI de partida normal y dejar el tablero centrado */
body.sandbox-mode #enemy-hand-wrap,
body.sandbox-mode #game-bottom,
body.sandbox-mode #log-panel,
body.sandbox-mode #btn-pass,
body.sandbox-mode #turn-banner,
body.sandbox-mode #timer-bar-wrap { display: none !important; }
body.sandbox-mode #screen-game { padding: 0 352px 0 382px; }
body.sandbox-mode #board-wrap { padding-bottom: 56px; }

/* Barra de herramientas (abajo, centrada entre los paneles) */
#sb-toolbar {
  position: fixed; bottom: 14px; left: 50%; transform: translateX(-50%);
  z-index: 5200; align-items: center; gap: 10px;
  background: rgba(13,13,26,.92); border: 1px solid var(--border);
  border-radius: 12px; padding: 8px 14px; backdrop-filter: blur(6px);
  box-shadow: 0 10px 30px rgba(0,0,0,.6);
}
.sb-toolbar-title { font-size: .66rem; letter-spacing: .26em; color: var(--gold); font-weight: 800; margin-right: 4px; }
.sb-player-toggle { display: flex; gap: 0; border: 1px solid var(--border); border-radius: 8px; overflow: hidden; margin-right: 4px; }
.sb-player-btn { padding: 8px 14px; background: var(--bg3); color: var(--dim); border: none; font-size: .74rem; font-weight: 700; cursor: pointer; transition: all .15s; }
.sb-player-btn + .sb-player-btn { border-left: 1px solid var(--border); }
.sb-player-btn:hover { color: #fff; }
#sb-pa.active { background: rgba(96,165,250,.18); color: #90caf9; }
#sb-pb.active { background: rgba(239,83,80,.18); color: #ef9a9a; }
.sb-tool-btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 16px; border-radius: 8px; border: 1px solid var(--border);
  background: var(--bg3); color: var(--dim); font-size: .76rem; font-weight: 700;
  cursor: pointer; transition: all .15s; letter-spacing: .04em;
}
.sb-tool-btn:hover { color: #fff; border-color: var(--gold); }
.sb-tool-btn:disabled { opacity: .5; cursor: default; }
.sb-tool-fight { color: var(--gold); border-color: var(--gold); }
.sb-tool-fight:hover { background: rgba(201,162,42,.14); }

/* Paneles laterales */
.sb-panel {
  position: fixed; top: 0; bottom: 0; z-index: 5100;
  flex-direction: column; background: var(--bg2);
  border-left: 1px solid var(--border); border-right: 1px solid var(--border);
}
#sb-left  { left: 0;  width: 380px; border-left: none; }
#sb-right { right: 0; width: 350px; border-right: none; }
.sb-panel-head { padding: 14px 16px 10px; font-size: .7rem; letter-spacing: .22em; color: var(--gold); font-weight: 800; border-bottom: 1px solid var(--border); flex-shrink: 0; }

/* Pestañas del panel izquierdo */
.sb-panel-tabs { display: flex; flex-shrink: 0; border-bottom: 1px solid var(--border); }
.sb-tab { flex: 1; padding: 10px; font-size: .68rem; letter-spacing: .08em; background: none; border: none; color: var(--dim); cursor: pointer; border-bottom: 2px solid transparent; font-weight: 700; transition: all .15s; }
.sb-tab.active { color: var(--gold); border-bottom-color: var(--gold); }
.sb-panel-body { flex: 1; overflow-y: auto; padding: 14px 16px; }

/* Documentación de sinergias/pasivas */
.sb-doc-sec { margin-bottom: 18px; }
.sb-doc-h { font-size: .74rem; color: #fff; font-weight: 800; margin-bottom: 8px; letter-spacing: .04em; }
.sb-doc-sub { color: var(--dim); font-weight: 500; font-size: .66rem; }
.sb-doc-item { font-size: .72rem; color: rgba(255,255,255,.78); line-height: 1.5; padding: 6px 0; border-bottom: 1px solid rgba(255,255,255,.05); }
.sb-doc-item b { color: #fff; }
.sb-doc-reg { color: var(--dim); font-size: .66rem; }
.sb-doc-note { color: var(--dim); font-style: italic; border-bottom: none; }
.sb-pas-count { display: inline-block; font-size: .6rem; font-weight: 800; padding: 1px 6px; border-radius: 8px; background: rgba(255,255,255,.1); color: rgba(255,255,255,.7); vertical-align: middle; }
.sb-pas-count.sb-pas-unique { background: rgba(201,162,42,.18); color: var(--gold); }
.sb-pas-desc { font-size: .68rem; color: rgba(255,255,255,.65); line-height: 1.35; margin-top: 2px; }
.sb-doc-dot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; margin-right: 5px; vertical-align: middle; }

/* Sinergias visuales: tablero de referencia + texto */
.sb-syn-item { display: flex; gap: 11px; align-items: center; padding: 9px 0; border-bottom: 1px solid rgba(255,255,255,.05); }
.sb-syn-txt { display: flex; flex-direction: column; gap: 2px; font-size: .72rem; }
.sb-syn-txt b { color: #fff; }
.sb-syn-txt span { color: rgba(255,255,255,.72); line-height: 1.35; }
.sb-mini { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2px; width: 44px; flex-shrink: 0; }
.sb-mini-cell { aspect-ratio: 1; border-radius: 2px; background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.09); }
.sb-mini-cell.on  { background: var(--acc); border-color: var(--acc); box-shadow: 0 0 4px var(--acc); }
.sb-mini-cell.on2 { background: var(--acc); border-color: var(--acc); opacity: .42; }

/* Efectos por región inline bajo cada formación */
.sb-eff-list { margin: 6px 0 0; display: flex; flex-direction: column; gap: 3px; }
.sb-eff { font-size: .66rem; color: rgba(255,255,255,.6); line-height: 1.3; }
.sb-eff b { color: rgba(255,255,255,.85); font-weight: 700; }

/* Bloques por tier */
.sb-tier-block { padding: 10px 0 12px; border-bottom: 1px solid rgba(255,255,255,.07); }
.sb-tier-head { font-size: .74rem; color: #fff; font-weight: 800; margin-bottom: 8px; }
.sb-tier-sub { color: var(--dim); font-weight: 500; font-size: .64rem; }
.sb-shapes { display: flex; flex-wrap: wrap; gap: 12px; margin-bottom: 4px; }
.sb-shape { display: flex; flex-direction: column; align-items: center; gap: 3px; width: 44px; }
.sb-shape-name { font-size: .58rem; color: rgba(255,255,255,.7); text-align: center; line-height: 1.15; }

/* Botón "Probar" (sinergia) */
.sb-syn-test {
  margin-top: 3px; padding: 2px 8px; border-radius: 6px; border: 1px solid var(--gold);
  background: rgba(201,162,42,.1); color: var(--gold); font-size: .58rem; font-weight: 700; cursor: pointer;
  transition: all .12s; white-space: nowrap;
}
.sb-syn-test:hover { background: rgba(201,162,42,.22); color: #fff; }
.sb-syn-txt .sb-syn-test,
.sb-golpe-info .sb-syn-test { align-self: flex-start; margin-top: 5px; }

/* Fila de mini-tableros por golpe (varias posiciones) */
.sb-golpe-minis { display: flex; gap: 10px; flex-shrink: 0; }
.sb-golpe-minis .sb-mini { width: 46px; }

/* Pasivas ocultas: miniatura de la carta dueña + texto */
.sb-pas-item { display: flex; gap: 11px; align-items: center; padding: 9px 0; border-bottom: 1px solid rgba(255,255,255,.05); }
.sb-pas-thumbs { display: flex; gap: 4px; flex-shrink: 0; }
.sb-pas-thumb { width: 38px; aspect-ratio: 9/13; object-fit: cover; object-position: top; border-radius: 4px; border: 1.5px solid var(--border); }

/* Filtros del panel de cartas */
.sb-filters { padding: 10px 14px; border-bottom: 1px solid var(--border); flex-shrink: 0; }
.sb-fil-grp { display: flex; align-items: center; gap: 8px; margin-bottom: 7px; }
.sb-fil-grp:last-child { margin-bottom: 0; }
.sb-fil-lbl { font-size: .6rem; letter-spacing: .14em; color: var(--dim); width: 50px; flex-shrink: 0; text-transform: uppercase; }
.sb-fil-chips { display: flex; flex-wrap: wrap; gap: 4px; }
.sb-tier, .sb-region {
  padding: .28rem .5rem; border-radius: 6px; border: 1px solid var(--border);
  background: var(--bg3); color: var(--dim); font-size: .66rem; cursor: pointer;
  font-weight: 700; transition: all .12s;
}
.sb-tier:hover { color: #fff; border-color: var(--gold); }
.sb-tier.active { color: var(--gold); border-color: var(--gold); background: rgba(201,162,42,.1); }
/* Chips de región: color de la región siempre visible (borde) + relleno al activarse */
.sb-region { border-left: 3px solid var(--rc); }
.sb-region:hover { color: #fff; border-color: var(--border); border-left-color: var(--rc); background: rgba(255,255,255,.06); }
.sb-region.active { color: #fff; border-color: var(--rc); background: var(--rc); }

/* Grid de cartas (panel derecho) */
.sb-pool { flex: 1; overflow-y: auto; padding: 12px; display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; align-content: start; }
.sb-card {
  position: relative; aspect-ratio: 9/13; border-radius: 8px; border: 2px solid var(--border);
  overflow: hidden; cursor: grab; background: var(--bg3);
  transition: transform .15s, box-shadow .15s;
}
.sb-card:hover { transform: translateY(-3px); box-shadow: 0 8px 18px rgba(0,0,0,.6), 0 0 10px var(--c, transparent); z-index: 2; }
.sb-card.dragging { opacity: .5; }
/* Imagen en absoluto: no aporta altura en flujo, así el aspect-ratio define el alto */
.sb-card img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: top; }
/* El card entero arrastra: sus hijos no capturan el drag ni el puntero */
.sb-card img, .sb-card-stat, .sb-card-name { -webkit-user-drag: none; user-drag: none; pointer-events: none; }
.sb-card-stat { position: absolute; top: 2px; left: 0; right: 0; display: flex; justify-content: space-between; padding: 0 4px; font-size: .46rem; font-weight: 700; text-shadow: 0 1px 3px rgba(0,0,0,.9); }
.sb-card-stat .cstat { gap: 1px; }
.sb-card-stat .stat-ico { width: .9em; height: .9em; }
.sb-card-name { position: absolute; bottom: 0; left: 0; right: 0; background: linear-gradient(transparent, rgba(0,0,0,.92)); padding: 10px 3px 3px; font-size: .5rem; color: #fff; text-align: center; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sb-card-name .name-tier { display: inline-block; min-width: 1.1em; padding: 0 2px; border-radius: 3px; margin-right: 2px; font-size: .82em; color: #0a0a12; font-weight: 800; }

/* Botón "Probar golpe" — aparece al hover de la carta del pool */
.sb-test-btn {
  position: absolute; left: 4px; right: 4px; top: 50%; transform: translateY(-50%);
  padding: 4px 2px; border-radius: 6px; border: 1px solid var(--gold);
  background: rgba(13,13,26,.92); color: var(--gold); font-size: .56rem; font-weight: 800;
  letter-spacing: .04em; cursor: pointer; opacity: 0; transition: opacity .12s; z-index: 3;
}
.sb-card:hover .sb-test-btn { opacity: 1; }
.sb-test-btn:hover { background: rgba(201,162,42,.18); color: #fff; }

/* Panel de Golpes: select + mini-tablero + info */
.sb-golpe-sel {
  width: 100%; margin-bottom: 12px; padding: 8px 10px; border-radius: 7px;
  background: var(--bg3); color: #fff; border: 1px solid var(--border); font-size: .76rem; cursor: pointer;
}
.sb-golpe-view { display: flex; gap: 12px; align-items: flex-start; }
.sb-golpe-view .sb-mini { width: 60px; flex-shrink: 0; }
/* Lista de golpes */
.sb-golpe-item { display: flex; gap: 12px; align-items: center; padding: 9px 0; border-bottom: 1px solid rgba(255,255,255,.06); }
.sb-golpe-item .sb-mini { width: 50px; flex-shrink: 0; }
.sb-golpe-owner { color: var(--gold); font-size: .64rem; font-weight: 700; }
.sb-golpe-owners { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.sb-golpe-owners .sb-pas-thumb { width: 26px; }
.sb-golpe-info { display: flex; flex-direction: column; gap: 4px; font-size: .72rem; }
.sb-golpe-info b { color: #fff; font-size: .8rem; }
.sb-golpe-info span { color: rgba(255,255,255,.72); line-height: 1.35; }
.sb-golpe-legend { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; font-size: .6rem; color: var(--dim); margin-top: 2px; }
.sb-golpe-legend i { display: inline-block; width: 9px; height: 9px; border-radius: 2px; margin-right: 3px; vertical-align: middle; }

/* Móvil: paneles colapsan a tiras inferiores apiladas (fallback básico) */
/* ── Log de combate del sandbox (toggleable, a la izquierda del panel de cartas) ── */
#sb-log {
  display: none; position: fixed; top: 0; bottom: 0; right: 351px; width: 280px; z-index: 5100;
  flex-direction: column; background: var(--bg2);
  border-left: 1px solid var(--border); border-right: 1px solid var(--border);
}
body.sandbox-mode.sb-log-open #sb-log { display: flex; }
.sb-log-clear {
  float: right; font-size: .56rem; font-weight: 700; padding: 2px 8px; border-radius: 6px;
  border: 1px solid var(--border); background: rgba(255,255,255,.06); color: rgba(255,255,255,.75); cursor: pointer;
}
.sb-log-clear:hover { background: rgba(255,255,255,.14); color: #fff; }
.sb-log-entries { flex: 1; overflow-y: auto; padding: 10px 12px; font-size: .62rem; line-height: 1.5; }
.sb-log-entries .log-entry { padding: 3px 0; border-bottom: 1px solid rgba(255,255,255,.05); color: #cdd; }
.sb-log-entries .log-entry.dmg { color: #f8a0a0; }
.sb-log-entries .log-entry.key { color: var(--gold); }
.sb-log-entries .log-entry.round { color: var(--gold); font-weight: 700; text-align: center;
  letter-spacing: .04em; margin-top: 8px; padding-top: 8px; border-top: 1px solid var(--gold); }

.sb-doc-actions { display: flex; gap: 8px; margin: 12px 0 8px; }

@media (max-width: 900px) {
  body.sandbox-mode #screen-game { padding: 0; }
  #sb-left, #sb-right { top: auto; bottom: 0; width: 50%; height: 42vh; }
  #sb-left { left: 0; border-top: 1px solid var(--border); }
  #sb-right { right: 0; border-top: 1px solid var(--border); }
  #sb-toolbar { bottom: calc(42vh + 10px); }
}
