/* ════════════════════════════════════════════════════════════
   VISTA PERSONAJES
   Grid de cards. Avatar = ícono de persona genérico (no iniciales),
   teñido con el color del personaje. Nombre en negrita como elemento
   de mayor jerarquía; rol · ubicación debajo, sin negrita, tenue.
   ════════════════════════════════════════════════════════════ */

.grid-personajes {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--space-4);
}

.persona-card {
  background: var(--blanco-calido);
  border: 1px solid var(--borde);
  border-radius: var(--radio-lg);
  overflow: hidden;
  cursor: pointer;
  transition: transform 0.12s ease, box-shadow 0.12s ease;
  display: flex;
  flex-direction: column;
}

.persona-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--sombra-card);
}

.persona-card__top {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-4);
  border-bottom: 1px solid var(--borde);
}

.persona-card__avatar {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.persona-card__avatar svg { width: 19px; height: 19px; }

.persona-card__identidad { min-width: 0; }

.persona-card__nombre {
  font-size: 14px;
  font-weight: 700;
  color: var(--texto-principal);
  line-height: 1.3;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.persona-card__meta {
  font-size: 12px;
  font-weight: 400;
  color: var(--texto-secundario);
  margin-top: 1px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.persona-card__cuerpo {
  padding: var(--space-3) var(--space-4);
  font-size: 13px;
  color: var(--texto-secundario);
  line-height: 1.55;
  flex: 1;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.persona-card__cuerpo--vacio {
  color: var(--texto-terciario);
  font-style: italic;
}

.persona-card__tags {
  padding: var(--space-3) var(--space-4);
  background: var(--crema);
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.persona-card__tags:empty { display: none; }

.tag-chip {
  font-size: 11.5px;
  font-weight: 500;
  padding: 3px 10px;
  border-radius: 99px;
  background: var(--blanco-calido);
  border: 1px solid var(--borde);
  color: var(--texto-secundario);
  white-space: nowrap;
}

.tag-chip--mas {
  background: transparent;
  border-style: dashed;
  color: var(--texto-terciario);
}

/* — Card "Nuevo personaje" — */
.persona-card--nueva {
  border-style: dashed;
  border-color: var(--borde-fuerte);
  background: transparent;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  min-height: 140px;
  color: var(--texto-terciario);
  font-size: 13px;
  font-weight: 500;
}

.persona-card--nueva:hover {
  border-color: var(--acento);
  color: var(--acento);
  box-shadow: none;
  transform: none;
}

.persona-card--nueva svg { width: 22px; height: 22px; }

@media (max-width: 720px) {
  .grid-personajes { grid-template-columns: 1fr; }
}

/* — Modal de personaje: campos en fila, editor de tags — */
.campos-fila {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
  margin-bottom: var(--space-4);
}

.campos-fila .modal__seccion-label { margin-bottom: var(--space-2); }

.tags-editor__chips {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-bottom: var(--space-3);
}

.tags-editor__chips:empty::after {
  content: 'Todavía no hay tags creados en el proyecto.';
  font-size: 12px;
  color: var(--texto-terciario);
  font-style: italic;
}

.tag-chip-toggle {
  font-size: 12.5px;
  font-weight: 500;
  padding: 5px 12px;
  border-radius: 99px;
  background: var(--blanco-calido);
  border: 1px solid var(--borde-fuerte);
  color: var(--texto-secundario);
  transition: all 0.12s ease;
}

.tag-chip-toggle:hover { background: var(--crema-2); }

.tag-chip-toggle.seleccionado {
  background: var(--acento);
  border-color: var(--acento);
  color: var(--texto-sobre-oscuro);
  font-weight: 600;
}

.tags-editor__nuevo {
  display: flex;
  gap: var(--space-2);
}

.tags-editor__nuevo input {
  flex: 1;
  padding: 9px 12px;
  border: 1px solid var(--borde-fuerte);
  border-radius: var(--radio-sm);
  background: var(--blanco-calido);
  font-family: var(--font-cuerpo);
  font-size: 13px;
  color: var(--texto-principal);
}

.tags-editor__nuevo input:focus { outline: none; border-color: var(--acento); }

@media (max-width: 480px) {
  .campos-fila { grid-template-columns: 1fr; }
}
