:root{
  --movie-rail-card-w:208px;
}

/* GRID */
.grid{
  display:grid;
  grid-template-columns:repeat(6, minmax(0, 1fr));
  gap:24px;
  align-items:stretch;
}

.movie-card{
  position:relative;
  display:flex;
  flex-direction:column;
  width:100%;
  min-width:0;
  min-height:100%;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.08);
  border-radius:24px;
  background:linear-gradient(180deg, rgba(16,22,39,.98), rgba(8,12,22,.98));
  box-shadow:0 16px 36px rgba(0,0,0,.24);
  cursor:pointer;
  transition:box-shadow .22s ease, border-color .22s ease, background .22s ease;
}

.movie-card:hover{
  box-shadow:0 24px 48px rgba(0,0,0,.28);
  border-color:rgba(255,255,255,.14);
}

.movie-card:focus-within{
  border-color:rgba(255,77,90,.28);
  box-shadow:0 24px 48px rgba(0,0,0,.28), 0 0 0 1px rgba(255,77,90,.12);
}

.movie-poster{
  position:relative;
  aspect-ratio:2/3;
  background:
    radial-gradient(80% 100% at 20% 0%, rgba(255,255,255,.08), transparent 55%),
    linear-gradient(180deg, #101828, #070b14);
}

.movie-poster::after{
  content:"";
  position:absolute;
  inset:auto 0 0 0;
  height:46%;
  background:linear-gradient(180deg, transparent, rgba(4,8,15,.14), rgba(4,8,15,.72));
  pointer-events:none;
}

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

.movie-poster-top{
  position:absolute;
  inset:10px 10px auto 10px;
  z-index:2;
  display:flex;
  align-items:flex-start;
  justify-content:flex-start;
}

.movie-tmdb{
  display:inline-flex;
  align-items:center;
  min-height:28px;
  padding:0 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(6,10,19,.72);
  backdrop-filter:blur(10px);
  white-space:nowrap;
  font-size:12px;
  font-weight:800;
  letter-spacing:.01em;
}

.movie-body{
  display:grid;
  grid-template-rows:minmax(58px, auto) 40px;
  gap:12px;
  padding:14px 14px 16px;
  flex:1 1 auto;
  min-height:0;
}

.movie-heading{
  display:block;
  min-height:0;
}

.movie-title{
  margin:0;
  font-size:15px;
  font-weight:800;
  line-height:1.3;
  letter-spacing:-.01em;
  display:-webkit-box;
  -webkit-box-orient:vertical;
  -webkit-line-clamp:2;
  overflow:hidden;
  min-height:40px;
}

.movie-title-link{
  color:inherit;
  text-decoration:none;
}

.movie-title-link:hover{
  text-decoration:underline;
  text-decoration-color:rgba(255,255,255,.32);
}

.movie-subline{
  display:flex;
  align-items:center;
  min-height:16px;
}

.movie-year{
  font-size:12px;
  line-height:1;
  color:var(--muted);
  font-weight:700;
}

.movie-actions{
  display:grid;
  grid-template-columns:minmax(0, 1fr) 40px;
  gap:10px;
  align-items:center;
  width:100%;
  margin-top:auto;
}

.movie-status{
  position:relative;
  min-width:0;
  --status-accent:rgba(153,163,181,.72);
}

.movie-status[data-state="watching"]{--status-accent:#38bdf8}
.movie-status[data-state="planned"]{--status-accent:#f59e0b}
.movie-status[data-state="completed"]{--status-accent:#22c55e}
.movie-status[data-state="dropped"]{--status-accent:#f87171}

.movie-status-btn{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  width:100%;
  min-width:0;
  height:40px;
  padding:0 10px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.04);
  color:var(--text);
  outline:none;
  cursor:pointer;
  transition:border-color .18s ease, background .18s ease, box-shadow .18s ease;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.02);
}

.movie-status-btn:hover,
.movie-status-btn:focus-visible,
.movie-status.is-open .movie-status-btn{
  border-color:rgba(255,255,255,.14);
  box-shadow:0 0 0 3px rgba(255,255,255,.03);
}

.movie-status[data-state="watching"] .movie-status-btn{
  border-color:rgba(56,189,248,.24);
  background:rgba(56,189,248,.10);
}

.movie-status[data-state="planned"] .movie-status-btn{
  border-color:rgba(245,158,11,.24);
  background:rgba(245,158,11,.10);
}

.movie-status[data-state="completed"] .movie-status-btn{
  border-color:rgba(34,197,94,.24);
  background:rgba(34,197,94,.10);
}

.movie-status[data-state="dropped"] .movie-status-btn{
  border-color:rgba(248,113,113,.24);
  background:rgba(248,113,113,.10);
}

.movie-status-main{
  display:flex;
  align-items:center;
  gap:8px;
  min-width:0;
  flex:1 1 auto;
}

.movie-status-dot{
  width:8px;
  height:8px;
  border-radius:999px;
  flex:0 0 auto;
  background:var(--status-accent);
  box-shadow:0 0 0 4px rgba(255,255,255,.02);
}

.status-empty{background:#94a3b8}
.status-watching{background:#38bdf8}
.status-planned{background:#f59e0b}
.status-completed{background:#22c55e}
.status-dropped{background:#f87171}

.movie-status-text{
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  font-size:12px;
  font-weight:700;
}

.movie-status-btn svg{
  width:14px;
  height:14px;
  flex:0 0 auto;
  stroke:currentColor;
  fill:none;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
  opacity:.72;
  transition:transform .18s ease;
}

.movie-status.is-open .movie-status-btn svg{
  transform:rotate(180deg);
}

.movie-status-popover{
  position:fixed;
  left:0;
  top:0;
  z-index:4200;
  display:none;
  padding:6px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.10);
  background:linear-gradient(180deg, rgba(18,26,46,.98), rgba(8,12,22,.98));
  box-shadow:0 22px 54px rgba(0,0,0,.42);
  backdrop-filter:blur(14px);
}

.movie-status-popover.is-open{
  display:block;
}

.movie-status-popover-inner{
  display:flex;
  flex-direction:column;
  gap:4px;
}

.movie-status-popover-item{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  width:100%;
  min-height:40px;
  padding:0 10px;
  border:none;
  border-radius:12px;
  background:transparent;
  color:var(--text);
  text-align:left;
  cursor:pointer;
  transition:background .16s ease, color .16s ease;
}

.movie-status-popover-item:hover,
.movie-status-popover-item:focus-visible{
  background:rgba(255,255,255,.06);
  outline:none;
}

.movie-status-popover-main{
  display:flex;
  align-items:center;
  gap:10px;
  min-width:0;
}

.movie-status-popover-text{
  min-width:0;
  font-size:13px;
  font-weight:600;
  line-height:1.25;
}

.movie-status-check{
  opacity:0;
  font-size:13px;
  font-weight:800;
  color:#dbeafe;
  transition:opacity .16s ease, transform .16s ease;
  transform:scale(.92);
}

.movie-status-popover-item.is-active .movie-status-check{
  opacity:1;
  transform:scale(1);
}

.movie-action-link{
  display:flex;
  align-items:center;
  justify-content:center;
  width:40px;
  height:40px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.08);
  background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.03));
  color:rgba(255,255,255,.72);
  text-decoration:none;
  transition:border-color .18s ease, background .18s ease, color .18s ease, box-shadow .18s ease;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.02);
}

.movie-action-link:hover,
.movie-action-link:focus-visible{
  border-color:rgba(255,255,255,.14);
  background:rgba(255,255,255,.07);
  color:var(--text);
  box-shadow:0 0 0 3px rgba(255,255,255,.03);
}

.movie-action-link svg{
  width:16px;
  height:16px;
  stroke:currentColor;
  fill:none;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
}

.bottom-pager{
  margin-top:22px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:12px;
}

.pager-info{color:var(--muted);font-size:12px}
.pager-info strong{color:var(--text)}

.reco{
  position:relative;
  margin:10px 0 24px;
  padding:22px 18px 18px;
  border-radius:30px;
  border:1px solid rgba(255,255,255,.08);
  background:linear-gradient(180deg, rgba(12,18,34,.88), rgba(7,11,21,.96));
  box-shadow:0 22px 54px rgba(0,0,0,.28);
  overflow:hidden;
}

.reco::before{
  content:"";
  position:absolute;
  inset:0 0 auto 0;
  height:120px;
  background:linear-gradient(180deg, rgba(32,45,78,.18), rgba(32,45,78,0));
  pointer-events:none;
}

.reco-head{position:relative;display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin:0 0 16px}
.reco-title{font-weight:900;font-size:20px;letter-spacing:-.02em}
.reco-sub{font-size:12px;color:var(--muted)}
.reco-row{display:flex;gap:16px;overflow:auto;scroll-behavior:smooth;padding:2px 2px 10px;scroll-snap-type:x mandatory;scrollbar-width:none}
.reco-row::-webkit-scrollbar{display:none}
.reco-row .movie-card{
  flex:0 0 var(--movie-rail-card-w);
  width:var(--movie-rail-card-w);
  scroll-snap-align:start;
}
.reco-row .movie-actions{display:grid}
.reco-row .movie-body{grid-template-rows:minmax(54px, auto) 40px;gap:10px;padding:12px 12px 14px}
.reco-row .movie-title{font-size:13px;line-height:16px;min-height:32px}

@media(max-width:560px){
  .movie-card{border-radius:20px}
  .movie-poster-top{inset:8px 8px auto 8px}
  .movie-tmdb{min-height:26px;padding:0 9px}
  .movie-body{grid-template-rows:minmax(56px, auto) 38px;padding:10px 10px 12px}
  .movie-title{font-size:14px;min-height:38px}
  .movie-actions{grid-template-columns:minmax(0, 1fr) 32px;gap:4px}
  .movie-status-btn{height:38px;padding:0 6px}
  .movie-status-main{gap:5px}
  .movie-status-dot{width:7px;height:7px}
  .movie-status-text{font-size:11px}
  .movie-action-link{width:32px;height:38px}
}


@media (min-width:1200px){
  .reco-row .movie-card{
    width:calc((100% - 80px) / 6);
    min-width:calc((100% - 80px) / 6);
    flex:0 0 calc((100% - 80px) / 6);
  }
}
