/* Tweak colours to brand colours. */
.vjs-control-bar {
  color: #fff;
}

.vjs-control-bar .vjs-volume-level {
  background: #3a7563;
}

.vjs-control-bar .vjs-play-progress {
  background: #3a7563;
}

.video-js .vjs-load-progress div {
  background: #d1d1d17a;
}

.video-js .vjs-slider {
  background-color: #d1d1d178;
}

.video-js .vjs-control-bar {
  background-color: #0000009c;
  overflow: visible; /* only if your bar clips controls */
}

.vjs-menu-button-popup .vjs-menu .vjs-menu-content {
  background-color: #0000009c;
  margin: 0 !important;
}

.vjs-theme-fantasy {
  --vjs-theme-fantasy--primary: #3a7563;
  --vjs-theme-fantasy--secondary: #fff;
}

/* Hacks to make things work, not final fixes. */

/* Remove picture-in-picture button. */
.vjs-picture-in-picture-control.vjs-control.vjs-button {
  display: none;
}

/* Vertically centre the playback rate button. */
.vjs-playback-rate .vjs-playback-rate-value {
  line-height: 3.5;
}

/* Move the pop out menus up. */
.vjs-menu-button-popup .vjs-menu {
  margin-bottom: 4em;
}

/* Show time controls for bigger screens but not smmaller ones. */
.video-js .vjs-time-control {
  display: block;
  font-size: 1.2em;
}

@media only screen and (max-width: 600px) {
  .video-js .vjs-time-control {
    display: none;
  }
}

/* Hide time left. */
.video-js .vjs-remaining-time {
  display: none;
}

/*.video-js button,
.video-js button:visited {
	color: #ffffff !important;
	background-color: transparent !important;
	font-size: 10px !important;
	text-transform: none;
	border: none !important;
}*/

.video-js button *,
.video-js button:visited * {
  color: #fff !important;
}

.video-js button:hover {
  background-color: transparent !important;
  color: #fff !important;
  border: none !important;
}

.video-js button:hover * {
  color: #fff !important;
}

button.vjs-menu-button.vjs-menu-button-popup.vjs-icon-cog.vjs-button {
  font-size: 1.5em !important;
  font-family: videojs, sans-serif !important;
}

.wwmc-videojs-dimensions {
  width: 100%;
  max-width: 100%;
}

.video-js .vjs-seek-button {
  font-size: 14px !important;
}

.vjs-theme-fantasy .vjs-big-play-button {
  font-size: 80px !important;
}

.vjs-theme-fantasy .vjs-play-control {
  font-size: 1.5em !important;
}

/** div.vjs-control-bar > div.vjs-subs-caps-button.vjs-menu-button.vjs-menu-button-popup.vjs-control.vjs-button {
	display: none;
} **/

.video-js.vjs-http-source-selector {
  display: block;
}

div.vjs-http-source-selector > button:nth-child(1) > span:nth-child(1)::before {
  font-family: VideoJS, sans-serif;
  font-weight: 400;
  font-style: normal;
  content: '\f114';
}

div.vjs-icon-cog.vjs-http-source-selector.vjs-menu-button.vjs-menu-button-popup.vjs-control.vjs-button::before {
  display: none;
}

/* Shrink sprite tooltip to ~85% */
.wwmc-videojs .vjs-progress-control .vjs-mouse-display .vjs-time-tooltip {
  transform: scale(0.85) !important;
  transform-origin: bottom center !important; /* keeps it anchored on the bar */
  pointer-events: none;
}

.video-js .vjs-control.vjs-chromecast-button,
.video-js .vjs-control.vjs-chromecast-control {
  display: block !important;
  opacity: 1 !important;
  visibility: visible !important;
}

/* Graceful fallback if external CSS is late */
.video-js .vjs-control.vjs-chromecast-button {
  min-width: 2.8em;
}

/* Hide all Cast-like controls by default */
.video-js .vjs-wwmc-cast-stub,
.video-js .vjs-wwmc-cast-btn,
.video-js .vjs-chromecast-stub,
.video-js .vjs-chromecast-button,
.video-js .vjs-chromecast-control,
.video-js .vjs-control[aria-label*='Cast' i],
.video-js .vjs-control[title*='Cast' i],
.video-js .vjs-button[aria-label*='Cast' i],
.video-js .vjs-button[title*='Cast' i] {
  display: none !important;
}

/* Only show when we explicitly allow casting */
html.can-cast .video-js .vjs-wwmc-cast-stub,
html.can-cast .video-js .vjs-wwmc-cast-btn,
html.can-cast .video-js .vjs-chromecast-stub,
html.can-cast .video-js .vjs-chromecast-button,
html.can-cast .video-js .vjs-chromecast-control,
html.can-cast .video-js .vjs-control[aria-label*='Cast' i],
html.can-cast .video-js .vjs-control[title*='Cast' i],
html.can-cast .video-js .vjs-button[aria-label*='Cast' i],
html.can-cast .video-js .vjs-button[title*='Cast' i] {
  display: inline-flex !important;
}

/* Center stub and real cast buttons */
.video-js .vjs-control.vjs-wwmc-cast-stub,
.video-js .vjs-control.vjs-chromecast-stub,
.video-js .vjs-control.vjs-chromecast-button,
.video-js .vjs-control.vjs-chromecast-control {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  line-height: inherit;
}

/* AirPlay size/centering */
.video-js .vjs-airplay-control {
  min-width: 3em;
}

.video-js .vjs-control.vjs-airplay-control {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  line-height: inherit;
}

.video-js .vjs-control.vjs-airplay-control .vjs-icon-placeholder,
.video-js .vjs-control.vjs-airplay-control .vjs-icon-placeholder::before {
  font-size: 1.8em;
  line-height: 1;
}

/* Custom Error Display Overlay (Phase 4.2) */
.video-js .wwmc-vp-error-display {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: rgba(0, 0, 0, 0.9);
  color: #fff;
  padding: 2em;
  border-radius: 8px;
  text-align: center;
  max-width: 90%;
  z-index: 10000;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.5);
}

.video-js .wwmc-vp-error-icon {
  font-size: 3em;
  margin-bottom: 0.5em;
}

.video-js .wwmc-vp-error-title {
  font-size: 1.5em;
  font-weight: bold;
  margin-bottom: 0.5em;
  color: #fff;
}

.video-js .wwmc-vp-error-message {
  font-size: 1em;
  margin-bottom: 1em;
  line-height: 1.5;
  color: #d1d1d1;
}

.video-js .wwmc-vp-error-refresh {
  background: #3a7563;
  color: #fff;
  border: none;
  padding: 0.75em 1.5em;
  border-radius: 4px;
  font-size: 1em;
  cursor: pointer;
  transition: background 0.3s ease;
}

.video-js .wwmc-vp-error-refresh:hover {
  background: #2d5d4e;
}

/* Hide default Video.js error display when using custom error */
.video-js.wwmc-vp-has-custom-error .vjs-error-display {
  display: none;
}

/* Responsive adjustments */
@media only screen and (max-width: 600px) {
  .video-js .wwmc-vp-error-display {
    padding: 1.5em;
    max-width: 95%;
  }

  .video-js .wwmc-vp-error-icon {
    font-size: 2.5em;
  }

  .video-js .wwmc-vp-error-title {
    font-size: 1.25em;
  }

  .video-js .wwmc-vp-error-message {
    font-size: 0.9em;
  }
}
