.cover-block {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

/* Flip box */

.cover-flip {
  perspective: 1200px;
  display: block;
  width: 100%;
  aspect-ratio: 1;
  cursor: default;
}

.cover-flip:not(.cover-flip--no-back) {
  cursor: pointer;
}

.cover-flip__inner {
  position: relative;
  width: 100%;
  height: 100%;
  transform-style: preserve-3d;
  transition: transform 0.65s cubic-bezier(0.4, 0.2, 0.2, 1);
}

.cover-flip__face {
  position: absolute;
  inset: 0;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  overflow: hidden;
}

.cover-flip__face img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.cover-flip__face--back {
  transform: rotateY(180deg);
}

/* Placeholder gdy brak okładki */

.cover-flip__placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  background: #f0f0f0;
  color: #999;
  font-size: 0.8rem;
  letter-spacing: 0.05em;
}

/* Desktop – hover */

@media (hover: hover) {
  .cover-flip:not(.cover-flip--no-back):hover .cover-flip__inner {
    transform: rotateY(180deg);
  }
}

/* Mobile / touch – kliknięcie (klasa dodawana przez JS) */

.cover-flip.is-flipped .cover-flip__inner {
  transform: rotateY(180deg);
}

/* Dostępność – focus visible */

.cover-flip:focus-visible {
  outline: 3px solid #005fcc;
  outline-offset: 3px;
}

@media (prefers-reduced-motion: reduce) {
  .cover-flip__inner {
    transition: none;
  }
}

/* Meta (tytuł, rok, typ nośnika) */

.cover-block__meta {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.cover-block__title {
  font-size: clamp(1.1rem, 2vw, 1.4rem);
  font-weight: 600;
  line-height: 1.2;
  margin: 0;
}

.cover-block__year {
  font-size: 0.875rem;
  color: var(--theme-palette-color-3, #666);
  margin: 0;
}

.cover-block__media-type {
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--theme-palette-color-1, #cc0000);
  margin-top: 0.25rem;
}
