$control-bar-height: 2.5rem;
$control-bar-font-size: 0.8rem;
$control-bar-popup-font-size: 0.8rem;
$control-bar-icon-size: 0.8rem;

.video-js {
  font-size: 12px;
  overflow: hidden;

  // Control Bar (container)
  .vjs-control-bar {
    background: none;
    color: #dbd8d8;
    height: $control-bar-height;

    &::before {
      position: absolute;
      bottom: 0;
      content: '';
      height: 5rem;
      width: 100%;
      background: rgba(20, 20, 20, 0.45);
      background: linear-gradient(0deg, rgba(0, 0, 0, 0.85) 10%, rgba(0, 0, 0, 0) 100%);
    }
  }

  // Progress Bar
  .vjs-progress-control.vjs-control {
    position: absolute;
    display: flex;
    align-items: center;
    width: 100%;
    height: 1rem;
    bottom: 90%;

    // Circle play head
    .vjs-play-progress::before {
      transform: scale(0);
      transition: transform 0.1s;
    }

    &:hover {
      .vjs-play-progress::before {
        transform: scale(1);
      }
    }

    // Progress Slider
    .vjs-slider {
      margin: 0 1rem;
    }
  }

  // Load progress color
  .vjs-load-progress,
  .vjs-load-progress div {
    background-color: rgba(var(--color-secondary), 0.5);
  }

  // Progress Bar Background
  .vjs-slider {
    background-color: rgba(60, 60, 60, 0.5);
  }

  // Primary Color Progress
  .vjs-slider-bar {
    background-color: var(--color-gray-5);
  }

  // Inner Progress Bar
  .vjs-play-progress {
    background-color: var(--color-primary);
    color: var(--color-primary);
  }

  // Spacer
  .vjs-custom-control-spacer {
    display: flex;
    flex: auto;
  }

  // Transcoding menu
  /*.vjs-tech {
    height: auto !important;
    position: absolute !important;
  }*/

  // Volume slider
  .vjs-volume-panel {
    margin-right: calc(var(--spacing-xxs) * -1);

    .vjs-volume-control.vjs-volume-horizontal {
      transition: 0.1s;
      margin-top: 2px;
    }
  }
}

// Tooltip
.vjs-mouse-display .vjs-time-tooltip {
  color: white;
}

// Tooltip
.video-js {
  .vjs-progress-control {
    .vjs-play-progress {
      .vjs-time-tooltip {
        display: none;
      }
    }
  }
}

// Transitions control bar between active / inactive
.vjs-has-started {
  .vjs-control-bar {
    opacity: 1;
    transition: 0.1s;
  }

  &.vjs-user-inactive.vjs-playing {
    .vjs-control-bar {
      opacity: 0;
      transition: 0.1s;
    }
  }

  &.vjs-user-active.vjs-playing {
    .vjs-control-bar {
    }
  }
}

// Button glow
.video-js {
  .vjs-control,
  .vjs-time-divider {
    user-select: none;

    &:focus:before,
    &:hover:before,
    &:focus {
      // Disable builtin button glow
      text-shadow: none;
    }
  }
}

.bottom-gradient {
  background-image: linear-gradient(to top, rgba(0, 0, 0, 0.4) 0%, transparent 72px);
}

.vjs-hover {
  opacity: 1;
}

[dir] .vjs-menu-button-popup .vjs-menu .vjs-menu-content {
  background-color: rgba(43, 51, 63);
  max-height: 20em;
  margin-bottom: calc(var(--spacing-xxs) * -1); // Prevents accidental dismissal when the gap is hovered.

  li {
    font-size: $control-bar-popup-font-size;
  }
}

.vjs-slider-horizontal {
  background-color: #474747 !important;
}

.vjs-mouse-display {
  color: white !important;
  background-color: lightgrey !important;
  width: 8px !important;
  margin-left: -5px !important;
}

.vjs_video_3_ima-ad-container {
  display: none;
}

.ima-ad-container {
  display: none;
}

.vjs-chromecast-button {
  .vjs-icon-placeholder {
    width: 19px;
    height: 19px;
  }
}

.video-js-parent .vjs-tech-chromecast {
  .vjs-tech-chromecast-poster {
    &::after {
      $chromecast-poster-width: 50px;
      width: $chromecast-poster-width;
      left: calc(50% - #{$chromecast-poster-width * 0.5});
    }
  }

  .vjs-tech-chromecast-poster-img {
    $chromecast-poster-max-height: 50px;
    max-height: $chromecast-poster-max-height;
    &.vjs-tech-chromecast-poster-img-empty {
      width: 80px;
      height: 90px;
    }
  }

  .vjs-tech-chromecast-title-container {
    margin-bottom: var(--spacing-main-padding);
  }

  .vjs-tech-chromecast-title {
    font-size: var(--font-title);
    @media (max-width: $breakpoint-small) {
      font-size: var(--font-small);
    }
  }

  .vjs-tech-chromecast-subtitle {
    color: var(--color-text-subtitle);
    font-size: var(--font-body);
    @media (max-width: $breakpoint-small) {
      font-size: var(--font-xsmall);
    }
  }
}

// larger than default spinner for all but smallest devices
@media (min-width: 680px) {
  .vjs-loading-spinner {
    border-radius: 100px;
    height: 75px;
    width: 75px;
    margin: -49px 0 0 -37px;
  }
}

// TODO: make sure there's no bad side effects of this
button.vjs-big-play-button {
  display: none !important;
}

// Rearrange icons
.vjs-play-control {
  order: 1 !important;
}
.vjs-volume-panel {
  order: 2 !important;
}
.vjs-current-time {
  order: 3 !important;
}
.vjs-time-divider {
  order: 4 !important;
}
.vjs-duration {
  order: 5 !important;
}

.vjs-custom-control-spacer {
  order: 6 !important;
}

.vjs-button--autoplay-next {
  order: 7 !important;
}
.vjs-playback-rate {
  order: 8 !important;
}
.vjs-chromecast-button {
  order: 9 !important;
}
.vjs-quality-selector {
  order: 10 !important;
}
.vjs-button--theater-mode {
  order: 11 !important;
}
.vjs-fullscreen-control {
  order: 12 !important;
}