/* Index-only universal/race-core card mode.
   Extends the shared race grid from race-cards.css and modal sizing from lore-modal.css. */

/* ─── UNIVERSAL SCENARIO CARD INDEX MODE ─────── */

.universal-index-card {
  --universal-index-min-height: 168px;
  --universal-index-gap: 12px;
  --universal-index-icon-size: 132px;
  --universal-index-icon-filter: brightness(0.92) saturate(0.95);
  --universal-index-icon-hover-transform: translateY(-5px);
  --universal-index-icon-hover-filter: brightness(1) saturate(1) drop-shadow(0 0 14px rgba(200,191,176,0.16));
  --universal-index-name-max-width: 170px;
  --universal-index-name-size: 0.76rem;
  --universal-index-name-letter-spacing: 0.12em;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: start;
  min-height: var(--universal-index-min-height);
  gap: var(--universal-index-gap);
  border: 0;
  background: transparent;
  box-shadow: none;
  padding: 0;
  color: var(--gold-light);
  cursor: pointer;
  text-align: center;
}

.universal-index-card__icon {
  display: grid;
  place-items: center;
  width: var(--universal-index-icon-size);
  height: var(--universal-index-icon-size);
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  overflow: visible;
  transition: transform 0.18s ease;
}

.universal-index-card__icon img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  filter: var(--universal-index-icon-filter);
  transition: transform 0.18s ease, filter 0.18s ease;
}

.universal-index-card__name {
  display: block;
  color: var(--gold-light);
  font-family: var(--font-heading);
  font-size: var(--universal-index-name-size);
  font-weight: 700;
  line-height: 1.25;
  letter-spacing: var(--universal-index-name-letter-spacing);
  max-width: var(--universal-index-name-max-width);
  text-transform: uppercase;
  text-shadow: 0 2px 12px rgba(0,0,0,0.55);
}

.universal-index-card:focus-visible {
  outline: none;
}

.universal-index-card:is(:hover, :focus-visible) .universal-index-card__icon {
  transform: var(--universal-index-icon-hover-transform);
}

.universal-index-card:is(:hover, :focus-visible) .universal-index-card__icon img {
  transform: scale(1.06);
  filter: var(--universal-index-icon-hover-filter);
}

@media (max-width: 700px) {
  .universal-index-card {
    --universal-index-icon-size: 112px;
    --universal-index-name-max-width: 138px;
    --universal-index-name-size: 0.62rem;
    --universal-index-name-letter-spacing: 0.08em;
  }
}

/* ─── UNIVERSAL GRID ROWS ─────────────── */
.races-grid.races-grid--universal {
  --universal-grid-gap: clamp(62px, 5.2vw, 90px) clamp(34px, 3.6vw, 62px);
  --universal-card-flex: 0 1 184px;
  --universal-card-max-width: 184px;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: flex-start;
  gap: var(--universal-grid-gap);
}

.races-grid.races-grid--universal .universal-index-card {
  flex: var(--universal-card-flex);
  max-width: var(--universal-card-max-width);
}

@media (max-width: 900px) {
  .races-grid.races-grid--universal {
    --universal-card-flex: 0 1 160px;
    --universal-card-max-width: 160px;
  }
}

@media (max-width: 620px) {
  .races-grid.races-grid--universal {
    --universal-grid-gap: 42px 18px;
    --universal-card-flex: 0 1 140px;
    --universal-card-max-width: 140px;
  }
}
