Stack Exchange global dark mode

Enables Stack Exchange Inc's own dark mode everywhere

이 스크립트를 설치하려면 Tampermonkey, Greasemonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey와 같은 확장 프로그램을 설치해야 합니다.

이 스크립트를 설치하려면 Tampermonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey 또는 Userscripts와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 유저 스크립트 관리자 확장 프로그램이 필요합니다.

(이미 유저 스크립트 관리자가 설치되어 있습니다. 설치를 진행합니다!)

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

(이미 유저 스타일 관리자가 설치되어 있습니다. 설치를 진행합니다!)

// ==UserScript==
// @author      daniel.z.tg
// @description Enables Stack Exchange Inc's own dark mode everywhere
// @grant       GM_addStyle
// @license     Unlicense
// @match       https://*.askubuntu.com/*
// @match       https://*.mathoverflow.net/*
// @match       https://*.serverfault.com/*
// @match       https://*.stackapps.com/*
// @match       https://*.stackexchange.com/*
// @match       https://*.stackoverflow.com/*
// @match       https://*.superuser.com/*
// @run-at      document-body
// @name        Stack Exchange global dark mode
// @namespace   https://github.com/danielzgtg
// @version     202604020758390001
// ==/UserScript==

/*
 * Inpsired by https://meta.stackexchange.com/a/407981/1373352
 * Features:
 * - Forcibly enables dark mode on all sites in the Stack Exchange network
 * - Unsets many site-specific customizations to recover legibility. A nice side effect is increased stylistic standardization
 * - Stably leaves legibile all SE sites I visit since mid-2025
 * - Works in Stack Exchange Chat too
 * - Cleans up remaining items like headers and footers to darken them
 * - Faster than Dark Reader and doesn't flash. Please disable it on these sites when using this userscript
 * - Hides cookie banners
 */

document.body.classList.add("theme-dark");

new MutationObserver(mutations => {
  for (const mutation of mutations) {
    mutation.addedNodes.forEach(node => node.classList?.remove("theme-light__forced"));
  }
}).observe(document.body, { childList: true });

GM_addStyle(`
/* Reset per-site customizations to the defaults that support dark mode */
body.unified-theme {
  --theme-background-color: var(--white);
  background-image: none;
  header * {
    --theme-header-foreground-color: var(--white);
  }
  footer {
    --theme-footer-background-color: var(--white);
    &, * {
      --theme-footer-text-color: var(--fc-dark);
      --theme-footer-link-color: var(--theme-link-color);
      --theme-footer-link-color-hover: var(--theme-link-color-hover);
    }
  }
  div.s-post-summary, a/*.question-hyperlink*/, a code {
    --theme-link-color: var(--theme-primary);
    --theme-link-color-hover: var(--theme-primary-500);
    --theme-link-color-visited: var(--theme-primary-600);
    --theme-post-title-color: var(--theme-link-color) !important;
    --theme-post-title-color-hover: var(--theme-link-color-hover) !important;
    --theme-post-title-color-visited: var(--theme-link-color-visited) !important;
    --theme-post-title-color-hover-visited: var(--theme-link-color-hover) !important;
  }
  a.s-tag {
	--theme-tag-border-color: var(--_ta-bg);
	--theme-tag-background-color: var(--black-150);
	--theme-tag-color: var(--black-500);
	--theme-tag-hover-border-color: var(--black-200);
	--theme-tag-hover-background-color: var(--black-200);
	--theme-tag-hover-color: var(--black-600);
  }
}
body.outside, body#chat-body, body#transcript-body {
  background: unset !important;
  background-color: var(--theme-background-color,var(--white)) !important;
  > #container, > #footer, div.footerwrap a, div.messages, a.signature, div#sidebar, div.msg-small {
    color:var(--fc-medium) !important;
  }
  div.messages, div.notification, div.fire-popup, div.fire-tooltip, div.fire-reported-post {
    background-color: var(--black-150) !important;
    > div.reply-parent, div.reply-child, div.highlight {
      background-color: transparent !important;
      border: 1px solid yellow;
    }
  }
  div.ob-wikipedia, div.room-mini, div.ob-post, div.timestamp {
    color: unset !important;
    background-color: unset !important;
    > div.ob-wikipedia-title > a {
      color: unset !important;
    }
  }
  span.mention {
    background-color: #ff0 !important;
    color: #000 !important;
  }
}
div#user-menu, body#chat-body div.popup, #userlist>div.usercard, div.usercard-xxl, div.roomcard {
  background-color: var(--black-150);
  color: var(--fc-medium);
  a.um-user-link:not(#a#b), span {
    color: var(--fc-medium) !important;
  }
}
div.roomcard.frozen {
  background-color: var(--black-200)
}
body#chat-body div.message-info-container>div>div.ob-post {
  background-color: var(--black-150);
  &, &>div.ob-post-title>a {
    color: var(--fc-medium) !important;
  }
}
/* Chat FAQ */
body.faq-page {
  #toc {
    background-color: var(--black-150) !important;
    li.current {
      background-color: var(--black-200) !important;
    }
  }
  /* jQuery error :(
  /*div.col-section.expanded {
    background-color: transparent !important;
  }*/
}
#content {
  --theme-content-background-color: none;
}
header.s-topbar {
  --theme-topbar-accent-border: var(--theme-primary) !important;
  --theme-topbar-background-color: hsl(210,8%,5%) !important;
  --theme-topbar-item-background: transparent !important;
  --theme-topbar-item-background-hover: var(--black-200) !important;
  --theme-topbar-item-color: var(--black-400) !important;
  --theme-topbar-item-color-hover: var(--black-600) !important;
  --theme-topbar-search-color: var(--black-500) !important;
  --theme-topbar-search-background: hsl(210,8%,25%) !important;
  --theme-topbar-search-placeholder: var(--black-400) !important;
  --theme-topbar-select-background: transparent !important;
}
/* Hide cookie and Google banners */
div#onetrust-consent-sdk, div#credential_picker_container, a.ot-sdk-show-settings {
  display: none;
}
`);