:root {
  --brand-color: #b50015;
  --brand-color-dark: #76000d;
  --section-heading-bg: #b50015;
  --section-heading-text: #ffffff;
  --section-note-text: #ffffff;
  --page-bg: #050505;
  --panel-bg: #111;
  --panel-bg-soft: #171717;
  --text-main: #fff;
  --text-muted: #cfcfcf;
  --border-soft: rgba(255, 255, 255, 0.12);
  --button-bg: #000;
  --button-text: #fff;
  --max-page-width: 1480px;
}

* {
  box-sizing: border-box;
}

html,
body {
  min-height: 100%;
  margin: 0;
  background: var(--page-bg);
  color: var(--text-main);
  font-family: Arial, Helvetica, sans-serif;
}

body {
  overflow-x: hidden;
  overflow-y: auto;
}

.main-container {
  width: 100%;
  min-height: 100vh;
  background: var(--page-bg);
  display: flex;
  flex-direction: column;
}

/* =========================
   Header
   ========================= */
header.flex-grid {
  position: sticky;
  top: 0;
  z-index: 50;
  width: 100%;
  min-height: 86px;
  padding: 16px 28px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 20px;
  background: linear-gradient(90deg, var(--brand-color), var(--brand-color-dark));
  border-bottom: 1px solid rgba(255, 255, 255, 0.16);
}

.logo-container {
  display: flex;
  align-items: center;
  min-width: 0;
}

.logo-container .logo {
  display: block;
  max-width: 230px;
  max-height: 58px;
  width: auto;
  height: auto;
  object-fit: contain;
}

.filter-buttons,
.navigation.nav-buttons {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap;
}

.navigation.nav-buttons {
  justify-content: flex-end;
}

.btn,
.player-stats button,
.description-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 9px 14px;
  border: 1px solid rgba(255, 255, 255, 0.22);
  border-radius: 0;
  background: var(--button-bg);
  color: var(--button-text);
  font-size: 14px;
  font-weight: 700;
  line-height: 1;
  text-decoration: none;
  cursor: pointer;
  transition: transform 0.15s ease, background 0.15s ease, border-color 0.15s ease;
}

.btn:hover,
.player-stats button:hover,
.description-toggle:hover {
  background: #222;
  border-color: rgba(255, 255, 255, 0.45);
}

.btn:focus-visible,
.player-stats button:focus-visible,
.description-toggle:focus-visible,
select:focus-visible {
  outline: 3px solid #fff;
  outline-offset: 2px;
}

.dropdown-container {
  display: none;
  gap: 10px;
  width: 100%;
}

.dropdown-container select {
  width: 100%;
  min-height: 40px;
  border: 1px solid rgba(255, 255, 255, 0.28);
  border-radius: 0;
  background: #000;
  color: #fff;
  padding: 8px 10px;
  font-size: 15px;
  font-weight: 700;
}

/* =========================
   Stacked page sections
   ========================= */
.site-content {
  width: min(100%, var(--max-page-width));
  margin: 0 auto;
  padding: 24px 26px 34px;
  display: flex;
  flex-direction: column;
  gap: 22px;
}

.section-card {
  width: 100%;
  background: var(--panel-bg);
  border: 1px solid var(--border-soft);
  border-radius: 0;
  overflow: hidden;
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.28);
}

.section-heading {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 14px 18px;
  background: var(--brand-color);
  border-bottom: 1px solid rgba(255, 255, 255, 0.14);
}

.section-heading h2,
.section-heading h3 {
  margin: 0;
  font-size: 18px;
  line-height: 1.2;
  color: #fff;
  letter-spacing: 0.2px;
}

.section-note {
  color: rgba(255, 255, 255, 0.88);
  font-size: 14px;
}

/* Player */
.video-container,
.player-section {
  width: 100%;
  display: block;
  position: static !important;
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
}

.video-player-wrapper {
  width: 100%;
  position: static !important;
  margin: 0 !important;
  padding: 16px;
  background: var(--panel-bg);
  border-radius: 0;
}

.video-player,
#target {
  width: 100%;
  aspect-ratio: 16 / 9;
  background: #000;
  overflow: hidden;
  border-radius: 0 !important;
}

#target media-player,
#target video,
media-player,
media-video-layout,
.video-player video {
  width: 100%;
  height: 100%;
  border-radius: 0 !important;
  overflow: hidden;
}

.player-stats {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 12px;
  padding: 14px 0 0;
  color: var(--text-muted);
  font-size: 15px;
}

.player-stats p {
  margin: 0;
  display: inline-flex;
  gap: 5px;
  align-items: center;
}

.dropdown-description {
  margin-top: 14px;
  padding: 14px;
  background: var(--panel-bg-soft);
  border: 1px solid var(--border-soft);
  color: var(--text-muted);
  line-height: 1.55;
}

/* Playlist */
.playlist-section,
.content-container {
  position: static !important;
  top: auto !important;
  bottom: auto !important;
  left: auto !important;
  right: auto !important;
  width: 100% !important;
  height: auto !important;
  min-height: 0 !important;
  overflow: visible !important;
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
}

.playlist-body {
  padding: 16px;
  background: var(--panel-bg);
}

.flex-grid-fifths,
#thumbnail-container {
  display: grid !important;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 16px;
  width: 100%;
  padding: 0 !important;
  margin: 0 !important;
  overflow: visible !important;
}

#thumbnail-container .col,
.col {
  width: 100% !important;
  min-width: 0;
  margin: 0 !important;
  padding: 0 !important;
  background: #151515;
  border: 1px solid var(--border-soft);
  border-radius: 0;
  overflow: hidden;
  cursor: pointer;
  transition: border-color 0.15s ease, transform 0.15s ease, background 0.15s ease;
}

#thumbnail-container .col:hover,
.col:hover {
  background: #1f1f1f;
  border-color: rgba(255, 255, 255, 0.36);
  transform: translateY(-2px);
}

.aspect-ratio-wrapper {
  width: 100%;
  aspect-ratio: 16 / 9;
  background: #000;
  overflow: hidden;
  border-radius: 0 !important;
}

.aspect-ratio-wrapper img,
#thumbnail-container img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  border-radius: 0 !important;
}

.title-overlay {
  position: static !important;
  display: block !important;
  min-height: 54px;
  padding: 10px 12px;
  background: transparent !important;
  color: #fff !important;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.25;
  overflow: hidden;
  display: -webkit-box !important;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

/* Description */
.description-section {
  display: block;
}

.description-body {
  padding: 18px;
}

.video-description {
  position: static !important;
  width: 100% !important;
  max-width: none !important;
  height: auto !important;
  min-height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  color: var(--text-muted);
  line-height: 1.6;
  overflow: visible !important;
}

.video-description h3 {
  margin: 0 0 10px;
  color: #fff;
  font-size: 20px;
}

.video-description p {
  margin: 0 0 10px;
}

.video-description a,
.dropdown-description a {
  color: #fff;
  text-decoration: underline;
}

/* Sponsors */
.sponsor-section {
  display: block;
}

.sponsor-body {
  padding: 16px;
  background: rgba(255, 255, 255, 0.04);
}

.sponsor-logos {
  position: static !important;
  width: 100% !important;
  height: auto !important;
  display: flex !important;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 14px;
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
}

.sponsor-logos img {
  display: block;
  max-width: 180px;
  height: 62px;
  object-fit: contain;
  padding: 8px 12px;
  background: #fff;
  border: 1px solid rgba(0, 0, 0, 0.12);
  border-radius: 0;
}

.sponsor-logos img.major-partner {
  max-width: 240px;
  height: 76px;
}

.sponsor-logos-mobile {
  display: none !important;
}

footer {
  width: 100%;
  margin-top: auto;
  padding: 18px 24px;
  text-align: center;
  color: var(--text-muted);
  background: #000;
  border-top: 1px solid var(--border-soft);
}

/* =========================
   Responsive
   ========================= */
@media (max-width: 1200px) {
  .flex-grid-fifths,
  #thumbnail-container {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media (max-width: 960px) {
  header.flex-grid {
    position: static;
    grid-template-columns: 1fr;
    justify-items: center;
    padding: 14px 16px 16px;
  }

  .logo-container .logo {
    max-width: 220px;
  }

  .dropdown-container {
    display: grid;
    grid-template-columns: 1fr 1fr;
  }

  .filter-buttons,
  .navigation.nav-buttons {
    display: none !important;
  }

  .site-content {
    padding: 16px;
    gap: 16px;
  }

  .flex-grid-fifths,
  #thumbnail-container {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
  }

  .section-heading {
    padding: 12px 14px;
  }

  .video-player-wrapper,
  .playlist-body,
  .description-body,
  .sponsor-body {
    padding: 12px;
  }
}

@media (max-width: 700px) {
  .dropdown-container {
    grid-template-columns: 1fr;
  }

  .flex-grid-fifths,
  #thumbnail-container {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .player-stats {
    align-items: stretch;
  }

  .player-stats button,
  .description-toggle {
    flex: 1 1 auto;
  }

  .section-note {
    display: none;
  }

  .sponsor-logos img {
    max-width: 140px;
    height: 54px;
  }

  .sponsor-logos img.major-partner {
    max-width: 190px;
    height: 66px;
  }
}

@media (max-width: 460px) {
  .site-content {
    padding: 12px;
  }

  .flex-grid-fifths,
  #thumbnail-container {
    grid-template-columns: 1fr;
  }

  .title-overlay {
    min-height: 0;
  }
}
  

/* =========================
   v3 sizing fixes
   These explicitly neutralise old style.css rules that otherwise survive.
   ========================= */
.video-player-wrapper {
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  align-items: stretch !important;
}

.video-player,
#target {
  display: block !important;
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  height: auto !important;
  aspect-ratio: 16 / 9 !important;
}

#target > *,
#target media-player,
#target video,
media-player,
media-provider,
media-video-layout,
media-poster,
media-provider video,
.video-player video {
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  height: 100% !important;
  border-radius: 0 !important;
}

.flex-grid-fifths,
#thumbnail-container {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)) !important;
  align-items: start !important;
}

#thumbnail-container .col,
.flex-grid-fifths .col {
  flex: none !important;
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  position: relative !important;
  overflow: hidden !important;
}

#thumbnail-container .aspect-ratio-wrapper,
.flex-grid-fifths .aspect-ratio-wrapper,
.aspect-ratio-wrapper {
  position: relative !important;
  width: 100% !important;
  height: auto !important;
  min-height: 0 !important;
  padding-top: 0 !important;
  aspect-ratio: 16 / 9 !important;
  display: block !important;
}

#thumbnail-container .aspect-ratio-wrapper img,
.flex-grid-fifths .aspect-ratio-wrapper img,
.aspect-ratio-wrapper img {
  position: static !important;
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  aspect-ratio: 16 / 9 !important;
  object-fit: cover !important;
}

#thumbnail-container .title-overlay,
.flex-grid-fifths .title-overlay,
.title-overlay {
  position: static !important;
  display: -webkit-box !important;
  width: 100% !important;
  min-height: 48px !important;
  max-height: none !important;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden !important;
}

@media (max-width: 700px) {
  .flex-grid-fifths,
  #thumbnail-container {
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)) !important;
  }
}


/* =========================
   v4 fixes
   - Keep thumbnails at a stable card size when filtered/single item.
   - Avoid showing both desktop description section and mobile dropdown.
   ========================= */
:root {
  --thumb-card-width: 240px;
  --thumb-card-mobile-width: 170px;
}

.flex-grid-fifths,
#thumbnail-container {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, var(--thumb-card-width)), var(--thumb-card-width))) !important;
  justify-content: start !important;
  align-items: start !important;
  gap: 16px !important;
}

#thumbnail-container .col,
.flex-grid-fifths .col,
.col {
  width: var(--thumb-card-width) !important;
  max-width: 100% !important;
  min-width: 0 !important;
  justify-self: start !important;
}

/* Desktop/tablet: use the full description section below the playlist only. */
@media (min-width: 769px) {
  #toggle-description,
  .description-toggle,
  .dropdown-description {
    display: none !important;
  }

  .description-section {
    display: block !important;
  }
}

/* Mobile: use the dropdown under the player stats only, and hide the lower duplicate section. */
@media (max-width: 768px) {
  .description-section {
    display: none !important;
  }

  #toggle-description,
  .description-toggle {
    display: inline-flex !important;
  }

  .dropdown-description[hidden] {
    display: none !important;
  }

  .dropdown-description:not([hidden]) {
    display: block !important;
    width: 100% !important;
  }

  .flex-grid-fifths,
  #thumbnail-container {
    grid-template-columns: repeat(auto-fill, minmax(min(100%, var(--thumb-card-mobile-width)), var(--thumb-card-mobile-width))) !important;
    justify-content: start !important;
    gap: 12px !important;
  }

  #thumbnail-container .col,
  .flex-grid-fifths .col,
  .col {
    width: var(--thumb-card-mobile-width) !important;
    max-width: 100% !important;
  }
}

@media (max-width: 390px) {
  :root {
    --thumb-card-mobile-width: 100%;
  }
}


/* =========================
   v5 refinements
   - Description sits between player and playlist.
   - Filter buttons are visually centered in the header.
   - Sponsor logos are larger, transparent, and stable-sized.
   - Major sponsor occupies its own centered row.
   ========================= */

/* Center the filter group in the middle header column. */
header.flex-grid {
  grid-template-columns: minmax(180px, 280px) minmax(320px, 1fr) minmax(180px, 280px) !important;
}

#filter-buttons.filter-buttons {
  justify-self: center !important;
  width: auto !important;
  max-width: 100% !important;
  margin: 0 auto !important;
}

.navigation.nav-buttons {
  justify-self: end !important;
}

/* Make the description directly below the player feel like part of the viewing area. */
.description-section {
  order: 2;
}

.playlist-section {
  order: 3;
}

.sponsor-section {
  order: 4;
}

.description-body {
  padding: 18px 20px !important;
}

.video-description {
  max-width: 1180px !important;
}

/* Transparent/page-colour sponsor block. */
.sponsor-section.section-card {
  background: transparent !important;
  border-color: transparent !important;
  box-shadow: none !important;
}

.sponsor-section .section-heading {
  background: transparent !important;
  border: 0 !important;
  padding: 4px 0 10px !important;
}

.sponsor-section .section-heading h2 {
  font-size: 18px;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.sponsor-body {
  background: transparent !important;
  padding: 8px 0 0 !important;
}

.sponsor-logos {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(180px, 220px));
  justify-content: center !important;
  align-items: center !important;
  gap: 22px 26px !important;
  width: 100% !important;
  background: transparent !important;
}

.sponsor-logos img {
  width: 100% !important;
  max-width: 220px !important;
  height: 92px !important;
  object-fit: contain !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
}

.sponsor-logos img.major-partner {
  grid-column: 1 / -1 !important;
  justify-self: center !important;
  width: min(100%, 420px) !important;
  max-width: 420px !important;
  height: 150px !important;
  margin-bottom: 4px !important;
}

@media (max-width: 1100px) {
  header.flex-grid {
    grid-template-columns: auto 1fr auto !important;
  }
}

@media (max-width: 960px) {
  header.flex-grid {
    grid-template-columns: 1fr !important;
  }

  #filter-buttons.filter-buttons,
  .navigation.nav-buttons {
    justify-self: center !important;
  }
}

@media (max-width: 768px) {
  /* Mobile still uses the dropdown description and hides the lower description section. */
  .description-section {
    display: none !important;
  }

  .sponsor-logos {
    grid-template-columns: repeat(2, minmax(120px, 1fr)) !important;
    gap: 18px 20px !important;
  }

  .sponsor-logos img {
    max-width: 180px !important;
    height: 76px !important;
  }

  .sponsor-logos img.major-partner {
    grid-column: 1 / -1 !important;
    max-width: 320px !important;
    height: 120px !important;
  }
}

@media (max-width: 430px) {
  .sponsor-logos {
    grid-template-columns: 1fr !important;
  }

  .sponsor-logos img.major-partner,
  .sponsor-logos img {
    max-width: 260px !important;
  }
}

/* =========================
   v6 refinements
   - Restore section outlines and red section headers.
   - Use dropdowns for both filters and main menu at all sizes.
   - Keep hidden link/button lists as JS data sources.
   - Add top breathing room below sticky header.
   ========================= */

.visually-hidden {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

header.flex-grid {
  grid-template-columns: minmax(160px, 280px) minmax(320px, 680px) minmax(160px, 280px) !important;
  padding: 14px 28px !important;
}

.logo-container {
  justify-self: start !important;
}

.header-dropdowns,
.dropdown-container {
  display: grid !important;
  grid-template-columns: minmax(180px, 260px) minmax(220px, 320px) !important;
  gap: 12px !important;
  justify-self: center !important;
  align-items: center !important;
  width: min(100%, 600px) !important;
}

.filter-dropdown,
.nav-dropdown,
.dropdown-container select {
  width: 100% !important;
  min-height: 42px !important;
  border-radius: 0 !important;
  border: 1px solid rgba(255, 255, 255, 0.34) !important;
  background: #000 !important;
  color: #fff !important;
  padding: 8px 12px !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  cursor: pointer !important;
}

.header-data-list,
#filter-buttons.filter-buttons,
.navigation.nav-buttons {
  display: none !important;
}

.site-content {
  padding-top: 34px !important;
}

.section-card,
.sponsor-section.section-card {
  background: var(--panel-bg) !important;
  border: 1px solid var(--border-soft) !important;
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.28) !important;
  overflow: hidden !important;
}

.section-heading,
.sponsor-section .section-heading {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 16px !important;
  padding: 14px 18px !important;
  background: var(--brand-color) !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.14) !important;
}

.section-heading h2,
.sponsor-section .section-heading h2 {
  margin: 0 !important;
  color: #fff !important;
  font-size: 18px !important;
  line-height: 1.2 !important;
  text-transform: none !important;
  letter-spacing: 0.2px !important;
}

/* Sponsor logos remain transparent/page-colour inside the restored panel. */
.sponsor-body {
  background: var(--panel-bg) !important;
  padding: 18px 20px 22px !important;
}

.sponsor-logos,
.sponsor-logos img,
.sponsor-logos img.major-partner {
  background: transparent !important;
}

/* Add a touch more separation around the description now it sits below the player. */
.description-section {
  margin-top: 2px !important;
}

/* Future page-editor note:
   The nav dropdown can be populated from hidden .nav-buttons links today.
   Later, generate those links from a pages/site config file with fields like:
   label, href, pageId, menuGroup, isPublished, sortOrder.
*/

@media (max-width: 1100px) {
  header.flex-grid {
    grid-template-columns: auto minmax(300px, 1fr) !important;
  }

  .logo-container {
    grid-column: 1 !important;
  }

  .header-dropdowns,
  .dropdown-container {
    grid-column: 2 !important;
    justify-self: end !important;
  }
}

@media (max-width: 760px) {
  header.flex-grid {
    grid-template-columns: 1fr !important;
    justify-items: center !important;
    gap: 12px !important;
    padding: 12px 14px 14px !important;
  }

  .logo-container {
    grid-column: auto !important;
    justify-self: center !important;
  }

  .header-dropdowns,
  .dropdown-container {
    grid-column: auto !important;
    grid-template-columns: 1fr 1fr !important;
    justify-self: center !important;
    width: min(100%, 560px) !important;
  }

  .site-content {
    padding-top: 18px !important;
  }
}

@media (max-width: 520px) {
  .header-dropdowns,
  .dropdown-container {
    grid-template-columns: 1fr !important;
  }
}


/* =========================
   v7 refinements
   - Header is now logo + site menu only.
   - Filter dropdown moves into the player action row next to likes/plays.
   - Keeps current JS hooks: #filter-dropdown, #nav-dropdown, .filter-btn, .nav-buttons.
   ========================= */

header.flex-grid {
  grid-template-columns: minmax(160px, 320px) 1fr minmax(220px, 360px) !important;
  gap: 20px !important;
}

.logo-container {
  grid-column: 1 !important;
}

.header-dropdowns,
.dropdown-container.header-dropdowns {
  grid-column: 3 !important;
  display: grid !important;
  grid-template-columns: minmax(220px, 320px) !important;
  justify-self: end !important;
  width: min(100%, 320px) !important;
}

.header-dropdowns .filter-dropdown {
  display: none !important;
}

.player-actions {
  justify-content: center !important;
  align-items: center !important;
  gap: 14px 18px !important;
  padding-top: 14px !important;
}

.player-filter-control {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  min-height: 42px !important;
  color: var(--text-muted) !important;
  font-size: 15px !important;
  font-weight: 700 !important;
}

.player-filter-control label {
  white-space: nowrap !important;
}

.player-filter-control .filter-dropdown,
.player-actions .filter-dropdown {
  width: 220px !important;
  min-height: 40px !important;
  border-radius: 0 !important;
  border: 1px solid rgba(255, 255, 255, 0.34) !important;
  background: #000 !important;
  color: #fff !important;
  padding: 8px 12px !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  cursor: pointer !important;
}

/* The hidden legacy filter button list remains only as a JS data source. */
#filter-buttons.filter-buttons.header-data-list {
  display: none !important;
}

@media (max-width: 1100px) {
  header.flex-grid {
    grid-template-columns: minmax(150px, 260px) 1fr !important;
  }

  .logo-container {
    grid-column: 1 !important;
    justify-self: start !important;
  }

  .header-dropdowns,
  .dropdown-container.header-dropdowns {
    grid-column: 2 !important;
    justify-self: end !important;
    width: min(100%, 320px) !important;
  }
}

@media (max-width: 760px) {
  header.flex-grid {
    grid-template-columns: 1fr !important;
    justify-items: center !important;
  }

  .logo-container {
    grid-column: auto !important;
    justify-self: center !important;
  }

  .header-dropdowns,
  .dropdown-container.header-dropdowns {
    grid-column: auto !important;
    justify-self: center !important;
    width: min(100%, 360px) !important;
  }

  .player-actions {
    gap: 12px !important;
  }

  .player-filter-control {
    width: 100% !important;
    justify-content: center !important;
  }

  .player-filter-control .filter-dropdown,
  .player-actions .filter-dropdown {
    width: min(100%, 260px) !important;
  }
}

@media (max-width: 520px) {
  .player-actions {
    align-items: stretch !important;
  }

  .player-filter-control {
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 6px !important;
  }

  .player-filter-control .filter-dropdown,
  .player-actions .filter-dropdown {
    width: 100% !important;
  }
}

/* =========================
   v8 refinements
   - Header is site navigation only on desktop; compact description toggle joins it on responsive.
   - Player tools stay on one line: stats left, filter right.
   - Filter options are populated from JSON tags by main.js.
   - Active thumbnail outline uses the page/header colour variable.
   - Extra playlist breathing room.
   ========================= */

/* Header: keep nav compact, reserve room for responsive description button. */
.header-description-toggle {
  display: none !important;
  min-height: 42px !important;
  padding: 8px 12px !important;
  white-space: nowrap !important;
}

.header-dropdowns,
.dropdown-container.header-dropdowns {
  grid-template-columns: minmax(220px, 320px) !important;
}

/* Player action row: left tools, right filter, no wrapping unless the viewport is extremely narrow. */
.player-actions {
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 10px !important;
  width: 100% !important;
  overflow-x: auto !important;
  overflow-y: hidden !important;
  scrollbar-width: thin !important;
  padding: 12px 0 0 !important;
}

.player-actions > button,
.player-actions > p,
.player-filter-control {
  flex: 0 0 auto !important;
}

.player-actions #like-button {
  min-height: 34px !important;
  padding: 7px 12px !important;
  font-size: 14px !important;
}

.player-actions p {
  font-size: 14px !important;
  white-space: nowrap !important;
}

.player-filter-control {
  margin-left: auto !important;
  min-height: 36px !important;
  gap: 0 !important;
}

.player-filter-control label {
  display: none !important;
}

.player-filter-control .filter-dropdown,
.player-actions .filter-dropdown {
  width: 180px !important;
  min-height: 36px !important;
  padding: 7px 10px !important;
  font-size: 14px !important;
}

/* Active/loaded thumbnail outline. Uses --brand-color so the page editor can change it per page later. */
#thumbnail-container .col {
  outline: 2px solid transparent !important;
  outline-offset: 2px !important;
}

#thumbnail-container .col.active {
  border-color: var(--brand-color) !important;
  outline-color: var(--brand-color) !important;
  box-shadow: 0 0 0 3px rgba(181, 0, 21, 0.22) !important;
}

#thumbnail-container .col.active:hover {
  border-color: var(--brand-color) !important;
}

/* Playlist breathing room. */
.playlist-body {
  padding: 22px 20px 24px !important;
}

/* The section header already says Description, so hide any older injected heading if present. */
.video-description > h3:first-child,
.dropdown-description > h3:first-child {
  display: none !important;
}

@media (max-width: 760px) {
  header.flex-grid {
    grid-template-columns: 1fr !important;
  }

  .header-dropdowns,
  .dropdown-container.header-dropdowns {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    gap: 10px !important;
    width: min(100%, 520px) !important;
  }

  .header-description-toggle {
    display: inline-flex !important;
  }

  .header-dropdowns .nav-dropdown {
    min-width: 0 !important;
  }

  .player-actions {
    gap: 8px !important;
    padding-top: 10px !important;
  }

  .player-actions #like-button {
    min-height: 32px !important;
    padding: 6px 10px !important;
    font-size: 13px !important;
  }

  .player-actions p {
    font-size: 13px !important;
  }

  .player-filter-control {
    width: auto !important;
    justify-content: flex-end !important;
    flex-direction: row !important;
    margin-left: auto !important;
  }

  .player-filter-control .filter-dropdown,
  .player-actions .filter-dropdown {
    width: 140px !important;
    min-height: 32px !important;
    padding: 6px 8px !important;
    font-size: 13px !important;
  }

  .dropdown-description:not([hidden]) {
    display: block !important;
    width: 100% !important;
  }
}

@media (max-width: 420px) {
  .header-dropdowns,
  .dropdown-container.header-dropdowns {
    grid-template-columns: minmax(0, 1fr) auto !important;
  }

  .header-description-toggle {
    min-height: 38px !important;
    padding: 7px 9px !important;
    font-size: 13px !important;
  }

  .player-actions {
    gap: 7px !important;
  }

  .player-actions #like-button,
  .player-actions p,
  .player-filter-control .filter-dropdown {
    font-size: 12px !important;
  }

  .player-filter-control .filter-dropdown,
  .player-actions .filter-dropdown {
    width: 118px !important;
  }
}


/* =========================
   v9 final polish
   - Generic --brand-color naming for page-level theming.
   - Compact, consistent control heights across menus/buttons.
   - Responsive header: menu + description toggle share space evenly.
   - Responsive playlist: centered two-column thumbnails.
   - Native iOS AirPlay only; no extra custom AirPlay button in JS.
   ========================= */
:root {
  --brand-color: #b50015;
  --brand-color-dark: #76000d;
  --control-height: 34px;
  --control-font-size: 13px;
  --control-padding-x: 10px;
}

header.flex-grid {
  background: linear-gradient(90deg, var(--brand-color), var(--brand-color-dark)) !important;
}

.section-heading {
  background: var(--brand-color) !important;
}

.btn,
.player-stats button,
.description-toggle,
.dropdown-container select,
.filter-dropdown,
.nav-dropdown,
.player-filter-control .filter-dropdown,
.player-actions .filter-dropdown {
  min-height: var(--control-height) !important;
  height: var(--control-height) !important;
  padding: 6px var(--control-padding-x) !important;
  font-size: var(--control-font-size) !important;
  line-height: 1 !important;
  border-radius: 0 !important;
}

.player-actions {
  min-height: calc(var(--control-height) + 12px) !important;
  gap: 8px !important;
  padding-top: 10px !important;
}

.player-actions #like-button {
  min-height: var(--control-height) !important;
  height: var(--control-height) !important;
  padding: 6px var(--control-padding-x) !important;
  font-size: var(--control-font-size) !important;
}

.player-actions p {
  font-size: var(--control-font-size) !important;
  line-height: var(--control-height) !important;
  margin: 0 !important;
}

.player-filter-control {
  min-height: var(--control-height) !important;
}

.player-filter-control .filter-dropdown,
.player-actions .filter-dropdown {
  width: 170px !important;
}

#thumbnail-container .col.active {
  border-color: var(--brand-color) !important;
  outline-color: var(--brand-color) !important;
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--brand-color) 26%, transparent) !important;
}

#thumbnail-container .col.active:hover {
  border-color: var(--brand-color) !important;
}

/* Responsive header: keep main menu and description toggle balanced. */
@media (max-width: 760px) {
  header.flex-grid {
    padding: 10px 14px !important;
    gap: 10px !important;
  }

  .header-dropdowns,
  .dropdown-container.header-dropdowns {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
    gap: 8px !important;
    width: min(100%, 520px) !important;
    align-items: center !important;
  }

  .header-dropdowns .nav-dropdown,
  .header-description-toggle {
    width: 100% !important;
    min-width: 0 !important;
    height: var(--control-height) !important;
    min-height: var(--control-height) !important;
    padding: 6px 8px !important;
    font-size: var(--control-font-size) !important;
    white-space: nowrap !important;
  }

  .header-description-toggle {
    justify-self: stretch !important;
  }

  /* Two across, evenly spaced, once the page enters responsive layout. */
  .flex-grid-fifths,
  #thumbnail-container {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    justify-content: center !important;
    justify-items: stretch !important;
    align-items: start !important;
    gap: 14px !important;
  }

  #thumbnail-container .col,
  .flex-grid-fifths .col,
  .col {
    width: 100% !important;
    max-width: none !important;
    justify-self: stretch !important;
  }

  .playlist-body {
    padding: 18px 14px 20px !important;
  }
}

@media (max-width: 420px) {
  :root {
    --control-height: 32px;
    --control-font-size: 12px;
    --control-padding-x: 8px;
  }

  .header-dropdowns,
  .dropdown-container.header-dropdowns {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
    gap: 6px !important;
  }

  .player-filter-control .filter-dropdown,
  .player-actions .filter-dropdown {
    width: 136px !important;
  }

  .player-actions {
    gap: 6px !important;
  }
}


/* =========================
   Theme editor additions
   - Allows bright section/header backgrounds with black or custom text.
   - These variables are picked up by the page editor and can be overridden per page.
   ========================= */
:root {
  --section-heading-bg: #b50015;
  --section-heading-text: #ffffff;
  --section-note-text: #ffffff;
}

.section-heading,
.sponsor-section .section-heading {
  background: var(--section-heading-bg) !important;
  color: var(--section-heading-text) !important;
}

.section-heading h2,
.section-heading h3,
.sponsor-section .section-heading h2,
.sponsor-section .section-heading h3 {
  color: var(--section-heading-text) !important;
}

.section-note {
  color: var(--section-note-text) !important;
}

