/* Dark mode */
html {
  --bs-secondary-bg: #f4f5f6 !important;
}

html[data-bs-theme="dark"] {
  --bs-body-bg: #181818;
  --bs-tertiary-bg: #202224;
  --bs-tertiary-bg-rgb: 32, 34, 36;
  --bs-secondary-bg: #282b2c !important;
}

/* Common */
.fs-5-5 {
  font-size: 1.125rem;
}

.badge-sm {
  font-size: 12px !important;
}

.preserve-newlines {
  white-space: pre-line;
}

.text-discord {
  color: #5865F2;
}

.bg-discord {
  background-color: #5865F2;
  border-color: #5865F2;
}

.bg-discord:hover {
  background-color: #4752c4;
  border-color: #4752c4;
}

/* Nav and layout */
.nav-center {
  width: 100%;
  justify-content: center;
}

.navbar-brand img {
  transform: scale(1.15);
}

.validation-summary-errors ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

main {
  padding-top: 32px;
  padding-bottom: 32px;
}

a>.card:hover {
  background-color: var(--bs-tertiary-bg);
}

@media (min-width: 768px) {
  .nav-center {
    width: auto;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    margin-top: 0;
  }
}

@media (max-width: 450px) {
  .navbar-brand {
    font-size: 1.15rem;
  }

  .navbar-brand img {
    transform: scale(1.1);
  }
}

body>header {
  height: 62px;
}

/* Dark mode support for Choices.js */
[data-bs-theme="dark"] .choices__inner {
  background-color: var(--bs-body-bg);
  color: var(--bs-body-color);
  border: 1px solid var(--bs-border-color);
}

[data-bs-theme="dark"] .choices__input {
  background-color: var(--bs-body-bg);
  color: var(--bs-body-color);
}

[data-bs-theme="dark"] .choices__list--dropdown,
[data-bs-theme="dark"] .choices__list[aria-expanded] {
  background-color: var(--bs-body-bg);
  color: var(--bs-body-color);
  border: 1px solid var(--bs-border-color);
}

[data-bs-theme="dark"] .choices__item--selectable.is-highlighted {
  background-color: var(--bs-tertiary-bg);
  color: var(--bs-primary-text);
}

[data-bs-theme="dark"] .choices__item--selectable.is-highlighted {
  background-color: var(--bs-tertiary-bg) !important;
  color: var(--bs-primary-text) !important;
}

.choices {
  margin-bottom: 4px !important;
}

/* List page */
.list-group-item {
  transition: background-color 0.2s ease-in-out;
}

.list-group-item.is-expanded {
  background-color: var(--bs-tertiary-bg);
}

.video-toggle[aria-expanded="true"] .bi-chevron-down {
  transform: rotate(180deg);
}

.video-toggle .bi-chevron-down {
  transition: transform 0.2s ease-in-out;
}

.list-video-card {
  display: grid;
  gap: 0 8px;
  grid-template-columns: auto 1fr auto;
  grid-template-areas:
    "thumb meta chevron"
    "desc  desc desc";
  align-items: start;
  overflow: hidden;
}

.video-toggle {
  display: contents;
  cursor: pointer;
  text-decoration: none;
  color: inherit;
}

.video-thumbnail {
  grid-area: thumb;
  width: 110px;
  object-fit: cover;
  transition: width 0.3s;
}

.video-meta {
  grid-area: meta;
  min-width: 0;
}

.video-chevron {
  grid-area: chevron;
  align-self: start;
  padding: 0.5rem;
}

.video-desc {
  grid-area: desc;
}

.video-element.is-expanded {
  background-color: var(--bs-tertiary-bg);
}

.video-element {
  margin-top: 5px;
  border: none !important;
  background-color: var(--bs-tertiary-bg) !important;
}

@media (max-width: 576px) {
  .video-element.is-expanded .list-video-card {
    grid-template-columns: auto auto 1fr;
    grid-template-areas:
      "thumb chevron ."
      "meta  meta    meta"
      "desc  desc    desc";
    gap: 8px;
  }

  .video-element.is-expanded .video-thumbnail {
    width: 100%;
  }

  .video-element.is-expanded .video-chevron {
    align-self: start;
    padding: 0.25rem;
  }

  .video-meta.fade-back-in {
    animation: fadeIn 0.2s ease forwards;
  }

  @keyframes fadeIn {
    0% {
      opacity: 0;
    }

    100% {
      opacity: 1;
    }
  }

  .d-none-mobile {
    display: none;
  }
}

@media (min-width: 576px) {
  .video-thumbnail {
    width: 130px;
  }

  .video-element.is-expanded .video-thumbnail {
    width: 200px;
  }
}

@media (min-width: 768px) {
  .list-video-card {
    grid-template-areas:
      "thumb meta chevron"
      "thumb desc chevron";
    gap: 0 16px;
  }

  .video-thumbnail {
    grid-row: span 2;
  }
}

@media (min-width: 992px) {
  .video-element.is-expanded .video-thumbnail {
    width: 320px;
  }

  .video-description {
    min-height: 75px;
  }
}

@media (min-width: 1400px) {
  .video-element.is-expanded .video-thumbnail {
    width: 400px;
  }
  .video-description {
    min-height: 120px;
  }

}

/* Searching and filtering in list */
mark {
  background-color: #f39c12;
  color: #000;
  padding: 0.1em 0.25em;
  border-radius: 0.2rem;
}

.hidden {
  display: none !important;
}

#filter-box::-webkit-scrollbar {
  display: none;
}

#filter-box .filter-badge {
  cursor: pointer;
  opacity: 0.4;
  /* default inactive look */
  transition: opacity 0.15s ease-in-out;
}

#filter-box .filter-badge.active {
  opacity: 1;
  /* fully visible when active */
}

/* Home page */
.video-element:has(.video-toggle:hover), .card-hover:hover {
  background-color: var(--bs-secondary-bg) !important;
}

.video-element, .card-hover {
  transition: background-color .2s;
}

@media (min-width: 1800px) {
  .row-xxxl-cols-5>* {
    width: calc(100% / 5);
  }

  #container-toggle.container-fluid {
    padding-left: 50px;
    padding-right: 50px;
  }
}

@media (min-width: 2100px) {
  .row-xxxxl-cols-6>* {
    width: calc(100% / 6);
  }
}

/* Choice banner */
.progress-circle {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-shrink: 0;
  width: 100px;
  height: 100px;
  border-radius: 50%;

  background: radial-gradient(closest-side,
      var(--bs-card-bg) 79%,
      transparent 80% 100%),
    conic-gradient(var(--bs-primary) calc(var(--p, 0) * 1%),
      var(--bs-secondary, #dee2e6) 0);
}

.progress-circle-value,
.progress-value {
  display: flex;
  justify-content: center;
  align-items: center;
  font-weight: bold;
}

.progress-circle.success {
  background: radial-gradient(closest-side,
      var(--bs-card-bg, #fff) 79%,
      transparent 80% 100%),
    conic-gradient(var(--bs-success) 100%, var(--bs-success) 0);
}

.progress-circle.success .progress-value {
  color: var(--bs-success);
  font-size: 3rem;
}

.progress-circle.danger {
  background: radial-gradient(closest-side,
      var(--bs-card-bg, #fff) 79%,
      transparent 80% 100%),
    conic-gradient(var(--bs-danger) 100%, var(--bs-danger) 0);
}

.progress-circle.danger .progress-value {
  color: var(--bs-danger);
  font-size: 3rem;
}

/* Player */
.description-collapse {
  position: relative;
  cursor: pointer;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 4;
  line-clamp: 4;
  -webkit-box-orient: vertical;
  max-height: 6.5rem;
  padding: 12px 14px;
  transition: background-color .2s;
}

.description-collapse::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 3.5em;
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0), var(--bs-body-bg, #fff));
  pointer-events: none;
}

.description-collapse.expanded {
  -webkit-line-clamp: unset;
  line-clamp: unset;
  max-height: none;
  cursor: auto;
}

.description-collapse.expanded::after {
  display: none;
}

.description-collapse:not(.expanded):hover {
  background-color: var(--bs-secondary-bg) !important;
}

#watched-button.bg-success {
  color: white;
}

#watched-button:hover {
  opacity: 0.9;
}

.dark-filter {
  filter: brightness(0.4);
}