/**
 * Media Store — Personalized Home rails (Phase 5).
 * Horizontal rails of track / album / artist cards + a Continue Listening hero.
 */

.mst-home-rails { display: flex; flex-direction: column; gap: 8px; }
.mst-home-rails:empty { display: none; }

.mst-home-loading { display: flex; justify-content: center; padding: 40px 0; }

.mst-home-section { margin: 8px 0 4px; }
.mst-home-section__title {
	font-size: 1.15rem; font-weight: 700; margin: 0 0 14px;
	color: var(--mst-text, #fff); letter-spacing: -0.01em;
}

/* Horizontal rail (reuses .mst-row drag-scroll from main.js) */
.mst-home-row {
	display: flex; gap: 16px; overflow-x: auto; scroll-snap-type: x proximity;
	padding-bottom: 8px; scrollbar-width: thin;
}
.mst-home-row::-webkit-scrollbar { height: 6px; }
.mst-home-row::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.15); border-radius: 3px; }

/* ── Cards ───────────────────────────────────────────────────────────────── */
.mst-home-card { flex: 0 0 auto; width: 168px; scroll-snap-align: start; }
.mst-home-card__art {
	position: relative; width: 168px; height: 168px; border-radius: 10px; overflow: hidden;
	background: rgba(255,255,255,0.05); display: block;
}
.mst-home-card__art--round { border-radius: 50%; }
.mst-home-card__img { width: 100%; height: 100%; object-fit: cover; display: block; }
.mst-home-card__ph {
	display: block; width: 100%; height: 100%;
	background: linear-gradient(135deg, #2b2d55, #5c6ef4);
}

.mst-home-card__play {
	position: absolute; right: 10px; bottom: 10px; width: 42px; height: 42px; border-radius: 50%;
	border: 0; background: var(--mst-accent, #5c6ef4); color: #fff; cursor: pointer;
	display: flex; align-items: center; justify-content: center;
	opacity: 0; transform: translateY(8px); transition: opacity 0.18s, transform 0.18s;
	box-shadow: 0 6px 16px rgba(0,0,0,0.4);
}
.mst-home-card__art:hover .mst-home-card__play,
.mst-home-card:focus-within .mst-home-card__play { opacity: 1; transform: translateY(0); }

.mst-home-card__hover {
	position: absolute; left: 8px; top: 8px; display: flex; gap: 6px;
	opacity: 0; transition: opacity 0.18s;
}
.mst-home-card__art:hover .mst-home-card__hover,
.mst-home-card:focus-within .mst-home-card__hover { opacity: 1; }
.mst-home-card__mini {
	width: 30px; height: 30px; border-radius: 50%; border: 0; cursor: pointer;
	background: rgba(0,0,0,0.6); color: #fff; backdrop-filter: blur(6px);
	display: flex; align-items: center; justify-content: center; transition: background 0.15s;
}
.mst-home-card__mini:hover { background: rgba(0,0,0,0.85); }

.mst-home-card__title {
	display: block; margin-top: 10px; font-size: 0.875rem; font-weight: 600; color: var(--mst-text, #fff);
	text-decoration: none; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.mst-home-card__title:hover { text-decoration: underline; }
.mst-home-card__title--center { text-align: center; }
.mst-home-card__sub {
	display: block; margin-top: 2px; font-size: 0.78rem; color: var(--mst-text-dim, rgba(255,255,255,0.55));
	white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

/* ── Continue Listening ──────────────────────────────────────────────────── */
.mst-home-section--continue { margin-bottom: 18px; }
.mst-home-continue {
	display: flex; align-items: center; gap: 18px; padding: 16px;
	border-radius: 14px; background: linear-gradient(135deg, rgba(92,110,244,0.18), rgba(255,255,255,0.04));
	border: 1px solid rgba(255,255,255,0.08);
}
.mst-home-continue__art { width: 84px; height: 84px; flex-shrink: 0; border-radius: 10px; overflow: hidden; background: rgba(255,255,255,0.06); }
.mst-home-continue__img { width: 100%; height: 100%; object-fit: cover; }
.mst-home-continue__art .mst-home-card__ph { border-radius: 10px; }
.mst-home-continue__info { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 3px; }
.mst-home-continue__eyebrow { font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.08em; color: var(--mst-accent, #8b97ff); font-weight: 700; }
.mst-home-continue__title { font-size: 1.05rem; font-weight: 700; color: #fff; text-decoration: none; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mst-home-continue__title:hover { text-decoration: underline; }
.mst-home-continue__sub { font-size: 0.85rem; color: rgba(255,255,255,0.6); }
.mst-home-continue__bar { height: 4px; border-radius: 2px; background: rgba(255,255,255,0.15); margin-top: 6px; overflow: hidden; }
.mst-home-continue__bar span { display: block; height: 100%; background: var(--mst-accent, #5c6ef4); border-radius: 2px; }
.mst-home-continue__time { font-size: 0.72rem; color: rgba(255,255,255,0.45); margin-top: 4px; }
.mst-home-continue__resume { flex-shrink: 0; display: inline-flex; align-items: center; gap: 7px; }

@media (max-width: 600px) {
	.mst-home-card, .mst-home-card__art { width: 132px; }
	.mst-home-card__art { height: 132px; }
	.mst-home-continue { flex-wrap: wrap; }
	.mst-home-continue__resume { width: 100%; justify-content: center; }
}
