/* ==UserStyle== @name Keyoxide Catppuccin @namespace github.com/catppuccin/userstyles/styles/keyoxide @homepageURL https://github.com/catppuccin/userstyles/tree/main/styles/keyoxide @version 2025.09.06 @updateURL https://github.com/catppuccin/userstyles/raw/main/styles/keyoxide/catppuccin.user.less @supportURL https://github.com/catppuccin/userstyles/issues?q=is%3Aopen+is%3Aissue+label%3Akeyoxide @description Soothing pastel theme for Keyoxide @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 url-prefix("https://keyoxide.org") { :root { @media (prefers-color-scheme: light) { #catppuccin(@lightFlavor); } @media (prefers-color-scheme: dark) { #catppuccin(@darkFlavor); } } #catppuccin(@flavor) { #lib.palette(); #lib.defaults(); --primary-color: @accent; --primary-color-subtle: lighten(@accent, 5%); --body-background-color: @mantle; --section-background-color: @base; --text-color: @text; --text-color-subtle: @subtext1; --text-color-inverse: @crust; --link-color: @blue; --link-color-subtle: var(--text-color); --link-color-hover: lighten(@blue, 5%); --line-color-subtle: @surface1; --button-text-color: var(--text-color); --button-text-color-hover: var(--text-color); --button-border-color: @surface0; --button-border-color-hover: @surface0; --button-background-color: @surface0; --button-background-color-hover: @surface1; --input-text-color: var(--text-color); --input-text-color-hover: var(--text-color); --input-border-color: @surface0; --input-border-color-hover: @surface0; --input-background-color: @mantle; --input-background-color-hover: @mantle; --footer-text-color: var(--text-color-subtle); .kx-item details summary .info img, .kx-item details .subsection > img { filter: @text-filter; } kx-claim, kx-key { --loader-color: @subtext1; --success-color: @green; --failure-color: @red; --background-color: @surface0; --header-background-color: @surface1; } a.button.button--donate.button--opencollective { background-color: @blue; color: @crust; &:hover { background-color: lighten(@blue, 5%); } svg { fill: @crust; } } } } @-moz-document domain("docs.keyoxide.org"), domain("blog.keyoxide.org") { :root { @media (prefers-color-scheme: light) { #catppuccin(@lightFlavor); } @media (prefers-color-scheme: dark) { #catppuccin(@darkFlavor); } } #catppuccin(@flavor) { #lib.palette(); @text-filter: @catppuccin-filters[@@flavor][@text]; #lib.defaults(); background-color: @base; --clr-primary-100: @crust; --clr-primary-99: @crust; --clr-primary-98: @mantle; --clr-primary-95: @base; --clr-primary-90: lighten(@accent, 30%); --clr-primary-80: lighten(@accent, 20%); --clr-primary-70: lighten(@accent, 10%); --clr-primary-60: @accent; --clr-primary-50: darken(@accent, 5%); --clr-primary-40: darken(@accent, 10%); --clr-primary-35: darken(@accent, 15%); --clr-primary-30: darken(@accent, 20%); --clr-primary-25: darken(@accent, 25%); --clr-primary-20: darken(@accent, 30%); --clr-primary-10: darken(@accent, 35%); --clr-primary-0: @text; --clr-primary: @accent; --clr-header: @text; --clr-header-subtle: @subtext1; --clr-text: @text; --clr-text-subtle: @subtext1; --clr-bg: @mantle; --clr-bg-alt: @crust; --clr-border: @surface0; --clr-link: @blue; --clr-secondary-20: @subtext1; nav a.active { color: @crust; } .quick-links img, [src="/chevron-up.svg"], [src="/chevron-down.svg"] { filter: @text-filter; } img[title="Keyoxide logo"] { @svg: escape( '' ); content: url("data:image/svg+xml,@{svg}"); } table { &, td { border-color: @surface0; } } pre { background-color: @mantle !important; color: @text !important; span[style="color:#c82728;"] { color: @blue !important; } span[style="color:#4271ae;"], span[style="color:#f07219;"] { color: @green !important; } span[style="color:#8e908c;"] { color: @overlay0 !important; } span[style="color:#8959a8;"] { color: @mauve !important; } span[style="color:#839c00;"] { color: @green !important; } span[style="color:#3e999f;"] { color: @teal !important; } } .info { background-color: @mantle; &::before { background-color: @sky; color: @crust; } } .warning { background-color: @mantle; &::before { background-color: @yellow; color: @crust; } } .widget { background-color: fade(@accent, 60%); border-color: @accent; .title { color: @text; } input, select { background-color: @mantle; } } } }