684 lines
19 KiB
CSS

/* ==UserStyle==
@name Mastodon Catppuccin
@namespace github.com/catppuccin/userstyles/styles/mastodon
@homepageURL https://github.com/catppuccin/userstyles/tree/main/styles/mastodon
@version 1.1.9
@description Soothing pastel theme for Mastodon
@author Catppuccin
@updateURL https://github.com/catppuccin/userstyles/raw/main/styles/mastodon/catppuccin.user.css
@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== */
@-moz-document domain("mstdn.social"),
domain("fosstodon.org"),
domain("tech.lgbt"),
domain("mastodon.social"),
domain("piaille.fr") {
.theme-mastodon-light,
.skin-mastodon-light {
#mastodon(@lightFlavor, @accentColor);
}
.theme-contrast,
.skin-contrast {
#mastodon(@darkFlavor, @accentColor);
}
@media (prefers-color-scheme: light) {
.theme-default,
.skin-default {
#mastodon(@lightFlavor, @accentColor);
}
}
@media (prefers-color-scheme: dark) {
.theme-default,
.skin-default {
#mastodon(@darkFlavor, @accentColor);
}
}
#mastodon(@lookup, @accent) {
@catppuccin: {
@latte: {
@rosewater: #dc8a78;
@flamingo: #dd7878;
@pink: #ea76cb;
@mauve: #8839ef;
@red: #d20f39;
@maroon: #e64553;
@peach: #fe640b;
@yellow: #df8e1d;
@green: #40a02b;
@teal: #179299;
@sky: #04a5e5;
@sapphire: #209fb5;
@blue: #1e66f5;
@lavender: #7287fd;
@text: #4c4f69;
@subtext1: #5c5f77;
@subtext0: #6c6f85;
@overlay2: #7c7f93;
@overlay1: #8c8fa1;
@overlay0: #9ca0b0;
@surface2: #acb0be;
@surface1: #bcc0cc;
@surface0: #ccd0da;
@base: #eff1f5;
@mantle: #e6e9ef;
@crust: #dce0e8;
}
@frappe: {
@rosewater: #f2d5cf;
@flamingo: #eebebe;
@pink: #f4b8e4;
@mauve: #ca9ee6;
@red: #e78284;
@maroon: #ea999c;
@peach: #ef9f76;
@yellow: #e5c890;
@green: #a6d189;
@teal: #81c8be;
@sky: #99d1db;
@sapphire: #85c1dc;
@blue: #8caaee;
@lavender: #babbf1;
@text: #c6d0f5;
@subtext1: #b5bfe2;
@subtext0: #a5adce;
@overlay2: #949cbb;
@overlay1: #838ba7;
@overlay0: #737994;
@surface2: #626880;
@surface1: #51576d;
@surface0: #414559;
@base: #303446;
@mantle: #292c3c;
@crust: #232634;
}
@macchiato: {
@rosewater: #f4dbd6;
@flamingo: #f0c6c6;
@pink: #f5bde6;
@mauve: #c6a0f6;
@red: #ed8796;
@maroon: #ee99a0;
@peach: #f5a97f;
@yellow: #eed49f;
@green: #a6da95;
@teal: #8bd5ca;
@sky: #91d7e3;
@sapphire: #7dc4e4;
@blue: #8aadf4;
@lavender: #b7bdf8;
@text: #cad3f5;
@subtext1: #b8c0e0;
@subtext0: #a5adcb;
@overlay2: #939ab7;
@overlay1: #8087a2;
@overlay0: #6e738d;
@surface2: #5b6078;
@surface1: #494d64;
@surface0: #363a4f;
@base: #24273a;
@mantle: #1e2030;
@crust: #181926;
}
@mocha: {
@rosewater: #f5e0dc;
@flamingo: #f2cdcd;
@pink: #f5c2e7;
@mauve: #cba6f7;
@red: #f38ba8;
@maroon: #eba0ac;
@peach: #fab387;
@yellow: #f9e2af;
@green: #a6e3a1;
@teal: #94e2d5;
@sky: #89dceb;
@sapphire: #74c7ec;
@blue: #89b4fa;
@lavender: #b4befe;
@text: #cdd6f4;
@subtext1: #bac2de;
@subtext0: #a6adc8;
@overlay2: #9399b2;
@overlay1: #7f849c;
@overlay0: #6c7086;
@surface2: #585b70;
@surface1: #45475a;
@surface0: #313244;
@base: #1e1e2e;
@mantle: #181825;
@crust: #11111b;
}
}
@rosewater: @catppuccin[@@lookup][@rosewater];
@flamingo: @catppuccin[@@lookup][@flamingo];
@pink: @catppuccin[@@lookup][@pink];
@mauve: @catppuccin[@@lookup][@mauve];
@red: @catppuccin[@@lookup][@red];
@maroon: @catppuccin[@@lookup][@maroon];
@peach: @catppuccin[@@lookup][@peach];
@yellow: @catppuccin[@@lookup][@yellow];
@green: @catppuccin[@@lookup][@green];
@teal: @catppuccin[@@lookup][@teal];
@sky: @catppuccin[@@lookup][@sky];
@sapphire: @catppuccin[@@lookup][@sapphire];
@blue: @catppuccin[@@lookup][@blue];
@lavender: @catppuccin[@@lookup][@lavender];
@text: @catppuccin[@@lookup][@text];
@subtext1: @catppuccin[@@lookup][@subtext1];
@subtext0: @catppuccin[@@lookup][@subtext0];
@overlay2: @catppuccin[@@lookup][@overlay2];
@overlay1: @catppuccin[@@lookup][@overlay1];
@overlay0: @catppuccin[@@lookup][@overlay0];
@surface2: @catppuccin[@@lookup][@surface2];
@surface1: @catppuccin[@@lookup][@surface1];
@surface0: @catppuccin[@@lookup][@surface0];
@base: @catppuccin[@@lookup][@base];
@mantle: @catppuccin[@@lookup][@mantle];
@crust: @catppuccin[@@lookup][@crust];
@accent-color: @catppuccin[@@lookup][@@accent];
&,
.tabs-bar__wrapper,
.admin-wrapper .sidebar-wrapper__inner,
.ui__header{
background: @crust;
color: @text;
}
.ui__header {
border-bottom: none;
}
.navigation-panel, .column-link{
background: transparent;
}
.account__header__bio .account__header__fields dt {
background: transparent;
}
.search-popout,
.search-popout em,
.dismissable-banner__message,
.dismissable-banner__message h1,
.account__header__bio .account__header__fields dt,
.account__section-headline a.active,
.account__section-headline button.active,
.notification__filter-bar a.active,
.notification__filter-bar button.active,
.account__header__bio .account__header__content,
.navigation-bar,
.column-link__badge,
.column-subheading,
.account__display-name strong,
.status__display-name strong,
.notification__message,
.public-layout .public-account-bio .account__header__content,
.reply-indicator__content,
.status__content,
.card__bar .display-name strong {
color: @text;
}
.search-popout span,
.link-footer p,
.link-footer p a {
color: @subtext1;
}
.account__header__tabs__name h1 small,
.account__header__bio .account__header__fields dd,
.display-name__account,
.status__relative-time,
.empty-column-indicator,
.follow_requests-unlocked_explanation,
.account .account__display-name,
.label_input .search__input,
.search__input:focus,
.account__header__fields dt {
color: @subtext0
}
.compose-panel hr,
.navigation-panel hr {
border-top-color: @subtext0
}
.trends__item,
.status,
.getting-started__trends h4,
.trends__item__name span,
.story {
border-color: @surface0
}
.mention,
.account__header__tabs__name h1,
.account__header__content a,
.account__header__bio .account__header__fields a,
.empty-column-indicator a,
.follow_requests-unlocked_explanation a,
.column-back-button,
.icon-button.inverted,
.text-icon-button,
.icon-button.active,
.public-layout .public-account-bio .account__header__fields a,
.column-header__back-button,
.navigation-bar strong,
.reply-indicator__content a.unhandled-link,
.status__content a.unhandled-link,
.announcements__item__content a.unhandled-link,
.reactions-bar__item.active .reactions-bar__item__count,
.column-header.active .column-header__icon{
color: @accent-color;
}
.conversation__unread,
.react-toggle--checked .react-toggle-track, .react-toggle--checked:hover .react-toggle-track,
.pillbar-button:not([disabled]).active, .pillbar-button:not([disabled]).active:focus, .pillbar-button:not([disabled]).active:hover,
.radio-button__input.checked{
background-color: @accent-color;
}
.reactions-bar__item.active {
background-color: rgba(@accent-color, .25);
}
.trends__item__sparkline path:last-child {
stroke: @accent-color !important;
}
.trends__item__sparkline path:first-child {
fill: rgba(@accent-color, .25) !important;
}
.icon-button,
.notification__message .fa{
color: @surface2;
}
.icon-button:active,
.icon-button:focus,
.icon-button:hover,
.text-icon-button:active,
.text-icon-button:focus,
.text-icon-button:hover,
.icon-button.inverted:active,
.icon-button.inverted:focus,
.icon-button.inverted:hover,
.public-layout .public-account-bio .account__header__fields a:hover {
color: @accent-color;
}
.column-header,
.column-header__button,
.column-header__back-button,
.column-back-button,
.drawer__header,
.notification__filter-bar,
.account__section-headline button,
.notification__filter-bar button,
.account__header,
.search__input,
.search__input:focus,
.column-link__badge,
.column-subheading,
.public-layout .header,
.public-layout .public-account-header__bar::before,
.account__header__fields,
.account__header__fields dt,
.account__header__fields dd:not(.account__header__bio .account__header__fields dd),
.admin-wrapper .sidebar ul .simple-navigation-active-leaf .selected,
.explore__search-header,
.column-inline-form,
.follow_requests-unlocked_explanation,
.conversation--unread,
.column-header__collapsible-inner,
.announcements,
.status-card__image,
.account__header__bar{
border-color: @crust;
background: @surface0;
}
.account__section-headline {
background: @mantle;
border-color: @crust
}
.focusable:focus {
background: unset;
}
.admin-wrapper .sidebar ul a:hover,
.admin-wrapper .sidebar ul .simple-navigation-active-leaf a:hover,
.detailed-status, .detailed-status__action-bar{
background: @surface0;
}
.detailed-status__wrapper > div:first-child .detailed-status {
border-top: none;
}
.dismissable-banner {
border-color: @surface1;
background: @base;
}
.column-header__wrapper.active {
box-shadow: 0 1px 0 rgba(@accent-color,.3);
}
.column-header__wrapper.active::before {
background: radial-gradient(ellipse,rgba(@accent-color,.23) 0,rgba(99,100,255,0) 60%);
}
.theme-mastodon-light .account__header__bar,
.theme-mastodon-light .column-header__back-button,
.account__header__bio .account__header__fields dl,
.account__header__bio .account__header__fields,
.empty-column-indicator,
.column > .scrollable,
.nothing-here,
.public-layout .public-account-bio,
.hero-widget__text,
&.admin,
.admin-wrapper .sidebar ul a.selected,
.admin-wrapper .sidebar ul ul {
border-color: @mantle;
background: @base;
}
.public-layout .public-account-header__tabs__tabs .counter::after,
.public-layout .public-account-header__tabs__tabs .counter.active::after ,
.react-toggle--checked .react-toggle-thumb,
.radio-button__input.checked,
.account__action-bar__tab.active{
border-color: @accent-color;
}
.account,
.load-gap {
border-color: @mantle;
}
.account__section-headline a.active::after {
border-color: transparent transparent @base;
}
.account__section-headline a.active::before,
.account__section-headline button.active::after,
.account__section-headline button.active::before,
.notification__filter-bar a.active::after,
.notification__filter-bar a.active::before,
.notification__filter-bar button.active::after,
.notification__filter-bar button.active::before {
border-color: transparent transparent @mantle;
}
.search-popout,
.drawer__header a:hover,
.column-header__button:hover,
.account__section-headline button:hover,
.notification__filter-bar button:hover,
.account__section-headline a:hover {
background: @surface2;
}
.column-link .active,
.column-link--transparent.active,
.column-link--transparent:focus,
.column-link:focus {
color: @accent-color;
}
.column-link--transparent:hover,
.column-link:hover {
color: @accent-color;
}
.status.collapsed .status__content:after {
background: linear-gradient(fadeout(@base, 100), @base);
}
.button.button-tertiary:focus,
.button.button-tertiary:hover,
.button.button-tertiary:active {
color: @base;
}
.button.button-tertiary {
border-color: @accent-color;
}
.button,
.button.button-tertiary,
.button.logo-button,
.icon-with-badge__badge {
background: @accent-color;
color: @base;
}
.button.logo-button svg {
fill: currentColor;
}
.public-layout .header .nav-button {
background-color: @surface1;
}
.public-layout .header .nav-button:hover {
background-color: @surface2;
}
.button.button-secondary {
background-color: transparent;
color: @text;
border-color: @accent-color;
}
.button.button-secondary:active,
.button.button-secondary:focus,
.button.button-secondary:hover {
border-color: @accent-color;
color: @base;
transition: .2s;
}
.button:active,
.button:focus,
.button:hover,
.button.button-tertiary:active,
.button.button-tertiary:focus,
.button.button-tertiary:hover,
.button.logo-button:active,
.button.logo-button:focus,
.button.logo-button:hover {
background: @accent-color;
}
.drawer__inner,
.drawer__inner__mastodon,
.explore__search-header .search__input{
background-color: @base;
}
.compose-form .compose-form__modifiers,
.compose-form .autosuggest-textarea__textarea,
.compose-form .compose-form__autosuggest-wrapper,
.compose-form .spoiler-input__input {
background: @surface1 !important;
color: @text !important;
}
.compose-form .autosuggest-textarea__textarea::placeholder {
color: @subtext0 !important
}
.compose-form .compose-form__buttons-wrapper {
background: @surface0;
}
.load-more:hover {
background-color: @mantle;
}
.character-counter {
color: @subtext0
}
.public-layout .header,
.hero-widget,
.public-layout .public-account-header,
.public-layout .public-account-bio,
.nothing-here {
box-shadow: none;
}
.search__popout,
.dropdown-menu__arrow:before,
.dropdown-menu__item a,
.dropdown-menu__item button,
.dropdown-menu__container__list,
.dropdown-menu.bottom {
background: @surface0;
color: @text;
}
.dropdown-menu__item a:hover,
.dropdown-menu__item button:hover {
background: @surface1;
}
.input-copy,
.simple_form input[type=text],
.simple_form textarea,
.simple_form .block-button,
.simple_form .button,
.simple_form button {
background: @mantle;
color: @text;
}
.simple_form .block-button:hover,
.simple_form .button:hover,
.simple_form button:hover {
background: @surface0;
}
.simple_form .input.with_label .label_input > label,
.simple_form select,
.accounts-table__count,
.simple_form textarea {
color: @text;
}
.simple_form textarea,
.simple_form input[type=password],
.simple_form input[type=number],
.simple_form input[type=text] {
border: 1px solid @crust;
}
.simple_form input[type=email]:required:valid {
border: 1px solid @green
}
.simple_form input[type=password],
.simple_form input[type=number],
.simple_form input[type=email]:required:valid,
.simple_form input[type=password]:required:invalid:not(:placeholder-shown) {
color: @text;
background: @mantle;
}
.simple_form input[type=password]:required:invalid:not(:placeholder-shown) {
border: 1px solid @red;
}
.simple_form select {
background: @mantle url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14.933 18.467' height='19.698' width='15.929'><path d='M3.467 14.967l-3.393-3.5H14.86l-3.392 3.5c-1.866 1.925-3.666 3.5-4 3.5-.335 0-2.135-1.575-4-3.5zm.266-11.234L7.467 0 11.2 3.733l3.733 3.734H0l3.733-3.734z' fill='%2342485A'/></svg>") no-repeat right 8px center/auto 16px;
border: 1px solid @crust;
}
.simple_form input[type=datetime-local]:active,
.simple_form input[type=datetime-local]:focus,
.simple_form input[type=email]:active,
.simple_form input[type=email]:focus,
.simple_form input[type=number]:active,
.simple_form input[type=number]:focus,
.simple_form input[type=password]:active,
.simple_form input[type=password]:focus,
.simple_form input[type=text]:active,
.simple_form input[type=text]:focus,
.simple_form input[type=url]:active,
.simple_form input[type=url]:focus,
.simple_form textarea:active,
.simple_form textarea:focus {
border-color: @accent-color !important;
background: @mantle !important;
color: @text !important;
}
.table > thead > tr > th,
.setting-text:active, .setting-text:focus{
border-color: @accent-color !important;
}
.batch-table__toolbar,
.table > thead > tr > th {
background: @surface0 !important;
color: @text !important;
}
.simple_form input[type=datetime-local]:hover,
.simple_form input[type=email]:hover,
.simple_form input[type=number]:hover,
.simple_form input[type=password]:hover,
.simple_form input[type=text]:hover,
.simple_form input[type=url]:hover,
.simple_form textarea:hover {
background: @mantle !important;
border-color: @accent-color !important;
transition: 0.4s;
}
.batch-table__row {
background: @surface1;
}
.batch-table__row:hover,
.batch-table__row:nth-child(2n):hover {
background: @surface2;
}
.batch-table__row:nth-child(2n),
.table > tbody > tr > td {
background: @surface0;
}
.table > thead > tr > th {
border-bottom: 2px solid @surface0;
}
.positive-hint {
color: @green !important;
}
.card__bar {
background: @surface0;
}
}
}