/*
 * justblack - Pure OLED Black Theme for Forgejo
 */

@import "codemirror/dark.css";

:root {
  --void-900: #000000;
  --void-850: #050505;
  --void-800: #0a0a0a;
  --void-750: #0f0f0f;
  --void-700: #141414;
  --void-650: #1a1a1a;
  --void-600: #212121;
  --void-550: #2a2a2a;
  --void-500: #333333;
  --void-450: #404040;
  --void-400: #525252;
  --void-350: #666666;
  --void-300: #7a7a7a;
  --void-250: #8f8f8f;
  --void-200: #a3a3a3;
  --void-150: #b8b8b8;
  --void-100: #d4d4d4;
  --is-dark-theme: true;

  --color-primary: #ffffff;
  --color-primary-contrast: #000000;
  --color-primary-dark-1: #f5f5f5;
  --color-primary-dark-2: #e5e5e5;
  --color-primary-dark-3: #d4d4d4;
  --color-primary-dark-4: #c4c4c4;
  --color-primary-dark-5: #b3b3b3;
  --color-primary-dark-6: #a3a3a3;
  --color-primary-dark-7: #929292;
  --color-primary-light-1: #ffffff;
  --color-primary-light-2: #f5f5f5;
  --color-primary-light-3: #e5e5e5;
  --color-primary-light-4: #d4d4d4;
  --color-primary-light-5: #c4c4c4;
  --color-primary-light-6: #b3b3b3;
  --color-primary-light-7: #a3a3a3;
  --color-primary-alpha-10: #ffffff19;
  --color-primary-alpha-20: #ffffff33;
  --color-primary-alpha-30: #ffffff4b;
  --color-primary-alpha-40: #ffffff66;
  --color-primary-alpha-50: #ffffff80;
  --color-primary-alpha-60: #ffffff99;
  --color-primary-alpha-70: #ffffffb3;
  --color-primary-alpha-80: #ffffffcc;
  --color-primary-alpha-90: #ffffffe6;
  --color-primary-hover: var(--color-primary-dark-1);
  --color-primary-active: var(--color-primary-dark-2);

  --color-secondary: var(--void-700);
  --color-secondary-dark-1: var(--void-550);
  --color-secondary-dark-2: var(--void-500);
  --color-secondary-dark-3: var(--void-450);
  --color-secondary-dark-4: var(--void-400);
  --color-secondary-dark-5: var(--void-350);
  --color-secondary-dark-6: var(--void-300);
  --color-secondary-dark-7: var(--void-250);
  --color-secondary-dark-8: var(--void-200);
  --color-secondary-dark-9: var(--void-150);
  --color-secondary-dark-10: var(--void-100);
  --color-secondary-dark-11: var(--void-100);
  --color-secondary-dark-12: var(--void-100);
  --color-secondary-dark-13: var(--void-100);
  --color-secondary-light-1: var(--void-650);
  --color-secondary-light-2: var(--void-700);
  --color-secondary-light-3: var(--void-750);
  --color-secondary-light-4: var(--void-800);
  --color-secondary-alpha-10: #1a1a1a19;
  --color-secondary-alpha-20: #1a1a1a33;
  --color-secondary-alpha-30: #1a1a1a4b;
  --color-secondary-alpha-40: #1a1a1a66;
  --color-secondary-alpha-50: #1a1a1a80;
  --color-secondary-alpha-60: #1a1a1a99;
  --color-secondary-alpha-70: #1a1a1ab3;
  --color-secondary-alpha-80: #1a1a1acc;
  --color-secondary-alpha-90: #1a1a1ae6;
  --color-secondary-hover: var(--color-secondary-light-1);
  --color-secondary-active: var(--color-secondary-light-2);

  --color-console-fg: #e0e0e0;
  --color-console-fg-subtle: #888888;
  --color-console-bg: #0a0a0a;
  --color-console-border: #1a1a1a;
  --color-console-hover-bg: #ffffff10;
  --color-console-active-bg: #2a2a2a;
  --color-console-menu-bg: #141414;
  --color-console-menu-border: #333333;

  --color-red: #dc2626;
  --color-orange: #ea580c;
  --color-yellow: #eab308;
  --color-olive: #84cc16;
  --color-green: #22c55e;
  --color-teal: #14b8a6;
  --color-blue: #3b82f6;
  --color-violet: #8b5cf6;
  --color-purple: #a855f7;
  --color-pink: #ec4899;
  --color-brown: #a47252;
  --color-grey: var(--void-400);
  --color-black: #000000;

  /* light variants */
  --color-red-light: #ef4444;
  --color-orange-light: #f97316;
  --color-yellow-light: #facc15;
  --color-olive-light: #a3e635;
  --color-green-light: #4ade80;
  --color-teal-light: #2dd4bf;
  --color-blue-light: #60a5fa;
  --color-violet-light: #a78bfa;
  --color-purple-light: #c084fc;
  --color-pink-light: #f472b6;
  --color-brown-light: #c4956a;
  --color-grey-light: var(--void-300);
  --color-black-light: #1a1a1a;

  --color-red-dark-1: #b91c1c;
  --color-orange-dark-1: #c2410c;
  --color-yellow-dark-1: #ca8a04;
  --color-olive-dark-1: #65a30d;
  --color-green-dark-1: #16a34a;
  --color-teal-dark-1: #0d9488;
  --color-blue-dark-1: #2563eb;
  --color-violet-dark-1: #7c3aed;
  --color-purple-dark-1: #9333ea;
  --color-pink-dark-1: #db2777;
  --color-brown-dark-1: #8b5a3c;
  --color-black-dark-1: #000000;

  --color-red-dark-2: #991b1b;
  --color-orange-dark-2: #9a3412;
  --color-yellow-dark-2: #a16207;
  --color-olive-dark-2: #4d7c0f;
  --color-green-dark-2: #15803d;
  --color-teal-dark-2: #0f766e;
  --color-blue-dark-2: #1d4ed8;
  --color-violet-dark-2: #6d28d9;
  --color-purple-dark-2: #7e22ce;
  --color-pink-dark-2: #be185d;
  --color-brown-dark-2: #723f2a;
  --color-black-dark-2: #000000;

  --color-ansi-black: #000000;
  --color-ansi-red: #ef4444;
  --color-ansi-green: #4ade80;
  --color-ansi-yellow: #facc15;
  --color-ansi-blue: #60a5fa;
  --color-ansi-magenta: #e879f9;
  --color-ansi-cyan: #22d3ee;
  --color-ansi-white: #d4d4d4;
  --color-ansi-bright-black: #525252;
  --color-ansi-bright-red: #fca5a5;
  --color-ansi-bright-green: #86efac;
  --color-ansi-bright-yellow: #fde047;
  --color-ansi-bright-blue: #93c5fd;
  --color-ansi-bright-magenta: #f0abfc;
  --color-ansi-bright-cyan: #67e8f9;
  --color-ansi-bright-white: #f5f5f5;

  /* other colors */
  --color-gold: #fbbf24;
  --color-white: #ffffff;
  --color-pure-black: #000000;
  --color-diff-removed-word-bg: #7f1d1d;
  --color-diff-added-word-bg: #14532d;
  --color-diff-removed-row-bg: #450a0a;
  --color-diff-moved-row-bg: #713f12;
  --color-diff-added-row-bg: #052e16;
  --color-diff-removed-row-border: #7f1d1d;
  --color-diff-moved-row-border: #a16207;
  --color-diff-added-row-border: #14532d;
  --color-diff-inactive: var(--void-650);

  --color-error-border: #7f1d1d;
  --color-error-bg: #450a0a;
  --color-error-bg-active: #7f1d1d;
  --color-error-bg-hover: #7f1d1d;
  --color-error-text: #fecaca;
  --color-success-border: #14532d;
  --color-success-bg: #052e16;
  --color-success-text: #bbf7d0;
  --color-warning-border: #a16207;
  --color-warning-bg: #422006;
  --color-warning-text: #fef08a;
  --color-info-border: #1e40af;
  --color-info-bg: #172554;
  --color-info-text: #bfdbfe;

  --color-red-badge: #dc2626;
  --color-red-badge-bg: #dc262622;
  --color-red-badge-hover-bg: #dc262644;
  --color-green-badge: #22c55e;
  --color-green-badge-bg: #22c55e22;
  --color-green-badge-hover-bg: #22c55e44;
  --color-yellow-badge: #eab308;
  --color-yellow-badge-bg: #eab30822;
  --color-yellow-badge-hover-bg: #eab30844;
  --color-orange-badge: #ea580c;
  --color-orange-badge-bg: #ea580c22;
  --color-orange-badge-hover-bg: #ea580c44;

  /* thin element colors */
  --thin-lightness: 0.7;
  --regular-chroma: 0.18;
  --color-thin-green: oklch(var(--thin-lightness) var(--regular-chroma) 145deg);
  --color-thin-red: oklch(var(--thin-lightness) var(--regular-chroma) 27deg);
  --color-thin-purple: oklch(var(--thin-lightness) var(--regular-chroma) 298deg);
  --color-thin-orange: oklch(var(--thin-lightness) var(--regular-chroma) 41deg);
  --thin-lightness-highlight: 0.8;
  --color-thin-red-highlight: oklch(var(--thin-lightness-highlight) var(--regular-chroma) 27deg);
  --bg-lightness: 0.2;
  --bg-chroma: 0.04;
  --color-danger-bg: oklch(var(--bg-lightness) var(--bg-chroma) 27deg);

  --color-body: #000000;
  --color-box-header: var(--void-750);
  --color-box-body: var(--void-800);
  --color-box-body-highlight: var(--void-700);
  --color-text-dark: #ffffff;
  --color-text: var(--void-100);
  --color-text-light: var(--void-150);
  --color-text-light-1: var(--void-150);
  --color-text-light-2: var(--void-200);
  --color-text-light-3: var(--void-250);
  --color-footer: #000000;
  --color-timeline: var(--void-650);
  --color-input-text: var(--void-100);
  --color-input-background: var(--void-750);
  --color-input-toggle-background: var(--void-750);
  --color-input-border: var(--void-600);
  --color-input-border-hover: var(--void-500);
  --color-header-wrapper: #000000;
  --color-header-wrapper-transparent: #00000000;
  --color-light: #ffffff10;
  --color-light-mimic-enabled: rgba(255, 255, 255, 0.05);
  --color-light-border: #ffffff15;
  --color-hover: var(--void-750);
  --color-active: var(--void-700);
  --color-menu: var(--void-800);
  --color-card: var(--void-850);
  --fancy-card-bg: var(--void-800);
  --fancy-card-border: var(--void-700);
  --color-markup-table-row: #ffffff06;
  --color-markup-code-block: var(--void-850);
  --color-markup-code-inline: var(--void-800);
  --color-button: var(--void-700);
  --color-code-bg: var(--void-850);
  --color-shadow: #00000080;
  --color-secondary-bg: var(--void-800);
  --color-text-focus: #ffffff;
  --color-expand-button: var(--void-700);
  --color-placeholder-text: var(--void-400);
  --color-editor-line-highlight: var(--void-800);
  --color-project-board-bg: var(--void-850);
  --color-project-board-dark-label: var(--void-300);
  --color-caret: var(--color-text);
  --color-reaction-bg: #ffffff0a;
  --color-reaction-active-bg: var(--color-primary-alpha-20);
  --color-reaction-hover-bg: var(--color-primary-alpha-30);
  --color-tooltip-text: #000000;
  --color-tooltip-bg: #ffffffe0;
  --color-nav-bg: #000000;
  --color-nav-hover-bg: var(--void-750);
  --color-secondary-nav-bg: #000000;
  --color-label-text: #ffffff;
  --color-label-bg: var(--void-700);
  --color-label-hover-bg: var(--void-650);
  --color-label-active-bg: var(--void-600);
  --color-label-bg-alt: var(--void-650);
  --color-accent: var(--color-primary);
  --color-small-accent: var(--void-300);
  --color-highlight-fg: var(--color-primary);
  --color-highlight-bg: var(--color-primary-alpha-20);
  --color-overlay-backdrop: #000000e0;
  --color-selection-bg: var(--void-100);
  --color-selection-fg: #000000;
  --checkerboard-color-1: #1a1a1a;
  --checkerboard-color-2: #0a0a0a;
  --color-indicator-offline: #737373;
  --color-indicator-offline-20: #73737333;
  --color-indicator-idle: #22c55e;
  --color-indicator-idle-20: #22c55e33;
  --color-indicator-active: #3b82f6;
  --color-indicator-active-20: #3b82f633;

  accent-color: var(--color-accent);
  color-scheme: dark;
}

/* invert emojis that are hard to read on dark */
.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);
}

i.grey.icon.icon.icon.icon {
  color: var(--void-350) !important;
}

.ui.secondary.vertical.menu {
  border-radius: 0.28571429rem !important;
  overflow: hidden;
}

.ui.basic.primary.button.item {
  background-color: var(--void-750) !important;
  color: var(--color-text) !important;
  box-shadow: none !important;
}

.ui.red.label.notification_count,
.ui.primary.label,
.ui.primary.labels .label {
  background-color: var(--color-primary) !important;
  color: var(--color-primary-contrast) !important;
}

.ui.labeled.icon.buttons > .button > .icon,
.ui.labeled.icon.button > .icon {
  background-color: var(--color-light) !important;
}

#review-box .review-comments-counter {
  background-color: var(--void-700) !important;
  color: var(--color-white) !important;
  margin-left: 0.5em;
}

.ui.basic.labels .primary.label,
.ui.ui.ui.basic.primary.label {
  color: var(--color-text-dark) !important;
}

.ui.yellow.label.pending-label {
  color: var(--color-warning-text) !important;
}

strong.attention-important, svg.attention-important {
  color: var(--color-violet-light);
}

strong.attention-note, svg.attention-note {
  color: var(--color-blue-light);
}

strong.attention-caution, svg.attention-caution {
  color: var(--color-red-light);
}

.ui.basic.red.button {
  background-color: var(--color-red);
  color: var(--color-white);
}

.ui.basic.red.button:hover,
.ui.basic.red.button:focus {
  background-color: var(--color-red-dark-1);
  color: var(--color-white);
}

.ui.basic.red.button:active {
  background-color: var(--color-red-dark-2);
  color: var(--color-white);
}

/* borders for OLED - subtle separation */
.ui.segment,
.ui.segments .segment {
  border-color: var(--void-700) !important;
}

/*
 * Chroma syntax highlighting (dark)
 * Based on: https://github.com/alecthomas/chroma
 */

/* LineTableTD */
.chroma .lntd {
  vertical-align: top;
  padding: 0;
  margin: 0;
  border: 0;
}

/* LineTable */
.chroma .lntable {
  border-spacing: 0;
  padding: 0;
  margin: 0;
  border: 0;
  width: auto;
  overflow: auto;
  display: block;
}

/* LineHighlight */
.chroma .hl {
  display: block;
  width: 100%;
}

/* LineNumbersTable */
.chroma .lnt {
  margin-right: 0.4em;
  padding: 0 0.4em;
}

/* LineNumbers */
.chroma .ln {
  margin-right: 0.4em;
  padding: 0 0.4em;
}

/* GenericStrong */
.chroma .gs {
  font-weight: var(--font-weight-semibold);
}

/* GenericUnderline */
.chroma .gl {
  text-decoration: underline;
}

.chroma .bp { color: #fabd2f; } /* NameBuiltinPseudo */
.chroma .c { color: #777e94; } /* Comment */
.chroma .c1 { color: #777e94; } /* CommentSingle */
.chroma .ch { color: #777e94; } /* CommentHashbang */
.chroma .cm { color: #777e94; } /* CommentMultiline */
.chroma .cp { color: #8ec07c; } /* CommentPreproc */
.chroma .cpf { color: #649bc4; } /* CommentPreprocFile */
.chroma .cs { color: #9075cd; } /* CommentSpecial */
.chroma .dl { color: #649bc4; } /* LiteralStringDelimiter */
.chroma .fm {} /* NameFunctionMagic */
.chroma .g {} /* Generic */
.chroma .gd { color: #ffffff; background-color: #5f3737; } /* GenericDeleted */
.chroma .ge { color: #ddee30; } /* GenericEmph */
.chroma .gh { color: #ffaa10; } /* GenericHeading */
.chroma .gi { color: #ffffff; background-color: #3a523a; } /* GenericInserted */
.chroma .go { color: #777e94; } /* GenericOutput */
.chroma .gp { color: #ebdbb2; } /* GenericPrompt */
.chroma .gr { color: #ff4433; } /* GenericError */
.chroma .gt { color: #ff7540; } /* GenericTraceback */
.chroma .gu { color: #b8bb26; } /* GenericSubheading */
.chroma .il { color: #649bc4; } /* LiteralNumberIntegerLong */
.chroma .k { color: #ff7540; } /* Keyword */
.chroma .kc { color: #649bc4; } /* KeywordConstant */
.chroma .kd { color: #ff7540; } /* KeywordDeclaration */
.chroma .kn { color: #ffaa10; } /* KeywordNamespace */
.chroma .kp { color: #5f8700; } /* KeywordPseudo */
.chroma .kr { color: #ff7540; } /* KeywordReserved */
.chroma .kt { color: #ff7b72; } /* KeywordType */
.chroma .l {} /* Literal */
.chroma .ld {} /* LiteralDate */
.chroma .m { color: #649bc4; } /* LiteralNumber */
.chroma .mb { color: #649bc4; } /* LiteralNumberBin */
.chroma .mf { color: #649bc4; } /* LiteralNumberFloat */
.chroma .mh { color: #649bc4; } /* LiteralNumberHex */
.chroma .mi { color: #649bc4; } /* LiteralNumberInteger */
.chroma .mo { color: #649bc4; } /* LiteralNumberOct */
.chroma .n { color: #c9d1d9; } /* Name */
.chroma .na { color: #fabd2f; } /* NameAttribute */
.chroma .nb { color: #fabd2f; } /* NameBuiltin */
.chroma .nc { color: #ffaa10; } /* NameClass */
.chroma .nd { color: #8ec07c; } /* NameDecorator */
.chroma .ne { color: #ff7540; } /* NameException */
.chroma .nf { color: #fabd2f; } /* NameFunction */
.chroma .ni { color: #fabd2f; } /* NameEntity */
.chroma .nl { color: #ff7540; } /* NameLabel */
.chroma .nn { color: #c9d1d9; } /* NameNamespace */
.chroma .no { color: #649bc4; } /* NameConstant */
.chroma .nt { color: #ff7540; } /* NameTag */
.chroma .nv { color: #ebdbb2; } /* NameVariable */
.chroma .nx { color: #b6bac5; } /* NameOther */
.chroma .o { color: #ff7540; } /* Operator */
.chroma .ow { color: #5f8700; } /* OperatorWord */
.chroma .p { color: #d2d4db; } /* Punctuation */
.chroma .py {} /* NameProperty */
.chroma .s { color: #b8bb26; } /* LiteralString */
.chroma .s1 { color: #b8bb26; } /* LiteralStringSingle */
.chroma .s2 { color: #b8bb26; } /* LiteralStringDouble */
.chroma .sa { color: #ffaa10; } /* LiteralStringAffix */
.chroma .sb { color: #b8bb26; } /* LiteralStringBacktick */
.chroma .sc { color: #ffaa10; } /* LiteralStringChar */
.chroma .sd { color: #b8bb26; } /* LiteralStringDoc */
.chroma .se { color: #ff8540; } /* LiteralStringEscape */
.chroma .sh { color: #b8bb26; } /* LiteralStringHeredoc */
.chroma .si { color: #ffaa10; } /* LiteralStringInterpol */
.chroma .sr { color: #9075cd; } /* LiteralStringRegex */
.chroma .ss { color: #ff8540; } /* LiteralStringSymbol */
.chroma .sx { color: #ffaa10; } /* LiteralStringOther */
.chroma .vc { color: #649bee; } /* NameVariableClass */
.chroma .vg { color: #649bee; } /* NameVariableGlobal */
.chroma .vi { color: #649bee; } /* NameVariableInstance */
.chroma .vm {} /* NameVariableMagic */
.chroma .w { color: #7f8699; } /* TextWhitespace */
.chroma .err {} /* Error - not styled */

/* markup dark mode image toggles */
.markup [src$="#gh-light-mode-only"],
.markup [src$="#light-mode-only"],
.markup [href$="#gh-light-mode-only"],
.markup [href$="#light-mode-only"] {
  display: none;
}

.markup [src$="#gh-dark-mode-only"],
.markup [src$="#dark-mode-only"],
.markup [href$="#gh-dark-mode-only"],
.markup [href$="#dark-mode-only"] {
  display: unset;
}
