/**
 * Joyn ML Player — Frontend Styles
 * ----------------------------------------------------------------------------
 * All rules scoped under .jml-player to avoid bleed into host theme.
 * Theme accent overridable via [data-theme=X] on the player container.
 * Uses color-mix() for translucent variants — auto-derived from --accent.
 */

/* ============== DESIGN TOKENS — scoped to player only ============== */
.jml-player {
	/* surfaces */
	--jml-bg:        #0a0a0c;
	--jml-bg-elev-1: #111114;
	--jml-bg-elev-2: #181820;
	--jml-bg-elev-3: #1f1f29;

	/* ink */
	--jml-ink:        #ece7dc;
	--jml-ink-muted:  #9a958a;
	--jml-ink-subtle: #6a6660;

	/* accent (themable) */
	--accent:        #c9a560;
	--accent-bright: #e3bf73;
	--accent-soft:   #8a7341;
	--line-accent:   color-mix(in srgb, var(--accent) 32%, transparent);

	/* border lines */
	--jml-line:        rgba(236, 231, 220, 0.08);
	--jml-line-strong: rgba(236, 231, 220, 0.16);

	/* misc */
	--jml-radius:    10px;
	--jml-radius-lg: 16px;
	--jml-shadow-lg: 0 24px 60px -20px rgba(0,0,0,0.7), 0 8px 20px -8px rgba(0,0,0,0.5);
	--jml-crimson:   #c2493b;

	/* fonts — fall back to host theme; consumer can override via filter */
	--jml-font:    "Pretendard Variable", "Pretendard", -apple-system, BlinkMacSystemFont, sans-serif;
	--jml-font-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, monospace;
}

/* ============== NAMED THEMES ============== */
.jml-player[data-theme="gold"]    { --accent:#c9a560; --accent-bright:#e3bf73; --accent-soft:#8a7341; }
.jml-player[data-theme="indigo"]  { --accent:#4541ff; --accent-bright:#7a78ff; --accent-soft:#2e2cb3; }
.jml-player[data-theme="crimson"] { --accent:#c2493b; --accent-bright:#e16957; --accent-soft:#8b3328; }
.jml-player[data-theme="forest"]  { --accent:#4a9b6e; --accent-bright:#6abe8e; --accent-soft:#2f6b48; }
.jml-player[data-theme="ocean"]   { --accent:#3d8db5; --accent-bright:#5cb0d6; --accent-soft:#266180; }
.jml-player[data-theme="rose"]    { --accent:#c97b8e; --accent-bright:#e0a4b3; --accent-soft:#8b526a; }
/* [data-theme="custom"] uses inline --accent, --accent-bright, --accent-soft */

/* ============== CONTAINER ============== */
.jml-player {
	position: relative;
	width: 100%;
	color: var(--jml-ink);
	font-family: var(--jml-font);
	-webkit-font-smoothing: antialiased;
}
.jml-player *, .jml-player *::before, .jml-player *::after { box-sizing: border-box; }
.jml-player button { font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; padding: 0; }

.jml-player--empty {
	padding: 40px 20px;
	background: var(--jml-bg-elev-1);
	border: 1px dashed var(--jml-line-strong);
	border-radius: var(--jml-radius);
	color: var(--jml-ink-muted);
	text-align: center;
	font-size: 14px;
}

/* ============== PLAYER FRAME ============== */
.jml-frame {
	position: relative;
	aspect-ratio: 16 / 9;
	border-radius: var(--jml-radius-lg);
	overflow: hidden;
	background: #050505;
	box-shadow: var(--jml-shadow-lg);
	border: 1px solid var(--jml-line-strong);
}

.jml-stage {
	position: absolute;
	inset: 0;
	background:
		radial-gradient(ellipse at 30% 20%, color-mix(in srgb, var(--accent) 18%, transparent), transparent 55%),
		radial-gradient(ellipse at 70% 80%, rgba(69,65,255,0.12), transparent 60%),
		linear-gradient(135deg, #1a1612 0%, #0c0a08 50%, #100c14 100%);
	display: grid;
	place-items: center;
	transition: opacity 0.4s ease;
}
.jml-stage::after {
	content: "";
	position: absolute;
	inset: 0;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='400' height='400'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.7' numOctaves='3' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.6'/></svg>");
	opacity: 0.06;
	mix-blend-mode: overlay;
	pointer-events: none;
}
.jml-stage iframe {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	border: 0;
}
.jml-stage-placeholder {
	z-index: 1;
	color: color-mix(in srgb, var(--accent) 60%, transparent);
}
.jml-stage-icon::before {
	content: "";
	display: block;
	width: 64px;
	height: 64px;
	border-radius: 50%;
	background: color-mix(in srgb, var(--accent) 15%, transparent);
	border: 1px solid color-mix(in srgb, var(--accent) 30%, transparent);
}

/* Provider badge — top-left */
.jml-provider-badge {
	position: absolute;
	top: 18px;
	left: 18px;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 7px 12px 7px 10px;
	background: rgba(0,0,0,0.55);
	backdrop-filter: blur(12px);
	border: 1px solid var(--jml-line-strong);
	border-radius: 999px;
	font-family: var(--jml-font-mono);
	font-size: 11px;
	letter-spacing: 0.1em;
	color: var(--jml-ink);
	text-transform: uppercase;
	z-index: 5;
}
.jml-provider-badge i { font-size: 13px; color: var(--accent); }
.jml-provider-badge[data-provider="youtube"] i { color: #ff4040; }

/* ============== LANGUAGE PILL ============== */
.jml-pill-wrap {
	position: absolute;
	top: 18px;
	right: 18px;
	z-index: 10;
}
.jml-pill {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 9px 14px 9px 12px;
	background: rgba(0,0,0,0.55);
	backdrop-filter: blur(12px);
	border: 1px solid var(--line-accent);
	border-radius: 999px;
	font-size: 13px;
	font-weight: 500;
	color: var(--jml-ink);
	transition: all 0.18s ease;
}
.jml-pill:hover {
	background: color-mix(in srgb, var(--accent) 18%, transparent);
	border-color: var(--accent);
}
.jml-pill .fi {
	width: 20px;
	height: 14px;
	border-radius: 2px;
	background-size: cover;
	background-position: center;
	box-shadow: 0 0 0 1px rgba(255,255,255,0.1);
}
.jml-pill i { font-size: 14px; color: var(--jml-ink-muted); transition: transform 0.2s ease; }
.jml-pill[aria-expanded="true"] i { transform: rotate(180deg); }

/* ============== LANGUAGE MENU ============== */
.jml-menu {
	position: absolute;
	top: calc(100% + 8px);
	right: 0;
	width: 320px;
	max-height: 60vh;
	overflow-y: auto;
	background: rgba(17, 17, 20, 0.96);
	backdrop-filter: blur(20px);
	border: 1px solid var(--jml-line-strong);
	border-radius: var(--jml-radius);
	padding: 6px;
	box-shadow: 0 20px 50px rgba(0,0,0,0.6);
	opacity: 0;
	pointer-events: none;
	transform: translateY(-6px);
	transition: opacity 0.2s ease, transform 0.2s ease;
}
.jml-menu[aria-expanded="true"], .jml-menu:not([hidden]) {
	opacity: 1;
	pointer-events: auto;
	transform: translateY(0);
}
.jml-menu[hidden] { display: none; }
.jml-menu::-webkit-scrollbar { width: 6px; }
.jml-menu::-webkit-scrollbar-thumb { background: var(--jml-line-strong); border-radius: 3px; }
.jml-menu::-webkit-scrollbar-track { background: transparent; }

.jml-menu-header {
	padding: 10px 12px;
	font-family: var(--jml-font-mono);
	font-size: 10px;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--jml-ink-subtle);
	border-bottom: 1px solid var(--jml-line);
	margin-bottom: 4px;
}
.jml-menu-list { display: flex; flex-direction: column; }

.jml-option {
	display: flex;
	align-items: center;
	gap: 12px;
	width: 100%;
	padding: 10px 12px;
	border-radius: 6px;
	text-align: left;
	transition: background 0.15s ease;
}
.jml-option:hover { background: rgba(255,255,255,0.05); }
.jml-option[aria-selected="true"] { background: color-mix(in srgb, var(--accent) 12%, transparent); }
.jml-option .fi {
	width: 26px;
	height: 18px;
	border-radius: 3px;
	background-size: cover;
	flex-shrink: 0;
	box-shadow: 0 0 0 1px rgba(255,255,255,0.08);
}
.jml-option-name {
	flex: 1;
	font-size: 14px;
	font-weight: 500;
}
.jml-option .jml-check {
	color: var(--accent-bright);
	font-size: 16px;
	display: none;
}
.jml-option[aria-selected="true"] .jml-check { display: block; }

/* ============== CENTER PLAY BUTTON ============== */
.jml-play {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 88px;
	height: 88px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.08);
	backdrop-filter: blur(8px);
	border: 1px solid rgba(255,255,255,0.2);
	display: grid;
	place-items: center;
	z-index: 4;
	transition: all 0.25s ease;
}
.jml-play:hover {
	background: var(--accent);
	border-color: var(--accent);
	transform: translate(-50%, -50%) scale(1.06);
}
.jml-play i { font-size: 32px; color: var(--jml-ink); margin-left: 4px; transition: color 0.2s; }
.jml-play:hover i { color: var(--jml-bg); }
.jml-player.is-playing .jml-play { opacity: 0; pointer-events: none; }

/* ============== CONTROLS ============== */
.jml-controls {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	padding: 16px 20px 14px;
	background: linear-gradient(to top, rgba(0,0,0,0.75), transparent);
	z-index: 3;
}

.jml-scrub {
	height: 4px;
	background: rgba(255,255,255,0.15);
	border-radius: 2px;
	position: relative;
	cursor: pointer;
	margin-bottom: 12px;
	transition: height 0.15s ease;
}
.jml-scrub:hover { height: 6px; }
.jml-scrub-fill {
	position: absolute;
	left: 0;
	top: 0;
	bottom: 0;
	width: 0%;
	background: var(--accent);
	border-radius: 2px;
	transition: width 0.1s linear;
}
.jml-scrub-buffered {
	position: absolute;
	left: 0;
	top: 0;
	bottom: 0;
	width: 0%;
	background: rgba(255,255,255,0.25);
	border-radius: 2px;
}
.jml-scrub-thumb {
	position: absolute;
	top: 50%;
	left: 0%;
	width: 12px;
	height: 12px;
	background: var(--accent);
	border-radius: 50%;
	transform: translate(-50%, -50%);
	box-shadow: 0 0 12px var(--accent);
	transition: left 0.1s linear;
}

.jml-controls-row { display: flex; align-items: center; gap: 14px; }
.jml-ctrl-btn {
	width: 36px;
	height: 36px;
	display: grid;
	place-items: center;
	border-radius: 50%;
	color: var(--jml-ink);
	transition: background 0.15s ease;
}
.jml-ctrl-btn:hover { background: rgba(255,255,255,0.1); }
.jml-ctrl-btn i { font-size: 20px; }
.jml-time {
	font-family: var(--jml-font-mono);
	font-size: 12px;
	color: rgba(236,231,220,0.8);
	letter-spacing: 0.05em;
}
.jml-time-sep { color: rgba(236,231,220,0.4); margin: 0 6px; }
.jml-ctrl-spacer { flex: 1; }

/* ============== AUTO-DETECT NOTICE BAR ============== */
.jml-notice {
	margin-top: 16px;
	padding: 14px 20px;
	display: flex;
	align-items: center;
	gap: 16px;
	background: var(--jml-bg-elev-1);
	border: 1px solid var(--jml-line);
	border-left: 3px solid var(--accent);
	border-radius: 6px;
	font-size: 13px;
}
.jml-notice[hidden] { display: none; }
.jml-notice-icon {
	width: 28px;
	height: 28px;
	border-radius: 50%;
	background: color-mix(in srgb, var(--accent) 15%, transparent);
	display: grid;
	place-items: center;
	color: var(--accent);
	flex-shrink: 0;
}
.jml-notice-icon i { font-size: 14px; }
.jml-notice-text { flex: 1; color: var(--jml-ink-muted); }
.jml-notice-text strong { color: var(--jml-ink); font-weight: 500; margin-right: 6px; }
.jml-notice-text code {
	font-family: var(--jml-font-mono);
	font-size: 11px;
	background: var(--jml-bg-elev-3);
	padding: 2px 6px;
	border-radius: 3px;
	color: var(--accent);
}
.jml-notice-actions { display: flex; gap: 8px; }
.jml-notice-btn {
	padding: 6px 12px;
	font-size: 12px;
	border: 1px solid var(--jml-line-strong);
	border-radius: 4px;
	color: var(--jml-ink);
	transition: all 0.15s ease;
	display: inline-flex;
	align-items: center;
	gap: 6px;
}
.jml-notice-btn:hover { border-color: var(--accent); color: var(--accent); }
.jml-notice-btn[hidden] { display: none; }

/* ============== CONTINUE TOAST (language switch) ============== */
.jml-toast {
	position: fixed;
	bottom: 32px;
	left: 50%;
	transform: translateX(-50%) translateY(20px);
	background: var(--jml-bg-elev-3);
	border: 1px solid var(--line-accent);
	border-radius: var(--jml-radius);
	padding: 14px 20px;
	display: flex;
	align-items: center;
	gap: 14px;
	box-shadow: 0 16px 40px rgba(0,0,0,0.6);
	font-size: 13px;
	opacity: 0;
	pointer-events: none;
	transition: all 0.3s cubic-bezier(0.2, 0.9, 0.3, 1);
	z-index: 9999;
	color: var(--jml-ink-muted);
	font-family: var(--jml-font);
}
.jml-toast.is-visible {
	opacity: 1;
	transform: translateX(-50%) translateY(0);
	pointer-events: auto;
}
.jml-toast-icon {
	width: 28px;
	height: 28px;
	border-radius: 50%;
	background: color-mix(in srgb, var(--accent) 15%, transparent);
	display: grid;
	place-items: center;
	color: var(--accent);
}
.jml-toast strong { color: var(--jml-ink); font-weight: 500; }
.jml-toast-time { font-family: var(--jml-font-mono); color: var(--accent); font-size: 12px; }

/* ============== RESPONSIVE ============== */
@media (max-width: 600px) {
	.jml-pill-wrap, .jml-provider-badge { top: 12px; }
	.jml-pill-wrap { right: 12px; }
	.jml-provider-badge { left: 12px; padding: 5px 10px 5px 8px; font-size: 10px; }
	.jml-menu { width: calc(100vw - 32px); max-width: 320px; }
	.jml-play { width: 64px; height: 64px; }
	.jml-play i { font-size: 24px; }
}

/* ============== ERROR OVERLAY ============== */
.jml-error-overlay {
	position: absolute;
	inset: 0;
	display: none;
	align-items: center;
	justify-content: center;
	background: rgba(10, 10, 12, 0.92);
	backdrop-filter: blur(12px);
	z-index: 50;
	padding: 20px;
}
.jml-error-card {
	max-width: 420px;
	text-align: center;
	color: var(--jml-ink);
}
.jml-error-icon {
	width: 60px;
	height: 60px;
	margin: 0 auto 18px;
	border-radius: 50%;
	background: color-mix(in srgb, var(--jml-crimson) 15%, transparent);
	border: 1px solid color-mix(in srgb, var(--jml-crimson) 40%, transparent);
	display: grid;
	place-items: center;
	color: var(--jml-crimson);
}
.jml-error-icon i { font-size: 28px; }
.jml-error-title {
	font-size: 16px;
	font-weight: 500;
	margin-bottom: 8px;
	color: var(--jml-ink);
}
.jml-error-detail {
	font-family: var(--jml-font-mono);
	font-size: 11px;
	color: var(--jml-ink-subtle);
	margin-bottom: 20px;
	letter-spacing: 0.04em;
	max-width: 100%;
	overflow-wrap: break-word;
	word-break: break-all;
}
.jml-error-retry {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 8px 16px;
	background: var(--accent);
	color: var(--jml-bg);
	border-radius: 999px;
	border: none;
	font-size: 13px;
	font-weight: 500;
	transition: all 0.15s ease;
}
.jml-error-retry:hover {
	background: var(--accent-bright);
	transform: scale(1.02);
}
.jml-error-retry i { font-size: 15px; }
