/* =========================================================
   BuddyBoss YouTube Player — player.css
   ========================================================= */

/* ── Imports ─────────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700&display=swap');

/* ── Variables ───────────────────────────────────────────── */
:root {
	--bbyt-bg:         rgba(14, 14, 18, 0.96);
	--bbyt-bg2:        rgba(22, 22, 30, 0.98);
	--bbyt-border:     rgba(255, 255, 255, 0.10);
	--bbyt-text:       #f0f0f5;
	--bbyt-text-sub:   rgba(240, 240, 245, 0.50);
	--bbyt-radius:     18px;
	--bbyt-font:       'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
	--bbyt-shadow:     0 24px 60px rgba(0,0,0,0.55), 0 8px 24px rgba(0,0,0,0.35);
	--bbyt-transition: 0.28s cubic-bezier(0.4, 0, 0.2, 1);
}

/* ── Hidden YouTube iframe ───────────────────────────────── */
#bbyt-yt-container {
	position: absolute;
	width: 1px;
	height: 1px;
	overflow: hidden;
	opacity: 0;
	pointer-events: none;
	left: -9999px;
	top: -9999px;
}

/* ── Wrapper ─────────────────────────────────────────────── */
.bbyt-player {
	position: fixed;
	bottom: 24px;
	z-index: 99999;
	font-family: var(--bbyt-font);
	-webkit-font-smoothing: antialiased;
	user-select: none;
}
.bbyt-player.bbyt-right { right: 24px; }
.bbyt-player.bbyt-left  { left:  24px; }

/* ── Mini pill ───────────────────────────────────────────── */
.bbyt-mini {
	display: flex;
	align-items: center;
	gap: 10px;
	background: var(--bbyt-bg);
	border: 1px solid var(--bbyt-border);
	border-radius: 60px;
	padding: 8px 14px 8px 8px;
	box-shadow: var(--bbyt-shadow);
	backdrop-filter: blur(24px) saturate(160%);
	-webkit-backdrop-filter: blur(24px) saturate(160%);
	cursor: pointer;
	min-width: 200px;
	max-width: 320px;
	transition: transform var(--bbyt-transition), box-shadow var(--bbyt-transition);
}
.bbyt-mini:hover {
	transform: translateY(-2px);
	box-shadow: 0 28px 70px rgba(0,0,0,0.65);
}
.bbyt-mini-thumb-wrap {
	position: relative;
	flex-shrink: 0;
	width: 40px;
	height: 40px;
}
.bbyt-mini-thumb {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	object-fit: cover;
	display: block;
	border: 2px solid var(--bbyt-accent, #FF0000);
	animation: bbyt-spin-thumb 8s linear infinite paused;
}
.bbyt-player.bbyt-playing .bbyt-mini-thumb {
	animation-play-state: running;
}
@keyframes bbyt-spin-thumb {
	to { transform: rotate(360deg); }
}
.bbyt-mini-spin {
	position: absolute;
	inset: -3px;
	border-radius: 50%;
	border: 2px solid transparent;
	border-top-color: var(--bbyt-accent, #FF0000);
	animation: bbyt-spinner 1s linear infinite;
	display: none;
}
.bbyt-player.bbyt-buffering .bbyt-mini-spin { display: block; }
@keyframes bbyt-spinner {
	to { transform: rotate(360deg); }
}
.bbyt-mini-info {
	flex: 1;
	min-width: 0;
}
.bbyt-mini-title {
	display: block;
	color: var(--bbyt-text);
	font-size: 13px;
	font-weight: 600;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

/* ── Full card ───────────────────────────────────────────── */
.bbyt-full {
	position: absolute;
	bottom: calc(100% + 10px);
	width: 300px;
	background: var(--bbyt-bg2);
	border: 1px solid var(--bbyt-border);
	border-radius: var(--bbyt-radius);
	box-shadow: var(--bbyt-shadow);
	backdrop-filter: blur(32px) saturate(180%);
	-webkit-backdrop-filter: blur(32px) saturate(180%);
	padding: 0 0 16px;
	overflow: hidden;
	transform-origin: bottom center;
	transform: scale(0.9) translateY(12px);
	opacity: 0;
	pointer-events: none;
	transition: transform var(--bbyt-transition), opacity var(--bbyt-transition);
}
.bbyt-player.bbyt-right .bbyt-full { right: 0; }
.bbyt-player.bbyt-left  .bbyt-full { left:  0; }
.bbyt-full.bbyt-open {
	transform: scale(1) translateY(0);
	opacity: 1;
	pointer-events: all;
}

/* ── Collapse button ─────────────────────────────────────── */
.bbyt-collapse {
	position: absolute;
	top: 10px;
	right: 10px;
	z-index: 2;
	width: 28px;
	height: 28px;
	color: rgba(255,255,255,0.7);
	background: rgba(255,255,255,0.08);
	border-radius: 50%;
}
.bbyt-collapse:hover { color: #fff; background: rgba(255,255,255,0.16); }

/* ── Artwork ─────────────────────────────────────────────── */
.bbyt-artwork-wrap {
	position: relative;
	width: 100%;
	height: 160px;
	overflow: hidden;
}
.bbyt-artwork {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 6s ease;
}
.bbyt-player.bbyt-playing .bbyt-artwork { transform: scale(1.05); }
.bbyt-artwork-overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to bottom, rgba(14,14,18,0) 40%, rgba(14,14,18,1));
}

/* ── Visualizer bars ─────────────────────────────────────── */
.bbyt-visualizer {
	position: absolute;
	bottom: 10px;
	left: 16px;
	display: flex;
	align-items: flex-end;
	gap: 3px;
	height: 24px;
}
.bbyt-visualizer span {
	display: block;
	width: 3px;
	border-radius: 2px;
	background: var(--bbyt-accent, #FF0000);
	animation: bbyt-bar 0.9s ease-in-out infinite alternate;
	height: 4px;
}
.bbyt-visualizer span:nth-child(1) { animation-duration: 0.7s; animation-delay: 0.0s; }
.bbyt-visualizer span:nth-child(2) { animation-duration: 0.9s; animation-delay: 0.1s; }
.bbyt-visualizer span:nth-child(3) { animation-duration: 0.6s; animation-delay: 0.2s; }
.bbyt-visualizer span:nth-child(4) { animation-duration: 1.1s; animation-delay: 0.05s; }
.bbyt-visualizer span:nth-child(5) { animation-duration: 0.8s; animation-delay: 0.15s; }
@keyframes bbyt-bar {
	from { height: 3px;  opacity: 0.4; }
	to   { height: 22px; opacity: 1.0; }
}
.bbyt-visualizer span { animation-play-state: paused; height: 3px; }
.bbyt-player.bbyt-playing .bbyt-visualizer span { animation-play-state: running; }

/* ── Meta ────────────────────────────────────────────────── */
.bbyt-meta {
	padding: 14px 18px 4px;
}
.bbyt-title {
	margin: 0 0 2px;
	color: var(--bbyt-text);
	font-size: 14px;
	font-weight: 700;
	line-height: 1.3;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.bbyt-sub {
	margin: 0;
	color: var(--bbyt-text-sub);
	font-size: 11px;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: .06em;
}

/* ── Progress bar ────────────────────────────────────────── */
.bbyt-progress-wrap {
	padding: 14px 18px 4px;
	cursor: pointer;
}
.bbyt-progress-bg {
	position: relative;
	height: 4px;
	background: rgba(255,255,255,0.12);
	border-radius: 4px;
	overflow: visible;
}
.bbyt-progress-fill {
	height: 100%;
	background: var(--bbyt-accent, #FF0000);
	border-radius: 4px;
	width: 0%;
	transition: width .5s linear;
}
.bbyt-progress-knob {
	position: absolute;
	top: 50%;
	left: 0%;
	transform: translate(-50%, -50%) scale(0);
	width: 14px;
	height: 14px;
	background: #fff;
	border-radius: 50%;
	box-shadow: 0 0 0 3px var(--bbyt-accent, #FF0000);
	transition: transform .2s, left .5s linear;
}
.bbyt-progress-wrap:hover .bbyt-progress-knob { transform: translate(-50%, -50%) scale(1); }
.bbyt-time-row {
	display: flex;
	justify-content: space-between;
	margin-top: 6px;
	color: var(--bbyt-text-sub);
	font-size: 11px;
	font-weight: 500;
}

/* ── Controls ────────────────────────────────────────────── */
.bbyt-controls {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 10px 18px 4px;
}
.bbyt-icon-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: transparent;
	border: none;
	cursor: pointer;
	color: var(--bbyt-text);
	padding: 6px;
	border-radius: 50%;
	transition: background var(--bbyt-transition), color var(--bbyt-transition), transform .15s;
}
.bbyt-icon-btn:hover { background: rgba(255,255,255,0.10); transform: scale(1.1); }
.bbyt-icon-btn svg { width: 20px; height: 20px; display: block; }
.bbyt-icon-btn.bbyt-ctrl svg { width: 22px; height: 22px; }

.bbyt-play-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 52px;
	height: 52px;
	border-radius: 50%;
	background: var(--bbyt-accent, #FF0000);
	border: none;
	cursor: pointer;
	color: #fff;
	box-shadow: 0 4px 20px rgba(var(--bbyt-accent-rgb, 255,0,0), 0.50);
	transition: transform .15s, box-shadow .15s;
}
.bbyt-play-btn:hover {
	transform: scale(1.08);
	box-shadow: 0 6px 28px rgba(var(--bbyt-accent-rgb, 255,0,0), 0.65);
}
.bbyt-play-btn svg { width: 26px; height: 26px; }

/* ── Mini play button ────────────────────────────────────── */
#bbyt-mini-play {
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background: var(--bbyt-accent, #FF0000);
	color: #fff;
	flex-shrink: 0;
}
#bbyt-mini-play:hover { background: color-mix(in srgb, var(--bbyt-accent, #FF0000) 80%, white); }
#bbyt-mini-play svg { width: 18px; height: 18px; }

/* Expand btn in mini */
#bbyt-expand-btn {
	flex-shrink: 0;
	color: var(--bbyt-text-sub);
	width: 28px;
	height: 28px;
}
#bbyt-expand-btn svg { width: 16px; height: 16px; }

/* ── Volume row ──────────────────────────────────────────── */
.bbyt-volume-row {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 4px 18px 8px;
}
.bbyt-vol-icon { color: var(--bbyt-text-sub); }
.bbyt-vol-icon svg { width: 18px; height: 18px; }
.bbyt-volume-slider-wrap { flex: 1; }
.bbyt-volume-slider {
	width: 100%;
	-webkit-appearance: none;
	appearance: none;
	height: 4px;
	border-radius: 4px;
	background: rgba(255,255,255,0.12);
	outline: none;
	cursor: pointer;
}
.bbyt-volume-slider::-webkit-slider-thumb {
	-webkit-appearance: none;
	width: 13px;
	height: 13px;
	border-radius: 50%;
	background: var(--bbyt-accent, #FF0000);
	cursor: pointer;
	box-shadow: 0 0 0 2px rgba(255,255,255,0.15);
	transition: transform .15s;
}
.bbyt-volume-slider::-webkit-slider-thumb:hover { transform: scale(1.3); }
.bbyt-volume-slider::-moz-range-thumb {
	width: 13px;
	height: 13px;
	border-radius: 50%;
	background: var(--bbyt-accent, #FF0000);
	cursor: pointer;
	border: none;
}
.bbyt-vol-label {
	font-size: 11px;
	color: var(--bbyt-text-sub);
	min-width: 28px;
	text-align: right;
}

/* ── Playlist ────────────────────────────────────────────── */
.bbyt-playlist-section { padding: 0 18px; }
.bbyt-playlist-heading {
	margin: 0 0 8px;
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .08em;
	color: var(--bbyt-text-sub);
}
.bbyt-playlist-list {
	list-style: none;
	margin: 0;
	padding: 0;
	max-height: 140px;
	overflow-y: auto;
	scrollbar-width: thin;
	scrollbar-color: rgba(255,255,255,0.15) transparent;
}
.bbyt-playlist-list li {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 7px 8px;
	border-radius: 8px;
	cursor: pointer;
	transition: background .2s;
}
.bbyt-playlist-list li:hover { background: rgba(255,255,255,0.07); }
.bbyt-playlist-list li.active { background: rgba(var(--bbyt-accent-rgb,255,0,0),0.15); }
.bbyt-playlist-list li img {
	width: 36px;
	height: 36px;
	border-radius: 6px;
	object-fit: cover;
	flex-shrink: 0;
}
.bbyt-playlist-list li span {
	font-size: 12px;
	color: var(--bbyt-text);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.bbyt-playlist-list li.active span { color: var(--bbyt-accent, #FF0000); font-weight: 600; }

/* ── Loop button ─────────────────────────────────────────── */
.bbyt-loop-row {
	display: flex;
	justify-content: center;
	padding: 0 18px 6px;
}
.bbyt-loop-btn {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	background: rgba(255,255,255,0.06);
	border: 1px solid rgba(255,255,255,0.10);
	border-radius: 20px;
	padding: 5px 14px 5px 10px;
	color: var(--bbyt-text-sub);
	font-family: var(--bbyt-font);
	font-size: 12px;
	font-weight: 600;
	cursor: pointer;
	transition: background var(--bbyt-transition), color var(--bbyt-transition),
	            border-color var(--bbyt-transition), box-shadow var(--bbyt-transition);
}
.bbyt-loop-btn svg {
	width: 15px;
	height: 15px;
	flex-shrink: 0;
	transition: stroke var(--bbyt-transition);
}
.bbyt-loop-btn:hover {
	background: rgba(255,255,255,0.11);
	color: var(--bbyt-text);
}
.bbyt-loop-btn.active {
	background: rgba(var(--bbyt-accent-rgb, 255,0,0), 0.18);
	border-color: rgba(var(--bbyt-accent-rgb, 255,0,0), 0.45);
	color: var(--bbyt-accent, #FF0000);
	box-shadow: 0 0 10px rgba(var(--bbyt-accent-rgb, 255,0,0), 0.20);
}
.bbyt-loop-btn.active svg { stroke: var(--bbyt-accent, #FF0000); }

/* ── Loop button ─────────────────────────────────────────── */
.bbyt-yt-link {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	margin: 4px 18px 0;
	padding: 8px;
	border-radius: 10px;
	background: rgba(255,255,255,0.05);
	border: 1px solid rgba(255,255,255,0.08);
	color: var(--bbyt-text-sub) !important;
	font-size: 12px;
	font-weight: 500;
	text-decoration: none !important;
	transition: background .2s, color .2s;
}
.bbyt-yt-link:hover { background: rgba(255,255,255,0.10); color: var(--bbyt-text) !important; }
.bbyt-yt-link svg { width: 16px; height: 16px; flex-shrink: 0; }

/* ── Entry animation ─────────────────────────────────────── */
@keyframes bbyt-slide-in {
	from { opacity: 0; transform: translateY(20px); }
	to   { opacity: 1; transform: translateY(0); }
}
.bbyt-player { animation: bbyt-slide-in .45s ease both; }

/* ── Mobile ──────────────────────────────────────────────── */
@media (max-width: 600px) {
	.bbyt-player { bottom: 12px; }
	.bbyt-player.bbyt-right { right: 12px; }
	.bbyt-player.bbyt-left  { left:  12px; }
	.bbyt-full { width: calc(100vw - 24px); }
}
