/* ── Social: Views ── */
.views-count {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: .8rem; color: var(--text-muted);
}
.views-count::before { content: '👁'; font-size: .75rem; }
.views-count.loading { opacity: .4; }

/* Views on comic card */
.comic-views {
  font-size: .75rem; color: var(--text-muted);
}

/* ── Social Bar (comic page) ── */
.social-bar {
  display: flex; flex-direction: column; gap: 16px;
  margin: 20px 0 28px;
  padding: 16px 20px;
  background: var(--bg-card); border: 1px solid var(--border); border-radius: 8px;
}

.social-row {
  display: flex; align-items: center; gap: 16px; flex-wrap: wrap;
}

.social-views {
  display: flex; align-items: center; gap: 6px;
  font-size: .85rem; color: var(--text-muted);
}
.social-views-icon { font-size: 1rem; }
.social-views-num { font-weight: 600; color: var(--text); }

/* ── Rating ── */
.rating-widget {
  display: flex; align-items: center; gap: 10px;
}

.stars {
  display: flex; gap: 2px;
}

.star-btn {
  background: none; border: none; cursor: pointer;
  font-size: 1.4rem; line-height: 1; padding: 2px;
  color: var(--border);
  transition: color .1s, transform .1s;
}
.star-btn:hover,
.star-btn.hovered { color: var(--yellow); transform: scale(1.15); }
.star-btn.filled  { color: var(--yellow); }
.star-btn.voted   { color: var(--yellow); filter: drop-shadow(0 0 4px rgba(224,175,104,.5)); }

.rating-info {
  display: flex; align-items: baseline; gap: 5px;
}
.rating-avg {
  font-size: 1.1rem; font-weight: 700; color: var(--yellow);
}
.rating-avg.no-votes { color: var(--text-muted); font-weight: 400; font-size: .85rem; }
.rating-cnt { font-size: .75rem; color: var(--text-muted); }

/* ── Reactions ── */
.reactions {
  display: flex; flex-wrap: wrap; gap: 6px;
}

.react-btn {
  display: inline-flex; align-items: center; gap: 5px;
  background: var(--bg-alt); border: 1px solid var(--border);
  border-radius: 20px; padding: 4px 10px;
  cursor: pointer; font-size: .85rem; color: var(--text-muted);
  transition: background .15s, border-color .15s, color .15s, transform .1s;
  user-select: none;
}
.react-btn:hover {
  background: var(--bg-hover); border-color: var(--text-muted);
  color: var(--text); transform: scale(1.05);
}
.react-btn.active {
  background: rgba(122,162,247,.12); border-color: var(--accent);
  color: var(--text);
}
.react-btn.active:hover {
  background: rgba(122,162,247,.2);
}
.react-emoji { font-size: 1rem; line-height: 1; }
.react-count { font-size: .8rem; min-width: 14px; }

/* ── Chapter end social bar ── */
.ch-end-social {
  margin: 40px 0 24px;
  padding-top: 32px;
  border-top: 1px solid var(--border);
}

.ch-end-social-label {
  margin: 0 0 12px;
  font-size: .75rem;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.ch-end-social .social-bar {
  margin: 0;
}

/* bump animation on click */
@keyframes react-pop {
  0%   { transform: scale(1); }
  40%  { transform: scale(1.25); }
  100% { transform: scale(1); }
}
.react-btn.pop { animation: react-pop .2s ease; }
