/**
 * MediaBlaster video player styles (native + Video.js).
 */

.mediablaster-player {
	--mb-player-max-width: 1920px;
	--mb-player-aspect-ratio: 16 / 9;
	--mb-player-radius: 8px;
	--mb-player-bg: #000;
	--mb-player-accent: #3b82f6;
	--mb-player-control-bg: rgba(20, 20, 20, 0.92);
	--mb-player-control-color: #f9fafb;
	--mb-player-message-bg: #111827;
	--mb-player-message-color: #f3f4f6;

	box-sizing: border-box;
	width: 100%;
	max-width: var(--mb-player-max-width);
	margin-left: auto;
	margin-right: auto;
	background: var(--mb-player-bg);
	border-radius: var(--mb-player-radius);
	overflow: hidden;
	position: relative;
}

.mediablaster-player *,
.mediablaster-player *::before,
.mediablaster-player *::after {
	box-sizing: border-box;
}

.mediablaster-player__inner {
	position: relative;
	width: 100%;
	aspect-ratio: var(--mb-player-aspect-ratio, 16 / 9);
	background: var(--mb-player-bg);
	overflow: hidden;
}

/* Fallback play button when Video.js UI is unavailable (privacy browsers, blocked assets). */
.mediablaster-player__play-fallback {
	position: absolute;
	inset: 0;
	z-index: 4;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0;
	padding: 0;
	border: 0;
	background: transparent;
	cursor: pointer;
}

.mediablaster-player__play-fallback[hidden] {
	display: none;
}

.mediablaster-player--videojs-ready .mediablaster-player__play-fallback {
	display: none;
}

.mediablaster-player__play-fallback-icon {
	display: block;
	width: 4rem;
	height: 4rem;
	border-radius: 999px;
	background: rgba(0, 0, 0, 0.65);
	box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.12);
	position: relative;
	transition: transform 0.15s ease, background 0.15s ease;
}

.mediablaster-player__play-fallback-icon::before {
	content: "";
	position: absolute;
	top: 50%;
	left: 54%;
	transform: translate(-50%, -50%);
	border-style: solid;
	border-width: 0.75rem 0 0.75rem 1.2rem;
	border-color: transparent transparent transparent #fff;
}

.mediablaster-player__play-fallback:hover .mediablaster-player__play-fallback-icon,
.mediablaster-player__play-fallback:focus-visible .mediablaster-player__play-fallback-icon {
	background: var(--mb-player-accent);
	transform: scale(1.05);
}

.mediablaster-player--native-fallback .mediablaster-player__video {
	position: relative;
	z-index: 1;
}

.mediablaster-player__video {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: contain;
	background: var(--mb-player-bg);
	border-radius: inherit;
}

/* Video.js layout inside player wrapper */
.mediablaster-player .video-js {
	width: 100%;
	height: 100%;
	font-family: inherit;
}

.mediablaster-player .video-js.vjs-fluid {
	padding-top: 0;
	height: 100%;
}

.mediablaster-player .video-js .vjs-tech {
	object-fit: contain;
}

.mediablaster-player .video-js .vjs-big-play-button {
	border: none;
	border-radius: 999px;
	width: 3.5rem;
	height: 3.5rem;
	line-height: 3.5rem;
	margin-top: -1.75rem;
	margin-left: -1.75rem;
	background: rgba(0, 0, 0, 0.65);
	transition: transform 0.15s ease, background 0.15s ease;
}

.mediablaster-player .video-js:hover .vjs-big-play-button,
.mediablaster-player .video-js .vjs-big-play-button:focus {
	background: var(--mb-player-accent);
	transform: scale(1.05);
}

.mediablaster-player .video-js .vjs-control-bar {
	background: var(--mb-player-control-bg);
	color: var(--mb-player-control-color);
	border-bottom-left-radius: var(--mb-player-radius);
	border-bottom-right-radius: var(--mb-player-radius);
}

.mediablaster-player .video-js .vjs-play-progress,
.mediablaster-player .video-js .vjs-volume-level {
	background-color: var(--mb-player-accent);
}

.mediablaster-player .video-js .vjs-slider-bar {
	background: rgba(255, 255, 255, 0.25);
}

.mediablaster-player .video-js.vjs-fullscreen {
	border-radius: 0;
}

/* Default skin */
.mediablaster-player--skin-default {
	box-shadow: 0 4px 24px rgba(0, 0, 0, 0.25);
}

/* Streaming skin */
.mediablaster-player--skin-streaming {
	--mb-player-radius: 14px;
	box-shadow: 0 12px 48px rgba(0, 0, 0, 0.45);
}

.mediablaster-player--skin-streaming .video-js .vjs-big-play-button {
	width: 4rem;
	height: 4rem;
	line-height: 4rem;
	margin-top: -2rem;
	margin-left: -2rem;
}

/* Creator skin */
.mediablaster-player--skin-creator {
	--mb-player-radius: 4px;
	box-shadow: none;
	border: 1px solid rgba(255, 255, 255, 0.08);
}

.mediablaster-player--skin-creator .video-js .vjs-big-play-button {
	background: rgba(0, 0, 0, 0.8);
}

/* Error state */
.mediablaster-player--error,
.mediablaster-player--playback-error {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 200px;
	aspect-ratio: var(--mb-player-aspect-ratio, 16 / 9);
	background: var(--mb-player-message-bg);
}

.mediablaster-player--playback-error .mediablaster-player__inner {
	opacity: 0.35;
}

.mediablaster-player__message {
	text-align: center;
	padding: 2rem 1.5rem;
	color: var(--mb-player-message-color);
	max-width: 32rem;
}

.mediablaster-player__message strong {
	display: block;
	font-size: 1.125rem;
	margin-bottom: 0.5rem;
}

.mediablaster-player__message p {
	margin: 0.5rem 0 0;
	font-size: 0.9375rem;
	line-height: 1.5;
	opacity: 0.85;
}

.mediablaster-player__debug {
	font-size: 0.8125rem !important;
	opacity: 0.65 !important;
	font-style: italic;
	margin-top: 1rem !important;
}

/* Locked state */
.mediablaster-player--locked .mediablaster-player__inner {
	display: flex;
	align-items: center;
	justify-content: center;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}

.mediablaster-player--locked .mediablaster-player__inner::before {
	content: "";
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.65);
	backdrop-filter: blur(2px);
}

.mediablaster-player__lock {
	position: relative;
	z-index: 1;
	text-align: center;
	padding: 2rem 1.5rem;
	color: var(--mb-player-message-color);
	max-width: 28rem;
}

.mediablaster-player__lock-title {
	display: block;
	font-size: 1.25rem;
	margin-bottom: 0.5rem;
}

.mediablaster-player__lock-message {
	margin: 0.5rem 0 0;
	font-size: 0.9375rem;
	line-height: 1.5;
}

.mediablaster-player__lock-actions {
	margin-top: 1rem !important;
}

.mediablaster-player__lock-link {
	display: inline-block;
	margin: 0 0.5rem;
	padding: 0.5rem 1.25rem;
	border-radius: 4px;
	background: var(--mb-player-accent);
	color: #fff !important;
	text-decoration: none !important;
	font-size: 0.875rem;
	font-weight: 600;
	transition: opacity 0.15s ease;
}

.mediablaster-player__lock-link:hover,
.mediablaster-player__lock-link:focus {
	opacity: 0.9;
	color: #fff !important;
}

/* Vertical video */
.mediablaster-player[style*="9 / 16"] .mediablaster-player__inner,
.mediablaster-player[style*="9/16"] .mediablaster-player__inner {
	max-height: min(90vh, 960px);
	margin: 0 auto;
}

@media (max-width: 640px) {
	.mediablaster-player__message,
	.mediablaster-player__lock {
		padding: 1.5rem 1rem;
	}

	.mediablaster-player__lock-link {
		display: block;
		margin: 0.5rem auto;
		max-width: 12rem;
	}

	.mediablaster-player .video-js .vjs-big-play-button {
		width: 3rem;
		height: 3rem;
		line-height: 3rem;
		margin-top: -1.5rem;
		margin-left: -1.5rem;
	}
}
