/* ==UserStyle== @name AlternativeTo Catppuccin @namespace github.com/catppuccin/userstyles/styles/alternativeto @homepageURL https://github.com/catppuccin/userstyles/tree/main/styles/alternativeto @version 2025.09.06 @updateURL https://github.com/catppuccin/userstyles/raw/main/styles/alternativeto/catppuccin.user.less @supportURL https://github.com/catppuccin/userstyles/issues?q=is%3Aopen+is%3Aissue+label%3Aalternativeto @description Soothing pastel theme for AlternativeTo @author Catppuccin @license MIT @preprocessor less @var select lightFlavor "Light Flavor" ["latte:Latte*", "frappe:Frappé", "macchiato:Macchiato", "mocha:Mocha"] @var select darkFlavor "Dark Flavor" ["latte:Latte", "frappe:Frappé", "macchiato:Macchiato", "mocha:Mocha*"] @var select accentColor "Accent" ["rosewater:Rosewater", "flamingo:Flamingo", "pink:Pink", "mauve:Mauve*", "red:Red", "maroon:Maroon", "peach:Peach", "yellow:Yellow", "green:Green", "teal:Teal", "blue:Blue", "sapphire:Sapphire", "sky:Sky", "lavender:Lavender", "subtext0:Gray"] ==/UserStyle== */ @import "https://userstyles.catppuccin.com/lib/lib.less"; @-moz-document domain("alternativeto.net") { :root[data-theme="dark"] { #catppuccin(@darkFlavor); } :root[data-theme="light"] { #catppuccin(@lightFlavor); } #catppuccin(@flavor) { #lib.palette(); #lib.defaults(); --mainBrand: @accent; --topBrand: @accent; --footer: @mantle; --mainBg: @base; --mainFg: @text; --popBrand: @accent; --introBoxText: @text; --introBoxLink: @text; --introBoxMeta: @subtext0; --meta: @subtext0; --metaLight: @subtext1; --linkColorHeader: @text; --linkColor: @text; --brandLight3: @surface2; --brandLight4: @surface2; --brandLight5: @surface1; --brandLight6: @mantle; --brandLight7: @surface0; --brandLight8: @text; --brandLight10: @surface0; --brandLight11: @mantle; --gray50: @surface0; --gray100: @surface0; --gray150: @surface0; --gray200: @surface1; --gray250: @surface1; --gray300: @surface1; --gray500: @overlay0; --headingButton: @accent; --positiveGreener: @green; --positiveGreenerLight: fade(@green, 10%); --positiveGreenerDark: @green; --danger: @red; --negativeLight: fade(@peach, 10%); --lightDanger: fade(@red, 25%); --dangerDark: @red; --ctaMain: @mauve; --ctaLight: @base; --ctaLightest: @mantle; --tab: @mantle; --toastify-color-dark: @mantle; --toastify-color-light: @text; --toastify-color-info: @blue; --toastify-color-success: @green; --toastify-color-warning: @yellow; --toastify-color-error: @red; // heart icon [class^="ModernLikeButton_likeWrapper"] { [class^="ModernLikeButton_heart"]:hover, [class^="ModernLikeButton_liked"] { svg { color: @red; } } } // primary button [class*="Button_primary"] { color: @crust !important; } // footer [class^="Footer_footer"] { &, p a, [class^="Footer_footerMenu"] li a { color: @text; } } [class^="Footer_footerLogo"] { @svg: escape( '' ); content: url("data:image/svg+xml,@{svg}"); } // rating stars [class^="StarRating_star"] { color: @text; &[class*="StarRating_active"] { color: @peach; } } // danger "discontinued" label [class*="AppAlertWrapper_warning"] span { color: @peach; } // feature point in alternative's features [class*="HighlightFeatureListItem_featurePoint"]:not( [class*="HighlightFeatureListItem_gray"] ) { background-color: @green; color: @green; border-color: lighten(@green, 25%); } // app banner (ad) [class*="AppBanner_iconWrapper"], [class*="AppBanner_banner"], [class*="AppBanner_bottom"] { border-color: @overlay0; } // navigation/top bar [class^="HeaderLinks_globalSiteNav"] a, [class^="HeaderLinks_globalSiteNav"] span, [class^="HeaderLinks_authAndMenu"] a, [class*="Button_headerTextButton"] svg, [class*="Button_headerTextButton"]:hover svg, [class^="HeaderLinks_header"] button:focus { color: @base !important; } [class^="HeaderLinks_logoSmall"] { @svg: escape( '' ); content: url("data:image/svg+xml,@{svg}"); } [class*="HeaderLinks_logoLarge"] { @svg: escape( '' ); content: url("data:image/svg+xml,@{svg}"); } // hanburger menu [class^="DropdownListLink_additionalInfo"] { color: @subtext0; } // svg color variables @light-peach: lighten(@peach, 25%); @dark-peach: darken(@peach, 25%); @dark-blue: desaturate(darken(@blue, 60%), 40%); @darker-blue: desaturate(darken(@blue, 65%), 40%); // main page header img[class*="PageIntroImage_a2-header-"] { @svg: escape( '' ); content: url("data:image/svg+xml,@{svg}"); // flipped/mirrored/right variation of the a2 robot svg (found in /about and /about/privacy) &[src^="/static/a2-header-right"] { transform: scale(-1, 1); } } @media screen and (min-width: 1200px) { [class*="PageIntroWrapper_wrapper"] { @svg: escape( '' ); @svg2: escape( '' ); background-image: url("data:image/svg+xml,@{svg}"), url("data:image/svg+xml,@{svg2}"); } } // news page header [src^="/static/a2-screen"] { @svg: escape( '' ); content: url("data:image/svg+xml,@{svg}"); } // new app releases page header [src^="/static/a2-drop"] { @svg: escape( '' ); content: url("data:image/svg+xml,@{svg}"); } // bottom right loading spinner icon #nprogress .spinner-icon { border-top-color: @accent; border-left-color: @accent; } // top progress bar when loading a new page #nprogress .peg { box-shadow: 0 0 10px @accent, 0 0 5px @accent; } // toast .Toastify__close-button { color: @text; } [data-testid="toast"] > div > span { color: @text !important; } // remove filter badge li[class^="AppFilterBarCommon_current"]:hover { a::after, > span::after { color: darken(@red, 25%); } } // news fire icon @newstype: { hottest: @peach; hot_: @yellow; luke: @text; }; each( @newstype, { [class^="NewsForListMeta_@{key}"] { color: @value; } } ); // current page nummber [class*="Pagination_current"] { color: @subtext0; } // full screen screenshot button [class^="ImageCollection-modern_expandImage"] { background: fade(@text, 80%) !important; svg { color: @crust !important; } & when (@flavor = latte) { background: fade(@crust, 80%) !important; svg { color: @text !important; } } } // social icons // rrs svg[color="#f26522"] { color: @peach !important; } // "Share on" icons @socialapps: { facebook: @blue; reddit: @peach; }; [class^="ShareButtons_shareButtons"] { each( @socialapps, { [title="Share on @{key}"] > svg { color: @value !important; } } ); } // AppStores & Other Links [class*="Button_black"], [class^="AppExternalLinks_appstoreWrapper"] { background: @crust; color: @text; &:hover { background: @base; } [src$="ms-store.svg"] { @svg: escape( '' ); content: url("data:image/svg+xml,@{svg}"); } [src$="android-store.svg"] { @svg: escape( '' ); content: url("data:image/svg+xml,@{svg}"); } [src$="ios-store.svg"] { @svg: escape( '' ); content: url("data:image/svg+xml,@{svg}"); } } // social networks @socialnetworks: { Facebook: @blue; X: @text; }; [class^="AppExternalLinks_socialLinksWrapper"] { each( @socialnetworks, { [title^="@{key} page"] > svg { color: @value !important; } } ); } // yello star (e.g. the level in a user profile) svg[color="#e39d06"] { color: @yellow !important; } // list like button hover [class*="LikeButton_likeButton"]:hover [class*="LikeButton_heart"] { color: @red; } // register popup header .data-collector .header { color: @overlay2; } // danger button (clear all filters) [class*="Button_danger"] { background: @red; border-color: @red; color: @crust; } // warning button [class*="Button_warning"] { background-color: @yellow; border-color: @yellow; color: @crust; } // success button [class*="Button_success"] { background-color: @green; border-color: @green; color: @crust; } // disabled buttons [class*="Button_button"][disabled] { background-color: @surface2 !important; border-color: @surface2 !important; color: @overlay2 !important; } } } @-moz-document domain("auth.alternativeto.net") { :root { @media (prefers-color-scheme: light) { #catppuccin(@lightFlavor); } @media (prefers-color-scheme: dark) { #catppuccin(@darkFlavor); } } #catppuccin(@flavor) { #lib.palette(); #lib.defaults(); --widget-background-color: @base; --input-background-color: @base; --input-border-color: @surface1; --input-text-color: @text; --base-focus-color: @accent; --link-color: @accent; --primary-color: @accent; --button-font-color: @crust; --title-font-color: @text; --font-default-color: @text; --font-light-color: @subtext0; --border-default-color: @surface1; --social-button-border-color: @surface1; --secondary-button-text-color: @text; --transparency-focus-color: fade(@accent, 15%); --icon-default-color: @overlay1; --gray-lightest: @text; --error-color: @red; @error-svg: escape( '' ); --icon-error: url("data:image/svg+xml,@{error-svg}"); body { background: @crust; } .footer { a { color: @text; } background: @mantle; color: @subtext0; } #prompt-logo-center { @svg: escape( '' ); content: url("data:image/svg+xml,@{svg}"); } .password-icon-tooltip { background: @crust; &::before { border-color: @crust transparent transparent; } } // "Continue with" login button icons @loginicon: { google: ""; windowslive: ""; github: ""; apple: ""; }; each( @loginicon, { span[data-provider="@{key}"] { @svg: escape(@value); background-image: url("data:image/svg+xml,@{svg}"); } } ); } }