/* Race-card grids, card chrome, lore badges, and thumbnail markers. */

.races-grid {
  --races-grid-gap: clamp(20px, 2vw, 30px);
  --race-card-grid-flex: 0 1 clamp(210px, 17.5vw, 292px);
  --race-card-grid-max-width: 292px;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: flex-start;
  gap: var(--races-grid-gap);
}

.race-card {
  --race-card-thumb-transition: transform 0.28s ease, opacity 0.18s ease;
  display: block;
  text-decoration: none;
  border-radius: var(--radius);
  overflow: hidden;
  border: 1px solid var(--border);
  background: var(--bg-surface);
  transition: border-color 0.2s, box-shadow 0.2s, transform 0.2s;
  position: relative;
  aspect-ratio: 2/3;
  contain: layout paint style;
  content-visibility: visible;
  contain-intrinsic-size: none;
}

.race-card:hover {
  border-color: var(--gold);
  box-shadow: 0 10px 28px rgba(0,0,0,0.48), 0 0 15px rgba(207,197,153,0.08);
  transform: translateY(-5px);
}

.race-card:focus-visible {
  box-shadow: 0 10px 28px rgba(0,0,0,0.48), 0 0 15px rgba(207,197,153,0.08);
}

.race-card > .race-card__img-wrap {
  position: absolute;
  inset: 0 0 52px 0;
  width: auto;
  height: auto;
  overflow: hidden;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}

.race-card > .race-card__img-wrap::after {
  border-radius: 0;
}

.race-card > .race-card__img-wrap > img.race-card__thumb {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  min-width: 100%;
  min-height: 100%;
  object-fit: cover;
  object-position: center 8%;
  display: block;
  transform: scale(1.42);
  transform-origin: center 9%;
  transition: var(--race-card-thumb-transition);
  will-change: auto;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}

.race-card:is(:hover, :focus-visible) .race-card__img-wrap > img.race-card__thumb {
  will-change: transform;
  transform: scale(1.47);
}

.race-card__name {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 52px;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 6px 10px;
  background: linear-gradient(to top, var(--bg-base) 40%, rgba(8,8,14,0.7) 100%);
  border-top: 1px solid var(--border);
  z-index: 4;
  will-change: auto;
  backface-visibility: hidden;
  transform: translate3d(0, 0, 0);
  transition:
    transform 0.14s ease-out,
    opacity 0.14s ease-out,
    background 0.14s ease-out,
    border-color 0.14s ease-out;
}

.race-card__name-text {
  display: block;
  max-width: 100%;
  min-width: 0;
  font-family: var(--font-heading);
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--text-body);
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  line-height: 1.25;
}

.race-card__name.has-index-mechanics .race-card__name-text {
  max-width: min(100%, calc(100% - 116px));
  flex: 1 1 auto;
  text-align: left;
}

.race-card__name.has-index-mechanics.has-long-index-name .race-card__name-text {
  font-size: 0.64rem;
  letter-spacing: 0.055em;
  line-height: 1.12;
}

.race-card__index-mechanics {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 3px;
  max-width: 112px;
  height: 33px;
  line-height: 0;
  pointer-events: none;
  flex: 0 0 auto;
  margin-left: auto;
}

.race-card__index-mechanic-icon {
  width: 33px;
  height: 33px;
  flex: 0 0 33px;
  display: block;
  object-fit: contain;
  opacity: 0.9;
  filter:
    brightness(0.96)
    saturate(0.88)
    drop-shadow(0 2px 6px rgba(0,0,0,0.62));
}

@media (max-width: 500px) {
  .race-card__name-text {
    font-size: 0.6rem;
    letter-spacing: 0.06em;
  }

  .race-card__name.has-index-mechanics.has-long-index-name .race-card__name-text {
    font-size: 0.56rem;
    letter-spacing: 0.035em;
  }

  .race-card__index-mechanics {
    height: 26px;
    max-width: 84px;
  }

  .race-card__index-mechanic-icon {
    width: 26px;
    height: 26px;
    flex-basis: 26px;
  }
}

.race-card__lore-summary {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 3;
  height: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: nowrap;
  gap: 8px 14px;
  padding: 5px 12px;
  border-top: 1px solid rgba(204,194,174,0.16);
  background: linear-gradient(to top, rgba(4,4,8,0.96), rgba(11,11,18,0.88));
  opacity: 0;
  pointer-events: auto;
  transform: translate3d(0, 7px, 0);
  contain: layout;
  overflow: visible;
  will-change: auto;
  backface-visibility: hidden;
  transition:
    transform 0.14s ease-out,
    opacity 0.14s ease-out,
    background 0.14s ease-out,
    border-color 0.14s ease-out;
}

.race-card:is(:hover, :focus-visible) .race-card__name {
  will-change: transform;
  border-top-color: rgba(204,194,174,0.24);
  background: linear-gradient(to top, rgba(4,4,8,0.98), rgba(11,11,18,0.92));
  transform: translate3d(0, -50px, 0);
}

.race-card:is(:hover, :focus-visible) .race-card__lore-summary {
  will-change: transform, opacity;
  opacity: 1;
  transform: translate3d(0, 0, 0);
}

.race-card__lore-count {
  position: relative;
  width: auto;
  min-width: 0;
  display: inline-flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  gap: 0;
  padding: 0 2px;
  color: var(--text-body);
  font-family: var(--font-heading);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  line-height: 1;
  white-space: nowrap;
  text-shadow: 0 2px 8px rgba(0,0,0,0.75);
  pointer-events: auto;
  overflow: visible;
  transition: none;
  will-change: auto;
}

.race-card__lore-count img {
  width: 33px;
  height: 33px;
  flex: 0 0 33px;
  object-fit: contain;
  display: block;
  opacity: 0.95;
  filter: drop-shadow(0 2px 7px rgba(0,0,0,0.45));
  pointer-events: none;
  transition: none;
  will-change: auto;
}

.race-card__lore-count > span {
  position: absolute;
  top: -9px;
  right: -12px;
  min-width: 24px;
  height: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 6px;
  border: 1px solid rgba(238, 229, 211, 0.46);
  border-radius: 999px;
  background: rgba(12, 12, 20, 0.88);
  color: var(--gold-light);
  font-family: var(--font-heading);
  font-size: 0.76rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.02em;
  margin-top: 1px;
  box-shadow: 0 0 12px rgba(0, 0, 0, 0.42);
  opacity: 0;
  visibility: hidden;
  transform: translateY(3px) scale(0.86);
  pointer-events: none;
  z-index: 3;
  overflow: visible;
  transition: none;
  will-change: auto;
}

.race-card__lore-count:is(:hover, :focus-within) > span,
.race-card:is(:hover, :focus-visible) .race-card__lore-count > span {
  opacity: 1;
  visibility: visible;
  transform: translateY(0) scale(1);
}

.race-card__img-wrap > .race-card__cat-icon,
.race-card__img-wrap > .race-card__book-marker {
  --race-card-badge-size: clamp(38px, 3.05vw, 42px);
  --race-card-badge-offset: 10px;
  --race-card-badge-padding: 4px;
  --race-card-badge-opacity: 0.56;
  position: absolute;
  z-index: 5;
  display: block;
  top: var(--race-card-badge-offset);
  width: var(--race-card-badge-size);
  height: var(--race-card-badge-size);
  min-width: var(--race-card-badge-size);
  min-height: var(--race-card-badge-size);
  max-width: var(--race-card-badge-size);
  max-height: var(--race-card-badge-size);
  margin: 0;
  padding: var(--race-card-badge-padding);
  border: 1px solid rgba(220,214,198,0.16);
  border-radius: 999px;
  background:
    radial-gradient(circle at 50% 44%, rgba(31,31,46,0.62) 0%, rgba(17,17,28,0.52) 68%, rgba(5,5,10,0.40) 100%);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  box-sizing: border-box;
  box-shadow: 0 5px 13px rgba(0,0,0,0.34), inset 0 0 8px rgba(200,191,176,0.02);
  object-fit: contain;
  object-position: center;
  opacity: var(--race-card-badge-opacity);
  pointer-events: none;
  transform: none;
  transition: opacity 0.16s ease, transform 0.16s ease;
  will-change: auto;
}

.race-card__img-wrap > .race-card__cat-icon {
  right: var(--race-card-badge-offset);
  filter: brightness(0.98) saturate(0.88) drop-shadow(0 4px 12px rgba(0,0,0,0.72));
}

.race-card__img-wrap > .race-card__book-marker {
  left: var(--race-card-badge-offset);
  filter: brightness(0.94) saturate(0.8) drop-shadow(0 4px 12px rgba(0,0,0,0.72));
}

.race-card:is(:hover, :focus-visible) .race-card__img-wrap > .race-card__cat-icon,
.race-card:is(:hover, :focus-visible) .race-card__img-wrap > .race-card__book-marker {
  opacity: 0.82;
  border-color: rgba(230,224,208,0.28);
  transform: translateY(-1px) scale(1.025);
  filter:
    brightness(1.02)
    saturate(0.9)
    drop-shadow(0 0 8px rgba(200,191,176,0.06))
    drop-shadow(0 4px 10px rgba(0,0,0,0.55));
}

@media (max-width: 700px) {
  .race-card__lore-summary {
    height: 46px;
    padding: 4px 8px;
  }

  .race-card__lore-count {
    font-size: 0.66rem;
  }

  .race-card__lore-count img {
    width: 29px;
    height: 29px;
    flex-basis: 29px;
  }

  .race-card__lore-count > span {
    font-size: 0.67rem;
  }

  .race-card__img-wrap > .race-card__cat-icon,
  .race-card__img-wrap > .race-card__book-marker {
    --race-card-badge-size: 34px;
    --race-card-badge-offset: 8px;
    --race-card-badge-padding: 3px;
    --race-card-badge-opacity: 0.58;
  }
}

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

@media (prefers-reduced-motion: reduce) {
  .race-card__thumb {
    animation: none !important;
  }

  :is(.race-card__thumb, .race-card, .race-card__name, .race-card__lore-summary) {
    transition: none !important;
  }
}

@media (max-width: 900px) {
  .races-grid {
    --race-card-grid-flex: 0 1 clamp(190px, 31vw, 260px);
  }
}

@media (max-width: 620px) {
  .races-grid {
    --races-grid-gap: 18px;
    --race-card-grid-flex: 0 1 min(100%, 320px);
    --race-card-grid-max-width: 320px;
  }
}
