.text-left {
  text-align: left !important;
}
.text-center {
  text-align: center !important;
}
.text-right {
  text-align: right !important;
}
.text-justify {
  text-align: justify !important;
}
.gap-0 {
  gap: 0 !important;
}
.gap-1 {
  gap: 0.25rem !important;
}
.gap-2 {
  gap: 0.5rem !important;
}
.gap-3 {
  gap: 1rem !important;
}
.gap-4 {
  gap: 1.5rem !important;
}
.row-gap-0 {
  row-gap: 0 !important;
}
.row-gap-1 {
  row-gap: 0.25rem !important;
}
.row-gap-2 {
  row-gap: 0.5rem !important;
}
.row-gap-3 {
  row-gap: 1rem !important;
}
.row-gap-4 {
  row-gap: 1.5rem !important;
}
.column-gap-0 {
  column-gap: 0 !important;
}
.column-gap-1 {
  column-gap: 0.25rem !important;
}
.column-gap-2 {
  column-gap: 0.5rem !important;
}
.column-gap-3 {
  column-gap: 1rem !important;
}
.column-gap-4 {
  column-gap: 1.5rem !important;
}
@media (max-width: 767px) {
  .gap-mobile-0 {
    gap: 0 !important;
  }
}
@media (min-width: 768px) and (max-width: 1023px) {
  .gap-tablet-0 {
    gap: 0 !important;
  }
}
@media (min-width: 1024px) {
  .gap-pc-0 {
    gap: 0 !important;
  }
}
@media (max-width: 767px) {
  .gap-mobile-1 {
    gap: 0.25rem !important;
  }
}
@media (min-width: 768px) and (max-width: 1023px) {
  .gap-tablet-1 {
    gap: 0.25rem !important;
  }
}
@media (min-width: 1024px) {
  .gap-pc-1 {
    gap: 0.25rem !important;
  }
}
@media (max-width: 767px) {
  .gap-mobile-2 {
    gap: 0.5rem !important;
  }
}
@media (min-width: 768px) and (max-width: 1023px) {
  .gap-tablet-2 {
    gap: 0.5rem !important;
  }
}
@media (min-width: 1024px) {
  .gap-pc-2 {
    gap: 0.5rem !important;
  }
}
@media (max-width: 767px) {
  .gap-mobile-3 {
    gap: 1rem !important;
  }
}
@media (min-width: 768px) and (max-width: 1023px) {
  .gap-tablet-3 {
    gap: 1rem !important;
  }
}
@media (min-width: 1024px) {
  .gap-pc-3 {
    gap: 1rem !important;
  }
}
@media (max-width: 767px) {
  .gap-mobile-4 {
    gap: 1.5rem !important;
  }
}
@media (min-width: 768px) and (max-width: 1023px) {
  .gap-tablet-4 {
    gap: 1.5rem !important;
  }
}
@media (min-width: 1024px) {
  .gap-pc-4 {
    gap: 1.5rem !important;
  }
}
@media (max-width: 767px) {
  .row-gap-mobile-0 {
    row-gap: 0 !important;
  }
}
@media (min-width: 768px) and (max-width: 1023px) {
  .row-gap-tablet-0 {
    row-gap: 0 !important;
  }
}
@media (min-width: 1024px) {
  .row-gap-pc-0 {
    row-gap: 0 !important;
  }
}
@media (max-width: 767px) {
  .row-gap-mobile-1 {
    row-gap: 0.25rem !important;
  }
}
@media (min-width: 768px) and (max-width: 1023px) {
  .row-gap-tablet-1 {
    row-gap: 0.25rem !important;
  }
}
@media (min-width: 1024px) {
  .row-gap-pc-1 {
    row-gap: 0.25rem !important;
  }
}
@media (max-width: 767px) {
  .row-gap-mobile-2 {
    row-gap: 0.5rem !important;
  }
}
@media (min-width: 768px) and (max-width: 1023px) {
  .row-gap-tablet-2 {
    row-gap: 0.5rem !important;
  }
}
@media (min-width: 1024px) {
  .row-gap-pc-2 {
    row-gap: 0.5rem !important;
  }
}
@media (max-width: 767px) {
  .row-gap-mobile-3 {
    row-gap: 1rem !important;
  }
}
@media (min-width: 768px) and (max-width: 1023px) {
  .row-gap-tablet-3 {
    row-gap: 1rem !important;
  }
}
@media (min-width: 1024px) {
  .row-gap-pc-3 {
    row-gap: 1rem !important;
  }
}
@media (max-width: 767px) {
  .row-gap-mobile-4 {
    row-gap: 1.5rem !important;
  }
}
@media (min-width: 768px) and (max-width: 1023px) {
  .row-gap-tablet-4 {
    row-gap: 1.5rem !important;
  }
}
@media (min-width: 1024px) {
  .row-gap-pc-4 {
    row-gap: 1.5rem !important;
  }
}
@media (max-width: 767px) {
  .column-gap-mobile-0 {
    column-gap: 0 !important;
  }
}
@media (min-width: 768px) and (max-width: 1023px) {
  .column-gap-tablet-0 {
    column-gap: 0 !important;
  }
}
@media (min-width: 1024px) {
  .column-gap-pc-0 {
    column-gap: 0 !important;
  }
}
@media (max-width: 767px) {
  .column-gap-mobile-1 {
    column-gap: 0.25rem !important;
  }
}
@media (min-width: 768px) and (max-width: 1023px) {
  .column-gap-tablet-1 {
    column-gap: 0.25rem !important;
  }
}
@media (min-width: 1024px) {
  .column-gap-pc-1 {
    column-gap: 0.25rem !important;
  }
}
@media (max-width: 767px) {
  .column-gap-mobile-2 {
    column-gap: 0.5rem !important;
  }
}
@media (min-width: 768px) and (max-width: 1023px) {
  .column-gap-tablet-2 {
    column-gap: 0.5rem !important;
  }
}
@media (min-width: 1024px) {
  .column-gap-pc-2 {
    column-gap: 0.5rem !important;
  }
}
@media (max-width: 767px) {
  .column-gap-mobile-3 {
    column-gap: 1rem !important;
  }
}
@media (min-width: 768px) and (max-width: 1023px) {
  .column-gap-tablet-3 {
    column-gap: 1rem !important;
  }
}
@media (min-width: 1024px) {
  .column-gap-pc-3 {
    column-gap: 1rem !important;
  }
}
@media (max-width: 767px) {
  .column-gap-mobile-4 {
    column-gap: 1.5rem !important;
  }
}
@media (min-width: 768px) and (max-width: 1023px) {
  .column-gap-tablet-4 {
    column-gap: 1.5rem !important;
  }
}
@media (min-width: 1024px) {
  .column-gap-pc-4 {
    column-gap: 1.5rem !important;
  }
}
.visibility-visible {
  visibility: visible !important;
}
.visibility-hidden {
  visibility: hidden !important;
}
.visibility-collapse {
  visibility: collapse !important;
}
.overflow-visible {
  overflow: visible !important;
}
.overflow-hidden {
  overflow: hidden !important;
}
.overflow-scroll {
  overflow: scroll !important;
}
.overflow-auto {
  overflow: auto !important;
}
/*
 * Flute CMS Helper Classes
 * A comprehensive collection of utility classes for rapid UI development
 */
/* ===== Display & Visibility ===== */
.hidden {
  display: none;
  visibility: hidden;
}
.d-flex, .flex-center, .icon-hover, .flex-between, .flex-around, .flex-evenly, .align-center, .align-end, .align-start, .align-stretch, .align-baseline, .justify-center, .justify-start, .justify-end, .justify-between, .justify-around, .justify-evenly, .flex-column, .flex-row, .flex-row-reverse, .flex-column-reverse {
  display: flex;
}
.d-inline-flex {
  display: inline-flex;
}
.d-block {
  display: block;
}
.d-inline-block {
  display: inline-block;
}
.d-none {
  display: none;
}
.d-grid {
  display: grid;
}
.d-contents {
  display: contents;
}
.invisible {
  visibility: hidden;
}
.visible {
  visibility: visible;
}
/* ===== Sizing ===== */
.w-full, .w-100 {
  width: 100% !important;
}
.h-full, .h-100 {
  height: 100% !important;
}
.w-auto {
  width: auto !important;
}
.h-auto {
  height: auto !important;
}
.w-screen {
  width: 100vw !important;
}
.h-screen {
  height: 100vh !important;
}
.min-w-0 {
  min-width: 0 !important;
}
.min-h-0 {
  min-height: 0 !important;
}
.max-w-full {
  max-width: 100% !important;
}
.max-h-full {
  max-height: 100% !important;
}
.max-w-screen {
  max-width: 100vw !important;
}
.max-h-screen {
  max-height: 100vh !important;
}
/* ===== Positioning ===== */
.p-relative, .position-relative {
  position: relative;
}
.p-absolute, .position-absolute {
  position: absolute;
}
.p-fixed, .position-fixed {
  position: fixed;
}
.p-sticky, .position-sticky {
  position: sticky;
}
.p-static, .position-static {
  position: static;
}
.top-0 {
  top: 0 !important;
}
.right-0 {
  right: 0 !important;
}
.bottom-0 {
  bottom: 0 !important;
}
.left-0 {
  left: 0 !important;
}
.inset-0 {
  top: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  left: 0 !important;
}
/* ===== Flex Layout ===== */
.flex-center, .icon-hover {
  align-items: center;
  justify-content: center;
}
.flex-between {
  align-items: center;
  justify-content: space-between;
}
.flex-around {
  align-items: center;
  justify-content: space-around;
}
.flex-evenly {
  align-items: center;
  justify-content: space-evenly;
}
.align-center {
  align-items: center;
}
.align-end {
  align-items: flex-end;
}
.align-start {
  align-items: flex-start;
}
.align-stretch {
  align-items: stretch;
}
.align-baseline {
  align-items: baseline;
}
.justify-center {
  justify-content: center;
}
.justify-start {
  justify-content: flex-start;
}
.justify-end {
  justify-content: flex-end;
}
.justify-between {
  justify-content: space-between;
}
.justify-around {
  justify-content: space-around;
}
.justify-evenly {
  justify-content: space-evenly;
}
.flex-column {
  flex-direction: column;
}
.flex-row {
  flex-direction: row;
}
.flex-row-reverse {
  flex-direction: row-reverse;
}
.flex-column-reverse {
  flex-direction: column-reverse;
}
.flex-wrap {
  flex-wrap: wrap;
}
.flex-nowrap {
  flex-wrap: nowrap;
}
.flex-wrap-reverse {
  flex-wrap: wrap-reverse;
}
.flex-grow-0 {
  flex-grow: 0 !important;
}
.flex-grow-1 {
  flex-grow: 1 !important;
}
.flex-shrink-0 {
  flex-shrink: 0 !important;
}
.flex-shrink-1 {
  flex-shrink: 1 !important;
}
.flex-basis-0 {
  flex-basis: 0 !important;
}
.flex-basis-auto {
  flex-basis: auto !important;
}
.flex-1 {
  flex: 1 !important;
}
.flex-auto {
  flex: 1 1 auto !important;
}
.flex-none {
  flex: none !important;
}
/* ===== Grid Layout ===== */
.grid-cols-1 {
  grid-template-columns: repeat(1, minmax(0, 1fr));
}
.grid-cols-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.grid-cols-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.grid-cols-4 {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
.grid-cols-5 {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}
.grid-cols-6 {
  grid-template-columns: repeat(6, minmax(0, 1fr));
}
.grid-cols-12 {
  grid-template-columns: repeat(12, minmax(0, 1fr));
}
.grid-rows-1 {
  grid-template-rows: repeat(1, minmax(0, 1fr));
}
.grid-rows-2 {
  grid-template-rows: repeat(2, minmax(0, 1fr));
}
.grid-rows-3 {
  grid-template-rows: repeat(3, minmax(0, 1fr));
}
.grid-rows-4 {
  grid-template-rows: repeat(4, minmax(0, 1fr));
}
.grid-rows-5 {
  grid-template-rows: repeat(5, minmax(0, 1fr));
}
.grid-rows-6 {
  grid-template-rows: repeat(6, minmax(0, 1fr));
}
/* ===== Text Alignment ===== */
.text-center {
  text-align: center !important;
}
.text-start, .text-left {
  text-align: left !important;
}
.text-end, .text-right {
  text-align: right !important;
}
.text-justify {
  text-align: justify !important;
}
/* ===== Text Styling ===== */
.text-ellipsis {
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  display: inline-block;
  max-width: 100%;
}
.text-small {
  font-size: var(--small) !important;
}
.text-medium {
  font-size: var(--medium) !important;
}
.text-large {
  font-size: var(--large) !important;
}
.text-muted {
  color: var(--text-400);
  line-height: 1.5;
}
.text-lowercase {
  text-transform: lowercase !important;
}
.text-uppercase {
  text-transform: uppercase !important;
}
.text-capitalize {
  text-transform: capitalize !important;
}
.text-wrap {
  white-space: normal !important;
}
.text-nowrap {
  white-space: nowrap !important;
}
.text-break {
  word-wrap: break-word !important;
  word-break: break-word !important;
}
.text-truncate {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.text-balance {
  text-wrap: balance;
}
.line-clamp {
  display: -webkit-box;
  -webkit-line-clamp: 5;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.line-clamp-1 {
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.line-clamp-2 {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.line-clamp-3 {
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.line-clamp-4 {
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
/* ===== Font Sizes ===== */
.h1 {
  font-size: var(--h1);
}
.h2 {
  font-size: var(--h2);
}
.h3 {
  font-size: var(--h3);
}
.h4 {
  font-size: var(--h4);
}
.h5 {
  font-size: var(--h5);
}
.h6 {
  font-size: var(--h6);
}
/* ===== Font Weights ===== */
.font-thin {
  font-weight: 100 !important;
}
.font-extralight {
  font-weight: 200 !important;
}
.font-light {
  font-weight: 300 !important;
}
.font-normal {
  font-weight: 400 !important;
}
.font-medium {
  font-weight: 500 !important;
}
.font-semibold {
  font-weight: 600 !important;
}
.font-bold {
  font-weight: 700 !important;
}
.font-extrabold {
  font-weight: 800 !important;
}
.font-black {
  font-weight: 900 !important;
}
/* ===== Colors ===== */
.text-error {
  color: var(--error);
}
.text-success {
  color: var(--success);
}
.text-warning {
  color: var(--warning);
}
.text-info {
  color: var(--info);
}
.primary {
  color: var(--primary);
}
.accent {
  color: var(--accent);
}
.hover-accent:hover {
  color: var(--accent);
}
.bg-primary {
  background-color: var(--primary) !important;
}
.bg-accent {
  background-color: var(--accent) !important;
}
.bg-error {
  background-color: var(--error) !important;
}
.bg-success {
  background-color: var(--success) !important;
}
.bg-warning {
  background-color: var(--warning) !important;
}
.bg-info {
  background-color: var(--info) !important;
}
.bg-transparent {
  background-color: transparent !important;
}
/* ===== Cursors ===== */
.cursor-move {
  cursor: move;
}
.cursor-pointer {
  cursor: pointer;
}
.cursor-default {
  cursor: default;
}
.cursor-not-allowed {
  cursor: not-allowed;
}
.cursor-grab {
  cursor: grab;
}
.cursor-grabbing {
  cursor: grabbing;
}
.cursor-text {
  cursor: text;
}
.cursor-wait {
  cursor: wait;
}
.cursor-help {
  cursor: help;
}
.cursor-crosshair {
  cursor: crosshair;
}
.cursor-zoom-in {
  cursor: zoom-in;
}
.cursor-zoom-out {
  cursor: zoom-out;
}
/* ===== Opacity ===== */
.opacity-0 {
  opacity: 0 !important;
}
.opacity-25 {
  opacity: 0.25 !important;
}
.opacity-50 {
  opacity: 0.5 !important;
}
.opacity-75 {
  opacity: 0.75 !important;
}
.opacity-100 {
  opacity: 1 !important;
}
/* ===== Z-Index ===== */
.z-index-0 {
  z-index: 0 !important;
}
.z-index-1 {
  z-index: 1 !important;
}
.z-index-2 {
  z-index: 2 !important;
}
.z-index-3 {
  z-index: 3 !important;
}
.z-index-10 {
  z-index: 10 !important;
}
.z-index-100 {
  z-index: 100 !important;
}
.z-index-1000 {
  z-index: 1000 !important;
}
.z-index-auto {
  z-index: auto !important;
}
/* ===== Borders ===== */
.border {
  border: 1px solid var(--transp-1);
}
.border-none {
  border: none;
}
.border-top {
  border-top: 1px solid var(--transp-1);
}
.border-bottom {
  border-bottom: 1px solid var(--transp-1);
}
.border-left {
  border-left: 1px solid var(--transp-1);
}
.border-right {
  border-right: 1px solid var(--transp-1);
}
.border-primary {
  border-color: var(--primary) !important;
}
.border-accent {
  border-color: var(--accent) !important;
}
.border-error {
  border-color: var(--error) !important;
}
.border-success {
  border-color: var(--success) !important;
}
.border-warning {
  border-color: var(--warning) !important;
}
.border-info {
  border-color: var(--info) !important;
}
/* ===== Border Radius ===== */
.rounded {
  border-radius: var(--border05);
}
.rounded-sm {
  border-radius: var(--border025);
}
.rounded-lg {
  border-radius: var(--border1);
}
.rounded-xl {
  border-radius: var(--border1);
}
.rounded-full, .rounded-circle {
  border-radius: 50%;
}
.rounded-none {
  border-radius: 0;
}
.rounded-t {
  border-top-left-radius: var(--border05);
  border-top-right-radius: var(--border05);
}
.rounded-r {
  border-top-right-radius: var(--border05);
  border-bottom-right-radius: var(--border05);
}
.rounded-b {
  border-bottom-left-radius: var(--border05);
  border-bottom-right-radius: var(--border05);
}
.rounded-l {
  border-top-left-radius: var(--border05);
  border-bottom-left-radius: var(--border05);
}
/* ===== Overflow ===== */
.overflow-auto {
  overflow: auto;
}
.overflow-hidden {
  overflow: hidden;
}
.overflow-visible {
  overflow: visible;
}
.overflow-scroll {
  overflow: scroll;
}
.overflow-x-auto {
  overflow-x: auto;
}
.overflow-y-auto {
  overflow-y: auto;
}
.overflow-x-hidden {
  overflow-x: hidden;
}
.overflow-y-hidden {
  overflow-y: hidden;
}
.overflow-x-visible {
  overflow-x: visible;
}
.overflow-y-visible {
  overflow-y: visible;
}
.overflow-x-scroll {
  overflow-x: scroll;
}
.overflow-y-scroll {
  overflow-y: scroll;
}
/* ===== Special Effects ===== */
.blur-bg, .wiki-search__results, .wiki-category-section, .wiki-landing .wiki-category-section, .wiki-article-content table, .banners-widget .banners-slider .banners-controls .banner-prev, .banners-widget .banners-slider .banners-controls .banner-next, .banners-widget .banners-slider .banners-indicators, .banners-widget .banners-slider .banner-progress-timer .progress-circle, .blog-index .blog-categories-box, .blog-index .blog-category-latest, .blog-index .blog-categories-panel, .blog-index .blog-category-header, .blog-index .blog-category-articles, .blog-index .blog-card, .blog-index .blog-featured, .blog-index .blog-feed-card__body, .blog-index .blog-search__results, .blog-index .blog-code-header, .blog-index .blog-code-copy, .blog-index .blog-like-action__button, .blog-index .blog-article-latest .blog-feed-card__body, .blog-index .pagination a, .blog-landing .blog-categories-box, .blog-landing .blog-category-latest, .blog-landing .blog-categories-panel, .blog-landing .blog-category-header, .blog-landing .blog-category-articles, .blog-landing .blog-card, .blog-landing .blog-featured, .blog-landing .blog-feed-card__body, .blog-landing .blog-search__results, .blog-landing .blog-code-header, .blog-landing .blog-code-copy, .blog-landing .blog-like-action__button, .blog-landing .blog-article-latest .blog-feed-card__body, .blog-landing .pagination a, .blog-category .blog-categories-box, .blog-category .blog-category-latest, .blog-category .blog-categories-panel, .blog-category .blog-category-header, .blog-category .blog-category-articles, .blog-category .blog-card, .blog-category .blog-featured, .blog-category .blog-feed-card__body, .blog-category .blog-search__results, .blog-category .blog-code-header, .blog-category .blog-code-copy, .blog-category .blog-like-action__button, .blog-category .blog-article-latest .blog-feed-card__body, .blog-category .pagination a, .blog-search-page .blog-categories-box, .blog-search-page .blog-category-latest, .blog-search-page .blog-categories-panel, .blog-search-page .blog-category-header, .blog-search-page .blog-category-articles, .blog-search-page .blog-card, .blog-search-page .blog-featured, .blog-search-page .blog-feed-card__body, .blog-search-page .blog-search__results, .blog-search-page .blog-code-header, .blog-search-page .blog-code-copy, .blog-search-page .blog-like-action__button, .blog-search-page .blog-article-latest .blog-feed-card__body, .blog-search-page .pagination a, .blog-article .blog-categories-box, .blog-article .blog-category-latest, .blog-article .blog-categories-panel, .blog-article .blog-category-header, .blog-article .blog-category-articles, .blog-article .blog-card, .blog-article .blog-featured, .blog-article .blog-feed-card__body, .blog-article .blog-search__results, .blog-article .blog-code-header, .blog-article .blog-code-copy, .blog-article .blog-like-action__button, .blog-article .blog-article-latest .blog-feed-card__body, .blog-article .pagination a, .blog-article .blog-article-content table, .flute-users-grid__card, .monitoring-card .card-btn, .monitoring-card-mode .card-btn, .card-bans-table, .sitebans-info-card, .sitebans-ip-map, .support-result, .support-add-composer, .support-side-card, .support-chat-section, .support-chat-section .wall-composer, .servers-block, .bans-main-block {
  position: relative;
  backdrop-filter: saturate(150%) blur(var(--blur-amount, 14px));
  -webkit-backdrop-filter: saturate(150%) blur(var(--blur-amount, 14px));
}
.icon-hover {
  display: inline-flex;
  height: 40px;
  width: 40px;
  border-radius: 25px;
  cursor: pointer;
  background: none;
  transition: all 0.2s ease-in-out;
}
.icon-hover:hover {
  color: var(--text);
  background-color: var(--transp-1);
}
.img-thumbnail {
  background-color: var(--background-900);
  border: 1px solid var(--transp-2);
  border-radius: var(--border05);
  max-width: 100%;
  height: auto;
}
.shadow-sm {
  box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
}
.shadow {
  box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px 0 rgba(0, 0, 0, 0.06);
}
.shadow-md {
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
}
.shadow-lg {
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
}
.shadow-xl {
  box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
}
.shadow-2xl {
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
}
.shadow-inner {
  box-shadow: inset 0 2px 4px 0 rgba(0, 0, 0, 0.06);
}
.shadow-none {
  box-shadow: none;
}
/* ===== Transitions ===== */
.transition {
  transition: all 0.2s ease-in-out;
}
.transition-colors {
  transition: background-color 0.2s ease-in-out, border-color 0.2s ease-in-out, color 0.2s ease-in-out, fill 0.2s ease-in-out, stroke 0.2s ease-in-out;
}
.transition-opacity {
  transition: opacity 0.2s ease-in-out;
}
.transition-shadow {
  transition: box-shadow 0.2s ease-in-out;
}
.transition-transform {
  transition: transform 0.2s ease-in-out;
}
/* ===== Miscellaneous ===== */
.clearfix::after {
  content: "";
  display: table;
  clear: both;
}
.table-responsive {
  -webkit-overflow-scrolling: touch;
  overflow-x: auto;
}
.user-select-none {
  user-select: none;
}
.user-select-all {
  user-select: all;
}
.user-select-auto {
  user-select: auto;
}
.user-select-text {
  user-select: text;
}
.pointer-events-none {
  pointer-events: none;
}
.pointer-events-auto {
  pointer-events: auto;
}
.whitespace-normal {
  white-space: normal;
}
.whitespace-nowrap {
  white-space: nowrap;
}
.whitespace-pre {
  white-space: pre;
}
.whitespace-pre-line {
  white-space: pre-line;
}
.whitespace-pre-wrap {
  white-space: pre-wrap;
}
.break-normal {
  overflow-wrap: normal;
  word-break: normal;
}
.break-words {
  overflow-wrap: break-word;
}
.break-all {
  word-break: break-all;
}
.truncate {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0;
}
.not-sr-only {
  position: static;
  width: auto;
  height: auto;
  padding: 0;
  margin: 0;
  overflow: visible;
  clip: auto;
  white-space: normal;
}
.object-contain {
  object-fit: contain;
}
.object-cover {
  object-fit: cover;
}
.object-fill {
  object-fit: fill;
}
.object-none {
  object-fit: none;
}
.object-scale-down {
  object-fit: scale-down;
}
.object-center {
  object-position: center;
}
.object-top {
  object-position: top;
}
.object-right {
  object-position: right;
}
.object-bottom {
  object-position: bottom;
}
.object-left {
  object-position: left;
}
.rotate-0 {
  transform: rotate(0deg);
}
.rotate-45 {
  transform: rotate(45deg);
}
.rotate-90 {
  transform: rotate(90deg);
}
.rotate-180 {
  transform: rotate(180deg);
}
.rotate-270 {
  transform: rotate(270deg);
}
.scale-0 {
  transform: scale(0);
}
.scale-50 {
  transform: scale(0.5);
}
.scale-75 {
  transform: scale(0.75);
}
.scale-90 {
  transform: scale(0.9);
}
.scale-100 {
  transform: scale(1);
}
.scale-110 {
  transform: scale(1.1);
}
.scale-125 {
  transform: scale(1.25);
}
.scale-150 {
  transform: scale(1.5);
}
.translate-x-0 {
  transform: translateX(0);
}
.translate-y-0 {
  transform: translateY(0);
}
.translate-x-full {
  transform: translateX(100%);
}
.translate-y-full {
  transform: translateY(100%);
}
.translate-x-half {
  transform: translateX(50%);
}
.translate-y-half {
  transform: translateY(50%);
}
.translate-x-negative-full {
  transform: translateX(-100%);
}
.translate-y-negative-full {
  transform: translateY(-100%);
}
.translate-x-negative-half {
  transform: translateX(-50%);
}
.translate-y-negative-half {
  transform: translateY(-50%);
}
:root {
  --wiki-sidebar-width: 280px;
  --wiki-toc-width: 260px;
  --wiki-content-max: 800px;
  --wiki-transition-fast: 0.15s cubic-bezier(0.4, 0, 0.2, 1);
  --wiki-transition-normal: 0.25s cubic-bezier(0.4, 0, 0.2, 1);
  --wiki-transition-smooth: 0.35s cubic-bezier(0.4, 0, 0.2, 1);
  --wiki-radius-xs: 4px;
  --wiki-radius-sm: 8px;
  --wiki-radius-md: 12px;
  --wiki-radius-lg: 16px;
  --wiki-radius-xl: 20px;
  --wiki-radius-full: 9999px;
  --wiki-blur: 20px;
  --wiki-blur-heavy: 40px;
  --wiki-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.04), 0 1px 3px rgba(0, 0, 0, 0.06);
  --wiki-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.06), 0 2px 4px -1px rgba(0, 0, 0, 0.04);
  --wiki-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.08), 0 4px 6px -2px rgba(0, 0, 0, 0.04);
  --wiki-shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.08), 0 10px 10px -5px rgba(0, 0, 0, 0.03);
  --wiki-glass-bg: rgba(255, 255, 255, 0.6);
  --wiki-glass-border: rgba(255, 255, 255, 0.2);
}
:root[data-theme=dark] {
  --wiki-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.2), 0 1px 3px rgba(0, 0, 0, 0.3);
  --wiki-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.3), 0 2px 4px -1px rgba(0, 0, 0, 0.2);
  --wiki-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.35), 0 4px 6px -2px rgba(0, 0, 0, 0.2);
  --wiki-shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.4), 0 10px 10px -5px rgba(0, 0, 0, 0.2);
  --wiki-glass-bg: rgba(28, 28, 30, 0.75);
  --wiki-glass-border: rgba(255, 255, 255, 0.08);
}
.wiki-page {
  display: flex;
  min-height: 50vh;
  background: transparent;
  position: relative;
  align-items: flex-start;
}
.wiki-container {
  display: flex;
  flex: 1;
  max-width: 1400px;
  margin: 0 auto;
  width: 100%;
}
.wiki-main {
  flex: 1;
  padding-left: var(--space-xl);
  min-width: 0;
  display: flex;
  flex-direction: column;
}
.wiki-content-wrapper {
  display: flex;
  gap: 24px;
  flex: 1;
}
.wiki-content {
  flex: 1;
  min-width: 0;
  max-width: 100%;
}
.wiki-breadcrumbs {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  color: var(--text-500);
  margin-bottom: 32px;
}
.wiki-breadcrumb__link {
  color: var(--text-500);
  transition: color var(--wiki-transition-fast);
  cursor: pointer;
  text-decoration: none;
  display: flex;
  align-items: center;
}
.wiki-breadcrumb__link svg {
  width: 14px;
  height: 14px;
}
.wiki-breadcrumb__link:hover {
  color: var(--text);
}
.wiki-breadcrumb__separator {
  color: var(--text-600);
  width: 12px;
  height: 12px;
  flex-shrink: 0;
}
.wiki-breadcrumb__current {
  color: var(--text-300);
  font-weight: 500;
  max-width: 200px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.wiki-article-header {
  margin-bottom: 40px;
  padding-bottom: 32px;
  border-bottom: 1px solid var(--transp-1);
}
.wiki-article__meta {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 20px;
  flex-wrap: wrap;
}
.wiki-article__category {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  background: var(--transp-05);
  border: 1px solid var(--transp-1);
  border-radius: var(--wiki-radius-full);
  font-size: 12px;
  font-weight: 500;
  color: var(--text-400);
  transition: all var(--wiki-transition-fast);
}
.wiki-article__category svg {
  width: 12px;
  height: 12px;
  opacity: 0.7;
}
.wiki-article__category:hover {
  background: var(--transp-1);
  border-color: var(--transp-2);
}
.wiki-article__title {
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  font-weight: 700;
  color: var(--text);
  line-height: 1.2;
  margin-bottom: 16px;
  letter-spacing: -0.025em;
}
.wiki-article__description {
  font-size: 1.05rem;
  color: var(--text-400);
  line-height: 1.7;
  margin-bottom: 24px;
}
.wiki-article__info {
  display: flex;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
}
.wiki-article__info-item {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  color: var(--text-500);
}
.wiki-article__info-item svg {
  opacity: 0.6;
  width: 14px;
  height: 14px;
}
.wiki-article__author {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  transition: opacity var(--wiki-transition-fast);
}
.wiki-article__author:hover {
  opacity: 0.8;
}
.wiki-article__author-avatar {
  width: 24px;
  height: 24px;
  border-radius: var(--wiki-radius-sm);
  object-fit: cover;
}
.wiki-article__author-name {
  font-size: 13px;
  font-weight: 500;
  color: var(--text);
}
.wiki-tags {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 20px;
}
.wiki-tag {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 10px;
  background: var(--transp-05);
  border: 1px solid var(--transp-1);
  border-radius: var(--wiki-radius-sm);
  font-size: 12px;
  color: var(--text-500);
  cursor: default;
  transition: all var(--wiki-transition-fast);
}
.wiki-tag svg {
  width: 10px;
  height: 10px;
  opacity: 0.5;
}
.wiki-sidebar {
  width: var(--wiki-sidebar-width);
  min-width: var(--wiki-sidebar-width);
  background: transparent;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  border: 1px solid var(--transp-1);
  border-radius: var(--wiki-radius-lg);
  position: sticky;
  top: 80px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.wiki-sidebar__header {
  padding: 20px 16px;
  border-bottom: 1px solid var(--transp-1);
  flex-shrink: 0;
}
.wiki-sidebar__title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 12px;
  letter-spacing: -0.01em;
}
.wiki-sidebar__title svg {
  color: var(--accent);
  width: 18px;
  height: 18px;
}
.wiki-sidebar__back {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 10px 14px;
  border-radius: var(--wiki-radius-full);
  border: 1px solid var(--transp-2);
  background: linear-gradient(180deg, var(--transp-05) 0%, rgba(255, 255, 255, 0.01) 100%);
  color: var(--text);
  text-decoration: none;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.01em;
  box-shadow: 0 10px 22px -18px rgba(0, 0, 0, 0.55);
  transition: transform 0.15s ease, border-color 0.15s ease, background 0.15s ease, box-shadow 0.15s ease;
  margin-bottom: 0;
}
.wiki-sidebar__back svg {
  width: 14px;
  height: 14px;
  opacity: 0.8;
  flex-shrink: 0;
}
.wiki-sidebar__back:hover {
  transform: translateY(-1px);
  border-color: var(--transp-3);
  background: linear-gradient(180deg, var(--transp-1) 0%, var(--transp-05) 100%);
  box-shadow: 0 14px 26px -18px rgba(0, 0, 0, 0.7);
}
.wiki-search-wrapper {
  position: relative;
}
.wiki-search__icon {
  position: absolute;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--text-500);
  pointer-events: none;
  width: 14px;
  height: 14px;
  transition: color 0.15s ease;
}
.wiki-search__input {
  width: 100%;
  padding: 8px 10px 8px 32px;
  background: var(--transp-05);
  border: 1px solid var(--transp-1);
  border-radius: var(--wiki-radius-sm);
  color: var(--text);
  font-size: 12px;
  transition: border-color 0.15s ease;
}
.wiki-search__input:focus {
  border-color: var(--accent);
  outline: none;
}
.wiki-search__input:focus + .wiki-search__icon, .wiki-search__input:focus ~ .wiki-search__icon {
  color: var(--accent);
}
.wiki-search__input::placeholder {
  color: var(--text-600);
}
.wiki-search__results {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  right: 0;
  background: var(--wiki-glass-bg);
  border: 1px solid var(--transp-1);
  border-radius: var(--wiki-radius-sm);
  box-shadow: var(--wiki-shadow-lg);
  max-height: 280px;
  overflow-y: auto;
  z-index: 200;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-4px);
  transition: opacity 0.15s ease, transform 0.15s ease, visibility 0.15s ease;
}
.wiki-search__results--open {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.wiki-search__result-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  cursor: pointer;
  transition: background 0.1s ease;
  text-decoration: none;
}
.wiki-search__result-item:not(:last-child) {
  border-bottom: 1px solid var(--transp-05);
}
.wiki-search__result-item:hover {
  background: var(--transp-05);
}
.wiki-search__result-icon {
  color: var(--text-500);
  width: 14px;
  height: 14px;
  flex-shrink: 0;
}
.wiki-search__result-content {
  flex: 1;
  min-width: 0;
  text-align: left;
}
.wiki-search__result-title {
  font-size: 12px;
  font-weight: 500;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1.4;
}
.wiki-search__result-category {
  font-size: 10px;
  color: var(--text-500);
  margin-top: 1px;
  line-height: 1.4;
}
.wiki-search__no-results {
  padding: 16px 12px;
  text-align: center;
  color: var(--text-500);
  font-size: 12px;
}
.wiki-categories {
  flex: 1;
  overflow-y: auto;
  padding: 8px;
}
.wiki-categories::-webkit-scrollbar {
  width: 3px;
}
.wiki-categories::-webkit-scrollbar-track {
  background: transparent;
}
.wiki-categories::-webkit-scrollbar-thumb {
  background: var(--transp-2);
  border-radius: var(--wiki-radius-full);
}
.wiki-category:not(:last-child) {
  margin-bottom: 2px;
}
.wiki-category__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 6px 10px;
  border-radius: var(--wiki-radius-sm);
  cursor: pointer;
  transition: background 0.1s ease;
  user-select: none;
  gap: 6px;
}
.wiki-category__header:hover {
  background: var(--transp-05);
}
.wiki-category__header--active {
  background: var(--transp-05);
}
.wiki-category__title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  font-weight: 500;
  color: var(--text);
  flex: 1;
  min-width: 0;
}
.wiki-category__title span:not(.wiki-category__icon) {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.wiki-category__icon {
  color: var(--text-400);
  width: 14px;
  height: 14px;
  flex-shrink: 0;
}
.wiki-category__header--active .wiki-category__icon {
  color: var(--accent);
}
.wiki-category__meta {
  display: flex;
  align-items: center;
  gap: 4px;
  flex-shrink: 0;
}
.wiki-category__count {
  font-size: 10px;
  font-weight: 500;
  color: var(--text-500);
  background: var(--transp-1);
  padding: 1px 5px;
  border-radius: var(--wiki-radius-full);
  min-width: 16px;
  text-align: center;
}
.wiki-category__chevron {
  color: var(--text-500);
  transition: transform 0.2s ease;
  width: 12px;
  height: 12px;
  flex-shrink: 0;
}
.wiki-category__chevron--open {
  transform: rotate(180deg);
}
.wiki-articles-list {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 0.25s ease;
}
.wiki-articles-list--open {
  grid-template-rows: 1fr;
}
.wiki-articles-list__inner {
  overflow: hidden;
  padding-left: 22px;
}
.wiki-articles-list--open .wiki-articles-list__inner {
  padding-top: 2px;
  padding-bottom: 4px;
}
.wiki-article-item {
  display: block;
  padding: 8px 10px;
  font-size: 12px;
  color: var(--text-400);
  border-radius: var(--wiki-radius-sm);
  cursor: pointer;
  transition: color 0.1s ease, background 0.1s ease;
  text-decoration: none;
  line-height: 1.4;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.wiki-article-item:hover {
  color: var(--text);
  background: var(--transp-05);
}
.wiki-article-item--active {
  color: var(--accent);
  background: var(--transp-05);
  font-weight: 500;
}
.wiki-article-item__icon {
  display: none;
}
.wiki-article-item__text {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
}
.wiki-article-content {
  font-size: 15px;
  line-height: 1.8;
  color: var(--text);
  max-width: var(--wiki-content-max);
}
.wiki-article-content h2 {
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--text);
  margin: 40px 0 16px;
  scroll-margin-top: 100px;
  letter-spacing: -0.02em;
}
.wiki-article-content h2:first-child {
  margin-top: 0;
  padding-top: 0;
  border-top: none;
}
.wiki-article-content h3 {
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--text);
  margin: 28px 0 12px;
  scroll-margin-top: 100px;
  letter-spacing: -0.01em;
}
.wiki-article-content h4 {
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--text);
  margin: 20px 0 10px;
  scroll-margin-top: 100px;
}
.wiki-article-content p {
  color: var(--text-300);
}
.wiki-article-content ul, .wiki-article-content ol {
  margin-bottom: 18px;
  padding-left: 20px;
}
.wiki-article-content li {
  color: var(--text-300);
}
.wiki-article-content li::marker {
  color: var(--text-500);
}
.wiki-article-content a {
  color: var(--accent);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: all var(--wiki-transition-fast);
}
.wiki-article-content a:hover {
  border-bottom-color: var(--accent);
}
.wiki-article-content strong {
  font-weight: 600;
  color: var(--text);
}
.wiki-article-content em {
  font-style: italic;
}
.wiki-article-content blockquote {
  margin: 24px 0;
  padding: 16px 20px;
  background: var(--transp-05);
  border-left: 3px solid var(--accent);
  border-radius: 0 var(--wiki-radius-md) var(--wiki-radius-md) 0;
  color: var(--text-300);
}
.wiki-article-content blockquote p:last-child {
  margin-bottom: 0;
}
.wiki-article-content pre {
  position: relative;
  margin: 24px 0;
  background: var(--background-800);
  border: 1px solid var(--transp-1);
  border-radius: var(--wiki-radius-md);
  overflow: hidden;
}
.wiki-article-content pre code {
  display: block;
  overflow-x: auto;
  font-family: var(--font-mono);
  font-size: 13px;
  line-height: 1.6;
  color: var(--text);
  white-space: pre;
}
.wiki-article-content code:not(pre code) {
  padding: 2px 6px;
  background: var(--transp-1);
  border-radius: var(--wiki-radius-xs);
  font-family: var(--font-mono);
  font-size: 0.875em;
  color: var(--text-200);
}
.wiki-article-content img {
  max-width: 100%;
  height: auto;
  border-radius: var(--wiki-radius-md);
  margin: 20px 0;
}
.wiki-article-content table {
  width: 100%;
  border-collapse: collapse;
  margin: 24px 0;
  font-size: 14px;
}
.wiki-article-content table th, .wiki-article-content table td {
  padding: 12px 16px;
  text-align: left;
  border-bottom: 1px solid var(--transp-1);
}
.wiki-article-content table th {
  font-weight: 600;
  color: var(--text);
  background: var(--transp-05);
}
.wiki-article-content table td {
  color: var(--text-300);
}
.wiki-article-content table tr:hover td {
  background: var(--transp-05);
}
.wiki-article-content hr {
  border: none;
  height: 1px;
  background: var(--transp-1);
  margin: 32px 0;
}
.wiki-article-content .blog-ta-left {
  text-align: left;
}
.wiki-article-content .blog-ta-center {
  text-align: center;
}
.wiki-article-content .blog-ta-right {
  text-align: right;
}
.wiki-article-content .blog-ta-justify {
  text-align: justify;
}
.wiki-article-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 60px 20px;
  color: var(--text-500);
}
.wiki-article-empty svg {
  width: 48px;
  height: 48px;
  margin-bottom: 16px;
  opacity: 0.4;
}
.wiki-article-empty p {
  font-size: 14px;
  color: var(--text-500);
}
.wiki-article-footer {
  margin-top: 56px;
  padding-top: 32px;
  border-top: 1px solid var(--transp-1);
  max-width: var(--wiki-content-max);
}
.wiki-feedback {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 24px;
  background: var(--transp-05);
  border: 1px solid var(--transp-1);
  border-radius: var(--wiki-radius-lg);
  margin-bottom: 32px;
  gap: 16px;
}
.wiki-feedback__question {
  font-size: 14px;
  font-weight: 500;
  color: var(--text);
}
.wiki-feedback__buttons {
  display: flex;
  gap: 10px;
}
.wiki-feedback__btn {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 16px;
  background: var(--transp-05);
  border: 1px solid var(--transp-1);
  border-radius: var(--wiki-radius-sm);
  font-size: 13px;
  font-weight: 500;
  color: var(--text-400);
  cursor: pointer;
  transition: all var(--wiki-transition-fast);
}
.wiki-feedback__btn svg {
  width: 14px;
  height: 14px;
}
.wiki-feedback__btn:hover {
  background: var(--transp-1);
  color: var(--text);
}
.wiki-feedback__btn--positive:hover, .wiki-feedback__btn--positive.active {
  border-color: var(--success);
  color: var(--success);
  background: var(--success-light);
}
.wiki-feedback__btn--negative:hover, .wiki-feedback__btn--negative.active {
  border-color: var(--error);
  color: var(--error);
  background: var(--error-light);
}
.wiki-feedback__count {
  font-size: 12px;
  color: var(--text-500);
  margin-left: 2px;
}
.wiki-related {
  margin-top: 32px;
}
.wiki-related__title {
  font-size: 1rem;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 16px;
}
.wiki-related__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
}
.wiki-related__card {
  display: flex;
  flex-direction: column;
  padding: 18px 20px;
  background: var(--transp-05);
  border: 1px solid var(--transp-1);
  border-radius: var(--wiki-radius-md);
  cursor: pointer;
  transition: all var(--wiki-transition-fast);
  text-decoration: none;
}
.wiki-related__card:hover {
  background: var(--transp-1);
  border-color: var(--transp-2);
}
.wiki-related__category {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-500);
  margin-bottom: 6px;
}
.wiki-related__card-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 4px;
  line-height: 1.4;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.wiki-related__card-desc {
  font-size: 12px;
  color: var(--text-500);
  line-height: 1.5;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.wiki-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 80px 20px;
  text-align: center;
}
.wiki-empty__icon {
  width: 72px;
  height: 72px;
  border-radius: var(--wiki-radius-lg);
  background: var(--transp-05);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 24px;
}
.wiki-empty__icon svg {
  width: 32px;
  height: 32px;
  color: var(--text-500);
}
.wiki-empty h3 {
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 8px;
}
.wiki-empty p {
  font-size: 14px;
  color: var(--text-500);
  max-width: 320px;
}
.wiki-toc {
  width: 200px;
  min-width: 200px;
  position: sticky;
  top: 100px;
  height: fit-content;
  max-height: calc(100vh - 140px);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
}
.wiki-toc__title {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-500);
  margin-bottom: 12px;
}
.wiki-toc__title svg {
  width: 12px;
  height: 12px;
  opacity: 0.6;
}
.wiki-toc__list {
  list-style: none;
  padding: 0;
  margin: 0;
  overflow-y: auto;
  flex: 1;
  position: relative;
  padding-left: 12px;
}
.wiki-toc__list::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 1px;
  background: var(--transp-1);
}
.wiki-toc__list::-webkit-scrollbar {
  width: 2px;
}
.wiki-toc__list::-webkit-scrollbar-track {
  background: transparent;
}
.wiki-toc__list::-webkit-scrollbar-thumb {
  background: var(--transp-2);
  border-radius: var(--wiki-radius-full);
}
.wiki-toc__item {
  margin-bottom: 0;
  position: relative;
}
.wiki-toc__link {
  display: block;
  font-size: 12px;
  color: var(--text-500);
  line-height: 1.5;
  cursor: pointer;
  transition: all var(--wiki-transition-fast);
  padding: 4px 0;
  position: relative;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  line-clamp: 2;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}
.wiki-toc__link::before {
  content: "";
  position: absolute;
  left: -12px;
  top: 50%;
  transform: translateY(-50%);
  width: 1px;
  height: 0;
  background: var(--accent);
  transition: height var(--wiki-transition-fast);
}
.wiki-toc__link:hover {
  color: var(--text);
}
.wiki-toc__link--active {
  color: var(--accent);
  font-weight: 500;
}
.wiki-toc__link--active::before {
  height: 16px;
}
.wiki-toc__link--h3 {
  padding-left: 12px;
  font-size: 11px;
  color: var(--text-500);
}
.wiki-toc__link--h3::before {
  left: 0px;
}
.wiki-toc__link--h4 {
  padding-left: 20px;
  font-size: 10px;
  color: var(--text-500);
}
.wiki-toc__link--h4::before {
  left: 8px;
}
.wiki-last-updated {
  margin-top: 20px;
  padding-top: 16px;
  border-top: 1px solid var(--transp-1);
  flex-shrink: 0;
}
.wiki-last-updated__title {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-500);
  margin-bottom: 10px;
}
.wiki-feedback--toc {
  margin-top: 20px;
  margin-bottom: 0;
  padding: 16px 0 0;
  background: transparent;
  border: none;
  border-top: 1px solid var(--transp-1);
  border-radius: 0;
  flex-direction: column;
  align-items: stretch;
  justify-content: flex-start;
  gap: 10px;
}
.wiki-feedback--toc .wiki-feedback__title {
  margin-bottom: 0;
}
.wiki-feedback--toc .wiki-feedback__buttons {
  width: 100%;
  justify-content: stretch;
  gap: 8px;
}
.wiki-feedback--toc .wiki-feedback__btn {
  flex: 1 1 0;
  justify-content: center;
  padding: 8px 10px;
  font-size: 11px;
}
.wiki-feedback--toc .wiki-feedback__count {
  font-size: 11px;
}
.wiki-update-item {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 12px;
  color: var(--text-400);
  cursor: pointer;
  transition: opacity var(--wiki-transition-fast);
  text-decoration: none;
}
.wiki-update-item:hover {
  opacity: 0.8;
}
.wiki-update-item__avatar {
  width: 26px;
  height: 26px;
  border-radius: var(--wiki-radius-sm);
  object-fit: cover;
  flex-shrink: 0;
}
.wiki-update-item__avatar--placeholder {
  background: var(--transp-1);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 9px;
  font-weight: 600;
  color: var(--text-400);
}
.wiki-update-item__info {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 1px;
}
.wiki-update-item__author {
  font-weight: 500;
  color: var(--text);
  font-size: 11px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  line-height: 1.25;
}
.wiki-update-item__date {
  line-height: 1.25;
  font-size: 10px;
  color: var(--text-500);
}
.wiki-code-wrapper {
  position: relative;
  margin: 24px 0;
  background: var(--secondary);
  border: 1px solid var(--transp-1);
  border-radius: var(--wiki-radius-lg);
  overflow: hidden;
}
.wiki-code-wrapper pre {
  margin: 0;
  border: none;
  border-radius: 0;
  background: transparent;
}
.wiki-code-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 14px;
  background: var(--transp-05);
  border-bottom: 1px solid var(--transp-1);
}
.wiki-code-lang {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  font-weight: 500;
  color: var(--text-500);
  font-family: var(--font-mono);
  text-transform: uppercase;
  letter-spacing: 0.3px;
}
.wiki-code-lang svg {
  opacity: 0.6;
}
.wiki-code-copy {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 5px 10px;
  background: var(--transp-05);
  border: 1px solid var(--transp-1);
  border-radius: var(--wiki-radius-sm);
  font-size: 11px;
  font-weight: 500;
  color: var(--text-500);
  cursor: pointer;
  transition: all var(--wiki-transition-fast);
}
.wiki-code-copy svg {
  width: 12px;
  height: 12px;
}
.wiki-code-copy:hover {
  background: var(--transp-1);
  color: var(--text);
  border-color: var(--transp-2);
}
.wiki-code-copy.copied {
  color: var(--success);
  border-color: var(--success);
  background: var(--success-light);
}
.wiki-landing {
  min-height: calc(100vh - 80px);
  padding-bottom: 80px;
}
.wiki-landing__hero {
  position: relative;
  padding: 0px 0 50px;
  text-align: center;
}
.wiki-landing__hero::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 800px;
  height: 500px;
  background: radial-gradient(ellipse at center, var(--accent-alpha-1) 0%, transparent 70%);
  pointer-events: none;
  opacity: 0.6;
}
.wiki-landing__hero-content {
  position: relative;
  z-index: 1;
  max-width: 580px;
  margin: 0 auto;
  padding: 0 24px;
}
.wiki-landing__title {
  font-size: clamp(2.25rem, 5vw, 3rem);
  font-weight: 700;
  color: var(--text);
  letter-spacing: -0.035em;
  line-height: 1.1;
  margin-bottom: 12px;
}
.wiki-landing__subtitle {
  font-size: 1.0625rem;
  color: var(--text-400);
  line-height: 1.6;
  margin-bottom: 36px;
  text-align: center;
}
.wiki-landing__search {
  position: relative;
  max-width: 520px;
  margin: 0 auto;
}
.wiki-landing__search-box {
  position: relative;
  display: flex;
  align-items: center;
}
.wiki-landing__search-icon {
  position: absolute;
  left: 20px;
  width: 20px;
  height: 20px;
  color: var(--text-500);
  pointer-events: none;
  transition: color 0.2s ease;
}
.wiki-landing__search-input {
  width: 100%;
  padding: 18px 100px 18px 54px;
  background: var(--block);
  border: 1px solid var(--transp-1);
  border-radius: 14px;
  font-size: 16px;
  color: var(--text);
  transition: all 0.2s ease;
  box-shadow: 0 2px 16px -4px rgba(0, 0, 0, 0.06);
}
.wiki-landing__search-input::placeholder {
  color: var(--text-500);
}
.wiki-landing__search-input:hover {
  border-color: var(--transp-2);
}
.wiki-landing__search-input:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 2px 16px -4px rgba(0, 0, 0, 0.06), 0 0 0 3px var(--accent-alpha-1);
}
.wiki-landing__search-input:focus ~ .wiki-landing__search-icon {
  color: var(--accent);
}
.wiki-landing__search-hint {
  position: absolute;
  right: 16px;
  display: flex;
  gap: 4px;
  pointer-events: none;
}
.wiki-landing__search-hint kbd {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 24px;
  height: 24px;
  padding: 0 6px;
  background: var(--transp-05);
  border: 1px solid var(--transp-1);
  border-radius: 6px;
  font-size: 11px;
  font-family: inherit;
  color: var(--text-500);
}
.wiki-landing__search-results {
  top: calc(100% + 8px);
  border-radius: 12px;
  max-height: 360px;
}
.wiki-category-section {
  margin-bottom: 32px;
  background: var(--transp-03);
  border: 1px solid var(--transp-1);
  box-shadow: var(--shadow-small);
  border-radius: 16px;
  overflow: hidden;
}
.wiki-category-section:last-child {
  margin-bottom: 0;
}
.wiki-category-section__header {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 20px 24px;
  background: transparent;
  border: 0;
  border-bottom: 1px solid var(--transp-1);
}
.wiki-category-section__icon {
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--accent-alpha-1);
  border-radius: 12px;
  flex-shrink: 0;
}
.wiki-category-section__icon svg {
  width: 22px;
  height: 22px;
  color: var(--accent);
}
.wiki-category-section__info {
  flex: 1;
  min-width: 0;
}
.wiki-category-section__title {
  font-size: 17px;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 2px;
  letter-spacing: -0.01em;
}
.wiki-category-section__desc {
  font-size: 13px;
  color: var(--text-400);
  line-height: 1.4;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.wiki-category-section__count {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-500);
  background: var(--transp-1);
  padding: 4px 12px;
  border-radius: 20px;
  flex-shrink: 0;
}
.wiki-category-section__articles {
  background: transparent;
  border: 0;
  border-radius: 0;
  overflow: hidden;
}
.wiki-article-row {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 16px 24px;
  text-decoration: none;
  transition: background 0.15s ease;
  border-bottom: 1px solid var(--transp-05);
}
.wiki-article-row:last-child {
  border-bottom: none;
}
.wiki-article-row:hover {
  background: var(--transp-05);
}
.wiki-article-row:hover .wiki-article-row__arrow {
  transform: translateX(4px);
  opacity: 1;
}
.wiki-article-row:hover .wiki-article-row__title {
  color: var(--accent);
}
.wiki-article-row__content {
  flex: 1;
  min-width: 0;
}
.wiki-article-row__title {
  font-size: 15px;
  font-weight: 500;
  color: var(--text);
  margin-bottom: 2px;
  transition: color 0.15s ease;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.wiki-article-row__desc {
  font-size: 13px;
  color: var(--text-400);
  line-height: 1.4;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.wiki-article-row__meta {
  margin-left: auto;
  display: inline-flex;
  align-items: center;
  gap: 12px;
  flex-shrink: 0;
}
.wiki-article-row__votes {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.wiki-article-row__vote {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 12px;
  color: var(--text-500);
  line-height: 1;
}
.wiki-article-row__vote svg {
  width: 14px;
  height: 14px;
  opacity: 0.9;
}
.wiki-article-row__vote--positive svg {
  color: var(--success);
}
.wiki-article-row__vote--negative svg {
  color: var(--error);
}
.wiki-article-row__arrow {
  width: 18px;
  height: 18px;
  color: var(--text-400);
  opacity: 0.4;
  flex-shrink: 0;
  transition: all 0.2s ease;
}
.wiki-landing__empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 80px 24px;
  text-align: center;
}
.wiki-landing__empty svg {
  width: 56px;
  height: 56px;
  color: var(--text-500);
  opacity: 0.4;
  margin-bottom: 20px;
}
.wiki-landing__empty h3 {
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 6px;
}
.wiki-landing__empty p {
  font-size: 14px;
  color: var(--text-400);
}
@media (max-width: 768px) {
  .wiki-landing__hero {
    padding: 48px 0 40px;
  }
  .wiki-landing__title {
    font-size: 1.875rem;
  }
  .wiki-landing__subtitle {
    font-size: 1rem;
    margin-bottom: 28px;
  }
  .wiki-landing__search-input {
    padding: 16px 16px 16px 48px;
    font-size: 15px;
    border-radius: 12px;
  }
  .wiki-landing__search-icon {
    left: 16px;
    width: 18px;
    height: 18px;
  }
  .wiki-landing__search-hint {
    display: none;
  }
  .wiki-category-section__header {
    padding: 16px 20px;
    gap: 12px;
  }
  .wiki-category-section__icon {
    width: 40px;
    height: 40px;
  }
  .wiki-category-section__icon svg {
    width: 20px;
    height: 20px;
  }
  .wiki-category-section__title {
    font-size: 15px;
  }
  .wiki-category-section__desc {
    display: none;
  }
  .wiki-article-row {
    padding: 14px 20px;
  }
  .wiki-article-row__title {
    font-size: 14px;
  }
  .wiki-article-row__desc {
    display: none;
  }
  .wiki-article-row__meta {
    gap: 8px;
  }
  .wiki-article-row__votes {
    gap: 8px;
  }
  .wiki-article-row__vote {
    font-size: 11px;
  }
  .wiki-article-row__vote svg {
    width: 13px;
    height: 13px;
  }
}
@media (max-width: 1280px) {
  .wiki-main {
    padding: 32px 40px;
  }
  .wiki-content-wrapper {
    gap: 20px;
  }
  .wiki-toc {
    width: 200px;
    min-width: 200px;
  }
}
@media (max-width: 1100px) {
  .wiki-toc {
    display: none;
  }
  .wiki-main {
    padding: 32px 40px;
  }
}
@media (max-width: 900px) {
  :root {
    --wiki-sidebar-width: 260px;
  }
  .wiki-main {
    padding: 24px 32px;
  }
  .wiki-article__title {
    font-size: 1.75rem;
  }
  .wiki-related__grid {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 768px) {
  .wiki-page {
    flex-direction: column;
  }
  .wiki-sidebar {
    width: 100%;
    min-width: 100%;
    position: relative;
    top: 0;
    height: auto;
    max-height: none;
    border-bottom: 1px solid var(--transp-1);
  }
  .wiki-sidebar__header {
    padding: 20px 16px;
  }
  .wiki-categories {
    max-height: 300px;
    padding: 12px 16px 16px;
  }
  .wiki-main {
    padding: 24px 16px;
  }
  .wiki-article__title {
    font-size: 1.5rem;
  }
  .wiki-article__description {
    font-size: 1rem;
  }
  .wiki-article__info {
    gap: 12px;
  }
  .wiki-breadcrumbs {
    margin-bottom: 20px;
  }
  .wiki-breadcrumbs .wiki-breadcrumb__link:not(:first-child):not(:last-child) {
    display: none;
  }
  .wiki-breadcrumbs .wiki-breadcrumb__separator:not(:first-of-type):not(:last-of-type) {
    display: none;
  }
  .wiki-feedback {
    flex-direction: column;
    text-align: center;
    padding: 16px;
  }
  .wiki-feedback__buttons {
    width: 100%;
    justify-content: center;
  }
  .wiki-article-content {
    font-size: 14px;
  }
  .wiki-article-content h2 {
    font-size: 1.3rem;
    margin: 36px 0 16px;
  }
  .wiki-article-content h3 {
    font-size: 1.1rem;
    margin: 24px 0 12px;
  }
  .wiki-article-content pre code {
    font-size: 12px;
    padding: 14px 16px;
  }
  .wiki-article-content blockquote {
    padding: 14px 16px;
  }
  .wiki-code-header {
    padding: 8px 12px;
  }
  .wiki-code-lang {
    font-size: 10px;
  }
  .wiki-code-copy {
    padding: 4px 8px;
    font-size: 10px;
  }
  .wiki-code-copy span {
    display: none;
  }
}
@media (max-width: 480px) {
  .wiki-main {
    padding: 20px 12px;
  }
  .wiki-sidebar__header {
    padding: 16px 12px;
  }
  .wiki-categories {
    padding: 8px 12px 12px;
  }
  .wiki-article__title {
    font-size: 1.35rem;
  }
  .wiki-article__meta {
    gap: 8px;
  }
  .wiki-article__category {
    padding: 4px 10px;
    font-size: 11px;
  }
  .wiki-article-header {
    margin-bottom: 24px;
    padding-bottom: 20px;
  }
  .wiki-feedback__btn {
    padding: 8px 12px;
    font-size: 12px;
  }
  .wiki-related__card {
    padding: 14px 16px;
  }
  .wiki-empty {
    padding: 48px 16px;
  }
  .wiki-empty__icon {
    width: 56px;
    height: 56px;
  }
  .wiki-empty__icon svg {
    width: 24px;
    height: 24px;
  }
  .wiki-empty h3 {
    font-size: 1.1rem;
  }
  .wiki-empty p {
    font-size: 13px;
  }
}
@media (hover: none) {
  .wiki-category__header:hover {
    background: transparent;
  }
  .wiki-category__header--active {
    background: var(--transp-1);
  }
  .wiki-article-item:hover {
    background: transparent;
  }
  .wiki-article-item--active {
    background: var(--transp-05);
  }
}
/* Wiki landing cards style aligned with profile/settings */
.wiki-landing .wiki-category-section {
  background: var(--transp-03);
  border: 1px solid var(--transp-1);
  box-shadow: var(--shadow-small);
}
.wiki-landing .wiki-article-row {
  border-bottom: 1px solid var(--transp-1);
  transition: background-color var(--transition);
}
.wiki-landing .wiki-article-row__title, .wiki-landing .wiki-article-row__desc, .wiki-landing .wiki-article-row__arrow {
  transition: color var(--transition);
}
.wiki-landing .wiki-article-row:hover {
  background-color: var(--background-900);
}
.wiki-landing .wiki-article-row:hover .wiki-article-row__title, .wiki-landing .wiki-article-row:hover .wiki-article-row__desc, .wiki-landing .wiki-article-row:hover .wiki-article-row__arrow {
  color: var(--accent);
}
.wiki-article-content table {
  background: var(--transp-03);
  border: 1px solid var(--transp-1);
  box-shadow: var(--shadow-small);
}
.wiki-article-content table th {
  background: var(--transp-03);
  border-bottom: 1px solid var(--transp-1);
}
.wiki-article-content table tr {
  transition: background-color var(--transition);
}
.wiki-article-content table td, .wiki-article-content table a, .wiki-article-content table .support-user__name, .wiki-article-content table .support-user__link, .wiki-article-content table .support-user__inline {
  transition: color var(--transition);
}
.wiki-article-content table tr:hover {
  background-color: var(--background-900);
}
.wiki-article-content table tr:hover td {
  background-color: transparent;
  color: var(--accent);
}
.wiki-article-content table tr:hover a, .wiki-article-content table tr:hover .support-user__name, .wiki-article-content table tr:hover .support-user__link, .wiki-article-content table tr:hover .support-user__inline {
  color: var(--accent);
}
html {
  --announcement-stack-height: 0px;
}
.announcement-container {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 125;
  opacity: 0;
  transform: translateY(-100%);
  transition: opacity 0.5s cubic-bezier(0.16, 1, 0.3, 1), transform 0.5s cubic-bezier(0.16, 1, 0.3, 1);
  pointer-events: auto;
}
@media (min-width: 769px) {
  html[data-nav-style="sidebar"] .announcement-container {
    z-index: 900;
  }
}
.announcement-container--active {
  opacity: 1;
  transform: translateY(0);
}
.announcement-container--active .announcement-bar {
  animation: announceFadeIn 0.5s cubic-bezier(0.16, 1, 0.3, 1) both;
}
html[data-announcement-active="true"] .flute_header {
  top: var(--announcement-stack-height);
}
@media (min-width: 1024px) {
  html[data-announcement-active="true"][data-nav-style="pill"] #main, html[data-announcement-active="true"][data-nav-style="pill-transparent"] #main {
    padding-top: calc(var(--announcement-stack-height, 0px) + 60px + var(--space-lg));
  }
}
@media (min-width: 1024px) {
  html[data-announcement-active="true"][data-nav-style="pill-full"] #main {
    padding-top: calc(var(--announcement-stack-height, 0px) + 70px + var(--space-lg));
  }
}
@media (min-width: 769px) {
  html[data-announcement-active="true"][data-nav-style="sidebar"] .sidebar-nav {
    top: var(--announcement-stack-height, 0px);
  }
}
html[data-announcement-active="true"] .sidebar-contained-toggle {
  top: calc(24px + var(--announcement-stack-height, 0px));
}
.announcement-bar {
  position: relative;
  min-height: 38px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  transition: min-height 0.35s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.3s ease, padding 0.3s ease;
}
.announcement-bar--hiding {
  opacity: 0;
  min-height: 0;
  height: 0;
  padding-top: 0;
  padding-bottom: 0;
  overflow: hidden;
}
.announcement-bar .container {
  min-height: 38px;
}
.announcement-bar__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 38px;
  padding: 8px 0;
  gap: var(--space-md);
}
@media (max-width: 640px) {
  .announcement-bar__inner {
    flex-wrap: wrap;
    gap: var(--space-sm);
  }
}
.announcement-bar__left {
  display: flex;
  align-items: center;
  gap: 12px;
  flex: 1;
  min-width: 0;
}
.announcement-bar__body {
  display: flex;
  align-items: baseline;
  gap: 8px;
  min-width: 0;
  flex: 1;
}
@media (max-width: 768px) {
  .announcement-bar__body {
    flex-direction: column;
    align-items: flex-start;
    gap: 0;
  }
}
.announcement-bar--stacked .announcement-bar__body {
  flex-direction: column;
  align-items: flex-start;
  gap: 0;
}
.announcement-bar--clickable {
  cursor: pointer;
}
.announcement-bar--clickable:hover .announcement-bar__text {
  opacity: 0.85;
}
.announcement-bar__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.85);
  font-size: 16px;
}
@media (max-width: 640px) {
  .announcement-bar__icon {
    width: 28px;
    height: 28px;
    font-size: 14px;
  }
}
.announcement-bar__title {
  font-size: 14px;
  font-weight: 600;
  color: #fff;
  letter-spacing: -0.01em;
  line-height: 1.2;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
@media (max-width: 768px) {
  .announcement-bar__title {
    white-space: normal;
  }
}
.announcement-bar__text {
  font-size: 13px;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.75);
  letter-spacing: -0.01em;
  line-height: 1.25;
  min-width: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  word-break: break-word;
  overflow-wrap: anywhere;
}
@media (max-width: 640px) {
  .announcement-bar__text {
    font-size: 12px;
    -webkit-line-clamp: 3;
  }
}
.announcement-bar__text p {
  margin: 0;
  display: inline;
  line-height: 1.25;
}
.announcement-bar__text br {
  display: none;
}
.announcement-bar__text a {
  color: inherit;
  text-decoration: underline;
  text-underline-offset: 2px;
  text-decoration-color: rgba(255, 255, 255, 0.3);
}
.announcement-bar__text a:hover {
  text-decoration-color: currentColor;
}
.announcement-bar__right {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}
@media (max-width: 640px) {
  .announcement-bar__right {
    width: 100%;
    justify-content: flex-end;
  }
}
.announcement-bar__timer {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  color: rgba(255, 255, 255, 0.85);
  font-variant-numeric: tabular-nums;
}
.announcement-bar__timer--expired {
  opacity: 0.4;
}
.announcement-bar__timer-unit {
  display: inline-flex;
  align-items: baseline;
  gap: 2px;
  padding: 4px 8px;
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.08);
  font-size: 12px;
  font-weight: 600;
}
@media (max-width: 640px) {
  .announcement-bar__timer-unit {
    padding: 3px 6px;
    font-size: 11px;
  }
}
.announcement-bar__timer-label {
  color: rgba(255, 255, 255, 0.55);
  font-size: 0.85em;
  font-weight: 500;
}
.announcement-bar__timer-expired {
  padding: 4px 10px;
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.08);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.01em;
  color: rgba(255, 255, 255, 0.65);
  text-transform: uppercase;
}
.announcement-bar__buttons {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.announcement-bar__btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  border-radius: 8px;
  font-size: 12px;
  font-weight: 600;
  text-decoration: none;
  white-space: nowrap;
  flex-shrink: 0;
  border: 1px solid transparent;
  transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease, transform 0.1s ease;
}
.announcement-bar__btn > span {
  line-height: 1.25;
}
.announcement-bar__btn:active {
  transform: scale(0.97);
}
.announcement-bar__btn svg {
  font-size: 13px;
}
.announcement-bar__btn--primary {
  background: #fff;
  color: #111;
}
.announcement-bar__btn--primary:hover {
  background: rgba(255, 255, 255, 0.9);
}
.announcement-bar__btn--outline {
  background: transparent;
  color: #fff;
  border-color: rgba(255, 255, 255, 0.35);
}
.announcement-bar__btn--outline:hover {
  background: rgba(255, 255, 255, 0.1);
  border-color: rgba(255, 255, 255, 0.55);
}
.announcement-bar__btn--light {
  background: rgba(255, 255, 255, 0.18);
  color: #fff;
}
.announcement-bar__btn--light:hover {
  background: rgba(255, 255, 255, 0.28);
}
.announcement-bar__btn--ghost {
  background: transparent;
  color: rgba(255, 255, 255, 0.85);
}
.announcement-bar__btn--ghost:hover {
  background: rgba(255, 255, 255, 0.08);
  color: #fff;
}
.announcement-bar__close {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  padding: 0;
  border: none;
  border-radius: 6px;
  background: transparent;
  color: rgba(255, 255, 255, 0.45);
  cursor: pointer;
  flex-shrink: 0;
  transition: background 0.15s ease, color 0.15s ease, transform 0.1s ease;
}
.announcement-bar__close:hover {
  background: rgba(255, 255, 255, 0.1);
  color: rgba(255, 255, 255, 0.9);
}
.announcement-bar__close:active {
  transform: scale(0.9);
}
.announcement-bar__close svg {
  font-size: 12px;
}
.announcement-bar--info {
  background: color-mix(in srgb, var(--info) 55%, #0f172a);
}
.announcement-bar--info .announcement-bar__icon {
  color: color-mix(in srgb, var(--info), #fff 40%);
}
.announcement-bar--success {
  background: color-mix(in srgb, var(--success) 45%, #0a1a12);
}
.announcement-bar--success .announcement-bar__icon {
  color: color-mix(in srgb, var(--success), #fff 40%);
}
.announcement-bar--warning {
  background: color-mix(in srgb, var(--warning) 40%, #1a1008);
}
.announcement-bar--warning .announcement-bar__icon {
  color: color-mix(in srgb, var(--warning), #fff 30%);
}
.announcement-bar--error {
  background: color-mix(in srgb, var(--error) 45%, #1a0808);
}
.announcement-bar--error .announcement-bar__icon {
  color: color-mix(in srgb, var(--error), #fff 40%);
}
@keyframes announceFadeIn {
  from {
    opacity: 0;
    transform: translateY(-4px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.banners-widget {
  width: 100%;
}
.banners-widget .banners-empty {
  padding: var(--space-xl);
  text-align: center;
  background-color: var(--transp-1);
  border-radius: var(--border1);
  border: 1px solid var(--transp-2);
}
.banners-widget .banners-slider {
  position: relative;
  width: 100%;
  overflow: hidden;
  border-radius: var(--border1);
  transition: all var(--transition);
}
.banners-widget .banners-slider[data-height-mode="auto"] {
  height: auto !important;
  min-height: 200px;
}
.banners-widget .banners-slider[data-height-mode="auto"] .banner-slide {
  height: auto;
  min-height: 200px;
}
.banners-widget .banners-slider[data-height-mode="auto"] .banner-slide .banner-image {
  height: auto;
  aspect-ratio: 1.7777777778;
  max-height: 60vh;
}
.banners-widget .banners-slider[data-height-mode="auto"] .banner-slide .banner-image img {
  height: auto;
  width: 100%;
  max-height: inherit;
  object-fit: cover;
}
.banners-widget .banners-slider.single-banner .banners-controls {
  display: none;
}
.banners-widget .banners-slider.single-banner .banner-slide {
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  transform: none !important;
}
.banners-widget .banners-slider.single-banner .banner-content {
  padding-bottom: var(--space-lg) !important;
}
.banners-widget .banners-slider .banners-slider-track {
  height: 100%;
  width: 100%;
}
.banners-widget .banners-slider .banner-slide {
  width: 100%;
  height: 100%;
  position: relative;
  overflow: hidden;
}
.banners-widget .banners-slider .banner-slide a {
  display: block;
  height: 100%;
  color: inherit;
  text-decoration: none;
}
.banners-widget .banners-slider .banner-slide a:focus {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}
.banners-widget .banners-slider .banner-slide .banner-image {
  height: 100%;
  width: 100%;
  overflow: hidden;
}
.banners-widget .banners-slider .banner-slide .banner-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  transition: transform calc(var(--transition) * 2);
}
.banners-widget .banners-slider .banner-slide .banner-content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: var(--space-lg) calc(var(--space-lg) + 3rem) calc(var(--space-lg) + 2rem) var(--space-lg);
  background: linear-gradient(to top, rgba(0, 0, 0, 0.7), rgba(0, 0, 0, 0.5) 50%, transparent);
  color: #fff;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: flex-start;
  gap: var(--space-xs);
  max-height: 60%;
  overflow: hidden;
}
@media (max-width: 768px) {
  .banners-widget .banners-slider .banner-slide .banner-content {
    padding: var(--space-md) calc(var(--space-md) + 2.5rem) calc(var(--space-md) + 1.5rem) var(--space-md);
    gap: var(--space-xs);
  }
}
.banners-widget .banners-slider .banner-slide .banner-content.content-hidden .banner-title, .banners-widget .banners-slider .banner-slide .banner-content.content-hidden .banner-description {
  opacity: 0;
  transform: translateY(20px) scale(0.98);
  filter: blur(2px);
  pointer-events: none;
}
.banners-widget .banners-slider .banner-slide .banner-content .banner-title {
  font-size: var(--h2);
  font-weight: 600;
  line-height: 1.5;
  text-shadow: 0 1px 4px rgba(0, 0, 0, 0.8);
  transform: translateY(0) scale(1);
  opacity: 1;
  filter: blur(0);
  transition: all 0.4s cubic-bezier(0.2, 0, 0.2, 1);
  backface-visibility: hidden;
  will-change: transform, opacity, filter;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  word-break: break-word;
  hyphens: auto;
}
@media (max-width: 768px) {
  .banners-widget .banners-slider .banner-slide .banner-content .banner-title {
    font-size: var(--h4);
    -webkit-line-clamp: 1;
  }
}
@media (prefers-reduced-motion: reduce) {
  .banners-widget .banners-slider .banner-slide .banner-content .banner-title {
    transition: none;
  }
}
.banners-widget .banners-slider .banner-slide .banner-content .banner-description {
  font-size: var(--p-small);
  opacity: 0.9;
  line-height: 1.5;
  max-width: 85%;
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.6);
  transform: translateY(0) scale(1);
  filter: blur(0);
  transition: all 0.4s cubic-bezier(0.2, 0, 0.2, 1);
  backface-visibility: hidden;
  will-change: transform, opacity, filter;
  color: rgba(255, 255, 255, 0.7);
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  word-break: break-word;
  hyphens: auto;
}
@media (max-width: 768px) {
  .banners-widget .banners-slider .banner-slide .banner-content .banner-description {
    font-size: var(--p);
    -webkit-line-clamp: 4;
    max-width: 90%;
  }
}
@media (prefers-reduced-motion: reduce) {
  .banners-widget .banners-slider .banner-slide .banner-content .banner-description {
    transition: none;
  }
}
.banners-widget .banners-slider .banner-slide .banner-content.content-out .banner-title, .banners-widget .banners-slider .banner-slide .banner-content.content-out .banner-description {
  transition-timing-function: cubic-bezier(0.4, 0, 0.6, 1);
  transition-duration: 0.2s;
}
.banners-widget .banners-slider .banner-slide .banner-content.content-in .banner-title, .banners-widget .banners-slider .banner-slide .banner-content.content-in .banner-description {
  transition-timing-function: cubic-bezier(0.2, 0, 0.2, 1);
  transition-duration: 0.3s;
}
.banners-widget .banners-slider .banner-slide .banner-content::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 2rem;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.7), transparent);
  pointer-events: none;
  z-index: 1;
}
.banners-widget .banners-slider .banners-controls {
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  transform: translateY(-50%);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 var(--space-sm);
  z-index: 12;
  pointer-events: none;
}
@media (prefers-reduced-motion: reduce) {
  .banners-widget .banners-slider .banners-controls {
    transition: none;
  }
}
.banners-widget .banners-slider .banners-controls .banner-prev, .banners-widget .banners-slider .banners-controls .banner-next {
  background-color: var(--blurred-background);
  border: none;
  width: 2.25rem;
  height: 2.25rem;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all var(--transition);
  color: var(--text);
  pointer-events: auto;
  opacity: 0.8;
}
@media (max-width: 768px) {
  .banners-widget .banners-slider .banners-controls .banner-prev, .banners-widget .banners-slider .banners-controls .banner-next {
    width: 2rem;
    height: 2rem;
    opacity: 0.9;
  }
}
@media (prefers-reduced-motion: reduce) {
  .banners-widget .banners-slider .banners-controls .banner-prev, .banners-widget .banners-slider .banners-controls .banner-next {
    transition: none;
  }
}
.banners-widget .banners-slider .banners-controls .banner-prev:hover, .banners-widget .banners-slider .banners-controls .banner-next:hover {
  background-color: var(--accent);
  color: var(--background);
  opacity: 1;
  transform: scale(1.05);
}
.banners-widget .banners-slider .banners-controls .banner-prev:active, .banners-widget .banners-slider .banners-controls .banner-next:active {
  transform: scale(0.95);
}
.banners-widget .banners-slider .banners-controls .banner-prev:focus-visible, .banners-widget .banners-slider .banners-controls .banner-next:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}
.banners-widget .banners-slider .banners-controls .banner-prev svg, .banners-widget .banners-slider .banners-controls .banner-next svg {
  width: 1.25rem;
  height: 1.25rem;
}
@media (max-width: 768px) {
  .banners-widget .banners-slider .banners-controls .banner-prev svg, .banners-widget .banners-slider .banners-controls .banner-next svg {
    width: 1rem;
    height: 1rem;
  }
}
.banners-widget .banners-slider .banners-indicators {
  position: absolute;
  bottom: var(--space-md);
  display: flex;
  left: 50%;
  right: 0;
  transform: translateX(-50%);
  justify-content: center;
  gap: var(--space-xs);
  pointer-events: auto;
  z-index: 15;
  background-color: var(--blurred-background);
  padding: var(--space-xs) var(--space-sm);
  border-radius: var(--border1);
  width: min-content;
  opacity: 0.9;
}
@media (max-width: 768px) {
  .banners-widget .banners-slider .banners-indicators {
    bottom: var(--space-sm);
    padding: var(--space-xs);
    gap: calc(var(--space-xs) * 0.75);
  }
}
.banners-widget .banners-slider .banners-indicators .banner-indicator {
  width: 0.375rem;
  height: 0.375rem;
  border-radius: 50%;
  background-color: rgba(255, 255, 255, 0.4);
  opacity: 0.7;
  border: none;
  padding: 0;
  cursor: pointer;
  transition: all var(--transition);
  margin: 0;
}
@media (max-width: 768px) {
  .banners-widget .banners-slider .banners-indicators .banner-indicator {
    width: 0.3rem;
    height: 0.3rem;
  }
}
@media (prefers-reduced-motion: reduce) {
  .banners-widget .banners-slider .banners-indicators .banner-indicator {
    transition: none;
  }
}
.banners-widget .banners-slider .banners-indicators .banner-indicator.active {
  opacity: 1;
  background-color: var(--accent);
  transform: scale(1.4);
}
@media (max-width: 768px) {
  .banners-widget .banners-slider .banners-indicators .banner-indicator.active {
    transform: scale(1.3);
  }
}
.banners-widget .banners-slider .banners-indicators .banner-indicator:hover:not(.active) {
  opacity: 0.9;
  transform: scale(1.2);
  background-color: rgba(255, 255, 255, 0.6);
}
.banners-widget .banners-slider .banners-indicators .banner-indicator:focus-visible {
  outline: 1px solid var(--accent);
  outline-offset: 1px;
}
.banners-widget .banners-slider .banner-progress-timer {
  position: absolute;
  top: var(--space-md);
  right: var(--space-md);
  z-index: 20;
  opacity: 0.9;
}
@media (max-width: 768px) {
  .banners-widget .banners-slider .banner-progress-timer {
    top: var(--space-sm);
    right: var(--space-sm);
  }
}
.banners-widget .banners-slider .banner-progress-timer .progress-circle {
  background-color: var(--blurred-background);
  border-radius: 50%;
  position: relative;
  width: 36px;
  height: 36px;
}
@media (max-width: 768px) {
  .banners-widget .banners-slider .banner-progress-timer .progress-circle {
    width: 32px;
    height: 32px;
  }
}
.banners-widget .banners-slider .banner-progress-timer .progress-circle svg {
  width: 100%;
  height: 100%;
  transform: rotate(-90deg);
  filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.2));
}
.banners-widget .banners-slider .banner-progress-timer .progress-circle svg .progress-path {
  color: var(--accent);
  transition: stroke-dashoffset linear;
  will-change: stroke-dashoffset;
}
.banners-widget .banners-slider .banner-progress-timer .progress-circle .progress-text {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: flex;
  align-items: center;
  justify-content: center;
}
.banners-widget .banners-slider .banner-progress-timer .progress-circle .progress-text .progress-count {
  font-size: 0.7rem;
  font-weight: 500;
  color: var(--text);
  min-width: 1ch;
  text-align: center;
}
@media (max-width: 768px) {
  .banners-widget .banners-slider .banner-progress-timer .progress-circle .progress-text .progress-count {
    font-size: 0.65rem;
  }
}
.banners-settings-form {
  max-height: 100%;
}
.banners-settings-form .settings-section {
  margin-bottom: var(--space-lg);
  padding-bottom: var(--space-lg);
  border-bottom: 1px solid var(--transp-2);
}
.banners-settings-form .settings-section:last-child {
  margin-bottom: 0;
  padding-bottom: 0;
  border-bottom: none;
}
.banners-settings-form .settings-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-md);
}
@media (max-width: 768px) {
  .banners-settings-form .settings-row {
    grid-template-columns: 1fr;
  }
}
.banners-settings-form .settings-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-md);
}
.banners-settings-form .settings-header .section-title {
  font-size: var(--h5);
  font-weight: 600;
  margin: 0;
}
.banners-settings-form .settings-header .btn-add {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
  padding: var(--space-xs) var(--space-md);
  background-color: var(--accent);
  color: var(--background);
  border-radius: var(--border05);
  transition: all var(--transition);
  font-size: var(--p-small);
  font-weight: 500;
}
@media (prefers-reduced-motion: reduce) {
  .banners-settings-form .settings-header .btn-add {
    transition: none;
  }
}
.banners-settings-form .settings-header .btn-add:hover {
  background-color: var(--accent-400);
  transform: translateY(-1px);
}
.banners-settings-form .settings-header .btn-add:active {
  transform: translateY(0);
}
.banners-settings-form .settings-header .btn-add:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}
.banners-settings-form .settings-header .btn-add svg {
  width: 1.25em;
  height: 1.25em;
}
.banners-settings-form .banners-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  margin-bottom: var(--space-md);
  max-height: min(55vh, 1000px);
  min-height: 200px;
  overflow-y: auto;
  overflow-x: hidden;
}
.banners-settings-form .banners-list .banner-item {
  background-color: var(--transp-05);
  border-radius: var(--border05);
  padding: var(--space-md);
  transition: all var(--transition);
  position: relative;
  border: 1px solid var(--transp-2);
}
@media (prefers-reduced-motion: reduce) {
  .banners-settings-form .banners-list .banner-item {
    transition: none;
  }
}
.banners-settings-form .banners-list .banner-item:hover {
  background-color: var(--transp-1);
}
.banners-settings-form .banners-list .banner-item .banner-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-md);
}
.banners-settings-form .banners-list .banner-item .banner-header .banner-title {
  margin: 0;
  font-size: var(--h6);
  font-weight: 500;
}
.banners-settings-form .banners-list .banner-item .banner-header .btn-remove-banner {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border-radius: 50%;
  background-color: var(--transp-2);
  color: var(--error);
  transition: all var(--transition);
}
@media (prefers-reduced-motion: reduce) {
  .banners-settings-form .banners-list .banner-item .banner-header .btn-remove-banner {
    transition: none;
  }
}
.banners-settings-form .banners-list .banner-item .banner-header .btn-remove-banner:hover {
  background-color: var(--error-light);
  transform: scale(1.05);
}
.banners-settings-form .banners-list .banner-item .banner-header .btn-remove-banner:active {
  transform: scale(1);
}
.banners-settings-form .banners-list .banner-item .banner-header .btn-remove-banner:focus-visible {
  outline: 2px solid var(--error);
  outline-offset: 2px;
}
.banners-settings-form .banners-list .banner-item .banner-header .btn-remove-banner svg {
  width: 1.25em;
  height: 1.25em;
}
.banners-settings-form .banners-list .banner-item .banner-inputs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-md);
}
@media (max-width: 992px) {
  .banners-settings-form .banners-list .banner-item .banner-inputs {
    grid-template-columns: 1fr;
  }
}
.banners-settings-form .banners-list .banner-item .banner-inputs .banner-col {
  display: flex;
  flex-direction: column;
}
.banners-settings-form .banners-list .banner-item .banner-image-upload {
  position: relative;
}
.banners-settings-form .banners-list .banner-item .banner-image-upload .image-upload-actions {
  display: flex;
  gap: var(--space-xs);
  margin-top: var(--space-xs);
}
.banners-settings-form .banners-list .banner-item .banner-image-upload .image-upload-actions .btn-upload svg {
  width: 1em;
  height: 1em;
}
.banners-settings-form .banners-list .banner-item .banner-image-upload .upload-progress {
  margin-top: var(--space-xs);
  padding: var(--space-xs);
  background-color: var(--transp-05);
  border-radius: var(--border05);
}
.banners-settings-form .banners-list .banner-item .banner-image-upload .upload-progress .progress-bar {
  width: 100%;
  height: 0.25rem;
  background-color: var(--transp-2);
  border-radius: var(--border05);
  overflow: hidden;
  margin-bottom: var(--space-xs);
}
.banners-settings-form .banners-list .banner-item .banner-image-upload .upload-progress .progress-bar .progress-fill {
  height: 100%;
  background-color: var(--accent);
  transition: width 0.3s ease;
  border-radius: var(--border05);
}
.banners-settings-form .banners-list .banner-item .banner-image-upload .upload-progress .progress-text {
  font-size: var(--p-small);
  color: var(--text-muted);
}
.banners-settings-form .banners-list .banner-item .banner-image-upload .image-preview {
  position: relative;
  margin-top: var(--space-sm);
  border-radius: var(--border05);
  overflow: hidden;
  border: 1px solid var(--transp-2);
  max-width: 200px;
}
.banners-settings-form .banners-list .banner-item .banner-image-upload .image-preview img {
  width: 100%;
  height: 100px;
  object-fit: cover;
  display: block;
}
.banners-settings-form .banners-list .banner-item .banner-image-upload .image-preview .btn-remove-preview {
  position: absolute;
  top: var(--space-xs);
  right: var(--space-xs);
  width: 1.5rem;
  height: 1.5rem;
  background-color: rgba(0, 0, 0, 0.7);
  color: white;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--transition);
}
@media (prefers-reduced-motion: reduce) {
  .banners-settings-form .banners-list .banner-item .banner-image-upload .image-preview .btn-remove-preview {
    transition: none;
  }
}
.banners-settings-form .banners-list .banner-item .banner-image-upload .image-preview .btn-remove-preview:hover {
  background-color: var(--error);
  transform: scale(1.1);
}
.banners-settings-form .banners-list .banner-item .banner-image-upload .image-preview .btn-remove-preview:active {
  transform: scale(1);
}
.banners-settings-form .banners-list .banner-item .banner-image-upload .image-preview .btn-remove-preview svg {
  width: 0.875rem;
  height: 0.875rem;
}
@media (prefers-reduced-motion: reduce) {
  .banners-slider * {
    transition-duration: 0.01ms !important;
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
  }
}
:root {
  --blog-sidebar-width: 280px;
  --blog-content-max: 860px;
  --blog-radius-sm: 8px;
  --blog-radius-md: 12px;
  --blog-radius-lg: 16px;
  --blog-radius-full: 9999px;
  --blog-blur: 20px;
  --blog-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.08), 0 4px 6px -2px rgba(0, 0, 0, 0.04);
  --blog-glass-bg: rgba(255, 255, 255, 0.6);
  --blog-glass-border: rgba(255, 255, 255, 0.2);
}
:root[data-theme=dark] {
  --blog-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.35), 0 4px 6px -2px rgba(0, 0, 0, 0.2);
  --blog-glass-bg: rgba(28, 28, 30, 0.75);
  --blog-glass-border: rgba(255, 255, 255, 0.08);
}
.blog-index .blog-header, .blog-category .blog-header, .blog-search-page .blog-header, .blog-article .blog-header {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 24px;
}
.blog-index .blog-search__summary, .blog-category .blog-search__summary, .blog-search-page .blog-search__summary, .blog-article .blog-search__summary {
  font-size: 13px;
  color: var(--text-500);
}
.blog-index .blog-grid, .blog-category .blog-grid, .blog-search-page .blog-grid, .blog-article .blog-grid {
  display: grid;
  grid-template-columns: var(--blog-sidebar-width) minmax(0, 1fr);
  gap: 32px;
}
.blog-index .blog-index-layout, .blog-category .blog-index-layout, .blog-search-page .blog-index-layout, .blog-article .blog-index-layout {
  display: grid;
  grid-template-columns: var(--blog-sidebar-width) minmax(0, 1fr);
  gap: 32px;
  align-items: start;
}
.blog-index .blog-index-main, .blog-category .blog-index-main, .blog-search-page .blog-index-main, .blog-article .blog-index-main {
  min-width: 0;
}
.blog-index .blog-categories-box, .blog-category .blog-categories-box, .blog-search-page .blog-categories-box, .blog-article .blog-categories-box {
  background: var(--blog-glass-bg);
  border: 1px solid var(--transp-1);
  border-radius: var(--blog-radius-lg);
  padding: 16px;
  position: sticky;
  top: 80px;
}
.blog-index .blog-categories-box__title, .blog-category .blog-categories-box__title, .blog-search-page .blog-categories-box__title, .blog-article .blog-categories-box__title {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-500);
  margin-bottom: 12px;
}
.blog-index .blog-categories-box__list, .blog-category .blog-categories-box__list, .blog-search-page .blog-categories-box__list, .blog-article .blog-categories-box__list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.blog-index .blog-category-btn, .blog-category .blog-category-btn, .blog-search-page .blog-category-btn, .blog-article .blog-category-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 12px;
  border-radius: var(--blog-radius-sm);
  border: 1px solid var(--transp-1);
  background: var(--transp-05);
  color: var(--text-300);
  text-decoration: none;
  transition: background 0.15s ease, color 0.15s ease;
}
.blog-index .blog-category-btn:hover, .blog-category .blog-category-btn:hover, .blog-search-page .blog-category-btn:hover, .blog-article .blog-category-btn:hover {
  background: var(--transp-1);
  color: var(--text);
}
.blog-index .blog-category-latest-grid, .blog-category .blog-category-latest-grid, .blog-search-page .blog-category-latest-grid, .blog-article .blog-category-latest-grid {
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.blog-index .blog-category-latest, .blog-category .blog-category-latest, .blog-search-page .blog-category-latest, .blog-article .blog-category-latest {
  padding: 16px;
  border-radius: var(--blog-radius-lg);
  border: 1px solid var(--transp-1);
  background: var(--transp-05);
}
.blog-index .blog-category-latest__header, .blog-category .blog-category-latest__header, .blog-search-page .blog-category-latest__header, .blog-article .blog-category-latest__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}
.blog-index .blog-category-latest__header h2, .blog-category .blog-category-latest__header h2, .blog-search-page .blog-category-latest__header h2, .blog-article .blog-category-latest__header h2 {
  font-size: 18px;
  margin: 0;
}
.blog-index .blog-category-latest__link, .blog-category .blog-category-latest__link, .blog-search-page .blog-category-latest__link, .blog-article .blog-category-latest__link {
  font-size: 12px;
  color: var(--text-500);
  text-decoration: none;
}
.blog-index .blog-page, .blog-category .blog-page, .blog-search-page .blog-page, .blog-article .blog-page {
  display: grid;
  grid-template-columns: var(--blog-sidebar-width) minmax(0, 1fr);
  gap: 32px;
}
.blog-index .blog-main, .blog-category .blog-main, .blog-search-page .blog-main, .blog-article .blog-main {
  min-width: 0;
}
.blog-index .blog-content-wrapper, .blog-category .blog-content-wrapper, .blog-search-page .blog-content-wrapper, .blog-article .blog-content-wrapper {
  display: flex;
  gap: 24px;
}
.blog-index .blog-content, .blog-category .blog-content, .blog-search-page .blog-content, .blog-article .blog-content {
  flex: 1;
  min-width: 0;
  max-width: var(--blog-content-max);
}
.blog-index .blog-article-layout, .blog-category .blog-article-layout, .blog-search-page .blog-article-layout, .blog-article .blog-article-layout {
  display: grid;
  grid-template-columns: minmax(0, 220px) minmax(0, 1fr) minmax(0, 260px);
  gap: 28px;
  align-items: start;
}
.blog-index .blog-article-left, .blog-index .blog-article-side, .blog-category .blog-article-left, .blog-category .blog-article-side, .blog-search-page .blog-article-left, .blog-search-page .blog-article-side, .blog-article .blog-article-left, .blog-article .blog-article-side {
  position: sticky;
  top: 90px;
  height: fit-content;
}
.blog-index .blog-article-back, .blog-category .blog-article-back, .blog-search-page .blog-article-back, .blog-article .blog-article-back {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 10px 14px;
  border-radius: var(--blog-radius-full);
  border: 1px solid var(--transp-2);
  background: linear-gradient(180deg, var(--transp-05) 0%, rgba(255, 255, 255, 0.01) 100%);
  color: var(--text);
  text-decoration: none;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.01em;
  box-shadow: 0 10px 22px -18px rgba(0, 0, 0, 0.55);
  transition: transform 0.15s ease, border-color 0.15s ease, background 0.15s ease, box-shadow 0.15s ease;
  margin-bottom: 16px;
}
.blog-index .blog-article-back svg, .blog-category .blog-article-back svg, .blog-search-page .blog-article-back svg, .blog-article .blog-article-back svg {
  width: 14px;
  height: 14px;
  opacity: 0.8;
  flex-shrink: 0;
}
.blog-index .blog-article-back:hover, .blog-category .blog-article-back:hover, .blog-search-page .blog-article-back:hover, .blog-article .blog-article-back:hover {
  transform: translateY(-1px);
  border-color: var(--transp-3);
  background: linear-gradient(180deg, var(--transp-1) 0%, var(--transp-05) 100%);
  box-shadow: 0 14px 26px -18px rgba(0, 0, 0, 0.7);
}
.blog-index .blog-article-main, .blog-category .blog-article-main, .blog-search-page .blog-article-main, .blog-article .blog-article-main {
  min-width: 0;
}
.blog-index .blog-article-latest__title, .blog-category .blog-article-latest__title, .blog-search-page .blog-article-latest__title, .blog-article .blog-article-latest__title {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-500);
  margin-bottom: 12px;
}
.blog-index .blog-article-latest__list, .blog-category .blog-article-latest__list, .blog-search-page .blog-article-latest__list, .blog-article .blog-article-latest__list {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.blog-index .blog-related-empty, .blog-category .blog-related-empty, .blog-search-page .blog-related-empty, .blog-article .blog-related-empty {
  font-size: 12px;
  color: var(--text-500);
}
.blog-index .blog-toc, .blog-category .blog-toc, .blog-search-page .blog-toc, .blog-article .blog-toc {
  width: 100%;
  min-width: 0;
  position: static;
  height: fit-content;
  max-height: calc(100vh - 140px);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
}
.blog-index .blog-toc__title, .blog-category .blog-toc__title, .blog-search-page .blog-toc__title, .blog-article .blog-toc__title {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-500);
  margin-bottom: 12px;
}
.blog-index .blog-toc__title svg, .blog-category .blog-toc__title svg, .blog-search-page .blog-toc__title svg, .blog-article .blog-toc__title svg {
  width: 12px;
  height: 12px;
  opacity: 0.6;
}
.blog-index .blog-toc__list, .blog-category .blog-toc__list, .blog-search-page .blog-toc__list, .blog-article .blog-toc__list {
  list-style: none;
  padding: 0 0 0 12px;
  margin: 0;
  overflow-y: auto;
  flex: 1;
  position: relative;
}
.blog-index .blog-toc__list::before, .blog-category .blog-toc__list::before, .blog-search-page .blog-toc__list::before, .blog-article .blog-toc__list::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 1px;
  background: var(--transp-1);
}
.blog-index .blog-toc__item, .blog-category .blog-toc__item, .blog-search-page .blog-toc__item, .blog-article .blog-toc__item {
  margin-bottom: 0;
}
.blog-index .blog-toc__link, .blog-category .blog-toc__link, .blog-search-page .blog-toc__link, .blog-article .blog-toc__link {
  display: block;
  font-size: 12px;
  color: var(--text-500);
  line-height: 1.5;
  cursor: pointer;
  padding: 4px 0;
  position: relative;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.blog-index .blog-toc__link::before, .blog-category .blog-toc__link::before, .blog-search-page .blog-toc__link::before, .blog-article .blog-toc__link::before {
  content: "";
  position: absolute;
  left: -12px;
  top: 50%;
  transform: translateY(-50%);
  width: 1px;
  height: 0;
  background: var(--accent);
  transition: height 0.15s ease;
}
.blog-index .blog-toc__link:hover, .blog-category .blog-toc__link:hover, .blog-search-page .blog-toc__link:hover, .blog-article .blog-toc__link:hover {
  color: var(--accent);
}
.blog-index .blog-toc__link--active, .blog-category .blog-toc__link--active, .blog-search-page .blog-toc__link--active, .blog-article .blog-toc__link--active {
  color: var(--accent);
  font-weight: 500;
}
.blog-index .blog-toc__link--active::before, .blog-category .blog-toc__link--active::before, .blog-search-page .blog-toc__link--active::before, .blog-article .blog-toc__link--active::before {
  height: 16px;
}
.blog-index .blog-toc__link--h3, .blog-category .blog-toc__link--h3, .blog-search-page .blog-toc__link--h3, .blog-article .blog-toc__link--h3 {
  padding-left: 12px;
  font-size: 11px;
  color: var(--text-500);
}
.blog-index .blog-toc__link--h3::before, .blog-category .blog-toc__link--h3::before, .blog-search-page .blog-toc__link--h3::before, .blog-article .blog-toc__link--h3::before {
  left: 0;
}
.blog-index .blog-last-updated, .blog-category .blog-last-updated, .blog-search-page .blog-last-updated, .blog-article .blog-last-updated {
  margin-top: 20px;
  padding-top: 16px;
  border-top: 1px solid var(--transp-1);
  flex-shrink: 0;
}
.blog-index .blog-last-updated__title, .blog-category .blog-last-updated__title, .blog-search-page .blog-last-updated__title, .blog-article .blog-last-updated__title {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-500);
  margin-bottom: 10px;
}
.blog-index .blog-update-item, .blog-category .blog-update-item, .blog-search-page .blog-update-item, .blog-article .blog-update-item {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 12px;
  color: var(--text);
  cursor: pointer;
  text-decoration: none;
  transition: opacity 0.15s ease;
}
.blog-index .blog-update-item:hover, .blog-category .blog-update-item:hover, .blog-search-page .blog-update-item:hover, .blog-article .blog-update-item:hover {
  opacity: 0.8;
}
.blog-index .blog-update-item__avatar, .blog-category .blog-update-item__avatar, .blog-search-page .blog-update-item__avatar, .blog-article .blog-update-item__avatar {
  width: 26px;
  height: 26px;
  border-radius: var(--blog-radius-sm);
  object-fit: cover;
  flex-shrink: 0;
}
.blog-index .blog-update-item__avatar--placeholder, .blog-category .blog-update-item__avatar--placeholder, .blog-search-page .blog-update-item__avatar--placeholder, .blog-article .blog-update-item__avatar--placeholder {
  background: var(--transp-1);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 9px;
  font-weight: 600;
  color: var(--text);
}
.blog-index .blog-update-item__info, .blog-category .blog-update-item__info, .blog-search-page .blog-update-item__info, .blog-article .blog-update-item__info {
  display: flex;
  flex-direction: column;
  gap: 1px;
  min-width: 0;
}
.blog-index .blog-update-item__author, .blog-category .blog-update-item__author, .blog-search-page .blog-update-item__author, .blog-article .blog-update-item__author {
  font-weight: 500;
  color: var(--text);
  font-size: 11px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.blog-index .blog-update-item__date, .blog-category .blog-update-item__date, .blog-search-page .blog-update-item__date, .blog-article .blog-update-item__date {
  font-size: 10px;
  color: var(--text-500);
}
.blog-index .blog-preview-notice, .blog-category .blog-preview-notice, .blog-search-page .blog-preview-notice, .blog-article .blog-preview-notice {
  padding: 12px 14px;
  border-radius: var(--blog-radius-md);
  border: 1px solid rgba(255, 180, 0, 0.35);
  background: rgba(255, 180, 0, 0.08);
  margin-bottom: 16px;
}
.blog-index .blog-article-divider, .blog-category .blog-article-divider, .blog-search-page .blog-article-divider, .blog-article .blog-article-divider {
  height: 1px;
  background: var(--transp-1);
  margin: 32px 0;
}
.blog-index .blog-article-header, .blog-category .blog-article-header, .blog-search-page .blog-article-header, .blog-article .blog-article-header {
  margin-bottom: 32px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--transp-1);
}
.blog-index .blog-article__category, .blog-category .blog-article__category, .blog-search-page .blog-article__category, .blog-article .blog-article__category {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  background: var(--transp-05);
  border: 1px solid var(--transp-1);
  border-radius: var(--blog-radius-full);
  font-size: 12px;
  font-weight: 500;
  color: var(--text);
  text-decoration: none;
}
.blog-index .blog-article__info, .blog-category .blog-article__info, .blog-search-page .blog-article__info, .blog-article .blog-article__info {
  display: flex;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
  font-size: 13px;
  color: var(--text-500);
}
.blog-index .blog-article__info-item, .blog-category .blog-article__info-item, .blog-search-page .blog-article__info-item, .blog-article .blog-article__info-item {
  display: flex;
  align-items: center;
  gap: 6px;
}
.blog-index .blog-article__info-item svg, .blog-category .blog-article__info-item svg, .blog-search-page .blog-article__info-item svg, .blog-article .blog-article__info-item svg {
  opacity: 0.6;
  width: 14px;
  height: 14px;
}
.blog-index .blog-article__author, .blog-category .blog-article__author, .blog-search-page .blog-article__author, .blog-article .blog-article__author {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  text-decoration: none;
  color: var(--text);
}
.blog-index .blog-article__author-avatar, .blog-category .blog-article__author-avatar, .blog-search-page .blog-article__author-avatar, .blog-article .blog-article__author-avatar {
  width: 24px;
  height: 24px;
  border-radius: var(--blog-radius-sm);
  object-fit: cover;
}
.blog-index .blog-article__author-avatar--placeholder, .blog-category .blog-article__author-avatar--placeholder, .blog-search-page .blog-article__author-avatar--placeholder, .blog-article .blog-article__author-avatar--placeholder {
  background: var(--transp-1);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 9px;
  font-weight: 600;
  color: var(--text);
}
.blog-index .blog-article__author-name, .blog-category .blog-article__author-name, .blog-search-page .blog-article__author-name, .blog-article .blog-article__author-name {
  font-size: 13px;
  font-weight: 500;
  color: var(--text);
}
.blog-index .blog-article__title, .blog-category .blog-article__title, .blog-search-page .blog-article__title, .blog-article .blog-article__title {
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  font-weight: 700;
  color: var(--text);
  line-height: 1.2;
  margin-bottom: 12px;
}
.blog-index .blog-article__description, .blog-category .blog-article__description, .blog-search-page .blog-article__description, .blog-article .blog-article__description {
  font-size: 1.05rem;
  color: var(--text);
  line-height: 1.7;
  margin-bottom: 20px;
}
.blog-index .blog-code-wrapper, .blog-category .blog-code-wrapper, .blog-search-page .blog-code-wrapper, .blog-article .blog-code-wrapper {
  position: relative;
  margin: 24px 0;
  background: var(--secondary);
  border: 1px solid var(--transp-1);
  border-radius: var(--blog-radius-lg);
  overflow: hidden;
}
.blog-index .blog-code-wrapper pre, .blog-category .blog-code-wrapper pre, .blog-search-page .blog-code-wrapper pre, .blog-article .blog-code-wrapper pre {
  margin: 0;
  border: none;
  border-radius: 0;
  background: transparent;
}
.blog-index .blog-code-header, .blog-category .blog-code-header, .blog-search-page .blog-code-header, .blog-article .blog-code-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 14px;
  background: var(--transp-05);
  border-bottom: 1px solid var(--transp-1);
}
.blog-index .blog-code-lang, .blog-category .blog-code-lang, .blog-search-page .blog-code-lang, .blog-article .blog-code-lang {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  font-weight: 500;
  color: var(--text-500);
  text-transform: uppercase;
  letter-spacing: 0.3px;
}
.blog-index .blog-code-copy, .blog-category .blog-code-copy, .blog-search-page .blog-code-copy, .blog-article .blog-code-copy {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 5px 10px;
  background: var(--transp-05);
  border: 1px solid var(--transp-1);
  border-radius: var(--blog-radius-sm);
  font-size: 11px;
  font-weight: 500;
  color: var(--text-500);
  cursor: pointer;
}
.blog-index .blog-code-copy.copied, .blog-category .blog-code-copy.copied, .blog-search-page .blog-code-copy.copied, .blog-article .blog-code-copy.copied {
  color: var(--success);
  border-color: var(--success);
  background: var(--success-light);
}
.blog-index .blog-article__info, .blog-category .blog-article__info, .blog-search-page .blog-article__info, .blog-article .blog-article__info {
  display: flex;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
  font-size: 13px;
  color: var(--text-500);
}
.blog-index .blog-card, .blog-category .blog-card, .blog-search-page .blog-card, .blog-article .blog-card {
  padding: 18px;
  margin-bottom: 16px;
  border-radius: var(--blog-radius-lg);
  border: 1px solid var(--transp-1);
  background: var(--transp-05);
}
.blog-index .blog-card__title a, .blog-category .blog-card__title a, .blog-search-page .blog-card__title a, .blog-article .blog-card__title a {
  color: var(--text);
  text-decoration: none;
}
.blog-index .blog-card__excerpt, .blog-category .blog-card__excerpt, .blog-search-page .blog-card__excerpt, .blog-article .blog-card__excerpt {
  color: var(--text);
}
.blog-index .blog-card__cover img, .blog-index .blog-article__cover img, .blog-category .blog-card__cover img, .blog-category .blog-article__cover img, .blog-search-page .blog-card__cover img, .blog-search-page .blog-article__cover img, .blog-article .blog-card__cover img, .blog-article .blog-article__cover img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: var(--blog-radius-md);
}
.blog-index .pagination, .blog-category .pagination, .blog-search-page .pagination, .blog-article .pagination {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.blog-index .pagination a.active, .blog-category .pagination a.active, .blog-search-page .pagination a.active, .blog-article .pagination a.active {
  font-weight: bold;
}
/* Blog landing (index) */
.blog-landing {
  min-height: calc(100vh - 80px);
  padding-bottom: 80px;
}
.blog-landing__hero {
  position: relative;
  padding: 0;
  text-align: center;
}
.blog-landing__hero::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 800px;
  height: 500px;
  background: radial-gradient(ellipse at center, var(--accent-alpha-1) 0%, transparent 70%);
  pointer-events: none;
  opacity: 0.6;
}
.blog-landing__hero-content {
  position: relative;
  z-index: 1;
  max-width: 580px;
  margin: 0 auto;
  padding: 0 24px;
}
.blog-landing__title {
  font-size: clamp(2.25rem, 5vw, 3rem);
  font-weight: 700;
  color: var(--text);
  letter-spacing: -0.035em;
  line-height: 1.1;
  margin-bottom: 12px;
}
.blog-landing__subtitle {
  font-size: 1.0625rem;
  color: var(--text);
  line-height: 1.6;
  text-align: center;
  margin-bottom: 36px;
}
.blog-landing__search {
  position: relative;
  max-width: 520px;
  margin: 0 auto;
}
.blog-landing__search-box {
  position: relative;
  display: flex;
  align-items: center;
}
.blog-landing__search-icon {
  position: absolute;
  left: 20px;
  width: 20px;
  height: 20px;
  color: var(--text-500);
  pointer-events: none;
}
.blog-landing__search-input {
  width: 100%;
  padding: 18px 100px 18px 54px;
  background: var(--block);
  border: 1px solid var(--transp-1);
  border-radius: 14px;
  font-size: 16px;
  color: var(--text);
  transition: all 0.2s ease;
  box-shadow: 0 2px 16px -4px rgba(0, 0, 0, 0.06);
}
.blog-landing__search-input::placeholder {
  color: var(--text-500);
}
.blog-landing__search-input:hover {
  border-color: var(--transp-2);
}
.blog-landing__search-input:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 2px 16px -4px rgba(0, 0, 0, 0.06), 0 0 0 3px var(--accent-alpha-1);
}
.blog-landing__search-hint {
  position: absolute;
  right: 16px;
  display: flex;
  gap: 4px;
  pointer-events: none;
}
.blog-landing__search-hint kbd {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 24px;
  height: 24px;
  padding: 0 6px;
  background: var(--transp-05);
  border: 1px solid var(--transp-1);
  border-radius: 6px;
  font-size: 11px;
  font-family: inherit;
  color: var(--text-500);
}
.blog-landing__search-results {
  top: calc(100% + 8px);
  border-radius: 12px;
  max-height: 360px;
}
.blog-search__results {
  position: absolute;
  left: 0;
  right: 0;
  background: var(--blog-glass-bg);
  border: 1px solid var(--transp-1);
  border-radius: var(--blog-radius-sm);
  box-shadow: var(--blog-shadow-lg);
  max-height: 280px;
  overflow-y: auto;
  z-index: 200;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-4px);
  transition: opacity 0.15s ease, transform 0.15s ease, visibility 0.15s ease;
}
.blog-search__results--open {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.blog-search__result-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  cursor: pointer;
  transition: background 0.1s ease;
  text-decoration: none;
}
.blog-search__result-item:not(:last-child) {
  border-bottom: 1px solid var(--transp-05);
}
.blog-search__result-item:hover {
  background: var(--transp-05);
}
.blog-search__result-icon {
  color: var(--text-500);
  width: 14px;
  height: 14px;
  flex-shrink: 0;
}
.blog-search__result-content {
  flex: 1;
  min-width: 0;
  text-align: left;
}
.blog-search__result-title {
  font-size: 12px;
  font-weight: 500;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1.4;
}
.blog-search__result-category {
  font-size: 10px;
  color: var(--text-500);
  margin-top: 1px;
  line-height: 1.4;
}
.blog-search__no-results {
  padding: 16px 12px;
  text-align: center;
  color: var(--text-500);
  font-size: 12px;
}
.blog-card__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  font-size: 12px;
  color: var(--text-500);
}
.blog-card__meta .wall-post__avatar {
  width: 35px;
  height: 35px;
  border-radius: 50%;
  overflow: hidden;
  border: 1px solid var(--transp-1);
  flex-shrink: 0;
}
.blog-card__meta .wall-post__avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.blog-card__meta .wall-post__info {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  line-height: 1.4;
}
.blog-card__meta .wall-post__name {
  font-weight: 600;
  color: var(--text);
  text-decoration: none;
  font-size: 12px;
}
.blog-card__meta .wall-post__name:hover {
  text-decoration: underline;
}
.blog-card__meta .blog-card__date {
  font-size: 12px;
  color: var(--text-500);
}
.blog-feed {
  display: flex;
  flex-direction: column;
  gap: 28px;
}
.blog-featured {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
  gap: 24px;
  padding: 20px;
  border-radius: var(--blog-radius-lg);
  border: 1px solid var(--transp-1);
  background: var(--transp-05);
}
.blog-featured__media {
  border-radius: var(--blog-radius-lg);
  overflow: hidden;
  display: block;
  min-height: 100%;
}
.blog-featured__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.blog-featured__body {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.blog-featured__title {
  font-size: clamp(1.6rem, 2.4vw, 2.2rem);
  margin: 0;
}
.blog-featured__title a {
  color: var(--text);
  text-decoration: none;
}
.blog-featured__excerpt {
  color: var(--text);
  line-height: 1.6;
  margin: 0;
}
.blog-featured__link {
  color: var(--text);
  text-decoration: none;
  font-size: 13px;
  font-weight: 600;
  margin-top: auto;
}
.blog-feed-duo, .blog-feed-grid {
  display: grid;
  gap: 20px;
}
.blog-feed-duo {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.blog-feed-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
.blog-feed-card {
  border-radius: var(--blog-radius-lg);
  border: 0;
  background: transparent;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.blog-feed-card__media {
  display: block;
  position: relative;
  width: 100%;
  aspect-ratio: 1.7777777778;
  overflow: hidden;
}
.blog-feed-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.blog-feed-card__body {
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  border: 1px solid var(--transp-1);
  border-top: 0;
  border-radius: 0 0 var(--blog-radius-lg) var(--blog-radius-lg);
  background: var(--transp-05);
}
.blog-feed-card--no-cover .blog-feed-card__body {
  border-top: 1px solid var(--transp-1);
  border-radius: var(--blog-radius-lg);
}
.blog-feed-card__title {
  font-size: 1.1rem;
  margin: 0;
}
.blog-feed-card__title-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}
.blog-feed-card__title-row .blog-feed-card__title {
  flex: 1;
  min-width: 0;
}
.blog-feed-card__draft-badge {
  flex-shrink: 0;
  margin-top: 1px;
  font-size: 11px;
  line-height: 1;
  padding: 5px 9px;
}
.blog-feed-card__title a {
  color: var(--text);
  text-decoration: none;
}
.blog-feed-card__excerpt {
  color: var(--text);
  line-height: 1.5;
  margin: 0;
  font-size: 0.95rem;
}
.blog-feed-grid--info .blog-feed-card, .blog-feed-grid--news .blog-feed-card {
  height: 100%;
}
.blog-feed-grid--info .blog-feed-card__body, .blog-feed-grid--news .blog-feed-card__body {
  flex: 1 1 auto;
}
.blog-feed-grid--info .blog-feed-card__title, .blog-feed-grid--news .blog-feed-card__title {
  line-height: 1.35;
  min-height: calc(1.35em * 2);
  max-height: calc(1.35em * 2);
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}
.blog-feed-grid--info .blog-feed-card__excerpt, .blog-feed-grid--news .blog-feed-card__excerpt {
  min-height: calc(1.5em * 4);
  max-height: calc(1.5em * 4);
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 4;
  overflow: hidden;
}
.blog-feed-card__link {
  color: var(--text);
  text-decoration: none;
  font-size: 13px;
  font-weight: 600;
  margin-top: auto;
  transition: color 0.2s ease;
}
.blog-feed-card__link:hover, .blog-feed-card__link:focus-visible {
  color: var(--accent);
}
.blog-feed-card__meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  min-width: 0;
}
.blog-feed-card__meta .blog-article__author {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex: 1;
  min-width: 0;
  text-decoration: none;
  color: var(--text);
}
.blog-feed-card__meta .blog-article__author-avatar {
  width: 24px;
  height: 24px;
  border-radius: var(--blog-radius-sm);
  object-fit: cover;
  flex-shrink: 0;
}
.blog-feed-card__meta .blog-article__author-avatar--placeholder {
  background: var(--transp-1);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 9px;
  font-weight: 600;
  color: var(--text);
}
.blog-feed-card__meta .blog-article__author-name {
  font-size: 13px;
  font-weight: 500;
  color: var(--text);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.blog-feed-card__meta-date {
  flex-shrink: 0;
  font-size: 12px;
  color: var(--text-500);
  white-space: nowrap;
}
.blog-feed-card__footer {
  margin-top: auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.blog-feed-card__likes {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--text-500);
  font-size: 12px;
}
.blog-feed-card__likes svg {
  width: 14px;
  height: 14px;
}
.blog-feed-card__stats {
  display: inline-flex;
  align-items: center;
  gap: 12px;
}
.blog-feed-card__views {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--text-500);
  font-size: 12px;
}
.blog-feed-card__views svg {
  width: 14px;
  height: 14px;
}
.blog-feed-card--compact .blog-feed-card__body {
  padding: 14px;
}
.blog-widget {
  overflow: visible;
}
.blog-widget__header {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: var(--space-sm);
}
.blog-widget__title {
  margin: 0;
  font-size: calc(var(--h6) + 2px);
  font-weight: 600;
  color: var(--text);
}
.blog-widget--recent {
  border: 0;
  background: transparent;
  box-shadow: none;
}
.blog-widget--recent .card-header {
  padding: 0 0 12px;
  border-bottom: 0;
}
.blog-widget--recent .card-body {
  padding: 0;
}
.blog-widget__list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}
.blog-pagination {
  margin-top: 36px;
  display: flex;
  justify-content: center;
}
.blog-category-layout {
  display: grid;
  grid-template-columns: var(--blog-sidebar-width) minmax(0, 1fr);
  gap: 32px;
  align-items: start;
}
.blog-categories-panel {
  background: var(--blog-glass-bg);
  border: 1px solid var(--transp-1);
  border-radius: var(--blog-radius-lg);
  padding: 16px;
  position: sticky;
  top: 80px;
}
.blog-categories-panel__search {
  position: relative;
  margin-bottom: 16px;
}
.blog-categories-panel__title {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-500);
  margin-bottom: 12px;
}
.blog-categories-panel__list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.blog-category-btn {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 8px 12px;
  border-radius: var(--blog-radius-sm);
  border: 1px solid var(--transp-1);
  background: var(--transp-05);
  color: var(--text-300);
  text-decoration: none;
  transition: background 0.15s ease, color 0.15s ease;
}
.blog-category-btn__count {
  font-size: 11px;
  padding: 2px 6px;
  border-radius: var(--blog-radius-full);
  background: var(--transp-05);
  color: var(--text-500);
}
.blog-category-btn:hover, .blog-category-btn.is-active {
  background: var(--transp-1);
  color: var(--text);
}
.blog-category-content {
  min-width: 0;
}
.blog-category-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 20px 24px;
  background: var(--block);
  border: 1px solid var(--transp-1);
  border-radius: 16px 16px 0 0;
  border-bottom: none;
}
.blog-category-header h2 {
  font-size: 17px;
  font-weight: 600;
  color: var(--text);
  margin: 0 0 4px;
}
.blog-category-header p {
  font-size: 13px;
  color: var(--text);
  margin: 0;
}
.blog-category-header__count {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-500);
  background: var(--transp-1);
  padding: 4px 12px;
  border-radius: 20px;
}
.blog-category-articles {
  background: var(--block);
  border: 1px solid var(--transp-1);
  border-radius: 0 0 16px 16px;
  overflow: hidden;
}
.blog-article-row {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 16px 24px;
  text-decoration: none;
  transition: background 0.15s ease;
  border-bottom: 1px solid var(--transp-05);
}
.blog-article-row:last-child {
  border-bottom: none;
}
.blog-article-row:hover {
  background: var(--transp-05);
}
.blog-article-row__content {
  flex: 1;
  min-width: 0;
}
.blog-article-row__title {
  font-size: 15px;
  font-weight: 500;
  color: var(--text);
  margin-bottom: 2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.blog-article-row__desc {
  font-size: 13px;
  color: var(--text);
  line-height: 1.4;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.blog-article-row__arrow {
  width: 18px;
  height: 18px;
  color: var(--text);
  opacity: 0.4;
  flex-shrink: 0;
  transition: all 0.2s ease;
}
.blog-landing__empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 80px 24px;
  text-align: center;
}
.blog-landing__empty svg {
  width: 56px;
  height: 56px;
  color: var(--text-500);
  opacity: 0.4;
  margin-bottom: 20px;
}
.blog-landing__empty h3 {
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 6px;
}
.blog-info-wiki {
  margin-top: 52px;
}
.blog-info-news-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.blog-info-news-head--back {
  justify-content: flex-start;
}
.blog-info-news-head__all {
  margin-bottom: 16px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
  text-decoration: none;
  transition: color 0.2s ease;
}
.blog-info-news-head__all svg {
  width: 14px;
  height: 14px;
  transition: color 0.2s ease, transform 0.2s ease;
}
.blog-info-news-head__all:hover, .blog-info-news-head__all:focus-visible {
  color: var(--accent);
}
.blog-info-news-head__all:hover svg, .blog-info-news-head__all:focus-visible svg {
  transform: translateX(2px);
}
.blog-info-news-head__all--back svg {
  transform: none;
}
.blog-info-news-head__all--back:hover svg, .blog-info-news-head__all--back:focus-visible svg {
  transform: translateX(-2px);
}
.blog-article-content.md-content {
  font-size: 15px;
  line-height: 1.8;
  color: var(--text);
}
.blog-article-content.md-content p, .blog-article-content.md-content li, .blog-article-content.md-content blockquote, .blog-article-content.md-content code, .blog-article-content.md-content pre {
  font-size: inherit;
  color: var(--text-300);
}
.blog-article-content.md-content .blog-ta-left {
  text-align: left;
}
.blog-article-content.md-content .blog-ta-center {
  text-align: center;
}
.blog-article-content.md-content .blog-ta-right {
  text-align: right;
}
.blog-article-content.md-content .blog-ta-justify {
  text-align: justify;
}
@media (max-width: 768px) {
  .blog-feed-duo, .blog-feed-grid {
    grid-template-columns: 1fr;
  }
  .blog-landing__hero {
    padding: 48px 0 40px;
  }
  .blog-landing__title {
    font-size: 1.875rem;
  }
  .blog-landing__subtitle {
    font-size: 1rem;
    margin-bottom: 28px;
  }
  .blog-landing__search-input {
    padding: 16px 16px 16px 48px;
    font-size: 15px;
    border-radius: 12px;
  }
  .blog-landing__search-icon {
    left: 16px;
    width: 18px;
    height: 18px;
  }
  .blog-landing__search-hint {
    display: none;
  }
  .blog-info-news-head {
    align-items: flex-end;
  }
  .blog-category-header {
    padding: 16px 20px;
    gap: 12px;
  }
  .blog-article-row {
    padding: 14px 20px;
  }
}
@media (max-width: 900px) {
  .blog-featured {
    grid-template-columns: 1fr;
  }
  .blog-featured__media {
    aspect-ratio: 1.7777777778;
    min-height: auto;
  }
  .blog-feed-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .blog-index .blog-grid, .blog-index .blog-page, .blog-index .blog-index-layout, .blog-category .blog-grid, .blog-category .blog-page, .blog-category .blog-index-layout, .blog-search-page .blog-grid, .blog-search-page .blog-page, .blog-search-page .blog-index-layout, .blog-article .blog-grid, .blog-article .blog-page, .blog-article .blog-index-layout {
    grid-template-columns: 1fr;
  }
  .blog-index .blog-categories-box, .blog-category .blog-categories-box, .blog-search-page .blog-categories-box, .blog-article .blog-categories-box {
    position: static;
  }
  .blog-index .blog-toc, .blog-category .blog-toc, .blog-search-page .blog-toc, .blog-article .blog-toc {
    position: static;
    width: 100%;
    min-width: 0;
    max-height: none;
  }
  .blog-index .blog-category-layout, .blog-category .blog-category-layout, .blog-search-page .blog-category-layout, .blog-article .blog-category-layout {
    grid-template-columns: 1fr;
  }
  .blog-index .blog-categories-panel, .blog-category .blog-categories-panel, .blog-search-page .blog-categories-panel, .blog-article .blog-categories-panel {
    position: static;
    width: 100%;
  }
  .blog-index .blog-article-layout, .blog-category .blog-article-layout, .blog-search-page .blog-article-layout, .blog-article .blog-article-layout {
    grid-template-columns: 1fr;
  }
  .blog-index .blog-article-left, .blog-index .blog-article-side, .blog-category .blog-article-left, .blog-category .blog-article-side, .blog-search-page .blog-article-left, .blog-search-page .blog-article-side, .blog-article .blog-article-left, .blog-article .blog-article-side {
    position: static;
    width: 100%;
  }
  .blog-index .blog-article-main, .blog-category .blog-article-main, .blog-search-page .blog-article-main, .blog-article .blog-article-main {
    order: 0;
  }
  .blog-index .blog-article-left, .blog-category .blog-article-left, .blog-search-page .blog-article-left, .blog-article .blog-article-left {
    order: 1;
  }
  .blog-index .blog-article-side, .blog-category .blog-article-side, .blog-search-page .blog-article-side, .blog-article .blog-article-side {
    order: 2;
  }
}
@media (max-width: 900px) {
  .blog-category-layout {
    grid-template-columns: 1fr;
  }
  .blog-categories-panel {
    position: static;
    width: 100%;
  }
}
@media (max-width: 900px) {
  .blog-feed-grid--info {
    grid-template-columns: 1fr;
  }
}
/* Wiki-style article view for Blog */
.blog-article {
  --blog-sidebar-width: 280px;
  --blog-toc-width: 200px;
  --blog-content-max: 800px;
  --blog-transition-fast: 0.15s cubic-bezier(0.4, 0, 0.2, 1);
  --blog-transition-normal: 0.25s cubic-bezier(0.4, 0, 0.2, 1);
  --blog-transition-smooth: 0.35s cubic-bezier(0.4, 0, 0.2, 1);
  --blog-radius-xs: 4px;
  --blog-radius-sm: 8px;
  --blog-radius-md: 12px;
  --blog-radius-lg: 16px;
  --blog-radius-xl: 20px;
  --blog-radius-full: 9999px;
  --blog-blur: 20px;
  --blog-blur-heavy: 40px;
  --blog-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.04), 0 1px 3px rgba(0, 0, 0, 0.06);
  --blog-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.06), 0 2px 4px -1px rgba(0, 0, 0, 0.04);
  --blog-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.08), 0 4px 6px -2px rgba(0, 0, 0, 0.04);
  --blog-shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.08), 0 10px 10px -5px rgba(0, 0, 0, 0.03);
  --blog-glass-bg: rgba(255, 255, 255, 0.6);
  --blog-glass-border: rgba(255, 255, 255, 0.2);
}
:root[data-theme=dark] .blog-article {
  --blog-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.2), 0 1px 3px rgba(0, 0, 0, 0.3);
  --blog-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.3), 0 2px 4px -1px rgba(0, 0, 0, 0.2);
  --blog-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.35), 0 4px 6px -2px rgba(0, 0, 0, 0.2);
  --blog-shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.4), 0 10px 10px -5px rgba(0, 0, 0, 0.2);
  --blog-glass-bg: rgba(28, 28, 30, 0.75);
  --blog-glass-border: rgba(255, 255, 255, 0.08);
}
.blog-article .blog-article-layout {
  display: flex;
  gap: 24px;
  align-items: flex-start;
}
.blog-article .blog-article-main {
  flex: 1;
  min-width: 0;
}
.blog-article .blog-article-left {
  width: var(--blog-sidebar-width);
  min-width: var(--blog-sidebar-width);
  position: sticky;
  top: 80px;
  height: fit-content;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.blog-article .blog-article-side {
  width: var(--blog-toc-width);
  min-width: var(--blog-toc-width);
  position: sticky;
  top: 100px;
  height: fit-content;
  display: flex;
  flex-direction: column;
}
.blog-article .blog-article-back {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 10px 14px;
  border-radius: var(--blog-radius-full);
  border: 1px solid var(--transp-2);
  background: linear-gradient(180deg, var(--transp-05) 0%, rgba(255, 255, 255, 0.01) 100%);
  color: var(--text);
  text-decoration: none;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.01em;
  box-shadow: 0 10px 22px -18px rgba(0, 0, 0, 0.55);
  transition: transform var(--blog-transition-fast), border-color var(--blog-transition-fast), background var(--blog-transition-fast), box-shadow var(--blog-transition-fast);
  margin-bottom: 0;
}
.blog-article .blog-article-back svg {
  width: 14px;
  height: 14px;
  opacity: 0.8;
  flex-shrink: 0;
}
.blog-article .blog-article-back:hover {
  transform: translateY(-1px);
  border-color: var(--transp-3);
  background: linear-gradient(180deg, var(--transp-1) 0%, var(--transp-05) 100%);
  box-shadow: 0 14px 26px -18px rgba(0, 0, 0, 0.7);
}
.blog-article .blog-toc {
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
}
.blog-article .blog-toc__title {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-500);
  margin-bottom: 12px;
}
.blog-article .blog-toc__title svg {
  width: 12px;
  height: 12px;
  opacity: 0.6;
}
.blog-article .blog-toc__list {
  list-style: none;
  padding: 0 0 0 12px;
  margin: 0;
  overflow-y: auto;
  flex: 1;
  position: relative;
}
.blog-article .blog-toc__list::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 1px;
  background: var(--transp-1);
}
.blog-article .blog-toc__item {
  margin-bottom: 0;
  position: relative;
}
.blog-article .blog-toc__link {
  display: block;
  font-size: 12px;
  color: var(--text-500);
  line-height: 1.5;
  cursor: pointer;
  transition: all var(--blog-transition-fast);
  padding: 4px 0;
  position: relative;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  line-clamp: 2;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}
.blog-article .blog-toc__link::before {
  content: "";
  position: absolute;
  left: -12px;
  top: 50%;
  transform: translateY(-50%);
  width: 1px;
  height: 0;
  background: var(--accent);
  transition: height var(--blog-transition-fast);
}
.blog-article .blog-toc__link:hover {
  color: var(--accent);
}
.blog-article .blog-toc__link--active {
  color: var(--accent);
  font-weight: 500;
}
.blog-article .blog-toc__link--active::before {
  height: 16px;
}
.blog-article .blog-toc__link--h3 {
  padding-left: 12px;
  font-size: 11px;
  color: var(--text-500);
}
.blog-article .blog-toc__link--h3::before {
  left: 0;
}
.blog-article .blog-toc__link--h4 {
  padding-left: 20px;
  font-size: 10px;
  color: var(--text-600);
}
.blog-article .blog-toc__link--h4::before {
  left: 8px;
}
.blog-article .blog-article-side-divider {
  height: 1px;
  background: var(--transp-1);
  margin: 14px 0;
}
.blog-article .blog-last-updated {
  margin-top: 0;
  padding-top: 0;
  border-top: none;
  flex-shrink: 0;
}
.blog-article .blog-like-action {
  width: 100%;
}
.blog-article .blog-like-action__button {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 12px;
  border-radius: var(--blog-radius-md);
  border: 1px solid var(--transp-2);
  background: linear-gradient(180deg, var(--transp-05) 0%, rgba(255, 255, 255, 0.01) 100%);
  color: var(--text);
  cursor: pointer;
  transition: transform var(--blog-transition-fast), border-color var(--blog-transition-fast), background var(--blog-transition-fast), box-shadow var(--blog-transition-fast);
  box-shadow: 0 12px 24px -20px rgba(0, 0, 0, 0.6);
}
.blog-article .blog-like-action__button:hover {
  transform: translateY(-1px);
  border-color: var(--transp-3);
  background: linear-gradient(180deg, var(--transp-1) 0%, var(--transp-05) 100%);
  box-shadow: 0 16px 28px -20px rgba(0, 0, 0, 0.75);
}
.blog-article .blog-like-action__button:disabled {
  cursor: default;
  opacity: 0.8;
  transform: none;
  box-shadow: none;
}
.blog-article .blog-like-action__button:disabled:hover {
  transform: none;
  border-color: var(--transp-2);
  background: linear-gradient(180deg, var(--transp-05) 0%, rgba(255, 255, 255, 0.01) 100%);
  box-shadow: none;
}
.blog-article .blog-like-action__button.is-liked .blog-like-action__icon {
  color: #ff4f72;
}
.blog-article .blog-like-action__main {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
}
.blog-article .blog-like-action__icon {
  width: 14px;
  height: 14px;
  color: #ef5d75;
  flex-shrink: 0;
}
.blog-article .blog-like-action__label {
  font-size: 12px;
  font-weight: 600;
  color: var(--text);
}
.blog-article .blog-like-action__count {
  min-width: 34px;
  text-align: center;
  padding: 4px 8px;
  border-radius: var(--blog-radius-full);
  border: 1px solid var(--transp-2);
  background: var(--transp-1);
  color: var(--text);
  font-size: 12px;
  font-weight: 600;
  line-height: 1;
}
.blog-article .blog-like-action--mobile {
  display: none;
  margin-top: 22px;
}
.blog-article .blog-like-action--side {
  display: block;
}
.blog-article .blog-last-updated__title {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-500);
  margin-bottom: 10px;
}
.blog-article .blog-update-item {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 12px;
  color: var(--text-400);
  cursor: pointer;
  transition: opacity var(--blog-transition-fast);
  text-decoration: none;
}
.blog-article .blog-update-item:hover {
  opacity: 0.8;
}
.blog-article .blog-update-item__avatar {
  width: 26px;
  height: 26px;
  border-radius: var(--blog-radius-sm);
  object-fit: cover;
  flex-shrink: 0;
}
.blog-article .blog-update-item__avatar--placeholder {
  background: var(--transp-1);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 9px;
  font-weight: 600;
  color: var(--text-400);
}
.blog-article .blog-update-item__info {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 1px;
}
.blog-article .blog-update-item__author {
  font-weight: 500;
  color: var(--text);
  font-size: 11px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  line-height: 1.25;
}
.blog-article .blog-update-item__date {
  line-height: 1.25;
  font-size: 10px;
  color: var(--text-500);
}
.blog-article .blog-article-header {
  margin-bottom: 40px;
  padding-bottom: 32px;
  border-bottom: 1px solid var(--transp-1);
}
.blog-article .blog-article__title {
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  font-weight: 700;
  color: var(--text);
  line-height: 1.2;
  margin-bottom: 16px;
  letter-spacing: -0.025em;
}
.blog-article .blog-article__description {
  font-size: 1.05rem;
  color: var(--text-400);
  line-height: 1.7;
  margin-bottom: 24px;
}
.blog-article .blog-article__info {
  display: flex;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
}
.blog-article .blog-article__info-item {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  color: var(--text-500);
}
.blog-article .blog-article__info-item svg {
  opacity: 0.6;
  width: 14px;
  height: 14px;
}
.blog-article .blog-article__author {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  transition: opacity var(--blog-transition-fast);
  text-decoration: none;
}
.blog-article .blog-article__author:hover {
  opacity: 0.8;
}
.blog-article .blog-article__author-avatar {
  width: 24px;
  height: 24px;
  border-radius: var(--blog-radius-sm);
  object-fit: cover;
}
.blog-article .blog-article__author-avatar--placeholder {
  width: 24px;
  height: 24px;
  border-radius: var(--blog-radius-sm);
  background: var(--transp-1);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 9px;
  font-weight: 600;
  color: var(--text-400);
}
.blog-article .blog-article__author-name {
  font-size: 13px;
  font-weight: 500;
  color: var(--text);
}
.blog-article .blog-article__cover img {
  border-radius: var(--blog-radius-md);
}
.blog-article .blog-article-content {
  font-size: 15px;
  line-height: 1.8;
  color: var(--text);
  max-width: var(--blog-content-max);
}
.blog-article .blog-article-content h2 {
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--text);
  margin: 40px 0 16px;
  scroll-margin-top: 100px;
  letter-spacing: -0.02em;
}
.blog-article .blog-article-content h2:first-child {
  margin-top: 0;
  padding-top: 0;
  border-top: none;
}
.blog-article .blog-article-content h3 {
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--text);
  margin: 28px 0 12px;
  scroll-margin-top: 100px;
  letter-spacing: -0.01em;
}
.blog-article .blog-article-content h4 {
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--text);
  margin: 20px 0 10px;
  scroll-margin-top: 100px;
}
.blog-article .blog-article-content p {
  color: var(--text-300);
}
.blog-article .blog-article-content ul, .blog-article .blog-article-content ol {
  margin-bottom: 18px;
  padding-left: 20px;
}
.blog-article .blog-article-content li {
  color: var(--text-300);
}
.blog-article .blog-article-content li::marker {
  color: var(--text-500);
}
.blog-article .blog-article-content a {
  color: var(--accent);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: all var(--blog-transition-fast);
}
.blog-article .blog-article-content a:hover {
  border-bottom-color: var(--accent);
}
.blog-article .blog-article-content strong {
  font-weight: 600;
  color: var(--text);
}
.blog-article .blog-article-content em {
  font-style: italic;
}
.blog-article .blog-article-content blockquote {
  margin: 24px 0;
  padding: 16px 20px;
  background: var(--transp-05);
  border-left: 3px solid var(--accent);
  border-radius: 0 var(--blog-radius-md) var(--blog-radius-md) 0;
  color: var(--text-300);
}
.blog-article .blog-article-content blockquote p:last-child {
  margin-bottom: 0;
}
.blog-article .blog-article-content pre {
  position: relative;
  margin: 24px 0;
  background: var(--background-800);
  border: 1px solid var(--transp-1);
  border-radius: var(--blog-radius-md);
  overflow: hidden;
}
.blog-article .blog-article-content pre code {
  display: block;
  overflow-x: auto;
  font-family: var(--font-mono);
  font-size: 13px;
  line-height: 1.6;
  color: var(--text);
  white-space: pre;
}
.blog-article .blog-article-content code:not(pre code) {
  padding: 2px 6px;
  background: var(--transp-1);
  border-radius: var(--blog-radius-xs);
  font-family: var(--font-mono);
  font-size: 0.875em;
  color: var(--text-200);
}
.blog-article .blog-article-content img {
  max-width: 100%;
  height: auto;
  border-radius: var(--blog-radius-md);
  margin: 20px 0;
}
.blog-article .blog-article-content table {
  width: 100%;
  border-collapse: collapse;
  margin: 24px 0;
  font-size: 14px;
}
.blog-article .blog-article-content table th, .blog-article .blog-article-content table td {
  padding: 12px 16px;
  text-align: left;
  border-bottom: 1px solid var(--transp-1);
}
.blog-article .blog-article-content table th {
  font-weight: 600;
  color: var(--text);
  background: var(--transp-05);
}
.blog-article .blog-article-content table td {
  color: var(--text-300);
}
.blog-article .blog-article-content table tr:hover td {
  background: var(--transp-05);
}
.blog-article .blog-article-content hr {
  border: none;
  height: 1px;
  background: var(--transp-1);
  margin: 32px 0;
}
.blog-article .blog-article-divider {
  border: none;
  height: 1px;
  background: var(--transp-1);
  margin: 32px 0;
}
.blog-article .blog-code-wrapper {
  position: relative;
  margin: 24px 0;
  background: var(--secondary);
  border: 1px solid var(--transp-1);
  border-radius: var(--blog-radius-lg);
  overflow: hidden;
}
.blog-article .blog-code-wrapper pre {
  margin: 0;
  border: none;
  border-radius: 0;
  background: transparent;
}
.blog-article .blog-code-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 14px;
  background: var(--transp-05);
  border-bottom: 1px solid var(--transp-1);
}
.blog-article .blog-code-lang {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  font-weight: 500;
  color: var(--text-500);
  font-family: var(--font-mono);
  text-transform: uppercase;
  letter-spacing: 0.3px;
}
.blog-article .blog-code-lang svg {
  opacity: 0.6;
}
.blog-article .blog-code-copy {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 5px 10px;
  background: var(--transp-05);
  border: 1px solid var(--transp-1);
  border-radius: var(--blog-radius-sm);
  font-size: 11px;
  font-weight: 500;
  color: var(--text-500);
  cursor: pointer;
  transition: all var(--blog-transition-fast);
}
.blog-article .blog-code-copy svg {
  width: 12px;
  height: 12px;
}
.blog-article .blog-code-copy:hover {
  background: var(--transp-1);
  color: var(--text);
  border-color: var(--transp-2);
}
.blog-article .blog-code-copy.copied {
  color: var(--success);
  border-color: var(--success);
  background: var(--success-light);
}
.blog-article .blog-article-latest__title {
  font-size: 1rem;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 16px;
  text-transform: none;
  letter-spacing: normal;
}
.blog-article .blog-article-latest__list {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.blog-article .blog-article-latest .blog-feed-card {
  display: flex;
  flex-direction: column;
  padding: 0;
  background: transparent;
  border: 0;
  border-radius: var(--blog-radius-lg);
  overflow: hidden;
  cursor: pointer;
  transition: all var(--blog-transition-fast);
  text-decoration: none;
}
.blog-article .blog-article-latest .blog-feed-card:hover .blog-feed-card__body {
  background: var(--transp-1);
  border-color: var(--transp-2);
}
.blog-article .blog-article-latest .blog-feed-card:hover .blog-card__title-arrow {
  color: var(--accent);
}
.blog-article .blog-article-latest .blog-feed-card__media {
  display: block;
  width: 100%;
  aspect-ratio: 1.7777777778;
  overflow: hidden;
}
.blog-article .blog-article-latest .blog-feed-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.blog-article .blog-article-latest .blog-feed-card__title {
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
  margin: 0;
  line-height: 1.4;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.blog-article .blog-article-latest .blog-feed-card__body {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 12px 14px 14px;
}
.blog-article .blog-article-latest .blog-card__meta {
  font-size: 11px;
  font-weight: 500;
  text-transform: none;
  letter-spacing: normal;
  color: var(--text-500);
}
.blog-article .blog-article-latest .blog-card__meta--author {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  min-width: 0;
}
.blog-article .blog-article-latest .blog-card__author {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
  flex: 1;
}
.blog-article .blog-article-latest .blog-card__author-avatar {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
}
.blog-article .blog-article-latest .blog-card__author-avatar--placeholder {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--transp-1);
  color: var(--text);
  font-size: 9px;
  font-weight: 700;
}
.blog-article .blog-article-latest .blog-card__author-name {
  font-size: 12px;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.blog-article .blog-article-latest .blog-card__meta-date {
  font-size: 11px;
  color: var(--text-500);
  flex-shrink: 0;
  white-space: nowrap;
}
.blog-article .blog-article-latest .blog-card__title-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  min-width: 0;
}
.blog-article .blog-article-latest .blog-card__title-row .blog-feed-card__title {
  flex: 1;
  min-width: 0;
}
.blog-article .blog-article-latest .blog-card__title-arrow {
  width: 14px;
  height: 14px;
  color: var(--text-500);
  flex-shrink: 0;
  transition: color var(--blog-transition-fast);
}
@media (max-width: 1280px) {
  .blog-article .blog-article-layout {
    gap: 20px;
  }
  .blog-article .blog-article-side {
    width: 200px;
    min-width: 200px;
  }
}
@media (max-width: 1100px) {
  .blog-article .blog-article-side {
    display: none;
  }
  .blog-article .blog-like-action--side {
    display: none;
  }
  .blog-article .blog-like-action--mobile {
    display: block;
  }
}
@media (max-width: 900px) {
  .blog-article {
    --blog-sidebar-width: 260px;
  }
  .blog-article .blog-article__title {
    font-size: 1.75rem;
  }
}
@media (max-width: 768px) {
  .blog-article .blog-article-layout {
    flex-direction: column;
  }
  .blog-article .blog-article-left, .blog-article .blog-article-side {
    width: 100%;
    min-width: 0;
    position: static;
  }
  .blog-article .blog-article__title {
    font-size: 1.5rem;
  }
  .blog-article .blog-article__description {
    font-size: 1rem;
  }
  .blog-article .blog-article__info {
    gap: 12px;
  }
  .blog-article .blog-article-content {
    font-size: 14px;
  }
  .blog-article .blog-article-content h2 {
    font-size: 1.3rem;
    margin: 36px 0 16px;
  }
  .blog-article .blog-article-content h3 {
    font-size: 1.1rem;
    margin: 24px 0 12px;
  }
  .blog-article .blog-article-content pre code {
    font-size: 12px;
    padding: 14px 16px;
  }
  .blog-article .blog-article-content blockquote {
    padding: 14px 16px;
  }
  .blog-article .blog-code-header {
    padding: 8px 12px;
  }
  .blog-article .blog-code-lang {
    font-size: 10px;
  }
  .blog-article .blog-code-copy {
    padding: 4px 8px;
    font-size: 10px;
  }
  .blog-article .blog-code-copy span {
    display: none;
  }
}
/* Blog module cards/tables style aligned with profile/settings */
.blog-index .blog-categories-box, .blog-index .blog-category-latest, .blog-index .blog-categories-panel, .blog-index .blog-category-header, .blog-index .blog-category-articles, .blog-index .blog-card, .blog-index .blog-featured, .blog-index .blog-feed-card__body, .blog-index .blog-search__results, .blog-index .blog-code-header, .blog-index .blog-code-copy, .blog-index .blog-like-action__button, .blog-index .blog-article-latest .blog-feed-card__body, .blog-index .pagination a, .blog-landing .blog-categories-box, .blog-landing .blog-category-latest, .blog-landing .blog-categories-panel, .blog-landing .blog-category-header, .blog-landing .blog-category-articles, .blog-landing .blog-card, .blog-landing .blog-featured, .blog-landing .blog-feed-card__body, .blog-landing .blog-search__results, .blog-landing .blog-code-header, .blog-landing .blog-code-copy, .blog-landing .blog-like-action__button, .blog-landing .blog-article-latest .blog-feed-card__body, .blog-landing .pagination a, .blog-category .blog-categories-box, .blog-category .blog-category-latest, .blog-category .blog-categories-panel, .blog-category .blog-category-header, .blog-category .blog-category-articles, .blog-category .blog-card, .blog-category .blog-featured, .blog-category .blog-feed-card__body, .blog-category .blog-search__results, .blog-category .blog-code-header, .blog-category .blog-code-copy, .blog-category .blog-like-action__button, .blog-category .blog-article-latest .blog-feed-card__body, .blog-category .pagination a, .blog-search-page .blog-categories-box, .blog-search-page .blog-category-latest, .blog-search-page .blog-categories-panel, .blog-search-page .blog-category-header, .blog-search-page .blog-category-articles, .blog-search-page .blog-card, .blog-search-page .blog-featured, .blog-search-page .blog-feed-card__body, .blog-search-page .blog-search__results, .blog-search-page .blog-code-header, .blog-search-page .blog-code-copy, .blog-search-page .blog-like-action__button, .blog-search-page .blog-article-latest .blog-feed-card__body, .blog-search-page .pagination a, .blog-article .blog-categories-box, .blog-article .blog-category-latest, .blog-article .blog-categories-panel, .blog-article .blog-category-header, .blog-article .blog-category-articles, .blog-article .blog-card, .blog-article .blog-featured, .blog-article .blog-feed-card__body, .blog-article .blog-search__results, .blog-article .blog-code-header, .blog-article .blog-code-copy, .blog-article .blog-like-action__button, .blog-article .blog-article-latest .blog-feed-card__body, .blog-article .pagination a {
  background: var(--transp-03);
  border: 1px solid var(--transp-1);
  box-shadow: var(--shadow-small);
}
.blog-index .blog-article-row, .blog-index .blog-search__result-item, .blog-landing .blog-article-row, .blog-landing .blog-search__result-item, .blog-category .blog-article-row, .blog-category .blog-search__result-item, .blog-search-page .blog-article-row, .blog-search-page .blog-search__result-item, .blog-article .blog-article-row, .blog-article .blog-search__result-item {
  border-bottom: 1px solid var(--transp-1);
}
.blog-index .blog-category-btn, .blog-index .blog-article__category, .blog-index .blog-search__result-item, .blog-index .blog-article-row, .blog-index .blog-feed-card__body, .blog-index .blog-featured, .blog-index .blog-like-action__button, .blog-index .pagination a, .blog-landing .blog-category-btn, .blog-landing .blog-article__category, .blog-landing .blog-search__result-item, .blog-landing .blog-article-row, .blog-landing .blog-feed-card__body, .blog-landing .blog-featured, .blog-landing .blog-like-action__button, .blog-landing .pagination a, .blog-category .blog-category-btn, .blog-category .blog-article__category, .blog-category .blog-search__result-item, .blog-category .blog-article-row, .blog-category .blog-feed-card__body, .blog-category .blog-featured, .blog-category .blog-like-action__button, .blog-category .pagination a, .blog-search-page .blog-category-btn, .blog-search-page .blog-article__category, .blog-search-page .blog-search__result-item, .blog-search-page .blog-article-row, .blog-search-page .blog-feed-card__body, .blog-search-page .blog-featured, .blog-search-page .blog-like-action__button, .blog-search-page .pagination a, .blog-article .blog-category-btn, .blog-article .blog-article__category, .blog-article .blog-search__result-item, .blog-article .blog-article-row, .blog-article .blog-feed-card__body, .blog-article .blog-featured, .blog-article .blog-like-action__button, .blog-article .pagination a {
  transition: background-color var(--transition), border-color var(--transition), color var(--transition);
}
.blog-index .blog-category-btn:hover, .blog-index .blog-search__result-item:hover, .blog-index .blog-article-row:hover, .blog-index .blog-feed-card:hover .blog-feed-card__body, .blog-index .blog-featured:hover, .blog-index .blog-like-action__button:hover, .blog-index .pagination a:hover, .blog-landing .blog-category-btn:hover, .blog-landing .blog-search__result-item:hover, .blog-landing .blog-article-row:hover, .blog-landing .blog-feed-card:hover .blog-feed-card__body, .blog-landing .blog-featured:hover, .blog-landing .blog-like-action__button:hover, .blog-landing .pagination a:hover, .blog-category .blog-category-btn:hover, .blog-category .blog-search__result-item:hover, .blog-category .blog-article-row:hover, .blog-category .blog-feed-card:hover .blog-feed-card__body, .blog-category .blog-featured:hover, .blog-category .blog-like-action__button:hover, .blog-category .pagination a:hover, .blog-search-page .blog-category-btn:hover, .blog-search-page .blog-search__result-item:hover, .blog-search-page .blog-article-row:hover, .blog-search-page .blog-feed-card:hover .blog-feed-card__body, .blog-search-page .blog-featured:hover, .blog-search-page .blog-like-action__button:hover, .blog-search-page .pagination a:hover, .blog-article .blog-category-btn:hover, .blog-article .blog-search__result-item:hover, .blog-article .blog-article-row:hover, .blog-article .blog-feed-card:hover .blog-feed-card__body, .blog-article .blog-featured:hover, .blog-article .blog-like-action__button:hover, .blog-article .pagination a:hover {
  background-color: var(--background-900);
  border-color: var(--transp-2);
}
.blog-index .blog-category-btn.is-active, .blog-index .pagination a.active, .blog-landing .blog-category-btn.is-active, .blog-landing .pagination a.active, .blog-category .blog-category-btn.is-active, .blog-category .pagination a.active, .blog-search-page .blog-category-btn.is-active, .blog-search-page .pagination a.active, .blog-article .blog-category-btn.is-active, .blog-article .pagination a.active {
  color: var(--accent);
  background-color: var(--accent-100);
  border-color: var(--transp-2);
}
.blog-index .blog-article-row:hover .blog-article-row__title, .blog-index .blog-article-row:hover .blog-article-row__desc, .blog-index .blog-article-row:hover .blog-article-row__arrow, .blog-index .blog-search__result-item:hover .blog-search__result-title, .blog-index .blog-search__result-item:hover .blog-search__result-category, .blog-index .blog-search__result-item:hover a, .blog-landing .blog-article-row:hover .blog-article-row__title, .blog-landing .blog-article-row:hover .blog-article-row__desc, .blog-landing .blog-article-row:hover .blog-article-row__arrow, .blog-landing .blog-search__result-item:hover .blog-search__result-title, .blog-landing .blog-search__result-item:hover .blog-search__result-category, .blog-landing .blog-search__result-item:hover a, .blog-category .blog-article-row:hover .blog-article-row__title, .blog-category .blog-article-row:hover .blog-article-row__desc, .blog-category .blog-article-row:hover .blog-article-row__arrow, .blog-category .blog-search__result-item:hover .blog-search__result-title, .blog-category .blog-search__result-item:hover .blog-search__result-category, .blog-category .blog-search__result-item:hover a, .blog-search-page .blog-article-row:hover .blog-article-row__title, .blog-search-page .blog-article-row:hover .blog-article-row__desc, .blog-search-page .blog-article-row:hover .blog-article-row__arrow, .blog-search-page .blog-search__result-item:hover .blog-search__result-title, .blog-search-page .blog-search__result-item:hover .blog-search__result-category, .blog-search-page .blog-search__result-item:hover a, .blog-article .blog-article-row:hover .blog-article-row__title, .blog-article .blog-article-row:hover .blog-article-row__desc, .blog-article .blog-article-row:hover .blog-article-row__arrow, .blog-article .blog-search__result-item:hover .blog-search__result-title, .blog-article .blog-search__result-item:hover .blog-search__result-category, .blog-article .blog-search__result-item:hover a {
  color: var(--accent);
}
.blog-article .blog-article-content table {
  background: var(--transp-03);
  border: 1px solid var(--transp-1);
  box-shadow: var(--shadow-small);
}
.blog-article .blog-article-content table th {
  background: var(--transp-03);
  border-bottom: 1px solid var(--transp-1);
}
.blog-article .blog-article-content table tr {
  transition: background-color var(--transition);
}
.blog-article .blog-article-content table td, .blog-article .blog-article-content table a, .blog-article .blog-article-content table .support-user__name, .blog-article .blog-article-content table .support-user__link, .blog-article .blog-article-content table .support-user__inline {
  transition: color var(--transition);
}
.blog-article .blog-article-content table tr:hover {
  background-color: var(--background-900);
}
.blog-article .blog-article-content table tr:hover td {
  background-color: transparent;
  color: var(--accent);
}
.blog-article .blog-article-content table tr:hover a, .blog-article .blog-article-content table tr:hover .support-user__name, .blog-article .blog-article-content table tr:hover .support-user__link, .blog-article .blog-article-content table tr:hover .support-user__inline {
  color: var(--accent);
}
@media (max-width: 480px) {
  .blog-article .blog-article__title {
    font-size: 1.35rem;
  }
  .blog-article .blog-article-header {
    margin-bottom: 24px;
    padding-bottom: 20px;
  }
}
:root {
  --wiki-sidebar-width: 280px;
  --wiki-toc-width: 260px;
  --wiki-content-max: 800px;
  --wiki-transition-fast: 0.15s cubic-bezier(0.4, 0, 0.2, 1);
  --wiki-transition-normal: 0.25s cubic-bezier(0.4, 0, 0.2, 1);
  --wiki-transition-smooth: 0.35s cubic-bezier(0.4, 0, 0.2, 1);
  --wiki-radius-xs: 4px;
  --wiki-radius-sm: 8px;
  --wiki-radius-md: 12px;
  --wiki-radius-lg: 16px;
  --wiki-radius-xl: 20px;
  --wiki-radius-full: 9999px;
  --wiki-blur: 20px;
  --wiki-blur-heavy: 40px;
  --wiki-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.04), 0 1px 3px rgba(0, 0, 0, 0.06);
  --wiki-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.06), 0 2px 4px -1px rgba(0, 0, 0, 0.04);
  --wiki-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.08), 0 4px 6px -2px rgba(0, 0, 0, 0.04);
  --wiki-shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.08), 0 10px 10px -5px rgba(0, 0, 0, 0.03);
  --wiki-glass-bg: rgba(255, 255, 255, 0.6);
  --wiki-glass-border: rgba(255, 255, 255, 0.2);
}
:root[data-theme=dark] {
  --wiki-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.2), 0 1px 3px rgba(0, 0, 0, 0.3);
  --wiki-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.3), 0 2px 4px -1px rgba(0, 0, 0, 0.2);
  --wiki-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.35), 0 4px 6px -2px rgba(0, 0, 0, 0.2);
  --wiki-shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.4), 0 10px 10px -5px rgba(0, 0, 0, 0.2);
  --wiki-glass-bg: rgba(28, 28, 30, 0.75);
  --wiki-glass-border: rgba(255, 255, 255, 0.08);
}
.wiki-page {
  display: flex;
  min-height: 50vh;
  background: transparent;
  position: relative;
  align-items: flex-start;
}
.wiki-container {
  display: flex;
  flex: 1;
  max-width: 1400px;
  margin: 0 auto;
  width: 100%;
}
.wiki-main {
  flex: 1;
  padding-left: var(--space-xl);
  min-width: 0;
  display: flex;
  flex-direction: column;
}
.wiki-content-wrapper {
  display: flex;
  gap: 24px;
  flex: 1;
}
.wiki-content {
  flex: 1;
  min-width: 0;
  max-width: 100%;
}
.wiki-breadcrumbs {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  color: var(--text-500);
  margin-bottom: 32px;
}
.wiki-breadcrumb__link {
  color: var(--text-500);
  transition: color var(--wiki-transition-fast);
  cursor: pointer;
  text-decoration: none;
  display: flex;
  align-items: center;
}
.wiki-breadcrumb__link svg {
  width: 14px;
  height: 14px;
}
.wiki-breadcrumb__link:hover {
  color: var(--text);
}
.wiki-breadcrumb__separator {
  color: var(--text-600);
  width: 12px;
  height: 12px;
  flex-shrink: 0;
}
.wiki-breadcrumb__current {
  color: var(--text-300);
  font-weight: 500;
  max-width: 200px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.wiki-article-header {
  margin-bottom: 40px;
  padding-bottom: 32px;
  border-bottom: 1px solid var(--transp-1);
}
.wiki-article__meta {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 20px;
  flex-wrap: wrap;
}
.wiki-article__category {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  background: var(--transp-05);
  border: 1px solid var(--transp-1);
  border-radius: var(--wiki-radius-full);
  font-size: 12px;
  font-weight: 500;
  color: var(--text-400);
  transition: all var(--wiki-transition-fast);
}
.wiki-article__category svg {
  width: 12px;
  height: 12px;
  opacity: 0.7;
}
.wiki-article__category:hover {
  background: var(--transp-1);
  border-color: var(--transp-2);
}
.wiki-article__title {
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  font-weight: 700;
  color: var(--text);
  line-height: 1.2;
  margin-bottom: 16px;
  letter-spacing: -0.025em;
}
.wiki-article__description {
  font-size: 1.05rem;
  color: var(--text-400);
  line-height: 1.7;
  margin-bottom: 24px;
}
.wiki-article__info {
  display: flex;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
}
.wiki-article__info-item {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  color: var(--text-500);
}
.wiki-article__info-item svg {
  opacity: 0.6;
  width: 14px;
  height: 14px;
}
.wiki-article__author {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  transition: opacity var(--wiki-transition-fast);
}
.wiki-article__author:hover {
  opacity: 0.8;
}
.wiki-article__author-avatar {
  width: 24px;
  height: 24px;
  border-radius: var(--wiki-radius-sm);
  object-fit: cover;
}
.wiki-article__author-name {
  font-size: 13px;
  font-weight: 500;
  color: var(--text);
}
.wiki-tags {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 20px;
}
.wiki-tag {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 10px;
  background: var(--transp-05);
  border: 1px solid var(--transp-1);
  border-radius: var(--wiki-radius-sm);
  font-size: 12px;
  color: var(--text-500);
  cursor: default;
  transition: all var(--wiki-transition-fast);
}
.wiki-tag svg {
  width: 10px;
  height: 10px;
  opacity: 0.5;
}
.wiki-sidebar {
  width: var(--wiki-sidebar-width);
  min-width: var(--wiki-sidebar-width);
  background: transparent;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  border: 1px solid var(--transp-1);
  border-radius: var(--wiki-radius-lg);
  position: sticky;
  top: 80px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.wiki-sidebar__header {
  padding: 20px 16px;
  border-bottom: 1px solid var(--transp-1);
  flex-shrink: 0;
}
.wiki-sidebar__title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 12px;
  letter-spacing: -0.01em;
}
.wiki-sidebar__title svg {
  color: var(--accent);
  width: 18px;
  height: 18px;
}
.wiki-sidebar__back {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 10px 14px;
  border-radius: var(--wiki-radius-full);
  border: 1px solid var(--transp-2);
  background: linear-gradient(180deg, var(--transp-05) 0%, rgba(255, 255, 255, 0.01) 100%);
  color: var(--text);
  text-decoration: none;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.01em;
  box-shadow: 0 10px 22px -18px rgba(0, 0, 0, 0.55);
  transition: transform 0.15s ease, border-color 0.15s ease, background 0.15s ease, box-shadow 0.15s ease;
  margin-bottom: 0;
}
.wiki-sidebar__back svg {
  width: 14px;
  height: 14px;
  opacity: 0.8;
  flex-shrink: 0;
}
.wiki-sidebar__back:hover {
  transform: translateY(-1px);
  border-color: var(--transp-3);
  background: linear-gradient(180deg, var(--transp-1) 0%, var(--transp-05) 100%);
  box-shadow: 0 14px 26px -18px rgba(0, 0, 0, 0.7);
}
.wiki-search-wrapper {
  position: relative;
}
.wiki-search__icon {
  position: absolute;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--text-500);
  pointer-events: none;
  width: 14px;
  height: 14px;
  transition: color 0.15s ease;
}
.wiki-search__input {
  width: 100%;
  padding: 8px 10px 8px 32px;
  background: var(--transp-05);
  border: 1px solid var(--transp-1);
  border-radius: var(--wiki-radius-sm);
  color: var(--text);
  font-size: 12px;
  transition: border-color 0.15s ease;
}
.wiki-search__input:focus {
  border-color: var(--accent);
  outline: none;
}
.wiki-search__input:focus + .wiki-search__icon, .wiki-search__input:focus ~ .wiki-search__icon {
  color: var(--accent);
}
.wiki-search__input::placeholder {
  color: var(--text-600);
}
.wiki-search__results {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  right: 0;
  background: var(--wiki-glass-bg);
  border: 1px solid var(--transp-1);
  border-radius: var(--wiki-radius-sm);
  box-shadow: var(--wiki-shadow-lg);
  max-height: 280px;
  overflow-y: auto;
  z-index: 200;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-4px);
  transition: opacity 0.15s ease, transform 0.15s ease, visibility 0.15s ease;
}
.wiki-search__results--open {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.wiki-search__result-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  cursor: pointer;
  transition: background 0.1s ease;
  text-decoration: none;
}
.wiki-search__result-item:not(:last-child) {
  border-bottom: 1px solid var(--transp-05);
}
.wiki-search__result-item:hover {
  background: var(--transp-05);
}
.wiki-search__result-icon {
  color: var(--text-500);
  width: 14px;
  height: 14px;
  flex-shrink: 0;
}
.wiki-search__result-content {
  flex: 1;
  min-width: 0;
  text-align: left;
}
.wiki-search__result-title {
  font-size: 12px;
  font-weight: 500;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1.4;
}
.wiki-search__result-category {
  font-size: 10px;
  color: var(--text-500);
  margin-top: 1px;
  line-height: 1.4;
}
.wiki-search__no-results {
  padding: 16px 12px;
  text-align: center;
  color: var(--text-500);
  font-size: 12px;
}
.wiki-categories {
  flex: 1;
  overflow-y: auto;
  padding: 8px;
}
.wiki-categories::-webkit-scrollbar {
  width: 3px;
}
.wiki-categories::-webkit-scrollbar-track {
  background: transparent;
}
.wiki-categories::-webkit-scrollbar-thumb {
  background: var(--transp-2);
  border-radius: var(--wiki-radius-full);
}
.wiki-category:not(:last-child) {
  margin-bottom: 2px;
}
.wiki-category__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 6px 10px;
  border-radius: var(--wiki-radius-sm);
  cursor: pointer;
  transition: background 0.1s ease;
  user-select: none;
  gap: 6px;
}
.wiki-category__header:hover {
  background: var(--transp-05);
}
.wiki-category__header--active {
  background: var(--transp-05);
}
.wiki-category__title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  font-weight: 500;
  color: var(--text);
  flex: 1;
  min-width: 0;
}
.wiki-category__title span:not(.wiki-category__icon) {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.wiki-category__icon {
  color: var(--text-400);
  width: 14px;
  height: 14px;
  flex-shrink: 0;
}
.wiki-category__header--active .wiki-category__icon {
  color: var(--accent);
}
.wiki-category__meta {
  display: flex;
  align-items: center;
  gap: 4px;
  flex-shrink: 0;
}
.wiki-category__count {
  font-size: 10px;
  font-weight: 500;
  color: var(--text-500);
  background: var(--transp-1);
  padding: 1px 5px;
  border-radius: var(--wiki-radius-full);
  min-width: 16px;
  text-align: center;
}
.wiki-category__chevron {
  color: var(--text-500);
  transition: transform 0.2s ease;
  width: 12px;
  height: 12px;
  flex-shrink: 0;
}
.wiki-category__chevron--open {
  transform: rotate(180deg);
}
.wiki-articles-list {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 0.25s ease;
}
.wiki-articles-list--open {
  grid-template-rows: 1fr;
}
.wiki-articles-list__inner {
  overflow: hidden;
  padding-left: 22px;
}
.wiki-articles-list--open .wiki-articles-list__inner {
  padding-top: 2px;
  padding-bottom: 4px;
}
.wiki-article-item {
  display: block;
  padding: 8px 10px;
  font-size: 12px;
  color: var(--text-400);
  border-radius: var(--wiki-radius-sm);
  cursor: pointer;
  transition: color 0.1s ease, background 0.1s ease;
  text-decoration: none;
  line-height: 1.4;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.wiki-article-item:hover {
  color: var(--text);
  background: var(--transp-05);
}
.wiki-article-item--active {
  color: var(--accent);
  background: var(--transp-05);
  font-weight: 500;
}
.wiki-article-item__icon {
  display: none;
}
.wiki-article-item__text {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
}
.wiki-article-content {
  font-size: 15px;
  line-height: 1.8;
  color: var(--text);
  max-width: var(--wiki-content-max);
}
.wiki-article-content h2 {
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--text);
  margin: 40px 0 16px;
  scroll-margin-top: 100px;
  letter-spacing: -0.02em;
}
.wiki-article-content h2:first-child {
  margin-top: 0;
  padding-top: 0;
  border-top: none;
}
.wiki-article-content h3 {
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--text);
  margin: 28px 0 12px;
  scroll-margin-top: 100px;
  letter-spacing: -0.01em;
}
.wiki-article-content h4 {
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--text);
  margin: 20px 0 10px;
  scroll-margin-top: 100px;
}
.wiki-article-content p {
  color: var(--text-300);
}
.wiki-article-content ul, .wiki-article-content ol {
  margin-bottom: 18px;
  padding-left: 20px;
}
.wiki-article-content li {
  color: var(--text-300);
}
.wiki-article-content li::marker {
  color: var(--text-500);
}
.wiki-article-content a {
  color: var(--accent);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: all var(--wiki-transition-fast);
}
.wiki-article-content a:hover {
  border-bottom-color: var(--accent);
}
.wiki-article-content strong {
  font-weight: 600;
  color: var(--text);
}
.wiki-article-content em {
  font-style: italic;
}
.wiki-article-content blockquote {
  margin: 24px 0;
  padding: 16px 20px;
  background: var(--transp-05);
  border-left: 3px solid var(--accent);
  border-radius: 0 var(--wiki-radius-md) var(--wiki-radius-md) 0;
  color: var(--text-300);
}
.wiki-article-content blockquote p:last-child {
  margin-bottom: 0;
}
.wiki-article-content pre {
  position: relative;
  margin: 24px 0;
  background: var(--background-800);
  border: 1px solid var(--transp-1);
  border-radius: var(--wiki-radius-md);
  overflow: hidden;
}
.wiki-article-content pre code {
  display: block;
  overflow-x: auto;
  font-family: var(--font-mono);
  font-size: 13px;
  line-height: 1.6;
  color: var(--text);
  white-space: pre;
}
.wiki-article-content code:not(pre code) {
  padding: 2px 6px;
  background: var(--transp-1);
  border-radius: var(--wiki-radius-xs);
  font-family: var(--font-mono);
  font-size: 0.875em;
  color: var(--text-200);
}
.wiki-article-content img {
  max-width: 100%;
  height: auto;
  border-radius: var(--wiki-radius-md);
  margin: 20px 0;
}
.wiki-article-content table {
  width: 100%;
  border-collapse: collapse;
  margin: 24px 0;
  font-size: 14px;
}
.wiki-article-content table th, .wiki-article-content table td {
  padding: 12px 16px;
  text-align: left;
  border-bottom: 1px solid var(--transp-1);
}
.wiki-article-content table th {
  font-weight: 600;
  color: var(--text);
  background: var(--transp-05);
}
.wiki-article-content table td {
  color: var(--text-300);
}
.wiki-article-content table tr:hover td {
  background: var(--transp-05);
}
.wiki-article-content hr {
  border: none;
  height: 1px;
  background: var(--transp-1);
  margin: 32px 0;
}
.wiki-article-content .blog-ta-left {
  text-align: left;
}
.wiki-article-content .blog-ta-center {
  text-align: center;
}
.wiki-article-content .blog-ta-right {
  text-align: right;
}
.wiki-article-content .blog-ta-justify {
  text-align: justify;
}
.wiki-article-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 60px 20px;
  color: var(--text-500);
}
.wiki-article-empty svg {
  width: 48px;
  height: 48px;
  margin-bottom: 16px;
  opacity: 0.4;
}
.wiki-article-empty p {
  font-size: 14px;
  color: var(--text-500);
}
.wiki-article-footer {
  margin-top: 56px;
  padding-top: 32px;
  border-top: 1px solid var(--transp-1);
  max-width: var(--wiki-content-max);
}
.wiki-feedback {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 24px;
  background: var(--transp-05);
  border: 1px solid var(--transp-1);
  border-radius: var(--wiki-radius-lg);
  margin-bottom: 32px;
  gap: 16px;
}
.wiki-feedback__question {
  font-size: 14px;
  font-weight: 500;
  color: var(--text);
}
.wiki-feedback__buttons {
  display: flex;
  gap: 10px;
}
.wiki-feedback__btn {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 16px;
  background: var(--transp-05);
  border: 1px solid var(--transp-1);
  border-radius: var(--wiki-radius-sm);
  font-size: 13px;
  font-weight: 500;
  color: var(--text-400);
  cursor: pointer;
  transition: all var(--wiki-transition-fast);
}
.wiki-feedback__btn svg {
  width: 14px;
  height: 14px;
}
.wiki-feedback__btn:hover {
  background: var(--transp-1);
  color: var(--text);
}
.wiki-feedback__btn--positive:hover, .wiki-feedback__btn--positive.active {
  border-color: var(--success);
  color: var(--success);
  background: var(--success-light);
}
.wiki-feedback__btn--negative:hover, .wiki-feedback__btn--negative.active {
  border-color: var(--error);
  color: var(--error);
  background: var(--error-light);
}
.wiki-feedback__count {
  font-size: 12px;
  color: var(--text-500);
  margin-left: 2px;
}
.wiki-related {
  margin-top: 32px;
}
.wiki-related__title {
  font-size: 1rem;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 16px;
}
.wiki-related__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
}
.wiki-related__card {
  display: flex;
  flex-direction: column;
  padding: 18px 20px;
  background: var(--transp-05);
  border: 1px solid var(--transp-1);
  border-radius: var(--wiki-radius-md);
  cursor: pointer;
  transition: all var(--wiki-transition-fast);
  text-decoration: none;
}
.wiki-related__card:hover {
  background: var(--transp-1);
  border-color: var(--transp-2);
}
.wiki-related__category {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-500);
  margin-bottom: 6px;
}
.wiki-related__card-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 4px;
  line-height: 1.4;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.wiki-related__card-desc {
  font-size: 12px;
  color: var(--text-500);
  line-height: 1.5;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.wiki-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 80px 20px;
  text-align: center;
}
.wiki-empty__icon {
  width: 72px;
  height: 72px;
  border-radius: var(--wiki-radius-lg);
  background: var(--transp-05);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 24px;
}
.wiki-empty__icon svg {
  width: 32px;
  height: 32px;
  color: var(--text-500);
}
.wiki-empty h3 {
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 8px;
}
.wiki-empty p {
  font-size: 14px;
  color: var(--text-500);
  max-width: 320px;
}
.wiki-toc {
  width: 200px;
  min-width: 200px;
  position: sticky;
  top: 100px;
  height: fit-content;
  max-height: calc(100vh - 140px);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
}
.wiki-toc__title {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-500);
  margin-bottom: 12px;
}
.wiki-toc__title svg {
  width: 12px;
  height: 12px;
  opacity: 0.6;
}
.wiki-toc__list {
  list-style: none;
  padding: 0;
  margin: 0;
  overflow-y: auto;
  flex: 1;
  position: relative;
  padding-left: 12px;
}
.wiki-toc__list::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 1px;
  background: var(--transp-1);
}
.wiki-toc__list::-webkit-scrollbar {
  width: 2px;
}
.wiki-toc__list::-webkit-scrollbar-track {
  background: transparent;
}
.wiki-toc__list::-webkit-scrollbar-thumb {
  background: var(--transp-2);
  border-radius: var(--wiki-radius-full);
}
.wiki-toc__item {
  margin-bottom: 0;
  position: relative;
}
.wiki-toc__link {
  display: block;
  font-size: 12px;
  color: var(--text-500);
  line-height: 1.5;
  cursor: pointer;
  transition: all var(--wiki-transition-fast);
  padding: 4px 0;
  position: relative;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  line-clamp: 2;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}
.wiki-toc__link::before {
  content: "";
  position: absolute;
  left: -12px;
  top: 50%;
  transform: translateY(-50%);
  width: 1px;
  height: 0;
  background: var(--accent);
  transition: height var(--wiki-transition-fast);
}
.wiki-toc__link:hover {
  color: var(--text);
}
.wiki-toc__link--active {
  color: var(--accent);
  font-weight: 500;
}
.wiki-toc__link--active::before {
  height: 16px;
}
.wiki-toc__link--h3 {
  padding-left: 12px;
  font-size: 11px;
  color: var(--text-500);
}
.wiki-toc__link--h3::before {
  left: 0px;
}
.wiki-toc__link--h4 {
  padding-left: 20px;
  font-size: 10px;
  color: var(--text-500);
}
.wiki-toc__link--h4::before {
  left: 8px;
}
.wiki-last-updated {
  margin-top: 20px;
  padding-top: 16px;
  border-top: 1px solid var(--transp-1);
  flex-shrink: 0;
}
.wiki-last-updated__title {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-500);
  margin-bottom: 10px;
}
.wiki-feedback--toc {
  margin-top: 20px;
  margin-bottom: 0;
  padding: 16px 0 0;
  background: transparent;
  border: none;
  border-top: 1px solid var(--transp-1);
  border-radius: 0;
  flex-direction: column;
  align-items: stretch;
  justify-content: flex-start;
  gap: 10px;
}
.wiki-feedback--toc .wiki-feedback__title {
  margin-bottom: 0;
}
.wiki-feedback--toc .wiki-feedback__buttons {
  width: 100%;
  justify-content: stretch;
  gap: 8px;
}
.wiki-feedback--toc .wiki-feedback__btn {
  flex: 1 1 0;
  justify-content: center;
  padding: 8px 10px;
  font-size: 11px;
}
.wiki-feedback--toc .wiki-feedback__count {
  font-size: 11px;
}
.wiki-update-item {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 12px;
  color: var(--text-400);
  cursor: pointer;
  transition: opacity var(--wiki-transition-fast);
  text-decoration: none;
}
.wiki-update-item:hover {
  opacity: 0.8;
}
.wiki-update-item__avatar {
  width: 26px;
  height: 26px;
  border-radius: var(--wiki-radius-sm);
  object-fit: cover;
  flex-shrink: 0;
}
.wiki-update-item__avatar--placeholder {
  background: var(--transp-1);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 9px;
  font-weight: 600;
  color: var(--text-400);
}
.wiki-update-item__info {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 1px;
}
.wiki-update-item__author {
  font-weight: 500;
  color: var(--text);
  font-size: 11px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  line-height: 1.25;
}
.wiki-update-item__date {
  line-height: 1.25;
  font-size: 10px;
  color: var(--text-500);
}
.wiki-code-wrapper {
  position: relative;
  margin: 24px 0;
  background: var(--secondary);
  border: 1px solid var(--transp-1);
  border-radius: var(--wiki-radius-lg);
  overflow: hidden;
}
.wiki-code-wrapper pre {
  margin: 0;
  border: none;
  border-radius: 0;
  background: transparent;
}
.wiki-code-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 14px;
  background: var(--transp-05);
  border-bottom: 1px solid var(--transp-1);
}
.wiki-code-lang {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  font-weight: 500;
  color: var(--text-500);
  font-family: var(--font-mono);
  text-transform: uppercase;
  letter-spacing: 0.3px;
}
.wiki-code-lang svg {
  opacity: 0.6;
}
.wiki-code-copy {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 5px 10px;
  background: var(--transp-05);
  border: 1px solid var(--transp-1);
  border-radius: var(--wiki-radius-sm);
  font-size: 11px;
  font-weight: 500;
  color: var(--text-500);
  cursor: pointer;
  transition: all var(--wiki-transition-fast);
}
.wiki-code-copy svg {
  width: 12px;
  height: 12px;
}
.wiki-code-copy:hover {
  background: var(--transp-1);
  color: var(--text);
  border-color: var(--transp-2);
}
.wiki-code-copy.copied {
  color: var(--success);
  border-color: var(--success);
  background: var(--success-light);
}
.wiki-landing {
  min-height: calc(100vh - 80px);
  padding-bottom: 80px;
}
.wiki-landing__hero {
  position: relative;
  padding: 0px 0 50px;
  text-align: center;
}
.wiki-landing__hero::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 800px;
  height: 500px;
  background: radial-gradient(ellipse at center, var(--accent-alpha-1) 0%, transparent 70%);
  pointer-events: none;
  opacity: 0.6;
}
.wiki-landing__hero-content {
  position: relative;
  z-index: 1;
  max-width: 580px;
  margin: 0 auto;
  padding: 0 24px;
}
.wiki-landing__title {
  font-size: clamp(2.25rem, 5vw, 3rem);
  font-weight: 700;
  color: var(--text);
  letter-spacing: -0.035em;
  line-height: 1.1;
  margin-bottom: 12px;
}
.wiki-landing__subtitle {
  font-size: 1.0625rem;
  color: var(--text-400);
  line-height: 1.6;
  margin-bottom: 36px;
  text-align: center;
}
.wiki-landing__search {
  position: relative;
  max-width: 520px;
  margin: 0 auto;
}
.wiki-landing__search-box {
  position: relative;
  display: flex;
  align-items: center;
}
.wiki-landing__search-icon {
  position: absolute;
  left: 20px;
  width: 20px;
  height: 20px;
  color: var(--text-500);
  pointer-events: none;
  transition: color 0.2s ease;
}
.wiki-landing__search-input {
  width: 100%;
  padding: 18px 100px 18px 54px;
  background: var(--block);
  border: 1px solid var(--transp-1);
  border-radius: 14px;
  font-size: 16px;
  color: var(--text);
  transition: all 0.2s ease;
  box-shadow: 0 2px 16px -4px rgba(0, 0, 0, 0.06);
}
.wiki-landing__search-input::placeholder {
  color: var(--text-500);
}
.wiki-landing__search-input:hover {
  border-color: var(--transp-2);
}
.wiki-landing__search-input:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 2px 16px -4px rgba(0, 0, 0, 0.06), 0 0 0 3px var(--accent-alpha-1);
}
.wiki-landing__search-input:focus ~ .wiki-landing__search-icon {
  color: var(--accent);
}
.wiki-landing__search-hint {
  position: absolute;
  right: 16px;
  display: flex;
  gap: 4px;
  pointer-events: none;
}
.wiki-landing__search-hint kbd {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 24px;
  height: 24px;
  padding: 0 6px;
  background: var(--transp-05);
  border: 1px solid var(--transp-1);
  border-radius: 6px;
  font-size: 11px;
  font-family: inherit;
  color: var(--text-500);
}
.wiki-landing__search-results {
  top: calc(100% + 8px);
  border-radius: 12px;
  max-height: 360px;
}
.wiki-category-section {
  margin-bottom: 32px;
  background: var(--transp-03);
  border: 1px solid var(--transp-1);
  box-shadow: var(--shadow-small);
  border-radius: 16px;
  overflow: hidden;
}
.wiki-category-section:last-child {
  margin-bottom: 0;
}
.wiki-category-section__header {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 20px 24px;
  background: transparent;
  border: 0;
  border-bottom: 1px solid var(--transp-1);
}
.wiki-category-section__icon {
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--accent-alpha-1);
  border-radius: 12px;
  flex-shrink: 0;
}
.wiki-category-section__icon svg {
  width: 22px;
  height: 22px;
  color: var(--accent);
}
.wiki-category-section__info {
  flex: 1;
  min-width: 0;
}
.wiki-category-section__title {
  font-size: 17px;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 2px;
  letter-spacing: -0.01em;
}
.wiki-category-section__desc {
  font-size: 13px;
  color: var(--text-400);
  line-height: 1.4;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.wiki-category-section__count {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-500);
  background: var(--transp-1);
  padding: 4px 12px;
  border-radius: 20px;
  flex-shrink: 0;
}
.wiki-category-section__articles {
  background: transparent;
  border: 0;
  border-radius: 0;
  overflow: hidden;
}
.wiki-article-row {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 16px 24px;
  text-decoration: none;
  transition: background 0.15s ease;
  border-bottom: 1px solid var(--transp-05);
}
.wiki-article-row:last-child {
  border-bottom: none;
}
.wiki-article-row:hover {
  background: var(--transp-05);
}
.wiki-article-row:hover .wiki-article-row__arrow {
  transform: translateX(4px);
  opacity: 1;
}
.wiki-article-row:hover .wiki-article-row__title {
  color: var(--accent);
}
.wiki-article-row__content {
  flex: 1;
  min-width: 0;
}
.wiki-article-row__title {
  font-size: 15px;
  font-weight: 500;
  color: var(--text);
  margin-bottom: 2px;
  transition: color 0.15s ease;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.wiki-article-row__desc {
  font-size: 13px;
  color: var(--text-400);
  line-height: 1.4;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.wiki-article-row__meta {
  margin-left: auto;
  display: inline-flex;
  align-items: center;
  gap: 12px;
  flex-shrink: 0;
}
.wiki-article-row__votes {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.wiki-article-row__vote {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 12px;
  color: var(--text-500);
  line-height: 1;
}
.wiki-article-row__vote svg {
  width: 14px;
  height: 14px;
  opacity: 0.9;
}
.wiki-article-row__vote--positive svg {
  color: var(--success);
}
.wiki-article-row__vote--negative svg {
  color: var(--error);
}
.wiki-article-row__arrow {
  width: 18px;
  height: 18px;
  color: var(--text-400);
  opacity: 0.4;
  flex-shrink: 0;
  transition: all 0.2s ease;
}
.wiki-landing__empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 80px 24px;
  text-align: center;
}
.wiki-landing__empty svg {
  width: 56px;
  height: 56px;
  color: var(--text-500);
  opacity: 0.4;
  margin-bottom: 20px;
}
.wiki-landing__empty h3 {
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 6px;
}
.wiki-landing__empty p {
  font-size: 14px;
  color: var(--text-400);
}
@media (max-width: 768px) {
  .wiki-landing__hero {
    padding: 48px 0 40px;
  }
  .wiki-landing__title {
    font-size: 1.875rem;
  }
  .wiki-landing__subtitle {
    font-size: 1rem;
    margin-bottom: 28px;
  }
  .wiki-landing__search-input {
    padding: 16px 16px 16px 48px;
    font-size: 15px;
    border-radius: 12px;
  }
  .wiki-landing__search-icon {
    left: 16px;
    width: 18px;
    height: 18px;
  }
  .wiki-landing__search-hint {
    display: none;
  }
  .wiki-category-section__header {
    padding: 16px 20px;
    gap: 12px;
  }
  .wiki-category-section__icon {
    width: 40px;
    height: 40px;
  }
  .wiki-category-section__icon svg {
    width: 20px;
    height: 20px;
  }
  .wiki-category-section__title {
    font-size: 15px;
  }
  .wiki-category-section__desc {
    display: none;
  }
  .wiki-article-row {
    padding: 14px 20px;
  }
  .wiki-article-row__title {
    font-size: 14px;
  }
  .wiki-article-row__desc {
    display: none;
  }
  .wiki-article-row__meta {
    gap: 8px;
  }
  .wiki-article-row__votes {
    gap: 8px;
  }
  .wiki-article-row__vote {
    font-size: 11px;
  }
  .wiki-article-row__vote svg {
    width: 13px;
    height: 13px;
  }
}
@media (max-width: 1280px) {
  .wiki-main {
    padding: 32px 40px;
  }
  .wiki-content-wrapper {
    gap: 20px;
  }
  .wiki-toc {
    width: 200px;
    min-width: 200px;
  }
}
@media (max-width: 1100px) {
  .wiki-toc {
    display: none;
  }
  .wiki-main {
    padding: 32px 40px;
  }
}
@media (max-width: 900px) {
  :root {
    --wiki-sidebar-width: 260px;
  }
  .wiki-main {
    padding: 24px 32px;
  }
  .wiki-article__title {
    font-size: 1.75rem;
  }
  .wiki-related__grid {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 768px) {
  .wiki-page {
    flex-direction: column;
  }
  .wiki-sidebar {
    width: 100%;
    min-width: 100%;
    position: relative;
    top: 0;
    height: auto;
    max-height: none;
    border-bottom: 1px solid var(--transp-1);
  }
  .wiki-sidebar__header {
    padding: 20px 16px;
  }
  .wiki-categories {
    max-height: 300px;
    padding: 12px 16px 16px;
  }
  .wiki-main {
    padding: 24px 16px;
  }
  .wiki-article__title {
    font-size: 1.5rem;
  }
  .wiki-article__description {
    font-size: 1rem;
  }
  .wiki-article__info {
    gap: 12px;
  }
  .wiki-breadcrumbs {
    margin-bottom: 20px;
  }
  .wiki-breadcrumbs .wiki-breadcrumb__link:not(:first-child):not(:last-child) {
    display: none;
  }
  .wiki-breadcrumbs .wiki-breadcrumb__separator:not(:first-of-type):not(:last-of-type) {
    display: none;
  }
  .wiki-feedback {
    flex-direction: column;
    text-align: center;
    padding: 16px;
  }
  .wiki-feedback__buttons {
    width: 100%;
    justify-content: center;
  }
  .wiki-article-content {
    font-size: 14px;
  }
  .wiki-article-content h2 {
    font-size: 1.3rem;
    margin: 36px 0 16px;
  }
  .wiki-article-content h3 {
    font-size: 1.1rem;
    margin: 24px 0 12px;
  }
  .wiki-article-content pre code {
    font-size: 12px;
    padding: 14px 16px;
  }
  .wiki-article-content blockquote {
    padding: 14px 16px;
  }
  .wiki-code-header {
    padding: 8px 12px;
  }
  .wiki-code-lang {
    font-size: 10px;
  }
  .wiki-code-copy {
    padding: 4px 8px;
    font-size: 10px;
  }
  .wiki-code-copy span {
    display: none;
  }
}
@media (max-width: 480px) {
  .wiki-main {
    padding: 20px 12px;
  }
  .wiki-sidebar__header {
    padding: 16px 12px;
  }
  .wiki-categories {
    padding: 8px 12px 12px;
  }
  .wiki-article__title {
    font-size: 1.35rem;
  }
  .wiki-article__meta {
    gap: 8px;
  }
  .wiki-article__category {
    padding: 4px 10px;
    font-size: 11px;
  }
  .wiki-article-header {
    margin-bottom: 24px;
    padding-bottom: 20px;
  }
  .wiki-feedback__btn {
    padding: 8px 12px;
    font-size: 12px;
  }
  .wiki-related__card {
    padding: 14px 16px;
  }
  .wiki-empty {
    padding: 48px 16px;
  }
  .wiki-empty__icon {
    width: 56px;
    height: 56px;
  }
  .wiki-empty__icon svg {
    width: 24px;
    height: 24px;
  }
  .wiki-empty h3 {
    font-size: 1.1rem;
  }
  .wiki-empty p {
    font-size: 13px;
  }
}
@media (hover: none) {
  .wiki-category__header:hover {
    background: transparent;
  }
  .wiki-category__header--active {
    background: var(--transp-1);
  }
  .wiki-article-item:hover {
    background: transparent;
  }
  .wiki-article-item--active {
    background: var(--transp-05);
  }
}
/* Wiki landing cards style aligned with profile/settings */
.wiki-landing .wiki-category-section {
  background: var(--transp-03);
  border: 1px solid var(--transp-1);
  box-shadow: var(--shadow-small);
}
.wiki-landing .wiki-article-row {
  border-bottom: 1px solid var(--transp-1);
  transition: background-color var(--transition);
}
.wiki-landing .wiki-article-row__title, .wiki-landing .wiki-article-row__desc, .wiki-landing .wiki-article-row__arrow {
  transition: color var(--transition);
}
.wiki-landing .wiki-article-row:hover {
  background-color: var(--background-900);
}
.wiki-landing .wiki-article-row:hover .wiki-article-row__title, .wiki-landing .wiki-article-row:hover .wiki-article-row__desc, .wiki-landing .wiki-article-row:hover .wiki-article-row__arrow {
  color: var(--accent);
}
.wiki-article-content table {
  background: var(--transp-03);
  border: 1px solid var(--transp-1);
  box-shadow: var(--shadow-small);
}
.wiki-article-content table th {
  background: var(--transp-03);
  border-bottom: 1px solid var(--transp-1);
}
.wiki-article-content table tr {
  transition: background-color var(--transition);
}
.wiki-article-content table td, .wiki-article-content table a, .wiki-article-content table .support-user__name, .wiki-article-content table .support-user__link, .wiki-article-content table .support-user__inline {
  transition: color var(--transition);
}
.wiki-article-content table tr:hover {
  background-color: var(--background-900);
}
.wiki-article-content table tr:hover td {
  background-color: transparent;
  color: var(--accent);
}
.wiki-article-content table tr:hover a, .wiki-article-content table tr:hover .support-user__name, .wiki-article-content table tr:hover .support-user__link, .wiki-article-content table tr:hover .support-user__inline {
  color: var(--accent);
}
.flute-users-grid__top {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: var(--space-lg);
  margin-bottom: var(--space-lg);
}
@media (max-width: 767px) {
  .flute-users-grid__top {
    flex-direction: column;
    align-items: stretch;
  }
}
.flute-users-grid__legend h1 {
  margin: 0;
  font-size: var(--h1);
  line-height: 1.1;
}
.flute-users-grid__legend p {
  margin: var(--space-2xs) 0 0;
  color: var(--text-300);
}
.flute-users-grid__search {
  width: min(420px, 100%);
  margin: 0;
}
.flute-users-grid__search-form {
  width: min(420px, 100%);
}
.flute-users-grid__search-submit {
  display: none;
}
.flute-users-grid__cards {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--space-md);
}
@media (min-width: 768px) and (max-width: 1023px) {
  .flute-users-grid__cards {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 767px) {
  .flute-users-grid__cards {
    grid-template-columns: 1fr;
  }
}
.flute-users-grid__card {
  display: block;
  text-decoration: none;
  color: inherit;
  background: var(--transp-03);
  border: 1px solid var(--transp-1);
  box-shadow: var(--shadow-small);
  border-radius: var(--border1);
  overflow: hidden;
  transition: background-color var(--transition), border-color var(--transition), box-shadow var(--transition), transform var(--transition);
}
.flute-users-grid__card:hover {
  background: var(--background-900);
  border-color: var(--transp-2);
  transform: translateY(-2px);
}
.flute-users-grid__card-header {
  position: relative;
  display: block;
  height: 92px;
  text-decoration: none;
  color: inherit;
}
.flute-users-grid__banner {
  position: absolute;
  inset: 0;
  background: var(--accent-100);
}
.flute-users-grid__banner img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  filter: brightness(0.72);
}
.flute-users-grid__banner::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0.08) 0%, var(--background) 95%);
}
.flute-users-grid__avatar {
  position: absolute;
  left: 50%;
  bottom: -30px;
  transform: translateX(-50%);
  width: 62px;
  height: 62px;
  border-radius: 50%;
  border: 3px solid var(--background);
  overflow: hidden;
  z-index: 2;
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.25);
}
.flute-users-grid__avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.flute-users-grid__body {
  padding: 40px var(--space-sm) var(--space-sm);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-xs);
  background-color: var(--transp-05);
}
.flute-users-grid__name {
  max-width: 100%;
  text-decoration: none;
  font-size: var(--h6);
  font-weight: 700;
  color: var(--text-100);
  transition: color var(--transition);
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
}
.flute-users-grid__card:hover .flute-users-grid__name, .flute-users-grid__name:hover {
  color: var(--accent);
}
.flute-users-grid__roles {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.4rem;
  margin-top: var(--space-2xs);
  min-height: 26px;
}
.flute-users-grid__role {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  border-radius: 999px;
  background: var(--transp-03);
  border: 1px solid var(--transp-1);
  padding: 0.2rem 0.55rem;
  color: var(--text);
  font-size: 0.72rem;
  line-height: 1;
  transition: background-color var(--transition), border-color var(--transition), color var(--transition);
}
.flute-users-grid__role-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  flex-shrink: 0;
}
.flute-users-grid__role--empty {
  opacity: 0.8;
}
.flute-users-grid__empty {
  padding: calc(var(--space-xl) * 1.1) var(--space-lg);
  text-align: center;
}
.flute-users-grid__empty h3 {
  margin: var(--space-sm) 0 var(--space-2xs);
}
.flute-users-grid__empty-icon {
  color: var(--accent);
  opacity: 0.9;
}
.flute-users-grid__more {
  display: flex;
  justify-content: center;
  margin-top: var(--space-lg);
}
.media-page__legend {
  text-align: center;
}
.media-page__legend .col {
  display: flex;
  justify-content: center;
}
.media-page__legend .legend-block legend {
  justify-content: center;
}
.media-page__legend .legend-content {
  justify-content: center;
}
.media-page__legend .legend-text {
  align-items: center;
  text-align: center;
}
.media-page__filters {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
  margin: -2px 0 16px;
}
.media-page__filter {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  border: 1px solid var(--transp-2, rgba(255, 255, 255, 0.08));
  padding: 6px 12px;
  font-size: 0.87rem;
  text-decoration: none;
  color: inherit;
  background: transparent;
  transition: border-color 0.18s ease, color 0.18s ease, background-color 0.18s ease;
}
.media-page__filter:hover {
  color: var(--accent, var(--primary, #2ebf7a));
  border-color: color-mix(in srgb, var(--accent, var(--primary, #2ebf7a)) 40%, var(--transp-2, rgba(255, 255, 255, 0.08)));
}
.media-page__filter.is-active {
  color: var(--accent, var(--primary, #2ebf7a));
  border-color: color-mix(in srgb, var(--accent, var(--primary, #2ebf7a)) 46%, var(--transp-2, rgba(255, 255, 255, 0.08)));
  background: color-mix(in srgb, var(--accent, var(--primary, #2ebf7a)) 10%, transparent);
}
.media-page__empty {
  padding: 28px 18px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}
.media-page__empty svg, .media-page__empty i {
  font-size: 34px;
  width: 34px;
  height: 34px;
  color: var(--accent, var(--primary, #2ebf7a));
  opacity: 0.88;
}
.media-page__empty h3 {
  margin: 0;
  font-size: 1.05rem;
}
.media-page__empty p {
  margin: 0;
  font-size: 0.92rem;
  color: var(--text-400, rgba(255, 255, 255, 0.6));
}
.media-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}
.media-card {
  background: transparent;
  border: 0;
  border-radius: 14px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  min-height: 100%;
  position: relative;
}
.media-card--clickable {
  transition: transform 0.18s ease;
}
.media-card--clickable:hover {
  transform: translateY(-2px);
}
.media-card__stretched-link {
  position: absolute;
  inset: 0;
  z-index: 2;
  text-decoration: none;
}
.media-card__cover {
  display: block;
  position: relative;
  overflow: hidden;
  width: 100%;
  height: clamp(150px, 9.6vw, 190px);
  background: var(--transp-03, var(--transp-3, rgba(255, 255, 255, 0.14)));
  border-radius: 14px 14px 0 0;
}
.media-card__cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.media-card__cover-empty {
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0.7;
}
.media-card__body {
  padding: 14px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  position: relative;
  border: 1px solid var(--transp-1, rgba(255, 255, 255, 0.05));
  border-top: 0;
  border-radius: 0 0 14px 14px;
  background: var(--transp-05, rgba(255, 255, 255, 0.04));
}
.media-card__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 8px;
}
.media-card__head h3, .media-card__body h3 {
  margin: 0;
  font-size: 1.05rem;
  line-height: 1.25;
  transition: color 0.18s ease;
}
.media-card__head a, .media-card__body a {
  text-decoration: none;
}
.media-card__desc {
  margin: 0;
  opacity: 0.85;
  line-height: 1.45;
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  min-height: calc(1.45em * 2);
  transition: color 0.18s ease, opacity 0.18s ease;
}
.media-card--clickable:hover .media-card__head h3, .media-card--clickable:hover .media-card__desc {
  color: var(--accent, var(--primary, #2ebf7a));
  opacity: 1;
}
.media-card__meta {
  margin-top: auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.media-card__author {
  min-width: 0;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.media-card__author-avatar {
  width: 26px;
  height: 26px;
  border-radius: 999px;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  position: relative;
  z-index: 3;
}
.media-card__author-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.media-card__author-avatar--empty {
  background: var(--transp-2, rgba(255, 255, 255, 0.08));
  color: rgba(255, 255, 255, 0.78);
}
.media-card__author-name {
  min-width: 0;
  text-overflow: ellipsis;
  overflow: hidden;
  white-space: nowrap;
  position: relative;
  z-index: 3;
}
.media-card__author-name--empty {
  opacity: 0.72;
}
.media-card__stats {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
}
.media-card__stat {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  font-size: 0.8rem;
  opacity: 0.88;
}
.media-card__stat svg, .media-card__stat i {
  color: var(--accent, var(--primary, #2ebf7a));
}
.media-show__top {
  margin-bottom: 14px;
}
.media-show__back {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  text-decoration: none;
}
.media-show__layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 20px;
}
.media-show__side {
  display: flex;
  flex-direction: column;
  gap: 12px;
  align-self: start;
}
.media-show__gallery {
  display: grid;
  grid-template-columns: 90px minmax(0, 1fr);
  gap: 12px;
  align-items: start;
}
.media-show__thumbs {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.media-show__thumb {
  border: 1px solid var(--transp-2, rgba(255, 255, 255, 0.08));
  background: transparent;
  border-radius: 10px;
  overflow: hidden;
  cursor: pointer;
  padding: 0;
}
.media-show__thumb.is-active {
  border-color: var(--accent, var(--primary, #2ebf7a));
}
.media-show__thumb img {
  width: 100%;
  height: 72px;
  object-fit: cover;
  display: block;
}
.media-show__preview {
  border: 1px solid var(--transp-2, rgba(255, 255, 255, 0.08));
  border-radius: 14px;
  overflow: hidden;
  height: 460px;
  min-height: 460px;
  align-self: start;
  background: var(--background-card, #12141a);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}
.media-show__preview img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.media-show__preview-image-btn {
  border: 0;
  padding: 0;
  width: 100%;
  height: 100%;
  display: block;
  background: transparent;
  cursor: zoom-in;
}
.media-show__nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  border: 1px solid var(--transp-3, rgba(255, 255, 255, 0.14));
  background: rgba(12, 14, 20, 0.72);
  width: 34px;
  height: 34px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  z-index: 2;
  color: #fff;
  cursor: pointer;
}
.media-show__nav--prev {
  left: 10px;
}
.media-show__nav--next {
  right: 10px;
}
.media-viewer[hidden] {
  display: none;
}
.media-viewer {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
}
.media-viewer__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(6, 8, 12, 0.9);
}
.media-viewer__dialog {
  position: relative;
  z-index: 1;
  width: min(94vw, 1400px);
  height: min(92vh, 920px);
  display: flex;
  align-items: center;
  justify-content: center;
}
.media-viewer__dialog img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
}
.media-viewer__close {
  position: absolute;
  top: 8px;
  right: 8px;
  z-index: 2;
  border: 1px solid var(--transp-3, rgba(255, 255, 255, 0.14));
  background: rgba(12, 14, 20, 0.72);
  width: 36px;
  height: 36px;
  border-radius: 999px;
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}
.media-viewer__nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 2;
  border: 1px solid var(--transp-3, rgba(255, 255, 255, 0.14));
  background: rgba(12, 14, 20, 0.72);
  width: 42px;
  height: 42px;
  border-radius: 999px;
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}
.media-viewer__nav--prev {
  left: 18px;
}
.media-viewer__nav--next {
  right: 18px;
}
.media-show__preview--empty {
  opacity: 0.7;
}
.media-show__meta {
  border: 1px solid var(--transp-2, rgba(255, 255, 255, 0.08));
  border-radius: 14px;
  padding: 18px;
  height: fit-content;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.media-show__meta h1 {
  margin: 0;
  font-size: 2.2rem;
  line-height: 1.1;
}
.media-show__topline {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.media-show__version-inline {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.92rem;
}
.media-show__version-inline span {
  opacity: 0.72;
}
.media-show__title {
  margin: 0;
  font-weight: 800;
}
.media-show__short {
  margin: 0;
  opacity: 0.88;
}
.media-show__author-stats {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 14px;
}
.media-show__author {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}
.media-show__author-avatar {
  width: 36px;
  height: 36px;
  border-radius: 999px;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
}
.media-show__author-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.media-show__author-avatar--empty {
  background: var(--transp-2, rgba(255, 255, 255, 0.08));
  color: rgba(255, 255, 255, 0.8);
}
.media-show__author-name {
  text-decoration: none;
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
}
.media-show__author-name--empty {
  opacity: 0.65;
}
.media-show__stats {
  display: inline-flex;
  align-items: center;
  gap: 12px;
}
.media-show__stat {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  opacity: 0.88;
  font-size: 0.9rem;
}
.media-show__stat svg, .media-show__stat i {
  color: var(--accent, var(--primary, #2ebf7a));
}
.media-show__buttons {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.media-show__buttons .btn {
  display: inline-flex;
  gap: 8px;
  align-items: center;
}
.media-show__buttons > a.btn {
  color: var(--accent, var(--primary, #2ebf7a));
  border-color: color-mix(in srgb, var(--accent, var(--primary, #2ebf7a)) 42%, var(--transp-3, rgba(255, 255, 255, 0.2)));
}
.media-show__buttons > a.btn svg, .media-show__buttons > a.btn i {
  color: inherit;
}
.media-show__like-btn.is-liked {
  color: #ff6b88;
  border-color: color-mix(in srgb, #ff6b88 45%, var(--transp-3, rgba(255, 255, 255, 0.2)));
}
.media-show__description, .media-show__related {
  margin-top: 26px;
}
.media-show__description h2, .media-show__related h2 {
  margin: 0 0 12px;
}
.media-show__description-content {
  opacity: 0.92;
  line-height: 1.65;
}
.media-show__description-content > :first-child {
  margin-top: 0;
}
.media-show__description-content > :last-child {
  margin-bottom: 0;
}
.media-show__versions {
  margin-top: 26px;
}
.media-show__versions-list {
  display: grid;
  gap: 10px;
}
.media-show__meta-versions {
  border: 1px solid var(--transp-2, rgba(255, 255, 255, 0.08));
  border-radius: 12px;
  background: transparent;
  overflow: hidden;
}
.media-show__meta-versions-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
  padding: 12px 14px;
  border-bottom: 1px solid var(--transp-2, rgba(255, 255, 255, 0.08));
}
.media-show__meta-versions-head h2 {
  margin: 0;
  font-size: 1rem;
}
.media-show__meta-versions-head span {
  opacity: 0.68;
  font-size: 0.9rem;
}
.media-show__versions-list--meta {
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.media-show__version-item {
  border: 0;
  border-bottom: 1px solid var(--transp-2, rgba(255, 255, 255, 0.08));
  border-radius: 0;
  padding: 0;
  background: transparent;
}
.media-show__version-item:last-child {
  border-bottom: 0;
}
.media-show__version-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
}
.media-show__version-head span {
  opacity: 0.65;
  font-size: 13px;
}
.media-show__version-head-right {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.media-show__version-toggle {
  width: 100%;
  border: 0;
  background: transparent;
  color: inherit;
  padding: 0;
  text-align: left;
  cursor: pointer;
}
.media-show__version-toggle .media-show__version-head-right svg, .media-show__version-toggle .media-show__version-head-right i {
  transition: transform 0.2s ease;
}
.media-show__version-item.is-open .media-show__version-toggle .media-show__version-head-right svg, .media-show__version-item.is-open .media-show__version-toggle .media-show__version-head-right i {
  transform: rotate(180deg);
}
.media-show__version-label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.media-show__version-label strong {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 6px;
  font-size: 0.86rem;
  line-height: 1.1;
  color: var(--accent, var(--primary, #2ebf7a));
  background: color-mix(in srgb, var(--accent, var(--primary, #2ebf7a)) 16%, transparent);
}
.media-show__version-label span {
  color: var(--accent, var(--primary, #2ebf7a));
  opacity: 1;
  font-size: 0.82rem;
  text-transform: lowercase;
}
.media-show__version-content {
  margin-top: 0;
  opacity: 0.9;
  padding: 0 12px 10px;
  border-radius: 0;
  background: transparent;
}
.media-show__version-content > :first-child {
  margin-top: 0;
}
.media-show__version-content > :last-child {
  margin-bottom: 0;
}
.media-show__versions-empty {
  margin: 0;
  opacity: 0.75;
}
.richtext-editor-wrapper .tiptap-editor + textarea[data-editor="richtext"] {
  display: none !important;
}
.media-card--mini .media-card__cover {
  height: 120px;
}
@media (max-width: 1500px) {
  .media-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
@media (max-width: 1200px) {
  .media-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 900px) {
  .media-show__layout {
    grid-template-columns: 1fr;
  }
  .media-show__gallery {
    grid-template-columns: 1fr;
  }
  .media-show__thumbs {
    flex-direction: row;
    overflow-x: auto;
    padding-bottom: 4px;
  }
  .media-show__thumb {
    min-width: 82px;
  }
  .media-show__preview {
    height: 260px;
    min-height: 260px;
  }
  .media-show__author-stats {
    flex-direction: column;
    align-items: flex-start;
  }
  .media-show__stats {
    width: 100%;
    justify-content: flex-start;
  }
  .media-show__nav {
    width: 30px;
    height: 30px;
  }
  .media-viewer__nav {
    width: 36px;
    height: 36px;
  }
  .media-viewer__nav--prev {
    left: 10px;
  }
  .media-viewer__nav--next {
    right: 10px;
  }
}
@media (max-width: 680px) {
  .media-grid {
    grid-template-columns: 1fr;
  }
  .media-card__meta {
    align-items: flex-start;
    flex-direction: column;
  }
}
.monitoring-pill {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 0;
  padding: 0;
  border-radius: 10px;
  font-size: var(--p-small);
  font-weight: 500;
  line-height: 1;
  white-space: nowrap;
  color: var(--text);
  cursor: default;
  border: 1px solid var(--transp-1);
  background: color-mix(in srgb, var(--blurred-background) 82%, transparent);
  backdrop-filter: saturate(180%) blur(20px);
  -webkit-backdrop-filter: saturate(180%) blur(20px);
  transition: background 0.2s ease, border-color 0.2s ease;
}
@media (max-width: 768px) {
  .monitoring-pill {
    display: none;
  }
}
.monitoring-pill:hover {
  background: color-mix(in srgb, var(--blurred-background) 96%, transparent);
  border-color: var(--transp-2);
}
.monitoring-pill__section {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 12px;
}
.monitoring-pill__section-icon {
  width: 14px;
  height: 14px;
  color: var(--text-500);
  flex-shrink: 0;
  opacity: 0.7;
}
.monitoring-pill__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
  background: var(--text-600);
  transition: background 0.3s ease, box-shadow 0.3s ease;
}
.monitoring-pill__count {
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  font-size: var(--p-small);
  color: var(--text);
  transition: color 0.2s ease;
}
.monitoring-pill__sep {
  width: 1px;
  align-self: stretch;
  margin: 6px 0;
  flex-shrink: 0;
  background: var(--transp-2);
}
.monitoring-pill__servers {
  font-variant-numeric: tabular-nums;
  color: var(--text);
  font-size: var(--p-small);
  font-weight: 600;
}
.monitoring-pill__servers-dim {
  font-weight: 400;
  color: var(--text-600);
}
.monitoring-pill--online .monitoring-pill__dot {
  background: var(--accent);
  box-shadow: 0 0 0 2.5px color-mix(in srgb, var(--accent) 18%, transparent);
}
.monitoring-pill--cool .monitoring-pill__count {
  color: var(--accent);
}
.monitoring-pill--cool .monitoring-pill__section:first-child .monitoring-pill__section-icon {
  color: var(--accent);
  opacity: 1;
}
.monitoring-pill--warm .monitoring-pill__dot {
  background: #ff9f0a;
  box-shadow: 0 0 0 2.5px color-mix(in srgb, #ff9f0a 18%, transparent);
}
.monitoring-pill--warm .monitoring-pill__count {
  color: #ff9f0a;
}
.monitoring-pill--warm .monitoring-pill__section:first-child .monitoring-pill__section-icon {
  color: #ff9f0a;
  opacity: 1;
}
.monitoring-pill--hot .monitoring-pill__dot {
  background: #ff453a;
  box-shadow: 0 0 0 2.5px color-mix(in srgb, #ff453a 20%, transparent);
}
.monitoring-pill--hot .monitoring-pill__count {
  color: #ff453a;
}
.monitoring-pill--hot .monitoring-pill__section:first-child .monitoring-pill__section-icon {
  color: #ff453a;
  opacity: 1;
}
.monitoring-pill--empty .monitoring-pill__dot {
  background: var(--text-700);
  opacity: 0.4;
}
.monitoring-pill--empty .monitoring-pill__count {
  color: var(--text-600);
}
.monitoring-pill--empty .monitoring-pill__servers {
  color: var(--text-600);
}
.monitoring-pill--empty .monitoring-pill__section-icon {
  opacity: 0.4;
}
.tooltip:has(.mp-tip) {
  max-width: min(340px, calc(100vw - 24px));
  padding: 0;
  overflow: hidden;
  border-radius: 14px;
  border: 1px solid var(--transp-1);
  background: color-mix(in srgb, var(--blurred-background) 85%, transparent);
  backdrop-filter: saturate(180%) blur(24px);
  -webkit-backdrop-filter: saturate(180%) blur(24px);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.12), 0 1px 3px rgba(0, 0, 0, 0.06);
}
.mp-tip {
  display: flex;
  flex-direction: column;
  max-height: min(72vh, 480px);
  min-height: 0;
  text-align: left;
}
.mp-tip__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-shrink: 0;
  gap: 8px;
  padding: 10px 14px;
  border-bottom: 1px solid var(--transp-1);
}
.mp-tip__label {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-500);
  letter-spacing: -0.01em;
}
.mp-tip__total {
  display: flex;
  align-items: baseline;
  gap: 1px;
  font-variant-numeric: tabular-nums;
}
.mp-tip__total-count {
  font-size: var(--p);
  font-weight: 700;
  color: var(--text);
}
.mp-tip__total-sep {
  color: var(--text-700);
  font-weight: 400;
  font-size: var(--small);
}
.mp-tip__total-max {
  font-size: var(--small);
  font-weight: 500;
  color: var(--text-600);
}
.mp-tip__list {
  flex: 1 1 auto;
  min-height: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 4px;
  overflow-y: auto;
  overflow-x: hidden;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  scrollbar-color: var(--transp-2) transparent;
}
.mp-tip__list::-webkit-scrollbar {
  width: 4px;
}
.mp-tip__list::-webkit-scrollbar-thumb {
  background: var(--transp-2);
  border-radius: 100px;
}
.mp-tip__list::-webkit-scrollbar-track {
  background: transparent;
}
.mp-tip__srv {
  position: relative;
  overflow: hidden;
  border-radius: 10px;
  font-size: var(--small);
  line-height: 1.25;
  flex-shrink: 0;
  transition: background 0.15s ease;
}
.mp-tip__srv:hover {
  background: color-mix(in srgb, var(--text) 4%, transparent);
}
.mp-tip__srv:hover .mp-tip__srv-bg img {
  transform: scale(1.02);
}
.mp-tip__srv-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.mp-tip__srv-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(0.45) saturate(0.85);
  transition: transform 0.4s ease;
}
.mp-tip__srv-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background: linear-gradient(90deg, rgba(0, 0, 0, 0.7) 0%, rgba(0, 0, 0, 0.3) 50%, rgba(0, 0, 0, 0.05) 100%);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  mask-image: linear-gradient(90deg, black 0%, black 40%, transparent 100%);
  -webkit-mask-image: linear-gradient(90deg, black 0%, black 40%, transparent 100%);
}
.mp-tip__srv-inner {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 44px;
  padding: 8px 10px;
}
.mp-tip__srv:has(.mp-tip__srv-bg):hover {
  background: none;
}
.mp-tip__srv:has(.mp-tip__srv-bg) .mp-tip__srv-name {
  color: #fff;
  text-shadow: 0 1px 4px rgba(0, 0, 0, 0.3);
}
.mp-tip__srv:has(.mp-tip__srv-bg) .mp-tip__srv-map {
  color: rgba(255, 255, 255, 0.55);
}
.mp-tip__srv:has(.mp-tip__srv-bg) .mp-tip__srv-players {
  background: rgba(255, 255, 255, 0.12);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
.mp-tip__srv:has(.mp-tip__srv-bg) .mp-tip__srv-players-bar {
  background: rgba(255, 255, 255, 0.2);
}
.mp-tip__srv:has(.mp-tip__srv-bg) .mp-tip__srv-players-text {
  color: #fff;
}
.mp-tip__srv:has(.mp-tip__srv-bg) .mp-tip__srv-players-max {
  color: rgba(255, 255, 255, 0.45);
}
.mp-tip__srv:has(.mp-tip__srv-bg) .mp-tip__srv-btn {
  color: rgba(255, 255, 255, 0.6);
  background: rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.mp-tip__srv:has(.mp-tip__srv-bg) .mp-tip__srv-btn:hover {
  background: rgba(255, 255, 255, 0.2);
  color: #fff;
}
.mp-tip__srv:has(.mp-tip__srv-bg) .mp-tip__srv-btn--play:hover {
  background: color-mix(in srgb, var(--accent) 35%, transparent);
  color: #fff;
}
.mp-tip__srv-info {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 1px;
}
.mp-tip__srv-name {
  margin: 0;
  font-weight: 600;
  font-size: var(--small);
  color: var(--text);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  letter-spacing: -0.01em;
}
.mp-tip__srv-map {
  font-size: 10px;
  color: var(--text-600);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  line-height: 1.2;
}
.mp-tip__srv-right {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-shrink: 0;
}
.mp-tip__srv-players {
  position: relative;
  font-variant-numeric: tabular-nums;
  flex-shrink: 0;
  align-self: center;
  min-width: 2.75rem;
  height: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 6px;
  overflow: hidden;
  background: color-mix(in srgb, var(--text) 5%, transparent);
}
.mp-tip__srv-players-bar {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: var(--fill, 0%);
  background: var(--bar-color, color-mix(in srgb, var(--accent) 18%, transparent));
  border-radius: 6px;
  transition: width 0.4s ease, background 0.3s ease;
}
.mp-tip__srv-players-text {
  position: relative;
  z-index: 1;
  font-weight: 600;
  font-size: 10px;
  color: var(--text);
  padding: 0 8px;
  line-height: 1;
}
.mp-tip__srv-players-max {
  font-weight: 400;
  color: var(--text-500);
}
.mp-tip__srv--cool {
  --bar-color: color-mix(in srgb, var(--text) 6%, transparent);
}
.mp-tip__srv--warm {
  --bar-color: color-mix(in srgb, #ff9f0a 22%, transparent);
}
.mp-tip__srv--warm .mp-tip__srv-players-text {
  color: #ff9f0a;
}
.mp-tip__srv--warm .mp-tip__srv-players-max {
  color: #ff9f0a;
  opacity: 0.5;
}
.mp-tip__srv--hot {
  --bar-color: color-mix(in srgb, #ff9f0a 28%, transparent);
}
.mp-tip__srv--hot .mp-tip__srv-players-text {
  color: #ff9f0a;
}
.mp-tip__srv--hot .mp-tip__srv-players-max {
  color: #ff9f0a;
  opacity: 0.5;
}
.mp-tip__srv--full {
  --bar-color: color-mix(in srgb, #ff453a 25%, transparent);
}
.mp-tip__srv--full .mp-tip__srv-players-text {
  color: #ff453a;
}
.mp-tip__srv--full .mp-tip__srv-players-max {
  color: #ff453a;
  opacity: 0.5;
}
.mp-tip__srv:has(.mp-tip__srv-bg).mp-tip__srv--warm .mp-tip__srv-players-bar {
  background: rgba(255, 159, 10, 0.3);
}
.mp-tip__srv:has(.mp-tip__srv-bg).mp-tip__srv--hot .mp-tip__srv-players-bar {
  background: rgba(255, 159, 10, 0.35);
}
.mp-tip__srv:has(.mp-tip__srv-bg).mp-tip__srv--full .mp-tip__srv-players-bar {
  background: rgba(255, 69, 58, 0.35);
}
.mp-tip__srv:has(.mp-tip__srv-bg).mp-tip__srv--warm .mp-tip__srv-players-text, .mp-tip__srv:has(.mp-tip__srv-bg).mp-tip__srv--hot .mp-tip__srv-players-text {
  color: #ffbf40;
}
.mp-tip__srv:has(.mp-tip__srv-bg).mp-tip__srv--warm .mp-tip__srv-players-max, .mp-tip__srv:has(.mp-tip__srv-bg).mp-tip__srv--hot .mp-tip__srv-players-max {
  color: #ffbf40;
  opacity: 0.5;
}
.mp-tip__srv:has(.mp-tip__srv-bg).mp-tip__srv--full .mp-tip__srv-players-text {
  color: #ff6961;
}
.mp-tip__srv:has(.mp-tip__srv-bg).mp-tip__srv--full .mp-tip__srv-players-max {
  color: #ff6961;
  opacity: 0.5;
}
.mp-tip__srv-actions {
  display: flex;
  align-items: center;
  gap: 2px;
  flex-shrink: 0;
}
.mp-tip__srv-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 7px;
  color: var(--text-500);
  cursor: pointer;
  text-decoration: none;
  border: none;
  background: transparent;
  transition: background 0.15s ease, color 0.15s ease;
}
.mp-tip__srv-btn svg {
  width: 12px;
  height: 12px;
}
.mp-tip__srv-btn:hover {
  background: color-mix(in srgb, var(--text) 8%, transparent);
  color: var(--text);
}
.mp-tip__srv-btn--play:hover {
  background: color-mix(in srgb, var(--accent) 15%, transparent);
  color: var(--accent);
}
.prime-indicator {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: var(--p);
  height: var(--p);
}
.prime-indicator.prime {
  color: var(--accent);
}
.prime-indicator.non-prime {
  color: var(--error);
}
.prime-indicator svg {
  fill: currentColor;
  width: 100%;
  height: 100%;
}
.monitoring-mode-table {
  display: block;
  padding: 0;
  gap: 0;
}
.monitoring-table-rows {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-top: 1em;
}
.server-row {
  position: relative;
  overflow: hidden;
  border-radius: 14px;
  cursor: pointer;
  transition: box-shadow 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}
.server-row:hover {
  box-shadow: 0 0 0 1px var(--transp-1);
}
.server-row:hover .server-row-bg img {
  transform: scale(1.04);
}
.server-row:hover .server-play-btn {
  opacity: 1;
  transform: translateY(-50%) scale(1);
}
.server-row.inactive {
  opacity: 0.45;
}
.server-row.inactive:hover {
  opacity: 0.65;
  box-shadow: none;
}
.server-row.error .server-row-dot {
  background: var(--error);
}
.server-row-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.server-row-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(0.55) saturate(0.9);
  transition: transform 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.server-row-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(to right, rgba(0, 0, 0, 0.7) 0%, rgba(0, 0, 0, 0.35) 55%, rgba(0, 0, 0, 0.08) 100%);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  mask-image: linear-gradient(to right, black 0%, black 40%, transparent 70%);
  -webkit-mask-image: linear-gradient(to right, black 0%, black 40%, transparent 70%);
  transition: background 0.3s;
}
.server-row:not(:has(.server-row-bg)) .server-row-overlay {
  background: var(--transp-05);
  backdrop-filter: none;
}
.server-row:not(:has(.server-row-bg)):hover .server-row-overlay {
  background: var(--transp-1);
}
.server-row-content {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
  gap: 20px;
  padding: 14px 20px;
  padding-right: 64px;
}
.monitoring-container .server-row .server-row-content {
  align-items: center;
}
.server-row-main {
  display: flex;
  align-items: center;
  align-self: center;
  gap: 12px;
  flex: 1;
  min-width: 0;
}
.server-row-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  flex-shrink: 0;
}
.server-row-dot.online {
  background: var(--accent);
  box-shadow: 0 0 6px color-mix(in srgb, var(--accent) 50%, transparent);
  animation: server-dot-pulse 2.5s ease-in-out infinite;
}
.server-row-dot.error {
  background: var(--error);
  opacity: 0.7;
}
.server-row-dot.inactive {
  background: var(--text-500);
  opacity: 0.4;
}
@keyframes server-dot-pulse {
  0%, 100% {
    box-shadow: 0 0 6px color-mix(in srgb, var(--accent) 50%, transparent);
  }
  50% {
    box-shadow: 0 0 12px color-mix(in srgb, var(--accent) 15%, transparent);
  }
}
.server-row-ring {
  position: relative;
  width: 38px;
  height: 38px;
  flex-shrink: 0;
}
.server-row-ring svg {
  width: 100%;
  height: 100%;
}
.server-row-ring-text {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 700;
  color: #fff;
  line-height: 1;
}
.server-row-ring-text.dimmed {
  color: rgba(255, 255, 255, 0.2);
}
.server-row:not(:has(.server-row-bg)) .server-row-ring-text {
  color: var(--text);
}
.server-row:not(:has(.server-row-bg)) .server-row-ring-text.dimmed {
  color: var(--text-500);
}
.server-ring-track {
  stroke: rgba(255, 255, 255, 0.06);
}
.server-row:not(:has(.server-row-bg)) .server-ring-track {
  stroke: var(--transp-1);
}
.server-ring-fill {
  transition: stroke-dashoffset 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  transform: rotate(-90deg);
  transform-origin: center;
}
.server-row-info {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 3px;
  min-width: 0;
}
.server-row-name {
  margin: 0;
  font-size: var(--p);
  font-weight: 600;
  color: #fff;
  line-height: 1.3;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.server-row:not(:has(.server-row-bg)) .server-row-name {
  color: var(--text);
}
.server-game-badge {
  display: inline-flex;
  align-items: center;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.02em;
  padding: 2px 7px;
  border-radius: 100px;
  vertical-align: middle;
  margin-left: 6px;
  line-height: 1.2;
  color: #ff9f0a;
  background: rgba(255, 159, 10, 0.12);
  border: 1px solid rgba(255, 159, 10, 0.15);
}
.server-row-ip {
  font-size: 11px;
  color: rgba(255, 255, 255, 0.3);
  cursor: pointer;
  transition: color var(--transition);
  line-height: 1;
  white-space: nowrap;
}
.server-row-ip:hover {
  color: var(--accent);
}
.server-row:not(:has(.server-row-bg)) .server-row-ip {
  color: var(--text-500);
}
.server-row-map {
  display: flex;
  align-items: center;
  align-self: center;
  flex-shrink: 0;
}
@media (max-width: 767px) {
  .server-row-map {
    display: none;
  }
}
.server-map-pill {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: var(--small);
  font-weight: 600;
  padding: 4px 10px;
  border-radius: 100px;
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.1);
  color: rgba(255, 255, 255, 0.9);
  white-space: nowrap;
  backdrop-filter: saturate(180%) blur(20px);
  -webkit-backdrop-filter: saturate(180%) blur(20px);
}
.server-row:not(:has(.server-row-bg)) .server-map-pill {
  background: var(--transp-05);
  border-color: var(--transp-05);
  color: var(--text-300);
  backdrop-filter: none;
}
.server-row-ping {
  display: flex;
  align-items: center;
  align-self: center;
  flex-shrink: 0;
}
@media (max-width: 767px) {
  .server-row-ping {
    display: none;
  }
}
.server-ping-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: var(--small);
  font-weight: 600;
  padding: 4px 10px;
  border-radius: 100px;
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.1);
  color: rgba(255, 255, 255, 0.7);
  white-space: nowrap;
  backdrop-filter: saturate(180%) blur(20px);
  -webkit-backdrop-filter: saturate(180%) blur(20px);
}
.server-ping-badge svg, .server-ping-badge .icon {
  width: 13px;
  height: 13px;
  opacity: 0.6;
}
.server-row:not(:has(.server-row-bg)) .server-ping-badge {
  background: var(--transp-05);
  border-color: var(--transp-05);
  color: var(--text-400);
  backdrop-filter: none;
}
.server-row-muted {
  color: rgba(255, 255, 255, 0.2);
  font-size: var(--small);
}
.server-row:not(:has(.server-row-bg)) .server-row-muted {
  color: var(--text-600);
}
.server-play-btn {
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-50%) scale(0.8);
  z-index: 4;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  border: none;
  background: var(--accent);
  color: var(--accent-950);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity 0.25s cubic-bezier(0.4, 0, 0.2, 1), transform 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}
.server-play-btn:hover {
  filter: brightness(1.1);
}
.server-play-btn svg, .server-play-btn .icon {
  width: 14px;
  height: 14px;
}
@media (max-width: 767px) {
  .server-row-content {
    gap: 10px;
    padding: 10px 56px 10px 14px;
  }
  .server-row-ring {
    width: 32px;
    height: 32px;
  }
  .server-play-btn {
    opacity: 1;
    transform: translateY(-50%) scale(1);
    width: 32px;
    height: 32px;
    right: 10px;
  }
}
.total-online {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  width: 100%;
}
.total-online__top {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
}
.total-online__left {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.total-online__label {
  font-size: var(--small);
  color: var(--text-400);
  font-weight: 500;
}
.total-online__num {
  font-size: var(--h2);
  font-weight: 700;
  letter-spacing: -0.04em;
  color: var(--text);
  line-height: 1;
}
.total-online__num span {
  font-size: var(--h5);
  color: var(--text-500);
  font-weight: 400;
}
.total-online__right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 2px;
  text-align: right;
}
.total-online__pct {
  font-size: var(--h5);
  font-weight: 700;
  color: var(--text-300);
  letter-spacing: -0.02em;
}
.total-online__servers {
  font-size: var(--small);
  color: var(--accent);
  font-weight: 500;
  white-space: nowrap;
}
.total-online__bar {
  width: 100%;
  height: 6px;
  background: var(--transp-1);
  border-radius: 100px;
  overflow: hidden;
}
.total-online__bar-fill {
  height: 100%;
  border-radius: 100px;
  background: linear-gradient(90deg, var(--accent), color-mix(in srgb, var(--accent) 60%, transparent));
  transition: width 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}
@media (max-width: 767px) {
  .total-online {
    gap: 10px;
  }
  .total-online__num {
    font-size: var(--h3);
  }
  .total-online__num span {
    font-size: var(--h6);
  }
  .total-online__pct {
    font-size: var(--h6);
  }
  .total-online__bar {
    height: 4px;
  }
}
.monitoring-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: var(--space-lg);
  gap: var(--space-md);
}
@media (max-width: 767px) {
  .monitoring-header {
    flex-direction: column;
    align-items: flex-start;
  }
}
.monitoring-header__left {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.monitoring-header__title {
  font-size: var(--h4);
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--text);
  line-height: 1.2;
}
.monitoring-header__meta {
  display: flex;
  align-items: center;
  gap: 10px;
}
.monitoring-header__server-count {
  font-size: var(--small);
  color: var(--text-500);
}
.monitoring-header .monitoring-total {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 2px;
}
@media (max-width: 767px) {
  .monitoring-header .monitoring-total {
    display: none;
  }
}
.monitoring-header .monitoring-total-label {
  font-size: 11px;
  color: var(--text-500);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.monitoring-header .monitoring-total-num {
  font-size: var(--h4);
  font-weight: 700;
  letter-spacing: -0.03em;
  color: var(--text);
  line-height: 1;
}
.monitoring-header .monitoring-total-num span {
  font-size: var(--p);
  color: var(--text-500);
  font-weight: 400;
}
.monitoring-live-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 2px 8px;
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  border: 1px solid color-mix(in srgb, var(--accent) 25%, transparent);
  border-radius: 100px;
  font-size: 10px;
  font-weight: 700;
  color: var(--accent);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.monitoring-live-badge__dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--accent);
  animation: monitoring-live-pulse 2s ease-in-out infinite;
  flex-shrink: 0;
}
@keyframes monitoring-live-pulse {
  0%, 100% {
    box-shadow: 0 0 0 0 color-mix(in srgb, var(--accent) 40%, transparent);
  }
  50% {
    box-shadow: 0 0 0 4px transparent;
  }
}
.monitoring-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(380px, 1fr));
  gap: 12px;
}
@media (max-width: 767px) {
  .monitoring-grid {
    grid-template-columns: 1fr;
  }
}
.monitoring-grid > div {
  display: flex;
}
.monitoring-mode-compact {
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 10px;
}
.monitoring-mode-ultracompact {
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 8px;
}
@media (max-width: 767px) {
  .monitoring-empty-hide {
    display: none;
  }
}
.monitoring-empty-card {
  background: radial-gradient(circle, var(--background-900) 30%, var(--primary-900) 100%);
  height: 100%;
  width: 100%;
  border-radius: var(--border1);
}
.monitoring-card, .monitoring-card-mode {
  position: relative;
  overflow: hidden;
  border-radius: var(--border1);
  border: 1px solid var(--transp-1);
  cursor: pointer;
  transition: border-color var(--transition), box-shadow 0.3s;
  min-height: 140px;
}
.monitoring-card:hover, .monitoring-card-mode:hover {
  border-color: var(--transp-2);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.25);
}
.monitoring-card:hover .card-bg img, .monitoring-card-mode:hover .card-bg img {
  transform: scale(1.05);
}
.monitoring-card:hover .card-overlay, .monitoring-card-mode:hover .card-overlay {
  backdrop-filter: blur(2px);
}
.monitoring-card .card-bg, .monitoring-card-mode .card-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.monitoring-card .card-bg img, .monitoring-card-mode .card-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.monitoring-card .card-overlay, .monitoring-card-mode .card-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(to right, rgba(0, 0, 0, 0.75) 20%, rgba(0, 0, 0, 0.4) 55%, transparent 100%);
  backdrop-filter: blur(1px);
  mask-image: linear-gradient(to right, black 0%, black 35%, transparent 80%);
  -webkit-mask-image: linear-gradient(to right, black 0%, black 35%, transparent 80%);
  transition: all 0.3s;
}
.monitoring-card .card-content, .monitoring-card-mode .card-content {
  position: relative;
  z-index: 2;
  padding: 18px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  height: 100%;
}
.monitoring-card .card-name, .monitoring-card-mode .card-name {
  font-size: var(--h6);
  font-weight: 700;
  letter-spacing: -0.01em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin: 0;
  color: #fff;
}
.monitoring-card .card-meta, .monitoring-card-mode .card-meta {
  display: flex;
  gap: 5px;
  margin-top: 4px;
  flex-wrap: wrap;
}
.monitoring-card .card-tag, .monitoring-card-mode .card-tag {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  padding: 2px 7px;
  border-radius: 5px;
  background: rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(4px);
  color: rgba(255, 255, 255, 0.8);
  display: inline-flex;
  align-items: center;
  gap: 3px;
}
.monitoring-card .card-tag svg, .monitoring-card .card-tag .icon, .monitoring-card-mode .card-tag svg, .monitoring-card-mode .card-tag .icon {
  width: 10px;
  height: 10px;
  opacity: 0.7;
}
.monitoring-card .card-tag--off, .monitoring-card-mode .card-tag--off {
  color: #ff453a;
  background: rgba(255, 69, 58, 0.15);
}
.monitoring-card .card-tag--csgo, .monitoring-card-mode .card-tag--csgo {
  color: #ff9f0a;
  background: rgba(255, 159, 10, 0.15);
}
.monitoring-card .card-bottom, .monitoring-card-mode .card-bottom {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: auto;
  padding-top: 6px;
}
.monitoring-card .card-player-ring, .monitoring-card-mode .card-player-ring {
  position: relative;
  width: 34px;
  height: 34px;
  flex-shrink: 0;
}
.monitoring-card .card-player-ring svg, .monitoring-card-mode .card-player-ring svg {
  width: 100%;
  height: 100%;
  transform: rotate(-90deg);
}
.monitoring-card .card-player-ring__count, .monitoring-card-mode .card-player-ring__count {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  font-weight: 800;
  color: #fff;
  letter-spacing: -0.03em;
}
.monitoring-card .card-ring, .monitoring-card-mode .card-ring {
  width: 22px;
  height: 22px;
  flex-shrink: 0;
  transform: rotate(-90deg);
}
.monitoring-card .card-ring--off, .monitoring-card-mode .card-ring--off {
  opacity: 0.4;
}
.monitoring-card .card-players, .monitoring-card-mode .card-players {
  font-size: var(--h6);
  font-weight: 700;
  letter-spacing: -0.02em;
  color: #fff;
}
.monitoring-card .card-players span, .monitoring-card-mode .card-players span {
  color: rgba(255, 255, 255, 0.25);
  font-weight: 400;
  font-size: var(--small);
}
.monitoring-card .card-players--off, .monitoring-card-mode .card-players--off {
  color: var(--text-400);
}
.monitoring-card .card-players--off span, .monitoring-card-mode .card-players--off span {
  color: var(--text-500);
}
.monitoring-card .card-ping, .monitoring-card-mode .card-ping {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: var(--small);
  font-weight: 600;
  color: var(--text-300);
}
.monitoring-card .card-ping svg, .monitoring-card .card-ping .icon, .monitoring-card-mode .card-ping svg, .monitoring-card-mode .card-ping .icon {
  width: 12px;
  height: 12px;
}
.monitoring-card .card-toolbar, .monitoring-card-mode .card-toolbar {
  position: absolute;
  bottom: 0;
  right: 0;
  z-index: 4;
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 14px 16px;
}
.monitoring-card .card-btn, .monitoring-card-mode .card-btn {
  width: 38px;
  height: 38px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 10px;
  background: rgba(0, 0, 0, 0.3);
  border: 1px solid rgba(255, 255, 255, 0.1);
  color: rgba(255, 255, 255, 0.7);
  cursor: pointer;
  text-decoration: none;
  transition: var(--transition);
}
.monitoring-card .card-btn:hover, .monitoring-card-mode .card-btn:hover {
  background: rgba(255, 255, 255, 0.12);
  color: #fff;
  border-color: rgba(255, 255, 255, 0.2);
}
.monitoring-card .card-btn svg, .monitoring-card .card-btn .icon, .monitoring-card-mode .card-btn svg, .monitoring-card-mode .card-btn .icon {
  width: 17px;
  height: 17px;
}
.monitoring-card .card-btn--play, .monitoring-card-mode .card-btn--play {
  background: var(--accent);
  color: var(--accent-950);
  border-color: transparent;
}
.monitoring-card .card-btn--play:hover, .monitoring-card-mode .card-btn--play:hover {
  opacity: 0.85;
}
.monitoring-card-inactive, .monitoring-card-mode-inactive {
  opacity: 0.5;
}
.monitoring-card-inactive:hover, .monitoring-card-mode-inactive:hover {
  opacity: 0.65;
  box-shadow: none;
}
.monitoring-card-inactive .card-bg img, .monitoring-card-mode-inactive .card-bg img {
  filter: grayscale(1) brightness(0.5);
}
.monitoring-card--compact {
  min-height: 120px;
}
.monitoring-card--compact .card-content {
  padding: 14px;
}
.monitoring-card--compact .card-name {
  font-size: var(--p-small);
}
.monitoring-card--compact .card-player-ring {
  width: 28px;
  height: 28px;
}
.monitoring-card--compact .card-player-ring__count {
  font-size: 9px;
}
.monitoring-card--compact .card-toolbar {
  padding: 10px 12px;
}
.monitoring-card--compact .card-btn {
  width: 32px;
  height: 32px;
  border-radius: 8px;
}
.monitoring-card--compact .card-btn svg, .monitoring-card--compact .card-btn .icon {
  width: 15px;
  height: 15px;
}
.monitoring-card--ultracompact {
  min-height: 100px;
}
.monitoring-card--ultracompact .card-content {
  padding: 12px;
  gap: 2px;
}
.monitoring-card--ultracompact .card-name {
  font-size: var(--p-small);
}
.monitoring-card--ultracompact .card-meta {
  margin-top: 2px;
}
.monitoring-card--ultracompact .card-player-ring {
  width: 24px;
  height: 24px;
}
.monitoring-card--ultracompact .card-player-ring__count {
  font-size: 8px;
}
.monitoring-card--ultracompact .card-toolbar {
  padding: 8px 10px;
  gap: 4px;
}
.monitoring-card--ultracompact .card-btn {
  width: 28px;
  height: 28px;
  border-radius: 7px;
}
.monitoring-card--ultracompact .card-btn svg, .monitoring-card--ultracompact .card-btn .icon {
  width: 13px;
  height: 13px;
}
.monitoring-card-mode {
  min-height: auto;
  padding: 0;
}
.server-modal-split {
  position: relative;
  display: flex;
  flex-direction: row;
  width: 100%;
  height: 540px;
  max-height: 70vh;
  overflow: hidden;
}
@media (max-width: 767px) {
  .server-modal-split {
    flex-direction: column;
    height: auto;
    max-height: 85vh;
    overflow-y: auto;
  }
}
@media (min-width: 1024px) {
  .server-modal-split {
    min-width: 820px;
  }
}
.server-modal-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
}
.server-modal-split::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(to right, transparent 20%, var(--background-950) 55%);
  pointer-events: none;
}
@media (max-width: 767px) {
  .server-modal-split::before {
    background: linear-gradient(to bottom, transparent 20%, var(--background-950) 50%);
  }
}
.server-modal-split::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  mask-image: linear-gradient(to right, transparent 360px, black 360px);
  -webkit-mask-image: linear-gradient(to right, transparent 360px, black 360px);
  pointer-events: none;
}
@media (max-width: 767px) {
  .server-modal-split::after {
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    mask-image: linear-gradient(to bottom, transparent 200px, black 200px);
    -webkit-mask-image: linear-gradient(to bottom, transparent 200px, black 200px);
  }
}
.server-modal-map {
  width: 360px;
  flex-shrink: 0;
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  z-index: 2;
}
@media (max-width: 767px) {
  .server-modal-map {
    width: 100%;
    flex-shrink: 0;
  }
}
.server-modal-map-fade {
  position: absolute;
  inset: 0;
  z-index: 1;
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  mask-image: linear-gradient(to top, black 0%, black 45%, transparent 80%);
  -webkit-mask-image: linear-gradient(to top, black 0%, black 45%, transparent 80%);
  background: linear-gradient(to top, rgba(0, 0, 0, 0.82) 0%, rgba(0, 0, 0, 0.4) 45%, transparent 80%);
}
@media (max-width: 767px) {
  .server-modal-map-fade {
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    background: linear-gradient(to top, rgba(0, 0, 0, 0.85) 0%, rgba(0, 0, 0, 0.3) 50%, transparent 100%);
  }
}
.server-modal-map-content {
  position: relative;
  z-index: 2;
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
@media (max-width: 767px) {
  .server-modal-map-content {
    padding: 16px;
  }
}
.server-modal-title {
  font-size: var(--h4);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.2;
  color: #fff;
  text-shadow: 0 2px 12px rgba(0, 0, 0, 0.5);
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  word-break: break-word;
}
.server-modal-subtitle {
  font-size: var(--small);
  color: rgba(255, 255, 255, 0.45);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.server-modal-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin-top: 8px;
}
.server-modal-pill {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: var(--small);
  font-weight: 600;
  padding: 4px 10px;
  border-radius: 100px;
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.1);
  color: rgba(255, 255, 255, 0.9);
  white-space: nowrap;
  backdrop-filter: saturate(180%) blur(20px);
  -webkit-backdrop-filter: saturate(180%) blur(20px);
}
.server-modal-pill--ping {
  color: rgba(255, 255, 255, 0.7);
}
.server-modal-pill--ping svg, .server-modal-pill--ping .icon {
  width: 13px;
  height: 13px;
  opacity: 0.6;
}
.server-modal-pill--online {
  color: var(--accent);
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  border-color: color-mix(in srgb, var(--accent) 20%, transparent);
}
.server-modal-pill--offline {
  color: #ff453a;
  background: rgba(255, 69, 58, 0.12);
  border-color: rgba(255, 69, 58, 0.2);
}
.server-modal-pill--csgo {
  color: #ff9f0a;
  background: rgba(255, 159, 10, 0.12);
  border-color: rgba(255, 159, 10, 0.2);
  font-size: 10px;
  letter-spacing: 0.03em;
}
.server-modal-online-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 8px color-mix(in srgb, var(--accent) 50%, transparent);
}
.server-modal-ring {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}
.server-modal-ip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: var(--p-small);
  font-weight: 500;
  color: rgba(255, 255, 255, 0.8);
  margin-top: 8px;
  padding: 6px 14px;
  border-radius: 100px;
  background: rgba(255, 255, 255, 0.1);
  backdrop-filter: saturate(180%) blur(20px);
  -webkit-backdrop-filter: saturate(180%) blur(20px);
  border: 1px solid rgba(255, 255, 255, 0.12);
  width: fit-content;
  max-width: 100%;
  overflow: hidden;
  cursor: pointer;
  transition: background var(--transition);
}
.server-modal-ip:hover {
  background: rgba(255, 255, 255, 0.16);
}
.server-modal-ip span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  transition: color var(--transition);
}
.server-modal-ip svg, .server-modal-ip .icon {
  width: 15px;
  height: 15px;
  opacity: 0.5;
  flex-shrink: 0;
}
.server-modal-play-btn {
  margin-top: 14px;
}
@media (max-width: 767px) {
  .server-modal-play-btn {
    margin-top: 10px;
  }
}
.server-modal-players {
  flex: 1;
  min-width: 0;
  min-height: 0;
  display: flex;
  flex-direction: column;
  position: relative;
  z-index: 2;
}
@media (max-width: 767px) {
  .server-modal-players {
    border-top: 1px solid rgba(255, 255, 255, 0.06);
    max-height: none;
    flex: none;
  }
}
.server-modal-players-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 20px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  gap: 8px;
  background: rgba(0, 0, 0, 0.15);
  flex-shrink: 0;
}
.server-modal-players-header h3 {
  font-size: var(--p);
  font-weight: 700;
  display: flex;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
}
.server-modal-players-count {
  background: rgba(255, 255, 255, 0.08);
  font-size: 11px;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: 100px;
  color: rgba(255, 255, 255, 0.45);
  min-width: 24px;
  text-align: center;
}
.server-modal-players-list {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
}
.server-modal-search {
  width: 160px;
  min-height: auto;
  padding: 5px 10px;
  font-size: var(--small);
  transition: width var(--transition);
}
.server-modal-search:focus-within {
  width: 190px;
}
.server-modal-search input {
  background: none;
  border: none;
  outline: none;
  color: var(--text);
  font-size: var(--small);
  width: 100%;
}
.server-modal-search input::placeholder {
  color: var(--text-400);
}
.server-modal-table {
  width: 100%;
  border-collapse: collapse;
}
.server-modal-table th, .server-modal-table td {
  padding: 8px 14px;
  text-align: left;
}
.server-modal-table th {
  position: sticky;
  top: 0;
  background: var(--background);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  font-weight: 600;
  color: rgba(255, 255, 255, 0.3);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  z-index: 1;
}
.server-modal-table th svg, .server-modal-table th .icon {
  width: 14px;
  height: 14px;
}
.server-modal-table tbody tr {
  transition: background var(--transition);
  border-bottom: 1px solid var(--transp-05);
}
.server-modal-table tbody tr:last-child {
  border-bottom: none;
}
.server-modal-table tbody tr:hover {
  background: var(--transp-05);
}
.server-modal-table tbody tr.ct-row {
  background: linear-gradient(to right, rgba(33, 149, 243, 0.06), transparent 50%);
}
.server-modal-table tbody tr.t-row {
  background: linear-gradient(to right, rgba(255, 193, 7, 0.06), transparent 50%);
}
.server-modal-table .player-info > a {
  display: flex;
  align-items: center;
  gap: 8px;
  width: fit-content;
}
.server-modal-table .player-avatar {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  overflow: hidden;
  flex-shrink: 0;
  background: var(--transp-05);
  border: 1px solid var(--transp-1);
}
.server-modal-table .player-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.server-modal-table .player-faceit-rank {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  overflow: hidden;
  flex-shrink: 0;
}
.server-modal-table .player-faceit-rank img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.server-modal-table .player-name {
  font-weight: 500;
  font-size: var(--p-small);
  color: var(--text-200);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 180px;
  display: flex;
  align-items: center;
  gap: 4px;
}
.server-modal-table .player-rank {
  width: 100%;
  height: 24px;
}
.server-modal-table .player-rank img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.server-modal-table .player-ping .ping-value, .server-modal-table .ping-value {
  font-size: var(--small);
  font-weight: 600;
}
.server-modal-table .player-ping .ping-value.good, .server-modal-table .ping-value.good {
  color: var(--accent);
}
.server-modal-table .player-ping .ping-value.medium, .server-modal-table .ping-value.medium {
  color: #ff9f0a;
}
.server-modal-table .player-ping .ping-value.bad, .server-modal-table .ping-value.bad {
  color: #ff453a;
}
.server-modal-table td {
  font-size: var(--p-small);
  color: var(--text-300);
}
.server-ping-value {
  font-size: var(--small);
  font-weight: 600;
  transition: color 0.2s;
}
.server-ping-value.good {
  color: var(--accent);
}
.server-ping-value.medium {
  color: #ff9f0a;
}
.server-ping-value.bad {
  color: #ff453a;
}
.server-ping-value.offline {
  color: rgba(255, 255, 255, 0.3);
}
.server-details-empty {
  color: var(--text-400);
  text-align: center;
  padding: 2em;
  font-size: var(--small);
}
.server-details-skeleton {
  width: 100%;
  display: flex;
  height: 540px;
  max-height: 70vh;
}
@media (min-width: 1024px) {
  .server-details-skeleton {
    min-width: 820px;
  }
}
@media (max-width: 767px) {
  .server-details-skeleton {
    flex-direction: column;
    height: auto;
    max-height: none;
  }
}
.server-details-skeleton .skeleton-left {
  width: 360px;
  flex-shrink: 0;
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}
@media (max-width: 767px) {
  .server-details-skeleton .skeleton-left {
    width: 100%;
    min-height: 260px;
  }
}
.server-details-skeleton .skeleton-left .skeleton-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  background: var(--background-900);
  border-radius: 0;
}
.server-details-skeleton .skeleton-left-content {
  position: relative;
  z-index: 1;
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.server-details-skeleton .skeleton-left-content .skeleton-title-lg {
  height: 22px;
  width: 70%;
  background: var(--transp-1);
  border-radius: var(--border05);
}
.server-details-skeleton .skeleton-left-content .skeleton-subtitle {
  height: 12px;
  width: 40%;
  background: var(--transp-05);
  border-radius: var(--border05);
}
.server-details-skeleton .skeleton-left-content .skeleton-pills {
  display: flex;
  gap: 6px;
  margin-top: 4px;
}
.server-details-skeleton .skeleton-left-content .skeleton-pill {
  height: 26px;
  width: 80px;
  background: var(--transp-05);
  border-radius: 100px;
}
.server-details-skeleton .skeleton-left-content .skeleton-pill--sm {
  width: 56px;
}
.server-details-skeleton .skeleton-left-content .skeleton-ip {
  height: 28px;
  width: 65%;
  background: var(--transp-05);
  border-radius: 100px;
  margin-top: 4px;
}
.server-details-skeleton .skeleton-left-content .skeleton-btn {
  height: 38px;
  width: 100%;
  background: var(--transp-1);
  border-radius: var(--border05);
  margin-top: 6px;
}
.server-details-skeleton .skeleton-right {
  flex: 1;
  display: flex;
  flex-direction: column;
  background: rgba(0, 0, 0, 0.15);
}
.server-details-skeleton .skeleton-right-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 14px 20px;
  border-bottom: 1px solid var(--transp-05);
}
.server-details-skeleton .skeleton-right-header .skeleton-title {
  height: 18px;
  width: 120px;
  background: var(--transp-1);
  border-radius: var(--border05);
}
.server-details-skeleton .skeleton-right-header .skeleton-search {
  height: 32px;
  width: 140px;
  background: var(--transp-05);
  border-radius: var(--border05);
}
.server-details-skeleton .skeleton-right-rows {
  flex: 1;
  padding: 4px 0;
}
.server-details-skeleton .skeleton-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 20px;
}
.server-details-skeleton .skeleton-row .skeleton-avatar {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--transp-05);
  flex-shrink: 0;
}
.server-details-skeleton .skeleton-row .skeleton-name {
  height: 14px;
  width: 120px;
  background: var(--transp-1);
  border-radius: var(--border05);
}
.server-details-skeleton .skeleton-row .skeleton-stat {
  height: 12px;
  width: 36px;
  background: var(--transp-05);
  border-radius: var(--border05);
  margin-left: auto;
}
.server-details-skeleton .skeleton-row .skeleton-stat--sm {
  width: 28px;
  background: var(--background-900);
  margin-left: 0;
}
@media (min-width: 1024px) {
  .server-details-modal .modal__container {
    min-width: 820px;
    max-width: 900px;
  }
}
@media (max-width: 767px) {
  .server-details-modal .modal__container {
    max-width: 100%;
    margin: 0;
    border-radius: 16px 16px 0 0;
    max-height: 90vh;
  }
}
.server-details-modal .modal__content {
  padding: 0;
}
@media (max-width: 767px) {
  .server-details-modal .modal__content {
    overflow: hidden;
  }
}
.server-details-modal .modal__header {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 10;
  padding: var(--space-md);
}
.server-details-modal .modal__header .modal__title {
  display: none;
}
.server-details-modal .modal__close {
  background: rgba(0, 0, 0, 0.3);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-radius: 50%;
  color: rgba(255, 255, 255, 0.6);
}
.server-details-modal .modal__close:hover {
  background: rgba(0, 0, 0, 0.5);
  color: #fff;
}
.server-details-modal .modal__footer-server-details, .server-details-modal .modal__header {
  display: none;
}
.card-bans-table {
  background-color: var(--transp-05);
  border: 1px solid var(--transp-1);
  box-shadow: var(--shadow-small);
  overflow: hidden;
}
.card-bans-table .user-avatar {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  object-fit: cover;
}
.card-bans-table .type-icon {
  text-align: center;
  font-size: 20px;
  margin: 0 auto;
  color: var(--text-500);
  display: flex;
  align-items: center;
  justify-content: center;
}
.card-bans-table .ban-chip {
  padding: 10px 15px;
  background-color: var(--transp-03);
  font-weight: 500;
  font-size: 14px;
  border-radius: 6px;
  width: min-content;
  text-align: center;
  color: var(--error);
  position: relative;
  margin: 0 auto;
  white-space: nowrap;
}
.card-bans-table .ban-chip.bans-unban {
  color: var(--success);
}
.card-bans-table .ban-chip.bans-forever {
  color: var(--error);
}
.card-bans-table .ban-chip.bans-end {
  color: var(--success);
  text-decoration: line-through;
}
.card-bans-table .ban-chip.bans-session {
  color: var(--error);
}
.card-bans-table--table-surface .card-header {
  background-color: var(--transp-05);
  border-bottom: 0;
}
.card-bans-table--table-surface .card-body {
  background-color: var(--transp-05);
}
.sitebans-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}
.sitebans-card-header__text {
  min-width: 0;
}
.sitebans-card-header__search {
  margin: 0;
  width: min(360px, 100%);
  min-width: 280px;
  flex-shrink: 0;
}
@media (max-width: 768px) {
  .sitebans-card-header {
    flex-direction: column;
  }
  .sitebans-card-header__search {
    width: 100%;
    min-width: 0;
  }
}
.sitebans-row, .support-row {
  cursor: pointer;
  transition: background-color var(--transition);
}
.sitebans-row td, .support-row td {
  transition: color var(--transition);
}
.sitebans-row:hover, .support-row:hover {
  background-color: var(--background-900);
}
.sitebans-row:hover td, .support-row:hover td {
  color: var(--accent);
}
.sitebans-row:hover a, .sitebans-row:hover .support-user__name, .sitebans-row:hover .support-user__link, .sitebans-row:hover .support-user__inline, .support-row:hover a, .support-row:hover .support-user__name, .support-row:hover .support-user__link, .support-row:hover .support-user__inline {
  color: var(--accent);
}
.sitebans-cell-ip {
  display: inline-block;
  white-space: nowrap;
  word-break: normal;
  overflow-wrap: normal;
  font-variant-numeric: tabular-nums;
}
.sitebans-modal {
  display: grid;
  gap: 12px;
}
.sitebans-modal__row {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding-bottom: 6px;
  border-bottom: 1px solid var(--transp-03);
}
.sitebans-modal__row span {
  color: var(--text-500);
}
.sitebans-modal__row strong {
  text-align: right;
}
.sitebans-modal__actions {
  display: flex;
  justify-content: flex-end;
  margin-top: 8px;
}
.sitebans-info-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}
@media (max-width: 767px) {
  .sitebans-info-grid {
    grid-template-columns: 1fr;
  }
}
.sitebans-info-card {
  padding: 14px 16px;
  border-radius: var(--border1);
  border: 1px solid var(--transp-1);
  background: var(--transp-03);
  display: grid;
  gap: 6px;
  min-width: 0;
}
.sitebans-info-label {
  font-size: 12px;
  color: var(--text-500);
}
.sitebans-info-value {
  font-weight: 600;
  color: var(--text);
  word-break: break-word;
}
.sitebans-ip-link {
  color: var(--accent);
  text-decoration: underline;
  text-decoration-color: rgba(var(--accent), 0.4);
  cursor: pointer;
}
.sitebans-ip-link:hover {
  color: var(--accent-100);
  text-decoration-color: rgba(var(--accent-100), 0.6);
}
.sitebans-ip-modal {
  display: grid;
  gap: 12px;
}
.sitebans-ip-map {
  border-radius: var(--border1);
  overflow: hidden;
  border: 1px solid var(--transp-1);
  background: var(--transp-03);
}
.sitebans-ip-map iframe {
  display: block;
  width: 100%;
  height: 320px;
  border: 0;
}
.sitebans-ip-meta {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding-bottom: 6px;
  border-bottom: 1px solid var(--transp-03);
}
.sitebans-ip-meta span {
  color: var(--text-500);
}
.sitebans-ip-meta strong {
  text-align: right;
}
.sitebans-ip-map-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--accent);
}
.support-results {
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  background-color: transparent;
  min-height: 60px;
}
.support-results__list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.support-result {
  display: flex;
  gap: 12px;
  padding: 10px 12px;
  border-radius: var(--border05);
  border: 1px solid var(--transp-1);
  background-color: var(--transp-03);
  cursor: pointer;
  transition: var(--transition);
}
.support-result:hover {
  background-color: var(--transp-03);
  border-color: var(--accent);
}
.support-result:hover .support-result__title, .support-result:hover .support-result__meta, .support-result:hover .support-result__reason, .support-result:hover .text-muted {
  color: var(--accent);
}
.support-result input {
  margin-top: 4px;
}
.support-result__body {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.support-result__title {
  font-weight: 600;
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.support-result__meta {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  font-size: 12px;
  color: var(--text-500);
}
.support-result__reason {
  font-size: 13px;
  color: var(--text);
}
.support-status {
  display: inline-flex;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 12px;
  background-color: var(--transp-03);
  color: var(--text);
}
.support-status--pending {
  color: var(--warning);
}
.support-status--approved {
  color: var(--success);
}
.support-status--rejected {
  color: var(--error);
}
.support-status--closed {
  color: var(--success);
}
.support-table th, .support-table td {
  text-align: center;
  vertical-align: middle;
}
.support-user {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.support-user__avatar {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  object-fit: cover;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--transp-03);
  color: var(--text-500);
  font-weight: 600;
  border: 1px solid var(--transp-1);
}
.support-user__inline {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: inherit;
  transition: color var(--transition);
  text-decoration: none;
}
.support-user__avatar--placeholder {
  font-size: 12px;
}
.support-user__link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  text-decoration: none;
  color: inherit;
  transition: color var(--transition);
}
.support-user__name {
  font-weight: 500;
  color: var(--text);
  transition: color var(--transition);
}
.support-type-switch {
  display: grid;
  gap: 12px;
  margin-bottom: 0;
}
.support-type-switch__btn {
  width: 100%;
  min-height: 56px;
  padding: 12px 16px;
  border-radius: 12px;
  border: 1px solid var(--transp-1);
  background-color: var(--transp-03);
  color: var(--text);
  font-size: 15px;
  font-weight: 700;
  line-height: 1.2;
  transition: background-color var(--transition), border-color var(--transition), color var(--transition);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  white-space: normal;
}
.support-type-switch__btn:hover {
  border-color: var(--accent);
  color: var(--accent);
  background-color: var(--transp-03);
}
.support-type-switch__btn:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--accent) 55%, transparent);
  outline-offset: 2px;
}
.support-type-switch__btn.is-active {
  border-color: var(--accent);
  background-color: var(--transp-03);
  color: var(--accent);
}
.support-type-switch__btn-title {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-width: 0;
}
.support-type-switch__label {
  font-size: 1rem;
  font-weight: 600;
  color: var(--text);
  margin: 0;
  text-align: left;
  width: 100%;
}
.support-type-switch__buttons {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  width: 100%;
}
@media (max-width: 767px) {
  .support-type-switch__buttons {
    grid-template-columns: 1fr;
  }
}
.support-form-body {
  margin-top: 0;
  display: grid;
  gap: 18px;
  max-width: 100%;
  width: 100%;
}
.support-form-actions {
  display: flex;
  justify-content: flex-end;
  margin-top: 12px;
}
.support-form-body .support-form-actions {
  justify-content: flex-end;
}
.support-add-form {
  display: grid;
  gap: 18px;
  background-color: var(--transp-05);
  border-top: 1px solid var(--transp-1);
  padding: 18px;
}
@media (max-width: 767px) {
  .support-add-form {
    padding: 14px;
  }
}
.support-note {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 10px 12px;
  border-radius: var(--border1);
  border: 1px solid color-mix(in srgb, var(--accent) 32%, var(--transp-1));
  background: transparent;
  background-color: transparent;
}
.support-note__icon {
  width: 20px;
  height: 20px;
  flex: 0 0 20px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  border: 1px solid color-mix(in srgb, var(--accent) 45%, transparent);
  color: var(--accent);
  font-size: 13px;
  font-weight: 700;
  line-height: 1;
  margin-top: 1px;
}
.support-note__text {
  color: var(--text);
  font-size: 14px;
  line-height: 1.45;
}
.support-add-composer {
  display: flex;
  gap: 1rem;
  padding: 1rem;
  background: var(--transp-03);
  border: 1px solid var(--transp-1);
  border-radius: var(--border1, 0.75rem);
}
.support-add-composer .wall-composer__avatar {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--transp-03);
  color: var(--text-500);
  font-weight: 600;
  border: 1px solid var(--transp-1);
}
.support-add-composer .wall-composer__form {
  flex: 1;
  min-width: 0;
}
.support-add-composer .wall-composer__row {
  display: flex;
  gap: 12px;
  align-items: center;
}
@media (max-width: 767px) {
  .support-add-composer .wall-composer__row {
    flex-direction: column;
    align-items: stretch;
  }
}
.support-add-composer .wall-composer__input {
  width: 100%;
  background: transparent;
  border: none;
  color: var(--text);
  font-size: var(--p, 0.9375rem);
  font-family: var(--font);
  padding: var(--space-xs, 0.5rem) 0;
  resize: none;
  min-height: 2.5rem;
  outline: none;
  line-height: 1.5;
  flex: 1 1 auto;
}
.support-add-composer .wall-composer__input::placeholder {
  color: var(--text-600);
}
.support-add-composer .wall-composer__submit {
  padding: 0.375rem 1rem;
  background: var(--text);
  color: var(--background);
  border: none;
  border-radius: 1rem;
  font-size: var(--small, 0.75rem);
  font-weight: 600;
  font-family: var(--font);
  cursor: pointer;
  transition: opacity var(--transition);
  white-space: nowrap;
}
.support-add-composer .wall-composer__submit:hover {
  opacity: 0.9;
}
.support-steps {
  display: grid;
  gap: 16px;
  padding-bottom: 0;
}
.support-step {
  display: grid;
  gap: 10px;
  padding: 14px;
  border-radius: var(--border1);
  border: 0 !important;
  background: transparent !important;
  background-color: transparent !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}
.support-step.is-hidden {
  display: none;
}
.support-step__header {
  display: flex;
  align-items: center;
  gap: 10px;
}
.support-step__badge {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--accent);
  color: var(--background);
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
}
.support-step__title {
  font-size: 1rem;
  font-weight: 600;
  color: var(--text);
}
.support-form-section {
  display: grid;
  gap: 12px;
}
.support-search-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: end;
}
@media (max-width: 767px) {
  .support-search-row {
    grid-template-columns: 1fr;
  }
}
.support-search-btn {
  white-space: nowrap;
  min-width: 140px;
}
.support-comment {
  min-height: 140px;
  color: var(--text) !important;
}
.support-comment::placeholder {
  color: var(--text-500) !important;
  opacity: 1;
}
.support-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 24px;
  align-items: start;
}
@media (max-width: 992px) {
  .support-layout {
    grid-template-columns: 1fr;
  }
}
.support-page .card-header {
  flex-wrap: wrap;
  gap: 12px;
}
.support-topbar {
  grid-column: 1 / -1;
  border: 0 !important;
  background: transparent !important;
  background-color: transparent !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  padding: 0 !important;
}
.support-topbar .card-header, .support-summary .card-header {
  margin-bottom: 0;
  background: transparent !important;
  background-color: transparent !important;
}
.support-topbar .card-header {
  border: 0 !important;
  padding: 0 !important;
}
.support-summary__body {
  padding: 0;
}
.support-actions {
  row-gap: 8px;
}
.support-bottom-grid {
  display: contents;
}
.support-summary, .support-chat-section {
  grid-column: 1;
}
.support-side {
  grid-column: 2;
  grid-row: 2 / span 2;
}
@media (max-width: 992px) {
  .support-summary, .support-chat-section, .support-side {
    grid-column: auto;
    grid-row: auto;
  }
}
.support-side {
  display: grid;
  gap: 16px;
}
.support-side-card {
  border: 1px solid var(--transp-1);
  border-radius: var(--border1);
  padding: 16px;
  background-color: var(--transp-05);
  box-shadow: var(--shadow-small);
}
.support-side-card__title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 15px;
  font-weight: 600;
  margin: 0 0 12px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--transp-05);
}
.support-side-card__title i {
  font-size: 16px;
  color: var(--text-500);
  line-height: 1;
}
.support-side-meta {
  display: grid;
  gap: 8px;
}
.support-side-meta__row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: baseline;
  gap: 12px;
  padding: 2px 0;
}
.support-side-meta__row span {
  color: var(--text-500);
  font-size: 13px;
}
.support-side-meta__row strong {
  color: var(--text);
  font-weight: 600;
  text-align: right;
  font-size: 14px;
  line-height: 1.35;
}
.support-side-meta__row .support-info-value {
  font-size: 14px;
  padding: 2px 10px;
  border: 0;
}
.support-side-meta__row .support-info-value--status-pending {
  background-color: color-mix(in srgb, var(--warning) 12%, transparent);
}
.support-side-meta__row .support-info-value--status-approved {
  background-color: color-mix(in srgb, var(--success) 12%, transparent);
}
.support-side-meta__row .support-info-value--status-rejected {
  background-color: color-mix(in srgb, var(--error) 12%, transparent);
}
.support-side-meta__row .support-info-value--status-closed {
  background-color: var(--transp-03);
}
.support-side .support-side-meta__row .support-info-value--status {
  color: var(--text);
}
.support-side-list {
  display: grid;
  gap: 0;
}
.support-side-item {
  display: grid;
  gap: 4px;
  padding: 10px 0;
  border: 0;
  border-radius: 0;
  color: inherit;
  text-decoration: none;
  background: transparent;
  border-bottom: 1px solid var(--transp-03);
}
.support-side-item__title {
  font-weight: 600;
}
.support-side-item__meta {
  font-size: 12px;
  color: var(--text-500);
}
.support-side-list .support-side-item:last-child {
  border-bottom: 0;
}
.support-side-item:hover .support-side-item__title, .support-side-item:hover .support-side-item__meta {
  color: var(--accent);
}
.support-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}
.support-actions form {
  margin: 0;
}
.support-chat-section {
  min-width: 0;
  border: 1px solid var(--transp-1);
  border-radius: var(--border1);
  padding: 16px;
  background: var(--transp-05);
  box-shadow: var(--shadow-small);
}
.support-chat-section .wall-container {
  display: flex;
  flex-direction: column;
}
.support-chat-section .wall-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-md, 1rem);
}
.support-chat-section .wall-header__title {
  font-size: var(--h6, 1rem);
  font-weight: 600;
  color: var(--text);
  margin: 0;
}
.support-chat-section .wall-header__count {
  font-size: var(--small, 0.75rem);
  color: var(--text-500);
}
.support-chat-section .wall-composer {
  display: flex;
  gap: var(--space-md, 1rem);
  padding: var(--space-md, 1rem);
  background: var(--transp-03);
  border: 1px solid var(--transp-1);
  border-radius: var(--border1, 0.75rem);
  margin-bottom: var(--space-md, 1rem);
}
.support-chat-section .wall-composer--locked {
  align-items: center;
  border-color: var(--accent);
  background: transparent;
}
.support-chat-section .wall-composer--guest {
  justify-content: center;
}
.support-chat-section .wall-composer__lock-text {
  color: var(--accent);
  font-size: 14px;
  line-height: 1.4;
  font-weight: 600;
}
.support-chat-section .wall-composer__avatar {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--transp-03);
  color: var(--text-500);
  font-weight: 600;
}
.support-chat-section .wall-composer__avatar--placeholder {
  border: 1px solid var(--transp-1);
}
.support-chat-section .wall-composer__form {
  flex: 1;
  min-width: 0;
}
.support-chat-section .wall-composer__row {
  display: flex;
  gap: 12px;
  align-items: center;
}
@media (max-width: 767px) {
  .support-chat-section .wall-composer__row {
    flex-direction: column;
    align-items: stretch;
  }
}
.support-chat-section .wall-composer__row--guest {
  justify-content: center;
  text-align: center;
}
@media (max-width: 767px) {
  .support-chat-section .wall-composer__row--guest {
    align-items: center;
  }
}
.support-chat-section .wall-composer__guest-note {
  margin: 0;
  color: var(--text-500);
  line-height: 1.35;
}
.support-chat-section .wall-composer__input {
  width: 100%;
  background: transparent;
  border: none;
  color: var(--text);
  font-size: var(--p, 0.9375rem);
  font-family: var(--font);
  padding: var(--space-xs, 0.5rem) 0;
  resize: none;
  overflow-y: hidden;
  min-height: 2.5rem;
  outline: none;
  line-height: 1.5;
  flex: 1 1 auto;
}
.support-chat-section .wall-composer__input::placeholder {
  color: var(--text-600);
}
.support-chat-section .wall-composer__actions {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: var(--space-xs, 0.5rem);
}
.support-chat-section .wall-composer__submit {
  padding: 0.375rem 1rem;
  background: var(--text);
  color: var(--background);
  border: none;
  border-radius: 1rem;
  font-size: var(--small, 0.75rem);
  font-weight: 600;
  font-family: var(--font);
  cursor: pointer;
  transition: opacity var(--transition);
  white-space: nowrap;
}
.support-chat-section .wall-composer__submit:hover {
  opacity: 0.9;
}
.support-chat-section .wall-composer__submit:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
.support-chat-section .wall-feed {
  display: flex;
  flex-direction: column;
}
.support-chat-section .wall-post {
  display: flex;
  gap: var(--space-sm, 0.75rem);
  padding: var(--space-md, 1rem) 0;
  border-bottom: 1px solid var(--transp-03);
}
.support-chat-section .wall-post:last-child {
  border-bottom: none;
}
.support-chat-section .wall-post__left {
  display: flex;
  flex-direction: column;
  align-items: center;
  flex-shrink: 0;
}
.support-chat-section .wall-post__avatar {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 50%;
  overflow: hidden;
  border: 1px solid var(--transp-1);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-500);
  background: var(--transp-03);
  font-weight: 600;
}
.support-chat-section .wall-post__avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.support-chat-section .wall-post__avatar-link {
  display: inline-flex;
  width: 100%;
  height: 100%;
}
.support-chat-section .wall-post__body {
  flex: 1;
  min-width: 0;
}
.support-chat-section .wall-post__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-xs, 0.5rem);
  margin-bottom: 0.125rem;
}
.support-chat-section .wall-post__info {
  display: flex;
  align-items: center;
  gap: var(--space-xs, 0.5rem);
  flex-wrap: wrap;
  line-height: 1.4;
}
.support-chat-section .wall-post__name {
  font-weight: 600;
  color: var(--text);
  text-decoration: none;
  font-size: var(--p, 0.9375rem);
}
.support-chat-section .wall-post__time {
  font-size: var(--small, 0.75rem);
  color: var(--text-500);
}
.support-chat-section .wall-post__content {
  font-size: var(--p, 0.9375rem);
  line-height: 1.5;
  color: var(--text-200);
  white-space: pre-wrap;
  word-wrap: break-word;
}
.support-details-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}
@media (max-width: 767px) {
  .support-details-grid {
    grid-template-columns: 1fr;
  }
}
.support-details-unban {
  display: grid;
  gap: 16px;
  padding: 0 16px 12px;
}
@media (max-width: 767px) {
  .support-details-unban {
    padding: 0 12px 10px;
  }
}
.support-details-unban__meta {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 0.8fr);
  gap: 18px;
  align-items: start;
}
@media (max-width: 767px) {
  .support-details-unban__meta {
    grid-template-columns: 1fr;
  }
}
.support-details-unban__meta--single {
  grid-template-columns: minmax(0, 1fr);
}
.support-player-head {
  grid-column: 1 / -1;
  display: flex;
  align-items: flex-start;
  gap: 14px;
  border-radius: var(--border1);
  border: 0 !important;
  padding: 14px 0;
  background: transparent !important;
  background-color: transparent !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  min-width: 0;
}
.support-player-head__avatar {
  width: 56px;
  height: 56px;
  flex: 0 0 56px;
  border-radius: 50%;
  overflow: hidden;
  border: 1px solid var(--transp-1);
  background: var(--transp-03);
  color: var(--text-500);
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.support-player-head__avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.support-player-head__avatar-link {
  display: block;
  width: 100%;
  height: 100%;
}
.support-player-head__body {
  min-width: 0;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 4px;
}
.support-player-head__name {
  color: var(--text);
  text-decoration: none;
  font-size: 1.05rem;
  font-weight: 700;
  display: inline-flex;
  width: fit-content;
}
.support-player-head__name:hover {
  color: var(--accent);
}
.support-player-head__ids {
  display: flex;
  align-items: center;
  flex-wrap: nowrap;
  gap: 14px;
  min-width: 0;
  overflow-x: auto;
  scrollbar-width: thin;
}
.support-player-head__id {
  font-size: 14px;
  line-height: 1.35;
  font-weight: 400;
  color: var(--text);
  padding: 0;
  max-width: 100%;
  word-break: break-word;
}
.support-info-card {
  border-radius: var(--border1);
  padding: 12px 0 0;
  background: transparent !important;
  background-color: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  display: grid;
  gap: 0;
  align-content: start;
}
.support-info-card__title {
  font-size: 16px;
  font-weight: 700;
  margin: 0 0 8px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--transp-05);
}
.support-info-card__row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: baseline;
  gap: 12px;
  margin: 0;
  padding: 8px 0;
  border-bottom: 1px solid var(--transp-03);
}
.support-info-card__row > span {
  color: var(--text-500);
  font-size: 13px;
  line-height: 1.35;
}
.support-info-card__row strong {
  text-align: right;
  font-size: 14px;
  line-height: 1.35;
  color: var(--text);
  font-weight: 600;
  min-width: 0;
  word-break: break-word;
}
.support-info-card__row:last-child {
  border-bottom: 0;
}
@media (max-width: 767px) {
  .support-info-card__row {
    grid-template-columns: 1fr;
    gap: 4px;
  }
  .support-info-card__row strong {
    text-align: left;
  }
}
.support-info-value {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 2px 10px;
  border-radius: 999px;
  background-color: var(--transp-03);
}
.support-info-value--status.support-info-value--status-pending {
  color: var(--warning);
}
.support-info-value--status.support-info-value--status-approved {
  color: var(--success);
}
.support-info-value--status.support-info-value--status-rejected {
  color: var(--error);
}
.support-info-value--status.support-info-value--status-closed {
  color: var(--text-500);
}
.support-info-value--length-permanent {
  color: var(--error);
  background-color: color-mix(in srgb, var(--error) 12%, transparent);
}
.support-info-value--length-time {
  color: var(--warning);
  background-color: color-mix(in srgb, var(--warning) 12%, transparent);
}
.support-info-value--length-unbanned {
  color: var(--success);
  background-color: color-mix(in srgb, var(--success) 12%, transparent);
}
.support-info-value--length-unknown {
  color: var(--text-500);
}
.support-steam-inline {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 14px;
  flex-wrap: nowrap;
  white-space: nowrap;
  max-width: 100%;
  overflow-x: auto;
  scrollbar-width: thin;
}
.support-steam-inline__primary {
  color: var(--text);
  font-weight: 600;
}
.support-steam-inline__item {
  color: var(--text);
  font-weight: 600;
}
@media (max-width: 767px) {
  .support-steam-inline {
    justify-content: flex-start;
  }
}
.sitebans-other-list {
  display: grid;
  gap: 8px;
}
.servers > .btn {
  transition: var(--transition);
}
.servers > .btn:hover {
  color: var(--accent);
  background-color: var(--background-900);
  border-color: var(--transp-2);
}
.servers > .btn.btn-primary {
  color: var(--accent);
  background-color: var(--accent-100);
  border-color: color-mix(in srgb, var(--accent) 35%, transparent);
}
.card-bans-table .table th.sortable:hover {
  background-color: transparent;
  color: var(--accent);
}
.card-bans-table .table th.sortable:hover a, .card-bans-table .table th.sortable:hover .sort-icon {
  color: var(--accent);
}
.card-bans-table .table__pagination-item.active {
  color: var(--accent);
  background-color: var(--accent-100);
}
.card-bans-table .table__pagination-item:not(.disabled):hover {
  color: var(--accent);
  background-color: var(--background-900);
}
.card-bans-table .table th.sortable:has(.sort-icon:has(.ph-arrow-up)), .card-bans-table .table th.sortable:has(.sort-icon:has(.ph-arrow-down)) {
  color: var(--accent);
  background-color: var(--accent-100);
  border-radius: var(--border05);
}
.servers-block {
  background-color: var(--transp-03);
  border: 1px solid var(--transp-1);
  box-shadow: var(--shadow-small);
  border-radius: var(--border1);
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  position: sticky;
  top: 110px;
}
.servers-block-container {
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.servers-block-container > a {
  padding: 10px 15px;
  font-weight: 500;
  border-radius: var(--border05);
  border: 1px solid transparent;
  transition: var(--transition);
  color: var(--text-500);
  font-size: 14px;
}
.servers-block-container > a:hover {
  color: var(--accent);
  background-color: var(--background-900);
  border-color: var(--transp-2);
}
.servers-block-container > a.selected {
  color: var(--accent);
  background-color: var(--accent-100);
  border-color: color-mix(in srgb, var(--accent) 35%, transparent);
}
.support-user__steam-link {
  color: var(--text-link, #3b82f6);
  text-decoration: none;
  transition: color 0.2s ease;
}
.support-user__steam-link:hover {
  color: var(--text-link-hover, #1d4ed8);
}
.servers {
  display: flex;
  flex-direction: row;
  gap: 5px;
  justify-content: center;
}
.servers-block {
  background-color: var(--transp-03);
  border: 1px solid var(--transp-1);
  box-shadow: var(--shadow-small);
  border-radius: var(--border1);
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  position: sticky;
  top: 110px;
}
.servers-block-container {
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.servers-block-container > a {
  padding: 10px 15px;
  font-weight: 500;
  border-radius: var(--border05);
  transition: var(--transition);
  color: var(--text-500);
  font-size: 14px;
}
.servers-block-container > a:hover {
  background-color: var(--transp-03);
  color: var(--text);
}
.servers-block-container > a.selected {
  color: var(--accent);
  background-color: var(--accent-100);
}
.sitebans-profile-servers {
  position: static;
  top: auto;
  margin-bottom: 10px;
}
.sitebans-profile-servers .servers-block-container {
  flex-direction: row;
  flex-wrap: wrap;
  gap: 8px;
}
.sitebans-profile-servers .servers-block-container > a {
  white-space: nowrap;
}
.sitebans-profile-privileges {
  margin-top: 10px;
  padding: 12px;
  background-color: var(--transp-03);
  border: 1px solid var(--transp-1);
  box-shadow: var(--shadow-small);
  border-radius: var(--border1);
}
.sitebans-profile-privileges__title {
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-bottom: 8px;
}
.sitebans-profile-privileges__list {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.sitebans-profile-privileges__item {
  background: var(--transp-03);
  border-radius: var(--border05);
  padding: 8px 10px;
  border: 1px solid var(--transp-2);
}
.sitebans-profile-privileges__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}
.sitebans-profile-privileges__name {
  font-weight: 600;
  font-size: 15px;
  line-height: 1.2;
  min-width: 0;
}
.sitebans-profile-privileges__server {
  margin-top: 4px;
  font-size: 12px;
  line-height: 1.25;
  color: var(--text-500);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.sitebans-profile-privileges__expires {
  font-size: 12px;
  white-space: nowrap;
  color: var(--text-500);
}
.sitebans-profile-privileges__empty {
  color: var(--text-400);
  font-size: 12px;
}
.bans-blocks-container {
  display: flex;
  flex-direction: row;
  gap: 15px;
  flex-wrap: wrap;
  width: 100%;
}
.bans-main-block {
  flex: 1 0;
  padding: 20px 25px;
  border-radius: var(--border1);
  position: relative;
  overflow: hidden;
  border: 1px solid var(--transp-1);
  box-shadow: var(--shadow-small);
  min-width: 250px;
  background: var(--transp-03);
}
.bans-main-block.admins {
  --text-color: var(--accent);
}
.bans-main-block.bans {
  --text-color: var(--error);
}
.bans-main-block > i {
  position: absolute;
  right: -35px;
  font-size: 100px;
  color: var(--text-color);
  top: 5px;
  transform: rotate(15deg);
  opacity: 0.3;
}
.bans-main-block-content > p {
  font-weight: 500;
  opacity: 0.5;
  color: inherit;
}
.bans-main-block-content > h2 {
  font-weight: bold;
  color: var(--text-color);
}
.tournaments-page, .tournament-page {
  font-family: "Manrope", "Rubik", sans-serif;
  color: var(--text);
  --tournament-accent: var(--accent, #f5c84c);
  --tournament-accent-soft: color-mix(in srgb, var(--tournament-accent) 20%, transparent);
  --tournament-accent-strong: color-mix(in srgb, var(--tournament-accent) 90%, transparent);
  --tournament-accent-faint: color-mix(in srgb, var(--tournament-accent) 10%, transparent);
  --tournament-accent-border: color-mix(in srgb, var(--tournament-accent) 40%, transparent);
  --tournament-surface: var(--block, rgba(20, 22, 30, 0.78));
  --tournament-surface-soft: var(--transp-05, rgba(18, 20, 28, 0.7));
  --tournament-surface-muted: var(--transp-1, rgba(15, 17, 24, 0.6));
  --tournament-surface-strong: var(--background-800, rgba(18, 20, 28, 0.92));
}
.tournaments-page {
  position: relative;
  padding-bottom: 64px;
}
.tournaments-page::before {
  content: none;
}
.tournaments-hero {
  position: relative;
  margin-bottom: 32px;
}
.tournaments-hero__content {
  position: relative;
  z-index: 1;
  max-width: 640px;
  margin: 0 auto;
  text-align: center;
}
.tournaments-hero__title {
  font-size: clamp(32px, 5vw, 44px);
  margin: 0 0 12px;
  font-weight: 700;
}
.tournaments-hero__subtitle {
  margin: 0 auto;
  color: var(--text-200);
  font-size: 16px;
  text-align: center;
  max-width: 760px;
}
.tournaments-grouped {
  display: grid;
  gap: 28px;
  position: relative;
  z-index: 1;
}
.tournaments-section {
  display: grid;
  gap: 14px;
  margin-bottom: 28px;
}
.tournaments-section__head {
  display: grid;
  gap: 8px;
}
.tournaments-section__title {
  margin: 0;
  font-size: 20px;
  font-weight: 700;
}
.tournaments-section__line {
  height: 2px;
  width: 140px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--tournament-accent-strong), var(--tournament-accent-faint));
}
.tournaments-group__title {
  margin: 0 0 12px;
  font-size: 18px;
  font-weight: 700;
}
.tournaments-group__heading {
  display: grid;
  gap: 8px;
  margin-bottom: 14px;
}
.tournaments-group__line {
  height: 2px;
  width: 120px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--tournament-accent-strong), var(--tournament-accent-faint));
}
.tournaments-row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
  align-items: stretch;
}
@media (max-width: 1240px) {
  .tournaments-row {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
@media (max-width: 900px) {
  .tournaments-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 640px) {
  .tournaments-row {
    grid-template-columns: 1fr;
  }
}
.tournament-card {
  display: flex;
  flex-direction: column;
  border-radius: 18px;
  overflow: hidden;
  background: var(--tournament-surface);
  border: 1px solid var(--transp-1);
  box-shadow: var(--shadow-small);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.tournament-card:hover {
  transform: none;
  box-shadow: var(--shadow-small);
}
.tournament-card__media {
  position: relative;
  padding-top: 56%;
  background: linear-gradient(135deg, rgba(30, 35, 45, 0.9), rgba(16, 18, 24, 0.95));
  background-size: cover;
  background-position: center;
}
.tournament-card__status {
  position: absolute;
  top: 14px;
  right: 14px;
  background: rgba(0, 0, 0, 0.55);
  color: var(--tournament-accent);
  font-size: 12px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid var(--tournament-accent-border);
}
.tournament-card__body {
  padding: 18px;
  display: flex;
  flex-direction: column;
  background: var(--tournament-surface-strong);
}
.tournament-card__header {
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr);
  align-items: center;
  gap: 12px;
}
.tournament-card__header > .tournament-card__content:first-child {
  grid-column: 1 / -1;
}
.tournament-card__logo {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid var(--transp-2);
  background: var(--tournament-surface-muted);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.05);
}
.tournament-card__logo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.tournament-card__content {
  display: grid;
  gap: 10px;
  min-width: 0;
}
.tournament-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  font-size: 12px;
  color: var(--text-200);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.tournament-card__title {
  margin: 0;
  font-size: 20px;
  font-weight: 700;
  line-height: 1.2;
}
.tournaments-empty {
  margin: 8px auto 0;
  text-align: center;
  color: var(--text-200);
  font-size: clamp(24px, 4vw, 30px);
  font-weight: 700;
}
.tournaments-empty--small {
  margin: 0;
  text-align: left;
  font-size: 15px;
  font-weight: 500;
}
.tournaments-champions__card {
  position: relative;
}
.tournaments-champions__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.tournaments-champions__head .tournament-team-card__head {
  flex: 1 1 auto;
  min-width: 0;
}
.tournaments-champions__tag {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 0 10px;
  border-radius: 999px;
  border: 1px solid var(--transp-2);
  background: var(--tournament-surface-soft);
  color: var(--text-200);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.02em;
}
.tournaments-champions__members-summary {
  margin-top: -2px;
  color: var(--text-200);
  font-size: 12px;
}
.tournaments-champions .tournament-team-card__meta a {
  color: var(--text-100);
  text-decoration: none;
}
.tournaments-champions .tournament-team-card__meta a:hover {
  text-decoration: underline;
}
.tournaments-champions .tournament-team-card__member-role.is-captain {
  border-color: var(--tournament-accent-border);
  background: var(--tournament-accent-soft);
  color: var(--tournament-accent);
}
.tournaments-champions__divider {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 2px;
}
.tournaments-champions__divider::before, .tournaments-champions__divider::after {
  content: "";
  height: 1px;
  border-radius: 999px;
  background: var(--transp-2);
  flex: 1 1 auto;
}
.tournaments-champions__divider > span {
  flex: 0 0 auto;
  color: var(--text-300, var(--text-200));
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 700;
}
.tournaments-champions__achievement-row {
  margin-top: 2px;
  padding-bottom: 2px;
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  gap: 6px;
  min-width: 0;
}
.tournaments-champions__achievement-row.has-banner {
  border: 1px solid var(--transp-2);
  border-radius: 10px;
  padding: 8px 9px;
  background-image: linear-gradient(90deg, color-mix(in srgb, var(--background, #ffffff) 92%, transparent), color-mix(in srgb, var(--background, #ffffff) 78%, transparent)), var(--tournament-achievement-banner);
  background-size: cover;
  background-position: center;
}
.tournaments-champions__achievement-tournament {
  min-width: 0;
  color: var(--text-100);
  font-size: 12px;
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.tournaments-champions__achievement-place {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 24px;
  padding: 0 10px;
  border-radius: 999px;
  border: 1px solid var(--transp-2);
  background: var(--tournament-surface-soft);
  color: var(--text-100);
  font-size: 12px;
  font-weight: 600;
}
.tournaments-champions__achievement-tournament a {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  color: var(--text-100);
  text-decoration: none;
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.tournaments-champions__achievement-tournament img {
  width: 17px;
  height: 17px;
  border-radius: 5px;
  border: 1px solid var(--transp-2);
  object-fit: cover;
  flex: 0 0 17px;
}
.tournaments-champions__achievement-tournament > img {
  margin-right: 7px;
}
.tournaments-champions__achievement-tournament a:hover {
  text-decoration: underline;
}
.tournaments-champions__cup {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
}
.tournaments-champions__cup.is-gold {
  color: #f6c94b;
}
.tournaments-champions__cup.is-silver {
  color: #c3cbd6;
}
.tournaments-champions__cup.is-bronze {
  color: #cd7f32;
}
.tournament-page {
  padding-bottom: 64px;
}
.tournament-back {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  border-radius: 999px;
  border: 1px solid var(--transp-2);
  background: var(--tournament-surface-soft);
  color: var(--text);
  text-decoration: none;
  margin-bottom: 16px;
}
.tournament-page__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin: 12px 0 16px;
}
.tournament-page__header .tournament-back {
  margin-bottom: 0;
}
.tournament-page__header form {
  margin: 0;
}
.tournament-page__actions {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.tournament-page__action.is-danger {
  border-color: rgba(255, 105, 97, 0.4);
  color: #ff9d96;
  background: rgba(255, 105, 97, 0.12);
}
.tournament-page__title {
  margin: 0;
  font-size: 20px;
  font-weight: 700;
}
.tournament-page__action {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  border-radius: 999px;
  border: 1px solid var(--transp-2);
  background: var(--tournament-surface-soft);
  color: var(--text);
  text-decoration: none;
}
.tournament-page__action.is-disabled {
  opacity: 0.6;
  cursor: not-allowed;
}
.tournament-panel__line--full {
  width: 100%;
  height: 1px;
  border-radius: 999px;
  background: var(--transp-2);
}
.tournament-hero-card {
  border-radius: 20px;
  overflow: hidden;
  background: var(--tournament-surface-strong);
  border: 1px solid var(--transp-2);
  box-shadow: var(--shadow-large);
}
.tournament-hero {
  position: relative;
  padding: 42px 32px;
  background: linear-gradient(135deg, rgba(18, 22, 32, 0.95), rgba(10, 12, 18, 0.98));
  background-size: cover;
  background-position: center;
  min-height: 280px;
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.tournament-hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(0, 0, 0, 0.65), rgba(0, 0, 0, 0.2));
}
.tournament-hero__content {
  position: absolute;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
  inset: 14px;
}
.tournament-hero__status {
  position: absolute;
  top: 16px;
  right: 16px;
  padding: 6px 12px;
  border-radius: 999px;
  background: var(--tournament-accent);
  color: #1a1a1a;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 11px;
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.35);
}
.tournament-hero__main {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  padding: 8px 10px;
  border-radius: 12px;
  background: rgba(10, 12, 18, 0.45);
  border: 1px solid rgba(255, 255, 255, 0.18);
}
.tournament-hero__logo {
  width: 52px;
  height: 52px;
  border-radius: 12px;
  background: var(--tournament-accent-soft);
  display: grid;
  place-items: center;
  overflow: hidden;
  flex: 0 0 auto;
}
.tournament-hero__logo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.tournament-hero__logo svg {
  width: 36px;
  height: 36px;
}
.tournament-hero__title {
  font-size: clamp(20px, 3vw, 30px);
  margin: 0;
  letter-spacing: 0.02em;
}
.tournament-summary {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 8px 12px;
  padding: 14px 16px 16px;
  border-top: 1px solid var(--transp-2);
  background: var(--tournament-surface-strong);
}
.tournament-summary__item {
  display: grid;
  gap: 6px;
  font-size: 12px;
  color: var(--text-200);
}
.tournament-summary__item strong {
  font-size: 15px;
  color: var(--text);
}
@media (min-width: 1180px) {
  .tournament-summary {
    display: flex;
    flex-wrap: nowrap;
    gap: 10px;
  }
  .tournament-summary__item {
    min-width: 0;
    flex: 1 1 0;
  }
}
.tournament-layout {
  display: flex;
  flex-direction: column;
  gap: 26px;
  min-width: 0;
}
.tournament-tabs {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 10px;
  position: static;
  align-self: stretch;
  padding: 20px 0 0;
  border-bottom: none;
}
.tournament-tabs__link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border-radius: 999px;
  background: var(--tournament-surface-muted);
  border: 1px solid transparent;
  color: var(--text-200);
  text-decoration: none;
  transition: 0.2s ease;
}
.tournament-tabs__link.is-active {
  background: var(--tournament-accent-soft);
  border-color: var(--tournament-accent-border);
  color: var(--tournament-accent);
}
.tournament-tabs__link:hover {
  color: var(--text);
  border-color: var(--transp-2);
}
.tournament-tabs__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
  padding: 0 6px;
  border-radius: 999px;
  background: var(--tournament-accent);
  color: #1a1a1a;
  font-size: 10px;
  font-weight: 700;
}
.tournament-panels {
  display: grid;
  gap: 18px;
  min-width: 0;
}
.tournament-panel {
  display: none;
  background: var(--tournament-surface-soft);
  border: 1px solid var(--transp-2);
  border-radius: 16px;
  padding: 24px;
  min-width: 0;
}
.tournament-panel.is-active {
  display: block;
  animation: tournamentFade 0.25s ease;
}
.tournament-panel h3 {
  margin-top: 0;
}
.tournament-panel--plain {
  background: transparent;
  border: none;
  padding: 0;
}
.tournament-panel__heading {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 16px;
}
.tournament-panel__heading h3 {
  margin: 0;
}
.tournament-unpublished-note {
  display: inline-flex;
  align-items: center;
  margin-left: 8px;
  padding: 2px 8px;
  border-radius: 999px;
  border: 1px solid rgba(255, 184, 77, 0.35);
  background: rgba(255, 184, 77, 0.12);
  color: #ffcf7a;
  font-size: 11px;
  font-weight: 600;
  vertical-align: middle;
}
.tournament-panel__heading--split {
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}
.tournament-panel__title {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.tournament-panel__actions {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.tournament-panel__line {
  height: 2px;
  width: 120px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--tournament-accent-strong), var(--tournament-accent-faint));
}
.tournament-info-grid {
  display: grid;
  grid-template-columns: minmax(0, 2fr) minmax(0, 1fr);
  gap: 18px;
  align-items: start;
}
.tournament-info-main {
  display: grid;
  gap: 18px;
}
.tournament-schedule-side {
  display: grid;
  gap: 18px;
}
.tournament-info-card {
  background: var(--tournament-surface-soft);
  border: 1px solid var(--transp-2);
  border-radius: 16px;
  padding: 18px 20px;
  min-width: 0;
}
.tournament-info-card--schedule {
  display: grid;
  gap: 14px;
}
.tournament-info-card--maps {
  display: grid;
  gap: 12px;
}
.tournament-info-card--prizes {
  display: grid;
  gap: 12px;
}
.tournament-info-card--matches {
  display: grid;
  gap: 14px;
}
.tournament-bracket-card {
  min-width: 0;
  overflow: hidden;
}
.tournament-schedule-list {
  display: grid;
  gap: 10px;
}
.tournament-schedule-item {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid var(--transp-2);
  background: var(--tournament-surface-muted);
  font-size: 12px;
  color: var(--text-200);
}
.tournament-schedule-item strong {
  display: block;
  font-size: 13px;
  color: var(--text);
}
.tournament-schedule-item span {
  display: block;
  margin-top: 2px;
}
.tournament-schedule-item__status {
  align-self: center;
  padding: 4px 8px;
  border-radius: 999px;
  background: var(--tournament-accent-soft);
  color: var(--tournament-accent);
  font-size: 11px;
  white-space: nowrap;
}
.tournament-maps-list {
  display: grid;
  gap: 10px;
}
.tournament-maps-list__item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
  padding: 9px 0;
  border-bottom: 1px solid var(--transp-2);
}
.tournament-maps-list__item:last-child {
  border-bottom: none;
}
.tournament-maps-list__name {
  color: var(--text);
  font-weight: 600;
  font-size: 16px;
  line-height: 1.25;
  overflow-wrap: anywhere;
}
.tournament-maps-list__stats {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 5px 9px;
  border-radius: 10px;
  border: 1px solid var(--tournament-accent-border);
  background: var(--tournament-accent-faint);
}
.tournament-maps-list__stat {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  white-space: nowrap;
}
.tournament-maps-list__label {
  color: var(--tournament-accent);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.tournament-maps-list__value {
  color: var(--text);
  font-size: 12px;
  font-weight: 600;
}
@media (max-width: 640px) {
  .tournament-maps-list__item {
    grid-template-columns: 1fr;
    align-items: flex-start;
    gap: 8px;
  }
  .tournament-maps-list__stats {
    align-self: flex-start;
  }
}
.tournament-prize-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 10px;
}
.tournament-prize-list__item {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
  min-height: 92px;
  padding: 12px 12px;
  border-radius: 12px;
  border: 1px solid var(--transp-2);
  background: var(--tournament-surface-muted);
  font-size: 12px;
  color: var(--text-200);
}
.tournament-prize-list__place {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 26px;
  height: 26px;
  padding: 0 8px;
  border-radius: 999px;
  border: 1px solid var(--transp-2);
  background: rgba(255, 255, 255, 0.03);
  color: var(--text);
  font-weight: 600;
}
.tournament-prize-list__item.is-gold .tournament-prize-list__place {
  color: var(--tournament-accent);
}
.tournament-prize-list__item.is-silver .tournament-prize-list__place {
  color: #c3cbd6;
}
.tournament-prize-list__item.is-bronze .tournament-prize-list__place {
  color: #cd7f32;
}
.tournament-prize-list__reward {
  color: var(--text);
  font-weight: 600;
  line-height: 1.35;
}
.tournament-prize-list__item.is-gold {
  border-color: var(--tournament-accent-border);
  box-shadow: inset 0 2px 0 var(--tournament-accent-strong);
}
.tournament-prize-list__item.is-silver {
  border-color: rgba(195, 203, 214, 0.5);
  box-shadow: inset 0 2px 0 rgba(195, 203, 214, 0.9);
}
.tournament-prize-list__item.is-bronze {
  border-color: rgba(205, 127, 50, 0.5);
  box-shadow: inset 0 2px 0 rgba(205, 127, 50, 0.9);
}
.tournament-matches-groups {
  display: grid;
  gap: 18px;
  grid-template-columns: 1fr;
}
.tournament-matches-groups.is-split {
  grid-template-columns: 1fr;
}
.tournament-matches-group {
  display: grid;
  gap: 10px;
}
.tournament-matches-group--undated {
  grid-column: auto;
}
.tournament-matches-group--centered {
  grid-column: auto;
  width: 100%;
  max-width: 100%;
  justify-self: stretch;
}
.tournament-matches-group__date {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--tournament-accent);
  font-size: 13px;
  font-weight: 600;
}
.tournament-matches-table-wrap {
  overflow-x: auto;
}
.tournament-matches-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 460px;
  color: var(--text);
}
.tournament-matches-table th, .tournament-matches-table td {
  padding: 9px 10px;
  border-bottom: 1px dashed var(--transp-2);
  text-align: left;
  font-size: 13px;
  white-space: nowrap;
}
.tournament-matches-table th {
  color: var(--text-200);
  font-weight: 600;
}
.tournament-matches-table tbody tr:last-child td {
  border-bottom: none;
}
.tournament-matches-table td:last-child, .tournament-matches-table th:last-child {
  text-align: right;
}
.tournament-matches-table .is-defeat {
  color: var(--text-200);
}
.tournament-matches-table .is-winner .tournament-matches-team {
  color: #a7f3b4;
  font-weight: 700;
}
.tournament-matches-team {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
}
.tournament-matches-team__logo, .tournament-matches-team__avatar {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.tournament-matches-team__logo {
  object-fit: cover;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(255, 255, 255, 0.04);
}
.tournament-matches-team__avatar {
  font-size: 9px;
  font-weight: 700;
  color: var(--text);
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(255, 255, 255, 0.06);
}
.tournament-matches-team__name {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.tournament-matches-team__cup {
  width: 12px;
  height: 12px;
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  opacity: 0.95;
}
.tournament-matches-team__cup svg {
  width: 100%;
  height: 100%;
  display: block;
}
.tournament-matches-team__cup.is-gold {
  color: #f6c94b;
  filter: drop-shadow(0 0 6px rgba(246, 201, 75, 0.32));
}
.tournament-matches-team__cup.is-silver {
  color: #c3cbd6;
  filter: drop-shadow(0 0 5px rgba(195, 203, 214, 0.28));
}
.tournament-matches-team__cup.is-bronze {
  color: #cd7f32;
  filter: drop-shadow(0 0 5px rgba(205, 127, 50, 0.28));
}
.tournament-matches-team__badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 2px 8px;
  border-radius: 999px;
  border: 1px solid rgba(125, 235, 142, 0.45);
  background: rgba(125, 235, 142, 0.16);
  color: #a7f3b4;
  font-size: 10px;
  letter-spacing: 0.08em;
  font-weight: 700;
  line-height: 1;
}
.tournament-matches-match-meta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.tournament-text {
  color: var(--text-200);
  line-height: 1.6;
}
.tournament-list {
  display: grid;
  gap: 12px;
}
.tournament-list__row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  border-radius: 12px;
  background: var(--tournament-surface-muted);
  border: 1px solid var(--transp-2);
  color: var(--text);
  text-decoration: none;
}
.tournament-list__title {
  display: flex;
  align-items: center;
  gap: 10px;
}
.tournament-list__title img {
  width: 32px;
  height: 32px;
  border-radius: 10px;
  object-fit: cover;
}
.tournament-list__badge {
  width: 32px;
  height: 32px;
  border-radius: 10px;
  background: var(--tournament-accent-soft);
  color: var(--tournament-accent);
  font-weight: 700;
  display: grid;
  place-items: center;
}
.tournament-list__meta {
  font-size: 12px;
  color: var(--text-200);
}
.tournament-teams-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}
.tournament-team-card {
  display: flex;
  flex-direction: column;
  gap: 12px;
  min-width: 0;
  padding: 14px;
  border-radius: 14px;
  border: 1px solid var(--transp-2);
  background: var(--tournament-surface-muted);
}
.tournament-team-card__head {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}
.tournament-team-card__logo, .tournament-team-card__avatar {
  width: 46px;
  height: 46px;
  border-radius: 12px;
  flex: 0 0 46px;
}
.tournament-team-card__logo {
  object-fit: cover;
  border: 1px solid var(--transp-2);
  background: var(--tournament-surface);
}
.tournament-team-card__avatar {
  display: grid;
  place-items: center;
  font-size: 16px;
  font-weight: 700;
  color: var(--tournament-accent);
  background: var(--tournament-accent-soft);
  border: 1px solid var(--tournament-accent-border);
}
.tournament-team-card__title-wrap {
  display: grid;
  gap: 4px;
  min-width: 0;
}
.tournament-team-card__title {
  margin: 0;
  min-width: 0;
  font-size: 15px;
  font-weight: 700;
  color: var(--text);
  line-height: 1.25;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.tournament-team-card__meta {
  font-size: 12px;
  color: var(--text-200);
}
.tournament-team-card__members {
  display: grid;
  gap: 8px;
  min-width: 0;
}
.tournament-team-card__member {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  min-width: 0;
  padding: 6px 9px;
  border-radius: 8px;
  border: 1px solid var(--transp-2);
  background: var(--transp-1, color-mix(in srgb, var(--background, #ffffff) 92%, var(--text, #000000) 8%));
  color: var(--text-100);
  font-size: 12px;
  line-height: 1.35;
  position: relative;
  overflow: hidden;
  transition: border-color 0.15s ease;
}
.tournament-team-card__member.has-banner {
  background-image: linear-gradient(90deg, color-mix(in srgb, var(--background, #ffffff) 92%, transparent), color-mix(in srgb, var(--background, #ffffff) 78%, transparent)), var(--tournament-member-banner);
  background-size: cover;
  background-position: center;
}
.tournament-team-card__member:hover {
  border-color: color-mix(in srgb, var(--accent) 45%, var(--transp-2));
}
.tournament-team-card__member-main {
  flex: 1 1 auto;
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 8px;
}
.tournament-team-card__member-name {
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.tournament-team-card__member-avatar, .tournament-team-card__member-avatar-fallback {
  width: 22px;
  height: 22px;
  flex: 0 0 22px;
  border-radius: 999px;
}
.tournament-team-card__member-avatar-link {
  width: 22px;
  height: 22px;
  flex: 0 0 22px;
  border-radius: 999px;
  text-decoration: none;
  color: inherit;
}
.tournament-team-card__member-avatar-link:visited, .tournament-team-card__member-avatar-link:hover, .tournament-team-card__member-avatar-link:active, .tournament-team-card__member-avatar-link:focus {
  color: inherit;
  text-decoration: none;
}
.tournament-team-card__member-avatar {
  object-fit: cover;
  border: 1px solid var(--transp-2);
  background: var(--tournament-surface-soft);
}
.tournament-team-card__member-avatar-fallback {
  display: grid;
  place-items: center;
  border: 1px solid var(--transp-2);
  background: var(--transp-2);
  color: var(--text);
  font-size: 10px;
  font-weight: 700;
}
.tournament-team-card__member-name-link, .tournament-team-card__member-name-link:hover, .tournament-team-card__member-name-link:visited, .tournament-team-card__member-name-link:active, .tournament-team-card__member-name-link:focus {
  min-width: 0;
  color: var(--text);
  text-decoration: none;
}
.tournament-team-card__member-name {
  color: var(--text);
}
.tournament-team-card__member-role {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 20px;
  padding: 0 8px;
  border-radius: 999px;
  border: 1px solid var(--transp-2);
  background: var(--tournament-surface-soft);
  color: var(--text-100);
  font-size: 10px;
  font-weight: 600;
  line-height: 1;
  white-space: nowrap;
}
.tournament-team-card__member-role.is-captain {
  border-color: rgba(98, 156, 255, 0.46);
  background: rgba(98, 156, 255, 0.14);
  color: #86b4ff;
}
.tournament-team-card__member-role.is-player {
  border-color: rgba(94, 208, 128, 0.48);
  background: rgba(94, 208, 128, 0.14);
  color: #7be0a0;
}
.tournament-team-card__member-role.is-substitute {
  border-color: rgba(239, 180, 58, 0.5);
  background: rgba(239, 180, 58, 0.14);
  color: #efbe58;
}
.tournament-team-card__member-role.is-none {
  color: var(--text-200);
}
.tournament-team-card__member.is-empty {
  text-align: center;
  color: var(--text-300, var(--text-200));
  justify-content: center;
}
:root[data-theme="light"] .tournament-team-card__member-role.is-captain {
  border-color: rgba(45, 101, 199, 0.34);
  background: rgba(45, 101, 199, 0.1);
  color: #2456b3;
}
:root[data-theme="light"] .tournament-team-card__member-role.is-player {
  border-color: rgba(33, 140, 84, 0.34);
  background: rgba(33, 140, 84, 0.1);
  color: #1f8a55;
}
:root[data-theme="light"] .tournament-team-card__member-role.is-substitute {
  border-color: rgba(178, 120, 20, 0.34);
  background: rgba(178, 120, 20, 0.1);
  color: #a16410;
}
@media (max-width: 1240px) {
  .tournament-teams-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
.tournament-bracket-layout {
  display: grid;
  gap: 14px;
  width: 100%;
  min-width: 0;
}
.tournament-bracket-layout--double {
  gap: 14px;
}
.tournament-bracket-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
}
.tournament-bracket-toolbar__window {
  display: inline-flex;
  align-items: center;
  gap: 16px;
  margin-right: auto;
}
.tournament-bracket-toolbar__window[hidden] {
  display: none !important;
}
.tournament-bracket-toolbar__nav {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  border: 1px solid var(--transp-2);
  background: rgba(255, 255, 255, 0.04);
  color: var(--text);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 15px;
  font-weight: 700;
}
.tournament-bracket-toolbar__nav:disabled {
  opacity: 0.45;
  cursor: default;
}
.tournament-bracket-toolbar__fullscreen {
  border: 1px solid var(--transp-2);
  background: rgba(255, 255, 255, 0.04);
  color: var(--text);
  border-radius: 10px;
  padding: 6px 12px;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
}
.tournament-bracket-canvas {
  overflow-y: auto;
  overflow-x: hidden;
  width: 100%;
  min-width: 0;
  box-sizing: border-box;
  max-width: 100%;
  padding: 2px;
  border: 1px solid var(--transp-2);
  border-radius: 12px;
  background: var(--tournament-surface-soft);
  cursor: auto;
}
.tournament-bracket-canvas.is-fullscreen {
  width: 100%;
  height: 100%;
  max-width: 100%;
  border: none;
  border-radius: 0;
  padding: 18px;
  background: var(--background);
  overflow: auto;
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  cursor: auto;
}
.tournament-bracket-board {
  width: 100%;
  min-width: 0;
}
.tournament-bracket-canvas.is-fullscreen .tournament-bracket-board {
  width: 100%;
  min-width: 0;
}
.tournament-bracket-stage {
  display: grid;
  gap: 10px;
}
.tournament-bracket-stage__title {
  margin: 0;
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--text-200);
}
.tournament-bracket {
  display: grid;
  grid-template-columns: repeat(var(--round-count, 1), 210px);
  gap: 14px;
  align-items: start;
  overflow: visible;
  justify-content: space-between;
  padding: 2px 2px 6px;
}
.tournament-bracket__round {
  display: grid;
  gap: 10px;
  min-width: 0;
}
.tournament-bracket__round[hidden] {
  display: none !important;
}
.tournament-bracket__round-title {
  margin: 0;
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--text-200);
  text-align: center;
  border-radius: 7px;
  border: 1px solid var(--transp-2);
  background: var(--tournament-surface-muted);
  backdrop-filter: none;
  padding: 5px 8px;
}
.tournament-bracket__matches {
  display: grid;
  row-gap: var(--round-gap, 8px);
  padding-top: calc(var(--round-offset, 0px) + var(--round-extra-offset, 0px));
  position: relative;
}
.tournament-bracket__match {
  position: relative;
  display: grid;
  gap: 5px;
  padding: 4px;
  min-height: 84px;
  border: none;
  background: transparent;
  backdrop-filter: none;
  transition: opacity 0.2s ease, background 0.2s ease;
}
.tournament-bracket__match--linked::after {
  content: "";
  position: absolute;
  top: 50%;
  right: calc(-1 * var(--round-connector-span, 12px));
  width: var(--round-connector-span, 12px);
  border-top: 1px solid rgba(172, 184, 215, 0.5);
}
.tournament-bracket__match--linked.tournament-bracket__match--pair-a::before, .tournament-bracket__match--linked.tournament-bracket__match--pair-b::before {
  content: "";
  position: absolute;
  right: calc(-1 * var(--round-connector-span, 12px));
  width: 1px;
  background: rgba(172, 184, 215, 0.5);
}
.tournament-bracket__match.is-custom-next-link.tournament-bracket__match--linked::after, .tournament-bracket__match.is-custom-next-link.tournament-bracket__match--linked.tournament-bracket__match--pair-a::before, .tournament-bracket__match.is-custom-next-link.tournament-bracket__match--linked.tournament-bracket__match--pair-b::before {
  display: none;
}
.tournament-bracket__cross-link {
  position: absolute;
  left: 100%;
  top: 50%;
  width: var(--cross-x, 12px);
  height: 0;
  pointer-events: none;
}
.tournament-bracket__cross-link::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: var(--cross-mid, 8px);
  border-top: 1px solid rgba(172, 184, 215, 0.5);
}
.tournament-bracket__cross-link::after {
  content: "";
  position: absolute;
  left: var(--cross-mid, 8px);
  top: var(--cross-y-start, 0px);
  width: 1px;
  height: var(--cross-y-size, 0px);
  background: rgba(172, 184, 215, 0.5);
}
.tournament-bracket__cross-link-tail {
  position: absolute;
  left: var(--cross-mid, 8px);
  top: var(--cross-y, 0px);
  width: calc(var(--cross-x, 12px) - var(--cross-mid, 8px));
  border-top: 1px solid rgba(172, 184, 215, 0.5);
}
.tournament-bracket__match--linked.tournament-bracket__match--pair-a::before {
  top: 50%;
  height: calc(100% + var(--pair-gap, 14px));
}
.tournament-bracket__match--linked.tournament-bracket__match--pair-b::before {
  bottom: 50%;
  height: calc(100% + var(--pair-gap, 14px));
}
.tournament-bracket__meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 6px;
  padding: 0 1px;
  font-size: 10px;
  color: var(--text-200);
}
.tournament-bracket__meta-date {
  white-space: nowrap;
  opacity: 0.9;
}
.tournament-bracket__meta-match {
  font-weight: 700;
  margin-right: 4px;
}
.tournament-bracket__meta-bo {
  text-transform: uppercase;
  font-weight: 700;
  letter-spacing: 0.03em;
}
.tournament-bracket__team {
  display: grid;
  grid-template-columns: 3px minmax(0, 1fr) 18px 20px;
  gap: 6px;
  align-items: center;
  min-height: 30px;
  border-radius: 7px;
  background: rgba(255, 255, 255, 0.015);
  border: 1px solid rgba(255, 255, 255, 0.06);
  padding-right: 6px;
  color: var(--text-200);
  transition: opacity 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}
.tournament-bracket__team-accent {
  width: 3px;
  height: 100%;
  border-radius: 4px;
  background: var(--team-color, var(--tournament-accent));
}
.tournament-bracket__team-main {
  min-width: 0;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.tournament-bracket__team-drop {
  font-size: 11px;
  line-height: 1;
  color: #8fb4ff;
  opacity: 0.9;
  flex: 0 0 auto;
}
.tournament-bracket__team-avatar {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  display: inline-grid;
  place-items: center;
  font-size: 9px;
  font-weight: 700;
  color: var(--text);
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.05);
  flex: 0 0 auto;
}
.tournament-bracket__team.is-winner {
  color: var(--text);
  font-weight: 600;
}
.tournament-bracket__team-name {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  min-width: 0;
  max-width: 100%;
}
.tournament-bracket__team-name-text {
  min-width: 0;
  flex: 1 1 auto;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  overflow-wrap: anywhere;
}
.tournament-bracket__place-cup {
  flex: 0 0 auto;
  width: 12px;
  height: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  opacity: 0.95;
}
.tournament-bracket__place-cup svg {
  width: 100%;
  height: 100%;
  display: block;
}
.tournament-bracket__place-cup.is-gold {
  color: #f6c94b;
  filter: drop-shadow(0 0 6px rgba(246, 201, 75, 0.32));
}
.tournament-bracket__place-cup.is-silver {
  color: #c3cbd6;
  filter: drop-shadow(0 0 5px rgba(195, 203, 214, 0.28));
}
.tournament-bracket__place-cup.is-bronze {
  color: #cd7f32;
  filter: drop-shadow(0 0 5px rgba(205, 127, 50, 0.28));
}
.tournament-bracket__team-result {
  text-align: center;
  font-size: 11px;
  color: var(--text-200);
  font-weight: 600;
}
.tournament-bracket__team-result.is-win {
  color: #59d96c;
}
.tournament-bracket__team-result.is-loss {
  color: #ff7070;
}
.tournament-bracket__team-score {
  min-width: 20px;
  text-align: right;
  font-weight: 700;
  font-size: 13px;
  color: var(--text-200);
}
.tournament-bracket__team-score.is-win {
  color: #59d96c;
}
.tournament-bracket__team-score.is-loss {
  color: #ff7070;
}
.tournament-bracket-board.has-team-highlight .tournament-bracket__match {
  opacity: 0.45;
}
.tournament-bracket-board.has-team-highlight .tournament-bracket__team {
  opacity: 0.4;
}
.tournament-bracket__match.is-path-match {
  opacity: 1 !important;
  border-radius: 0;
  background: transparent;
}
.tournament-bracket__team.is-path-team {
  opacity: 1 !important;
  border-color: color-mix(in srgb, var(--path-team-color, var(--team-color, #7695ff)) 78%, transparent);
  background: color-mix(in srgb, var(--path-team-color, var(--team-color, #7695ff)) 16%, transparent);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--path-team-color, var(--team-color, #7695ff)) 40%, transparent);
}
.tournament-bracket__match.is-path-match.tournament-bracket__match--linked::after {
  border-top-color: var(--path-team-color, #7695ff);
}
.tournament-bracket__match.is-path-match.tournament-bracket__match--linked.tournament-bracket__match--pair-a::before, .tournament-bracket__match.is-path-match.tournament-bracket__match--linked.tournament-bracket__match--pair-b::before {
  background: var(--path-team-color, #7695ff);
}
.tournament-bracket__match.is-path-match .tournament-bracket__cross-link::before, .tournament-bracket__match.is-path-match .tournament-bracket__cross-link-tail {
  border-top-color: var(--path-team-color, #7695ff);
}
.tournament-bracket__match.is-path-match .tournament-bracket__cross-link::after {
  background: var(--path-team-color, #7695ff);
}
.tournament-bracket__round.is-window-last .tournament-bracket__match--linked::after, .tournament-bracket__round.is-window-last .tournament-bracket__match--linked.tournament-bracket__match--pair-a::before, .tournament-bracket__round.is-window-last .tournament-bracket__match--linked.tournament-bracket__match--pair-b::before {
  display: none;
}
@media (min-width: 1180px) {
  .tournament-bracket {
    align-items: start;
  }
}
.tournament-muted {
  color: var(--text-200);
}
.tournament-registration {
  padding: 18px;
  border-radius: 16px;
  background: var(--tournament-surface-soft);
  border: 1px solid var(--transp-2);
  display: grid;
  gap: 16px;
}
.tournament-registration__form {
  display: grid;
  gap: 16px;
}
.tournament-registration__row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
  align-items: end;
  position: relative;
}
.tournament-registration__row--member {
  padding: 10px;
  border-radius: 12px;
  background: var(--tournament-surface-muted);
  border: 1px solid var(--transp-2);
}
.tournament-registration__row.is-captain {
  background: var(--tournament-surface-muted);
  border: 1px dashed var(--transp-2);
  padding: 12px;
  border-radius: 12px;
}
.tournament-registration__field {
  display: grid;
  gap: 6px;
}
.tournament-registration__field label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-200);
}
.tournament-registration__field input, .tournament-registration__field select {
  width: 100%;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid var(--transp-2);
  background: var(--tournament-surface);
  color: var(--text);
}
.tournament-registration__static {
  padding: 10px 12px;
  border-radius: 10px;
  background: var(--tournament-surface);
  border: 1px solid var(--transp-2);
  color: var(--text);
}
.tournament-registration__member-list {
  display: grid;
  gap: 10px;
}
.tournament-registration__remove {
  align-self: center;
  justify-self: end;
  border: none;
  background: var(--tournament-surface-muted);
  color: var(--text-200);
  border-radius: 10px;
  padding: 8px;
  cursor: pointer;
}
.tournament-registration__add {
  justify-self: start;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  border-radius: 999px;
  border: 1px solid var(--transp-2);
  background: var(--tournament-surface);
  color: var(--text);
  cursor: pointer;
}
.tournament-registration__submit {
  justify-self: start;
  padding: 10px 18px;
  border-radius: 12px;
  border: none;
  background: var(--tournament-accent);
  color: #1a1a1a;
  font-weight: 700;
  cursor: pointer;
}
.tournament-registration__status {
  padding: 12px 14px;
  border-radius: 12px;
  background: var(--tournament-surface-muted);
  border: 1px solid var(--transp-2);
  color: var(--text-200);
}
.tournament-registration__hint {
  margin-top: 10px;
  font-size: 12px;
  color: var(--text-200);
}
.tournament-registration__hint a {
  color: var(--tournament-accent);
  text-decoration: none;
}
.tournament-team-logo {
  width: 40px;
  height: 40px;
  border-radius: 12px;
  object-fit: cover;
  display: inline-block;
}
.tournament-applications {
  display: grid;
  gap: 14px;
}
.tournament-registration-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 16px;
  align-items: start;
}
.tournament-registration-grid--single {
  grid-template-columns: minmax(0, 1fr);
}
@media (max-width: 900px) {
  .tournament-teams-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .tournament-registration-grid {
    grid-template-columns: 1fr;
  }
  .tournament-bracket-canvas {
    max-height: none;
    cursor: auto;
  }
  .tournament-bracket {
    grid-template-columns: 1fr;
    gap: 14px;
    overflow-x: visible;
  }
  .tournament-bracket__round {
    min-width: 0;
  }
  .tournament-bracket__matches {
    padding-top: 0;
    row-gap: 12px;
  }
  .tournament-bracket__match--linked::before, .tournament-bracket__match--linked::after {
    display: none;
  }
  .tournament-matches-groups.is-split {
    grid-template-columns: 1fr;
  }
  .tournament-matches-group--centered {
    max-width: 100%;
    justify-self: stretch;
  }
}
@keyframes tournamentFade {
  from {
    opacity: 0;
    transform: translateY(6px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
@media (max-width: 900px) {
  .tournament-tabs {
    gap: 10px;
  }
  .tournament-info-grid {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 640px) {
  .tournament-teams-grid {
    grid-template-columns: 1fr;
  }
  .tournament-hero {
    padding: 32px 20px;
  }
  .tournament-summary {
    padding: 14px 14px 16px;
  }
}
