.artists-grid {
  display: grid;
  padding: clamp(24px, 4vw, 72px);   /* un peu moins large que 6vw pour laisser rentrer 5 colonnes */
  gap: clamp(12px, 1.2vw, 24px);
  grid-template-columns: repeat(5, minmax(0, 1fr)); /* ✅ 5 colonnes */
}

/* Desktop normal */
@media (max-width: 1600px) {
  .artists-grid {
    grid-template-columns: repeat(5, minmax(0, 1fr)); /* ✅ 5 colonnes */
  }
}

/* Laptop */
@media (max-width: 1300px) {
  .artists-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

/* Tablet */
@media (max-width: 1024px) {
  .artists-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 32px;
  }
}

/* Mobile */
@media (max-width: 640px) {
  .artists-grid {
    grid-template-columns: 1fr;
    gap: 28px;
    padding: 24px 20px;
  }
}


/* --- CARD --- */
.artist-card {
  position: relative;
  display: block;
  width: 100%;
  aspect-ratio: 3 / 4;
  perspective: 1600px;
  isolation: isolate;
}

/* Glow */
.artist-card::after {
  content: "";
  position: absolute;
  inset: -12px;
  border-radius: 12px;
  background: radial-gradient(
    circle at center,
    rgba(255,255,255,0.12),
    rgba(255,255,255,0.02),
    transparent 70%
  );
  opacity: 0;
  filter: blur(20px);
  transition: opacity 0.8s ease;
  pointer-events: none;
  z-index: -1;
}

.artist-card:hover::after {
  opacity: 1;
}

/* --- INNER --- */
.artist-card-inner {
  width: 100%;
  height: 100%;
  position: relative;
  transform-style: preserve-3d;
  transition: transform 1.2s cubic-bezier(0.16, 1, 0.3, 1);
}

/* Slow cinematic flip */
.artist-card:hover .artist-card-inner {
  transform: rotateY(180deg);
}

/* --- FACES --- */
.artist-card-face {
  position: absolute;
  inset: 0;
  backface-visibility: hidden;
  overflow: hidden;
  border-radius: 10px;
}

/* Subtle zoom & fade */
.artist-card-face img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 1.2s ease, filter 1.2s ease, opacity 0.6s ease;
}

/* FRONT */
.artist-card-front {
  transform: rotateY(0deg);
}

/* BACK */
.artist-card-back {
  transform: rotateY(180deg);
}

/* Hover effects */
.artist-card:hover .artist-card-front img {
  transform: scale(1.05);
  opacity: 0.85;
  filter: blur(1px);
}

.artist-card:hover .artist-card-back img {
  transform: scale(1.02);
}
