/* --- Tags Grid --- */

.media-tags-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 3px;
}

.media-tag-card {
  position: relative;
  aspect-ratio: 1;
  overflow: hidden;
  display: block;
  background: linear-gradient(
    110deg,
    var(--color-surface) 30%,
    color-mix(in srgb, var(--color-primary) 8%, var(--color-surface)) 50%,
    var(--color-surface) 70%
  );
  background-size: 200% 100%;
  animation: shimmer 1.5s ease-in-out infinite;
}

.media-tag-card img,
.media-tag-card video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.2s;
}

.media-tag-card:hover img,
.media-tag-card:hover video {
  transform: scale(1.05);
}

.media-tag-card__label {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: var(--space-sm);
  background: linear-gradient(transparent, rgb(0 0 0 / 80%));
  color: #fff;
  font-size: var(--text-sm);
  font-weight: 600;
}

.media-tag-card__label small {
  opacity: 0.7;
  font-weight: normal;
}

/* --- Pagination info --- */

.pagination__info {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}

.media-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 3px;
  animation: media-page-in 0.25s ease-out;
}

@keyframes media-page-in {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
}

.media-grid__item {
  aspect-ratio: 1;
  overflow: hidden;
  position: relative;
  background: linear-gradient(
    110deg,
    var(--color-surface) 30%,
    color-mix(in srgb, var(--color-primary) 8%, var(--color-surface)) 50%,
    var(--color-surface) 70%
  );
  background-size: 200% 100%;
  animation: shimmer 1.5s ease-in-out infinite;
}

.media-grid__item img,
.media-grid__item video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition:
    transform 0.2s,
    opacity 0.2s;
}

/* Fade in once loaded */
.media-grid__item img {
  opacity: 0;
  transition: opacity 0.3s ease-out;
}

.media-grid__item img.loaded {
  opacity: 1;
}

/* Videos show immediately */
.media-grid__item video {
  opacity: 1;
}

.media-grid__item:hover img,
.media-grid__item:hover video {
  transform: scale(1.05);
  opacity: 0.85;
}

.media-grid__multi,
.media-grid__video {
  position: absolute;
  top: var(--space-xs);
  right: var(--space-xs);
  background: rgb(0 0 0 / 60%);
  color: #fff;
  font-size: var(--text-sm);
  padding: 2px 5px;
  border-radius: var(--radius-sm);
  pointer-events: none;
}

@keyframes shimmer {
  0% {
    background-position: 200% 0;
  }

  100% {
    background-position: -200% 0;
  }
}
