Apple Music Dark Reader Fix for LibreWolf

Fixes the display of Apple Music page elements in LibreWolf when Dark Reader is installed. LibreWolf interferes with Dark Reader on some web pages elements due to the Resist Fingerprinting measures that it implements. This userscript itself will not undermine Resist Fingerprinting measures because it: does not access or expose sensitive browser APIs, only modifies CSS properties and shadow DOM elements for styling purposes, and avoids interacting with device-specific or identifying information.

// ==UserScript==
// @name         Apple Music Dark Reader Fix for LibreWolf
// @namespace    http://tampermonkey.net/
// @version      0.4
// @icon         https://ptpimg.me/3wphme.png
// @description  Fixes the display of Apple Music page elements in LibreWolf when Dark Reader is installed. LibreWolf interferes with Dark Reader on some web pages elements due to the Resist Fingerprinting measures that it implements. This userscript itself will not undermine Resist Fingerprinting measures because it: does not access or expose sensitive browser APIs, only modifies CSS properties and shadow DOM elements for styling purposes, and avoids interacting with device-specific or identifying information.
// @match        https://music.apple.com/*
// @grant        GM_addStyle
// @license      MIT
// @run-at       document-idle
// ==/UserScript==

(function() {
    'use strict';

    // Apply general styles with GM_addStyle
    GM_addStyle(`
      :root {
	    --systemPrimary: hsla(0,0%,100%,.92);
	    --systemPrimary-vibrant: #f5f5f7;
	    --systemPrimary-onLight: rgba(0,0,0,.88);
	    --systemPrimary-onDark: hsla(0,0%,100%,.92);
	    --systemSecondary: hsla(0,0%,100%,.64);
	    --systemSecondary-vibrant: #a1a1a6;
	    --systemSecondary-onLight: rgba(0,0,0,.56);
	    --systemSecondary-onDark: hsla(0,0%,100%,.64);
	    --systemTertiary: hsla(0,0%,100%,.4);
	    --systemTertiary-vibrant: #6e6e73;
	    --systemTertiary-onLight: rgba(0,0,0,.48);
	    --systemTertiary-onDark: hsla(0,0%,100%,.4);
	    --keyColor: #ff364c;
	    --keyColor-rgb: 255,54,76;
	    --keyColor-rollover: #ff8a9c;
	    --keyColor-rollover-rgb: 255,138,156;
	    --keyColor-pressed: #ff7183;
	    --keyColor-pressed-rgb: 255,113,131;
	    --keyColor-deepPressed: #ff8a9c;
	    --keyColor-deepPressed-rgb: 255,138,156;
	    --keyColor-disabled: rgba(255,54,76,.35);
	    --musicKeyColor: #fa586a;
	    --musicKeyColor-rollover: #ff8a9c;
	    --musicKeyColor-pressed: #ff7183;
	    --musicKeyColor-deepPressed: #ff8a9c;
	    --musicKeyColor-disabled: rgba(255,54,76,.35);
	    --keyColorBG: #d60017;
	    --selectionColor: #a60012;
        --darkreader-bg--keyColorBG: #df1b30;
      }
      amp-chrome-player::before {
        --playerGradientTop: #fff0;
        --playerGradientBottom: #fff0;
        background-color: #2d2d2de0 !important
      }
      amp-chrome-player {
        --systemSecondary: #ffffffa3;
        --skip-control-color-hover: white;
        --chromeVolumeIcon: #fff6;
        --chromeVolumeTrack: #ffffff26;
        --chromeVolumeElapsed: #fff9;
      }
      amp-lcd {
        --lcd-artworkHoverBGColor: #121212e8;
        --playerMissingArtworkBg: #121212;
        --playerLCDBGFill: #4d4d4d;
        --systemSecondary: #ffffffa3;
      }
    `);

    function applyStylesInShadowRoot() {
        const chromePlayer = document.querySelector('amp-chrome-player');
        if (!chromePlayer || !chromePlayer.shadowRoot) return;

        const playbackControls = chromePlayer.shadowRoot.querySelector('apple-music-playback-controls');
        if (!playbackControls || !playbackControls.shadowRoot) return;

        // Add style to modify shadow DOM elements
        const style = document.createElement('style');
        style.textContent = `
          :host {
            --systemSecondary: #ffffffa3 !important;
            --systemPrimary-vibrant: white !important;
          }
        `;
        playbackControls.shadowRoot.appendChild(style);
    }

    // Monitor for changes to ensure styles are always applied
    const observer = new MutationObserver(() => {
        applyStylesInShadowRoot();
    });

    // Observe the player container for dynamic changes
    const playerContainer = document.querySelector('amp-chrome-player');
    if (playerContainer) {
        observer.observe(playerContainer, { childList: true, subtree: true });
    }

    // Initial call to apply styles after a delay
    setTimeout(applyStylesInShadowRoot, 400);
})();