theme-dark.scss 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291
  1. // Dark Mode Theme Variables and Overrides.
  2. @use 'sass:map';
  3. @import './theme-base';
  4. // Theme colors (BS5 classes)
  5. $primary: $blue-300;
  6. $secondary: $gray-500;
  7. $success: $green-300;
  8. $info: $cyan-300;
  9. $warning: $yellow-300;
  10. $danger: $red-300;
  11. $light: $gray-300;
  12. $dark: $gray-500;
  13. $theme-colors: (
  14. // BS5 theme colors
  15. 'primary': $primary,
  16. 'secondary': $secondary,
  17. 'success': $success,
  18. 'info': $info,
  19. 'warning': $warning,
  20. 'danger': $danger,
  21. 'light': $light,
  22. 'dark': $dark,
  23. // General-purpose palette
  24. 'blue': $blue-300,
  25. 'indigo': $indigo-300,
  26. 'purple': $purple-300,
  27. 'pink': $pink-300,
  28. 'red': $red-300,
  29. 'orange': $orange-300,
  30. 'yellow': $yellow-300,
  31. 'green': $green-300,
  32. 'teal': $teal-300,
  33. 'cyan': $cyan-300,
  34. 'gray': $gray-300,
  35. 'black': $black,
  36. 'white': $white
  37. );
  38. // Gradient
  39. $gradient: linear-gradient(180deg, rgba($white, 0.15), rgba($white, 0));
  40. // Body
  41. $body-bg: $darker;
  42. $body-color: $white;
  43. $body-text-align: null;
  44. $border-color: $gray-700;
  45. $box-shadow: 0 0.5rem 1rem rgba($black, 0.15);
  46. $box-shadow-sm: 0 0.125rem 0.25rem rgba($black, 0.075);
  47. $box-shadow-lg: 0 1rem 3rem rgba($black, 0.175);
  48. $box-shadow-inset: inset 0 1px 2px rgba($black, 0.075);
  49. $text-muted: $gray-400;
  50. $blockquote-footer-color: $gray-600;
  51. $mark-bg: #fcf8e3;
  52. $link-color: $blue-200;
  53. $link-hover-color: $blue-100;
  54. // Alerts
  55. $alert-bg-scale: -5%;
  56. $alert-border-scale: -20%;
  57. $alert-color-scale: 20%;
  58. // Tables
  59. $table-color: $gray-100;
  60. $table-border-color: $border-color;
  61. $table-striped-color: $table-color;
  62. $table-striped-bg: rgba($white, $table-striped-bg-factor);
  63. $table-active-color: $table-color;
  64. $table-active-bg: rgba($white, $table-active-bg-factor);
  65. $table-hover-color: $table-color;
  66. $table-hover-bg: rgba($white, $table-hover-bg-factor);
  67. $table-flush-header-bg: $gray-700;
  68. // Buttons
  69. $btn-box-shadow: inset 0 1px 0 rgba($black, 0.15), 0 1px 1px rgba($white, 0.075);
  70. $btn-active-box-shadow: inset 0 3px 5px rgba($white, 0.125);
  71. $btn-link-disabled-color: $gray-300;
  72. // Forms
  73. $component-active-bg: $primary;
  74. $component-active-color: $black;
  75. $form-text-color: $text-muted;
  76. $input-bg: $gray-900;
  77. $input-disabled-bg: $gray-700;
  78. $input-color: $gray-100;
  79. $input-border-color: $gray-700;
  80. $input-focus-bg: $input-bg;
  81. $input-focus-border-color: tint-color($component-active-bg, 10%);
  82. $input-focus-color: $input-color;
  83. $input-placeholder-color: $gray-700;
  84. $input-plaintext-color: $body-color;
  85. input {
  86. color-scheme: dark;
  87. }
  88. $form-check-input-active-filter: brightness(90%);
  89. $form-check-input-bg: $input-bg;
  90. $form-check-input-border: 1px solid rgba(255, 255, 255, 0.25);
  91. $form-check-input-checked-color: $component-active-color;
  92. $form-check-input-checked-bg-color: $component-active-bg;
  93. $form-check-input-checked-border-color: $form-check-input-checked-bg-color;
  94. $form-check-input-indeterminate-color: $component-active-color;
  95. $form-check-input-indeterminate-bg-color: $component-active-bg;
  96. $form-check-input-indeterminate-border-color: $form-check-input-indeterminate-bg-color;
  97. $form-switch-color: rgba(255, 255, 255, 0.25);
  98. $form-switch-focus-color: $input-focus-border-color;
  99. $form-switch-checked-color: $component-active-color;
  100. $input-group-addon-color: $input-color;
  101. $input-group-addon-bg: $gray-700;
  102. $input-group-addon-border-color: $input-border-color;
  103. $form-select-color: $input-color;
  104. $form-select-disabled-color: $gray-500;
  105. $form-select-bg: $input-bg;
  106. $form-select-disabled-bg: $input-disabled-bg;
  107. $form-select-indicator-color: $form-select-color;
  108. $form-select-indicator: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><path fill='none' stroke='#{$form-select-indicator-color}' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M2 5l6 6 6-6'/></svg>");
  109. $form-select-border-color: $input-border-color;
  110. $form-range-track-bg: $gray-300;
  111. $form-range-thumb-bg: $component-active-bg;
  112. $form-range-thumb-box-shadow: 0 0.1rem 0.25rem rgba($black, 0.1);
  113. $form-range-thumb-focus-box-shadow: 0 0 0 1px $body-bg, $input-focus-box-shadow;
  114. $form-range-thumb-active-bg: tint-color($component-active-bg, 70%);
  115. $form-range-thumb-disabled-bg: $gray-500;
  116. $form-file-button-color: $input-color;
  117. $form-file-button-bg: $input-group-addon-bg;
  118. $form-file-button-hover-bg: shade-color($form-file-button-bg, 5%);
  119. $form-feedback-valid-color: $success;
  120. $form-feedback-invalid-color: $danger;
  121. // Navs
  122. $nav-link-color: $body-color;
  123. $nav-link-hover-color: null;
  124. $nav-link-disabled-color: $gray-800;
  125. $nav-tabs-border-color: $border-color;
  126. $nav-tabs-link-hover-border-color: rgba($gray-800, 0.5) rgba($gray-800, 0.5) $nav-tabs-border-color;
  127. $nav-tabs-link-active-color: $gray-100;
  128. $nav-tabs-link-active-bg: $body-bg;
  129. $nav-tabs-link-active-border-color: $gray-800 $gray-800 $nav-tabs-link-active-bg;
  130. $nav-pills-link-active-color: $component-active-color;
  131. $nav-pills-link-active-bg: $component-active-bg;
  132. $navbar-light-color: $darker;
  133. $navbar-light-toggler-border-color: $gray-700;
  134. $navbar-light-toggler-icon-bg: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'><path stroke='#{$navbar-light-toggler-border-color}' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/></svg>");
  135. // Dropdowns
  136. $dropdown-color: $body-color;
  137. $dropdown-bg: $gray-900;
  138. $dropdown-border-color: rgba($white, 0.15);
  139. $dropdown-link-color: $gray-100;
  140. $dropdown-link-hover-color: $white;
  141. $dropdown-link-hover-bg: $gray-600;
  142. $dropdown-link-disabled-color: $gray-800;
  143. $dropdown-header-color: $gray-600;
  144. // Pagination
  145. $pagination-color: $link-color;
  146. $pagination-bg: $gray-800;
  147. $pagination-border-color: $gray-600;
  148. $pagination-focus-color: $link-hover-color;
  149. $pagination-focus-bg: $gray-400;
  150. $pagination-hover-color: $link-hover-color;
  151. $pagination-hover-bg: $gray-400;
  152. $pagination-hover-border-color: $gray-500;
  153. $pagination-active-color: $component-active-color;
  154. $pagination-active-bg: $component-active-bg;
  155. $pagination-active-border-color: $pagination-active-bg;
  156. $pagination-disabled-color: $gray-600;
  157. $pagination-disabled-bg: $gray-800;
  158. $pagination-disabled-border-color: $gray-600;
  159. // Cards
  160. $card-border-color: rgba($white, 0.125);
  161. $card-inner-border-radius: subtract($card-border-radius, $card-border-width);
  162. $card-cap-color: null;
  163. $card-height: null;
  164. $card-color: null;
  165. $card-bg: $gray-900;
  166. // Accordion
  167. $accordion-color: $body-color;
  168. $accordion-bg: transparent;
  169. $accordion-border-color: $border-color;
  170. $accordion-button-color: $accordion-color;
  171. $accordion-button-bg: $accordion-bg;
  172. $accordion-button-active-bg: shade-color($blue-300, 10%);
  173. $accordion-button-active-color: color-contrast($accordion-button-active-bg);
  174. $accordion-button-focus-border-color: $input-focus-border-color;
  175. $accordion-icon-color: $accordion-color;
  176. $accordion-icon-active-color: $accordion-button-active-color;
  177. $accordion-button-icon: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='#{$accordion-icon-color}'><path fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/></svg>");
  178. $accordion-button-active-icon: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='#{$accordion-icon-active-color}'><path fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/></svg>");
  179. // Tooltips
  180. $tooltip-color: $body-color;
  181. $tooltip-bg: $gray-700;
  182. $tooltip-arrow-color: $tooltip-bg;
  183. $form-feedback-tooltip-opacity: $tooltip-opacity;
  184. // Popovers
  185. $popover-bg: $gray-700;
  186. $popover-border-color: rgba($white, 0.2);
  187. $popover-header-bg: shade-color($popover-bg, 6%);
  188. $popover-header-color: $headings-color;
  189. $popover-body-color: $body-color;
  190. $popover-arrow-color: $popover-bg;
  191. $popover-arrow-outer-color: fade-in($popover-border-color, 0.05);
  192. // Toasts
  193. $toast-color: null;
  194. $toast-background-color: rgba($white, 0.85);
  195. $toast-border-color: rgba(0, 0, 0, 0.1);
  196. $toast-header-color: $gray-600;
  197. $toast-header-background-color: rgba($white, 0.85);
  198. $toast-header-border-color: rgba(0, 0, 0, 0.05);
  199. // Badges
  200. $badge-color: $white;
  201. // Modals
  202. $modal-content-color: null;
  203. $modal-content-bg: $gray-800;
  204. $modal-content-border-color: rgba($white, 0.2);
  205. $modal-backdrop-bg: $black;
  206. $modal-header-border-color: $border-color;
  207. $modal-footer-border-color: $modal-header-border-color;
  208. // Progress bars
  209. $progress-bg: $gray-600;
  210. $progress-bar-color: $white;
  211. $progress-bar-bg: $primary;
  212. // List group
  213. $list-group-color: $body-color;
  214. $list-group-bg: $card-bg;
  215. $list-group-border-color: rgba($white, 0.125);
  216. $list-group-hover-bg: rgba($gray-100, 0.15);
  217. $list-group-active-color: $component-active-color;
  218. $list-group-active-bg: $component-active-bg;
  219. $list-group-active-border-color: $list-group-active-bg;
  220. $list-group-disabled-bg: $list-group-bg;
  221. $list-group-action-color: $gray-300;
  222. $list-group-action-hover-color: $body-color;
  223. $list-group-action-active-color: $body-color;
  224. $list-group-action-active-bg: rgba($gray-300, 0.125);
  225. // Image thumbnails
  226. $thumbnail-bg: $body-bg;
  227. $thumbnail-border-color: $gray-300;
  228. // Figures
  229. $figure-caption-color: $gray-600;
  230. // Breadcrumbs
  231. $breadcrumb-divider-color: $gray-100;
  232. $breadcrumb-active-color: $body-color;
  233. $breadcrumb-divider-flipped: $breadcrumb-divider;
  234. $breadcrumb-divider: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='8'%3E%3Cpath d='M2.5 0L1 1.5 3.5 4 1 6.5 2.5 8l4-4-4-4z' fill='#{$breadcrumb-divider-color}'/%3E%3C/svg%3E");
  235. // Carousel
  236. $carousel-control-color: $white;
  237. $carousel-indicator-active-bg: $white;
  238. $carousel-caption-color: $white;
  239. $carousel-dark-indicator-active-bg: $black;
  240. $carousel-dark-caption-color: $black;
  241. $carousel-dark-control-icon-filter: invert(1) grayscale(100);
  242. // Close
  243. $btn-close-color: $white;
  244. $btn-close-white-filter: invert(1) grayscale(100%) brightness(200%);
  245. $btn-close-bg: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='#{$btn-close-color}'><path d='M.293.293a1 1 0 011.414 0L8 6.586 14.293.293a1 1 0 111.414 1.414L9.414 8l6.293 6.293a1 1 0 01-1.414 1.414L8 9.414l-6.293 6.293a1 1 0 01-1.414-1.414L6.586 8 .293 1.707a1 1 0 010-1.414z'/></svg>");
  246. // Code
  247. $code-color: $gray-600;
  248. $kbd-color: $white;
  249. $kbd-bg: $gray-300;
  250. $pre-color: null;
  251. // Tabbed content
  252. $tab-content-bg: $darkest;