/* ─── Page headers ──────────────────────────────────────────────────────── */
.page-title {
	font: var(--font-h3);
	margin: 4px 0 16px;
}
.section-title {
	font: var(--font-h5);
	margin: 22px 0 12px;
	display: flex;
	align-items: center;
	justify-content: space-between;
}
.top-bar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	margin-bottom: 8px;
}
.top-bar .brand {
	font: var(--font-h4);
	display: flex;
	align-items: center;
	gap: 8px;
}
.top-bar .brand .ms { color: var(--accent); font-size: 26px; }
.icon-btn {
	background: var(--surface-2);
	border: 1px solid var(--border);
	color: var(--text);
	width: 40px; height: 40px;
	border-radius: 50%;
	display: grid; place-items: center;
	cursor: pointer;
}
.icon-btn:hover { background: var(--surface-3); }
.icon-btn .ms { font-size: 22px; }

/* ─── Album / artist grid ───────────────────────────────────────────────── */
.grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
	gap: 16px;
}
.h-scroll {
	display: flex;
	gap: 14px;
	overflow-x: auto;
	padding-bottom: 6px;
	scroll-snap-type: x proximity;
	-webkit-overflow-scrolling: touch;
}
.h-scroll > * { flex: 0 0 150px; scroll-snap-align: start; }

.card {
	cursor: pointer;
	border-radius: var(--radius-card, 14px);
	transition: transform 0.12s;
}
.card:active { transform: scale(0.97); }
.card .art {
	aspect-ratio: 1;
	width: 100%;
	border-radius: 12px;
	background: var(--surface-2);
	object-fit: cover;
	display: grid;
	place-items: center;
	overflow: hidden;
	box-shadow: 0 6px 18px rgba(0,0,0,0.35);
}
.art .ms { font-size: 46px; color: var(--text-faint); }
.track-row cover-art .art .ms { font-size: 22px; }
.card .title { font: var(--font-body-medium-semibold); margin: 8px 2px 1px; }
.card .sub   { font: var(--font-body-small-regular); color: var(--text-dim); margin: 0 2px; }
.card.round .art { border-radius: 50%; }

/* ─── Track list ────────────────────────────────────────────────────────── */
.track-row {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 9px 8px;
	border-radius: 10px;
	cursor: pointer;
}
.track-row:hover { background: var(--surface); }
.track-row.playing { background: var(--surface); }
.track-row .num {
	width: 24px;
	text-align: center;
	color: var(--text-faint);
	font: var(--font-body-small-regular);
	flex-shrink: 0;
}
.track-row.playing .num { color: var(--accent); }
.track-row.selected { background: var(--surface-2); }
.track-row.selected .num { color: var(--accent); }

/* ─── Modal + track picker (playlists) ───────────────────────────────────── */
.modal-backdrop {
	position: fixed;
	inset: 0;
	z-index: 100;
	background: rgba(0, 0, 0, 0.6);
	backdrop-filter: blur(3px);
	display: grid;
	place-items: center;
	padding: 20px;
	animation: fade-in 0.15s ease;
}
.modal {
	width: 100%;
	max-width: 460px;
	max-height: 80vh;
	display: flex;
	flex-direction: column;
	background: var(--surface-2);
	border: 1px solid var(--border);
	border-radius: var(--radius-modal);
	box-shadow: 0 24px 64px rgba(0, 0, 0, 0.55);
	padding: 16px;
}
.modal-head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	margin-bottom: 12px;
}
.modal-head h2 { margin: 0; font-size: 18px; font-weight: 600; }
.modal-search {
	width: 100%;
	background: var(--surface);
	border: 1px solid var(--border);
	border-radius: var(--radius-input);
	color: var(--text);
	padding: 10px 12px;
	font-size: 15px;
	outline: none;

	&::placeholder { color: var(--text-faint); }
	&:focus { border-color: var(--accent); }
}
.picker-list {
	flex: 1;
	min-height: 0;
	overflow-y: auto;
	margin: 12px 0 4px;
}
.modal-foot {
	display: flex;
	justify-content: flex-end;
	gap: 8px;
	padding-top: 8px;
}

/* ─── Playlist reorder ────────────────────────────────────────────────────── */
.reorder-bar {
	position: sticky;
	top: 0;
	z-index: 20;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	flex-wrap: wrap;
	padding: 10px 0;
	margin-bottom: 4px;
	background: var(--surface);
	border-bottom: 1px solid var(--border);
}
.reorder-list { margin-top: 4px; }
.reorder-row {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 10px 8px;
	margin-bottom: 6px;
	border-radius: 10px;
	background: var(--surface);
	border: 1px solid var(--border);
}
.reorder-row.dragging {
	border-color: var(--accent);
	box-shadow: 0 6px 18px rgba(0, 0, 0, 0.45);
}
.reorder-row .drag-handle {
	flex-shrink: 0;
	display: grid;
	place-items: center;
	color: var(--text-faint);
	cursor: grab;
	touch-action: none;       /* the handle owns the gesture, so the page never scrolls */

	&:active { cursor: grabbing; }
	& .ms { font-size: 24px; }
}
.reorder-row .meta { flex: 1; min-width: 0; }
.reorder-arrows { display: flex; gap: 2px; flex-shrink: 0; }
.track-row .meta { flex: 1; min-width: 0; }
.track-row .t-title { font: var(--font-body-medium-medium); }
.track-row .t-sub { font: var(--font-body-small-regular); color: var(--text-dim); }
.track-row .dur { color: var(--text-faint); font: var(--font-body-small-regular); flex-shrink: 0; }
.track-row .row-actions { display: flex; align-items: center; gap: 4px; flex-shrink: 0; }
.row-icon {
	background: none;
	border: none;
	color: var(--text-faint);
	display: grid;
	place-items: center;
	padding: 4px;
	cursor: pointer;
	border-radius: 50%;

	&:hover { color: var(--text); background: var(--surface-3); }
	&:disabled { opacity: 0.3; cursor: default; background: none; color: var(--text-faint); }
	& .ms { font-size: 20px; }
}
.dl-dot { width: 16px; height: 16px; color: var(--accent); flex-shrink: 0; }

/* ─── Detail header ─────────────────────────────────────────────────────── */
.detail-head {
	display: flex;
	gap: 18px;
	align-items: flex-end;
	margin-bottom: 18px;
}
.detail-head .art {
	width: 168px;
	height: 168px;
	border-radius: 14px;
	background: var(--surface-2);
	object-fit: cover;
	box-shadow: 0 12px 32px rgba(0,0,0,0.5);
	display: grid;
	place-items: center;
	flex-shrink: 0;
}
.detail-head .art .ms { font-size: 66px; color: var(--text-faint); }
.detail-head .info h1 { font: var(--font-h3); margin: 0 0 6px; }
.detail-head .info .sub { color: var(--text-dim); font: var(--font-body-medium-regular); }
.detail-actions { display: flex; gap: 10px; align-items: center; margin: 4px 0 22px; }

.play-btn {
	background: var(--accent-grad);
	color: #fff;
	border: none;
	border-radius: 999px;
	padding: 11px 26px;
	font: var(--font-body-medium-bold);
	display: inline-flex;
	align-items: center;
	gap: 8px;
	cursor: pointer;
}
.play-btn:active { transform: scale(0.97); }
.ghost-btn {
	background: var(--surface-2);
	border: 1px solid var(--border);
	color: var(--text);
	border-radius: 999px;
	padding: 10px 16px;
	font: var(--font-body-medium-medium);
	display: inline-flex;
	align-items: center;
	gap: 8px;
	cursor: pointer;
}
.ghost-btn:hover { background: var(--surface-3); }

@media (max-width: 560px) {
	.detail-head { flex-direction: column; align-items: center; text-align: center; }
	.detail-head .art { width: 60vw; height: 60vw; max-width: 260px; max-height: 260px; }
}

.empty {
	text-align: center;
	color: var(--text-dim);
	padding: 60px 20px;
}
.empty .ms { font-size: 54px; color: var(--surface-3); margin-bottom: 12px; }

/* ─── Search ────────────────────────────────────────────────────────────── */
.search-input {
	width: 100%;
	background: var(--surface-2);
	border: 1px solid var(--border);
	color: var(--text);
	border-radius: 12px;
	padding: 13px 16px;
	font: var(--font-body-large-regular);
	margin-bottom: 16px;
}
.search-input:focus { outline: none; border-color: var(--accent); }

/* ─── Auth page ─────────────────────────────────────────────────────────── */
.auth-page { min-height: 100dvh; display: grid; place-items: center; padding: 20px; }
.auth-card {
	width: 100%;
	max-width: 380px;
	text-align: center;
	background: var(--surface);
	border: 1px solid var(--border);
	border-radius: 20px;
	padding: 36px 28px;
}
.auth-logo {
	width: 72px; height: 72px;
	border-radius: 20px;
	background: var(--accent-grad);
	display: grid; place-items: center;
	margin: 0 auto 18px;
	color: #fff;
}
.auth-logo .ms { font-size: 40px; }
.auth-title { font: var(--font-h3); margin: 0 0 6px; }
.auth-subtitle { color: var(--text-dim); margin: 0 0 26px; font: var(--font-body-medium-regular); }
.auth-actions { display: flex; flex-direction: column; gap: 10px; }
.auth-hint { color: var(--text-dim); font: var(--font-body-small-regular); margin: 0 0 18px; line-height: 1.5; }
.auth-error { color: var(--danger); font: var(--font-body-small-medium); margin-top: 14px; }

cover-art { display: block; }

/* ─── Download toggle (idle / progress ring / done) ─────────────────────── */
.dl-btn {
	background: none;
	border: none;
	padding: 0;
	color: var(--text-dim);
	width: 36px; height: 36px;
	border-radius: 50%;
	display: grid; place-items: center;
	cursor: pointer;
	flex-shrink: 0;
}
.dl-btn:hover { background: var(--surface-2); }
.dl-btn .ms { font-size: 22px; }
.dl-btn.done .dl-check { color: var(--accent); }
.dl-ring { display: block; width: 22px; height: 22px; transform: rotate(-90deg); transform-origin: center; }
.dl-ring-bg { fill: none; stroke: var(--surface-3); stroke-width: 2.4; }
.dl-ring-fg { fill: none; stroke: var(--accent); stroke-width: 2.4; stroke-linecap: round; transition: stroke-dashoffset 0.18s linear; }
.dl-ring.spin { animation: dl-spin 0.9s linear infinite; }
@keyframes dl-spin { from { transform: rotate(-90deg); } to { transform: rotate(270deg); } }

/* ─── Show description (clamp + expand) ─────────────────────────────────── */
.show-desc {
	color: var(--text-dim);
	line-height: 1.5;
	max-width: 70ch;
	margin: 0 0 4px;
}
.show-desc.clamp {
	display: -webkit-box;
	-webkit-line-clamp: 3;
	line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.desc-toggle {
	background: none;
	border: none;
	color: var(--accent);
	font: var(--font-body-small-semibold);
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	gap: 3px;
	padding: 2px 0;
	margin: 0 0 14px;
}
.desc-toggle .ms { font-size: 18px; }

/* ─── Episode sort/filter controls ──────────────────────────────────────── */
.ep-controls {
	display: flex;
	align-items: center;
	gap: 8px;
	flex-wrap: wrap;
	margin: 4px 0 12px;
}
.chip {
	background: var(--surface-2);
	border: 1px solid var(--border);
	color: var(--text-dim);
	border-radius: 999px;
	padding: 6px 14px;
	font: var(--font-body-small-semibold);
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	gap: 5px;
	white-space: nowrap;
}
.chip:hover { background: var(--surface-3); }
.chip.on { background: var(--accent); border-color: var(--accent); color: #fff; }
.chip .ms { font-size: 18px; }
.chip.sort { margin-left: auto; }
.ep-search {
	width: 100%;
	background: var(--surface-2);
	border: 1px solid var(--border);
	color: var(--text);
	border-radius: 10px;
	padding: 10px 14px;
	font: var(--font-body-medium-regular);
	margin-bottom: 10px;
}
.ep-search:focus { outline: none; border-color: var(--accent); }

/* ─── Episode list (podcasts) ───────────────────────────────────────────── */
.ep-row {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 10px 6px;
	border-bottom: 1px solid var(--border);
}
.ep-row.playing { background: var(--surface); border-radius: 10px; }
.ep-play {
	flex-shrink: 0;
	width: 42px; height: 42px;
	border-radius: 50%;
	border: 1px solid var(--border);
	background: var(--surface-2);
	color: var(--text);
	display: grid; place-items: center;
	cursor: pointer;
}
.ep-play:hover { background: var(--surface-3); }
.ep-play .ms { font-size: 22px; }
.ep-main { flex: 1; min-width: 0; cursor: pointer; }
.ep-title { font: var(--font-body-medium-semibold); }
.ep-title.done { color: var(--text-dim); }
.ep-sub { font: var(--font-body-small-regular); color: var(--text-dim); margin-top: 1px; }
.ep-progress { height: 4px; background: var(--surface-3); border-radius: 3px; margin-top: 7px; overflow: hidden; }
.ep-progress .fill { height: 100%; background: var(--accent); }
.ep-action { width: 36px; height: 36px; flex-shrink: 0; }
.ep-action .ms { font-size: 20px; }
.ep-row .ep-action:first-of-type .ms { color: var(--text-dim); }

/* ─── Now-playing bar ───────────────────────────────────────────────────── */
player-bar { display: block; }
