/*
 * Single song page (v2) — mirrors the album page shell.
 * Reuses .album-tabs* and .key-credits styles from albums.css.
 */

#song-layout {
	display: grid;
	grid-template-columns: 300px minmax(0, 1fr) 360px;
	grid-template-areas:
		"cover main context"
		"media media context"
		"tabs tabs context";
	gap: 1.5rem 2.5rem;
	align-items: start;
	margin-bottom: 2.5rem;
}

#song-layout .song-cover { grid-area: cover; }
#song-layout .song-main { grid-area: main; }
#song-layout .song-media-section { grid-area: media; }
#song-layout .song-context { grid-area: context; }
#song-layout #song-content { grid-area: tabs; margin-top: 0; }

@media (max-width: 1180px) {
	#song-layout {
		grid-template-columns: 280px minmax(0, 1fr);
		grid-template-areas:
			"cover main"
			"media media"
			"tabs tabs"
			"context context";
	}
}

@media (max-width: 720px) {
	#song-layout {
		grid-template-columns: 1fr;
		grid-template-areas:
			"cover"
			"main"
			"media"
			"tabs"
			"context";
	}
}

@media (max-width: 720px) {
	#song-layout {
		grid-template-columns: 1fr;
	}
}

/* Cover */
.song-cover {
	position: relative;
	aspect-ratio: 1 / 1;
	overflow: hidden;
	box-shadow: 0 10px 30px rgba(0, 0, 0, 0.15);
	background: #eaeaea;
}

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

.song-cover .placeholder {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #999;
}

.song-cover .cover-source {
	position: absolute;
	bottom: 0.4rem;
	left: 0.4rem;
	background: rgba(0, 0, 0, 0.55);
	color: #fff;
	font-size: 0.7em;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	padding: 0.15em 0.5em;
	border-radius: 3px;
}

/* Page heading */
.song-page-heading {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	gap: 1rem;
	border-bottom: 1px solid #eaeaea;
	padding-bottom: 1em;
	margin: 0 0 1.5rem;
	width: 100%;
}

.song-heading-main {
	flex: 1;
	min-width: 0;
}

.song-page-heading h1 {
	border-bottom: 0;
	padding-bottom: 0;
	margin-bottom: 0.35rem;
}

.song-release-line {
	align-items: baseline;
	color: #111;
	display: flex;
	flex-wrap: wrap;
	gap: 0.45rem 0.7rem;
	font-family: 'gotham_mediumregular';
	font-size: 0.92em;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.song-release-line em {
	color: #999;
	font-family: 'gotham_bookregular';
	font-size: 0.82em;
	font-style: normal;
}

.song-from-album {
	font-size: 0.9em;
	color: #666;
	margin-bottom: 0.5em;
}

.song-from-album__label {
	text-transform: uppercase;
	letter-spacing: 0.1em;
	font-size: 0.85em;
	color: #999;
	margin-right: 0.4em;
}

.song-from-album a {
	color: #111;
	text-decoration: none;
	font-family: 'gotham_mediumregular';
}

.song-from-album a:hover {
	text-decoration: underline;
}

/* Main column */
.song-overview {
	max-width: 680px;
}

.song-overview .tag-chips {
	margin: -0.25rem 0 1rem;
}

.song-overview__heading {
	margin-bottom: 1rem;
}

.song-overview__heading > span {
	color: #999;
	display: block;
	font-family: 'gotham_mediumregular';
	font-size: 0.72em;
	letter-spacing: 0.11em;
	margin-bottom: 0.35rem;
	text-transform: uppercase;
}

.song-overview__heading h2 {
	color: #111;
	font-family: 'gotham_mediumregular';
	font-size: 1.55em;
	line-height: 1.15;
	margin: 0 0 0.35rem;
}

.song-overview__heading p {
	color: #888;
	font-family: 'gotham_mediumregular';
	font-size: 0.82em;
	letter-spacing: 0.08em;
	margin: 0;
	text-transform: uppercase;
}

.song-main .synopsis {
	color: #333;
	display: -webkit-box;
	font-size: 1.02em;
	line-height: 1.45;
	margin: 0 0 1.1rem;
	max-width: 62ch;
	overflow: hidden;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 1;
}

.record-tabs-body--song-main {
	display: block;
}

.record-tabs-body--song-main .record-tab-panels {
	max-width: none;
}

.song-main .key-credits {
	display: grid;
	grid-template-columns: 8.5rem minmax(0, 1fr);
	gap: 0.45rem 1rem;
	margin: 0 0 1.5rem;
	max-width: 62ch;
}

.song-main .key-credits--song-overview {
	border-top: 1px solid var(--mjdb-line, #e8e8e8);
	padding-top: 1rem;
}

.song-main .key-credits dt {
	font-family: var(--mjdb-font-medium, 'gotham_mediumregular');
	text-transform: uppercase;
	font-size: 0.68em;
	letter-spacing: 0.08em;
	color: var(--mjdb-muted, #888);
	align-self: baseline;
	padding-top: 0.05rem;
}

.song-main .key-credits dd {
	margin: 0;
	color: var(--mjdb-text, #222);
	font-size: 0.92em;
	line-height: 1.45;
}

.song-main .key-credits .credit-link {
	color: inherit;
	text-decoration: none;
}

.song-main .key-credits .credit-link:hover {
	color: var(--mjdb-ink, #111);
	text-decoration: underline;
}

.song-main .key-credits .credit-separator {
	color: var(--mjdb-muted, #888);
}

.song-main .read-more-inline--block {
	display: block;
	margin-top: 0.2rem;
}

@media (max-width: 1320px) {
	.song-main .key-credits {
		grid-template-columns: 8.5rem minmax(0, 1fr);
	}
}

.song-spotify {
	margin: 0;
}

.song-media-section {
	background: #fff;
	border-top: 1px solid var(--mjdb-line, #e8e8e8);
	display: grid;
	gap: 1.5rem;
	grid-template-columns: 260px minmax(0, 1fr);
	margin: 0;
	padding: 1.15rem 0 0;
}

.song-media-copy h2 {
	color: var(--mjdb-muted, #777);
	font-family: var(--mjdb-font-medium, 'gotham_mediumregular');
	font-size: 0.74em;
	font-weight: normal;
	letter-spacing: 0.1em;
	line-height: 1.2;
	margin: 0 0 0.65rem;
	text-transform: uppercase;
}

.song-media-copy h3 {
	color: var(--mjdb-ink, #111);
	font-family: var(--mjdb-font-medium, 'gotham_mediumregular');
	font-size: 0.95em;
	font-weight: normal;
	line-height: 1.25;
	margin: 0 0 0.3rem;
}

.song-media-copy p {
	color: var(--mjdb-text, #535353);
	font-size: 0.9em;
	line-height: 1.45;
	margin: 0 0 0.75rem;
}

.song-media-copy .song-media-meta {
	color: var(--mjdb-muted, #888);
	font-family: var(--mjdb-font-book, 'gotham_bookregular');
	font-size: 0.78em;
	line-height: 1.35;
	margin: 0 0 0.85rem;
}

.song-media-copy .song-media-meta span + span::before {
	content: "·";
	margin: 0 0.5rem;
	color: var(--mjdb-line-strong, #d6d6d6);
}

.song-media-link {
	color: var(--mjdb-ink, #111);
	font-family: var(--mjdb-font-medium, 'gotham_mediumregular');
	font-size: 0.72em;
	letter-spacing: 0.08em;
	text-decoration: none;
	text-transform: uppercase;
}

.song-media-link:hover {
	color: var(--mjdb-gold, #b08320);
	text-decoration: underline;
}

.song-media-player {
	min-width: 0;
}

.song-feature-video {
	max-width: none;
}

.song-feature-video__frame {
	aspect-ratio: 16 / 9;
	background: #111;
	overflow: hidden;
	width: 100%;
}

.song-feature-video__frame iframe {
	display: block;
	width: 100%;
	height: 100%;
}

@media (max-width: 1180px) {
	.song-media-section {
		grid-template-columns: 280px minmax(0, 1fr);
	}
}

@media (max-width: 720px) {
	.song-media-section {
		grid-template-columns: 1fr;
	}
}

.song-context {
	min-width: 0;
}

.song-context-block {
	margin-bottom: 2rem;
}

.song-context .song-album-card {
	margin-bottom: 1.5rem;
}

.song-context .aside-title {
	border-bottom: 1px solid #eaeaea;
	color: #535353;
	font-family: 'gotham_mediumregular';
	font-size: 0.85em;
	letter-spacing: 0.08em;
	margin: 0 0 1rem;
	padding-bottom: 0.65rem;
	text-transform: uppercase;
}

.song-context-tracklist ol {
	list-style: none;
	margin: 0;
	padding: 0;
}

.song-context-tracklist li {
	align-items: center;
	background: #fff;
	border-bottom: 1px solid var(--mjdb-line-table, #eeeeee);
	display: grid;
	font-family: var(--mjdb-font-book, 'gotham_bookregular');
	font-size: 0.78em;
	grid-template-columns: 2.35rem minmax(0, 1fr);
	line-height: 1.25;
	min-height: 0;
	padding: 0.6rem 0.75rem;
	text-transform: uppercase;
}

.song-context-tracklist li:nth-of-type(even) {
	background: #fff;
}

.song-context-tracklist li.is-current {
	background: #fafafa;
	box-shadow: inset 2px 0 0 var(--mjdb-gold, #d4a017);
	color: var(--mjdb-ink, #111);
	font-family: var(--mjdb-font-medium, 'gotham_mediumregular');
}

.song-context-tracklist .track-no {
	color: var(--mjdb-muted, #999);
	font-size: 0.85em;
	font-variant-numeric: tabular-nums;
}

.song-context-tracklist li.is-current .track-no {
	color: var(--mjdb-gold, #d4a017);
}

.song-context-tracklist .track-title {
	color: inherit;
	overflow: hidden;
	text-decoration: none;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.song-context-tracklist a.track-title:hover {
	text-decoration: underline;
}

.song-context-stats .aside-stats {
	font-family: var(--mjdb-font-book, 'gotham_bookregular');
	font-size: 0.82em;
	line-height: 1.35;
}

.song-context-stats .aside-stats li {
	border-bottom: 1px solid var(--mjdb-line-table, #eeeeee);
	padding: 0.55rem 0;
}

.song-context-stats .aside-stats li:last-child {
	border-bottom: 0;
}

.song-context-stats .aside-stats strong {
	color: var(--mjdb-ink, #111);
	font-family: var(--mjdb-font-medium, 'gotham_mediumregular');
}

.song-context-videos ul,
.song-context-appearances ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

.song-context-videos li,
.song-context-appearances li {
	border-bottom: 1px solid #eee;
	padding: 0 0 0.75rem;
	margin-bottom: 0.75rem;
}

.song-context-videos a,
.song-context-appearances a {
	align-items: center;
	color: inherit;
	display: grid;
	gap: 0.85rem;
	text-decoration: none;
}

.song-context-videos a {
	grid-template-columns: 88px minmax(0, 1fr);
}

.song-context-videos img {
	aspect-ratio: 16 / 9;
	background: #111;
	display: block;
	object-fit: cover;
	width: 88px;
}

.song-context-appearances a {
	grid-template-columns: 58px minmax(0, 1fr);
}

.song-context-appearances img {
	aspect-ratio: 1 / 1;
	background: #eee;
	display: block;
	object-fit: cover;
	width: 58px;
}

.song-context-videos strong,
.song-context-appearances strong {
	color: #111;
	display: block;
	font-family: 'gotham_mediumregular';
	line-height: 1.2;
}

.song-context-videos em,
.song-context-appearances em {
	color: #999;
	display: block;
	font-size: 0.85em;
	font-style: normal;
	margin-top: 0.2em;
}

.song-context-videos a:hover strong,
.song-context-appearances a:hover strong {
	text-decoration: underline;
}

.song-album-card__link {
	align-items: center;
	color: inherit;
	display: grid;
	gap: 0.75rem;
	grid-template-columns: 64px minmax(0, 1fr);
	text-decoration: none;
}

.song-album-card__link img {
	display: block;
	width: 64px;
	height: 64px;
	aspect-ratio: 1 / 1;
	object-fit: cover;
	border-radius: 4px;
}

.song-album-card__body {
	display: flex;
	flex-direction: column;
	min-width: 0;
}

.song-album-card__title {
	font-family: 'gotham_mediumregular';
	color: #111;
	line-height: 1.25;
}

.song-album-card__link:hover .song-album-card__title {
	text-decoration: underline;
}

.song-album-card__meta {
	color: #999;
	font-size: 0.85em;
	margin-top: 0.2em;
}

/* Lyrics tab */
.song-lyrics {
	font-size: 1em;
	line-height: 1.7;
	color: #222;
	max-width: 56ch;
}

.song-lyrics p {
	margin: 0 0 1.4em;
}


/* Personnel grouping */
.song-credits-list {
	display: grid;
	grid-template-columns: max-content 1fr;
	gap: 0.5rem 1.5rem;
	margin: 0;
}

.song-credits-list dt {
	font-family: 'gotham_mediumregular';
	text-transform: uppercase;
	font-size: 0.72em;
	letter-spacing: 0.08em;
	color: #888;
	align-self: center;
}

.song-credits-list dd {
	margin: 0;
}

/* Origins / Covers */
.origin-list {
	list-style: none;
	padding: 0;
	margin: 0 0 1rem;
}

.origin-list li {
	padding: 0.4rem 0;
	border-bottom: 1px solid #f0f0f0;
}

.origin-list a {
	color: #111;
	text-decoration: none;
}

.origin-list a:hover {
	text-decoration: underline;
}

.origin-external {
	color: #555;
	font-style: italic;
}

/* Music video */
.song-video iframe {
	width: 100%;
	aspect-ratio: 16 / 9;
	border: 0;
}

/* Track navigation footer with cover thumbnails */
.song-nav.post-nav__cover--placeholder,
.song-nav .post-nav__cover--placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 60px;
	height: 60px;
	background: linear-gradient(135deg, #2a2a2a 0%, #4a4a4a 100%);
	color: #d4a017;
	font-size: 1.6em;
	border-radius: 3px;
	flex-shrink: 0;
}

/* Credit note next to a chip */
.credit-note {
	color: #888;
	font-size: 0.85em;
	font-style: italic;
}

/* Charts subhead */
.charts-subhead {
	margin: 1.5rem 0 0.5rem;
	font-family: 'gotham_mediumregular';
	font-size: 0.85em;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: #888;
}

.cert-list {
	list-style: none;
	padding: 0;
	margin: 0;
}

.cert-list li {
	padding: 0.3rem 0;
	border-bottom: 1px solid #f4f4f4;
	font-size: 0.95em;
}
