/* player-radar.css — estilos del componente playerRadar (radar/spider SVG).
   Autocontenido: solo clases .player-radar*. Usa los tokens del proyecto
   (--surface, --hairline, --ink-*, --r-md, --t…) con fallbacks razonables. */

.player-radar {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  width: 100%;
  max-width: 360px;
  margin: 0 auto;
}

.player-radar__svg {
  display: block;
  width: 100%;
  height: auto;
  overflow: visible;
}

/* Rejilla: anillos + ejes en tono hairline. */
.player-radar__ring {
  fill: var(--surface-soft, #f6f7f9);
  fill-opacity: 0.35;
  stroke: var(--hairline, #e6e9ee);
  stroke-width: 1;
}
.player-radar__ring:nth-child(odd) {
  fill-opacity: 0.18;
}

.player-radar__axis {
  stroke: var(--hairline, #e6e9ee);
  stroke-width: 1;
}

.player-radar__axis-label {
  font-family: var(--font-ui, system-ui, sans-serif);
  font-size: 11px;
  font-weight: 600;
  fill: var(--ink-3, #8a93a3);
}

/* Área (polígono) de cada jugador: relleno semitransparente del color propio. */
.player-radar__area {
  fill: var(--radar-color, var(--brand-1, #4f46e5));
  fill-opacity: 0.16;
  stroke: var(--radar-color, var(--brand-1, #4f46e5));
  stroke-width: 2;
  stroke-linejoin: round;
  transition: opacity var(--t, 220ms) var(--ease, ease);
}

/* Polígono A un poco más sólido al ir encima. */
.player-radar__player.is-a .player-radar__area {
  fill-opacity: 0.2;
}
.player-radar__player.is-b .player-radar__area {
  fill-opacity: 0.13;
}

.player-radar__dot {
  fill: var(--surface, #fff);
  stroke: var(--radar-color, var(--brand-1, #4f46e5));
  stroke-width: 2;
}

.player-radar__value {
  font-family: var(--num, var(--font-ui, system-ui)), system-ui;
  font-size: 10px;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  fill: var(--ink-2, #4a5160);
  paint-order: stroke;
  stroke: var(--surface, #fff);
  stroke-width: 3px;
  stroke-linejoin: round;
}

/* Leyenda. */
.player-radar__legend {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px 16px;
}

.player-radar__legend-item {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-family: var(--font-ui, system-ui, sans-serif);
  font-size: 13px;
  font-weight: 600;
  color: var(--ink, #0c1019);
}

.player-radar__swatch {
  width: 12px;
  height: 12px;
  border-radius: 4px;
  background: var(--radar-color, var(--brand-1, #4f46e5));
  box-shadow: var(--shadow-sm, 0 1px 2px rgba(12, 16, 25, 0.12));
  flex: 0 0 auto;
}

/* Aparición sutil al entrar; respeta prefers-reduced-motion. */
@media (prefers-reduced-motion: no-preference) {
  .player-radar__area {
    animation: player-radar-in var(--t-slow, 380ms) var(--ease, ease) both;
  }
  .player-radar__player.is-a .player-radar__area {
    animation-delay: 80ms;
  }
  @keyframes player-radar-in {
    from { opacity: 0; }
    to { opacity: 1; }
  }
}
