/* Custom Plyr Styling */

:root {
  --plyr-color-main: #3b82f6; /* Blue-500 */
  --plyr-video-background: #ffffff;
  --plyr-audio-controls-background: #f9fafb; /* Gray-50 */
  --plyr-audio-control-color: #374151; /* Gray-700 */
  --plyr-audio-control-color-hover: #1f2937; /* Gray-800 */
}

/* Dark mode Plyr variables */
.dark {
  --plyr-color-main: #60a5fa; /* Blue-400 */
  --plyr-video-background: #1f2937;
  --plyr-audio-controls-background: #374151; /* Gray-700 */
  --plyr-audio-control-color: #e5e7eb; /* Gray-200 */
  --plyr-audio-control-color-hover: #ffffff;
}

/* Player container styling */
.plyr {
  border-radius: 0.5rem;
  overflow: visible; /* Allow menus to overflow */
  box-shadow: 0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1);
  position: relative;
  z-index: 1;
}

/* Ensure the controls allow overflow too */
.plyr__controls {
  position: relative;
  overflow: visible;
}

/* Audio player specific */
.plyr--audio .plyr__controls {
  background: linear-gradient(to bottom, #f9fafb, #f3f4f6);
  border: 1px solid #e5e7eb;
  border-radius: 0.5rem;
  padding: 1rem;
}

.dark .plyr--audio .plyr__controls {
  background: linear-gradient(to bottom, #374151, #1f2937);
  border: 1px solid #4b5563;
}

/* Progress bar */
.plyr__progress input[type="range"] {
  color: #3b82f6;
}

.plyr__progress__buffer {
  background: rgba(59, 130, 246, 0.25);
}

/* Volume slider */
.plyr--audio input[type="range"]::-webkit-slider-thumb {
  background: #3b82f6;
}

.plyr--audio input[type="range"]::-moz-range-thumb {
  background: #3b82f6;
}

/* Play button */
.plyr--audio .plyr__control--overlaid {
  background: #3b82f6;
  border-radius: 50%;
}

.plyr--audio .plyr__control--overlaid:hover {
  background: #2563eb; /* Blue-600 */
}

/* Control buttons */
.plyr__controls button:hover {
  background: rgba(59, 130, 246, 0.1);
}

.plyr__controls button.plyr__control--pressed {
  background: rgba(59, 130, 246, 0.15);
}

/* Time display */
.plyr__time {
  color: #6b7280; /* Gray-500 */
  font-variant-numeric: tabular-nums;
}

/* Volume and settings popups */
.plyr__menu {
  background: white;
  border: 1px solid #e5e7eb;
  border-radius: 0.375rem;
  box-shadow: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
  z-index: 100;
  position: absolute;
  bottom: 100%;
  right: 0;
  margin-bottom: 0.5rem;
}

.plyr__menu__container {
  position: relative;
}

.plyr__menu__container .plyr__control {
  color: #374151;
}

.plyr__menu__container .plyr__control:hover {
  background: #f3f4f6;
}

/* Focus styles */
.plyr__control:focus-visible {
  outline: 2px solid #3b82f6;
  outline-offset: 2px;
}

/* Custom Range Slider Styles for Stem Mixer */
input[type="range"] {
  -webkit-appearance: none;
  appearance: none;
  background: transparent;
  cursor: pointer;
}

input[type="range"]::-webkit-slider-runnable-track {
  height: 8px;
  border-radius: 4px;
}

input[type="range"]::-moz-range-track {
  height: 8px;
  border-radius: 4px;
}

input[type="range"]::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: white;
  border: 2px solid currentColor;
  margin-top: -5px;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2);
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}

input[type="range"]::-moz-range-thumb {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: white;
  border: 2px solid currentColor;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2);
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}

input[type="range"]:hover::-webkit-slider-thumb {
  transform: scale(1.1);
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.25);
}

input[type="range"]:hover::-moz-range-thumb {
  transform: scale(1.1);
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.25);
}

input[type="range"]:focus {
  outline: none;
}

input[type="range"]:focus::-webkit-slider-thumb {
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.3);
}

input[type="range"]:focus::-moz-range-thumb {
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.3);
}
