mirror of
https://gitea.com/gitea/gitea-mirror.git
synced 2026-04-02 01:41:10 +00:00
Desaturate all structural grey colors in the dark theme from blue-grey (H≈210°, S≈12-15%) to near-monochrome (H=220°, S=6%), using `#1e1f20` as the page background color. All colors preserve their original HSL lightness values. Semantic colors (primary accent, named colors, diff, alerts, badges, brand) are unchanged. Motivation: The previous blue tint looked bad (kind of green-ish) on certain screens and I think a near-monochrome color is more neutral because its closer to being an inversion of the light theme. Before and after: <img width="280" alt="Screenshot 2026-04-02 at 00 18 38" src="https://github.com/user-attachments/assets/544c71b9-fdaf-4222-822c-c5b87bc5b76d" /> <img width="280" alt="image" src="https://github.com/user-attachments/assets/5d6de5d0-05c6-4a49-a649-063da4d136ce" /> Co-authored-by: Claude (Opus 4.6) <noreply@anthropic.com>
318 lines
11 KiB
CSS
318 lines
11 KiB
CSS
gitea-theme-meta-info {
|
|
--theme-display-name: "Dark";
|
|
--theme-color-scheme: "dark";
|
|
}
|
|
|
|
:root {
|
|
--is-dark-theme: true;
|
|
--color-primary: #4183c4;
|
|
--color-primary-contrast: #ffffff;
|
|
--color-primary-dark-1: #548fca;
|
|
--color-primary-dark-2: #679cd0;
|
|
--color-primary-dark-3: #7aa8d6;
|
|
--color-primary-dark-4: #8db5dc;
|
|
--color-primary-dark-5: #b3cde7;
|
|
--color-primary-dark-6: #d9e6f3;
|
|
--color-primary-dark-7: #f4f8fb;
|
|
--color-primary-light-1: #3876b3;
|
|
--color-primary-light-2: #31699f;
|
|
--color-primary-light-3: #2b5c8b;
|
|
--color-primary-light-4: #254f77;
|
|
--color-primary-light-5: #193450;
|
|
--color-primary-light-6: #0c1a28;
|
|
--color-primary-light-7: #04080c;
|
|
--color-primary-alpha-10: #4183c419;
|
|
--color-primary-alpha-20: #4183c433;
|
|
--color-primary-alpha-30: #4183c44b;
|
|
--color-primary-alpha-40: #4183c466;
|
|
--color-primary-alpha-50: #4183c480;
|
|
--color-primary-alpha-60: #4183c499;
|
|
--color-primary-alpha-70: #4183c4b3;
|
|
--color-primary-alpha-80: #4183c4cc;
|
|
--color-primary-alpha-90: #4183c4e1;
|
|
--color-primary-hover: var(--color-primary-light-1);
|
|
--color-primary-active: var(--color-primary-light-2);
|
|
--color-secondary: #3f4248;
|
|
--color-secondary-dark-1: #46494f;
|
|
--color-secondary-dark-2: #4f5259;
|
|
--color-secondary-dark-3: #5e626a;
|
|
--color-secondary-dark-4: #6f747d;
|
|
--color-secondary-dark-5: #7d828c;
|
|
--color-secondary-dark-6: #8b8f98;
|
|
--color-secondary-dark-7: #999da4;
|
|
--color-secondary-dark-8: #a8abb1;
|
|
--color-secondary-dark-9: #aeb1b8;
|
|
--color-secondary-dark-10: #bbbec3;
|
|
--color-secondary-dark-11: #c8cacf;
|
|
--color-secondary-dark-12: #d2d4d7;
|
|
--color-secondary-dark-13: #d5d6d9;
|
|
--color-secondary-light-1: #35373c;
|
|
--color-secondary-light-2: #2c2e32;
|
|
--color-secondary-light-3: #1f2124;
|
|
--color-secondary-light-4: #191a1c;
|
|
--color-secondary-alpha-10: #3f424819;
|
|
--color-secondary-alpha-20: #3f424833;
|
|
--color-secondary-alpha-30: #3f42484b;
|
|
--color-secondary-alpha-40: #3f424866;
|
|
--color-secondary-alpha-50: #3f424880;
|
|
--color-secondary-alpha-60: #3f424899;
|
|
--color-secondary-alpha-70: #3f4248b3;
|
|
--color-secondary-alpha-80: #3f4248cc;
|
|
--color-secondary-alpha-90: #3f4248e1;
|
|
--color-secondary-button: var(--color-secondary-dark-4);
|
|
--color-secondary-hover: var(--color-secondary-dark-3);
|
|
--color-secondary-active: var(--color-secondary-dark-2);
|
|
/* console colors - used for actions console and console files */
|
|
--color-console-fg: #f8f8f8;
|
|
--color-console-fg-subtle: #c1c3c8;
|
|
--color-console-bg: #191a1c;
|
|
--color-console-border: #313338;
|
|
--color-console-hover-bg: #2a2c30;
|
|
--color-console-active-bg: #313338;
|
|
--color-console-menu-bg: #292b2e;
|
|
--color-console-menu-border: #46494f;
|
|
--color-console-link: #969aa1;
|
|
/* named colors */
|
|
--color-red: #cc4848;
|
|
--color-orange: #cc580c;
|
|
--color-yellow: #cc9903;
|
|
--color-olive: #91a313;
|
|
--color-green: #87ab63;
|
|
--color-teal: #00918a;
|
|
--color-blue: #3a8ac6;
|
|
--color-violet: #906ae1;
|
|
--color-purple: #b259d0;
|
|
--color-pink: #d22e8b;
|
|
--color-brown: #a47252;
|
|
--color-black: #202225;
|
|
/* light variants - produced via Sass scale-color(color, $lightness: +10%) */
|
|
--color-red-light: #d15a5a;
|
|
--color-orange-light: #f6a066;
|
|
--color-yellow-light: #eaaf03;
|
|
--color-olive-light: #abc016;
|
|
--color-green-light: #93b373;
|
|
--color-teal-light: #00b6ad;
|
|
--color-blue-light: #4e96cc;
|
|
--color-violet-light: #9b79e4;
|
|
--color-purple-light: #ba6ad5;
|
|
--color-pink-light: #d74397;
|
|
--color-brown-light: #b08061;
|
|
--color-black-light: #45484e;
|
|
/* dark 1 variants - produced via Sass scale-color(color, $lightness: -10%) */
|
|
--color-red-dark-1: #c23636;
|
|
--color-orange-dark-1: #f38236;
|
|
--color-yellow-dark-1: #b88a03;
|
|
--color-olive-dark-1: #839311;
|
|
--color-green-dark-1: #7a9e55;
|
|
--color-teal-dark-1: #00837c;
|
|
--color-blue-dark-1: #347cb3;
|
|
--color-violet-dark-1: #7b4edb;
|
|
--color-purple-dark-1: #a742c9;
|
|
--color-pink-dark-1: #be297d;
|
|
--color-brown-dark-1: #94674a;
|
|
--color-black-dark-1: #2e3033;
|
|
/* dark 2 variants - produced via Sass scale-color(color, $lightness: -20%) */
|
|
--color-red-dark-2: #ad3030;
|
|
--color-orange-dark-2: #f16e17;
|
|
--color-yellow-dark-2: #a37a02;
|
|
--color-olive-dark-2: #74820f;
|
|
--color-green-dark-2: #6c8c4c;
|
|
--color-teal-dark-2: #00746e;
|
|
--color-blue-dark-2: #2e6e9f;
|
|
--color-violet-dark-2: #6733d6;
|
|
--color-purple-dark-2: #9834b9;
|
|
--color-pink-dark-2: #a9246f;
|
|
--color-brown-dark-2: #835b42;
|
|
--color-black-dark-2: #292b2e;
|
|
/* ansi colors used for actions console and console files */
|
|
--color-ansi-black: #202225;
|
|
--color-ansi-red: #cc4848;
|
|
--color-ansi-green: #87ab63;
|
|
--color-ansi-yellow: #cc9903;
|
|
--color-ansi-blue: #3a8ac6;
|
|
--color-ansi-magenta: #d22e8b;
|
|
--color-ansi-cyan: #00918a;
|
|
--color-ansi-white: var(--color-console-fg-subtle);
|
|
--color-ansi-bright-black: #45484e;
|
|
--color-ansi-bright-red: #d15a5a;
|
|
--color-ansi-bright-green: #93b373;
|
|
--color-ansi-bright-yellow: #eaaf03;
|
|
--color-ansi-bright-blue: #4e96cc;
|
|
--color-ansi-bright-magenta: #d74397;
|
|
--color-ansi-bright-cyan: #00b6ad;
|
|
--color-ansi-bright-white: var(--color-console-fg);
|
|
/* other colors */
|
|
--color-grey: #3d3f44;
|
|
--color-grey-light: #898d96;
|
|
--color-gold: #b1983b;
|
|
--color-white: #ffffff;
|
|
--color-diff-added-fg: #87ab63;
|
|
--color-diff-added-linenum-bg: #274227;
|
|
--color-diff-added-row-bg: #203224;
|
|
--color-diff-added-row-border: #314a37;
|
|
--color-diff-added-word-bg: #3c653c;
|
|
--color-diff-moved-row-bg: #818044;
|
|
--color-diff-moved-row-border: #bcca6f;
|
|
--color-diff-removed-fg: #cc4848;
|
|
--color-diff-removed-linenum-bg: #482121;
|
|
--color-diff-removed-row-bg: #301e1e;
|
|
--color-diff-removed-row-border: #634343;
|
|
--color-diff-removed-word-bg: #6f3333;
|
|
--color-diff-inactive: #25272a;
|
|
--color-error-border: #763232;
|
|
--color-error-bg: #322226;
|
|
--color-error-bg-active: #49262a;
|
|
--color-error-bg-hover: #3c2427;
|
|
--color-error-text: var(--color-text);
|
|
--color-success-border: #225633;
|
|
--color-success-bg: #1c3329;
|
|
--color-success-text: var(--color-text);
|
|
--color-warning-border: #5f481a;
|
|
--color-warning-bg: #342e1f;
|
|
--color-warning-text: var(--color-text);
|
|
--color-info-border: #254a7e;
|
|
--color-info-bg: #1b283a;
|
|
--color-info-text: var(--color-text);
|
|
--color-red-badge: #db2828;
|
|
--color-red-badge-bg: #db28281a;
|
|
--color-red-badge-hover-bg: #db28284d;
|
|
--color-green-badge: #21ba45;
|
|
--color-green-badge-bg: #21ba451a;
|
|
--color-green-badge-hover-bg: #21ba454d;
|
|
--color-yellow-badge: #fbbd08;
|
|
--color-yellow-badge-bg: #fbbd081a;
|
|
--color-yellow-badge-hover-bg: #fbbd084d;
|
|
--color-orange-badge: #f2711c;
|
|
--color-orange-badge-bg: #f2711c1a;
|
|
--color-orange-badge-hover-bg: #f2711c4d;
|
|
--color-git: #f05133;
|
|
--color-logo: #609926;
|
|
/* target-based colors */
|
|
--color-body: #1e1f20;
|
|
--color-box-header: #1b1c1e;
|
|
--color-box-body: #161718;
|
|
--color-box-body-highlight: #202124;
|
|
--color-text-dark: #f8f8f8;
|
|
--color-text: #d2d4d8;
|
|
--color-text-light: #c0c2c7;
|
|
--color-text-light-1: #aaadb4;
|
|
--color-text-light-2: #969aa1;
|
|
--color-text-light-3: #80858f;
|
|
--color-footer: var(--color-nav-bg);
|
|
--color-timeline: #383b40;
|
|
--color-input-text: var(--color-text-dark);
|
|
--color-input-background: #191a1c;
|
|
--color-input-toggle-background: #323438;
|
|
--color-input-border: var(--color-secondary-dark-1);
|
|
--color-light: #0b0b0c28;
|
|
--color-light-border: #f3f3f428;
|
|
--color-hover: #f3f3f419;
|
|
--color-hover-opaque: #232528; /* TODO: color-mix(in srgb, var(--color-body), var(--color-hover)); */
|
|
--color-active: #f3f3f424;
|
|
--color-menu: #191a1c;
|
|
--color-card: #191a1c;
|
|
--color-markup-table-row: #f3f3f40f;
|
|
--color-markup-code-block: #f3f3f412;
|
|
--color-markup-code-inline: #f3f3f428;
|
|
--color-button: #191a1c;
|
|
--color-code-bg: #161718;
|
|
--color-shadow: #0b0b0c58;
|
|
--color-shadow-opaque: #0b0b0c;
|
|
--color-secondary-bg: #2e3033;
|
|
--color-expand-button: #333539;
|
|
--color-placeholder-text: var(--color-text-light-3);
|
|
--color-editor-line-highlight: var(--color-secondary-alpha-40);
|
|
--color-editor-selection: var(--color-primary-alpha-50);
|
|
--color-project-column-bg: var(--color-secondary-light-2);
|
|
--color-caret: var(--color-text); /* should ideally be --color-text-dark, see #15651 */
|
|
--color-reaction-bg: #f3f3f412;
|
|
--color-reaction-hover-bg: var(--color-primary-light-4);
|
|
--color-reaction-active-bg: var(--color-primary-light-5);
|
|
--color-tooltip-text: #fafafa;
|
|
--color-tooltip-bg: #0b0b0cf0;
|
|
--color-nav-bg: #18191b;
|
|
--color-nav-hover-bg: var(--color-secondary-light-1);
|
|
--color-nav-text: var(--color-text);
|
|
--color-secondary-nav-bg: #1a1b1e;
|
|
--color-label-text: var(--color-text);
|
|
--color-label-bg: #7a7f8a4b;
|
|
--color-label-hover-bg: #7a7f8aa0;
|
|
--color-label-active-bg: #7a7f8aff;
|
|
--color-accent: var(--color-primary-light-1);
|
|
--color-small-accent: var(--color-primary-light-5);
|
|
--color-highlight-fg: #87651e;
|
|
--color-highlight-bg: #443a27;
|
|
--color-overlay-backdrop: #080808c0;
|
|
--color-danger: var(--color-red);
|
|
--color-transparency-grid-light: #2a2a2a;
|
|
--color-transparency-grid-dark: #1a1a1a;
|
|
--color-workflow-edge-hover: #666a73;
|
|
--color-syntax-keyword: #ff8854;
|
|
--color-syntax-bool: #25bbc9;
|
|
--color-syntax-control: #dd9e17;
|
|
--color-syntax-name: #c7a618;
|
|
--color-syntax-type: #eb8cb3;
|
|
--color-syntax-number: #63b2dd;
|
|
--color-syntax-operator: #ff8854;
|
|
--color-syntax-regexp: #b89de4;
|
|
--color-syntax-string: #95b62a;
|
|
--color-syntax-comment: #8898b0;
|
|
--color-syntax-invalid: #ff8686;
|
|
--color-syntax-link: var(--color-primary);
|
|
--color-syntax-tag: #ff8854;
|
|
--color-syntax-attribute: #c792ff;
|
|
--color-syntax-property: #55afff;
|
|
--color-syntax-variable: #e29b33;
|
|
--color-syntax-string-special: #dd9e17;
|
|
--color-syntax-escape: #c7a618;
|
|
--color-syntax-entity: #c792ff;
|
|
--color-syntax-preproc: #4cbe7a;
|
|
--color-syntax-preproc-file: #63b2dd;
|
|
--color-syntax-decorator: #4cbe7a;
|
|
--color-syntax-namespace: #c9d1d9;
|
|
--color-syntax-name-pseudo: #c792ff;
|
|
--color-syntax-comment-special: #b89de4;
|
|
--color-syntax-text: #c9d1d9;
|
|
--color-syntax-text-alt: #b9bcc7;
|
|
--color-syntax-punctuation: #d2d4db;
|
|
--color-syntax-whitespace: #7f8699;
|
|
--color-syntax-diff-fg: #ffffff;
|
|
--color-syntax-deleted-bg: #5f3737;
|
|
--color-syntax-inserted-bg: #3a523a;
|
|
--color-syntax-emph: #d1a242;
|
|
--color-syntax-strong: #e29b33;
|
|
--color-syntax-heading: #dd9e17;
|
|
--color-syntax-subheading: #95b62a;
|
|
--color-syntax-output: #8898b0;
|
|
--color-syntax-prompt: #e29b33;
|
|
--color-syntax-traceback: #ff8686;
|
|
--color-syntax-matching-bracket-bg: #00918a48;
|
|
--color-syntax-nonmatching-bracket-bg: #cc484848;
|
|
accent-color: var(--color-accent);
|
|
color-scheme: dark;
|
|
}
|
|
|
|
/* invert emojis that are hard to read otherwise */
|
|
.emoji[aria-label="check mark"],
|
|
.emoji[aria-label="currency exchange"],
|
|
.emoji[aria-label="TOP arrow"],
|
|
.emoji[aria-label="END arrow"],
|
|
.emoji[aria-label="ON! arrow"],
|
|
.emoji[aria-label="SOON arrow"],
|
|
.emoji[aria-label="heavy dollar sign"],
|
|
.emoji[aria-label="copyright"],
|
|
.emoji[aria-label="registered"],
|
|
.emoji[aria-label="trade mark"],
|
|
.emoji[aria-label="multiply"],
|
|
.emoji[aria-label="plus"],
|
|
.emoji[aria-label="minus"],
|
|
.emoji[aria-label="divide"],
|
|
.emoji[aria-label="curly loop"],
|
|
.emoji[aria-label="double curly loop"],
|
|
.emoji[aria-label="wavy dash"],
|
|
.emoji[aria-label="paw prints"],
|
|
.emoji[aria-label="musical note"],
|
|
.emoji[aria-label="musical notes"] {
|
|
filter: invert(100%) hue-rotate(180deg);
|
|
}
|