Modern Design and Dark Theme for SoundCloud

A modern design and dark theme for SoundCloud.com, inspired by the SoundCloud Android app.

// ==UserScript==
// @name         Modern Design and Dark Theme for SoundCloud
// @version      0.23.0
// @description  A modern design and dark theme for SoundCloud.com, inspired by the SoundCloud Android app.
// @author       jottocraft
// @match        *://soundcloud.com/*
// @grant        none
// @license      MIT
// @namespace    https://greasyfork.org/users/154395
// ==/UserScript==

(function () {
    "use strict";

    // Makes a SoundCloud menu dark using the built-in styles
    function setMenuDarkMode(node) {
        if (document.documentElement.classList.contains("jtc-sc-dark")) {
            node.classList.remove("m-light");
            node.classList.add("m-dark");
        } else {
            node.classList.remove("m-dark");
            node.classList.add("m-light");
        }
    }

    // Observe DOM mutations
    const observer = new MutationObserver((mutations) => {
        mutations.forEach(({ addedNodes }) => {
            addedNodes.forEach((node) => {
                // Add toggle dark button
                if (
                    node.nodeType === 1 &&
                    node.classList.contains("headerMenu") &&
                    node.classList.contains("moreMenu")
                ) {
                    node.insertAdjacentHTML(
                        "afterBegin",
                        `<ul class="headerMenu__list sc-list-nostyle"><li><a id="jtcToggle" onmousedown="event.preventDefault();" onclick="jtcScToggleDark(); event.preventDefault();" class="headerMenu__link moreMenu__link" href="#">Toggle dark theme</a></li></ul>`
                    );
                }

                // Enable built-in dark menus
                if (
                    node.nodeType === 1 &&
                    (node.classList.contains("m-light") ||
                        node.classList.contains("m-dark"))
                ) {
                    setMenuDarkMode(node);
                }
            });
        });
    });

    // Starts the monitoring
    observer.observe(document.documentElement, {
        childList: true,
        subtree: true
    });

    // Load fonts
    const scSans500 = new FontFace(
        "SoundCloudSans",
        "url(https://cdn.jottocraft.com/userscripts/modern-sc/assets/soundcloud-sans-500.woff2)",
        { style: "normal", stretch: "normal", weight: 500 }
    );
    const scSans700 = new FontFace(
        "SoundCloudSans",
        "url(https://cdn.jottocraft.com/userscripts/modern-sc/assets/soundcloud-sans-700.woff2)",
        { style: "normal", stretch: "normal", weight: 700 }
    );
    const scSans900 = new FontFace(
        "SoundCloudSans",
        "url(https://cdn.jottocraft.com/userscripts/modern-sc/assets/soundcloud-sans-900.woff2)",
        { style: "normal", stretch: "normal", weight: 900 }
    );
    scSans500.load().then(() => document.fonts.add(scSans500));
    scSans700.load().then(() => document.fonts.add(scSans700));
    scSans900.load().then(() => document.fonts.add(scSans900));

    // Toggle dark mode
    window.jtcScToggleDark = function () {
        const isDark = document.documentElement.classList.toggle("jtc-sc-dark");
        window.localStorage.setItem("jtc-sc-isDark", isDark);
        jtcScApplyDark();
    };

    // Apply dark mode
    function jtcScApplyDark() {
        // Apply dark mode to menus
        document
            .querySelectorAll(".m-light, .m-dark")
            .forEach((node) => setMenuDarkMode(node));
    }

    // Set dark mode on load
    const darkPref = window.localStorage.getItem("jtc-sc-isDark");
    const darkSys = window.matchMedia("(prefers-color-scheme: dark)").matches;
    const useDarkMode = darkPref !== null ? darkPref === "true" : darkSys;
    if (useDarkMode) {
        document.documentElement.classList.add("jtc-sc-dark");
        jtcScApplyDark();
    }

    // Insert CSS at the very end of the document
    // so it can safely override SoundCloud styles without !important.
    function addCss(cssString) {
        const newCss = document.createElement("style");
        newCss.type = "text/css";
        newCss.innerHTML = cssString;
        document.body.appendChild(newCss);
    }

    addCss(`
:root {
    --jtc-sc-root-text: #000000;
    --jtc-sc-bg: #ffffff;
    --jtc-sc-header: #000000;
    --jtc-sc-header-active: #080808;
    --jtc-sc-header-border: #111;
    --jtc-sc-border-light: #f2f2f2;
    --jtc-sc-tag-bg: #f3f3f3;
    --jtc-sc-tag-hover-bg: #eaeaea;
    --jtc-sc-light-text: #939393;
    --jtc-sc-btn-main: #000000;
    --jtc-sc-btn-main-text: #ffffff;
    --jtc-sc-btn: #f0f0f0;
    --jtc-sc-tile: #fbfbfb;
    --jtc-sc-btn-hover: #e6e6e6;
    --jtc-sc-text-verylight: #b1b1b1;
    --jtc-sc-almost-root-text: #3b3b3b;
    --jtc-sc-header-search: #f3f3f3;
    --jtc-sc-border: #d5d5d5;
    --jtc-sc-whiteout: #ffffffe6;
    --jtc-sc-block: #f3f3f3;
    --jtc-sc-bar: #ffffff;
    --jtc-sc-popup: #ffffff;
}

:root.jtc-sc-dark {
    --jtc-sc-root-text: #ffffff;
    --jtc-sc-bg: #000000;
    --jtc-sc-header: #111;
    --jtc-sc-header-active: #0c0c0c;
    --jtc-sc-header-border: #1a1a1a;
    --jtc-sc-border-light: #212121;
    --jtc-sc-tag-bg: #262626;
    --jtc-sc-tag-hover-bg: #424242;
    --jtc-sc-light-text: #bfbfbf;
    --jtc-sc-btn-main: #ffffff;
    --jtc-sc-btn-main-text: #000000;
    --jtc-sc-btn: #272727;
    --jtc-sc-tile: #0a0a0a;
    --jtc-sc-btn-hover: #373737;
    --jtc-sc-text-verylight: #707070;
    --jtc-sc-almost-root-text: #e8e8e8;
    --jtc-sc-header-search: #242424;
    --jtc-sc-border: #585858;
    --jtc-sc-whiteout: #000000e6;
    --jtc-sc-block: #101010;
    --jtc-sc-bar: #282828;
    --jtc-sc-popup: #181818;
}
`);

    addCss(
        `
:root.jtc-sc-dark {
  color-scheme: dark;
}

body {
  color: var(--jtc-sc-root-text);
  background: var(--jtc-sc-bg);
}

body.sc-classic,
.sc-font {
  font-family: SoundCloudSans, system-ui, -apple-system, Segoe UI, Roboto,
    Lucida Grande, sans-serif, Apple Color Emoji, Segoe UI EmojiSoundCloudSans,
    system-ui, -apple-system, Segoe UI, Roboto, Lucida Grande, sans-serif,
    Apple Color Emoji, Segoe UI Emoji;
}

.sc-classic .sidebarHeader__title,
.sc-text,
button,
input,
select,
textarea {
  color: var(--jtc-sc-root-text);
}

.sc-classic .header {
  background-color: var(--jtc-sc-header);
}

.sc-classic .sound__soundActions {
  background-color: var(--jtc-sc-bg);
}

.sc-classic .header {
  font-size: 14px;
  font-weight: 400;
  font-family: inherit;
}

.sc-input {
  font-family: inherit;
}

.sc-classic .insightsSidebarModule__title {
  color: var(--jtc-sc-root-text);
}

.sc-classic .headerMenu,
.sc-font-light,
.sc-type-light,
.sc-classic .spotlightTitle,
.sc-classic .userstream__header {
  font-weight: 400;
  font-family: inherit;
}

.sc-classic .header > li > a:focus,
.sc-classic .header__navMenu > li > a.selected {
  text-decoration: underline;
  background-color: var(--jtc-sc-header-active);
}

.sc-type-h1,
.sc-type-h2,
.sc-type-h3,
.sc-type-h4,
.sc-type-h5,
.sc-type-h6,
h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: inherit;
}

.sc-type-large {
  font-size: 20px;
  font-weight: 400;
}

.sc-type-light:not(.systemPlaylistBannerItem) {
  color: var(--jtc-sc-light-text):
}

.sc-classic .profileMenu.m-dark .headerMenu__link:after {
  filter: brightness(100) saturate(0);
}

.sc-classic .profileMenu__insights:after {
  background-image: url();
  background-size: 16px;
  background-position: 50%;
}

:root.jtc-sc-dark .sc-classic .banner.m-alert {
  background-color: #290c0c;
}

.sc-classic .notificationBadge--unread {
  background-color: var(--jtc-sc-tile);
}

:root.jtc-sc-dark .sc-classic .featureHeader__closeButton, :root.jtc-sc-dark .sc-classic .g-button-remove {
  filter: invert(1) brightness(2);
}

:root.jtc-sc-dark .sc-classic .loading {
  filter: invert(1);
}

:root:not(.jtc-sc-dark) .systemPlaylistBannerItem .sc-button-icon:before {
  filter: brightness(0) grayscale(1);
}

.sc-classic .header__navMenu > li > a {
  border-color: var(--jtc-sc-header-border);
}

.sc-border-light,
.sc-border-light-top,
.sc-border-light-right,
.sc-border-light-bottom,
.sc-border-light-left {
  border-color: var(--jtc-sc-border-light);
}

.sc-classic .listenContent__inner {
  background-color: var(--jtc-sc-bg);
}

.sc-classic .l-fluid-fixed .l-main,
.sc-classic .sidebarHeader {
  border: none;
}

.sc-classic .headerMenu__link:not(.m-highlight),
.sc-classic .headerMenu__link:not(.m-highlight):focus,
.sc-classic .headerMenu__link:not(.m-highlight):hover {
  color: var(--jtc-sc-root-text);
}

.sc-classic .l-fixed-top-one-column > .l-top {
  background: var(--jtc-sc-bg);
}

.sc-classic .sidebarHeader,
.sc-classic .sidebarHeader__more {
  font-weight: 400;
}

.sidebarHeader__icon {
  filter: brightness(0) grayscale(1);
}

.sc-classic .textfield__clear:after,
.sc-classic .textfield__clear:before {
  border-color: var(--jtc-sc-root-text);
}

.sc-classic .textfield__clear {
  background-color: var(--jtc-sc-border);
}

:root.jtc-sc-dark .sidebarHeader__icon {
  filter: brightness(100) grayscale(1);
}

.soundBadge__artwork .sc-artwork {
  border-radius: 4px;
}

.sc-classic .infoStats__value {
  color: var(--jtc-sc-almost-root-text);
}

.listenNetworkInfo__imageLink .sc-artwork {
  border-radius: 6px;
}

.sc-classic .createPlaylistSuggestion__addContainer {
  background: linear-gradient(
    90deg,
    hsl(0deg 0% 100% / 0%),
    var(--jtc-sc-popup) 20px
  );
}

.playableTile__artwork {
  border-radius: 6px;
  overflow: hidden;
}

.sc-button-dropdown:focus:not(.sc-button-disabled):not(:disabled) {
  box-shadow: 0 0 0 4px var(--jtc-sc-border);
}

:root.jtc-sc-dark .soundBadge.playlist .soundBadge__artwork  {
  filter: invert(1);
}

:root.jtc-sc-dark .soundBadge.playlist .soundBadge__artwork > * {
  filter: invert(1);
}

:root.jtc-sc-dark
  .sc-classic
  .emptyNetworkPage.emptyReposts
  .emptyNetworkPage__image,
:root.jtc-sc-dark
  .sc-classic
  .emptyNetworkPage.emptyAlbums
  .emptyNetworkPage__image,
:root.jtc-sc-dark
  .sc-classic
  .emptyNetworkPage.emptyTracks
  .emptyNetworkPage__image {
  filter: invert(1);
}

:root.jtc-sc-dark .sc-button-medium.sc-button-like:before {
  filter: invert(1);
}

.sc-classic .showSpotlightUpsellBanner.spotlightUpsellBanner {
  border-color: var(--jtc-sc-border);
}

.sound__coverArt {
  border-radius: 6px;
  overflow: hidden;
}

.selectionPlaylistBanner__artwork {
  border-radius: 8px;
  overflow: hidden;
}

.sc-classic .g-modal-section {
  background-color: var(--jtc-sc-popup);
}

.sc-classic .readMoreTile__countWrapper {
  background-color: var(--jtc-sc-bg);
}

.sc-classic .playbackTimeline {
  font-size: 14px;
}

.sc-classic .fullHero__artwork {
  border-radius: 10px;
  overflow: hidden;
}

.sc-tag,
.sc-tag:visited {
  background-color: var(--jtc-sc-tag-bg);
  color: var(--jtc-sc-root-text);
  font-weight: 400;
  border: none;
}

.sc-tag-small,
.sc-tag-small:visited {
  height: 18px;
  padding: 0 8px;
  line-height: 18px;
  font-size: 14px;
}

.sc-tag:hover {
  background-color: var(--jtc-sc-tag-hover-bg);
  color: var(--jtc-sc-root-text);
}

.sc-classic .compactTrackListItem,
.sc-classic .compactTrackList {
  border: none;
}

.sc-classic .compactTrackListItem {
  height: 32px;
}

.sc-classic .compactTrackListItem__image {
  margin: 0 5px 0 0;
}

.sc-classic .listenLogin {
  background-color: var(--jtc-sc-tile);
}

.sc-classic .editTrackItem.m-active, .sc-classic .editTrackItem.m-hover {
  background-color: var(--jtc-sc-tile);
}

.sc-classic .editTrackItem__additional {
  background: linear-gradient(90deg,transparent,var(--jtc-sc-popup) 17px);
}

.sc-classic .editTrackItem.m-active .editTrackItem__additional, .sc-classic .editTrackItem.m-hover .editTrackItem__additional {
  background: linear-gradient(90deg,transparent,var(--jtc-sc-tile) 17px);
}

.sc-classic .soundTitle__uploadTime {
  color: var(--jtc-sc-light-text);
  font-weight: 400;
}

.sc-classic .g-tabs,
.infoStats__stat,
.sc-border-light-top.g-box-full,
.sc-classic .mixedSelectionModule,
.sc-classic .l-footer.standard {
  border: none;
  font-family: inherit;
}

.sc-classic .g-type-shrinkwrap-block,
.sc-classic .g-type-shrinkwrap-block:hover,
.sc-classic .g-type-shrinkwrap-block:visited,
.sc-classic .g-type-shrinkwrap-inline,
.sc-classic .g-type-shrinkwrap-inline:hover,
.sc-classic .g-type-shrinkwrap-inline:visited {
  background-color: #000000b3;
  backdrop-filter: blur(10px);
  border-radius: 2px;
}

.sc-classic .g-type-shrinkwrap-large-primary,
.sc-classic .g-type-shrinkwrap-primary,
.sc-classic .g-type-shrinkwrap-large-secondary,
.sc-classic .g-type-shrinkwrap-large-secondary:visited,
.sc-classic .g-type-shrinkwrap-secondary,
.sc-classic .g-type-shrinkwrap-secondary:visited {
  font-weight: 400;
}

.sc-classic .g-tabs-link.active {
  font-weight: 700;
}

.sc-button$BTN_EXCLUDE {
  border: none;
  background-color: var(--jtc-sc-btn);
  color: var(--jtc-sc-root-text);
  font-weight: 400;
  border-radius: 5px;
  font-family: inherit;
}

.moreActions .sc-button:not(:hover)$BTN_EXCLUDE {
  background-color: transparent;
}

.sc-button:hover$BTN_EXCLUDE {
  background-color: var(--jtc-sc-btn-hover);
}

.sc-classic .recipientChooser .tokenInput__wrapper {
  background-color: var(--jtc-sc-bg);
}

.sc-classic .currentPlan__planUpsell,
.sc-classic .currentPlan__planContainer {
  background-color: var(--jtc-sc-bg);
}

:root.jtc-sc-dark
  .sc-button:not(.sc-button-selected):not(.sc-button-active):not(
    .sc-button-medium.sc-button-like
  ):not(.sc-button-follow)$BTN_EXCLUDE:before {
  filter: brightness(100) grayscale(1);
}

.trackItem__image .sc-artwork {
  border-radius: 4px;
}

.sc-classic .tokenInput__token {
  background-color: var(--jtc-sc-btn);
}

.sc-button:not(.sc-button-more).sc-button-active$BTN_EXCLUDE,
.sc-button:not(.sc-button-more).sc-button-selected$BTN_EXCLUDE {
  background-color: #f50;
  color: white;
}

.sc-button.sc-button-more.sc-button-active$BTN_EXCLUDE,
.sc-button.sc-button-more.sc-button-selected$BTN_EXCLUDE {
  background-color: var(--jtc-sc-btn-hover);
}

.sc-button-active:not(.sc-button-more)$BTN_EXCLUDE:before,
.sc-button-selected:not(.sc-button-more)$BTN_EXCLUDE:before {
  filter: brightness(100) grayscale(1);
}

.sc-button.sc-button-follow:not(.sc-button-selected):not(
    .sc-button-active
  )$BTN_EXCLUDE {
  background-color: var(--jtc-sc-btn-main);
  color: var(--jtc-sc-btn-main-text);
}

.sc-button.sc-button-follow:not(.sc-button-selected):not(
    .sc-button-active
  )$BTN_EXCLUDE:before {
  filter: brightness(100) grayscale(1);
}

:root.jtc-sc-dark
  .sc-button.sc-button-follow:not(.sc-button-selected):not(
    .sc-button-active
  )$BTN_EXCLUDE:before {
  filter: brightness(0) grayscale(1);
}

a.sc-link-dark {
  color: var(--jtc-sc-root-text);
}

a.sc-link-light {
  color: var(--jtc-sc-light-text);
}

.sc-type-large,
.sc-classic .mixedSelectionModule__titleText {
  color: var(--jtc-sc-root-text);
  font-weight: 700;
}

.sc-classic .listenEngagement,
.sc-classic .l-listen-wrapper .l-about-rows,
.sc-clearfix.sc-border-light-bottom {
  border: none;
  box-shadow: none;
}

.sc-type-medium,
.sc-type-small,
.sc-ministats,
.sc-buylink-medium {
  font-weight: 400;
  font-family: inherit;
}

a.sc-link-verylight {
  color: var(--jtc-sc-text-verylight);
}

.sc-classic .soundBadge__additional {
  background: linear-gradient(
    90deg,
    hsl(0deg 0% 100% / 0%),
    var(--jtc-sc-bg) 17px
  );
}

.sc-classic
  .truncatedAudioInfo.m-overflow.m-collapsed
  .truncatedAudioInfo__wrapper:after {
  background: linear-gradient(hsla(0, 0%, 100%, 0), var(--jtc-sc-bg));
}

.sc-classic .g-tabs-link:not(.g-tabs-link.active),
.sc-classic .g-tabs-link:visited:not(.g-tabs-link.active),
.sc-buylink {
  color: var(--jtc-sc-almost-root-text);
}

:root.jtc-sc-dark .backgroundGradient {
  filter: brightness(0.4) saturate(1.6);
}

.sc-classic
  .truncatedUserDescription.m-overflow.m-collapsed
  .truncatedUserDescription__wrapper:after {
  background: linear-gradient(hsla(0, 0%, 100%, 0), var(--jtc-sc-bg));
}

.sc-classic .dropbar__content {
  background-color: var(--jtc-sc-bg);
}

.sc-classic .image__whiteOutline .image__full {
  border-color: var(--jtc-sc-bg);
}

.sc-classic .moreActions {
  border-color: var(--jtc-sc-btn-hover);
}

.sc-classic .compactTrackListItem__number,
.sc-classic .compactTrackListItem__trackTitle {
  color: var(--jtc-sc-root-text);
}

.sc-classic .compactTrackListItem__user,
.sc-ministats-small:not(.sc-ministats-inverted) {
  color: var(--jtc-sc-light-text);
}

.sc-classic .compactTrackListItem.clickToPlay.active,
.sc-classic .compactTrackListItem.clickToPlay:focus,
.sc-classic .compactTrackListItem.clickToPlay:hover,
.sc-classic .compactTrackList__moreLink:focus,
.sc-classic .compactTrackList__moreLink:hover {
  background-color: var(--jtc-sc-btn-hover);
  color: var(--jtc-sc-root-text);
}

.sc-classic
  .compactTrackListItem.clickToPlay.active
  .compactTrackListItem__additional,
.sc-classic
  .compactTrackListItem.clickToPlay:focus
  .compactTrackListItem__additional,
.sc-classic
  .compactTrackListItem.clickToPlay:hover
  .compactTrackListItem__additional {
  background: linear-gradient(
    90deg,
    hsla(0, 0%, 100%, 0),
    var(--jtc-sc-btn-hover) 17px
  );
}

.sc-classic .tileGallery__sliderButton:after {
  border-color: var(--jtc-sc-root-text);
}

.sc-classic .searchTitle {
  background-color: var(--jtc-sc-bg);
}

.sc-classic .searchTitle__text,
.sc-classic .g-form-section-head {
  border: none;
}

.sc-classic .g-nav-item:not(.active) > .g-nav-link {
  color: var(--jtc-sc-root-text);
}

.sc-classic .g-nav-item:not(.active) .g-nav-link {
  filter: brightness(0) grayscale(1);
}

:root.jtc-sc-dark .sc-classic .g-nav-item:not(.active) .g-nav-link {
  filter: brightness(100) grayscale(1);
}

.sc-classic .g-form-section-title {
  color: var(--jtc-sc-almost-root-text);
  font-weight: 400;
}

.sc-classic .hintButton,
.sc-ministats-small.sc-ministats-sounds:before {
  filter: brightness(0) grayscale(1);
}

:root.jtc-sc-dark .sc-classic .hintButton,
:root.jtc-sc-dark .sc-ministats-small.sc-ministats-sounds:before,
:root.jtc-sc-dark .sc-classic .reportCopyright {
  filter: brightness(100) grayscale(1);
}

input,
select,
textarea {
  background-color: var(--jtc-sc-bg);
  border-color: var(--jtc-sc-border);
  border-width: 1.5px;
  font-weight: 400;
}

.g-dark input[type="password"],
.g-dark input[type="search"],
.g-dark input[type="text"],
.g-dark select,
.g-dark textarea {
  background-color: var(--jtc-sc-header-search);
}

.sc-select {
  font-weight: 400;
}

.sc-toggle {
  background-color: var(--jtc-sc-btn);
  border-color: var(--jtc-sc-btn);
}

.sc-toggle-handle {
  background-color: var(--jtc-sc-bg);
}

.sc-classic .commentForm__input {
  border: none;
  border-bottom: 2px solid var(--jtc-sc-bg);
  border-radius: 0px;
  transition: border-color 0.2s;
  padding: 0;
  margin: 0 9px;
}

.sc-classic .commentForm__inputWrapper.focused .commentForm__input {
  border-color: var(--jtc-sc-border);
}

.sc-classic .commentForm__wrapper {
  background-image: none;
  background-color: var(--jtc-sc-bg);
  border: none;
}

.sc-classic .audibleEditForm__audio,
.sc-classic .audibleEditForm__form,
.sc-classic .tabs__headingContainer,
.sc-classic .tabs__tabs,
.sc-classic .uploadMain__foot,
.sc-classic .uploadMain__chooserContainer,
.sc-classic .quotaMeterWrapper {
  background-color: var(--jtc-sc-popup);
}

.sc-classic .tagInput__wrapper {
  background-color: var(--jtc-sc-bg);
}

.sc-classic .editTrackList__list .sortable-placeholder {
  background-color: var(--jtc-sc-tile);
  border-color: var(--jtc-sc-border);
}

.sc-classic .profileUploadFooter,
.sc-classic .trackManager__upsellWrapper {
  background-color: var(--jtc-sc-bg);
}

.sc-classic .soundBadge.active:not(.compact),
.sc-classic .soundBadge.hover:not(.compact),
.sc-classic .soundBadge.selected:not(.compact),
.sc-classic .soundBadge:hover:not(.compact) {
  background-color: var(--jtc-sc-tile);
}

.sc-classic .soundBadge.active:not(.compact) .soundBadge__additional,
.sc-classic .soundBadge.hover:not(.compact) .soundBadge__additional,
.sc-classic .soundBadge.selected:not(.compact) .soundBadge__additional,
.sc-classic .soundBadge:hover:not(.compact) .soundBadge__additional {
  background: linear-gradient(90deg, transparent, var(--jtc-sc-tile) 17px);
}

:root.jtc-sc-dark .sc-classic .quotaMeter__dropdownButton:after {
  filter: invert(1);
}

.sc-button.sc-button-translucent:not(.sc-button-cta) {
  background-color: var(--jtc-sc-btn);
}

.sc-classic .modal.modalWhiteout {
  background-color: var(--jtc-sc-whiteout);
}

.sc-classic .dialog,
.sc-classic .dialog__arrow {
  background-color: var(--jtc-sc-popup);
  border-color: var(--jtc-sc-border);
}

.sc-classic .linkMenu {
  background-color: var(--jtc-sc-bg);
  border: 1px solid var(--jtc-sc-border);
}

.sc-classic .g-upsell-container,
.sc-classic .sidebarInfoBox__body {
  background-color: var(--jtc-sc-block);
  border-color: var(--jtc-sc-border);
}

.sc-classic .blockCheckbox,
.sc-text-light {
  color: var(--jtc-sc-light-text);
}

.sc-classic .blockCheckbox__title {
  color: var(--jtc-sc-root-text);
}

:root.jtc-sc-dark
  .sc-classic
  .blockCheckbox:not(.m-checked)
  .blockCheckbox__icon {
  filter: grayscale(1) brightness(0.2);
}

.sc-background-white {
  background-color: var(--jtc-sc-bg);
}

.sc-classic .modal__modal {
  background-color: var(--jtc-sc-popup);
  border-color: var(--jtc-sc-border);
}

.sc-background-light,
.statsOverview__separator {
  background-color: var(--jtc-sc-block);
}

.topStatsItemPlaceholder__text:after,
.topStatsItemPlaceholder__text:before {
  background-color: var(--jtc-sc-light-text);
}

.sc-classic .moreActions__group:not(:first-child),
.topStatsModule__item,
.sc-border-dark,
.topStatsItemPlaceholder.listener .topStatsItemPlaceholder__visual {
  border-color: var(--jtc-sc-border);
}

.sc-classic .paging-eof:before {
  background: none;
}

.sc-classic .collection.m-overview .collection__section:not(:last-child),
.sc-classic .g-modal-title-h1 {
  border: none;
}

.sc-classic .playControls__bg,
.sc-classic .playControls__inner,
.sc-classic .volume__sliderWrapper {
  background-color: var(--jtc-sc-bar);
}

.sc-classic .playControls__inner {
  box-shadow: 0 -4px 6px -1px rgb(0 0 0 / 10%), 0 2px 4px -2px rgb(0 0 0 / 10%);
}

.sc-classic .playControls__bg,
.sc-classic .playControls__inner {
  border-color: var(--jtc-sc-border);
}

.sc-classic .soundContext__line {
  color: var(--jtc-sc-light-text);
}

:root.jtc-sc-dark
  .sc-classic
  .playControls__elements
  .playControls__control
  .shuffleControl:not(.m-shuffling),
:root.jtc-sc-dark
  .sc-classic
  .playControls__elements
  .playControls__control
  .repeatControl.m-none,
:root.jtc-sc-dark
  .sc-classic
  .playControls__elements
  .playControls__control.playControl,
:root.jtc-sc-dark
  .sc-classic
  .playControls__elements
  .playControls__control.skipControl,
:root.jtc-sc-dark .sc-classic .volume__button,
:root.jtc-sc-dark
  .sc-classic
  .playbackSoundBadge__follow:not(.sc-button-selected),
:root.jtc-sc-dark
  .sc-classic
  .playbackSoundBadge__like:not(.sc-button-selected) {
  filter: brightness(100) grayscale(1);
}

:root.jtc-sc-dark .sc-classic .queue__hide {
  filter: invert(1);
}

:root.jtc-sc-dark .sc-classic .queueItemView__more.sc-button-small:before,
:root.jtc-sc-dark
  .sc-button-small.queueItemView__like:not(.sc-button-selected):before {
  filter: brightness(100) grayscale(1);
}

.sc-classic .playbackTimeline__progressBackground,
.sc-classic .volume__sliderBackground {
  background-color: var(--jtc-sc-border);
}

.sc-classic .volume__sliderWrapper:before,
.sc-classic .volume__sliderWrapper:after {
  border-color: transparent transparent var(--jtc-sc-border)
    var(--jtc-sc-border);
}

.sc-classic .volume.expanded .volume__sliderWrapper {
  border-color: var(--jtc-sc-border);
}

.sc-classic .playControls__castControl > #castbutton {
  --disconnected-color: var(--jtc-sc-root-text);
}

.sc-classic
  .playbackSoundBadge:not(.m-queueVisible)
  .playbackSoundBadge__queueIcon {
  fill: var(--jtc-sc-root-text);
}

.sc-classic .gritter-item-wrapper {
  background-color: var(--jtc-sc-block);
  color: var(--jtc-sc-root-text);
  border-color: var(--jtc-sc-border);
}

.sc-classic .playbackTimeline__duration {
  color: var(--jtc-sc-light-text);
}

.sc-classic .playbackSoundBadge__titleLink,
.sc-classic .playbackSoundBadge__titleLink:visited {
  color: var(--jtc-sc-root-text);
}

.sc-classic .queue,
.sc-classic .queue__itemWrapper {
  background-color: var(--jtc-sc-popup);
}

.sc-classic .queue__itemsHeight {
  background: var(--jtc-sc-popup);
}

.sc-classic .queue__panel {
  border-color: var(--jtc-sc-border);
}

.sc-classic .queueFallback__stationMode,
.sc-classic .queue__panel {
  border: none;
}

.sc-classic .keyboardShortcuts__shortcutsGroup > dl > dt > kbd > kbd {
  background-color: var(--jtc-sc-btn);
}

.sc-classic .queueItemView.m-active,
.sc-classic .queueItemView:hover {
  background-color: var(--jtc-sc-btn-hover);
}

.sc-classic .moreActions {
  background-color: var(--jtc-sc-popup);
  padding: 4px;
  border-radius: 5px;
}

.sc-classic .headerMenu {
  padding: 0px 4px;
  border-radius: 5px;
  margin-top: 4px;
  border: 1px solid var(--jtc-sc-border);
  background-color: var(--jtc-sc-popup);
  font-family: inherit;
}

.sc-classic .headerMenu__list {
  padding: 4px 0px;
}

.sc-classic .headerMenu__list li .headerMenu__link {
  border-radius: 5px;
}

.sc-classic .dropdownContent__container {
  background-color: var(--jtc-sc-popup);
}

.sc-classic .dropdownContent__header,
.sc-classic .dropdownContent__main,
.sc-classic .dropdownContent__container,
.sc-classic .dropdownContent__listItem,
.sc-classic .activitiesListFull__item + .activitiesListFull__item,
.sc-classic .composeMessage__bottomWrapper {
  border-color: var(--jtc-sc-border);
}

.sc-classic .notificationBadge__main {
  font-weight: 400;
  color: var(--jtc-sc-light-text);
}

.sc-classic .conversation__actions {
  background-color: var(--jtc-sc-bg);
  box-shadow: none;
}

.sc-classic .conversation__form {
  border: none;
}

.sc-classic .inbox__item:before {
  background-color: var(--jtc-sc-bg);
}

.sc-classic .inboxItem.active,
.sc-classic .inboxItem.unread,
.sc-classic .inboxItem:focus,
.sc-classic .inboxItem:hover {
  background-color: var(--jtc-sc-btn-hover);
}

.sc-classic .trackItem.active,
.sc-classic .trackItem.hover {
  background-color: var(--jtc-sc-btn-hover);
}

.sc-classic .trackItem:not(.m-disabled).active .trackItem__additional,
.sc-classic .trackItem:not(.m-disabled).hover .trackItem__additional {
  background: linear-gradient(
    90deg,
    hsla(0, 0%, 100%, 0),
    var(--jtc-sc-btn-hover) 17px
  );
}

.sc-classic .commentPopover.darkText .commentPopover__body {
  color: var(--jtc-sc-root-text);
}

.commentItem__body,
.commentItem__creatorLink, .commentItem__creatorLink:hover, .commentItem__creatorLink:visited, .commentItem__username, .commentItem__usernameLink, .commentItem__usernameLink:hover, .commentItem__usernameLink:visited,
.commentItem__replyButton, .commentItem__replyButton:hover, .commentItem__replyButton:visited {
  color: var(--jtc-sc-root-text);
}

.commentItem__createdAt, .commentItem__separator, .commentItem__timestamp {
  color: var(--jtc-sc-light-text);
}

.commentItem__timestampLink, .commentItem__timestampLink:hover, .commentItem__timestampLink:visited {
  background-color: var(--jtc-sc-tag-bg);
  color: #38d;
}

.uiEvoButton--isLight.commentItem__likeButton {
  background-color: var(--jtc-sc-bg);
}

.uiEvoButton--isLight, .uiEvoButton:hover.uiEvoButton--isLight, .uiEvoButton:link.uiEvoButton--isLight, .uiEvoButton:visited.uiEvoButton--isLight {
  background-color: var(--jtc-sc-btn);
  color: var(--jtc-sc-root-text);
}

.sc-classic .commentFormDisabled {
  background-color: var(--jtc-sc-bg);
}
`
            .replaceAll(";\n", " !important;\n")
            .replaceAll(":\n", ";\n")
            .replaceAll(
                "$BTN_EXCLUDE",
                ":not(.reportCopyright):not(.hintButton):not(.sc-classic .playbackSoundBadge .playbackSoundBadge__follow):not(.sc-classic .playbackSoundBadge .playbackSoundBadge__like):not(.sc-button-nostyle):not(.sc-button-next):not(.sc-button-pause):not(.sc-button-play):not(.sc-button-prev):not(.sc-button-blocked)"
            )
    );
})();