/**
 * Index:
 *
 * 01. BASIC
 * 02. MAIN
 * 03. HEADER
 * 04. COMMON
 * 05. PUBLISHER
 * 06. POST
 * 07. COMMENT
 * 08. BLOG
 * 09. AUTO-COMPLETE
 * 10. LIGHTBOX
 * 11. STORIES
 * 12. CHAT
 * 13. EMOJI
 * 14. REACTIONS
 * 15. RATING
 * 16. PAGE = [BASIC]
 * 17. PAGE = [404]
 * 18. PAGE = [OAUTH]
 * 19. PAGE = [INDEX]
 * 20. PAGE = [FORUMS]
 * 21. PAGE = [DIRECTORY]
 * 22. PAGE = [MESSAGES]
 * 23. PAGE = [LIVE]
 * 24. PAGE = [PROFILE]
 * 25. PAGE = [ADMIN]
 * 26. PAGE = [MARKET]
 * 27. PAGE = [MOVIES]
 * 28. PAGE = [REELS]
 * 29. TRANSLATOR
 * 30. BIG ICON
 * 31. LOADER
 * 32. POST LOADER
 * 33. ON/OFF TOGGLE
 * 34. CUSTOM RADIO/CHECKBOX TEMPLATES
 * 35. PWA INSTALL PROMPT
 * 36. EXTRAS
 * 37. OFFCANVAS
 */

/* BASIC */
/* ------------------------------- */

:root {
  --body-font-family:
    Inter, "Work Sans", "Segoe UI", Helvetica, Arial, "Microsoft YaHei",
    "sans-serif";
  --body-bg-color: #f5f5f5;
  --body-bg-color-dark: #111827;
  --body-color: #333333;
  --body-color-dark: #f3f4f6;
  --link-color: #66c7f4;
  --header-bg-color: #fff;
  --header-bg-color-dark: #1f2937;
  --card-dark-color: #1f2937;
  --card-dark-divider: #334155;
  --card-dark-hover: #273244;
  --card-dark-input: #0f172a;
  --card-dark-input-color: #e5e7eb;
  --plyr-color-main: #66c7f4;
  --base-font-size: 93.75%; /* nb##: 15px/16px=93.75%，改为相对单位以尊重用户浏览器字号偏好 */
}

/* -------------------------------
   Site-wide stat number style
   Applies Georgia italic bold to common statistic number selectors
   and provides `.sg-stat-number` / `.sg-stats-number` utility classes for future use.
   ------------------------------- */
.sg-stats-number,
.sg-stat-number,
.sg-directory-hero-stat-value,
.forum-directory-thread-metric-value,
.forum-list-stat-number,
.forum-directory-thread-metric-card .forum-directory-thread-metric-value {
  font-family: Georgia, "Times New Roman", serif;
  font-style: italic;
  font-weight: 700;
}

/* nb##: PUBLIC Forum 与 GROUP/PAGE/EVENT 的 FORUM/BLOG/SUPPORT 目录 Hero 统一共用一套结构类，避免模块前缀把样式链拆开 */
.sg-directory-hero {
  position: relative;
  margin-bottom: 1.15rem;
  padding: 0 0 0.85rem;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  overflow: visible;
}

.sg-directory-hero-main {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1.25rem;
}

.sg-directory-hero-copy {
  min-width: 0;
  max-width: 46rem;
}

.sg-directory-hero-main > .sg-directory-hero-copy:only-child {
  flex: 1 1 100%;
  max-width: none;
}

.sg-directory-hero-breadcrumb {
  margin: 0 0 0.85rem !important;
}

.sg-directory-hero-description {
  max-width: 38rem;
  margin-top: 0.95rem;
  color: var(--sg-theme-text-sub);
  font-size: 1rem;
  line-height: 1.7;
}

.sg-directory-hero-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
  margin-top: 1.25rem;
}

.sg-directory-hero-stat-card {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  min-width: 118px;
  padding: 0.5rem 1rem;
  border: 0;
  border-radius: var(--bs-border-radius);
  background: var(--bs-dark);
  color: var(--bs-white);
  box-shadow: none;
}

.sg-directory-hero-stat-value {
  display: block;
  color: inherit;
  font-size: clamp(1.45rem, 1.25rem + 0.45vw, 1.7rem);
  line-height: 1;
}

.sg-directory-hero-stat-value--plain {
  font-family: var(--body-font-family);
  font-style: normal;
  font-weight: 700;
}

.sg-directory-hero-stat-label {
  display: block;
  margin-top: 0.35rem;
  color: rgba(255, 255, 255, 0.55);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.sg-directory-hero-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: flex-end;
  gap: 0.65rem;
  padding-top: 0.25rem;
}

.sg-directory-hero-actions .btn {
  padding: 0.78rem 1.05rem;
  border-radius: 2px;
  font-weight: 700;
  letter-spacing: 0.02em;
  box-shadow: none;
}

.sg-directory-hero-primary-btn {
  background: #d4af4d !important;
  border-color: #d4af4d !important;
  color: #1b1b1b !important;
}

.sg-directory-hero-primary-btn:hover {
  background: #e3c26a !important;
  border-color: #e3c26a !important;
  color: #111827 !important;
}

.sg-directory-hero-secondary-btn {
  background: var(--sg-theme-surface) !important;
  border-color: var(--sg-theme-border-mid) !important;
  color: var(--sg-theme-text) !important;
}

.sg-directory-hero-secondary-btn:hover {
  background: var(--sg-theme-surface-2) !important;
  border-color: var(--sg-theme-border-mid) !important;
  color: var(--sg-theme-text) !important;
}

.sg-directory-hero--wide-copy .sg-directory-hero-copy {
  max-width: 52rem;
}

.sg-directory-mainbar > .sg-directory-hero + .sg-blog-hub,
.sg-directory-mainbar > .sg-directory-hero + .card {
  margin-top: 1.25rem;
}

body {
  font-family: var(--body-font-family);
  /* 70px for header */
  padding-top: 70px;
  font-size: var(--base-font-size); /* nb##: 原 15px，改引用 :root 变量，支持用户浏览器字号缩放 */
  color: var(--body-color);
  background-color: var(--body-bg-color);
  position: relative;
}

body.night-mode {
  color: var(--body-color-dark);
  background-color: var(--body-bg-color-dark);
}

body.n_activated,
body.n_live {
  /* 70px for header + 50px for top bar */
  padding-top: 120px;
}

ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

a {
  color: var(--link-color);
  text-decoration: none;
}

a:hover {
  text-decoration: none;
}

pre {
  padding: 15px;
  font-size: 13px;
  word-break: break-all;
  word-wrap: break-word;
  background-color: #f7f7f7;
  border: 1px solid #dbdbdb;
  border-radius: 4px;
}

body.night-mode pre {
  color: var(--body-color-dark);
  background-color: var(--card-dark-input);
  border-color: var(--card-dark-divider);
}

/* -- */

/* MAIN */
/* ------------------------------- */

/* == Icons == */

/* header-icons */
.header-icon,
.header-icon * {
  color: #111 !important;
  fill: #111 !important;
}

body.night-mode .header-icon,
body.night-mode .header-icon * {
  color: #c1d4e3 !important;
  fill: #c1d4e3 !important;
}

.header-icon.active,
.header-icon.active *,
body.night-mode .header-icon.active,
body.night-mode .header-icon.active * {
  color: var(--link-color) !important;
  fill: var(--link-color) !important;
}

/* == */

/* main-icons */
.main-icon,
.main-icon *,
.x-form-tools {
  color: #66c7f4 !important;
  fill: #66c7f4 !important;
}

body.night-mode .main-icon,
body.night-mode .main-icon *,
body.night-mode .x-form-tools {
  color: #66c7f4 !important;
  fill: #66c7f4 !important;
}

/* == */

/* action-icons */
.action-icon,
.action-icon * {
  color: #111 !important;
  fill: #111 !important;
}

body.night-mode .action-icon,
body.night-mode .action-icon * {
  color: #c1d4e3 !important;
  fill: #c1d4e3 !important;
}

/* == */

/* cutom-icons */
.white-icon,
.white-icon * {
  color: #fff !important;
  fill: #fff !important;
}

.danger-icon,
.danger-icon * {
  color: #cb2027 !important;
  fill: #cb2027 !important;
}

/* == */

/* == SVG == */
.svg-container {
  display: inline-block;
}

.svg-container svg {
  display: block; /* nb##: SVG 默认为 inline，基线偏移会导致圆形按钮内图标不居中；block 消除基线空白 */
  width: inherit !important;
  height: inherit !important;
}

/* == */

/* == Scrollbar == */
.custom-scrollbar ::-webkit-scrollbar {
  visibility: hidden;
  height: 8px;
  width: 8px;
}

.custom-scrollbar ::-webkit-scrollbar-thumb {
  visibility: hidden;
  border-radius: 4px;
  background: #808080;
}

.custom-scrollbar:hover ::-webkit-scrollbar,
.custom-scrollbar:hover ::-webkit-scrollbar-thumb {
  visibility: visible;
}

/* == */

/* == Tooltip == */
.tooltip-inner {
  font-family: var(--body-font-family);
  white-space: nowrap;
  max-width: none;
}

/* == */

/* == Text == */
body.night-mode .text-muted {
  color: #798ea4 !important;
}

/* == */

/* == Badge == */
.badge.badge-lg {
  font-size: 100%;
}

/* == */

/* == Img-thumbnail == */
body.night-mode .img-thumbnail {
  background: var(--card-dark-color);
  border-color: var(--card-dark-divider);
}

/* == */

/* == List-group == */
.packages-permissions .list-group-item {
  border-width: 0 0 1px 0;
}

body.night-mode .list-group-item {
  background: var(--card-dark-color);
  border-color: var(--card-dark-divider);
  color: var(--body-color-dark);
}

/* == */

/* == Nav-pills == */

.nav-link {
  color: var(--link-color);
}

/* -- Custom Nav */
.nav-pills.nav-search .nav-item,
.nav-pills.nav-started .nav-item {
  margin-right: 10px;
  margin-bottom: 10px;
}

.nav-pills.nav-search .nav-item:last-child,
.nav-pills.nav-started .nav-item:last-child {
  margin-right: 0;
}

.nav-pills.nav-search .nav-link:not(.active) {
  background: #fff;
}

.nav-pills.nav-started .nav-link {
  padding-top: 15px;
  padding-bottom: 15px;
}

.nav-pills.nav-started .nav-link:not(.active) {
  background: #f3f3f3;
}

body.night-mode .nav-pills.nav-search .nav-link:not(.active),
body.night-mode .nav-pills.nav-started .nav-link:not(.active) {
  background: var(--card-dark-color);
  color: #fff;
}

body.night-mode .nav-pills.nav-search .nav-link:not(.active):hover,
body.night-mode .nav-pills.nav-started .nav-link:not(.active):hover {
  background: var(--card-dark-hover);
}

/* == */

/* == Nav-tabs == */
body.night-mode .nav-tabs {
  border-bottom-color: var(--card-dark-divider);
}

body.night-mode .nav-tabs .nav-item.show .nav-link,
body.night-mode .nav-tabs .nav-link.active {
  color: var(--body-color-dark);
  border-color: var(--card-dark-divider);
  background-color: var(--card-dark-divider);
}

body.night-mode .nav-tabs .nav-link:not(.active):hover {
  border-color: var(--card-dark-divider);
}

/* == */

/* == Dropdown == */
.dropdown {
  outline: none;
}

.dropdown-item.active,
.dropdown-item:active {
  background-color: var(--link-color);
}

.dropdown-divider {
  border-color: #f4f4f4;
  margin-left: 20px;
  margin-right: 20px;
}

.dropdown-menu {
  min-width: 260px;
  border: 0;
  box-shadow:
    rgb(0 0 0 / 10%) 0px 10px 15px -3px,
    rgb(0 0 0 / 10%) 0px 4px 6px -4px;
}

body.night-mode .dropdown-menu {
  color: var(--body-color-dark);
  background: var(--header-bg-color-dark);
  box-shadow: 0 6px 12px rgba(0, 0, 0, 0.175);
}

.dropdown-menu .dropdown-item {
  font-size: 15px;
  padding: 12px 26px;
}

body.night-mode .dropdown-item {
  color: var(--body-color-dark);
}

body.night-mode .dropdown-item:focus,
body.night-mode .dropdown-item:hover {
  color: var(--body-color-dark);
  background-color: var(--card-dark-hover);
}

body.night-mode .dropdown-divider {
  border-top-color: var(--card-dark-divider);
}

/* == */

/* == Modal == */
/* nb##: public auth 已回到 Bootstrap 结构，这里只保留通用 modal 基础样式 */
.modal {
  z-index: 99999;
}

body.night-mode .modal-content {
  background-color: var(--card-dark-color);
}

body.night-mode .modal-header,
body.night-mode .modal-footer {
  border-color: var(--card-dark-divider);
}

.modal-header.with-nav {
  padding-bottom: 0;
  border-bottom: 0;
}

/* == */

/* == Alert == */
.alert {
  padding: 16px 24px;
  border-radius: 16px;
}

.alert-link:hover {
  text-decoration: underline;
}

.alert-dismissible {
  padding-right: 72px;
}

.alert-primary {
  color: #fff;
  border-color: #8dd8f7;
  background-color: #8dd8f7;
}

.alert-primary hr {
  border-top-color: #74cff6;
}

.alert-secondary {
  color: #212529;
  border-color: #f6f7f8;
  background-color: #f6f7f8;
}

.alert-secondary hr {
  border-top-color: #e8eaed;
}

.alert-success {
  color: #fff;
  border-color: #4fd69c;
  background-color: #4fd69c;
}

.alert-success hr {
  border-top-color: #3ad190;
}

.alert-info {
  color: #fff;
  border-color: #37d5f2;
  background-color: #37d5f2;
}

.alert-info hr {
  border-top-color: #1fd0f0;
}

.alert-warning {
  color: #fff;
  border-color: #fc7c5f;
  background-color: #fc7c5f;
}

.alert-warning hr {
  border-top-color: #fc6846;
}

.alert-danger {
  color: #fff;
  border-color: #f75676;
  background-color: #f75676;
}

.alert-danger hr {
  border-top-color: #f63e62;
}

.alert-light {
  color: #fff;
  border-color: #bac1c8;
  background-color: #bac1c8;
}

.alert-light hr {
  border-top-color: #acb4bd;
}

.alert-dark {
  color: #fff;
  border-color: #45484b;
  background-color: #45484b;
}

.alert-dark hr {
  border-top-color: #393b3e;
}

/* -- Custom Alerts */
.alert-post {
  background: #f8f9fa;
  color: var(--link-color);
  font-weight: 600;
  box-shadow: 0 1px 1px rgba(0, 0, 0, 0.05);
}

body.night-mode .alert-post {
  background: var(--card-dark-hover);
}

.alert-chat {
  background: #f4f4f4;
  width: 75%;
  padding: 15px 25px !important;
  margin: 0 auto !important;
  color: #555;
  border-top-left-radius: 0px;
  border-top-right-radius: 0px;
}

body.night-mode .alert-chat {
  background: var(--card-dark-input);
}

.alert .title {
  padding-bottom: 8px;
  margin-bottom: 10px;
  font-weight: 600;
  border-bottom: 1px solid #00000012;
}

.alert .icon {
  display: table-cell;
  vertical-align: middle;
  padding-right: 10px;
}

.alert .text {
  display: table-cell;
  vertical-align: top;
  text-align: left;
}

/* == */

/* == Buttons == */
.btn {
  font-size: 13px;
  font-weight: 600;
  padding: 1rem 2.5rem;
  white-space: nowrap;
  box-shadow: none !important;
}

.btn.focus,
.btn:focus {
  outline: 0;
  box-shadow: none;
}

.btn.disabled,
.btn:disabled {
  box-shadow: none;
}

.btn-lg,
.btn-group-lg > .btn {
  font-size: 14px;
  padding: 16px 96px;
}

.btn-md,
.btn-group-md > .btn {
  font-size: 12px;
  padding: 0.75rem 1.85rem;
}

.btn-sm,
.btn-group-sm > .btn {
  font-size: 11px;
  padding: 8px 26px;
}

.btn-icon {
  padding: 12px 14px;
}

.btn-lg.btn-icon {
  padding: 19px 22px;
}

.btn-md.btn-icon {
  padding: 20px;
}

.btn-sm.btn-icon {
  padding: 5px 8px;
}

.btn-primary,
.btn-primary.disabled,
.btn-primary:disabled,
.btn-primary:not(:disabled):not(.disabled).active,
.btn-primary:not(:disabled):not(.disabled):active,
.show > .btn-primary.dropdown-toggle {
  color: #fff;
  border-color: #66c7f4;
  background-color: #66c7f4;
}

.btn-primary {
  box-shadow:
    0 4px 6px rgba(50, 50, 93, 0.11),
    0 1px 3px rgba(0, 0, 0, 0.08);
}

.btn-primary:hover {
  color: #fff;
  border-color: #4fb9ea;
  background-color: #4fb9ea;
}

.btn-primary.focus,
.btn-primary:focus {
  box-shadow:
    0 4px 6px rgba(50, 50, 93, 0.11),
    0 1px 3px rgba(0, 0, 0, 0.08),
    0 0 0 0 rgba(102, 199, 244, 0.5);
}

.btn-primary:not(:disabled):not(.disabled).active:focus,
.btn-primary:not(:disabled):not(.disabled):active:focus,
.show > .btn-primary.dropdown-toggle:focus {
  box-shadow: none;
}

.btn-secondary,
.btn-secondary.disabled,
.btn-secondary:disabled,
.btn-secondary:not(:disabled):not(.disabled).active,
.btn-secondary:not(:disabled):not(.disabled):active,
.show > .btn-secondary.dropdown-toggle {
  color: #212529;
  border-color: #f7fafc;
  background-color: #f7fafc;
}

.btn-secondary {
  box-shadow:
    0 4px 6px rgba(50, 50, 93, 0.11),
    0 1px 3px rgba(0, 0, 0, 0.08);
}

.btn-secondary:hover {
  color: #212529;
  border-color: #f1f4f6;
  background-color: #f1f4f6;
}

.btn-secondary.focus,
.btn-secondary:focus {
  box-shadow:
    0 4px 6px rgba(50, 50, 93, 0.11),
    0 1px 3px rgba(0, 0, 0, 0.08),
    0 0 0 0 rgba(247, 250, 252, 0.5);
}

.btn-secondary:not(:disabled):not(.disabled).active:focus,
.btn-secondary:not(:disabled):not(.disabled):active:focus,
.show > .btn-secondary.dropdown-toggle:focus {
  box-shadow: none;
}

body.night-mode .btn-secondary {
  color: #f1f1f1;
  border-color: #262d34;
  background-color: #262d34;
}

.btn-success,
.btn-success.disabled,
.btn-success:disabled,
.btn-success:not(:disabled):not(.disabled).active,
.btn-success:not(:disabled):not(.disabled):active,
.show > .btn-success.dropdown-toggle {
  color: #fff;
  border-color: #2dce89;
  background-color: #2dce89;
}

.btn-success {
  box-shadow:
    0 4px 6px rgba(50, 50, 93, 0.11),
    0 1px 3px rgba(0, 0, 0, 0.08);
}

.btn-success:hover {
  color: #fff;
  border-color: #2bc080;
  background-color: #2bc080;
}

.btn-success.focus,
.btn-success:focus {
  box-shadow:
    0 4px 6px rgba(50, 50, 93, 0.11),
    0 1px 3px rgba(0, 0, 0, 0.08),
    0 0 0 0 rgba(45, 206, 137, 0.5);
}

.btn-success:not(:disabled):not(.disabled).active:focus,
.btn-success:not(:disabled):not(.disabled):active:focus,
.show > .btn-success.dropdown-toggle:focus {
  box-shadow: none;
}

.btn-info,
.btn-info.disabled,
.btn-info:disabled,
.btn-info:not(:disabled):not(.disabled).active,
.btn-info:not(:disabled):not(.disabled):active,
.show > .btn-info.dropdown-toggle {
  color: #fff;
  border-color: #11cdef;
  background-color: #11cdef;
}

.btn-info {
  box-shadow:
    0 4px 6px rgba(50, 50, 93, 0.11),
    0 1px 3px rgba(0, 0, 0, 0.08);
}

.btn-info:hover {
  color: #fff;
  border-color: #10bede;
  background-color: #10bede;
}

.btn-info.focus,
.btn-info:focus {
  box-shadow:
    0 4px 6px rgba(50, 50, 93, 0.11),
    0 1px 3px rgba(0, 0, 0, 0.08),
    0 0 0 0 rgba(17, 205, 239, 0.5);
}

.btn-info:not(:disabled):not(.disabled).active:focus,
.btn-info:not(:disabled):not(.disabled):active:focus,
.show > .btn-info.dropdown-toggle:focus {
  box-shadow: none;
}

.btn-warning,
.btn-warning.disabled,
.btn-warning:disabled,
.btn-warning:not(:disabled):not(.disabled).active,
.btn-warning:not(:disabled):not(.disabled):active,
.show > .btn-warning.dropdown-toggle {
  color: #fff;
  border-color: #fb6340;
  background-color: #fb6340;
}

.btn-warning {
  box-shadow:
    0 4px 6px rgba(50, 50, 93, 0.11),
    0 1px 3px rgba(0, 0, 0, 0.08);
}

.btn-warning:hover {
  color: #fff;
  border-color: #f0603f;
  background-color: #f0603f;
}

.btn-warning.focus,
.btn-warning:focus {
  box-shadow:
    0 4px 6px rgba(50, 50, 93, 0.11),
    0 1px 3px rgba(0, 0, 0, 0.08),
    0 0 0 0 rgba(251, 99, 64, 0.5);
}

.btn-warning:not(:disabled):not(.disabled).active:focus,
.btn-warning:not(:disabled):not(.disabled):active:focus,
.show > .btn-warning.dropdown-toggle:focus {
  box-shadow: none;
}

.btn-danger,
.btn-danger.disabled,
.btn-danger:disabled,
.btn-danger:not(:disabled):not(.disabled).active,
.btn-danger:not(:disabled):not(.disabled):active,
.show > .btn-danger.dropdown-toggle {
  color: #fff;
  border-color: #f5365c;
  background-color: #f5365c;
}

.btn-danger {
  box-shadow:
    0 4px 6px rgba(50, 50, 93, 0.11),
    0 1px 3px rgba(0, 0, 0, 0.08);
}

.btn-danger:hover {
  color: #fff;
  border-color: #eb3357;
  background-color: #eb3357;
}

.btn-danger.focus,
.btn-danger:focus {
  box-shadow:
    0 4px 6px rgba(50, 50, 93, 0.11),
    0 1px 3px rgba(0, 0, 0, 0.08),
    0 0 0 0 rgba(245, 54, 92, 0.5);
}

.btn-danger:not(:disabled):not(.disabled).active:focus,
.btn-danger:not(:disabled):not(.disabled):active:focus,
.show > .btn-danger.dropdown-toggle:focus {
  box-shadow: none;
}

.btn-light,
.btn-light.disabled,
.btn-light:disabled,
.btn-light:not(:disabled):not(.disabled).active,
.btn-light:not(:disabled):not(.disabled):active,
.show > .btn-light.dropdown-toggle {
  color: #363853;
  border-color: #f2f2f2;
  background-color: #f2f2f2;
}

.btn-light {
  box-shadow:
    0 4px 6px rgba(50, 50, 93, 0.11),
    0 1px 3px rgba(0, 0, 0, 0.08);
}

.btn-light:hover {
  color: #fff;
  border-color: #a5adb4;
  background-color: #a5adb4;
}

.btn-light.focus,
.btn-light:focus {
  box-shadow:
    0 4px 6px rgba(50, 50, 93, 0.11),
    0 1px 3px rgba(0, 0, 0, 0.08),
    0 0 0 0 rgba(173, 181, 189, 0.5);
}

.btn-light:not(:disabled):not(.disabled).active:focus,
.btn-light:not(:disabled):not(.disabled):active:focus,
.show > .btn-light.dropdown-toggle:focus {
  box-shadow: none;
}

.btn-dark,
.btn-dark.disabled,
.btn-dark:disabled,
.btn-dark:not(:disabled):not(.disabled).active,
.btn-dark:not(:disabled):not(.disabled):active,
.show > .btn-dark.dropdown-toggle {
  color: #fff;
  border-color: #212529;
  background-color: #212529;
}

.btn-dark {
  box-shadow:
    0 4px 6px rgba(50, 50, 93, 0.11),
    0 1px 3px rgba(0, 0, 0, 0.08);
}

.btn-dark:hover {
  color: #fff;
  border-color: #212529;
  background-color: #212529;
}

.btn-dark.focus,
.btn-dark:focus {
  box-shadow:
    0 4px 6px rgba(50, 50, 93, 0.11),
    0 1px 3px rgba(0, 0, 0, 0.08),
    0 0 0 0 rgba(33, 37, 41, 0.5);
}

.btn-dark:not(:disabled):not(.disabled).active:focus,
.btn-dark:not(:disabled):not(.disabled):active:focus,
.show > .btn-dark.dropdown-toggle:focus {
  box-shadow: none;
}

.btn-link {
  font-weight: 400;
  color: var(--link-color);
  background-color: transparent;
}

.btn-link:hover {
  text-decoration: none;
  color: #3ca9dc;
  border-color: transparent;
  background-color: transparent;
}

.btn-link.focus,
.btn-link:focus {
  text-decoration: none;
  border-color: transparent;
  box-shadow: none;
}

.btn-link.disabled,
.btn-link:disabled {
  pointer-events: none;
  color: #8898aa;
}

.btn-outline-primary {
  color: #66c7f4;
  border-color: #66c7f4;
  background-color: transparent;
  background-image: none;
}

.btn-outline-primary:hover {
  color: #fff;
  border-color: #66c7f4;
  background-color: #66c7f4;
}

.btn-outline-primary.focus,
.btn-outline-primary:focus {
  box-shadow: 0 0 0 0 rgba(102, 199, 244, 0.5);
}

.btn-outline-primary.disabled,
.btn-outline-primary:disabled {
  color: #66c7f4;
  background-color: transparent;
}

.btn-outline-primary:not(:disabled):not(.disabled).active,
.btn-outline-primary:not(:disabled):not(.disabled):active,
.show > .btn-outline-primary.dropdown-toggle {
  color: #fff;
  border-color: #66c7f4;
  background-color: #66c7f4;
}

.btn-outline-primary:not(:disabled):not(.disabled).active:focus,
.btn-outline-primary:not(:disabled):not(.disabled):active:focus,
.show > .btn-outline-primary.dropdown-toggle:focus {
  box-shadow: 0 0 0 0 rgba(102, 199, 244, 0.5);
}

.btn-outline-secondary {
  color: #f7fafc;
  border-color: #f7fafc;
  background-color: transparent;
  background-image: none;
}

.btn-outline-secondary:hover {
  color: #212529;
  border-color: #f7fafc;
  background-color: #f7fafc;
}

.btn-outline-secondary.focus,
.btn-outline-secondary:focus {
  box-shadow: 0 0 0 0 rgba(247, 250, 252, 0.5);
}

.btn-outline-secondary.disabled,
.btn-outline-secondary:disabled {
  color: #f7fafc;
  background-color: transparent;
}

.btn-outline-secondary:not(:disabled):not(.disabled).active,
.btn-outline-secondary:not(:disabled):not(.disabled):active,
.show > .btn-outline-secondary.dropdown-toggle {
  color: #212529;
  border-color: #f7fafc;
  background-color: #f7fafc;
}

.btn-outline-secondary:not(:disabled):not(.disabled).active:focus,
.btn-outline-secondary:not(:disabled):not(.disabled):active:focus,
.show > .btn-outline-secondary.dropdown-toggle:focus {
  box-shadow: 0 0 0 0 rgba(247, 250, 252, 0.5);
}

.btn-outline-success {
  color: #2dce89;
  border-color: #2dce89;
  background-color: transparent;
  background-image: none;
}

.btn-outline-success:hover {
  color: #fff;
  border-color: #2dce89;
  background-color: #2dce89;
}

.btn-outline-success.focus,
.btn-outline-success:focus {
  box-shadow: 0 0 0 0 rgba(45, 206, 137, 0.5);
}

.btn-outline-success.disabled,
.btn-outline-success:disabled {
  color: #2dce89;
  background-color: transparent;
}

.btn-outline-success:not(:disabled):not(.disabled).active,
.btn-outline-success:not(:disabled):not(.disabled):active,
.show > .btn-outline-success.dropdown-toggle {
  color: #fff;
  border-color: #2dce89;
  background-color: #2dce89;
}

.btn-outline-success:not(:disabled):not(.disabled).active:focus,
.btn-outline-success:not(:disabled):not(.disabled):active:focus,
.show > .btn-outline-success.dropdown-toggle:focus {
  box-shadow: 0 0 0 0 rgba(45, 206, 137, 0.5);
}

.btn-outline-info {
  color: #11cdef;
  border-color: #11cdef;
  background-color: transparent;
  background-image: none;
}

.btn-outline-info:hover {
  color: #fff;
  border-color: #11cdef;
  background-color: #11cdef;
}

.btn-outline-info.focus,
.btn-outline-info:focus {
  box-shadow: 0 0 0 0 rgba(17, 205, 239, 0.5);
}

.btn-outline-info.disabled,
.btn-outline-info:disabled {
  color: #11cdef;
  background-color: transparent;
}

.btn-outline-info:not(:disabled):not(.disabled).active,
.btn-outline-info:not(:disabled):not(.disabled):active,
.show > .btn-outline-info.dropdown-toggle {
  color: #fff;
  border-color: #11cdef;
  background-color: #11cdef;
}

.btn-outline-info:not(:disabled):not(.disabled).active:focus,
.btn-outline-info:not(:disabled):not(.disabled):active:focus,
.show > .btn-outline-info.dropdown-toggle:focus {
  box-shadow: 0 0 0 0 rgba(17, 205, 239, 0.5);
}

.btn-outline-warning {
  color: #fb6340;
  border-color: #fb6340;
  background-color: transparent;
  background-image: none;
}

.btn-outline-warning:hover {
  color: #fff;
  border-color: #fb6340;
  background-color: #fb6340;
}

.btn-outline-warning.focus,
.btn-outline-warning:focus {
  box-shadow: 0 0 0 0 rgba(251, 99, 64, 0.5);
}

.btn-outline-warning.disabled,
.btn-outline-warning:disabled {
  color: #fb6340;
  background-color: transparent;
}

.btn-outline-warning:not(:disabled):not(.disabled).active,
.btn-outline-warning:not(:disabled):not(.disabled):active,
.show > .btn-outline-warning.dropdown-toggle {
  color: #fff;
  border-color: #fb6340;
  background-color: #fb6340;
}

.btn-outline-warning:not(:disabled):not(.disabled).active:focus,
.btn-outline-warning:not(:disabled):not(.disabled):active:focus,
.show > .btn-outline-warning.dropdown-toggle:focus {
  box-shadow: 0 0 0 0 rgba(251, 99, 64, 0.5);
}

.btn-outline-danger {
  color: #f5365c;
  border-color: #f5365c;
  background-color: transparent;
  background-image: none;
}

.btn-outline-danger:hover {
  color: #fff;
  border-color: #f5365c;
  background-color: #f5365c;
}

.btn-outline-danger.focus,
.btn-outline-danger:focus {
  box-shadow: 0 0 0 0 rgba(245, 54, 92, 0.5);
}

.btn-outline-danger.disabled,
.btn-outline-danger:disabled {
  color: #f5365c;
  background-color: transparent;
}

.btn-outline-danger:not(:disabled):not(.disabled).active,
.btn-outline-danger:not(:disabled):not(.disabled):active,
.show > .btn-outline-danger.dropdown-toggle {
  color: #fff;
  border-color: #f5365c;
  background-color: #f5365c;
}

.btn-outline-danger:not(:disabled):not(.disabled).active:focus,
.btn-outline-danger:not(:disabled):not(.disabled):active:focus,
.show > .btn-outline-danger.dropdown-toggle:focus {
  box-shadow: 0 0 0 0 rgba(245, 54, 92, 0.5);
}

.btn-outline-light {
  color: #adb5bd;
  border-color: #adb5bd;
  background-color: transparent;
  background-image: none;
}

.btn-outline-light:hover {
  color: #fff;
  border-color: #adb5bd;
  background-color: #adb5bd;
}

.btn-outline-light.focus,
.btn-outline-light:focus {
  box-shadow: 0 0 0 0 rgba(173, 181, 189, 0.5);
}

.btn-outline-light.disabled,
.btn-outline-light:disabled {
  color: #adb5bd;
  background-color: transparent;
}

.btn-outline-light:not(:disabled):not(.disabled).active,
.btn-outline-light:not(:disabled):not(.disabled):active,
.show > .btn-outline-light.dropdown-toggle {
  color: #fff;
  border-color: #adb5bd;
  background-color: #adb5bd;
}

.btn-outline-light:not(:disabled):not(.disabled).active:focus,
.btn-outline-light:not(:disabled):not(.disabled):active:focus,
.show > .btn-outline-light.dropdown-toggle:focus {
  box-shadow: 0 0 0 0 rgba(173, 181, 189, 0.5);
}

.btn-outline-dark {
  color: #212529;
  border-color: #212529;
  background-color: transparent;
  background-image: none;
}

.btn-outline-dark:hover {
  color: #fff;
  border-color: #212529;
  background-color: #212529;
}

.btn-outline-dark.focus,
.btn-outline-dark:focus {
  box-shadow: 0 0 0 0 rgba(33, 37, 41, 0.5);
}

.btn-outline-dark.disabled,
.btn-outline-dark:disabled {
  color: #212529;
  background-color: transparent;
}

.btn-outline-dark:not(:disabled):not(.disabled).active,
.btn-outline-dark:not(:disabled):not(.disabled):active,
.show > .btn-outline-dark.dropdown-toggle {
  color: #fff;
  border-color: #212529;
  background-color: #212529;
}

.btn-outline-dark:not(:disabled):not(.disabled).active:focus,
.btn-outline-dark:not(:disabled):not(.disabled):active:focus,
.show > .btn-outline-dark.dropdown-toggle:focus {
  box-shadow: 0 0 0 0 rgba(33, 37, 41, 0.5);
}

/* -- Custom Buttons */
.btn-rounded {
  border: 0 !important;
  border-radius: 50%;
}

.btn-delete:hover {
  color: #fff;
  border-color: #eb3357;
  background-color: #eb3357;
}

.btn-delete:hover .fa:before {
  content: "\f1f8";
}

.btn-payment {
  background: #f7f7f7;
}

.btn-payment:hover {
  background: #f1f1f1;
}

body.night-mode .btn-payment {
  background: var(--card-dark-input);
}

body.night-mode .btn-payment:hover {
  background: var(--card-dark-hover);
}

.btn-voice-start,
.btn-voice-stop {
  display: inline-block;
  padding: 4px 14px;
  background: #007bff;
  color: #fff;
  cursor: pointer;
  border-radius: 18px;
}

.btn-voice-stop {
  background: red;
}

.btn-chat {
  background: #fff;
  padding: 15px;
}

body.night-mode .btn-chat {
  background: var(--card-dark-color);
}

.btn-chat:hover {
  background: #f7f7f7;
}

body.night-mode .btn-chat:hover {
  background: var(--card-dark-hover);
}

.btn-icon-social {
  display: inline-block;
  background: #fbfbfb;
  width: 40px;
  height: 40px;
  line-height: 40px;
  text-align: center;
  border-radius: 50%;
}

body.night-mode .btn-icon-social {
  background: var(--card-dark-hover);
}

.btn-icon-social:hover {
  background: #f7f7f7;
}

body.night-mode .btn-icon-social:hover {
  background: var(--card-dark-color);
}

/* == */

/* == Inputs == */

body.night-mode .form-text {
  color: var(--body-color-dark);
}

.form-group {
  margin-bottom: 15px;
}

.form-control,
.form-select,
.input-group-text {
  padding: 0.75rem 1.5rem;
}

.form-label {
  font-weight: 600;
}

body.night-mode .form-control-plaintext {
  color: var(--body-color-dark);
}

.input-group .btn {
  padding-top: 9px;
  padding-bottom: 9px;
}

.form-check-label {
  padding-top: 2px;
}

/* -- Custom Inputs */
.form-table-row {
  display: flex;
  margin-bottom: 30px;
}

.form-table-row.disabled {
  opacity: 0.5;
}

.form-table-row > div {
  flex: 1;
}

.form-table-row > div:last-child {
  flex-basis: auto;
  flex-grow: 0;
  margin-left: 10px;
}

.form-table-row > div.avatar {
  flex-basis: auto;
  flex-grow: 0;
  margin-right: 20px; /* nb##: svg-to-fa-migration 图标变大后适当拉开与文字区块的间距 */
}

.input-money {
  position: relative;
}

.input-money span {
  font-size: 20px;
  position: absolute;
  top: 15px;
  left: 0;
  width: 45px;
  text-align: center;
}

.input-money.right span {
  left: auto;
  right: 0;
}

.input-money input {
  font-size: 40px;
  line-height: 40px;
  font-family: opensanslight;
  margin: 0;
  padding: 10px;
  padding-left: 45px;
  height: 60px;
  outline: 0;
}

.input-money.right input {
  padding-left: 10px;
  padding-right: 45px;
}

/* == */

/* == Card == */
.card {
  border: 0 none;
  border-radius: 16px;
  margin-bottom: 20px;
}

body.night-mode .card {
  background: var(--card-dark-color);
  color: var(--body-color-dark);
}

.card-header {
  border: 0 none;
  padding: 16px;
  border-radius: 16px 16px 0 0 !important;
}

.card-footer {
  border-radius: 0 0 16px 16px !important;
  border: 0 none;
}

/* -- Custom Cards */
.card-header.with-icon {
  padding: 30px;
}

/* nb##: 卡片头部 FA 图标与原 SVG 同为 24px BEGIN */
.card-header.with-icon > i.main-icon {
  font-size: 1.5rem;
  line-height: 1;
  flex: 0 0 auto;
}
/* nb##: END */

.card-header.with-nav {
  padding-bottom: 0;
  border-bottom: 0;
}

@media (min-width: 768px) {
  .card-header.with-icon {
    font-size: 16px;
    font-weight: 600;
  }
}

.card-body.with-nav,
.card-body.with-list,
.card-body.with-form {
  padding: 10px;
}

.divider,
.card-body .divider,
.modal-body .divider {
  border-top: 1px solid #e6ecf5;
  margin: 25px 0;
}

.divider.dashed,
.card-body .divider.dashed,
.modal-body .divider.dashed {
  border-top-style: dashed;
}

body.night-mode .divider,
body.night-mode .card-body .divider,
body.night-mode .modal-body .divider {
  border-color: var(--card-dark-divider);
}

@media (min-width: 768px) {
  .card-body.page-content {
    padding: 30px;
  }

  .card-body.static-page-content {
    padding: 50px;
  }
}

/*//nb##: 全站通用文章正文排版组件，从 BLOG 详情页抽离；仅在显式挂载 .sg-article + .sg-prose 时生效 BEGIN*/
.sg-article {
  --sg-article-surface: #ffffff;
  --sg-article-surface-soft: #f8f3ea;
  --sg-article-surface-soft-2: #efe5d7;
  --sg-article-border: rgba(30, 41, 59, 0.1);
  --sg-article-border-strong: rgba(30, 41, 59, 0.14);
  --sg-article-shadow-sm: 0 16px 32px rgba(15, 23, 42, 0.06);
  --sg-article-shadow-md: 0 24px 48px rgba(15, 23, 42, 0.08);
  --sg-article-text: #29323d;
  --sg-article-text-sub: #647082;
  --sg-article-text-muted: #8591a0;
  --sg-article-text-faint: #a3adb8;
  --sg-article-quote-bg: linear-gradient(
    135deg,
    rgba(var(--sg-theme-accent-rgb), 0.08) 0%,
    #fcfaf5 100%
  );
  --sg-article-tag-bg: rgba(var(--sg-theme-accent-rgb), 0.1);
  --sg-article-tag-border: rgba(var(--sg-theme-accent-rgb), 0.18);
  --sg-article-body-font-family:
    "IBM Plex Serif", Georgia, "Times New Roman", serif;
  --sg-article-body-font-size: 1.1rem;
  --sg-article-body-line-height: 1.92;
  --sg-article-h2-size: clamp(1.4rem, 3vw, 1.85rem);
  --sg-article-h3-size: clamp(1.15rem, 2.5vw, 1.45rem);
  --sg-article-h4-size: 0.92rem;
}

body.night-mode .sg-article {
  --sg-article-surface: #131820;
  --sg-article-surface-soft: #1b212b;
  --sg-article-surface-soft-2: #212836;
  --sg-article-border: rgba(255, 255, 255, 0.08);
  --sg-article-border-strong: rgba(255, 255, 255, 0.14);
  --sg-article-shadow-sm: 0 16px 32px rgba(0, 0, 0, 0.2);
  --sg-article-shadow-md: 0 26px 52px rgba(0, 0, 0, 0.28);
  --sg-article-text: rgba(240, 244, 255, 0.92);
  --sg-article-text-sub: rgba(209, 217, 231, 0.8);
  --sg-article-text-muted: rgba(188, 197, 213, 0.64);
  --sg-article-text-faint: rgba(174, 184, 201, 0.48);
  --sg-article-quote-bg: linear-gradient(
    135deg,
    rgba(var(--sg-theme-accent-rgb), 0.16) 0%,
    rgba(27, 33, 43, 0.96) 100%
  );
  --sg-article-tag-bg: rgba(var(--sg-theme-accent-rgb), 0.16);
  --sg-article-tag-border: rgba(var(--sg-theme-accent-rgb), 0.24);
}

.sg-article.sg-article--compact {
  --sg-article-body-font-size: 1rem;
  --sg-article-body-line-height: 1.78;
  --sg-article-h2-size: clamp(1.28rem, 2.7vw, 1.55rem);
  --sg-article-h3-size: clamp(1.05rem, 2.1vw, 1.22rem);
  --sg-article-h4-size: 0.84rem;
}

:where(.sg-article.sg-prose, .sg-article .sg-prose) {
  color: var(--sg-article-text-sub);
  font-family: var(--sg-article-body-font-family);
  font-size: var(--sg-article-body-font-size);
  font-weight: 400;
  line-height: var(--sg-article-body-line-height);
  word-break: normal;
  overflow-wrap: break-word;
}

:where(.sg-article.sg-prose, .sg-article .sg-prose) > :last-child {
  margin-bottom: 0;
}

:where(.sg-article.sg-prose, .sg-article .sg-prose) p,
:where(.sg-article.sg-prose, .sg-article .sg-prose) ul,
:where(.sg-article.sg-prose, .sg-article .sg-prose) ol,
:where(.sg-article.sg-prose, .sg-article .sg-prose) blockquote,
:where(.sg-article.sg-prose, .sg-article .sg-prose) figure,
:where(.sg-article.sg-prose, .sg-article .sg-prose) iframe,
:where(.sg-article.sg-prose, .sg-article .sg-prose) table {
  margin: 0 0 1.5rem;
}

:where(.sg-article.sg-prose, .sg-article .sg-prose) strong {
  color: var(--sg-article-text);
  font-weight: 700;
}

:where(.sg-article.sg-prose, .sg-article .sg-prose) h2 {
  margin: 2.75rem 0 1.1rem;
  color: var(--sg-article-text);
  font-family: Georgia, "Times New Roman", serif;
  font-size: var(--sg-article-h2-size);
  font-weight: 700;
  letter-spacing: -0.018em;
  line-height: 1.22;
}

:where(.sg-article.sg-prose, .sg-article .sg-prose) h3 {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  margin: 2.25rem 0 0.9rem;
  color: var(--sg-article-text);
  font-family: Georgia, "Times New Roman", serif;
  font-size: var(--sg-article-h3-size);
  font-weight: 600;
  letter-spacing: -0.01em;
  line-height: 1.3;
}

:where(.sg-article.sg-prose, .sg-article .sg-prose) h3::before {
  content: "";
  display: inline-block;
  width: 4px;
  height: 1em;
  border-radius: 2px;
  background: var(--sg-theme-accent);
  flex-shrink: 0;
}

:where(.sg-article.sg-prose, .sg-article .sg-prose) h4 {
  margin: 2rem 0 0.8rem;
  color: var(--sg-article-text);
  font-family: "IBM Plex Sans", "Segoe UI", Helvetica, Arial, sans-serif;
  font-size: var(--sg-article-h4-size);
  font-weight: 700;
  letter-spacing: 0.09em;
  line-height: 1.45;
  text-transform: uppercase;
}

:where(.sg-article.sg-prose, .sg-article .sg-prose) blockquote {
  position: relative;
  padding: 1.5rem 1.75rem 1.5rem 2rem;
  border-left: 3px solid var(--sg-theme-accent);
  border-radius: 0 10px 10px 0;
  background: var(--sg-article-quote-bg);
}

:where(.sg-article.sg-prose, .sg-article .sg-prose) blockquote::before {
  content: '"';
  position: absolute;
  top: -0.5rem;
  left: 1.2rem;
  color: var(--sg-theme-accent);
  font-family: Georgia, "Times New Roman", serif;
  font-size: 4.5rem;
  font-weight: 900;
  line-height: 1;
  opacity: 0.3;
  pointer-events: none;
}

:where(.sg-article.sg-prose, .sg-article .sg-prose) blockquote p {
  margin-bottom: 0.65rem;
  color: var(--sg-article-text);
  font-family: Georgia, "Times New Roman", serif;
  font-size: 1.15rem;
  font-style: italic;
  font-weight: 400;
  line-height: 1.65;
}

:where(.sg-article.sg-prose, .sg-article .sg-prose) blockquote cite {
  display: block;
  color: var(--sg-theme-accent);
  font-family: "IBM Plex Sans", "Segoe UI", Helvetica, Arial, sans-serif;
  font-size: 0.78rem;
  font-style: normal;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

:where(.sg-article.sg-prose, .sg-article .sg-prose) blockquote cite::before {
  content: "\2014 ";
}

:where(.sg-article.sg-prose, .sg-article .sg-prose) ul,
:where(.sg-article.sg-prose, .sg-article .sg-prose) ol {
  padding-left: 1.5rem;
}

:where(.sg-article.sg-prose, .sg-article .sg-prose) li {
  margin-bottom: 0.5rem;
  color: var(--sg-article-text);
}

:where(.sg-article.sg-prose, .sg-article .sg-prose) ul li::marker,
:where(.sg-article.sg-prose, .sg-article .sg-prose) ol li::marker {
  color: var(--sg-theme-accent);
}

:where(.sg-article.sg-prose, .sg-article .sg-prose) a {
  color: var(--sg-theme-accent);
  text-decoration: underline;
  text-decoration-color: rgba(var(--sg-theme-accent-rgb), 0.42);
  text-underline-offset: 3px;
  transition:
    color 0.18s ease,
    text-decoration-color 0.18s ease;
}

:where(.sg-article.sg-prose, .sg-article .sg-prose) a:hover,
:where(.sg-article.sg-prose, .sg-article .sg-prose) a:focus {
  color: var(--sg-theme-accent);
  text-decoration-color: var(--sg-theme-accent);
}

:where(.sg-article.sg-prose, .sg-article .sg-prose) > img,
:where(.sg-article.sg-prose, .sg-article .sg-prose) figure img,
:where(.sg-article.sg-prose, .sg-article .sg-prose) p > img:only-child {
  display: block;
  width: 100%;
  max-width: 100% !important;
  height: auto !important;
  margin: 2.25rem 0;
  border-radius: 12px;
  box-shadow: var(--sg-article-shadow-md);
}

:where(.sg-article.sg-prose, .sg-article .sg-prose) figure {
  margin: 2.25rem 0;
}

:where(.sg-article.sg-prose, .sg-article .sg-prose) .sg-article-img-wrap {
  margin: 2.25rem 0;
  border: 1px solid var(--sg-article-border);
  border-radius: 12px;
  background: var(--sg-article-surface-soft);
  box-shadow: var(--sg-article-shadow-sm);
  overflow: hidden;
}

:where(.sg-article.sg-prose, .sg-article .sg-prose) .sg-article-img-wrap > img,
:where(.sg-article.sg-prose, .sg-article .sg-prose)
  figure.sg-article-img-wrap
  img {
  margin: 0;
  border-radius: 0;
  box-shadow: none;
}

:where(.sg-article.sg-prose, .sg-article .sg-prose) .sg-article-img-caption,
:where(.sg-article.sg-prose, .sg-article .sg-prose)
  figure.sg-article-img-wrap
  figcaption {
  display: flex;
  align-items: flex-start;
  gap: 0.45rem;
  padding: 0.65rem 1rem;
  border-top: 1px solid var(--sg-article-border);
  background: var(--sg-article-surface-soft-2);
  color: var(--sg-article-text-muted);
  font-family: "IBM Plex Sans", "Segoe UI", Helvetica, Arial, sans-serif;
  font-size: 0.78rem;
  font-style: italic;
  line-height: 1.55;
}

:where(.sg-article.sg-prose, .sg-article .sg-prose) .sg-article-img-caption i,
:where(.sg-article.sg-prose, .sg-article .sg-prose)
  figure.sg-article-img-wrap
  figcaption
  i {
  color: var(--sg-theme-accent);
  margin-top: 0.08rem;
  flex-shrink: 0;
}

:where(.sg-article.sg-prose, .sg-article .sg-prose) iframe {
  width: 100% !important;
  min-height: 420px;
  border: 0;
  border-radius: 12px;
  background: #000;
  box-shadow: var(--sg-article-shadow-sm);
}

:where(.sg-article.sg-prose, .sg-article .sg-prose) hr {
  margin: 2.35rem 0;
  border: 0;
  border-top: 1px solid var(--sg-article-border);
  opacity: 1;
}

:where(.sg-article.sg-prose, .sg-article .sg-prose) .drop-cap::first-letter {
  float: left;
  margin-top: 0.06em;
  margin-right: 0.12em;
  color: var(--sg-theme-accent);
  font-family: Georgia, "Times New Roman", serif;
  font-size: 4.2rem;
  font-weight: 900;
  line-height: 0.82;
}

@media (max-width: 767.98px) {
  :where(.sg-article.sg-prose, .sg-article .sg-prose) {
    font-size: 1rem;
    line-height: 1.78;
  }

  :where(.sg-article.sg-prose, .sg-article .sg-prose) h2 {
    margin-top: 2.35rem;
    font-size: 1.5rem;
  }

  :where(.sg-article.sg-prose, .sg-article .sg-prose) h3 {
    gap: 0;
    padding-left: 0.85rem;
    border-left: 3px solid var(--sg-theme-accent);
    font-size: 1.18rem;
  }

  :where(.sg-article.sg-prose, .sg-article .sg-prose) h3::before {
    display: none;
  }

  :where(.sg-article.sg-prose, .sg-article .sg-prose) .drop-cap::first-letter {
    font-size: 3.45rem;
  }

  :where(.sg-article.sg-prose, .sg-article .sg-prose) > img,
  :where(.sg-article.sg-prose, .sg-article .sg-prose) figure img,
  :where(.sg-article.sg-prose, .sg-article .sg-prose) p > img:only-child {
    margin: 1.8rem 0;
    border-radius: 10px;
  }

  :where(.sg-article.sg-prose, .sg-article .sg-prose) iframe {
    min-height: 220px;
  }
}
/*//nb##: END*/

.card-pricing {
  border: 1px solid #f4f4f4;
}

.card-pricing .icon {
  max-width: 42px;
  border: 1px solid #f4f4f4;
  padding: 4px;
  border-radius: 16px;
}

body.night-mode .card-pricing .icon {
  border-color: var(--card-dark-divider);
}

.card-pricing .price {
  font-weight: 700;
}

body.night-mode .card-pricing,
body.night-mode .card-pricing .list-group-item {
  border-color: var(--card-dark-divider);
}

.card-footer-fake {
  text-align: right;
  padding: 0.75rem 1rem;
  background-color: rgba(0, 0, 0, 0.03);
  margin: 1rem -1rem -1rem;
  border-radius: 0 0 16px 16px;
}

/* == */

/* == Bg-gradient == */
.bg-gradient-primary {
  color: #fff !important;
  background: linear-gradient(87deg, #66c7f4 0, #4fb9ea 100%) !important;
}

.bg-primary {
  color: #fff !important;
  background: #66c7f4 !important;
}

.bg-gradient-secondary {
  background: linear-gradient(87deg, #f7fafc 0, #f7f8fc 100%) !important;
}

.bg-gradient-success {
  color: #fff !important;
  background: linear-gradient(87deg, #2dce89 0, #2dcecc 100%) !important;
}

.bg-gradient-info {
  color: #fff !important;
  background: linear-gradient(87deg, #11cdef 0, #1171ef 100%) !important;
}

.bg-gradient-warning {
  color: #fff !important;
  background: linear-gradient(87deg, #fb6340 0, #fbb140 100%) !important;
}

.bg-gradient-danger {
  color: #fff !important;
  background: linear-gradient(87deg, #f5365c 0, #f56036 100%) !important;
}

.bg-gradient-light {
  background: linear-gradient(87deg, #adb5bd 0, #adaebd 100%) !important;
}

.bg-gradient-dark {
  color: #eee;
  background: linear-gradient(87deg, #212529 0, #212229 100%) !important;
}

.bg-gradient-default {
  color: #eee;
  background: linear-gradient(87deg, #172b4d 0, #1a174d 100%) !important;
}

.bg-gradient-white {
  background: linear-gradient(87deg, #fff 0, #fff 100%) !important;
}

.bg-gradient-neutral {
  background: linear-gradient(87deg, #fff 0, #fff 100%) !important;
}

.bg-gradient-darker {
  color: #eee;
  background: linear-gradient(87deg, #000 0, #000 100%) !important;
}

.bg-gradient-blue {
  color: #fff !important;
  background: linear-gradient(87deg, #66c7f4 0, #4fb9ea 100%) !important;
}

.bg-gradient-indigo {
  color: #fff !important;
  background: linear-gradient(87deg, #5603ad 0, #9d03ad 100%) !important;
}

.bg-indigo {
  color: #fff !important;
  background: #5603ad !important;
}

.bg-gradient-purple {
  color: #fff !important;
  background: linear-gradient(87deg, #8965e0 0, #bc65e0 100%) !important;
}

.bg-gradient-pink {
  color: #fff !important;
  background: linear-gradient(87deg, #f3a4b5 0, #f3b4a4 100%) !important;
}

.bg-gradient-red {
  color: #fff !important;
  background: linear-gradient(87deg, #f5365c 0, #aa2b07 100%) !important;
}

.bg-red {
  color: #fff !important;
  background: #f5365c !important;
}

.bg-gradient-orange {
  color: #fff !important;
  background: linear-gradient(87deg, #fb6340 0, #fbb140 100%) !important;
}

.bg-gradient-yellow {
  color: #666;
  background: linear-gradient(87deg, #ffd600 0, #beff00 100%) !important;
}

.bg-gradient-green {
  color: #fff !important;
  background: linear-gradient(87deg, #2dce89 0, #2dcecc 100%) !important;
}

.bg-gradient-teal {
  color: #fff !important;
  background: linear-gradient(87deg, #11cdef 0, #1171ef 100%) !important;
}

.bg-teal {
  color: #fff !important;
  background: #1171ef !important;
}

.bg-gradient-cyan {
  color: #fff !important;
  background: linear-gradient(87deg, #009688 0, #26b8ab 100%) !important;
}

.bg-gradient-white {
  color: #000 !important;
  background: linear-gradient(87deg, #fff 0, #fff 100%) !important;
}

.bg-gradient-gray {
  color: #fff !important;
  background: linear-gradient(87deg, #8898aa 0, #888aaa 100%) !important;
}

.bg-gradient-gray-dark {
  color: #fff !important;
  background: linear-gradient(87deg, #32325d 0, #44325d 100%) !important;
}

.bg-gradient-light {
  color: #000 !important;
  background: linear-gradient(87deg, #ced4da 0, #cecfda 100%) !important;
}

.bg-gradient-lighter {
  color: #000 !important;
  background: linear-gradient(87deg, #e9ecef 0, #e9eaef 100%) !important;
}

/* == */

/* == Callout == */
.bs-callout {
  background: #fff;
  padding: 20px;
  margin: 20px 0;
  border-left: 5px solid #eee;
  border-radius: 3px;
}

body.night-mode .bs-callout {
  background: var(--card-dark-input);
}

.bs-callout h4 {
  margin-top: 0;
  margin-bottom: 5px;
}

.bs-callout p:last-child {
  margin-bottom: 0;
}

.bs-callout code {
  border-radius: 3px;
}

.bs-callout + .bs-callout {
  margin-top: -5px;
}

.bs-callout-default {
  border-left-color: #777;
}

.bs-callout-default h4 {
  color: #777;
}

.bs-callout-primary {
  border-left-color: #428bca;
}

.bs-callout-primary h4 {
  color: #428bca;
}

.bs-callout-success {
  border-left-color: #5cb85c;
}

.bs-callout-success h4 {
  color: #5cb85c;
}

.bs-callout-danger {
  border-left-color: #d9534f;
  background: #fff1f0;
}

.bs-callout-danger h4 {
  color: #d9534f;
}

.bs-callout-warning {
  border-left-color: #f0ad4e;
  background: #fdf5e9;
}

.bs-callout-warning h4 {
  color: #f0ad4e;
}

.bs-callout-info {
  border-left-color: #5bc0de;
}

.bs-callout-info h4 {
  color: #5bc0de;
}

/* == */

/* == [JS Plugin] Bootstrap-Select == */
.bootstrap-select:not(.input-group-btn) {
  height: 100%;
}

.bootstrap-select .dropdown-toggle .filter-option {
  display: inline-block !important;
  position: static !important;
  padding: 0 !important;
}

.bootstrap-select .btn-outline-light {
  color: #495057;
  border-color: #ddd;
}

.bootstrap-select .option .icon {
  display: table-cell;
  vertical-align: middle;
  padding-right: 10px;
}

.bootstrap-select .option .text {
  display: table-cell;
  vertical-align: top;
  text-align: left;
}

/* == */

/* == [JS Plugin] MCE Editor == */
div.mce-fullscreen {
  z-index: 99999;
}

/* == */

/* == [JS Plugin] jQuery-UI (autocomplete) == */
.ui-autocomplete {
  position: absolute;
  top: 0;
  left: 0;
  cursor: default;
  z-index: 9999;
}

.ui-widget-content {
  background: #fff;
  color: #444;
  z-index: 99999;
  padding: 10px;
  border-radius: 0 0 3px 3px;
  box-shadow: 0 3px 4px rgba(0, 0, 0, 0.15);
}

body.night-mode .ui-widget-content {
  background: var(--header-bg-color-dark);
  box-shadow: 0 6px 12px rgba(0, 0, 0, 0.175);
}

.ui-menu-item {
  position: relative;
  margin: 0;
  padding: 5px 0;
  border-radius: 3px;
  cursor: pointer;
}

.ui-menu-item:hover {
  background: #efefef;
}

body.night-mode .ui-menu-item:hover {
  background: #424242;
}

.ui-menu-item a {
  color: #444;
}

body.night-mode .ui-menu-item a {
  color: #e5e5e5;
}

.ui-menu-item img {
  width: 30px;
  margin: 5px;
  border-radius: 50%;
}

.ui-menu-item span {
  font-size: 13px;
}

.ui-helper-hidden-accessible {
  display: none;
}

/* -- */

/* == [JS Plugin] Tagify == */
.tagify {
  width: 100%;
}

body.night-mode .tagify {
  border-color: var(--card-dark-divider);
  color: var(--body-color-dark);
}

body.night-mode .tagify__dropdown,
body.night-mode .tagify__dropdown__wrapper {
  background-color: var(--card-dark-input);
  border-color: var(--card-dark-divider);
}

body.night-mode .tagify__dropdown__item--active {
  background-color: var(--card-dark-input);
}

.tagify__dropdown {
  z-index: 99999 !important;
}

/* == */

/* == [JS Plugin] CookieConsent == */
.cc-window.cc-floating {
  border-radius: 10px;
}

/* == */

/* == [JS Plugin] DataTables == */
.table > :not(caption) > * > * {
  padding: 0.875rem 0.875rem;
}

/* == */

/* == [JS Plugin] Tagify == */
.tagify {
  border-radius: var(--bs-border-radius);
}

/* == */

/* topic-tag-picker */
.js_topic-tag-picker {
  margin-top: 10px;
}

.js_topic-tag-picker-label {
  font-size: 12px;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

.js_topic-selection-input + .tagify,
.js_topic-selection-input.tagify {
  background: linear-gradient(180deg, #fffaf1 0%, #fff4dd 100%);
  border-color: #e7c47d;
}

body.night-mode .js_topic-selection-input + .tagify,
body.night-mode .js_topic-selection-input.tagify {
  background: linear-gradient(180deg, #382b17 0%, #2c2112 100%);
  border-color: #8f7240;
}

.topic-tag-option {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 0.45rem 0.8rem;
  border: 1px dashed #9cb6d3;
  border-radius: 999px;
  background: linear-gradient(180deg, #f8fbff 0%, #eef5ff 100%);
  color: #2d5f93;
  font-size: 12px;
  font-weight: 700;
  line-height: 1;
  transition: all 0.18s ease;
}

.topic-tag-option:hover,
.topic-tag-option:focus {
  border-color: #5a94cf;
  background: linear-gradient(180deg, #eef6ff 0%, #ddeeff 100%);
  color: #174975;
  transform: translateY(-1px);
}

.topic-tag-option.is-picked {
  border-style: solid;
  border-color: #70b27d;
  background: #edf8f0;
  color: #25633a;
}

/* nb##: BLOG-TAG-HEIGHT-SCHEDULE-HIDE BLOG 发布/编辑页统一 Tagify 与 AI 建议标签高度，避免中英文混排导致 pill 高度跳动 */
.sg-blog-form-card {
  --sg-blog-form-tag-height: 32px;
  --sg-blog-form-tag-inline-padding: 0.8rem;
}

.sg-blog-form-card .tagify__tag {
  display: inline-flex;
  align-items: center;
}

.sg-blog-form-card .tagify__tag > div {
  min-height: var(--sg-blog-form-tag-height);
  padding-block: 0;
  padding-inline: var(--sg-blog-form-tag-inline-padding);
  display: inline-flex;
  align-items: center;
}

.sg-blog-form-card .tagify__tag-text {
  display: inline-flex;
  align-items: center;
  line-height: 1.2;
}

.sg-blog-form-card .tagify__input,
.sg-blog-form-card .tagify__input::before,
.sg-blog-form-card .tagify__input:empty::before {
  min-height: var(--sg-blog-form-tag-height);
  line-height: 1.2;
  align-self: center;
}

.sg-blog-form-card .nbai-tag-suggestions .nbai-tag-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: var(--sg-blog-form-tag-height);
  padding: 0.35rem var(--sg-blog-form-tag-inline-padding);
  font-size: 0.875rem;
  line-height: 1.2;
  white-space: nowrap;
}

body.night-mode .topic-tag-option {
  border-color: #4d6d90;
  background: linear-gradient(180deg, #1f2e40 0%, #1a2635 100%);
  color: #b6d7fb;
}

body.night-mode .topic-tag-option:hover,
body.night-mode .topic-tag-option:focus {
  border-color: #73a8de;
  background: linear-gradient(180deg, #22364b 0%, #1d3044 100%);
  color: #d7ebff;
}

body.night-mode .topic-tag-option.is-picked {
  border-color: #5ea16d;
  background: #1d3524;
  color: #93d5a1;
}

/* -- */

/* == [JS Plugin] Plyr.JS == */
.plyr.fluid-video.non-fullscreen .plyr__video-wrapper {
  max-height: calc(100vh - 350px);
  width: auto;
  height: auto;
  max-width: 100%;
  overflow: hidden;
}

.plyr.fluid-video.non-fullscreen .plyr__video-wrapper video {
  max-height: calc(100vh - 350px);
}

.plyr.fluid-video.fullscreen .plyr__video-wrapper {
  max-height: 100%;
  height: 100%;
  width: 100%;
}

.plyr.fluid-video.fullscreen .plyr__video-wrapper video {
  max-height: 100%;
}

/* == */

/* == [JS Plugin] Quill.js == */
.ql-bubble .ql-tooltip {
  z-index: 99999 !important;
}

.ql-editor {
  font-size: 16px !important;
  line-height: 24px !important;
  padding: 4px 0px !important;
}

.ql-editor.ql-blank::before {
  font-family: var(--body-font-family) !important;
  left: 0 !important;
  font-style: normal !important;
  font-size: 16px !important;
}

body.night-mode .ql-editor {
  color: #fff !important;
}

body.night-mode .ql-editor.ql-blank::before {
  color: #c0c0c0 !important;
}

.ql-mention-list-container {
  background: #fff;
  color: #333;
  z-index: 99999 !important;
  padding: 6px !important;
  border-radius: 12px !important;
  box-shadow:
    0 4px 24px rgba(0, 0, 0, 0.12),
    0 0 0 1px rgba(0, 0, 0, 0.06) !important;
  border: none !important;
  min-width: 240px;
  max-width: min(320px, calc(100vw - 24px)) !important;
  max-height: min(280px, 50vh) !important;
  overflow-x: hidden !important;
  -webkit-overflow-scrolling: touch !important;
}

body.night-mode .ql-mention-list-container {
  background: var(--header-bg-color-dark);
  color: #e8e8e8;
  box-shadow:
    0 8px 32px rgba(0, 0, 0, 0.45),
    0 0 0 1px rgba(255, 255, 255, 0.08);
}

.ql-mention-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.ql-mention-list-item {
  position: relative;
  margin: 0;
  padding: 0 !important;
  border-radius: 8px;
  cursor: pointer;
  display: flex;
  align-items: stretch;
  color: inherit;
  font-size: 13px;
  line-height: 1.25;
  transition: background-color 0.12s ease;
}

body.night-mode .ql-mention-list-item {
  color: #e5e5e5;
}

.ql-mention-list-item.selected {
  background: rgba(0, 0, 0, 0.06);
  text-decoration: none;
}

body.night-mode .ql-mention-list-item.selected {
  background: rgba(255, 255, 255, 0.08);
}

body.night-mode .ql-editor .mention {
  background-color: #090b0d;
}

.publisher-mention-item {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  min-width: 0;
  padding: 8px 10px;
  border-radius: 8px;
}

.publisher-mention-item__avatar {
  flex-shrink: 0;
}

.publisher-mention-item__img,
.ql-mention-list-item img {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  object-fit: cover;
  display: block;
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.06);
}

body.night-mode .publisher-mention-item__img,
body.night-mode .ql-mention-list-item img {
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.1);
}

.publisher-mention-item__body {
  min-width: 0;
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 2px;
}

.mention-item-label,
.publisher-mention-item__name {
  font-weight: 600;
  font-size: 0.9375rem;
  line-height: 1.2;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.tagify__dropdown--collaborative {
  border-top: 0;
  overflow: visible;
  width: auto !important;
  max-width: min(520px, calc(100vw - 24px));
  /* nb##: Collaborative 好友建议层去除 Tagify 默认外壳，避免夜间主题出现 #253044 包裹底色 */
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
}

.tagify__dropdown--collaborative .tagify__dropdown__wrapper {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: flex-start;
  width: auto;
  min-width: 0;
  padding: 8px;
  border: none;
  border-radius: 12px;
  box-shadow:
    0 4px 24px rgba(0, 0, 0, 0.12),
    0 0 0 1px rgba(0, 0, 0, 0.06);
  max-width: min(520px, calc(100vw - 24px));
  max-height: min(280px, 50vh);
}

.tagify__dropdown--collaborative .tagify__dropdown__item,
.tagify__dropdown--collaborative
  .tagify__dropdown__item.tagify__dropdown__item--active {
  display: inline-flex;
  align-items: center;
  width: auto;
  max-width: 100%;
  max-height: none;
  margin: 0;
  padding: 0;
  border-radius: 999px;
  color: inherit;
  white-space: nowrap;
  background: transparent;
  transition:
    background-color 0.12s ease,
    color 0.12s ease;
}

.tagify__dropdown--collaborative .tagify__dropdown__item:hover,
.tagify__dropdown--collaborative
  .tagify__dropdown__item.tagify__dropdown__item--active {
  background: rgba(0, 0, 0, 0.06);
}

.tagify__dropdown--collaborative .publisher-mention-item {
  width: auto;
  min-width: 0;
  padding: 7px 12px;
  gap: 8px;
  border-radius: 999px;
}

.tagify__dropdown--collaborative .publisher-mention-item__body {
  flex: 0 1 auto;
}

.tagify__dropdown--collaborative .publisher-mention-item__name {
  max-width: 180px;
}

body.night-mode .tagify__dropdown--collaborative .tagify__dropdown__wrapper {
  background: var(--header-bg-color-dark);
  color: #e8e8e8;
  box-shadow:
    0 8px 32px rgba(0, 0, 0, 0.45),
    0 0 0 1px rgba(255, 255, 255, 0.08);
}

body.night-mode .tagify__dropdown--collaborative .tagify__dropdown__item:hover,
body.night-mode
  .tagify__dropdown--collaborative
  .tagify__dropdown__item.tagify__dropdown__item--active {
  background: rgba(255, 255, 255, 0.08);
}

.publisher-hashtag-item {
  display: flex;
  align-items: center;
  width: 100%;
  min-width: 0;
  padding: 8px 10px;
  border-radius: 8px;
}

.publisher-hashtag-item__body {
  min-width: 0;
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

/* nb##: Publisher #Hashtags Autocomplete 改成单行图标格式；Topic/Hashtag 只靠统一尺寸图标和固定排序区分 BEGIN */
.publisher-hashtag-item__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  min-width: 0;
  height: 1.125rem;
}

.publisher-hashtag-item__label {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
  flex: 1;
}

.publisher-hashtag-item__icon {
  flex-shrink: 0;
  width: 14px;
  font-size: 0.875rem;
  line-height: 1;
  color: #6c757d;
  text-align: center;
}

.publisher-hashtag-item__name {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.publisher-hashtag-item__following {
  flex-shrink: 0;
  color: #6c757d;
  font-size: 0.75rem;
  font-weight: 600;
  line-height: 1.2;
  white-space: nowrap;
}

body.night-mode .publisher-hashtag-item__icon,
body.night-mode .publisher-hashtag-item__following {
  color: rgba(255, 255, 255, 0.68);
}
/* nb##: END */

/* == */

/* HEADER */
/* ------------------------------- */

/* main-wrapper */
.main-wrapper {
  width: 100%;
  min-width: 260px;
  /* to show scroll for small size browsers ;) */
}

/* -- */

/* top-bar */
.top-bar {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: 50px;
  font-size: 13px;
  line-height: 50px;
  background: #fff2cc;
  color: #333;
  z-index: 1001;
}

@media (min-width: 768px) {
  .top-bar .col-sm-5 {
    text-align: right;
  }
}

.top-bar.danger {
  background: #ce3426;
  color: #fff;
}

.top-bar.danger a {
  color: #fff200;
}

.top-bar.danger a:hover {
  text-decoration: underline;
}

/* -- */

/* bottom-bar */
.bottom-bar {
  position: fixed;
  bottom: 10px;
  left: 50%;
  transform: translate(-50%, 0);
  z-index: 1001;
}

.logged-as-container {
  /* nb##: 将登录提示改为警告/注意背景色，提升可读性与 WCAG 对比（中文注：需同步 minified） BEGIN */
  background: #ffc107; /* Bootstrap 警告色 */
  padding: 20px 40px;
  border-radius: 16px;
  color: #212529; /* 深色文字，保证对比 */
}

.logged-as-container a {
  color: #212529; /* 链接使用深色以保证对比 */
  font-weight: 600;
}
/* nb##: END */

/* -- */

/* main-header */
.main-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: 70px;
  background: var(--header-bg-color);
  z-index: 1001;
}

body.night-mode .main-header {
  background: var(--header-bg-color-dark);
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.2);
}

/* ** fix bootstrap modal padding-right for hiding scroll */
body.modal-open .main-header,
body.modal-open .top-bar {
  padding-right: 17px !important;
}

body.n_activated .main-header,
body.n_live .main-header {
  top: 50px;
  /* for top bar */
}

/* -- */

/* logo-wrapper */
.main-header .logo-wrapper {
  position: relative;
  padding-left: 48px;
  height: 70px;
  overflow: hidden;
  word-break: break-all;
}

@media (min-width: 768px) {
  .main-header .logo-wrapper {
    padding-left: 0;
  }
}

.main-header .logo {
  display: block;
  font-size: 32px;
  font-weight: 600;
  line-height: 60px;
  opacity: 1;
}

.main-header img.logo-light {
  display: inline-block;
}

body.night-mode .main-header img.logo-light {
  display: none;
}

.main-header img.logo-dark {
  display: none;
}

body.night-mode .main-header img.logo-dark {
  display: inline-block;
}

.main-header .logo:hover {
  opacity: 0.8;
  text-decoration: none;
}

.main-header .logo img {
  max-height: 60px;
}

.main-header .menu-icon {
  position: absolute;
  top: 10px;
  left: 0;
  display: block;
  text-align: center;
  color: #fff;
  height: 50px;
  padding: 15px 14px;
  line-height: 100%;
  border-radius: 4px;
}

.main-header .menu-icon:hover {
  background-color: rgba(255, 255, 255, 0.1);
}

/* -- */

/* search-wrapper */
.main-header .search-wrapper,
.search-wrapper.sg-mobile-search-sheet {
  position: relative;
}

.main-header .search-wrapper .search-row,
.search-wrapper.sg-mobile-search-sheet .search-row {
  display: flex;
  align-items: stretch;
  gap: 8px;
  margin-top: 13px;
  margin-bottom: 8px;
}

.main-header .search-wrapper .search-module-select,
.search-wrapper.sg-mobile-search-sheet .search-module-select {
  width: 132px;
  min-width: 132px;
  height: 44px;
  margin: 0;
  box-shadow: none;
  background: #f2f2f2;
  border: 0 none;
  border-radius: 8px;
  color: #666;
  font-size: 14px;
}

.main-header .search-wrapper .search-input-holder,
.search-wrapper.sg-mobile-search-sheet .search-input-holder {
  position: relative;
  flex: 1 1 auto;
}

.main-header .search-wrapper .search-module-mobile-picker,
.search-wrapper.sg-mobile-search-sheet .search-module-mobile-picker {
  display: none;
  position: relative;
  flex: 0 0 132px;
  min-width: 132px;
}

.main-header .search-wrapper .search-module-mobile-toggle,
.search-wrapper.sg-mobile-search-sheet .search-module-mobile-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  height: 44px;
  padding: 0 14px;
  border: 0 none;
  border-radius: 8px;
  background: #f2f2f2;
  color: #666;
  font-size: 14px;
  box-shadow: none;
}

.main-header .search-wrapper .search-module-mobile-toggle:focus,
.search-wrapper.sg-mobile-search-sheet .search-module-mobile-toggle:focus {
  box-shadow: none;
}

.main-header .search-wrapper .search-module-mobile-label,
.search-wrapper.sg-mobile-search-sheet .search-module-mobile-label {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.main-header .search-wrapper .search-module-mobile-menu,
.search-wrapper.sg-mobile-search-sheet .search-module-mobile-menu {
  min-width: 100%;
  padding: 6px 0;
  border-radius: 14px;
}

.main-header .search-wrapper .search-mobile-close,
.search-wrapper.sg-mobile-search-sheet .search-mobile-close {
  display: none;
  align-items: center;
  justify-content: center;
  flex: 0 0 44px;
  width: 44px;
  height: 44px;
  padding: 0;
  border: 0 none;
  border-radius: 8px;
  background: #f2f2f2;
  color: #666;
  pointer-events: auto !important;
}

.main-header .search-wrapper .search-input-holder .dropdown-search,
.search-wrapper.sg-mobile-search-sheet .search-input-holder .dropdown-search {
  top: 100%;
  left: 0;
  right: auto;
  width: 420px;
  max-width: 100%;
  min-width: 0 !important;
  margin-top: 4px;
}

.main-header .search-wrapper .search-input-holder #search-forums-panel,
.search-wrapper.sg-mobile-search-sheet
  .search-input-holder
  #search-forums-panel {
  width: 100%;
}

.main-header .search-input-icon,
.search-wrapper.sg-mobile-search-sheet .search-input-icon {
  position: absolute;
  top: 0;
  bottom: 0;
  right: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  pointer-events: none;
}

/* nb##: 页头搜索框内的搜索图标改为随输入框高度 flex 垂直居中，避免使用固定 top 偏移后出现上下不正 */
.main-header .search-input-icon .header-icon,
.search-wrapper.sg-mobile-search-sheet .search-input-icon .header-icon {
  display: block;
  flex-shrink: 0;
}

.main-header .search-wrapper .form-control,
.search-wrapper.sg-mobile-search-sheet .form-control {
  height: 44px;
  margin-top: 0;
  margin-bottom: 0;
  padding-right: 34px;
  font-size: 16px;
}

body.night-mode .main-header .search-wrapper .search-module-mobile-toggle,
body.night-mode
  .search-wrapper.sg-mobile-search-sheet
  .search-module-mobile-toggle {
  background: var(--body-bg-color-dark);
  color: var(--body-color-dark);
}

body.night-mode .main-header .search-wrapper .search-mobile-close,
body.night-mode .search-wrapper.sg-mobile-search-sheet .search-mobile-close {
  background: var(--body-bg-color-dark);
  color: var(--body-color-dark);
}

/* nb##: 手机/竖放平板底部 SEARCH 点击后，复用桌面 header search DOM 作为底部弹出搜索层 BEGIN */
@media (max-width: 767.98px) {
  body.sg-mobile-search-open {
    overflow: hidden;
  }

  body.sg-mobile-search-open .search-wrapper.sg-mobile-search-sheet {
    display: flex !important;
    position: fixed;
    inset: 0;
    z-index: 1105;
    align-items: flex-end;
    padding: 0 15px calc(82px + env(safe-area-inset-bottom, 0px));
    background: transparent;
    pointer-events: auto !important;
  }

  body.night-mode.sg-mobile-search-open .search-wrapper.sg-mobile-search-sheet {
    background: transparent;
  }

  body.sg-mobile-search-open .search-wrapper.sg-mobile-search-sheet form {
    width: 100%;
    pointer-events: auto !important;
  }

  body.sg-mobile-search-open
    .search-wrapper.sg-mobile-search-sheet
    .search-row {
    pointer-events: auto !important;
    align-items: center;
    margin: 0;
    padding: 12px;
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.98);
    box-shadow: 0 18px 42px rgba(15, 23, 42, 0.16);
  }

  body.night-mode.sg-mobile-search-open
    .search-wrapper.sg-mobile-search-sheet
    .search-row {
    border-color: rgba(255, 255, 255, 0.08);
    background: rgba(28, 30, 33, 0.98);
    box-shadow: 0 18px 42px rgba(0, 0, 0, 0.32);
  }

  body.sg-mobile-search-open
    .search-wrapper.sg-mobile-search-sheet
    .search-module-select {
    display: none;
  }

  body.sg-mobile-search-open
    .search-wrapper.sg-mobile-search-sheet
    .search-module-mobile-picker {
    display: block;
    width: 92px;
    min-width: 92px;
  }

  body.sg-mobile-search-open
    .search-wrapper.sg-mobile-search-sheet
    .search-module-mobile-toggle {
    padding: 0 10px;
  }

  body.sg-mobile-search-open
    .search-wrapper.sg-mobile-search-sheet
    .search-module-mobile-menu {
    inset: auto auto calc(100% + 10px) 0 !important;
    transform: none !important;
    width: max-content;
    min-width: 168px;
    max-width: min(220px, calc(100vw - 30px));
  }

  body.sg-mobile-search-open
    .search-wrapper.sg-mobile-search-sheet
    .search-mobile-close {
    display: inline-flex;
    border-radius: 12px;
  }

  body.sg-mobile-search-open
    .search-wrapper.sg-mobile-search-sheet
    .search-input-holder
    .dropdown-search {
    top: auto;
    bottom: calc(100% + 10px);
    width: 100%;
    max-width: 100%;
    max-height: calc(100vh - 210px - env(safe-area-inset-bottom, 0px));
    margin-top: 0;
    overflow-y: auto;
    border-radius: 16px;
  }

  body.sg-mobile-search-open
    .footer-bottom-bar-links
    > .link.sg-mobile-search-link
    > a
    > .title,
  body.night-mode.sg-mobile-search-open
    .footer-bottom-bar-links
    > .link.sg-mobile-search-link
    > a
    > .title {
    color: var(--link-color);
    font-weight: bold;
  }
}
/* nb##: END */

/* -- */

/* navbar-wrapper (Horizontale Navigation) */
.navbar-wrapper > ul {
  display: flex;
}

.navbar-wrapper > ul > li {
  flex: 1;
  text-align: center;
  margin: 0 2px;
}

.navbar-wrapper > ul > li.mini-search {
  flex: 4;
}

.navbar-wrapper > ul > li > a {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
  text-align: center;
  height: 50px;
  margin-top: 10px;
  padding: 0 10px;
  line-height: 1;
  border-radius: 8px;
}

/* nb##: navbar-wrapper 图标统一改走 flex 居中，避免 SVG 按文本基线下沉到底部 */
.navbar-wrapper > ul > li > a > .header-icon,
.navbar-wrapper > ul > li > a > .action-icon,
.navbar-wrapper > ul > li > a > .main-icon {
  display: block;
  flex-shrink: 0;
}

.navbar-wrapper > ul > li > a:hover {
  background-color: rgb(160 160 160 / 10%);
}

body.night-mode .navbar-wrapper > ul > li > a:hover {
  background-color: rgb(234 234 234 / 10%);
}

.navbar-wrapper > ul > li.dropdown.show > a {
  background-color: rgba(255, 255, 255, 0.1);
}

body.night-mode .navbar-wrapper > ul > li.dropdown.show > a {
  background-color: #494c62;
}

.navbar-wrapper .counter {
  position: absolute;
  top: 5px;
  right: 0;
  padding: 2px 4px;
  color: #fff;
  font-size: 10px;
  line-height: 14px;
  font-weight: 600;
  border-radius: 3px;
}

.navbar-wrapper .counter.red {
  background: #ff5e3a;
}

.navbar-wrapper .counter.blue {
  background: #38a9ff;
}

.navbar-wrapper .counter.purple {
  background: #7c5ac2;
}

/* -- user-menu */
.user-menu > img {
  display: block;
  margin-top: 0;
  height: 20px;
  width: 20px;
  border-radius: 50%;
}

@media (min-width: 768px) {
  .user-menu > img {
    height: 25px;
    width: 25px;
  }
}

.main-header .user-menu .title {
  display: none;
}

.footer-bottom-bar .user-menu.dropdown-toggle::after {
  content: none;
}

/* -- dropdown-menu */
.navbar-wrapper > ul > li.dropdown {
  position: static;
}

@media (min-width: 768px) {
  .navbar-wrapper > ul > li.dropdown {
    position: relative;
  }
}

/* -- dropdown-widget */
.dropdown-widget {
  width: 100%;
  padding-bottom: 0;
  padding-top: 0;
}

.dropdown-widget-header {
  padding: 12px;
  font-size: 11px;
  border-bottom: 1px solid #f4f4f4;
}

body.night-mode .dropdown-widget-header {
  border-color: var(--card-dark-divider);
}

.dropdown-widget-header .title {
  font-size: 16px;
  line-height: 22px;
  font-weight: 500;
}

.dropdown-widget-header a:hover {
  text-decoration: underline;
}

.dropdown-widget-body {
  padding: 0;
  font-size: 12px;
}

.dropdown-widget-body .title {
  border-top: 1px solid #e4e4e4;
  border-bottom: 1px solid #e4e4e4;
  color: #9a9fbf;
  padding: 8px;
  display: block;
  font-size: 11px;
  font-weight: 600;
  line-height: 16px;
}

body.night-mode .dropdown-widget-body .title {
  border-color: var(--card-dark-divider);
}

.dropdown-widget-footer {
  display: block;
  padding: 10px 0;
  border-top: 1px solid #f4f4f4;
  border-bottom: 0 none;
  text-align: center;
  font-size: 13px;
}

body.night-mode .dropdown-widget-footer {
  border-color: var(--card-dark-divider);
}

.dropdown-widget-footer:hover {
  text-decoration: underline;
}

@media (min-width: 768px) {
  .dropdown-widget {
    min-width: 380px !important;
  }

  .dropdown-widget.dropdown-search {
    border-radius: 0.375rem;
  }
}

/* -- */

/* COMMON */
/* ------------------------------- */

/* no-data */
.no-data {
  padding: 8px 20px;
  background: #f7f7f7;
  border-radius: 10px;
  font-weight: 500;
}

body.night-mode .no-data {
  background: var(--card-dark-input);
}

/* payments plans */
.payment-plans {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.payment-plan {
  flex-basis: 100%;
  background: #f9f9f9;
  padding: 15px 30px;
  border-radius: 16px;
}

@media (min-width: 1400px) {
  .payment-plan {
    flex-basis: 49%;
  }

  .payment-plan.full {
    flex-basis: 100%;
  }
}

body.night-mode .payment-plan {
  background: var(--card-dark-input);
}

.payment-plan.new {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--link-color);
  cursor: pointer;
  min-height: 150px;
}

.payment-plan.new.address {
  min-height: 220px;
}

/* -- */

/* shipping-address */
.shipping-address {
  padding: 20px;
  margin-bottom: 10px;
  border: 1px solid #f4f4f4;
  border-radius: 16px;
}

body.night-mode .shipping-address {
  border-color: var(--card-dark-divider);
}

/* -- */

/* section-title */
.section-title {
  background: #f5f5f5;
  padding: 14px;
  font-weight: 600;
  text-align: center;
  border-radius: 8px;
}

body.night-mode .section-title {
  background-color: var(--card-dark-hover);
}

/* -- */

/* heading */
.heading-small {
  font-size: 12px;
  padding: 4px 0;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

/* -- */

/* user-box */
.user-box {
  display: block;
  margin: 5px;
  text-align: center;
  text-decoration: none;
}

.circled-user-box {
  margin: 5px;
}

.circled-user-box .user-box {
  position: relative;
  padding-top: 100%;
  margin: 0;
  margin-bottom: 20px;
}

.pro-box-wrapper .user-box {
  width: 71px;
  float: left;
  opacity: 0.55;
}

.pro-box-wrapper.full-opacity .user-box {
  opacity: 1;
}

.pro-box-wrapper .user-box.slick-center {
  opacity: 1;
  transform: scale(1.1);
  font-weight: 600;
}

.user-box img {
  width: 100%;
  height: 100%;
  margin: 0 auto;
  border-radius: 50%;
}

.circled-user-box .user-box img {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  object-fit: cover;
}

.pro-box-wrapper .user-box img {
  width: 60px;
  height: 60px;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
}

.user-box .name {
  margin-top: 5px;
  font-size: 11px;
  word-break: break-word;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.circled-user-box .user-box .name {
  position: absolute;
  left: 0;
  right: 0;
}

/* -- */

/* ui-box */
.ui-box {
  position: relative;
  background: #fff;
  padding: 50px 15px 15px;
  margin-top: 50px;
  margin-bottom: 20px;
  text-align: center;
  border-radius: 16px;
}

.ui-box.darker {
  background: #f4f4f4;
}

body.night-mode .ui-box {
  background: var(--card-dark-input);
}

.ui-box .img {
  position: absolute;
  top: -50px;
  left: 50%;
  transform: translate(-50%);
  background: #fff;
  padding: 4px;
  margin: 0 auto;
  border-radius: 50%;
}

body.night-mode .ui-box .img {
  background: var(--card-dark-color);
}

.ui-box img {
  height: 92px;
  width: 92px;
  border-radius: 50%;
  object-fit: cover;
}

.ui-box .btn {
  box-shadow: none;
}

.sg-group-member-grid {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 16px;
  grid-template-columns: minmax(0, 1fr);
}

.sg-group-member-grid__item {
  display: flex;
  min-width: 0;
}

@media (min-width: 576px) {
  .sg-group-member-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 992px) {
  .sg-group-member-grid--members {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .sg-group-member-grid--settings {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.sg-group-member-card {
  width: 100%;
}

.sg-group-member-name {
  width: 100%;
}

.sg-group-member-name .h6 {
  margin-bottom: 0;
}

.sg-group-member-status-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  flex-wrap: wrap;
  min-height: 20px;
  margin-top: 8px;
}

.sg-group-member-status-row .sg-country-flag--inline {
  margin-inline-start: 0;
  transform: none;
}

.sg-group-member-actions {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}

.sg-group-member-actions .btn {
  margin: 0;
}

/* -- */

/* stat-panel */
.stat-panel {
  border-radius: 16px;
  margin-bottom: 20px;
  overflow: hidden;
}

.stat-panel.border {
  border: 1px solid #e6ecf5;
}

body.night-mode .stat-panel.border {
  border-color: var(--card-dark-divider) !important;
}

.stat-cell {
  position: relative;
  padding: 40px;
}

.stat-cell.narrow {
  padding: 25px;
}

.stat-cell .icon {
  position: absolute;
  top: 20px;
  right: 20px;
  background: #fff;
  font-size: 20px;
  width: 48px;
  height: 48px;
  padding: 14px;
  border-radius: 50%;
}

.stat-cell .bg-icon {
  position: absolute;
  bottom: -5px;
  right: -5px;
  font-size: 100px;
  opacity: 0.25;
}

.stat-cell a {
  font-size: 12px;
  color: #fff;
}

.stat-cell a:hover {
  text-decoration: underline;
}

/* -- */

/* nb##: 横向/纵向导航共用基础视觉 token，骨架交给 Bootstrap，sg 只保留主题薄皮层 */
.sg-nav-sidebar,
.sg-nav-sidebar-card,
.sg-nav-header {
  --sg-nav-tone-text: var(--sg-theme-text-sub);
  --sg-nav-tone-text-muted: var(--sg-theme-text-muted);
  --sg-nav-tone-accent: var(--sg-theme-accent);
  --sg-nav-tone-accent-bg: var(--sg-theme-accent-dim);
  --sg-nav-tone-border: var(--sg-theme-border-mid);
  --sg-nav-surface-bg: var(--sg-theme-surface-2);
  --sg-nav-section-padding: 0.35rem 0.625rem 0.15rem;
  --sg-nav-section-title-size: 0.78rem;
  --sg-nav-section-title-weight: 700;
  --sg-nav-section-title-letter-spacing: 0.04em;
  --sg-nav-section-title-line-height: 1.2;
}

/* nb##: 垂直导航统一为 sg-nav-sidebar / sg-nav-sidebar-card 通用类；核心间距与状态变量化后供卡片侧栏和 BLOG 下拉树共用 */
.sg-nav-sidebar,
.sg-nav-sidebar ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

.sg-nav-sidebar {
  --sg-nav-sidebar-gap: 0.25rem;
  --sg-nav-sidebar-subtree-gap: 0.15rem;
  --sg-nav-sidebar-subtree-padding-start: 1.375rem;
  --sg-nav-sidebar-link-gap: 0.9375rem;
  --sg-nav-sidebar-label-gap: var(--sg-nav-sidebar-link-gap);
  --sg-nav-sidebar-link-padding: 0.625rem 0.875rem;
  --sg-nav-sidebar-link-radius: 0.5rem;
  --sg-nav-sidebar-link-hover-bg: transparent;
  --sg-nav-sidebar-link-hover-color: var(--sg-nav-tone-accent);
  --sg-nav-sidebar-link-active-bg: var(--sg-nav-tone-accent-bg);
  --sg-nav-sidebar-link-active-color: var(--sg-nav-tone-accent);
  --sg-nav-sidebar-link-active-radius: 0;
  --sg-nav-sidebar-sub-link-padding: 0.55rem 0.875rem;
  --sg-nav-sidebar-collapse-color: var(--sg-nav-tone-text-muted);
  --sg-nav-sidebar-subtree-guide-color: transparent;
  --bs-list-group-bg: transparent;
  --bs-list-group-color: var(--sg-theme-text-sub);
  --bs-list-group-border-color: var(--sg-nav-tone-border);
  --bs-list-group-border-width: 1px;
  --bs-list-group-border-radius: 0;
  z-index: 2;
  display: flex;
  flex-direction: column;
  gap: var(--sg-nav-sidebar-gap);
}

.sg-nav-sidebar.list-group {
  padding-block: 0.5rem;
}

.sg-nav-sidebar.list-group > li {
  background: transparent;
  border: 0;
}

.sg-nav-sidebar ul {
  display: flex;
  flex-direction: column;
  gap: var(--sg-nav-sidebar-subtree-gap);
  padding-top: 0.15rem;
  padding-inline-start: var(--sg-nav-sidebar-subtree-padding-start);
}

.sg-nav-sidebar img {
  width: 24px;
  height: 24px;
  flex: 0 0 auto;
}

.sg-nav-sidebar a,
.sg-nav-sidebar .static {
  display: flex;
  align-items: center;
  gap: var(--sg-nav-sidebar-link-gap);
  min-width: 0;
  padding: var(--sg-nav-sidebar-link-padding);
  border-radius: var(--sg-nav-sidebar-link-radius);
  color: var(--sg-theme-text-sub);
  font-size: 0.95rem;
  font-weight: 500;
  line-height: 1.35;
  text-decoration: none;
  transition:
    background-color 0.15s ease,
    color 0.15s ease,
    box-shadow 0.15s ease;
}

.sg-nav-sidebar .main-icon,
.sg-nav-sidebar .main-icon * {
  color: currentColor !important;
  fill: currentColor !important;
}

/* nb##: 统一 FA 图标与原 SVG 等宽 24px BEGIN */
.sg-nav-sidebar i.main-icon {
  font-size: 1.5rem;
  line-height: 1;
  width: 24px;
  text-align: center;
  flex: 0 0 24px;
}
/* nb##: END */

.sg-nav-sidebar .main-icon,
.sg-nav-sidebar img {
  margin: 0 !important;
  flex: 0 0 auto;
}

.sg-nav-sidebar .sg-nav-sidebar__label {
  display: flex;
  align-items: center;
  gap: var(--sg-nav-sidebar-label-gap);
  min-width: 0;
  flex: 1 1 auto;
}

.sg-nav-sidebar .sg-nav-sidebar__text {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.sg-nav-sidebar .sg-nav-sidebar__meta,
.sg-nav-sidebar a > small {
  display: flex;
  justify-content: flex-end;
  margin-inline-start: auto;
  float: none;
  flex: 0 0 auto;
  text-align: end;
  white-space: nowrap;
}

.sg-nav-sidebar .sg-nav-sidebar__section {
  padding: var(--sg-nav-section-padding);
}

/* nb##: section 节点补上 list-group-item 语义后，继续压回当前轻量分组视觉 */
.sg-nav-sidebar.list-group > .list-group-item.sg-nav-sidebar__section {
  background: transparent;
  border: 0;
  border-radius: 0;
}

/* nb##: divider section 自带内部横线，避免再叠加 list-group 顶部边框形成双分割线 */
.sg-nav-sidebar.list-group > .sg-nav-sidebar__section:not(:first-child),
.sg-nav-sidebar.list-group > .list-group-item.sg-nav-sidebar__section:not(:first-child) {
  margin-top: 0.15rem;
  padding-top: 0.65rem;
}

.sg-nav-sidebar.list-group > .sg-nav-sidebar__section:not(:first-child):not(.sg-nav-sidebar__section--divider),
.sg-nav-sidebar.list-group > .list-group-item.sg-nav-sidebar__section:not(:first-child):not(.sg-nav-sidebar__section--divider) {
  border-top: var(--bs-list-group-border-width) solid var(--bs-list-group-border-color);
}

.sg-nav-sidebar .sg-nav-sidebar__section-title {
  display: block;
  color: var(--sg-nav-tone-text-muted) !important;
  font-size: var(--sg-nav-section-title-size);
  font-weight: var(--sg-nav-section-title-weight);
  letter-spacing: var(--sg-nav-section-title-letter-spacing);
  line-height: var(--sg-nav-section-title-line-height);
  text-transform: uppercase;
}

.sg-nav-sidebar a[data-bs-toggle="collapse"]:after {
  font-family: "Font Awesome 7 Pro";
  font-weight: 400;
  font-style: normal;
  font-variant: normal;
  display: inline-block;
  margin-inline-start: auto;
  float: none;
  content: "\f078";
  transition: all 0.15s ease;
  color: var(--sg-nav-sidebar-collapse-color);
  text-rendering: auto;
  -webkit-font-smoothing: antialiased;
}

.sg-nav-sidebar a[data-bs-toggle="collapse"][aria-expanded="true"]:after {
  transform: rotate(180deg);
}

.sg-nav-sidebar a:hover {
  background: var(--sg-nav-sidebar-link-hover-bg);
  color: var(--sg-nav-sidebar-link-hover-color);
}

.sg-nav-sidebar > li.active > a,
.sg-nav-sidebar ul > li.active > a,
.sg-nav-sidebar > li.is-active-root > a,
.sg-nav-sidebar ul > li.is-active-root > a {
  background: var(--sg-nav-sidebar-link-active-bg);
  border-radius: var(--sg-nav-sidebar-link-active-radius);
  color: var(--sg-nav-sidebar-link-active-color);
  box-shadow: none;
}

.sg-nav-sidebar > li.active > a[data-bs-toggle="collapse"]:after,
.sg-nav-sidebar ul > li.active > a[data-bs-toggle="collapse"]:after,
.sg-nav-sidebar > li.is-active-root > a[data-bs-toggle="collapse"]:after,
.sg-nav-sidebar ul > li.is-active-root > a[data-bs-toggle="collapse"]:after {
  color: currentColor;
}

.sg-nav-sidebar ul a {
  position: relative;
  margin-inline-start: 0;
  padding: var(--sg-nav-sidebar-sub-link-padding);
  font-size: 0.9rem;
  border-inline-start: 0;
}

.sg-nav-sidebar ul a::before {
  content: "";
  position: absolute;
  inset-block: 0.3rem;
  inset-inline-start: 0.2rem;
  width: 1px;
  background: var(--sg-nav-sidebar-subtree-guide-color);
  pointer-events: none;
}

/* sg-nav-sidebar-card */
.sg-nav-sidebar-card {
  --bs-card-border-color: var(--sg-theme-border);
  --bs-list-group-border-color: var(--sg-theme-border-mid);
  --bs-list-group-bg: transparent;
  background: linear-gradient(
    180deg,
    var(--sg-theme-surface) 0%,
    var(--sg-nav-surface-bg) 100%
  );
  box-shadow: var(--sg-theme-shadow-md);
  border: 1px solid var(--sg-theme-border) !important;
}

.sg-nav-sidebar-card,
.sg-nav-sidebar-card .card-body,
.sg-nav-sidebar-card hr {
  border-color: var(--sg-theme-border-mid) !important;
}

.sg-nav-sidebar-card .card-body {
  padding: 0.625rem 0.625rem 0.875rem;
}

.sg-nav-sidebar-card .card-body.with-nav {
  padding: 0 !important;
}

.sg-nav-sidebar-card .sg-nav-sidebar {
  --sg-nav-sidebar-link-hover-bg: var(--sg-nav-tone-accent-bg);
  --sg-nav-sidebar-collapse-color: var(--sg-nav-tone-accent);
  --sg-nav-sidebar-sub-link-padding: 0.55rem 0.875rem 0.55rem 1.125rem;
  --sg-nav-sidebar-subtree-guide-color: var(--sg-nav-tone-border);
}

.sg-nav-sidebar-card .card-body.with-nav .sg-nav-sidebar.list-group {
  padding-block: 0.5rem;
}

.sg-nav-sidebar-card .sg-nav-sidebar .main-icon,
.sg-nav-sidebar-card .sg-nav-sidebar .main-icon *,
.sg-nav-sidebar-card .sg-nav-sidebar i[class*="fa-"] {
  color: currentColor !important;
  fill: currentColor !important;
}

.sg-nav-sidebar-card .card-body > .small {
  color: var(--sg-nav-tone-text-muted) !important;
  font-size: var(--sg-nav-section-title-size);
  font-weight: var(--sg-nav-section-title-weight);
  letter-spacing: var(--sg-nav-section-title-letter-spacing);
  display: block;
  margin-bottom: 0.625rem;
  text-transform: uppercase;
}

/* nb##: PUBLIC Forum 与 Space FORUM/BLOG/SUPPORT 左栏统一收口到同一套目录侧栏类，不再依赖 forum/blog 专属容器名 */
.sg-nav-sidebar .sg-nav-sidebar__section--divider {
  padding: 0.35rem 0.625rem 0.15rem;
}

.sg-nav-sidebar .sg-nav-sidebar__section-divider {
  position: static;
  display: flex;
  align-items: center;
  gap: 0.6rem;
}

.sg-nav-sidebar .sg-nav-sidebar__section-divider::before,
.sg-nav-sidebar .sg-nav-sidebar__section-divider::after {
  content: "";
  display: block;
  flex: 1 1 auto;
  height: 1px;
  background: var(--sg-nav-tone-border);
}

.sg-nav-sidebar .sg-nav-sidebar__section-title--divider {
  display: block;
  flex: 0 0 auto;
  margin: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: none !important;
  box-shadow: none;
  color: var(--sg-theme-text-muted) !important;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 1.2;
  text-transform: uppercase;
}

.sg-directory-layout .sg-directory-sidebar .sg-nav-sidebar-card {
  margin-bottom: 0;
}

/* nb##: 首页 Post Category 提示卡跟随 sg-theme 变量，避免 light 背景在 night-mode 下发灰且可读性漂移 */
.post-category-hero {
  background: linear-gradient(
    135deg,
    rgba(var(--sg-theme-accent-rgb), 0.1) 0%,
    var(--sg-theme-surface) 48%,
    var(--sg-theme-surface-2) 100%
  );
  border: 1px solid var(--sg-theme-border) !important;
  box-shadow: var(--sg-theme-shadow-sm);
}

.post-category-hero .card-body {
  padding: 1rem 1.125rem;
}

.post-category-hero__badge {
  background: rgba(var(--sg-theme-accent-rgb), 0.14);
  color: var(--sg-theme-accent);
  border: 1px solid rgba(var(--sg-theme-accent-rgb), 0.2);
  padding: 0.45rem 0.8rem;
}

.post-category-hero__badge:hover,
.post-category-hero__badge:focus {
  color: var(--sg-theme-accent);
  background: rgba(var(--sg-theme-accent-rgb), 0.2);
}

.post-category-hero__title {
  color: var(--sg-theme-text);
}

.post-category-hero__title:hover,
.post-category-hero__title:focus {
  color: var(--sg-theme-accent);
}

.post-category-hero__description {
  margin-top: 0.35rem;
  color: var(--sg-theme-text-muted) !important;
}

.post-category-inline-link {
  color: inherit;
  text-decoration-color: rgba(var(--sg-theme-accent-rgb), 0.35);
}

.post-category-inline-link:hover,
.post-category-inline-link:focus {
  color: var(--sg-theme-accent);
  text-decoration-color: currentColor;
}

body.night-mode .post-category-hero {
  background: linear-gradient(
    145deg,
    rgba(var(--sg-theme-accent-rgb), 0.18) 0%,
    var(--sg-theme-surface) 44%,
    var(--sg-theme-surface-2) 100%
  );
  box-shadow: var(--sg-theme-shadow-md);
}

body.night-mode .post-category-hero__badge {
  background: rgba(var(--sg-theme-accent-rgb), 0.18);
  border-color: rgba(var(--sg-theme-accent-rgb), 0.3);
}

/* sg-nav-header */
.sg-nav-header-wrap {
  position: sticky;
  top: 70px;
  z-index: 1000;
  width: 100%;
  background: var(--sg-theme-glass);
  border-top: 1px solid var(--sg-theme-border);
  border-bottom: 1px solid var(--sg-theme-border);
  backdrop-filter: saturate(180%) blur(12px);
  -webkit-backdrop-filter: saturate(180%) blur(12px);
}

body.n_activated .sg-nav-header-wrap,
body.n_live .sg-nav-header-wrap {
  top: 120px;
}

.sg-nav-header {
  --sg-nav-header-link-color: var(--sg-nav-tone-text-muted);
  --sg-nav-header-link-hover-bg: transparent;
  --sg-nav-header-link-hover-color: var(--sg-nav-tone-accent);
  --sg-nav-header-link-hover-border: var(--sg-nav-tone-accent);
  --sg-nav-header-link-active-bg: transparent;
  --sg-nav-header-link-active-color: var(--sg-nav-tone-accent);
  --sg-nav-header-link-active-border: var(--sg-nav-tone-accent);
  --sg-nav-header-menu-bg: var(--sg-nav-surface-bg);
  --sg-nav-header-menu-border: var(--sg-nav-tone-border);
  --sg-nav-header-item-divider: var(--sg-nav-tone-border);
  padding: 0;
  background: transparent;
  border-bottom: 0 !important;
}

.sg-nav-header__scroller {
  width: 100%;
  max-width: 1320px;
  margin: 0 auto;
  overflow: visible;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  white-space: nowrap;
}

.sg-nav-header__scroller::-webkit-scrollbar {
  display: none;
}

.sg-nav-header__list {
  list-style: none;
  width: max-content;
  min-width: 100%;
  min-height: 44px;
  margin: 0;
  padding: 0;
}

.sg-nav-header__item {
  position: relative;
  display: flex;
  align-items: stretch;
  flex: 0 0 auto;
}

.sg-nav-header__item + .sg-nav-header__item {
  margin-inline-start: 0.1rem;
  padding-inline-start: 0.1rem;
}

.sg-nav-header__item + .sg-nav-header__item::before {
  content: "";
  display: block;
  align-self: center;
  width: 1px;
  height: 0.95rem;
  background: var(--sg-nav-header-item-divider);
  opacity: 0.9;
}

.sg-nav-header__link,
.sg-nav-header__link.dropdown-toggle {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  border: 0;
  background: transparent;
  border-bottom: 2px solid transparent;
  border-radius: 0;
  color: var(--sg-nav-header-link-color);
  font-family:
    "IBM Plex Sans", "Work Sans", "Segoe UI", Helvetica, Arial,
    "Microsoft YaHei", sans-serif;
  font-size: 0.93rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  line-height: 1;
  min-height: 44px;
  padding: 0 0.9rem;
  text-transform: uppercase;
  white-space: nowrap;
  transition:
    color 0.18s ease,
    border-color 0.18s ease,
    background-color 0.18s ease;
  box-shadow: none;
  text-decoration: none;
}

.sg-nav-header__home-link {
  justify-content: center;
  gap: 0.4rem;
  min-width: 2.8rem;
  padding-inline: 1.1rem;
  color: var(--sg-theme-accent);
  font-weight: 600;
  letter-spacing: 0.06em;
}

.sg-nav-header__home-link .fa-home {
  font-size: 0.93rem;
}

.sg-nav-header__link.dropdown-toggle::after {
  margin-inline-start: 0.35rem;
  vertical-align: 0.08em;
}

.sg-nav-header__link:hover,
.sg-nav-header__link:focus {
  color: var(--sg-nav-header-link-hover-color);
  background: var(--sg-nav-header-link-hover-bg);
  border-bottom-color: var(--sg-nav-header-link-hover-border);
  text-decoration: none;
  box-shadow: none;
}

.sg-nav-header__link.active,
.sg-nav-header__link.active:hover,
.sg-nav-header__link.active:focus,
.sg-nav-header__link.is-active-root,
.sg-nav-header__link.is-active-root:hover,
.sg-nav-header__link.is-active-root:focus {
  color: var(--sg-nav-header-link-active-color);
  background: var(--sg-nav-header-link-active-bg);
  border-bottom-color: var(--sg-nav-header-link-active-border);
  box-shadow: none;
}

.sg-nav-header__menu {
  margin-top: 0 !important;
  padding: 0.5rem 0;
  border: 1px solid var(--sg-nav-header-menu-border);
  border-radius: 8px;
  background: var(--sg-nav-header-menu-bg);
  box-shadow: var(--sg-theme-shadow-md);
  min-width: 200px;
}

/* nb##: BLOG 顶部 dropdown tree 只覆写变量与导引线，hover/active 统一复用 sg-nav-sidebar 基类 */
.sg-nav-header__tree.sg-nav-sidebar {
  min-width: 200px;
  font-family:
    "IBM Plex Sans", "Work Sans", "Segoe UI", Helvetica, Arial,
    "Microsoft YaHei", sans-serif;
  --sg-nav-sidebar-gap: 0.15rem;
  --sg-nav-sidebar-subtree-padding-start: 0.65rem;
  --sg-nav-sidebar-link-gap: 0.65rem;
  --sg-nav-sidebar-label-gap: 0.65rem;
  --sg-nav-sidebar-link-padding: 0.45rem 1.1rem;
  --sg-nav-sidebar-link-radius: 0;
  --sg-nav-sidebar-link-hover-bg: var(--sg-nav-tone-accent-bg);
  --sg-nav-sidebar-link-active-radius: 0;
  --sg-nav-sidebar-sub-link-padding: 0.45rem 1.1rem 0.45rem 1.125rem;
  --sg-nav-sidebar-subtree-guide-color: var(--sg-nav-tone-border);
}

.sg-nav-header--blog-public {
  display: none;
}

@media (min-width: 992px) {
  .sg-nav-header--blog-public {
    display: block;
  }

  .sg-offcanvas--blog-public .blog-public-sidebar {
    display: none !important;
  }
}

@media (max-width: 991.98px) {
  .sg-offcanvas--directory {
    position: relative;
    overflow: hidden;
  }

  .sg-offcanvas--directory .sg-directory-sidebar {
    position: absolute !important;
    top: 0;
    left: 0;
    right: auto;
    width: 100%;
    z-index: 100;
    display: block !important;
    transform: translateX(-100%);
    transition: transform 0.25s ease-out;
  }

  .sg-offcanvas--directory.active .sg-directory-sidebar {
    transform: translateX(0);
  }

  .sg-offcanvas--directory .sg-directory-mainbar,
  .sg-offcanvas--directory.active .sg-directory-mainbar {
    position: relative;
    left: 0;
    right: auto;
    transform: translateX(0);
    transition: transform 0.25s ease-out;
  }

  .sg-offcanvas--directory.active .sg-directory-mainbar {
    transform: translateX(100%);
  }

  html[dir="rtl"] .sg-offcanvas--directory .sg-directory-sidebar {
    left: auto;
    right: 0;
    transform: translateX(100%);
  }

  html[dir="rtl"] .sg-offcanvas--directory.active .sg-directory-sidebar {
    transform: translateX(0);
  }

  html[dir="rtl"] .sg-offcanvas--directory .sg-directory-mainbar,
  html[dir="rtl"] .sg-offcanvas--directory.active .sg-directory-mainbar {
    left: auto;
    right: 0;
    transform: translateX(0);
  }

  html[dir="rtl"] .sg-offcanvas--directory.active .sg-directory-mainbar {
    transform: translateX(-100%);
  }

  .sg-nav-header {
    padding: 0;
  }

  .sg-nav-header__scroller {
    max-width: 100%;
    overflow-x: auto;
    overflow-y: visible;
  }

  .sg-nav-header__list {
    min-height: 42px;
  }

  .sg-nav-header__menu {
    position: static !important;
    inset: auto !important;
    transform: none !important;
    float: none !important;
    min-width: min(16rem, calc(100vw - 2rem));
    margin-top: 0.35rem !important;
  }

  .sg-nav-header--blog-public {
    display: none !important;
  }
}

@media (max-width: 767.98px) {
  .sg-directory-hero-main {
    flex-direction: column;
  }

  .sg-directory-hero-actions {
    justify-content: flex-start;
    width: 100%;
  }

  .sg-directory-hero-stat-card {
    min-width: 96px;
    flex: 1 1 0;
  }

  .sg-nav-header__link,
  .sg-nav-header__link.dropdown-toggle {
    font-size: 0.93rem;
    letter-spacing: 0.04em;
    padding: 0 0.78rem;
  }

  .sg-nav-header__home-link {
    padding-inline: 0.95rem;
  }
}

body.night-mode
  .sg-nav-sidebar
  .sg-nav-sidebar__section-divider::before,
body.night-mode
  .sg-nav-sidebar
  .sg-nav-sidebar__section-divider::after {
  background: rgba(var(--bs-white-rgb), 0.12);
}

body.night-mode
  .sg-nav-sidebar
  .sg-nav-sidebar__section-title--divider {
  background: none !important;
  box-shadow: none;
  color: var(--sg-theme-text-muted) !important;
}

body.night-mode .sg-nav-header-wrap {
  background: var(--sg-theme-glass);
  border-color: var(--sg-theme-border);
}

body.night-mode .sg-nav-header__menu {
  background: var(--sg-theme-surface-2);
  border-color: var(--sg-theme-border-mid);
  box-shadow: var(--sg-theme-shadow-md);
}

/* -- */

/* -- */

/* see-more */
.see-more {
  text-align: center;
  margin-top: 10px;
  margin-bottom: 20px;
  padding: 10px;
}

@media (max-width: 768px) {
  .see-more {
    margin-bottom: 90px;
  }
}

.see-more:hover {
  text-decoration: underline;
  cursor: pointer;
}

.see-more.loading:hover {
  text-decoration: none;
  cursor: default;
}

.see-more.done:hover {
  text-decoration: underline;
  cursor: text;
}

/* --*/

/* feeds-item */
.feeds-item {
  border-bottom: 1px solid #f4f4f4;
}

body.night-mode .feeds-item {
  border-color: var(--card-dark-divider);
}

.feeds-item.with-hover:hover {
  cursor: pointer;
}

.feeds-item:last-child {
  border-bottom: 0 none;
}

.feeds-item.unread {
  background: #e9eaed;
}

body.night-mode .feeds-item.unread {
  background: var(--card-dark-input);
}

/* -- */

/* feeds-action-item */

.feeds-action-item.unread,
.feeds-action-item:hover {
  cursor: pointer;
  background: #f4f4f4;
  border-radius: 16px;
}

body.night-mode .feeds-action-item.unread,
body.night-mode .feeds-action-item:hover {
  background: var(--card-dark-input);
}

/* -- */

/* data-container */
.data-container {
  display: block;
  width: 100%;
  padding: 8px;
  min-height: 56px;
  /* 40px avatar + 16px padding */
}

.data-container.small {
  min-height: 46px;
  /* 30px avatar + 16px padding */
}

a.data-container:hover,
.data-container.clickable:hover {
  background: #f6f7f8;
  text-decoration: none;
  cursor: pointer;
}

body.night-mode a.data-container:hover,
body.night-mode .data-container.clickable:hover {
  background: var(--card-dark-divider);
}

.data-avatar {
  display: block;
  position: relative;
  /* relative for .data-reaction to be absolute */
  float: left;
}

.data-avatar img {
  width: 30px;
  height: 30px;
  text-align: center;
  border-radius: 50%;
}

/* nb##: GROUP-REQUESTS-BATCH 申请列表 checkbox 与头像同轴居中，避免普通块元素把头像挤到下一行 */
.sg-group-requests-batch-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem 1rem;
}

.sg-group-requests-batch-toolbar__selector {
  flex: 0 0 30px;
  width: 30px;
  height: 30px;
  margin-right: 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.sg-group-requests-batch-toolbar__selector .form-check-input {
  margin: 0;
}

.sg-group-requests-batch-toolbar__actions {
  margin-left: auto;
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 0.5rem;
}

.js_group-request-row .sg-group-request-checkbox-cell {
  float: left;
  width: 30px;
  height: 30px;
  margin-right: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.js_group-request-row .data-content {
  padding-left: 78px;
}

@media (min-width: 768px) {
  .data-avatar img {
    width: 40px;
    height: 40px;
    border-radius: 50%;
  }

  .sg-group-requests-batch-toolbar__selector {
    flex-basis: 40px;
    width: 40px;
    height: 40px;
  }

  .js_group-request-row .sg-group-request-checkbox-cell {
    width: 40px;
    height: 40px;
  }

  .js_group-request-row .data-content {
    padding-left: 98px;
  }

  .data-container.small .data-avatar img {
    width: 30px;
    /* override the previous */
    height: 30px;
  }

  .js_group-request-row .data-container.small .sg-group-request-checkbox-cell {
    width: 30px;
    height: 30px;
  }

  .js_group-request-row .data-container.small .data-content {
    padding-left: 78px;
  }
}

.data-avatar .left-avatar,
.data-avatar .right-avatar {
  background-size: cover;
  background-position: center center;
  float: left;
  overflow: hidden;
  width: 14px;
  height: 30px;
  margin-right: 1px;
  border-radius: 20px 0 0 20px;
}

.data-avatar .right-avatar {
  width: 15px;
  margin-right: 0;
  border-radius: 0 20px 20px 0;
}

.sg-country-flag-avatar-host {
  position: relative;
}

.sg-country-flag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  vertical-align: middle;
  line-height: 0;
}

.sg-country-flag img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 2px;
}

.sg-country-flag--inline {
  width: 16px;
  height: 12px;
  margin-inline-start: 6px;
  overflow: hidden;
  border-radius: 3px;
  box-shadow: 0 0 0 1px rgba(15, 23, 42, 0.12);
  transform: translateY(-1px);
}

.sg-country-flag--avatar {
  position: absolute;
  left: -2px;
  bottom: -2px;
  width: 18px;
  height: 13px;
  overflow: hidden;
  border-radius: 4px;
  background: #fff;
  border: 1px solid rgba(15, 23, 42, 0.14);
  box-shadow: 0 4px 10px rgba(15, 23, 42, 0.2);
  z-index: 4;
}

/* nb##: GROUP 成员卡片头像位单独收口为左下角，避免 inline 容器把国旗视觉中心抬到中线 */
.sg-group-member-card .sg-country-flag-avatar-host {
  display: inline-block;
  line-height: 0;
}

.sg-group-member-card .sg-country-flag--avatar {
  top: auto;
  right: auto;
  left: -2px;
  bottom: -2px;
  transform: none;
}

body.night-mode .sg-country-flag--avatar {
  background: var(--body-bg-color-dark);
  border-color: rgba(255, 255, 255, 0.18);
}

.profile-avatar-wrapper .sg-country-flag--avatar,
.user-card-avatar .sg-country-flag--avatar {
  width: 24px;
  height: 18px;
  left: 2px;
  bottom: 2px;
}

.post-avatar .sg-country-flag--avatar {
  width: 20px;
  height: 15px;
  left: 2px;
  bottom: 2px;
}

.chat-sidebar-contact__avatar .sg-country-flag--avatar,
.comment-avatar .sg-country-flag--avatar {
  left: 0;
  right: auto;
  bottom: 0;
}

/* nb##: 聊天侧栏好友国旗角标恢复左下角，并改为方角显示 */
.chat-sidebar-contact__avatar .sg-country-flag--avatar,
.chat-sidebar-contact__avatar .sg-country-flag--avatar img {
  border-radius: 0;
}

.conversation-user .sg-country-flag--avatar {
  width: 14px;
  height: 10px;
  left: -1px;
  bottom: -1px;
}

.profile-name-wrapper .sg-country-flag--inline {
  width: 20px;
  height: 15px;
}

@media (min-width: 768px) {
  .data-avatar .left-avatar,
  .data-avatar .right-avatar {
    width: 19px;
    height: 40px;
    border-radius: 20px 0 0 20px;
  }

  .data-avatar .right-avatar {
    width: 20px;
    border-radius: 0 20px 20px 0;
  }

  .data-container.small .data-avatar .left-avatar,
  .data-container.small .data-avatar .right-avatar {
    width: 14px;
    height: 30px;
  }

  .data-container.small .data-avatar .right-avatar {
    width: 15px;
  }
}

.data-reaction {
  position: absolute;
  bottom: -4px;
  right: -6px;
}

.data-content {
  padding-left: 38px;
  color: #555;
  font-size: 13px;
}

body.night-mode .data-content {
  color: var(--body-color-dark);
}

.toast-body .data-content {
  color: #fff;
}

@media (min-width: 768px) {
  .data-content {
    padding-left: 48px;
    word-wrap: break-word;
  }

  .data-container.small .data-content {
    padding-left: 38px;
    /* override the previous */
  }
}

.data-content .data-img {
  background-color: #fff;
  border: 1px solid #ddd;
  padding: 1px;
  width: 48px;
  height: 48px;
  object-fit: cover;
  border-radius: 14px;
}

.data-content .btn {
  padding: 2px 6px;
  font-size: 10px;
}

.sg-group-member-role-badges {
  position: absolute;
  top: 12px;
  right: 12px;
  z-index: 2;
  display: flex;
  align-items: center;
  gap: 6px;
  pointer-events: none;
}

.sg-group-member-role-badges .badge {
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.18);
}

.sg-group-member-role-badges--inline {
  position: static;
  display: inline-flex;
  margin-left: 8px;
  vertical-align: middle;
  pointer-events: auto;
}

/* nb##: group members 卡片将状态图标拆到用户名下一行；settings/members 与公开 members 共用同一套布局 */

@media (min-width: 576px) {
  .data-content .btn {
    padding: 4px 12px;
    font-size: 12px;
  }
}

.data-content .name {
  font-weight: bold;
}

.data-content .time {
  font-size: 10px;
  color: #888;
}

.data-content .text {
  word-break: break-all;
}

/* -- */

/* x-form */
.x-form {
  position: relative;
  /* for x-form-tools */
}

.x-form-tools {
  position: absolute;
}

.x-form-tools > li {
  float: left;
  margin-left: 4px;
  padding: 4px 2px;
  border-radius: 50%;
}

.x-form-tools > li:first-child {
  margin-left: 0;
}

.x-form-tools > li:hover {
  background: #f3f3f3;
  cursor: pointer;
}

body.night-mode .x-form-tools > li:hover {
  background: var(--card-dark-hover);
}

.x-form-tools-post,
.x-form-tools-attach,
.x-form-tools-voice,
.x-form-tools-emoji {
  position: relative;
  /* for input & menus */
  overflow: hidden;
  display: inline-block;
  cursor: pointer;
}

@media (min-width: 992px) {
  .x-form-tools-post {
    display: none;
  }
}

.x-form-tools-attach input[type="file"] {
  position: absolute;
  top: 0;
  right: 0;
  min-width: 100%;
  min-height: 100%;
  font-size: 100px;
  text-align: right;
  filter: alpha(opacity=0);
  opacity: 0;
  outline: none;
  background: white;
  cursor: inherit;
  display: block;
}

/* -- */

/* attachments */
.attachments li {
  float: left;
  width: 64px;
  height: 64px;
  margin-right: 5px;
  margin-bottom: 5px;
  transition: padding 0.5s;
}

@media (min-width: 768px) {
  .attachments li {
    width: 96px;
    height: 96px;
  }
}

.attachments li.item {
  position: relative;
  cursor: pointer;
  border-radius: 10px;
}

.attachments li.item img {
  width: 64px;
  height: 64px;
  border-radius: 10px;
}

@media (min-width: 768px) {
  .attachments li.item img {
    width: 94px;
    height: 94px;
  }
}

.attachments li.item .name {
  background: #fafafa;
  height: 100%;
  width: 100%;
  padding: 10px;
  color: #999;
  font-size: 10px;
  word-break: break-all;
}

.attachments li.item button {
  position: absolute;
  top: 2px;
  right: 5px;
  color: #fff;
  text-shadow: 0 1px 0 #000;
}

.attachments li.loading {
  padding-top: 22px;
  /* 64px-20px(loader) / 2 */
  background: #f3f3f3;
  border: 1px solid #f4f4f4;
  display: none;
  border-radius: 10px;
}

@media (min-width: 768px) {
  .attachments li.loading {
    padding-top: 45px;
    /* 96px-5px(loader) / 2 */
  }
}

body.night-mode .attachments li.loading {
  background: var(--card-dark-color);
  border-color: var(--card-dark-divider);
}

.attachments li.add {
  position: relative;
  overflow: hidden;
  padding: 20px 0 0 25px;
  color: #ddd;
  font-size: 16px;
  cursor: pointer;
  border-radius: 16px;
  border: 2px dashed #cecece;
}

body.night-mode .attachments li.add {
  color: var(--body-color-dark);
  border-color: var(--card-dark-divider);
}

@media (min-width: 768px) {
  .attachments li.add {
    padding: 30px 0 0 35px;
    font-size: 24px;
  }
}

/* -- */

/* x-uploader */
.x-uploader {
  overflow: hidden;
}

.x-uploader input[type="file"] {
  position: absolute;
  top: 0;
  right: 0;
  min-width: 100%;
  min-height: 100%;
  font-size: 100px;
  text-align: right;
  opacity: 0;
  outline: none;
  background: white;
  cursor: pointer;
  display: block;
}

.x-uploader .fa {
  cursor: pointer;
}

/* -- */

/* x-image */
.x-image {
  position: relative;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
  background-color: #eee;
  border: 1px dashed #ccc;
  width: 96px;
  height: 96px;
  overflow: hidden;
  display: block;
  border-radius: 10px;
}

body.night-mode .x-image {
  background-color: var(--card-dark-input);
  border-color: var(--card-dark-divider);
}

.x-image.full {
  width: 100%;
}

.x-image.blog-cover-uploader {
  width: 100%;
  max-width: 640px;
  height: auto;
  aspect-ratio: 16 / 4;
}

.x-image.blog-cover-uploader .x-image-loader {
  padding-top: 0;
}

/* nb##: BLOG Cover 上传区需保持整块可点击，同时让相机图标稳定落在预览区正中 */
.x-image.blog-cover-uploader .x-uploader {
  display: flex;
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  align-items: center;
  justify-content: center;
  margin: 0;
  padding: 0;
  z-index: 1;
}

.x-image.blog-cover-uploader .x-uploader input[type="file"] {
  z-index: 2;
}

.x-image.blog-cover-uploader .js_x-uploader {
  display: flex;
  width: 100%;
  height: 100%;
  align-items: center;
  justify-content: center;
  margin: 0;
  padding: 0;
  line-height: 1;
  text-align: center;
  pointer-events: none;
}

.x-image.blog-cover-uploader .js_x-uploader::before {
  display: block;
}

@supports not (aspect-ratio: 16 / 4) {
  .x-image.blog-cover-uploader::after {
    content: "";
    display: block;
    padding-top: 25%;
  }
}

.x-image.sm {
  width: 48px;
  height: 48px;
}

.x-image:before {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: 100%;
  background: #000;
  content: "";
  opacity: 0;
}

.x-image:hover.x-image:before {
  opacity: 0.2;
}

.x-image-success {
  display: none;
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0.5;
  background: #000;
  width: 100%;
  height: 100%;
  padding-top: 30%;
  text-align: center;
  color: #fff;
  font-size: 12px;
  transition: all 0.5s;
}

.x-image-loader {
  display: none;
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0.5;
  background: #000;
  width: 100%;
  height: 100%;
  padding-top: 50%;
  transition: all 0.5s;
}

.x-image.full .x-image-loader {
  padding-top: 20%;
}

.x-image .x-uploader {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  text-align: center;
  padding: 37px;
}

.x-image.full .x-uploader {
  padding-top: 35px;
}

.x-image button {
  position: absolute;
  top: 0;
  right: 5px;
  z-index: 2;
}

/* -- */

/* x-progress (uploading progress) */
.x-progress {
  height: 5px;
  margin: 0 1.5rem;
  border-radius: 25px;
}

/* -- */

/* tbl-image */
.tbl-image {
  width: 24px;
  height: 24px;
  float: left;
  margin-right: 5px;
  border-radius: 50%;
}

.tbl-image.app-icon {
  width: 34px;
  height: 34px;
  border-radius: 4px;
}

/* -- */

/* badges */
.verified-badge {
  color: #55acee;
}

.pro-badge {
  color: #e13c4c;
}

.privacy-badge {
  color: #fff;
  font-size: 16px;
}

.verified-badge:hover,
.pro-badge:hover,
.privacy-badge:hover {
  cursor: pointer;
}

/* -- */

/* ads */
.ads-title {
  font-size: 14px;
  padding: 5px 0;
  margin: 0;
  word-break: break-all;
}

.ads-descrition {
  font-size: 12px;
  word-break: break-word;
}

.adblock-warning-message {
  display: none;
  padding: 20px;
  background: #d30000;
  text-align: center;
  color: #fff;
  border-radius: 16px;
  margin-bottom: 20px;
}

.adblock-detector {
  position: fixed;
  top: 70px;
  left: 0;
  right: 0;
  display: none;
  margin-bottom: 30px;
  padding: 40px 10px;
  background: #d30000;
  text-align: center;
  font-weight: bold;
  color: #fff;
}

/* -- */

/* user-popover */
@media (min-width: 768px) {
  .user-popover {
    position: relative;
  }

  .user-popover-wrapper {
    width: 400px;
    min-height: 180px;
    z-index: 99999;
  }

  .user-popover-content {
    width: 400px;
    position: absolute;
    top: 5px;
    left: 0;
    border-radius: 16px;
    background-color: #fff;
    box-shadow: 0 1px 12px rgba(0, 0, 0, 0.2);
    z-index: 999999;
  }

  body.night-mode .user-popover-content {
    background: var(--card-dark-color);
  }

  .user-card {
    position: relative;
  }

  .user-card-cover {
    width: 100%;
    height: 120px;
    background-color: #424242;
    background-size: cover;
    background-position: center center;
    border-radius: 16px 16px 0 0;
  }

  body.night-mode .user-card-cover {
    background-color: #151a1f;
  }

  .user-card-avatar {
    position: absolute;
    left: 15px;
    bottom: -15px;
    padding: 2px;
    border-radius: 50%;
    background: #fff;
    box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.3);
  }

  body.night-mode .user-card-avatar {
    background: var(--card-dark-color);
  }

  .user-card-avatar img {
    width: 60px;
    height: 60px;
    border-radius: 50%;
  }

  .user-card-info {
    position: absolute;
    left: 96px;
    bottom: 10px;
    color: #fff;
  }

  .user-card-info a {
    color: #fff;
    text-shadow: 0 0 3px rgba(0, 0, 0, 0.9);
  }

  .user-card-info a:hover {
    text-decoration: underline;
  }

  .user-card-info a.name {
    font-size: 20px;
    font-weight: 600;
  }

  .user-card-info .info {
    font-size: 12px;
    line-height: 15px;
    text-shadow: 0 0 3px rgba(0, 0, 0, 0.9);
  }

  .user-card-meta {
    padding-left: 96px;
    padding-top: 10px;
    font-size: 14px;
    color: #000;
  }

  body.night-mode .user-card-meta {
    color: var(--body-color-dark);
  }

  .user-popover-content .popover-footer {
    padding: 8px;
    text-align: center;
    border-radius: 0 0 6px 6px;
  }

  .user-popover-content .popover-footer .btn {
    padding: 6px 12px;
    margin-right: 5px;
    margin-bottom: 5px;
  }

  /* -- */
}

/* -- */

/* trending */
.trending-item {
  word-break: break-word;
  display: block;
  padding: 5px 0;
  font-size: 13px;
}

.trending-item .hash {
  display: block;
  color: #ffffff;
  font-weight: bold;
  font-size: 14px;
}

.trending-item .frequency {
  font-size: 12px;
  color: #ffeb00;
}

.trending-item:hover .hash {
  text-decoration: underline;
}

/* -- */

/* sticker */
.sticker {
  max-height: 100px;
  display: block;
  margin: 0 auto;
}

/* -- */

/* collaborative users */
.collaborative-users {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  column-gap: 0.75rem;
  row-gap: 0.5rem;
  margin-bottom: 1rem;
  padding-top: 1rem;
  padding-bottom: 1rem;
  border-top: 1px solid rgba(0, 0, 0, 0.08);
  border-bottom: 1px solid rgba(0, 0, 0, 0.08);
}

.collaborative-users__label {
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--bs-secondary-color, #6c757d);
  margin-bottom: 0.65rem;
}

.collaborative-users .collaborative-users__label {
  flex: 0 0 auto;
  margin-bottom: 0;
  align-self: center;
}

.collaborative-users .collaborative-users__list {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  flex: 1 1 0;
  min-width: 0;
  max-width: 100%;
  vertical-align: unset;
}

.collaborative-users__list {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  vertical-align: middle;
  max-width: 100%;
}

.collaborative-users__tag {
  display: inline-flex;
  max-width: 100%;
}

.collaborative-users__link {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  max-width: 100%;
  padding: 0.25rem 0.65rem 0.25rem 0.35rem;
  border-radius: 999px;
  background-color: rgba(0, 0, 0, 0.04);
  border: 1px solid rgba(0, 0, 0, 0.06);
  color: inherit;
  text-decoration: none;
  font-size: 0.875rem;
  font-weight: 500;
  line-height: 1.2;
  transition:
    background-color 0.15s ease,
    border-color 0.15s ease,
    box-shadow 0.15s ease;
}

.collaborative-users__link:hover {
  background-color: rgba(0, 0, 0, 0.07);
  border-color: rgba(0, 0, 0, 0.1);
  color: inherit;
  text-decoration: none;
}

.collaborative-users__avatar {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
  border: 1px solid rgba(0, 0, 0, 0.08);
}

.collaborative-users__name {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 200px;
}

@media (prefers-color-scheme: dark) {
  .collaborative-users__link {
    background-color: rgba(255, 255, 255, 0.06);
    border-color: rgba(255, 255, 255, 0.1);
  }

  .collaborative-users__link:hover {
    background-color: rgba(255, 255, 255, 0.1);
    border-color: rgba(255, 255, 255, 0.14);
  }

  .collaborative-users__avatar {
    border-color: rgba(255, 255, 255, 0.12);
  }
}

/* -- */

/* card balance */

.card-balance {
  background-color: #f7f7f7;
  padding: 20px;
  border-radius: 12px;
}

body.night-mode .card-balance {
  background-color: #2e3f4d;
}

.card-balance p {
  margin-bottom: 0;
}

.card-balance-value {
  font-size: 34px;
  font-weight: 600;
  margin: 0;
}

/* -- */

/* PUBLISHER */
/* ------------------------------- */

.publisher-overlay {
  background: #000;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  opacity: 0;
  z-index: 1002;
}

body.publisher-focus .publisher-overlay {
  bottom: 0;
  opacity: 0.6;
}

.publisher {
  margin-bottom: 20px;
  background: #fff;
  border-radius: 16px;
  box-shadow: 0 1px 1px rgba(0, 0, 0, 0.05);
}

body.night-mode .publisher {
  background: var(--card-dark-color);
}

body.publisher-focus .publisher {
  z-index: 1003;
}

.publisher.mini {
  margin-bottom: 0;
  border-radius: 0;
}

.publisher-loader {
  display: none;
  position: absolute;
  top: 5px;
  right: 10px;
  z-index: 1;
}

.publisher-close {
  position: absolute;
  top: 5px;
  right: 10px;
  z-index: 1;
}

.publisher-message {
  position: relative;
  padding: 15px 15px 20px 65px;
}

.publisher-message.no-avatar {
  padding-left: 15px;
}

.publisher-message.colored,
.post-colored,
.post-colored-preview {
  height: 300px;
  padding: 30px;
  background-repeat: no-repeat !important;
  background-size: cover !important;
}

.publisher-message.colored {
  border-radius: 2px 2px 0 0;
}

.post-colored-preview {
  border-radius: 2px;
}

.post-colored-preview.small {
  height: 180px;
}

.post-colored-preview h2 {
  text-align: center;
  padding-top: 100px;
}

.post-colored-preview h4 {
  text-align: center;
  padding-top: 50px;
}

.publisher-message.colored .colored-text-wrapper,
.post-colored-text-wrapper {
  height: 240px;
  display: flex;
  text-align: center;
}

.publisher-message.colored .colored-text-wrapper {
  overflow-x: auto;
  overflow-y: auto;
  flex-direction: column;
  justify-content: center;
  align-items: stretch;
}

.publisher .colored-text-wrapper .quill-editor {
  min-height: 32px;
  min-width: 100%;
}

.publisher-message.colored .colored-text-wrapper .quill-editor {
  height: auto;
  flex-shrink: 0;
}

/* publisher-avatar */
.publisher-avatar {
  position: absolute;
  left: 15px;
  top: 15px;
  width: 40px;
  height: 40px;
  padding: 2px;
  border: 1px solid #efefef;
  border-radius: 50%;
}

body.night-mode .publisher-avatar {
  border-color: var(--card-dark-divider);
}

.publisher-message.colored .publisher-avatar {
  display: none;
}

/* -- */

/* publisher textarea */
.publisher textarea:not(.form-control) {
  background: transparent;
  direction: ltr;
  resize: none;
  outline: none;
  width: 100%;
  margin-top: 5px;
  padding: 0;
  font-size: 16px;
  line-height: 24px;
  height: 24px;
  border: 0 none;
}

body.night-mode .publisher textarea:not(.form-control) {
  color: #fff;
}

.publisher textarea:not(.form-control)::placeholder {
  color: inherit;
  opacity: 0.65;
}

.publisher textarea:not(.form-control):-ms-input-placeholder {
  color: inherit;
  opacity: 0.65;
}

.publisher textarea:not(.form-control)::-ms-input-placeholder {
  color: inherit;
  opacity: 0.65;
}

.publisher-message.colored textarea,
.post-colored .post-text {
  text-align: center;
  font-size: 25px;
  line-height: 30px;
  font-weight: 600;
  margin: auto;
}

.publisher-message.colored .quill-editor * {
  text-align: center;
  margin: auto;
}

.publisher-message.colored .quill-editor {
  min-height: 60px;
}

.publisher-message.colored textarea {
  min-height: 60px;
}

.post-colored .post-text a {
  color: inherit !important;
  text-decoration: underline !important;
}

.post-colored .post-text a:hover {
  text-decoration: none !important;
}

/* -- */

/* publisher-emojis */
.publisher-emojis {
  display: none;
  position: absolute;
  bottom: 5px;
  right: 10px;
}

.publisher-emojis .fal {
  cursor: pointer;
  color: #555;
}

body.night-mode .publisher-emojis .fal {
  color: var(--body-color-dark);
}

/* -- */

/* publisher-slider */
.publisher-slider {
  display: none;
}

/* -- */

/* publisher-scraper */
.publisher-scraper {
  display: none;
  position: relative;
  padding: 10px;
}

.publisher-scraper video {
  width: 100%;
}

.publisher-scraper img {
  width: 100%;
  height: auto;
}

.publisher-scraper-remover {
  position: absolute;
  top: 15px;
  right: 20px;
  width: 26px;
  height: 26px;
  padding-right: 4px;
  background: #fbfbfb;
  border: 1px solid #eaeaea;
  border-radius: 50%;
  z-index: 1;
}

body.night-mode .publisher-scraper-remover {
  background: var(--card-dark-color);
  border-color: var(--card-dark-divider);
}

.publisher-scraper-remover:hover {
  background: #fff;
}

.publisher-scraper-remover button.close {
  opacity: 0.5;
}

/* -- */

/* publisher-attachments */
.publisher-attachments {
  padding: 10px 10px 5px;
}

/* -- */

/* publisher-meta */
.publisher-meta {
  position: relative;
  border-top: 1px dashed #eee;
  font-weight: 600;
  margin: 0 15px;
  padding: 8px 0;
  display: none;
}

body.night-mode .publisher-meta {
  border-color: var(--card-dark-divider);
}

.publisher-meta.top {
  border-top: 0;
  border-bottom: 1px dashed #eee;
}

.publisher-meta .svg-container {
  position: absolute;
  top: 18px;
  left: 14px;
}

.publisher-meta .svg-container.static {
  position: static;
}

.publisher-meta input {
  background: #f3f3f3;
  width: 100%;
  color: var(--link-color);
  font-weight: 600;
  font-size: 14px;
  line-height: 20px;
  padding: 12px 16px 12px 40px;
  outline: 0 none;
  border: 0 none;
  border-radius: 16px;
}

.publisher-meta input.no-icon {
  padding: 12px 16px;
}

body.night-mode .publisher-meta input {
  color: var(--body-color-dark);
  background: var(--card-dark-input);
}

.publisher-meta input::-webkit-input-placeholder {
  color: #9c9c9c;
}

.publisher-meta input:-moz-placeholder {
  color: #9c9c9c;
  opacity: 1;
}

.publisher-meta input:-ms-input-placeholder {
  color: #9c9c9c;
}

/* -- */

/* publisher-custom-thumbnail */
.publisher-custom-thumbnail {
  display: none;
  position: relative;
  margin: 10px 15px;
  padding: 8px 0;
  border-top: 1px dashed #eee;
  overflow: hidden;
}

body.night-mode .publisher-custom-thumbnail {
  border-color: var(--card-dark-divider);
}

.publisher-custom-thumbnail .x-image {
  width: 100%;
  height: 160px;
  margin-top: 5px;
}

.publisher-custom-thumbnail .x-image-loader {
  padding-top: 80px;
}

/* -- */

/* feelings */
#feelings-menu-toggle {
  white-space: nowrap;
  padding: 5px;
  cursor: pointer;
  padding: 8px 18px;
  background: #f3f3f3;
  color: #6f6f6f;
  font-weight: 600;
  border-radius: 18px;
}

body.night-mode #feelings-menu-toggle {
  background: var(--card-dark-input);
}

#feelings-menu-toggle.active {
  display: table-cell;
  background: #e2e8f6;
}

body.night-mode #feelings-menu-toggle.active {
  background: var(--card-dark-input);
  color: var(--body-color-dark);
}

#feelings-data {
  display: table-cell;
  width: 100%;
  padding-left: 5px;
}

#feelings-data span {
  white-space: nowrap;
  padding: 10px 14px;
  background: var(--link-color);
  color: #ffffff;
  font-weight: 600;
  border-radius: 18px;
  cursor: pointer;
}

#feelings-data span .twa {
  vertical-align: middle;
}

.feeling-item {
  padding: 5px;
  cursor: pointer;
  color: #666;
  margin-bottom: 5px;
}

body.night-mode .feeling-item {
  color: var(--body-color-dark);
}

.feeling-item:hover {
  background: #fff;
  color: var(--link-color) !important;
}

body.night-mode .feeling-item:hover {
  background: var(--card-dark-input);
}

.feeling-item .icon {
  display: table-cell;
  vertical-align: top;
  padding-right: 10px;
}

.feeling-item .data {
  display: table-cell;
  vertical-align: middle;
  width: 100%;
  font-size: 1.2em;
  font-weight: 600;
}

/* -- */

/* colored-pattern-item */
.colored-pattern-item {
  display: inline-block;
  height: 36px;
  width: 36px;
  padding: 0;
  border: 2px solid #fff;
  border-radius: 50%;
  background-size: cover;
  cursor: pointer;
}

body.night-mode .colored-pattern-item {
  border-color: var(--card-dark-input);
}

.colored-pattern-item.active {
  box-shadow: 0px 0px 0px 2px rgba(102, 199, 244, 0.65);
}

/* -- */

/* gif-search */
.dropdown-menu.gif-search {
  display: none;
}

.gif-search .item {
  width: 33%;
  float: left;
  margin-right: 1px;
  margin-bottom: 1px;
}

.gif-search .item > img {
  width: 100%;
  height: fit-content;
  cursor: pointer;
}

/* -- */

/* publisher-tools-tabs */
.publisher-tools-tabs {
  margin: 0 15px;
  padding-top: 15px;
  border-top: 1px solid #f4f4f4;
  border-bottom: 1px solid #f4f4f4;
}

body.night-mode .publisher-tools-tabs {
  border-color: var(--card-dark-divider);
}

.publisher-tools-tabs .divider {
  border-top: 1px solid #f4f4f4;
  margin-bottom: 15px;
}

body.night-mode .publisher-tools-tabs .divider {
  border-top-color: var(--card-dark-divider);
}

.publisher-tools-tab {
  display: block;
  background: #f7f7f7;
  padding: 10px 14px;
  color: #555;
  font-size: 13px;
  font-weight: 700;
  border-radius: 16px;
  margin-bottom: 15px;
}

body.night-mode .publisher-tools-tab {
  background: var(--card-dark-hover);
  color: var(--body-color-dark);
}

.publisher-tools-tab:hover {
  background: #f3f3f3;
  color: var(--link-color);
  cursor: pointer;
}

body.night-mode .publisher-tools-tab:hover {
  background: var(--card-dark-input);
}

.publisher-tools-tab.active,
body.night-mode .publisher-tools-tab.active {
  color: var(--link-color);
}

.publisher-tools-tab.activated {
  background: #d2e0ff;
}

body.night-mode .publisher-tools-tab.activated {
  background: var(--card-dark-input);
}

.publisher-tools-tab[data-tab="video"].activated:after,
.publisher-tools-tab[data-tab="audio"].activated:after,
.publisher-tools-tab[data-tab="file"].activated:after {
  content: "";
  background: transparent;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  cursor: initial;
}

.publisher-tools-tab.disabled {
  position: relative;
}

.publisher-tools-tab.disabled:hover {
  background: #f7f7f7;
  color: #7f838a;
  cursor: initial;
}

body.night-mode .publisher-tools-tab.disabled:hover {
  background: var(--card-dark-input);
  color: var(--body-color-dark);
}

.publisher-tools-tab.disabled:after {
  content: "";
  background: #fff;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  opacity: 0.6;
  border-radius: 16px;
}

body.night-mode .publisher-tools-tab.disabled:after {
  background: #000;
}

.publisher-tools-tab.attach {
  position: relative;
  /* for input file */
  overflow: hidden;
}

.publisher-tools-tab.attach form {
  display: initial;
}

.publisher-tools-tab img {
  width: 24px;
  height: 24px;
  margin-right: 5px;
}

/* -- */

/* publisher-footer */
.publisher-footer {
  text-align: right;
  padding: 15px;
}

.publisher-footer-options {
  text-align: left;
  border-bottom: 1px solid #f4f4f4;
  margin-bottom: 20px;
}

body.night-mode .publisher-footer-options {
  border-color: var(--card-dark-divider);
}

.publisher-footer-buttons {
  display: flex;
  justify-content: space-between;
}

/* -- */

/* posts-filter */
.posts-filter {
  margin-bottom: 20px;
  padding-bottom: 5px;
  border-bottom: 1px solid #dfdfdf;
  line-height: 34px;
  font-weight: 600;
}

body.night-mode .posts-filter {
  border-bottom-color: var(--card-dark-divider);
}

.posts-filter .btn-group .btn,
.posts-filter .btn-group .open .btn.dropdown-toggle,
.posts-filter .btn-group .btn-default.active,
.posts-filter .btn-group .btn-default:active,
.posts-filter .btn-group .open .btn-default.dropdown-toggle {
  background: #fff;
  box-shadow: none !important;
  border: 0 none !important;
  padding: 6px 10px !important;
  border-radius: 10px;
  font-size: 13px;
}

body.night-mode .posts-filter .btn-group .btn,
body.night-mode .posts-filter .btn-group .open .btn.dropdown-toggle,
body.night-mode .posts-filter .btn-group .btn-default.active,
body.night-mode .posts-filter .btn-group .btn-default:active,
body.night-mode .posts-filter .btn-group .open .btn-default.dropdown-toggle {
  background: var(--card-dark-color);
  color: var(--body-color-dark);
}

.posts-filter .countries-filter {
  background: #ffff;
  padding: 7px 10px;
  border-radius: 10px;
  font-size: 13px;
  color: #212529;
}

body.night-mode .posts-filter .countries-filter {
  background: var(--card-dark-color);
  color: var(--body-color-dark);
}

.posts-filter .dropdown-menu:not(.countries-dropdown) {
  min-width: 160px;
}

.posts-filter .dropdown-menu .dropdown-item {
  padding: 2px 16px;
}

/* -- */

/* jobs publisher */
.add-job-question {
  background: #f7f7f7;
  margin: 10px 0;
  padding: 10px;
  font-weight: 600;
  text-align: center;
  border: 1px solid #ddd;
  border-radius: 4px;
  cursor: pointer;
}

.add-job-question:hover {
  background: #f3f3f3;
}

body.night-mode .add-job-question {
  background: var(--card-dark-input);
  border-color: var(--card-dark-divider);
}

body.night-mode .add-job-question:hover {
  background: var(--card-dark-color);
}

.job-question {
  background: #f7f7f7;
  margin: 10px 0;
  padding: 20px;
  border-radius: 16px;
}

body.night-mode .job-question {
  background: var(--card-dark-input);
}

.job-question .question {
  font-size: 16px;
  font-weight: bold;
}

.job-question .answer {
  font-size: 14px;
}

.job-candidate-wrapper {
  padding: 15px;
  border: 1px solid #f4f4f4;
  border-radius: 16px;
  margin-bottom: 20px;
}

body.night-mode .job-candidate-wrapper {
  border-color: var(--card-dark-divider);
}

.job-candidate-avatar {
  position: relative;
  display: table-cell;
  vertical-align: top;
  padding-right: 10px;
}

.job-candidate-info {
  display: table-cell;
  vertical-align: top;
  width: 100%;
  font-size: 14px;
  word-break: break-word;
}

.job-candidate-info .name {
  font-size: 18px;
  font-weight: 600;
  margin-bottom: 10px;
}

/* -- */

/* posts-staging */
.posts-staging-btn {
  display: none;
  position: fixed;
  top: 150px;
  left: 50%;
  transition: all 0.2s ease;
  transform: translate(-50%, -50%);
  z-index: 99;
}

/* -- */

/* POST */
/* ------------------------------- */

.post {
  position: relative;
  margin-bottom: 20px;
  background: #fff;
  border-radius: 16px;
  box-shadow: 0px 0px 30px 0px rgb(82 63 105 / 5%);
}

body.night-mode .post {
  background: var(--card-dark-color);
}

.post.flagged {
  padding: 15px;
  background: #f6f7f8;
}

.post .pin-icon {
  position: absolute;
  right: 18px;
  top: -10px;
  width: auto;
  font-size: 25px;
  color: #f9b340;
}

.post.boosted,
body.night-mode .post.boosted {
  border: 2px solid #ffa412;
}

.post .boosted-icon {
  position: absolute;
  left: -5px;
  top: -15px;
  width: auto;
  padding: 3px 6px;
  font-size: 16px;
  background: #ffa412;
  color: #ffffff;
  border-radius: 50%;
  -ms-transform: rotate(-20deg);
  /* IE 9 */
  -webkit-transform: rotate(-20deg);
  /* Safari */
  transform: rotate(-20deg);
  /* Standard syntax */
}

.post.pending,
body.night-mode .post.pending {
  border: 1px dashed #9b9b9b;
}

.post .pending-icon {
  position: absolute;
  right: 18px;
  top: -18px;
  width: auto;
  font-size: 25px;
  color: #f9b340;
}

.post.highlighted {
  border: 1px solid #4083a9;
  box-shadow: inset 0 0 0 1px #4083a9;
}

.post.is_hidden {
  border: 2px dashed #aeaeae;
  border-radius: 8px;
  z-index: 1;
}

.post a:not(.dropdown-item):hover {
  text-decoration: underline;
}

.post-memory-header {
  padding: 10px 20px;
  border-bottom: 1px solid #f4f4f4;
  font-size: 14px;
  font-weight: 600;
  text-transform: capitalize;
}

body.night-mode .post-memory-header {
  border-color: var(--card-dark-divider);
}

.post-body.with-loader {
  padding: 16px;
}

.post-top-alert {
  padding: 10px 0;
  background: repeating-linear-gradient(
    45deg,
    #606dbc,
    #606dbc 10px,
    #465298 10px,
    #465298 20px
  );
  border-radius: 8px 8px 0 0;
  color: #fff;
  font-weight: 500;
  text-align: center;
  filter: grayscale(1);
}

.post-top-alert:hover,
.post-top-alert:focus {
  color: #fff;
  text-decoration: none;
}

.post-collaborative-alert {
  padding: 12px 0;
  background: #f7f7f7;
  border-radius: 8px 8px 0 0;
  color: #212529;
  font-size: 12px;
  text-align: center;
}

body.night-mode .post-collaborative-alert {
  background: #27333f;
  color: var(--body-color-dark);
}

.post-header {
  padding: 16px 16px 0;
  margin-bottom: 10px;
}

.post-avatar {
  position: relative;
  display: table-cell;
  vertical-align: top;
  padding-right: 10px;
}

.post-avatar-anonymous {
  padding: 5px;
  border-radius: 50%;
  overflow: hidden;
}

.post-avatar-picture {
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
  background-color: #eee;
  width: 100%;
  height: 100%;
  padding-top: 100%;
  overflow: hidden;
  min-width: 60px;
  min-height: 60px;
  display: block;
  border-radius: 20px;
}

.post-avatar-picture.small {
  min-width: 25px;
  min-height: 25px;
}

.post-avatar-picture.large {
  min-width: 60px;
  min-height: 60px;
}

.post-avatar-picture.rounded {
  border-radius: 50%;
}

.post-avatar .online-dot {
  font-size: 10px;
  margin-right: 3px;
  position: absolute;
  top: 50px;
  right: 4px;
  border: 3px solid #fff;
  border-radius: 50%;
  color: #65a830;
}

body.night-mode .post-avatar .online-dot {
  border-color: var(--card-dark-color);
}

/* -- */

.post-meta {
  display: table-cell;
  vertical-align: top;
  width: 100%;
  word-break: break-word;
  word-wrap: break-word;
}

.post-meta .dropdown .dropdown-toggle {
  color: #888;
  padding: 6px 8px;
  border-radius: 10px;
}

.post-meta .dropdown .dropdown-toggle.show,
.post-meta .dropdown .dropdown-toggle:hover {
  color: #666;
  cursor: pointer;
  background: #f4f4f4;
}

body.night-mode .post-meta .dropdown .dropdown-toggle.show,
body.night-mode .post-meta .dropdown .dropdown-toggle:hover {
  background: var(--card-dark-divider);
  color: var(--body-color-dark);
}

.post-meta .dropdown-toggle:after {
  display: none !important;
}

.post-author {
  font-size: 14px;
  line-height: 20px;
  font-weight: bold;
}

.post-time {
  color: #999;
  font-size: 11px;
  line-height: 16px;
}

.post-time a {
  color: #999;
}

.post-time .fa:not(.fa-star):hover {
  cursor: pointer;
}

.post-time .btn-group {
}

.post-time .btn-group,
.post-time .btn-group .btn {
  background: transparent !important;
  box-shadow: none !important;
  border: 0 none !important;
  padding: 2px 4px !important;
  color: #999 !important;
}

.post-time .btn-group .btn:hover {
  background: #f3f3f3 !important;
}

.post-text {
  padding: 0 16px;
  text-align: initial;
  word-break: initial;
  word-wrap: break-word;
  overflow: hidden;
  margin-bottom: 10px;
  transition: height 0.2s;
}

.post-text blockquote {
  border-left: 2px solid #e9eaee;
  padding-left: 10px;
  margin-top: 10px;
}

body.night-mode .post-text blockquote {
  border-left-color: var(--card-dark-divider);
}

.post-product-container .post-text,
.post-media-meta .post-text {
  padding: 0;
}

.post-replace {
  font-size: 15px;
  line-height: 22px;
}

.post-replace > a[data-readmore-toggle] {
  margin-left: 16px;
}

.post-product-container .post-replace > a[data-readmore-toggle] {
  margin-left: 0;
}

.post-text-translation {
  border-left: 2px solid #e9eaee;
  padding-left: 10px;
  margin-top: 10px;
}

.post-text .twa {
  height: 1.6em !important;
  width: 1.6em !important;
  margin: 0 0.0665em 0 0.15em !important;
  vertical-align: -0.15em !important;
  background-size: 1.6em 1.6em !important;
}

.post-paid-description {
  margin-top: 20px;
  padding: 20px;
  background: #f7f7f7;
}

body.night-mode .post-paid-description {
  background: var(--card-dark-color);
}

.post-snippet {
  margin: 16px;
  border: 1px solid #f4f4f4;
  border-radius: 16px;
}

body.night-mode .post-snippet {
  border-color: var(--card-dark-divider);
}

.post-snippet-toggle {
  padding: 6px;
  border-radius: 4px;
  text-align: center;
}

.post-edit {
  padding: 0 16px;
}

.post-stats {
  margin-top: 15px;
  margin-bottom: 10px;
  padding: 0 16px;
  font-size: 11px;
  color: #999;
}

.post-actions {
  display: flex;
  margin-top: 10px;
  padding: 6px 16px 6px 16px;
  border-top: 1px solid #f4f4f4;
}

body.night-mode .post-actions {
  border-color: var(--card-dark-divider);
}

.post-actions .action-btn {
  flex: 1;
  padding: 10px;
  color: #555;
  font-size: 13px;
  font-weight: 700;
  line-height: 14px;
  text-align: center;
  border-radius: 14px;
  transition: all 0.1s ease-in-out;
}

body.night-mode .post-actions .action-btn {
  color: var(--body-color-dark);
}

.post-actions .action-btn:hover {
  background: #f7f7f7;
  cursor: pointer;
}

body.night-mode .post-actions .action-btn:hover {
  background: var(--card-dark-hover);
}

.post-tips {
  display: flex;
  gap: 10px;
  margin-top: 10px;
  padding: 6px 16px 6px 16px;
  border-top: 1px solid #f4f4f4;
}

body.night-mode .post-tips {
  border-color: var(--card-dark-divider);
}

.post-tips .btn {
  flex: 1;
  font-weight: 700;
  text-align: center;
  border-radius: 14px;
  transition: all 0.1s ease-in-out;
}

.post-footer {
  background: #f9f9f9;
  border-top: 1px solid #eee;
  border-radius: 0 0 14px 14px;
  padding: 0 15px;
}

/* nb##: 帖内统计数字统一放大 2x 并改为斜体，同时给图标与数字留出更明显的间距，避免整条统计文案被放大破坏版式 */
.post-stat-number {
  display: inline-block;
  font-size: 150%;
  font-style: italic;
  font-weight: 400;
  line-height: 1;
  margin-left: 0.35rem;
  font-variant-numeric: tabular-nums;
}

body.night-mode .post-footer {
  background: var(--card-dark-color);
  border-top-color: var(--card-dark-divider);
}

.post-approval {
  background: #f9f9f9;
  border-top: 1px solid #eee;
  padding: 15px;
  text-align: right;
  border-radius: 0 0 16px 16px;
}

body.night-mode .post-approval {
  background: var(--card-dark-color);
  border-top-color: var(--card-dark-divider);
}

.post-social-share {
  padding-bottom: 15px;
  margin-bottom: 20px;
  text-align: center;
  border-bottom: 1px solid #f4f4f4;
}

body.night-mode .post-social-share {
  border-color: var(--card-dark-divider);
}

.post-comments {
  padding-top: 10px;
}

/* comments-filter */
.comments-filter {
  margin-bottom: 10px;
  padding-bottom: 10px;
  border-bottom: 1px solid #e6ecf5;
}

body.night-mode .comments-filter {
  border-bottom-color: var(--card-dark-divider);
}

.comments-filter .btn-group .btn,
.comments-filter .btn-group .open .btn.dropdown-toggle,
.comments-filter .btn-group .btn-default.active,
.comments-filter .btn-group .btn-default:active,
.comments-filter .btn-group .open .btn-default.dropdown-toggle {
  background: transparent !important;
  box-shadow: none !important;
  border: 0 none !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  color: var(--link-color) !important;
}

.comments-filter .dropdown-menu {
  min-width: 100%;
}

.comments-filter .dropdown-menu .dropdown-item {
  padding: 4px 16px;
}

/* -- */

/* post images */
.pg_wrapper a {
  display: block;
  position: relative;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center center;
  background-color: #f5f5f5;
}

body.night-mode .pg_wrapper a {
  background-color: var(--card-dark-hover);
}

.pg_wrapper .more {
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.3);
  color: #fff;
  font-size: 2em;
  font-weight: 600;
  line-height: 100%;
  text-align: center;
  padding-top: 40%;
}

.pg_1x {
  text-align: center;
}

.pg_1x img {
  max-width: 100%;
  max-height: 680px;
}

.pg_2x {
  width: 50%;
  float: left;
  padding-right: 1px;
}

.pg_2x > a {
  padding-bottom: 100%;
}

.pg_2o3,
.pg_1o3 {
  float: left;
  margin-right: 1px;
}

.pg_1o3 {
  margin-right: -1px;
}

.pg_2o3 .pg_2o3_in {
  margin-bottom: 1px;
}

.pg_2o3 .pg_2o3_in:last-child {
  margin-bottom: 0;
}

.pg_1o3 .pg_1o3_in {
  margin-bottom: 1px;
}

.pg_1o3 .pg_1o3_in:last-child {
  margin-bottom: 0;
}

/* -- */

/* post media */
.post-media {
  background: #f3f3f3;
  border-radius: 16px;
}

.post-media.module {
  background: transparent;
  border: 1px solid #f3f3f3;
}

body.night-mode .post-media.module {
  background: transparent;
  border-color: var(--card-dark-divider);
}

.post-snippet .post-media {
  border-radius: 4px;
}

body.night-mode .post-media {
  background: var(--card-dark-input);
}

.post-media.list {
  background: #fff;
  box-shadow: none;
  margin-bottom: 15px;
  border: 0;
}

body.night-mode .post-media.list {
  background: var(--card-dark-color);
}

.post-media img.img-fluid {
  width: 100%;
  max-height: 350px;
}

.post-media-image-wrapper {
  position: relative;
}

.post-media-image-meta {
  position: absolute;
  bottom: 15px;
  left: 15px;
}

.post-media-image {
  display: block;
  position: relative;
}

.post-media-image > div {
  border-radius: 16px;
}

.post-media-image img,
.post-media-image .image {
  width: 100%;
  height: 100%;
  overflow: hidden;
  min-width: 100px;
  min-height: 100px;
  border-radius: 16px;
}

.post-media-image .image {
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
  background-color: #eee;
  padding-top: 50%;
}

body.night-mode .post-media-image .image {
  background-color: transparent;
}

.post-media-image .source {
  position: absolute;
  bottom: 10px;
  left: 10px;
  padding: 8px 12px;
  background: rgba(0, 0, 0, 0.65);
  color: #fff;
  font-size: 13px;
  border-radius: 10px;
  text-transform: uppercase;
}

.post-media-image .date {
  position: absolute;
  top: 20px;
  left: 20px;
  padding: 0;
  background: #fff;
  color: #000;
  font-size: 20px;
  line-height: 24px;
  font-weight: bold;
  border-radius: 10px;
  text-transform: uppercase;
  text-align: center;
}

body.night-mode .post-media-image .date {
  background: var(--card-dark-input);
  color: var(--body-color-dark);
}

.post-media-image .date .month {
  background: red;
  color: #fff;
  padding: 5px 20px;
  border-radius: 0 0 10px 10px;
}

.post-media-image .date .day {
  padding: 5px 20px;
}

.post-media-image .icon {
  position: absolute;
  bottom: -31px;
  left: 50%;
  margin-left: -31px;
  padding: 15px;
  background: #fff;
  border-radius: 50%;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
}

body.night-mode .post-media-image .icon {
  background: var(--card-dark-input);
}

.embed-facebook-wrapper iframe {
  display: none;
}

.embed-iframe-wrapper {
  padding: 0 16px;
}

.embed-iframe-wrapper * {
  width: 100% !important;
}

.embed-iframe-wrapper iframe {
  min-height: 100%;
}

.post-media-meta {
  padding: 15px;
  width: 100%;
  transition: all 0.2s;
}

.post-media-meta .title {
  display: block;
  font-size: 16px;
  font-weight: 600;
  line-height: 22px;
  word-break: break-word;
}

.post-media-meta .title:hover {
  text-decoration: none;
}

.post-media-meta .text {
  max-height: 135px;
  overflow: hidden;
}

.post-media-meta .info {
  color: #999;
  font-size: 11px;
}

.post-funding-meta,
.post-job-meta,
.post-course-meta,
.post-merit-meta {
  padding: 15px;
  padding-bottom: 0;
  text-align: center;
}

.post-funding-meta .funding-title,
.post-job-meta .job-title,
.post-course-meta .course-title {
  font-size: 18px;
  font-weight: 600;
  line-height: 26px;
  word-break: break-word;
}

.post-funding-meta .funding-completion {
  background: #f7f7f7;
  padding: 10px;
  border: 1px solid #e5e5e5;
  margin-top: 10px;
  border-radius: 6px;
  text-align: left;
}

.post-funding-meta .funding-description,
.post-job-meta .job-description,
.post-course-meta .course-description,
.post-merit-meta .merit-description {
  background: #f7f7f7;
  padding: 10px;
  border: 1px solid #e5e5e5;
  margin-top: 10px;
  border-radius: 16px;
}

body.night-mode .funding-completion,
body.night-mode .funding-description,
body.night-mode .job-description,
body.night-mode .course-description,
body.night-mode .merit-description {
  border-color: var(--card-dark-divider);
  background: var(--card-dark-input);
}

/* -- */

/* post-downloader */
.post-downloader {
  border-top: 1px solid #eee;
  border-bottom: 1px solid #eee;
  padding: 10px 16px;
  margin-top: 10px;
}

body.night-mode .post-downloader {
  border-color: var(--card-dark-divider);
}

.post-downloader .icon {
  display: table-cell;
  vertical-align: middle;
  background-color: #f9f9f9;
  padding: 10px 20px;
  border-radius: 16px;
}

body.night-mode .post-downloader .icon {
  background-color: var(--card-dark-input);
}

.post-downloader .info {
  display: table-cell;
  vertical-align: top;
  padding-left: 10px;
  width: 100%;
}

/* -- */

/* post product */
.post-product-container {
  padding: 0 16px;
}

.post-product-wrapper {
  display: flex;
  background: #f7f7f7;
  padding: 10px 5px;
  border: 1px solid #e5e5e5;
  font-size: 14px;
  border-radius: 16px;
}

body.night-mode .post-product-wrapper {
  border-color: var(--card-dark-divider);
  background: var(--card-dark-input);
}

.post-product-details {
  flex: 1;
  border-right: 1px solid #e5e5e5;
  text-align: center;
  vertical-align: middle;
}

body.night-mode .post-product-details {
  border-color: var(--card-dark-divider);
}

.post-product-details:last-child {
  border-right: 0;
}

.post-product-details .title {
  font-weight: 600;
  margin-bottom: 3px;
}

.post-product-details .description {
  color: #555;
}

.post-product-details .description .badge {
  font-size: 13px;
  padding: 4px 12px;
}

body.night-mode .post-product-details .description {
  color: var(--body-color-dark);
}

/* -- */

/* action-dropdown-menu */
.action-dropdown-menu .fa {
  margin-right: 10px;
  color: #8b8b8b;
}

.action-dropdown-menu .action {
  font-size: 14px;
  line-height: 18px;
  font-weight: 600;
}

.action-dropdown-menu .action.no-icon {
  padding-left: 22px;
  font-weight: normal;
}

.action-dropdown-menu .action.no-desc {
  font-weight: normal;
}

.action-dropdown-menu .action-desc {
  padding-left: 30px;
  color: #555;
  font-size: 11px;
  line-height: 16px;
}

body.night-mode .action-dropdown-menu .action-desc {
  color: #a2acb7;
}

/* -- */

/* polls */
.poll-options {
  padding: 0 16px;
}

.poll-option {
  display: table-cell;
  vertical-align: top;
  position: relative;
  width: 100%;
  padding: 8px 12px;
  background-color: #ebebeb;
  font-weight: 600;
  border-radius: 16px;
}

body.night-mode .poll-option {
  background-color: var(--card-dark-input);
}

.poll-option:hover {
  cursor: pointer;
  background: #d4d4d4;
}

.poll-option .percentage-bg {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  background-color: #89a8e8;
  border-radius: 12px;
  opacity: 0.5;
}

body.night-mode .poll-option .percentage-bg {
  background-color: var(--link-color);
}

.poll-voters {
  display: table-cell;
  vertical-align: top;
  padding-left: 5px;
}

.poll-voters .more {
  width: 35px;
  height: 35px;
  background-color: #ebebeb;
  padding: 8px 0;
  border-radius: 50%;
  font-size: 13px;
  font-weight: 600;
  text-align: center;
  cursor: pointer;
}

body.night-mode .poll-voters .more {
  background-color: var(--card-dark-input);
}

/* -- */

/* youtube-player */
.youtube-player {
  position: relative;
  padding-top: 56%;
  height: 0;
  overflow: hidden;
  max-width: 100%;
  background: #000;
  border-radius: 16px;
}

.youtube-player iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: transparent;
}

.youtube-player img {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  display: block;
  margin: auto;
  max-width: 100%;
  width: 100%;
  height: auto;
  cursor: pointer;
  transition: 0.4s all;
}

.youtube-player img:hover {
  filter: brightness(75%);
}

.youtube-player .play {
  width: 72px;
  height: 72px;
  left: 50%;
  top: 50%;
  margin-left: -36px;
  margin-top: -36px;
  position: absolute;
  background-image: url(/content/themes/default/images/icons/youtube.png);
  background-size: contain;
  cursor: pointer;
}

.youtube-player.with-live .play {
  width: 52px;
  height: 52px;
  left: 50%;
  top: 50%;
  margin-left: -26px;
  margin-top: -26px;
  position: absolute;
  background-image: url(/content/themes/default/images/play-button.png);
  background-size: contain;
  cursor: pointer;
}

/* -- */

/* who-shares */
.who-shares {
  background: #f3f3f3;
}

body.night-mode .who-shares {
  background: var(--body-bg-color-dark);
}

/* -- */

/* post-custom-fileds-wrapper  */
.post-custom-fileds-wrapper {
  background: #f7f7f7;
  padding: 10px 20px;
  border: 1px solid #e5e5e5;
  font-size: 14px;
  border-radius: 6px;
  text-align: left;
}

body.night-mode .post-custom-fileds-wrapper {
  background: var(--card-dark-color);
  border-color: var(--card-dark-divider);
}

.post-custom-fileds-wrapper div:not(:last-child) {
  margin-bottom: 10px;
  padding-bottom: 10px;
  border-bottom: 1px solid #e7e7e7;
}

body.night-mode .post-custom-fileds-wrapper div:not(:last-child) {
  border-color: var(--card-dark-divider);
}

/* -- */

/* COMMENT */
/* ------------------------------- */

.comment {
  padding-bottom: 10px;
}

.comment-avatar {
  float: left;
}

.comment-avatar-picture {
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
  background-color: #eee;
  width: 100%;
  height: 100%;
  padding-top: 100%;
  overflow: hidden;
  min-width: 46px;
  min-height: 46px;
  display: block;
  border-radius: 50%;
}

.comment-data,
.comment-edit {
  margin-left: 56px;
}

.comment-data .img-fluid {
  max-width: 30%;
  max-height: 100px;
  margin: 5px 0;
}

.comment-inner-wrapper {
  display: flex;
  margin-bottom: 5px;
}

.comment-inner {
  position: relative;
  /* :before */
  padding: 8px 12px;
  background-color: #fff;
  border-radius: 18px;
  box-shadow: 0 0 1px rgba(0, 0, 0, 0.1);
}

body.night-mode .comment-inner {
  background-color: var(--card-dark-input);
}

.comment-inner:before {
  content: "";
  display: block;
  position: absolute;
  left: -6px;
  top: 9px;
  width: 0;
  height: 0;
  border: 8px solid transparent;
  border-left-width: 0;
  border-right-color: #ffffff;
  cursor: default;
  z-index: 1;
  filter: drop-shadow(-1px 1px 0px rgba(0, 0, 0, 0.02));
}

body.night-mode .comment-inner:before {
  border-right-color: var(--card-dark-input);
}

.comment-author {
  font-weight: 500;
}

.comment-text {
  text-align: initial;
  word-break: break-word;
  word-wrap: break-word;
  overflow: hidden;
  margin-bottom: 5px;
}

.comment-text .twa {
  font-size: 1.4em;
}

.comment-actions > li {
  float: left;
  margin-right: 8px;
}

.comment-replies {
  padding-top: 10px;
}

.comment-replies > ul {
  width: 100%;
}

/* comment-form */
.post-form textarea,
.comment-form textarea {
  background: #fff;
  direction: ltr;
  display: block;
  border: 0;
  resize: none;
  outline: none;
  width: 100%;
  padding: 8px 16px;
  padding-right: 136px;
  margin: 0;
  font-size: 16px;
  line-height: 26px;
  height: 46px;
  border-radius: 12px;
}

.post-form textarea {
  padding-right: 44px;
}

.post-edit .post-form textarea,
.post-edit .comment-form textarea {
  background: #f7f7f7;
}

body.night-mode .post-form textarea,
body.night-mode .comment-form textarea {
  color: var(--card-dark-input-color);
  background: var(--card-dark-input);
}

@media (min-width: 992px) {
  .comment-form textarea {
    padding-right: 106px;
  }
}

.post-form .x-form-tools,
.comment-form .x-form-tools {
  bottom: 8px;
  right: 14px;
}

/* -- */

.comment-voice-notes,
.comment-attachments {
  background: #fff;
  padding: 10px 14px 4px 14px;
  margin-top: 5px;
  border: 1px solid #eee;
  border-radius: 18px;
}

.comment-voice-notes {
  display: none;
  padding: 10px;
}

body.night-mode .comment-voice-notes,
body.night-mode .comment-attachments {
  background: transparent;
  border-color: var(--card-dark-divider);
}

.comment .comment-btn {
  display: none;
  float: right;
}

.comment:hover .comment-btn {
  display: block;
}

.live-comments .comment:hover .comment-btn {
  display: none;
}

.comment-btn button.close {
  font-size: 1.4em;
}

.comment .dropdown-toggle-icon {
  color: #999;
  padding: 5px;
  border-radius: 50%;
}

.comment .dropdown-toggle-icon:hover {
  background: #e9eaee;
  cursor: pointer;
}

body.night-mode .comment .dropdown-toggle-icon:hover {
  background: var(--card-dark-divider);
}

/*//nb##: Blog module styles extracted from common stylesheet BEGIN*/
.blog.pending,
body.night-mode .blog.pending {
  border: 1px dashed #9b9b9b;
}

.blog .pending-icon {
  position: absolute;
  right: 18px;
  top: -18px;
  width: auto;
  font-size: 25px;
  color: #f9b340;
}
/*//nb##: END*/

/* BLOG */
/* ------------------------------- */

/* blog-container */
.blog-container {
  background: #ffffff;
  border-radius: 16px;
  overflow: hidden;
  margin-bottom: 20px;
  display: block;
  color: inherit;
  text-decoration: none;
  position: relative;
}

body.night-mode .blog-container {
  background: var(--card-dark-color);
}

@media (min-width: 768px) {
  .blog-container {
    height: 410px;
  }

  .blog-container.primary {
    background: var(--link-color);
  }
}

.blog-image {
  min-height: 150px;
}

@media (min-width: 576px) {
  .blog-image {
    overflow: hidden;
    height: 150px;
  }
}

.blog-image img {
  height: 100%;
  width: 100%;
  object-fit: cover;
}

@media (min-width: 768px) {
  .blog-container.primary .blog-image {
    display: inline-block;
    width: 50%;
    height: 100%;
    max-height: 100%;
  }

  .blog-container.primary .blog-image img {
    width: auto;
    max-width: inherit;
  }
}

.blog-source {
  position: absolute;
  top: 110px;
  left: 10px;
  padding: 6px;
  background: rgba(0, 0, 0, 0.65);
  color: #fff;
  font-size: 13px;
  border-radius: 3px;
  text-transform: uppercase;
}

.blog-container.primary .blog-source {
  bottom: 10px;
  top: auto;
}

.blog-content {
  padding: 10px;
}

@media (min-width: 768px) {
  .blog-container.primary .blog-content {
    color: #fff;
    display: inline-block;
    vertical-align: top;
    width: 49%;
  }
}

.blog-content h3 {
  margin: 0;
  font-weight: 900;
  font-size: 20px;
  text-transform: uppercase;
}

@media (min-width: 576px) {
  .blog-container .blog-content h3 {
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    line-height: 24px;
    max-height: 72px;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
  }
}

@media (min-width: 768px) {
  .blog-container.primary .blog-content h3 {
    font-size: 26px;
    line-height: 30px;
    max-height: 180px;
    -webkit-line-clamp: 6;
  }
}

.blog-content .text {
  margin: 12px 0;
  font-size: 13px;
}

@media (min-width: 576px) {
  .blog-container .blog-content .text {
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    line-height: 18px;
    max-height: 108px;
    -webkit-line-clamp: 6;
    -webkit-box-orient: vertical;
  }
}

@media (min-width: 768px) {
  .blog-container.primary .blog-content .text {
    margin: 13px 0;
    font-size: 16px;
    font-weight: 300;
    line-height: 20px;
    max-height: 140px;
    -webkit-line-clamp: 7;
  }
}

@media (min-width: 768px) {
  .blog-container.primary .text-link {
    color: #eee;
  }
}

.blog-content .post-avatar {
  padding-right: 5px;
  padding-top: 3px;
}

.blog-more {
  width: 0%;
  height: 100%;
  color: #aaa;
  background-color: var(--link-color);
  position: absolute;
  top: 0;
  opacity: 0;
  text-align: center;
  -o-transition: all 0.4s ease-out 0s;
  transition: all 0.4s ease-out 0s;
}

.blog-more span {
  position: absolute;
  top: calc(50% - 22px);
  left: calc(50% - 45px);
  border: 1px solid #fff;
  display: inline-block;
  padding: 10px 30px;
  border-radius: 16px;
  color: #fff;
  font-size: 16px;
}

.blog-container:hover .blog-more {
  width: 100%;
  opacity: 0.95;
}

/* -- */

/* blog */
.blog {
  position: relative;
  border-radius: 16px;
}

.blog-wrapper {
  background: #fff;
  padding: 30px;
  border-radius: 16px 16px 0 0;
}

.blog-wrapper.no-footer {
  border-radius: 16px;
}

body.night-mode .blog-wrapper {
  background: var(--card-dark-color);
}

.blog-wrapper h3 {
  margin-top: 0;
  margin-bottom: 20px;
}

/*//nb##: BLOG detail hero 参照 demo-pages/preview1.html 的 cover 大图覆层样式，聚合标题摘要与元信息，正文仍走原模板逻辑 BEGIN*/
.sg-blog-hero {
  --sg-blog-hero-title: #f0ebe0;
  --sg-blog-hero-text: rgba(240, 235, 224, 0.82);
  --sg-blog-hero-muted: rgba(240, 235, 224, 0.62);
  --sg-blog-hero-border: rgba(240, 235, 224, 0.18);
  --sg-blog-hero-glass: rgba(20, 24, 29, 0.28);
  --sg-blog-hero-shadow: 0 14px 48px rgba(0, 0, 0, 0.34);
  position: relative;
  display: flex;
  align-items: flex-end;
  min-height: clamp(300px, 50vw, 580px);
  overflow: hidden;
  background: #16181d;
}

body.night-mode .sg-blog-hero {
  --sg-blog-hero-title: #f3eee4;
  --sg-blog-hero-text: rgba(243, 238, 228, 0.84);
  --sg-blog-hero-muted: rgba(243, 238, 228, 0.64);
  --sg-blog-hero-border: rgba(255, 255, 255, 0.16);
  --sg-blog-hero-glass: rgba(255, 255, 255, 0.08);
  --sg-blog-hero-shadow: 0 16px 52px rgba(0, 0, 0, 0.46);
  background: #12141a;
}

.sg-blog-hero--no-cover {
  min-height: auto;
  background: linear-gradient(135deg, #16181d 0%, #262a33 100%);
}

.sg-blog-hero__img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  filter: brightness(0.6) saturate(0.75);
  transform: scale(1.02);
  transition: transform 7s ease;
  will-change: transform;
}

.sg-blog-hero:hover .sg-blog-hero__img {
  transform: scale(1.06);
}

/* nb##: BLOG hero/目录 hero 封面改为宽度优先，图片按原始比例参与布局，避免 4:1 cover 被固定高度再次裁切 */
.sg-blog-hero--fluid-cover {
  display: grid;
  min-height: 0;
  align-items: end;
}

.sg-blog-hero--fluid-cover .sg-blog-hero__img {
  grid-area: 1 / 1;
  position: relative;
  inset: auto;
  display: block;
  width: 100%;
  height: auto;
  object-fit: contain;
  object-position: center top;
  transform: none;
}

.sg-blog-hero--fluid-cover:hover .sg-blog-hero__img {
  transform: none;
}

.sg-blog-hero--fluid-cover .sg-blog-hero__overlay,
.sg-blog-hero--fluid-cover .sg-hero__content {
  grid-area: 1 / 1;
}

.sg-blog-hero--fluid-cover .sg-hero__content {
  align-self: end;
  width: 100%;
  margin-top: 0;
  padding-top: clamp(4rem, 10vw, 8rem);
}

.sg-blog-hero__overlay {
  position: absolute;
  inset: 0;
}

.sg-blog-hero__overlay {
  background: linear-gradient(
    to top,
    rgba(16, 18, 22, 0.97) 0%,
    rgba(16, 18, 22, 0.74) 34%,
    rgba(16, 18, 22, 0.28) 70%,
    rgba(16, 18, 22, 0.04) 100%
  );
}

body.night-mode .sg-blog-hero__overlay {
  background: linear-gradient(
    to top,
    rgba(10, 12, 16, 0.98) 0%,
    rgba(10, 12, 16, 0.78) 36%,
    rgba(10, 12, 16, 0.32) 72%,
    rgba(10, 12, 16, 0.06) 100%
  );
}

.sg-blog-hero--no-cover .sg-blog-hero__overlay {
  background: linear-gradient(
    135deg,
    rgba(var(--sg-theme-accent-rgb), 0.26) 0%,
    rgba(22, 24, 29, 0.94) 100%
  );
}

body.night-mode .sg-blog-hero--no-cover .sg-blog-hero__overlay {
  background: linear-gradient(
    135deg,
    rgba(var(--sg-theme-accent-rgb), 0.3) 0%,
    rgba(18, 20, 26, 0.96) 100%
  );
}

.sg-blog-hero .sg-hero__content {
  position: relative;
  z-index: 2;
  width: 100%;
  padding-top: 3.5rem;
  padding-bottom: 2.75rem;
}

.sg-blog-hero__inner {
  max-width: 900px;
}

.sg-blog-hero__toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 0.9rem 1.25rem;
  margin-bottom: 1rem;
}

.sg-blog-hero__edit {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.45rem 0.9rem;
  border: 1px solid var(--sg-blog-hero-border);
  border-radius: 2px;
  background: var(--sg-blog-hero-glass);
  color: var(--sg-blog-hero-text);
  font-family:
    system-ui,
    -apple-system,
    BlinkMacSystemFont,
    "Segoe UI",
    Helvetica,
    Arial,
    "Microsoft YaHei",
    sans-serif;
  font-size: 0.86rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  line-height: 1;
  text-decoration: none;
  text-transform: uppercase;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: var(--sg-blog-hero-shadow);
  transition:
    border-color 0.18s ease,
    background-color 0.18s ease,
    color 0.18s ease,
    transform 0.18s ease;
}

.sg-blog-hero__edit:hover,
.sg-blog-hero__edit:focus {
  color: var(--sg-theme-accent-text);
  border-color: var(--sg-theme-accent);
  background: var(--sg-theme-accent);
  transform: translateY(-1px);
}

.sg-blog-hero__badge {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  margin-bottom: 0.95rem;
  padding: 0.28rem 0.72rem;
  border-radius: 2px;
  background: var(--sg-theme-accent);
  color: var(--sg-theme-accent-text);
  font-family:
    system-ui,
    -apple-system,
    BlinkMacSystemFont,
    "Segoe UI",
    Helvetica,
    Arial,
    "Microsoft YaHei",
    sans-serif;
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  line-height: 1;
  text-decoration: none;
  text-transform: uppercase;
  transition:
    opacity 0.18s ease,
    transform 0.18s ease;
}

.sg-blog-hero__badge:hover,
.sg-blog-hero__badge:focus {
  color: var(--sg-theme-accent-text);
  opacity: 0.9;
  transform: translateY(-1px);
}

.sg-blog-hero__title {
  margin: 0 0 1rem;
  color: var(--sg-blog-hero-title);
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(1.9rem, 4.2vw, 3.25rem);
  font-weight: 700;
  letter-spacing: -0.01em;
  line-height: 1.18;
  max-width: 760px;
  text-shadow: 0 2px 24px rgba(0, 0, 0, 0.7);
}

body.night-mode .sg-blog-hero__title {
  text-shadow: 0 2px 24px rgba(0, 0, 0, 0.78);
}

.sg-blog-hero__meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.65rem 1.1rem;
}

.sg-blog-hero__meta-item,
.sg-blog-hero__author {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  color: var(--sg-blog-hero-text);
  font-family:
    system-ui,
    -apple-system,
    BlinkMacSystemFont,
    "Segoe UI",
    Helvetica,
    Arial,
    "Microsoft YaHei",
    sans-serif;
  font-size: 0.94rem;
  font-weight: 500;
  line-height: 1.3;
  text-decoration: none;
}

.sg-blog-hero__author:hover,
.sg-blog-hero__author:focus,
.sg-blog-hero__meta-item[href]:hover,
.sg-blog-hero__meta-item[href]:focus {
  color: var(--sg-theme-accent);
}

.sg-blog-hero__meta-item .sg-stat-number {
  font-size: 1.08rem;
  font-weight: 700;
  line-height: 1;
}

.sg-blog-hero__author-avatar {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 1px solid rgba(var(--sg-theme-accent-rgb), 0.52);
  object-fit: cover;
  box-shadow: none;
}

.sg-blog-hero__meta-dot {
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--sg-blog-hero-muted);
  opacity: 0.45;
}

.sg-blog-hero__status {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.36rem 0.72rem;
  border: 1px solid rgba(var(--sg-theme-accent-rgb), 0.34);
  border-radius: 2px;
  background: rgba(var(--sg-theme-accent-rgb), 0.14);
  color: var(--sg-theme-accent);
  font-family:
    system-ui,
    -apple-system,
    BlinkMacSystemFont,
    "Segoe UI",
    Helvetica,
    Arial,
    "Microsoft YaHei",
    sans-serif;
  font-size: 0.9rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1;
  text-transform: uppercase;
}

.blog-wrapper--hero-body {
  padding-top: 36px;
}

.blog-detail-summary {
  position: relative;
  margin-top: 0.25rem;
  padding: 1.1rem 1.25rem 1.1rem 1.5rem;
  border: 1px solid rgba(var(--sg-theme-accent-rgb), 0.18);
  border-radius: 10px;
  background: linear-gradient(
    135deg,
    rgba(var(--sg-theme-accent-rgb), 0.08) 0%,
    rgba(255, 255, 255, 0.96) 100%
  );
  box-shadow: 0 14px 34px rgba(12, 18, 28, 0.08);
}

body.night-mode .blog-detail-summary {
  border-color: rgba(var(--sg-theme-accent-rgb), 0.22);
  background: linear-gradient(
    135deg,
    rgba(var(--sg-theme-accent-rgb), 0.12) 0%,
    rgba(22, 28, 38, 0.96) 100%
  );
  box-shadow: 0 16px 38px rgba(0, 0, 0, 0.24);
}

.blog-detail-summary::before {
  content: "";
  position: absolute;
  inset: 16px auto 16px 0;
  width: 4px;
  border-radius: 999px;
  background: var(--sg-theme-accent);
}

.blog-detail-summary__text {
  margin: 0;
  color: #2b3642;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 1.04rem;
  line-height: 1.9;
}

body.night-mode .blog-detail-summary__text {
  color: rgba(240, 244, 255, 0.88);
}

@media (max-width: 991.98px) {
  .sg-blog-hero {
    min-height: clamp(260px, 58vw, 400px);
  }

  .sg-blog-hero .sg-hero__content {
    padding-top: 2.6rem;
    padding-bottom: 2.2rem;
  }
}

@media (max-width: 767.98px) {
  /*//nb##: BLOG detail mobile layout 收紧 container/row/col 的外层 gutter，修正右侧离屏幕留白 BEGIN*/
  .sg-blog-page-layout--detail {
    padding-right: 0;
    padding-left: 0;
  }

  .sg-blog-page-layout--detail > .row,
  .sg-blog-page-layout--detail > .row > .sg-offcanvas-mainbar > .row {
    --bs-gutter-x: 0;
    margin-right: 0;
    margin-left: 0;
  }

  .sg-blog-page-layout--detail > .row > .sg-offcanvas-mainbar,
  .sg-blog-page-layout--detail > .row > .sg-offcanvas-mainbar > .col-lg-8,
  .sg-blog-page-layout--detail > .row > .sg-offcanvas-mainbar > .col-lg-4 {
    padding-right: 0;
    padding-left: 0;
  }
  /*//nb##: END*/

  .sg-blog-hero__toolbar {
    align-items: flex-start;
  }

  .sg-blog-hero__title {
    font-size: clamp(1.6rem, 9vw, 2.45rem);
  }

  .sg-blog-hero__meta-dot {
    display: none;
  }

  .sg-blog-hero__meta {
    gap: 0.65rem 0.85rem;
  }

  .blog-wrapper--hero-body {
    padding-top: 28px;
  }

  .blog-detail-summary {
    padding: 1rem 1rem 1rem 1.3rem;
  }

  .blog-detail-summary__text {
    font-size: 0.96rem;
    line-height: 1.75;
  }
}
/*//nb##: END*/

/*//nb##: BLOG detail 正文与作者栏改为对齐 demo-pages/view1.html 的 prose/widget 视觉，同时保留现有交互结构 BEGIN*/
.sg-blog-hero__inner {
  max-width: none;
}

.sg-blog-hero__toolbar {
  justify-content: flex-start;
  gap: 0.75rem 1.1rem;
  margin-bottom: 0.9rem;
}

.sg-blog-hero__meta-row {
  display: flex;
  align-items: flex-start;
  gap: 1rem 1.5rem;
  width: 100%;
}

.sg-blog-hero__meta {
  flex: 1 1 auto;
  min-width: 0;
}

.sg-blog-hero__edit--side {
  width: auto;
  justify-content: center;
}

.sg-blog-hero__edit--create {
  padding-inline: 0.72rem;
}

.sg-blog-hero__actions {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-left: auto;
  flex-shrink: 0;
}

.sg-blog-hero__actions--side {
  width: auto;
  max-width: 100%;
  flex-wrap: wrap;
  justify-content: flex-end;
  margin-left: 0;
}

.sg-blog-directory-hero__desc {
  margin: 0;
  max-width: 100%;
  color: var(--sg-blog-hero-text);
  font-size: 1rem;
  line-height: 1.82;
}

.sg-blog-directory-hero__actions {
  width: 100%;
  margin-top: 1.15rem;
  margin-left: 0;
  justify-content: flex-end;
}

/* nb##: 目录页 hero copy 区整体下沉并贴近底部 CTA，避免 breadcrumb/标题/简介悬在封面中上段 */
.sg-blog-directory-hero__layout {
  row-gap: 0.7rem;
}

.sg-blog-directory-hero .sg-hero__content {
  padding-bottom: 1.6rem;
}

.sg-blog-directory-hero.sg-blog-hero--fluid-cover .sg-hero__content {
  padding-top: 0;
}

.sg-blog-directory-hero .sg-blog-hero__inner {
  padding-top: clamp(2.5rem, 7vw, 5.5rem);
}

.sg-blog-directory-hero.sg-blog-hero--fluid-cover .sg-blog-hero__inner {
  padding-top: clamp(1rem, 2.8vw, 1.9rem);
}

.sg-blog-directory-hero .sg-blog-hero__toolbar {
  margin-bottom: 0.55rem;
}

.sg-blog-directory-hero .sg-blog-hero__badge {
  margin-bottom: 0.55rem;
}

.sg-blog-directory-hero .sg-blog-hero__title {
  margin-bottom: 0.5rem;
}

.sg-blog-directory-hero .sg-blog-directory-hero__actions {
  margin-top: 0;
}

/* nb##: TAG landing hero 去掉目录页无封面时的深色底板，改回正文页同级的纯内容呈现 */
.sg-blog-directory-hero--tag {
  --sg-blog-hero-title: #0f172a;
  --sg-blog-hero-text: #1f2937;
  --sg-blog-hero-muted: #64748b;
  --sg-blog-hero-border: rgba(30, 41, 59, 0.12);
  --sg-blog-hero-glass: rgba(255, 255, 255, 0);
  --sg-blog-hero-shadow: none;
  min-height: auto;
  background: transparent;
}

.sg-blog-directory-hero--tag .sg-blog-hero__overlay {
  display: none;
}

.sg-blog-directory-hero--tag .sg-blog-hero__title {
  max-width: none;
  text-shadow: none;
}

body.night-mode .sg-blog-directory-hero--tag {
  --sg-blog-hero-title: rgba(243, 238, 228, 0.96);
  --sg-blog-hero-text: rgba(243, 238, 228, 0.84);
  --sg-blog-hero-muted: rgba(243, 238, 228, 0.64);
  --sg-blog-hero-border: rgba(255, 255, 255, 0.12);
  --sg-blog-hero-glass: rgba(255, 255, 255, 0);
  background: transparent;
}

body.night-mode .sg-blog-directory-hero--tag .sg-blog-hero__title {
  text-shadow: none;
}

.sg-blog-detail-grid,
.sg-blog-article-detail {
  --sg-article-surface: #ffffff;
  --sg-article-surface-soft: #f8f3ea;
  --sg-article-surface-soft-2: #efe5d7;
  --sg-article-border: rgba(30, 41, 59, 0.1);
  --sg-article-border-strong: rgba(30, 41, 59, 0.14);
  --sg-article-shadow-sm: 0 16px 32px rgba(15, 23, 42, 0.06);
  --sg-article-shadow-md: 0 24px 48px rgba(15, 23, 42, 0.08);
  --sg-article-text: #29323d;
  --sg-article-text-sub: #647082;
  --sg-article-text-muted: #8591a0;
  --sg-article-text-faint: #a3adb8;
  --sg-article-quote-bg: linear-gradient(
    135deg,
    rgba(var(--sg-theme-accent-rgb), 0.08) 0%,
    #fcfaf5 100%
  );
  --sg-article-tag-bg: rgba(var(--sg-theme-accent-rgb), 0.1);
  --sg-article-tag-border: rgba(var(--sg-theme-accent-rgb), 0.18);
}

body.night-mode .sg-blog-detail-grid,
body.night-mode .sg-blog-article-detail {
  --sg-article-surface: #131820;
  --sg-article-surface-soft: #1b212b;
  --sg-article-surface-soft-2: #212836;
  --sg-article-border: rgba(255, 255, 255, 0.08);
  --sg-article-border-strong: rgba(255, 255, 255, 0.14);
  --sg-article-shadow-sm: 0 16px 32px rgba(0, 0, 0, 0.2);
  --sg-article-shadow-md: 0 26px 52px rgba(0, 0, 0, 0.28);
  --sg-article-text: rgba(240, 244, 255, 0.92);
  --sg-article-text-sub: rgba(209, 217, 231, 0.8);
  --sg-article-text-muted: rgba(188, 197, 213, 0.64);
  --sg-article-text-faint: rgba(174, 184, 201, 0.48);
  --sg-article-quote-bg: linear-gradient(
    135deg,
    rgba(var(--sg-theme-accent-rgb), 0.16) 0%,
    rgba(27, 33, 43, 0.96) 100%
  );
  --sg-article-tag-bg: rgba(var(--sg-theme-accent-rgb), 0.16);
  --sg-article-tag-border: rgba(var(--sg-theme-accent-rgb), 0.24);
}

.sg-blog-detail-grid {
  align-items: flex-start;
}

.sg-blog-article-detail {
  background: transparent;
  border: 0;
  box-shadow: none;
}

.sg-blog-article-shell {
  background: transparent;
  padding: 0;
  border-radius: 0;
  box-shadow: none;
}

body.night-mode .sg-blog-article-shell {
  background: transparent;
}

.blog-wrapper--hero-body {
  padding-top: 40px;
}

/* nb##: BLOG 详情右栏在 Hero 预览场景下同步正文的顶部内边距，保证外层列与正文内容起始线对齐 */
.sg-blog-detail-grid .sg-blog-detail-sidebar-col--hero-offset {
  padding-top: 40px;
}

.sg-blog-article-detail .blog-detail-summary {
  margin: 0 0 2.2rem;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

body.night-mode .sg-blog-article-detail .blog-detail-summary {
  background: transparent;
  box-shadow: none;
}

.sg-blog-article-detail .blog-detail-summary::before {
  display: none;
}

.sg-blog-article-detail .sg-article-tags {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.65rem 0.8rem;
  margin-top: 2.35rem;
}

.sg-blog-article-detail .sg-article-tags__label {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  color: var(--sg-article-text-muted);
  font-family: "IBM Plex Sans", "Segoe UI", Helvetica, Arial, sans-serif;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  line-height: 1;
  text-transform: uppercase;
}

.sg-blog-article-detail .sg-article-tags__label .fa-tags {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1em;
  line-height: 1;
}

.sg-blog-article-detail .sg-article-tags__label i,
.sg-blog-article-detail .sg-article-tags__label .fa-tags {
  color: var(--sg-theme-accent);
}

.sg-blog-article-detail .blog-tags {
  margin-top: 0;
}

.sg-blog-article-detail .blog-tags ul {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.sg-blog-article-detail .blog-tags ul > li {
  margin: 0;
}

.sg-blog-article-detail .blog-tags ul > li > a {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  padding: 0.35rem 0.82rem;
  border: 1px solid var(--sg-article-tag-border);
  border-radius: 999px;
  background: var(--sg-article-tag-bg);
  color: var(--sg-theme-accent);
  font-family: "IBM Plex Sans", "Segoe UI", Helvetica, Arial, sans-serif;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.07em;
  line-height: 1.1;
  text-decoration: none;
  text-transform: uppercase;
  transition:
    border-color 0.18s ease,
    background-color 0.18s ease,
    color 0.18s ease,
    transform 0.18s ease;
}

.sg-blog-article-detail .blog-tags ul > li > a:hover,
.sg-blog-article-detail .blog-tags ul > li > a:focus {
  background: var(--sg-theme-accent);
  border-color: var(--sg-theme-accent);
  color: var(--sg-theme-accent-text);
  transform: translateY(-1px);
}

.sg-blog-article-detail .post-stats {
  display: flex;
  align-items: center;
  padding: 0 0 0.18rem;
  margin-top: 1.15rem;
  margin-bottom: 0;
  border: 0;
  border-bottom: 1px solid var(--sg-article-border-strong);
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.sg-blog-article-detail .post-stats .float-start {
  float: none !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

.sg-blog-article-detail .post-stats .reactions-stats {
  display: inline-flex;
  align-items: flex-end;
  gap: 0.4rem;
  color: var(--sg-article-text-sub);
}

.sg-blog-article-detail .post-stats .reactions-stats > .reactions-stats-item {
  padding: 4px;
}

.sg-blog-article-detail .post-stats .inline-emoji {
  width: 44px;
  height: 44px;
}

.sg-blog-article-detail .post-stats .inline-emoji .emoji {
  width: 44px;
  height: 44px;
}

.sg-blog-article-detail .post-stats .inline-emoji .emoji img {
  width: 44px;
  height: 44px;
}

.sg-blog-article-detail .post-stats .reactions-stats span {
  align-self: flex-end;
  font-family: "IBM Plex Sans", "Segoe UI", Helvetica, Arial, sans-serif;
  font-size: 0.82rem;
  font-weight: 600;
  line-height: 1;
  padding-bottom: 4px;
}

.sg-blog-article-detail .post-actions {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 0.75rem;
  padding: 1rem 0 0;
  border-top: 0;
}

.sg-blog-article-detail .post-stats + .post-actions {
  padding-top: 0.12rem;
}

.sg-blog-article-detail .post-actions .action-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
  min-height: 48px;
  padding: 0.7rem 1rem;
  border: 1px solid var(--sg-article-border-strong);
  border-radius: 10px;
  background: var(--sg-article-surface);
  box-shadow: var(--sg-article-shadow-sm);
  transition:
    border-color 0.18s ease,
    background-color 0.18s ease,
    color 0.18s ease,
    transform 0.18s ease;
}

.sg-blog-article-detail .post-actions .action-btn:hover,
.sg-blog-article-detail .post-actions .action-btn:focus {
  border-color: rgba(var(--sg-theme-accent-rgb), 0.3);
  background: rgba(var(--sg-theme-accent-rgb), 0.08);
  color: var(--sg-theme-accent);
  transform: translateY(-1px);
}

.sg-blog-article-detail .post-actions .reactions-wrapper:hover,
.sg-blog-article-detail .post-actions .reactions-wrapper:focus-within {
  transform: none;
}

.sg-blog-article-detail .post-actions .reaction-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
}

.sg-blog-article-detail .post-actions .action-icon {
  margin-left: 0 !important;
  margin-right: 0 !important;
}

.sg-blog-article-detail .post-actions .sg-blog-action-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.5rem;
  padding: 0.12rem 0.35rem;
  border-radius: 999px;
  background: rgba(var(--sg-theme-accent-rgb), 0.12);
  color: var(--sg-theme-accent);
  font-family: "IBM Plex Sans", "Segoe UI", Helvetica, Arial, sans-serif;
  font-size: 0.8rem;
  font-style: italic;
  font-weight: 800;
  line-height: 1;
}

.sg-blog-article-detail .post-actions .sg-blog-action-btn--tip {
  border-color: rgba(214, 138, 0, 0.22);
  background: linear-gradient(
    135deg,
    rgba(255, 245, 214, 0.98) 0%,
    rgba(255, 233, 162, 0.95) 100%
  );
  color: #8c5a00;
  box-shadow:
    0 10px 24px rgba(214, 138, 0, 0.16),
    inset 0 1px 0 rgba(255, 255, 255, 0.55);
  font-weight: 700;
}

.sg-blog-article-detail .post-actions .sg-blog-action-btn--tip:hover,
.sg-blog-article-detail .post-actions .sg-blog-action-btn--tip:focus {
  border-color: rgba(214, 138, 0, 0.45);
  background: linear-gradient(
    135deg,
    rgba(255, 240, 196, 1) 0%,
    rgba(255, 224, 136, 0.98) 100%
  );
  color: #6d4200;
  box-shadow:
    0 14px 30px rgba(214, 138, 0, 0.22),
    inset 0 1px 0 rgba(255, 255, 255, 0.62);
}

.sg-blog-article-detail .post-actions .sg-blog-action-btn--tip .action-icon,
.sg-blog-article-detail .post-actions .sg-blog-action-btn--tip span {
  color: inherit;
}

.sg-blog-article-detail .post-actions .sg-blog-action-btn--saved {
  border-color: rgba(var(--sg-theme-accent-rgb), 0.34);
  background: linear-gradient(
    135deg,
    rgba(var(--sg-theme-accent-rgb), 0.18) 0%,
    rgba(var(--sg-theme-accent-rgb), 0.1) 100%
  );
  color: var(--sg-theme-accent);
  box-shadow:
    0 10px 24px rgba(var(--sg-theme-accent-rgb), 0.14),
    inset 0 1px 0 rgba(255, 255, 255, 0.55);
  font-weight: 700;
}

.sg-blog-article-detail .post-actions .sg-blog-action-btn--saved:hover,
.sg-blog-article-detail .post-actions .sg-blog-action-btn--saved:focus {
  border-color: rgba(var(--sg-theme-accent-rgb), 0.48);
  background: linear-gradient(
    135deg,
    rgba(var(--sg-theme-accent-rgb), 0.22) 0%,
    rgba(var(--sg-theme-accent-rgb), 0.14) 100%
  );
  color: var(--sg-theme-accent);
  box-shadow:
    0 14px 30px rgba(var(--sg-theme-accent-rgb), 0.18),
    inset 0 1px 0 rgba(255, 255, 255, 0.62);
}

.sg-blog-article-detail .post-actions .sg-blog-action-btn--saved i,
.sg-blog-article-detail .post-actions .sg-blog-action-btn--saved span {
  color: inherit;
}

.sg-blog-article-detail .post-actions .reactions-container {
  bottom: auto;
  z-index: 30;
}

.sg-blog-article-detail .post-footer {
  margin-top: 1.25rem;
  padding: 1.35rem 1.5rem;
  border: 1px solid var(--sg-article-border-strong);
  border-radius: 14px;
  background: var(--sg-article-surface);
  box-shadow: var(--sg-article-shadow-sm);
}

.sg-blog-article-detail .post-footer .ptb10 {
  padding: 0;
}

/* nb##: BLOG 详情页把 Comment 入口提升到评论区右上角，正文尾部不再重复放入口按钮 */
.sg-blog-article-detail .sg-blog-comments-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 0.9rem;
  margin-bottom: 1rem;
}

.sg-blog-article-detail .sg-blog-comments-toolbar__hint {
  display: inline-flex;
  align-items: center;
  white-space: nowrap;
  gap: 0.4rem;
  color: var(--sg-article-text-muted);
  font-size: 0.96rem;
  font-weight: 600;
  line-height: 1.2;
}

.sg-blog-article-detail .sg-blog-comments-toolbar__count {
  color: var(--sg-article-text);
  font-weight: 700;
}

.sg-blog-article-detail .sg-blog-comments-toolbar__separator,
.sg-blog-article-detail .sg-blog-comments-toolbar__label {
  color: inherit;
}

/* nb##: 评论头部图标不再单独指定颜色，统一跟随文字继承 */
.sg-blog-article-detail .sg-blog-comments-toolbar__icon {
  flex: 0 0 auto;
}

.sg-blog-article-detail .sg-blog-comments-toolbar__hint svg,
.sg-blog-article-detail .sg-blog-comments-toolbar__hint i {
  display: block;
}

@media (max-width: 575.98px) {
  .sg-blog-article-detail .sg-blog-comments-toolbar {
    align-items: flex-start;
  }

  .sg-blog-article-detail .sg-blog-comments-toolbar__hint {
    font-size: 0.9rem;
  }
}

/* nb##: BLOG 详情页评论区改成按钮式交互，并把一级回复收敛为整块底色卡片 */
.sg-blog-article-detail .post-comments .comment-avatar {
  position: relative;
}

.sg-blog-article-detail .post-comments .comment-online-dot {
  position: absolute;
  right: 2px;
  bottom: 2px;
  font-size: 8px;
  border: 2px solid #fff;
  border-radius: 50%;
  color: #65a830;
  line-height: 1;
}

body.night-mode .sg-blog-article-detail .post-comments .comment-online-dot {
  border-color: var(--card-dark-color);
}

.sg-blog-article-detail .post-comments .comment-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.55rem;
}

.sg-blog-article-detail .post-comments .comment-actions > li {
  float: none;
  margin-right: 0;
}

.sg-blog-article-detail .post-comments .comment-actions__time {
  order: 1;
}

.sg-blog-article-detail .post-comments .comment-actions__edit {
  order: 2;
  display: block !important;
}

.sg-blog-article-detail .post-comments .comment-actions__delete {
  order: 3;
  display: block !important;
}

.sg-blog-article-detail .post-comments .comment-actions__stats {
  order: 4;
  margin-left: 0;
}

.sg-blog-article-detail .post-comments .comment-actions__react {
  order: 5;
  margin-left: auto;
}

.sg-blog-article-detail .post-comments .comment-actions__reply {
  order: 6;
  margin-left: 0;
}

.sg-blog-article-detail .post-comments .comment-btn--with-manage {
  display: none;
}

.sg-blog-article-detail .post-comments .comment-action-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
  min-height: 34px;
  padding: 0.38rem 0.9rem;
  border: 1px solid rgba(var(--sg-theme-accent-rgb), 0.16);
  border-radius: 999px;
  background: #fff;
  color: var(--sg-article-heading);
  font-family: "IBM Plex Sans", "Segoe UI", Helvetica, Arial, sans-serif;
  font-size: 0.82rem;
  font-weight: 600;
  line-height: 1;
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.05);
  transition:
    border-color 0.18s ease,
    background-color 0.18s ease,
    color 0.18s ease,
    box-shadow 0.18s ease,
    transform 0.18s ease;
}

body.night-mode .sg-blog-article-detail .post-comments .comment-action-btn {
  background: var(--card-dark-input);
  color: var(--card-dark-color-text);
}

.sg-blog-article-detail .post-comments .comment-action-btn:hover,
.sg-blog-article-detail .post-comments .comment-action-btn:focus,
.sg-blog-article-detail .post-comments .comment-action-btn:focus-within {
  border-color: rgba(var(--sg-theme-accent-rgb), 0.38);
  background: rgba(var(--sg-theme-accent-rgb), 0.08);
  color: var(--sg-theme-accent);
  box-shadow: 0 12px 24px rgba(var(--sg-theme-accent-rgb), 0.12);
  transform: translateY(-1px);
}

.sg-blog-article-detail .post-comments .comment-action-btn--react:hover,
.sg-blog-article-detail .post-comments .comment-action-btn--react:focus,
.sg-blog-article-detail .post-comments .comment-action-btn--react:focus-within {
  transform: none;
}

.sg-blog-article-detail .post-comments .comment-action-btn .reaction-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
}

.sg-blog-article-detail
  .post-comments
  .comment-action-btn--react
  .reaction-btn-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
  line-height: 1;
}

.sg-blog-article-detail
  .post-comments
  .comment-action-btn--react
  .reaction-btn-icon
  .inline-emoji {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
}

.sg-blog-article-detail
  .post-comments
  .comment-action-btn--react
  .reaction-btn-icon
  .inline-emoji
  .emoji {
  position: static;
  top: auto;
  right: auto;
  transform: scale(0.15);
}

.sg-blog-article-detail
  .post-comments
  .comment-action-btn--react
  .reaction-btn-name {
  display: inline-flex;
  align-items: center;
  line-height: 1;
}

.sg-blog-article-detail .post-comments .comment-action-btn .reaction-btn-name,
.sg-blog-article-detail .post-comments .comment-action-btn .reaction-btn-icon,
.sg-blog-article-detail
  .post-comments
  .comment-action-btn
  .reaction-btn-icon
  i {
  color: inherit !important;
}

.sg-blog-article-detail .post-comments .comment-action-btn--reply.has-replies {
  border-color: rgba(var(--sg-theme-accent-rgb), 0.34);
  background: rgba(var(--sg-theme-accent-rgb), 0.1);
  color: var(--sg-theme-accent);
}

.sg-blog-article-detail .post-comments .comment-action-btn--reply.is-active {
  border-color: rgba(var(--sg-theme-accent-rgb), 0.5);
  background: rgba(var(--sg-theme-accent-rgb), 0.15);
  color: var(--sg-theme-accent);
  box-shadow: 0 14px 26px rgba(var(--sg-theme-accent-rgb), 0.14);
}

.sg-blog-article-detail .post-comments .comment-action-btn__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.45rem;
  padding: 0.15rem 0.38rem;
  border-radius: 999px;
  background: rgba(var(--sg-theme-accent-rgb), 0.12);
  color: inherit;
  font-size: 0.72rem;
  font-style: italic;
  font-weight: 800;
  line-height: 1;
}

.sg-blog-article-detail
  .post-comments
  .comment-action-btn--reply.has-replies
  .comment-action-btn__count,
.sg-blog-article-detail
  .post-comments
  .comment-action-btn--reply.is-active
  .comment-action-btn__count {
  background: #fff;
}

body.night-mode
  .sg-blog-article-detail
  .post-comments
  .comment-action-btn--reply.has-replies
  .comment-action-btn__count,
body.night-mode
  .sg-blog-article-detail
  .post-comments
  .comment-action-btn--reply.is-active
  .comment-action-btn__count {
  background: rgba(255, 255, 255, 0.14);
}

.sg-blog-article-detail .post-comments .comment-manage-btn {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  min-width: 30px;
  min-height: 30px;
  padding: 0;
  border: 1px solid rgba(15, 23, 42, 0.1);
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.03);
  color: var(--sg-article-text-muted);
  font-family: "IBM Plex Sans", "Segoe UI", Helvetica, Arial, sans-serif;
  font-size: 0.82rem;
  font-weight: 700;
  line-height: 1;
  transition:
    border-color 0.18s ease,
    background-color 0.18s ease,
    color 0.18s ease;
}

.sg-blog-article-detail .post-comments .comment-manage-btn i {
  line-height: 1;
}

body.night-mode .sg-blog-article-detail .post-comments .comment-manage-btn {
  border-color: rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.05);
  color: rgba(255, 255, 255, 0.74);
}

.sg-blog-article-detail .post-comments .comment-manage-btn:hover,
.sg-blog-article-detail .post-comments .comment-manage-btn:focus {
  border-color: rgba(var(--sg-theme-accent-rgb), 0.3);
  background: rgba(var(--sg-theme-accent-rgb), 0.08);
  color: var(--sg-theme-accent);
}

.sg-blog-article-detail .post-comments .comment-manage-btn--delete:hover,
.sg-blog-article-detail .post-comments .comment-manage-btn--delete:focus {
  border-color: rgba(220, 38, 38, 0.28);
  background: rgba(220, 38, 38, 0.08);
  color: #c62828;
}

.sg-blog-article-detail
  .post-comments
  .comment-actions__stats
  .reactions-stats {
  display: inline-flex;
  align-items: center;
  gap: 0.05rem;
}

.sg-blog-article-detail
  .post-comments
  .comment-actions__stats
  .reactions-stats
  > span {
  font-size: 0.74rem;
  margin-left: 2px;
}

.sg-blog-article-detail
  .post-comments
  .comment-actions__stats
  .reactions-stats-item {
  margin-right: -3px;
}

.sg-blog-article-detail .post-comments .comment-actions__stats .inline-emoji {
  transform: scale(0.5);
  transform-origin: center;
}

.sg-blog-article-detail .post-comments .js_replies-toggle {
  display: none !important;
}

.sg-blog-article-detail .post-comments .comment-replies {
  flex-direction: column;
  gap: 0.8rem;
}

.sg-blog-article-detail .post-comments .comment-replies > .js_reply-form {
  order: 1;
}

.sg-blog-article-detail .post-comments .comment-replies > .js_see-more {
  order: 2;
}

.sg-blog-article-detail .post-comments .comment-replies > .js_replies {
  order: 3;
}

.sg-blog-article-detail .post-comments .js_reply-form {
  margin-top: 0.15rem;
}

.sg-blog-article-detail .post-comments .comment-replies > ul > li + li {
  margin-top: 0.85rem;
  padding-top: 0.85rem;
  border-top: 1px solid rgba(15, 23, 42, 0.08);
}

.sg-blog-article-detail
  .post-comments
  .comment-replies
  > ul
  > li
  > .comment.reply {
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

body.night-mode
  .sg-blog-article-detail
  .post-comments
  .comment-replies
  > ul
  > li
  + li {
  border-top-color: rgba(255, 255, 255, 0.1);
}

.sg-blog-article-detail .post-comments .comment.reply .comment-inner {
  padding: 0;
  background: transparent;
  box-shadow: none;
}

.sg-blog-article-detail .post-comments .comment.reply .comment-inner::before {
  display: none;
}

.sg-blog-article-detail .post-comments .comment.reply .comment-inner-wrapper {
  margin-bottom: 0.4rem;
}

.sg-blog-article-detail .post-comments .comment.reply .js_comment-reply-btn {
  display: none;
}

.sg-blog-article-detail
  .post-comments
  .comment-action-btn--react
  .reactions-container {
  z-index: 30;
}

.sg-blog-detail-grid .sg-widget {
  margin-bottom: 1.5rem;
  border: 1px solid var(--sg-article-border-strong);
  border-radius: 12px;
  overflow: hidden;
  background: var(--sg-article-surface);
  /* nb##: BLOG 详情右栏区块去掉卡片阴影，保留边框与底色层级即可 */
  box-shadow: none;
}

.sg-blog-detail-grid .sg-widget__header {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.85rem 1.25rem;
  border-bottom: 1px solid var(--sg-article-border);
}

.sg-blog-detail-grid .sg-widget__title-accent {
  width: 16px;
  height: 2px;
  border-radius: 999px;
  background: var(--sg-theme-accent);
  flex-shrink: 0;
}

.sg-blog-detail-grid .sg-widget__title {
  margin: 0;
  color: var(--sg-article-text-muted);
  font-family: "IBM Plex Sans", "Segoe UI", Helvetica, Arial, sans-serif;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  line-height: 1;
  text-transform: uppercase;
}

.sg-blog-detail-grid .sg-widget__body {
  padding: 1.1rem 1.25rem 1.25rem;
}

.sg-blog-detail-grid .sg-widget__empty {
  padding: 1rem 0;
  color: var(--sg-article-text-muted);
  font-family: "IBM Plex Sans", "Segoe UI", Helvetica, Arial, sans-serif;
  font-size: 0.84rem;
  line-height: 1.6;
  text-align: center;
}

.sg-blog-detail-grid .sg-widget__body.py-0 .sg-related-item:first-child {
  padding-top: 1rem;
}

.sg-blog-detail-grid .sg-widget__body.py-0 .sg-related-item:last-child {
  padding-bottom: 1rem;
}

.sg-blog-detail-grid .sg-widget-author {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  gap: 0.9rem;
}

.sg-blog-detail-grid .sg-widget-author__avatar-link {
  position: relative;
  display: inline-flex;
  flex-shrink: 0;
  line-height: 0;
}

.sg-blog-detail-grid .sg-widget-author__content {
  min-width: 0;
  flex: 1 1 auto;
}

.sg-blog-detail-grid .sg-widget-author__headline {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.3rem 0.45rem;
}

.sg-blog-detail-grid .sg-widget-author__badge {
  display: inline-flex;
  align-items: center;
  line-height: 0;
}

.sg-blog-detail-grid .sg-widget-author__badge .svg-container {
  width: 20px !important;
  height: 20px !important;
}

.sg-blog-detail-grid .sg-widget-author__avatar {
  width: 60px;
  height: 60px;
  border: 2px solid var(--sg-theme-accent);
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
  box-shadow: 0 10px 20px rgba(var(--sg-theme-accent-rgb), 0.18);
}

.sg-blog-detail-grid .sg-widget-author__online-dot {
  position: absolute;
  right: 1px;
  bottom: 1px;
  font-size: 10px;
  border: 3px solid #fff;
  border-radius: 50%;
  color: #65a830;
  line-height: 1;
}

body.night-mode .sg-blog-detail-grid .sg-widget-author__online-dot {
  border-color: var(--card-dark-color);
}

.sg-blog-detail-grid .sg-widget-author__name {
  display: block;
  max-width: 100%;
  color: var(--sg-article-text);
  font-family: Georgia, "Times New Roman", serif;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.3;
  text-decoration: none;
}

.sg-blog-detail-grid .sg-widget-author__name:hover,
.sg-blog-detail-grid .sg-widget-author__name:focus {
  color: var(--sg-theme-accent);
}

.sg-blog-detail-grid .sg-widget-author__role {
  /* nb##: BLOG 详情作者卡片的职称/工作地点保留用户原始大小写，避免被统一转成全大写 */
  margin-top: 0.18rem;
  color: var(--sg-theme-accent);
  font-family: "IBM Plex Sans", "Segoe UI", Helvetica, Arial, sans-serif;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  line-height: 1.4;
  text-transform: none;
}

.sg-blog-detail-grid .sg-widget-author__bio {
  margin: 0;
  color: var(--sg-article-text-sub);
  font-family: "IBM Plex Sans", "Segoe UI", Helvetica, Arial, sans-serif;
  font-size: 0.84rem;
  line-height: 1.65;
  white-space: pre-wrap;
}

.sg-blog-detail-grid .sg-related-item {
  display: flex;
  gap: 0.75rem;
  padding: 0.75rem 0;
  border-bottom: 1px solid var(--sg-article-border);
  color: inherit;
  text-decoration: none;
  transition: opacity 0.18s ease;
}

.sg-blog-detail-grid .sg-related-item:last-child {
  border-bottom: 0;
}

.sg-blog-detail-grid .sg-related-item:hover,
.sg-blog-detail-grid .sg-related-item:focus {
  opacity: 0.82;
  text-decoration: none;
}

.sg-blog-detail-grid .sg-related-item__thumb {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 70px;
  height: 55px;
  border-radius: 6px;
  background: var(--sg-article-surface-soft);
  color: var(--sg-article-text-faint);
  overflow: hidden;
  flex-shrink: 0;
}

.sg-blog-detail-grid .sg-related-item__thumb img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.sg-blog-detail-grid .sg-related-item__thumb--fluid {
  align-items: flex-start;
  height: auto;
}

.sg-blog-detail-grid .sg-related-item__thumb--fluid img {
  height: auto;
  object-fit: contain;
}

.sg-blog-detail-grid .sg-related-item__title {
  margin-bottom: 0.2rem;
  color: var(--sg-article-text);
  font-family: Georgia, "Times New Roman", serif;
  font-size: 0.88rem;
  font-weight: 600;
  line-height: 1.35;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.sg-blog-detail-grid .sg-related-item__meta {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  color: var(--sg-article-text-muted);
  font-family: "IBM Plex Sans", "Segoe UI", Helvetica, Arial, sans-serif;
  font-size: 0.72rem;
  line-height: 1.4;
}

/* nb##: Recommended Articles 右栏卡片改为上图下文，避免缩图与标题在窄侧栏中横向挤压 */
.sg-blog-detail-grid .sg-widget--recommended-articles .sg-related-item {
  display: block;
}

.sg-blog-detail-grid .sg-widget--recommended-articles .sg-related-item__thumb {
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 4;
  margin-bottom: 0.7rem;
  border-radius: 10px;
}

.sg-blog-detail-grid
  .sg-widget--recommended-articles
  .sg-related-item__thumb--fluid {
  aspect-ratio: auto;
}

.sg-blog-detail-grid .sg-widget--recommended-articles .sg-related-item__title {
  margin-bottom: 0.35rem;
}

.sg-blog-detail-grid .sg-hot-topic-list {
  display: flex;
  flex-direction: column;
}

/* nb##: Hot Topics 右栏改为一行一个的媒体卡片，左侧固定圆形缩图，右侧上统计下标题 */
.sg-blog-detail-grid .sg-hot-topic-card {
  display: flex;
  align-items: center;
  gap: 0.9rem;
  padding: 0.8rem 0;
  border-bottom: 1px solid var(--sg-article-border);
  color: inherit;
  text-decoration: none;
  transition: opacity 0.18s ease;
}

.sg-blog-detail-grid .sg-hot-topic-card:last-child {
  border-bottom: 0;
}

.sg-blog-detail-grid .sg-hot-topic-card:hover,
.sg-blog-detail-grid .sg-hot-topic-card:focus {
  opacity: 0.82;
  text-decoration: none;
}

.sg-blog-detail-grid .sg-hot-topic-card__thumb {
  width: 72px;
  height: 72px;
  border-radius: 999px;
  overflow: hidden;
  background: var(--sg-article-surface-soft);
  flex-shrink: 0;
}

.sg-blog-detail-grid .sg-hot-topic-card__thumb img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.sg-blog-detail-grid .sg-hot-topic-card__body {
  min-width: 0;
  flex: 1 1 auto;
}

.sg-blog-detail-grid .sg-hot-topic-card__stats {
  display: flex;
  flex-wrap: wrap;
  gap: 0.2rem 0.5rem;
  margin-bottom: 0.34rem;
  color: var(--sg-article-text-muted);
  font-family: "IBM Plex Sans", "Segoe UI", Helvetica, Arial, sans-serif;
  font-size: 0.78rem;
  font-weight: 600;
  line-height: 1.45;
}

.sg-blog-detail-grid .sg-hot-topic-card__stat {
  display: inline-flex;
  align-items: center;
  gap: 0.32rem;
}

.sg-blog-detail-grid .sg-hot-topic-card__stat .sg-stat-number {
  font-size: 1.08rem;
  line-height: 1;
}

.sg-blog-detail-grid
  .sg-hot-topic-card__stat
  + .sg-hot-topic-card__stat::before {
  content: "|";
  opacity: 0.38;
  margin-inline: 0 0.48rem;
}

.sg-blog-detail-grid .sg-hot-topic-card__name {
  color: var(--sg-article-text);
  font-family: Georgia, "Times New Roman", serif;
  font-size: 1.24rem;
  font-weight: 700;
  line-height: 1.3;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.sg-blog-detail-grid .sg-tag-cloud {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}

.sg-blog-detail-grid .sg-tag {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.34rem 0.82rem;
  border: 1px solid var(--sg-article-tag-border);
  border-radius: 999px;
  background: var(--sg-article-tag-bg);
  color: var(--sg-theme-accent);
  font-family: "IBM Plex Sans", "Segoe UI", Helvetica, Arial, sans-serif;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.07em;
  line-height: 1.1;
  text-decoration: none;
  text-transform: uppercase;
  transition:
    border-color 0.18s ease,
    background-color 0.18s ease,
    color 0.18s ease,
    transform 0.18s ease;
}

.sg-blog-detail-grid .sg-tag .fa-hashtag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1em;
  line-height: 1;
}

.sg-blog-detail-grid .sg-tag:hover,
.sg-blog-detail-grid .sg-tag:focus {
  border-color: var(--sg-theme-accent);
  background: var(--sg-theme-accent);
  color: var(--sg-theme-accent-text);
  text-decoration: none;
  transform: translateY(-1px);
}

.post-social-share {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.8rem;
}

.post-social-share .btn-icon-social {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border-radius: 999px;
  color: var(--sg-article-text-sub);
  transition:
    transform 0.18s ease,
    opacity 0.18s ease;
}

.post-social-share .btn-icon-social .svg-container {
  width: 22px !important;
  height: 22px !important;
}

.post-social-share .btn-icon-social:hover,
.post-social-share .btn-icon-social:focus {
  transform: translateY(-1px);
  opacity: 0.92;
}

.post-social-share .btn-icon-social--facebook {
  color: #1877f2;
}

.post-social-share .btn-icon-social--x {
  color: #111111;
}

.post-social-share .btn-icon-social--vk {
  color: #0077ff;
}

.post-social-share .btn-icon-social--linkedin {
  color: #0a66c2;
}

.post-social-share .btn-icon-social--whatsapp {
  color: #25d366;
}

.post-social-share .btn-icon-social--reddit {
  color: #ff4500;
}

.post-social-share .btn-icon-social--pinterest {
  color: #e60023;
}

body.night-mode .post-social-share .btn-icon-social--x {
  background: #ffffff;
  color: #111111;
}

.sg-blog-detail-grid .sg-author-card__follow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
  min-height: 42px;
  padding: 0.6rem 1rem;
  border: 1px solid rgba(var(--sg-theme-accent-rgb), 0.22);
  border-radius: 999px;
  background: var(--sg-theme-accent-dim);
  color: var(--sg-theme-accent);
  font-family: "IBM Plex Sans", "Segoe UI", Helvetica, Arial, sans-serif;
  font-size: 0.78rem;
  font-weight: 600;
  line-height: 1;
  text-decoration: none;
  transition:
    border-color 0.18s ease,
    background-color 0.18s ease,
    color 0.18s ease,
    transform 0.18s ease;
}

.sg-blog-detail-grid .sg-author-card__follow:hover,
.sg-blog-detail-grid .sg-author-card__follow:focus {
  border-color: var(--sg-theme-accent);
  background: var(--sg-theme-accent);
  color: var(--sg-theme-accent-text);
  text-decoration: none;
  transform: translateY(-1px);
}

@media (min-width: 992px) {
  .sg-blog-detail-grid .sg-sidebar-sticky {
    position: sticky;
    top: 60px;
  }
}

@media (max-width: 991.98px) {
  .sg-blog-directory-hero__layout {
    row-gap: 0.65rem;
  }

  .sg-blog-directory-hero .sg-blog-hero__inner {
    padding-top: clamp(1.5rem, 6vw, 3rem);
  }

  .sg-blog-hero__meta-row {
    flex-direction: column;
    align-items: stretch;
    gap: 0.9rem;
  }

  .sg-blog-hero__actions {
    margin-left: 0;
  }

  .sg-blog-hero__actions--side {
    justify-content: flex-start;
  }

  .sg-blog-hero__edit--side {
    width: 100%;
  }
}

@media (max-width: 767.98px) {
  .sg-blog-directory-hero .sg-hero__content {
    padding-bottom: 1.2rem;
  }

  .sg-blog-directory-hero .sg-blog-hero__toolbar,
  .sg-blog-directory-hero .sg-blog-hero__badge,
  .sg-blog-directory-hero .sg-blog-hero__title {
    margin-bottom: 0.45rem;
  }

  .sg-blog-hero__meta-row {
    gap: 0.85rem;
  }

  .sg-blog-hero__actions {
    width: 100%;
    flex-direction: column;
    align-items: stretch;
  }

  .sg-blog-hero__edit {
    width: 100%;
    justify-content: center;
  }

  .blog-wrapper--hero-body {
    padding-top: 32px;
  }

  .sg-blog-article-detail .blog-detail-summary {
    margin-bottom: 1.6rem;
  }

  .sg-blog-article-detail .post-stats,
  .sg-blog-article-detail .post-footer {
    padding: 1rem;
  }

  .sg-blog-article-detail .post-stats {
    padding: 0 0 0.18rem;
  }

  .sg-blog-article-detail .post-actions {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .sg-blog-article-detail .sg-article-tags {
    align-items: flex-start;
    gap: 0.65rem;
  }

  .sg-blog-detail-grid .sg-widget__header,
  .sg-blog-detail-grid .sg-widget__body {
    padding-left: 1rem;
    padding-right: 1rem;
  }
}
/*//nb##: END*/

.blog-meta-counter {
  display: inline-block;
  padding: 6px 14px;
  margin-bottom: 5px;
  font-size: 13px;
  line-height: 24px;
  color: #515eab;
  background: #f5f5f5;
  border-radius: 12px;
}

.blog-meta-counter:hover {
  color: #999;
  background: #e1e1e1;
  cursor: pointer;
}

.blog-text {
  font-size: 1.2em;
  line-height: 1.6em;
  word-break: normal;
  overflow-wrap: break-word;
  word-wrap: break-word;
}

.blog-text img {
  max-width: 100% !important;
  height: auto !important;
}

.blog-text iframe {
  width: 100% !important;
}

.blog-tags {
  margin-top: 20px;
}

.blog-tags ul > li {
  display: inline-block;
  margin-right: 4px;
  margin-top: 4px;
}

.blog-tags ul > li > a {
  border-radius: 12px;
  background: #f5f5f5;
  padding: 4px 18px;
  line-height: 24px;
  color: #555;
  font-weight: 600;
  font-size: 13px;
  text-transform: uppercase;
  text-align: center;
  word-break: break-all;
  word-wrap: break-word;
  display: inline-block;
}

.blog-tags ul > li > a:hover {
  background: #b9b9b9;
  color: #fff;
}

/* -- */

/* blogs-widget */
.blogs-widget-header {
  margin-bottom: 20px;
  border-bottom: 1px solid #e1e1e1;
}

body.night-mode .blogs-widget-header {
  border-color: var(--card-dark-divider);
}

.blogs-widget-title {
  display: inline-block;
  margin: 0;
  margin-bottom: -1px;
  text-transform: uppercase;
  white-space: nowrap;
  font-weight: 500;
  font-size: 18px;
  line-height: 40px;
  color: var(--link-color);
  border-bottom: 1px solid var(--link-color);
}

.blogs-widget-title.lg {
  line-height: 60px;
}

/* -- */

/* .blog-categories */
.blog-categories {
  margin-bottom: 15px;
}

.blog-categories li {
  float: left;
  margin-right: 5px;
  margin-bottom: 5px;
}

.blog-category {
  border-radius: 12px;
  background: #d8daf2;
  padding: 4px 14px;
  line-height: 24px;
  color: #515eab;
  font-weight: 600;
  font-size: 13px;
  text-transform: uppercase;
  text-align: center;
  white-space: nowrap;
  display: inline-block;
}

body.night-mode .blog-category {
  background: #3f4851;
  color: var(--body-color-dark);
}

.blog-category.small {
  font-size: 9px;
}

.blog-category:hover,
body.night-mode .blog-category:hover {
  background: var(--link-color);
  color: #fff;
}

/* -- */

/* blog references */

.blog-references-section {
  margin-top: 1.25rem;
  padding: 1.25rem 1.35rem;
  border: 1px solid rgba(0, 0, 0, 0.08);
  border-radius: 8px;
  background: rgba(0, 0, 0, 0.02);
}

.blog-references-heading {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin: 0 0 1rem 0;
  padding-bottom: 0.65rem;
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
  font-size: 0.8125rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(0, 0, 0, 0.55);
}

.blog-references-heading i {
  font-size: 0.95rem;
  opacity: 0.85;
}

.blog-references-list {
  margin: 0;
  padding-left: 1.35rem;
  list-style-position: outside;
}

.blog-references-item {
  margin-bottom: 0.65rem;
  padding-left: 0.35rem;
  line-height: 1.55;
  color: inherit;
}

.blog-references-item:last-child {
  margin-bottom: 0;
}

.blog-references-link {
  display: inline;
  text-decoration: none;
  border-bottom: 1px solid rgba(0, 0, 0, 0.12);
  transition:
    color 0.15s ease,
    border-color 0.15s ease;
}

.blog-references-link:hover {
  border-bottom-color: rgba(0, 0, 0, 0.35);
}

.blog-references-external {
  display: inline-block;
  margin-inline-start: 0.35rem;
  font-size: 0.7em;
  vertical-align: super;
  opacity: 0.45;
}

html[dir="RTL"] .blog-references-list {
  padding-right: 1.35rem;
  padding-left: 0;
}

body.night-mode .blog-references-section {
  border-color: var(--card-dark-divider, #2e3f4d);
  background: rgba(0, 0, 0, 0.2);
}

body.night-mode .blog-references-heading {
  border-bottom-color: var(--card-dark-divider, #2e3f4d);
  color: rgba(193, 212, 227, 0.65);
}

body.night-mode .blog-references-link {
  border-bottom-color: rgba(193, 212, 227, 0.25);
}

body.night-mode .blog-references-link:hover {
  border-bottom-color: rgba(193, 212, 227, 0.5);
}

/* -- */

/* nb##: BLOG 目录页改为首屏 Featured + Topics + 三栏正文布局，彻底替换旧 landing hero/sidebar 结构 BEGIN */
.sg-blog-directory {
  display: flex;
  flex-direction: column;
  gap: 1.35rem;
}

.sg-blog-directory__lead {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 1.5rem;
  padding-bottom: 0.2rem;
  border-bottom: 1px solid var(--sg-blog-border);
}

.sg-blog-directory__lead-copy,
.sg-blog-directory__actions {
  min-width: 0;
}

.sg-blog-directory__lead-copy {
  flex: 1;
}

.sg-blog-directory__section-title,
.sg-blog-directory__column-head {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  color: var(--sg-blog-accent);
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.sg-blog-directory__section-title,
.sg-blog-directory__column-head {
  color: var(--sg-blog-heading);
}

.sg-blog-directory__title {
  margin: 0.35rem 0 0.45rem;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(1.7rem, 3vw, 2.45rem);
  line-height: 1.08;
  letter-spacing: -0.03em;
  color: var(--sg-blog-heading);
}

.sg-blog-directory__desc,
.sg-blog-directory__topic-count,
.post-card--text__meta {
  color: var(--sg-blog-text-muted);
}

.sg-blog-directory__breadcrumb {
  margin-bottom: 0.75rem;
}

.sg-blog-directory__desc {
  margin: 0;
  max-width: 62ch;
  font-size: 0.92rem;
  line-height: 1.72;
}

.sg-blog-directory__actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  align-self: flex-start;
}

.sg-blog-directory__action {
  white-space: nowrap;
  border-radius: 2px;
}

.sg-blog-directory__section {
  display: flex;
  flex-direction: column;
  gap: 0.95rem;
}

.sg-blog-directory__featured-grid,
.sg-blog-directory__columns {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.sg-blog-directory__featured-grid {
  align-items: stretch;
}

.sg-blog-directory__columns {
  align-items: stretch;
}

.sg-blog-directory__featured-item,
.sg-blog-directory__column {
  min-width: 0;
  display: flex;
  flex-direction: column;
}

.sg-blog-directory__featured-item {
  height: 100%;
}

.sg-blog-directory__column {
  height: 100%;
}

.sg-blog-directory__topics {
  display: flex;
  flex-direction: column;
  gap: 0.9rem;
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}

.sg-blog-directory__topics-list {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.85rem;
}

.sg-blog-directory__topics-list .sg-recommended-topic-card {
  display: flex;
  align-items: center;
  width: 100%;
  gap: 0.8rem;
  padding: 0.8rem 0.95rem;
  border: 1px solid var(--sg-blog-border);
  border-radius: 18px;
  background: var(--sg-blog-surface-2);
  color: inherit;
  text-decoration: none;
  transition:
    border-color 0.18s ease,
    transform 0.18s ease,
    box-shadow 0.18s ease;
}

.sg-blog-directory__topics-list .sg-recommended-topic-card:hover,
.sg-blog-directory__topics-list .sg-recommended-topic-card:focus {
  transform: translateY(-2px);
  border-color: rgba(102, 199, 244, 0.28);
  box-shadow: 0 16px 30px rgba(15, 23, 42, 0.08);
}

.sg-blog-directory__topics-list .sg-recommended-topic-card__thumb {
  flex: 0 0 68px;
  width: 68px;
  height: 68px;
  border-radius: 999px;
  overflow: hidden;
  background: var(--sg-blog-surface-soft);
}

.sg-blog-directory__topics-list .sg-recommended-topic-card__thumb img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.sg-blog-directory__topics-list .sg-recommended-topic-card__body {
  min-width: 0;
  flex: 1 1 auto;
}

.sg-blog-directory__topics-list .sg-recommended-topic-card__stats {
  display: flex;
  flex-wrap: wrap;
  gap: 0.2rem 0.5rem;
  margin-bottom: 0.34rem;
  color: var(--sg-blog-text-muted);
  font-family: "IBM Plex Sans", "Segoe UI", Helvetica, Arial, sans-serif;
  font-size: 0.8rem;
  font-weight: 600;
  line-height: 1.45;
}

.sg-blog-directory__topics-list .sg-recommended-topic-card__stat {
  display: inline-flex;
  align-items: center;
  gap: 0.32rem;
}

.sg-blog-directory__topics-list
  .sg-recommended-topic-card__stat
  .sg-stat-number {
  font-size: 1.08rem;
  line-height: 1;
}

.sg-blog-directory__topics-list
  .sg-recommended-topic-card__stat
  + .sg-recommended-topic-card__stat::before {
  content: "|";
  opacity: 0.38;
  margin-inline: 0 0.48rem;
}

.sg-blog-directory__topics-list .sg-recommended-topic-card__name {
  color: var(--sg-blog-heading);
  font-size: 1.16rem;
  font-weight: 700;
  line-height: 1.28;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

@media (max-width: 1199.98px) {
  .sg-blog-directory__topics-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 767.98px) {
  .sg-blog-directory__topics-list {
    grid-template-columns: 1fr;
  }

  .sg-blog-directory__topics-list .sg-recommended-topic-card {
    min-width: 0;
  }
}

.sg-blog-directory__stream {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.sg-blog-directory__stream > li {
  display: flex;
  align-items: stretch;
}

.sg-blog-directory__stream--text {
  gap: 0.8rem;
}

/* nb##: /blogs 首页与目录页标准卡统一固定高度，继续沿用纯 CSS，避免不同封面比例与摘要长度把列表撑成高低不齐 BEGIN */
.js_blog-directory .sg-blog-directory__column .sg-blog-feed__item,
.js_blog-directory .sg-blog-directory__column .post-card--standard,
.js_blog-home .sg-blog-directory__column .sg-blog-feed__item,
.js_blog-home .sg-blog-directory__column .post-card--standard {
  height: clamp(22rem, 28vw, 23.5rem);
}

.js_blog-directory .sg-blog-directory__column .sg-blog-directory__stream,
.js_blog-home .sg-blog-directory__column .sg-blog-directory__stream {
  height: 100%;
}

.js_blog-directory .sg-blog-directory__column .post-card--standard__excerpt,
.js_blog-home .sg-blog-directory__column .post-card--standard__excerpt {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  overflow: hidden;
  -webkit-line-clamp: 4;
  height: calc(0.775rem * 1.65 * 4);
}

.js_blog-directory
  .sg-blog-directory__column
  .post-card--standard__excerpt.sg-blog-card__locked,
.js_blog-home
  .sg-blog-directory__column
  .post-card--standard__excerpt.sg-blog-card__locked {
  display: flex;
  align-items: flex-start;
}
/* nb##: END */

/* nb##: Featured 首行与空栏位提示都在展示层处理，避免为补高或空态引入额外数据拼装 BEGIN */
.sg-blog-directory__empty {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 180px;
  padding: 1.2rem 1rem;
  border: 1px dashed var(--sg-blog-border-strong);
  background: var(--sg-blog-surface-2);
  color: var(--sg-blog-text-muted);
  font-size: 0.82rem;
  line-height: 1.7;
  text-align: center;
}

.sg-blog-directory__empty--feature {
  flex: 1;
  min-height: 100%;
}
/*//nb##: END*/

/* nb##: BLOG 首页页头改与目录页一致后，Slider 回到页面内容宽度，仅保留同组交互与文案样式 BEGIN */
.sg-blog-home__slider-section {
  gap: 0;
  width: 100%;
  max-width: 100%;
  margin-inline: 0;
}

.sg-blog-home__lead {
  margin-top: 0.15rem;
}

.sg-blog-home__slider {
  width: 100%;
  overflow: hidden;
  overflow: clip;
}

.sg-blog-home__slider-item {
  padding: 0;
}

.sg-blog-home__slider .carousel-inner {
  overflow: hidden;
  overflow: clip;
}

.sg-blog-home__slider-control {
  width: 2.8rem;
  opacity: 1;
}

.sg-blog-home__slider-control .carousel-control-prev-icon,
.sg-blog-home__slider-control .carousel-control-next-icon {
  width: 2rem;
  height: 2rem;
  border-radius: 50%;
  background-color: rgba(15, 23, 42, 0.78);
  background-size: 58% 58%;
}

.sg-blog-home__slider-indicators {
  margin-bottom: -0.35rem;
}

.sg-blog-home__slider-indicators [data-bs-target] {
  width: 0.65rem;
  height: 0.65rem;
  border-radius: 50%;
  background-color: var(--sg-blog-border-strong);
  opacity: 1;
}

.sg-blog-home__slider-indicators .active {
  background-color: var(--sg-blog-accent);
}

.sg-blog-home .post-card--slider {
  border: 0;
  border-radius: 0;
}

.sg-blog-home .post-card--slider__title,
.sg-blog-home .post-card--slider__excerpt {
  width: 100%;
}

.sg-blog-home .post-card--slider__content {
  width: 100%;
  padding-inline: 0;
}

.sg-blog-home .post-card--slider__content-shell {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 0.95rem;
  width: 100%;
  min-height: inherit;
}

.sg-blog-home .post-card--slider__meta {
  width: 100%;
}
/*//nb##: END*/

.sg-blog-home__breaking-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
}

.sg-blog-home__breaking-item {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  height: 100%;
  min-width: 0;
  padding: 1rem 1.05rem;
  border: 1px solid var(--sg-blog-border);
  background: var(--sg-blog-surface);
  color: inherit;
  text-decoration: none;
  transition:
    transform 0.18s ease,
    box-shadow 0.18s ease,
    border-color 0.18s ease;
}

.sg-blog-home__breaking-item:hover {
  transform: translateY(-2px);
  box-shadow: var(--sg-blog-shadow-sm);
  border-color: rgba(102, 199, 244, 0.2);
}

.sg-blog-home__breaking-label {
  color: var(--sg-blog-accent);
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.sg-blog-home__breaking-title {
  font-family: Georgia, "Times New Roman", serif;
  font-size: 1rem;
  line-height: 1.35;
  color: var(--sg-blog-heading);
}

.sg-blog-home__breaking-meta {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.45rem;
  color: var(--sg-blog-text-muted);
  font-size: 0.75rem;
}

.sg-blog-home__breaking-empty {
  grid-column: 1 / -1;
}

.sg-blog-directory__load-more {
  margin-top: 0.2rem;
}

/* nb##: /blogs 首页三栏流与 Breaking 卡片统一拉伸到等高，避免首页列表高度参差而目录页正常 */
.sg-blog-home .sg-blog-directory__columns {
  align-items: stretch;
}

.sg-blog-home .sg-blog-directory__stream > li {
  height: 100%;
}

.sg-blog-hub .post-card--text,
.sg-blog-hub .post-card--standard {
  background: var(--sg-blog-surface);
  border: 1px solid var(--sg-blog-border);
  border-radius: 2px;
  box-shadow: none;
}

.sg-blog-hub .post-card--text {
  display: flex;
  flex-direction: column;
  padding: 1.05rem 1.1rem 1rem;
  color: inherit;
  text-decoration: none;
  transition:
    transform 0.18s ease,
    box-shadow 0.18s ease,
    border-color 0.18s ease;
}

.sg-blog-hub .post-card--text:hover {
  transform: translateY(-2px);
  box-shadow: var(--sg-blog-shadow-sm);
  border-color: rgba(102, 199, 244, 0.2);
}

.sg-blog-hub .post-card--text__cat,
.sg-blog-hub .post-card--text__title,
.sg-blog-hub .post-card--text__excerpt,
.sg-blog-hub .post-card--text__meta {
  margin: 0;
}

.sg-blog-hub .post-card--text__cat {
  color: var(--sg-blog-accent);
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-bottom: 0.55rem;
}

.sg-blog-hub .post-card--text__title {
  font-family: Georgia, "Times New Roman", serif;
  font-size: 1.02rem;
  line-height: 1.38;
  color: var(--sg-blog-heading);
  margin-bottom: 0.7rem;
}

.sg-blog-hub .post-card--text__excerpt {
  font-size: 0.8rem;
  line-height: 1.68;
  color: var(--sg-blog-text-muted);
  margin-bottom: 0.9rem;
}

.sg-blog-hub .post-card--text__meta {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  font-size: 0.74rem;
  padding-top: 0.8rem;
  border-top: 1px solid var(--sg-blog-border);
  margin-top: auto;
}

.sg-blog-hub .post-card--text__author {
  color: var(--sg-blog-heading);
  font-weight: 700;
}

.sg-blog-directory__column .post-card--standard {
  height: 100%;
}

.sg-blog-directory__stream .post-card--text,
.sg-blog-directory__stream .post-card--standard {
  height: 100%;
}

.sg-blog-directory__featured-item .post-card--featured {
  min-height: 100%;
}

@media (max-width: 1199.98px) {
  .sg-blog-directory__lead {
    flex-direction: column;
    align-items: stretch;
  }

  .sg-blog-directory__actions {
    justify-content: flex-start;
  }

  .sg-blog-directory__featured-grid,
  .sg-blog-directory__columns {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .sg-blog-home__breaking-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 767.98px) {
  .sg-blog-directory__featured-grid,
  .sg-blog-directory__columns {
    grid-template-columns: minmax(0, 1fr);
  }

  .sg-blog-home__slider-item {
    padding: 0;
  }

  .sg-blog-home__breaking-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .sg-blog-directory__action {
    width: auto;
  }

  .sg-blog-directory__topics {
    padding: 0.9rem;
  }
}

/*//nb##: END*/

/* -- */
/*//nb##: END*/

/*//nb##: BLOG landing list1 首页/分类页重构样式 BEGIN*/
.sg-blog-hub {
  --sg-blog-surface: #ffffff;
  --sg-blog-surface-2: #f8fafc;
  --sg-blog-border: rgba(15, 23, 42, 0.08);
  --sg-blog-border-strong: rgba(15, 23, 42, 0.14);
  --sg-blog-text: #1f2937;
  --sg-blog-text-muted: #64748b;
  --sg-blog-heading: #0f172a;
  --sg-blog-accent: var(--link-color);
  --sg-blog-accent-soft: rgba(102, 199, 244, 0.12);
  --sg-blog-shadow: 0 18px 48px rgba(15, 23, 42, 0.08);
  --sg-blog-shadow-sm: 0 10px 30px rgba(15, 23, 42, 0.06);
  font-family:
    system-ui,
    -apple-system,
    BlinkMacSystemFont,
    "Segoe UI",
    sans-serif;
  color: var(--sg-blog-text);
}

body.night-mode .sg-blog-hub {
  --sg-blog-surface: var(--card-dark-color);
  --sg-blog-surface-2: #162132;
  --sg-blog-border: rgba(255, 255, 255, 0.08);
  --sg-blog-border-strong: rgba(255, 255, 255, 0.14);
  --sg-blog-text: #e5e7eb;
  --sg-blog-text-muted: #94a3b8;
  --sg-blog-heading: #f8fafc;
  --sg-blog-accent-soft: rgba(102, 199, 244, 0.18);
  --sg-blog-shadow: 0 20px 54px rgba(0, 0, 0, 0.28);
  --sg-blog-shadow-sm: 0 14px 34px rgba(0, 0, 0, 0.2);
}

.sg-blog-home-hero {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--sg-blog-border);
  border-radius: 2px;
  background: var(--sg-blog-surface);
  margin-bottom: 1.5rem;
  box-shadow: var(--sg-blog-shadow-sm);
}

.sg-blog-home-hero--no-cover {
  background:
    repeating-linear-gradient(
      0deg,
      transparent,
      transparent 39px,
      var(--sg-blog-border) 39px,
      var(--sg-blog-border) 40px
    ),
    repeating-linear-gradient(
      90deg,
      transparent,
      transparent 79px,
      var(--sg-blog-border) 79px,
      var(--sg-blog-border) 80px
    ),
    var(--sg-blog-surface);
}

.sg-blog-home-hero--no-cover .sg-blog-home-hero__overlay {
  background: transparent;
}

.sg-blog-home-hero--no-cover .sg-blog-home-hero__grain {
  opacity: 0.5;
}

.sg-blog-home-hero--no-cover .sg-blog-home-hero__eyebrow {
  color: var(--sg-blog-accent);
}

.sg-blog-home-hero--no-cover .sg-blog-home-hero__title {
  color: var(--sg-blog-heading);
}

.sg-blog-home-hero--no-cover .sg-blog-home-hero__desc,
.sg-blog-home-hero--no-cover .sg-blog-home-hero__stat {
  color: var(--sg-blog-text-muted);
}

.sg-blog-home-hero--no-cover .sg-blog-pill {
  border-color: var(--sg-blog-border-strong);
  color: var(--sg-blog-text-muted);
}

.sg-blog-home-hero--no-cover .sg-blog-pill:hover,
.sg-blog-home-hero--no-cover .sg-blog-pill.is-active {
  border-color: var(--sg-blog-accent);
  color: var(--sg-blog-accent);
}

.sg-blog-home-hero--no-cover .sg-blog-home-hero__aside-card {
  border-color: var(--sg-blog-border);
  background: var(--sg-blog-surface-2);
}

.sg-blog-home-hero--no-cover .sg-blog-home-hero__aside-label,
.sg-blog-home-hero--no-cover .sg-blog-home-hero__aside-meta {
  color: var(--sg-blog-text-muted);
}

.sg-blog-home-hero--no-cover .sg-blog-home-hero__aside-value {
  color: var(--sg-blog-heading);
}

.sg-blog-home-hero__img,
.sg-blog-home-hero__overlay,
.sg-blog-home-hero__grain {
  position: absolute;
  inset: 0;
}

.sg-blog-home-hero__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(0.52) saturate(0.84);
}

.sg-blog-home-hero__overlay {
  background: linear-gradient(
    135deg,
    rgba(10, 14, 24, 0.78),
    rgba(10, 14, 24, 0.42) 45%,
    rgba(10, 14, 24, 0.74)
  );
}

.sg-blog-home-hero__grain {
  background-image:
    linear-gradient(
      0deg,
      transparent,
      transparent 39px,
      rgba(255, 255, 255, 0.05) 39px,
      rgba(255, 255, 255, 0.05) 40px
    ),
    linear-gradient(
      90deg,
      transparent,
      transparent 79px,
      rgba(255, 255, 255, 0.05) 79px,
      rgba(255, 255, 255, 0.05) 80px
    );
  opacity: 0.3;
}

.sg-blog-home-hero__content {
  position: relative;
  z-index: 2;
  padding: clamp(1.6rem, 3vw, 2.5rem);
}

.sg-blog-home-hero__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  color: var(--sg-blog-accent);
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  margin-bottom: 0.6rem;
}

.sg-blog-home-hero__eyebrow::before {
  content: "";
  width: 24px;
  height: 2px;
  background: var(--sg-blog-accent);
}

.sg-blog-home-hero__title {
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(2rem, 5vw, 3.5rem);
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: #ffffff;
  margin-bottom: 0.75rem;
}

.sg-blog-home-hero__desc {
  max-width: 520px;
  color: rgba(255, 255, 255, 0.8);
  font-size: 0.875rem;
  line-height: 1.65;
  margin-bottom: 1.25rem;
}

.sg-blog-home-hero__stats,
.sg-blog-home-hero__links {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.sg-blog-home-hero__stats {
  margin-bottom: 1.2rem;
}

.sg-blog-home-hero__stat {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  color: rgba(255, 255, 255, 0.8);
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.sg-blog-pill {
  display: inline-flex;
  align-items: center;
  padding: 0.28rem 0.75rem;
  border-radius: 2px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: transparent;
  color: rgba(255, 255, 255, 0.76);
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-decoration: none;
  transition:
    border-color 0.18s ease,
    background 0.18s ease,
    color 0.18s ease;
  white-space: nowrap;
}

.sg-blog-pill:hover,
.sg-blog-pill.is-active {
  border-color: rgba(102, 199, 244, 0.7);
  background: rgba(102, 199, 244, 0.16);
  color: #ffffff;
}

.sg-blog-home-hero__aside {
  display: flex;
  justify-content: flex-end;
}

.sg-blog-home-hero__aside-card {
  width: 100%;
  max-width: 320px;
  padding: 1.15rem 1.15rem 1.2rem;
  border-radius: 2px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(10, 14, 24, 0.28);
  box-shadow: none;
  backdrop-filter: blur(10px);
}

.sg-blog-home-hero__aside-label {
  color: rgba(255, 255, 255, 0.7);
  font-size: 0.74rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  margin-bottom: 0.45rem;
}

.sg-blog-home-hero__aside-value {
  color: #ffffff;
  font-size: 1.35rem;
  font-weight: 700;
  line-height: 1.2;
}

.sg-blog-home-hero__aside-meta {
  color: rgba(255, 255, 255, 0.72);
  font-size: 0.84rem;
  line-height: 1.6;
  margin-top: 0.45rem;
}

.sg-blog-home-hero__action {
  width: 100%;
  margin-top: 1rem;
  border-radius: 999px;
  font-weight: 700;
}

.sg-blog-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
  padding: 0.95rem 1.05rem;
  margin-bottom: 1.5rem;
  border: 1px solid var(--sg-blog-border);
  border-radius: 2px;
  background: var(--sg-blog-surface);
  box-shadow: none;
}

.sg-blog-toolbar__form,
.sg-blog-toolbar__view {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex-wrap: wrap;
}

.sg-blog-toolbar__group {
  display: flex;
  align-items: center;
}

.sg-blog-toolbar__select {
  min-width: 170px;
  border: 1px solid var(--sg-blog-border-strong);
  border-radius: 2px;
  background: var(--sg-blog-surface-2);
  color: var(--sg-blog-text);
  font-size: 0.72rem;
  padding: 0.38rem 1.9rem 0.38rem 0.65rem;
}

.sg-blog-toolbar__count {
  color: var(--sg-blog-text-muted);
  font-size: 0.7rem;
  font-style: italic;
}

.sg-blog-toolbar__view-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 30px;
  height: 30px;
  padding: 0 0.65rem;
  border-radius: 2px;
  border: 1px solid var(--sg-blog-border-strong);
  background: transparent;
  color: var(--sg-blog-text-muted);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  transition:
    border-color 0.18s ease,
    color 0.18s ease,
    background 0.18s ease;
}

.sg-blog-toolbar__view-btn:hover,
.sg-blog-toolbar__view-btn.is-active {
  border-color: rgba(102, 199, 244, 0.4);
  background: var(--sg-blog-accent-soft);
  color: var(--sg-blog-accent);
}

.sg-blog-section-divider {
  height: 1px;
  margin-bottom: 1.35rem;
  background: linear-gradient(
    90deg,
    var(--sg-blog-accent) 0,
    var(--sg-blog-accent) 72px,
    var(--sg-blog-border) 72px,
    var(--sg-blog-border) 100%
  );
}

.sg-blog-feed {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
  list-style: none;
  margin: 0;
  padding: 0;
}

.sg-blog-feed-shell[data-view="list"] .sg-blog-feed {
  grid-template-columns: minmax(0, 1fr);
}

.sg-blog-feed__item {
  display: flex;
  list-style: none;
}

/* nb##: BLOG 首页 Slider 改为封面底图叠字，下部与目录页标准卡片统一为封面在上、文案在下的纵向结构 BEGIN */
.sg-blog-hub .post-card--slider,
.sg-blog-hub .post-card--featured,
.sg-blog-hub .post-card--side,
.sg-blog-hub .post-card--standard,
.sg-blog-sidebar-story,
.sg-blog-sidebar__widget {
  background: var(--sg-blog-surface);
  border: 1px solid var(--sg-blog-border);
  border-radius: 2px;
  box-shadow: none;
}

.sg-blog-hub .post-card--slider,
.sg-blog-hub .post-card--featured,
.sg-blog-hub .post-card--side,
.sg-blog-hub .post-card--standard,
.sg-blog-sidebar-story {
  display: flex;
  overflow: hidden;
  color: inherit;
  text-decoration: none;
  transition:
    transform 0.18s ease,
    box-shadow 0.18s ease,
    border-color 0.18s ease;
}

.sg-blog-hub .post-card--slider:hover,
.sg-blog-hub .post-card--featured:hover,
.sg-blog-hub .post-card--side:hover,
.sg-blog-hub .post-card--standard:hover,
.sg-blog-sidebar-story:hover {
  transform: translateY(-2px);
  box-shadow: var(--sg-blog-shadow-sm);
  border-color: rgba(102, 199, 244, 0.2);
}

.sg-blog-hub .post-card--slider {
  position: relative;
  min-height: clamp(360px, 48vw, 500px);
}

.sg-blog-hub .post-card--slider--fluid-cover {
  min-height: 0;
}

.sg-blog-hub .post-card--slider__media {
  position: relative;
  display: flex;
  align-items: flex-end;
  min-height: inherit;
  width: 100%;
  background: #0f172a;
}

.sg-blog-hub .post-card--slider__img,
.sg-blog-hub .post-card--slider__placeholder,
.sg-blog-hub .post-card--slider__overlay {
  position: absolute;
  inset: 0;
}

.sg-blog-hub .post-card--slider__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.55s ease;
}

.sg-blog-hub .post-card--slider:hover .post-card--slider__img {
  transform: scale(1.04);
}

.sg-blog-hub .post-card--slider__media--fluid {
  display: block;
  min-height: 0;
}

.sg-blog-hub .post-card--slider__media--fluid .post-card--slider__img {
  position: relative;
  inset: auto;
  display: block;
  width: 100%;
  height: auto;
  object-fit: contain;
  object-position: center top;
  transform: none;
}

.sg-blog-hub
  .post-card--slider:hover
  .post-card--slider__media--fluid
  .post-card--slider__img {
  transform: none;
}

/* nb##: BLOG 首页 Slider 区整体高度也改为由封面宽高比决定，文案层绝对贴底覆在图片上，避免再把轮播容器撑高 */
.sg-blog-home .post-card--slider__media--fluid .post-card--slider__content {
  position: absolute;
  inset: auto 0 0 0;
  min-height: 0;
  margin-top: 0;
  padding-top: 0;
}

.sg-blog-home
  .post-card--slider__media--fluid
  .post-card--slider__content-shell {
  min-height: 0;
}

.sg-blog-hub .post-card--slider__overlay {
  background: linear-gradient(
    180deg,
    rgba(10, 14, 24, 0.16) 0%,
    rgba(10, 14, 24, 0.52) 42%,
    rgba(10, 14, 24, 0.92) 100%
  );
}

.sg-blog-hub .post-card--slider__content {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 0.95rem;
  width: 100%;
  min-height: inherit;
  padding: clamp(1.35rem, 3vw, 2.2rem);
}

.sg-blog-hub .post-card--slider__title {
  margin: 0;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(1.6rem, 3vw, 2.55rem);
  line-height: 1.08;
  letter-spacing: -0.03em;
  color: #ffffff;
}

.sg-blog-hub .post-card--slider__excerpt,
.sg-blog-hub .post-card--slider .sg-blog-card__locked,
.sg-blog-hub .post-card--slider .post-card__author-name,
.sg-blog-hub .post-card--slider .post-card__date,
.sg-blog-hub .post-card--slider .post-card__stat {
  color: rgba(255, 255, 255, 0.82);
}

.sg-blog-hub .post-card--slider__excerpt {
  margin: 0;
  font-size: 0.9rem;
  line-height: 1.75;
}

.sg-blog-hub .post-card--slider__meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  flex-wrap: wrap;
  padding-top: 1rem;
  border-top: 1px solid rgba(255, 255, 255, 0.18);
}

.sg-blog-hub .post-card--slider .post-card__author {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
}

@media (max-width: 991.98px) {
  /* nb##: BLOG 首页 slider 在手机/平板遇到超宽封面时，改为图片在上文案在下，避免图片高度过浅把绝对定位文案裁掉 */
  .sg-blog-home .post-card--slider {
    min-height: 0;
  }

  .sg-blog-home .post-card--slider__media--fluid {
    display: flex;
    flex-direction: column;
  }

  .sg-blog-home .post-card--slider__media--fluid .post-card--slider__overlay {
    display: none;
  }

  .sg-blog-home .post-card--slider__media--fluid .post-card--slider__content {
    position: relative;
    inset: auto;
    display: block;
    min-height: 0;
    padding: 1rem 1rem 1.15rem;
    background: linear-gradient(
      180deg,
      rgba(10, 14, 24, 0.06) 0%,
      rgba(10, 14, 24, 0.88) 18%,
      rgba(10, 14, 24, 0.96) 100%
    );
  }

  .sg-blog-home
    .post-card--slider__media--fluid
    .post-card--slider__content-shell {
    gap: 0.85rem;
  }

  .sg-blog-home .post-card--slider__title {
    font-size: clamp(1.2rem, 4.8vw, 1.85rem);
    line-height: 1.16;
  }

  .sg-blog-home .post-card--slider__excerpt {
    font-size: 0.84rem;
    line-height: 1.65;
  }

  .sg-blog-home .post-card--slider__meta {
    padding-top: 0.85rem;
  }
}

.sg-blog-hub .post-card--featured {
  flex-direction: column;
  height: 100%;
}

.sg-blog-hub .post-card--featured__img-wrap,
.sg-blog-hub .post-card--standard__img-wrap,
.sg-blog-hub .post-card--side__img-wrap,
.sg-blog-sidebar-story__cover {
  position: relative;
  overflow: hidden;
  background: var(--sg-blog-surface-2);
}

.sg-blog-hub .post-card--featured__img-wrap {
  aspect-ratio: 16 / 10;
}

.sg-blog-hub .post-card--featured__img-wrap--fluid {
  aspect-ratio: auto;
}

.sg-blog-hub .post-card--standard__img-wrap {
  width: 100%;
  aspect-ratio: 16 / 10;
}

.sg-blog-hub .post-card--standard__img-wrap--fluid {
  aspect-ratio: auto;
}

.sg-blog-hub .post-card--standard {
  flex-direction: column;
  height: 100%;
}

.sg-blog-hub .post-card--side {
  flex-direction: column;
  min-height: 100%;
}

.sg-blog-hub .post-card--side__img-wrap {
  width: 100%;
  aspect-ratio: 16 / 10;
}

.sg-blog-hub .post-card--side__img-wrap--fluid,
.sg-blog-sidebar-story__cover--fluid {
  aspect-ratio: auto;
}
/*//nb##: END*/

.sg-blog-hub .post-card--featured__img,
.sg-blog-hub .post-card--standard__img,
.sg-blog-hub .post-card--side__img,
.sg-blog-sidebar-story__cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.55s ease;
}

.sg-blog-hub .post-card--featured__img-wrap--fluid .post-card--featured__img,
.sg-blog-hub .post-card--standard__img-wrap--fluid .post-card--standard__img,
.sg-blog-hub .post-card--side__img-wrap--fluid .post-card--side__img,
.sg-blog-sidebar-story__cover--fluid img {
  display: block;
  height: auto;
  object-fit: contain;
  object-position: center top;
  transform: none;
}

.sg-blog-hub .post-card--featured:hover .post-card--featured__img,
.sg-blog-hub .post-card--standard:hover .post-card--standard__img,
.sg-blog-hub .post-card--side:hover .post-card--side__img,
.sg-blog-sidebar-story:hover .sg-blog-sidebar-story__cover img {
  transform: scale(1.05);
}

.sg-blog-hub
  .post-card--featured:hover
  .post-card--featured__img-wrap--fluid
  .post-card--featured__img,
.sg-blog-hub
  .post-card--standard:hover
  .post-card--standard__img-wrap--fluid
  .post-card--standard__img,
.sg-blog-hub
  .post-card--side:hover
  .post-card--side__img-wrap--fluid
  .post-card--side__img,
.sg-blog-sidebar-story:hover .sg-blog-sidebar-story__cover--fluid img {
  transform: none;
}

.sg-blog-hub .post-card--standard__badge,
.sg-blog-sidebar-story__rank {
  position: absolute;
  left: 1rem;
  top: 1rem;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.34rem 0.72rem;
  border-radius: 2px;
  background: rgba(10, 14, 24, 0.78);
  color: #ffffff;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.sg-blog-hub .post-card--featured__reading-time {
  position: absolute;
  right: 1rem;
  bottom: 1rem;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.35rem 0.7rem;
  border-radius: 2px;
  background: rgba(10, 14, 24, 0.72);
  color: rgba(255, 255, 255, 0.88);
  font-size: 0.76rem;
}

.sg-blog-hub .post-card--featured__body,
.sg-blog-hub .post-card--standard__body,
.sg-blog-hub .post-card--side__body,
.sg-blog-sidebar-story__body {
  display: flex;
  flex-direction: column;
}

.sg-blog-hub .post-card--featured__body {
  padding: 1.4rem 1.4rem 1.3rem;
  flex: 1;
}

.sg-blog-hub .post-card--standard__body,
.sg-blog-hub .post-card--side__body {
  padding: 1.1rem 1.15rem 1.05rem;
  flex: 1;
}

.sg-blog-hub .post-card--featured__cat,
.sg-blog-hub .post-card--standard__cat,
.sg-blog-hub .post-card--side__cat,
.sg-blog-sidebar-story__cat {
  color: var(--sg-blog-accent);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-bottom: 0.55rem;
}

.sg-blog-hub .post-card--featured__title,
.sg-blog-hub .post-card--standard__title,
.sg-blog-hub .post-card--side__title,
.sg-blog-sidebar-story__title {
  font-family: Georgia, "Times New Roman", serif;
  color: var(--sg-blog-heading);
  letter-spacing: -0.02em;
}

.sg-blog-hub .post-card--featured__title {
  font-size: 1.3rem;
  line-height: 1.25;
  margin-bottom: 0.75rem;
}

.sg-blog-hub .post-card--standard__title,
.sg-blog-hub .post-card--side__title {
  font-size: 0.96rem;
  line-height: 1.3;
  margin-bottom: 0.7rem;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  overflow: hidden;
  -webkit-line-clamp: 3;
}

.sg-blog-sidebar-story__title {
  font-size: 0.82rem;
  line-height: 1.35;
  margin-bottom: 0.55rem;
}

.sg-blog-hub .post-card--featured__excerpt,
.sg-blog-hub .post-card--standard__excerpt,
.sg-blog-card__locked,
.sg-blog-sidebar-story__meta,
.sg-blog-topic-entry__meta,
.sg-blog-home-hero__aside-meta,
.sg-blog-home-hero__stat,
.sg-blog-hub .post-card__author-name,
.sg-blog-hub .post-card__date,
.sg-blog-hub .post-card__stat,
.sg-blog-hub .post-card--side__meta {
  color: var(--sg-blog-text-muted);
}

.sg-blog-hub .post-card--featured__excerpt,
.sg-blog-hub .post-card--standard__excerpt {
  font-size: 0.82rem;
  line-height: 1.65;
}

.sg-blog-hub .post-card--standard__excerpt {
  font-size: 0.775rem;
  margin-bottom: 0.9rem;
}

.sg-blog-card__locked {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  font-weight: 700;
}

.sg-blog-card__locked--compact {
  font-size: 0.8rem;
}

.sg-blog-card__badge--lock {
  background: rgba(10, 14, 24, 0.76);
}

.sg-blog-hub .post-card--featured__meta,
.sg-blog-hub .post-card--standard__meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.6rem;
  flex-wrap: wrap;
  border-top: 1px solid var(--sg-blog-border);
  padding-top: 0.9rem;
  margin-top: auto;
}

.sg-blog-hub .post-card__author,
.sg-blog-hub .post-card--side__meta {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
}

.sg-blog-hub .post-card__author-img {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  object-fit: cover;
}

.sg-blog-hub .post-card__author-name {
  font-size: 0.78rem;
  font-weight: 700;
}

/* nb##: BLOG Slider 与目录卡片底部统计把图标和数字拆开排版，数字单独放大并用斜体强调 BEGIN */
.sg-blog-hub .post-card--slider .post-card__stats,
.sg-blog-hub .post-card__stats {
  display: inline-flex;
  align-items: flex-end;
  gap: 0.95rem;
}

.sg-blog-hub .post-card__stat {
  display: inline-flex;
  align-items: baseline;
  gap: 0.45rem;
  font-size: 0.78rem;
  line-height: 1;
}

.sg-blog-hub .post-card__stat i {
  font-size: 0.95em;
}

.sg-blog-hub .post-card__stat-value {
  display: inline-block;
  font-size: 1.65em;
  font-style: italic;
  line-height: 0.92;
}
/* nb##: END */

.sg-blog-hub .post-card--standard__no-cover,
.sg-blog-card__placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--sg-blog-text-muted);
}

.sg-blog-hub .post-card--standard__no-cover,
.sg-blog-card__placeholder--side,
.sg-blog-card__placeholder--trend,
.sg-blog-card__placeholder--feature {
  background:
    radial-gradient(
      circle at top right,
      var(--sg-blog-accent-soft),
      transparent 40%
    ),
    var(--sg-blog-surface-2);
}

.sg-blog-hub .post-card--standard__no-cover {
  min-height: 210px;
}

.sg-blog-card__placeholder--side,
.sg-blog-card__placeholder--feature,
.sg-blog-card__placeholder--trend {
  width: 100%;
  height: 100%;
  min-height: 180px;
}

.sg-blog-card__placeholder--side {
  min-height: 160px;
}

.sg-blog-card__placeholder--trend {
  min-height: 140px;
}

.sg-blog-card__placeholder i,
.sg-blog-hub .post-card--standard__no-cover i {
  font-size: 1.6rem;
}

.sg-blog-feed-shell[data-view="list"] .sg-blog-feed__item {
  width: 100%;
}

.sg-blog-feed-shell[data-view="list"] .post-card--standard {
  flex-direction: row;
}

.sg-blog-feed-shell[data-view="list"] .post-card--standard__img-wrap,
.sg-blog-feed-shell[data-view="list"] .post-card--standard__no-cover {
  width: 240px;
  min-width: 240px;
  aspect-ratio: auto;
}

.sg-blog-feed-shell[data-view="list"] .post-card--standard__no-cover {
  min-height: auto;
}

.sg-blog-sidebar {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.sg-blog-sidebar__widget {
  padding: 1.15rem;
}

.sg-blog-sidebar__title {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  color: var(--sg-blog-heading);
  font-size: 0.64rem;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  margin-bottom: 1rem;
  padding-bottom: 0.65rem;
  border-bottom: 1px solid var(--sg-blog-border);
}

.sg-blog-topic-list,
.sg-blog-sidebar__stories {
  display: flex;
  flex-direction: column;
  gap: 0.8rem;
}

.sg-blog-topic-entry {
  display: block;
  padding: 0.75rem 0.9rem;
  border-radius: 2px;
  background: transparent;
  border: 1px solid var(--sg-blog-border);
  text-decoration: none;
  transition:
    border-color 0.18s ease,
    transform 0.18s ease;
}

.sg-blog-topic-entry:hover {
  transform: translateY(-2px);
  border-color: rgba(102, 199, 244, 0.24);
}

.sg-blog-topic-entry__title {
  color: var(--sg-blog-heading);
  font-family: Georgia, "Times New Roman", serif;
  font-size: 0.82rem;
  font-weight: 700;
  margin-bottom: 0.35rem;
}

.sg-blog-topic-entry__meta,
.sg-blog-sidebar-story__meta {
  font-size: 0.62rem;
}

.sg-blog-sidebar-story {
  flex-direction: column;
}

.sg-blog-sidebar-story__cover {
  aspect-ratio: 16 / 9;
}

.sg-blog-sidebar-story__body {
  padding: 0.95rem 1rem 1rem;
}

.sg-blog-sidebar-story__rank {
  right: auto;
  bottom: auto;
}

.sg-blog-load-more {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.7rem;
  margin-top: 1.4rem;
  padding: 0.95rem 1.2rem;
  border-radius: 2px;
  border: 1px solid var(--sg-blog-border-strong);
  background: transparent;
  color: var(--sg-blog-text-muted);
  cursor: pointer;
  text-transform: uppercase;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.12em;
}

.sg-blog-load-more:hover {
  border-color: rgba(102, 199, 244, 0.32);
  color: var(--sg-blog-accent);
  background: var(--sg-blog-accent-soft);
}

@media (max-width: 1199.98px) {
  .sg-blog-feed {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 767.98px) {
  .sg-offcanvas .sg-blog-public-offcanvas-sidebar {
    position: fixed !important;
    top: 70px;
    left: -100%;
    bottom: 0;
    width: 100vw;
    max-height: calc(100vh - 70px);
    padding: 0.85rem 0.75rem calc(5.5rem + env(safe-area-inset-bottom, 0px));
    overflow-y: auto;
    background: var(--body-bg-color);
    z-index: 1002;
    transition: left 0.25s ease-out;
  }

  body.night-mode .sg-offcanvas .sg-blog-public-offcanvas-sidebar {
    background: var(--body-bg-color-dark);
  }

  body.n_activated .sg-offcanvas .sg-blog-public-offcanvas-sidebar,
  body.n_live .sg-offcanvas .sg-blog-public-offcanvas-sidebar {
    top: 120px;
    max-height: calc(100vh - 120px);
  }

  .sg-offcanvas.active .sg-blog-public-offcanvas-sidebar {
    left: 0;
  }

  .sg-blog-home-hero {
    border-radius: 2px;
  }

  .sg-blog-toolbar {
    padding: 0.9rem;
  }

  .sg-blog-feed,
  .sg-blog-feed-shell[data-view="list"] .sg-blog-feed {
    grid-template-columns: minmax(0, 1fr);
  }

  .sg-blog-feed-shell[data-view="list"] .post-card--standard {
    flex-direction: column;
  }

  .sg-blog-feed-shell[data-view="list"] .post-card--standard__img-wrap,
  .sg-blog-feed-shell[data-view="list"] .post-card--standard__no-cover {
    width: 100%;
    min-width: 0;
  }
}
/*//nb##: END*/

/* AUTO-COMPLETE */
/* ------------------------------- */

.dropdown-menu.auto-complete {
  display: none;
}

.typeahead {
  position: relative;
  /* for dropdown-menu */
  float: left;
}

.typeahead input {
  background: transparent;
  width: 100%;
  color: #4e5665;
  font-size: 16px;
  line-height: 30px;
  outline: 0 none;
  border: 0 none;
}

body.night-mode .typeahead input {
  color: #fff;
}

.tags li {
  float: left;
  padding: 8px 12px;
  margin: 0 3px 3px 0;
  background: #f4f4f4;
  font-size: 12px;
  line-height: 16px;
  border-radius: 16px;
}

body.night-mode .tags li {
  background: var(--card-dark-color);
}

.tags button {
  font-size: 8px;
  margin-left: 4px;
}

/* Google Geo-Autocomplete */
.pac-container {
  z-index: 999999;
}

/* -- */

/* LIGHTBOX */
/* ------------------------------- */

.lightbox-open {
  overflow: hidden;
  /* hide the page scroll */
}

.lightbox {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.75);
  z-index: 9999;
  overflow-y: scroll;
}

@media (min-width: 992px) {
  .lightbox {
    overflow-y: none;
  }
}

.lightbox-container {
  display: table;
  width: 100%;
  box-shadow: 0 0 15px 0 rgba(0, 0, 0, 0.6);
  padding-right: 0;
  padding-left: 0;
}

@media (min-width: 992px) {
  .lightbox-container {
    height: 100%;
  }
}

.lightbox-preview {
  position: relative;
  display: block;
  width: 100%;
  vertical-align: middle;
  background: #000;
  text-align: center;
}

@media (min-width: 992px) {
  .lightbox-preview {
    display: table-cell;
    width: 60%;
    max-width: 800px;
  }
}

@media (min-width: 1200px) {
  .lightbox-preview {
    width: 70%;
  }
}

.lightbox-preview.nodata {
  width: 100%;
}

.lightbox-preview.with-live {
  padding: 25px;
}

.lightbox-preview.with-live video {
  top: 0 !important;
  left: 0 !important;
}

.lightbox-exit {
  position: absolute;
  top: 4%;
  right: 2%;
  opacity: 0.5;
  color: #fff;
}

.lightbox-exit:hover {
  opacity: 1;
  cursor: pointer;
}

.lightbox-next,
.lightbox-prev {
  position: absolute;
  top: 50%;
  opacity: 0.5;
}

.lightbox-next {
  right: 2%;
}

.lightbox-prev {
  left: 2%;
}

.lightbox-next:hover,
.lightbox-prev:hover {
  opacity: 1;
  cursor: pointer;
}

.lightbox-next .fa,
.lightbox-prev .fa {
  color: #fff;
  text-shadow: 0 2px 2px rgba(0, 0, 0, 0.5);
}

.lightbox-download {
  position: absolute;
  bottom: 4%;
  left: 2%;
}

.lightbox-download a {
  color: #fff;
  opacity: 0.5;
}

.lightbox-download a:hover {
  opacity: 0.75;
}

.lightbox-preview img {
  margin: 0 auto;
  max-width: 100%;
  max-height: calc(100vh - 92px);
  /* 92px = 46*2 (header) */
}

.lightbox-data {
  display: block;
  width: 100%;
  vertical-align: top;
  background: #fff;
}

@media (min-width: 992px) {
  .lightbox-data {
    display: table-cell;
    width: 40%;
  }
}

@media (min-width: 1200px) {
  .lightbox-data {
    width: 30%;
  }
}

body.night-mode .lightbox-data {
  background: var(--card-dark-color);
}

.lightbox-post {
  padding: 0 8px;
  height: calc(100vh - 113px);
  /* 113px = 46*2 (header) + 21px (close btn) */
}

/* -- */

/* STORIES */
/* ------------------------------- */

/* nb##: 首页 Stories 改为 Sociala 风格卡片与横向切换按钮 */
.stories-home-card {
  position: relative;
  overflow: hidden;
}

.stories-home-card__viewport {
  position: relative;
}

.stories-wrapper {
  overflow: auto hidden;
  padding: 10px 42px 12px 0;
  margin-bottom: 0;
  scrollbar-width: none;
  scroll-behavior: smooth;
}

.stories-wrapper::-webkit-scrollbar {
  display: none;
}

.stories.carousel {
  display: flex;
  align-items: stretch;
  gap: 8px;
  overflow: visible !important;
  white-space: normal;
  padding: 0;
}

.stories-home-card__nav {
  position: absolute;
  top: 30%;
  left: auto;
  z-index: 4;
  width: 38px;
  height: 38px;
  padding: 0;
  border: 0;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.96);
  color: #111827;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 14px 28px rgba(15, 23, 42, 0.18);
  transform: translateY(-50%);
  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease;
}

.stories-home-card__nav:hover {
  transform: translateY(-50%) scale(1.05);
  box-shadow: 0 18px 32px rgba(15, 23, 42, 0.22);
}

.stories-home-card__nav--prev {
  left: 2px;
}

.stories-home-card__nav--next {
  right: 2px;
}

.add-story {
  position: relative;
  flex: 0 0 126px;
  width: 126px;
  max-width: 126px;
  height: 205px;
  margin: 0;
  cursor: pointer;
  border-radius: 28px;
  overflow: hidden;
  background:
    radial-gradient(
      circle at 50% 18%,
      rgba(255, 255, 255, 0.16),
      transparent 30%
    ),
    linear-gradient(180deg, #334155 0%, #0f172a 100%);
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  box-shadow: 0 18px 32px rgba(15, 23, 42, 0.16);
}

.add-story__backdrop,
.story-card__backdrop {
  position: absolute;
  inset: 0;
  display: block;
}

.add-story__backdrop img,
.story-card__backdrop img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: center center;
  transform: scale(1.02);
  transition:
    transform 0.35s ease,
    filter 0.35s ease;
}

.add-story__backdrop video,
.story-card__backdrop video {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: center center;
  transform: scale(1.02);
  transition:
    transform 0.35s ease,
    filter 0.35s ease;
  pointer-events: none;
}

.story-card__backdrop--fallback {
  background: #334155;
}

.add-story::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    180deg,
    rgba(15, 23, 42, 0.02) 0%,
    rgba(15, 23, 42, 0.12) 36%,
    rgba(15, 23, 42, 0.9) 100%
  );
  z-index: 1;
}

.add-story__delete {
  position: absolute;
  top: 14px;
  left: 14px;
  z-index: 4;
  width: 32px;
  height: 32px;
  padding: 0;
}

.story-card__delete {
  position: absolute;
  top: 24px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 4;
  width: 32px;
  height: 32px;
  padding: 0;
}

.add-story__plus {
  width: 48px;
  height: 48px;
  margin: 0 0 8px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.96);
  color: #111827;
  fill: #111827;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 10px 20px rgba(15, 23, 42, 0.16);
  flex: 0 0 auto;
}

body.night-mode .add-story__plus,
body.night-mode .stories-home-card__nav {
  background: rgba(15, 23, 42, 0.92);
  color: #fff;
  fill: #fff;
}

.add-story__copy {
  position: absolute;
  right: 14px;
  bottom: 14px;
  left: 14px;
  z-index: 3;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
  color: #fff;
  width: auto;
  text-align: center;
}

.add-story__label {
  display: block;
  width: 100%;
  font-size: 13px;
  font-weight: 700;
  line-height: 1.35;
  text-align: center;
}

.stories.sngine.carousel .story {
  position: relative;
  flex: 0 0 126px;
  width: 126px;
  max-width: 126px;
  height: 205px;
  margin: 0;
}

.stories.sngine.carousel .story > .item-link {
  position: relative;
  display: block;
  height: 205px;
  border-radius: 28px;
  overflow: hidden;
  background: #0f172a;
  box-shadow: 0 18px 32px rgba(15, 23, 42, 0.16);
}

.story-card__overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(
    180deg,
    rgba(15, 23, 42, 0.02) 0%,
    rgba(15, 23, 42, 0.12) 34%,
    rgba(15, 23, 42, 0.9) 100%
  );
  pointer-events: none;
}

.stories.sngine.carousel .story:hover .story-card__backdrop img,
.stories.sngine.carousel .story:hover .story-card__backdrop video,
.add-story:hover .add-story__backdrop img {
  transform: scale(1.07);
}

.stories.sngine .story.seen .story-card__backdrop img,
.stories.sngine .story.seen .story-card__backdrop video {
  filter: saturate(0.72) brightness(0.82);
}

/* nb##: 首页 Stories 卡片底部信息层使用更高优先级覆盖 Zuck 默认样式，统一收敛到主题 CSS */
.stories-home-card .stories.carousel .story > .item-link > .info {
  position: absolute;
  right: 14px;
  bottom: 14px;
  left: 14px;
  z-index: 2;
  display: flex !important;
  flex-direction: column;
  align-items: center !important;
  justify-content: flex-end !important;
  margin-top: 0 !important;
  width: calc(100% - 28px) !important;
  text-align: center;
  color: #fff;
  font-size: 13px;
  line-height: 1.3;
  padding-left: 0;
  text-shadow: 0 2px 10px rgba(0, 0, 0, 0.24);
  overflow: visible !important;
  text-overflow: clip !important;
}

.stories-home-card .stories.carousel .story > .item-link > .info::before {
  display: none;
}

.stories-home-card .story-card__avatar {
  display: block;
  width: 48px;
  height: 48px;
  margin: 0 0 8px;
  padding: 3px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 12px 24px rgba(15, 23, 42, 0.22);
  align-self: center;
}

.story-card__avatar img {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  object-fit: cover;
  display: block;
}

.stories-home-card .stories.carousel .story > .item-link > .info .name {
  display: block;
  width: 100% !important;
  font-size: 13px;
  font-weight: 700 !important;
  line-height: 1.35;
  text-align: center !important;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.stories-home-card .stories.carousel .story > .item-link > .info .time {
  display: none;
}

body.night-mode .stories.sngine.carousel .story > .item-link,
body.night-mode .add-story {
  box-shadow: 0 20px 36px rgba(0, 0, 0, 0.34);
}

@media (max-width: 575.98px) {
  .stories-wrapper {
    padding: 6px 0 10px;
  }

  .stories-home-card__nav {
    display: none;
  }

  .stories.sngine.carousel .story,
  .add-story {
    flex-basis: 112px;
    width: 112px;
    max-width: 112px;
    height: 184px;
  }

  .stories.sngine.carousel .story > .item-link,
  .story-card__backdrop,
  .add-story__backdrop {
    height: 184px;
  }

  .stories-home-card .stories.carousel .story > .item-link > .info {
    right: 12px;
    bottom: 12px;
    left: 12px;
    width: calc(100% - 24px) !important;
  }

  .stories-home-card .story-card__avatar {
    width: 42px;
    height: 42px;
    margin-bottom: 8px;
  }

  .add-story__plus {
    width: 42px;
    height: 42px;
  }

  .add-story__delete {
    top: 12px;
    left: 12px;
  }

  .story-card__delete {
    top: 20px;
  }
}

#zuck-modal-content .story-viewer.muted .tip.muted {
  display: none !important;
}

/* -- */

/* CHAT */
/* ------------------------------- */

/* chat-sidebar */
.chat-sidebar {
  display: none;
  position: fixed;
  /* nb##: 让 chat-sidebar 改成右下角浮动停靠，避免压住页面右边贴边视觉 BEGIN */
  --chat-sidebar-edge-gap: 12px;
  --chat-sidebar-right-gap: 6px;
  --chat-sidebar-right-offset: max(
    var(--chat-sidebar-right-gap),
    env(safe-area-inset-right, 0px)
  );
  --chat-sidebar-bottom-offset: max(
    var(--chat-sidebar-edge-gap),
    env(safe-area-inset-bottom, 0px)
  );
  right: var(--chat-sidebar-right-offset);
  bottom: var(--chat-sidebar-bottom-offset);
  width: 60px;
  z-index: 1002;
  pointer-events: none;
  --chat-sidebar-max-height: calc(
    100vh - var(--chat-sidebar-edge-gap) - var(--chat-sidebar-bottom-offset)
  );
  /* nb##: END */
}

@media (min-width: 1200px) {
  .chat-sidebar {
    display: block;
  }
}

/* nb##: 仅在 standalone 平板 PWA 中提前启用桌面聊天侧栏，普通移动浏览器仍隐藏 BEGIN */
@media (min-width: 768px) and (min-height: 600px) {
  html.sg-pwa-standalone .chat-sidebar {
    display: block;
  }
}
/* nb##: END */

.chat-sidebar__panel {
  display: flex;
  flex-direction: column;
  height: auto;
  max-height: var(--chat-sidebar-max-height);
  pointer-events: none;
}

/* chat-sidebar-content */
.chat-sidebar-content {
  position: relative;
  flex: 0 1 auto;
  min-height: 0;
  pointer-events: none;
}

.chat-sidebar .slimScrollDiv,
.chat-sidebar-scroll {
  height: auto !important;
  max-height: calc(var(--chat-sidebar-max-height) - 92px);
}

.chat-sidebar-groups {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 0;
}

.chat-sidebar-section {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

.chat-sidebar-section.is-empty {
  display: none;
}

body.night-mode .chat-sidebar-section {
  border-color: transparent;
  background: transparent;
  box-shadow: none;
}

.chat-sidebar-section__label {
  margin: 0;
  color: #8b96a5;
  font-size: 10px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.08em;
  text-align: center;
  text-transform: uppercase;
}

body.night-mode .chat-sidebar-section__label {
  color: #98a4b3;
}

.chat-sidebar-section__list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.chat-sidebar-contact {
  display: block;
  width: 100%;
  padding: 0;
  border: 0;
  background: transparent;
  color: inherit;
  text-align: center;
  cursor: pointer;
  pointer-events: auto;
}

.chat-sidebar-contact__avatar {
  position: relative;
  display: block;
  width: 48px;
  height: 48px;
  margin: 0 auto;
}

.chat-sidebar-contact__avatar img {
  display: block;
  width: 100%;
  height: 100%;
  background-color: #eee;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  border-radius: 50%;
  box-shadow: 0 6px 16px rgba(15, 23, 42, 0.08);
  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease;
}

.chat-sidebar-contact:hover .chat-sidebar-contact__avatar img,
.chat-sidebar-contact:focus-visible .chat-sidebar-contact__avatar img {
  transform: translateY(-1px) scale(1.02);
  box-shadow: 0 10px 22px rgba(15, 23, 42, 0.14);
}

.chat-sidebar-contact__status {
  position: absolute;
  bottom: 0;
  right: 2px;
  border: 3px solid var(--body-bg-color);
  border-radius: 50%;
  font-size: 10px;
  color: #999;
}

body.night-mode .chat-sidebar-contact__status {
  border-color: var(--body-bg-color-dark);
}

.chat-sidebar-contact__status.online {
  color: #65a830;
}

.chat-sidebar-contact__meta {
  display: block;
  min-height: 16px;
  margin-top: 6px;
}

.chat-sidebar-contact__last-seen,
.chat-sidebar-contact__spacer {
  display: block;
  min-height: 12px;
}

.chat-sidebar-contact__last-seen {
  opacity: 0.32;
  background: #e7eaee;
  color: #666;
  font-size: 8px;
  line-height: 1.2;
  padding: 2px 4px;
  border-radius: 999px;
  text-align: center;
  transition:
    opacity 0.2s ease,
    transform 0.2s ease;
}

.chat-sidebar-contact:hover .chat-sidebar-contact__last-seen,
.chat-sidebar-contact:focus-visible .chat-sidebar-contact__last-seen {
  opacity: 1;
  transform: translateY(-1px);
}

body.night-mode .chat-sidebar-contact__last-seen {
  background: var(--card-dark-color);
  color: #999;
}

.chat-sidebar.disabled .chat-sidebar-content,
.chat-sidebar.disabled .chat-sidebar-footer {
  opacity: 0.3;
}

.chat-sidebar.disabled .chat-sidebar-contact__status {
  display: none;
}

/* -- */

/* chat-sidebar-footer */
.chat-sidebar-footer {
  flex: 0 0 auto;
  margin-top: 10px;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  pointer-events: auto;
}

body.night-mode .chat-sidebar-footer {
  border-color: transparent;
  background: transparent;
  box-shadow: none;
}

.chat-sidebar-actions {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}

.chat-sidebar-footer .dropdown-menu {
  pointer-events: auto;
}

/* -- */

/* chat-widget */
.chat-widget {
  display: none;
  position: fixed;
  bottom: 0;
  right: 10px;
  width: 340px;
  z-index: 1000;
  box-shadow:
    0 12px 28px 0 rgb(0 0 0 / 5%),
    0 2px 10px 0 rgb(0 0 0 / 4%);
}

@media (min-width: 992px) {
  .chat-widget {
    display: block;
  }
}

/* nb##: standalone 平板 PWA 允许 chat-widget 提前显示，和侧栏一起工作 BEGIN */
@media (min-width: 768px) and (min-height: 600px) {
  html.sg-pwa-standalone .chat-widget {
    display: block;
  }
}
/* nb##: END */

/* -- */

/* chat-head-title */
.chat-widget-head {
  background: var(--header-bg-color);
  width: 100%;
  padding: 10px 16px;
  border-radius: 16px 16px 0 0;
  min-height: 60px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid #f4f4f4;
  cursor: pointer;
}

body.night-mode .chat-widget-head {
  background: var(--card-dark-color);
  border-color: var(--card-dark-divider);
}

.chat-head-label {
  display: none;
  position: absolute;
  top: -15px;
  right: 5px;
}

.chat-widget.chat-box.new .chat-head-label {
  display: block;
}

.chat-user-card {
  display: flex;
  align-items: center;
  min-width: 0;
}

.chat-user-card .avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  margin-right: 10px;
  position: relative;
}

.chat-user-card .avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
}

.chat-user-card .name {
  font-size: 14px;
  font-weight: 600;
  color: #555;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
}

body.night-mode .chat-user-card .name {
  color: var(--body-color-dark);
}

.chat-user-card .name > span {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
  line-height: normal;
}

/* nb##: CHAT窗口头部头像仅保留国旗角标，不再显示在线小绿点 */
.chat-user-card .online-status {
  position: absolute;
  bottom: 0;
  right: 0;
  border: 2px solid #fff;
  border-radius: 50%;
  font-size: 9px;
  color: #65a830;
  display: none;
}

.chat-user-card .online-status.offline {
  color: #999;
}

/* nb##: chatbox 头部头像国旗角标固定到左下角 */
.chat-user-card .avatar .sg-country-flag--avatar {
  left: 0;
  bottom: 0;
  width: 14px;
  height: 10px;
}

.chat-head-btns {
  flex: 0 0 auto;
}

.chat-head-btn {
  margin-right: 4px;
  background: #fff;
  padding: 4px;
  border-radius: 10px;
}

body.night-mode .chat-head-btn {
  background: var(--card-dark-color);
}

.chat-head-btn:last-child {
  margin-right: 0;
}

.chat-head-btn:hover {
  background: #f4f4f4;
  cursor: pointer;
}

body.night-mode .chat-head-btn:hover {
  background: var(--card-dark-divider);
}

/* -- */

/* chat-widget-content */
.chat-widget-content {
  position: relative;
  /* for chat-to */
  display: none;
  background: #fff;
  padding: 0;
}

body.night-mode .chat-widget-content {
  background: var(--card-dark-color);
}

/* -- */

/* chat-to */
.chat-to {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  background: #fff;
  border-bottom: 1px solid #f4f4f4;
  padding: 10px 10px 10px 40px;
}

body.night-mode .chat-to {
  background: var(--card-dark-input);
  border-color: var(--card-dark-divider);
}

.chat-to .to {
  position: absolute;
  top: 10px;
  left: 10px;
}

.panel-messages .chat-to {
  padding-top: 10px;
  padding-bottom: 10px;
}

.panel-messages .chat-to .to {
  top: 10px;
}

/* -- */

/* chat-conversations */
.chat-conversations {
  padding: 0 7px;
}

/* -- */

/* chat-typing */
.chat-typing {
  display: none;
  padding: 10px;
}

.loading-dots:after {
  content: " .";
  animation: dots 1s steps(5, end) infinite;
}

@keyframes dots {
  0%,
  20% {
    color: rgba(0, 0, 0, 0);
    text-shadow:
      0.25em 0 0 rgba(0, 0, 0, 0),
      0.5em 0 0 rgba(0, 0, 0, 0);
  }

  40% {
    color: var(--body-color);
    text-shadow:
      0.25em 0 0 rgba(0, 0, 0, 0),
      0.5em 0 0 rgba(0, 0, 0, 0);
  }

  60% {
    text-shadow:
      0.25em 0 0 var(--body-color),
      0.5em 0 0 rgba(0, 0, 0, 0);
  }

  80%,
  100% {
    text-shadow:
      0.25em 0 0 var(--body-color),
      0.5em 0 0 var(--body-color);
  }
}

/* -- */

/* chat-voice-notes & chat-attachments */
.chat-voice-notes {
  display: none;
}

.chat-voice-notes,
.chat-attachments {
  background: #fff;
  padding: 10px;
  border-top: 1px solid #f4f4f4;
}

body.night-mode .chat-voice-notes,
body.night-mode .chat-attachments {
  background: var(--card-dark-color);
  border-color: var(--card-dark-divider);
}

/* -- */

/* chat-form */
.chat-form {
  background: #fff;
  padding: 10px;
  border-top: 1px solid #f4f4f4;
  border-radius: 0 0 16px 16px;
}

body.night-mode .chat-form {
  background: var(--card-dark-color);
  border-color: var(--card-dark-divider);
}

.chat-form-message {
  background: #f7f7f7;
  padding: 14px;
  overflow-y: auto;
  overflow-x: hidden;
  max-height: 69px;
  border-radius: 16px;
}

body.night-mode .chat-form-message {
  background-color: var(--card-dark-input);
}

.chat-form-message textarea,
.chat-form-message input[type="text"] {
  background: transparent;
  direction: ltr;
  display: block;
  border: 0 none;
  resize: none;
  outline: none;
  box-shadow: none;
  width: 100%;
  padding: 0;
  margin: 0;
  font-size: 16px;
  line-height: 26px;
  height: 26px;
  overflow: hidden;
}

body.night-mode .chat-form-message textarea,
body.night-mode .chat-form-message input[type="text"] {
  color: #fff;
}

.chat-form .x-form-tools {
  position: static;
  padding-top: 5px;
}

.chat-form ul.x-form-tools > li.x-form-tools-colors {
  color: var(--link-color);
}

.chat-form .emoji-menu {
  bottom: 40px;
  right: 100%;
  left: 2px;
}

.chat-form .emoji-menu:before {
  right: auto;
  left: 38px;
}

.chat-form .emoji-menu:after {
  right: auto;
  left: 39px;
}

/* -- */

/* chat-colors-menu */
.chat-colors-menu {
  display: none;
  position: absolute;
  bottom: 40px;
  left: 28px;
  width: 189px;
  margin: 0;
  padding: 6px;
  font-size: 13px;
  line-height: 100%;
  background-color: #fff;
  border: 1px solid #f4f4f4;
  border-radius: 16px;
  box-shadow: 0 1px 1px rgba(0, 0, 0, 0.05);
  z-index: 99999;
}

body.night-mode .chat-colors-menu {
  background-color: var(--card-dark-color);
  border-color: var(--card-dark-divider);
}

.chat-colors-menu .item {
  float: left;
  padding: 4px;
  margin-right: 1px;
  margin-bottom: 1px;
}

.chat-colors-menu .item:hover {
  cursor: pointer;
  background: #f3f3f3;
  border-radius: 4px;
}

body.night-mode .chat-colors-menu .item:hover {
  background: var(--card-dark-hover);
}

/* -- */

/* conversation */
.conversation {
  padding-top: 10px;
  margin-bottom: 20px;
}

.conversation-user {
  width: 30px;
  height: 30px;
  float: left;
  border-radius: 50%;
  overflow: hidden;
  margin-right: 10px;
}

.conversation-user img {
  width: 30px;
  height: 30px;
  border-radius: 50%;
}

.conversation-user.sg-country-flag-avatar-host {
  overflow: visible;
}

.conversation-body {
  position: relative;
  /* for arrow */
  float: left;
  max-width: -moz-calc(100% - 40px);
  /* 40px = (30px+10px) (avatar + margin) */
  max-width: -webkit-calc(100% - 40px);
  max-width: -o-calc(100% - 40px);
  max-width: calc(100% - 40px);
}

.conversation.right .conversation-user,
.conversation.right .conversation-body {
  float: right;
}

.conversation-body .text {
  float: left;
  background: #f0f2f5;
  padding: 6px 8px;
  border-radius: 12px;
  border-bottom-left-radius: 0;
  word-break: initial;
  word-wrap: break-word;
}

body.night-mode .conversation-body .text {
  background: var(--card-dark-input);
}

.conversation.right .conversation-body .text {
  float: right;
  background: var(--link-color);
  color: #fff;
  border-radius: 12px;
  border-bottom-right-radius: 0;
}

.conversation.right .conversation-body .text a {
  color: #fff;
}

.conversation-body .text a {
  text-decoration: underline;
}

.conversation-body .text a:hover {
  text-decoration: none;
}

.conversation-body .text .twa {
  font-size: 2em;
}

.conversation-body .img-wrapper {
  max-width: 180px;
  border-radius: 16px;
}

.conversation-body .video-wrapper {
  width: 100%;
  border-radius: 16px;
  overflow: hidden;
  border-radius: 16px;
}

.chat-product {
  display: block;
  background: #f7f7f7;
  border-radius: 17px;
  height: auto;
  max-width: 240px;
  min-width: 240px;
}

body.night-mode .chat-product {
  background: var(--card-dark-input);
}

.chat-product-image {
  width: 240px;
  height: auto;
  border-radius: 16px 16px 0 0;
  overflow: hidden;
}

.chat-product-image img {
  display: block;
  width: 100%;
  height: auto;
}

.chat-product-info {
  padding: 10px;
}

.chat-product-title {
  font-size: 16px;
  font-weight: bold;
  display: block;
  overflow: hidden;
  word-break: break-all;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.chat-product-price {
  font-size: 16px;
  font-weight: 500;
  color: red;
}

/* -- */

/* attachments */
.conversation-body .attachments li {
  float: left;
  width: 64px;
  height: 64px;
  margin-right: 5px;
  margin-bottom: 5px;
}

.conversation-body .attachments li.item {
  border: 1px solid #eee;
  cursor: pointer;
}

.conversation-body .attachments li.item img {
  width: 64px;
  height: 64px;
}

.conversation-body .attachments li.loading {
  padding-top: 22px;
  /* 64px-20px(loader) / 2 */
  background: #f3f3f3;
  border: 1px solid #eee;
}

/* -- */

/* time */
.conversation-body .time {
  position: absolute;
  top: 100%;
  left: 0px;
  width: 204px;
  margin-top: 2px;
  color: #605f5f;
  font-size: 10px;
}

body.night-mode .conversation-body .time {
  color: #999;
}

.conversation.right .conversation-body .time {
  right: 0;
  left: auto;
  text-align: right;
}

.conversation-body .time:before {
  content: "\f017";
  font-family: "Font Awesome 7 Pro";
  font-style: normal;
  font-weight: 400;
  text-decoration: inherit;
  margin-top: 4px;
  padding-right: 2px;
  font-size: 0.875em;
}

/* -- */

/* translations */
.conversation-body .translate {
  /* position: absolute;
  /* bottom: 0; */
  /* left: 110%; */
  color: #605f5f;
  font-size: 10px;
  margin-top: 2px;
}

body.night-mode .conversation-body .translate {
  color: #999;
}

.conversation.right .conversation-body .translate {
  right: 0;
  left: auto;
  text-align: right;
}

/* -- */

/* seen */
.conversation-body .seen {
  position: absolute;
  top: 100%;
  right: 0px;
  width: 204px;
  margin-top: 18px;
  margin-bottom: 4px;
  font-size: 10px;
  text-align: right;
}

.conversation-body .seen:before {
  content: "\f00c";
  font-family: "Font Awesome 7 Pro";
  font-style: normal;
  font-weight: 400;
  text-decoration: inherit;
  margin-top: 4px;
  padding-right: 4px;
  font-size: 0.875em;
}

/* -- */

/* video-call-stream (video/audio chat) */
.video-call-stream-wrapper {
  position: relative;
  border-radius: 8px;
}

.video-call-stream,
.video-call-stream-local {
  border-radius: 8px;
}

.video-call-stream div,
.video-call-stream video {
  width: 100%;
  border-radius: 8px;
}

.video-call-stream video {
  height: 100%;
}

.video-call-stream-local {
  display: none;
  height: 420px;
}

@media (min-width: 992px) {
  .video-call-stream-local {
    height: 240px;
  }
}

.video-call-stream-local div,
.video-call-stream-local video {
  width: 100%;
  border-radius: 8px;
}

.video-call-stream-local video {
  height: 100%;
}

@media (min-width: 992px) {
  .video-call-stream-local {
    background: #000;
    position: absolute;
    width: 180px;
    height: 240px;
    top: 20px;
    right: 20px;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.3);
    border: 1px solid #fff;
  }

  .video-call-stream-local div {
    width: 180px;
    height: 240px;
  }
}

/* -- */

/* EMOJI */
/* ------------------------------- */

.emoji-menu {
  display: none;
  position: absolute;
  bottom: 30px;
  right: 0;
  min-width: 252px;
  margin: 0;
  padding: 6px 2px 0 6px;
  font-size: 13px;
  line-height: 100%;
  background-color: #fff;
  border: 1px solid #f5f5f5;
  border-radius: 16px;
  box-shadow:
    rgb(0 0 0 / 10%) 0px 10px 15px -3px,
    rgb(0 0 0 / 10%) 0px 4px 6px -4px;
  z-index: 99999;
}

body.night-mode .emoji-menu {
  background-color: var(--card-dark-color);
  border-color: var(--card-dark-divider);
}

.publisher .emoji-menu {
  bottom: auto;
  top: 25px;
  right: -4px;
}

.lightbox .emoji-menu {
  bottom: auto;
  top: 27px;
  right: -7px;
}

.emoji-menu .item {
  float: left;
  padding: 3px;
  margin-right: 3px;
  margin-bottom: 3px;
}

.emoji-menu .item:hover {
  cursor: pointer;
  background: #f3f3f3;
  border-radius: 4px;
}

body.night-mode .emoji-menu .item:hover {
  background: var(--card-dark-divider);
}

.emoji-menu .item > img {
  width: 65px;
  height: 65px;
}

.emoji-menu .nav-tabs {
  border-top: 1px #f3f3f3 solid;
  border-bottom: 0;
  margin: 0px -2px 0px -6px;
  padding: 0 20px;
}

body.night-mode .emoji-menu .nav-tabs {
  border-color: var(--card-dark-divider);
}

.emoji-menu .nav-tabs > li > .nav-link {
  color: #555;
  padding: 14px 18px;
  margin: 0;
  border: 0;
  border-radius: 0;
  border-top: 2px solid transparent;
}

body.night-mode .emoji-menu .nav-tabs > li > .nav-link {
  color: var(--body-color-dark);
}

.emoji-menu .nav-tabs > li > .nav-link:hover {
  background: transparent;
  color: var(--link-color);
  border-color: transparent;
  border-bottom: 0;
}

.emoji-menu .nav-tabs > li > .nav-link.active,
.emoji-menu .nav-tabs > li > .nav-link.active:hover,
.emoji-menu .nav-tabs > li > .nav-link.active:focus {
  border: 0;
  color: var(--link-color);
  background: transparent;
  border-top: 2px solid var(--link-color);
  margin-top: -1px;
}

/* -- */

/* REACTIONS */
/* ------------------------------- */

/* reactions-stats */
.reactions-stats {
  display: inline-flex;
  align-items: flex-end;
  cursor: pointer;
  line-height: 1;
}

.reactions-stats > .reactions-stats-item {
  float: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #fff;
  margin: 0 0 0 -12px;
  padding: 6px;
  border-radius: 50%;
}

/* nb##: reactions-stats 内表情图标放大一倍并强制居中，避免沿用全局 emoji 位移逻辑 */
.reactions-stats .inline-emoji {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  line-height: 0;
}

.reactions-stats .inline-emoji .emoji {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  position: static;
  transform: none;
}

.reactions-stats .inline-emoji .emoji img {
  display: block;
  width: 36px;
  height: 36px;
}

.reactions-stats > span {
  align-self: flex-end;
  margin-left: 8px;
  line-height: 1;
  padding-bottom: 3px;
}

body.night-mode .reactions-stats > .reactions-stats-item {
  background: var(--card-dark-color);
}

.reactions-stats > .reactions-stats-item:nth-child(1) {
  z-index: 3;
}

.reactions-stats > .reactions-stats-item:nth-child(2) {
  z-index: 2;
}

.reactions-stats > .reactions-stats-item:nth-child(3) {
  z-index: 1;
}

/* -- */

.reactions-wrapper {
  position: relative;
}

/* reaction-btn */
.reaction-btn {
  display: flex;
  align-items: center;
  justify-content: center;
}

.reaction-btn .reaction-btn-icon {
  display: inline-block;
}

.reaction-btn .reaction-btn-icon .fal {
  font-size: 20px;
  color: #000;
}

.reaction-btn .reaction-btn-name {
  text-transform: capitalize;
  margin-left: 5px;
}

/* -- */

.reactions-container {
  display: none;
  position: fixed;
  background: #fff;
  box-shadow: 0 1px 5px rgba(0, 0, 0, 0.2);
  border-radius: 40px;
  z-index: 4;
}

body.night-mode .reactions-container {
  background: var(--card-dark-input);
}

@media (max-width: 480px) {
  .reactions-container {
    width: 144px;
    border-radius: 20px;
  }
}

.reactions_item {
  width: 48px;
  height: 48px;
  float: left;
  transform: scale(1);
  transition: transform 0.25s ease;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
  -webkit-animation: slideUp cubic-bezier(0.49, 0, 0.46, 1);
  animation: slideUp cubic-bezier(0.49, 0, 0.46, 1);
}

.reactions_item.duration-1 {
  -webkit-animation-duration: 0.1s;
  animation-duration: 0.1s;
}

.reactions_item.duration-2 {
  -webkit-animation-duration: 0.2s;
  animation-duration: 0.2s;
}

.reactions_item.duration-3 {
  -webkit-animation-duration: 0.3s;
  animation-duration: 0.3s;
}

.reactions_item.duration-4 {
  -webkit-animation-duration: 0.4s;
  animation-duration: 0.4s;
}

.reactions_item.duration-5 {
  -webkit-animation-duration: 0.5s;
  animation-duration: 0.5s;
}

.reactions_item.duration-6 {
  -webkit-animation-duration: 0.6s;
  animation-duration: 0.6s;
}

.reactions_item.duration-7 {
  -webkit-animation-duration: 0.7s;
  animation-duration: 0.7s;
}

.reactions_item:hover {
  transform: scale(1.25) translate(0, -3px);
}

.reactions_item:after {
  content: attr(data-title);
  position: absolute;
  background-color: rgba(0, 0, 0, 0.75);
  border-radius: 16px;
  box-sizing: border-box;
  color: #fff;
  display: inline-block;
  font-size: 10px;
  font-weight: bold;
  font-style: normal;
  line-height: 16px;
  opacity: 0;
  overflow: hidden;
  padding: 0 8px;
  text-decoration: none;
  text-overflow: ellipsis;
  transition: opacity 50ms ease;
  -webkit-user-select: none;
  text-transform: capitalize;
  visibility: hidden;
  top: 0;
  left: 50%;
  -webkit-transform: translate(-50%, -100%);
  transform: translate(-50%, -100%);
}

.reactions_item:hover:after {
  opacity: 1;
  visibility: visible;
}

@-webkit-keyframes slideUp {
  0% {
    opacity: 0;
    transform: translateY(30px);
  }

  100% {
    opacity: 1;
    transform: translateY(0px);
  }
}

@keyframes slideUp {
  0% {
    opacity: 0;
    transform: translateY(30px);
  }

  100% {
    opacity: 1;
    transform: translateY(0px);
  }
}

/* -- Reaction Emoji */
.inline-emoji {
  width: 18px;
  height: 18px;
}

.inline-emoji .emoji {
  transform: scale(0.15);
  top: -285%;
  right: 285%;
}

.no_animation *,
.no_animation *:after,
.no_animation *:before {
  animation: none !important;
}

.emoji {
  width: 120px;
  height: 120px;
  display: inline-block;
  border-radius: 50%;
  position: relative;
  transform: scale(0.325);
  top: -76%;
  right: 76%;
}

.emoji img {
  width: 120px;
  height: 120px;
}

.reaction img {
  animation-fill-mode: both;
  animation-duration: 1.3s;
  animation-iteration-count: infinite;
}

.reaction.reaction-1 img {
  animation-name: bounce;
  transform-origin: center bottom;
}

.reaction.reaction-2 img {
  animation-name: heartBeat;
  animation-timing-function: ease-in-out;
}

.reaction.reaction-3 img {
  animation-name: swing;
  transform-origin: top center;
}

.reaction.reaction-4 img {
  animation-name: pulse;
  animation-timing-function: ease-in-out;
}

.reaction.reaction-5 img {
  animation-name: fadeInDown;
}

.reaction.reaction-6 img {
  animation-name: swing;
  animation-timing-function: ease-in-out;
}

.reaction.reaction-7 img {
  animation-name: headShake;
  animation-timing-function: ease-in-out;
}

@keyframes bounce {
  from,
  20%,
  53%,
  to {
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    transform: translate3d(0, 0, 0);
  }

  40%,
  43% {
    animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
    transform: translate3d(0, -2px, 0) scaleY(1.1);
  }

  70% {
    animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
    transform: translate3d(0, -1px, 0) scaleY(1.05);
  }

  80% {
    transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    transform: translate3d(0, 0, 0) scaleY(0.95);
  }

  90% {
    transform: translate3d(0, -1px, 0) scaleY(1.02);
  }
}

@keyframes heartBeat {
  0% {
    transform: scale(1);
  }

  14% {
    transform: scale(1.05);
  }

  28% {
    transform: scale(1);
  }

  42% {
    transform: scale(1.05);
  }

  70% {
    transform: scale(1);
  }
}

@keyframes swing {
  20% {
    transform: rotate3d(0, 0, 1, 2deg);
  }

  40% {
    transform: rotate3d(0, 0, 1, -2deg);
  }

  60% {
    transform: rotate3d(0, 0, 1, 0deg);
  }

  80% {
    transform: rotate3d(0, 0, 1, -2deg);
  }

  to {
    transform: rotate3d(0, 0, 1, 0deg);
  }
}

@keyframes pulse {
  from {
    transform: scale3d(1, 1, 1);
  }

  50% {
    transform: scale3d(1.05, 1.05, 1.05);
  }

  to {
    transform: scale3d(1, 1, 1);
  }
}

@keyframes fadeInDown {
  from {
    opacity: 1;
    transform: translate3d(0, -5%, 0);
  }

  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

@keyframes headShake {
  0% {
    transform: translateX(0);
  }

  6.5% {
    transform: translateX(-2px) rotateY(-9deg);
  }

  18.5% {
    transform: translateX(1px) rotateY(7deg);
  }

  31.5% {
    transform: translateX(-1px) rotateY(-5deg);
  }

  43.5% {
    transform: translateX(1px) rotateY(3deg);
  }

  50% {
    transform: translateX(0);
  }
}

/* -- */

/* RATING */
/* ------------------------------- */

/* star-rating */
.star-rating {
  display: flex;
  justify-content: flex-end;
  flex-direction: row-reverse;
  font-size: 28px;
  color: #999;
}

.star-rating input {
  display: none;
}

.star-rating label {
  margin-left: 5px;
  cursor: pointer;
}

.star-rating label:last-child {
  margin-left: 0;
}

.star-rating > label:hover i {
  color: #ff9800;
}

.star-rating > label:hover ~ label i {
  color: #ff9800;
}

.star-rating > input:checked ~ label i {
  color: #ff9800;
}

/* -- */

/* review-stars */
.review-stars {
  font-size: 22px;
  color: #999;
}

.review-stars.small {
  font-size: 13px;
}

.review-stars i.checked {
  color: #ff9800;
}

.review-review {
  font-size: 14px;
}

.review-photos img {
  width: 100px;
  height: 100px;
  border-radius: 16px;
  margin-right: 5px;
  margin-bottom: 5px;
  border: 1px solid #d5d5d5;
  padding: 2px;
}

.review-reply {
  background: #ededed;
  border-radius: 16px;
  width: 80%;
  margin: 0 auto;
  padding: 10px;
}

body.night-mode .review-reply {
  background: var(--card-dark-color);
}

/* -- */

/* PAGE = [BASIC] */
/* ------------------------------- */

/* page-header */
.page-header {
  background: linear-gradient(to right, #667db6, #0082c8, #0082c8, #667db6);
  position: relative;
  text-align: center;
  padding: 70px 15px;
  overflow: hidden;
  color: #fff;
  z-index: auto;
}

.page-header.mini {
  padding: 35px 15px;
}

@media (min-width: 768px) {
  .page-header {
    padding: 90px 15px;
  }

  .page-header.mini {
    padding: 45px 15px;
  }
}

.page-header.bank-transfer {
  z-index: 1;
  padding: 20px;
  background-color: #2196f3;
  background: linear-gradient(90deg, #03a9f4 0%, #2196f3 35%, #3f51b5 100%);
}

.page-header .floating-img {
  position: absolute;
  bottom: 10px;
  left: 10%;
  width: 300px;
  opacity: 0.5;
  /*z-index: -997;*/
}

.page-header .circle-1 {
  position: absolute;
  top: 60px;
  left: -180px;
  width: 290px;
  height: 290px;
  background-image: radial-gradient(
    circle 800px at 75% -25%,
    #000000 0,
    rgba(255, 255, 255, 0) 100%
  );
  border-radius: 50%;
  opacity: 0.05;
}

.page-header .circle-2 {
  position: absolute;
  top: 17px;
  right: -242px;
  width: 500px;
  height: 500px;
  background-image: radial-gradient(
    circle 800px at 10% -25%,
    #000000 0,
    rgba(255, 255, 255, 0) 100%
  );
  border-radius: 50%;
  opacity: 0.03;
}

.page-header .circle-3 {
  position: absolute;
  top: -73px;
  right: 78px;
  width: 200px;
  height: 200px;
  background-image: radial-gradient(
    circle 800px at 10% -25%,
    #000000 0,
    rgba(255, 255, 255, 0) 100%
  );
  border-radius: 50%;
  opacity: 0.04;
}

.page-header .inner {
  z-index: 999;
}

.page-header.bank-transfer .inner {
  border: 6px solid rgba(255, 255, 255, 0.3);
  padding: 20px;
  border-radius: 5px;
}

.page-header.bank-transfer .bank-info-meta {
  font-size: 18px;
}

.page-header.bank-transfer .bank-info-help {
  font-size: 12px;
  color: #eee;
  text-transform: uppercase;
}

/* -- */

/* footer */
.footer {
  border-top: 1px solid #e6ecf5;
  padding-top: 10px;
  padding-bottom: 10px;
  margin-top: 25px;
  margin-bottom: 25px;
}

@media (max-width: 768px) {
  .footer {
    margin-bottom: 85px;
  }
}

body.night-mode .footer {
  border-top: 1px solid var(--card-dark-divider);
}

@media (min-width: 768px) {
  .footer .links {
    text-align: right;
  }
}

/* -- */

/* mini-footer */
.mini-footer {
  font-size: 12px;
  margin-top: 25px;
  margin-bottom: 25px;
}

@media (max-width: 768px) {
  .mini-footer {
    margin-bottom: 85px !important;
  }
}

.mini-footer .copyrights {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-bottom: 5px;
  margin-bottom: 5px;
  color: #858585;
  font-weight: 500;
  border-bottom: 1px solid #e9e9e9;
}

body.night-mode .mini-footer .copyrights {
  border-bottom-color: var(--card-dark-divider);
}

.mini-footer .links {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  margin: 0 -5px 0;
}

.mini-footer .links li {
  display: inline-block;
  padding-right: 5px;
  padding-left: 5px;
}

/* -- */

/* footer bottom bar */
.footer-bottom-bar {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 999;
  background: #fff;
  border-top: 1px solid #e6ecf5;
  height: 70px;
}

body.night-mode .footer-bottom-bar {
  background: #1c1e21;
  border-top: 1px solid #2c2f33;
}

@media (min-width: 768px) {
  .footer-bottom-bar {
    display: none;
  }
}

/* bottom bar links */
.footer-bottom-bar-links {
  display: flex;
  gap: 10px;
}

.footer-bottom-bar-links > .link {
  flex: 1;
  text-align: center;
  height: 70px;
}

.footer-bottom-bar-links > .link > a {
  position: relative;
  display: block;
  text-align: center;
  padding: 8px 10px 8px 10px;
  margin: 2px 0;
  border-radius: 10px;
  color: #000;
}

.footer-bottom-bar-links > .link > a:hover {
  background-color: rgb(160 160 160 / 10%);
}

body.night-mode .footer-bottom-bar-links > .link > a:hover {
  background-color: rgb(234 234 234 / 10%);
}

.footer-bottom-bar-links .link > a > .title {
  font-size: 12px;
  line-height: 26px;
}

body.night-mode .footer-bottom-bar-links .link > a > .title {
  color: #c1d4e3;
}

.footer-bottom-bar-links > .link.active > a > .title,
body.night-mode .footer-bottom-bar-links > .link.active > a > .title {
  color: var(--link-color);
  font-weight: bold;
}

.footer-bottom-bar-links .dropdown-widget {
  box-shadow: none;
  border-radius: 8px 8px 0 0;
}

.footer-quick-adds {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  padding: 20px;
}

.footer-quick-adds .add-quick-item {
  flex: 1;
  text-align: center;
  background: #f7f7f7;
  padding: 10px;
  border-radius: 12px;
  min-width: 150px;
  color: #000;
  cursor: pointer;
  font-size: 13px;
}

.footer-quick-adds .add-quick-item.full {
  flex-basis: 100%;
}

.footer-quick-adds .add-quick-item:hover {
  background: #f3f6f9;
}

body.night-mode .footer-quick-adds .add-quick-item {
  background: var(--card-dark-hover);
  color: #c1d4e3;
}

body.night-mode .footer-quick-adds .add-quick-item:hover {
  background: var(--card-dark-input);
}

.quick-menu-items {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 15px;
}

.quick-menu-item,
.quick-menu-item-mini {
  flex: 1;
  display: block;
  background: #f7f7f7;
  padding: 20px 15px;
  border-radius: 12px;
  color: #000;
}

body.night-mode .quick-menu-item,
body.night-mode .quick-menu-item-mini {
  background: var(--card-dark-hover);
  color: #c1d4e3;
}

.quick-menu-item-mini {
  min-width: 150px;
  font-size: 13px;
}

/* -- */

/* language-dropdown */
.language-dropdown {
  padding: 8px 12px;
  border-radius: 4px;
}

.language-dropdown:hover {
  background: #f3f6f9;
}

/* -- */

/* PAGE = [404] */
/* ------------------------------- */

.notfound-wrapper {
  position: relative;
  min-height: 560px;
}

.notfound {
  position: absolute;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  max-width: 560px;
  width: 100%;
  padding-left: 160px;
  line-height: 1.1;
}

.notfound .notfound-circle {
  position: absolute;
  left: 0;
  top: 0;
  width: 140px;
  height: 140px;
  font-size: 140px;
}

.notfound .notfound-circle:before {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  -webkit-transform: scale(2.4);
  -ms-transform: scale(2.4);
  transform: scale(2.4);
  border-radius: 50%;
  background-color: #f2f5f8;
  z-index: -1;
}

body.night-mode .notfound .notfound-circle:before {
  background-color: var(--card-dark-color);
}

@media only screen and (max-width: 767px) {
  .notfound {
    padding-left: 15px;
    padding-right: 15px;
    padding-top: 110px;
  }

  .notfound .notfound-circle {
    width: 110px;
    height: 110px;
    font-size: 110px;
  }
}

.notfound h1 {
  font-family: "Nunito", sans-serif;
  font-size: 65px;
  font-weight: 700;
  margin-top: 0px;
  margin-bottom: 10px;
  color: #151723;
  text-transform: uppercase;
}

.notfound h2 {
  font-family: "Nunito", sans-serif;
  font-size: 21px;
  font-weight: 400;
  margin: 0;
  text-transform: uppercase;
  color: #151723;
}

body.night-mode .notfound h1,
body.night-mode .notfound h2 {
  color: #fff;
}

/* -- */

/* PAGE = [OAUTH] */
/* ------------------------------- */

/* ouath-card */
.card-ouath-overlay {
  background: #000;
  position: fixed;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  opacity: 0.6;
  transition: opacity 0.5s;
  z-index: 1002;
}

.card-ouath {
  background: #fff;
  border: 0;
  box-shadow: 0 1px 1px rgba(0, 0, 0, 0.05);
  z-index: 1003;
}

/* -- */

/* daytime_message */
.daytime_message {
  display: none;
  padding: 15px;
  margin-bottom: 20px;
  border-left: 2px solid #fba540 !important;
}

.daytime_message button {
  margin-top: 4px;
  font-size: 18px;
}

/* -- */

/* PAGE = [FORUMS] */
/* ------------------------------- */

/* nb##: 全站 breadcrumb 统一通过 sg-site-breadcrumb 向 Bootstrap 注入主题变量，结构层交回原生 breadcrumb 骨架 */
.sg-site-breadcrumb {
  --sg-breadcrumb-link: #5b6776;
  --sg-breadcrumb-link-hover: var(--link-color);
  --sg-breadcrumb-active: #1f2937;
  --sg-breadcrumb-divider-color: rgba(91, 103, 118, 0.5);
  --bs-breadcrumb-divider: "/";
  --bs-breadcrumb-divider-color: var(--sg-breadcrumb-divider-color);
  --bs-breadcrumb-item-active-color: var(--sg-breadcrumb-active);
  --bs-breadcrumb-font-size: 0.72rem;
  --bs-breadcrumb-item-padding-x: 0.45rem;
  --bs-breadcrumb-margin-bottom: 0;
  margin-top: 20px;
  font-family:
    "IBM Plex Sans", "Work Sans", "Segoe UI", Helvetica, Arial,
    "Microsoft YaHei", sans-serif;
  font-weight: 600;
  letter-spacing: 0.08em;
  line-height: 1.2;
  text-transform: uppercase;
  overflow-wrap: anywhere;
  word-break: normal;
}

.sg-site-breadcrumb .breadcrumb-item {
  min-width: 0;
}

.sg-site-breadcrumb .breadcrumb-item > a,
.sg-site-breadcrumb .breadcrumb-item > span {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  min-width: 0;
}

.sg-site-breadcrumb .breadcrumb-item > a {
  color: var(--sg-breadcrumb-link);
  text-decoration: none;
  transition: color 0.18s ease;
}

.sg-site-breadcrumb .breadcrumb-item > a:hover,
.sg-site-breadcrumb .breadcrumb-item > a:focus {
  color: var(--sg-breadcrumb-link-hover);
}

.sg-site-breadcrumb .breadcrumb-item.active,
.sg-site-breadcrumb .breadcrumb-item.active > span,
.sg-site-breadcrumb .breadcrumb-item.active > a {
  color: var(--sg-breadcrumb-active);
}

.sg-site-breadcrumb .breadcrumb-item i {
  flex-shrink: 0;
}

.sg-site-breadcrumb--accent {
  position: relative;
  padding-inline-start: 18px;
}

.sg-site-breadcrumb--accent::before {
  content: "";
  position: absolute;
  inset-inline-start: 0;
  top: 16.67%;
  bottom: 16.67%;
  width: 6px;
  background: var(--link-color);
}

/* -- */

/* forum-title */
.forum-title {
  margin-top: 20px;
  margin-bottom: 20px;
  word-wrap: break-word;
}

.forum-title h1 {
  font-size: 20px;
  margin-top: 0;
  margin-bottom: 5px;
}

.forum-title p {
  margin-bottom: 0;
}

.forum-thread-header {
  margin-bottom: 18px;
}

.forum-thread-detail-public .forum-thread-header {
  position: relative;
}

.forum-thread-detail-public
  .forum-thread-header.forum-thread-header-has-watermark {
  min-height: 88px;
  padding-right: 92px;
}

.forum-thread-header h1 {
  font-size: 32px;
  line-height: 1.2;
  margin-bottom: 0;
}

.forum-thread-header h1 .badge {
  font-size: 12px;
  padding: 0.45em 0.65em;
  vertical-align: middle;
}

.forum-thread-header h1 .forum-solved-badge {
  display: inline-flex;
  margin-left: 6px !important;
  vertical-align: baseline;
}

.forum-thread-header-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
  justify-content: flex-end;
  margin-top: 16px;
}

.forum-thread-header-actions .btn {
  padding: 0.25rem 1rem;
  font-size: 0.875rem;
  line-height: 1.5;
}

.forum-thread-detail-public .forum-thread-header-watermark {
  position: absolute;
  right: 0;
  bottom: -6px;
  pointer-events: none;
  user-select: none;
}

.forum-thread-detail-public
  .forum-thread-header-watermark
  .forum-thread-type-watermark {
  --forum-thread-watermark-min-width: 4.8rem;
  --forum-thread-watermark-question-size: 4.75rem;
  --forum-thread-watermark-announcement-size: 3rem;
}

/* nb##: PUBLIC THREAD 详情页正文操作按钮、回复入口按钮与统计分隔条统一收敛到这一组样式 */
.forum-thread-detail-public .forum-thread-body-footer,
.forum-thread-detail-public .forum-thread-detail-entry-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
}

.forum-thread-detail-public .forum-thread-detail-entry-actions {
  margin: 14px 0 8px;
}

.forum-thread-detail-public .forum-thread-body-footer {
  flex-wrap: wrap;
  margin-top: 14px;
}

.forum-thread-detail-public .forum-thread-action-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border-radius: 999px;
  border-width: 1px;
  font-weight: 700;
  transition:
    background-color 0.18s ease,
    border-color 0.18s ease,
    color 0.18s ease,
    box-shadow 0.18s ease;
}

.forum-thread-detail-public .forum-thread-action-chip.btn-light {
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  border-color: rgba(79, 95, 111, 0.14);
  color: #314253;
  box-shadow: 0 10px 22px rgba(15, 23, 42, 0.05);
}

.forum-thread-detail-public .forum-thread-action-chip.btn-light:hover,
.forum-thread-detail-public .forum-thread-action-chip.btn-light:focus,
.forum-thread-detail-public .forum-thread-action-chip.btn-light:active {
  background: linear-gradient(180deg, #f8fbff 0%, #eef6ff 100%);
  border-color: rgba(59, 130, 246, 0.22);
  color: #1f4d80;
  box-shadow: 0 12px 24px rgba(37, 99, 235, 0.08);
}

.forum-thread-detail-public .forum-thread-action-chip--readonly {
  padding: 0.425rem 0.95rem;
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(79, 95, 111, 0.12);
  color: #51606f;
  font-size: 13px;
  font-weight: 600;
}

.forum-thread-detail-public .forum-thread-action-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 30px;
  padding: 0 8px;
  border-radius: 999px;
  background: rgba(79, 95, 111, 0.08);
  font-size: 12px;
  font-weight: 700;
}

.forum-thread-detail-public
  .forum-thread-action-chip.btn-forum-follow-active
  .forum-thread-action-count {
  background: rgba(255, 255, 255, 0.72);
  color: #14532d;
}

.forum-thread-detail-public
  .forum-thread-action-chip.btn-light
  .forum-thread-action-count {
  background: rgba(79, 95, 111, 0.08);
  color: #334155;
}

.forum-thread-detail-public .forum-thread-detail-entry-btn {
  padding: 0.8rem 1.35rem;
  border-radius: 999px;
  font-size: 15px;
  font-weight: 700;
  box-shadow: 0 14px 28px rgba(37, 99, 235, 0.18);
}

.forum-thread-detail-public .forum-thread-detail-entry-btn:hover,
.forum-thread-detail-public .forum-thread-detail-entry-btn:focus {
  box-shadow: 0 16px 32px rgba(37, 99, 235, 0.24);
}

.forum-replies-divider {
  display: flex;
  align-items: center;
  gap: 14px;
  margin: 20px 0 14px;
  color: #4f5f6f;
}

.forum-replies-divider-summary {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
}

.forum-replies-divider-form {
  display: inline-flex;
  margin: 0;
}

.forum-replies-divider-label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
  padding: 8px 12px;
  border: 1px solid rgba(79, 95, 111, 0.12);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.88);
  color: #51606f;
  font-size: 13px;
  font-weight: 600;
}

.forum-replies-divider-label i {
  color: #6f7f8f;
}

.forum-replies-divider-stat {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.88);
  border: 1px solid rgba(79, 95, 111, 0.12);
  color: #51606f;
  font-size: 13px;
  font-weight: 600;
}

.forum-replies-divider-stat-btn {
  appearance: none;
  -webkit-appearance: none;
  font: inherit;
  text-align: left;
  cursor: pointer;
  text-decoration: none;
  border-style: solid;
  border-width: 2px;
  min-height: 48px;
  transition:
    background-color 0.18s ease,
    border-color 0.18s ease,
    color 0.18s ease;
}

.forum-replies-divider-stat-btn.btn-light {
  background: linear-gradient(180deg, #f7fbff 0%, #e8f3ff 100%);
  border-color: rgba(59, 130, 246, 0.48);
  color: #16385f;
}

.forum-replies-divider-stat-btn.btn-light i,
.forum-replies-divider-stat-btn.btn-light .forum-stat-number,
.forum-replies-divider-stat-btn.btn-light strong {
  color: inherit;
}

.forum-replies-divider-stat-btn.btn-light:hover,
.forum-replies-divider-stat-btn.btn-light:focus,
.forum-replies-divider-stat-btn.btn-light:active {
  background: linear-gradient(180deg, #e3f0ff 0%, #cfe4ff 100%);
  border-color: rgba(37, 99, 235, 0.72);
  color: #0f3f74;
}

.forum-replies-divider-stat-btn.btn-forum-follow-active {
  background: linear-gradient(180deg, #28a86b 0%, #1d7f51 100%);
  border-color: rgba(21, 128, 61, 0.66);
  color: #f5fff9;
}

.forum-replies-divider-stat-btn.btn-forum-follow-active .forum-stat-number,
.forum-replies-divider-stat-btn.btn-forum-follow-active i,
.forum-replies-divider-stat-btn.btn-forum-follow-active strong {
  color: inherit;
}

.forum-replies-divider-stat-btn.btn-forum-follow-active:hover,
.forum-replies-divider-stat-btn.btn-forum-follow-active:focus,
.forum-replies-divider-stat-btn.btn-forum-follow-active:active {
  background: linear-gradient(180deg, #31ba76 0%, #249463 100%);
  border-color: rgba(21, 128, 61, 0.84);
  color: #ffffff;
}

.forum-replies-divider-stat--readonly {
  cursor: default;
}

.forum-stat-number {
  display: inline-block;
  font-size: 15px;
  font-style: italic;
  font-weight: 800;
}

.forum-thread-detail-public .forum-replies-divider {
  margin-top: 12px;
}

.forum-thread-detail-public .forum-replies-divider-summary {
  gap: 12px;
}

.forum-thread-detail-public .forum-replies-divider-label,
.forum-thread-detail-public .forum-replies-divider-stat {
  gap: 10px;
  padding: 10px 14px;
}

.forum-thread-detail-public .forum-replies-divider .forum-stat-number {
  font-size: 22px;
  line-height: 1;
}

.forum-thread-detail-public .forum-replies-divider .sg-stats-number {
  letter-spacing: -0.02em;
}

.forum-thread-detail-public .forum-replies-divider strong {
  font-size: 12px;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

.forum-replies-divider-stat i {
  color: #6f7f8f;
}

.forum-replies-divider-line {
  flex: 1 1 auto;
  height: 1px;
  background: linear-gradient(
    90deg,
    rgba(79, 95, 111, 0.28),
    rgba(79, 95, 111, 0.08)
  );
}

body.night-mode .sg-site-breadcrumb--accent {
  background: transparent;
}

body.night-mode .sg-site-breadcrumb--accent::before {
  background: var(--link-color);
}

body.night-mode .sg-site-breadcrumb {
  --sg-breadcrumb-link: rgba(226, 232, 240, 0.78);
  --sg-breadcrumb-link-hover: #7dd3fc;
  --sg-breadcrumb-active: rgba(248, 250, 252, 0.95);
  --sg-breadcrumb-divider-color: rgba(226, 232, 240, 0.38);
}

body.night-mode .forum-replies-divider {
  color: #b7c3cf;
}

body.night-mode .forum-replies-divider-label {
  background: rgba(255, 255, 255, 0.04);
  border-color: rgba(183, 195, 207, 0.18);
  color: #d1d8df;
}

body.night-mode .forum-replies-divider-label i {
  color: #aebdca;
}

body.night-mode .forum-replies-divider-stat {
  background: rgba(255, 255, 255, 0.04);
  border-color: rgba(183, 195, 207, 0.18);
  color: #d1d8df;
}

body.night-mode .forum-replies-divider-stat-btn.btn-light {
  background: linear-gradient(
    180deg,
    rgba(59, 130, 246, 0.2) 0%,
    rgba(30, 64, 175, 0.18) 100%
  );
  border-color: rgba(125, 211, 252, 0.44);
  color: #e8f3ff;
}

body.night-mode .forum-replies-divider-stat-btn.btn-light:hover,
body.night-mode .forum-replies-divider-stat-btn.btn-light:focus,
body.night-mode .forum-replies-divider-stat-btn.btn-light:active {
  background: linear-gradient(
    180deg,
    rgba(96, 165, 250, 0.36) 0%,
    rgba(37, 99, 235, 0.28) 100%
  );
  border-color: rgba(125, 211, 252, 0.72);
  color: #f8fafc;
}

body.night-mode .forum-replies-divider-stat-btn.btn-forum-follow-active {
  background: linear-gradient(
    180deg,
    rgba(34, 197, 94, 0.72) 0%,
    rgba(21, 128, 61, 0.82) 100%
  );
  border-color: rgba(134, 239, 172, 0.58);
  color: #f3fff7;
}

body.night-mode .forum-replies-divider-stat-btn.btn-forum-follow-active:hover,
body.night-mode .forum-replies-divider-stat-btn.btn-forum-follow-active:focus,
body.night-mode .forum-replies-divider-stat-btn.btn-forum-follow-active:active {
  background: linear-gradient(
    180deg,
    rgba(74, 222, 128, 0.82) 0%,
    rgba(22, 163, 74, 0.9) 100%
  );
  border-color: rgba(187, 247, 208, 0.74);
  color: #ffffff;
}

body.night-mode .forum-replies-divider-stat i {
  color: #aebdca;
}

body.night-mode .forum-replies-divider-line {
  background: linear-gradient(
    90deg,
    rgba(183, 195, 207, 0.28),
    rgba(183, 195, 207, 0.06)
  );
}

body.night-mode
  .forum-thread-detail-public
  .forum-thread-action-chip--readonly {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(183, 195, 207, 0.18);
  color: #d1d8df;
}

body.night-mode
  .forum-thread-detail-public
  .forum-thread-action-chip.btn-light {
  background: linear-gradient(
    180deg,
    rgba(255, 255, 255, 0.06) 0%,
    rgba(255, 255, 255, 0.03) 100%
  );
  border-color: rgba(183, 195, 207, 0.18);
  color: #dbe7f2;
  box-shadow: 0 12px 22px rgba(2, 6, 23, 0.22);
}

body.night-mode
  .forum-thread-detail-public
  .forum-thread-action-chip.btn-light:hover,
body.night-mode
  .forum-thread-detail-public
  .forum-thread-action-chip.btn-light:focus,
body.night-mode
  .forum-thread-detail-public
  .forum-thread-action-chip.btn-light:active {
  background: linear-gradient(
    180deg,
    rgba(125, 211, 252, 0.14) 0%,
    rgba(59, 130, 246, 0.12) 100%
  );
  border-color: rgba(125, 211, 252, 0.28);
  color: #eff7ff;
  box-shadow: 0 14px 26px rgba(15, 23, 42, 0.3);
}

body.night-mode .forum-thread-detail-public .forum-thread-action-count {
  background: rgba(183, 195, 207, 0.12);
  color: #eff4f9;
}

body.night-mode
  .forum-thread-detail-public
  .forum-thread-action-chip.btn-forum-follow-active
  .forum-thread-action-count {
  background: rgba(255, 255, 255, 0.18);
  color: #f0fdf4;
}

body.night-mode
  .forum-thread-detail-public
  .forum-thread-action-chip.btn-light
  .forum-thread-action-count {
  background: rgba(183, 195, 207, 0.14);
  color: #e2e8f0;
}

body.night-mode
  .forum-thread-detail-public
  .forum-thread-header-watermark
  .forum-thread-type-watermark--question {
  color: rgba(125, 211, 252, 0.16);
}

body.night-mode
  .forum-thread-detail-public
  .forum-thread-header-watermark
  .forum-thread-type-watermark--announcement {
  color: rgba(56, 189, 248, 0.18);
}

.forum-space-manage-table {
  margin-bottom: 0;
}

.forum-space-manage-edit-row > td.forum-space-manage-edit-cell {
  background: linear-gradient(
    180deg,
    rgba(248, 250, 252, 0.98) 0%,
    rgba(241, 245, 249, 0.94) 100%
  );
  border-top-color: rgba(79, 95, 111, 0.08);
}

.forum-space-manage-edit-cell .form-control,
.forum-space-manage-edit-cell .form-select {
  background-color: #fff;
}

body.night-mode .forum-space-manage-edit-row > td.forum-space-manage-edit-cell {
  background: linear-gradient(
    180deg,
    rgba(15, 23, 42, 0.96) 0%,
    rgba(15, 23, 42, 0.9) 100%
  );
  border-top-color: rgba(148, 163, 184, 0.18);
}

body.night-mode .forum-space-manage-table {
  --bs-table-striped-bg: rgba(255, 255, 255, 0.02);
  --bs-table-hover-bg: rgba(125, 211, 252, 0.05);
}

body.night-mode .forum-space-manage-table > :not(caption) > * > * {
  background-color: transparent;
}

.sg-group-settings-table-plain > :not(caption) > * > * {
  background-color: transparent;
}

/* -- */

/* forum-category */
.forum-category {
  padding: 15px 20px;
  margin-top: 20px;
  background-color: var(--link-color);
  color: #fff;
  font-weight: 600;
  font-size: 13px;
  border-radius: 16px 16px 0 0;
}

.forum-category a {
  color: #fff;
}

.forum-category a:hover {
  text-decoration: underline;
}

/* -- */

/* forum-head */
.forum-head {
  margin-right: 0;
  margin-left: 0;
}

.forum-head > .column {
  padding: 20px;
  background-color: #16232d;
  color: #fff;
  font-weight: 300;
  font-size: 12px;
  text-align: center;
  border-right: 1px solid #192534;
  border-left: 1px solid #161e27;
}

body.night-mode .forum-head > .column {
  background: var(--card-dark-input);
  border-right-color: var(--card-dark-divider);
  border-left-color: #121212;
}

.forum-head.threads > .column {
  background-color: #576c7c;
  border-right: 1px solid #374855;
  border-left: 1px solid #6d8292;
}

body.night-mode .forum-head.threads > .column {
  background: var(--card-dark-input);
}

.forum-head > .column:first-child {
  text-align: left;
  border-left: none;
}

.forum-head > .column:last-child {
  border-right: none;
}

/* -- */

/* forum-row */
.forum-row {
  display: flex;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  flex-wrap: wrap;
  margin-right: 0;
  margin-left: 0;
}

.forum-row > .column {
  display: flex;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  flex-direction: column;
  padding: 20px;
  background-color: #ffffff;
  border-bottom: 1px solid #e6e6e6;
  color: #808080;
  font-size: 12px;
  word-wrap: break-word;
}

body.night-mode .forum-row > .column {
  background: var(--card-dark-color);
  border-color: var(--card-dark-divider);
}

.forum-row > .column.icon {
  color: #999999;
  text-align: center;
}

.forum-row .sub-forums li {
  float: left;
  margin-right: 10px;
}

/* -- */

/* forum-meta */
.forum-meta-head {
  padding: 15px 20px 15px 20px;
  background-color: #16232d;
  color: #fff;
  font-size: 12px;
  font-weight: 300;
}

body.night-mode .forum-meta-head {
  background: var(--card-dark-input);
}

.forum-meta-conent {
  padding: 15px 20px 15px 20px;
  background-color: #fff;
  color: #808080;
  font-size: 12px;
}

.forum-meta-conent:last-child {
  border-radius: 0 0 16px 16px;
}

body.night-mode .forum-meta-conent {
  background-color: var(--card-dark-color);
}

/* forum-bounty-bar */
.forum-bounty-bar {
  margin-top: 10px;
  padding: 12px 14px;
  border: 1px solid #fdba74;
  border-radius: 12px;
  background: linear-gradient(120deg, #fff7ed, #ffedd5);
  color: #9a3412;
}

.forum-bounty-bar-main {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
}

.forum-bounty-bar-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 8px;
  font-size: 12px;
}

.forum-bounty-bar-urgent {
  border-color: #ef4444;
  background: linear-gradient(120deg, #fef2f2, #fee2e2);
  color: #991b1b;
  animation: forum-bounty-pulse 1.2s ease-in-out infinite;
}

.forum-bounty-awarded {
  margin-top: 10px;
  padding: 14px 18px;
  border: 1px solid #22c55e;
  border-radius: 4px;
  background: #22302b;
  color: #d1fae5;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.forum-bounty-awarded-main {
  display: flex;
  align-items: center;
  gap: 16px;
  min-width: 0;
  flex: 1 1 auto;
}

.forum-bounty-awarded-icon {
  width: 34px;
  height: 34px;
  min-width: 34px;
  border-radius: 999px;
  border: 1px solid rgba(34, 197, 94, 0.35);
  background: rgba(34, 197, 94, 0.08);
  color: #22c55e;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
}

.forum-bounty-awarded-copy {
  min-width: 0;
}

.forum-bounty-awarded-title {
  color: #4ade80;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.4;
}

.forum-bounty-awarded-meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 6px;
  color: #9ca3af;
  font-size: 12px;
  line-height: 1.5;
}

.forum-bounty-awarded-meta strong {
  color: #f8fafc;
  font-weight: 700;
}

.forum-bounty-awarded-meta a,
.forum-bounty-awarded-jump {
  color: #d1fae5;
  text-decoration: none;
}

.forum-bounty-awarded-meta a:hover,
.forum-bounty-awarded-jump:hover {
  color: #ffffff;
}

.forum-bounty-awarded-jump {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  opacity: 0.75;
}

@keyframes forum-bounty-pulse {
  0%,
  100% {
    box-shadow: 0 0 0 0 rgba(239, 68, 68, 0.25);
  }
  50% {
    box-shadow: 0 0 0 6px rgba(239, 68, 68, 0.08);
  }
}

body.night-mode .forum-bounty-bar {
  border-color: #a16207;
  background: linear-gradient(120deg, #3f2f0f, #4a3412);
  color: #fef3c7;
}

body.night-mode .forum-bounty-bar-urgent {
  border-color: #dc2626;
  background: linear-gradient(120deg, #3f1d1d, #4a2424);
  color: #fecaca;
}

body.night-mode .forum-bounty-awarded {
  border-color: #22c55e;
  background: #1f2a26;
  color: #d1fae5;
}

/* forum-thread-card */
.forum-thread-list-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin: 10px 0;
  padding: 4px 2px;
}

.forum-thread-list {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.forum-thread-card {
  border: 1px solid #e5e7eb;
  border-radius: 14px;
  background: #ffffff;
  transition:
    box-shadow 0.18s ease,
    transform 0.18s ease;
}

.forum-thread-card:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 22px rgba(15, 23, 42, 0.08);
}

.forum-thread-card-body {
  padding: 14px 16px;
}

/* nb##: 论坛 Pin/Recommended 状态统一改为圆形单图标贴纸，供 forum space / topic hub 复用 */
.forum-thread-status-stickers {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 0.45rem;
}

.forum-thread-status-stickers-inline {
  justify-content: flex-start;
  gap: 0.4rem;
  margin-top: 0.45rem;
}

.forum-thread-status-sticker {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border: 1px solid rgba(148, 163, 184, 0.28);
  border-radius: 999px;
  background: #ffffff;
  color: #334155;
  box-shadow:
    0 0.55rem 1.15rem rgba(15, 23, 42, 0.12),
    0 0 0 3px rgba(255, 255, 255, 0.92);
}

.forum-thread-status-sticker__label {
  display: none;
}

.forum-thread-status-sticker i {
  font-size: 0.95rem;
  line-height: 1;
}

.forum-thread-status-sticker-button {
  appearance: none;
  -webkit-appearance: none;
  font: inherit;
  line-height: inherit;
  cursor: pointer;
  margin: 0;
  text-decoration: none;
}

.forum-thread-status-sticker-button:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.18);
}

.forum-thread-status-sticker.is-pinned {
  border-color: rgba(185, 28, 28, 0.18);
  background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%);
  color: #ffffff;
}

.forum-thread-status-sticker.is-hot {
  border-color: rgba(217, 119, 6, 0.18);
  background: linear-gradient(135deg, #f59e0b 0%, #f97316 100%);
  color: #111827;
}

.forum-thread-status-sticker.is-solved {
  border-color: rgba(21, 128, 61, 0.18);
  background: linear-gradient(135deg, #22c55e 0%, #16a34a 100%);
  color: #ffffff;
}

.forum-thread-status-sticker.is-hidden {
  border-color: rgba(71, 85, 105, 0.2);
  background: linear-gradient(135deg, #64748b 0%, #475569 100%);
  color: #ffffff;
}

.forum-thread-status-sticker.is-closed {
  border-color: rgba(75, 85, 99, 0.2);
  background: linear-gradient(135deg, #6b7280 0%, #4b5563 100%);
  color: #ffffff;
}

.forum-thread-status-stickers-inline .forum-thread-status-sticker {
  width: auto;
  min-height: 28px;
  height: auto;
  padding: 0.32rem 0.68rem;
  gap: 0.34rem;
  box-shadow: none;
}

.forum-thread-status-stickers-inline .forum-thread-status-sticker i {
  font-size: 0.82rem;
}

.forum-thread-status-stickers-inline .forum-thread-status-sticker__label {
  display: inline;
  font-size: 0.76rem;
  font-weight: 700;
  line-height: 1.1;
}

.forum-thread-status-stickers-inline .forum-thread-status-sticker.is-pinned,
.forum-thread-status-stickers-inline .forum-thread-status-sticker.is-hot {
  width: 28px;
  min-width: 28px;
  min-height: 28px;
  height: 28px;
  padding: 0;
  gap: 0;
}

.forum-thread-status-stickers-inline
  .forum-thread-status-sticker.is-pinned
  .forum-thread-status-sticker__label,
.forum-thread-status-stickers-inline
  .forum-thread-status-sticker.is-hot
  .forum-thread-status-sticker__label {
  display: none;
}

.forum-thread-status-stickers-inline .forum-thread-status-sticker.is-pinned i,
.forum-thread-status-stickers-inline .forum-thread-status-sticker.is-hot i {
  font-size: 0.82rem;
}

.forum-thread-status-stickers-detail {
  display: inline-flex;
  margin-top: 0;
  margin-inline-start: 0.55rem;
  vertical-align: middle;
}

.forum-thread-status-stickers-detail .forum-thread-status-sticker {
  width: auto;
  min-width: 0;
  min-height: 28px;
  height: 28px;
  padding: 0.32rem 0.68rem;
  gap: 0.34rem;
  box-shadow: none;
}

.forum-thread-status-stickers-detail .forum-thread-status-sticker i {
  font-size: 0.82rem;
}

.forum-thread-status-stickers-detail .forum-thread-status-sticker__label {
  display: inline;
  font-size: 0.76rem;
  font-weight: 700;
  line-height: 1.1;
}

.forum-thread-status-stickers-detail.forum-thread-status-stickers-inline
  .forum-thread-status-sticker.is-pinned,
.forum-thread-status-stickers-detail.forum-thread-status-stickers-inline
  .forum-thread-status-sticker.is-hot {
  width: auto;
  min-width: 0;
  min-height: 28px;
  height: 28px;
  padding: 0.32rem 0.68rem;
  gap: 0.34rem;
}

.forum-thread-status-stickers-detail.forum-thread-status-stickers-inline
  .forum-thread-status-sticker.is-pinned
  .forum-thread-status-sticker__label,
.forum-thread-status-stickers-detail.forum-thread-status-stickers-inline
  .forum-thread-status-sticker.is-hot
  .forum-thread-status-sticker__label {
  display: inline;
}

.forum-thread-status-stickers-detail .forum-thread-status-sticker.is-inactive {
  border-color: rgba(148, 163, 184, 0.32);
  background: #f8fafc;
  color: #64748b;
}

.forum-thread-card-title-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}

.forum-thread-card-title {
  color: #111827;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.45;
  word-break: break-word;
}

.forum-thread-card:hover .forum-thread-card-title {
  color: var(--link-color);
}

.forum-thread-card-badges {
  gap: 6px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.forum-thread-card-snippet {
  margin-top: 8px;
  color: #4b5563;
  font-size: 13px;
  line-height: 1.55;
  word-break: break-word;
}

.forum-thread-card-meta,
.forum-thread-card-stats {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 10px;
  color: #6b7280;
  font-size: 12px;
}

.forum-thread-card-meta .badge {
  font-weight: 500;
}

.forum-thread-card-mobile {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 10px;
}

.forum-thread-card-empty {
  padding: 18px 16px;
  border: 1px dashed #d1d5db;
  border-radius: 12px;
  background: #f8fafc;
  color: #6b7280;
}

body.night-mode .forum-thread-card {
  border-color: var(--card-dark-divider);
  background: var(--card-dark-color);
}

body.night-mode .forum-thread-card:hover {
  box-shadow: 0 12px 22px rgba(0, 0, 0, 0.35);
}

body.night-mode .forum-thread-card-title {
  color: #e5e7eb;
}

body.night-mode .forum-thread-card-snippet,
body.night-mode .forum-thread-card-meta,
body.night-mode .forum-thread-card-stats {
  color: #9ca3af;
}

body.night-mode .forum-thread-status-sticker {
  border-color: rgba(255, 255, 255, 0.08);
  box-shadow:
    0 0.65rem 1.35rem rgba(2, 6, 23, 0.36),
    0 0 0 3px #18263d;
}

body.night-mode
  .forum-thread-status-stickers-detail
  .forum-thread-status-sticker.is-inactive {
  border-color: rgba(var(--bs-white-rgb), 0.14);
  background: rgba(var(--bs-white-rgb), 0.05);
  color: rgba(var(--bs-white-rgb), 0.68);
}

body.night-mode .forum-thread-card-empty {
  border-color: var(--card-dark-divider);
  background: var(--card-dark-input);
  color: #9ca3af;
}

/* forum-related-thread-card */
.forum-related-threads-panel {
  position: relative;
}

.forum-related-threads-head {
  position: relative;
  padding-inline-start: 18px;
  margin-bottom: 0.9rem;
}

.forum-related-threads-head::before {
  content: "";
  position: absolute;
  inset-inline-start: 0;
  top: 16.67%;
  bottom: 16.67%;
  width: 6px;
  background: var(--link-color);
}

.forum-related-threads-title {
  margin: 0;
  color: #0f172a;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.3;
}

.forum-related-threads-panel .js_forum-related-threads-body {
  min-height: 0;
}

.forum-related-thread-card {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 14px 16px;
  border: 1px solid rgba(148, 163, 184, 0.28);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.84);
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06);
  backdrop-filter: blur(10px);
  transition:
    box-shadow 0.18s ease,
    transform 0.18s ease;
}

.forum-related-thread-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 18px 28px rgba(15, 23, 42, 0.12);
}

.forum-related-thread-avatar-link {
  flex: 0 0 auto;
  display: inline-flex;
  text-decoration: none;
}

.forum-related-thread-avatar {
  width: 44px;
  height: 44px;
  border-radius: 999px;
  object-fit: cover;
  display: block;
}

.forum-related-thread-main {
  flex: 1 1 auto;
  min-width: 0;
}

.forum-related-thread-head {
  min-width: 0;
}

.forum-related-thread-meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 6px;
  color: #6b7280;
  font-size: 12px;
}

.forum-related-thread-forum,
.forum-related-thread-author {
  color: inherit;
  text-decoration: none;
}

.forum-related-thread-forum:hover,
.forum-related-thread-author:hover {
  color: var(--link-color);
}

.forum-related-thread-title {
  display: block;
  min-height: calc(1.5em * 2);
  color: #111827;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.5;
  text-decoration: none;
  word-break: break-word;
}

.forum-home-thread-title,
.forum-directory-thread-title {
  font-size: 18px;
  line-height: 1.45;
  font-weight: 700;
}

.forum-list-stat-number {
  display: inline-block;
  font-style: italic;
  font-weight: 700;
  line-height: 1;
  font-variant-numeric: tabular-nums;
}

.forum-list-stat-number-inline {
  font-size: 1rem;
}

.forum-home-thread-stats .forum-list-stat-number {
  font-size: 1.08rem;
}

.forum-directory-thread-metric-value {
  font-size: 1.72rem;
  font-style: italic;
}

.sg-topic-hub .forum-directory-thread-metric-value {
  font-size: 1.72rem;
  font-style: italic;
}

.forum-directory-thread-meta-item .forum-list-stat-number,
.forum-related-thread-stats .forum-list-stat-number {
  font-size: 1rem;
}

.forum-related-threads-state {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 72px;
}

.forum-thread-invite-state {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 52px;
}

.forum-related-thread-title:hover {
  color: var(--link-color);
}

.forum-related-thread-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-top: 12px;
}

.forum-related-thread-stats,
.forum-related-thread-time {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 14px;
  color: #6b7280;
  font-size: 12px;
}

.forum-related-thread-time {
  justify-content: flex-end;
  white-space: nowrap;
}

@media (max-width: 575.98px) {
  .forum-related-thread-footer {
    flex-direction: column;
    align-items: flex-start;
  }

  .forum-related-thread-time {
    justify-content: flex-start;
  }
}

body.night-mode .forum-related-thread-card {
  border-color: rgba(96, 165, 250, 0.24);
  background: rgba(15, 23, 42, 0.82);
}

body.night-mode .forum-related-thread-card:hover {
  box-shadow: 0 12px 22px rgba(0, 0, 0, 0.35);
}

body.night-mode .forum-related-threads-panel {
  background: transparent;
}

body.night-mode .forum-related-threads-title {
  color: #e5e7eb;
}

body.night-mode .forum-related-thread-meta,
body.night-mode .forum-related-thread-stats,
body.night-mode .forum-related-thread-time {
  color: #9ca3af;
}

body.night-mode .forum-related-thread-title {
  color: #e5e7eb;
}

/* -- */

/* forum-thread */
.forum-thread {
  padding: 20px 10px;
  margin-top: 10px;
  background: #fff;
  border-radius: 16px;
  box-shadow: 0 1px 1px rgba(0, 0, 0, 0.05);
}

.forum-thread.forum-best-reply {
  background: #eaf7ee;
  border: 1px solid #87d1a0;
  box-shadow: 0 4px 14px rgba(21, 128, 61, 0.14);
}

.forum-thread.forum-best-reply .time {
  border-bottom-color: #7fcf9b;
}

body.night-mode .forum-thread {
  background: var(--card-dark-color);
}

body.night-mode .forum-thread.forum-best-reply {
  background: #1a2f25;
  border: 1px solid #2f7f59;
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.32);
}

body.night-mode .forum-thread.forum-best-reply .time {
  border-bottom-color: #3d8a62;
}

.forum-thread .row {
  margin-left: 0;
  margin-right: 0;
}

.forum-thread .avatar {
  width: 80px;
  height: 80px;
  border-radius: 50%;
}

/* nb##: Forum 在线绿点与 Post 保持一致，统一主贴/回复头像右下角尺寸与位置 */
.forum-thread-avatar-link {
  position: relative;
  display: inline-block;
}

.forum-thread-avatar-link .online-dot,
.forum-thread-avatar-link-small .online-dot.online-dot-small {
  font-size: 10px;
  margin-right: 3px;
  position: absolute;
  top: auto;
  right: 0px;
  bottom: 0px;
  border: 3px solid #fff;
  border-radius: 50%;
  color: #65a830;
}

body.night-mode .forum-thread-avatar-link .online-dot {
  border-color: var(--card-dark-color);
}

.forum-thread .time {
  padding-bottom: 5px;
  margin-bottom: 10px;
  border-bottom: 1px solid #f4f4f4;
}

body.night-mode .forum-thread .time {
  border-color: var(--card-dark-divider);
}

.forum-thread .text {
  word-wrap: break-word;
}

.forum-thread .text img,
.forum-thread .text iframe {
  max-width: 100%;
}

.forum-mobile-reply-entry {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1040;
  padding: 10px 12px calc(10px + env(safe-area-inset-bottom));
  background: rgba(255, 255, 255, 0.95);
  border-top: 1px solid #e5e7eb;
  backdrop-filter: blur(6px);
}

.forum-mobile-reply-entry .btn {
  border-radius: 999px;
}

.forum-mobile-reply-spacer {
  height: 82px;
}

body.night-mode .forum-mobile-reply-entry {
  background: rgba(31, 41, 55, 0.95);
  border-top-color: #374151;
}

@media (min-width: 768px) {
  .forum-mobile-reply-entry,
  .forum-mobile-reply-spacer {
    display: none !important;
  }
}

.forum-thread ul {
  margin: initial;
  padding-inline-start: 40px;
  list-style: initial;
}

.forum-quoted-reply {
  padding: 12px 14px;
  border: 1px solid #cfe2ff;
  border-left: 4px solid var(--link-color);
  border-radius: 12px;
  background: #eef5ff;
  box-shadow: 0 1px 6px rgba(0, 0, 0, 0.06);
}

.forum-quoted-reply-head {
  display: flex;
  align-items: flex-start;
  gap: 10px;
}

.forum-quoted-reply-avatar-link {
  position: relative;
  flex: 0 0 auto;
  display: inline-flex;
  text-decoration: none !important;
}

.forum-thread .forum-quoted-reply-avatar,
.forum-quoted-reply-avatar {
  width: 40px;
  height: 40px;
  object-fit: cover;
  border-radius: 50%;
}

.forum-quoted-reply-compact .forum-quoted-reply-avatar {
  width: 40px;
  height: 40px;
}

.forum-quoted-reply-online-dot {
  font-size: 9px;
  position: absolute;
  right: 0;
  bottom: 0;
  transform: translate(22%, 22%);
  margin: 0;
  border: 2px solid #fff;
  border-radius: 50%;
  color: #65a830;
  background: #fff;
}

.forum-quoted-reply-compact .forum-quoted-reply-online-dot {
  font-size: 9px;
  right: 0;
  bottom: 0;
  transform: translate(22%, 22%);
}

.forum-quoted-reply-content {
  min-width: 0;
  flex: 1 1 auto;
}

.forum-thread-child-avatar {
  width: 40px;
  height: 40px;
  object-fit: cover;
}

.forum-thread-child-avatar-link {
  position: relative;
  display: inline-flex;
  flex: 0 0 auto;
  align-self: flex-start;
  line-height: 0;
}

.forum-thread-child-avatar-link .forum-thread-child-online-dot {
  font-size: 9px;
  position: absolute;
  right: -2px;
  bottom: -2px;
  transform: none;
  margin: 0;
  border: 2px solid #fff;
  border-radius: 50%;
  color: #65a830;
  background: #fff;
  line-height: 1;
}

.forum-thread-invite-card {
  background: linear-gradient(180deg, #fff7e3 0%, #fffdf6 100%);
  border: 1px solid #f2d7a1;
}

body.night-mode .forum-thread-invite-card {
  background: linear-gradient(
    180deg,
    rgba(120, 83, 24, 0.24) 0%,
    rgba(54, 41, 13, 0.32) 100%
  );
  border-color: rgba(242, 215, 161, 0.35);
}

.btn-forum-follow-active {
  color: #1d6b43;
  background-color: #dff4e8;
  border-color: #b9dfc7;
}

.btn-forum-follow-active:hover,
.btn-forum-follow-active:focus,
.btn-forum-follow-active:active {
  color: #165737;
  background-color: #cfeeda;
  border-color: #abd5ba;
}

.btn-forum-follow-active.focus,
.btn-forum-follow-active:focus {
  box-shadow: 0 0 0 0.2rem rgba(73, 163, 111, 0.2);
}

.forum-thread-invite-suggestion-avatar {
  width: 32px;
  height: 32px;
  flex: 0 0 32px;
  border-radius: 50%;
  object-fit: cover;
}

body.night-mode .btn-forum-follow-active {
  color: #d9f7e4;
  background-color: rgba(46, 125, 84, 0.38);
  border-color: rgba(114, 194, 153, 0.42);
}

body.night-mode .btn-forum-follow-active:hover,
body.night-mode .btn-forum-follow-active:focus,
body.night-mode .btn-forum-follow-active:active {
  color: #ecfff3;
  background-color: rgba(58, 145, 98, 0.46);
  border-color: rgba(132, 214, 172, 0.5);
}

.forum-thread-child-user-link,
.forum-thread-child-user-link:hover {
  text-decoration: none !important;
}

.forum-thread-child-action-btn {
  border-radius: 8px;
}

.forum-thread-detail-public .forum-reply-footer {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-top: 12px;
  padding-top: 10px;
  border-top: 1px solid rgba(79, 95, 111, 0.12);
}

.forum-thread-detail-public .forum-reply-footer-votes {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}

.forum-thread-detail-public .forum-reply-vote-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(79, 95, 111, 0.05);
  border: 1px solid rgba(79, 95, 111, 0.08);
}

.forum-thread-detail-public
  .forum-reply-vote-chip.is-active.forum-reply-vote-chip--up {
  background: rgba(29, 107, 67, 0.1);
  border-color: rgba(29, 107, 67, 0.18);
}

.forum-thread-detail-public
  .forum-reply-vote-chip.is-active.forum-reply-vote-chip--down {
  background: rgba(198, 40, 40, 0.08);
  border-color: rgba(198, 40, 40, 0.14);
}

.forum-thread-detail-public .forum-reply-vote-copy,
.forum-thread-detail-public .forum-reply-save-copy {
  display: inline-flex;
  align-items: baseline;
  gap: 6px;
  font-size: 12px;
}

.forum-thread-detail-public .forum-reply-vote-label,
.forum-thread-detail-public .forum-reply-save-label {
  font-weight: 700;
}

.forum-thread-detail-public .forum-reply-vote-label {
  color: #51606f;
}

.forum-thread-detail-public .forum-reply-footer-save .forum-reply-save-label {
  color: inherit;
}

.forum-thread-detail-public .forum-reply-vote-metrics {
  color: #738294;
  font-weight: 600;
}

.forum-thread-detail-public .forum-reply-footer-save {
  display: inline-flex;
  align-items: center;
  margin-left: auto;
}

.forum-thread-detail-public .forum-reply-vote-chip .btn,
.forum-thread-detail-public .forum-reply-footer-save .btn {
  line-height: 1;
}

.forum-thread-detail-public .forum-thread-action-chip--reply {
  padding: 6px 12px;
  min-height: 38px;
}

.forum-thread-detail-public .forum-reply-footer-save .forum-thread-action-chip,
.forum-thread-detail-public
  .forum-reply-footer-save
  .forum-thread-action-chip--readonly {
  margin-left: auto;
}

@media (max-width: 767.98px) {
  .forum-thread-detail-public
    .forum-thread-header.forum-thread-header-has-watermark {
    min-height: 72px;
    padding-right: 68px;
  }

  .forum-thread-detail-public
    .forum-thread-header-watermark
    .forum-thread-type-watermark {
    --forum-thread-watermark-min-width: 3.4rem;
    --forum-thread-watermark-question-size: 3.35rem;
    --forum-thread-watermark-announcement-size: 2.3rem;
  }

  .forum-thread-detail-public .forum-thread-body-footer,
  .forum-thread-detail-public .forum-thread-detail-entry-actions,
  .forum-thread-detail-public .forum-reply-footer {
    justify-content: flex-start;
  }

  .forum-thread-detail-public .forum-reply-footer-save {
    margin-left: 0;
  }
}

.forum-quoted-reply a,
.forum-quoted-reply a:hover,
.forum-quoted-reply-user,
.forum-quoted-reply-user:hover {
  text-decoration: none !important;
}

.forum-quoted-reply-snippet {
  margin-top: 4px;
  white-space: normal;
  word-break: break-word;
}

body.night-mode .forum-quoted-reply {
  background: #1c2736;
  border-color: #334155;
  border-left-color: var(--link-color);
  box-shadow: 0 1px 6px rgba(0, 0, 0, 0.25);
}

body.night-mode .forum-quoted-reply-online-dot {
  border-color: var(--card-dark-color);
  background: var(--card-dark-color);
}

body.night-mode .forum-thread-child-avatar-link .forum-thread-child-online-dot {
  border-color: var(--card-dark-color);
  background: var(--card-dark-color);
}

body.night-mode .forum-thread-detail-public .forum-reply-footer {
  border-top-color: rgba(183, 195, 207, 0.16);
}

body.night-mode .forum-thread-detail-public .forum-reply-vote-chip {
  background: rgba(255, 255, 255, 0.05);
  border-color: rgba(183, 195, 207, 0.14);
}

body.night-mode
  .forum-thread-detail-public
  .forum-reply-vote-chip.is-active.forum-reply-vote-chip--up {
  background: rgba(29, 107, 67, 0.28);
  border-color: rgba(114, 194, 153, 0.32);
}

body.night-mode
  .forum-thread-detail-public
  .forum-reply-vote-chip.is-active.forum-reply-vote-chip--down {
  background: rgba(151, 53, 53, 0.28);
  border-color: rgba(224, 115, 115, 0.26);
}

body.night-mode .forum-thread-detail-public .forum-reply-vote-label,
body.night-mode .forum-thread-detail-public .forum-reply-save-label {
  font-weight: 700;
}

body.night-mode .forum-thread-detail-public .forum-reply-vote-label {
  color: #eff4f9;
}

body.night-mode .forum-thread-detail-public .forum-reply-vote-metrics,
body.night-mode
  .forum-thread-detail-public
  .forum-reply-save-copy
  #forum-reply-save-count {
  color: #bec9d6;
}

/* -- */

/* forum-result */
.forum-result {
  margin-top: 14px;
}

.forum-result .head {
  padding: 8px 16px;
  background-color: #576c7c;
  color: #fff;
  border-radius: 0;
}

.forum-thread-list-card > .head,
.forum-thread-list-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}

body.night-mode .forum-result .head {
  background-color: var(--card-dark-divider);
}

.forum-result .head a {
  color: #fff;
}

.forum-result .head a:hover {
  text-decoration: underline;
}

.forum-result-head-actions {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  flex-wrap: nowrap;
  white-space: nowrap;
}

.forum-thread-list-head-meta,
.forum-thread-list-head-side {
  min-width: 0;
}

.forum-thread-list-head-meta {
  justify-content: flex-start;
}

.forum-thread-list-head-side {
  margin-inline-start: auto;
}

.forum-result-head-item {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  white-space: nowrap;
}

.forum-result-head-form,
.forum-result-head-form .btn {
  white-space: nowrap;
}

.forum-result-head-button {
  padding: 0.18rem 0.52rem;
  font-size: 0.72rem;
  font-weight: 700;
  line-height: 1.15;
}

.forum-result .content {
  padding: 12px 16px 16px;
  background-color: #ffffff;
  border-radius: 0;
}

body.night-mode .forum-result .content {
  background-color: var(--card-dark-color);
}

.forum-result .title {
  font-size: 17px;
  line-height: 1.35;
}

.forum-result .title a,
.forum-thread-title-link {
  color: #0f172a;
  text-decoration: none;
}

.forum-result .title a:hover,
.forum-thread-title-link:hover {
  color: var(--link-color);
}

.forum-result .float-end strong {
  display: inline-block;
  font-size: 1.12rem;
  font-style: italic;
  font-weight: 700;
  line-height: 1;
  font-variant-numeric: tabular-nums;
}

/* nb##: my-* forum 列表共享标题/统计双栏布局；左侧标题可换行，右侧统计固定不换行 */
.forum-result-summary,
.forum-my-replies-summary,
.forum-result-thread-layout,
.forum-my-replies-thread-layout {
  --forum-result-author-width: 104px;
  --forum-result-author-gap: 10px;
  --forum-result-summary-gap: 16px;
}

.forum-result-summary,
.forum-my-replies-summary {
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: flex-start;
  width: 100%;
  max-width: 100%;
  gap: var(--forum-result-summary-gap);
  overflow: hidden;
}

.forum-result-summary-main,
.forum-my-replies-summary-main {
  flex: 1 1 0;
  min-width: 0;
  overflow: hidden;
}

.forum-result-thread-layout,
.forum-my-replies-thread-layout {
  display: flex;
  align-items: flex-start;
  width: 100%;
  max-width: 100%;
  gap: var(--forum-result-summary-gap);
}

.forum-result-thread-main,
.forum-my-replies-thread-main {
  flex: 1 1 0;
  min-width: 0;
}

.forum-my-replies-thread-layout,
.forum-result-thread-layout-has-reply {
  display: grid;
  grid-template-columns: var(--forum-result-author-width) minmax(0, 1fr) auto;
  align-items: start;
  column-gap: var(--forum-result-summary-gap);
  row-gap: 14px;
}

.forum-my-replies-thread-layout > .forum-result-author-block,
.forum-result-thread-layout-has-reply > .forum-result-author-block {
  grid-column: 1;
  grid-row: 1 / span 2;
}

.forum-my-replies-thread-layout > .forum-result-summary-stats,
.forum-result-thread-layout-has-reply > .forum-result-summary-stats {
  grid-column: 3;
  grid-row: 1;
}

.forum-my-replies-thread-layout > .forum-my-replies-thread-main,
.forum-result-thread-layout-has-reply > .forum-result-thread-main {
  display: contents;
}

.forum-my-replies-thread-layout .forum-my-replies-thread-summary-copy,
.forum-result-thread-layout-has-reply .forum-result-thread-summary-copy {
  grid-column: 2;
  grid-row: 1;
}

.forum-my-replies-thread-layout .forum-my-replies-list,
.forum-result-thread-layout-has-reply .forum-my-replies-list {
  grid-column: 2 / 4;
  grid-row: 2;
  margin-top: 0;
}

.forum-result-thread-summary-copy,
.forum-my-replies-thread-summary-copy {
  min-width: 0;
}

.forum-result .forum-result-thread-snippet {
  margin-top: 8px;
  margin-left: 0;
  margin-right: 0;
  padding-top: 12px;
  padding-right: 0;
  padding-bottom: 0;
  padding-left: 0;
  border-top: 1px solid rgba(15, 23, 42, 0.28);
  background: transparent;
  border-radius: 0;
  color: #475569;
  font-size: 0.96rem;
  line-height: 1.55;
}

.forum-thread-list-footer {
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid rgba(15, 23, 42, 0.16);
}

.forum-thread-list-latest {
  display: flex;
  align-items: center;
  flex-wrap: nowrap;
  gap: 10px;
  min-width: 0;
  color: #64748b;
  font-size: 0.86rem;
  line-height: 1.45;
}

.forum-thread-list-latest-label {
  flex: 0 0 auto;
  color: #94a3b8;
  font-weight: 700;
}

.forum-thread-list-latest-avatar {
  display: inline-flex;
  flex: 0 0 auto;
}

.forum-thread-list-latest-avatar img {
  width: 34px;
  height: 34px;
  border-radius: 999px;
  object-fit: cover;
  display: block;
  box-shadow: 0 0.35rem 0.85rem rgba(15, 23, 42, 0.14);
}

.forum-thread-list-latest-copy {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 0.45rem;
  flex: 1 1 auto;
  white-space: nowrap;
}

.forum-thread-list-latest-role {
  display: inline-flex;
  align-items: center;
  position: relative;
  flex: 0 0 auto;
  max-width: 100%;
  padding-inline-start: 0.6rem;
  color: #64748b;
  font-size: 0.74rem;
  font-weight: 600;
  line-height: 1.2;
  white-space: nowrap;
}

.forum-thread-list-latest-role::before,
.forum-thread-list-latest-time::before {
  content: "\00B7";
  position: absolute;
  inset-inline-start: 0;
  top: 50%;
  transform: translateY(-50%);
  color: #94a3b8;
}

.forum-thread-list-latest-role-admin,
.forum-thread-list-latest-role-moderator {
  color: #475569;
}

.forum-thread-list-latest-role-member {
  color: #64748b;
}

.forum-thread-list-latest-name,
.forum-thread-list-latest-time {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  text-decoration: none;
}

.forum-thread-list-latest-name {
  flex: 0 1 auto;
  min-width: 0;
  color: #0f172a;
  font-size: 0.88rem;
  font-weight: 700;
}

.forum-thread-list-latest-time {
  position: relative;
  flex: 0 0 auto;
  padding-inline-start: 0.6rem;
  color: #64748b;
  font-size: 0.8rem;
}

.forum-thread-list-latest-name:hover,
.forum-thread-list-latest-time:hover {
  color: var(--link-color);
}

.forum-thread-list-latest-empty {
  color: #94a3b8;
  font-size: 0.82rem;
}

.forum-thread-list-latest-actions {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  flex: 0 0 auto;
  margin-inline-start: auto;
}

.forum-thread-list-latest-action-form {
  margin: 0;
}

.forum-thread-list-latest-action-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.forum-result-author-role .sg-country-flag--inline,
.forum-thread-list-latest-role .sg-country-flag--inline,
.forum-my-replies-item-profile-role .sg-country-flag--inline {
  margin-inline-start: 0;
}

.forum-result-summary-layout {
  display: flex;
  align-items: flex-start;
  gap: var(--forum-result-author-gap);
  min-width: 0;
}

.forum-result-author-block {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  flex: 0 0 var(--forum-result-author-width);
  min-width: var(--forum-result-author-width);
  max-width: var(--forum-result-author-width);
  color: inherit;
  text-decoration: none;
  text-align: center;
}

.forum-result-author-block:hover {
  color: inherit;
  text-decoration: none;
}

.forum-result-author-avatar-wrap {
  position: relative;
  flex: 0 0 auto;
  width: 74px;
  height: 74px;
}

.forum-result-author-avatar {
  width: 74px;
  height: 74px;
  display: block;
  border-radius: 999px;
  object-fit: cover;
}

.forum-result-author-avatar-wrap .online-dot {
  position: absolute;
  right: 0;
  bottom: 0;
  transform: translate(18%, 18%);
  font-size: 9px;
  color: #65a830;
  border: 2px solid #fff;
  border-radius: 50%;
  line-height: 1;
}

.forum-result-author-copy {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  min-width: 0;
  width: 100%;
}

.forum-result-author-username {
  display: block;
  max-width: 100%;
  overflow-wrap: anywhere;
  word-break: break-word;
  white-space: normal;
  color: #0f172a;
  font-size: 0.94rem;
  font-weight: 800;
  line-height: 1.35;
}

.forum-result-author-role {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  max-width: 100%;
  padding: 0;
  border-radius: 0;
  font-size: 0.8rem;
  font-weight: 500;
  line-height: 1.35;
  white-space: normal;
  text-align: center;
}

.forum-result-author-role-admin {
  background: transparent;
  color: #334155;
}

.forum-result-author-role-moderator {
  background: transparent;
  color: #334155;
}

.forum-result-author-role-member {
  background: transparent;
  color: #475569;
}

.forum-result-summary-copy {
  flex: 1 1 auto;
  min-width: 0;
}

.forum-result-summary-title,
.forum-my-replies-summary-title {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 8px;
  min-width: 0;
  margin-bottom: 0;
}

.forum-result-summary-title .forum-thread-title-link,
.forum-my-replies-summary-title .forum-thread-title-link {
  display: block;
  flex: 0 1 auto;
  min-width: 0;
  min-height: calc(1.32em * 2);
  overflow-wrap: anywhere;
  word-wrap: break-word;
  word-break: break-all;
  color: #0f172a;
  font-size: 1.14rem;
  font-weight: 800;
  line-height: 1.32;
}

.forum-result-summary-title-has-badge .forum-thread-title-link {
  flex: 1 1 auto;
  max-width: none;
}

.forum-result-summary-badges,
.forum-my-replies-summary-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 6px;
}

.forum-thread-bounty-badge {
  display: inline-flex;
  align-items: center;
  align-self: flex-start;
  gap: 0.42rem;
  padding: 0.46rem 0.82rem;
  border: 1px solid rgba(217, 119, 6, 0.26);
  border-radius: 999px;
  background: linear-gradient(135deg, #fbbf24 0%, #f59e0b 52%, #f97316 100%);
  color: #431407;
  box-shadow:
    0 0.45rem 0.95rem rgba(245, 158, 11, 0.22),
    inset 0 1px 0 rgba(255, 255, 255, 0.48);
  font-size: 0.9rem;
  font-weight: 800;
  line-height: 1;
  letter-spacing: 0.01em;
  white-space: nowrap;
}

.forum-thread-bounty-badge i {
  font-size: 0.9rem;
  line-height: 1;
}

.forum-thread-bounty-badge__label {
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-size: 0.72rem;
}

.forum-thread-bounty-badge__amount {
  font-size: 1.14rem;
  font-weight: 900;
  font-style: italic;
}

.forum-result-summary-stats,
.forum-my-replies-summary-stats {
  flex: 0 0 auto;
  align-self: flex-start;
  min-width: 98px;
  white-space: nowrap;
  text-align: right;
  line-height: 1.95;
}

.forum-result-summary-stats strong,
.forum-my-replies-summary-stats strong {
  display: inline-block;
  margin-right: 4px;
  font-size: 1.26rem;
  font-style: italic;
  font-weight: 600;
  line-height: 1;
}

.forum-result-summary-solved-badge {
  display: inline-flex;
  flex: 0 0 auto;
  align-self: flex-start;
  white-space: nowrap;
  margin-top: 3px;
  padding: 0.38rem 0.58rem;
  border-radius: 11px;
  font-size: 0.78rem;
  font-weight: 700;
  line-height: 1;
}

.forum-my-replies-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 14px;
  padding-top: 0;
  border-top: 0;
}

.forum-my-replies-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 50px;
  align-items: stretch;
  width: 100%;
  gap: 12px;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: inherit;
  text-decoration: none;
  transition: none;
}

.forum-my-replies-item:hover {
  transform: none;
}

.forum-my-replies-item-avatar-wrap {
  position: relative;
  flex: 0 0 auto;
  justify-self: end;
  margin-left: 0;
  width: 50px;
  height: 50px;
}

.forum-my-replies-item-avatar {
  width: 50px;
  height: 50px;
  display: block;
  border-radius: 999px;
  object-fit: cover;
}

.forum-my-replies-item-online-dot {
  position: absolute;
  right: 0;
  bottom: 0;
  transform: translate(18%, 18%);
  font-size: 8px;
  color: #65a830;
  border: 2px solid #fff;
  border-radius: 50%;
  line-height: 1;
}

.forum-my-replies-item-body {
  flex: 1 1 auto;
  min-width: 0;
  padding: 13px 18px;
  border: 1px solid #e2e8f0;
  border-radius: 18px;
  background: #f8fafc;
  transition:
    border-color 0.2s ease,
    background-color 0.2s ease;
}

.forum-my-replies-item:hover .forum-my-replies-item-body {
  border-color: rgba(3, 105, 161, 0.25);
  background: #ffffff;
}

.forum-my-replies-item-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 6px;
}

.forum-my-replies-item-meta {
  display: flex;
  align-items: center;
  flex: 1 1 auto;
  flex-wrap: wrap;
  gap: 8px;
  min-width: 0;
}

.forum-my-replies-item-label {
  color: #64748b;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.forum-my-replies-item-user {
  display: inline-flex;
  align-items: center;
  max-width: 100%;
  color: #475569;
  font-size: 12px;
  font-weight: 600;
  line-height: 1.3;
  white-space: nowrap;
}

.forum-my-replies-item-user-admin,
.forum-my-replies-item-user-moderator {
  color: #475569;
}

.forum-my-replies-item-user-member {
  color: #64748b;
}

.forum-my-replies-item-time {
  color: #64748b;
  font-size: 12px;
  white-space: nowrap;
}

.forum-my-replies-item-snippet {
  color: #334155;
  line-height: 1.6;
  word-break: break-word;
}

.forum-my-replies-item--profiled {
  grid-template-columns: minmax(0, 1fr) 96px;
  gap: 14px;
  align-items: start;
}

.forum-my-replies-item-profile {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  min-width: 0;
}

.forum-my-replies-item--profiled .forum-my-replies-item-avatar-wrap {
  justify-self: center;
}

.forum-my-replies-item-profile-name {
  display: block;
  max-width: 100%;
  overflow-wrap: anywhere;
  word-break: break-word;
  color: #0f172a;
  font-size: 0.82rem;
  font-weight: 700;
  line-height: 1.3;
  text-align: center;
}

.forum-my-replies-item-profile-role {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  max-width: 100%;
  color: #475569;
  font-size: 0.74rem;
  font-weight: 600;
  line-height: 1.35;
  text-align: center;
}

.forum-my-replies-item--profiled .forum-my-replies-item-snippet {
  font-size: 1.01rem;
  line-height: 1.72;
}

.forum-my-replies-item--best .forum-my-replies-item-body {
  background: #eaf7ee;
  border-color: #87d1a0;
  box-shadow: 0 4px 14px rgba(21, 128, 61, 0.14);
}

.forum-my-replies-item--best:hover .forum-my-replies-item-body {
  background: #f1faf4;
  border-color: #7fcf9b;
}

.forum-result .snippet {
  background: #f4f4f4;
  padding: 8px 10px;
  word-wrap: break-word;
  border-radius: 16px;
}

body.night-mode .forum-result .snippet {
  background: var(--card-dark-input);
}

body.night-mode .forum-result .forum-result-thread-snippet {
  background: transparent;
  border-top-color: rgba(var(--bs-white-rgb), 0.14);
  color: rgba(var(--bs-white-rgb), 0.78);
}

body.night-mode .forum-thread-list-footer {
  border-top-color: rgba(var(--bs-white-rgb), 0.12);
}

body.night-mode .forum-thread-list-latest-label {
  color: rgba(var(--bs-light-rgb), 0.5);
}

body.night-mode .forum-thread-list-latest-name {
  color: rgba(var(--bs-white-rgb), 0.92);
}

body.night-mode .forum-thread-list-latest-role,
body.night-mode .forum-thread-list-latest-time,
body.night-mode .forum-thread-list-latest-empty {
  color: rgba(var(--bs-light-rgb), 0.68);
}

body.night-mode .forum-result .title a,
body.night-mode .forum-thread-title-link {
  color: rgba(var(--bs-white-rgb), 0.92);
}

body.night-mode .forum-result .title a:hover,
body.night-mode .forum-thread-title-link:hover {
  color: var(--bs-info);
}

body.night-mode .forum-thread-bounty-badge {
  border-color: rgba(251, 191, 36, 0.34);
  background: linear-gradient(135deg, #facc15 0%, #f59e0b 50%, #ea580c 100%);
  color: #1f1300;
  box-shadow:
    0 0.55rem 1.1rem rgba(245, 158, 11, 0.28),
    inset 0 1px 0 rgba(255, 255, 255, 0.18);
}

body.night-mode .forum-result-author-avatar-wrap .online-dot {
  border-color: #18263d;
}

body.night-mode .forum-result-author-username {
  color: rgba(var(--bs-white-rgb), 0.92);
}

body.night-mode .forum-result-author-role-admin {
  background: transparent;
  color: rgba(var(--bs-white-rgb), 0.76);
}

body.night-mode .forum-result-author-role-moderator {
  background: transparent;
  color: rgba(var(--bs-white-rgb), 0.76);
}

body.night-mode .forum-result-author-role-member {
  background: transparent;
  color: rgba(var(--bs-white-rgb), 0.68);
}

body.night-mode .forum-my-replies-item {
  background: transparent;
}

body.night-mode .forum-my-replies-item-body {
  border-color: rgba(var(--bs-white-rgb), 0.08);
  background: rgba(var(--bs-white-rgb), 0.04);
}

body.night-mode .forum-my-replies-item:hover .forum-my-replies-item-body {
  border-color: rgba(56, 189, 248, 0.3);
  background: rgba(var(--bs-white-rgb), 0.06);
}

body.night-mode .forum-my-replies-item-label,
body.night-mode .forum-my-replies-item-time {
  color: rgba(var(--bs-light-rgb), 0.68);
}

body.night-mode .forum-my-replies-item-user {
  color: rgba(var(--bs-white-rgb), 0.72);
}

body.night-mode .forum-my-replies-item-profile-name {
  color: rgba(var(--bs-white-rgb), 0.92);
}

body.night-mode .forum-my-replies-item-profile-role {
  color: rgba(var(--bs-white-rgb), 0.72);
}

body.night-mode .forum-my-replies-item-snippet {
  color: rgba(var(--bs-white-rgb), 0.86);
}

body.night-mode .forum-my-replies-item--best .forum-my-replies-item-body {
  background: #1a2f25;
  border-color: #2f7f59;
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.32);
}

body.night-mode .forum-my-replies-item--best:hover .forum-my-replies-item-body {
  background: #20382b;
  border-color: #3d8a62;
}

body.night-mode .forum-my-replies-item-online-dot {
  border-color: #18263d;
}

@media (max-width: 767.98px) {
  .forum-result .head {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 0.45rem 0.75rem;
  }

  .forum-thread-list-card > .head,
  .forum-thread-list-head {
    justify-content: flex-start;
  }

  .forum-result .head .float-end {
    float: none !important;
    width: 100%;
    order: 2;
    text-align: left !important;
  }

  .forum-result-head-actions {
    justify-content: flex-start;
    flex-wrap: wrap;
    white-space: normal;
  }

  .forum-result-summary,
  .forum-my-replies-summary,
  .forum-result-thread-layout,
  .forum-my-replies-thread-layout {
    flex-wrap: wrap !important;
  }

  .forum-my-replies-thread-layout,
  .forum-result-thread-layout-has-reply {
    display: flex;
    row-gap: 0;
  }

  .forum-my-replies-thread-layout > .forum-my-replies-thread-main,
  .forum-result-thread-layout-has-reply > .forum-result-thread-main {
    display: block;
    flex: 1 1 100%;
    width: 100%;
  }

  .forum-result-summary-layout {
    width: 100%;
    flex-direction: column;
    gap: 12px;
  }

  .forum-result-author-block {
    flex-basis: auto;
    min-width: 0;
    max-width: 100%;
  }

  .forum-my-replies-list {
    margin-top: 10px;
  }

  .forum-thread-list-latest {
    align-items: center;
    flex-wrap: nowrap;
    gap: 0.45rem;
  }

  .forum-thread-list-latest-copy {
    width: auto;
  }

  .forum-result-summary-stats,
  .forum-my-replies-summary-stats {
    width: 100%;
    text-align: left;
  }
}

/* -- */

/* PAGE = [DIRECTORY] */
/* ------------------------------- */

.directory-card {
  display: block;
  width: 100%;
  height: 100%;
  background: #f6f7f9;
  padding: 25px;
  text-align: center;
  color: #555;
  border-radius: 16px;
}

body.night-mode .directory-card {
  background: var(--card-dark-input);
  color: var(--body-color-dark);
}

.directory-card:hover {
  background: #eee;
  color: #898f9c;
}

body.night-mode .directory-card:hover {
  background: var(--card-dark-hover);
}

.directory-card .title {
  margin-top: 15px;
  color: #4b4f56;
}

body.night-mode .directory-card .title {
  color: var(--link-color);
}

.directory-card p {
  margin-bottom: 0;
}

/* -- */

/* PAGE = [MESSAGES] */
/* ------------------------------- */

/* panel-messages */
.panel-messages .card-header .fa-circle {
  color: #65a830;
  font-size: 9px;
}

.panel-messages .card-body {
  padding: 0;
}

.panel-messages.fresh .card-body {
  position: relative;
}

.panel-messages .conversation-user {
  width: 50px;
  height: 50px;
}

.panel-messages .conversation-user img {
  width: 50px;
  height: 50px;
}

.panel-messages .conversation-body {
  /* 60px = (50px+10px) (avatars + margins) */
  max-width: calc(100% - 60px);
}

.panel-messages .conversation-body .text {
  background: #e9eaee;
}

/* -- */

/* PAGE = [LIVE] */
/* ------------------------------- */

.live-stream-wrapper {
  background: #323232;
  padding: 20px;
  border-radius: 16px;
}

body.night-mode .live-stream-wrapper {
  background: var(--card-dark-color);
}

@media (min-width: 992px) {
  .live-stream-wrapper {
    padding: 50px;
  }
}

.live-stream-title {
  color: #fff;
  font-size: 34px;
  line-height: 50px;
  margin-bottom: 10px;
}

.live-stream-video {
  position: relative;
  height: 500px;
}

.live-stream-video .live-counter {
  position: absolute;
  top: 20px;
  left: 20px;
  z-index: 2;
}

.live-stream-video .live-counter .status {
  background: #dc3545;
  padding: 5px 15px;
  color: #fff;
  text-transform: uppercase;
  border-radius: 4px;
  font-weight: 600;
}

.live-stream-video .live-counter .status.offline {
  background: #383838;
}

.live-stream-video .live-counter .number {
  background: #383838;
  padding: 5px 10px;
  margin-left: 4px;
  color: #fff;
  text-transform: uppercase;
  border-radius: 4px;
}

.live-stream-video .live-status {
  position: absolute;
  bottom: 30px;
  left: 50%;
  transform: translateX(-50%);
  padding: 10px 25px;
  background: #383838;
  color: #fff;
  text-align: center;
  border-radius: 16px;
  z-index: 4;
}

.live-stream-video .live-status.info {
  background: #1171ef;
}

.live-stream-video .live-status.success {
  background: #28a745;
}

.live-stream-video .live-status.error {
  background: #dc3545;
}

.live-stream-video .live-recording {
  display: none;
  position: absolute;
  top: 20px;
  right: 20px;
  color: #ff0000;
  font-weight: 600;
  background: #383838;
  padding: 5px 10px;
  border-radius: 4px;
  z-index: 2;
}

.live-stream-video .live-comments {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  padding: 20px;
  height: 200px;
  z-index: 3;
  background-image: linear-gradient(rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 1) 100%);
  border-radius: 0 0 16px 16px;
}

.live-stream-video .live-video-player {
  width: 100%;
  height: 100%;
  background: #000;
  border-radius: 16px;
}

.live-stream-video .live-video-player div {
  border-radius: 16px;
}

.live-stream-video .live-video-player video {
  border-radius: 16px;
  background: #000;
  height: auto !important;
  transform: none !important;
}

.live-stream-buttons {
  display: none;
  text-align: center;
  margin-top: 20px;
}

.live-stream-tips-wrapper {
  background: #111111;
  padding: 10px 15px;
  border-radius: 20px;
  margin-top: 8px;
  font-size: 12px;
  line-height: 18px;
}

/* -- */

/* PAGE = [PROFILE] */
/* ------------------------------- */

/* profile-header */
.profile-header {
  background: #fff;
  position: relative;
  margin-bottom: 20px;
  border-radius: 0 0 16px 16px;
}

body.night-mode .profile-header {
  background: var(--body-bg-color-dark);
}

@media (min-width: 992px) {
  .profile-header {
    margin-bottom: 40px;
  }
}

/* -- */

/* profile-cover-wrapper */
.profile-cover-wrapper {
  background: #424242;
  position: relative;
  height: 180px;
  overflow: hidden;
  border-radius: 0 0 16px 16px;
}

body.night-mode .profile-cover-wrapper {
  background: #151a1f;
}

@media (min-width: 576px) {
  .profile-cover-wrapper {
    height: 240px;
  }
}

@media (min-width: 768px) {
  .profile-cover-wrapper {
    height: 300px;
  }
}

@media (min-width: 992px) {
  .profile-cover-wrapper {
    height: 360px;
  }
}

/* -- */

/* profile-cover-wrapper -> img */
.profile-cover-wrapper img.js_position-cover-cropped {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.profile-cover-wrapper img.js_lightbox:hover {
  cursor: pointer;
}

.profile-cover-wrapper img.js_position-cover-full {
  width: 100%;
  height: auto;
  cursor: move;
}

/* -- */

/* profile-cover-wrapper -> buttons */
.profile-cover-buttons {
  position: absolute;
  top: 10px;
  left: 10px;
  color: #fff;
  font-size: 12px;
  opacity: 0.4;
  transition: all 0.5s;
}

@media (min-width: 768px) {
  .profile-cover-buttons {
    top: 15px;
    left: 15px;
    font-size: 16px;
  }
}

.profile-cover-buttons > div {
  float: left;
  margin-right: 5px;
  padding: 4px 8px;
  border-radius: 50%;
  text-align: center;
  background: rgba(0, 0, 0, 0.1);
  transition: all 0.5s;
}

.profile-cover-buttons > div:hover {
  cursor: pointer;
  background: rgba(0, 0, 0, 0.25);
}

.profile-cover-wrapper:hover .profile-cover-buttons {
  opacity: 1;
}

.profile-cover-buttons form.x-uploader {
  position: relative;
}

.profile-cover-buttons > div.profile-cover-position-buttons {
  display: none;
  padding: 4px 6px;
}

/* -- */

/* profile-cover-wrapper -> loaders */
.profile-cover-change-loader {
  display: none;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  opacity: 0.5;
  background: #000;
  width: 100%;
  height: 100%;
  padding-top: 20%;
  transition: all 0.5s;
}

@media (min-width: 768px) {
  .profile-cover-change-loader {
    padding-top: 15%;
  }
}

.profile-cover-position-loader {
  display: none;
  position: absolute;
  top: 15px;
  left: 50%;
  padding: 8px 10px;
  background: rgba(0, 0, 0, 0.45);
  color: #fff;
  font-size: 11px;
  border-radius: 2px;
  transform: translate(-50%);
}

@media (min-width: 768px) {
  .profile-cover-position-loader {
    padding: 8px 24px;
    font-size: 13px;
    font-weight: 600;
  }
}

/* -- */

/* profile-avatar-wrapper */
.profile-avatar-wrapper {
  position: absolute;
  top: 112px;
  left: 50%;
  transform: translate(-50%);
  padding: 2px;
  background: #fff;
  border-radius: 50%;
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.3);
}

@media (min-width: 576px) {
  .profile-avatar-wrapper {
    top: 140px;
  }
}

@media (min-width: 768px) {
  .profile-avatar-wrapper {
    top: 170px;
  }
}

body.night-mode .profile-avatar-wrapper {
  background: var(--body-bg-color-dark);
}

.profile-avatar-wrapper.static {
  top: 0;
}

@media (min-width: 992px) {
  .profile-avatar-wrapper {
    padding: 4px;
  }

  .profile-avatar-wrapper:not(.static) {
    top: auto;
    bottom: -25px;
    left: 55px;
    transform: none;
  }
}

/* profile-avatar-wrapper -> img */
.profile-avatar-wrapper img {
  width: 90px;
  height: 90px;
  border-radius: 50%;
  transition: all 0.5s;
}

.profile-avatar-wrapper img.js_lightbox:hover {
  cursor: pointer;
}

@media (min-width: 576px) {
  .profile-avatar-wrapper img {
    width: 120px;
    height: 120px;
  }
}

@media (min-width: 768px) {
  .profile-avatar-wrapper img {
    width: 150px;
    height: 150px;
  }
}

@media (min-width: 992px) {
  .profile-avatar-wrapper img {
    width: 160px;
    height: 160px;
  }
}

/* -- */

/* profile-avatar-wrapper -> buttons */
.profile-avatar-change,
.profile-avatar-crop,
.profile-avatar-delete {
  display: block;
  position: absolute;
  bottom: 5px;
  right: 5px;
  opacity: 0.4;
  color: #fff;
  font-size: 12px;
  padding: 4px 8px;
  border-radius: 50%;
  text-align: center;
  background: rgba(0, 0, 0, 0.1);
  transition: all 0.5s;
}

.profile-avatar-change:hover,
.profile-avatar-crop:hover,
.profile-avatar-delete:hover {
  cursor: pointer;
  background: rgba(0, 0, 0, 0.25);
}

.profile-avatar-crop {
  bottom: 35px;
  right: -15px;
}

.profile-avatar-delete {
  bottom: 75px;
  right: 5px;
}

.profile-avatar-change form.x-uploader {
  position: relative;
}

@media (min-width: 576px) {
  .profile-avatar-delete {
    bottom: 75px;
    right: -15px;
  }
}

@media (min-width: 768px) {
  .profile-avatar-change,
  .profile-avatar-crop,
  .profile-avatar-delete {
    bottom: 10px;
    right: 10px;
    font-size: 16px;
  }

  .profile-avatar-crop {
    bottom: 45px;
    right: -10px;
  }

  .profile-avatar-delete {
    bottom: 85px;
    right: -15px;
  }
}

.profile-avatar-wrapper:hover .profile-avatar-change,
.profile-avatar-wrapper:hover .profile-avatar-delete,
.profile-avatar-wrapper:hover .profile-avatar-crop {
  opacity: 1;
}

/* -- */

/* profile-avatar-wrapper -> loaders */
.profile-avatar-change-loader {
  display: none;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  opacity: 0.5;
  background: #000;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  padding-top: 50%;
  transition: all 0.5s;
}

/* -- */

/* profile-name-wrapper */
.profile-name-wrapper {
  background: #fff;
  padding-top: 30px;
  padding-bottom: 10px;
  text-align: center;
  font-size: 1.2em;
  font-weight: 600;
}

body.night-mode .profile-name-wrapper {
  background: var(--body-bg-color-dark);
}

@media (min-width: 992px) {
  .profile-name-wrapper {
    position: absolute;
    bottom: 20px;
    left: 255px;
    right: auto;
    background: transparent !important;
    padding-top: 0;
    padding-bottom: 0;
    text-align: left;
    font-size: 1.9em;
    text-shadow: 0 0 3px rgba(0, 0, 0, 0.9);
  }

  .no-avatar .profile-name-wrapper {
    left: 85px;
    bottom: 40px;
  }
}

.profile-name-wrapper a {
  color: #333;
}

body.night-mode .profile-name-wrapper a {
  color: #fff;
}

.profile-name-wrapper a.badge {
  color: #fff;
}

@media (min-width: 992px) {
  .profile-name-wrapper a {
    color: #fff;
  }

  .profile-name-wrapper a.badge {
    font-size: 14px;
  }
}

/* -- */

/* profle-date-wrapper */
.profle-date-wrapper {
  position: absolute;
  width: 45px;
  left: 10px;
  top: 120px;
  padding: 6px;
  border-radius: 6px;
  border: 2px solid white;
  background: rgba(0, 0, 0, 0.1);
  text-align: center;
  font-size: 12px;
  color: #fff;

  transition: all 0.5s;
}

@media (min-width: 576px) {
  .profle-date-wrapper {
    top: 180px;
  }
}

@media (min-width: 768px) {
  .profle-date-wrapper {
    top: 240px;
  }
}

@media (min-width: 992px) {
  .profle-date-wrapper {
    width: 55px;
    left: 15px;
    top: auto;
    bottom: 20px;
    font-size: 14px;
  }
}

/* -- */

/* profle-meta-wrapper */
.profle-meta-wrapper {
  position: absolute;
  left: 65px;
  top: 140px;
  color: #e9e9e9;
  font-size: 12px;
  text-shadow: 0 0 3px rgba(0, 0, 0, 0.9);
}

@media (min-width: 576px) {
  .profle-meta-wrapper {
    top: 200px;
  }
}

@media (min-width: 768px) {
  .profle-meta-wrapper {
    top: 260px;
  }
}

@media (min-width: 992px) {
  .profle-meta-wrapper {
    left: 85px;
    top: auto;
    bottom: 20px;
    font-size: 14px;
  }
}

/* -- */

/* profile-buttons-wrapper */
.profile-buttons-wrapper {
  background: #fff;
  padding-bottom: 20px;
  text-align: center;
  border-radius: 0 0 16px 16px;
}

body.night-mode .profile-buttons-wrapper {
  background: var(--body-bg-color-dark);
}

@media (min-width: 992px) {
  .profile-buttons-wrapper {
    background: transparent !important;
    position: absolute;
    bottom: 20px;
    right: 15px;
    padding-bottom: 0;
    text-align: left;
  }
}

@media (max-width: 992px) {
  .profile-buttons-wrapper .btn {
    box-shadow: none;
  }
}

/* -- */

/* nb##: sg-nav-tabs 统一承接站内路由型横向导航，直接基于 Bootstrap nav-tabs 骨架收口 */
.sg-nav-tabs.nav-tabs {
  --bs-nav-tabs-border-width: 0;
  --bs-nav-tabs-border-color: transparent;
  --bs-nav-tabs-border-radius: 0;
  --bs-nav-tabs-link-hover-border-color: transparent;
  --bs-nav-tabs-link-active-border-color: transparent;
  padding: 0 10px;
  background: #fff;
  border: 1px solid var(--sg-theme-border);
  border-radius: 16px;
  margin-bottom: 20px;
  column-gap: 0.25rem;
  row-gap: 0.35rem;
}

body.night-mode .sg-nav-tabs.nav-tabs {
  background: var(--card-dark-color);
  border-color: var(--card-dark-divider);
}

.sg-nav-tabs .nav-link {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  margin-bottom: 0;
  padding: 10px 5px;
  line-height: 20px;
  font-weight: 600;
  background: transparent;
  border: 0;
  border-bottom: 2px solid transparent;
  border-radius: 0;
  color: #666;
  transition: all 0.2s ease;
}

@media (min-width: 992px) {
  .sg-nav-tabs .nav-link {
    padding: 20px 25px;
  }
}

body.night-mode .sg-nav-tabs .nav-link {
  color: var(--body-color-dark);
}

.nav-tabs.sg-nav-tabs .nav-link:hover,
.nav-tabs.sg-nav-tabs .nav-link:focus,
body.night-mode .nav-tabs.sg-nav-tabs .nav-link:hover,
body.night-mode .nav-tabs.sg-nav-tabs .nav-link:focus {
  background: transparent;
  color: var(--link-color);
  border-color: transparent;
  border-bottom-color: var(--link-color);
}

.nav-tabs.sg-nav-tabs .nav-item.show .nav-link,
.nav-tabs.sg-nav-tabs .nav-link.active,
.nav-tabs.sg-nav-tabs .nav-link.active:hover,
.nav-tabs.sg-nav-tabs .nav-link.active:focus,
body.night-mode .nav-tabs.sg-nav-tabs .nav-item.show .nav-link,
body.night-mode .nav-tabs.sg-nav-tabs .nav-link.active,
body.night-mode .nav-tabs.sg-nav-tabs .nav-link.active:hover,
body.night-mode .nav-tabs.sg-nav-tabs .nav-link.active:focus {
  background: transparent;
  background-color: transparent;
  color: var(--link-color);
  border-color: transparent;
  border-bottom: 2px solid var(--link-color);
  box-shadow: none;
}

/* nb##: 把 TOPIC 的图标 route-tabs 样式抽成通用 sg-nav-tabs，供 profile/page/group/event/topic/search 统一复用 */
.sg-nav-tabs {
  row-gap: 0.35rem;
}

.sg-nav-tabs .nav-link,
.sg-nav-tabs a {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  gap: 0.25rem;
}

.sg-nav-tabs .nav-link > span:last-child,
.sg-nav-tabs a > span:last-child {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
  flex-wrap: wrap;
}

.sg-nav-tabs .nav-link .main-icon,
.sg-nav-tabs .nav-link .mr5,
.sg-nav-tabs .nav-link .ml5,
.sg-nav-tabs a .main-icon,
.sg-nav-tabs a .mr5,
.sg-nav-tabs a .ml5 {
  margin-right: 0 !important;
  margin-left: 0 !important;
}

.sg-nav-tabs .sg-nav-tabs__icon {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.75rem;
  height: 1.75rem;
  overflow: visible;
}

.sg-nav-tabs .sg-nav-tabs__icon > i,
.sg-nav-tabs .sg-nav-tabs__icon > .svg-container {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.5rem !important;
  height: 1.5rem !important;
  flex: 0 0 1.5rem;
}

.sg-nav-tabs .sg-nav-tabs__icon > i {
  font-size: 1.5rem !important;
  line-height: 1 !important;
}

.sg-nav-tabs .sg-nav-tabs__icon > .svg-container svg {
  display: block;
  width: 100%;
  height: 100%;
}

.sg-nav-tabs .sg-nav-tabs__count {
  position: absolute;
  top: -0.82rem;
  right: -1.22rem;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.2rem;
  height: 1.2rem;
  padding: 0 0.28rem;
  border-radius: 999px;
  background: #eef1f4;
  color: #6b7280;
  font-size: 0.64rem;
  font-weight: 700;
  line-height: 1;
  box-shadow: 0 0 0 2px #fff;
  pointer-events: none;
}

body.night-mode .sg-nav-tabs .sg-nav-tabs__count {
  background: rgba(255, 255, 255, 0.08);
  color: var(--body-color-dark);
  box-shadow: 0 0 0 2px var(--card-dark-color);
}

.sg-nav-tabs .nav-link.active .sg-nav-tabs__count,
.sg-nav-tabs .nav-link:hover .sg-nav-tabs__count,
.sg-nav-tabs .nav-link:focus .sg-nav-tabs__count,
.sg-nav-tabs a.active .sg-nav-tabs__count,
.sg-nav-tabs a:hover .sg-nav-tabs__count,
body.night-mode .sg-nav-tabs .nav-link.active .sg-nav-tabs__count,
body.night-mode .sg-nav-tabs .nav-link:hover .sg-nav-tabs__count,
body.night-mode .sg-nav-tabs .nav-link:focus .sg-nav-tabs__count,
body.night-mode .sg-nav-tabs a.active .sg-nav-tabs__count,
body.night-mode .sg-nav-tabs a:hover .sg-nav-tabs__count {
  background: var(--link-color);
  color: #fff;
}

/* nb##: 横向路由导航统一通过 sg-nav-tabs-shell 处理 tabs 与右侧 action 的排布，替代旧版 tabs 容器 */
.sg-nav-tabs-shell {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

.sg-nav-tabs-shell .sg-nav-tabs.nav-tabs {
  margin-bottom: 0;
}

.sg-nav-tabs-shell__actions {
  display: flex;
  justify-content: flex-end;
  gap: 0.5rem;
  margin-bottom: 20px;
}

@media (min-width: 992px) {
  .sg-nav-tabs-shell {
    flex-direction: row;
    align-items: flex-start;
    gap: 1rem;
  }

  .sg-nav-tabs-shell .sg-nav-tabs.nav-tabs {
    flex: 1 1 auto;
  }

  .sg-nav-tabs-shell__actions {
    flex: 0 0 auto;
    align-self: flex-start;
  }
}

/* nb##: Forum/Support 顶部文本筛选条统一回收为 sg-nav-tabs 的紧凑变体，替代旧的模块专属筛选条家族 */
.sg-nav-tabs-strip {
  margin-bottom: 1rem;
  border-bottom: 1px solid var(--sg-theme-border-mid);
}

.sg-nav-tabs.nav-tabs.sg-nav-tabs--compact {
  padding: 0;
  background: transparent;
  border: 0;
  border-radius: 0;
  margin-bottom: 0;
  column-gap: 0.25rem;
  row-gap: 0;
}

.sg-nav-tabs--compact {
  gap: 0.25rem;
  border-bottom: 0;
}

.sg-nav-tabs--compact .nav-link,
.sg-nav-tabs--compact a {
  display: inline-flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  position: relative;
  gap: 0.35rem;
  margin-bottom: -1px;
  padding-block: 0.82rem;
  padding-inline: 0.95rem;
  border: 0;
  border-bottom: 3px solid transparent;
  border-radius: 0;
  background: transparent;
  color: var(--sg-theme-text-sub);
  font-size: 0.84rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1.2;
  text-transform: uppercase;
  overflow: visible;
}

.sg-nav-tabs--compact .nav-link:hover,
.sg-nav-tabs--compact .nav-link:focus,
.sg-nav-tabs--compact a:hover,
.sg-nav-tabs--compact a:focus {
  border-color: transparent;
  color: var(--sg-theme-text);
}

.sg-nav-tabs--compact .nav-link.active,
.sg-nav-tabs--compact .nav-link.active:hover,
.sg-nav-tabs--compact .nav-link.active:focus,
.sg-nav-tabs--compact a.active,
.sg-nav-tabs--compact a.active:hover,
.sg-nav-tabs--compact a.active:focus {
  background: transparent;
  color: var(--sg-theme-accent);
  border-bottom-color: var(--sg-theme-accent);
}

/* nb##: 通用紧凑 tabs 若挂载 sg-nav-tabs__count，则角标自动落在 tab 右上角，无需模块专属修饰类 */
.sg-nav-tabs--compact .sg-nav-tabs__count {
  top: 0.1rem;
  right: -0.18rem;
  left: auto;
}

body.night-mode .sg-nav-tabs-strip {
  border-color: rgba(var(--bs-white-rgb), 0.08);
}

body.night-mode .sg-nav-tabs--compact .nav-link,
body.night-mode .sg-nav-tabs--compact a {
  color: rgba(var(--bs-light-rgb), 0.72);
}

body.night-mode .sg-nav-tabs--compact .nav-link:hover,
body.night-mode .sg-nav-tabs--compact .nav-link:focus,
body.night-mode .sg-nav-tabs--compact a:hover,
body.night-mode .sg-nav-tabs--compact a:focus {
  color: rgba(var(--bs-white-rgb), 0.92);
}

body.night-mode .sg-nav-tabs--compact .nav-link.active,
body.night-mode .sg-nav-tabs--compact .nav-link.active:hover,
body.night-mode .sg-nav-tabs--compact .nav-link.active:focus,
body.night-mode .sg-nav-tabs--compact a.active,
body.night-mode .sg-nav-tabs--compact a.active:hover,
body.night-mode .sg-nav-tabs--compact a.active:focus {
  color: #d8b861;
  border-bottom-color: #d8b861;
}

@media (max-width: 991.98px) {
  .sg-nav-tabs--compact {
    flex-wrap: nowrap;
    overflow: auto;
    white-space: nowrap;
    -webkit-overflow-scrolling: touch;
  }

  .sg-nav-tabs--compact .nav-link,
  .sg-nav-tabs--compact a {
    flex: 0 0 auto;
    padding-inline: 0.75rem;
  }
}

/* -- */

/* panel-mutual-friends */
@media (max-width: 559px) {
  .panel-mutual-friends {
    background: var(--sg-nav-tone-border);
  }
}

.panel-mutual-friends li {
  float: left;
  width: 40px;
  height: 40px;
  margin-right: -8px;
}

/* -- */

/* panel [about] */
.about-bio {
  word-wrap: break-word;
  text-align: center;
  border-bottom: 1px solid #f4f4f4;
  margin-bottom: 10px;
  padding-bottom: 10px;
}

body.night-mode .about-bio {
  border-color: var(--card-dark-divider);
}

/* panel [videos] */
.panel-videos div[class^="col-"],
.panel-videos div[class*=" col-"] {
  padding: 1px;
  padding-bottom: 0;
}

.pg_video {
  position: relative;
  background: #eee;
  display: block;
  padding-bottom: 100%;
  overflow: hidden;
}

.pg_video video {
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  bottom: 0;
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.pg_video .play-button {
  position: absolute;
  top: calc(50% - 25px);
  left: calc(50% - 25px);
  display: block;
  width: 50px;
  height: 50px;
  padding-top: 11px;
  padding-left: 6px;
  border-radius: 50%;
  color: #f5f5f5;
  text-align: center;
  background-color: rgba(0, 0, 0, 0.5);
  transition: all 0.3s ease;
}

.pg_video:hover .play-button {
  background-color: rgba(0, 0, 0, 0.8);
  box-shadow: 0px 0px 10px rgba(255, 255, 100, 1);
}

/* -- */

/* album-card */
.album-card {
  border: 1px solid #f4f4f4;
  border-radius: 16px;
  margin-bottom: 10px;
}

body.night-mode .album-card {
  border-color: var(--card-dark-divider);
}

.album-cover {
  display: block;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
  background-color: #eee;
  width: 100%;
  height: 100%;
  padding-top: 100%;
  overflow: hidden;
  min-width: 40px;
  min-height: 40px;
  border-radius: 16px 16px 0 0;
}

.album-details {
  padding: 20px;
}

.album-details .fa {
  cursor: pointer;
}

.album-details .tooltip {
  width: auto;
  min-width: 110px;
  font-size: 11px;
}

/* -- */

/* album */
.album-title {
  text-align: center;
  font-size: 1.5em;
  font-weight: 600;
  margin-top: 20px;
}

.album-meta {
  text-align: center;
  margin-bottom: 40px;
}

/* -- */

/* PAGE = [ADMIN] */
/* ------------------------------- */

/* nb##: 后台导航图标颜色统一收口，优先复用 Bootstrap text-*，仅补足框架缺少的业务色 */
.admin-icon-violet {
  color: #9c27b0;
}

.admin-icon-orange {
  color: #ff5722;
}

.admin-icon-teal {
  color: #009688;
}

.admin-icon-brown {
  color: #795548;
}

.admin-form-spacer {
  width: 40px;
  height: 40px;
}

.admin-settings-select-wrap {
  min-width: 220px;
}

/* nb##: 后台 Sitemap 状态信息块补齐 light/night-mode 语义样式，避免深色主题下继续使用硬编码浅底卡片 */
.seo-sitemap-status-card {
  background: linear-gradient(180deg, #f8fbff 0%, #eef5ff 100%);
  border: 1px solid #d8e3f3 !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.85);
}

.seo-sitemap-status-card__item {
  height: 100%;
  padding: 12px 14px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(203, 213, 225, 0.8);
}

.seo-sitemap-status-card__label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: #64748b;
}

.seo-sitemap-status-card__value {
  margin-top: 6px;
  font-size: 15px;
  line-height: 1.45;
  color: #0f172a;
  word-break: break-word;
}

.seo-sitemap-status-card code {
  display: inline-block;
  max-width: 100%;
  padding: 2px 8px;
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.08);
  color: #0f172a;
  white-space: normal;
  overflow-wrap: anywhere;
}

.seo-sitemap-status-card__versions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.seo-sitemap-status-card__badge {
  padding: 7px 10px;
  background: rgba(37, 99, 235, 0.12);
  color: #1d4ed8;
  border: 1px solid rgba(37, 99, 235, 0.18);
  font-weight: 600;
}

body.night-mode .seo-sitemap-status-card {
  background: linear-gradient(
    180deg,
    rgba(31, 41, 55, 0.98) 0%,
    rgba(15, 23, 42, 0.98) 100%
  );
  border-color: var(--card-dark-divider) !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

body.night-mode .seo-sitemap-status-card__item {
  background: rgba(15, 23, 42, 0.72);
  border-color: rgba(148, 163, 184, 0.18);
}

body.night-mode .seo-sitemap-status-card__label {
  color: #94a3b8;
}

body.night-mode .seo-sitemap-status-card__value {
  color: var(--body-color-dark);
}

body.night-mode .seo-sitemap-status-card .text-muted {
  color: #94a3b8 !important;
}

body.night-mode .seo-sitemap-status-card code {
  background: rgba(148, 163, 184, 0.16);
  color: #e2e8f0;
}

body.night-mode .seo-sitemap-status-card__badge {
  background: rgba(96, 165, 250, 0.16);
  color: #dbeafe;
  border-color: rgba(96, 165, 250, 0.24);
}

/* -- */

/* admin sidebar */
@media (max-width: 767px) {
  .admin-sidebar {
    background: #fff;
    border-radius: 16px;
  }

  body.night-mode .admin-sidebar {
    background: var(--card-dark-color);
  }
}

/* -- */

/* admin-chart */
.admin-chart {
  min-width: 100%;
  height: 400px;
  margin: 0 auto;
  border: 1px solid #e6ecf5;
}

body.night-mode .admin-chart {
  border-color: var(--card-dark-divider);
}

body.night-mode .admin-chart .highcharts-title,
body.night-mode .admin-chart .highcharts-axis > *,
body.night-mode .admin-chart .highcharts-axis-labels > *,
body.night-mode .admin-chart .highcharts-legend-item text {
  color: var(--body-color-dark) !important;
  fill: var(--body-color-dark) !important;
}

/* -- */

/* table-img-thumbnail */
.table-img-thumbnail {
  max-width: 100px;
}

/* -- */

/* change-log-list */
.change-log-list {
  margin-left: 30px;
}

.change-log-list > li {
  margin-left: 30px;
  list-style-type: disc;
}

/* -- */

/* auto-connect-nodes */
.add-auto-connect-node {
  background: #f7f7f7;
  margin: 10px 0;
  padding: 10px;
  font-weight: 600;
  text-align: center;
  border: 1px solid #ddd;
  border-radius: 16px;
  cursor: pointer;
}

.add-auto-connect-node :hover {
  background: #f3f3f3;
}

body.night-mode .add-auto-connect-node {
  background: var(--card-dark-input);
  border-color: var(--card-dark-divider);
}

body.night-mode .add-auto-connect-node :hover {
  background: var(--card-dark-color);
}

.auto-connect-node {
  margin: 10px 0;
  padding: 20px 30px 0;
  border: 1px solid #ddd;
  border-radius: 16px;
}

body.night-mode .auto-connect-node {
  border-color: var(--card-dark-divider);
}

/* -- */

/* PAGE = [MARKET] */
/* ------------------------------- */

.product {
  position: relative;
  border-radius: 16px;
}

.product:not(.active):hover {
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.2);
}

.product.active {
  border: 1px solid #f4f4f4;
}

body.night-mode .product.active {
  border-color: var(--card-dark-divider);
}

.product.boosted {
  border: 2px solid #f9b340;
}

.product .boosted-icon {
  position: absolute;
  left: -15px;
  top: -15px;
  width: auto;
  padding: 3px 6px;
  font-size: 16px;
  background: #f9b340;
  color: #ffffff;
  border-radius: 50%;
  transform: rotate(-20deg);
  z-index: 2;
}

.product-image {
  position: relative;
  width: 100%;
  height: 250px;
  overflow: hidden;
  border-radius: 16px 16px 0 0;
}

.product-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.product-price {
  position: absolute;
  left: 10px;
  bottom: 10px;
  background: rgba(0, 0, 0, 0.65);
  color: #fff;
  font-size: 16px;
  font-weight: bold;
  line-height: 1;
  padding: 6px 10px;
  border-radius: 6px;
}

.product-price.with-offer {
  font-size: 14px;
  font-weight: normal;
}

.product-overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: 100%;
  padding-top: 100px;
  background: rgba(0, 0, 0, 0.5);
  color: #fff;
  text-align: center;
  opacity: 0;
  transition: all 300ms;
}

.product:hover .product-overlay {
  opacity: 1;
}

.product-info {
  padding: 10px;
}

.product-meta {
  overflow: hidden;
  word-break: break-all;
  text-overflow: ellipsis;
  white-space: nowrap;
  margin-bottom: 10px;
}

.product-meta .title {
  font-size: 18px;
  font-weight: bold;
}

/* -- */

/* invoice */
.invoice-title h2,
.invoice-title h3 {
  display: inline-block;
}

.table-invoice > tbody > tr > .no-line {
  border-top: none;
}

.table-invoice > thead > tr > .no-line {
  border-bottom: none;
}

.table-invoice > tbody > tr > .thick-line {
  border-top: 2px solid;
}

/* -- */

/* -- */

/* PAGE = [MOVIES] */
/* ------------------------------- */

.movie-card {
  margin-bottom: 20px;
}

.movie-card-top {
  position: relative;
  display: block;
  border: 5px solid #fff;
  border-radius: 4px;
  margin-bottom: 10px;
}

body.night-mode .movie-card-top {
  border-color: var(--card-dark-divider);
}

.movie-picture {
  background-size: cover;
  background-repeat: no-repeat;
  background-position: top center;
  background-color: #fff;
  width: 100%;
  height: 100%;
  min-height: 330px;
}

.movie-info {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: 100%;
  padding-top: 70px;
  background: rgba(0, 0, 0, 0.5);
  color: #fff;
  text-align: center;
  opacity: 0;
  transition: all 300ms;
  transition-delay: 100ms;
}

.movie-info .meta {
  font-size: 20px;
  font-weight: 700;
  margin-bottom: 10px;
}

.movie-card-top:hover .movie-info {
  opacity: 1;
}

.movie-card-bottom {
  margin: 0 auto;
  padding: 0 5px;
  text-align: left;
}

.movie-title {
  display: block;
  font-weight: 700;
  transition: color 0.15s ease-in-out;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}

.movie-year {
  margin-top: 5x;
}

/* -- */

/* PAGE = [REELS] */
/* ------------------------------- */

.reels-wrapper {
  position: fixed;
  top: 70px;
  bottom: 0;
  right: 0;
  left: 0;
  background: #000;
  z-index: 1;
}

.reels-loader {
  display: none;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: #fff;
  background: #000;
  border-radius: 10px;
  padding: 10px 16px;
  z-index: 2;
}

.reel-container {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  padding-top: 70px;
  padding-bottom: 0;
  background: #000;
  transform: translateY(0);
  transition: transform 0.3s ease;
}

.reel-container.swipe-up {
  transform: translateY(-100%);
  transition: transform 0.3s ease-out;
}

.reel-container.swipe-down {
  transform: translateY(100%);
  transition: transform 0.3s ease-out;
}

.reel-container.hidden {
  opacity: 0;
  visibility: hidden;
}

.reel-video-wrapper {
  position: relative;
  display: flex;
  flex-direction: column;
  height: 100%;
  width: 100%;
  transition: all 0.2s;
  user-select: none;
  color: #fff;
}

.reel-container.comments-shown .reel-video-wrapper {
  width: 0;
}

@media (min-width: 768px) {
  .reel-container.comments-shown .reel-video-wrapper {
    width: calc(100% - 420px);
  }
}

/*//nb##: 上下导航按钮从绝对定位右端移入 reel-actions 列（头像上方）- 原代码屏蔽
.reel-next-btn,
.reel-prev-btn {
  display: none;
  position: absolute;
  bottom: 40px;
  right: 20px;
  opacity: 0.7;
}

.reel-prev-btn {
  bottom: 100px;
}
*/
/*//nb##: END */
/* nb##: 上下导航按钮内联进 reel-actions flex 列，头像上方 BEGIN */
.reel-next-btn,
.reel-prev-btn {
  display: none;
  opacity: 0.7;
  text-align: center;
}

.reel-prev-btn {
  /* nb##: 移入 flex 列后无需单独偏移 */
}
/* nb##: END */

.reel-next-btn:hover,
.reel-prev-btn:hover {
  opacity: 1;
  cursor: pointer;
}

@media (min-width: 768px) {
  .reel-next-btn,
  .reel-prev-btn {
    display: block;
  }
}

.reel-video-wrapper .reel-video-container {
  position: relative;
  width: 100%;
  max-width: min(100%, calc((100dvh - 70px) * 9 / 16)); /* nb##: Reel 独立播放页按可用高度推导宽度，避免桌面端被固定 459px 卡窄 */
  display: block !important;
  margin: auto;
  height: calc(100dvh - 70px);
}

.reel-video-wrapper .reel-video-container .plyr--video {
  width: 100%;
  height: 100%;
}

/*//nb##: reel plyr 控制栏原位置（仅 mute 悬顶右角）- 原代码屏蔽
.reel-video-wrapper .reel-video-container .plyr__controls {
  top: 0;
  right: 0;
  left: auto;
  bottom: 100%;
  background: transparent;
}
*/
/* nb##: reel 控制栏移至视频底部，展示进度条/时间/静音 BEGIN */
/* nb##: position:absolute 显式声明——JS 会把 .plyr__controls 移至 .reel-video-container 直属子节点，
         Plyr 原生 .plyr--video .plyr__controls 规则不再匹配，需在此补声明 */
.reel-video-wrapper .reel-video-container .plyr__controls {
  position: absolute;
  top: auto;
  right: 0;
  left: 0;
  bottom: 0;
  padding: 4px 10px 6px;
  background: transparent;
  display: flex;
  align-items: center;
  gap: 4px;
  z-index: 5;
}

/* 进度条不可拖拽：仅作视觉进度指示 */
.reel-video-wrapper .reel-video-container .plyr__progress {
  pointer-events: none;
  cursor: default;
}

/* 时间数字 */
.reel-video-wrapper .reel-video-container .plyr__time {
  font-size: 11px;
  color: rgba(255, 255, 255, 0.9);
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.7);
  min-width: 32px;
}

/* 静音按钮 */
.reel-video-wrapper .reel-video-container .plyr__controls .plyr__control[data-plyr="mute"] {
  color: #fff;
  padding: 2px 6px;
}
/* nb##: END */

.reel-video-wrapper .reel-video-container .video-caption-overlay {
  position: absolute;
  top: 80%;
  bottom: 0;
  left: 0;
  right: 0;
  background: linear-gradient(rgba(0, 0, 0, 0) 0, rgba(0, 0, 0, 0.75) 100%);
}

.reel-video-wrapper .reel-video-container .video-caption {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 90px;
  padding: 20px 10px 44px; /* nb##: 底部留出 Plyr 控制栏高度 */
  color: #fff;
}

@media (min-width: 768px) {
  .reel-video-wrapper .reel-video-container .video-caption {
    right: 0;
    background: linear-gradient(rgba(0, 0, 0, 0) 0, rgba(0, 0, 0, 1) 100%);
  }
}

.reel-video-wrapper .reel-video-container .video-controlls {
  position: absolute;
  top: 0;
  bottom: 20px;
  right: -80px;
}

@media screen and (max-width: 768px) {
  .reel-video-wrapper .reel-video-container .video-controlls {
    position: absolute;
    top: 0;
    bottom: 20px;
    right: 20px;
  }
}

.reel-actions {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  height: 100%;
  text-align: center;
}

.reel-actions-top,
.reel-actions-bottom {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.reel-actions .post-avatar {
  display: block;
  margin-bottom: 10px;
  padding-right: 0;
}

.reel-actions .post-avatar .post-avatar-picture {
  min-width: 50px;
  min-height: 50px;
  border-radius: 50%;
  margin: 0 auto;
}

.reel-actions .post-avatar .online-dot {
  border-color: #000;
}

.reel-actions .action-btn {
  background: #333;
  border-radius: 50%;
  width: 50px;
  height: 50px;
  padding: 10px;
  transition: all 0.1s ease-in-out;
}

.reel-actions .action-btn:hover {
  background: #555;
  cursor: pointer;
}

.reel-actions .reaction-btn .reaction-btn-icon .fal {
  font-size: 28px;
}

.reel-action-btn span {
  display: block;
  font-size: 13px;
  margin-top: 5px;
}

.reel-actions .action-btn .inline-emoji {
  width: 40px;
  height: 40px;
}

.reel-actions .action-btn .inline-emoji .emoji {
  transform: scale(0.25);
  top: -115%;
  right: 100%;
}

.reel-comments-wrapper {
  display: none;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  width: 100%;
  background: #fff;
}

body.night-mode .reel-comments-wrapper {
  background: var(--card-dark-color);
}

@media (min-width: 768px) {
  .reel-comments-wrapper {
    width: 420px;
  }
}

.reel-container.comments-shown .reel-comments-wrapper {
  display: block;
}

.reel-lightbox.comments-shown .reel-comments-wrapper {
  display: block;
}

.reels-box-wrapper {
  height: 400px;
}

.reels-box-wrapper .slick-prev,
.reels-box-wrapper .slick-next {
  width: 40px;
  height: 40px;
  z-index: 2;
}

.reels-box-wrapper .slick-prev {
  left: 10px;
}

.reels-box-wrapper .slick-next {
  right: 10px;
}

.reels-box-wrapper .slick-prev:before,
.reels-box-wrapper .slick-next:before {
  font-size: 40px;
  color: #fff;
  text-shadow: 1px 1px #000000;
}

.reel-box {
  background-color: #000;
  position: relative;
  display: block;
  border-radius: 16px;
  margin-right: 20px;
  width: 260px;
  height: 400px !important;
  overflow: hidden;
}

.reel-box video {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  object-fit: cover;
  width: 100%;
  height: auto;
  max-height: 400px;
  border-radius: 16px;
}

.reel-box .views {
  position: absolute;
  bottom: 10px;
  left: 15px;
  color: #fff;
  text-shadow: 1px 1px #000000;
  z-index: 2;
}

/* -- */

/* TRANSLATOR */
/* ------------------------------- */

.translator-language {
  display: block;
  font-size: 15px;
  line-height: 100%;
  padding: 15px;
  margin-bottom: 5px;
  border: 1px solid #eee;
  border-radius: 1px;
}

.translator-language:hover {
  background: #f3f3f3;
  cursor: pointer;
}

/* -- */

/* BIG ICON */
/* ------------------------------- */

.big-icon {
  width: 80px;
  height: 80px;
  border: 4px solid rgba(128, 128, 128, 0.15);
  border-radius: 50%;
  margin: 20px auto;
  position: relative;
}

.big-icon.success {
  border-color: rgba(76, 174, 76, 0.15);
}

.big-icon.error {
  border-color: rgba(217, 83, 79, 0.15);
}

.big-icon.warning {
  border-color: rgba(255, 153, 0, 0.21);
}

.big-icon .fa {
  padding-top: 17px;
  padding-left: 3px;
}

.big-icon.success .fa {
  color: #4cae4c;
}

.big-icon.error .fa {
  color: #d9534f;
}

.big-icon.warning .fa {
  color: #d9954f;
}

/* -- */

/* LOADER */
/* ------------------------------- */

.x-loader {
  text-align: center;
}

.loader {
  width: 100%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -moz-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -moz-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  padding: 5px 0;
}

.loader:after {
  display: block;
  position: relative;
  width: 20px;
  height: 20px;
  -webkit-animation: rotate 0.6s linear infinite;
  -moz-animation: rotate 0.6s linear infinite;
  -ms-animation: rotate 0.6s linear infinite;
  -o-animation: rotate 0.6s linear infinite;
  animation: rotate 0.6s linear infinite;
  -webkit-border-radius: 100%;
  -moz-border-radius: 100%;
  border-radius: 100%;
  border-top: 1px solid #545a6a;
  border-bottom: 1px solid #d4d4db;
  border-left: 1px solid #545a6a;
  border-right: 1px solid #d4d4db;
  content: "";
  opacity: 0.5;
}

.loader.loader_large:after {
  width: 40px;
  height: 40px;
}

.loader.loader_medium:after {
  width: 25px;
  height: 25px;
}

.loader.loader_small:after {
  width: 10px;
  height: 10px;
}

.loader.loader_green:after {
  opacity: 1;
  border-top: 1px solid #42a26e;
  border-bottom: 1px solid #fff;
  border-left: 1px solid #42a26e;
  border-right: 1px solid #fff;
}

@keyframes rotate {
  0% {
    transform: rotateZ(-360deg);
    -webkit-transform: rotateZ(-360deg);
    -moz-transform: rotateZ(-360deg);
    -o-transform: rotateZ(-360deg);
  }

  100% {
    transform: rotateZ(0deg);
    -webkit-transform: rotateZ(0deg);
    -moz-transform: rotateZ(0deg);
    -o-transform: rotateZ(0deg);
  }
}

@-webkit-keyframes rotate {
  0% {
    transform: rotateZ(-360deg);
    -webkit-transform: rotateZ(-360deg);
    -moz-transform: rotateZ(-360deg);
    -o-transform: rotateZ(-360deg);
  }

  100% {
    transform: rotateZ(0deg);
    -webkit-transform: rotateZ(0deg);
    -moz-transform: rotateZ(0deg);
    -o-transform: rotateZ(0deg);
  }
}

@-moz-keyframes rotate {
  0% {
    transform: rotateZ(-360deg);
    -webkit-transform: rotateZ(-360deg);
    -moz-transform: rotateZ(-360deg);
    -o-transform: rotateZ(-360deg);
  }

  100% {
    transform: rotateZ(0deg);
    -webkit-transform: rotateZ(0deg);
    -moz-transform: rotateZ(0deg);
    -o-transform: rotateZ(0deg);
  }
}

@-o-keyframes rotate {
  0% {
    transform: rotateZ(-360deg);
    -webkit-transform: rotateZ(-360deg);
    -moz-transform: rotateZ(-360deg);
    -o-transform: rotateZ(-360deg);
  }

  100% {
    transform: rotateZ(0deg);
    -webkit-transform: rotateZ(0deg);
    -moz-transform: rotateZ(0deg);
    -o-transform: rotateZ(0deg);
  }
}

/* -- */

/* POST LOADER */
/* ------------------------------- */
@keyframes anim {
  0% {
    background-position: -468px 0;
  }

  100% {
    background-position: 468px 0;
  }
}

@-o-keyframes anim {
  0% {
    background-position: -468px 0;
  }

  100% {
    background-position: 468px 0;
  }
}

@-ms-keyframes anim {
  0% {
    background-position: -468px 0;
  }

  100% {
    background-position: 468px 0;
  }
}

@-moz-keyframes anim {
  0% {
    background-position: -468px 0;
  }

  100% {
    background-position: 468px 0;
  }
}

@-webkit-keyframes anim {
  0% {
    background-position: -468px 0;
  }

  100% {
    background-position: 468px 0;
  }
}

.panel-effect {
  position: relative;
  background: #f6f7f8 no-repeat 800px 104px;
  background-image: url("data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4gPHN2ZyB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PGRlZnM+PGxpbmVhckdyYWRpZW50IGlkPSJncmFkIiBncmFkaWVudFVuaXRzPSJvYmplY3RCb3VuZGluZ0JveCIgeDE9IjAuMCIgeTE9IjAuNSIgeDI9IjEuMCIgeTI9IjAuNSI+PHN0b3Agb2Zmc2V0PSIwJSIgc3RvcC1jb2xvcj0iI2Y2ZjdmOCIvPjxzdG9wIG9mZnNldD0iMjAlIiBzdG9wLWNvbG9yPSIjZWRlZWYxIi8+PHN0b3Agb2Zmc2V0PSI0MCUiIHN0b3AtY29sb3I9IiNmNmY3ZjgiLz48c3RvcCBvZmZzZXQ9IjEwMCUiIHN0b3AtY29sb3I9IiNmNmY3ZjgiLz48L2xpbmVhckdyYWRpZW50PjwvZGVmcz48cmVjdCB4PSIwIiB5PSIwIiB3aWR0aD0iMTAwJSIgaGVpZ2h0PSIxMDAlIiBmaWxsPSJ1cmwoI2dyYWQpIiAvPjwvc3ZnPiA=");
  background-size: 100%;
  background-image: -webkit-gradient(
    linear,
    0% 50%,
    100% 50%,
    color-stop(0%, #f6f7f8),
    color-stop(20%, #edeef1),
    color-stop(40%, #f6f7f8),
    color-stop(100%, #f6f7f8)
  );
  background-image: -moz-linear-gradient(
    left,
    #f6f7f8 0%,
    #edeef1 20%,
    #f6f7f8 40%,
    #f6f7f8 100%
  );
  background-image: -webkit-linear-gradient(
    left,
    #f6f7f8 0%,
    #edeef1 20%,
    #f6f7f8 40%,
    #f6f7f8 100%
  );
  background-image: linear-gradient(
    to right,
    #f6f7f8 0%,
    #edeef1 20%,
    #f6f7f8 40%,
    #f6f7f8 100%
  );
  height: 104px;
  -moz-animation: anim 1s forwards infinite linear;
  -webkit-animation: anim 1s forwards infinite linear;
  animation: anim 1s forwards infinite linear;
}

body.night-mode .panel-effect {
  background: var(--body-bg-color-dark) no-repeat 800px 104px;
  background-image: -webkit-gradient(
    linear,
    0% 50%,
    100% 50%,
    color-stop(0%, var(--body-bg-color-dark)),
    color-stop(20%, #323b44),
    color-stop(40%, var(--body-bg-color-dark)),
    color-stop(100%, var(--body-bg-color-dark))
  );
  background-image: -moz-linear-gradient(
    left,
    var(--body-bg-color-dark) 0%,
    #323b44 20%,
    var(--body-bg-color-dark) 40%,
    var(--body-bg-color-dark) 100%
  );
  background-image: -webkit-linear-gradient(
    left,
    var(--body-bg-color-dark) 0%,
    #323b44 20%,
    var(--body-bg-color-dark) 40%,
    var(--body-bg-color-dark) 100%
  );
  background-image: linear-gradient(
    to right,
    var(--body-bg-color-dark) 0%,
    #323b44 20%,
    var(--body-bg-color-dark) 40%,
    var(--body-bg-color-dark) 100%
  );
}

.fake-effect {
  position: absolute;
  background: #fff;
  right: 0;
  left: 0;
  height: 6px;
}

body.night-mode .fake-effect {
  background: #262d34;
}

.fe-0 {
  height: 40px;
  left: 40px;
  width: 8px;
}

.fe-1 {
  height: 8px;
  left: 48px;
  top: 0;
  right: 0;
}

.fe-2 {
  left: 136px;
  top: 8px;
}

.fe-3 {
  height: 12px;
  left: 48px;
  top: 14px;
}

.fe-4 {
  left: 100px;
  top: 26px;
}

.fe-5 {
  height: 10px;
  left: 48px;
  top: 32px;
}

.fe-6 {
  height: 20px;
  top: 40px;
}

.fe-7 {
  left: 410px;
  top: 60px;
}

.fe-8 {
  height: 13px;
  top: 66px;
}

.fe-9 {
  left: 440px;
  top: 79px;
}

.fe-10 {
  height: 13px;
  top: 85px;
}

.fe-11 {
  left: 178px;
  top: 98px;
}

/* -- */

/* ON/OFF TOGGLE */
/* ------------------------------- */

.switch {
  position: relative;
  display: inline-block;
  width: 60px;
  height: 34px;
  margin: 0;
}

.switch.sm {
  width: 30px;
  height: 17px;
}

.switch input {
  display: none;
}

.switch .slider {
  position: absolute;
  cursor: pointer;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: #ccc;
  transition: 0.4s;
}

body.night-mode .switch .slider {
  background-color: #666;
}

.switch .slider:before {
  position: absolute;
  content: "";
  height: 26px;
  width: 26px;
  left: 4px;
  bottom: 4px;
  background-color: white;
  transition: 0.4s;
}

.switch.sm .slider:before {
  height: 13px;
  width: 13px;
  left: 2px;
  bottom: 2px;
}

.switch input:checked + .slider {
  background-color: var(--link-color);
}

.switch.switch-warning input:checked + .slider {
  background-color: #ffc107;
}

.switch input:focus + .slider {
  box-shadow: 0 0 1px #2196f3;
}

.switch.switch-warning input:focus + .slider {
  box-shadow: 0 0 1px #ffc107;
}

.switch input:checked + .slider:before {
  -webkit-transform: translateX(26px);
  -ms-transform: translateX(26px);
  transform: translateX(26px);
}

.switch.sm input:checked + .slider:before {
  -webkit-transform: translateX(13px);
  -ms-transform: translateX(13px);
  transform: translateX(13px);
}

.switch .slider.round {
  border-radius: 34px;
}

.switch .slider.round:before {
  border-radius: 50%;
}

/* -- */

/* CUSTOM RADIO/CHECKBOX TEMPLATES */
/* ------------------------------- */

.button-label {
  display: inline-block;
  padding: 1em 2em;
  margin: 0.5em;
  cursor: pointer;
  color: #6c6c6c;
  border-radius: 6px;
  transition: 0.3s;
  box-shadow: 0 0 0 1px #e6e6e6;
  min-width: 115px;
}

.button-label.small {
  min-width: 80px;
}

body.night-mode .button-label {
  box-shadow: 0 0 0 1px var(--card-dark-divider);
  color: var(--body-color-dark);
}

.button-label-image {
  display: block;
  padding: 5px;
  margin: 0px;
  width: 100%;
  height: 100%;
  box-shadow: none;
  cursor: pointer;
  transition: 0.3s;
  border-radius: 2px;
}

.button-label .icon {
  display: flex;
  align-items: center;
  justify-content: center;
  background: #f3f3f3;
  height: 60px;
  width: 60px;
  margin: 0 auto;
  border-radius: 50%;
  transition: all 0.2s;
  opacity: 0.75;
  filter: grayscale(1);
}

body.night-mode .button-label .icon {
  background: var(--card-dark-input);
}

.button-label.small .icon {
  width: 30px;
  height: 30px;
}

.button-label .icon img {
  width: 32px;
  height: 32px;
}

.button-label-image img {
  width: 100%;
  height: 100%;
  border-radius: 2px;
}

.button-label .title {
  font-weight: 500;
  font-size: 14px;
  margin-top: 15px;
  text-transform: capitalize;
  text-align: center;
}

.button-label:hover,
.button-label-image:hover {
  box-shadow: 0px 0px 0px 2px rgba(102, 199, 244, 0.65);
}

.input-label:checked + .button-label,
.input-label:checked + .button-label-image {
  box-shadow: 0px 0px 0px 2px rgba(102, 199, 244, 0.65);
}

.input-label:checked + .button-label .icon {
  filter: grayscale(0);
  opacity: 1;
}

/* -- */

/* PWA INSTALL PROMPT */
/* ------------------------------- */

/* nb##: Android/iPad PWA standalone 模式下把 container 横向留白收成约 15px，避免 .row 两侧太宽或太贴边 BEGIN */
@media (max-width: 767.98px) {
  html.sg-pwa-standalone .container,
  html.sg-pwa-standalone .container-sm,
  html.sg-pwa-standalone .container-md,
  html.sg-pwa-standalone .container-lg,
  html.sg-pwa-standalone .container-xl,
  html.sg-pwa-standalone .container-xxl,
  html.sg-pwa-standalone .container-fluid,
  html.sg-pwa-standalone .logged-as-container {
    width: 100%;
    max-width: none !important;
    padding-left: max(15px, env(safe-area-inset-left, 0px));
    padding-right: max(15px, env(safe-area-inset-right, 0px));
  }
}

@media (min-width: 768px) {
  html.sg-pwa-standalone .container,
  html.sg-pwa-standalone .container-sm,
  html.sg-pwa-standalone .container-md,
  html.sg-pwa-standalone .container-lg,
  html.sg-pwa-standalone .container-xl,
  html.sg-pwa-standalone .container-xxl,
  html.sg-pwa-standalone .container-fluid,
  html.sg-pwa-standalone .logged-as-container {
    width: 100%;
    max-width: none !important;
    padding-left: max(15px, env(safe-area-inset-left, 0px));
    padding-right: max(15px, env(safe-area-inset-right, 0px));
  }
}
/* nb##: END */

/* -- */

/* MERITS */
/* ------------------------------- */

.merits-box-wrapper {
  margin: 0 20px;
}

.merits-box-wrapper .slick-prev:before,
.merits-box-wrapper .slick-next:before {
  color: var(--link-color);
}

.merit-box {
  width: 100px;
  margin: 0 5px;
  text-align: center;
  cursor: pointer;
}

.merit-box img {
  display: inline-block !important;
}

.merit-box .name {
  font-size: 12px;
  font-weight: 600;
  margin-top: 5px;
}

/* -- */

/* EXTRAS */
/* ------------------------------- */

/* == margins == */
.ml0 {
  margin-left: 0 !important;
}

.mr0 {
  margin-right: 0 !important;
}

.mlr0 {
  margin-left: 0 !important;
  margin-right: 0 !important;
}

.mt0 {
  margin-top: 0 !important;
}

.mb0 {
  margin-bottom: 0 !important;
}

.mtb0 {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}

.ml5 {
  margin-left: 5px !important;
}

.mr5 {
  margin-right: 5px !important;
}

.mlr5 {
  margin-left: 5px !important;
  margin-right: 5px !important;
}

.mt5 {
  margin-top: 5px !important;
}

.mb5 {
  margin-bottom: 5px !important;
}

.mtb5 {
  margin-top: 5px !important;
  margin-bottom: 5px !important;
}

.ml10 {
  margin-left: 10px !important;
}

.mr10 {
  margin-right: 10px !important;
}

.mlr10 {
  margin-left: 10px !important;
  margin-right: 10px !important;
}

.mt10 {
  margin-top: 10px !important;
}

.mb10 {
  margin-bottom: 10px !important;
}

.mtb10 {
  margin-top: 10px !important;
  margin-bottom: 10px !important;
}

.ml15 {
  margin-left: 15px !important;
}

.mr15 {
  margin-right: 15px !important;
}

.mlr15 {
  margin-left: 15px !important;
  margin-right: 15px !important;
}

.mt15 {
  margin-top: 15px !important;
}

.mb15 {
  margin-bottom: 15px !important;
}

.mtb15 {
  margin-top: 15px !important;
  margin-bottom: 15px !important;
}

.ml20 {
  margin-left: 20px !important;
}

.mr20 {
  margin-right: 20px !important;
}

.mlr20 {
  margin-left: 20px !important;
  margin-right: 20px !important;
}

.mt20 {
  margin-top: 20px !important;
}

.mb20 {
  margin-bottom: 20px !important;
}

.mtb20 {
  margin-top: 20px !important;
  margin-bottom: 20px !important;
}

.ml25 {
  margin-left: 25px !important;
}

.mr25 {
  margin-right: 25px !important;
}

.mlr25 {
  margin-left: 25px !important;
  margin-right: 25px !important;
}

.mt25 {
  margin-top: 25px !important;
}

.mb25 {
  margin-bottom: 25px !important;
}

.mtb25 {
  margin-top: 25px !important;
  margin-bottom: 25px !important;
}

.ml30 {
  margin-left: 30px !important;
}

.mr30 {
  margin-right: 30px !important;
}

.mlr30 {
  margin-left: 30px !important;
  margin-right: 30px !important;
}

.mt30 {
  margin-top: 30px !important;
}

.mb30 {
  margin-bottom: 30px !important;
}

.mtb30 {
  margin-top: 30px !important;
  margin-bottom: 30px !important;
}

/* -- */

/* == paddings == */
.pl0 {
  padding-left: 0px !important;
}

.pr0 {
  padding-right: 0px !important;
}

.plr0 {
  padding-left: 0px !important;
  padding-right: 0px !important;
}

.pt0 {
  padding-top: 0px !important;
}

.pb0 {
  padding-bottom: 0px !important;
}

.ptb0 {
  padding-top: 0px !important;
  padding-bottom: 0px !important;
}

.pl5 {
  padding-left: 5px !important;
}

.pr5 {
  padding-right: 5px !important;
}

.plr5 {
  padding-left: 5px !important;
  padding-right: 5px !important;
}

.pt5 {
  padding-top: 5px !important;
}

.pb5 {
  padding-bottom: 5px !important;
}

.ptb5 {
  padding-top: 5px !important;
  padding-bottom: 5px !important;
}

.pl10 {
  padding-left: 10px !important;
}

.pr10 {
  padding-right: 10px !important;
}

.plr10 {
  padding-left: 10px !important;
  padding-right: 10px !important;
}

.pt10 {
  padding-top: 10px !important;
}

.pb10 {
  padding-bottom: 10px !important;
}

.ptb10 {
  padding-top: 10px !important;
  padding-bottom: 10px !important;
}

.pl15 {
  padding-left: 15px !important;
}

.pr15 {
  padding-right: 15px !important;
}

.plr15 {
  padding-left: 15px !important;
  padding-right: 15px !important;
}

.pt15 {
  padding-top: 15px !important;
}

.pb15 {
  padding-bottom: 15px !important;
}

.ptb15 {
  padding-top: 15px !important;
  padding-bottom: 15px !important;
}

.pl20 {
  padding-left: 20px !important;
}

.pr20 {
  padding-right: 20px !important;
}

.plr20 {
  padding-left: 20px !important;
  padding-right: 20px !important;
}

.pt20 {
  padding-top: 20px !important;
}

.pb20 {
  padding-bottom: 20px !important;
}

.ptb20 {
  padding-top: 20px !important;
  padding-bottom: 20px !important;
}

.pl25 {
  padding-left: 25px !important;
}

.pr25 {
  padding-right: 25px !important;
}

.plr25 {
  padding-left: 25px !important;
  padding-right: 25px !important;
}

.pt25 {
  padding-top: 25px !important;
}

.pb25 {
  padding-bottom: 25px !important;
}

.ptb25 {
  padding-top: 25px !important;
  padding-bottom: 25px !important;
}

.pl30 {
  padding-left: 30px !important;
}

.pr30 {
  padding-right: 30px !important;
}

.plr30 {
  padding-left: 30px !important;
  padding-right: 30px !important;
}

.pt30 {
  padding-top: 30px !important;
}

.pb30 {
  padding-bottom: 30px !important;
}

.ptb30 {
  padding-top: 30px !important;
  padding-bottom: 30px !important;
}

/* -- */

/* == text == */
.text-link {
  color: var(--link-color);
}

.text-link:hover {
  cursor: pointer;
  text-decoration: underline;
}

.text-link-no-underline {
  color: var(--link-color);
}

.text-underline:hover {
  cursor: pointer;
  text-decoration: underline;
}

.text-no-underline:hover {
  text-decoration: none !important;
}

.text-active {
  color: #66c7f4 !important;
}

/* text sizes */
.text-sm {
  font-size: 0.8em;
  line-height: 1;
}

.text-md {
  font-size: 1.1em;
  line-height: 1.6;
}

.text-lg {
  font-size: 1.2em;
  line-height: 1.7;
}

.text-xlg {
  font-size: 1.3em;
  line-height: 1.8em;
}

.text-xxlg {
  font-size: 2.3em;
  font-weight: 700;
}

/* -- */

.text-with-list ul {
  list-style-type: disc;
  padding-inline-start: 40px;
  margin-top: 1rem;
  margin-bottom: 1rem;
}

.red {
  color: red;
}

.green {
  color: green;
}

.yellow {
  color: #ebba16;
}

/* -- */

/* == user-select == */
.unselectable {
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -khtml-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

/* -- */

/* == cursor == */
.pointer {
  cursor: pointer;
}

/* -- */

/* == vertical-align == */
.vertical-align-top {
  vertical-align: top;
}

.vertical-align-middle {
  vertical-align: middle;
}

.vertical-align-bottom {
  vertical-align: bottom;
}

/* -- */

/* == x == */
.x-notifier {
  background: #ffffcd !important;
}

.x-hidden {
  display: none;
}

.x-blured {
  overflow: hidden;
}

.x-blured .js_lightbox,
.x-blured .album-cover {
  filter: blur(10px);
}

/* -- */

/* OFFCANVAS */
/* ------------------------------- */

@media (max-width: 767px) {
  .sg-offcanvas {
    position: relative;
    overflow: hidden;
  }

  .sg-offcanvas.active {
    transition: all 0.25s ease-out;
  }

  .sg-offcanvas .sg-offcanvas-sidebar {
    position: absolute !important;
    top: 0;
    left: -100%;
    width: 100%;
    z-index: 100;
    transition: all 0.25s ease-out;
  }

  .sg-offcanvas.active .sg-offcanvas-sidebar {
    left: 0;
  }

  .sg-offcanvas .sg-offcanvas-mainbar {
    left: 0;
    transition: all 0.25s ease-out;
  }

  .sg-offcanvas.active .sg-offcanvas-mainbar {
    left: 100%;
  }
}

/* -- */

/* == popup layer == */
/*//nb##: Add reusable popup-layer positioning system BEGIN*/
.sg-popup-layer,
.cc-window.cc-banner,
.cc-window.cc-floating {
  --sg-popup-offset: 16px;
  --sg-popup-offset-mobile: 10px;
  --sg-popup-width: min(560px, calc(100vw - 32px));
  --sg-popup-width-mobile: calc(100vw - 20px);
  --sg-popup-max-width: 560px;
  position: fixed !important;
  left: var(--sg-popup-offset) !important;
  right: auto !important;
  top: auto !important;
  bottom: var(--sg-popup-offset) !important;
  inset: auto auto var(--sg-popup-offset) var(--sg-popup-offset) !important;
  width: var(--sg-popup-width) !important;
  max-width: var(--sg-popup-max-width) !important;
  margin: 0 !important;
  transform: none !important;
  z-index: 1080 !important;
}

.sg-popup-layer--bottom-left,
.sg-popup-layer[data-popup-position="bottom-left"] {
  left: var(--sg-popup-offset) !important;
  right: auto !important;
  top: auto !important;
  bottom: var(--sg-popup-offset) !important;
  inset: auto auto var(--sg-popup-offset) var(--sg-popup-offset) !important;
  transform: none !important;
}

.sg-popup-layer--bottom-right,
.sg-popup-layer[data-popup-position="bottom-right"] {
  left: auto !important;
  right: var(--sg-popup-offset) !important;
  top: auto !important;
  bottom: var(--sg-popup-offset) !important;
  inset: auto var(--sg-popup-offset) var(--sg-popup-offset) auto !important;
  transform: none !important;
}

.sg-popup-layer--top-left,
.sg-popup-layer[data-popup-position="top-left"] {
  left: var(--sg-popup-offset) !important;
  right: auto !important;
  top: var(--sg-popup-offset) !important;
  bottom: auto !important;
  inset: var(--sg-popup-offset) auto auto var(--sg-popup-offset) !important;
  transform: none !important;
}

.sg-popup-layer--top-right,
.sg-popup-layer[data-popup-position="top-right"] {
  left: auto !important;
  right: var(--sg-popup-offset) !important;
  top: var(--sg-popup-offset) !important;
  bottom: auto !important;
  inset: var(--sg-popup-offset) var(--sg-popup-offset) auto auto !important;
  transform: none !important;
}

.sg-popup-layer--bottom-center,
.sg-popup-layer[data-popup-position="bottom-center"] {
  left: 50% !important;
  right: auto !important;
  top: auto !important;
  bottom: var(--sg-popup-offset) !important;
  inset: auto auto var(--sg-popup-offset) 50% !important;
  transform: translateX(-50%) !important;
}

@media (max-width: 576px) {
  .sg-popup-layer,
  .cc-window.cc-banner,
  .cc-window.cc-floating {
    left: var(--sg-popup-offset-mobile) !important;
    right: auto !important;
    top: auto !important;
    bottom: var(--sg-popup-offset-mobile) !important;
    inset: auto auto var(--sg-popup-offset-mobile) var(--sg-popup-offset-mobile) !important;
    width: var(--sg-popup-width-mobile) !important;
    max-width: var(--sg-popup-width-mobile) !important;
    transform: none !important;
  }

  .sg-popup-layer--bottom-right,
  .sg-popup-layer[data-popup-position="bottom-right"] {
    left: auto !important;
    right: var(--sg-popup-offset-mobile) !important;
    inset: auto var(--sg-popup-offset-mobile) var(--sg-popup-offset-mobile) auto !important;
  }

  .sg-popup-layer--top-left,
  .sg-popup-layer[data-popup-position="top-left"] {
    left: var(--sg-popup-offset-mobile) !important;
    right: auto !important;
    top: var(--sg-popup-offset-mobile) !important;
    bottom: auto !important;
    inset: var(--sg-popup-offset-mobile) auto auto var(--sg-popup-offset-mobile) !important;
  }

  .sg-popup-layer--top-right,
  .sg-popup-layer[data-popup-position="top-right"] {
    left: auto !important;
    right: var(--sg-popup-offset-mobile) !important;
    top: var(--sg-popup-offset-mobile) !important;
    bottom: auto !important;
    inset: var(--sg-popup-offset-mobile) var(--sg-popup-offset-mobile) auto auto !important;
  }

  .sg-popup-layer--bottom-center,
  .sg-popup-layer[data-popup-position="bottom-center"] {
    left: var(--sg-popup-offset-mobile) !important;
    right: auto !important;
    top: auto !important;
    bottom: var(--sg-popup-offset-mobile) !important;
    inset: auto auto var(--sg-popup-offset-mobile) var(--sg-popup-offset-mobile) !important;
    transform: none !important;
  }
}
/*//nb##: END*/

/* == cookie banner == */
#cookie-banner {
  /*//nb##: Keep cookie banner anchored bottom-left and lift it above the active PWA banner BEGIN*/
  position: fixed !important;
  left: 16px !important;
  right: auto !important;
  top: auto !important;
  bottom: calc(16px + var(--sg-pwa-install-banner-offset, 0px)) !important;
  inset: auto auto calc(16px + var(--sg-pwa-install-banner-offset, 0px)) 16px !important;
  width: min(560px, calc(100vw - 32px)) !important;
  max-width: 560px !important;
  margin: 0 !important;
  transform: none !important;
  z-index: 1080 !important;
  /*//nb##: END*/
  display: none;
  flex-direction: column;
  align-items: stretch;
  gap: 16px;
}

#cookie-banner .cookie-banner__text {
  font-size: 14px;
  line-height: 1.6;
}

#cookie-banner a {
  color: inherit;
  text-decoration: underline;
}

#cookie-banner .banner-btns {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-top: 2px;
  width: 100% !important;
  max-width: 100% !important;
}

/*//nb##: Keep compatibility when stale template cache still contains Bootstrap col-* classes BEGIN*/
#cookie-banner .banner-btns[class*="col-"] {
  width: 100% !important;
  max-width: 100% !important;
  flex: none !important;
}
/*//nb##: END*/

/*//nb##: Normalize cookie banner button layout and semantic colors BEGIN*/
#cookie-banner .banner-btns .btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  width: 100%;
  min-width: 0;
  white-space: normal;
  line-height: 1.25;
  border-radius: 12px;
  padding: 8px 12px;
  border-width: 1px;
  border-style: solid;
}

#cookie-banner .banner-btns .btn-settings,
#cookie-banner .banner-btns .btn-reject {
  background: rgba(255, 255, 255, 0.12) !important;
  border-color: rgba(255, 255, 255, 0.36) !important;
  color: #ffffff !important;
}

#cookie-banner .banner-btns .btn-settings:hover,
#cookie-banner .banner-btns .btn-settings:focus,
#cookie-banner .banner-btns .btn-reject:hover,
#cookie-banner .banner-btns .btn-reject:focus {
  background: rgba(255, 255, 255, 0.2) !important;
  border-color: rgba(255, 255, 255, 0.45) !important;
  color: #ffffff !important;
}

#cookie-banner .banner-btns .btn-accept {
  background: #66c7f4 !important;
  border-color: #66c7f4 !important;
  color: #ffffff !important;
}

#cookie-banner .banner-btns .btn-accept:hover,
#cookie-banner .banner-btns .btn-accept:focus {
  background: #4fb9ea !important;
  border-color: #4fb9ea !important;
  color: #ffffff !important;
}
/*//nb##: END*/

@media (max-width: 576px) {
  #cookie-banner {
    left: 10px !important;
    right: auto !important;
    top: auto !important;
    bottom: calc(10px + var(--sg-pwa-install-banner-offset, 0px)) !important;
    inset: auto auto calc(10px + var(--sg-pwa-install-banner-offset, 0px)) 10px !important;
    width: calc(100vw - 20px) !important;
    max-width: calc(100vw - 20px) !important;
    transform: none !important;
  }

  /*//nb##: Compress mobile cookie buttons and keep single-row layout whenever possible BEGIN*/
  #cookie-banner .banner-btns {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 6px;
  }

  #cookie-banner .banner-btns .btn {
    width: 100%;
    max-width: 92px;
    justify-self: center;
    padding: 6px 6px;
    font-size: 10px;
    line-height: 1.15;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }
  /*//nb##: END*/
}

/*//nb##: Apply demo-pages/preview.html dual-theme palette across the main site BEGIN*/
:root {
  --sg-theme-bg: #f4f1ec;
  --sg-theme-bg-alt: #ece8e1;
  --sg-theme-surface: #ffffff;
  --sg-theme-surface-2: #faf8f4;
  --sg-theme-surface-3: #f0ece5;
  --sg-theme-text: #18222e;
  --sg-theme-text-sub: #4a5568;
  --sg-theme-text-muted: #8a96a8;
  --sg-theme-text-faint: #bcc4cf;
  --sg-theme-accent: #b87200;
  --sg-theme-accent-hover: #8a5200;
  --sg-theme-accent-rgb: 184, 114, 0;
  --sg-theme-accent-text: #ffffff;
  --sg-theme-accent-dim: rgba(184, 114, 0, 0.1);
  --sg-theme-border: rgba(0, 0, 0, 0.07);
  --sg-theme-border-mid: rgba(0, 0, 0, 0.12);
  --sg-theme-border-hi: rgba(0, 0, 0, 0.2);
  --sg-theme-shadow-sm: 0 1px 4px rgba(0, 0, 0, 0.09);
  --sg-theme-shadow-md: 0 4px 20px rgba(0, 0, 0, 0.12);
  --sg-theme-shadow-lg: 0 12px 48px rgba(0, 0, 0, 0.16);
  --sg-theme-header-bg: rgba(255, 255, 255, 0.88);
  --sg-theme-glass: rgba(244, 241, 236, 0.9);
  --sg-theme-input-bg: #faf8f4;
  --sg-theme-selection-text: #ffffff;

  --body-bg-color: var(--sg-theme-bg);
  --body-color: var(--sg-theme-text);
  --link-color: var(--sg-theme-accent);
  --header-bg-color: var(--sg-theme-header-bg);
  --plyr-color-main: var(--sg-theme-accent);

  --bs-primary: var(--sg-theme-accent);
  --bs-primary-rgb: var(--sg-theme-accent-rgb);
  --bs-link-color: var(--sg-theme-accent);
  --bs-link-hover-color: var(--sg-theme-accent-hover);
  --bs-body-bg: var(--sg-theme-bg);
  --bs-body-color: var(--sg-theme-text);
  --bs-border-color: var(--sg-theme-border);
}

body.night-mode,
body[data-bs-theme="dark"] {
  --sg-theme-bg: #16202e;
  --sg-theme-bg-alt: #131c29;
  --sg-theme-surface: #1e2a3a;
  --sg-theme-surface-2: #253044;
  --sg-theme-surface-3: #2c3a52;
  --sg-theme-text: #dde4f0;
  --sg-theme-text-sub: #8c9db8;
  --sg-theme-text-muted: #5a6e8a;
  --sg-theme-text-faint: #344560;
  --sg-theme-accent: #e8a020;
  --sg-theme-accent-hover: #f0b34a;
  --sg-theme-accent-rgb: 232, 160, 32;
  --sg-theme-accent-text: #0d1520;
  --sg-theme-accent-dim: rgba(232, 160, 32, 0.14);
  --sg-theme-border: rgba(255, 255, 255, 0.06);
  --sg-theme-border-mid: rgba(255, 255, 255, 0.11);
  --sg-theme-border-hi: rgba(255, 255, 255, 0.18);
  --sg-theme-shadow-sm: 0 1px 4px rgba(0, 0, 0, 0.45);
  --sg-theme-shadow-md: 0 4px 20px rgba(0, 0, 0, 0.55);
  --sg-theme-shadow-lg: 0 12px 48px rgba(0, 0, 0, 0.65);
  --sg-theme-header-bg: rgba(19, 28, 41, 0.9);
  --sg-theme-glass: rgba(22, 32, 46, 0.84);
  --sg-theme-input-bg: #253044;
  --sg-theme-selection-text: #0d1520;

  --body-bg-color-dark: var(--sg-theme-bg);
  --body-color-dark: var(--sg-theme-text);
  --header-bg-color-dark: var(--sg-theme-header-bg);
  --card-dark-color: var(--sg-theme-surface);
  --card-dark-divider: var(--sg-theme-border-mid);
  --card-dark-hover: var(--sg-theme-accent-dim);
  --card-dark-input: var(--sg-theme-input-bg);
  --card-dark-input-color: var(--sg-theme-text);
  --link-color: var(--sg-theme-accent);
  --plyr-color-main: var(--sg-theme-accent);

  --bs-primary: var(--sg-theme-accent);
  --bs-primary-rgb: var(--sg-theme-accent-rgb);
  --bs-link-color: var(--sg-theme-accent);
  --bs-link-hover-color: var(--sg-theme-accent-hover);
  --bs-body-bg: var(--sg-theme-bg);
  --bs-body-color: var(--sg-theme-text);
  --bs-border-color: var(--sg-theme-border-mid);
}

body,
body.night-mode {
  background-color: var(--sg-theme-bg);
  color: var(--sg-theme-text);
}

::selection {
  background: var(--sg-theme-accent);
  color: var(--sg-theme-selection-text);
}

a,
.nav-link,
.text-link,
.post-stats-alt,
.post-stats .fal,
.navbar-container .data-content .name a {
  color: var(--sg-theme-accent);
}

a:hover,
.nav-link:hover {
  color: var(--sg-theme-accent-hover);
}

.header-icon,
.header-icon *,
.action-icon,
.action-icon *,
body.night-mode .header-icon,
body.night-mode .header-icon *,
body.night-mode .action-icon,
body.night-mode .action-icon * {
  color: var(--sg-theme-text-sub) !important;
  fill: var(--sg-theme-text-sub) !important;
}

.header-icon.active,
.header-icon.active *,
.action-icon.active,
.action-icon.active *,
body.night-mode .header-icon.active,
body.night-mode .header-icon.active *,
body.night-mode .action-icon.active,
body.night-mode .action-icon.active * {
  color: var(--sg-theme-accent) !important;
  fill: var(--sg-theme-accent) !important;
}

.main-icon,
.main-icon *,
.x-form-tools,
body.night-mode .main-icon,
body.night-mode .main-icon *,
body.night-mode .x-form-tools {
  color: var(--sg-theme-accent) !important;
  fill: var(--sg-theme-accent) !important;
}

.text-muted,
body.night-mode .text-muted,
.form-text,
.post-time,
.post-time a,
.sg-nav-header__item + .sg-nav-header__item::before {
  color: var(--sg-theme-text-muted) !important;
}

.sg-nav-header__item + .sg-nav-header__item::before {
  background: var(--sg-theme-border-mid);
}

pre,
body.night-mode pre,
.card,
.post,
.publisher,
.dropdown-menu,
body.night-mode .dropdown-menu,
.modal-content,
body.night-mode .modal-content,
.list-group-item,
body.night-mode .list-group-item,
.ui-box,
.offcanvas,
.sg-nav-header__menu,
body.night-mode .sg-nav-header__menu,
.post-paid-description,
body.night-mode .post-paid-description,
.post-footer,
body.night-mode .post-footer,
.post-approval,
body.night-mode .post-approval,
.nav-pills.nav-search .nav-link:not(.active),
.nav-pills.nav-started .nav-link:not(.active),
body.night-mode .nav-pills.nav-search .nav-link:not(.active),
body.night-mode .nav-pills.nav-started .nav-link:not(.active) {
  background: var(--sg-theme-surface);
  color: var(--sg-theme-text);
  border-color: var(--sg-theme-border-mid);
  box-shadow: var(--sg-theme-shadow-sm);
}

.dropdown-menu,
.modal-content,
.offcanvas,
.sg-nav-header__menu,
.card,
.post,
.publisher,
.ui-box,
.list-group-item {
  border: 1px solid var(--sg-theme-border);
}

.list-group-item,
body.night-mode .list-group-item,
.nav-pills.nav-search .nav-link:not(.active),
.nav-pills.nav-started .nav-link:not(.active),
body.night-mode .nav-pills.nav-search .nav-link:not(.active),
body.night-mode .nav-pills.nav-started .nav-link:not(.active) {
  box-shadow: none;
}

.divider,
.card-body .divider,
.modal-body .divider,
body.night-mode .divider,
body.night-mode .card-body .divider,
body.night-mode .modal-body .divider,
.comments-filter,
body.night-mode .comments-filter,
.post-actions,
body.night-mode .post-actions,
.post-tips,
body.night-mode .post-tips,
.post-social-share,
body.night-mode .post-social-share,
.post-memory-header,
body.night-mode .post-memory-header,
.dropdown-widget-header,
.dropdown-widget-footer {
  border-color: var(--sg-theme-border-mid);
}

.dropdown-widget-header,
.dropdown-widget-footer,
.main-header .search-wrapper .form-control,
.main-header .search-wrapper .search-module-select,
.search-wrapper.sg-mobile-search-sheet .form-control,
.search-wrapper.sg-mobile-search-sheet .search-module-select,
.form-control,
.form-select,
.input-group-text,
body.night-mode .main-header .search-wrapper .form-control,
body.night-mode .main-header .search-wrapper .search-module-select,
body.night-mode .search-wrapper.sg-mobile-search-sheet .form-control,
body.night-mode .search-wrapper.sg-mobile-search-sheet .search-module-select,
body.night-mode .form-control,
body.night-mode .form-select,
body.night-mode .input-group-text,
.post-snippet,
body.night-mode .post-snippet {
  background-color: var(--sg-theme-input-bg);
  color: var(--sg-theme-text);
  border-color: var(--sg-theme-border-mid);
}

.form-label,
body.night-mode .form-label,
.dropdown-item,
body.night-mode .dropdown-item,
.sg-nav-sidebar a,
.sg-nav-sidebar .static,
body.night-mode .sg-nav-sidebar a,
body.night-mode .sg-nav-sidebar .static,
.post-actions .action-btn,
body.night-mode .post-actions .action-btn,
.post-meta .dropdown .dropdown-toggle,
body.night-mode .post-meta .dropdown .dropdown-toggle {
  color: var(--sg-theme-text-sub);
}

.main-header {
  background: var(--sg-theme-header-bg);
  border-bottom: 1px solid var(--sg-theme-border);
  box-shadow: var(--sg-theme-shadow-sm);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

body.night-mode .main-header {
  background: var(--sg-theme-header-bg);
  border-bottom-color: var(--sg-theme-border-mid);
  box-shadow: var(--sg-theme-shadow-md);
}

.main-header .search-wrapper .form-control,
.main-header .search-wrapper .search-module-select,
.search-wrapper.sg-mobile-search-sheet .form-control,
.search-wrapper.sg-mobile-search-sheet .search-module-select {
  border-width: 1px;
  border-style: solid;
  border-radius: 10px;
  box-shadow: none;
}

.main-header .search-wrapper .form-control::placeholder,
.main-header .search-wrapper .form-control::-webkit-input-placeholder,
.main-header .search-wrapper .form-control:-moz-placeholder,
.search-wrapper.sg-mobile-search-sheet .form-control::placeholder,
.search-wrapper.sg-mobile-search-sheet .form-control::-webkit-input-placeholder,
.search-wrapper.sg-mobile-search-sheet .form-control:-moz-placeholder,
body.night-mode .main-header .search-wrapper .form-control::placeholder,
body.night-mode
  .main-header
  .search-wrapper
  .form-control::-webkit-input-placeholder,
body.night-mode .main-header .search-wrapper .form-control:-moz-placeholder,
body.night-mode
  .search-wrapper.sg-mobile-search-sheet
  .form-control::placeholder,
body.night-mode
  .search-wrapper.sg-mobile-search-sheet
  .form-control::-webkit-input-placeholder,
body.night-mode
  .search-wrapper.sg-mobile-search-sheet
  .form-control:-moz-placeholder,
.form-control::placeholder,
.form-select::placeholder,
.input-group-text::placeholder,
body.night-mode .form-control::placeholder,
body.night-mode .form-select::placeholder,
body.night-mode .input-group-text::placeholder {
  color: var(--sg-theme-text-muted);
  opacity: 1;
}

.form-control:focus,
.form-select:focus,
.main-header .search-wrapper .form-control:focus,
.main-header .search-wrapper .search-module-select:focus,
.search-wrapper.sg-mobile-search-sheet .form-control:focus,
.search-wrapper.sg-mobile-search-sheet .search-module-select:focus {
  border-color: rgba(var(--sg-theme-accent-rgb), 0.36);
  box-shadow: 0 0 0 3px var(--sg-theme-accent-dim);
}

.navbar-wrapper > ul > li > a:hover,
body.night-mode .navbar-wrapper > ul > li > a:hover,
.navbar-wrapper > ul > li.dropdown.show > a,
body.night-mode .navbar-wrapper > ul > li.dropdown.show > a,
.dropdown-item:focus,
.dropdown-item:hover,
body.night-mode .dropdown-item:focus,
body.night-mode .dropdown-item:hover,
.post-meta .dropdown .dropdown-toggle.show,
.post-meta .dropdown .dropdown-toggle:hover,
body.night-mode .post-meta .dropdown .dropdown-toggle.show,
body.night-mode .post-meta .dropdown .dropdown-toggle:hover,
.post-actions .action-btn:hover,
body.night-mode .post-actions .action-btn:hover,
.nav-pills.nav-search .nav-link:not(.active):hover,
.nav-pills.nav-started .nav-link:not(.active):hover,
body.night-mode .nav-pills.nav-search .nav-link:not(.active):hover,
body.night-mode .nav-pills.nav-started .nav-link:not(.active):hover,
.sg-nav-sidebar a:hover,
.sg-nav-sidebar > li.active > a,
.sg-nav-sidebar ul > li.active > a,
body.night-mode .sg-nav-sidebar a:hover,
body.night-mode .sg-nav-sidebar > li.active > a,
body.night-mode .sg-nav-sidebar ul > li.active > a {
  background: var(--sg-theme-accent-dim);
  color: var(--sg-theme-accent);
}

.nav-tabs,
body.night-mode .nav-tabs {
  border-bottom-color: var(--sg-theme-border-mid);
}

.nav-tabs .nav-item.show .nav-link,
.nav-tabs .nav-link.active,
body.night-mode .nav-tabs .nav-item.show .nav-link,
body.night-mode .nav-tabs .nav-link.active {
  color: var(--sg-theme-accent);
  background-color: var(--sg-theme-accent-dim);
  border-color: var(--sg-theme-border-mid);
}

.dropdown-item.active,
.dropdown-item:active {
  background-color: var(--sg-theme-accent);
  color: var(--sg-theme-accent-text);
}

.btn-primary,
.btn-primary.disabled,
.btn-primary:disabled,
.btn-primary:not(:disabled):not(.disabled).active,
.btn-primary:not(:disabled):not(.disabled):active,
.show > .btn-primary.dropdown-toggle {
  color: var(--sg-theme-accent-text);
  border-color: var(--sg-theme-accent);
  background-color: var(--sg-theme-accent);
}

.btn-primary:hover {
  color: var(--sg-theme-accent-text);
  border-color: var(--sg-theme-accent-hover);
  background-color: var(--sg-theme-accent-hover);
}

.btn-primary.focus,
.btn-primary:focus {
  box-shadow:
    0 0 0 3px var(--sg-theme-accent-dim),
    var(--sg-theme-shadow-sm);
}

.btn-secondary,
.btn-secondary.disabled,
.btn-secondary:disabled,
.btn-secondary:not(:disabled):not(.disabled).active,
.btn-secondary:not(:disabled):not(.disabled):active,
.show > .btn-secondary.dropdown-toggle,
body.night-mode .btn-secondary {
  color: var(--sg-theme-text-sub);
  border-color: var(--sg-theme-border-mid);
  background-color: var(--sg-theme-surface-2);
}

.btn-secondary:hover {
  color: var(--sg-theme-accent);
  border-color: rgba(var(--sg-theme-accent-rgb), 0.3);
  background-color: var(--sg-theme-accent-dim);
}

.btn-outline-primary,
.btn-outline-primary.disabled,
.btn-outline-primary:disabled {
  color: var(--sg-theme-accent);
  border-color: rgba(var(--sg-theme-accent-rgb), 0.32);
}

.btn-outline-primary:hover,
.btn-outline-primary:not(:disabled):not(.disabled).active,
.btn-outline-primary:not(:disabled):not(.disabled):active {
  color: var(--sg-theme-accent-text);
  border-color: var(--sg-theme-accent);
  background-color: var(--sg-theme-accent);
}

.alert-primary {
  color: var(--sg-theme-accent-text);
  border-color: var(--sg-theme-accent);
  background: linear-gradient(
    135deg,
    var(--sg-theme-accent),
    var(--sg-theme-accent-hover)
  );
}

.alert-secondary {
  color: var(--sg-theme-text-sub);
  border-color: var(--sg-theme-border-mid);
  background-color: var(--sg-theme-surface-2);
}

.sg-nav-header-wrap,
body.night-mode .sg-nav-header-wrap {
  background: var(--sg-theme-glass);
  border-top-color: var(--sg-theme-border);
  border-bottom-color: var(--sg-theme-border);
  backdrop-filter: saturate(180%) blur(14px);
  -webkit-backdrop-filter: saturate(180%) blur(14px);
}

.sg-nav-header__item + .sg-nav-header__item::before {
  background: var(--sg-theme-border-mid);
}

.sg-nav-header__menu,
body.night-mode .sg-nav-header__menu {
  background: var(--sg-theme-surface-2);
  color: var(--sg-theme-text);
  border-color: var(--sg-theme-border-mid);
  border-radius: 8px;
  box-shadow: var(--sg-theme-shadow-md);
}

.post .pin-icon,
.post .pending-icon {
  color: var(--sg-theme-accent);
}

.post.boosted,
body.night-mode .post.boosted,
.post.highlighted {
  border-color: var(--sg-theme-accent);
  box-shadow: inset 0 0 0 1px rgba(var(--sg-theme-accent-rgb), 0.3);
}

.post .boosted-icon {
  background: var(--sg-theme-accent);
  color: var(--sg-theme-accent-text);
}

#cookie-banner .banner-btns .btn-settings,
#cookie-banner .banner-btns .btn-reject {
  background: var(--sg-theme-surface-2) !important;
  border-color: var(--sg-theme-border-hi) !important;
  color: var(--sg-theme-text-sub) !important;
}

#cookie-banner .banner-btns .btn-settings:hover,
#cookie-banner .banner-btns .btn-settings:focus,
#cookie-banner .banner-btns .btn-reject:hover,
#cookie-banner .banner-btns .btn-reject:focus {
  background: var(--sg-theme-accent-dim) !important;
  border-color: rgba(var(--sg-theme-accent-rgb), 0.3) !important;
  color: var(--sg-theme-accent) !important;
}

#cookie-banner .banner-btns .btn-accept {
  background: var(--sg-theme-accent) !important;
  border-color: var(--sg-theme-accent) !important;
  color: var(--sg-theme-accent-text) !important;
}

#cookie-banner .banner-btns .btn-accept:hover,
#cookie-banner .banner-btns .btn-accept:focus {
  background: var(--sg-theme-accent-hover) !important;
  border-color: var(--sg-theme-accent-hover) !important;
  color: var(--sg-theme-accent-text) !important;
}

/* nb##: Topic Hub 页面恢复 LIGHT 模式默认变量，夜间模式由 body[data-bs-theme="dark"] 单独覆盖 */
.sg-topic-hub {
  --sg-topic-accent: #c9a252;
  --sg-topic-paper: #f4ecdf;
  --sg-topic-paper-2: #fffdf8;
  --sg-topic-paper-3: #f2eadb;
  --sg-topic-paper-4: #e7dbc5;
  --sg-topic-ink: #1f2530;
  --sg-topic-muted: rgba(51, 60, 72, 0.82);
  --sg-topic-muted-2: rgba(73, 83, 96, 0.68);
  --sg-topic-faint: rgba(92, 103, 117, 0.48);
  --sg-topic-border: rgba(38, 45, 58, 0.1);
  --sg-topic-border-strong: rgba(38, 45, 58, 0.16);
  --sg-topic-shadow-sm: 0 14px 28px rgba(21, 28, 38, 0.08);
  --bs-body-bg: #f4ecdf;
  --bs-body-bg-rgb: 244, 236, 223;
  --bs-secondary-bg: #fffdf8;
  --bs-secondary-bg-rgb: 255, 253, 248;
  --bs-tertiary-bg: #f2eadb;
  --bs-tertiary-bg-rgb: 242, 234, 219;
  --bs-border-color: rgba(38, 45, 58, 0.1);
  --bs-border-color-translucent: rgba(38, 45, 58, 0.1);
  --bs-card-bg: #fffdf8;
  --bs-card-cap-bg: #fffdf8;
  --bs-body-color: #1f2530;
  --bs-body-color-rgb: 31, 37, 48;
  --bs-emphasis-color: #1f2530;
  --bs-emphasis-color-rgb: 31, 37, 48;
  --bs-secondary-color: rgba(51, 60, 72, 0.82);
  --bs-secondary-color-rgb: 51, 60, 72;
  --bs-tertiary-color: rgba(73, 83, 96, 0.68);
  --bs-tertiary-color-rgb: 73, 83, 96;
  background: transparent;
  color: var(--sg-topic-ink);
  overflow-x: clip;
}

body[data-bs-theme="dark"] .sg-topic-hub,
.sg-topic-hub[data-bs-theme="dark"] {
  --sg-topic-paper: #16181d;
  --sg-topic-paper-2: #131820;
  --sg-topic-paper-3: #1b212b;
  --sg-topic-paper-4: #212836;
  --sg-topic-ink: rgba(240, 244, 255, 0.92);
  --sg-topic-muted: rgba(209, 217, 231, 0.8);
  --sg-topic-muted-2: rgba(188, 197, 213, 0.64);
  --sg-topic-faint: rgba(174, 184, 201, 0.48);
  --sg-topic-border: rgba(255, 255, 255, 0.08);
  --sg-topic-border-strong: rgba(255, 255, 255, 0.14);
  --sg-topic-shadow-sm: 0 16px 32px rgba(0, 0, 0, 0.2);
  --bs-body-bg: #16181d;
  --bs-body-bg-rgb: 22, 24, 29;
  --bs-secondary-bg: #131820;
  --bs-secondary-bg-rgb: 19, 24, 32;
  --bs-tertiary-bg: #1b212b;
  --bs-tertiary-bg-rgb: 27, 33, 43;
  --bs-border-color: rgba(255, 255, 255, 0.08);
  --bs-border-color-translucent: rgba(255, 255, 255, 0.08);
  --bs-card-bg: #131820;
  --bs-card-cap-bg: #131820;
  --bs-body-color: #ddd8cf;
  --bs-body-color-rgb: 221, 216, 207;
  --bs-emphasis-color: rgba(240, 244, 255, 0.92);
  --bs-emphasis-color-rgb: 240, 244, 255;
  --bs-secondary-color: rgba(209, 217, 231, 0.8);
  --bs-secondary-color-rgb: 209, 217, 231;
  --bs-tertiary-color: rgba(188, 197, 213, 0.64);
  --bs-tertiary-color-rgb: 188, 197, 213;
  color-scheme: dark;
}

.sg-topic-hub .serif {
  font-family: Georgia, "Times New Roman", serif;
}

.sg-topic-hub .text-aa {
  color: var(--sg-topic-accent) !important;
}

.sg-topic-hub .btn-aa {
  background: var(--sg-topic-accent) !important;
  border-color: var(--sg-topic-accent) !important;
  color: #111318 !important;
}

.sg-topic-hub .btn-aa:hover,
.sg-topic-hub .btn-aa:focus {
  filter: brightness(0.96);
}

/* nb##: TOPIC hero 改为复用 PUBLIC GROUP/PAGE 的 profile-header 骨架，只保留 topic 专属内容层样式 */
.sg-topic-profile-header .profile-avatar-wrapper,
.sg-topic-profile-header .profile-name-wrapper,
.sg-topic-profile-header .profile-buttons-wrapper {
  z-index: 2;
}

.sg-topic-profile-header .profile-avatar-wrapper .sg-topic-hero__thumb {
  display: block;
  width: 90px;
  height: 90px;
  border: 0;
  box-shadow: none;
}

@media (min-width: 576px) {
  .sg-topic-profile-header .profile-avatar-wrapper .sg-topic-hero__thumb {
    width: 120px;
    height: 120px;
  }
}

@media (min-width: 768px) {
  .sg-topic-profile-header .profile-avatar-wrapper .sg-topic-hero__thumb {
    width: 150px;
    height: 150px;
  }
}

@media (min-width: 992px) {
  .sg-topic-profile-header .profile-avatar-wrapper .sg-topic-hero__thumb {
    width: 160px;
    height: 160px;
  }
}

.sg-topic-profile-header__breadcrumb {
  margin-bottom: 0.85rem;
}

.sg-topic-profile-header__breadcrumb .sg-site-breadcrumb {
  --sg-breadcrumb-link: #6b7484;
  --sg-breadcrumb-active: #6b7484;
  --sg-breadcrumb-divider-color: rgba(107, 116, 132, 0.72);
  --bs-breadcrumb-font-size: 0.76rem;
  --bs-breadcrumb-item-padding-x: 0.2rem;
  justify-content: center;
  margin-top: 0;
}

.sg-topic-profile-header__headline {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 0.85rem;
}

.sg-topic-profile-header__headline a {
  display: inline-flex;
  align-items: center;
  color: inherit;
  text-decoration: none;
}

.sg-topic-profile-header__description,
.sg-topic-profile-header__stats,
.sg-topic-profile-header__alert,
.sg-topic-profile-header__breadcrumb,
.sg-topic-profile-header .sg-topic-hero__stat-card,
.sg-topic-profile-header .sg-topic-hero__stat-value,
.sg-topic-profile-header .sg-topic-hero__stat-label {
  text-shadow: none;
}

.sg-topic-profile-header__description {
  max-width: 46rem;
  margin-left: auto;
  margin-right: auto;
  color: #5f6877;
}

.sg-topic-profile-header__meta-row {
  margin-top: 1rem;
}

.sg-topic-profile-header__stats {
  justify-content: center;
}

.sg-topic-profile-header__alert {
  max-width: 46rem;
  margin-left: auto;
  margin-right: auto;
  font-size: 0.875rem;
  text-align: left;
}

.sg-topic-profile-header__actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 0.65rem;
}

.sg-topic-profile-header--no-cover .profile-cover-wrapper {
  background: linear-gradient(135deg, #fbf6ec 0%, #eadfc8 100%);
}

.sg-topic-profile-header--no-cover .profile-name-wrapper {
  text-shadow: none;
}

.sg-topic-profile-header--no-cover .sg-topic-profile-header__headline a,
.sg-topic-profile-header--no-cover .sg-topic-profile-header__description {
  color: var(--sg-topic-ink);
}

.sg-topic-profile-header--no-cover .sg-topic-profile-header__breadcrumb .sg-site-breadcrumb {
  --sg-breadcrumb-link: var(--sg-topic-ink);
  --sg-breadcrumb-active: var(--sg-topic-ink);
  --sg-breadcrumb-divider-color: color-mix(in srgb, var(--sg-topic-ink) 55%, transparent);
}

body.night-mode .sg-topic-profile-header--no-cover .profile-cover-wrapper,
body[data-bs-theme="dark"] .sg-topic-hub .sg-topic-profile-header--no-cover .profile-cover-wrapper,
.sg-topic-hub[data-bs-theme="dark"] .sg-topic-profile-header--no-cover .profile-cover-wrapper {
  background: linear-gradient(
    135deg,
    rgba(201, 162, 82, 0.24) 0%,
    rgba(18, 20, 26, 0.96) 100%
  );
}

body.night-mode .sg-topic-profile-header--no-cover .sg-topic-profile-header__headline a,
body.night-mode .sg-topic-profile-header--no-cover .sg-topic-profile-header__description,
body[data-bs-theme="dark"] .sg-topic-hub .sg-topic-profile-header--no-cover .sg-topic-profile-header__headline a,
body[data-bs-theme="dark"] .sg-topic-hub .sg-topic-profile-header--no-cover .sg-topic-profile-header__description,
.sg-topic-hub[data-bs-theme="dark"] .sg-topic-profile-header--no-cover .sg-topic-profile-header__headline a,
.sg-topic-hub[data-bs-theme="dark"] .sg-topic-profile-header--no-cover .sg-topic-profile-header__description {
  color: #ffffff !important;
}

body.night-mode .sg-topic-profile-header--no-cover .sg-topic-profile-header__breadcrumb .sg-site-breadcrumb,
body[data-bs-theme="dark"] .sg-topic-hub .sg-topic-profile-header--no-cover .sg-topic-profile-header__breadcrumb .sg-site-breadcrumb,
.sg-topic-hub[data-bs-theme="dark"] .sg-topic-profile-header--no-cover .sg-topic-profile-header__breadcrumb .sg-site-breadcrumb {
  --sg-breadcrumb-link: #ffffff;
  --sg-breadcrumb-active: #ffffff;
  --sg-breadcrumb-divider-color: rgba(255, 255, 255, 0.76);
}

body.night-mode .sg-topic-profile-header__breadcrumb .sg-site-breadcrumb,
body[data-bs-theme="dark"] .sg-topic-hub .sg-topic-profile-header__breadcrumb .sg-site-breadcrumb,
.sg-topic-hub[data-bs-theme="dark"] .sg-topic-profile-header__breadcrumb .sg-site-breadcrumb {
  --sg-breadcrumb-link: rgba(255, 255, 255, 0.76);
  --sg-breadcrumb-active: rgba(255, 255, 255, 0.76);
  --sg-breadcrumb-divider-color: rgba(255, 255, 255, 0.52);
}

body.night-mode .sg-topic-profile-header__description,
body[data-bs-theme="dark"] .sg-topic-hub .sg-topic-profile-header__description,
.sg-topic-hub[data-bs-theme="dark"] .sg-topic-profile-header__description {
  color: rgba(255, 255, 255, 0.78);
}

@media (min-width: 992px) {
  .sg-topic-profile-header .profile-name-wrapper {
    right: 17rem;
    max-width: calc(100% - 272px - 17rem);
  }

  .sg-topic-profile-header__breadcrumb .sg-site-breadcrumb {
    justify-content: flex-start;
  }

  .sg-topic-profile-header__breadcrumb .sg-site-breadcrumb,
  .sg-topic-profile-header__description {
    --sg-breadcrumb-link: rgba(255, 255, 255, 0.9);
    --sg-breadcrumb-active: rgba(255, 255, 255, 0.9);
    --sg-breadcrumb-divider-color: rgba(255, 255, 255, 0.52);
    color: rgba(255, 255, 255, 0.9);
  }

  .sg-topic-profile-header__headline {
    justify-content: flex-start;
  }

  .sg-topic-profile-header__description,
  .sg-topic-profile-header__alert {
    margin-left: 0;
    margin-right: 0;
  }

  .sg-topic-profile-header__stats {
    justify-content: flex-start;
  }

  .sg-topic-profile-header__actions {
    flex-wrap: nowrap;
    justify-content: flex-end;
    max-width: none;
    white-space: nowrap;
  }

  .sg-topic-profile-header__actions .btn {
    flex-shrink: 0;
  }

  .sg-topic-profile-header--no-cover .sg-topic-profile-header__headline a,
  .sg-topic-profile-header--no-cover .sg-topic-profile-header__description {
    color: var(--sg-topic-ink);
  }

  .sg-topic-profile-header--no-cover .sg-topic-profile-header__breadcrumb .sg-site-breadcrumb {
    --sg-breadcrumb-link: var(--sg-topic-ink);
    --sg-breadcrumb-active: var(--sg-topic-ink);
    --sg-breadcrumb-divider-color: color-mix(in srgb, var(--sg-topic-ink) 55%, transparent);
  }
}

.sg-topic-hero {
  position: relative;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
  min-height: 180px;
  width: 100%;
  background: var(--sg-topic-paper);
  border-radius: 0 0 16px 16px;
  margin-bottom: 20px;
}

@media (min-width: 576px) {
  .sg-topic-hero {
    min-height: 240px;
  }
}

@media (min-width: 768px) {
  .sg-topic-hero {
    min-height: 300px;
  }
}

@media (min-width: 992px) {
  .sg-topic-hero {
    min-height: 360px;
    margin-bottom: 40px;
  }
}

.sg-topic-hero--no-cover {
  background: linear-gradient(135deg, #fbf6ec 0%, #eadfc8 100%);
}

.sg-topic-hero__img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  filter: brightness(0.6) saturate(0.75);
  transform: scale(1.02);
  transition: transform 7s ease;
  will-change: transform;
}

.sg-topic-hero:hover .sg-topic-hero__img {
  transform: scale(1.06);
}

.sg-topic-hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgba(16, 18, 22, 0.97) 0%,
    rgba(16, 18, 22, 0.74) 34%,
    rgba(16, 18, 22, 0.28) 70%,
    rgba(16, 18, 22, 0.04) 100%
  );
}

body.night-mode .sg-topic-hero__overlay,
body[data-bs-theme="dark"] .sg-topic-hub .sg-topic-hero__overlay,
.sg-topic-hub[data-bs-theme="dark"] .sg-topic-hero__overlay {
  background: linear-gradient(
    to top,
    rgba(10, 12, 16, 0.98) 0%,
    rgba(10, 12, 16, 0.78) 36%,
    rgba(10, 12, 16, 0.32) 72%,
    rgba(10, 12, 16, 0.06) 100%
  );
}

.sg-topic-hero__grain {
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.045'/%3E%3C/svg%3E");
  opacity: 0.36;
  pointer-events: none;
}

.sg-topic-hero--no-cover .sg-topic-hero__overlay {
  background: linear-gradient(
    135deg,
    rgba(201, 162, 82, 0.18) 0%,
    rgba(255, 253, 248, 0.9) 100%
  );
}

.sg-topic-hero__content {
  position: relative;
  z-index: 2;
  width: 100%;
}

.sg-topic-accent-bar {
  flex-shrink: 0;
  background: var(--sg-topic-accent);
}

.sg-topic-accent-bar {
  width: 4px;
  height: 18px;
}

.sg-topic-card__eyebrow,
.sg-topic-card__label,
.sg-topic-hero__stat-label {
  font-family: system-ui, sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.16em;
}

.sg-topic-hero__thumb {
  width: 76px;
  height: 76px;
  border-radius: 50%;
  object-fit: cover;
  border: 2px solid rgba(255, 255, 255, 0.2);
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.24);
}

.sg-topic-hero__title {
  font-size: clamp(2.4rem, 6vw, 4rem);
}

.sg-topic-hero__headline {
  min-width: 0;
}

.sg-topic-hero__description {
  font-family: system-ui, sans-serif;
  font-size: 0.875rem;
  line-height: 1.7;
  max-width: 46rem;
}

.sg-topic-hero__meta-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem 1.25rem;
  flex-wrap: wrap;
}

.sg-topic-hero__stats {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
  min-width: 0;
}

.sg-topic-hero__stat-card {
  min-width: 118px;
  padding: 0.7rem 0.95rem;
  border: 1px solid var(--sg-topic-border-strong);
  background: rgba(255, 253, 248, 0.84);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.72),
    0 10px 22px rgba(21, 28, 38, 0.08);
  backdrop-filter: blur(10px);
}

.sg-topic-hero__stat-value {
  display: block;
  color: var(--sg-topic-ink);
  font-size: 2rem;
  font-weight: 700;
  line-height: 1;
}

.sg-topic-hero__stat-label {
  display: block;
  margin-top: 0.35rem;
  color: var(--sg-topic-muted-2);
  font-size: 0.68rem;
  font-weight: 700;
}

.sg-topic-hero--no-cover .sg-topic-hero__title,
.sg-topic-hero--no-cover .sg-topic-hero__description {
  color: var(--sg-topic-ink) !important;
}

.sg-topic-hero--no-cover .sg-topic-hero__thumb {
  border-color: rgba(31, 37, 48, 0.16);
  box-shadow: 0 10px 24px rgba(21, 28, 38, 0.12);
}

.sg-topic-hero__actions {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: flex-end;
  gap: 0.65rem;
  margin-left: auto;
  padding-top: 0.25rem;
}

.sg-topic-card__label,
.sg-topic-card__eyebrow {
  color: var(--sg-topic-accent);
  font-size: 0.6rem;
  font-weight: 700;
}

.sg-topic-card__meta {
  font-family: system-ui, sans-serif;
  font-size: 0.65rem;
}

.sg-topic-card__dot {
  font-size: 0.7rem;
}

.sg-nav-header-wrap .sg-nav-header {
  background: var(--sg-topic-paper-2);
  border-bottom-color: var(--sg-topic-border-strong);
}

.sg-nav-header-wrap {
  background: var(--sg-topic-paper-2);
  border-top: 1px solid var(--sg-topic-border-strong);
  border-bottom: 1px solid var(--sg-topic-border-strong);
}

.sg-nav-header-wrap .sg-nav-header__link,
.sg-nav-header-wrap .sg-nav-header__link.dropdown-toggle {
  color: var(--sg-topic-muted);
}

.sg-nav-header-wrap .sg-nav-header__link:hover,
.sg-nav-header-wrap .sg-nav-header__link:focus,
.sg-nav-header-wrap .sg-nav-header__link.active,
.sg-nav-header-wrap .sg-nav-header__link.is-active-root {
  color: var(--sg-topic-accent);
}

.sg-nav-header__badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.5rem;
  padding: 0.1rem 0.4rem;
  margin-left: 0.45rem;
  border-radius: 999px;
  background: rgba(201, 162, 82, 0.15);
  color: var(--sg-topic-accent);
  font-size: 0.68rem;
  font-weight: 700;
}

.sg-nav-header__link.active .sg-nav-header__badge {
  background: var(--sg-topic-accent);
  color: #111318;
}

.sg-topic-main {
  background: transparent;
  padding: 2.5rem 0 3rem;
}

.sg-topic-section + .sg-topic-section {
  margin-top: 2rem;
}

.sg-topic-section__head {
  display: flex;
  align-items: center;
  gap: 0.9rem;
  margin-bottom: 1rem;
}

.sg-topic-section__title {
  margin: 0;
  color: var(--sg-topic-ink);
  font-family: system-ui, sans-serif;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.sg-topic-story-card,
.sg-topic-blog-card,
.sg-topic-empty-card,
.sg-topic-hub .card.rounded-0 {
  border-color: var(--sg-topic-border-strong) !important;
  background: var(--sg-topic-paper-2);
  border-radius: 12px !important;
  box-shadow: var(--sg-topic-shadow-sm);
}

.sg-topic-story-card,
.sg-topic-blog-card {
  transition:
    transform 0.18s ease,
    box-shadow 0.18s ease;
}

.sg-topic-story-card:hover,
.sg-topic-story-card:focus,
.sg-topic-blog-card:hover,
.sg-topic-blog-card:focus {
  transform: translateY(-2px);
  box-shadow: 0 18px 36px rgba(0, 0, 0, 0.24);
}

.sg-topic-story-card__media {
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: var(--sg-topic-paper-3);
}

.sg-topic-story-card__media img,
.sg-topic-blog-card__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.sg-topic-story-card__placeholder,
.sg-topic-blog-card__thumb-placeholder,
.sg-topic-empty-card__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(201, 162, 82, 0.72);
  background: var(--sg-topic-paper-4);
}

.sg-topic-story-card__placeholder,
.sg-topic-blog-card__thumb-placeholder {
  height: 100%;
  min-height: 140px;
  font-size: 1.4rem;
}

.sg-topic-story-card__title,
.sg-topic-blog-card__title {
  color: var(--sg-topic-ink);
  font-size: 0.95rem;
}

.sg-topic-blog-card__thumb {
  width: 148px;
  min-height: 126px;
  overflow: hidden;
  background: var(--sg-topic-paper-4);
}

.sg-topic-blog-card__excerpt {
  font-family: system-ui, sans-serif;
  line-height: 1.65;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.sg-topic-blog-card__footer {
  font-family: system-ui, sans-serif;
  font-size: 0.65rem;
}

/* nb##: TOPIC Blogs 改复用 BLOG 目录页标准卡片，并固定为两栏网格 */
.sg-topic-blog-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
  padding: 0;
  margin: 0;
}

.sg-topic-post-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
  padding: 0;
  margin: 0;
}

.sg-topic-post-grid > li,
.sg-topic-blog-grid > .sg-blog-feed__item,
.sg-topic-forum-list__item {
  min-width: 0;
  list-style: none;
}

.sg-topic-hub .sg-topic-post-grid > li > .post {
  height: 100%;
}

.sg-topic-hub .post-card--standard {
  display: flex;
  flex-direction: column;
  min-height: 100%;
  border: 1px solid var(--sg-topic-border-strong);
  border-radius: 12px;
  overflow: hidden;
  background: var(--sg-topic-paper-2);
  box-shadow: var(--sg-topic-shadow-sm);
  text-decoration: none;
  transition:
    transform 0.18s ease,
    box-shadow 0.18s ease;
}

.sg-topic-hub .post-card--standard:hover,
.sg-topic-hub .post-card--standard:focus {
  transform: translateY(-2px);
  box-shadow: 0 18px 36px rgba(0, 0, 0, 0.24);
}

.sg-topic-hub .post-card--standard__img-wrap {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: var(--sg-topic-paper-4);
}

.sg-topic-hub .post-card--standard__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.55s ease;
}

.sg-topic-hub .post-card--standard:hover .post-card--standard__img {
  transform: scale(1.05);
}

.sg-topic-hub .post-card--standard__no-cover {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  color: var(--sg-topic-muted-2);
  background:
    radial-gradient(
      circle at top right,
      rgba(201, 162, 82, 0.18),
      transparent 40%
    ),
    var(--sg-topic-paper-3);
}

.sg-topic-hub .post-card--standard__no-cover i {
  font-size: 1.35rem;
}

.sg-topic-hub .post-card--standard__badge {
  position: absolute;
  inset-inline-start: 1rem;
  top: 1rem;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.34rem 0.72rem;
  border-radius: 2px;
  background: rgba(10, 14, 24, 0.78);
  color: #ffffff;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.sg-topic-hub .post-card--standard__body {
  display: flex;
  flex-direction: column;
  flex: 1;
  padding: 1.1rem 1.15rem 1.05rem;
}

.sg-topic-hub .post-card--standard__title {
  margin-bottom: 0.7rem;
  color: var(--sg-topic-ink);
  font-family: Georgia, "Times New Roman", serif;
  font-size: 0.96rem;
  line-height: 1.3;
  letter-spacing: -0.02em;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
}

.sg-topic-hub .post-card--standard__excerpt,
.sg-topic-hub .sg-blog-card__locked,
.sg-topic-hub .post-card__author-name,
.sg-topic-hub .post-card__date,
.sg-topic-hub .post-card__stat {
  color: var(--sg-topic-muted);
}

.sg-topic-hub .post-card--standard__excerpt {
  margin-bottom: 0.9rem;
  font-size: 0.775rem;
  line-height: 1.65;
}

.sg-topic-hub .sg-blog-card__locked {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  font-size: 0.8rem;
  font-weight: 700;
}

.sg-topic-hub .post-card--standard__meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.6rem;
  flex-wrap: wrap;
  margin-top: auto;
  padding-top: 0.9rem;
  border-top: 1px solid var(--sg-topic-border);
}

.sg-topic-hub .post-card__author,
.sg-topic-hub .post-card__stats {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
}

.sg-topic-hub .post-card__author-img {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  object-fit: cover;
}

.sg-topic-hub .post-card__author-name,
.sg-topic-hub .post-card__stat {
  font-size: 0.78rem;
}

.sg-topic-hub .post-card__stat {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
}

/* nb##: TOPIC Forums 改复用 FORUM 目录页线程卡片层，分页仍追加到同一列表 */
.sg-topic-forum-list {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding: 0;
  margin: 0;
}

.sg-topic-hub .forum-thread-list-card {
  border-color: var(--sg-topic-border-strong);
  border-style: solid;
  border-width: 1px;
  border-radius: 14px;
  overflow: hidden;
  background: var(--sg-topic-paper-2);
  box-shadow: var(--sg-topic-shadow-sm);
}

.sg-topic-hub .forum-thread-list-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 18px 36px rgba(0, 0, 0, 0.24);
}

.sg-topic-hub
  .forum-thread-card.forum-directory-thread-card
  .forum-thread-card-body {
  padding: 1rem 1.125rem;
}

/* nb##: TOPIC Forums tab 复用论坛目录线程卡片层级，右侧单独承载 Pin/Hot 与 Latest reply */
.sg-topic-hub .forum-directory-thread-row {
  display: flex;
  align-items: stretch;
  gap: 1rem;
  min-width: 0;
}

.sg-topic-hub .forum-directory-thread-metrics-group {
  flex: 0 0 auto;
  display: flex;
  align-items: stretch;
  gap: 0.55rem;
  align-self: stretch;
}

.sg-topic-hub .forum-directory-thread-metric-card {
  flex: 0 0 86px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  align-self: stretch;
  padding: 0.8rem 0.55rem;
  border: 1px solid var(--sg-topic-border-strong);
  border-radius: 14px;
  background: var(--sg-topic-paper-3);
  color: var(--sg-topic-muted);
  text-decoration: none;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.sg-topic-hub .forum-directory-thread-metric-card:hover {
  color: var(--sg-topic-ink);
  text-decoration: none;
}

.sg-topic-hub .forum-directory-thread-metric-card.is-solved {
  border-color: #1c9d5d;
  background: linear-gradient(180deg, #28b56e 0%, #198754 100%);
  color: #f0fdf4;
  box-shadow: 0 0.85rem 1.4rem rgba(22, 163, 74, 0.16);
}

.sg-topic-hub .forum-directory-thread-metric-value {
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1;
}

.sg-topic-hub .forum-directory-thread-metric-label {
  margin-top: 0.18rem;
  font-size: 0.67rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  opacity: 0.82;
}

.sg-topic-hub .forum-directory-thread-main {
  min-width: 0;
  flex: 1 1 auto;
}

.sg-topic-hub .forum-directory-thread-title-row {
  min-width: 0;
}

.sg-topic-hub .forum-directory-thread-title-inline {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 0.4rem 0.5rem;
  min-width: 0;
}

.sg-topic-hub .forum-directory-thread-title {
  flex: 1 1 240px;
  min-width: 0;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  color: var(--sg-topic-ink);
  font-size: 1.05rem;
  font-weight: 700;
  line-height: 1.45;
  text-decoration: none;
}

.sg-topic-hub .forum-directory-thread-title:hover {
  color: var(--sg-topic-accent);
  text-decoration: none;
}

.sg-topic-hub .forum-directory-thread-badges {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem;
  flex: 0 1 auto;
  min-width: 0;
}

.sg-topic-hub .forum-directory-thread-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.55rem 0.9rem;
  margin-top: 0.7rem;
  color: var(--sg-topic-muted);
  font-size: 0.86rem;
  line-height: 1.45;
}

.sg-topic-hub .forum-directory-thread-meta-item {
  display: inline-flex;
  align-items: center;
  color: var(--sg-topic-muted);
}

.sg-topic-hub .forum-directory-thread-author {
  display: inline-flex;
  align-items: center;
  min-width: 0;
  color: var(--sg-topic-ink);
  text-decoration: none;
}

.sg-topic-hub .forum-directory-thread-author:hover {
  color: var(--sg-topic-accent);
  text-decoration: none;
}

.sg-topic-hub .forum-directory-thread-author-avatar-wrap {
  position: relative;
  display: inline-flex;
  flex: 0 0 auto;
  margin-inline-end: 0.5rem;
}

.sg-topic-hub .forum-directory-thread-author-avatar {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  object-fit: cover;
  display: block;
  box-shadow: 0 0.35rem 0.85rem rgba(0, 0, 0, 0.18);
}

.sg-topic-hub .forum-directory-thread-author-avatar-wrap .online-dot {
  position: absolute;
  right: 0;
  bottom: 0;
  transform: translate(20%, 20%);
  font-size: 9px;
  color: #65a830;
  border: 2px solid var(--sg-topic-paper-2);
  border-radius: 50%;
  line-height: 1;
}

.sg-topic-hub .forum-directory-thread-author-name {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-weight: 600;
}

.sg-topic-hub .forum-directory-thread-side {
  position: relative;
  flex: 0 0 170px;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  min-width: 0;
  align-self: stretch;
  padding-top: 1.25rem;
}

.sg-topic-hub .forum-directory-thread-side-badges {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 0.35rem;
}

.sg-topic-hub .forum-thread-status-stickers {
  position: absolute;
  top: -0.35rem;
  inset-inline-end: 0;
  z-index: 2;
}

.sg-topic-hub .forum-directory-thread-latest {
  margin-top: auto;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.75rem;
  min-width: 0;
}

.sg-topic-hub .forum-directory-thread-latest-avatar {
  display: inline-flex;
  flex: 0 0 auto;
}

.sg-topic-hub .forum-directory-thread-latest-avatar img {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  object-fit: cover;
  display: block;
  box-shadow: 0 0.35rem 0.85rem rgba(0, 0, 0, 0.2);
}

.sg-topic-hub .forum-directory-thread-latest-copy {
  min-width: 0;
  text-align: end;
}

.sg-topic-hub .forum-directory-thread-latest-name,
.sg-topic-hub .forum-directory-thread-latest-time {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  text-decoration: none;
}

.sg-topic-hub .forum-directory-thread-latest-name {
  color: var(--sg-topic-ink);
  font-size: 0.88rem;
  font-weight: 700;
}

.sg-topic-hub .forum-directory-thread-latest-time {
  margin-top: 0.15rem;
  color: var(--sg-topic-muted);
  font-size: 0.8rem;
}

.sg-topic-hub .forum-directory-thread-latest-name:hover,
.sg-topic-hub .forum-directory-thread-latest-time:hover {
  color: var(--sg-topic-accent);
  text-decoration: none;
}

.sg-topic-hub .forum-directory-thread-latest-empty {
  color: var(--sg-topic-muted-2);
  font-size: 0.82rem;
  text-align: end;
}

.sg-topic-empty-card__icon {
  width: 36px;
  height: 36px;
  font-size: 1rem;
}

.sg-topic-detail-grid .sg-widget {
  margin-bottom: 0;
  border: 1px solid var(--sg-topic-border-strong);
  border-radius: 12px;
  overflow: hidden;
  background: var(--sg-topic-paper-2);
  box-shadow: var(--sg-topic-shadow-sm);
}

.sg-topic-detail-grid .sg-widget__header {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.85rem 1.25rem;
  border-bottom: 1px solid var(--sg-topic-border);
}

.sg-topic-detail-grid .sg-widget__title-accent {
  width: 16px;
  height: 2px;
  border-radius: 999px;
  background: var(--sg-topic-accent);
  flex-shrink: 0;
}

.sg-topic-detail-grid .sg-widget__title {
  margin: 0;
  color: var(--sg-topic-muted-2);
  font-family: "IBM Plex Sans", "Segoe UI", Helvetica, Arial, sans-serif;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  line-height: 1;
  text-transform: uppercase;
}

.sg-topic-detail-grid .sg-widget__body {
  padding: 1.1rem 1.25rem 1.25rem;
}

.sg-topic-detail-grid .sg-widget__empty {
  padding: 1rem 0;
  color: var(--sg-topic-muted-2);
  font-family: "IBM Plex Sans", "Segoe UI", Helvetica, Arial, sans-serif;
  font-size: 0.84rem;
  line-height: 1.6;
  text-align: center;
}

.sg-topic-hub .border-top,
.sg-topic-hub .border-bottom {
  border-color: var(--sg-topic-border) !important;
}

.sg-topic-related-link {
  color: inherit;
  transition: color 0.15s ease;
}

.sg-topic-related-link:hover,
.sg-topic-related-link:focus {
  color: var(--sg-topic-accent);
}

.sg-topic-related-link__initial {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--sg-topic-paper-4);
  color: var(--sg-topic-accent);
  font-size: 0.78rem;
  font-weight: 700;
}

.sg-topic-hub .post,
.sg-topic-hub .post__wrapper,
.sg-topic-hub .feeds-item {
  background: var(--sg-topic-paper-2);
  border-color: var(--sg-topic-border-strong) !important;
  box-shadow: var(--sg-topic-shadow-sm);
}

body[data-bs-theme="dark"] .sg-topic-hub .sg-topic-hero--no-cover,
.sg-topic-hub[data-bs-theme="dark"] .sg-topic-hero--no-cover {
  background: linear-gradient(135deg, #16181d 0%, #262a33 100%);
}

body[data-bs-theme="dark"]
  .sg-topic-hub
  .sg-topic-hero--no-cover
  .sg-topic-hero__overlay,
.sg-topic-hub[data-bs-theme="dark"]
  .sg-topic-hero--no-cover
  .sg-topic-hero__overlay {
  background: linear-gradient(
    135deg,
    rgba(201, 162, 82, 0.24) 0%,
    rgba(18, 20, 26, 0.96) 100%
  );
}

body[data-bs-theme="dark"] .sg-topic-hub .sg-topic-hero__stat-card,
.sg-topic-hub[data-bs-theme="dark"] .sg-topic-hero__stat-card {
  border-color: #2a2f36;
  background: #2a2f36;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

body[data-bs-theme="dark"] .sg-topic-hub .sg-topic-hero__stat-value,
.sg-topic-hub[data-bs-theme="dark"] .sg-topic-hero__stat-value {
  color: #f8fafc;
}

body[data-bs-theme="dark"] .sg-topic-hub .sg-topic-hero__stat-label,
.sg-topic-hub[data-bs-theme="dark"] .sg-topic-hero__stat-label {
  color: rgba(226, 232, 240, 0.48);
}

body[data-bs-theme="dark"]
  .sg-topic-hub
  .sg-topic-hero--no-cover
  .sg-topic-hero__title,
body[data-bs-theme="dark"]
  .sg-topic-hub
  .sg-topic-hero--no-cover
  .sg-topic-hero__description,
.sg-topic-hub[data-bs-theme="dark"]
  .sg-topic-hero--no-cover
  .sg-topic-hero__title,
.sg-topic-hub[data-bs-theme="dark"]
  .sg-topic-hero--no-cover
  .sg-topic-hero__description {
  color: #ffffff !important;
}

body[data-bs-theme="dark"]
  .sg-topic-hub
  .sg-topic-hero--no-cover
  .sg-topic-hero__thumb,
.sg-topic-hub[data-bs-theme="dark"]
  .sg-topic-hero--no-cover
  .sg-topic-hero__thumb {
  border-color: rgba(255, 255, 255, 0.2);
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.24);
}

@media (max-width: 991.98px) {
  .sg-topic-main {
    padding-top: 2rem;
  }

  .sg-topic-section + .sg-topic-section {
    margin-top: 1.75rem;
  }

  .sg-topic-hero__actions {
    margin-left: 0;
    width: 100%;
    justify-content: flex-start;
  }
}

@media (max-width: 767.98px) {
  .sg-topic-blog-grid {
    grid-template-columns: 1fr;
  }

  .sg-topic-post-grid {
    grid-template-columns: 1fr;
  }

  .sg-topic-hub .forum-directory-thread-row {
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 0.8rem;
  }

  .sg-topic-hub .forum-directory-thread-main {
    flex: 1 1 calc(100% - 168px);
  }

  .sg-topic-hub .forum-directory-thread-title-inline {
    flex-direction: column;
    align-items: flex-start;
  }

  .sg-topic-hub .forum-directory-thread-badges {
    justify-content: flex-start;
  }

  .sg-topic-hub .forum-directory-thread-side {
    flex: 1 1 100%;
    padding-inline-start: calc(156px + 0.8rem);
    padding-top: 0;
  }

  .sg-topic-hub .forum-directory-thread-side-badges {
    justify-content: flex-start;
  }

  .sg-topic-hub .forum-thread-status-stickers {
    position: static;
    margin-bottom: 0.55rem;
  }

  .sg-topic-hub .forum-directory-thread-latest {
    justify-content: flex-start;
  }

  .sg-topic-hub .forum-directory-thread-latest-copy,
  .sg-topic-hub .forum-directory-thread-latest-empty {
    text-align: start;
  }
}

@media (max-width: 575.98px) {
  .sg-topic-hero__thumb {
    width: 64px;
    height: 64px;
  }

  .sg-topic-hero__stat-card {
    min-width: 96px;
    flex: 1 1 0;
  }

  .sg-topic-hub .forum-directory-thread-metrics-group {
    gap: 0.45rem;
  }

  .sg-topic-hub .forum-directory-thread-metric-card {
    flex-basis: 78px;
    min-height: 96px;
  }

  .sg-topic-blog-card__thumb {
    display: none !important;
  }
}
/*//nb##: END*/

/* nb##: Admin Garbage Collector 选项卡片改为 light/dark 共用语义面板，避免 bg-light 在夜间模式下过曝 */
.sg-garbage-collector-panel {
  border: 1px solid var(--sg-theme-border-mid);
  background: var(--sg-theme-surface);
  color: inherit;
}

/* nb##: Support 详情摘要与辅助 badge 改成 light/dark 共用语义面板，避免 Ticket Overview 在夜间模式下继续使用 bg-light */
.sg-support-soft-badge {
  color: var(--sg-theme-text-sub) !important;
  border: 1px solid var(--sg-theme-border-mid);
  background: var(--sg-theme-surface-2);
}

.sg-support-soft-badge--accent {
  color: var(--sg-theme-accent) !important;
  border-color: rgba(var(--sg-theme-accent-rgb), 0.24);
  background: var(--sg-theme-accent-dim);
}

/* nb##: SUPPORT 首页与目录页的 Solved ticket 需要整卡高亮，方便在混合状态列表里快速区分已解决工单。 */
.support-ticket-list-card--solved {
  border: 1px solid rgba(34, 197, 94, 0.28);
  border-radius: 14px;
  overflow: hidden;
  background: linear-gradient(
    180deg,
    rgba(34, 197, 94, 0.08) 0%,
    #ffffff 18%,
    #f8fafc 100%
  );
  box-shadow: 0 0.9rem 1.65rem rgba(22, 163, 74, 0.12);
}

.support-ticket-list-card--solved > .head {
  background: linear-gradient(135deg, #22c55e 0%, #16a34a 100%);
}

.support-ticket-list-card__status--solved {
  border: 1px solid rgba(22, 163, 74, 0.24);
  background: linear-gradient(135deg, #34d399 0%, #16a34a 100%);
  color: #f0fdf4;
  box-shadow: 0 0.55rem 1rem rgba(22, 163, 74, 0.18);
}

body.night-mode .support-ticket-list-card--solved {
  border-color: rgba(34, 197, 94, 0.42);
  background: linear-gradient(
    180deg,
    rgba(21, 128, 61, 0.18) 0%,
    rgba(15, 23, 42, 0.96) 18%,
    rgba(17, 24, 39, 0.98) 100%
  );
  box-shadow: 0 1rem 1.9rem rgba(2, 6, 23, 0.34);
}

body.night-mode .support-ticket-list-card--solved > .head {
  background: linear-gradient(135deg, #16a34a 0%, #15803d 100%);
}

body.night-mode .support-ticket-list-card__status--solved {
  border-color: rgba(74, 222, 128, 0.28);
  background: linear-gradient(135deg, #22c55e 0%, #15803d 100%);
  color: #f0fdf4;
  box-shadow: 0 0.6rem 1rem rgba(21, 128, 61, 0.26);
}

.support-ticket-overview {
  border: 1px solid rgba(var(--sg-theme-accent-rgb), 0.16);
  background: linear-gradient(
    135deg,
    rgba(var(--sg-theme-accent-rgb), 0.12) 0%,
    var(--sg-theme-surface) 42%,
    var(--sg-theme-surface-2) 100%
  );
  box-shadow: var(--sg-theme-shadow-md);
}

.support-ticket-overview__summary {
  color: var(--sg-theme-text-sub);
}

.support-ticket-overview__summary strong,
.support-ticket-overview__summary a {
  color: var(--sg-theme-text);
}

.support-ticket-overview__stat {
  height: 100%;
  padding: 1rem;
  border: 1px solid var(--sg-theme-border-mid);
  border-radius: 1rem;
  background: var(--sg-theme-surface-2);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.support-ticket-overview__stat-label {
  color: var(--sg-theme-text-muted);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.support-ticket-overview__stat-value {
  color: var(--sg-theme-text);
}

.sg-garbage-collector-tabs {
  border-bottom-color: var(--sg-theme-border-mid);
}

.sg-garbage-collector-tabs__content {
  padding-top: 0.25rem;
}

.sg-garbage-collector-pane .form-check {
  padding: 0.7rem 0.95rem 0.7rem 2rem;
  border: 1px solid var(--sg-theme-border-mid);
  border-radius: 0.85rem;
  background: var(--sg-theme-surface-2);
}

.sg-garbage-collector-pane .form-check:last-child {
  margin-bottom: 0 !important;
}

.sg-garbage-collector-pane .form-check-input {
  margin-top: 0.2rem;
}

.sg-garbage-collector-pane .form-check-label {
  color: inherit;
}

.sg-garbage-collector-pane .form-check:has(.form-check-input:checked) {
  border-color: rgba(var(--sg-theme-accent-rgb), 0.35);
  background: var(--sg-theme-accent-dim);
}

body.night-mode .sg-garbage-collector-pane .form-check {
  background: var(--sg-theme-surface-2);
}

/* nb##: 统一移除站内弹出层阴影，补齐 mention/emoji/reaction/chat 等浮层阴影覆盖 BEGIN */
.dropdown-menu,
.modal-content,
.popover,
.tooltip,
.tooltip-inner,
.toast,
.offcanvas,
.ui-widget-content,
.tagify__dropdown,
.tagify__dropdown__wrapper,
.ql-mention-list-container,
.user-popover-content,
.chat-colors-menu,
.emoji-menu,
.reactions-container,
.lightbox-container,
.chat-widget,
.video-call-stream-local,
.sg-offcanvas .sg-offcanvas-sidebar,
body.night-mode .dropdown-menu,
body.night-mode .modal-content,
body.night-mode .popover,
body.night-mode .tooltip,
body.night-mode .tooltip-inner,
body.night-mode .toast,
body.night-mode .offcanvas,
body.night-mode .ui-widget-content,
body.night-mode .tagify__dropdown,
body.night-mode .tagify__dropdown__wrapper,
body.night-mode .ql-mention-list-container,
body.night-mode .user-popover-content,
body.night-mode .chat-colors-menu,
body.night-mode .emoji-menu,
body.night-mode .reactions-container,
body.night-mode .lightbox-container,
body.night-mode .chat-widget,
body.night-mode .video-call-stream-local,
body.night-mode .sg-offcanvas .sg-offcanvas-sidebar {
  box-shadow: none !important;
}
/* nb##: END */

/* nb##: Topic 后台编辑折叠层改成暗色编辑面板，和主后台动作按钮的图标化设计保持一致 */
.sg-topic-admin-edit-card {
  background: #12171f !important;
  color: #f4f7fb;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.04);
}

.sg-topic-admin-edit-card .form-label,
.sg-topic-admin-edit-card .card-title,
.sg-topic-admin-edit-card .card-text {
  color: #f4f7fb;
}

.sg-topic-admin-edit-card .form-text,
.sg-topic-admin-edit-card .text-muted {
  color: rgba(244, 247, 251, 0.68) !important;
}

.sg-topic-admin-edit-card .form-control,
.sg-topic-admin-edit-card .form-select,
.sg-topic-admin-edit-card .tagify {
  background: #0b1017;
  border-color: rgba(255, 255, 255, 0.16);
  color: #f4f7fb;
}

.sg-topic-admin-edit-card .form-control::placeholder,
.sg-topic-admin-edit-card .form-select::placeholder {
  color: rgba(244, 247, 251, 0.42);
}

.sg-topic-admin-edit-card .tagify__input,
.sg-topic-admin-edit-card .tagify__input::before,
.sg-topic-admin-edit-card .tagify__input:empty::before {
  color: rgba(244, 247, 251, 0.6);
}

.sg-topic-admin-edit-card .tagify__tag {
  --tag-bg: rgba(255, 255, 255, 0.1);
  --tag-hover: rgba(255, 255, 255, 0.16);
  --tag-text-color: #f4f7fb;
  --tag-remove-btn-color: rgba(244, 247, 251, 0.82);
}

.sg-topic-admin-edit-card .x-image {
  background: #0b1017;
  border: 1px solid rgba(255, 255, 255, 0.16);
}

.sg-topic-admin-asset-frame {
  width: 100%;
}

.sg-topic-admin-asset-frame .js_asset-preview-image {
  width: 100%;
  height: 100%;
  object-position: center;
}

.sg-topic-admin-asset-frame--cover,
.sg-topic-admin-asset-frame--thumb {
  height: auto;
  aspect-ratio: 18 / 5;
}

.sg-topic-admin-asset-frame--cover .js_asset-preview-image {
  object-fit: cover;
}

.sg-topic-admin-asset-frame--thumb .js_asset-preview-image {
  object-fit: contain;
}

.sg-topic-admin-asset-frame .x-uploader {
  display: flex;
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  align-items: center;
  justify-content: center;
  margin: 0;
  padding: 0;
}

.sg-topic-admin-asset-frame .js_x-uploader {
  display: flex;
  width: 100%;
  height: 100%;
  align-items: center;
  justify-content: center;
  margin: 0;
  padding: 0;
  line-height: 1;
  text-align: center;
  pointer-events: none;
}

.sg-topic-admin-asset-frame .js_x-uploader::before {
  display: block;
}

.sg-topic-admin-asset-frame .x-image-loader {
  padding-top: 0;
}

/* nb##: PUBLISHER-SCROLL-FIX 禁用 CSS Scroll Anchoring，防止 Quill 编辑器增高时浏览器自动将页面向下滚动（用户打字时页面会不断下移的 bug） */
html {
  overflow-anchor: none;
}
