607 lines
18 KiB
CSS
607 lines
18 KiB
CSS
/* ================================
|
|
USER-EDITABLE VARIABLES
|
|
================================ */
|
|
|
|
:root {
|
|
/* top bar vars */
|
|
--top-bar-padding-top: 45px;
|
|
--top-bar-padding-right: 20px;
|
|
--top-bar-padding-bottom: 5px;
|
|
--top-bar-padding-left: 20px;
|
|
--tab-border-radius: 6px;
|
|
--top-bar-border-width: 2px;
|
|
|
|
/* sidebar vars */
|
|
--sidebar-button-border-radius: 4px;
|
|
--sidebar-border-width: 2px;
|
|
|
|
/* player vars */
|
|
--player-height: 90px;
|
|
--player-padding: 0 20px;
|
|
--player-border-width: 2px;
|
|
|
|
/* scrollbar vars */
|
|
--scrollbar-border-radius: 4px;
|
|
--scrollbar-width: 6px;
|
|
--scrollbar-width-hover: 6px;
|
|
}
|
|
|
|
/* ================================
|
|
TOPBAR
|
|
================================ */
|
|
|
|
.spotify__container--is-desktop:not(.fullscreen) .main-topBar-container,
|
|
.spotify__container--is-desktop:not(.fullscreen) .main-topBar-background {
|
|
-webkit-app-region: drag !important;
|
|
}
|
|
.Root__top-container {
|
|
/* rearrange grid layout */
|
|
grid-template-areas:
|
|
". . ."
|
|
"left-sidebar main-view right-sidebar"
|
|
"now-playing-bar now-playing-bar now-playing-bar";
|
|
grid-template-rows:
|
|
calc(var(--top-bar-padding-top) + 40px + var(--top-bar-padding-bottom))
|
|
1fr auto;
|
|
overflow: hidden !important;
|
|
}
|
|
.Root__nav-bar {
|
|
grid-area: left-sidebar !important;
|
|
}
|
|
.Root__right-sidebar {
|
|
grid-area: right-sidebar !important;
|
|
}
|
|
.Root__now-playing-bar {
|
|
grid-area: now-playing-bar !important;
|
|
}
|
|
.body-drag-top {
|
|
/* make whole top bar draggable */
|
|
height: calc(
|
|
var(--top-bar-padding-top) + 40px + var(--top-bar-padding-bottom)
|
|
) !important;
|
|
}
|
|
.main-topBar-container,
|
|
.main-topBar-container:empty {
|
|
/* customize top bar */
|
|
position: fixed;
|
|
top: 0;
|
|
left: 0;
|
|
padding-top: var(--top-bar-padding-top);
|
|
padding-right: var(--top-bar-padding-right);
|
|
padding-bottom: var(--top-bar-padding-bottom);
|
|
padding-left: var(--top-bar-padding-left);
|
|
height: calc(
|
|
var(--top-bar-padding-top) + 40px + var(--top-bar-padding-bottom)
|
|
);
|
|
width: 100%;
|
|
border-bottom: var(--top-bar-border-width) solid var(--spice-topbar-border);
|
|
}
|
|
.main-topBar-container .contentSpacing {
|
|
max-width: unset;
|
|
padding: 0;
|
|
}
|
|
.main-topBar-background {
|
|
/* remove background upon scrolling */
|
|
opacity: 0 !important;
|
|
}
|
|
.queue-tabBar-active {
|
|
/* customize active tab */
|
|
border-radius: var(--tab-border-radius);
|
|
}
|
|
[dir="ltr"] .collection-collection-tabBar,
|
|
.queue-tabBar-nav {
|
|
/* remove tab bar left padding */
|
|
padding-left: 0;
|
|
padding-inline-start: 0;
|
|
}
|
|
.main-topBar-topbarContent {
|
|
/* add bigger gap between play button and name */
|
|
gap: 16px;
|
|
}
|
|
.x-searchInput-searchInputInput {
|
|
height: 41px;
|
|
}
|
|
.x-searchInput-searchInputInput:hover,
|
|
.x-searchInput-searchInputInput:focus,
|
|
.x-entityImage-imageContainer {
|
|
box-shadow: none;
|
|
}
|
|
.x-searchInput-searchInputInput,
|
|
.x-filterBox-filterInput {
|
|
border-radius: var(--tab-border-radius);
|
|
}
|
|
|
|
/* ================================
|
|
NAVBAR / LEFT SIDEBAR
|
|
================================ */
|
|
|
|
.Root__nav-bar {
|
|
/* add border */
|
|
border-right: var(--sidebar-border-width) solid var(--spice-sidebar-border);
|
|
}
|
|
.LayoutResizer__resize-bar--resizing,
|
|
.LayoutResizer__resize-bar:focus-within,
|
|
.LayoutResizer__resize-bar:hover {
|
|
/* remove border on hovering layout resizer */
|
|
opacity: 0;
|
|
}
|
|
.LayoutResizer__resize-bar {
|
|
/* replace cursor on layout resize */
|
|
cursor: w-resize;
|
|
width: 2px;
|
|
}
|
|
.LayoutResizer__inline-end {
|
|
inset-inline-end: 0;
|
|
}
|
|
.main-yourLibraryX-entryPoints,
|
|
.Root__main-view {
|
|
border-radius: 0;
|
|
}
|
|
.main-yourLibraryX-navItems {
|
|
padding-bottom: 0;
|
|
}
|
|
.main-yourLibraryX-navItem,
|
|
.main-yourLibraryX-headerContent {
|
|
padding: 4px 0;
|
|
}
|
|
.main-yourLibraryX-header {
|
|
padding-top: 0;
|
|
}
|
|
.main-yourLibraryX-navItem {
|
|
padding: 4px 0;
|
|
}
|
|
.main-yourLibraryX-navLink {
|
|
padding: 12px;
|
|
text-decoration: none !important;
|
|
}
|
|
.main-yourLibraryX-navLink,
|
|
.main-yourLibraryX-header .main-yourLibraryX-collapseButtonWrapper {
|
|
gap: 20px;
|
|
}
|
|
.Wrapper-md-leading {
|
|
margin-inline-end: 0;
|
|
}
|
|
|
|
/* ================================
|
|
MAIN VIEW
|
|
================================ */
|
|
|
|
.main-view-container__scroll-node-child-spacer {
|
|
/* remove main view padding */
|
|
display: none;
|
|
}
|
|
.marketplace-header,
|
|
.main-home-filterChipsContainer,
|
|
.main-trackList-trackListHeader,
|
|
.search-searchCategory-SearchCategory,
|
|
.artist-artistDiscography-topBar {
|
|
/* fix home filter, track list header, search category, artist discography */
|
|
top: -1px !important;
|
|
height: auto;
|
|
}
|
|
.LVMjmN2CaPruPAo62RAY {
|
|
height: unset !important;
|
|
}
|
|
.marketplace-header,
|
|
.main-home-filterChipsContainer,
|
|
.search-searchCategory-SearchCategory {
|
|
/* home filter, fix search category */
|
|
border-bottom: 1px solid rgba(var(--spice-rgb-selected-row), 0.1);
|
|
padding: 16px 0;
|
|
}
|
|
.search-searchCategory-catergoryGrid button {
|
|
margin-bottom: 0 !important;
|
|
}
|
|
.search-searchCategory-catergoryGrid button[aria-checked="true"] span {
|
|
/* customize active search category */
|
|
border-radius: var(--tab-border-radius);
|
|
}
|
|
.main-trackList-trackListHeader,
|
|
.artist-artistDiscography-topBar {
|
|
/* fix track list header & artist discography */
|
|
padding: 16px 32px 0 32px;
|
|
}
|
|
.main-trackList-trackListHeaderStuck.main-trackList-trackListHeader,
|
|
.artist-artistDiscography-topBar.artist-artistDiscography-topBarScrolled {
|
|
/* fix tracklist header & artist discography */
|
|
box-shadow: none;
|
|
border-bottom: 1px solid rgba(var(--spice-rgb-selected-row), 0.1);
|
|
}
|
|
.search-recentSearches-searchPageGrid
|
|
.main-trackList-trackListHeader.main-trackList-trackListHeaderStuck {
|
|
/* fix tracklist header in search */
|
|
top: 64px !important;
|
|
}
|
|
.main-home-homeHeader,
|
|
.x-entityHeader-overlay,
|
|
.x-actionBarBackground-background,
|
|
.main-actionBarBackground-background,
|
|
.main-entityHeader-overlay,
|
|
.main-entityHeader-backgroundColor {
|
|
/* remove background gradient */
|
|
background-color: unset !important;
|
|
background-image: unset !important;
|
|
}
|
|
|
|
/* full window artist background */
|
|
.main-entityHeader-background.main-entityHeader-gradient {
|
|
opacity: 0.3 !important;
|
|
}
|
|
.main-entityHeader-container.main-entityHeader-withBackgroundImage,
|
|
.main-entityHeader-background,
|
|
.main-entityHeader-background.main-entityHeader-overlay:after {
|
|
height: 100vh;
|
|
}
|
|
.main-entityHeader-withBackgroundImage .main-entityHeader-headerText {
|
|
justify-content: center;
|
|
}
|
|
.main-entityHeader-container.main-entityHeader-nonWrapped.main-entityHeader-withBackgroundImage {
|
|
padding-left: 9%;
|
|
}
|
|
.main-entityHeader-background.main-entityHeader-overlay:after {
|
|
background-image: linear-gradient(transparent, transparent),
|
|
linear-gradient(var(--spice-main), var(--spice-main));
|
|
}
|
|
.artist-artistOverview-overview .main-entityHeader-withBackgroundImage h1 {
|
|
font-size: 20vh !important;
|
|
line-height: 20vh !important;
|
|
}
|
|
/* cards */
|
|
.main-cardImage-imageWrapper {
|
|
background-color: transparent;
|
|
}
|
|
.main-card-card {
|
|
background: none;
|
|
}
|
|
.main-cardImage-image {
|
|
border-radius: 12px;
|
|
}
|
|
.main-cardImage-imageWrapper,
|
|
.main-entityHeader-shadow {
|
|
/* remove drop shadows from images */
|
|
-webkit-box-shadow: none;
|
|
box-shadow: none;
|
|
}
|
|
/* popup modal */
|
|
.main-trackCreditsModal-container {
|
|
background-color: var(--spice-main);
|
|
}
|
|
.main-trackCreditsModal-closeBtn svg path {
|
|
fill: var(--spice-subtext);
|
|
}
|
|
/* lyrics */
|
|
.lyrics-lyrics-background {
|
|
background-color: var(--spice-main);
|
|
}
|
|
.lyrics-lyrics-container.lyrics-lyrics-coverTopBar {
|
|
--lyrics-color-active: var(--spice-text) !important;
|
|
--lyrics-color-inactive: var(--spice-subtext) !important;
|
|
--lyrics-color-passed: var(--spice-subtext) !important;
|
|
--lyrics-color-messaging: var(--spice-subtext) !important;
|
|
}
|
|
.lyrics-lyricsContent-lyric {
|
|
opacity: 0.3;
|
|
}
|
|
.lyrics-lyricsContent-lyric.lyrics-lyricsContent-highlight {
|
|
opacity: 0.7;
|
|
}
|
|
.lyrics-lyricsContent-lyric.lyrics-lyricsContent-isInteractive.lyrics-lyricsContent-active {
|
|
text-shadow: 0 0 10px var(--lyrics-color-background),
|
|
-2px 1px 0 var(--spice-main), -3px 2px 0 var(--lyrics-color-background),
|
|
2px -1px 0 var(--spice-main), 3px -2px 0 var(--lyrics-color-background);
|
|
opacity: 1;
|
|
}
|
|
|
|
/* ================================
|
|
FRIEND ACTIVITY BAR / RIGHT SIDEBAR
|
|
================================ */
|
|
|
|
.Root__nav-right-sidebar {
|
|
border-left: var(--sidebar-border-width) solid var(--spice-sidebar-border);
|
|
}
|
|
.spotify__os--is-windows .main-buddyFeed-content {
|
|
margin-top: 0;
|
|
}
|
|
|
|
/* ================================
|
|
NOW PLAYING BAR
|
|
================================ */
|
|
|
|
.Root__now-playing-bar {
|
|
border-top: var(--player-border-width) solid var(--spice-player-border);
|
|
}
|
|
.main-nowPlayingBar-nowPlayingBar {
|
|
/* customize now playing bar */
|
|
height: var(--player-height);
|
|
padding: var(--player-padding);
|
|
}
|
|
.main-nowPlayingBar-container {
|
|
/* customize now playing bar*/
|
|
border-top: none;
|
|
}
|
|
[dir="ltr"] .main-nowPlayingWidget-coverExpanded {
|
|
transform: translateX(-76px);
|
|
}
|
|
.x-progressBar-fillColor {
|
|
/* fluid progress bars */
|
|
transition: transform, 0s, ease, 0.25s;
|
|
}
|
|
.progress-bar__slider {
|
|
/* fluid progress bars */
|
|
transition: left, 0s, ease, 0.25s;
|
|
}
|
|
|
|
/* ================================
|
|
MISC & FIXES
|
|
================================ */
|
|
|
|
/* font style
|
|
-------------------------------- */
|
|
* {
|
|
/* heading font weight */
|
|
font-weight: normal !important;
|
|
--font-family: CircularSp, CircularSp-Arab, CircularSp-Hebr, CircularSp-Cyrl,
|
|
CircularSp-Grek, CircularSp-Deva, var(--fallback-fonts, sans-serif),
|
|
sans-serif;
|
|
}
|
|
|
|
/* root
|
|
-------------------------------- */
|
|
.Root {
|
|
--panel-gap: 0 !important;
|
|
}
|
|
.spotify__container--is-desktop .Root__top-container {
|
|
padding-top: 0 !important;
|
|
}
|
|
|
|
/* scrollbar
|
|
-------------------------------- */
|
|
.os-scrollbar-handle {
|
|
/* customize scrollbar */
|
|
border-radius: var(--scrollbar-border-radius) !important;
|
|
width: var(--scrollbar-width) !important;
|
|
}
|
|
.os-scrollbar-handle:hover {
|
|
/* customize hovered scrollbar */
|
|
border-radius: var(--scrollbar-border-radius) !important;
|
|
width: var(--scrollbar-width-hover) !important;
|
|
}
|
|
.os-scrollbar-vertical {
|
|
/* fix scrollbar positioning */
|
|
top: 5px !important;
|
|
right: 5px !important;
|
|
}
|
|
.os-scrollbar-handle {
|
|
/* increase size from right to left */
|
|
position: absolute;
|
|
top: 0;
|
|
right: 0;
|
|
}
|
|
|
|
/* tooltip
|
|
-------------------------------- */
|
|
.main-contextMenu-tippy {
|
|
/* position below the element */
|
|
transform: translate(0, 65px);
|
|
}
|
|
|
|
/* placeholder
|
|
-------------------------------- */
|
|
.T7WHRub8pynnWPXERh8e,
|
|
.rOgsguaurlHVlgCTY0P7,
|
|
.eC25_w41L83mXDCqdm_A {
|
|
/* playlists loading placeholder */
|
|
opacity: 0.05;
|
|
filter: contrast(0.1);
|
|
}
|
|
|
|
|
|
/* color reassignment
|
|
-------------------------------- */
|
|
.encore-dark-theme,
|
|
.encore-dark-theme .encore-base-set {
|
|
/* song duration & queue button & folder arrow & settings desc text */
|
|
--text-subdued: var(--spice-subtext) !important;
|
|
--essential-subdued: var(--spice-button) !important;
|
|
}
|
|
|
|
/* ====topbar==== */
|
|
.main-topBar-container,
|
|
.main-topBar-container:empty {
|
|
background-color: var(--spice-topbar);
|
|
}
|
|
.main-topBar-historyButtons .main-topBar-button {
|
|
background-color: transparent;
|
|
color: var(--spice-topbar-text);
|
|
}
|
|
.main-topBar-historyButtons .main-topBar-button:disabled {
|
|
color: var(--spice-topbar-subtext);
|
|
opacity: 1;
|
|
}
|
|
.main-entityHeader-topbarTitle {
|
|
color: var(--spice-topbar-text) !important;
|
|
}
|
|
.queue-tabBar-active {
|
|
background-color: var(--spice-tab-active) !important;
|
|
color: var(--spice-tab-active-text) !important;
|
|
}
|
|
.queue-tabBar-headerItemLink {
|
|
color: var(--spice-topbar-subtext);
|
|
}
|
|
.queue-tabBar-headerItemLink:hover {
|
|
background-color: rgba(var(--spice-rgb-tab-hover), 0.3);
|
|
}
|
|
.x-searchInput-searchInputSearchIcon,
|
|
.x-searchInput-searchInputClearButton,
|
|
.x-searchInput-searchInputInput {
|
|
color: var(--spice-tab-active-text) !important;
|
|
}
|
|
.x-searchInput-searchInputInput {
|
|
background-color: var(--spice-tab-active);
|
|
color: var(--spice-tab-active-text) !important;
|
|
}
|
|
.x-searchInput-searchInputInput:hover {
|
|
background-color: var(--spice-tab-hover);
|
|
}
|
|
.x-filterBox-filterInput {
|
|
background-color: rgba(var(--spice-rgb-subtext), 0.1);
|
|
}
|
|
::placeholder {
|
|
color: var(--spice-topbar-subtext);
|
|
}
|
|
|
|
/* ====left sidebar==== */
|
|
.main-yourLibraryX-entryPoints {
|
|
background-color: var(--spice-sidebar);
|
|
}
|
|
.main-yourLibraryX-navLinkActive,
|
|
.main-yourLibraryX-navLinkActive .home-active-icon,
|
|
.main-yourLibraryX-navLinkActive .search-active-icon {
|
|
color: var(--spice-link-active-text) !important;
|
|
background-color: var(--spice-link-active);
|
|
border-radius: var(--tab-border-radius);
|
|
}
|
|
.link-subtle {
|
|
transition-property: none;
|
|
color: var(--spice-sidebar-text);
|
|
}
|
|
.link-subtle:focus,
|
|
.link-subtle:hover {
|
|
color: var(--spice-link-hover-text);
|
|
}
|
|
.Button-md-24-buttonTertiary-iconLeading-condensed-useBrowserDefaultFocusStyle,
|
|
.Button-md-24-buttonTertiary-iconLeading-condensed-isUsingKeyboard-useBrowserDefaultFocusStyle {
|
|
color: var(--spice-sidebar-text);
|
|
}
|
|
|
|
/* ====main view==== */
|
|
.main-trackList-trackListRow.main-trackList-selected,
|
|
.main-trackList-trackListRow.main-trackList-selected:hover,
|
|
.main-trackList-trackListRow:focus-within,
|
|
.main-trackList-trackListRow:hover {
|
|
background-color: var(--spice-card);
|
|
}
|
|
.main-trackList-trackListHeaderStuck.main-trackList-trackListHeader,
|
|
.artist-artistDiscography-topBar.artist-artistDiscography-topBarScrolled {
|
|
background: var(--spice-main) !important;
|
|
}
|
|
.main-trackList-placeholder {
|
|
/* recolor loading tracklist */
|
|
opacity: 0.05;
|
|
filter: contrast(0.1);
|
|
}
|
|
.view-homeShortcutsGrid-equaliser,
|
|
.main-trackList-playingIcon,
|
|
.main-devicePicker-nowPlayingActiveIcon {
|
|
/* change playing icon color to theme color */
|
|
filter: grayscale(1) opacity(0.2)
|
|
drop-shadow(0 0 0 var(--spice-button-active))
|
|
drop-shadow(0 0 0 var(--spice-button-active))
|
|
drop-shadow(0 0 0 var(--spice-button-active));
|
|
}
|
|
.main-home-filterChipsSection,
|
|
.main-home-filterChipsSection:after {
|
|
background-color: var(--spice-main) !important;
|
|
}
|
|
.search-searchCategory-catergoryGrid button[aria-checked="true"] span {
|
|
color: var(--spice-main);
|
|
background-color: var(--spice-button-active) !important;
|
|
}
|
|
.search-searchCategory-catergoryGrid span {
|
|
border-radius: var(--tab-border-radius);
|
|
color: var(--spice-subtext);
|
|
}
|
|
.artist-artistAbout-container.artist-artistAbout-backgroundImage
|
|
.artist-artistAbout-content
|
|
> div {
|
|
/* change about artist text color */
|
|
color: #fff;
|
|
}
|
|
.main-dropDown-dropDown,
|
|
.x-settings-input {
|
|
background-color: var(--spice-button-disabled);
|
|
color: var(--spice-text);
|
|
}
|
|
|
|
/* ====right sidebar==== */
|
|
.TypeElement-balladBold-textBase-type,
|
|
.main-buddyFeed-activityMetadata .main-buddyFeed-artistAndTrackName {
|
|
color: var(--spice-sidebar-text);
|
|
}
|
|
|
|
/* ====now playing bar==== */
|
|
.main-nowPlayingBar-container {
|
|
background-color: var(--spice-player);
|
|
}
|
|
.main-trackInfo-name,
|
|
.main-trackInfo-artists a:active,
|
|
.main-trackInfo-artists a:focus,
|
|
.main-trackInfo-artists a:hover {
|
|
color: var(--spice-player-text) !important;
|
|
}
|
|
.main-trackInfo-artists a:link,
|
|
.main-trackInfo-artists a:visited {
|
|
color: var(--spice-player-subtext);
|
|
}
|
|
.main-playPauseButton-button {
|
|
color: var(--spice-player);
|
|
background-color: var(--spice-button-active);
|
|
}
|
|
.control-button-heart[aria-checked="false"],
|
|
.player-controls__left button,
|
|
.player-controls__right button,
|
|
.main-nowPlayingBar-extraControls button {
|
|
color: rgba(var(--spice-rgb-player-selected-row), 0.7);
|
|
}
|
|
.Button-textBrightAccent-small-small-buttonTertiary-iconOnly-useBrowserDefaultFocusStyle,
|
|
.Button-textBrightAccent-small-small-buttonTertiary-iconOnly-isUsingKeyboard-useBrowserDefaultFocusStyle {
|
|
color: var(--spice-button) !important;
|
|
}
|
|
.progress-bar {
|
|
--bg-color: rgba(var(--spice-rgb-player-selected-row), 0.3);
|
|
--fg-color: var(--spice-player-selected-row);
|
|
}
|
|
|
|
/* ====misc==== */
|
|
|
|
/* ----scrollbar---- */
|
|
.os-scrollbar-handle {
|
|
background-color: var(--spice-scrollbar) !important;
|
|
}
|
|
.os-scrollbar-handle:hover,
|
|
.os-scrollbar-handle:active {
|
|
background-color: var(--spice-scrollbar-hover) !important;
|
|
}
|
|
|
|
/* ----context menu---- */
|
|
.main-contextMenu-menu {
|
|
background-color: var(--spice-context-menu);
|
|
}
|
|
.main-contextMenu-menuHeading,
|
|
.main-contextMenu-menuItemButton,
|
|
.main-contextMenu-menuItemButton:not(.main-contextMenu-disabled):focus,
|
|
.main-contextMenu-menuItemButton:not(.main-contextMenu-disabled):hover {
|
|
color: var(--spice-context-menu-text);
|
|
}
|
|
.main-contextMenu-menuItemButton:not(.main-contextMenu-disabled):focus,
|
|
.main-contextMenu-menuItemButton:not(.main-contextMenu-disabled):hover {
|
|
background-color: var(--spice-context-menu-hover);
|
|
}
|
|
|
|
/* ----button---- */
|
|
#_R_G *:not([fill="none"]) {
|
|
/* fix heart color on click */
|
|
fill: var(--spice-button-active) !important;
|
|
}
|
|
#_R_G *:not([stroke="none"]) {
|
|
stroke: var(--spice-button-active);
|
|
}
|
|
.ButtonInner-md-iconOnly {
|
|
/* base play/pause icon color on player instead of sidebar */
|
|
color: var(--spice-player);
|
|
}
|
|
.Button-sm-16-buttonTertiary-iconOnly-condensedAll-useBrowserDefaultFocusStyle {
|
|
/* base play/pause icon color on sidebar text instead of subtext */
|
|
color: var(--spice-sidebar-text);
|
|
}
|