/* SC: artist rows */
.artist-row { display: grid; grid-template-columns: 32px 28px 1fr 80px 80px 120px 20px; align-items: center; gap: 12px; padding: 11px 0; border-bottom: 1px solid var(--border); cursor: pointer; transition: background 0.15s ease; overflow: hidden; }
.artist-row:hover { background: var(--bg); margin: 0 -24px; padding: 11px 24px; }
.consensus-score { font-size: 16px; font-weight: 700; color: var(--accent); text-align: center; }
.consensus-score.low { color: var(--text-dim); }
img.artist-avatar { width: 28px !important; height: 28px !important; min-width: 28px; border-radius: 50%; object-fit: cover; }
.artist-avatar-empty { width: 28px; height: 28px; border-radius: 50%; background: var(--border); }
.artist-info { min-width: 0; }
.artist-name { color: var(--text-bright); font-weight: 600; font-size: 12px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.artist-name a { color: inherit; text-decoration: none; }
.artist-name a:hover { text-decoration: underline; }
.artist-meta { color: var(--text-dim); font-size: 10px; margin-top: 2px; }
.stat-col { font-size: 10px; color: var(--text-dim); text-align: right; }
.stat-col .num { color: var(--text); font-size: 11px; display: block; }
.liked-by { display: flex; gap: 4px; justify-content: flex-end; flex-wrap: wrap; }
.dot { width: 6px; height: 6px; border-radius: 50%; opacity: 0.85; }

/* SC: detail */
.artist-detail { display: grid; grid-template-rows: 0fr; overflow: hidden; padding: 0 0 0 44px; border-bottom: 1px solid transparent; transition: grid-template-rows 0.3s ease, padding 0.3s ease, border-color 0.3s ease; }
.artist-detail > div { min-height: 0; overflow: hidden; }
.artist-detail.open { grid-template-rows: 1fr; padding: 10px 0 10px 44px; border-color: var(--border); }
.track-row { display: flex; justify-content: space-between; align-items: center; padding: 5px 0; gap: 12px; }
.track-title { color: var(--text); font-size: 11px; flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; cursor: pointer; }
.track-title:hover { color: var(--accent); }
.track-plays { color: var(--text-dim); font-size: 10px; flex-shrink: 0; }
.track-liked-by { display: flex; gap: 3px; flex-shrink: 0; }
.sc-embed { margin-top: 8px; }
.sc-embed iframe { border: none; width: 100%; height: 120px; }

/* SC: all likes */
.like-row { border-bottom: 1px solid var(--border); padding: 10px 0; }
.liked-by-line { font-size: 10px; color: var(--text-dim); margin-bottom: 4px; display: flex; align-items: center; gap: 0; flex-wrap: wrap; }
.liked-by-dot { width: 6px; height: 6px; border-radius: 50%; display: inline-block; margin-right: 4px; margin-left: 2px; opacity: 0.85; flex-shrink: 0; }
.liked-by-line .liked-by-dot:first-child { margin-left: 0; }
.like-header { display: grid; grid-template-columns: 1fr 80px 60px 20px; align-items: center; gap: 12px; }
.like-track { color: var(--text-bright); font-size: 11px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.like-track a { color: inherit; text-decoration: none; }
.like-track a:hover { text-decoration: underline; }
.like-track .artist { color: var(--text-dim); }

/* BC: release rows */
.bc-release-row { display: grid; transition: background 0.15s ease; grid-template-columns: 40px 28px 1fr 80px 20px; align-items: center; gap: 12px; padding: 11px 0; border-bottom: 1px solid var(--border); cursor: pointer; }
.bc-release-row:hover { background: var(--bg); margin: 0 -24px; padding: 11px 24px; }
.bc-art { width: 28px; height: 28px; border-radius: 4px; object-fit: cover; flex-shrink: 0; }
.bc-art-empty { width: 28px; height: 28px; border-radius: 4px; background: var(--border); }
.bc-score { font-size: 16px; font-weight: 700; color: var(--accent); text-align: center; }
.bc-score .denom { font-size: 9px; font-weight: 400; color: var(--text-dim); }
.bc-info { min-width: 0; }
.bc-title { color: var(--text-bright); font-weight: 600; font-size: 12px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.bc-title a { color: inherit; text-decoration: none; }
.bc-title a:hover { text-decoration: underline; }
.bc-artist { color: var(--text-dim); font-size: 10px; margin-top: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.bc-artist a { color: inherit; text-decoration: none; }
.bc-artist a:hover { text-decoration: underline; }
.bc-fans { font-size: 10px; color: var(--text-dim); text-align: right; }
.bc-fans .num { color: var(--text); font-size: 11px; display: block; }
.bc-seed-badge { display: inline-block; font-size: 8px; letter-spacing: 0.5px; text-transform: uppercase; background: var(--accent-dim); color: var(--accent); padding: 1px 5px; margin-left: 6px; vertical-align: middle; }
.bc-detail { display: grid; grid-template-rows: 0fr; overflow: hidden; padding: 0 0 0 52px; border-bottom: 1px solid transparent; transition: grid-template-rows 0.3s ease, padding 0.3s ease, border-color 0.3s ease; }
.bc-detail > div { min-height: 0; overflow: hidden; }
.bc-detail.open { grid-template-rows: 1fr; padding: 10px 0 10px 52px; border-color: var(--border); }
.bc-embed { margin-top: 4px; }
.bc-embed iframe { border: none; width: 100%; height: 120px; }

/* DC: release rows */
.dc-release-row { display: grid; transition: background 0.15s ease; grid-template-columns: 40px 1fr 120px; align-items: center; gap: 12px; padding: 11px 0; border-bottom: 1px solid var(--border); }
.dc-release-row:hover { background: var(--bg); margin: 0 -24px; padding: 11px 24px; }
.dc-score { font-size: 16px; font-weight: 700; color: var(--accent); text-align: center; }
.dc-score .denom { font-size: 9px; font-weight: 400; color: var(--text-dim); }
.dc-info { min-width: 0; }
.dc-title { color: var(--text-bright); font-weight: 600; font-size: 12px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.dc-title a { color: inherit; text-decoration: none; }
.dc-title a:hover { text-decoration: underline; }
.dc-artist { color: var(--text-dim); font-size: 10px; margin-top: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.dc-meta { color: var(--text-dim); font-size: 9px; margin-top: 1px; }
.dc-breakdown { font-size: 10px; color: var(--text-dim); text-align: right; }
.dc-breakdown .num { color: var(--text); font-size: 11px; display: block; }
.dc-have { color: var(--text); }
.dc-want { color: var(--accent); }

/* RYM: release rows */
.rym-release-row { display: grid; transition: background 0.15s ease; grid-template-columns: 40px 1fr 60px; align-items: center; gap: 12px; padding: 11px 0; border-bottom: 1px solid var(--border); }
.rym-release-row:hover { background: var(--bg); margin: 0 -24px; padding: 11px 24px; }
.rym-score { text-align: center; }
.rym-score .count { font-size: 16px; font-weight: 700; color: var(--accent); }
.rym-score .denom { font-size: 9px; font-weight: 400; color: var(--text-dim); }
.rym-info { min-width: 0; }
.rym-title { color: var(--text-bright); font-weight: 600; font-size: 12px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.rym-title a { color: inherit; text-decoration: none; }
.rym-title a:hover { text-decoration: underline; }
.rym-artist { color: var(--text-dim); font-size: 10px; margin-top: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.rym-genres { color: var(--text-dim); font-size: 9px; margin-top: 1px; }
.rym-avg { text-align: right; }
.rym-avg .stars { font-size: 14px; font-weight: 700; color: var(--accent); }
.rym-avg .label { font-size: 9px; color: var(--text-dim); }

/* Nina: release rows */
.nina-release-row { display: grid; transition: background 0.15s ease; grid-template-columns: 40px 1fr 100px 20px; align-items: center; gap: 12px; padding: 11px 0; border-bottom: 1px solid var(--border); }
.nina-release-row:hover { background: var(--bg); margin: 0 -24px; padding: 11px 24px; }
.nina-score { font-size: 16px; font-weight: 700; color: var(--accent); text-align: center; }
.nina-score .denom { font-size: 9px; font-weight: 400; color: var(--text-dim); }
.nina-info { min-width: 0; }
.nina-title { color: var(--text-bright); font-weight: 600; font-size: 12px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.nina-title a { color: inherit; text-decoration: none; }
.nina-title a:hover { text-decoration: underline; }
.nina-artist { color: var(--text-dim); font-size: 10px; margin-top: 2px; }
.nina-pct { font-size: 10px; color: var(--text-dim); text-align: right; }
.nina-pct .num { color: var(--text); font-size: 11px; }

/* IRL: artist rows */
.irl-artist-row { display: grid; transition: background 0.15s ease; grid-template-columns: 40px 1fr 100px 20px; align-items: center; gap: 12px; padding: 11px 0; border-bottom: 1px solid var(--border); }
.irl-artist-row:hover { background: var(--bg); margin: 0 -24px; padding: 11px 24px; }
.irl-score { font-size: 16px; font-weight: 700; color: var(--accent); text-align: center; }
.irl-score .denom { font-size: 9px; font-weight: 400; color: var(--text-dim); }
.irl-info { min-width: 0; }
.irl-name { color: var(--text-bright); font-weight: 600; font-size: 12px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.irl-name a { color: inherit; text-decoration: none; }
.irl-name a:hover { text-decoration: underline; }
.irl-meta { color: var(--text-dim); font-size: 10px; margin-top: 2px; }
.irl-seeds { display: flex; gap: 3px; margin-top: 3px; }
.irl-right { font-size: 10px; color: var(--text-dim); text-align: right; }
.irl-right .num { color: var(--text); font-size: 11px; }

/* NTS: artist rows */
.nts-artist-row { display: grid; transition: background 0.15s ease; grid-template-columns: 40px 1fr 100px 20px; align-items: center; gap: 12px; padding: 11px 0; border-bottom: 1px solid var(--border); }
.nts-artist-row:hover { background: var(--bg); margin: 0 -24px; padding: 11px 24px; }
.nts-score { font-size: 16px; font-weight: 700; color: var(--accent); text-align: center; }
.nts-score .denom { font-size: 9px; font-weight: 400; color: var(--text-dim); }
.nts-info { min-width: 0; }
.nts-name { color: var(--text-bright); font-weight: 600; font-size: 12px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.nts-meta { color: var(--text-dim); font-size: 10px; margin-top: 2px; }
.nts-seeds { display: flex; gap: 3px; margin-top: 3px; }
.nts-right { font-size: 10px; color: var(--text-dim); text-align: right; }
.nts-right .num { color: var(--text); font-size: 11px; }

/* Blogs: artist rows */
.blog-artist-row { display: grid; transition: background 0.15s ease; grid-template-columns: 40px 1fr 100px 20px; align-items: center; gap: 12px; padding: 11px 0; border-bottom: 1px solid var(--border); }
.blog-artist-row:hover { background: var(--bg); margin: 0 -24px; padding: 11px 24px; }
.blog-score { font-size: 16px; font-weight: 700; color: var(--accent); text-align: center; }
.blog-score .denom { font-size: 9px; font-weight: 400; color: var(--text-dim); }
.blog-info { min-width: 0; }
.blog-name { color: var(--text-bright); font-weight: 600; font-size: 12px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.blog-name a { color: inherit; text-decoration: none; }
.blog-name a:hover { text-decoration: underline; }
.blog-meta { color: var(--text-dim); font-size: 10px; margin-top: 2px; }
.blog-sources { display: flex; gap: 3px; margin-top: 3px; }
.blog-right { font-size: 10px; color: var(--text-dim); text-align: right; }
.blog-right .num { color: var(--text); font-size: 11px; }
