Greasy Fork is available in English.
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)" ) ); })();