:root {
  /* Custom green-based steel replacements */
  --steel-900: #0d1607;
  --steel-850: #101a09;
  --steel-800: #141e0b;
  --steel-750: #19260e;
  --steel-700: #1e2d11;
  --steel-650: #243615;
  --steel-600: #2b431a;
  --steel-550: #335120;
  --steel-500: #3b5f26;
  --steel-450: #436e2c;
  --steel-400: #4c7d33;
  --steel-350: #568c3a;
  --steel-300: #609c42;
  --steel-250: #6bad4a;
  --steel-200: #77be53;
  --steel-150: #8cb369;
  --steel-100: #a1c482;
  
  /* Custom gray-green replacements for zinc */
  --zinc-50: #fafaf8;
  --zinc-100: #f6f9f1;
  --zinc-150: #f0f5e8;
  --zinc-200: #e8f0df;
  --zinc-250: #dfe9d3;
  --zinc-300: #d5e2c6;
  --zinc-350: #cad9b7;
  --zinc-400: #b8caa4;
  --zinc-450: #a5bb8f;
  --zinc-500: #92ab7a;
  --zinc-550: #7f9866;
  --zinc-600: #6c8453;
  --zinc-650: #5a7043;
  --zinc-700: #485c34;
  --zinc-750: #374826;
  --zinc-800: #273419;
  --zinc-850: #1d2611;
  --zinc-900: #141a0b;
  
  /* Primary colors - green based */
  --color-primary: #2c5e1a;
  --color-primary-contrast: #ffffff;
  --color-primary-dark-1: #265116;
  --color-primary-dark-2: #214512;
  --color-primary-dark-3: #1e3e12;
  --color-primary-dark-4: #1b380e;
  --color-primary-dark-5: #18310b;
  --color-primary-dark-6: #152b08;
  --color-primary-dark-7: #122405;
  --color-primary-light-1: #336b1f;
  --color-primary-light-2: #3a7824;
  --color-primary-light-3: #428529;
  --color-primary-light-4: #4a9c31;
  --color-primary-light-5: #5da843;
  --color-primary-light-6: #71b456;
  --color-primary-light-7: #8cb369;
  --color-primary-alpha-10: #2c5e1a19;
  --color-primary-alpha-20: #2c5e1a33;
  --color-primary-alpha-30: #2c5e1a4b;
  --color-primary-alpha-40: #2c5e1a66;
  --color-primary-alpha-50: #2c5e1a80;
  --color-primary-alpha-60: #2c5e1a99;
  --color-primary-alpha-70: #2c5e1ab3;
  --color-primary-alpha-80: #2c5e1acc;
  --color-primary-alpha-90: #2c5e1ae1;
  --color-primary-hover: var(--color-primary-dark-2);
  --color-primary-active: var(--color-primary-dark-4);
  
  /* Secondary colors using gray-green palette */
  --color-secondary: var(--zinc-200);
  --color-secondary-dark-1: var(--zinc-200);
  --color-secondary-dark-2: var(--zinc-300);
  --color-secondary-dark-3: var(--zinc-300);
  --color-secondary-dark-4: var(--zinc-400);
  --color-secondary-dark-5: var(--zinc-400);
  --color-secondary-dark-6: var(--zinc-500);
  --color-secondary-dark-7: var(--zinc-500);
  --color-secondary-dark-8: var(--zinc-600);
  --color-secondary-dark-9: var(--zinc-600);
  --color-secondary-dark-10: var(--zinc-700);
  --color-secondary-dark-11: var(--zinc-700);
  --color-secondary-dark-12: var(--zinc-800);
  --color-secondary-dark-13: var(--zinc-800);
  --color-secondary-light-1: var(--zinc-200);
  --color-secondary-light-2: var(--zinc-100);
  --color-secondary-light-3: var(--zinc-100);
  --color-secondary-light-4: var(--zinc-50);
  --color-secondary-alpha-10: #e8f0df19;
  --color-secondary-alpha-20: #e8f0df33;
  --color-secondary-alpha-30: #e8f0df4b;
  --color-secondary-alpha-40: #e8f0df66;
  --color-secondary-alpha-50: #e8f0df80;
  --color-secondary-alpha-60: #e8f0df99;
  --color-secondary-alpha-70: #e8f0dfb3;
  --color-secondary-alpha-80: #e8f0dfcc;
  --color-secondary-alpha-90: #e8f0dfe1;
  --color-secondary-hover: var(--color-secondary-dark-2);
  --color-secondary-active: var(--color-secondary-dark-4);
  
  /* console colors - adjusted for green theme */
  --color-console-fg: #eeeff2;
  --color-console-fg-subtle: #959cab;
  --color-console-bg: #1a2c0d;
  --color-console-border: #2e4a1a;
  --color-console-hover-bg: #ffffff16;
  --color-console-active-bg: #3d5a28;
  --color-console-menu-bg: #2e4a1a;
  --color-console-menu-border: #4a6e31;
  
  /* colors */
  --color-red: #dc2626;
  --color-orange: #ea580c;
  --color-yellow: #ca8a04;
  --color-olive: #91a313;
  --color-green: #2c5e1a;
  --color-teal: #0d9488;
  --color-blue: #2563eb;
  --color-violet: #7c3aed;
  --color-purple: #9333ea;
  --color-pink: #db2777;
  --color-brown: #a47252;
  --color-grey: #4b5563;
  --color-black: #000000;
  
  /* light variants */
  --color-red-light: #ef4444;
  --color-orange-light: #f97316;
  --color-yellow-light: #eab308;
  --color-olive-light: #839311;
  --color-green-light: #4a9c31;
  --color-teal-light: #14b8a6;
  --color-blue-light: #3b82f6;
  --color-violet-light: #8b5cf6;
  --color-purple-light: #a855f7;
  --color-pink-light: #ec4899;
  --color-brown-light: #94674a;
  --color-grey-light: #6b7280;
  --color-black-light: #181818;
  
  /* dark 1 variants */
  --color-red-dark-1: #c82020;
  --color-orange-dark-1: #d34f0b;
  --color-yellow-dark-1: #b67c04;
  --color-olive-dark-1: #839311;
  --color-green-dark-1: #265116;
  --color-teal-dark-1: #0c857a;
  --color-blue-dark-1: #1554e0;
  --color-violet-dark-1: #6a1feb;
  --color-purple-dark-1: #8519e7;
  --color-pink-dark-1: #c7216b;
  --color-brown-dark-1: #94674a;
  --color-black-dark-1: #000000;
  
  /* dark 2 variants */
  --color-red-dark-2: #b21d1d;
  --color-orange-dark-2: #bb460a;
  --color-yellow-dark-2: #a26e03;
  --color-olive-dark-2: #74820f;
  --color-green-dark-2: #1e3e12;
  --color-teal-dark-2: #0a766d;
  --color-blue-dark-2: #124bc7;
  --color-violet-dark-2: #5c14d8;
  --color-purple-dark-2: #7715cf;
  --color-pink-dark-2: #b11d5f;
  --color-brown-dark-2: #835b42;
  --color-black-dark-2: #000000;
  
  /* ansi colors */
  --color-ansi-black: #1f2326;
  --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: #46494d;
  --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-gold: #b1983b;
  --color-white: #ffffff;
  --color-diff-removed-word-bg: #fca5a5;
  --color-diff-added-word-bg: #86efac;
  --color-diff-removed-row-bg: #fee2e2;
  --color-diff-moved-row-bg: #fef9c3;
  --color-diff-added-row-bg: #dcfce7;
  --color-diff-removed-row-border: #fca5a5;
  --color-diff-moved-row-border: #fde047;
  --color-diff-added-row-border: #86efac;
  --color-diff-inactive: var(--zinc-100);
  --color-error-border: #fecaca;
  --color-error-bg: #fee2e2;
  --color-error-bg-active: #fca5a5;
  --color-error-bg-hover: #fecaca;
  --color-error-text: #7f1d1d;
  --color-success-border: #a8d899;
  --color-success-bg: #e5f3df;
  --color-success-text: #1e3e12;
  --color-warning-border: #fde047;
  --color-warning-bg: #fef3c7;
  --color-warning-text: #78350f;
  --color-info-border: #bae6fd;
  --color-info-bg: #e0f2fe;
  --color-info-text: #0c4a6e;
  --color-red-badge: #b91c1c;
  --color-red-badge-bg: #b91c1c22;
  --color-red-badge-hover-bg: #b91c1c44;
  --color-green-badge: #2c5e1a;
  --color-green-badge-bg: #2c5e1a22;
  --color-green-badge-hover-bg: #2c5e1a44;
  --color-yellow-badge: #ca8a04;
  --color-yellow-badge-bg: #ca8a0422;
  --color-yellow-badge-hover-bg: #ca8a0444;
  --color-orange-badge: #ea580c;
  --color-orange-badge-bg: #ea580c22;
  --color-orange-badge-hover-bg: #ea580c44;
  
  /* Icon colors */
  --color-icon-green: var(--color-green-light);
  --color-icon-red: var(--color-red-light);
  --color-icon-purple: var(--color-purple-light);
  
  /* target-based colors */
  --color-body: #fff;
  --color-box-header: var(--zinc-100);
  --color-box-body: var(--zinc-50);
  --color-box-body-highlight: var(--zinc-200);
  --color-text-dark: #1a2c0d;
  --color-text: var(--zinc-900);
  --color-text-light: var(--zinc-700);
  --color-text-light-1: var(--zinc-650);
  --color-text-light-2: var(--zinc-600);
  --color-text-light-3: var(--zinc-550);
  --color-footer: var(--zinc-100);
  --color-timeline: var(--zinc-200);
  --color-input-text: var(--zinc-800);
  --color-input-background: #fff;
  --color-input-toggle-background: #fff;
  --color-input-border: var(--zinc-300);
  --color-input-border-hover: var(--zinc-400);
  --color-header-wrapper: var(--zinc-50);
  --color-header-wrapper-transparent: #f6f9f100;
  --color-light: #ffffffcc;
  --color-light-mimic-enabled: rgba(0, 0, 0, calc(6 / 255 * 222 / 255 / var(--opacity-disabled)));
  --color-light-border: #0000001d;
  --color-hover: #e8f0dfaa;
  --color-active: #cad9b7aa;
  --color-menu: var(--zinc-100);
  --color-card: var(--zinc-50);
  --fancy-card-bg: var(--zinc-100);
  --fancy-card-border: var(--zinc-200);
  --color-markup-table-row: #ffffff06;
  --color-markup-code-block: var(--zinc-150);
  --color-markup-code-inline: var(--zinc-200);
  --color-button: var(--zinc-150);
  --color-code-bg: var(--zinc-50);
  --color-shadow: #00000060;
  --color-secondary-bg: var(--zinc-100);
  --color-text-focus: #fff;
  --color-expand-button: var(--zinc-200);
  --color-placeholder-text: var(--color-text-light-3);
  --color-editor-line-highlight: var(--zinc-100);
  --color-project-board-bg: var(--color-secondary-light-2);
  --color-project-board-dark-label: var(--color-text-light-3);
  --color-caret: var(--color-text);
  --color-reaction-bg: #0000000a;
  --color-reaction-active-bg: var(--color-primary-alpha-20);
  --color-reaction-hover-bg: var(--color-primary-alpha-30);
  --color-tooltip-text: #ffffff;
  --color-tooltip-bg: #1a2c0df0;
  --color-nav-bg: var(--zinc-100);
  --color-nav-hover-bg: var(--zinc-300);
  --color-nav-text: var(--color-text);
  --color-secondary-nav-bg: var(--color-body);
  --color-label-text: var(--color-text);
  --color-label-bg: #cad9b77b;
  --color-label-hover-bg: #cad9b7a0;
  --color-label-active-bg: #cad9b7ff;
  --color-label-bg-alt: #cad9b7ff;
  --color-accent: var(--color-primary-light-4);
  --color-small-accent: var(--color-primary-light-7);
  --color-highlight-fg: var(--color-primary-light-4);
  --color-highlight-bg: #8cb36922;
  --color-overlay-backdrop: #080808c0;
  
  /* pattern colors for gradient */
  --checkerboard-color-1: #ffffff;
  --checkerboard-color-2: #e8f0df;
  
  accent-color: var(--color-accent);
  color-scheme: light;
}

/* Custom class overrides with green theme */
.ui.secondary.vertical.menu {
  border-radius: 0.28571429rem !important;
  overflow: hidden;
}

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

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

.repository.view.issue .comment-list .code-comment + .code-comment {
  margin: 1.25rem 0 !important;
  padding-top: 1.25rem !important;
  border-top-color: var(--zinc-250) !important;
}

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

#review-box .review-comments-counter {
  background-color: var(--color-label-bg) !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 {
  background: var(--color-warning-bg) !important;
  color: var(--color-text-dark) !important;
}

::selection {
  background: var(--steel-450) !important;
  color: var(--color-white) !important;
}

/* https://github.com/alecthomas/chroma/blob/6428fb4e65f3c1493491571c8a6a8f1add1da822/types.go#L208 */
.chroma .bp { color: #999999; } /* NameBuiltinPseudo */
.chroma .c { color: #6a737d; } /* Comment */
.chroma .c1 { color: #6a737d; } /* CommentSingle */
.chroma .ch { color: #6a737d; } /* CommentHashbang */
.chroma .cm { color: #999988; } /* CommentMultiline */
.chroma .cp { color: #109295; } /* CommentPreproc */
.chroma .cpf { color: #4c4dbc; } /* CommentPreprocFile */
.chroma .cs { color: #999999; } /* CommentSpecial */
.chroma .dl { color: #106303; } /* LiteralStringDelimiter */
.chroma .fm {} /* NameFunctionMagic */
.chroma .g {} /* Generic */
.chroma .gd { color: #000000; background-color: #ffdddd; } /* GenericDeleted */
.chroma .ge { color: #000000; } /* GenericEmph */
.chroma .gh { color: #999999; } /* GenericHeading */
.chroma .gi { color: #000000; background-color: #ddffdd; } /* GenericInserted */
.chroma .gl {} /* GenericUnderline */
.chroma .go { color: #888888; } /* GenericOutput */
.chroma .gp { color: #555555; } /* GenericPrompt */
.chroma .gr { color: #aa0000; } /* GenericError */
.chroma .gs {} /* GenericStrong */
.chroma .gt { color: #aa0000; } /* GenericTraceback */
.chroma .gu { color: #aaaaaa; } /* GenericSubheading */
.chroma .il { color: #009999; } /* LiteralNumberIntegerLong */
.chroma .k { color: #d73a49; } /* Keyword */
.chroma .kc { color: #d73a49; } /* KeywordConstant */
.chroma .kd { color: #d73a49; } /* KeywordDeclaration */
.chroma .kn { color: #d73a49; } /* KeywordNamespace */
.chroma .kp { color: #d73a49; } /* KeywordPseudo */
.chroma .kr { color: #d73a49; } /* KeywordReserved */
.chroma .kt { color: #445588; } /* KeywordType */
.chroma .l {} /* Literal */
.chroma .ld {} /* LiteralDate */
.chroma .m { color: #009999; } /* LiteralNumber */
.chroma .mb { color: #009999; } /* LiteralNumberBin */
.chroma .mf { color: #009999; } /* LiteralNumberFloat */
.chroma .mh { color: #009999; } /* LiteralNumberHex */
.chroma .mi { color: #009999; } /* LiteralNumberInteger */
.chroma .mo { color: #009999; } /* LiteralNumberOct */
.chroma .n {} /* Name */
.chroma .na { color: #d73a49; } /* NameAttribute */
.chroma .nb { color: #005cc5; } /* NameBuiltin */
.chroma .nc { color: #445588; } /* NameClass */
.chroma .nd { color: #3c5d5d; } /* NameDecorator */
.chroma .ne { color: #990000; } /* NameException */
.chroma .nf { color: #005cc5; } /* NameFunction */
.chroma .ni { color: #6f42c1; } /* NameEntity */
.chroma .nl { color: #990000; } /* NameLabel */
.chroma .nn { color: #555555; } /* NameNamespace */
.chroma .no { color: #008080; } /* NameConstant */
.chroma .nt { color: #22863a; } /* NameTag */
.chroma .nv { color: #008080; } /* NameVariable */
.chroma .nx { color: #24292e; } /* NameOther */
.chroma .o { color: #d73a49; } /* Operator */
.chroma .ow { color: #d73a49; } /* OperatorWord */
.chroma .p {} /* Punctuation */
.chroma .py {} /* NameProperty */
.chroma .s { color: #106303; } /* LiteralString */
.chroma .s1 { color: #106303; } /* LiteralStringSingle */
.chroma .s2 { color: #106303; } /* LiteralStringDouble */
.chroma .sa { color: #cc7a00; } /* LiteralStringAffix */
.chroma .sb { color: #106303; } /* LiteralStringBacktick */
.chroma .sc { color: #cc7a00; } /* LiteralStringChar */
.chroma .sd { color: #106303; } /* LiteralStringDoc */
.chroma .se { color: #994400; } /* LiteralStringEscape */
.chroma .sh { color: #106303; } /* LiteralStringHeredoc */
.chroma .si { color: #cc7a00; } /* LiteralStringInterpol */
.chroma .sr { color: #4c4dbc; } /* LiteralStringRegex */
.chroma .ss { color: #994400; } /* LiteralStringSymbol */
.chroma .sx { color: #106303; } /* LiteralStringOther */
.chroma .vc { color: #008080; } /* NameVariableClass */
.chroma .vg { color: #008080; } /* NameVariableGlobal */
.chroma .vi { color: #008080; } /* NameVariableInstance */
.chroma .vm {} /* NameVariableMagic */
.chroma .w { color: #bbbbbb; } /* TextWhitespace */
.chroma .err {/* not styled because Chroma uses it on too many things like JSX */} /* Error */

.ui .field:not(:last-child) .EasyMDEContainer .editor-statusbar {
  margin-bottom: -1em; /* when there is a statusbar, the "margin-bottom: 1em" of the "field" is not needed, because the statusbar is likely a blank line */
}

.EasyMDEContainer .CodeMirror {
  color: var(--color-input-text);
  background-color: var(--color-input-background);
  border-color: var(--color-secondary);
  font: 14px var(--fonts-monospace);
}

.EasyMDEContainer .CodeMirror.cm-s-default {
  border-radius: var(--border-radius);
  padding: 0 !important;
}

.EasyMDEContainer .CodeMirror.CodeMirror-fullscreen.CodeMirror-focused {
  border-right: 1px solid var(--color-primary) !important;
}

.CodeMirror-cursor {
  border-color: var(--color-caret) !important;
}

.CodeMirror .cm-comment {
  background: inherit !important;
}

.CodeMirror .CodeMirror-code {
  font: 14px var(--fonts-monospace);
}

.CodeMirror-selected {
  background: var(--color-primary-light-1) !important;
  color: var(--color-white) !important;
}

.CodeMirror-placeholder {
  color: var(--color-placeholder-text) !important;
  opacity: 1 !important;
}

.CodeMirror-focused {
  border-color: var(--color-primary) !important;
}

.CodeMirror :focus {
  outline: none;
}

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