Greasy Fork is available in English.

BETSLIX - burning series enhancer

Wechselt automatisch zum VOE- oder Streamtape-Tab auf burning series und öffnet VOE oder Streamtape. Das Tool startet das nächste Video und falls nötig die nächste Staffel, wenn eine Episode beendet wurde.

// ==UserScript==
// @name           BETSLIX - burning series enhancer
// @name:en        BETSLIX - burning series enhancer

// @icon           https://bs.to/favicon.ico
// @author         xtrars
// @description:de Wechselt automatisch zum VOE- oder Streamtape-Tab auf burning series und öffnet VOE oder Streamtape. Das Tool startet das nächste Video und falls nötig die nächste Staffel, wenn eine Episode beendet wurde.
// @description:en Automatically switches to the VOE or Streamtape tab on burning series and opens VOE or Streamtape. The tool starts the next video and if necessary the next season when an episode is finished.
// @version        16.4
// @run-at         document-start
// @license        GPL-3.0-or-later
// @namespace      https://greasyfork.org/users/140785

// @compatible     chrome Chrome
// @compatible     firefox Firefox
// @compatible     opera Opera
// @compatible     edge Edge
// @compatible     safari Safari

// @grant          GM_setValue
// @grant          GM_getValue
// @grant          GM_addValueChangeListener
// @grant          GM_removeValueChangeListener
// @grant          GM_download
// @grant          GM_info
// @grant          GM_addStyle
// @grant          GM_getResourceText
// @grant          window.close
// @grant          window.focus

// @match          https://bs.to/*
// @match          https://burningseries.co/*
// @match          https://burningseries.sx/*
// @match          https://burningseries.vc/*
// @match          https://burningseries.ac/*
// @match          https://burningseries.cx/*
// @match          https://burningseries.nz/*
// @match          https://burningseries.se/*

// @match          https://dood.yt/*
// @match          https://d0000d.com/*

// @match          https://streamtape.com/*
// @match          https://streamadblocker.xyz/*
// @match          https://*.tapecontent.net/*

// @match          https://*.vidoza.net/*
// @match          https://*.videzz.net/*

// @match          https://*.voe-network.net/*
// @match          https://voe.sx/*
// @match          https://*.sandratableother.com/*

// @require        https://unpkg.com/video.js@latest/dist/video.min.js
// @require        https://unpkg.com/hls.js@latest/dist/hls.min.js

// @description Wechselt automatisch zum VOE- oder Streamtape-Tab auf burning series und öffnet VOE oder Streamtape. Das Tool startet das nächste Video und falls nötig die nächste Staffel, wenn eine Episode beendet wurde.
// ==/UserScript==


/**
 * The CBaseHandler class provides basic helper functions for handling DOM elements and URLs.
 * @class
 */
class CBaseHandler {

    /**
     * Returns the hoster as a string
     * @param {number} iIndex - 0: VOE, 1: Streamtape, 2: Doodstream, 3: Vidoza
     * @param {boolean} bAllLowerCase - If true, returns the hoster name in all lowercase
     * @returns {string} - The hoster name
     */
    getHoster(iIndex, bAllLowerCase = false) {
        const aHoster = ['VOE', 'Streamtape', 'Doodstream', 'Vidoza'];
        return bAllLowerCase ? aHoster[iIndex].toLowerCase() : aHoster[iIndex];
    }

    /**
     * Waits for an element to be available in the DOM and resolves with the element
     * @param {string} sSelector - The CSS selector of the element to wait for
     * @param {boolean} bWaitUnlimited - If true, waits indefinitely for the element. If false, waits for a maximum of 3 seconds
     * @returns {Promise<HTMLElement>} - A promise that resolves with the element when it becomes available in the DOM
     */
    waitForElement(sSelector, bWaitUnlimited = true) {
        return new Promise(async resolve => {
            if (document.querySelector(sSelector)) {
                return resolve(document.querySelector(sSelector));
            }

            const oObserver = new MutationObserver(() => {
                if (document.querySelector(sSelector)) {
                    resolve(document.querySelector(sSelector));
                    oObserver.disconnect();
                }
            });

            if (document.body) {
                oObserver.observe(document.body, {
                    childList: true, subtree: true,
                });
            }

            if (!bWaitUnlimited) {
                setTimeout(() => {
                    resolve(document.querySelector(sSelector));
                    oObserver.disconnect();
                }, 3000);
            }
        });
    }

    /**
     * Checks if the current URL contains all the selectors in the given array
     * @param {Array<RegExp>} aSelector - An array of URL selectors to check
     * @returns {boolean} - True if the URL contains all the selectors, false otherwise
     */
    hasUrl(aSelector) {
        let bIsAvailable = true;
        for (let rSelector of aSelector) {
            bIsAvailable = document.location.href.search(rSelector) !== -1;
            if (!bIsAvailable) {
                return false;
            }
        }
        return true;
    }

    /**
     * Reloads the current page after the specified delay
     * @param {number} iDelay - The delay in milliseconds before reloading the page
     */
    reload(iDelay = 300) {
        setTimeout(() => {
            window.location.reload();
        }, iDelay);
    }

    /**
     * Returns the first element matching the given CSS selector and attribute that matches the specified regular expression
     * @param {string} sSelector - The CSS selector to search for
     * @param {string} sAttribute - The attribute to match the regular expression against
     * @param {RegExp} rRegex - The regular expression to match against the attribute value
     * @returns {HTMLElement|boolean} - The first matching element, or false if no matching element is found
     */
    querySelectorAllRegex(sSelector = '*', sAttribute = 'name', rRegex = /.*/) {
        for (const oElement of document.querySelectorAll(sSelector)) {
            if (rRegex.test(oElement[sAttribute])) {
                return oElement;
            }
        }
        return false;
    }

    restartAnimation(oEl) {
        oEl.style.animation = 'none';
        oEl.offsetHeight; /* trigger reflow */
        oEl.style.animation = null;
    }
}

/**
 The CBurningSeriesHandler class extends the CBaseHandler class and provides methods for handling and enhancing
 the Burning Series website. This class is responsible for building the settings window that is displayed when
 the settings button is clicked.
 @class
 @extends CBaseHandler
 */
class CBurningSeriesHandler extends CBaseHandler {

    /**
     Initializes the values for the user script's settings.
     */
    initGMVariables() {
        const oVariables = [
            {name: 'bActivateEnhancer', defaultValue: false},
            {name: 'bAutoplayNextSeason', defaultValue: true},
            {name: 'bAutoplayRandomEpisode', defaultValue: false},
            {name: 'bSelectHoster', defaultValue: this.getHoster(0, true)},
            {name: 'bSkipStart', defaultValue: false},
            {name: 'bSkipEnd', defaultValue: false},
            {name: 'iSkipEndTime', defaultValue: 0},
            {name: 'iSkipStartTime', defaultValue: 0},
            {name: 'bFirstStart', defaultValue: true},
            {name: 'sLastActiveTab', defaultValue: ''},
            {name: 'bIsSettingsWindowOpen', defaultValue: false},
            {name: 'oSettingsWindowPosition', defaultValue: {}}
        ];

        for (const o of oVariables) {
            GM_setValue(o.name, GM_getValue(o.name) ?? o.defaultValue);
        }
    }

    /**
     Determines whether another hoster is available for the current episode.
     @returns {boolean} Whether another hoster is available.
     */
    hasAnotherHoster() {
        return this.hasUrl([new RegExp(`https:\\/\\/(bs.to|burningseries.[a-z]{2,3})\\/.*[0-9]{1,3}\\/[0-9]{1,3}-.*\\/[a-z]+\\/(?!${this.getHoster(0)}|${this.getHoster(1)}|${this.getHoster(2)}|${this.getHoster(3)}).*`, 'g')]);
    }

    /**
     Determines whether the current page is a series page.
     @returns {boolean} Whether the page is a series page.
     */
    isSeries() {
        return this.hasUrl([/^https:\/\/(bs.to|burningseries.[a-z]{2,3})\/serie\//g]);
    }

    /**
     Determines whether the current page is an episode page.
     @returns {boolean} Whether the page is an episode page.
     */
    isEpisode() {
        return this.hasUrl([/^https:\/\/(bs.to|burningseries.[a-z]{2,3})/g, /[0-9]{1,3}\/[0-9]{1,3}-/g]);
    }

    /**
     Clicks the play button on the current episode page.
     @async
     @returns {Promise<void>} A promise that resolves when the button has been clicked.
     */
    async clickPlay() {
        return new Promise(async resolve => {
            let oPlayerElem = await this.waitForElement('section.serie .hoster-player')
                .catch(() => null);
            let iNumberOfClicks = 0;
            let iClickInterval = setInterval(async () => {
                if (oPlayerElem) {
                    if (
                        document.querySelector('section.serie .hoster-player > a') ||
                        document.querySelector('section.serie .hoster-player > iframe') ||
                        iNumberOfClicks > 120 ||
                        this.querySelectorAllRegex('iframe', 'title', /recaptcha challenge/)
                    ) {
                        clearInterval(iClickInterval);
                        resolve();
                    }
                    iNumberOfClicks++;
                    let oClickEvent = new Event('click');
                    oClickEvent.which = 1;
                    oClickEvent.pageX = 6;
                    oClickEvent.pageY = 1;
                    oPlayerElem.dispatchEvent(oClickEvent);
                }
            }, 500);
        });
    }

    /**
     Plays the next episode if the current video has ended.
     @param {boolean} [bSetEvent=true] - Whether to set the event listener to play the next episode.
     */
    playNextEpisodeIfVideoEnded(bSetEvent = true) {
        if (!bSetEvent) {
            GM_removeValueChangeListener('isLocalVideoEnded');
            return;
        }
        GM_addValueChangeListener('isLocalVideoEnded', () => {
            if (GM_getValue('isLocalVideoEnded')) {
                GM_setValue('isLocalVideoEnded', false);
                window.focus();
                if (GM_getValue('bAutoplayRandomEpisode')) {
                    let oRandomEpisode = document.querySelector('#sp_right > a');
                    document.location.replace(oRandomEpisode.href);
                }
                else {
                    let oNextEpisode = document
                        .querySelector('.serie .frame ul li[class^="e"].active ~ li:not(.disabled) a');
                    if (oNextEpisode) {
                        document.location.replace(oNextEpisode.href);
                    }
                    else if (GM_getValue('bAutoplayNextSeason')) {
                        let oNextSeason = document
                            .querySelector('.serie .frame ul li[class^="s"].active ~ li:not(.disabled) a');
                        if (oNextSeason) {
                            GM_setValue('clickFirstSeason', true);
                            document.location.replace(oNextSeason.href);
                        }
                    }
                }
            }
        });
    }

    /**
     Appends custom styles to the current page.
     */
    appendOwnStyle() {
        const oStyle = document.createElement('style');
        oStyle.id = 'xtrars-style';

        // language=HTML
        oStyle.innerHTML = `<style>
              :root {
              --inner-pl: 14px;
              --inner-bc-before: #2FB536;
              --inner-bc-after: #12A6F6;
              --color: white;
              --xtrars-bs-img: url(data:image/png;base64,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);
            }
            
            @font-face { 
              font-family: "IEC symbols Unicode";
              src: url(data:font/woff2;base64,d09GMgABAAAAAARMAA4AAAAACNAAAAPvAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAP0ZGVE0cGh4GVgCCYhEICoUUhDABNgIkAygLFgAEIAWDdAeBFz93ZWJmBhtcB8iOxDgmcsRI5UX+Q571flJmrKx1G3faMbWgT8JJaVcQD/8/5u77M4malrZknsbpZlk8EgqZQ00kC4UUGTycdp7gnef436GyhAI+52tgAcacBezsL21O4FUACIDLl3TCAeCK6cpHpq4t/UPsNdoAU8AgECghkPXdAiSdSAMQIyteJF4GkC1+Y68jLRkCg5wckpDHQwH3yhQ405kVIUn7l4ajMpD0wQGAVQXWIWgMLwRdFrveXFNEQhagM+nflD+zIv7/hw/qd8n/b3fkt7SFffUxpB6SNKEghq9Atbz/CPno/38MwTmBsR04DtB86hTNhYBZ+28LJJHhPJ1phnoifW2qrq6qPiMAErypu68TSalRwxVwY1zXhenCDTTcVD/sfXz9NjXeCtt+iesS0LDPQo2GGw96Ht2ixvAVB3BqtbjxercaogaB69L8ar59/bEWdAmSpkGtrpBM6xo1YRoNR9T9UH2z6YZQLlFTLQhAZYOw6rXVwpMbN28+ffg4/NGzqFv3CQm/ex4IN5qaj2i+pXnT+7Astdmc5tuoBcj0FU6FnXtDQu2ZE+QQGlqleBzoBONgfETnMSGs/xpnFBdPX7+73eHZU4eOGIf2p886HHavL56eUWz81zrPCeZZHwbW31g+JmJHF4vGRtnlN7yrPmSZ2weHYPF1Z5AiNq6D5SrM090UcXEL+F1No3F//8aNnly/vv5R/K5d8Y/+EdkwPYr/59sbFhYa+jihfv36k3Gjf/+OxuVWN8WNUQQcHwpcURuWQX4WK47vUCQK1oUyp7lhyWrRAV+5eWsQNa9IN5cHtTaTf5qu88GMYnmR4cRZkEZ59WeUBA1+/ToYVMKSjb6gQV/avi1exmvXGnuBDKbN2DF0dUvMwfPAeD37rzItGeCWaPtk2v7/kl6OE8h2l4VA9qGdcDWAlOrni8/FDgAyFToGWYzJKG2hR18+hcEIwGGvVh8DoLDSmbRPC+9gESI5Aj1cTUJdpBPI4MpikMXSB8ih4RPk0fUHvmDqH3xjfuiCH8jIkfgLjlRv3GTRiQB4UlLgvaqUK0m+HCaTdy5PpuTv9SlSBUmVrlSOREVU8uUpMccXSZeKNzU0Zrpvy9FrrxDoOWKnVgam6jDGJhb96MaLmjCpuq5YZo90vEkvGmo/MVyqJGmjYJbQnUr0afYlsj7e1CzeM7M1hW9rYRNH763mRarMK5gDetvMeYnknSpUCk6RbEiVsw/qJBIOQEi0kiURiUlCUpJJS/My50u73LQD/MOVQXxwpK+rv4+RJ8Hfb46/ShVG6TH+CMNAsI9SGfCk1nPpwiUqhbaH0iUskld4Bil8lKDQhCPFAAA=);
            }
            
            .run-circleToWindow-animation {
                animation: 500ms linear 0s 1 normal none running xtrarsSlideIn, 
                           500ms linear 0s 1 normal none running xtrarsCircleToWindow;
                animation-fill-mode: forwards;
            }            
            
            .run-windowToCircle-animation {
                animation: 500ms linear 0s 1 normal none running xtrarsSlideIn, 
                           500ms linear 0s 1 normal none running xtrarsWindowToCircle;
                animation-fill-mode: forwards;
            }
            
            @keyframes xtrarsSlideIn {
                0%   {transform: translate(0, 0);}
                40%  {transform: translate(0, 0);}
                99.99% {transform: translate(0, 0);}
                100% {transform: translate(0, 0);}
            }    
           
            
            @keyframes xtrarsCircleToWindow {
                0%   {clip-path: circle(35px at center); opacity: .2;}
                60%  {clip-path: circle(35px at center); opacity: 1;}
                99.99% {clip-path: circle(270px at center);}
                100% {}
            }
             
             @keyframes xtrarsWindowToCircle {
                0%   {clip-path: circle(290px at center);}
                40%  {clip-path: circle(35px at center); opacity: 1;}
                99.99% {clip-path: circle(35px at center); opacity: .2;}
                100% {clip-path: circle(35px at center); display: none;}
            }         
            
            .xtrars-power-symbol {
                font-family: 'IEC symbols Unicode',sans-serif;
                font-style: normal;
            }
            
            #xtrars-settings-window {
                overflow: hidden;
            }
            
            .xtrars-donate {
                background-color:#12a6f6;
                border-radius:21px;
                border:1px solid #11a4e3;
                display:inline-block;
                cursor:pointer;
                font-weight:bold;
                padding:3px 12px;
                text-decoration:none;
                color: white;
            }
            
            .xtrars-donate:hover, button.tab:hover, a.tab:hover {
                text-decoration:none;
                background-color:#11a4e3;
            }
            
            button.tab, a.tab {
                background-color: transparent;
                color: white;
                float: left;
                border: none;
                outline: none;
                cursor: pointer;
                padding: 7px 10px 8px;
                user-select: none;
            }
            
            @keyframes shake {
                10%, 90% {transform: translate3d(-.5px, 0, 0);}
                20%, 80% {transform: translate3d(1px, 0, 0);}
                30%, 50%, 70% {transform: translate3d(-2px, 0, 0);}
                40%, 60% {transform: translate3d(2px, 0, 0);}
            }
            
            #Streaming .onoffswitch {
                min-width: 357px;
            }
            
            #BS .onoffswitch {
                min-width: 272px;
            }
            
            .onoffswitch {
                z-index: 161;
                position: relative; 
                width: 100%;
            }

            .onoffswitch-inner {
                display: inline-block; 
                width: 200%; 
                margin-left: -100%;
                transition: margin 0.3s ease-in 0s;
                position: relative;
                bottom: 0;
                transform: translateY(-40%);
                top: 50%;
            }
            
            .onoffswitch-inner span {
                padding-left: 10px;
            }           
             
             .onoffswitch-inner > span {
                display: inline-block;
                width: calc(50% - 3px);
            }

            .xtrars-toggle:has(> .onoffswitch-checkbox:checked) + .label-wrapper > .onoffswitch-inner {
                margin-left: 0;
            }
            
            .workaroundChecked {
                margin-left: 0;
            }
            
            .label-wrapper {
                font-size: 11px;
                font-family: Trebuchet, Arial, sans-serif;
                position: relative;
                white-space: nowrap;
                overflow: hidden;
                display: inline-block;
                width: calc(100% - 34px);
                height: 16px;
            }
            
            input.skip-start, input.skip-end {
                position: absolute; 
                right: 0; 
                top: 0; 
                height: 16px; 
                min-width: 0; 
                width: 50px; 
                display: none;
            }
            
            .onoffswitch-checkbox.disabled {
                pointer-events: none;
                -webkit-user-select: none; /* Safari */
                user-select: none;
            }
            
            #xtrars-btn {
               position: relative;
               left: calc(100% - 70px);
               background: #12a6f6;
               border-radius: 50%;
               width: 70px;
               height: 70px;
               line-height: 81px;
               text-align: center;
               cursor: pointer;
               transition: transform 0.2s ease, box-shadow 0.1s ease;
           }
            #xtrars-btn:hover {
                transform: scale(100.7%);
                box-shadow: 0 5px 10px rgba(0, 0, 0, 0.3);
                transition: transform .3s ease, box-shadow .2s ease;
            }
            
            #xtrars-menu {
               right: 4px;
            }
            
            .xtrars-donation-container {
                display: flex;
                align-items: center;
            }

            .xtrars-donation-text {
                flex: 1; 
                margin-right: 10px; 
            }
            
            #xtrars-pp-qr {
               width: 90px;
               height: 90px;
               display: inline-block;
               background: no-repeat center url('data:image/svg+xml;base64,<?xml version="1.0" encoding="utf-8"?>
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" xml:space="preserve" width="792" height="792" viewBox="0 0 792 792"><rect width="792" height="792" fill="#ffffff" x="0" y="0"/><g fill="#12a6f6">
<g transform="translate(240,48) scale(4.12) rotate(-2)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(264,48) scale(4.12) rotate(5)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(360,48) scale(4.12) rotate(2)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(384,48) scale(4.12) rotate(10)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(432,48) scale(4.12) rotate(-5)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(504,48) scale(4.12) rotate(1)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(528,48) scale(4.12) rotate(1)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(240,72) scale(4.12) rotate(-6)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(264,72) scale(4.12) rotate(-5)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(288,72) scale(4.12) rotate(0)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(312,72) scale(4.12) rotate(3)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(336,72) scale(4.12) rotate(-10)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(384,72) scale(4.12) rotate(1)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(480,72) scale(4.12) rotate(2)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(528,72) scale(4.12) rotate(-8)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(240,96) scale(4.12) rotate(-5)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(264,96) scale(4.12) rotate(-2)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(336,96) scale(4.12) rotate(2)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(432,96) scale(4.12) rotate(-10)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(480,96) scale(4.12) rotate(-1)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(288,120) scale(4.12) rotate(1)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(312,120) scale(4.12) rotate(-3)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(432,120) scale(4.12) rotate(3)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(456,120) scale(4.12) rotate(-5)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(504,120) scale(4.12) rotate(-8)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(528,120) scale(4.12) rotate(-1)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(264,144) scale(4.12) rotate(4)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(288,144) scale(4.12) rotate(-2)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(336,144) scale(4.12) rotate(7)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(360,144) scale(4.12) rotate(8)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(456,144) scale(4.12) rotate(-1)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(480,144) scale(4.12) rotate(-7)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(504,144) scale(4.12) rotate(-7)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(528,144) scale(4.12) rotate(9)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(240,168) scale(4.12) rotate(-8)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(312,168) scale(4.12) rotate(-6)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(480,168) scale(4.12) rotate(3)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(528,168) scale(4.12) rotate(-6)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(240,192) scale(4.12) rotate(2)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(288,192) scale(4.12) rotate(9)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(336,192) scale(4.12) rotate(-10)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(384,192) scale(4.12) rotate(-2)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(432,192) scale(4.12) rotate(5)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(480,192) scale(4.12) rotate(-10)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(528,192) scale(4.12) rotate(2)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(240,216) scale(4.12) rotate(-2)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(264,216) scale(4.12) rotate(3)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(288,216) scale(4.12) rotate(-7)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(312,216) scale(4.12) rotate(-2)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(336,216) scale(4.12) rotate(2)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(360,216) scale(4.12) rotate(-4)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(408,216) scale(4.12) rotate(-6)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(432,216) scale(4.12) rotate(-8)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(480,216) scale(4.12) rotate(2)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(96,240) scale(4.12) rotate(-7)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(120,240) scale(4.12) rotate(3)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(144,240) scale(4.12) rotate(6)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(192,240) scale(4.12) rotate(5)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(240,240) scale(4.12) rotate(5)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(312,240) scale(4.12) rotate(6)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(360,240) scale(4.12) rotate(-10)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(384,240) scale(4.12) rotate(-6)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(408,240) scale(4.12) rotate(10)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(432,240) scale(4.12) rotate(-2)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(480,240) scale(4.12) rotate(-5)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(504,240) scale(4.12) rotate(10)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(552,240) scale(4.12) rotate(-3)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(576,240) scale(4.12) rotate(6)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(600,240) scale(4.12) rotate(-3)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(672,240) scale(4.12) rotate(4)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(696,240) scale(4.12) rotate(-5)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(720,240) scale(4.12) rotate(3)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(72,264) scale(4.12) rotate(-2)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(96,264) scale(4.12) rotate(-8)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(120,264) scale(4.12) rotate(-9)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(144,264) scale(4.12) rotate(4)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(216,264) scale(4.12) rotate(-1)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(240,264) scale(4.12) rotate(-2)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(312,264) scale(4.12) rotate(0)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(384,264) scale(4.12) rotate(-6)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(408,264) scale(4.12) rotate(-5)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(480,264) scale(4.12) rotate(-1)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(504,264) scale(4.12) rotate(-3)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(528,264) scale(4.12) rotate(0)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(552,264) scale(4.12) rotate(-6)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(576,264) scale(4.12) rotate(2)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(600,264) scale(4.12) rotate(-9)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(624,264) scale(4.12) rotate(5)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(648,264) scale(4.12) rotate(3)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(672,264) scale(4.12) rotate(-4)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(720,264) scale(4.12) rotate(-4)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(48,288) scale(4.12) rotate(5)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(120,288) scale(4.12) rotate(-7)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(192,288) scale(4.12) rotate(-9)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(264,288) scale(4.12) rotate(7)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(312,288) scale(4.12) rotate(3)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(336,288) scale(4.12) rotate(9)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(360,288) scale(4.12) rotate(1)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(384,288) scale(4.12) rotate(-2)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(408,288) scale(4.12) rotate(10)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(432,288) scale(4.12) rotate(3)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(456,288) scale(4.12) rotate(0)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(576,288) scale(4.12) rotate(-2)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(672,288) scale(4.12) rotate(10)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(48,312) scale(4.12) rotate(-2)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(72,312) scale(4.12) rotate(-9)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(96,312) scale(4.12) rotate(-4)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(120,312) scale(4.12) rotate(4)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(216,312) scale(4.12) rotate(4)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(336,312) scale(4.12) rotate(-10)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(384,312) scale(4.12) rotate(5)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(408,312) scale(4.12) rotate(-4)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(528,312) scale(4.12) rotate(5)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(576,312) scale(4.12) rotate(-5)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(624,312) scale(4.12) rotate(-9)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(648,312) scale(4.12) rotate(5)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(696,312) scale(4.12) rotate(2)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(48,336) scale(4.12) rotate(-4)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(72,336) scale(4.12) rotate(-4)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(96,336) scale(4.12) rotate(5)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(120,336) scale(4.12) rotate(7)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(144,336) scale(4.12) rotate(10)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(192,336) scale(4.12) rotate(6)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(216,336) scale(4.12) rotate(9)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(264,336) scale(4.12) rotate(0)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(360,336) scale(4.12) rotate(-6)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(408,336) scale(4.12) rotate(5)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(456,336) scale(4.12) rotate(-7)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(504,336) scale(4.12) rotate(6)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(528,336) scale(4.12) rotate(-2)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(552,336) scale(4.12) rotate(9)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(672,336) scale(4.12) rotate(-1)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(696,336) scale(4.12) rotate(1)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(720,336) scale(4.12) rotate(3)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(48,360) scale(4.12) rotate(10)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(144,360) scale(4.12) rotate(2)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(240,360) scale(4.12) rotate(-7)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(288,360) scale(4.12) rotate(-4)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(384,360) scale(4.12) rotate(8)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(408,360) scale(4.12) rotate(-9)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(456,360) scale(4.12) rotate(-9)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(480,360) scale(4.12) rotate(1)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(504,360) scale(4.12) rotate(3)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(528,360) scale(4.12) rotate(-3)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(552,360) scale(4.12) rotate(8)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(576,360) scale(4.12) rotate(-4)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(624,360) scale(4.12) rotate(7)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(648,360) scale(4.12) rotate(0)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(696,360) scale(4.12) rotate(-7)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(720,360) scale(4.12) rotate(-5)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(120,384) scale(4.12) rotate(7)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(144,384) scale(4.12) rotate(8)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(168,384) scale(4.12) rotate(-6)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(192,384) scale(4.12) rotate(10)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(216,384) scale(4.12) rotate(-8)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(360,384) scale(4.12) rotate(2)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(432,384) scale(4.12) rotate(-5)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(456,384) scale(4.12) rotate(9)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(480,384) scale(4.12) rotate(-5)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(528,384) scale(4.12) rotate(6)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(696,384) scale(4.12) rotate(-7)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(120,408) scale(4.12) rotate(8)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(168,408) scale(4.12) rotate(-6)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(264,408) scale(4.12) rotate(-9)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(288,408) scale(4.12) rotate(-5)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(360,408) scale(4.12) rotate(-6)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(384,408) scale(4.12) rotate(10)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(432,408) scale(4.12) rotate(9)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(456,408) scale(4.12) rotate(-3)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(480,408) scale(4.12) rotate(3)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(648,408) scale(4.12) rotate(2)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(696,408) scale(4.12) rotate(5)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(48,432) scale(4.12) rotate(3)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(72,432) scale(4.12) rotate(4)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(120,432) scale(4.12) rotate(-3)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(144,432) scale(4.12) rotate(5)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(168,432) scale(4.12) rotate(9)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(192,432) scale(4.12) rotate(4)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(216,432) scale(4.12) rotate(-1)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(240,432) scale(4.12) rotate(-8)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(264,432) scale(4.12) rotate(-9)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(312,432) scale(4.12) rotate(-6)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(336,432) scale(4.12) rotate(-1)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(360,432) scale(4.12) rotate(3)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(384,432) scale(4.12) rotate(10)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(408,432) scale(4.12) rotate(8)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(648,432) scale(4.12) rotate(-5)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(672,432) scale(4.12) rotate(-4)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(720,432) scale(4.12) rotate(-8)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(48,456) scale(4.12) rotate(-9)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(72,456) scale(4.12) rotate(-8)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(144,456) scale(4.12) rotate(-9)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(240,456) scale(4.12) rotate(2)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(288,456) scale(4.12) rotate(-8)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(384,456) scale(4.12) rotate(-1)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(432,456) scale(4.12) rotate(-7)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(456,456) scale(4.12) rotate(3)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(480,456) scale(4.12) rotate(-3)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(504,456) scale(4.12) rotate(10)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(528,456) scale(4.12) rotate(7)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(576,456) scale(4.12) rotate(-10)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(600,456) scale(4.12) rotate(2)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(624,456) scale(4.12) rotate(7)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(648,456) scale(4.12) rotate(-5)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(672,456) scale(4.12) rotate(5)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(696,456) scale(4.12) rotate(3)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(720,456) scale(4.12) rotate(6)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(48,480) scale(4.12) rotate(6)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(192,480) scale(4.12) rotate(7)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(264,480) scale(4.12) rotate(2)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(288,480) scale(4.12) rotate(2)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(312,480) scale(4.12) rotate(-1)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(336,480) scale(4.12) rotate(-9)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(360,480) scale(4.12) rotate(-1)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(384,480) scale(4.12) rotate(3)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(408,480) scale(4.12) rotate(8)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(432,480) scale(4.12) rotate(-2)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(528,480) scale(4.12) rotate(7)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(576,480) scale(4.12) rotate(-9)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(600,480) scale(4.12) rotate(6)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(648,480) scale(4.12) rotate(10)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(48,504) scale(4.12) rotate(-2)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(96,504) scale(4.12) rotate(4)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(144,504) scale(4.12) rotate(-5)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(168,504) scale(4.12) rotate(-5)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(240,504) scale(4.12) rotate(6)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(264,504) scale(4.12) rotate(10)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(312,504) scale(4.12) rotate(7)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(360,504) scale(4.12) rotate(-4)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(504,504) scale(4.12) rotate(4)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(576,504) scale(4.12) rotate(2)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(600,504) scale(4.12) rotate(10)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(648,504) scale(4.12) rotate(-1)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(696,504) scale(4.12) rotate(-6)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(48,528) scale(4.12) rotate(-3)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(96,528) scale(4.12) rotate(-5)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(120,528) scale(4.12) rotate(7)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(144,528) scale(4.12) rotate(5)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(168,528) scale(4.12) rotate(-2)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(192,528) scale(4.12) rotate(3)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(288,528) scale(4.12) rotate(-7)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(360,528) scale(4.12) rotate(5)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(528,528) scale(4.12) rotate(10)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(552,528) scale(4.12) rotate(8)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(576,528) scale(4.12) rotate(4)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(600,528) scale(4.12) rotate(-8)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(624,528) scale(4.12) rotate(4)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(672,528) scale(4.12) rotate(-1)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(696,528) scale(4.12) rotate(3)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(720,528) scale(4.12) rotate(1)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(240,552) scale(4.12) rotate(10)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(264,552) scale(4.12) rotate(8)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(288,552) scale(4.12) rotate(7)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(312,552) scale(4.12) rotate(-3)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(384,552) scale(4.12) rotate(0)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(456,552) scale(4.12) rotate(-9)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(528,552) scale(4.12) rotate(8)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(624,552) scale(4.12) rotate(7)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(648,552) scale(4.12) rotate(4)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(696,552) scale(4.12) rotate(5)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(720,552) scale(4.12) rotate(2)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(264,576) scale(4.12) rotate(1)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(336,576) scale(4.12) rotate(-9)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(360,576) scale(4.12) rotate(3)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(432,576) scale(4.12) rotate(6)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(456,576) scale(4.12) rotate(4)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(480,576) scale(4.12) rotate(1)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(504,576) scale(4.12) rotate(9)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(528,576) scale(4.12) rotate(4)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(576,576) scale(4.12) rotate(-3)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(624,576) scale(4.12) rotate(-6)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(264,600) scale(4.12) rotate(3)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(288,600) scale(4.12) rotate(-7)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(312,600) scale(4.12) rotate(8)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(384,600) scale(4.12) rotate(8)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(432,600) scale(4.12) rotate(2)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(456,600) scale(4.12) rotate(1)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(504,600) scale(4.12) rotate(6)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(528,600) scale(4.12) rotate(1)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(624,600) scale(4.12) rotate(9)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(648,600) scale(4.12) rotate(-7)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(240,624) scale(4.12) rotate(7)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(312,624) scale(4.12) rotate(4)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(360,624) scale(4.12) rotate(-4)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(384,624) scale(4.12) rotate(-9)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(408,624) scale(4.12) rotate(-3)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(432,624) scale(4.12) rotate(7)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(528,624) scale(4.12) rotate(-8)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(552,624) scale(4.12) rotate(-10)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(576,624) scale(4.12) rotate(-7)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(600,624) scale(4.12) rotate(-9)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(624,624) scale(4.12) rotate(0)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(648,624) scale(4.12) rotate(7)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(672,624) scale(4.12) rotate(-1)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(696,624) scale(4.12) rotate(-2)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(240,648) scale(4.12) rotate(-6)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(264,648) scale(4.12) rotate(9)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(288,648) scale(4.12) rotate(-5)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(384,648) scale(4.12) rotate(9)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(456,648) scale(4.12) rotate(10)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(480,648) scale(4.12) rotate(-4)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(600,648) scale(4.12) rotate(6)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(648,648) scale(4.12) rotate(3)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(240,672) scale(4.12) rotate(-9)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(264,672) scale(4.12) rotate(3)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(288,672) scale(4.12) rotate(3)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(312,672) scale(4.12) rotate(-7)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(336,672) scale(4.12) rotate(9)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(384,672) scale(4.12) rotate(2)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(408,672) scale(4.12) rotate(-6)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(432,672) scale(4.12) rotate(0)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(576,672) scale(4.12) rotate(-8)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(624,672) scale(4.12) rotate(7)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(648,672) scale(4.12) rotate(6)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(696,672) scale(4.12) rotate(-9)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(336,696) scale(4.12) rotate(-9)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(360,696) scale(4.12) rotate(-6)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(408,696) scale(4.12) rotate(4)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(432,696) scale(4.12) rotate(2)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(504,696) scale(4.12) rotate(9)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(528,696) scale(4.12) rotate(4)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(624,696) scale(4.12) rotate(-4)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(696,696) scale(4.12) rotate(1)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(264,720) scale(4.12) rotate(-1)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(288,720) scale(4.12) rotate(5)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(336,720) scale(4.12) rotate(4)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(360,720) scale(4.12) rotate(8)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(384,720) scale(4.12) rotate(9)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(408,720) scale(4.12) rotate(-9)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(456,720) scale(4.12) rotate(-9)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(504,720) scale(4.12) rotate(8)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(552,720) scale(4.12) rotate(5)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(624,720) scale(4.12) rotate(-2)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(672,720) scale(4.12) rotate(2)"><rect x="0.5" y="0.5" width="5" height="5"/></g>
<g transform="translate(48,48)"><g transform="scale(12)"><path d="M0.2,0.1L0.1,0.6l0.1,0.5L0.2,1.6L0.1,2.1l0.1,0.5L0,3.1l0,0.5L0,4l0.1,0.5l0,0.5l0.1,0.5L0.1,6l0,0.5l0,0.5 l0.2,0.5L0.1,8l0.1,0.5L0,8.9l0.2,0.5L0,9.9l0.2,0.5l-0.1,0.5l0,0.5L0,11.9l0.2,0.5l-0.1,0.5l0.1,0.5l0,0.4L0.6,14l0.5,0l0.5-0.1 l0.5,0.1l0.5,0.1L3.1,14l0.5-0.1l0.5-0.1l0.5,0L5,13.9l0.5-0.1l0.5,0l0.5,0L7,13.9L7.5,14L8,14l0.5-0.2L9,13.9L9.4,14l0.5-0.2 l0.5,0.2l0.5-0.1l0.5,0l0.5-0.1l0.5,0l0.5,0l0.5,0l0.5,0.1l-0.1-0.5l0.2-0.5l-0.1-0.5l-0.1-0.5l0.2-0.5l-0.2-0.5l0.1-0.5L14,9.9 l-0.2-0.5L13.9,9L14,8.5L14,8l-0.2-0.5l0-0.5l0.1-0.5L13.8,6l0-0.5L14,5l0-0.5l-0.1-0.5l0.1-0.5l-0.2-0.5l0.1-0.5l0-0.5l0-0.5 l-0.1-0.5L14,0.6l-0.2-0.4l-0.4,0l-0.5,0L12.4,0l-0.5,0.2l-0.5,0l-0.5-0.1l-0.5,0L10,0l-0.5,0L9,0L8.5,0.2L8,0.2L7.5,0.1L7,0.1 L6.5,0.2L6,0L5.5,0.2L5.1,0.2L4.6,0.1L4.1,0.1L3.6,0L3.1,0.1L2.6,0L2.1,0.1l-0.5,0l-0.5,0L0.6,0.2L0.2,0.1z M11.9,11.9l-0.5-0.1 L10.9,12l-0.5-0.1L10,11.9l-0.5,0.1L9,11.8l-0.5,0l-0.5,0l-0.5,0.1l-0.5,0L6.5,12L6,11.9l-0.5,0l-0.5,0L4.6,12l-0.5-0.2L3.6,12 l-0.5-0.1L2.6,12l-0.4-0.1L2,11.4l0.1-0.5l0-0.5l0.1-0.5L2,9.5L2.1,9L2,8.5L2,8l0.2-0.5l0-0.5L2,6.5L2.1,6l0.1-0.5L2.2,5L2.1,4.5 L2,4.1l0-0.5l0.2-0.5L2,2.6L2,2l0.5,0l0.5,0.1l0.5,0.1l0.5,0L4.5,2L5,2.1l0.5,0.1L6,2l0.5,0.2L7,2.1l0.5,0L8,2l0.5,0L9,2l0.5,0 l0.5,0.1L10.4,2l0.5,0.2L11.4,2L12,2l-0.1,0.6L12,3.1l-0.1,0.5L11.8,4L12,4.5L11.9,5l-0.1,0.5l0,0.5L12,6.5L12,7l-0.1,0.5L12,8 l0,0.5l-0.2,0.5l0,0.5l0.1,0.5l-0.1,0.5l0.2,0.5l-0.1,0.5L11.9,11.9z"/></g></g>
<g transform="translate(576,48)"><g transform="scale(12)"><path d="M0.2,0.1L0.1,0.6l0.1,0.5L0.2,1.6L0.1,2.1l0.1,0.5L0,3.1l0,0.5L0,4l0.1,0.5l0,0.5l0.1,0.5L0.1,6l0,0.5l0,0.5 l0.2,0.5L0.1,8l0.1,0.5L0,8.9l0.2,0.5L0,9.9l0.2,0.5l-0.1,0.5l0,0.5L0,11.9l0.2,0.5l-0.1,0.5l0.1,0.5l0,0.4L0.6,14l0.5,0l0.5-0.1 l0.5,0.1l0.5,0.1L3.1,14l0.5-0.1l0.5-0.1l0.5,0L5,13.9l0.5-0.1l0.5,0l0.5,0L7,13.9L7.5,14L8,14l0.5-0.2L9,13.9L9.4,14l0.5-0.2 l0.5,0.2l0.5-0.1l0.5,0l0.5-0.1l0.5,0l0.5,0l0.5,0l0.5,0.1l-0.1-0.5l0.2-0.5l-0.1-0.5l-0.1-0.5l0.2-0.5l-0.2-0.5l0.1-0.5L14,9.9 l-0.2-0.5L13.9,9L14,8.5L14,8l-0.2-0.5l0-0.5l0.1-0.5L13.8,6l0-0.5L14,5l0-0.5l-0.1-0.5l0.1-0.5l-0.2-0.5l0.1-0.5l0-0.5l0-0.5 l-0.1-0.5L14,0.6l-0.2-0.4l-0.4,0l-0.5,0L12.4,0l-0.5,0.2l-0.5,0l-0.5-0.1l-0.5,0L10,0l-0.5,0L9,0L8.5,0.2L8,0.2L7.5,0.1L7,0.1 L6.5,0.2L6,0L5.5,0.2L5.1,0.2L4.6,0.1L4.1,0.1L3.6,0L3.1,0.1L2.6,0L2.1,0.1l-0.5,0l-0.5,0L0.6,0.2L0.2,0.1z M11.9,11.9l-0.5-0.1 L10.9,12l-0.5-0.1L10,11.9l-0.5,0.1L9,11.8l-0.5,0l-0.5,0l-0.5,0.1l-0.5,0L6.5,12L6,11.9l-0.5,0l-0.5,0L4.6,12l-0.5-0.2L3.6,12 l-0.5-0.1L2.6,12l-0.4-0.1L2,11.4l0.1-0.5l0-0.5l0.1-0.5L2,9.5L2.1,9L2,8.5L2,8l0.2-0.5l0-0.5L2,6.5L2.1,6l0.1-0.5L2.2,5L2.1,4.5 L2,4.1l0-0.5l0.2-0.5L2,2.6L2,2l0.5,0l0.5,0.1l0.5,0.1l0.5,0L4.5,2L5,2.1l0.5,0.1L6,2l0.5,0.2L7,2.1l0.5,0L8,2l0.5,0L9,2l0.5,0 l0.5,0.1L10.4,2l0.5,0.2L11.4,2L12,2l-0.1,0.6L12,3.1l-0.1,0.5L11.8,4L12,4.5L11.9,5l-0.1,0.5l0,0.5L12,6.5L12,7l-0.1,0.5L12,8 l0,0.5l-0.2,0.5l0,0.5l0.1,0.5l-0.1,0.5l0.2,0.5l-0.1,0.5L11.9,11.9z"/></g></g>
<g transform="translate(48,576)"><g transform="scale(12)"><path d="M0.2,0.1L0.1,0.6l0.1,0.5L0.2,1.6L0.1,2.1l0.1,0.5L0,3.1l0,0.5L0,4l0.1,0.5l0,0.5l0.1,0.5L0.1,6l0,0.5l0,0.5 l0.2,0.5L0.1,8l0.1,0.5L0,8.9l0.2,0.5L0,9.9l0.2,0.5l-0.1,0.5l0,0.5L0,11.9l0.2,0.5l-0.1,0.5l0.1,0.5l0,0.4L0.6,14l0.5,0l0.5-0.1 l0.5,0.1l0.5,0.1L3.1,14l0.5-0.1l0.5-0.1l0.5,0L5,13.9l0.5-0.1l0.5,0l0.5,0L7,13.9L7.5,14L8,14l0.5-0.2L9,13.9L9.4,14l0.5-0.2 l0.5,0.2l0.5-0.1l0.5,0l0.5-0.1l0.5,0l0.5,0l0.5,0l0.5,0.1l-0.1-0.5l0.2-0.5l-0.1-0.5l-0.1-0.5l0.2-0.5l-0.2-0.5l0.1-0.5L14,9.9 l-0.2-0.5L13.9,9L14,8.5L14,8l-0.2-0.5l0-0.5l0.1-0.5L13.8,6l0-0.5L14,5l0-0.5l-0.1-0.5l0.1-0.5l-0.2-0.5l0.1-0.5l0-0.5l0-0.5 l-0.1-0.5L14,0.6l-0.2-0.4l-0.4,0l-0.5,0L12.4,0l-0.5,0.2l-0.5,0l-0.5-0.1l-0.5,0L10,0l-0.5,0L9,0L8.5,0.2L8,0.2L7.5,0.1L7,0.1 L6.5,0.2L6,0L5.5,0.2L5.1,0.2L4.6,0.1L4.1,0.1L3.6,0L3.1,0.1L2.6,0L2.1,0.1l-0.5,0l-0.5,0L0.6,0.2L0.2,0.1z M11.9,11.9l-0.5-0.1 L10.9,12l-0.5-0.1L10,11.9l-0.5,0.1L9,11.8l-0.5,0l-0.5,0l-0.5,0.1l-0.5,0L6.5,12L6,11.9l-0.5,0l-0.5,0L4.6,12l-0.5-0.2L3.6,12 l-0.5-0.1L2.6,12l-0.4-0.1L2,11.4l0.1-0.5l0-0.5l0.1-0.5L2,9.5L2.1,9L2,8.5L2,8l0.2-0.5l0-0.5L2,6.5L2.1,6l0.1-0.5L2.2,5L2.1,4.5 L2,4.1l0-0.5l0.2-0.5L2,2.6L2,2l0.5,0l0.5,0.1l0.5,0.1l0.5,0L4.5,2L5,2.1l0.5,0.1L6,2l0.5,0.2L7,2.1l0.5,0L8,2l0.5,0L9,2l0.5,0 l0.5,0.1L10.4,2l0.5,0.2L11.4,2L12,2l-0.1,0.6L12,3.1l-0.1,0.5L11.8,4L12,4.5L11.9,5l-0.1,0.5l0,0.5L12,6.5L12,7l-0.1,0.5L12,8 l0,0.5l-0.2,0.5l0,0.5l0.1,0.5l-0.1,0.5l0.2,0.5l-0.1,0.5L11.9,11.9z"/></g></g>
<g transform="translate(96,96)"><g transform="scale(12)"><rect width="6" height="6"/></g></g>
<g transform="translate(624,96)"><g transform="scale(12)"><rect width="6" height="6"/></g></g>
<g transform="translate(96,624)"><g transform="scale(12)"><rect width="6" height="6"/></g></g>
</g><image xlink:href="data:image/png;base64,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" width="216" height="216" x="288" y="288"/></svg>
');
               background-size: contain;
            }
            
            #xtrars-btn-icon {
               width: 70px;
               height: 70px;
               display: inline-block;
               background: no-repeat center var(--xtrars-bs-img);
               background-size: contain;
               clip-path: circle(34px at center);
            }
            
            .onoffswitch-checkbox {
                float: left;
                margin-top: 3px;
                cursor: pointer;
            }
            
            .onoffswitch.disabled { 
                color: grey;            
            }
            
            .disabled:after {
                background-color: darkgrey !important;
            }
            
            .disabled:before {
                background-color: darkgrey !important;
            }
            
            .hidden {
                visibility: hidden !important;
            }
            
            .xtrars-tabcontent::-webkit-scrollbar {
                width: 10px;
            }
            
            .xtrars-tabcontent::-webkit-scrollbar-track {
                background: #fdfdfd; 
            }
             
            .xtrars-tabcontent::-webkit-scrollbar-thumb {
                background: #12a6f6; 
            }
            
            .xtrars-tabcontent::-webkit-scrollbar-thumb:hover {
                background: #0296d6; 
            }
            
            .xtrars-tabcontent {
                display: none;
                padding: 9px;
                width: 100%;
                height: calc(100% - 60px);
                overflow: auto;
            }
            
            .xtrars-active {
                text-shadow: -1px 0 #12a6f6 !important; 
                color: #12a6f6 !important; 
                background-color: rgb(253, 253, 253) !important;
            }
            
            #xtrars-settings-toolbar {
                height: 30px; 
                width: 100%; 
                color: white; 
                line-height: 30px;
                background: #12a6f6 var(--xtrars-bs-img) no-repeat center left 5px;
                background-size: auto 25px;
            }
            
            .xtrars-toolbar-text {
                display: inline-block; 
                margin-left: 10px;
                padding-left: 25px; 
                user-select: none; 
                width: calc(100% - 65px);
                text-overflow: ellipsis; 
                overflow: hidden; 
                white-space: nowrap;
                transition: width .7s;
            }
            
            .xtrars-toolbar-text:has(~ .xtrars-search input:not(:placeholder-shown) + div svg), 
            .xtrars-toolbar-text:has(~ .xtrars-search input:focus + div svg) {
                width: calc(100% - 125px);
                transition: width 0.5s;
            }
            
            .xtrars-select {
                display: inline; 
                font-size: 11px; 
                padding: 0 8px; 
                border-radius: 0;
                outline: none;
            }
            
            /*Thanks to halvves https://codepen.io/halvves/pen/ExjxaKj*/
            .xtrars-toggle {
                cursor: pointer;
                display: inline-block;
                isolation: isolate;
                position: relative;
                height: 14px;
                width: 30px;
                border-radius: 7px;
                overflow: hidden;
                box-shadow:
                    -4px -2px 4px 0 #ffffff,
                    4px 2px 6px 0 #d1d9e6,
                    2px 2px 2px 0 #d1d9e6 inset,
                    -2px -2px 2px 0 #ffffff inset;
            }
            
            .xtrars-toggle-state {
                display: none;
            }
            
            .xtrars-indicator {
                height: 100%;
                width: 200%;
                background: #12a6f6;
                border-radius: 7px;
                transform: translate3d(-75%, 0, 0);
                transition: transform .4s cubic-bezier(0.85, 0.05, 0.18, 1.35);
                box-shadow:
                    -4px -2px 4px 0 #ffffff,
                    4px 2px 6px 0 #d1d9e6;
            }
            
            
            @media (max-width: 270px) {
                #xtrars-settings-tabs .xtrars-settings-tabs, #xtrars-settings-tabs .xtrars-update-button {
                    padding-left: 3px !important;
                    padding-right: 3px !important;
                }
            }      
                  
            @media (max-width: 208px) {             
                #xtrars-settings-tabs .onoffswitch {
                    margin-right: 3px !important;
                }
            }
            
            #xtrars-settings-tabs {
                height: 30px; 
                width: 100%;
                background-color: #12a6f6; 
                color: white; 
                line-height: 33px; 
                overflow: clip
            }
            
            #xtrars-settings-tabs .onoffswitch {
                float: right;
                margin-right: 10px;
                width: 30px !important;
                min-width: 30px !important;
                display: inline-block;
            }
            
            #xtrars-settings-tabs .xtrars-indicator {
                box-shadow: none;
                background: #ecf0f3;
            }
            
            #xtrars-settings-tabs .xtrars-toggle {
                display: inline-block;
                isolation: isolate;
                position: relative;
                height: 14px;
                width: 30px;
                border-radius: 7px;
                overflow: hidden;
                box-shadow: none;
                outline: #ecf0f3 1px solid;
            }
            
            #xtrars-settings-tabs .xtrars-toggle-state:checked ~ .xtrars-indicator span {
                transform: translateX(2px) translateY(-28%);
                color: white;
            }          
              
            #xtrars-settings-tabs .xtrars-toggle-state ~ .xtrars-indicator span {
                transition: transform .4s cubic-bezier(0.85, 0.05, 0.18, 1.35);
                transform: translateX(47px) /*60 (indicator) - 11 (own width) - 2 (same space to borders as active state)*/ translateY(-28%);
                font-size: 10px;
                width: 11px;
                position: absolute;
                color: white;
                text-align: center;
            }
            
            #xtrars-settings-tabs .xtrars-toggle-state:checked ~ .xtrars-indicator {
                background-color: #0D4F8B;
            }
            
            #xtrars-settings-tabs .xtrars-toggle-state ~ .xtrars-indicator {
                background-color: #d06e6e;
            }
                                   
            .disabled .xtrars-indicator {
                background: #ecf0f3;
            }
            
            .xtrars-toggle-state:checked ~ .xtrars-indicator {
                transform: translate3d(25%, 0, 0);
            }
            
            /*Thanks to Aaron Iker https://codepen.io/aaroniker/pen/XyXzYp*/
            .xtrars-search {
                display: inline-table;
                float: right;
                margin-right: 10px;
                margin-top: 2px;
            }
            .xtrars-search input {
                box-shadow: none;
                border-radius: 0;
                -moz-border-radius: 0;
                -webkit-border-radius: 0;
                background: none;
                border: none;
                outline: none;
                width: 14px;
                min-width: 0;
                padding: 0;
                z-index: 1;
                position: relative;
                line-height: 10px;
                margin: 8px 0;
                font-size: 11px;
                -webkit-appearance: none;
                transition: all .6s ease;
                cursor: pointer;
                color: #fff;
            }
            .xtrars-search input + div {
                position: relative;
                height: 14px;
                width: 100%;
                margin: -21px 0 0 0;
            }
            .xtrars-search input + div svg {
                display: block;
                position: absolute;
                height: 14px;
                width: 79px;
                right: 0;
                top: 0;
                fill: none;
                stroke: #fff;
                stroke-width: 1px;
                stroke-dashoffset: 271.908;
                stroke-dasharray: 59 212.908;
                transition: all .6s ease;
            }
            .xtrars-search input:not(:-ms-input-placeholder) {
                width: 80px;
                padding: 0 4px;
                cursor: text;
            }
            .xtrars-search input:not(:placeholder-shown), .xtrars-search input:focus {
                width: 80px;
                padding: 0 4px;
                cursor: text;
            }
            .xtrars-search input:not(:placeholder-shown) + div svg {
                stroke-dasharray: 150 212.908;
                stroke-dashoffset: 300;
            }
            .xtrars-search input:not(:-ms-input-placeholder) + div svg {
                stroke-dasharray: 150 212.908;
                stroke-dashoffset: 300;
            }
            .xtrars-search input:not(:placeholder-shown) + div svg, .xtrars-search input:focus + div svg {
                stroke-dasharray: 150 212.908;
                stroke-dashoffset: 300;
            }
            
            @media (max-width: 320px) {
                .xtrars-update-button span {
                    display: none;
                }
                
                .xtrars-update-button .icon {
                    margin-right: 0 !important;
                }
            }

            .xtrars-update-button {
                display: inline-flex;
                align-items: center;
                background-color: #007bff; /* Same blue color as in the image */
                color: white;
                padding: 10px 15px;
                border-radius: 5px;
                height: 30px;
                font-size: 13px;
                text-decoration: none;
                transition: background-color 0.3s ease;
            }
            
            .xtrars-update-button .icon {
                width: 20px;
                height: 20px;
                margin-right: 10px;
            }
            
            #xtrars-settings-close-btn {
                user-select: none; 
                float: right; 
                margin-top: 6px; 
                background-color: transparent; 
                border: none; 
                margin-right: 10px; 
                cursor: pointer; 
                font-weight: bolder; color: white;
            }
            `.replace('<style>', '');
        document.head.appendChild(oStyle);
    }

    /**
     Creates a button element and appends it to the document.
     It waits for the element with class "infos" to be loaded and then appends the button to it as the first child.
     @async
     @returns {Promise<void>} A promise that resolves when the button is successfully added to the document.
     */
    async buildButton() {
        const oButton = document.createElement("div");
        oButton.id = 'xtrars-btn';
        oButton.innerHTML = '<i id="xtrars-btn-icon"></i>';
        await this.waitForElement('.infos').catch(() => null);
        document.getElementsByClassName('infos')[0]
            .insertBefore(oButton, document.getElementsByClassName('infos')[0].firstChild);

        if (GM_getValue('bFirstStart')) {
            GM_setValue('bFirstStart', false);
            oButton.style.animation = 'shake 1s ease 1s 1 normal;'
        }
    }

    /**
     This method builds the settings window that is displayed when the settings button is clicked. It creates and
     appends various DOM elements to the settings window such as tabs, checkboxes, and labels.
     */
    buildSettingsWindow() {
        const oSettingsWindow = document.createElement("div");
        oSettingsWindow.innerHTML = `
            <div id="xtrars-settings-toolbar">
                <div class="xtrars-toolbar-text">BETSLIX - Settings</div>
                <button id="xtrars-settings-close-btn">✕</button>
                
                <div class="xtrars-search">
                    <input class="xtrars-search-input" type="text" placeholder=" ">
                <div>
                        <svg>
                            <use xlink:href="#path">
                        </svg>
                    </div>
                </div>
                    
                <svg xmlns="http://www.w3.org/2000/svg" style="display: none;">
                    <symbol xmlns="http://www.w3.org/2000/svg" viewBox="0 0 160 28" id="path">
                        <path d="M32.9418651,-20.6880772 C37.9418651,-20.6880772 40.9418651,-16.6880772 40.9418651,-12.6880772 C40.9418651,-8.68807717 37.9418651,-4.68807717 32.9418651,-4.68807717 C27.9418651,-4.68807717 24.9418651,-8.68807717 24.9418651,-12.6880772 C24.9418651,-16.6880772 27.9418651,-20.6880772 32.9418651,-20.6880772 L32.9418651,-29.870624 C32.9418651,-30.3676803 33.3448089,-30.770624 33.8418651,-30.770624 C34.08056,-30.770624 34.3094785,-30.6758029 34.4782612,-30.5070201 L141.371843,76.386562" transform="translate(83.156854, 22.171573) rotate(-225.000000) translate(-83.156854, -22.171573)"></path>
                    </symbol>
                </svg>            
            </div>
            <div id="xtrars-settings-tabs">                
                <button 
                    class="tab xtrars-settings-tabs ${GM_getValue('sLastActiveTab') === 'BS' || GM_getValue('sLastActiveTab') === '' ? 'xtrars-active' : ''}" 
                    data-tab="BS">BS
                </button>
                <button 
                    class="tab xtrars-settings-tabs ${GM_getValue('sLastActiveTab') === 'Streaming' ? 'xtrars-active' : ''}" 
                    data-tab="Streaming">Streaming
                </button>
                <button 
                    class="tab xtrars-settings-tabs ${GM_getValue('sLastActiveTab') === 'Info' ? 'xtrars-active' : ''}" 
                    data-tab="Info">Info
                </button>
                
                <div class="onoffswitch">
                    <label class="onoffswitch-label" data-search="">
                        <div class="xtrars-toggle">
                            <input class="onoffswitch-checkbox xtrars-onoffswitch xtrars-toggle-state" 
                            type="checkbox" name="xtrars-onoffswitch" value="check" />
                            <div class="xtrars-indicator">
                                <span class="xtrars-power-symbol">&#x23FB;</span>
                            </div>
                        </div>
                    </label>
                </div>
  
                <a href="https://update.greasyfork.org/scripts/429666/BETSLIX%20-%20burning%20series%20enhancer.user.js" rel="nofollow" class="tab xtrars-update-button">
                    <img src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADIAAAAyCAYAAAAeP4ixAAAACXBIWXMAAAsTAAALEwEAmpwYAAAC40lEQVR4nO2Zy2oUQRSGSxPjdZOgwYjGN/ASkRAQ3LgwLsQRQdciivGyUBQvKAgJbhIwER9BRUVEEi/vIC4mKi4UI06MTLwhgia6+OTgCXSKms70TJVQ0h8MDNVT5++/e6rq1CljcnJycrIAzAc2A+eBO8Az4BMwDfwCvgCjwF3gDNApfUxogF3AJFAGdqb8rh3oBSbIzjugD1gV0sj7hOC443orcFWfeL1MAUNAcwgjs7Cu7QU+4p9JoBDcCNAIXEu5kW/ADeCAjpcVQBOwQL9L22HgIfAzJc4Q0BDECLAIeFRB+BWwH1iSIf5SoMf6Cye5DywMYWTE0fYDOCVvqg6dxTqLucbavXpiVzJi8xpYV5fIbL0umVQcOgMhjRRl1vJlIqG5Enjh0CuEfCMzjAHdHs2sdaxJH4CW0EaEki8jArBJ15Yk/SY2IwJw2dKQ6brNZCWDiTfA9swCc+svcwz+CyZGgOP2QzMxwt9sQDLnJOtNjAAPLCMnTIwAxywj102MAFssI09MjABrLCMTWTpv06z0M7Av6J1Wt4UuJ4wUs3R+mej41dveoEaA3Zq2SDq0NUtHO9dZbWIEeGoZ6TIxAty0jPSYGAFOWkaGTYwAGywjv0NspIIDzAPeWmaOmhgBLlpGSpJaB9DZodNqVdQi0OaoPfUFMOIqOFSkVpF+K45sPzs8G5E3XTWmRpEW3fgnkcWy3aORbt1lhjOiQgVHvOdSuvFlxioHjQYxogIDjpjjPld8YGM1g75ekUYtX9pImfNslpqvI7YUuc9VKGoPezWSEJTCsgsZN0ekMJ2xSnIwZXyMSBHbuxEVbwAGU968zGqP1VSnHgY16Q21atsh4DbwPSXO4EzxOogRawKQQxnflIE9llY4IyrQDFxxlDZrYUpjLXfojP2TupZOmb2O3KwaZDG8JPvyOdaZkn68VzQrJZpytHZaj6eLuuef1ic+qW239GCnQ/oEv7GcnJz/iz/Wmk6MdR/K1gAAAABJRU5ErkJggg==" alt="Update Icon" class="icon">
                    <span>Update</span>
                </a>
            </div>
            <!-- Tab content -->
            <div id="BS" class="xtrars-tabcontent" style="display: block; overflow: auto;">
                <div class="onoffswitch">
                    <label class="onoffswitch-label"
                        data-search="nächste,folgende,episode,wird,zufällig,abgespielt">
                        <div class="xtrars-toggle">
                            <input class="onoffswitch-checkbox xtrars-onoffswitch xtrars-toggle-state" 
                            type="checkbox" name="xtrars-onoffswitch" value="check" />
                            <div class="xtrars-indicator"></div>
                        </div>
                    </label>
                    <div class="label-wrapper">
                        <span class="onoffswitch-inner auto-random-episode">
                            <span>Nächste <strong>folgende</strong> Episode wird abgespielt</span>
                            <span>Nächste Episode wird <strong>zufällig</strong> abgespielt</span>
                        </span>
                    </div>
                </div>
                <div class="onoffswitch">
                    <label class="onoffswitch-label"
                        data-search="nächste,staffel,wird,automatisch,manuell,abgespielt">
                        <div class="xtrars-toggle">
                            <input class="onoffswitch-checkbox xtrars-onoffswitch xtrars-toggle-state" 
                            type="checkbox" name="xtrars-onoffswitch" value="check" />
                            <div class="xtrars-indicator"></div>
                        </div>
                    </label>
                    <div class="label-wrapper">
                        <span class="onoffswitch-inner auto-next-season">
                            <span>Nächste Staffel wird <strong>automatisch</strong> abgespielt</span>
                            <span>Nächste Staffel wird <strong>manuell</strong> abgespielt</span>
                        </span>
                    </div>
                </div>
                <div class="onoffswitch">
                    <label for="xtrars-onoffswitch" class="onoffswitch-label"
                        data-search="wechselt,zum,${this.getHoster(0, true)},${this.getHoster(1, true)},${this.getHoster(2, true)},${this.getHoster(3, true)},tab" 
                        style="font-size: 11px; float: left; height: 21px; padding-top: 4px;">
                        Wechselt zum
                        <select name="" class="xtrars-select xtrars-onoffswitch" style="width: 100px; max-width: 40%">
                            <option value="${this.getHoster(3, true)}">
                                ${this.getHoster(3, false)}
                            </option>
                            <option value="${this.getHoster(0, true)}">
                                ${this.getHoster(0, false)}
                            </option>
                            <option value="${this.getHoster(1, true)}">
                                ${this.getHoster(1, false)}
                            </option>
                            <option value="${this.getHoster(2, true)}">
                                ${this.getHoster(2, false)}
                            </option>
                        </select>
                        -Tab
                    </label>
                </div>
            </div>
            
            <div id="Streaming" class="xtrars-tabcontent">
                <div class="onoffswitch">
                    <label class="onoffswitch-label"
                        data-search="video,überspringt,ueberspringt,uberspringt,x,sekunden,anfang,spielt,von,überspringen,ueberspringen,uberspringen">
                        <div class="xtrars-toggle">
                            <input class="onoffswitch-checkbox xtrars-onoffswitch xtrars-toggle-state" type="checkbox" 
                                name="xtrars-onoffswitch" value="check" />
                            <div class="xtrars-indicator"></div>
                        </div>
                    </label>
                    <div class="label-wrapper">
                        <span class="onoffswitch-inner skip-start">
                            <span>Anfang des Videos wird <strong>x Sekunden übersprungen</strong></span>
                            <span>Video spielt <strong>von Anfang an</strong></span>
                        </span>
                         <input class="skip-start" type="text"
                        size="3" maxlength="3" 
                        value="${isNaN(GM_getValue('iSkipStartTime')) ? '' : GM_getValue('iSkipStartTime')}">
                    </div>
                </div>
                <div class="onoffswitch">
                    <label class="onoffswitch-label"
                        data-search="video,wird,x,sekunden,vor,ende,beendet,spielt,bis,zum,überspringen,ueberspringen,uberspringen,überspringt,ueberspringt,uberspringt">
                        <div class="xtrars-toggle">
                            <input class="onoffswitch-checkbox xtrars-onoffswitch xtrars-toggle-state" type="checkbox" 
                                name="xtrars-onoffswitch" value="check" />
                            <div class="xtrars-indicator"></div>
                        </div>
                    </label>
                    <div class="label-wrapper">
                        <span class="onoffswitch-inner skip-end">
                            <span>Video wird <strong>x Sekunden vor Ende</strong> beendet</span>
                
                        <span>Video spielt <strong>bis zum Ende</strong></span></span>
                         <input class="skip-end" type="text"
                        size="3" maxlength="3" 
                        value="${isNaN(GM_getValue('iSkipEndTime')) ? '' : GM_getValue('iSkipEndTime')}">
                    </div>
                </div>
            </div>
            
            <div id="Info" class="xtrars-tabcontent" style="font-size: 11px;">
                <div  class="xtrars-donation-container">
                    <div class="xtrars-donation-text">
                        <span style="font-weight: bold;">BETSLIX - burning series enhancer by xtrars</span> <br> 
                        Du magst meine Arbeit und das Projekt erleichtert dir dein Streaming-Leben? 
                        Dann gib mir doch ein leckeren Tee aus, denn so kann das Projekt immer weiter optimiert werden
                        und am Leben bleiben:
                        <a class="xtrars-donate" href="https://paypal.me/betslix" 
                            target="_blank">Spenden</a>
                        Danke dir :)
                    </div>
                    <i id="xtrars-pp-qr"></i>
                </div>
            </div>
        `;
        oSettingsWindow.style.cssText = 'display: none;';
        oSettingsWindow.id = 'xtrars-settings-window';
        oSettingsWindow.classList.add('run-circleToWindow-animation');
        document.getElementById('root')?.appendChild(oSettingsWindow);
    }

    /**
     Handles the start of the drag operation on the settings window.
     @param {MouseEvent|TouchEvent} o - The event object for the drag start.
     */
    dragStart(o) {
        document.settingsWindowActive = true;
        let oSettingsWindow = document.getElementById('xtrars-settings-window');
        let iSettingsWindowLeft = parseInt(window.getComputedStyle(oSettingsWindow).left);
        let iSettingsWindowTop = parseInt(window.getComputedStyle(oSettingsWindow).top);

        if (o.type === "touchstart" && o.touches?.length) {
            document.settingsWindowInitialX = o.touches[0].clientX - iSettingsWindowLeft;
            document.settingsWindowInitialY = o.touches[0].clientY - iSettingsWindowTop;
        }
        else {
            document.settingsWindowInitialX = o.clientX - iSettingsWindowLeft;
            document.settingsWindowInitialY = o.clientY - iSettingsWindowTop;
        }
    }

    /**
     Handles the end of the drag operation on the settings window.
     */
    dragEnd() {
        document.settingsWindowActive = false;
        let oSettingsWindow = document.getElementById('xtrars-settings-window');
        let iPixels = 2;
        let iPositionInterval = setInterval(() => {
            if (parseInt(window.getComputedStyle(oSettingsWindow).left) <= 0) {
                oSettingsWindow.style.left = parseInt(oSettingsWindow.style.left) + iPixels + 'px';
            }
            else if (parseInt(window.getComputedStyle(oSettingsWindow).top) <= 0) {
                oSettingsWindow.style.top = parseInt(oSettingsWindow.style.top) + iPixels + 'px';
            }
            else if (parseInt(window.getComputedStyle(oSettingsWindow).right) <= 0) {
                oSettingsWindow.style.left = parseInt(oSettingsWindow.style.left) - iPixels + 'px';
            }
            else if (parseInt(window.getComputedStyle(oSettingsWindow).bottom) <= 0) {
                oSettingsWindow.style.top = parseInt(oSettingsWindow.style.top) - iPixels + 'px';
            }
            else {
                clearInterval(iPositionInterval);
                if (oSettingsWindow.style.top !== '' && oSettingsWindow.style.left !== '') {
                    GM_setValue('oSettingsWindowPosition', {
                        x: oSettingsWindow.style.left,
                        y: oSettingsWindow.style.top,
                    });
                }
            }
        }, 1);
    }

    /**
     Handles the dragging of the settings window.
     @param {Event} o - The event object for the drag.
     */
    drag(o) {
        if (!document.settingsWindowActive) return;

        o.preventDefault();

        let oSettingsWindow = document.getElementById('xtrars-settings-window');
        let iCurrentX;
        let iCurrentY;
        if (o.type === "touchmove") {
            iCurrentX = (o.touches[0].clientX - document.settingsWindowInitialX);
            iCurrentY = (o.touches[0].clientY - document.settingsWindowInitialY);
        }
        else {
            iCurrentX = (o.clientX - document.settingsWindowInitialX);
            iCurrentY = (o.clientY - document.settingsWindowInitialY);
        }

        oSettingsWindow.style.top = iCurrentY + 'px';
        oSettingsWindow.style.left = iCurrentX + 'px';
    }

    /**
     Shows the settings window.
     */
    showSettingsWindow(bWithSlideIn = false) {
        const oSettingsWindow = document.getElementById('xtrars-settings-window');


        if (bWithSlideIn) {
            this.#slideInAndOpenOrSlideOutAndCloseWindow();
            oSettingsWindow.classList.remove('run-windowToCircle-animation');
            oSettingsWindow.classList.add('run-circleToWindow-animation');
        }

        // Vorher schonmal setzen, damit korrekte Breite und Höhe berechnet werden kann
        oSettingsWindow.style.cssText = `height: ${this.#nSettingsWindowHeight}px; width: ${this.#nSettingsWindowWidth}px; max-width: calc(100% - 5px); 
            max-height: calc(100% - 5px); display: block; position: fixed;`;
        oSettingsWindow.style.cssText = `height: ${this.#nSettingsWindowHeight}px; width: ${this.#nSettingsWindowWidth}px; max-width: calc(100% - 5px); 
            max-height: calc(100% - 5px); display: block; position: fixed; 
            top: ${GM_getValue('oSettingsWindowPosition').y ?? "calc(50% - " + (parseInt(window.getComputedStyle(oSettingsWindow).height) / 2) + "px)"};
            left: ${GM_getValue('oSettingsWindowPosition').x ?? "calc(50% - " + (parseInt(window.getComputedStyle(oSettingsWindow).width) / 2) + "px)"};
            background-color: #fdfdfd; box-shadow: rgba(0, 0, 0, .4) 1px 1px 10px 5px; z-index: 161;`

        if (!GM_getValue('bIsSettingsWindowOpen')) {
            this.restartAnimation(oSettingsWindow);
        }

        document.addEventListener("touchmove", this.drag, {passive: false});
        document.addEventListener("mousemove", this.drag, {passive: false});

        GM_setValue('bIsSettingsWindowOpen', true);
        GM_setValue('oSettingsWindowPosition', {
            x: window.getComputedStyle(oSettingsWindow).left,
            y: window.getComputedStyle(oSettingsWindow).top,
        });
    }

    /**
     Shows the content of the specified tab.
     @param {string} sTab - The ID of the tab to show.
     */
    showTabContent(sTab) {
        let oTabContent = document.querySelectorAll('.xtrars-tabcontent');
        oTabContent.forEach(oItem => {
            oItem.style.display = 'none';
        });

        document.getElementById(sTab).style.display = 'block';
        GM_setValue('sLastActiveTab', sTab);
    }

    /**
     Initializes the events and buttons that appear in the extension.
     */
    initEvents() {
        const oButton = document.getElementById('xtrars-btn');
        const oToolbar = document.getElementById('xtrars-settings-toolbar');
        const oSettingsWindow = document.getElementById('xtrars-settings-window');
        const oTabs = document.querySelectorAll('.xtrars-settings-tabs');

        const oActivateEnhancer = document.querySelector('#xtrars-settings-tabs .xtrars-onoffswitch');

        const oBsCheckboxes = document.querySelectorAll('#BS .xtrars-onoffswitch');
        const oStreamingCheckboxes = document.querySelectorAll('#Streaming .xtrars-onoffswitch');

        const oAutoplayRandomEpisode = oBsCheckboxes[0]; //auto-random-episode
        const oAutoplayNextSeason = oBsCheckboxes[1]; //auto-next-season
        const oSelectHoster = oBsCheckboxes[2]; // select-hoster

        const oSkipStart = oStreamingCheckboxes[0]; //skip-start
        const oSkipEnd = oStreamingCheckboxes[1]; //skip-end

        const oSkipStartInput = document.querySelector('input.skip-start');
        const oSkipEndInput = document.querySelector('input.skip-end');

        const oSearchInput = document.querySelector('.xtrars-search-input');

        oTabs.forEach(oItem => {
            oItem.addEventListener('click', e => {
                oTabs.forEach(oTab => {
                    oTab.classList.remove('xtrars-active');
                });
                e.target.classList.add('xtrars-active');
                this.showTabContent(e.target.dataset.tab);
            });
        });
        //
        // oUpdate.addEventListener('click', () => {
        //     window.open('https://update.greasyfork.org/scripts/429666/BETSLIX%20-%20burning%20series%20enhancer.user.js')
        // })

        // Öffne Settings
        !oButton || oButton.addEventListener('click', () => {

            if (this.#bButtonDisabled === true) return;

            this.#bButtonDisabled = true;
            setTimeout(() => {
                this.#bButtonDisabled = false;
            }, 500);

            if (GM_getValue('bIsSettingsWindowOpen') === true) {
                this.#closeSettingsWindow(oSettingsWindow);
            }
            else {
                this.showSettingsWindow(true);
                if (GM_getValue('bFirstStart')) {
                    GM_setValue('bFirstStart', false);
                    document.getElementsByClassName('xtrars-switch')[0].style.animation = 'shake 1s ease 1s 1 normal;'
                }
                document.addEventListener("touchmove", this.drag, {passive: false});
                document.addEventListener("mousemove", this.drag, {passive: false});
            }
        });

        !oToolbar || oToolbar.addEventListener("touchstart", this.dragStart, {passive: false});
        !oToolbar || oToolbar.addEventListener("mousedown", this.dragStart, {passive: false});
        document.addEventListener("touchend", this.dragEnd, {passive: false});
        document.addEventListener("mouseup", this.dragEnd, {passive: false});
        document.addEventListener("contextmenu", this.dragEnd, {passive: false});

        // Schließe Settings
        if (document.getElementById('xtrars-settings-close-btn')) {
            document.getElementById('xtrars-settings-close-btn').addEventListener('click', () => {
                this.#closeSettingsWindow(oSettingsWindow);
            });
        }


        let oManagedButtons = {
            'activateEnhancer': oActivateEnhancer,
            'autoplayRandomEpisode': oAutoplayRandomEpisode,
            'autoplayNextSeason': oAutoplayNextSeason,
            'selectHoster': oSelectHoster,
            'skipStart': oSkipStart,
            'skipEnd': oSkipEnd,
        };

        this.manageButtonState(oManagedButtons);

        !oActivateEnhancer || oActivateEnhancer.addEventListener('change', () => {
            GM_setValue('bActivateEnhancer', oActivateEnhancer ? oActivateEnhancer.checked : false);
            this.manageButtonState(oManagedButtons);
            this.reload();
        });

        !oAutoplayRandomEpisode || oAutoplayRandomEpisode.addEventListener('change', () => {
            GM_setValue('bAutoplayRandomEpisode', oAutoplayRandomEpisode ? !oAutoplayRandomEpisode.checked : false);
            this.manageButtonState(oManagedButtons);
        });

        !oAutoplayNextSeason || oAutoplayNextSeason.addEventListener('change', () => {
            GM_setValue('bAutoplayNextSeason', oAutoplayNextSeason ? oAutoplayNextSeason.checked : false);
        });

        !oSelectHoster || oSelectHoster.addEventListener('change', () => {
            GM_setValue('bSelectHoster', oSelectHoster.value);
        });

        !oSkipStart || oSkipStart.addEventListener('change', () => {
            GM_setValue('bSkipStart', oSkipStart ? oSkipStart.checked : false);
            let oSkipStartInput = document.querySelector('input.skip-start');
            (oSkipStart ? oSkipStart.checked : false) ?
                oSkipStartInput.style.display = "block" :
                oSkipStartInput.style.display = "none";
        });

        !oSkipEnd || oSkipEnd.addEventListener('change', () => {
            GM_setValue('bSkipEnd', oSkipEnd ? oSkipEnd.checked : false);
            let oSkipEndInput = document.querySelector('input.skip-end');
            (oSkipEnd ? oSkipEnd.checked : false) ?
                oSkipEndInput.style.display = "block" :
                oSkipEndInput.style.display = "none";
        });

        !oSkipEndInput || oSkipEndInput.addEventListener('keyup', (e) => {
            e.target.value = isNaN(parseInt(e.target.value)) ? '' : parseInt(e.target.value);
            GM_setValue('iSkipEndTime', parseInt(e.target.value));
        });

        !oSkipStartInput || oSkipStartInput.addEventListener('keyup', (e) => {
            e.target.value = isNaN(parseInt(e.target.value)) ? '' : parseInt(e.target.value);
            GM_setValue('iSkipStartTime', parseInt(e.target.value));
        });


        let iPixels = 2;
        window.addEventListener('resize', () => {
            let iPositionInterval = setInterval(() => {
                if (parseInt(window.getComputedStyle(oSettingsWindow).left) <= 0) {
                    oSettingsWindow.style.left = parseInt(oSettingsWindow.style.left) + iPixels + 'px';
                }
                else if (parseInt(window.getComputedStyle(oSettingsWindow).top) <= 0) {
                    oSettingsWindow.style.top = parseInt(oSettingsWindow.style.top) + iPixels + 'px';
                }
                else if (parseInt(window.getComputedStyle(oSettingsWindow).right) <= 0) {
                    oSettingsWindow.style.left = parseInt(oSettingsWindow.style.left) - iPixels + 'px';
                }
                else if (parseInt(window.getComputedStyle(oSettingsWindow).bottom) <= 0) {
                    oSettingsWindow.style.top = parseInt(oSettingsWindow.style.top) - iPixels + 'px';
                }
                else {
                    clearInterval(iPositionInterval);
                }
            }, 1);
        });

        !oSearchInput || oSearchInput.addEventListener('keyup', this.search);
        !oSearchInput || oSearchInput.addEventListener('mousemove', (e) => e.stopPropagation());
        !oSearchInput || oSearchInput.addEventListener('mousedown', (e) => e.stopPropagation());
        !oSkipStartInput || oSkipStartInput.addEventListener('mousemove', (e) => e.stopPropagation());
        !oSkipEndInput || oSkipEndInput.addEventListener('mousemove', (e) => e.stopPropagation());

        // Label-Workaround
        document.querySelectorAll('input[type="checkbox"][class~="onoffswitch-checkbox"]')
            .forEach(oElement => {
                labelWorkaround(oElement);
                oElement.addEventListener('change', o => {
                    labelWorkaround(o.target)
                });
            });

        function labelWorkaround(oElement) {
            let oInputTextElement = oElement.closest('.onoffswitch').querySelector('.label-wrapper > .onoffswitch-inner');

            if (!oInputTextElement) return;

            if (oElement.checked) {
                oInputTextElement.classList.add('workaroundChecked');
            }
            else {
                oInputTextElement.classList.remove('workaroundChecked');
            }
        }
    }

    /**
     This function searches for a keyword in a list of elements and highlights the matching elements with a red dashed outline.
     It also highlights the corresponding tab of the matched element with a red color.
     The search is case-insensitive and supports searching for multiple words separated by spaces.
     @param {Event} o - The event object passed to the function, which contains the search keyword in its target value.
     @returns {void}
     */
    search(o) {
        let bHasSearchWord;
        let iIndex = -1;
        let iTabIndex = 0;
        let oTabs = document.querySelectorAll('.xtrars-settings-tabs');

        for (const oTab of oTabs) {
            oTab.style.removeProperty('color');
        }

        for (const oElement of document.querySelectorAll('.onoffswitch-label')) {
            oElement.style.removeProperty('outline');
            bHasSearchWord = true;
            for (const sSearchWord of o.target.value.toLowerCase().split(' ').filter((s) => s !== '')) {
                let aSearchKeywords = oElement.dataset.search.toLowerCase().split(',')
                iIndex = 0;
                for (const sSearchKeyword of aSearchKeywords) {
                    iIndex++;
                    if (bHasSearchWord && sSearchKeyword.includes(sSearchWord)) {
                        break;
                    }
                    if (iIndex >= aSearchKeywords.length) {
                        oElement.style.removeProperty('outline');
                        bHasSearchWord = false;
                    }
                }
            }
            if (bHasSearchWord && iIndex !== -1) {
                oElement.style.setProperty('outline', '1px dashed red', 'important');
                let sTab = oElement.parentElement.parentElement.getAttribute('id');
                for (const oTab of oTabs) {
                    if (sTab === oTab.dataset.tab) {
                        oTab.style.color = 'red';
                        if (iTabIndex === 0) {
                            oTab.click();
                        }
                        iTabIndex++;
                    }
                }
            }
        }
    }

    /**
     Manages the state of the buttons in the setting window.
     @param {Object} oManagedButtons - The object containing the list of all the managed buttons.
     */
    manageButtonState(oManagedButtons) {
        let oActivateEnhancer = oManagedButtons.activateEnhancer;
        let oAutoplayRandomEpisode = oManagedButtons.autoplayRandomEpisode;
        let oAutoplayNextSeason = oManagedButtons.autoplayNextSeason;
        let oSelectHoster = oManagedButtons.selectHoster;
        let oSkipStart = oManagedButtons.skipStart;
        let oSkipEnd = oManagedButtons.skipEnd;

        !oActivateEnhancer || (oActivateEnhancer.checked = GM_getValue('bActivateEnhancer'));
        !oAutoplayRandomEpisode || (oAutoplayRandomEpisode.checked = !GM_getValue('bAutoplayRandomEpisode'));
        !oAutoplayNextSeason || (oAutoplayNextSeason.checked = GM_getValue('bAutoplayNextSeason'));
        !oSelectHoster || (oSelectHoster.value = GM_getValue('bSelectHoster'));
        !oSkipStart || (oSkipStart.checked = GM_getValue('bSkipStart'));
        !oSkipEnd || (oSkipEnd.checked = GM_getValue('bSkipEnd'));

        let oSkipStartInput = document.querySelector('input.skip-start');
        !oSkipStart || (oSkipStart.checked ? oSkipStartInput.style.display = "block" : oSkipStartInput.style.display = "none");
        let oSkipEndInput = document.querySelector('input.skip-end');
        !oSkipEnd || (oSkipEnd.checked ? oSkipEndInput.style.display = "block" : oSkipEndInput.style.display = "none");

        if (oActivateEnhancer ? !oActivateEnhancer.checked : false) {
            this.disableButton(oAutoplayNextSeason);
            this.disableButton(oAutoplayRandomEpisode);
            this.disableButton(oSelectHoster);
            this.disableButton(oSkipStart);
            this.disableButton(oSkipEnd);
            oSkipStartInput.style.display = "none";
            oSkipEndInput.style.display = "none";
        }
        else {
            this.enableButton(oSelectHoster);
            this.enableButton(oAutoplayRandomEpisode);
            this.enableButton(oSelectHoster);
            this.enableButton(oSkipStart);
            this.enableButton(oSkipEnd);
            !oSkipStart || (oSkipStart.checked ? oSkipStartInput.style.display = "block" : oSkipStartInput.style.display = "none");
            !oSkipEnd || (oSkipEnd.checked ? oSkipEndInput.style.display = "block" : oSkipEndInput.style.display = "none");

            if (oAutoplayRandomEpisode ? !oAutoplayRandomEpisode.checked : false) {
                this.disableButton(oAutoplayNextSeason);
            }
            else {
                this.enableButton(oAutoplayNextSeason);
            }
        }
    }

    /**
     Disables a given settings slider.
     @param {Element} oElement - The element to be disabled.
     */
    disableButton(oElement) {
        if (!oElement) return;

        if (oElement && oElement.parentElement.childNodes[3] &&
            oElement.parentElement.childNodes[3].childNodes[1] &&
            oElement.parentElement.childNodes[3].childNodes[1].classList.contains('auto-next-episode')) {
            this.playNextEpisodeIfVideoEnded(false);
        }

        oElement.classList.add('disabled');
        oElement.parentElement.classList.add('disabled');
        oElement.disabled = true;
    }

    /**
     Enables a given settings slider.
     @param {Element} oElement - The element to be enabled.
     */
    enableButton(oElement) {
        if (!oElement) return;

        oElement.classList.remove('disabled');
        oElement.parentElement.classList.remove('disabled');
        oElement.disabled = false
    }

    /**
     Skips the unavailable hosters.
     @async
     @param {Array} aHosterOrder - The list of hosters to try in the given order.
     @returns {Promise} A Promise that resolves when all unavailable hosters have been skipped.
     */
    async skipUnavailable(aHosterOrder) {
        let oHoster = await this.waitForElement(`.hoster-tabs .hoster.${aHosterOrder[0]}`, false);
        if (oHoster !== null) {
            document.location.replace(document.location.href + '/' + aHosterOrder[0]);
        }
        else {
            oHoster = await this.waitForElement(`.hoster-tabs .hoster.${aHosterOrder[1]}`, false);
            if (oHoster !== null) {
                document.location.replace(document.location.href + '/' + aHosterOrder[1]);
            }
            else {
                document.location.replace(document.location.href + '/' + aHosterOrder[2]);
            }
        }
    }

    /**
     Handles the video element for the given streaming hoster.
     @async
     @param {string} sActiveTab - The active tab.
     @param {Array} aToBeChecked - An array of regular expressions to check against.
     @returns {Promise<void>} A Promise that resolves after the video element is handled.
     */
    async handleBsVideo(sActiveTab, aToBeChecked) {
        for (const regexHoster of aToBeChecked) {
            if (regexHoster.test(sActiveTab)) {
                let oIframe = await this.waitForElement('section.serie .hoster-player > iframe');
                let sSrc = oIframe.src;
                window.open(sSrc, '_blank').focus();
                oIframe.remove();
                let oHosterPlayer = await this.waitForElement('.hoster-player');
                oHosterPlayer.innerHTML = `
                    <h2 class="">Dein Stream ist jetzt bereit</h2>
                    <div class="play" style="display: none;"></div>
                    <div class="loading" style="display: none;">
                        <div class="wrapper">
                            <div class="line"></div>
                        </div>
                        <div class="wrapper">
                            <div class="line"></div>
                        </div>
                        <div class="wrapper">
                            <div class="line"></div>
                        </div>
                        <div class="wrapper">
                            <div class="line"></div>
                        </div>
                        <div class="wrapper">
                            <div class="line"></div>
                        </div>
                    </div>
                    <a href="${sSrc}" target="_blank" rel="noreferrer">${sSrc}</a>
                `;
                break;
            }
        }
    }

    #slideInAndOpenOrSlideOutAndCloseWindow() {
        const rStartX = /(?<=@keyframes\s*xtrarsSlideIn\s*{\s*?0%\s*{transform: translate\()-?(0|\d+(\.|\d)*?px)/;
        const rStartY = /(?<=@keyframes\s*xtrarsSlideIn\s*{\s*0%\s*{transform: translate\(-?\d+(\.|\d)*(px)?,\s?)-?(0|\d+(\.|\d)*?px)/;
        const rHalfWayX = /(?<=@keyframes\s*xtrarsSlideIn\s*{(\s|.)*?40%\s*{transform: translate\()-?(0|\d+(\.|\d)*?px)/;
        const rHalfWayY = /(?<=@keyframes\s*xtrarsSlideIn\s*{(\s|.)*?40%\s*{transform: translate\(-?\d+(\.|\d)*px,\s?)-?(0|\d+(\.|\d)*?px)/;
        const rBeforeEndX = /(?<=@keyframes\s*xtrarsSlideIn\s*{(\s|.)*?99.99%\s*{transform: translate\()-?(0|\d+(\.|\d)*?px)/;
        const rBeforeEndY = /(?<=@keyframes\s*xtrarsSlideIn\s*{(\s|.)*?99.99%\s*{transform: translate\(-?\d+(\.|\d)*(px)?,\s?)-?(0|\d+(\.|\d)*?px)/;
        const rEndX = /(?<=@keyframes\s*xtrarsSlideIn\s*{(\s|.)*?100%\s*{transform: translate\()-?(0|\d+(\.|\d)*?px)/;
        const rEndY = /(?<=@keyframes\s*xtrarsSlideIn\s*{(\s|.)*?100%\s*{transform: translate\(-?\d+(\.|\d)*(px)?,\s?)-?(0|\d+(\.|\d)*?px)/;

        const oXtrarsBtn = document.getElementById('xtrars-btn');

        const oXtrarsBtnCoords = oXtrarsBtn?.getBoundingClientRect();
        const nXtrarsBtnWidth = oXtrarsBtn.getBoundingClientRect().width;
        const oXtrarsStyle = document.getElementById('xtrars-style');

        const nSettingsRealWidth = document.body.clientWidth > this.#nSettingsWindowWidth ? this.#nSettingsWindowWidth : document.body.clientWidth;


        // Damit Button nicht über Fenster ist
        oXtrarsBtn.style.cssText = 'z-index: 162;';
        setTimeout(() => {
            oXtrarsBtn.style.cssText = '';
        }, 600);

        // Ergänzt bestehenden CSS-Code mit den nötigen Koordinaten, um eine Animation mit CSS-Only zu erreichen
        if (oXtrarsBtnCoords && !GM_getValue('bIsSettingsWindowOpen')) {
            oXtrarsStyle.innerHTML = oXtrarsStyle.innerHTML
                .replace(rStartX,
                    (oXtrarsBtnCoords.x - parseInt(GM_getValue('oSettingsWindowPosition').x) -
                        nSettingsRealWidth / 2 + nXtrarsBtnWidth / 2)
                        .toString() + 'px')
                .replace(rStartY,
                    (oXtrarsBtnCoords.y - parseInt(GM_getValue('oSettingsWindowPosition').y) -
                        this.#nSettingsWindowHeight / 2 + nXtrarsBtnWidth / 2)
                        .toString() + 'px')
                .replace(rHalfWayX,
                    ((oXtrarsBtnCoords.x - parseInt(GM_getValue('oSettingsWindowPosition').x) -
                        (nSettingsRealWidth + nXtrarsBtnWidth) / 2) / 2)
                        .toString() + 'px')
                .replace(rHalfWayY,
                    ((oXtrarsBtnCoords.y - parseInt(GM_getValue('oSettingsWindowPosition').y) -
                        (this.#nSettingsWindowHeight + nXtrarsBtnWidth) / 2) / 2)
                        .toString() + 'px')
                .replace(rBeforeEndX, '0')
                .replace(rBeforeEndY, '0')
                .replace(rEndX, '0')
                .replace(rEndY, '0');
        }
        else {
            oXtrarsStyle.innerHTML = oXtrarsStyle.innerHTML
                .replace(rStartX, '0')
                .replace(rStartY, '0')
                .replace(rHalfWayX,
                    ((oXtrarsBtnCoords.x - parseInt(GM_getValue('oSettingsWindowPosition').x) -
                        (nSettingsRealWidth + nXtrarsBtnWidth) / 2) / 2)
                        .toString() + 'px')
                .replace(rHalfWayY,
                    ((oXtrarsBtnCoords.y - parseInt(GM_getValue('oSettingsWindowPosition').y) -
                        (this.#nSettingsWindowHeight + nXtrarsBtnWidth) / 2) / 2)
                        .toString() + 'px')
                .replace(rBeforeEndX, (oXtrarsBtnCoords.x - parseInt(GM_getValue('oSettingsWindowPosition').x) -
                    nSettingsRealWidth / 2 + nXtrarsBtnWidth / 2)
                    .toString() + 'px')
                .replace(rBeforeEndY, (oXtrarsBtnCoords.y - parseInt(GM_getValue('oSettingsWindowPosition').y) -
                    this.#nSettingsWindowHeight / 2 + nXtrarsBtnWidth / 2)
                    .toString() + 'px')
                .replace(rEndX,
                    (oXtrarsBtnCoords.x - parseInt(GM_getValue('oSettingsWindowPosition').x) -
                        nSettingsRealWidth / 2 + nXtrarsBtnWidth / 2)
                        .toString() + 'px')
                .replace(rEndY,
                    (oXtrarsBtnCoords.y - parseInt(GM_getValue('oSettingsWindowPosition').y) -
                        this.#nSettingsWindowHeight / 2 + nXtrarsBtnWidth / 2)
                        .toString() + 'px');
        }
    }

    #closeSettingsWindow(oSettingsWindow) {
        document.removeEventListener("touchmove", this.drag);
        document.removeEventListener("mousemove", this.drag);

        this.#slideInAndOpenOrSlideOutAndCloseWindow();
        oSettingsWindow.classList.remove('run-circleToWindow-animation');
        oSettingsWindow.classList.add('run-windowToCircle-animation');
        this.restartAnimation(oSettingsWindow);


        GM_setValue('bIsSettingsWindowOpen', false);
        GM_setValue('sLastActiveTab', '');
    }

    #nSettingsWindowWidth = 500;
    #nSettingsWindowHeight = 170;
    #bButtonDisabled = false;
}

/**
 The CStreamingHandler class that extends the CBaseHandler class and provides additional functionality for streaming
 video content.
 @class
 @extends CBaseHandler
 */
class CStreamingHandler extends CBaseHandler {
    oTimer;

    /**
     Checks if the given regex matches the current URL and if the element with the given selector exists on the page.
     @async
     @param {RegExp} rRegex - A regular expression to match the URL.
     @param {string} sSelector - A CSS selector for the element.
     @returns {Promise<Boolean>} A Promise that resolves to a Boolean indicating if the element exists.
     */
    async isStreamingHoster(rRegex, sSelector) {
        return this.hasUrl([rRegex]) && await this.waitForElement(sSelector).catch(() => null);
    }

    /**
     Iterates through a list of streaming hosters and finds the current hoster.
     @async
     @param {Array} aHoster - An array of hosters.
     @returns {Promise<void>} A Promise that resolves after the current hoster is found and the stream behavior is set.
     */
    async findOutStreamingHoster(aHoster) {
        for (let oHoster of aHoster) {
            if (await this.isStreamingHoster(oHoster.regex, oHoster.selector)) {
                let oVideo = await this.waitForElement(oHoster.selector)
                    .catch(() => null);
                await this.setStreamBehavior(oHoster, oVideo);
            }
        }
    }

    /**
     Appends custom style to the document head.
     */
    appendOwnStyle() {
        let oStyle = document.createElement('style');
        oStyle.innerHTML = `<style>
            @media screen and (max-width: 800px) {
              #xtrars-warning-window {
                width: calc(100% - 10px)  !important;
              }
            }
            
            .xtrars-copied {
                  padding: 8px 12px;
                  background-color: #4CAF50;
                  color: white;
                  border-radius: 3px;
                  font-size: 14px;
                  display: none;
                  animation-name: xtrars-fadeIn;
                  animation-duration: 1s;
            }
            @keyframes xtrars-fadeIn {
                  from {opacity: 0;}
                  to {opacity: 1;}
            }
            
            #xtrars-warning-window {
                position: absolute; 
                top: 20%; 
                left: 50%;
                transform: translateX(-50%); 
                width: 50%; 
                background-color: white;
            }`.replace('<style>', '');
        document.head.appendChild(oStyle)
    }

    /**
     Detects the current browser type and returns its name.
     @returns {string} A string representing the name of the browser.
     */
    detectBrowser() {
        // BIG thanks to Rob W https://stackoverflow.com/a/9851769/8887112
        let bIsChrome = !!window.chrome && (!!window.chrome.webstore || !!window.chrome.runtime);
        let isEdge = bIsChrome && (navigator.userAgent.indexOf("Edg") !== -1);
        let bIsFirefox = typeof InstallTrigger !== 'undefined';
        let bIsOpera = (!!window.opr && !!opr.addons) || !!window.opera || navigator.userAgent.indexOf(' OPR/') >= 0;
        let bIsSafari = /constructor/i.test(window.HTMLElement) || (function (p) {
            return p.toString() === "[object SafariRemoteNotification]";
        })(!window.safari || (typeof safari !== 'undefined' && safari.pushNotification));

        if (isEdge) return 'edge';
        if (bIsChrome) return 'chrome';
        if (bIsFirefox) return 'firefox';
        if (bIsOpera) return 'opera';
        if (bIsSafari) return 'safari';
        return 'none';
    }

    /**
     Registers keydown and keyup event listeners for the document object that will apply keyboard shortcuts to local video object
     */
    applyShortcuts(o = undefined) {
        try {
            if (o) {
                o.addEventListener('keydown', (o) => {
                    if (!this.#aKeyCodesToHandle.includes(o.keyCode)) return true;
                    o.stopImmediatePropagation();
                    o.preventDefault();
                    this.initShortcutTimer(o);
                });
                o.addEventListener('keyup', (o) => {
                    if (!this.#aKeyCodesToHandle.includes(o.keyCode)) return true;
                    o.stopImmediatePropagation();
                    o.preventDefault();
                    this.removeShortcutTimers();
                });
                o.addEventListener('click', (o) => {
                    o.stopImmediatePropagation();
                }, true);
                return;
            }

            document.addEventListener('keydown', (o) => {
                if (!this.#aKeyCodesToHandle.includes(o.keyCode)) return true;
                o.stopImmediatePropagation();
                o.preventDefault();
                this.initShortcutTimer(o);
            });

            document.addEventListener('keyup', (o) => {
                if (!this.#aKeyCodesToHandle.includes(o.keyCode)) return true;
                o.stopImmediatePropagation();
                o.preventDefault();
                this.removeShortcutTimers();
            });
        } catch (e) {

        }

    }

    /**
     Initializes a timer for a given keyboard event and calls the 'shortcuts' function every 150ms while the key is being held down.
     @param {Object} o - Keyboard event object that triggered the function
     */
    initShortcutTimer(o) {
        if (this.oTimer) return;
        this.fireShortcut(o);
        this.#bSingleKeyPressed = true;

        // aktiviere nur bei Pfeiltasten das Interval
        if (!(o.keyCode > 36 && o.keyCode < 41)) return;

        // speichere Zustand & pausiere Video
        if (o.keyCode === 37 || o.keyCode === 39) {
            this.#bIsPlaying = !document.localVideo.paused;
            this.#bIsTimeKeyPressed = true;
            document.localVideo.pause();
        }

        this.oTimer = () => {
            this.fireShortcut(o);
            this.#iTimeJumpIndex++;
            if (this.#fTimeout > 20) {
                if (this.#fTimeout === this.#fInitTimeout) {
                    this.#fTimeout = 250;
                }
                if (!(this.#iTimeJumpIndex % 3)) {
                    this.#fTimeout *= 0.9;
                }
            }
            this.#iTimeoutId = setTimeout(this.oTimer, Math.floor(this.#fTimeout));
        }
        this.#iTimeoutId = setTimeout(this.oTimer, Math.floor(this.#fTimeout));
    }

    /**
     Removes any existing keyboard shortcut timers or pauses the video playback if the arrow keys were pressed.
     */
    removeShortcutTimers() {
        clearTimeout(this.#iTimeoutId);
        delete this.oTimer;
        if (this.#bIsPlaying && this.#bIsTimeKeyPressed) {
            document.localVideo.play();
        }
        this.#iTimeJumpIndex = 0;
        this.#iTimeJump = 10;
        this.#fTimeout = this.#fInitTimeout;
        this.#bIsTimeKeyPressed = false;
        this.#bSingleKeyPressed = false;
    }

    /**
     Handles various keyboard shortcuts for the local video object depending on the key pressed.
     @param {Object} o - Keyboard event object.
     */
    fireShortcut(o) {
        if (!o || o.shiftKey || o.ctrlKey || o.altKey || o.metaKey || !document.localVideo) return;

        // noinspection FallThroughInSwitchStatementJS
        switch (o.keyCode) {
            case 37: // Left
                document.localVideo.currentTime -= this.#iTimeJump;
                break;
            case 38: // Up
                if (document.localVideo.volume < 0.9) {
                    document.localVideo.volume += 0.1;
                }
                else {
                    document.localVideo.volume = 1;
                }
                break;
            case 39: // Right
                document.localVideo.currentTime += this.#iTimeJump;
                break;
            case 40: // Down
                if (document.localVideo.volume > 0.1) {
                    document.localVideo.volume -= 0.1;
                }
                else {
                    document.localVideo.volume = 0;
                }
                break;
            case 70: // F
                if (this.#bSingleKeyPressed) break;
                if (!document.fullscreenElement) {
                    document.localVideo.requestFullscreen().catch(() => {
                        document.localVideo.style.width = "100%";
                        document.localVideo.style.height = "100%";
                        document.body.style.margin = "0px";
                        document.body.style['background-color'] = "black";
                    });
                }
                else {
                    document.exitFullscreen().catch(() => null);
                }
                break;
            case 32: // Space
                if (o.target.tagName === 'VIDEO') break;
            case 75: // K
                if (this.#bSingleKeyPressed) break;
                this.#bIsPlaying = document.localVideo.paused;
                if (this.#bIsPlaying) {
                    document.localVideo.play();
                }
                else {
                    document.localVideo.pause();
                }
                break;
            case 77: // M
                if (this.#bSingleKeyPressed) break;
                document.localVideo.muted = !document.localVideo.muted;
                break;
            case 48: // Zahlen 0-9
            case 49:
            case 50:
            case 51:
            case 52:
            case 53:
            case 54:
            case 55:
            case 56:
            case 57:
            case 96:
            case 97:
            case 98:
            case 99:
            case 100:
            case 101:
            case 102:
            case 103:
            case 104:
            case 105:
                if (this.#bSingleKeyPressed) break;
                let fDuration = document.localVideo.duration;
                let iSection = (o.keyCode + (o.keyCode < 96 ? 2 : 4)) % 10;

                document.localVideo.currentTime = fDuration / 10 * iSection;
                break;
        }
    }

    /**
     Waits for the local video object to become available and sets up event listeners to enable keyboard shortcuts.
     */
    async handleLocalVideo() {
        let oVideo = await this.waitForElement('html head ~ body video').catch(() => null);

        // Fängt Event ab und verhindert, dass untergeordnete Elemente auf das Event reagieren können (somit werden Popups verhindert)
        window.addEventListener('click', (o) => {
            o.stopImmediatePropagation();
        }, true);
        document.addEventListener('click', (o) => {
            o.stopImmediatePropagation();
        }, true);
        oVideo.addEventListener('click', (o) => {
            o.stopImmediatePropagation();
        }, true);

        let oWarningWindow = document.getElementById('xtrars-warning-window');

        document.localVideo = oVideo;

        // Ende überspringen
        let iIndex = 0;
        oVideo.addEventListener('timeupdate', () => {
            if (oWarningWindow && iIndex > 2) {
                oWarningWindow.style.display = "none";
            }
            iIndex++;

            if (oVideo.currentTime + (GM_getValue('bSkipEnd') ? (GM_getValue('iSkipEndTime') ?? 1) : 1) >= oVideo.duration) {
                GM_setValue('isLocalVideoEnded', true);
                window.close();
            }
        });

        oVideo.addEventListener('play', () => {
            this.#bIsPlaying = true;
            let oWarningWindow = document.getElementById('xtrars-warning-window');
            if (oWarningWindow) {
                oWarningWindow.style.display = "none";
            }
        });

        oVideo.addEventListener('loadeddata', () => {
            this.applyShortcuts();
            oVideo.currentTime = 0;

            if (GM_getValue('bSkipStart') && GM_getValue('iSkipStartTime')) {
                oVideo.currentTime = GM_getValue('iSkipStartTime');
            }

            if (!GM_getValue('bSkipEnd') || GM_getValue('iSkipEndTime') >= oVideo.duration) {
                oVideo.addEventListener('waiting', () => {
                    if (oVideo.currentTime + (GM_getValue('bSkipEnd') ? (GM_getValue('iSkipEndTime') ?? 1) : 1) >= oVideo.duration) {
                        setTimeout(() => {
                            GM_setValue('isLocalVideoEnded', true);
                            window.close();
                        }, 2e3);
                    }
                });
            }
        });

        // Erlaube Fullscreen durch Doppelklick
        window.addEventListener('dblclick', () => {
            if (window.innerHeight === screen.height) {
                document.exitFullscreen().catch(() => null);
            }
            else {
                oVideo.requestFullscreen().catch(() => null);
            }
        }, true);

        oVideo.style.left = 0;
        oVideo.style.top = 0;
        oVideo.style.position = "fixed";
        oVideo.style.width = "100vw";
        oVideo.style.height = "100vh";
        oVideo.style['z-index'] = 2147483647;
        oVideo.style.backgroundColor = "black";
        document.body.style.margin = "0px";
        document.body.style.backgroundColor = "black";
        document.body.style.overflow = "hidden";
        oVideo.requestFullscreen().catch(() => null);

        oVideo.play().catch(() => {
            // Autoplay wurde blockiert
            this.showAutoplayWarning();
        });
    }

    /**
     Sets the behavior of the video stream based on the hoster and video source
     @async
     @param {object} oHoster - The hoster object containing information on the hoster and its regular expression for
      matching the m3u8 video url
     @param {object} oVideo - The video object whose behavior is being set
     @returns {void}
     */
    async setStreamBehavior(oHoster, oVideo) {
        if (oHoster.hoster === this.getHoster(0, true)) {

            await new Promise(resolve => {
                window.addEventListener('load', async () => resolve(), false);
            });

            let oClickEvent = new Event('click');
            oClickEvent.which = 1;
            oClickEvent.pageX = 6;
            oClickEvent.pageY = 1;
            (await this.waitForElement(oHoster.selector)).dispatchEvent(oClickEvent);

            let oVideoElement = await this.waitForElement(oHoster.selector).catch(() => null);


            // let aMatch = typeof oVideo.src === 'undefined' ? null :
            //     oVideo.src.match(/^blob:https:\/\//g);
            // this.appendOwnStyle();
            //
            // if (aMatch !== null) {
            //     let sText = ''
            //     // Extract m3u8 video url and then
            //     // oVideo.src = Array.from(document.querySelectorAll('script')).filter(oItem => {
            //     //     sText += (oItem.text + "\n\n\n");
            //     //     let match = oItem.text.match(oHoster.m3u8Regex);
            //     //     return match && match.length;
            //     // }).map(oItem => oItem.text.match(oHoster.m3u8Regex)[0]);
            //
            //
            //
            //     if (oHoster.hoster === this.getHoster(0, true)) {
            //         if (Hls.isSupported()) {
            //             let oVideoElement = document.createElement('video');
            //             this.applyShortcuts(oVideoElement);
            //
            //             let videoSrc = oVideo.src;
            //             document.body.innerHTML = '';
            //             document.body.appendChild(oVideoElement);
            //
            //             const config = {
            //                 enableWorker: false,
            //             };
            //             let oHls = new Hls(config);
            //             oHls.loadSource(videoSrc);
            //             oHls.attachMedia(oVideoElement);
            //             oHls.startLoad();
            //
            //             oVideoElement.controls = true;
            //             oVideoElement.preload = true;
            //             oVideoElement.autoplay = true;
            //         }
            //     }
            // }

            // Seite bereinigen
            document.body.prepend(oVideoElement);
            Array.from(document.body.children).forEach(oElement => {
                if (oElement.tagName !== 'VIDEO') {
                    oElement.style.display = 'none';
                }
            });

            oVideoElement.controls = true;
            oVideoElement.preload = true;
            oVideoElement.autoplay = true;
        }
        else if (oHoster.hoster === this.getHoster(1, true)) {
            await new Promise(resolve => {
                document.addEventListener('DOMContentLoaded', () => resolve(), false);
            });
            oVideo.src = 'https:/' + oVideo.innerText;
            window.location.replace(oVideo.src);

        }
        else if (oHoster.hoster === this.getHoster(2, true)) {
            if (/https:\/\/.*\.[a-z]{2,3}\/d\//.test(document.location.href)) {
                window.location.replace(oVideo.src);
            }

            // im embedded mode
            let oVideoElement;
            await new Promise(resolve => {
                window.addEventListener('load', async () => {
                    oVideoElement = await this.waitForElement('.video-js > video').catch(() => null);
                    resolve();
                }, false);
            });


            // Seite bereinigen
            document.body.innerHTML = '';
            document.body.append(oVideoElement);
            window.addEventListener('click', (event) => {
                event.stopImmediatePropagation();
                event.preventDefault();
            }, true);

            oVideoElement.controls = true;
            oVideoElement.preload = true;
            oVideoElement.autoplay = true;
        }
        else if (oHoster.hoster === this.getHoster(3, true)) {
            await new Promise(resolve => {
                window.addEventListener('load', async () => {
                    await this.waitForElement(oHoster.selector + '[src]').catch(() => null);
                    resolve();
                }, false);
            });

            window.location.replace(oVideo.src);
        }
    }

    /**
     Shows a warning message for autoplay and appends custom style to the document head.
     */
    async showAutoplayWarning() {
        this.appendOwnStyle();

        let oContent = {
            chrome: `
                <div style="width: 100%; text-align: center;">
                    <span style="font-weight: bold; font-size: larger;">Autoplay wurde vom Browser blockiert!</span> <br><br>
                    Zum Aktivieren kopiere den Link in die Adressleiste und aktiviere "Ton"
                    (Es muss Zulassen drin stehen. Automatisch reicht nicht.)
                    <br><br>
                    <input id="xtrars-autoplay-input" type="text" style="width: calc(100% - 20px); margin: 5px;"
                    value="chrome://settings/content/siteDetails?site=${window.location.protocol}//${window.location.hostname}">
                </div>
                <div id="xtrars-copied-message"></div>`,
            firefox: `
                <div style="width: 100%; text-align: center; padding: 5px;">
                    <span style="font-weight: bold; font-size: larger;">Autoplay wurde vom Browser blockiert!</span> <br><br>
                    Zum Aktivieren halte dich an die Bildanleitung:
                    <br><br>
                    <img src="data:image/webp;base64,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" 
                    alt="Klicke oben im Firefox auf das Blockieren-Symbol und aktiviere Autoplay">
                    <br><br>
                </div>`,
            safari: ``,
            aliases: {
                chrome: 'chrome', edge: 'chrome', firefox: 'firefox', none: 'chrome', opera: 'chrome', safari: 'chrome', // TODO Safari anpassen
            }
        };

        const oWarningWindow = document.createElement("div");
        oWarningWindow.id = 'xtrars-warning-window';
        oWarningWindow.innerHTML = oContent[oContent.aliases[this.detectBrowser()]];
        oWarningWindow.style.cssText = `
            position: absolute; 
            top: 40%; background-color: white;  
            left:50%;
            top: 50%;
            transform: translate(-50%,-50%);
            font-family: Arial, Helvetica, sans-serif;
            padding: 10px;
            z-index: 2147483647;
        `;
        document.body.appendChild(oWarningWindow);

        let autoplayInput = document.getElementById('xtrars-autoplay-input');

        autoplayInput.addEventListener('focus', () => {
            navigator.clipboard
                .writeText(autoplayInput.value)
                .then(() => {
                    let oMessage = document.getElementById("xtrars-copied-message");
                    oMessage.innerHTML = "URL kopiert";
                    oMessage.classList.add("xtrars-copied");
                    oMessage.style.display = "block";
                    setTimeout(() => {
                        oMessage.style.display = "none";
                    }, 2500);
                })
                .catch(() => null);
        });
    }


    /**@type {boolean}*/
    #bIsPlaying = false;
    /**@type {boolean}*/
    #bIsTimeKeyPressed = false;
    /**@type {boolean}*/
    #bSingleKeyPressed = false;
    /**@type {number}*/
    #iTimeJump = 10;
    /**@type {number}*/
    #iTimeJumpIndex = 0;
    /**@type {number}*/
    #iTimeoutId;
    /**@type {number}*/
    #fInitTimeout = 750;
    /**@type {number}*/
    #fTimeout = this.#fInitTimeout;
    /**@type {number[]}*/
    #aKeyCodesToHandle = [
        32, // Space
        37, 38, 39, 40, // Arrow keys (37: Left, 38: Up, 39: Right, 40: Down)
        48, 49, 50, 51, 52, 53, 54, 55, 56, 57, // Number keys 0-9
        70, 75, 77, // 70, 75, 77: Character keys 'F', 'K', 'M'
        96, 97, 98, 99, 100, 101, 102, 103, 104, 105, // Number pad keys 0-9
    ];

}

/**
 An async IIFE that enhances the user experience on Burning Series website
 @async
 @function
 @returns {Promise<void>}
 */
(async function () {
    'use strict';

    /**
     Instance of the CBurningSeriesHandler class used to interact with the Burning Series website.
     @type {CBurningSeriesHandler}
     */
    let cBsHandler = new CBurningSeriesHandler();

    /**
     Instance of the CStreamingHandler class used to handle video streaming.
     @type {CStreamingHandler}
     */
    let cStreamingHandler = new CStreamingHandler();

    if (!cBsHandler.hasUrl([/https:\/\/(bs.to|burningseries.[a-z]{2,3})/])) {
        cStreamingHandler.applyShortcuts();
    }

    await new Promise((resolve) => {
        let iInterval = setInterval(() => {
            if (document.body) {
                clearInterval(iInterval);
                resolve();
            }
        }, 70);
    });

    if (GM_getValue('clickFirstSeason')) {
        GM_setValue('clickFirstSeason', false);
        let sSelector = '.serie > .episodes > tbody > tr:first-child > td:first-child > a:first-child';
        await cBsHandler.waitForElement(sSelector);
        document.location.replace(document.querySelector(sSelector));
    }
    cBsHandler.initGMVariables();

    if (cBsHandler.isSeries()) {
        cBsHandler.appendOwnStyle();
        await cBsHandler.buildButton();
        cBsHandler.buildSettingsWindow();
        cBsHandler.initEvents();

        if (GM_getValue('bIsSettingsWindowOpen')) {
            if (GM_getValue('sLastActiveTab') !== '') {
                cBsHandler.showTabContent(GM_getValue('sLastActiveTab'));
            }
            cBsHandler.showSettingsWindow();
        }

        if (cBsHandler.isEpisode()) {
            if (GM_getValue('bActivateEnhancer') &&
                !cBsHandler.hasAnotherHoster() &&
                !cBsHandler.hasUrl([new RegExp('/' + cBsHandler.getHoster(0))]) &&
                !cBsHandler.hasUrl([new RegExp('/' + cBsHandler.getHoster(1))]) &&
                !cBsHandler.hasUrl([new RegExp('/' + cBsHandler.getHoster(2))]) &&
                !cBsHandler.hasUrl([new RegExp('/' + cBsHandler.getHoster(3))])) {
                if (GM_getValue('bSelectHoster') === cBsHandler.getHoster(0, true)) {
                    await cBsHandler.skipUnavailable([
                        cBsHandler.getHoster(0),
                        cBsHandler.getHoster(3),
                        cBsHandler.getHoster(1),
                        cBsHandler.getHoster(2)
                    ]);
                }
                else if (GM_getValue('bSelectHoster') === cBsHandler.getHoster(1, true)) {
                    await cBsHandler.skipUnavailable([
                        cBsHandler.getHoster(1),
                        cBsHandler.getHoster(3),
                        cBsHandler.getHoster(0),
                        cBsHandler.getHoster(2)
                    ]);
                }
                else if (GM_getValue('bSelectHoster') === cBsHandler.getHoster(2, true)) {
                    await cBsHandler.skipUnavailable([
                        cBsHandler.getHoster(2),
                        cBsHandler.getHoster(3),
                        cBsHandler.getHoster(0),
                        cBsHandler.getHoster(1),
                    ]);
                }
                else if (GM_getValue('bSelectHoster') === cBsHandler.getHoster(3, true)) {
                    await cBsHandler.skipUnavailable([
                        cBsHandler.getHoster(3),
                        cBsHandler.getHoster(0),
                        cBsHandler.getHoster(2),
                        cBsHandler.getHoster(1),
                    ]);
                }
            }

            if (GM_getValue('bActivateEnhancer') && !cBsHandler.hasAnotherHoster() &&
                (cBsHandler.hasUrl([new RegExp('/' + cBsHandler.getHoster(0))]) ||
                    cBsHandler.hasUrl([new RegExp('/' + cBsHandler.getHoster(1))]) ||
                    cBsHandler.hasUrl([new RegExp('/' + cBsHandler.getHoster(2))]) ||
                    cBsHandler.hasUrl([new RegExp('/' + cBsHandler.getHoster(3))]))) {
                GM_setValue('isLocalVideoEnded', false);
                cBsHandler.playNextEpisodeIfVideoEnded();
                let oName = await cBsHandler.waitForElement('.episode > h2');
                GM_setValue('sEpisodeName', oName.outerText);
                let eActiveTab = await cBsHandler.waitForElement('section.serie .hoster-tabs .active a');
                await cBsHandler.clickPlay();
                await cBsHandler.handleBsVideo(eActiveTab.innerText,
                    [
                        new RegExp(cBsHandler.getHoster(0)),
                        new RegExp(cBsHandler.getHoster(1)),
                        new RegExp(cBsHandler.getHoster(2)),
                        new RegExp(cBsHandler.getHoster(3))
                    ]);
            }
        }
    }

    if (GM_getValue('bActivateEnhancer')) {
        const aHoster = [
            {
                regex: /^(https:\/\/(v-*o-*e|[-unblock\d]){1,15}\.[a-z]{2,3}\/.*)|(https:\/\/sandratableother\.com\/.*)/g,
                selector: '#voe-player',
                hoster: cBsHandler.getHoster(0, true),
                m3u8Regex: /(?<=sources = {([ \n]|.)*?hls': ')https:\/\/.*(?=',)/g,

            },
            {
                regex: /^https:\/\/(dood)|(ds2play)|(d[0o]+d)\.[a-z]{2,3}\//g,
                selector: '#os_player > iframe, #video_player_html5_api',
                hoster: cBsHandler.getHoster(2, true),
            },
            {
                regex: /^(https:\/\/streamtape\.[a-z]{2,3}\/)|(https:\/\/watchadsontape\.com)/g,
                selector: '#robotlink',
                hoster: cBsHandler.getHoster(1, true),
            },
            {
                regex: /^(https:\/\/(vidoza|videzz)\.[a-z]{2,3}\/embed)/g,
                selector: '#player_html5_api',
                hoster: cBsHandler.getHoster(3, true),
            }
        ];
        await cStreamingHandler.findOutStreamingHoster(aHoster);
        await cStreamingHandler.handleLocalVideo();
    }
})();