/**
 * Midiwood Audio Player
 * Clean, minimal styles. Widget style tab overrides theme.
 */

/* Isolate from theme – widget styles override */
.midiwood-player-wrapper {
	--midiwood-bg: #1a1a1e;
	--midiwood-surface: #242428;
	--midiwood-text: #e8e8ed;
	--midiwood-text-muted: #8a8a94;
	--midiwood-accent: #7c6b9a;
	--midiwood-border: #35353a;
	--midiwood-radius: 8px;
	--midiwood-transition: 0.15s ease;
	box-sizing: border-box;
}

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

/* Tracks container */
.midiwood-tracks-container {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

/* Player row */
.midiwood-player {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	align-items: center;
	gap: 16px;
	background: var( --midiwood-bg );
	border-radius: var( --midiwood-radius );
	padding: 14px 20px;
	border: 1px solid var( --midiwood-border );
}

/* Header */
.midiwood-player-header {
	display: flex;
	align-items: center;
	gap: 14px;
	flex-shrink: 0;
}

/* Play button – no inheritance, single stroke, no focus flash */
.midiwood-btn-play {
	all: unset;
	box-sizing: border-box;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	min-width: 44px;
	min-height: 44px;
	border-radius: 50%;
	border: 2px solid var( --midiwood-accent );
	background: transparent !important;
	color: var( --midiwood-accent );
	cursor: pointer;
	font: inherit;
	outline: none !important;
	box-shadow: none !important;
	transition: color var( --midiwood-transition ), border-color var( --midiwood-transition ),
		background var( --midiwood-transition ), transform var( --midiwood-transition );
}

.midiwood-btn-play:hover:not(:disabled) {
	background: rgba( 124, 107, 154, 0.15 ) !important;
}

.midiwood-player-wrapper .midiwood-btn-play:focus,
.midiwood-player-wrapper .midiwood-btn-play:focus:not(:hover):not(:disabled) {
	background: transparent !important;
	box-shadow: none !important;
}

.midiwood-player-wrapper .midiwood-btn-play:focus-visible {
	outline: 2px solid var( --midiwood-accent ) !important;
	outline-offset: 2px;
}

.midiwood-btn-play:active:not(:disabled) {
	transform: scale( 0.97 );
}

.midiwood-btn-play:disabled {
	opacity: 0.5;
	cursor: not-allowed;
}

/* Icons – SVG, centered, no inheritance */
.midiwood-btn-play .midiwood-icon {
	width: 20px;
	height: 20px;
	display: block;
	flex-shrink: 0;
}

.midiwood-btn-play .midiwood-icon-pause {
	display: none;
}

.midiwood-btn-play.playing .midiwood-icon-play {
	display: none;
}

.midiwood-btn-play.playing .midiwood-icon-pause {
	display: block;
}

/* Track info – fixed width */
.midiwood-track-info {
	display: flex;
	flex-direction: column;
	gap: 1px;
	width: 140px;
	min-width: 140px;
	overflow: hidden;
}

.midiwood-track-title {
	font-size: 0.9375rem;
	font-weight: 600;
	color: var( --midiwood-text );
	line-height: 1.25;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.midiwood-track-composer {
	font-size: 0.75rem;
	color: var( --midiwood-text-muted );
	line-height: 1.25;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

/* Waveform */
.midiwood-waveform-container {
	position: relative;
	min-height: 48px;
	flex: 1;
	min-width: 100px;
	background: var( --midiwood-surface );
	border-radius: 6px;
	overflow: hidden;
	cursor: pointer;
}

.midiwood-spinner {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 28px;
	height: 28px;
	margin: -14px 0 0 -14px;
	border: 2px solid var( --midiwood-border );
	border-top-color: var( --midiwood-accent );
	border-radius: 50%;
	animation: midiwood-spin 0.7s linear infinite;
}

@keyframes midiwood-spin {
	to { transform: rotate( 360deg ); }
}

.midiwood-waveform {
	position: relative;
	min-height: 48px;
	height: 100%;
}

/* Full and isolated waveforms overlay (same space); opacity crossfade avoids flash on isolate toggle */
.midiwood-waveform .midiwood-ws-full,
.midiwood-waveform .midiwood-ws-iso {
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	bottom: 0;
	min-height: 48px;
	cursor: pointer;
	transition: opacity 0.4s ease;
}

.midiwood-waveform .midiwood-ws-full {
	opacity: 1;
	pointer-events: auto;
}

.midiwood-waveform .midiwood-ws-iso {
	opacity: 0;
	pointer-events: none;
}

.midiwood-waveform canvas {
	border-radius: 4px;
}

.midiwood-waveform-ready {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 48px;
	color: var( --midiwood-text-muted );
	font-size: 0.8125rem;
}

.midiwood-error {
	color: #c66;
	font-size: 0.8125rem;
	padding: 12px;
	text-align: center;
}

/* Isolate button */
.midiwood-player-footer {
	display: flex;
	align-items: center;
	flex-shrink: 0;
}

.midiwood-single-track .midiwood-player-footer {
	display: none;
}

.midiwood-btn-isolate {
	padding: 8px 16px;
	border-radius: 6px;
	border: 2px solid var( --midiwood-border );
	background: transparent;
	color: var( --midiwood-text-muted );
	font-size: 0.8125rem;
	font-weight: 500;
	cursor: pointer;
	transition: color var( --midiwood-transition ), border-color var( --midiwood-transition ),
		background var( --midiwood-transition ), transform var( --midiwood-transition );
}

.midiwood-btn-isolate:hover:not(:disabled) {
	border-color: var( --midiwood-accent );
	color: var( --midiwood-text );
}

.midiwood-btn-isolate:active:not(:disabled) {
	transform: scale( 0.98 );
}

.midiwood-btn-isolate.active {
	background: var( --midiwood-accent );
	border-color: var( --midiwood-accent );
	color: #fff;
}

.midiwood-btn-isolate:focus {
	outline: none;
	box-shadow: 0 0 0 2px var( --midiwood-bg ), 0 0 0 4px var( --midiwood-accent );
}

.midiwood-btn-isolate:focus:not(:focus-visible) {
	box-shadow: none;
}

.midiwood-btn-isolate:disabled {
	opacity: 0.5;
	cursor: not-allowed;
}

/* Mini mode: play button + waveform only */
.midiwood-player-mini .midiwood-track-info,
.midiwood-player-mini .midiwood-player-footer {
	display: none;
}

/* Responsive */
@media ( max-width: 768px ) {
	.midiwood-player {
		flex-direction: column;
		align-items: stretch;
	}

	.midiwood-track-info {
		width: 100%;
		min-width: 0;
	}

	.midiwood-waveform-container {
		min-width: 0;
	}
}

@media ( max-width: 480px ) {
	.midiwood-btn-play {
		width: 40px;
		height: 40px;
		min-width: 40px;
		min-height: 40px;
	}

	.midiwood-btn-play .midiwood-icon-play {
		border-width: 6px 0 6px 10px;
		margin-left: 2px;
	}

	.midiwood-btn-play.playing .midiwood-icon-play {
		width: 3px;
		height: 12px;
		box-shadow: 4px 0 0 currentColor;
	}
}
