/* Some basic CSS to make the Audio controls in abcjs presentable. */

.abcjs-inline-audio {
	height: 26px;
	padding: 0 5px;
	border-radius: 8px;
	background-color: rgba(255,255,255,.06);
	border: 1px solid rgba(255,255,255,.10);
	display: flex;
	align-items: center;
	box-sizing: border-box;
	/* justify-content: space-between; */
}

.abcjs-inline-audio.abcjs-disabled {
	opacity: 0.5;
}

.abcjs-inline-audio .abcjs-btn {
	display: block;
	width: 28px;
	height: 34px;
	margin-right: 2px;
	padding: 7px 4px;

	background: none !important;
	border: 1px solid transparent;
	box-sizing: border-box;
	line-height: 1;
}

.abcjs-btn g {
	fill: rgba(255,255,255,.85);
	stroke: rgba(255,255,255,.85);
}

.abcjs-inline-audio .abcjs-btn:hover g {
	fill: rgba(255,255,255,.95);
	stroke: rgba(255,255,255,.95);
}

.abcjs-inline-audio .abcjs-midi-selection.abcjs-pushed {
	border: 1px solid rgba(255,255,255,.20);
	background-color: rgba(255,255,255,.12);
	box-sizing: border-box;
	border-radius: 4px;
}

.abcjs-inline-audio .abcjs-midi-loop.abcjs-pushed {
	border: 1px solid rgba(255,255,255,.20);
	background-color: rgba(255,255,255,.12);
	box-sizing: border-box;
	border-radius: 4px;
}

.abcjs-inline-audio .abcjs-midi-reset.abcjs-pushed {
	border: 1px solid rgba(255,255,255,.20);
	background-color: rgba(255,255,255,.12);
	box-sizing: border-box;
	border-radius: 4px;
}

.abcjs-inline-audio .abcjs-midi-start .abcjs-pause-svg {
	display: none;
}

.abcjs-inline-audio .abcjs-midi-start .abcjs-loading-svg {
	display: none;
}

.abcjs-inline-audio .abcjs-midi-start.abcjs-pushed .abcjs-play-svg {
	display: none;
}

.abcjs-inline-audio .abcjs-midi-start.abcjs-loading .abcjs-play-svg {
	display: none;
}

.abcjs-inline-audio .abcjs-midi-start.abcjs-pushed .abcjs-pause-svg {
	display: block;
}

.abcjs-inline-audio .abcjs-midi-progress-background {
	background-color: rgba(255,255,255,.08);
	height: 10px;
	border-radius: 5px;
	border: 2px solid rgba(255,255,255,.15);
	margin: 0 8px 0 15px;
	position: relative;
	flex: 1;
	padding: 0;
	box-sizing: border-box;
}

.abcjs-inline-audio .abcjs-midi-progress-indicator {
	width: 20px;
	margin-left: -10px; /* half of the width */
	height: 14px;
	background-color: rgba(255,255,255,.85);
	position: absolute;
	display: inline-block;
	border-radius: 6px;
	top: -4px;
	left: 0;
	box-sizing: border-box;
	box-shadow: 0 2px 4px rgba(0,0,0,.2);
}

.abcjs-inline-audio .abcjs-midi-clock {
	margin-left: 4px;
	margin-top: 1px;
	margin-right: 2px;
	display: inline-block;
	font-family: sans-serif;
	font-size: 16px;
	box-sizing: border-box;
	color: rgba(255,255,255,.85);
}

.abcjs-inline-audio .abcjs-tempo-wrapper {
	font-size: 10px;
	color: rgba(255,255,255,.85);
	box-sizing: border-box;
	display: flex;
	align-items: center;
}

.abcjs-inline-audio .abcjs-midi-tempo {
	border-radius: 4px;
	border: 1px solid rgba(255,255,255,.15);
	margin: 0 2px 0 4px;
	width: 42px;
	padding-left: 4px;
	padding-right: 4px;
	box-sizing: border-box;
	background-color: rgba(255,255,255,.04);
	color: rgba(255,255,255,.85);
	font-size: 10px;
}

.abcjs-inline-audio .abcjs-loading .abcjs-loading-svg {
	display: inherit;
}

.abcjs-inline-audio .abcjs-loading {
	outline: none;
	animation-name: abcjs-spin;
	animation-duration: 1s;
	animation-iteration-count: infinite;
	animation-timing-function: linear;

}
.abcjs-inline-audio .abcjs-loading-svg circle {
	stroke: rgba(255,255,255,.85);
}

@keyframes abcjs-spin {
	from {transform:rotate(0deg);}
	to {transform:rotate(360deg);}
}

/* Adding the class "abcjs-large" will make the control easier on a touch device. */
.abcjs-large .abcjs-inline-audio {
	height: 5rem;
}
.abcjs-large .abcjs-btn {
	width: 56px;
	height: 52px;
	font-size: 28px;
	padding: 6px 8px;
}
.abcjs-large .abcjs-midi-progress-background {
	height: 20px;
	border: 4px solid rgba(255,255,255,.15);
}
.abcjs-large .abcjs-midi-progress-indicator {
	height: 28px;
	top: -8px;
	width: 40px;
}
.abcjs-large .abcjs-midi-clock {
	font-size: 32px;
	margin-right: 10px;
	margin-left: 10px;
	margin-top: -1px;
}
.abcjs-large .abcjs-midi-tempo {
	font-size: 1rem;
	width: 5rem;
}
.abcjs-large .abcjs-tempo-wrapper {
	font-size: 1rem;
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.abcjs-css-warning {
	display: none;
}

/* 浅色主题样式 */
html.light .abcjs-inline-audio {
	background-color: rgba(255,255,255,.95);
	border: 1px solid rgba(0,0,0,.12);
}

html.light .abcjs-btn g {
	fill: rgba(0,0,0,.70);
	stroke: rgba(0,0,0,.70);
}

html.light .abcjs-inline-audio .abcjs-btn:hover g {
	fill: rgba(0,0,0,.85);
	stroke: rgba(0,0,0,.85);
}

html.light .abcjs-inline-audio .abcjs-midi-selection.abcjs-pushed,
html.light .abcjs-inline-audio .abcjs-midi-loop.abcjs-pushed,
html.light .abcjs-inline-audio .abcjs-midi-reset.abcjs-pushed {
	border: 1px solid rgba(0,0,0,.20);
	background-color: rgba(0,0,0,.08);
}

html.light .abcjs-inline-audio .abcjs-midi-progress-background {
	background-color: rgba(0,0,0,.08);
	border: 2px solid rgba(0,0,0,.15);
}

html.light .abcjs-large .abcjs-midi-progress-background {
	border: 4px solid rgba(0,0,0,.15);
}

html.light .abcjs-inline-audio .abcjs-midi-progress-indicator {
	background-color: rgba(0,0,0,.70);
	box-shadow: 0 2px 4px rgba(0,0,0,.15);
}

html.light .abcjs-inline-audio .abcjs-midi-clock,
html.light .abcjs-inline-audio .abcjs-tempo-wrapper {
	color: rgba(0,0,0,.70);
}

html.light .abcjs-inline-audio .abcjs-midi-tempo {
	border: 1px solid rgba(0,0,0,.15);
	background-color: rgba(0,0,0,.04);
	color: rgba(0,0,0,.70);
}

html.light .abcjs-inline-audio .abcjs-loading-svg circle {
	stroke: rgba(0,0,0,.70);
}