/* ==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}");
}
}
);
}
}