/* Image frame + skeleton loading */
.img-frame {
  position: relative;
  overflow: hidden;
  background: var(--color-surface-muted);
}

.img-skeleton {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    110deg,
    var(--skeleton-base) 8%,
    var(--skeleton-shine) 18%,
    var(--skeleton-base) 33%
  );
  background-size: 200% 100%;
  animation: img-shimmer 1.4s ease-in-out infinite;
  z-index: 1;
  pointer-events: none;
}

.img-frame--loaded .img-skeleton {
  opacity: 0;
  transition: opacity 0.35s ease;
}

.img-frame img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  opacity: 0;
  transition: opacity 0.4s ease, transform 0.5s ease;
}

.img-frame--loaded img {
  opacity: 1;
}

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

.favorite-item__frame {
  width: 52px;
  height: 52px;
  border-radius: var(--radius-md);
  flex-shrink: 0;
}

.favorite-item__frame img {
  border-radius: var(--radius-md);
}

.hero-card__frame {
  position: absolute;
  inset: 0;
}

.hero-card__frame img {
  position: absolute;
  inset: 0;
}
