/* ==========================================================================
   Cards, buttons, badges, player shell
   ========================================================================== */

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-sm) var(--space-lg);
  border-radius: var(--radius-md);
  font-weight: 600;
  font-size: var(--font-size-sm);
  transition: all var(--transition-fast);
}

.btn-primary {
  background: var(--color-primary);
  color: #fff;
}

.btn-primary:hover {
  background: var(--color-primary-light);
}

.btn-accent {
  background: var(--color-accent);
  color: var(--color-bg-dark);
}

.btn-accent:hover {
  background: var(--color-accent-light);
}

.btn-outline {
  border: 1px solid var(--color-border);
  color: var(--color-text-primary);
}

.btn-outline:hover {
  border-color: var(--color-accent);
  color: var(--color-accent);
}

.btn-round {
  border-radius: var(--radius-full);
}

/* ---------- Badges ---------- */
.badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
  padding: 2px var(--space-sm);
  border-radius: var(--radius-sm);
  font-size: var(--font-size-xs);
  font-weight: 700;
}

.badge-live {
  background: var(--color-live);
  color: #fff;
  animation: pulse-live 1.8s infinite;
}

.badge-live .dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #fff;
}

.badge-new {
  background: var(--color-accent);
  color: var(--color-bg-dark);
}

.badge-category {
  background: var(--color-bg-elevated);
  color: var(--color-accent);
  border: 1px solid var(--color-border);
}

@keyframes pulse-live {
  0%, 100% { box-shadow: 0 0 0 0 rgba(230, 57, 70, 0.5); }
  50% { box-shadow: 0 0 0 6px rgba(230, 57, 70, 0); }
}

/* ---------- Video Card ---------- */
.video-card {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: transform var(--transition-normal), border-color var(--transition-normal);
  scroll-snap-align: start;
}

.video-card:hover {
  transform: translateY(-4px);
  border-color: var(--color-accent);
}

.video-card .thumb {
  position: relative;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: var(--color-bg-surface);
}

.video-card .thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-normal);
}

.video-card:hover .thumb img {
  transform: scale(1.06);
}

.video-card .thumb .duration {
  position: absolute;
  bottom: var(--space-sm);
  left: var(--space-sm);
  background: rgba(0, 0, 0, 0.75);
  color: #fff;
  font-size: var(--font-size-xs);
  padding: 2px var(--space-xs);
  border-radius: var(--radius-sm);
}

.video-card .thumb .badges {
  position: absolute;
  top: var(--space-sm);
  right: var(--space-sm);
  display: flex;
  gap: var(--space-xs);
}

.video-card .thumb .play-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0, 0, 0, 0.35);
  opacity: 0;
  transition: opacity var(--transition-fast);
}

.video-card:hover .thumb .play-overlay {
  opacity: 1;
}

.video-card .thumb .play-overlay svg {
  width: 44px;
  height: 44px;
  color: var(--color-accent);
}

.video-card .info {
  padding: var(--space-md);
}

.video-card .info .cat {
  font-size: var(--font-size-xs);
  color: var(--color-accent);
  font-weight: 700;
  margin-bottom: var(--space-xs);
}

.video-card .info h3,
.video-card .info .title {
  font-size: var(--font-size-base);
  font-weight: 700;
  line-height: 1.4;
  margin-bottom: var(--space-xs);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.video-card .meta {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
  flex-wrap: wrap;
}

.video-card .meta span {
  display: flex;
  align-items: center;
  gap: 4px;
}

/* ---------- Channels strip ---------- */
.channel-chip {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-sm);
  min-width: 110px;
  padding: var(--space-md);
  background: var(--color-bg-card);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-lg);
  transition: all var(--transition-fast);
  scroll-snap-align: start;
}

.channel-chip:hover,
.channel-chip.active {
  border-color: var(--color-accent);
  background: var(--color-bg-elevated);
}

.channel-chip .icon {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--color-primary), var(--color-primary-dark));
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-accent);
}

.channel-chip .icon svg {
  width: 22px;
  height: 22px;
}

.channel-chip span.name {
  font-size: var(--font-size-xs);
  font-weight: 600;
  text-align: center;
  color: var(--color-text-secondary);
}

/* ---------- Category browse tiles ---------- */
.category-tile {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-md);
  padding: var(--space-2xl) var(--space-lg);
  background: var(--color-bg-card);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-lg);
  text-align: center;
  font-weight: 700;
  transition: all var(--transition-fast);
}

.category-tile:hover {
  border-color: var(--color-accent);
  background: var(--color-bg-elevated);
  transform: translateY(-4px);
}

.category-tile .icon {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--color-primary), var(--color-primary-dark));
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-accent);
}

.category-tile .icon svg {
  width: 26px;
  height: 26px;
}

/* ---------- Player shell ---------- */
.player-shell {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  background: var(--color-bg-dark);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-elevated);
}

.player-shell .player-poster {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  filter: brightness(0.55);
}

.player-shell .player-gradient {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.85) 0%, rgba(0, 0, 0, 0.1) 45%, transparent 70%);
}

.player-shell .player-center-btn {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 84px;
  height: 84px;
  border-radius: 50%;
  background: rgba(247, 181, 56, 0.9);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-bg-dark);
  transition: transform var(--transition-fast);
}

.player-shell .player-center-btn:hover {
  transform: translate(-50%, -50%) scale(1.08);
}

.player-shell .player-center-btn svg {
  width: 36px;
  height: 36px;
}

.player-shell .player-info {
  position: absolute;
  bottom: 70px;
  right: var(--space-xl);
  left: var(--space-xl);
}

.player-shell .player-info .badge-live {
  margin-bottom: var(--space-sm);
}

.player-shell .player-info h1,
.player-shell .player-info h2 {
  font-size: var(--font-size-2xl);
  margin-bottom: var(--space-xs);
}

.player-shell .player-info p {
  color: var(--color-text-secondary);
}

.player-controls {
  position: absolute;
  bottom: 0;
  right: 0;
  left: 0;
  padding: var(--space-md) var(--space-xl);
}

.progress-bar {
  width: 100%;
  height: 4px;
  background: rgba(255, 255, 255, 0.25);
  border-radius: var(--radius-full);
  margin-bottom: var(--space-md);
  cursor: pointer;
  position: relative;
}

.progress-bar .fill {
  position: absolute;
  inset-inline-start: 0;
  top: 0;
  bottom: 0;
  background: var(--color-accent);
  border-radius: var(--radius-full);
}

.controls-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.controls-left,
.controls-right {
  display: flex;
  align-items: center;
  gap: var(--space-md);
}

.controls-row button {
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
}

.controls-row svg {
  width: 20px;
  height: 20px;
}

.time-label {
  font-size: var(--font-size-xs);
  color: var(--color-text-secondary);
}

/* ---------- Now/Next bar ---------- */
.now-next {
  display: flex;
  background: var(--color-bg-card);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-lg);
  margin-top: var(--space-lg);
  overflow: hidden;
}

.now-next .item {
  flex: 1;
  padding: var(--space-lg);
  display: flex;
  align-items: center;
  gap: var(--space-md);
}

.now-next .item + .item {
  border-inline-start: 1px solid var(--color-border-light);
}

.now-next .time {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: var(--font-size-lg);
  color: var(--color-accent);
  min-width: 70px;
}

.now-next .label {
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 2px;
}

.now-next .title {
  font-weight: 700;
}

/* ---------- EPG mini list ---------- */
.epg-mini-item {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-md);
  border-radius: var(--radius-md);
  transition: background var(--transition-fast);
}

.epg-mini-item:hover {
  background: var(--color-bg-surface);
}

.epg-mini-item .time {
  font-weight: 700;
  color: var(--color-accent);
  min-width: 56px;
  font-size: var(--font-size-sm);
}

.epg-mini-item .status {
  margin-inline-start: auto;
}

.status-live {
  color: var(--color-live);
  font-size: var(--font-size-xs);
  font-weight: 700;
}

.status-upcoming {
  color: var(--color-text-muted);
  font-size: var(--font-size-xs);
}

/* ---------- Channel list (sidebar live) ---------- */
.channel-list-item {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-sm);
  border-radius: var(--radius-md);
  transition: background var(--transition-fast);
}

.channel-list-item:hover,
.channel-list-item.active {
  background: var(--color-bg-surface);
}

.channel-list-item .dot-live {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--color-live);
}

/* ---------- Filter bar (VOD) ---------- */
.filter-bar {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  overflow-x: auto;
  padding: var(--space-sm) 0;
}

.filter-chip {
  padding: var(--space-sm) var(--space-lg);
  border-radius: var(--radius-full);
  border: 1px solid var(--color-border);
  color: var(--color-text-secondary);
  font-size: var(--font-size-sm);
  font-weight: 600;
  white-space: nowrap;
  transition: all var(--transition-fast);
}

.filter-chip:hover {
  border-color: var(--color-accent);
  color: var(--color-text-primary);
}

.filter-chip.active {
  background: var(--color-accent);
  border-color: var(--color-accent);
  color: var(--color-bg-dark);
}

.toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin: var(--space-lg) 0;
  flex-wrap: wrap;
  gap: var(--space-md);
}

.sort-select {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-sm) var(--space-md);
  color: var(--color-text-primary);
  font-size: var(--font-size-sm);
}

/* ---------- Pagination ---------- */
.pagination {
  display: flex;
  justify-content: center;
  gap: var(--space-sm);
  margin-top: var(--space-xl);
}

.pagination button {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-md);
  background: var(--color-bg-card);
  border: 1px solid var(--color-border-light);
  color: var(--color-text-secondary);
  font-weight: 600;
}

.pagination button.active {
  background: var(--color-accent);
  color: var(--color-bg-dark);
  border-color: var(--color-accent);
}

.pagination button:hover:not(.active) {
  border-color: var(--color-accent);
  color: var(--color-text-primary);
}

/* ---------- Calendar strip (Replay) ---------- */
.calendar-strip {
  display: flex;
  gap: var(--space-sm);
  overflow-x: auto;
  padding: var(--space-sm) 0 var(--space-md);
}

.calendar-day {
  min-width: 68px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding: var(--space-md) var(--space-sm);
  background: var(--color-bg-card);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-lg);
  transition: all var(--transition-fast);
}

.calendar-day .dow {
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
}

.calendar-day .dom {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: var(--font-size-lg);
}

.calendar-day:hover,
.calendar-day.active {
  background: var(--color-accent);
  color: var(--color-bg-dark);
  border-color: var(--color-accent);
}

.calendar-day:hover .dow,
.calendar-day.active .dow {
  color: var(--color-bg-dark);
}

/* ---------- EPG table (program.html) ---------- */
.epg-table-wrap {
  overflow-x: auto;
}

.epg-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 900px;
}

.epg-table th {
  background: var(--color-bg-header);
  padding: var(--space-md);
  font-size: var(--font-size-sm);
  color: var(--color-accent);
  text-align: center;
  position: sticky;
  top: 0;
}

.epg-table td {
  border: 1px solid var(--color-border-light);
  padding: var(--space-sm);
  vertical-align: top;
  min-width: 140px;
}

.epg-table .time-col {
  background: var(--color-bg-header);
  font-weight: 700;
  color: var(--color-accent);
  text-align: center;
  white-space: nowrap;
  position: sticky;
  right: 0;
}

.epg-slot {
  display: block;
  border-radius: var(--radius-sm);
  padding: var(--space-sm);
  font-size: var(--font-size-xs);
  font-weight: 600;
  height: 100%;
  color: var(--color-text-primary);
}

.epg-slot.cat-lectures { background: rgba(233, 78, 27, 0.18); border-inline-start: 3px solid var(--color-orange); }
.epg-slot.cat-seminars { background: rgba(0, 108, 53, 0.22); border-inline-start: 3px solid var(--color-primary); }
.epg-slot.cat-quran { background: rgba(33, 150, 243, 0.18); border-inline-start: 3px solid var(--color-info); }
.epg-slot.cat-training { background: rgba(247, 181, 56, 0.18); border-inline-start: 3px solid var(--color-accent); }
.epg-slot.cat-docs { background: rgba(76, 175, 80, 0.18); border-inline-start: 3px solid var(--color-success); }

/* ---------- Tags ---------- */
.tag-list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
}

.tag {
  padding: var(--space-xs) var(--space-md);
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  font-size: var(--font-size-xs);
  color: var(--color-text-secondary);
}

.tag:hover {
  border-color: var(--color-accent);
  color: var(--color-accent);
}

/* ---------- Share buttons ---------- */
.share-row {
  display: flex;
  gap: var(--space-sm);
}

.share-row a {
  width: 38px;
  height: 38px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-md);
  background: var(--color-bg-card);
  border: 1px solid var(--color-border-light);
  color: var(--color-text-secondary);
}

.share-row a:hover {
  border-color: var(--color-accent);
  color: var(--color-accent);
}

/* ---------- Breadcrumb ---------- */
.breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
  margin-bottom: var(--space-lg);
}

.breadcrumb a:hover {
  color: var(--color-accent);
}
