/* ── TNH Media List — Public Styles ──────────────────────────────── */
:root {
  --tnh-bg:        #0f0f14;
  --tnh-card:      #1a1a24;
  --tnh-border:    #2a2a38;
  --tnh-accent:    #e94560;
  --tnh-accent2:   #7c5cbf;
  --tnh-text:      #e8e8f0;
  --tnh-muted:     #8888aa;
  --tnh-movie:     #e94560;
  --tnh-series:    #00b4d8;
  --tnh-game:      #06d6a0;
  --tnh-radius:    12px;
  --tnh-gap:       20px;
}

/* Wrapper */
#tnh-media-list {
  background: var(--tnh-bg);
  padding: 40px 24px 48px;
  border-radius: 16px;
  font-family: 'Segoe UI', system-ui, sans-serif;
  color: var(--tnh-text);
}

/* Header */
.tnh-header { text-align: center; margin-bottom: 32px; }
.tnh-heading {
  font-size: clamp(26px, 5vw, 40px);
  font-weight: 800;
  letter-spacing: -0.5px;
  margin: 0 0 6px;
  background: linear-gradient(135deg, var(--tnh-accent), var(--tnh-accent2));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.tnh-sub { color: var(--tnh-muted); margin: 0; font-size: 15px; }

/* Filter bar */
.tnh-filters {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 14px;
  margin-bottom: 28px;
  justify-content: space-between;
}
.tnh-tabs { display: flex; gap: 8px; flex-wrap: wrap; }
.tnh-tab {
  background: var(--tnh-card);
  border: 1px solid var(--tnh-border);
  color: var(--tnh-muted);
  padding: 8px 18px;
  border-radius: 50px;
  cursor: pointer;
  font-size: 14px;
  font-weight: 600;
  transition: all .2s;
}
.tnh-tab:hover { border-color: var(--tnh-accent); color: var(--tnh-text); }
.tnh-tab.active {
  background: var(--tnh-accent);
  border-color: var(--tnh-accent);
  color: #fff;
}
.tnh-search-wrap { display: flex; gap: 10px; }
#tnh-search, #tnh-genre-filter {
  background: var(--tnh-card);
  border: 1px solid var(--tnh-border);
  color: var(--tnh-text);
  padding: 8px 14px;
  border-radius: 8px;
  font-size: 14px;
  outline: none;
  transition: border-color .2s;
}
#tnh-search:focus, #tnh-genre-filter:focus { border-color: var(--tnh-accent); }
#tnh-search::placeholder { color: var(--tnh-muted); }
#tnh-genre-filter option { background: #1a1a24; }

/* Grid */
.tnh-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: var(--tnh-gap);
}

/* Card */
.tnh-card {
  background: var(--tnh-card);
  border: 1px solid var(--tnh-border);
  border-radius: var(--tnh-radius);
  overflow: hidden;
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s;
  display: flex;
  flex-direction: column;
}
.tnh-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 12px 32px rgba(233,69,96,.18);
  border-color: var(--tnh-accent);
}

/* Poster */
.tnh-card-poster {
  width: 100%;
  aspect-ratio: 2/3;
  object-fit: cover;
  display: block;
}
.tnh-no-poster {
  aspect-ratio: 2/3;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 56px;
  background: linear-gradient(135deg, #1e1e2e, #2a1a2e);
}

/* Card body */
.tnh-card-body { padding: 14px 16px 18px; flex: 1; display: flex; flex-direction: column; gap: 6px; }

/* Badge */
.tnh-badge {
  display: inline-block;
  padding: 2px 10px;
  border-radius: 50px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .4px;
  text-transform: uppercase;
  width: fit-content;
}
.tnh-badge-movie  { background: rgba(233,69,96,.15);  color: var(--tnh-movie);  border: 1px solid rgba(233,69,96,.3); }
.tnh-badge-series { background: rgba(0,180,216,.15);  color: var(--tnh-series); border: 1px solid rgba(0,180,216,.3); }
.tnh-badge-game   { background: rgba(6,214,160,.15);  color: var(--tnh-game);   border: 1px solid rgba(6,214,160,.3); }

/* Title */
.tnh-card-title {
  font-size: 15px;
  font-weight: 700;
  margin: 2px 0;
  color: var(--tnh-text);
  line-height: 1.3;
}

/* Meta */
.tnh-card-meta { display: flex; gap: 8px; flex-wrap: wrap; }
.tnh-year, .tnh-genre {
  font-size: 12px;
  color: var(--tnh-muted);
  background: rgba(255,255,255,.05);
  padding: 2px 8px;
  border-radius: 4px;
}

/* Stars */
.tnh-stars { display: flex; align-items: center; gap: 3px; margin-top: 2px; }
.tnh-star        { font-size: 15px; }
.tnh-star.full   { color: #f4c55a; }
.tnh-star.half   { color: #f4c55a; opacity: .65; }
.tnh-star.empty  { color: var(--tnh-border); }
.tnh-rating-num  { font-size: 13px; color: var(--tnh-muted); margin-left: 3px; }

/* Description */
.tnh-card-desc {
  font-size: 12.5px;
  color: var(--tnh-muted);
  margin: 4px 0 0;
  line-height: 1.5;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Empty state */
.tnh-empty {
  text-align: center;
  padding: 60px 20px;
  color: var(--tnh-muted);
  grid-column: 1/-1;
}
.tnh-empty span { font-size: 48px; display: block; margin-bottom: 12px; }
.tnh-empty p { font-size: 16px; }

/* Loading spinner */
.tnh-loading {
  text-align: center;
  padding: 30px;
  color: var(--tnh-muted);
  font-size: 15px;
}

/* Responsive */
@media (max-width: 600px) {
  #tnh-media-list { padding: 24px 14px 32px; }
  .tnh-filters { flex-direction: column; align-items: stretch; }
  .tnh-search-wrap { flex-direction: column; }
  .tnh-grid { grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 14px; }
}
