/* Hover popup styles moved from main stylesheet */

/* Hover popup source-card states */
.movie-card.is-hover-preview-source {
  z-index: 16;
}

.movie-card.is-hover-preview-source .movie-card__frame {
  transform: translateY(-12px) scale(1.045);
  box-shadow:
    0 28px 56px rgba(0, 0, 0, 0.58),
    0 14px 24px rgba(0, 0, 0, 0.28),
    0 0 0 1px rgba(229, 9, 20, 0.16);
  border-color: rgba(229, 9, 20, 0.34);
  filter: saturate(1.08);
}

.movie-card.is-hover-preview-source .movie-card__image {
  transform: scale(1.09);
}

/* Hover popup container */
.movie-hover-card {
  --hover-card-width: min(370px, calc(100vw - 1.5rem));
  --hover-origin-x: 50%;
  --hover-origin-y: calc(100% - 46px);
  position: fixed;
  top: 0;
  left: 0;
  width: var(--hover-card-width);
  border-radius: 24px;
  background:
    radial-gradient(circle at top right, rgba(229, 9, 20, 0.18), transparent 30%),
    linear-gradient(180deg, rgba(25, 26, 31, 0.96), rgba(17, 18, 22, 0.99));
  border: 1px solid rgba(255, 255, 255, 0.1);
  box-shadow:
    0 44px 90px rgba(0, 0, 0, 0.74),
    0 22px 38px rgba(0, 0, 0, 0.38),
    0 0 0 1px rgba(229, 9, 20, 0.08);
  overflow: hidden;
  pointer-events: none;
  opacity: 0;
  visibility: hidden;
  transform: translate3d(0, 12px, 0) scale(0.962);
  transform-origin: var(--hover-origin-x) var(--hover-origin-y);
  transition:
    opacity 0.18s cubic-bezier(0.22, 1, 0.36, 1),
    transform 0.28s cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 0.28s cubic-bezier(0.22, 1, 0.36, 1),
    border-color 0.28s ease,
    visibility 0s linear 0.28s;
  z-index: 1200;
  backdrop-filter: blur(18px);
  will-change: transform, opacity, top, left;
}

.movie-hover-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.05), transparent 24%),
    linear-gradient(0deg, rgba(229, 9, 20, 0.06), transparent 26%);
  pointer-events: none;
}

/* Hover popup media */
.movie-hover-card__media {
  position: relative;
  display: block;
  width: 100%;
  padding: 0;
  border: 0;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: #1f2128;
  cursor: pointer;
  appearance: none;
}

.movie-hover-card__media::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(5, 5, 6, 0.04) 0%, rgba(5, 5, 6, 0.1) 48%, rgba(10, 10, 12, 0.92) 100%),
    linear-gradient(90deg, rgba(5, 5, 6, 0.18), rgba(5, 5, 6, 0) 42%, rgba(229, 9, 20, 0.14) 100%);
  pointer-events: none;
  transition: opacity 0.24s ease, background 0.24s ease;
}

.movie-hover-card__media::before {
  content: "View Details";
  position: absolute;
  right: 0.95rem;
  bottom: 0.95rem;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  padding: 0.38rem 0.7rem;
  border-radius: 999px;
  background: rgba(10, 10, 12, 0.58);
  border: 1px solid rgba(255, 255, 255, 0.14);
  color: rgba(255, 255, 255, 0.88);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  opacity: 0;
  transform: translateY(4px);
  pointer-events: none;
  transition: opacity 0.22s ease, transform 0.22s ease;
}

.movie-hover-card__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1.04);
  transition: transform 0.3s ease, filter 0.24s ease;
}

.movie-hover-card__media:hover::after,
.movie-hover-card__media:focus-visible::after {
  background:
    linear-gradient(180deg, rgba(5, 5, 6, 0.02) 0%, rgba(5, 5, 6, 0.08) 44%, rgba(10, 10, 12, 0.88) 100%),
    linear-gradient(90deg, rgba(5, 5, 6, 0.12), rgba(5, 5, 6, 0) 42%, rgba(229, 9, 20, 0.2) 100%);
}

.movie-hover-card__media:hover::before,
.movie-hover-card__media:focus-visible::before {
  opacity: 1;
  transform: translateY(0);
}

.movie-hover-card__media:hover .movie-hover-card__image,
.movie-hover-card__media:focus-visible .movie-hover-card__image {
  transform: scale(1.075);
  filter: brightness(1.03);
}

.movie-hover-card__media:focus-visible {
  outline: none;
}

.movie-hover-card__media:focus-visible .movie-hover-card__image {
  box-shadow: inset 0 0 0 2px rgba(229, 9, 20, 0.24);
}

.movie-hover-card__body {
  position: relative;
  z-index: 1;
  padding: 1rem 1.15rem 1.2rem;
}

.movie-hover-card__title {
  margin: 0 0 0.85rem;
  color: #f5f7fb;
  font-size: 1.1rem;
  font-weight: 800;
  letter-spacing: -0.03em;
}

/* Hover popup actions */
.movie-hover-card__actions {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-top: -0.1rem;
}

.movie-hover-card__watch {
  min-height: 48px;
  padding: 0.78rem 1.15rem;
  border: 0;
  border-radius: 14px;
  background: linear-gradient(180deg, #f01420 0%, #e50914 72%, #b80710 100%);
  color: #fff;
  font-size: 0.95rem;
  font-weight: 800;
  letter-spacing: -0.01em;
  box-shadow:
    0 12px 24px rgba(0, 0, 0, 0.34),
    0 8px 18px rgba(229, 9, 20, 0.24),
    inset 0 1px 0 rgba(255, 255, 255, 0.16);
  transition:
    background-color 0.24s ease,
    transform 0.24s ease,
    box-shadow 0.24s ease,
    filter 0.24s ease,
    color 0.24s ease;
}

.movie-hover-card .movie-hover-card__watch,
.movie-hover-card .movie-hover-card__watch:visited,
.movie-hover-card .movie-hover-card__watch:hover,
.movie-hover-card .movie-hover-card__watch:active {
  color: #fff;
}

.movie-hover-card .movie-hover-card__watch i,
.movie-hover-card .movie-hover-card__watch:hover i,
.movie-hover-card .movie-hover-card__watch:focus-visible i {
  color: #fff;
}

.movie-hover-card__watch:hover {
  transform: translateY(-1px);
  background: linear-gradient(180deg, #ff2230 0%, #f01420 70%, #c70a14 100%);
  box-shadow:
    0 18px 32px rgba(0, 0, 0, 0.4),
    0 10px 22px rgba(229, 9, 20, 0.34),
    inset 0 1px 0 rgba(255, 255, 255, 0.18);
  filter: brightness(1.02);
}

.movie-hover-card__watch i {
  margin-right: 0.35rem;
}

.movie-hover-card__watch:focus-visible {
  outline: none;
  color: #fff;
  box-shadow:
    0 0 0 3px rgba(229, 9, 20, 0.4),
    0 18px 32px rgba(0, 0, 0, 0.38),
    0 10px 22px rgba(229, 9, 20, 0.3),
    inset 0 1px 0 rgba(255, 255, 255, 0.18);
}

.movie-hover-card__icon {
  width: 48px;
  height: 48px;
  flex: 0 0 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 50%;
  background:
    radial-gradient(circle at top, rgba(255, 255, 255, 0.12), transparent 56%),
    rgba(43, 45, 54, 0.9);
  color: #f5f7fb;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 12px 22px rgba(0, 0, 0, 0.34);
  transition:
    transform 0.24s ease,
    box-shadow 0.24s ease,
    border-color 0.24s ease,
    background 0.24s ease;
}

.movie-hover-card__icon:hover,
.movie-hover-card__icon.is-active {
  transform: translateY(-1px);
/*  border-color: rgba(229, 9, 20, 0.38);
  background:
    radial-gradient(circle at top, rgba(255, 255, 255, 0.14), transparent 56%),
    rgba(63, 22, 27, 0.96);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 18px 28px rgba(0, 0, 0, 0.4);*/
}

/* Hover popup metadata */
.movie-hover-card__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.55rem 0.8rem;
  margin-top: 0.95rem;
  color: rgba(241, 244, 250, 0.88);
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.015em;
}

.movie-hover-card__meta-item {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
}

.movie-hover-card__meta-item + .movie-hover-card__meta-item::before {
  content: "";
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.28);
  position: absolute;
  left: -0.45rem;
  top: 50%;
  transform: translateY(-50%);
}

.movie-hover-card__meta-badge {
  padding: 0.28rem 0.55rem;
  border-radius: 999px;
  background: rgba(229, 9, 20, 0.14);
  border: 1px solid rgba(229, 9, 20, 0.18);
  color: #ffd7da;
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

/* Hover popup description */
.movie-hover-card__description {
  margin: 0.95rem 0 0;
  color: rgba(222, 226, 235, 0.82);
  font-size: 0.9rem;
  line-height: 1.62;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Hover popup animation states */
.movie-hover-card.movie-hover-card--opening {
  opacity: 0;
  visibility: visible;
  pointer-events: none;
  transform: translate3d(0, 10px, 0) scale(0.97);
  box-shadow:
    0 30px 62px rgba(0, 0, 0, 0.54),
    0 14px 24px rgba(0, 0, 0, 0.28),
    0 0 0 1px rgba(229, 9, 20, 0.08);
}

.movie-hover-card.movie-hover-card--open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translate3d(0, 0, 0) scale(1);
  box-shadow:
    0 52px 100px rgba(0, 0, 0, 0.78),
    0 24px 40px rgba(0, 0, 0, 0.42),
    0 0 0 1px rgba(229, 9, 20, 0.12);
  transition-delay: 0s;
}

.movie-hover-card.movie-hover-card--closing {
  opacity: 0;
  visibility: visible;
  pointer-events: none;
  transform: translate3d(0, 6px, 0) scale(0.982);
  box-shadow:
    0 22px 46px rgba(0, 0, 0, 0.42),
    0 8px 16px rgba(0, 0, 0, 0.2),
    0 0 0 1px rgba(229, 9, 20, 0.06);
  transition:
    opacity 0.16s cubic-bezier(0.4, 0, 1, 1),
    transform 0.2s cubic-bezier(0.4, 0, 1, 1),
    box-shadow 0.2s ease,
    border-color 0.2s ease,
    visibility 0s linear 0s;
}

/* Hover popup edge-position modifiers */
.movie-hover-card.movie-hover-card--left {
  --hover-origin-x: 18%;
}

.movie-hover-card.movie-hover-card--center {
  --hover-origin-x: 50%;
}

.movie-hover-card.movie-hover-card--right {
  --hover-origin-x: 82%;
}
