/* MPV Bookmarks CSS — extracted from mpv-viewer.css */

/* Bookmarks (outline) overlay */
.mpv-bookmarks {
	position: absolute;
	top: 12px;
	bottom: 90px;
	right: 18px;
	z-index: 9;
	--mpv-bm-row-h: 24px;
	--mpv-bm-tree-base: 4px;
	--mpv-bm-tree-step: 12px;
	--mpv-bm-toggle-w: 12px;
	--mpv-bm-item-gap: 6px;
	--mpv-bm-tree-line: rgba(176,176,176,.9);
	--mpv-bm-panel-h: calc(var(--mpv-bm-row-h) * 10);
	--mpv-bm-fade-h: var(--mpv-bm-row-h);
	--mpv-bm-sb-w: 8px;
	--mpv-bm-viewer-max-width: calc(100% - 72px);
	--mpv-bm-narrow-panel-max-height: 320px;
	--mpv-bm-visible-panel-w: min(var(--mpv-bm-panel-w, 320px), var(--mpv-bm-viewer-max-width, calc(100% - 72px)));
	--mpv-bm-visible-panel-h: var(--mpv-bm-panel-h, calc(var(--mpv-bm-row-h) * 10));
	width: var(--mpv-bm-panel-w, 320px);
	max-width: var(--mpv-bm-viewer-max-width, calc(100% - 72px));
	pointer-events: none; /* Container doesn't capture pointer; only rail and list do */
	transition: opacity .12s ease;
	--mpv-bm-mask-opacity: 0;
	--mpv-bm-mask-top: 1;
	--mpv-bm-mask-bottom: 1;
}

.mpv-viewer.mpv-compact .mpv-bookmarks {
	top: 10px;
	right: 10px;
	bottom: 78px;
	--mpv-bm-row-h: 22px;
}

.mpv-viewer.mpv-compact .mpv-bookmarks-list {
	max-height: calc(100% - 4px);
}

.mpv-viewer.mpv-narrow .mpv-bookmarks {
	top: 8px;
	right: 8px;
	left: auto;
	bottom: 112px;
	width: var(--mpv-bm-panel-w, 320px);
	max-width: calc(100% - 16px);
	--mpv-bm-viewer-max-width: calc(100% - 16px);
	--mpv-bm-visible-panel-w: min(var(--mpv-bm-panel-w, 320px), calc(100% - 16px));
	--mpv-bm-visible-panel-h: min(var(--mpv-bm-panel-h, calc(var(--mpv-bm-row-h) * 10)), var(--mpv-bm-narrow-panel-max-height, 320px), calc(100% - 4px));
	--mpv-bm-row-h: 22px;
}

.mpv-viewer.mpv-narrow .mpv-bookmarks::before,
.mpv-viewer.mpv-narrow .mpv-bookmarks::after,
.mpv-viewer.mpv-narrow .mpv-bookmarks-list,
.mpv-viewer.mpv-narrow .mpv-bookmarks-resizer-top,
.mpv-viewer.mpv-narrow .mpv-bookmarks-resizer-bottom {
	max-width: calc(100% - 16px);
}

.mpv-viewer.mpv-narrow .mpv-bookmarks-list {
	height: var(--mpv-bm-visible-panel-h);
	max-height: calc(100% - 4px);
	padding-left: 30px;
	padding-right: 2px;
	border-radius: 10px;
}

.mpv-bookmarks::before,
.mpv-bookmarks::after {
	content: '';
	position: absolute;
	right: 0;
	width: var(--mpv-bm-visible-panel-w);
	max-width: var(--mpv-bm-viewer-max-width, calc(100% - 72px));
	height: var(--mpv-bm-fade-h);
	pointer-events: none;
	z-index: 6;
	transition: opacity .08s ease-out;
}

.mpv-bookmarks::before {
	top: calc(50% - (var(--mpv-bm-visible-panel-h) / 2));
	border-radius: 12px 12px 0 0;
	background: linear-gradient(to bottom, rgba(255,255,255,.92), rgba(255,255,255,0));
	opacity: calc(var(--mpv-bm-mask-opacity, 0) * var(--mpv-bm-mask-top, 1));
}

.mpv-bookmarks::after {
	bottom: calc(50% - (var(--mpv-bm-visible-panel-h) / 2));
	border-radius: 0 0 12px 12px;
	background: linear-gradient(to top, rgba(255,255,255,.92), rgba(255,255,255,0));
	opacity: calc(var(--mpv-bm-mask-opacity, 0) * var(--mpv-bm-mask-bottom, 1));
}

.mpv-bookmarks-hidden{
	display:none;
}

/* Note: we intentionally avoid an oversized hover pseudo-element here.
   The container clips the panel in collapsed state; hover is initiated from the rail itself. */

.mpv-bookmarks-list {
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	width: var(--mpv-bm-visible-panel-w);
	max-width: var(--mpv-bm-viewer-max-width, calc(100% - 72px));
	height: var(--mpv-bm-visible-panel-h);
	max-height: calc(100% - 8px);
	overflow-y: scroll;
	overflow-x: hidden;
	padding: 4px 4px 4px 34px; /* leave space for the dot rail */
	box-sizing: border-box;
	border-radius: 12px;
	background-color: transparent;
	box-shadow: none;
	border: 1px solid transparent;
	transition: background-color .10s ease-out, border-color .10s ease-out, box-shadow .12s ease-out;
	scrollbar-gutter: stable;
	/* Hide native scrollbar; we render a custom eased scrollbar instead. */
	scrollbar-width: none;
	scrollbar-color: transparent transparent;
	/* Disable pointer events when collapsed to prevent scroll events in hidden area */
	pointer-events: none;
}

.mpv-bookmarks.mpv-motion-bookmarks .mpv-bookmarks-list {
	transition: none;
	will-change: transform, background-color, border-color, box-shadow;
}

.mpv-viewer.mpv-bookmarks-resizing .mpv-bookmarks-list {
	transition: none;
	background-color: rgba(255,255,255,.92);
	border-color: rgba(0,0,0,.08);
	box-shadow: 0 12px 28px rgba(0,0,0,.18);
}

.mpv-bookmarks.mpv-bookmarks-force-solid .mpv-bookmarks-list {
	transition: none;
	background-color: rgba(255,255,255,.92) !important;
	border-color: rgba(0,0,0,.08) !important;
	box-shadow: 0 12px 28px rgba(0,0,0,.18) !important;
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	pointer-events: auto;
}

.mpv-viewer.mpv-bookmarks-resizing .mpv-bookmarks::before,
.mpv-viewer.mpv-bookmarks-resizing .mpv-bookmarks::after {
	transition: none;
}

.mpv-bookmarks-resizer {
	position: absolute;
	left: calc(100% - var(--mpv-bm-visible-panel-w) - 9px);
	right: auto;
	top: 50%;
	transform: translateY(-50%);
	width: 18px;
	height: var(--mpv-bm-visible-panel-h);
	max-height: 100%;
	cursor: ew-resize;
	opacity: 0;
	pointer-events: none;
	z-index: 4;
	transition: opacity .12s ease-out;
}

.mpv-bookmarks-resizer::before {
	content: '';
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	bottom: 0;
	background: transparent;
}

.mpv-bookmarks-resizer-left {
	cursor: ew-resize;
}

.mpv-bookmarks-resizer-top,
.mpv-bookmarks-resizer-bottom {
	right: 0;
	left: auto;
	width: var(--mpv-bm-visible-panel-w);
	height: 16px;
	transform: none;
	cursor: ns-resize;
}

.mpv-bookmarks-resizer-top {
	top: calc(50% - (var(--mpv-bm-visible-panel-h) / 2) - 8px);
	right: 0;
}

.mpv-bookmarks-resizer-bottom {
	top: calc(50% + (var(--mpv-bm-visible-panel-h) / 2) - 8px);
	right: 0;
}

.mpv-viewer.mpv-bookmarks-resizing .mpv-bookmarks-resizer,
.mpv-bookmarks.mpv-bookmarks-visual-open .mpv-bookmarks-resizer,
.mpv-bookmarks:not(.mpv-motion-bookmarks) .mpv-bookmarks-rail:hover ~ .mpv-bookmarks-resizer,
.mpv-bookmarks:not(.mpv-motion-bookmarks):focus-within .mpv-bookmarks-resizer,
.mpv-bookmarks:not(.mpv-motion-bookmarks):has(.mpv-bookmarks-list:hover) .mpv-bookmarks-resizer,
.mpv-bookmarks:not(.mpv-motion-bookmarks).mpv-bookmarks-auto-open .mpv-bookmarks-resizer {
	opacity: 1;
	pointer-events: auto;
}

.mpv-bookmarks.mpv-motion-bookmarks::before,
.mpv-bookmarks.mpv-motion-bookmarks::after {
	transition: none;
}

.mpv-bookmarks-list::-webkit-scrollbar{
	width:0;
	height:0;
}

/* Custom scrollbar (ease-out) */
.mpv-bm-scrollbar{
	position:absolute;
	top:6px;
	bottom:6px;
	right:4px;
	width:6px;
	border-radius:999px;
	background:transparent;
	pointer-events:none;
	opacity:0;
	transition: opacity .12s ease-out;
	will-change: transform;
	cursor:pointer;
}

.mpv-bookmarks.mpv-bookmarks-visual-open .mpv-bm-scrollbar{
	pointer-events:auto;
}

.mpv-bookmarks.mpv-motion-bookmarks .mpv-bm-scrollbar{
	transition: none;
}

.mpv-bm-thumb{
	position:absolute;
	left:0;
	right:0;
	top:0;
	height:24px;
	border-radius:999px;
	background: rgba(0,0,0,.22);
	will-change: transform, height;
	backface-visibility: hidden;
	cursor:pointer;
}

/* Dot rail: invisible hover sensing area at the right edge where dots appear */
.mpv-bookmarks-rail {
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 24px;
	height: var(--mpv-bm-panel-h);
	max-height: 100%;
	pointer-events: auto; /* Captures hover */
	z-index: 3;
}

/* (Native scrollbar styling removed; see custom scrollbar above.) */

.mpv-bookmark-item {
	border: 0;
	background: transparent;
	padding: 0 4px 0 0;
	margin: 0;
	box-sizing: border-box;
	width: 100%;
	height: var(--mpv-bm-row-h);
	display: flex;
	align-items: center;
	justify-content: flex-start;
	position: relative;
	gap: var(--mpv-bm-item-gap);
	color: #666;
	direction: ltr;
	padding-left: calc(var(--mpv-bm-tree-base) + (var(--mpv-bm-depth, 0) * var(--mpv-bm-tree-step)));
}

/* Locked outline items (outside preview range) */
.mpv-bookmark-item.is-locked .mpv-bookmark-text{
	color: rgba(0,0,0,.28);
}

.mpv-bookmark-item.is-locked .mpv-bookmark-dash{
	background: rgba(0,0,0,.18);
	--mpv-dot-base-opacity: .55;
}

.mpv-bookmark-item.is-locked::before{
	content:'';
	position:absolute;
	left:-10px;
	top:50%;
	width:12px;
	height:12px;
	transform: translateY(-50%);
	background: url('../icons/general/lock.svg') center / contain no-repeat;
	opacity: 0;
	transition: opacity .08s ease-out;
	z-index: 1;
	pointer-events: none;
}

/* Only show lock icon when the popover visuals are open (same time text is visible). */
.mpv-bookmarks.mpv-bookmarks-visual-open .mpv-bookmark-item.is-locked::before,
.mpv-bookmarks:not(.mpv-motion-bookmarks).mpv-bookmarks-auto-open .mpv-bookmark-item.is-locked::before,
.mpv-bookmarks:not(.mpv-motion-bookmarks) .mpv-bookmarks-rail:hover ~ .mpv-bookmarks-list .mpv-bookmark-item.is-locked::before,
.mpv-bookmarks:not(.mpv-motion-bookmarks):focus-within .mpv-bookmark-item.is-locked::before,
.mpv-bookmarks:not(.mpv-motion-bookmarks) .mpv-bookmarks-list:hover .mpv-bookmark-item.is-locked::before,
.mpv-bookmarks:not(.mpv-motion-bookmarks) .mpv-bookmarks-list:focus-within .mpv-bookmark-item.is-locked::before{
	opacity: .55;
}

@keyframes mpv-lock-shake{
	0%{ transform: translateY(-50%) translateX(0); }
	20%{ transform: translateY(-50%) translateX(-1px); }
	40%{ transform: translateY(-50%) translateX(2px); }
	60%{ transform: translateY(-50%) translateX(-2px); }
	80%{ transform: translateY(-50%) translateX(1px); }
	100%{ transform: translateY(-50%) translateX(0); }
}

.mpv-bookmark-item.is-locked.mpv-lock-shake::before{
	animation: mpv-lock-shake .35s ease-in-out;
}

@media (prefers-reduced-motion: reduce){
	.mpv-bookmark-item.is-locked.mpv-lock-shake::before{
		animation: none;
	}
}

.mpv-bookmark-tree{
	position:absolute;
	left:0;
	top:0;
	width:100%;
	height:100%;
	pointer-events:none;
	z-index:0;
	contain: layout paint;
}

.mpv-bookmark-tree-seg{
	position:absolute;
	pointer-events:none;
	backface-visibility:hidden;
	opacity:0;
	transition: opacity .12s ease-out;
}

.mpv-bookmark-tree-trunk,
.mpv-bookmark-tree-current-trunk{
	left: calc(var(--mpv-bm-tree-base) + (var(--mpv-bm-tree-col, 0) * var(--mpv-bm-tree-step)) + (var(--mpv-bm-toggle-w) / 2));
	width:1px;
	background-image: repeating-linear-gradient(to bottom, var(--mpv-bm-tree-line) 0 1px, transparent 1px 3px);
}

.mpv-bookmark-tree-trunk{
	top:0;
	bottom:0;
}

.mpv-bookmark-tree-current-trunk{
	top:0;
}

.mpv-bookmark-tree-current-trunk.is-last{
	height:50%;
}

.mpv-bookmark-tree-current-trunk.is-nonlast{
	bottom:0;
}

.mpv-bookmark-item.is-root-level.is-first-sibling.is-nonlast-sibling .mpv-bookmark-tree-current-trunk{
	top:50%;
	bottom:0;
	height:auto;
}

.mpv-bookmark-tree-branch{
	left: calc(var(--mpv-bm-tree-base) + (var(--mpv-bm-tree-col, 0) * var(--mpv-bm-tree-step)) + (var(--mpv-bm-toggle-w) / 2));
	top:50%;
	width: calc((var(--mpv-bm-toggle-w) / 2) + var(--mpv-bm-item-gap));
	height:1px;
	background-image: repeating-linear-gradient(to right, var(--mpv-bm-tree-line) 0 1px, transparent 1px 3px);
}

.mpv-bookmarks.mpv-bookmarks-visual-open .mpv-bookmark-tree-seg,
.mpv-bookmarks:not(.mpv-motion-bookmarks).mpv-bookmarks-auto-open .mpv-bookmark-tree-seg{
	opacity:1;
}

.mpv-bookmark-item.is-hidden-by-collapse{
	display:none;
}

.mpv-bookmark-link{
	appearance:none;
	border:0;
	background:transparent;
	cursor:pointer;
	padding:0;
	margin:0;
	min-width:0;
	flex:1 1 auto;
	display:flex;
	align-items:center;
	gap:8px;
	text-align:left;
	position:relative;
	z-index:1;
}

.mpv-bookmark-link:disabled{
	cursor:default;
}

.mpv-bookmark-toggle{
	appearance:none;
	border:0;
	background:transparent;
	width:var(--mpv-bm-toggle-w);
	height:var(--mpv-bm-toggle-w);
	padding:0;
	margin:0;
	flex:0 0 var(--mpv-bm-toggle-w);
	cursor:pointer;
	position:relative;
	top:0;
	opacity:0;
	transition: opacity .12s ease-out;
	z-index:1;
}

.mpv-bookmark-toggle::before,
.mpv-bookmark-toggle::after{
	content:'';
	position:absolute;
	left:50%;
	top:50%;
	background:rgba(0,0,0,.6);
	border-radius:1px;
	transform:translate(-50%, -50%);
}

.mpv-bookmark-toggle::before{
	width:8px;
	height:1.5px;
}

.mpv-bookmark-toggle::after{
	width:1.5px;
	height:8px;
}

.mpv-bookmark-item.has-children.is-expanded > .mpv-bookmark-toggle::after{
	display:none;
}

.mpv-bookmark-item:not(.has-children) > .mpv-bookmark-toggle{
	opacity:0;
	visibility:hidden;
	pointer-events:none;
}

.mpv-bookmark-item:not(.has-children) > .mpv-bookmark-toggle::before,
.mpv-bookmark-item:not(.has-children) > .mpv-bookmark-toggle::after{
	display:none;
}


.mpv-bookmark-dash {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: rgba(0,0,0,.35);
	--mpv-dot-base-opacity: .7;
	--mpv-dot-edge-opacity: 1;
	opacity: calc(var(--mpv-dot-base-opacity) * var(--mpv-dot-edge-opacity));
	transition: background .18s, opacity .18s, box-shadow .18s, transform .18s;
	flex: 0 0 auto;
	display: inline-block;
	margin-right: 6px;
	pointer-events: auto;
}

.mpv-bookmark-item.is-subsection .mpv-bookmark-dash {
	width: 6px;
	height: 6px;
	margin-right: 7px;
}


/* Hover/focus: make non-active dots darker (active dot keeps blue). */
.mpv-bookmark-item:not(.is-active) .mpv-bookmark-link:hover .mpv-bookmark-dash,
.mpv-bookmark-item:not(.is-active) .mpv-bookmark-link:focus .mpv-bookmark-dash{
	--mpv-dot-base-opacity: 1;
	background:rgba(0,0,0,.9);
}

.mpv-bookmark-link:focus,
.mpv-bookmark-toggle:focus{
	outline:none;
}


.mpv-bookmark-item.is-active .mpv-bookmark-dash{
	background:rgba(0,120,255,.98);
	--mpv-dot-base-opacity: 1;
	box-shadow:0 0 10px 3px rgba(0,120,255,.35), 0 0 0 2px rgba(0,120,255,.28);
	transform:none;
	z-index:1;
}

.mpv-bookmark-text{
	flex:1 1 auto;
	min-width:0;
	text-align:left;
	font-size:12px;
	line-height:1.2;
	white-space:nowrap;
	overflow:hidden;
	text-overflow:ellipsis;
	opacity:0;
	transition: opacity .08s ease-out;
	color: rgba(0,0,0,.55);
}

.mpv-bookmarks.mpv-bookmarks-visual-open .mpv-bookmark-text,
.mpv-bookmarks.mpv-bookmarks-visual-open .mpv-bookmark-toggle{
	opacity:1;
}

.mpv-bookmarks.mpv-motion-bookmarks .mpv-bookmark-text{
	transition: none;
}

.mpv-bookmarks.mpv-motion-bookmarks .mpv-bookmark-tree-seg{
	transition: none;
}

/* Expanded state: reveal panel visuals when hovering the rail or the list itself. */
.mpv-bookmarks:not(.mpv-motion-bookmarks) .mpv-bookmarks-rail:hover ~ .mpv-bookmarks-list,
.mpv-bookmarks:not(.mpv-motion-bookmarks):focus-within .mpv-bookmarks-list,
.mpv-bookmarks:not(.mpv-motion-bookmarks) .mpv-bookmarks-list:hover,
.mpv-bookmarks:not(.mpv-motion-bookmarks) .mpv-bookmarks-list:focus-within {
	background-color: rgba(255,255,255,.92);
	border-color: rgba(0,0,0,.08);
	box-shadow: 0 12px 28px rgba(0,0,0,.18);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	scrollbar-color: rgba(0,0,0,.28) transparent;
	pointer-events: auto;
}


.mpv-bookmarks.mpv-bookmarks-at-top {
	--mpv-bm-mask-top: 0;
}

.mpv-bookmarks.mpv-bookmarks-at-bottom {
	--mpv-bm-mask-bottom: 0;
}

.mpv-bookmarks:not(.mpv-motion-bookmarks):has(.mpv-bookmarks-rail:hover),
.mpv-bookmarks:not(.mpv-motion-bookmarks):focus-within,
.mpv-bookmarks:not(.mpv-motion-bookmarks):has(.mpv-bookmarks-list:hover),
.mpv-bookmarks:not(.mpv-motion-bookmarks):has(.mpv-bookmarks-list:focus-within),
.mpv-bookmarks:not(.mpv-motion-bookmarks).mpv-bookmarks-auto-open {
	--mpv-bm-mask-opacity: 1;
}

.mpv-bookmarks.mpv-motion-bookmarks {
	--mpv-bm-mask-opacity: 0;
}

.mpv-bookmarks.mpv-bookmarks-hidden {
	--mpv-bm-mask-opacity: 0;
}

.mpv-bookmarks.mpv-bookmarks-hidden::before,
.mpv-bookmarks.mpv-bookmarks-hidden::after {
	opacity: 0;
}

.mpv-bookmarks:not(.mpv-motion-bookmarks) .mpv-bookmarks-rail:hover ~ .mpv-bookmarks-list .mpv-bm-scrollbar,
.mpv-bookmarks:not(.mpv-motion-bookmarks):focus-within .mpv-bm-scrollbar,
.mpv-bookmarks:not(.mpv-motion-bookmarks) .mpv-bookmarks-list:hover .mpv-bm-scrollbar,
.mpv-bookmarks:not(.mpv-motion-bookmarks) .mpv-bookmarks-list:focus-within .mpv-bm-scrollbar,
.mpv-bookmarks:not(.mpv-motion-bookmarks).mpv-bookmarks-auto-open .mpv-bm-scrollbar{
	opacity:1;
}

/* While user is scrolling the main viewer, auto-open the bookmarks visuals. */
.mpv-bookmarks:not(.mpv-motion-bookmarks).mpv-bookmarks-auto-open .mpv-bookmarks-list {
	background-color: rgba(255,255,255,.92);
	border-color: rgba(0,0,0,.08);
	box-shadow: 0 12px 28px rgba(0,0,0,.18);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	scrollbar-color: rgba(0,0,0,.28) transparent;
	/* Enable pointer events during auto-open so user can click bookmarks */
	pointer-events: auto;
}

.mpv-bookmarks:not(.mpv-motion-bookmarks).mpv-bookmarks-auto-open .mpv-bookmark-text {
	opacity: 1;
}

/* Allow the panel to extend outside the narrow rail when expanded. */
.mpv-bookmarks:has(.mpv-bookmarks-rail:hover),
.mpv-bookmarks:has(.mpv-bookmarks-list:hover),
.mpv-bookmarks:focus-within{
	overflow:visible;
}

/* (Native scrollbar thumb hover removed; custom thumb handles visibility.) */

.mpv-bookmarks:not(.mpv-motion-bookmarks) .mpv-bookmarks-rail:hover ~ .mpv-bookmarks-list .mpv-bookmark-text,
.mpv-bookmarks:not(.mpv-motion-bookmarks):focus-within .mpv-bookmark-text,
.mpv-bookmarks:not(.mpv-motion-bookmarks) .mpv-bookmarks-list:hover .mpv-bookmark-text,
.mpv-bookmarks:not(.mpv-motion-bookmarks) .mpv-bookmarks-list:focus-within .mpv-bookmark-text{
	opacity:1;
}

.mpv-bookmarks:not(.mpv-motion-bookmarks) .mpv-bookmarks-rail:hover ~ .mpv-bookmarks-list .mpv-bookmark-tree-seg,
.mpv-bookmarks:not(.mpv-motion-bookmarks):focus-within .mpv-bookmark-tree-seg,
.mpv-bookmarks:not(.mpv-motion-bookmarks) .mpv-bookmarks-list:hover .mpv-bookmark-tree-seg,
.mpv-bookmarks:not(.mpv-motion-bookmarks) .mpv-bookmarks-list:focus-within .mpv-bookmark-tree-seg{
	opacity:1;
}

.mpv-bookmarks:not(.mpv-motion-bookmarks) .mpv-bookmarks-rail:hover ~ .mpv-bookmarks-list .mpv-bookmark-toggle,
.mpv-bookmarks:not(.mpv-motion-bookmarks):focus-within .mpv-bookmark-toggle,
.mpv-bookmarks:not(.mpv-motion-bookmarks) .mpv-bookmarks-list:hover .mpv-bookmark-toggle,
.mpv-bookmarks:not(.mpv-motion-bookmarks) .mpv-bookmarks-list:focus-within .mpv-bookmark-toggle,
.mpv-bookmarks:not(.mpv-motion-bookmarks).mpv-bookmarks-auto-open .mpv-bookmark-toggle{
	opacity:1;
}

.mpv-bookmarks .mpv-bookmark-item:not(.has-children) > .mpv-bookmark-toggle{
	opacity:0;
	visibility:hidden;
	pointer-events:none;
}

/* Hover/focus: text turns black. */
.mpv-bookmark-item:not(.is-active) .mpv-bookmark-link:hover .mpv-bookmark-text,
.mpv-bookmark-item:not(.is-active) .mpv-bookmark-link:focus .mpv-bookmark-text{
	color:#111;
}

.mpv-bookmarks-list:hover .mpv-bm-thumb{
	background: rgba(0,0,0,.28);
}

/* Remove row background highlight on hover/focus (keep clean list). */
.mpv-bookmark-link:hover,
.mpv-bookmark-link:focus,
.mpv-bookmark-toggle:hover,
.mpv-bookmark-toggle:focus{
	background:transparent;
}

.mpv-bookmark-item.is-active{
	/* Keep the row background neutral; emphasize via bold text and the active dot. */
	background:transparent;
}

.mpv-bookmark-item.is-expanded .mpv-bookmark-text{
	color: rgba(0,0,0,.55);
	text-shadow:none;
}

.mpv-bookmark-item.is-active .mpv-bookmark-text{
	font-weight:400;
	color: rgba(0,120,255,.98);
	text-shadow: 0 0 10px rgba(0,120,255,.25), 0 0 2px rgba(0,120,255,.35);
}
