/*
 * HLS Player — BEM-Namensraum
 *
 * Block:    .hlsplayer
 * Elements: .hlsplayer__<name>
 * Modifier: .hlsplayer--<mod>  bzw.  .hlsplayer__<el>--<mod>
 *
 * Themes: .hlsplayer--theme-dark | .hlsplayer--theme-light
 * Layout: .hlsplayer--layout-list | .hlsplayer--layout-grid
 *
 * CSS-Custom-Properties (für Customizer / Theme-Overrides):
 *   --hlsp-bg, --hlsp-fg, --hlsp-muted, --hlsp-accent,
 *   --hlsp-card, --hlsp-border, --hlsp-radius, --hlsp-thumb-size,
 *   --hlsp-cover-size, --hlsp-play-size
 */

.hlsplayer {
	--hlsp-bg: #1c1f24;
	--hlsp-fg: #f3f4f6;
	--hlsp-muted: #9aa0a6;
	--hlsp-accent: #4f9cf9;
	--hlsp-accent-fg: #ffffff;
	--hlsp-card: #262a31;
	--hlsp-border: #2f343c;
	--hlsp-radius: 12px;
	--hlsp-thumb-size: 36px;
	--hlsp-cover-size: 140px;
	--hlsp-play-size: 44px;

	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
	color: var(--hlsp-fg);
	background: var(--hlsp-bg);
	border-radius: var(--hlsp-radius);
	padding: 16px;
	box-sizing: border-box;
	max-width: 100%;
}
.hlsplayer.hlsplayer--theme-light {
	--hlsp-bg: #ffffff;
	--hlsp-fg: #111827;
	--hlsp-muted: #6b7280;
	--hlsp-accent: #2563eb;
	--hlsp-accent-fg: #ffffff;
	--hlsp-card: #f3f4f6;
	--hlsp-border: #e5e7eb;
}
.hlsplayer *,
.hlsplayer *::before,
.hlsplayer *::after { box-sizing: border-box; }

/* ---------- Layout Wrap ---------------------------------------------- */
.hlsplayer .hlsplayer__wrap {
	display: grid;
	grid-template-columns: minmax(200px, 1fr) 2fr;
	gap: 16px;
	align-items: stretch;
}
@media (max-width: 640px) {
	.hlsplayer .hlsplayer__wrap { grid-template-columns: 1fr; }
}
.hlsplayer.hlsplayer--single .hlsplayer__wrap {
	grid-template-columns: 1fr;
}

/* ---------- Stationsliste -------------------------------------------- */
.hlsplayer .hlsplayer__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 6px;
	max-height: 360px;
	overflow: auto;
}
.hlsplayer.hlsplayer--layout-grid .hlsplayer__list {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
	max-height: none;
}
.hlsplayer .hlsplayer__station { margin: 0; }

.hlsplayer .hlsplayer__station-btn {
	-webkit-appearance: none;
	appearance: none;
	width: 100%;
	min-height: var(--hlsp-thumb-size);
	text-align: left;
	background: var(--hlsp-card);
	color: var(--hlsp-fg);
	border: 1px solid var(--hlsp-border);
	padding: 8px 12px;
	border-radius: 8px;
	cursor: pointer;
	display: flex;
	align-items: center;
	gap: 10px;
	font: inherit;
	line-height: 1.2;
	transition: border-color .15s, background .15s;
}
.hlsplayer .hlsplayer__station-btn:hover { border-color: var(--hlsp-accent); }
.hlsplayer .hlsplayer__station-btn:focus-visible {
	outline: 2px solid var(--hlsp-accent);
	outline-offset: 2px;
}
.hlsplayer .hlsplayer__station-btn--active {
	border-color: var(--hlsp-accent);
	background: color-mix(in srgb, var(--hlsp-accent) 14%, var(--hlsp-card));
}

.hlsplayer .hlsplayer__station-thumb {
	flex: 0 0 var(--hlsp-thumb-size);
	width: var(--hlsp-thumb-size);
	height: var(--hlsp-thumb-size);
	border-radius: 6px;
	background-color: var(--hlsp-bg);
	background-position: center;
	background-size: cover;
	background-repeat: no-repeat;
	color: var(--hlsp-muted);
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
}
.hlsplayer .hlsplayer__station-thumb svg {
	width: 60%;
	height: 60%;
	fill: currentColor;
	display: block;
}

.hlsplayer .hlsplayer__station-text {
	display: flex;
	flex-direction: column;
	gap: 2px;
	min-width: 0;
	flex: 1 1 auto;
}
.hlsplayer .hlsplayer__station-name {
	font-weight: 600;
	font-size: 14px;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.hlsplayer .hlsplayer__station-desc {
	font-size: 12px;
	color: var(--hlsp-muted);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.hlsplayer .hlsplayer__station-desc:empty { display: none; }

/* ---------- Player --------------------------------------------------- */
.hlsplayer .hlsplayer__player {
	display: grid;
	grid-template-columns: var(--hlsp-cover-size) 1fr;
	grid-template-rows: auto 1fr auto;
	gap: 4px 16px;
	align-content: stretch;
	background: var(--hlsp-card);
	border: 1px solid var(--hlsp-border);
	border-radius: 10px;
	padding: 14px;
	min-width: 0;
}
@media (max-width: 480px) {
	.hlsplayer { --hlsp-cover-size: 96px; }
}

.hlsplayer .hlsplayer__cover {
	grid-column: 1;
	grid-row: 1 / span 3;
	width: var(--hlsp-cover-size);
	height: var(--hlsp-cover-size);
	border-radius: 8px;
	overflow: hidden;
	background: #000;
	display: flex;
	align-items: center;
	justify-content: center;
	align-self: start;
}
.hlsplayer .hlsplayer__cover-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.hlsplayer .hlsplayer__cover-fallback {
	width: 50%;
	height: 50%;
	color: var(--hlsp-muted);
	display: flex;
	align-items: center;
	justify-content: center;
	pointer-events: none;
}
.hlsplayer .hlsplayer__cover-fallback svg {
	width: 100%;
	height: 100%;
	fill: currentColor;
	display: block;
}

.hlsplayer .hlsplayer__meta {
	grid-column: 2;
	grid-row: 1;
	min-width: 0;
}
.hlsplayer .hlsplayer__station-label {
	font-size: 12px;
	letter-spacing: .04em;
	text-transform: uppercase;
	color: var(--hlsp-muted);
	margin-bottom: 4px;
}
.hlsplayer .hlsplayer__title {
	font-weight: 700;
	font-size: 16px;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	margin: 0;
}
.hlsplayer .hlsplayer__artist {
	color: var(--hlsp-muted);
	font-size: 14px;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	margin: 2px 0 0 0;
}

.hlsplayer .hlsplayer__controls {
	grid-column: 2;
	grid-row: 3;
	display: flex;
	align-items: center;
	gap: 12px;
	flex-wrap: wrap;
	min-width: 0;
}
.hlsplayer .hlsplayer__play { margin-right: 8px; }

/* ---------- Play-Button (gegen Theme-Overrides gehärtet) -------------- */
.hlsplayer .hlsplayer__play {
	-webkit-appearance: none;
	appearance: none;
	flex: 0 0 var(--hlsp-play-size);
	width: var(--hlsp-play-size) !important;
	height: var(--hlsp-play-size) !important;
	min-width: var(--hlsp-play-size);
	min-height: var(--hlsp-play-size);
	max-width: var(--hlsp-play-size);
	padding: 0;
	margin: 0;
	border: 0;
	border-radius: 50%;
	background: var(--hlsp-accent);
	color: var(--hlsp-accent-fg) !important;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	line-height: 1;
	box-shadow: none;
	font: inherit;
}
.hlsplayer .hlsplayer__play:hover { filter: brightness(1.08); }
.hlsplayer .hlsplayer__play:focus-visible {
	outline: 2px solid var(--hlsp-accent);
	outline-offset: 2px;
}
.hlsplayer .hlsplayer__play svg {
	width: 18px;
	height: 18px;
	display: block;
	fill: currentColor;
	pointer-events: none;
}

/* ---------- Bitrate-Select (custom Pfeil) ---------------------------- */
.hlsplayer .hlsplayer__select {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	background-color: var(--hlsp-bg);
	color: var(--hlsp-fg);
	border: 1px solid var(--hlsp-border);
	border-radius: 6px;
	padding: 6px 28px 6px 10px;
	font: inherit;
	font-size: 13px;
	line-height: 1.2;
	cursor: pointer;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%239aa0a6'><path d='M7 10l5 5 5-5z'/></svg>");
	background-repeat: no-repeat;
	background-position: right 6px center;
	background-size: 16px 16px;
}
.hlsplayer .hlsplayer__select:focus-visible {
	outline: 2px solid var(--hlsp-accent);
	outline-offset: 2px;
}

/* ---------- Mute-Toggle + Volume-Slider ------------------------------ */
.hlsplayer .hlsplayer__volume-group {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	flex: 0 0 auto;
}
.hlsplayer .hlsplayer__mute {
	-webkit-appearance: none;
	appearance: none;
	width: 32px !important;
	height: 32px !important;
	min-width: 32px;
	min-height: 32px;
	padding: 0;
	margin: 0;
	border: 0;
	background: transparent;
	color: var(--hlsp-fg) !important;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 4px;
	flex: 0 0 auto;
	font: inherit;
	line-height: 1;
}
.hlsplayer .hlsplayer__mute:hover { color: var(--hlsp-accent) !important; }
.hlsplayer .hlsplayer__mute:focus-visible {
	outline: 2px solid var(--hlsp-accent);
	outline-offset: 2px;
}
.hlsplayer .hlsplayer__mute svg {
	width: 20px;
	height: 20px;
	fill: currentColor;
	display: block;
	pointer-events: none;
}

/* Volume-Slider (Custom Track + Thumb) */
.hlsplayer .hlsplayer__volume {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	width: 120px !important;
	height: 18px;
	background: transparent !important;
	margin: 0;
	padding: 0;
	border: 0;
	cursor: pointer;
	flex: 0 0 auto;
}
.hlsplayer .hlsplayer__volume::-webkit-slider-runnable-track {
	height: 4px;
	background: var(--hlsp-border);
	border-radius: 2px;
	border: 0;
}
.hlsplayer .hlsplayer__volume::-moz-range-track {
	height: 4px;
	background: var(--hlsp-border);
	border-radius: 2px;
	border: 0;
}
.hlsplayer .hlsplayer__volume::-webkit-slider-thumb {
	-webkit-appearance: none;
	appearance: none;
	width: 14px;
	height: 14px;
	border-radius: 50%;
	background: var(--hlsp-accent);
	border: 0;
	margin-top: -5px;
	cursor: pointer;
	box-shadow: none;
}
.hlsplayer .hlsplayer__volume::-moz-range-thumb {
	width: 14px;
	height: 14px;
	border-radius: 50%;
	background: var(--hlsp-accent);
	border: 0;
	cursor: pointer;
	box-shadow: none;
}
.hlsplayer .hlsplayer__volume:focus-visible {
	outline: 2px solid var(--hlsp-accent);
	outline-offset: 2px;
}

/* ---------- Status & Audio ------------------------------------------- */
.hlsplayer .hlsplayer__status {
	font-size: 12px;
	color: var(--hlsp-muted);
	margin-left: auto;
	min-width: 0;
	flex: 0 1 auto;
}
.hlsplayer .hlsplayer__audio { display: none; }

/* ---------- Admin-Hinweis -------------------------------------------- */
.hlsplayer .hlsplayer__empty {
	padding: 12px;
	border: 1px dashed #c00;
	color: #c00;
	background: #fff5f5;
	border-radius: 6px;
}
