/* ========== MOON — стили страниц modules_extra и магазинов ========== */

/* Заголовки блоков */
.r_block_head .glyphicon,
.l_block_head .glyphicon {
	color: var(--cs-accent);
	margin-right: 8px;
	font-size: 14px;
	opacity: 0.95;
}

/* --- Формы магазина (buy_key, store, shop_key) --- */
.cs-page-main #buy_service_area .input-group.mb-10,
.cs-page-main .input-group.mb-10 {
	display: block;
	width: 100%;
	margin-bottom: 16px;
}

.cs-page-main #buy_service_area .input-group-btn,
.cs-page-main .input-group.mb-10 .input-group-btn {
	display: block;
	width: 100%;
	float: none;
}

.cs-page-main #buy_service_area .input-group-btn .shop1,
.cs-page-main .input-group.mb-10 .input-group-btn .shop1,
.cs-page-main .input-group.mb-10 .input-group-btn .btn-default {
	display: block;
	width: 100%;
	padding: 0 0 8px;
	background: transparent !important;
	border: none !important;
	box-shadow: none !important;
	color: var(--cs-text-dim) !important;
	font-size: 11px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	text-align: left;
	cursor: default;
	pointer-events: none;
	border-radius: 0 !important;
}

.cs-page-main #buy_service_area > .form-control,
.cs-page-main .input-group.mb-10 > .form-control {
	display: block;
	width: 100%;
	height: 44px;
	padding: 0 14px;
	border-radius: var(--cs-radius-sm) !important;
}

.cs-page-main #buy_service_area .mt-10,
.cs-page-main #buy_service_area #buy_result {
	color: var(--cs-text-dim);
	font-size: 13px;
	line-height: 1.5;
}

.cs-page-main #buy_service_area a {
	color: var(--cs-accent);
}

.cs-page-main #buy_service_area a:hover {
	color: var(--cs-accent-hover);
}

/* Кнопки покупки */
.shopbut,
.btn2.btn-big,
#store_buy_btn,
#store_buy_btn.shopbut {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 44px;
	padding: 0 28px !important;
	background: var(--cs-accent) !important;
	border: none !important;
	color: #fff !important;
	border-radius: var(--cs-radius-sm) !important;
	font-weight: 600 !important;
	font-size: 14px !important;
	transition: background 0.15s ease;
}

.shopbut:hover:not(.disabled),
.btn2.btn-big:hover,
#store_buy_btn:hover:not(.disabled) {
	background: var(--cs-accent-hover) !important;
	color: #fff !important;
}

#store_buy_btn.disabled,
.shopbut.disabled,
.cs-btn.disabled,
.cs-btn-primary.disabled {
	opacity: 0.45;
	cursor: not-allowed;
	pointer-events: none;
}

/* Skinchanger — привязка Steam */
.cs-skinchanger-page {
	min-width: 0;
}

.cs-skinchanger-panel__body {
	padding: 18px;
}

/* Font Awesome 4.6 на moon: модуль генерирует fas/fab из FA5 */
.cs-skinchanger-page .fa,
.cs-skinchanger-page .fas,
.cs-skinchanger-page .fab,
.cs-skinchanger-page .far {
	display: inline-block;
	font: normal normal normal 14px/1 FontAwesome;
	font-size: inherit;
	text-rendering: auto;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

.cs-skinchanger-page .fa-running:before { content: "\f04e"; }
.cs-skinchanger-page .fa-expand-arrows-alt:before { content: "\f065"; }
.cs-skinchanger-page .fa-slash:before { content: "\f0c4"; }
.cs-skinchanger-page .fa-fist-raised:before { content: "\f255"; }
.cs-skinchanger-page .fa-shield-alt:before { content: "\f132"; }
.cs-skinchanger-page .fa-gun:before { content: "\f05b"; }

.cs-skinchanger-page .categories-grid {
	margin-top: 0;
}

.cs-skinchanger-page .category-item i {
	font-size: 42px;
	color: var(--cs-accent);
	margin-bottom: 12px;
	line-height: 1;
}

.cs-skinchanger-page .steam-binding-content,
.r_block_c.steam-binding-content {
	text-align: center;
	padding: 32px 24px !important;
}

.steam-binding-icon {
	font-size: 48px;
	color: var(--cs-accent);
	margin-bottom: 16px;
}

.steam-binding-title {
	font-size: 18px;
	font-weight: 700;
	color: var(--cs-text);
	margin: 0 0 12px;
}

.steam-binding-description p {
	color: var(--cs-text-dim);
	font-size: 14px;
	margin: 0 0 8px;
}

.steam-binding-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	margin-top: 16px;
	padding: 12px 24px;
	background: var(--cs-accent);
	color: #fff !important;
	border-radius: var(--cs-radius-sm);
	font-weight: 600;
	font-size: 14px;
	transition: background 0.15s;
}

.steam-binding-btn:hover {
	background: var(--cs-accent-hover);
	color: #fff !important;
}

/* Skinchanger — карточки скинов, навигация, поиск */
.cs-skinchanger-page .back-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 16px;
	padding: 10px 16px;
	border: 1px solid var(--cs-border);
	border-radius: var(--cs-radius-sm);
	background: var(--cs-bg-pill);
	color: var(--cs-text);
	font-size: 14px;
	font-weight: 600;
	cursor: pointer;
	transition: border-color 0.15s, background 0.15s, color 0.15s;
}

.cs-skinchanger-page .back-btn:hover {
	border-color: var(--cs-accent);
	background: rgba(92, 108, 255, 0.08);
	color: var(--cs-text);
}

.cs-skinchanger-page .skins-search-container {
	margin: 12px 0 18px;
}

.cs-skinchanger-page .cs-skinchanger-search-wrap {
	position: relative;
	max-width: 420px;
}

.cs-skinchanger-page .cs-skinchanger-search {
	width: 100%;
	padding: 11px 42px 11px 14px;
	border: 1px solid var(--cs-border);
	border-radius: var(--cs-radius-sm);
	background: var(--cs-bg-pill);
	color: var(--cs-text);
	font-size: 14px;
	outline: none;
	transition: border-color 0.15s, background 0.15s;
}

.cs-skinchanger-page .cs-skinchanger-search::placeholder {
	color: var(--cs-text-dim);
}

.cs-skinchanger-page .cs-skinchanger-search:focus {
	border-color: var(--cs-accent);
	background: rgba(92, 108, 255, 0.06);
}

.cs-skinchanger-page .cs-skinchanger-search__icon {
	position: absolute;
	right: 14px;
	top: 50%;
	transform: translateY(-50%);
	color: var(--cs-text-dim);
	pointer-events: none;
}

.cs-skinchanger-page .weapon-card {
	border: 1px solid var(--cs-border);
	border-radius: var(--cs-radius-sm);
	background: var(--cs-bg-pill);
	padding: 16px;
	text-align: center;
	transition: border-color 0.15s, transform 0.15s, box-shadow 0.15s;
}

.cs-skinchanger-page .weapon-card:hover {
	transform: translateY(-2px);
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.22);
}

.cs-skinchanger-page .weapon-card.weapon-has-skin {
	border-color: rgba(0, 212, 170, 0.45);
	box-shadow: inset 3px 0 0 #00d4aa;
}

.cs-skinchanger-page #search-results-count {
	margin-top: 8px;
	font-size: 12px;
	color: var(--cs-text-dim);
}

.cs-skinchanger-page .search-highlight {
	background: rgba(92, 108, 255, 0.25);
	border-radius: 3px;
	padding: 0 2px;
}

/* --- skinchanger: CS2 modal (настройки скина) --- */
body.modal-open {
	overflow: hidden !important;
}

.skin-modal {
	z-index: 10050 !important;
}

.cs2-modal {
	font-family: inherit;
}

.cs2-modal input[type="checkbox"]:checked + span {
	background-color: var(--cs-accent) !important;
	border-color: var(--cs-accent) !important;
}

.cs2-team-icon:hover {
	background: var(--cs-bg-pill) !important;
	border-color: var(--cs-accent) !important;
	transform: scale(1.05);
}

.cs2-team-icon.selected {
	background: var(--cs-accent) !important;
	border-color: var(--cs-accent) !important;
	transform: scale(1.1);
}

.cs2-team-icon.selected img {
	filter: brightness(1.2) !important;
}

.cs2-modal input[type="range"]::-webkit-slider-thumb {
	-webkit-appearance: none;
	appearance: none;
	width: 18px;
	height: 18px;
	border-radius: 50%;
	background: #fff;
	cursor: pointer;
	border: 2px solid var(--cs-accent);
	box-shadow: 0 2px 6px rgba(0, 0, 0, 0.3);
}

.cs2-modal input[type="range"]::-moz-range-thumb {
	width: 18px;
	height: 18px;
	border-radius: 50%;
	background: #fff;
	cursor: pointer;
	border: 2px solid var(--cs-accent);
	box-shadow: 0 2px 6px rgba(0, 0, 0, 0.3);
}

.cs2-modal input[type="text"]:focus,
.cs2-modal #wear-manual-input:focus,
.cs2-modal #seed-manual-input:focus {
	border-color: var(--cs-accent) !important;
	box-shadow: 0 0 0 2px color-mix(in srgb, var(--cs-accent) 25%, transparent) !important;
}

.cs2-modal #wear-manual-input:hover,
.cs2-modal #seed-manual-input:hover {
	border-color: var(--cs-text-dim) !important;
}

.cs2-modal #apply-skin-btn {
	background: var(--cs-accent) !important;
}

.cs2-modal #apply-skin-btn:hover {
	background: var(--cs-accent-hover) !important;
	transform: translateY(-1px);
	box-shadow: 0 4px 12px color-mix(in srgb, var(--cs-accent) 40%, transparent) !important;
}

.cs2-modal #close-modal-btn:hover {
	color: var(--cs-text) !important;
}

@media (max-width: 480px) {
	.skin-modal {
		padding: 12px !important;
		align-items: flex-end !important;
	}

	.skin-modal .cs2-modal {
		max-width: 100% !important;
		border-radius: 12px 12px 0 0 !important;
		max-height: 92vh;
		overflow-y: auto;
	}
}

.cs-page-main .btn-primary {
	background: var(--cs-accent) !important;
	border-color: var(--cs-accent) !important;
	color: #fff !important;
	border-radius: var(--cs-radius-sm) !important;
}

.cs-page-main .btn-primary:hover {
	background: var(--cs-accent-hover) !important;
	border-color: var(--cs-accent-hover) !important;
}

/* --- buy_key: компактная вёрстка магазина --- */
.cs-shop-discount {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 16px;
	padding: 12px 16px;
	background: rgba(76, 175, 80, 0.12);
	border: 1px solid rgba(76, 175, 80, 0.35);
	border-radius: var(--cs-radius-sm);
	color: var(--cs-text);
	font-size: 13px;
	line-height: 1.45;
}

.cs-shop-discount strong {
	color: #81c784;
	font-weight: 700;
}

.cs-shop-empty {
	padding: 24px 16px;
	text-align: center;
	color: var(--cs-text-dim);
	font-size: 14px;
}

.cs-shop-layout {
	display: grid;
	grid-template-columns: minmax(260px, 380px) minmax(0, 1fr);
	gap: 24px;
	align-items: start;
}

.cs-shop-form {
	display: flex;
	flex-direction: column;
	gap: 16px;
	min-width: 0;
}

.cs-shop-form--solo {
	max-width: 520px;
}

.cs-shop-panel--perks {
	position: sticky;
	top: 16px;
	min-height: 120px;
}

.cs-shop-panel--perks #store_service_info.with_code:empty::before {
	content: "Выберите услугу, чтобы увидеть состав привилегии";
	display: block;
	font-size: 13px;
	line-height: 1.5;
	color: var(--cs-text-dim);
}

.cs-shop-perks-inline:empty {
	display: none;
}

.cs-shop-perks-inline.with_code {
	margin-top: 4px;
	padding-top: 4px;
}

.cs-field {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.cs-field label {
	font-size: 11px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--cs-text-dim);
}

.cs-shop-form .form-control {
	display: block;
	width: 100%;
	height: 44px;
	padding: 0 14px;
	border-radius: var(--cs-radius-sm) !important;
	background: var(--cs-bg-pill) !important;
	border: 1px solid var(--cs-border) !important;
	color: var(--cs-text) !important;
	font-size: 14px;
	transition: border-color 0.15s, background 0.15s;
}

.cs-shop-form .form-control:focus {
	border-color: var(--cs-accent) !important;
	outline: none;
	box-shadow: 0 0 0 2px rgba(99, 102, 241, 0.15);
}

.cs-shop-agree {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	margin: 4px 0 0;
	font-size: 13px;
	line-height: 1.45;
	color: var(--cs-text-dim);
	cursor: pointer;
}

.cs-shop-agree input {
	flex: 0 0 16px;
	width: 16px;
	height: 16px;
	margin-top: 2px;
	accent-color: var(--cs-accent);
}

.cs-shop-agree a {
	color: var(--cs-accent);
}

.cs-shop-agree a:hover {
	color: var(--cs-accent-hover);
}

.cs-shop-result {
	min-height: 0;
	font-size: 13px;
	line-height: 1.45;
	color: var(--cs-text-dim);
}

.cs-shop-result:empty {
	display: none;
}

.cs-shop-buy {
	display: flex !important;
	width: 100%;
	min-height: 48px !important;
	padding: 0 20px !important;
	border-radius: var(--cs-radius-sm) !important;
	font-size: 15px !important;
	font-weight: 600 !important;
	letter-spacing: 0.01em;
}

.cs-shop-buy.disp-n,
#store_answer_btn.disp-n {
	display: none !important;
}

.cs-shop-actions #store_answer_btn:not(.disp-n) {
	display: flex !important;
	width: 100%;
	min-height: 44px;
	align-items: center;
	justify-content: center;
}

.cs-shop-guest {
	margin-top: 14px;
}

.cs-shop-actions {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.cs-shop-details {
	display: flex;
	flex-direction: column;
	gap: 14px;
	min-width: 0;
}

.cs-shop-panel {
	padding: 14px;
	background: var(--cs-bg-pill);
	border: 1px solid var(--cs-border);
	border-radius: var(--cs-radius-sm);
}

.cs-shop-panel__title {
	margin-bottom: 12px;
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--cs-text-dim);
}

.cs-shop-panel__body:empty {
	display: none;
}

.cs-shop-panel--perks .cs-shop-panel__title {
	margin-bottom: 10px;
}

.cs-shop-panel--perks #store_service_info.with_code ul {
	grid-template-columns: 1fr;
	gap: 6px;
}

.cs-shop-card {
	--cs-shop-muted: #8b92a3;
	--cs-shop-body: #aeb4c2;
	--cs-shop-em: #c5cad6;
}

.cs-shop-card .r_block_head {
	color: var(--cs-shop-em) !important;
}

.cs-shop-card .cs-field label,
.cs-shop-card .cs-shop-panel__title {
	color: var(--cs-shop-muted);
}

.cs-shop-form .form-control {
	color: var(--cs-shop-body) !important;
}

.cs-shop-agree {
	color: var(--cs-shop-muted);
}

.cs-shop-panel--perks #store_service_info.with_code {
	color: var(--cs-shop-body);
	font-size: 13px;
	line-height: 1.55;
}

.cs-shop-panel--perks #store_service_info.with_code p {
	margin: 0 0 10px;
	color: var(--cs-shop-body);
}

.cs-shop-card .cs-shop-panel--perks #store_service_info.with_code ul li {
	padding: 8px 12px;
	font-size: 12px;
	color: inherit !important;
	background: rgba(255, 255, 255, 0.02);
	border-color: rgba(255, 255, 255, 0.06);
}

.cs-shop-panel--perks #store_service_info.with_code ul li::before {
	background: #5a9e72;
	opacity: 0.9;
}

.cs-shop-card .cs-shop-panel--perks #store_service_info.with_code strong:not([style*="color"]),
.cs-shop-card .cs-shop-panel--perks #store_service_info.with_code b:not([style*="color"]) {
	color: var(--cs-shop-em);
	font-weight: 600;
}

#store_type option.disp-n,
#store_type option[disabled] {
	display: none;
}

.cs-shop-sidebar-nav {
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.cs-shop-sidebar-nav a {
	display: block;
	padding: 10px 14px;
	border-radius: var(--cs-radius-sm);
	color: var(--cs-text-dim) !important;
	font-size: 13px;
	font-weight: 500;
	border: 1px solid transparent;
	transition: background 0.15s, color 0.15s, border-color 0.15s;
}

.cs-shop-sidebar-nav a:hover {
	background: var(--cs-bg-hover);
	color: var(--cs-text) !important;
	border-color: var(--cs-border);
}

.cs-shop-sidebar-nav a.is-active {
	background: var(--cs-bg-hover);
	color: var(--cs-text) !important;
	border-color: var(--cs-border);
}

/* --- Карточка сервера (moon server_min.tpl) --- */
.cs-server-card {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.cs-server-card__map {
	border-radius: var(--cs-radius-sm);
	overflow: hidden;
	border: 1px solid var(--cs-border);
	aspect-ratio: 16 / 9;
	background: var(--cs-bg-card);
}

.cs-server-card__map img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.cs-server-card__body {
	display: flex;
	flex-direction: column;
	gap: 8px;
	min-width: 0;
}

.cs-server-card__name {
	font-size: 15px;
	font-weight: 600;
	color: var(--cs-text);
	line-height: 1.3;
}

.cs-server-card__row {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: 12px;
	font-size: 13px;
}

.cs-server-card__label {
	color: var(--cs-text-dim);
	flex-shrink: 0;
}

.cs-server-card__row b {
	color: var(--cs-text);
	font-weight: 600;
	text-align: right;
	word-break: break-word;
}

.cs-server-card__ip {
	display: inline-block;
	align-self: flex-start;
	margin-top: 2px;
	font-size: 13px;
	font-weight: 600;
	color: var(--cs-green) !important;
	word-break: break-all;
}

.cs-server-card__ip:hover {
	opacity: 0.85;
}

.cs-server-card__links {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	margin-top: 4px;
	padding-top: 10px;
	border-top: 1px solid var(--cs-border);
}

.cs-server-card__links a {
	display: inline-flex;
	align-items: center;
	padding: 6px 12px;
	font-size: 12px;
	font-weight: 500;
	color: var(--cs-text-dim) !important;
	background: var(--cs-bg-card);
	border: 1px solid var(--cs-border);
	border-radius: 999px;
	transition: background 0.15s, color 0.15s;
}

.cs-server-card__links a:hover {
	background: var(--cs-bg-hover);
	color: var(--cs-text) !important;
}

.cs-server-card__links a.disp-n {
	display: none !important;
}

@media (max-width: 960px) {
	.cs-shop-layout {
		grid-template-columns: 1fr;
	}

	.cs-shop-panel--perks {
		position: static;
	}

	.cs-shop-panel--perks #store_service_info.with_code ul {
		grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
	}
}

/* --- Карточка сервера (legacy / AJAX fallback) --- */
.cs-mini-server,
.r_block_c .block.mini_serv {
	display: flex;
	gap: 16px;
	align-items: flex-start;
	padding: 0;
	background: transparent !important;
	border: none !important;
	box-shadow: none !important;
	margin: 0;
}

.cs-mini-server-map,
.r_block_c .mini_serv img {
	flex: 0 0 120px;
	width: 120px !important;
	height: 90px !important;
	float: none !important;
	margin: 0 !important;
	border-radius: var(--cs-radius-sm);
	overflow: hidden;
	border: 1px solid var(--cs-border);
	object-fit: cover;
}

.cs-mini-server-map img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.cs-mini-server-body,
.r_block_c .mini_serv > div {
	flex: 1;
	min-width: 0;
	float: none !important;
	width: auto !important;
	margin: 0 !important;
	white-space: normal !important;
	line-height: 1.45 !important;
}

.cs-mini-server-title {
	font-size: 15px;
	font-weight: 600;
	color: var(--cs-text);
	margin-bottom: 10px;
	line-height: 1.3;
}

.cs-mini-server-stats {
	list-style: none;
	margin: 0 0 10px;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 8px 16px;
}

.cs-mini-server-stats li {
	font-size: 13px;
	color: var(--cs-text-dim);
}

.cs-mini-server-stats span {
	color: var(--cs-text-dim);
	margin-right: 4px;
}

.cs-mini-server-stats b {
	color: var(--cs-text);
	font-weight: 600;
}

.cs-mini-server-ip {
	display: inline-block;
	font-size: 13px;
	color: var(--cs-green) !important;
	margin-bottom: 10px;
	word-break: break-all;
}

.cs-mini-server-ip:hover {
	opacity: 0.85;
}

.cs-mini-server-links,
.r_block_c .mini_serv div span:last-child {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.cs-mini-server-links a,
.r_block_c .mini_serv a {
	display: inline-flex;
	align-items: center;
	padding: 6px 12px;
	font-size: 12px;
	font-weight: 500;
	color: var(--cs-text-dim) !important;
	background: var(--cs-bg-pill);
	border: 1px solid var(--cs-border);
	border-radius: 999px;
	transition: background 0.15s, color 0.15s;
}

.cs-mini-server-links a:hover,
.r_block_c .mini_serv a:hover {
	background: var(--cs-bg-hover);
	color: var(--cs-text) !important;
}

.r_block_c .mini_serv span {
	color: var(--cs-text-dim);
}

.r_block_c .mini_serv span a {
	color: var(--cs-text) !important;
	background: none;
	border: none;
	padding: 0;
	border-radius: 0;
}

/* --- Описание услуги --- */
.r_block_c .with_code,
#store_service_info.with_code {
	color: var(--cs-text-dim);
	font-size: 13px;
	line-height: 1.55;
}

.r_block_c .with_code ul,
#store_service_info.with_code ul {
	list-style: none !important;
	margin: 0 !important;
	padding: 0 !important;
	display: grid;
	gap: 8px;
}

.r_block_c .with_code ul li,
#store_service_info.with_code ul li {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	padding: 10px 14px;
	background: var(--cs-bg-pill);
	border: 1px solid var(--cs-border);
	border-radius: var(--cs-radius-sm);
	color: var(--cs-text) !important;
	margin: 0 !important;
}

.r_block_c .with_code ul li::before,
#store_service_info.with_code ul li::before {
	content: "";
	flex: 0 0 6px;
	width: 6px;
	height: 6px;
	margin-top: 7px;
	border-radius: 50%;
	background: var(--cs-green);
}

.r_block_c .with_code p,
#store_service_info.with_code p {
	margin: 0 0 10px;
	color: var(--cs-text-dim);
}

.r_block_c .with_code strong,
.r_block_c .with_code b,
#store_service_info.with_code strong {
	color: var(--cs-text);
	font-weight: 600;
}

/* --- Таблицы в модулях --- */
.r_block_c .table {
	margin-bottom: 0;
	border-color: var(--cs-border) !important;
}

.r_block_c .table thead td,
.r_block_c .table thead th {
	background: var(--cs-bg-pill) !important;
	color: var(--cs-text) !important;
	font-weight: 600;
	font-size: 12px;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	border-color: var(--cs-border) !important;
	padding: 12px 14px !important;
}

.r_block_c .table tbody td {
	padding: 12px 14px !important;
	border-color: var(--cs-border) !important;
	vertical-align: middle;
}

.r_block_c .table tbody tr:hover td {
	background: var(--cs-bg-hover);
}

.r_block.scroll-x .table-responsive {
	border-radius: var(--cs-radius-sm);
	border: 1px solid var(--cs-border);
}

/* --- Сайдбар: сервера, навигация --- */
.left_block .nav-pills > li > a {
	display: block;
	padding: 9px 14px;
	margin-bottom: 4px;
	border-radius: var(--cs-radius-sm);
	color: var(--cs-text-dim) !important;
	background: transparent;
	border: 1px solid transparent;
	font-size: 13px;
	transition: background 0.15s, color 0.15s;
}

.left_block .nav-pills > li > a:hover,
.left_block .nav-pills > li.active > a {
	background: var(--cs-bg-hover) !important;
	color: var(--cs-text) !important;
	border-color: var(--cs-border);
}

/* --- Виджеты в правой колонке --- */
#top_users a,
#top_users .top_user a {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 8px 0;
	color: var(--cs-text-dim);
	font-size: 13px;
	border-bottom: 1px solid var(--cs-border);
}

#top_users a:last-child,
#top_users .top_user:last-child a {
	border-bottom: none;
}

#top_users img,
#top_users .top_user img {
	width: 32px;
	height: 32px;
	border-radius: 50%;
	object-fit: cover;
}

/* --- Пустые состояния и загрузка --- */
.empty-element {
	padding: 32px 20px;
	text-align: center;
	color: var(--cs-text-dim);
	font-size: 14px;
	background: var(--cs-bg-pill);
	border: 1px dashed var(--cs-border);
	border-radius: var(--cs-radius-sm);
}

.r_block_c .loader,
.r_block_c center img[src*="loader"] {
	display: block;
	margin: 24px auto;
	opacity: 0.6;
}

/* --- Поиск (demos и др.) --- */
.input-search {
	position: relative;
}

.input-search i,
.input-search .fas {
	position: absolute;
	right: 14px;
	top: 50%;
	transform: translateY(-50%);
	color: var(--cs-text-dim);
	cursor: pointer;
	z-index: 2;
}

.input-search .form-control {
	padding-right: 40px;
	height: 44px;
}

/* --- standart-layout модулей внутри moon --- */
.cs-page-main > .row {
	margin-left: -10px;
	margin-right: -10px;
}

.cs-page-main .col-lg-9,
.cs-page-main .col-lg-6,
.cs-page-main .col-lg-3 {
	padding-left: 10px;
	padding-right: 10px;
}

.cs-page-main .empty-element {
	grid-column: 1 / -1;
}

/* --- Розыгрыш --- */
.r_block_c .sortition {
	background: var(--cs-bg-pill) !important;
	border: 1px solid var(--cs-border);
	border-radius: var(--cs-radius);
	padding: 24px !important;
	font-family: 'Inter', system-ui, sans-serif !important;
}

.r_block_c .sortition h1,
.r_block_c .sortition h2,
.r_block_c .sortition h3,
.r_block_c .sortition h4,
.r_block_c .sortition h5,
.r_block_c .sortition h6 {
	color: var(--cs-text) !important;
	font-family: inherit !important;
}

.r_block_c .sortition #ending span {
	color: var(--cs-text) !important;
	font-family: inherit !important;
}

.r_block_c .sortition #ending i {
	color: var(--cs-text-dim) !important;
	font-family: inherit !important;
}

.r_block_c .sortition #participants a,
.cs-sortition-page #participants a {
	background: rgba(255, 255, 255, 0.04) !important;
	border: 1px solid var(--cs-border) !important;
	color: var(--cs-text) !important;
}

.r_block_c .sortition #participants a span,
.cs-sortition-page #participants a span {
	color: var(--cs-text) !important;
}

/* --- Кейсы: moon-обёртка поверх старого style.css --- */
.r_block_c.cases-main-block,
.r_block .r_block_c.cases-main-block {
	background: var(--cs-bg-card) !important;
	border-radius: var(--cs-radius) !important;
	padding: 24px !important;
	border: none !important;
	box-shadow: none !important;
}

.r_block_c.cases-main-block h2 {
	background: none !important;
	font-size: 20px !important;
	font-weight: 700 !important;
	color: var(--cs-text) !important;
	text-transform: none !important;
	margin-bottom: 24px !important;
	min-height: 0 !important;
	padding-top: 0 !important;
}

.r_block_c.cases-main-block .info-block {
	background: var(--cs-bg-pill) !important;
	border: 1px solid var(--cs-border) !important;
	box-shadow: none !important;
	border-radius: var(--cs-radius-sm) !important;
	padding: 18px !important;
}

.r_block_c.cases-main-block .info-block h3 {
	color: var(--cs-green) !important;
	text-shadow: none !important;
	font-size: 15px !important;
}

.r_block_c.cases-main-block .info-block p,
.r_block_c.cases-main-block .info-block ul {
	color: var(--cs-text-dim) !important;
}

/* --- Rcon shop --- */
.cs-page-main .rcon-shop-product {
	background: var(--cs-bg-card) !important;
	border: 1px solid var(--cs-border) !important;
	border-radius: var(--cs-radius) !important;
}

.cs-page-main .rcon-shop-product .image .title {
	background: rgba(10, 12, 16, 0.75) !important;
	border-radius: var(--cs-radius-sm) !important;
	backdrop-filter: blur(4px);
}

.cs-page-main .rcon-shop-product .actions .btn {
	border-radius: var(--cs-radius-sm) !important;
}

/* --- Demos --- */
.r_block_c .demo {
	border-bottom-color: var(--cs-border) !important;
	padding: 14px 0;
}

.r_block_c .demo .col-xs-5 p a {
	color: var(--cs-accent) !important;
}

.r_block_c .demo .col-xs-5 p b {
	color: var(--cs-text) !important;
}

.r_block_c .demo .map {
	border-radius: var(--cs-radius-sm) !important;
	border: 1px solid var(--cs-border);
}

@media (max-width: 700px) {
	.cs-mini-server,
	.r_block_c .block.mini_serv {
		flex-direction: column;
	}

	.cs-mini-server-map,
	.r_block_c .mini_serv img {
		width: 100% !important;
		height: 140px !important;
	}
}

/* --- Чат: перебиваем secondary.css --- */
.cs-chat-rail .chat_message {
	display: flex !important;
	align-items: flex-start;
	gap: 10px;
	position: relative;
	overflow: visible;
	margin-bottom: 0;
	padding: 10px 12px;
	border-bottom: 1px solid var(--cs-border);
}

.cs-chat-rail .chat_message > a {
	flex: 0 0 36px;
	line-height: 0;
}

.cs-chat-rail .chat_message .user_img {
	float: none !important;
	display: block;
	border-radius: 50%;
	height: 36px !important;
	width: 36px !important;
	padding: 0 !important;
	background: none !important;
	border: none !important;
	box-shadow: none !important;
}

.cs-chat-rail .chat_message .message {
	flex: 1;
	min-width: 0;
	margin-left: 0 !important;
	position: static !important;
	overflow: visible !important;
	word-wrap: break-word;
	color: var(--cs-text-dim);
}

.cs-chat-rail .chat_message .message .info {
	display: flex !important;
	flex-wrap: wrap;
	align-items: center;
	gap: 4px 6px;
	height: auto !important;
	min-height: 0;
	margin-bottom: 4px;
}

.cs-chat-rail .chat_message .message .info .author {
	float: none !important;
	position: static !important;
	font-size: 13px;
	font-weight: 600;
	line-height: 1.3;
	cursor: pointer;
	text-shadow: none !important;
	filter: none !important;
}

.cs-chat-rail .chat_message .message .info .date {
	float: none !important;
	position: static !important;
	margin-left: auto;
	font-size: 11px;
	font-weight: 500;
	line-height: 1.3;
	color: var(--cs-text-dim);
	opacity: 0.55;
	white-space: nowrap;
}

.cs-chat-rail .chat_message .message .info .date .m-icon {
	display: none;
}

.cs-chat-rail .chat_message .dell_message,
.cs-chat-rail .chat_message .edit_message {
	position: static !important;
	top: auto !important;
	right: auto !important;
	flex-shrink: 0;
	margin: 0;
	font-size: 11px;
	opacity: 0.45;
	cursor: pointer;
}

.cs-chat-rail .chat_message .dell_message:hover,
.cs-chat-rail .chat_message .edit_message:hover {
	opacity: 0.85;
}

.cs-chat-rail .chat_message .message [id^="message_text_"] {
	display: block;
	clear: both;
	margin: 0;
	padding: 0;
	color: rgba(238, 240, 244, 0.58) !important;
	line-height: 1.45;
	word-wrap: break-word;
	overflow-wrap: anywhere;
}

.cs-chat-rail .chat_message .message [id^="message_text_"] a {
	color: var(--cs-accent);
}

.cs-chat-rail .chat_message .message [id^="message_text_"] .g_smile,
.cs-chat-rail .chat_message .message [id^="message_text_"] .g_sticker {
	vertical-align: middle;
}

/* Поле ввода + смайлик */
.cs-chat-rail .cs-chat-compose {
	align-items: stretch;
	gap: 8px;
	padding: 10px 12px;
}

.cs-chat-rail .cs-chat-input-wrap {
	display: flex;
	align-items: center;
	gap: 8px;
	flex: 1;
	min-height: 40px;
	padding: 0 4px 0 10px;
	background: var(--cs-bg-pill);
	border: 1px solid var(--cs-border);
	border-radius: 999px;
	position: relative;
}

.cs-chat-rail .cs-chat-input-wrap .smile_btn,
.cs-chat-rail .cs-chat-smile {
	position: static !important;
	left: auto !important;
	right: auto !important;
	top: auto !important;
	transform: none !important;
	flex: 0 0 18px;
	width: 18px !important;
	height: 18px !important;
	margin: 0 !important;
	padding: 0 !important;
	cursor: pointer;
	opacity: 0.55;
	background-image: url('../img/smile.svg');
	background-size: 18px 18px;
	background-position: center;
	background-repeat: no-repeat;
	border: none;
	border-radius: 0;
}

.cs-chat-rail .cs-chat-input-wrap .smile_btn:hover,
.cs-chat-rail .cs-chat-smile:hover {
	opacity: 0.85;
}

.cs-chat-rail .cs-chat-input-wrap .form-control,
.cs-chat-rail #chat_message_input {
	flex: 1;
	width: auto !important;
	min-width: 0;
	height: 38px !important;
	padding: 0 8px 0 0 !important;
	margin: 0 !important;
	background: transparent !important;
	border: none !important;
	border-radius: 0 !important;
	box-shadow: none !important;
	color: var(--cs-text) !important;
	font-size: 13px !important;
	line-height: 38px !important;
}

.cs-chat-rail .cs-chat-send {
	flex-shrink: 0;
	align-self: center;
	width: 38px;
	height: 38px;
}

.cs-chat-rail #chat_messages {
	flex: 1 1 auto !important;
	height: 0 !important;
	max-height: none !important;
	overflow-x: hidden !important;
	overflow-y: auto !important;
}

.cs-chat-rail #chat_messages .chat_message {
	padding-right: 12px !important;
}

/* Главная: без лишней полосы над карточками */
.cs-page-main:has(#cs-home-modes) {
	background: transparent;
	border: none;
	min-height: 0;
}

#cs-home-modes {
	width: 100%;
}

/* ========== PROFILE (CyberShoke-style) ========== */
.cs-profile-page {
	display: flex;
	flex-direction: column;
	gap: 18px;
	min-width: 0;
	--pt-accent: 124, 92, 255;
	--pt-accent-2: 92, 108, 255;
	--pt-base-1: #171b28;
	--pt-base-2: #10131b;
	--pt-base-3: #1a1428;
	--pt-panel: 22, 25, 34;
	--pt-panel-2: 16, 19, 27;
	--pt-border: 124, 92, 255;
	--pt-shade: 10, 12, 16;
	--pt-tint: 0.16;
}

.cs-profile-page--theme-transparent.cs-profile-page--has-banner-bg {
	position: relative;
}

.cs-profile-page--theme-transparent.cs-profile-page--has-banner-bg::before {
	content: '';
	position: fixed;
	inset: 0;
	z-index: -2;
	background-image: var(--profile-bg-image);
	background-size: cover;
	background-position: center top;
	background-repeat: no-repeat;
	pointer-events: none;
}

.cs-profile-page--theme-transparent.cs-profile-page--has-banner-bg::after {
	content: '';
	position: fixed;
	inset: 0;
	z-index: -1;
	background: rgba(8, 10, 14, 0.42);
	pointer-events: none;
}

.cs-profile-page--theme-transparent.cs-profile-page--has-banner-bg .cs-profile-panel {
	background: rgba(15, 17, 23, 0.58);
	backdrop-filter: blur(14px);
	-webkit-backdrop-filter: blur(14px);
	border-color: rgba(255, 255, 255, 0.08);
}

.cs-profile-page--theme-transparent.cs-profile-page--has-banner-bg .cs-profile-tabs {
	background: rgba(15, 17, 23, 0.42);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	border-radius: var(--cs-radius);
	padding: 4px 6px 0;
	border: 1px solid rgba(255, 255, 255, 0.06);
}

.cs-profile-page--theme-transparent.cs-profile-page--has-banner-bg .cs-profile-kpi,
.cs-profile-page--theme-transparent.cs-profile-page--has-banner-bg .cs-profile-friend-card,
.cs-profile-page--theme-transparent.cs-profile-page--has-banner-bg .cs-profile-wall-compose,
.cs-profile-page--theme-transparent.cs-profile-page--has-banner-bg .cs-profile-wall-post {
	background: rgba(15, 17, 23, 0.52);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
}

.cs-profile-page--theme-transparent.cs-profile-page--has-banner-bg .cs-profile-cover:not(:has(.cs-profile-cover__banner-img)) .cs-profile-cover__shade {
	background: linear-gradient(180deg, rgba(10, 12, 16, 0.04) 0%, rgba(10, 12, 16, 0.28) 52%, rgba(10, 12, 16, 0.72) 100%);
}

.cs-profile-page--theme-default {
	--pt-accent: 124, 92, 255;
	--pt-accent-2: 92, 108, 255;
	--pt-base-1: #171b28;
	--pt-base-2: #10131b;
	--pt-base-3: #1a1428;
	--pt-panel: 22, 25, 34;
	--pt-panel-2: 16, 19, 27;
	--pt-border: 124, 92, 255;
	--pt-shade: 10, 12, 16;
	--pt-tint: 0.16;
}

.cs-profile-page--theme-summer {
	--pt-accent: 196, 154, 64;
	--pt-accent-2: 168, 122, 48;
	--pt-base-1: #2a2418;
	--pt-base-2: #1a1610;
	--pt-base-3: #2e2518;
	--pt-panel: 34, 28, 20;
	--pt-panel-2: 26, 22, 16;
	--pt-border: 196, 154, 64;
	--pt-shade: 26, 22, 16;
	--pt-tint: 0.22;
}

.cs-profile-page--theme-midnight {
	--pt-accent: 64, 96, 180;
	--pt-accent-2: 48, 72, 140;
	--pt-base-1: #0d1424;
	--pt-base-2: #080c14;
	--pt-base-3: #0a1220;
	--pt-panel: 12, 18, 32;
	--pt-panel-2: 8, 12, 22;
	--pt-border: 64, 96, 180;
	--pt-shade: 8, 12, 20;
	--pt-tint: 0.2;
}

.cs-profile-page--theme-steel {
	--pt-accent: 120, 132, 148;
	--pt-accent-2: 96, 108, 124;
	--pt-base-1: #1e2228;
	--pt-base-2: #151820;
	--pt-base-3: #242830;
	--pt-panel: 28, 32, 38;
	--pt-panel-2: 21, 24, 32;
	--pt-border: 120, 132, 148;
	--pt-shade: 16, 18, 24;
	--pt-tint: 0.18;
}

.cs-profile-page--theme-space {
	--pt-accent: 140, 88, 196;
	--pt-accent-2: 108, 64, 168;
	--pt-base-1: #1a1428;
	--pt-base-2: #120e1e;
	--pt-base-3: #221832;
	--pt-panel: 26, 18, 36;
	--pt-panel-2: 18, 14, 28;
	--pt-border: 140, 88, 196;
	--pt-shade: 14, 10, 22;
	--pt-tint: 0.2;
}

.cs-profile-page--theme-dark {
	--pt-accent: 96, 96, 96;
	--pt-accent-2: 64, 64, 64;
	--pt-base-1: #141414;
	--pt-base-2: #0c0c0c;
	--pt-base-3: #181818;
	--pt-panel: 20, 20, 20;
	--pt-panel-2: 14, 14, 14;
	--pt-border: 96, 96, 96;
	--pt-shade: 8, 8, 8;
	--pt-tint: 0.12;
}

.cs-profile-cover {
	position: relative;
	z-index: 40;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	overflow: visible;
	border-radius: var(--cs-radius);
	border: 1px solid var(--cs-border);
	min-height: 240px;
}

.cs-profile-cover__bottom {
	position: relative;
	z-index: 2;
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 16px 24px;
	padding: 20px 22px 22px;
	flex-wrap: wrap;
	overflow: visible;
}

.cs-profile-cover__media {
	position: absolute;
	inset: 0;
	border-radius: inherit;
	overflow: hidden;
	background:
		radial-gradient(120% 120% at 85% 15%, rgba(124, 92, 255, 0.28), transparent 55%),
		radial-gradient(90% 90% at 10% 100%, rgba(92, 108, 255, 0.22), transparent 50%),
		linear-gradient(135deg, #171b28 0%, #10131b 48%, #1a1428 100%);
	background-size: cover;
	background-position: center;
}

.cs-profile-cover__media--custom {
	background: #10131b;
}

.cs-profile-cover__banner-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	display: block;
	user-drag: none;
	-webkit-user-drag: none;
	user-select: none;
	-webkit-user-select: none;
	pointer-events: none;
}

/* Кастомный баннер: на мобилке тот же размер карточки, что и без баннера */
.cs-profile-cover--has-banner,
.cs-profile-cover:has(.cs-profile-cover__banner-img) {
	background: transparent;
}

@media (max-width: 900px) {
	.cs-profile-cover--has-banner,
	.cs-profile-cover:has(.cs-profile-cover__banner-img) {
		display: flex;
		flex-direction: column;
		justify-content: flex-end;
		min-height: 240px;
		overflow: visible;
	}

	.cs-profile-cover--has-banner .cs-profile-cover__media,
	.cs-profile-cover:has(.cs-profile-cover__banner-img) .cs-profile-cover__media {
		position: absolute;
		inset: 0;
		width: auto;
		height: auto;
		border-radius: inherit;
		overflow: hidden;
	}

	.cs-profile-cover--has-banner .cs-profile-cover__shade,
	.cs-profile-cover:has(.cs-profile-cover__banner-img) .cs-profile-cover__shade {
		display: block;
		z-index: 1;
	}

	.cs-profile-cover--has-banner .cs-profile-cover__bottom,
	.cs-profile-cover:has(.cs-profile-cover__banner-img) .cs-profile-cover__bottom {
		position: relative;
		z-index: 3;
		overflow: visible;
	}

	.cs-profile-cover--has-banner .cs-profile-actions-menu,
	.cs-profile-cover:has(.cs-profile-cover__banner-img) .cs-profile-actions-menu {
		position: relative;
		z-index: 20;
	}

	.cs-profile-cover--has-banner .cs-profile-actions-menu.open,
	.cs-profile-cover:has(.cs-profile-cover__banner-img) .cs-profile-actions-menu.open {
		z-index: 60;
	}
}

@media (min-width: 901px) {
	.cs-profile-cover:has(.cs-profile-cover__banner-img) {
		display: flex;
		flex-direction: column;
		justify-content: flex-end;
		min-height: 0;
		aspect-ratio: 4 / 1;
		overflow: visible;
		background: transparent;
	}

	.cs-profile-cover--has-banner .cs-profile-cover__bottom,
	.cs-profile-cover:has(.cs-profile-cover__banner-img) .cs-profile-cover__bottom {
		position: absolute;
		left: 0;
		right: 0;
		bottom: 0;
		display: flex;
		flex-direction: row;
		align-items: flex-end;
		justify-content: space-between;
		margin-top: 0;
		padding: 20px 22px 22px;
		background: transparent;
		z-index: 3;
	}

	.cs-profile-cover:has(.cs-profile-cover__banner-img) .cs-profile-cover__shade {
		display: block;
		z-index: 2;
		background: linear-gradient(180deg, rgba(10, 12, 16, 0.08) 0%, rgba(10, 12, 16, 0.42) 52%, rgba(10, 12, 16, 0.94) 100%);
	}

	.cs-profile-cover--has-banner .cs-profile-cover__media,
	.cs-profile-cover:has(.cs-profile-cover__banner-img) .cs-profile-cover__media {
		position: absolute;
		inset: 0;
		height: auto;
		min-height: 0;
		border-radius: inherit;
	}

	.cs-profile-cover--has-banner .cs-profile-cover__media::after,
	.cs-profile-cover:has(.cs-profile-cover__banner-img) .cs-profile-cover__media::after {
		display: none;
	}

	.cs-profile-cover--has-banner .cs-profile-cover__profile,
	.cs-profile-cover:has(.cs-profile-cover__banner-img) .cs-profile-cover__profile {
		flex: 1 1 280px;
		align-items: center;
		margin-top: 0;
	}

	.cs-profile-cover--has-banner .cs-profile-avatar,
	.cs-profile-cover:has(.cs-profile-cover__banner-img) .cs-profile-avatar {
		width: 108px;
		height: 108px;
		border-width: 3px;
		border-color: rgba(15, 17, 23, 0.92);
		box-shadow: 0 14px 34px rgba(0, 0, 0, 0.45);
	}

	.cs-profile-cover--has-banner .cs-profile-cover__toolbar,
	.cs-profile-cover:has(.cs-profile-cover__banner-img) .cs-profile-cover__toolbar {
		width: auto;
		align-items: flex-end;
		margin-top: 0;
		padding-top: 0;
		border-top: none;
	}
}

.cs-profile-cover:has(.cs-profile-cover__banner-img) {
	border-color: var(--cs-border);
}

.cs-profile-cover__shade {
	position: absolute;
	inset: 0;
	border-radius: inherit;
	background: linear-gradient(180deg, rgba(10, 12, 16, 0.08) 0%, rgba(10, 12, 16, 0.42) 52%, rgba(10, 12, 16, 0.94) 100%);
	pointer-events: none;
}

.cs-profile-page:not(.cs-profile-page--theme-transparent) .cs-profile-cover__media:not(.cs-profile-cover__media--custom) {
	background:
		radial-gradient(120% 120% at 85% 15%, rgba(var(--pt-accent), 0.28), transparent 55%),
		radial-gradient(90% 90% at 10% 100%, rgba(var(--pt-accent-2), 0.22), transparent 50%),
		linear-gradient(135deg, var(--pt-base-1) 0%, var(--pt-base-2) 48%, var(--pt-base-3) 100%);
}

.cs-profile-page:not(.cs-profile-page--theme-transparent) .cs-profile-cover:not(:has(.cs-profile-cover__banner-img)) .cs-profile-cover__shade {
	background: linear-gradient(
		180deg,
		rgba(var(--pt-shade), 0.08) 0%,
		rgba(var(--pt-shade), 0.42) 52%,
		rgba(var(--pt-shade), 0.94) 100%
	);
}

.cs-profile-page:not(.cs-profile-page--theme-transparent) .cs-profile-cover:not(:has(.cs-profile-cover__banner-img)) {
	border-color: rgba(var(--pt-border), 0.18);
}

.cs-profile-page:not(.cs-profile-page--theme-transparent) .cs-profile-panel {
	background: linear-gradient(
		180deg,
		rgba(var(--pt-panel), 0.98) 0%,
		rgba(var(--pt-panel-2), 0.98) 100%
	);
	border-color: rgba(var(--pt-border), 0.14);
}

.cs-profile-page:not(.cs-profile-page--theme-transparent) .cs-profile-tabs__indicator {
	background: rgb(var(--pt-accent));
}

.cs-profile-page:not(.cs-profile-page--theme-transparent) .cs-profile-kpi,
.cs-profile-page:not(.cs-profile-page--theme-transparent) .cs-profile-friend-card,
.cs-profile-page:not(.cs-profile-page--theme-transparent) .cs-settings-panel,
.cs-profile-page:not(.cs-profile-page--theme-transparent) .cs-profile-wall-compose,
.cs-profile-page:not(.cs-profile-page--theme-transparent) .cs-profile-wall-post {
	background: rgba(var(--pt-panel), 0.88);
	border-color: rgba(var(--pt-border), 0.12);
}

.cs-profile-page:not(.cs-profile-page--theme-transparent) .cs-profile-tabs__item.is-active {
	color: rgb(var(--pt-accent));
}

.cs-profile-cover__toolbar {
	position: relative;
	z-index: 3;
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	justify-content: flex-end;
	flex-wrap: wrap;
	gap: 10px;
	padding: 0;
	flex-shrink: 0;
	overflow: visible;
}

.cs-profile-cover__profile {
	position: relative;
	z-index: 2;
	display: flex;
	align-items: center;
	gap: 16px;
	padding: 0;
	min-width: 0;
	flex: 1 1 280px;
}

.cs-profile-cover__headline {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 6px;
	min-width: 0;
	padding-bottom: 2px;
}

.cs-profile-cover .cs-profile-avatar {
	width: 108px;
	height: 108px;
	border-color: rgba(15, 17, 23, 0.92);
	box-shadow: 0 14px 34px rgba(0, 0, 0, 0.45);
}

.cs-profile-cover .cs-profile-avatar__status {
	border-color: rgba(15, 17, 23, 0.92);
}

.cs-profile-cover .cs-profile-social__btn {
	background: rgba(15, 17, 23, 0.48);
	border-color: rgba(255, 255, 255, 0.12);
	backdrop-filter: blur(8px);
}

.cs-profile-cover .cs-profile-social__btn--static {
	background: rgba(15, 17, 23, 0.48);
}

.cs-profile-cover .cs-profile-actions .cs-btn-ghost {
	background: rgba(15, 17, 23, 0.48);
	border-color: rgba(255, 255, 255, 0.12);
	color: #eef0f4;
	backdrop-filter: blur(8px);
}

.cs-profile-cover .cs-profile-actions .cs-btn-ghost:hover {
	background: rgba(24, 28, 38, 0.82);
	color: #fff;
}

.cs-profile-cover .cs-profile-actions .cs-btn-balance {
	background:
		linear-gradient(135deg, rgba(210, 220, 255, 0.1) 0%, rgba(15, 17, 23, 0.42) 100%);
	border-color: rgba(200, 212, 240, 0.28);
	color: #d4dcf0 !important;
	backdrop-filter: blur(8px);
	box-shadow:
		inset 0 1px 0 rgba(255, 255, 255, 0.06),
		0 0 16px rgba(160, 190, 255, 0.08);
}

.cs-profile-cover .cs-profile-actions .cs-btn-balance:hover {
	background:
		linear-gradient(135deg, rgba(220, 230, 255, 0.16) 0%, rgba(24, 28, 38, 0.82) 100%);
	border-color: rgba(220, 230, 255, 0.42);
	color: #eef2ff !important;
	box-shadow:
		inset 0 1px 0 rgba(255, 255, 255, 0.08),
		0 0 22px rgba(186, 205, 255, 0.22);
}

.cs-profile-avatar-wrap {
	position: relative;
	flex-shrink: 0;
}

.cs-profile-avatar {
	width: 96px;
	height: 96px;
	border-radius: 50%;
	object-fit: cover;
	border: 3px solid rgba(255, 255, 255, 0.08);
	box-shadow: 0 12px 30px rgba(0, 0, 0, 0.35);
}

.cs-profile-avatar__status {
	position: absolute;
	right: 4px;
	bottom: 4px;
	width: 14px;
	height: 14px;
	border-radius: 50%;
	border: 2px solid var(--cs-bg-card);
}

.cs-profile-avatar__status--online {
	background: #5c9dff;
	box-shadow: 0 0 10px rgba(92, 157, 255, 0.55);
}

.cs-profile-avatar__status--ingame {
	background: #45d483;
	box-shadow: 0 0 10px rgba(69, 212, 131, 0.55);
}

.cs-profile-hero__info {
	min-width: 0;
}

.cs-profile-name {
	margin: 0;
	font-size: 30px;
	font-weight: 800;
	line-height: 1.1;
	color: var(--group-color, var(--cs-text));
}

.cs-profile-name--glow {
	text-shadow:
		0 0 12px color-mix(in srgb, var(--group-color) 55%, transparent),
		0 0 24px color-mix(in srgb, var(--group-color) 25%, transparent);
}

.cs-profile-name--sparkle {
	position: relative;
	display: inline-block;
	text-shadow:
		0 0 14px color-mix(in srgb, var(--group-color) 50%, transparent),
		0 0 28px color-mix(in srgb, var(--group-color) 22%, transparent);
}

.cs-profile-name--sparkle::before,
.cs-profile-name--sparkle::after {
	content: '✦';
	position: absolute;
	color: var(--group-color);
	opacity: 0.9;
	line-height: 1;
	pointer-events: none;
	animation: cs-profile-name-sparkle 2.6s ease-in-out infinite;
}

.cs-profile-name--sparkle::before {
	top: -4px;
	left: -10px;
	font-size: 13px;
}

.cs-profile-name--sparkle::after {
	bottom: 2px;
	left: 2px;
	font-size: 8px;
	animation-delay: 1.3s;
}

@keyframes cs-profile-name-sparkle {
	0%, 100% {
		opacity: 0.35;
		transform: scale(0.85) rotate(0deg);
	}
	50% {
		opacity: 1;
		transform: scale(1.1) rotate(18deg);
	}
}

.cs-profile-status {
	margin: 0;
	font-size: 13px;
	color: rgba(238, 240, 244, 0.72);
}

.cs-profile-status--ingame {
	color: #45d483;
	font-weight: 600;
}

.cs-profile-status--onsite {
	color: #7eb6ff;
	font-weight: 600;
}

.cs-profile-cover .cs-profile-status--offline {
	color: rgba(238, 240, 244, 0.62);
}

.cs-profile-status--offline-sub {
	margin-top: -6px;
	font-size: 12px;
	color: var(--cs-text-dim);
	opacity: 0.85;
}

.cs-profile-cover .cs-profile-actions {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end;
	gap: 8px;
}

.cs-profile-actions {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end;
	gap: 8px;
}

.cs-profile-social {
	display: flex;
	align-items: center;
	gap: 8px;
}

.cs-profile-social__btn {
	width: 34px;
	height: 34px;
	border-radius: 10px;
	border: 1px solid var(--cs-border);
	background: var(--cs-bg-pill);
	color: var(--cs-text-dim);
	display: grid;
	place-items: center;
	transition: background 0.15s, color 0.15s, border-color 0.15s;
}

.cs-profile-social__icon {
	display: block;
	flex-shrink: 0;
	width: 18px;
	height: 18px;
	object-fit: contain;
}

.cs-profile-social__btn:hover .cs-profile-social__icon {
	opacity: 0.92;
}

.cs-profile-social__btn--steam:hover {
	color: #66c0f4;
	border-color: rgba(102, 192, 244, 0.35);
}

.cs-profile-social__btn--vk:hover {
	color: #4c75a3;
	border-color: rgba(76, 117, 163, 0.35);
}

.cs-profile-social__btn--telegram:hover {
	color: #2aabee;
	border-color: rgba(42, 171, 238, 0.35);
}

.cs-profile-social__btn--discord:hover {
	color: #5865f2;
	border-color: rgba(88, 101, 242, 0.35);
}

.cs-profile-social__btn:hover {
	background: var(--cs-bg-hover);
	color: var(--cs-text);
	border-color: rgba(255, 255, 255, 0.12);
}

.cs-profile-social__btn--static {
	cursor: default;
}

.cs-profile-actions-menu {
	position: relative;
	display: inline-block;
	flex-shrink: 0;
	z-index: 2;
}

.cs-profile-actions-menu .dropdown-toggle {
	touch-action: manipulation;
	-webkit-tap-highlight-color: transparent;
}

.cs-profile-cover .cs-profile-actions-menu.open > .dropdown-menu,
.cs-profile-cover .cs-profile-actions-menu.open .dropdown-menu {
	display: block !important;
	visibility: visible !important;
	opacity: 1 !important;
	pointer-events: auto !important;
}

.cs-profile-page .dropdown-backdrop {
	display: none !important;
}

.cs-profile-cover .cs-profile-actions-menu.open {
	z-index: 60;
}

.cs-profile-cover .cs-profile-actions-menu > .dropdown-menu {
	position: absolute !important;
	top: calc(100% + 8px) !important;
	bottom: auto !important;
	right: 0 !important;
	left: auto !important;
	float: none !important;
	margin: 0 !important;
	min-width: 240px;
	max-width: min(300px, calc(100vw - 48px));
	padding: 6px 0 !important;
	z-index: 200;
	background: #141824 !important;
	border: 1px solid rgba(255, 255, 255, 0.1) !important;
	border-radius: var(--cs-radius-sm) !important;
	box-shadow: 0 18px 48px rgba(0, 0, 0, 0.55) !important;
	backdrop-filter: none !important;
	-webkit-backdrop-filter: none !important;
}

.cs-profile-cover .cs-profile-actions-menu .dropdown-menu > li > a {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 10px 16px !important;
	min-height: 44px;
	color: var(--cs-text) !important;
	white-space: nowrap;
}

.cs-profile-cover .cs-profile-actions-menu .dropdown-menu > li.disabled > a {
	color: var(--cs-text-dim) !important;
	opacity: 1;
	cursor: default;
	pointer-events: none;
}

.cs-profile-cover .cs-profile-actions-menu .dropdown-menu > li.disabled > a strong {
	color: var(--cs-text) !important;
	font-weight: 700;
}

.cs-profile-cover .cs-profile-actions-menu .dropdown-menu > li:not(.disabled) > a:hover,
.cs-profile-cover .cs-profile-actions-menu .dropdown-menu > li:not(.disabled) > a:focus {
	background: rgba(255, 255, 255, 0.06) !important;
	color: #fff !important;
}

.cs-profile-cover .cs-profile-actions-menu .dropdown-menu .divider {
	margin: 6px 0;
	background: rgba(255, 255, 255, 0.08);
}

.cs-btn-sm {
	padding: 8px 12px !important;
	font-size: 13px !important;
	line-height: 1 !important;
}

.cs-profile-kpis {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
	gap: 10px;
}

.cs-profile-kpi {
	padding: 14px 16px;
	border-radius: var(--cs-radius-sm);
	border: 1px solid var(--cs-border);
	background: var(--cs-bg-card);
	text-align: center;
}

.cs-profile-kpi__value {
	font-size: 22px;
	font-weight: 800;
	line-height: 1.1;
	color: var(--cs-text);
	font-variant-numeric: tabular-nums;
}

.cs-profile-kpi__value--text {
	font-size: 16px;
	font-weight: 700;
	word-break: break-word;
}

.cs-profile-kpi__label {
	margin-top: 6px;
	font-size: 12px;
	color: var(--cs-text-dim);
}

.cs-profile-tabs {
	position: relative;
	z-index: 1;
	display: flex;
	flex-direction: column;
	gap: 0;
	padding-bottom: 0;
	border-bottom: 1px solid var(--cs-border);
}

.cs-profile-tab-panels {
	position: relative;
	z-index: 1;
	min-width: 0;
}

.cs-profile-tabs__list {
	position: relative;
	display: flex;
	flex-wrap: wrap;
	gap: 4px;
	padding-bottom: 2px;
}

.cs-scroll-hint-x {
	position: relative;
}

.cs-scroll-hint-x.is-scrollable.is-scroll-start:not(.is-scroll-end) {
	-webkit-mask-image: linear-gradient(to right, #000 0%, #000 calc(100% - 28px), transparent 100%);
	mask-image: linear-gradient(to right, #000 0%, #000 calc(100% - 28px), transparent 100%);
}

.cs-scroll-hint-x.is-scrollable:not(.is-scroll-start):not(.is-scroll-end) {
	-webkit-mask-image: linear-gradient(to right, transparent 0%, #000 20px, #000 calc(100% - 20px), transparent 100%);
	mask-image: linear-gradient(to right, transparent 0%, #000 20px, #000 calc(100% - 20px), transparent 100%);
}

.cs-scroll-hint-x.is-scrollable.is-scroll-end:not(.is-scroll-start) {
	-webkit-mask-image: linear-gradient(to right, transparent 0%, #000 20px, #000 100%);
	mask-image: linear-gradient(to right, transparent 0%, #000 20px, #000 100%);
}

.cs-profile-tabs__indicator {
	position: absolute;
	left: 0;
	bottom: 0;
	height: 2px;
	width: 0;
	border-radius: 2px 2px 0 0;
	background: var(--cs-accent);
	transform: translateX(0);
	transition: transform 0.2s ease, width 0.2s ease;
	pointer-events: none;
}

.cs-profile-tabs__item {
	padding: 10px 14px;
	border: none;
	border-radius: 8px 8px 0 0;
	background: transparent;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--cs-text-dim);
	cursor: pointer;
	transition: color 0.15s, background 0.15s;
}

.cs-profile-tabs__item:hover {
	color: var(--cs-text);
	background: rgba(255, 255, 255, 0.03);
}

.cs-profile-tabs__item.is-active {
	color: var(--cs-accent);
	background: transparent;
	box-shadow: none;
}

a.cs-profile-tabs__item--link {
	display: inline-flex;
	align-items: center;
	text-decoration: none;
}

a.cs-profile-tabs__item--link.is-active {
	box-shadow: inset 0 -2px 0 var(--cs-accent);
}

.cs-profile-tab-panel {
	display: none;
	scroll-margin-top: 84px;
}

.cs-profile-tab-panel.is-active {
	display: block;
}

.cs-profile-panel {
	border-radius: var(--cs-radius);
	border: 1px solid var(--cs-border);
	background: var(--cs-bg-card);
	overflow: hidden;
}

.cs-profile-panel__head {
	padding: 16px 18px;
	border-bottom: 1px solid var(--cs-border);
}

.cs-profile-panel__head--split {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	flex-wrap: wrap;
}

.cs-profile-panel__title {
	margin: 0;
	font-size: 16px;
	font-weight: 700;
	color: var(--cs-text);
}

.cs-profile-panel__body {
	padding: 18px;
	color: var(--cs-text-dim);
}

.cs-profile-panel__body--flush {
	padding: 0;
}

.cs-profile-info-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: 18px;
}

.cs-profile-info-group__title {
	margin: 0 0 12px;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--cs-text-dim);
}

.cs-profile-info-list {
	margin: 0;
}

.cs-profile-info-row {
	display: grid;
	grid-template-columns: minmax(110px, 38%) 1fr;
	gap: 10px;
	padding: 10px 0;
	border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}

.cs-profile-info-row:last-child {
	border-bottom: none;
	padding-bottom: 0;
}

.cs-profile-info-row dt {
	margin: 0;
	font-size: 13px;
	color: var(--cs-text-dim);
}

.cs-profile-info-row dd {
	margin: 0;
	font-size: 13px;
	color: var(--cs-text);
	word-break: break-word;
}

.cs-profile-contact-link {
	display: inline-flex;
	align-items: center;
	gap: 8px;
}

.cs-profile-contact-link img {
	width: 24px;
	height: 24px;
	border-radius: 50%;
	object-fit: cover;
}

.cs-profile-server-tabs {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	margin: 0;
	padding: 0;
	list-style: none;
}

.cs-profile-server-tabs > li > a {
	display: inline-flex;
	padding: 6px 12px;
	border-radius: 999px;
	border: 1px solid var(--cs-border);
	background: var(--cs-bg-pill);
	font-size: 12px;
	font-weight: 600;
	color: var(--cs-text-dim) !important;
}

.cs-profile-server-tabs > li.active > a,
.cs-profile-server-tabs > li > a:hover {
	background: rgba(92, 108, 255, 0.16);
	border-color: rgba(92, 108, 255, 0.35);
	color: var(--cs-text) !important;
}

.cs-profile-stats-section .cs-profile-stats-body {
	padding: 0;
}

.cs-profile-stats-root {
	display: flex;
	flex-direction: column;
	gap: 0;
}

.cs-profile-stats-summary {
	display: grid;
	grid-template-columns: repeat(6, minmax(0, 1fr));
	gap: 10px;
	padding: 16px 18px;
	border-bottom: 1px solid var(--cs-border);
}

.cs-profile-stats-root--profile .cs-profile-stats-summary {
	grid-template-columns: repeat(auto-fit, minmax(132px, 1fr));
	border-bottom: none;
}

.cs-profile-stats-details {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	border-bottom: 1px solid var(--cs-border);
}

.cs-profile-stats-details .cs-profile-stats-group {
	border-bottom: none;
	border-right: 1px solid var(--cs-border);
	padding: 14px 16px;
	min-width: 0;
}

.cs-profile-stats-details .cs-profile-stats-group:last-child {
	border-right: none;
}

.cs-profile-stats-group--meters {
	padding: 14px 18px 16px;
	border-bottom: 1px solid var(--cs-border);
}

.cs-profile-stats-group--meters .cs-profile-stats-meters {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 16px;
}

.cs-profile-stats-card {
	display: flex;
	flex-direction: column;
	gap: 6px;
	padding: 14px 12px;
	border: 1px solid var(--cs-border);
	border-radius: var(--cs-radius-sm);
	background: var(--cs-bg-pill);
	min-width: 0;
}

.cs-profile-stats-card--accent {
	border-color: rgba(92, 108, 255, 0.35);
	background: rgba(92, 108, 255, 0.08);
}

.cs-profile-stats-card__label {
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: var(--cs-text-dim);
}

.cs-profile-stats-card__value {
	font-size: 22px;
	font-weight: 700;
	line-height: 1.1;
	color: var(--cs-text);
}

.cs-profile-stats-card__value--compact {
	font-size: 16px;
	line-height: 1.25;
}

.cs-profile-stats-group {
	padding: 16px 18px;
	border-bottom: 1px solid var(--cs-border);
}

.cs-profile-stats-group--block {
	padding-bottom: 18px;
}

.cs-profile-stats-group:last-child {
	border-bottom: none;
}

.cs-profile-stats-group__title {
	margin: 0 0 12px;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--cs-text-dim);
}

.cs-profile-stats-list {
	margin: 0;
}

.cs-profile-stats-row {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	gap: 16px;
	align-items: baseline;
	padding: 8px 0;
	border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}

.cs-profile-stats-row:first-child {
	padding-top: 0;
}

.cs-profile-stats-row:last-child {
	border-bottom: none;
	padding-bottom: 0;
}

.cs-profile-stats-row--section {
	padding-top: 4px;
	border-bottom: none;
}

.cs-profile-stats-row--section dt {
	color: var(--cs-text);
	font-size: 13px;
	text-transform: none;
	letter-spacing: 0;
}

.cs-profile-stats-row dt {
	margin: 0;
	font-size: 13px;
	font-weight: 500;
	color: var(--cs-text-dim);
}

.cs-profile-stats-row dd {
	margin: 0;
	font-size: 14px;
	color: var(--cs-text);
	word-break: break-word;
	text-align: right;
	font-variant-numeric: tabular-nums;
}

.cs-profile-stats-row dd b {
	color: var(--cs-text);
	font-weight: 600;
}

.cs-profile-stats-badge {
	display: inline-block;
	padding: 3px 10px;
	border-radius: 999px;
	font-size: 12px;
	font-weight: 600;
	border: 1px solid transparent;
}

.cs-profile-stats-badge--success {
	background: rgba(61, 214, 140, 0.12);
	color: var(--cs-green);
	border-color: rgba(61, 214, 140, 0.25);
}

.cs-profile-stats-badge--info {
	background: rgba(92, 108, 255, 0.12);
	color: var(--cs-accent);
	border-color: rgba(92, 108, 255, 0.25);
}

.cs-profile-stats-badge--warning {
	background: rgba(232, 179, 57, 0.12);
	color: #e8b339;
	border-color: rgba(232, 179, 57, 0.25);
}

.cs-profile-stats-badge--danger {
	background: rgba(239, 107, 107, 0.12);
	color: #ef6b6b;
	border-color: rgba(239, 107, 107, 0.25);
}

.cs-profile-stats-badge--default {
	background: var(--cs-bg-pill);
	color: var(--cs-text-dim);
	border-color: var(--cs-border);
}

.cs-profile-stats-meters {
	display: flex;
	flex-direction: column;
	gap: 14px;
}

.cs-profile-stats-meter__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
	margin-bottom: 8px;
	font-size: 13px;
	color: var(--cs-text-dim);
}

.cs-profile-stats-meter__head strong {
	font-size: 13px;
	font-weight: 700;
	color: var(--cs-text);
}

.cs-profile-stats-meter__track {
	height: 8px;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid var(--cs-border);
	overflow: hidden;
}

.cs-profile-stats-meter__fill {
	height: 100%;
	border-radius: inherit;
	background: linear-gradient(90deg, var(--cs-accent), #7080ff);
	min-width: 0;
	transition: width 0.3s ease;
}

.cs-profile-stats-meter__fill[style*="width: 0%"],
.cs-profile-stats-meter__fill[style*="width:0%"] {
	width: 0 !important;
}

.cs-profile-stats-meter__fill--warn {
	background: linear-gradient(90deg, #e8b339, #f0c85a);
}

.cs-profile-stats-table-wrap {
	overflow-x: auto;
	border: 1px solid var(--cs-border);
	border-radius: var(--cs-radius-sm);
}

.cs-profile-stats-table {
	width: 100%;
	border-collapse: collapse;
	min-width: 560px;
}

.cs-profile-stats-table thead th {
	padding: 10px 12px;
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: var(--cs-text-dim);
	text-align: left;
	background: rgba(255, 255, 255, 0.02);
	border-bottom: 1px solid var(--cs-border);
	white-space: nowrap;
}

.cs-profile-stats-table tbody td {
	padding: 10px 12px;
	border-bottom: 1px solid rgba(255, 255, 255, 0.04);
	color: #b7bacd;
	font-size: 13px;
	vertical-align: middle;
}

.cs-profile-stats-table tbody tr:last-child td {
	border-bottom: none;
}

.cs-profile-stats-table tbody img {
	display: block;
	max-width: 110px;
	height: auto;
	border-radius: 4px;
}

@media (max-width: 1100px) {
	.cs-profile-stats-summary {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.cs-profile-stats-details {
		grid-template-columns: 1fr;
	}

	.cs-profile-stats-details .cs-profile-stats-group {
		border-right: none;
		border-bottom: 1px solid var(--cs-border);
	}

	.cs-profile-stats-details .cs-profile-stats-group:last-child {
		border-bottom: none;
	}

	.cs-profile-stats-group--meters .cs-profile-stats-meters {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 640px) {
	.cs-profile-stats-summary {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.cs-profile-stats-row {
		grid-template-columns: 1fr;
		gap: 4px;
	}

	.cs-profile-stats-row dd {
		text-align: left;
	}
}

.cs-profile-stats-section .r_block {
	margin: 0 !important;
	border: none !important;
	border-radius: 0 !important;
	background: transparent !important;
	box-shadow: none !important;
}

.cs-profile-stats-section .r_block_head {
	display: none;
}

.cs-profile-stats-section .r_block_c {
	padding: 0 18px 18px !important;
}

.cs-profile-wall-panel .cs-profile-panel__body {
	padding: 18px;
}

.cs-profile-wall {
	display: flex;
	flex-direction: column;
	gap: 20px;
}

.cs-profile-wall-compose {
	border-radius: var(--cs-radius-sm);
	border: 1px solid var(--cs-border);
	background: var(--cs-bg-card);
	overflow: hidden;
}

.cs-profile-wall-compose__editor {
	padding: 0;
	background: var(--cs-bg-card);
}

.cs-profile-wall-compose__editor > textarea.form-control {
	display: block;
	width: 100%;
	min-height: 96px;
	padding: 12px 14px;
	border: none;
	border-radius: 0;
	background: var(--cs-bg-card);
	color: var(--cs-text);
	resize: vertical;
	box-shadow: none;
}

.cs-profile-wall-compose__editor > textarea.form-control:focus {
	outline: none;
	box-shadow: none;
}

.cs-profile-wall-compose__editor .tox-tinymce ~ textarea,
.cs-profile-wall-compose.is-editor-ready > .cs-profile-wall-compose__editor > textarea {
	display: none !important;
}

.cs-profile-wall-compose__footer {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	padding: 10px 14px;
	border-top: 1px solid var(--cs-border);
	background: rgba(255, 255, 255, 0.02);
}

.cs-profile-wall-compose__actions {
	display: flex;
	align-items: center;
	gap: 10px;
}

.cs-profile-wall-send {
	min-width: 120px;
	padding: 9px 16px !important;
	font-weight: 600 !important;
	border-radius: var(--cs-radius-sm) !important;
	flex-shrink: 0;
}

.cs-profile-wall-smile {
	position: static !important;
	right: auto !important;
	top: auto !important;
	flex-shrink: 0;
	width: 24px !important;
	height: 24px !important;
	min-width: 24px;
	padding: 0 !important;
	border: none !important;
	border-radius: 0 !important;
	background: transparent url('../img/smile.svg') center / 22px 22px no-repeat !important;
	cursor: pointer;
	opacity: 0.7;
	transition: opacity 0.15s;
}

.cs-profile-wall-smile:hover {
	opacity: 1;
}

.cs-profile-wall-feed {
	display: flex;
	flex-direction: column;
	min-width: 0;
}

.cs-profile-wall-posts {
	display: flex;
	flex-direction: column;
	gap: 10px;
	min-width: 0;
}

.cs-profile-wall-posts:empty {
	min-height: 0;
}

.cs-profile-wall-loader {
	display: flex;
	justify-content: center;
	padding: 24px 0;
}

.cs-profile-wall-loader img {
	width: 28px;
	height: 28px;
	opacity: 0.65;
}

/* TinyMCE на стене */
.cs-profile-wall-panel .tox.tox-tinymce {
	border: none !important;
	border-radius: 0 !important;
	background: var(--cs-bg-card) !important;
	box-shadow: none !important;
}

.cs-profile-wall-panel .tox .tox-editor-container {
	min-height: 0 !important;
	background: var(--cs-bg-card) !important;
}

.cs-profile-wall-panel .tox .tox-editor-header {
	background: var(--cs-bg-card) !important;
	border-bottom: 1px solid var(--cs-border) !important;
	padding: 8px 10px !important;
}

.cs-profile-wall-panel .tox .tox-toolbar-overlord,
.cs-profile-wall-panel .tox .tox-toolbar,
.cs-profile-wall-panel .tox .tox-toolbar__overflow,
.cs-profile-wall-panel .tox .tox-toolbar__primary {
	background: transparent !important;
	border: none !important;
}

.cs-profile-wall-panel .tox .tox-tbtn {
	color: var(--cs-text-dim) !important;
	border-radius: 8px !important;
}

.cs-profile-wall-panel .tox .tox-tbtn svg {
	fill: currentColor !important;
}

.cs-profile-wall-panel .tox .tox-tbtn:hover,
.cs-profile-wall-panel .tox .tox-tbtn:focus {
	background: var(--cs-bg-hover) !important;
	color: var(--cs-text) !important;
}

.cs-profile-wall-panel .tox .tox-edit-area {
	border: none !important;
	background: var(--cs-bg-card) !important;
}

.cs-profile-wall-panel .tox .tox-edit-area__iframe {
	background: var(--cs-bg-card) !important;
}

.cs-profile-wall-panel .tox .tox-statusbar {
	display: flex !important;
	align-items: center;
	height: 22px !important;
	padding: 0 8px !important;
	background: var(--cs-bg-card) !important;
	border-top: 1px solid var(--cs-border) !important;
	color: var(--cs-text-dim) !important;
}

.cs-profile-wall-panel .tox .tox-statusbar__path-item,
.cs-profile-wall-panel .tox .tox-statusbar__wordcount,
.cs-profile-wall-panel .tox .tox-statusbar a {
	color: var(--cs-text-dim) !important;
}

.cs-profile-wall-panel .tox .tox-statusbar__resize-handle svg {
	fill: var(--cs-text-dim) !important;
}

.cs-profile-wall-panel .tox .tox-sidebar-wrap {
	min-height: 120px !important;
	background: var(--cs-bg-card) !important;
}

.cs-profile-wall-panel .tox .tox-edit-area iframe {
	min-height: 120px !important;
}

.cs-profile-wall-post__content .g_sticker {
	display: block;
	max-width: min(180px, 100%);
	height: auto;
	margin-top: 4px;
}

/* Записи на стене */
.cs-profile-wall-post {
	display: flex;
	align-items: flex-start;
	gap: 12px;
	padding: 14px 16px;
	border: 1px solid var(--cs-border);
	border-radius: var(--cs-radius-sm);
	background: var(--cs-bg-card);
}

.cs-profile-wall-post__avatar {
	flex-shrink: 0;
	display: block;
	line-height: 0;
}

.cs-profile-wall-post__avatar img {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	object-fit: cover;
	border: 2px solid rgba(255, 255, 255, 0.06);
}

.cs-profile-wall-post__main {
	flex: 1;
	min-width: 0;
}

.cs-profile-wall-post__meta {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 12px;
	margin-bottom: 8px;
}

.cs-profile-wall-post__meta-main {
	display: flex;
	flex-wrap: wrap;
	align-items: baseline;
	gap: 6px 10px;
	min-width: 0;
}

.cs-profile-wall-post__author {
	padding: 0;
	border: none;
	background: none;
	font: inherit;
	font-size: 14px;
	font-weight: 700;
	line-height: 1.3;
	cursor: pointer;
	transition: opacity 0.15s;
}

.cs-profile-wall-post__author:hover {
	opacity: 0.85;
}

.cs-profile-wall-post__date {
	font-size: 12px;
	color: var(--cs-text-dim);
	line-height: 1.3;
	white-space: nowrap;
}

.cs-profile-wall-post__actions {
	flex-shrink: 0;
	display: flex;
	align-items: center;
	gap: 6px;
}

.cs-profile-wall-post__actions .dell_message,
.cs-profile-wall-post__actions .edit_message {
	position: static;
	float: none;
	font-size: 12px;
	opacity: 0.45;
	cursor: pointer;
	transition: opacity 0.15s, color 0.15s;
}

.cs-profile-wall-post:hover .dell_message,
.cs-profile-wall-post:hover .edit_message {
	opacity: 0.75;
}

.cs-profile-wall-post__actions .dell_message:hover,
.cs-profile-wall-post__actions .edit_message:hover {
	opacity: 1 !important;
	color: var(--cs-text) !important;
}

.cs-profile-wall-post__content {
	font-size: 14px;
	line-height: 1.55;
	color: var(--cs-text);
	word-break: break-word;
}

.cs-profile-wall-post__content p {
	margin: 0 0 8px;
}

.cs-profile-wall-post__content p:last-child {
	margin-bottom: 0;
}

.cs-profile-wall-post__content img {
	max-width: 100%;
	height: auto;
	border-radius: var(--cs-radius-sm);
}

.cs-profile-wall-post__content .thumbnail {
	max-width: min(240px, 100%);
	padding: 0;
	margin: 8px 0 0;
	border: none;
	border-radius: var(--cs-radius-sm);
}

.cs-profile-wall-panel .clearfix {
	display: none !important;
}

/* Legacy chat_message внутри стены — если кэш ещё не обновился */
.cs-profile-wall-panel .chat_message {
	display: flex !important;
	align-items: flex-start !important;
	gap: 12px !important;
	float: none !important;
	position: relative !important;
	overflow: visible !important;
	margin: 0 0 10px !important;
	padding: 14px 16px !important;
	border: 1px solid var(--cs-border) !important;
	border-bottom: 1px solid var(--cs-border) !important;
	border-radius: var(--cs-radius-sm) !important;
	background: var(--cs-bg-card) !important;
}

.cs-profile-wall-panel .chat_message .user_img {
	float: none !important;
	width: 40px !important;
	height: 40px !important;
	margin: 0 !important;
	padding: 0 !important;
	border-radius: 50% !important;
	background: transparent !important;
	object-fit: cover;
}

.cs-profile-wall-panel .chat_message .message {
	float: none !important;
	margin-left: 0 !important;
	flex: 1;
	min-width: 0;
}

.cs-profile-wall-panel .chat_message hr {
	display: none !important;
}

.cs-profile-friends-panel {
	overflow: visible;
}

.cs-profile-friends-panel .cs-profile-panel__body {
	overflow: visible;
	max-height: none;
}

.cs-profile-friends-sections {
	display: flex;
	flex-direction: column;
	gap: 22px;
	overflow: visible;
	max-height: none;
	padding-right: 0;
}

.cs-profile-friends-sections#companions {
	max-height: none;
	overflow: visible;
	overflow-y: visible;
	padding-right: 0;
}

.cs-profile-friends-section__title {
	margin: 0 0 10px;
	font-size: 12px;
	font-weight: 600;
	color: var(--cs-text-dim);
	text-transform: none;
}

.cs-profile-friends-list {
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.cs-profile-friends-grid {
	display: grid;
	grid-template-columns: repeat(6, minmax(0, 1fr));
	gap: 6px;
}

.cs-profile-friend-card {
	display: flex;
	align-items: flex-start;
	gap: 8px;
	padding: 8px 10px;
	border-radius: 8px;
	border: 1px solid rgba(255, 255, 255, 0.06);
	background: rgba(255, 255, 255, 0.03);
	text-decoration: none;
	transition: background 0.15s, border-color 0.15s;
	min-width: 0;
}

.cs-profile-friend-card:hover {
	background: rgba(255, 255, 255, 0.06);
	border-color: rgba(255, 255, 255, 0.1);
}

.cs-profile-friends-list .cs-profile-friend-card {
	align-items: center;
	padding: 10px 12px;
}

.cs-profile-friend-card--ingame,
.cs-profile-friend-card--onsite {
	background: rgba(255, 255, 255, 0.04);
}

.cs-profile-friends-list .cs-profile-friend-card--ingame {
	border-color: rgba(69, 212, 131, 0.15);
}

.cs-profile-friends-list .cs-profile-friend-card--onsite {
	border-color: rgba(92, 157, 255, 0.15);
}

.cs-profile-friends-grid .cs-profile-friend-card {
	padding: 6px 8px;
	align-items: center;
}

.cs-profile-friend-card__avatar {
	position: relative;
	flex-shrink: 0;
	width: 36px;
	height: 36px;
}

.cs-profile-friends-list .cs-profile-friend-card__avatar {
	width: 40px;
	height: 40px;
}

.cs-profile-friends-grid .cs-profile-friend-card__avatar {
	width: 32px;
	height: 32px;
}

.cs-profile-friend-card__avatar img {
	display: block;
	width: 100%;
	height: 100%;
	border-radius: 50%;
	object-fit: cover;
}

.cs-profile-friend-card__dot {
	position: absolute;
	right: 0;
	bottom: 0;
	width: 9px;
	height: 9px;
	border-radius: 50%;
	background: #6b7280;
	border: 2px solid var(--cs-bg-card);
	z-index: 1;
}

.cs-profile-friend-card__dot--ingame {
	background: #45d483;
	box-shadow: 0 0 6px rgba(69, 212, 131, 0.45);
}

.cs-profile-friend-card__dot--onsite {
	background: #5c9dff;
	box-shadow: 0 0 6px rgba(92, 157, 255, 0.45);
}

.cs-profile-friend-card__dot--offline {
	display: none;
}

.cs-profile-friend-card__info {
	min-width: 0;
	flex: 1;
}

.cs-profile-friend-card__name {
	font-size: 12px;
	font-weight: 700;
	line-height: 1.25;
	color: var(--cs-text);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.cs-profile-friends-list .cs-profile-friend-card__name {
	font-size: 14px;
	white-space: normal;
}

.cs-profile-friends-grid .cs-profile-friend-card__name {
	white-space: nowrap;
	display: block;
	overflow: hidden;
	text-overflow: ellipsis;
	font-size: 11px;
	line-height: 1.2;
}

.cs-profile-friend-card__status {
	margin-top: 2px;
	font-size: 11px;
	line-height: 1.2;
	color: var(--cs-text-dim);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.cs-profile-friends-grid .cs-profile-friend-card__status {
	margin-top: 1px;
	font-size: 10px;
	line-height: 1.2;
}

.cs-profile-friends-list .cs-profile-friend-card__status {
	font-size: 12px;
	-webkit-line-clamp: 1;
}

.cs-profile-friend-card__status--ingame {
	color: #45d483;
	font-weight: 600;
}

.cs-profile-friend-card__status--onsite {
	color: #7eb6ff;
	font-weight: 600;
}

.cs-profile-friend-card__status--offline {
	color: rgba(255, 255, 255, 0.45);
	font-weight: 400;
}

.cs-profile-friends-sections .empty-element {
	display: block;
	padding: 28px 16px;
	text-align: center;
	font-size: 14px;
	color: var(--cs-text-dim);
}

/* Profile privileges tab */
.cs-profile-privileges-panel .cs-profile-panel__body {
	padding: 18px;
}

.cs-profile-privileges-list {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
	gap: 12px;
}

.cs-profile-privileges-empty {
	padding: 28px 18px;
	border-radius: var(--cs-radius-sm);
	border: 1px dashed rgba(255, 255, 255, 0.08);
	color: var(--cs-text-dim);
	font-size: 13px;
	text-align: center;
}

.cs-profile-privilege-card {
	display: flex;
	flex-direction: column;
	gap: 14px;
	padding: 16px;
	border-radius: var(--cs-radius-sm);
	border: 1px solid var(--cs-border);
	background: var(--cs-bg-pill);
	transition: border-color 0.15s, background 0.15s;
}

.cs-profile-privilege-card:hover {
	border-color: rgba(92, 108, 255, 0.28);
	background: rgba(255, 255, 255, 0.03);
}

.cs-profile-privilege-card.is-suspended {
	border-color: rgba(255, 92, 92, 0.25);
}

.cs-profile-privilege-card__top {
	display: flex;
	align-items: center;
	gap: 10px;
	min-width: 0;
}

.cs-profile-privilege-card__num {
	flex-shrink: 0;
	width: 28px;
	height: 28px;
	border-radius: 8px;
	display: grid;
	place-items: center;
	font-size: 12px;
	font-weight: 700;
	color: var(--cs-accent);
	background: rgba(92, 108, 255, 0.12);
}

.cs-profile-privilege-card__server {
	margin: 0;
	font-size: 14px;
	font-weight: 700;
	line-height: 1.3;
	color: var(--cs-text);
	word-break: break-word;
}

.cs-profile-privilege-card__body {
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.cs-profile-privilege-card__field {
	display: grid;
	grid-template-columns: minmax(90px, 34%) 1fr;
	gap: 10px;
	align-items: start;
	padding-top: 10px;
	border-top: 1px solid rgba(255, 255, 255, 0.04);
}

.cs-profile-privilege-card__field:first-child {
	padding-top: 0;
	border-top: none;
}

.cs-profile-privilege-card__label {
	font-size: 12px;
	color: var(--cs-text-dim);
	line-height: 1.4;
}

.cs-profile-privilege-card__value {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	font-size: 13px;
	color: var(--cs-text);
	line-height: 1.45;
	word-break: break-word;
}

.cs-profile-privilege-card__value--mono {
	font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
	font-size: 12px;
}

.cs-profile-privilege-card__service {
	display: inline-flex;
	align-items: center;
	padding: 4px 10px;
	border-radius: 999px;
	background: rgba(92, 108, 255, 0.12);
	border: 1px solid rgba(92, 108, 255, 0.22);
	color: #aeb8ff;
	font-size: 12px;
	font-weight: 600;
}

.cs-profile-privilege-card__more {
	padding: 0;
	border: none;
	background: none;
	color: var(--cs-accent);
	font-size: 12px;
	font-weight: 600;
	cursor: pointer;
	transition: color 0.15s;
}

.cs-profile-privilege-card__more:hover {
	color: var(--cs-accent-hover);
}

.cs-profile-privilege-card__warn {
	padding: 2px 8px;
	border-radius: 999px;
	border: 1px solid rgba(255, 92, 92, 0.35);
	background: rgba(255, 92, 92, 0.1);
	color: #ff8a8a;
	font-size: 11px;
	font-weight: 600;
	cursor: pointer;
}

.cs-profile-privilege-modal .modal-dialog {
	margin: 48px auto;
}

.cs-profile-privilege-modal__content {
	overflow: hidden;
	border-radius: var(--cs-radius);
	border: 1px solid var(--cs-border);
	background: var(--cs-bg-card);
	color: var(--cs-text);
	box-shadow: 0 24px 64px rgba(0, 0, 0, 0.55);
}

.cs-profile-privilege-modal__content::before {
	content: "";
	display: block;
	height: 3px;
	background: linear-gradient(90deg, var(--cs-accent), rgba(92, 108, 255, 0.25));
}

.cs-profile-privilege-modal__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	padding: 14px 16px;
	border-bottom: 1px solid var(--cs-border);
}

.cs-profile-privilege-modal__heading {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px 10px;
	min-width: 0;
}

.cs-profile-privilege-modal__eyebrow {
	font-size: 13px;
	font-weight: 600;
	color: var(--cs-text-dim);
}

.cs-profile-privilege-modal__server {
	display: inline-flex;
	align-items: center;
	max-width: 100%;
	padding: 4px 10px;
	border-radius: 999px;
	background: rgba(92, 108, 255, 0.1);
	border: 1px solid rgba(92, 108, 255, 0.2);
	color: #aeb8ff;
	font-size: 12px;
	font-weight: 600;
	line-height: 1.2;
	word-break: break-word;
}

.cs-profile-privilege-modal__close {
	flex-shrink: 0;
	width: 34px;
	height: 34px;
	padding: 0;
	border: 1px solid var(--cs-border);
	border-radius: var(--cs-radius-sm);
	background: var(--cs-bg-pill);
	color: var(--cs-text-dim);
	font-size: 22px;
	line-height: 1;
	cursor: pointer;
	transition: background 0.15s, color 0.15s, border-color 0.15s;
}

.cs-profile-privilege-modal__close:hover {
	background: var(--cs-bg-hover);
	border-color: rgba(255, 255, 255, 0.1);
	color: var(--cs-text);
}

.cs-profile-privilege-modal__body {
	padding: 18px 20px;
}

.cs-profile-privilege-modal__table-card {
	border-radius: var(--cs-radius-sm);
	border: 1px solid rgba(255, 255, 255, 0.05);
	background: var(--cs-bg-pill);
	overflow: hidden;
}

.cs-profile-privilege-modal__table-wrap {
	overflow-x: auto;
}

.cs-profile-privilege-modal__table {
	width: 100%;
	border-collapse: collapse;
	font-size: 13px;
}

.cs-profile-privilege-modal__table th,
.cs-profile-privilege-modal__table td {
	padding: 12px 14px;
	border-bottom: 1px solid rgba(255, 255, 255, 0.05);
	text-align: left;
	vertical-align: middle;
}

.cs-profile-privilege-modal__table th {
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--cs-text-dim);
	background: rgba(255, 255, 255, 0.02);
	white-space: nowrap;
}

.cs-profile-privilege-modal__table tbody tr:last-child td {
	border-bottom: none;
}

.cs-profile-privilege-modal__row {
	transition: background 0.15s;
}

.cs-profile-privilege-modal__row:hover {
	background: rgba(255, 255, 255, 0.025);
}

.cs-profile-privilege-modal__index span {
	display: inline-grid;
	place-items: center;
	min-width: 26px;
	height: 26px;
	padding: 0 6px;
	border-radius: 8px;
	background: rgba(92, 108, 255, 0.12);
	color: var(--cs-accent);
	font-size: 12px;
	font-weight: 700;
}

.cs-profile-privilege-modal__badge {
	display: inline-flex;
	align-items: center;
	padding: 5px 11px;
	border-radius: 999px;
	background: rgba(92, 108, 255, 0.12);
	border: 1px solid rgba(92, 108, 255, 0.22);
	color: #aeb8ff;
	font-size: 12px;
	font-weight: 600;
	line-height: 1.2;
}

.cs-profile-privilege-modal__date {
	color: var(--cs-text-dim);
	font-size: 12px;
	line-height: 1.45;
	white-space: nowrap;
}

.cs-profile-privilege-modal__status {
	display: inline-flex;
	align-items: center;
	padding: 4px 10px;
	border-radius: 999px;
	font-size: 12px;
	font-weight: 600;
	line-height: 1.2;
	white-space: nowrap;
}

.cs-profile-privilege-modal__status--success {
	background: rgba(61, 214, 140, 0.12);
	border: 1px solid rgba(61, 214, 140, 0.24);
	color: var(--cs-green);
}

.cs-profile-privilege-modal__status--warning {
	background: rgba(240, 180, 41, 0.12);
	border: 1px solid rgba(240, 180, 41, 0.24);
	color: var(--cs-gold);
}

.cs-profile-privilege-modal__status--danger {
	background: rgba(255, 123, 123, 0.12);
	border: 1px solid rgba(255, 123, 123, 0.24);
	color: #ff8a8a;
}

.cs-profile-privilege-modal__footer {
	display: flex;
	justify-content: flex-end;
	padding: 14px 20px 18px;
	border-top: 1px solid var(--cs-border);
}

.cs-profile-privilege-modal .text-success {
	color: var(--cs-green) !important;
}

.cs-profile-privilege-modal .text-warning {
	color: var(--cs-gold) !important;
}

.cs-profile-privilege-modal .text-danger {
	color: #ff8a8a !important;
}

@media (max-width: 720px) {
	.cs-profile-privilege-modal .modal-dialog {
		margin: 24px 12px;
		width: auto;
	}

	.cs-profile-privilege-modal__header,
	.cs-profile-privilege-modal__body,
	.cs-profile-privilege-modal__footer {
		padding-left: 14px;
		padding-right: 14px;
	}

	.cs-profile-privilege-modal__date {
		white-space: normal;
	}
}

/* My stores page */
.cs-my-stores__body {
	padding: 0 !important;
}

.cs-my-stores__table-wrap {
	border-radius: 0 0 var(--cs-radius-sm) var(--cs-radius-sm);
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
}

.cs-my-stores__table {
	margin-bottom: 0 !important;
}

.cs-my-stores__index span {
	display: inline-grid;
	place-items: center;
	min-width: 26px;
	height: 26px;
	padding: 0 6px;
	border-radius: 8px;
	background: rgba(92, 108, 255, 0.12);
	color: var(--cs-accent);
	font-size: 12px;
	font-weight: 700;
}

.cs-my-stores__identifier {
	font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
	font-size: 12px;
	color: var(--cs-text);
	word-break: break-all;
}

.cs-my-stores__server {
	font-weight: 600;
	color: var(--cs-text);
}

.cs-my-stores__actions {
	text-align: right;
	white-space: nowrap;
}

.cs-my-stores__status {
	display: inline-flex;
	align-items: center;
	padding: 4px 10px;
	border-radius: 999px;
	font-size: 12px;
	font-weight: 600;
	line-height: 1.2;
	border: none;
	background: none;
}

.cs-my-stores__status--success {
	background: rgba(61, 214, 140, 0.12);
	border: 1px solid rgba(61, 214, 140, 0.24);
	color: var(--cs-green);
}

.cs-my-stores__status--warning {
	background: rgba(240, 180, 41, 0.12);
	border: 1px solid rgba(240, 180, 41, 0.24);
	color: var(--cs-gold);
}

.cs-my-stores__status--danger {
	background: rgba(255, 123, 123, 0.12);
	border: 1px solid rgba(255, 123, 123, 0.24);
	color: #ff8a8a;
	cursor: pointer;
}

.cs-my-stores__settings-btn {
	padding: 7px 14px;
	border-radius: var(--cs-radius-sm);
	border: 1px solid rgba(92, 108, 255, 0.28);
	background: rgba(92, 108, 255, 0.1);
	color: #aeb8ff;
	font-family: inherit;
	font-size: 12px;
	font-weight: 600;
	cursor: pointer;
	transition: background 0.15s, border-color 0.15s, color 0.15s;
}

.cs-my-stores__settings-btn:hover {
	border-color: rgba(92, 108, 255, 0.45);
	background: rgba(92, 108, 255, 0.16);
	color: #c8d0ff;
}

@media (max-width: 768px) {
	.cs-my-stores__body {
		padding: 12px !important;
	}

	.cs-my-stores__table-wrap {
		overflow: visible;
		padding: 0;
	}

	.cs-my-stores__table,
	.cs-my-stores__table tbody,
	.cs-my-stores__table tr,
	.cs-my-stores__table td {
		display: block;
		width: 100%;
	}

	.cs-my-stores__table {
		border: none !important;
	}

	.cs-my-stores__table thead {
		display: none;
	}

	.cs-my-stores__table tbody {
		display: flex;
		flex-direction: column;
		gap: 12px;
	}

	.cs-my-stores__table tbody tr.hidden-tr {
		display: none !important;
	}

	.cs-my-stores__table tbody tr:not(.hidden-tr) {
		padding: 14px;
		border: 1px solid var(--cs-border) !important;
		border-radius: var(--cs-radius-sm);
		background: var(--cs-bg-pill);
		-webkit-tap-highlight-color: transparent;
		-webkit-touch-callout: none;
		user-select: none;
		-webkit-user-select: none;
		touch-action: manipulation;
	}

	.cs-my-stores__table tbody tr:not(.hidden-tr):active {
		background: var(--cs-bg-pill);
	}

	.cs-my-stores__table tbody tr:not(.hidden-tr) td {
		border: none !important;
		padding: 0 !important;
	}

	.cs-my-stores__table tbody tr:not(.hidden-tr) td + td {
		margin-top: 10px;
	}

	.cs-my-stores__table tbody tr:not(.hidden-tr) td::before {
		display: block;
		margin-bottom: 4px;
		font-size: 11px;
		font-weight: 700;
		letter-spacing: 0.06em;
		text-transform: uppercase;
		color: var(--cs-text-dim);
	}

	.cs-my-stores__table tbody tr:not(.hidden-tr) td:nth-child(1)::before { content: '#'; }
	.cs-my-stores__table tbody tr:not(.hidden-tr) td:nth-child(2)::before { content: 'Идентификатор'; }
	.cs-my-stores__table tbody tr:not(.hidden-tr) td:nth-child(3)::before { content: 'Активность'; }
	.cs-my-stores__table tbody tr:not(.hidden-tr) td:nth-child(4)::before { content: 'Сервер'; }
	.cs-my-stores__table tbody tr:not(.hidden-tr) td:nth-child(5)::before { content: 'Параметры'; }

	.cs-my-stores__index span {
		min-width: 32px;
		height: 32px;
	}

	.cs-my-stores__actions {
		text-align: left;
	}

	.cs-my-stores__settings-btn {
		width: 100%;
		justify-content: center;
		display: inline-flex;
		-webkit-tap-highlight-color: transparent;
		touch-action: manipulation;
	}
}

@media (hover: none) {
	.r_block_c .table tbody tr:hover td,
	.cs-my-stores__table tbody tr:not(.hidden-tr):hover td {
		background: transparent !important;
	}

	.cs-my-stores__table tbody tr:not(.hidden-tr):hover {
		background: var(--cs-bg-pill) !important;
	}
}

/* Store settings modal */
.cs-store-settings-modal .modal-dialog {
	margin: 48px auto;
}

.cs-store-settings-modal__dialog--wide {
	width: min(1120px, calc(100vw - 32px));
	max-width: none;
}

.cs-store-settings-modal__content {
	overflow: hidden;
	border-radius: var(--cs-radius);
	border: 1px solid var(--cs-border);
	background: var(--cs-bg-card);
	color: var(--cs-text);
	box-shadow: 0 24px 64px rgba(0, 0, 0, 0.55);
}

.cs-store-settings-modal__content::before {
	content: "";
	display: block;
	height: 3px;
	background: linear-gradient(90deg, var(--cs-accent), rgba(92, 108, 255, 0.25));
}

.cs-store-settings-modal__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	padding: 14px 16px;
	border-bottom: 1px solid var(--cs-border);
}

.cs-store-settings-modal__heading {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px 10px;
	min-width: 0;
}

.cs-store-settings-modal__eyebrow {
	font-size: 13px;
	font-weight: 600;
	color: var(--cs-text-dim);
}

.cs-store-settings-modal__server {
	display: inline-flex;
	align-items: center;
	max-width: 100%;
	padding: 4px 10px;
	border-radius: 999px;
	background: rgba(92, 108, 255, 0.1);
	border: 1px solid rgba(92, 108, 255, 0.2);
	color: #aeb8ff;
	font-size: 12px;
	font-weight: 600;
	line-height: 1.2;
	word-break: break-word;
}

.cs-store-settings-modal__close {
	flex-shrink: 0;
	width: 34px;
	height: 34px;
	padding: 0;
	border: 1px solid var(--cs-border);
	border-radius: var(--cs-radius-sm);
	background: var(--cs-bg-pill);
	color: var(--cs-text-dim);
	font-size: 22px;
	line-height: 1;
	cursor: pointer;
	transition: background 0.15s, color 0.15s, border-color 0.15s;
}

.cs-store-settings-modal__close:hover {
	background: var(--cs-bg-hover);
	border-color: rgba(255, 255, 255, 0.1);
	color: var(--cs-text);
}

.cs-store-settings-modal__body {
	padding: 18px 20px;
}

.cs-store-settings-modal__footer {
	display: flex;
	justify-content: flex-end;
	padding: 14px 20px 18px;
	border-top: 1px solid var(--cs-border);
}

.cs-store-settings {
	display: flex;
	flex-direction: column;
	gap: 18px;
}

.cs-store-settings__section {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.cs-store-settings__section-title {
	margin: 0;
	font-size: 14px;
	font-weight: 700;
	color: var(--cs-text);
}

.cs-store-settings__grid {
	display: flex;
	flex-direction: column;
	border-radius: var(--cs-radius-sm);
	border: 1px solid rgba(255, 255, 255, 0.05);
	background: var(--cs-bg-pill);
	overflow: hidden;
}

.cs-store-settings__field {
	display: grid;
	grid-template-columns: minmax(110px, 34%) 1fr;
	gap: 12px;
	align-items: center;
	padding: 14px 16px;
	border-top: 1px solid rgba(255, 255, 255, 0.05);
}

.cs-store-settings__field:first-child {
	border-top: none;
}

.cs-store-settings__label {
	font-size: 12px;
	color: var(--cs-text-dim);
	line-height: 1.4;
}

.cs-store-settings__value {
	min-width: 0;
}

.cs-store-settings__control {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	align-items: stretch;
	width: 100%;
}

.cs-store-settings__control .cs-btn {
	flex-shrink: 0;
}

.cs-store-settings__select,
.cs-store-settings__input {
	flex: 1 1 180px;
	min-width: 0;
	height: 36px;
	padding: 8px 12px;
	border-radius: var(--cs-radius-sm);
	border: 1px solid var(--cs-border);
	background: var(--cs-bg-card);
	color: var(--cs-text) !important;
	font-size: 13px;
}

.cs-store-settings__select:focus,
.cs-store-settings__input:focus {
	border-color: rgba(92, 108, 255, 0.45);
	box-shadow: 0 0 0 2px rgba(92, 108, 255, 0.12);
	outline: none;
}

.cs-store-settings__services-table.admins_services td {
	display: table-cell !important;
	vertical-align: middle !important;
	white-space: normal !important;
}

.cs-store-settings__services-table.admins_services td p {
	float: none !important;
	display: block;
	width: auto;
	margin: 0;
}

.cs-store-settings__services-table.admins_services td .btn,
.cs-store-settings__services-table.admins_services td .cs-btn {
	float: none !important;
}

.cs-store-settings__services-table .cs-store-service-row:hover {
	background: rgba(255, 255, 255, 0.025);
}

.cs-store-service-row__name,
.cs-store-service-row__ending,
.cs-store-service-row__left {
	vertical-align: middle !important;
}

.cs-store-service-row__cell {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 8px;
}

.cs-store-service-row__date {
	margin: 0;
	font-size: 12px;
	color: var(--cs-text-dim);
	line-height: 1.45;
}

.cs-store-service-row__extend-form {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	align-items: stretch;
	width: 100%;
}

.cs-store-service-row__tarif {
	flex: 1 1 160px;
	min-width: 0;
	height: 34px;
}

@media (max-width: 720px) {
	.cs-store-settings-modal .modal-dialog {
		margin: 24px 12px;
		width: auto;
	}

	.cs-store-settings-modal__header,
	.cs-store-settings-modal__body,
	.cs-store-settings-modal__footer {
		padding-left: 14px;
		padding-right: 14px;
	}

	.cs-store-settings__field {
		grid-template-columns: 1fr;
		gap: 8px;
		align-items: start;
	}

	.cs-my-stores__actions {
		text-align: left;
	}
}

@media (max-width: 640px) {
	.cs-profile-privileges-list {
		grid-template-columns: 1fr;
	}

	.cs-profile-privilege-card__field {
		grid-template-columns: 1fr;
		gap: 4px;
	}
}

@media (max-width: 1600px) {
	.cs-profile-friends-grid {
		grid-template-columns: repeat(5, minmax(0, 1fr));
	}
}

@media (max-width: 1200px) {
	.cs-profile-friends-grid {
		grid-template-columns: repeat(4, minmax(0, 1fr));
	}
}

@media (max-width: 900px) {
	.cs-profile-cover .cs-profile-cover__bottom {
		flex-direction: column;
		align-items: flex-start;
		padding-top: 14px;
	}

	.cs-profile-cover__toolbar {
		align-items: flex-start;
		width: 100%;
	}

	.cs-profile-cover .cs-profile-cover__profile {
		flex-direction: column;
		align-items: flex-start;
		flex-basis: auto;
		width: 100%;
	}

	.cs-profile-cover__headline {
		padding-bottom: 0;
	}

	.cs-profile-actions {
		justify-content: flex-start;
	}

	.cs-profile-name {
		font-size: 24px;
	}

	.cs-profile-friends-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.cs-profile-cover__bottom {
		padding: 16px 14px 14px;
	}

	.cs-profile-tabs__list {
		flex-wrap: nowrap;
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
		scrollbar-width: none;
		gap: 2px;
		padding-bottom: 4px;
	}

	.cs-profile-tabs__list::-webkit-scrollbar {
		display: none;
	}

	.cs-profile-tabs__item {
		flex-shrink: 0;
		font-size: 11px;
		padding: 10px 12px;
		letter-spacing: 0.04em;
	}
}

/* Settings page (CyberShoke-style) */
.cs-settings-page {
	margin-bottom: 24px;
}

.cs-settings-header {
	margin-bottom: 16px;
}

.cs-settings-header__title {
	margin: 0;
	font-size: 22px;
	font-weight: 700;
	color: var(--cs-text);
}

.cs-settings-layout {
	display: grid;
	grid-template-columns: 220px minmax(0, 1fr);
	border: 1px solid var(--cs-border);
	border-radius: var(--cs-radius);
	background: var(--cs-bg-card);
	overflow: hidden;
}

.cs-settings-nav {
	display: flex;
	flex-direction: column;
	padding: 10px 0;
	border-right: 1px solid var(--cs-border);
	background: rgba(0, 0, 0, 0.18);
}

.cs-settings-nav__item {
	display: block;
	width: 100%;
	padding: 11px 20px;
	border: none;
	background: none;
	text-align: left;
	font-size: 14px;
	font-weight: 500;
	color: var(--cs-text-dim);
	cursor: pointer;
	transition: color 0.15s, background 0.15s;
}

.cs-settings-nav__item:hover {
	color: var(--cs-text);
	background: rgba(255, 255, 255, 0.03);
}

.cs-settings-nav__item.is-active {
	color: var(--cs-text);
	font-weight: 600;
	background: rgba(92, 108, 255, 0.14);
	box-shadow: inset 0 -2px 0 var(--cs-accent);
}

.cs-settings-panels {
	min-width: 0;
}

.cs-settings-panel {
	display: none;
}

.cs-settings-panel.is-active {
	display: block;
}

.cs-settings-row {
	display: grid;
	grid-template-columns: minmax(160px, 26%) minmax(0, 1fr) auto;
	gap: 12px 20px;
	align-items: start;
	padding: 18px 22px;
	border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.cs-settings-row:last-child {
	border-bottom: none;
}

.cs-settings-row__title {
	font-size: 14px;
	font-weight: 600;
	line-height: 1.35;
	color: var(--cs-text);
}

.cs-settings-row__hint {
	margin-top: 4px;
	font-size: 12px;
	line-height: 1.45;
	color: var(--cs-text-dim);
}

.cs-settings-row__hint u {
	text-decoration: underline;
	color: rgba(255, 255, 255, 0.55);
}

.cs-settings-row__field--stack {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.cs-settings-row__action {
	padding-top: 8px;
	text-align: right;
}

.cs-settings-input,
.cs-settings-select,
.cs-settings-textarea {
	width: 100%;
	max-width: 100%;
	padding: 10px 14px;
	border-radius: 8px;
	border: 1px solid var(--cs-border);
	background: rgba(0, 0, 0, 0.22);
	color: var(--cs-text);
	font-size: 14px;
	line-height: 1.35;
	transition: border-color 0.15s;
}

.cs-settings-input:focus,
.cs-settings-select:focus,
.cs-settings-textarea:focus {
	outline: none;
	border-color: var(--cs-accent);
}

.cs-settings-textarea {
	min-height: 120px;
	resize: vertical;
}

.cs-settings-birth {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.cs-settings-birth .cs-settings-select {
	width: auto;
	min-width: 72px;
	flex: 1;
}

.cs-settings-link {
	padding: 0;
	border: none;
	background: none;
	color: var(--cs-accent);
	font-size: 13px;
	font-weight: 600;
	cursor: pointer;
	white-space: nowrap;
}

.cs-settings-link:hover {
	color: var(--cs-accent-hover);
	text-decoration: underline;
}

.cs-settings-link--block {
	display: inline-block;
	margin-top: 8px;
}

.cs-settings-result {
	margin-top: 6px;
	font-size: 12px;
	line-height: 1.4;
}

.cs-settings-note {
	margin: 0;
	font-size: 13px;
	line-height: 1.45;
	color: var(--cs-text-dim);
}

.cs-settings-avatar {
	display: flex;
	align-items: center;
	gap: 14px;
	flex-wrap: wrap;
}

.cs-settings-avatar__img {
	width: 72px;
	height: 72px;
	border-radius: 10px;
	object-fit: cover;
	border: 1px solid var(--cs-border);
}

.cs-settings-avatar__upload {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 8px;
}

.cs-settings-banner {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.cs-settings-banner__preview {
	width: 100%;
	max-width: 420px;
	aspect-ratio: 4 / 1;
	height: auto;
	border-radius: var(--cs-radius-sm);
	border: 1px solid var(--cs-border);
	background:
		radial-gradient(120% 120% at 85% 15%, rgba(124, 92, 255, 0.22), transparent 55%),
		linear-gradient(135deg, #171b28 0%, #10131b 48%, #1a1428 100%);
	background-size: cover;
	background-position: center;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
}

.cs-settings-banner__preview--custom {
	background: #10131b;
}

.cs-settings-banner__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	display: block;
}

.cs-settings-banner__actions {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 10px 14px;
}

.cs-banner-crop-modal {
	z-index: 1060;
}

.cs-banner-crop-modal .modal-body {
	padding: 16px 20px 12px;
}

.cs-banner-crop-modal__footer {
	display: flex;
	justify-content: flex-end;
	gap: 10px;
}

.cs-banner-crop {
	position: relative;
	width: 100%;
	aspect-ratio: 4 / 1;
	background: #0a0c12;
	overflow: hidden;
	cursor: grab;
	touch-action: none;
	user-select: none;
	-webkit-user-drag: none;
}

.cs-banner-crop.is-dragging {
	cursor: grabbing;
}

.cs-banner-crop__img {
	position: absolute;
	top: 0;
	left: 0;
	max-width: none;
	pointer-events: none;
	will-change: transform;
}

.cs-banner-crop__frame {
	position: absolute;
	inset: 0;
	border: 2px solid rgba(91, 156, 255, 0.95);
	box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.12);
	pointer-events: none;
}

.cs-banner-crop__grid {
	position: absolute;
	inset: 0;
	background-image:
		linear-gradient(to right, rgba(255, 255, 255, 0.28) 1px, transparent 1px),
		linear-gradient(to bottom, rgba(255, 255, 255, 0.28) 1px, transparent 1px);
	background-size: 33.333% 100%, 100% 33.333%;
	opacity: 0.55;
}

.cs-banner-crop__crosshair {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 18px;
	height: 18px;
	margin: -9px 0 0 -9px;
}

.cs-banner-crop__crosshair::before,
.cs-banner-crop__crosshair::after {
	content: '';
	position: absolute;
	background: rgba(255, 255, 255, 0.75);
}

.cs-banner-crop__crosshair::before {
	top: 50%;
	left: 0;
	width: 100%;
	height: 1px;
	margin-top: -0.5px;
}

.cs-banner-crop__crosshair::after {
	left: 50%;
	top: 0;
	width: 1px;
	height: 100%;
	margin-left: -0.5px;
}

.cs-banner-crop__hint {
	margin: 12px 0 0;
	font-size: 12px;
	color: var(--cs-text-dim);
	text-align: center;
}

.cs-profile-theme-picker {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(92px, 1fr));
	gap: 14px 12px;
	max-width: 420px;
}

.cs-profile-theme-picker__item {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
	padding: 0;
	border: none;
	background: none;
	cursor: pointer;
	color: var(--cs-text-dim);
	transition: color 0.15s ease, transform 0.12s ease;
}

.cs-profile-theme-picker__item:hover:not(.is-disabled) {
	color: var(--cs-text);
	transform: translateY(-1px);
}

.cs-profile-theme-picker__item.is-active .cs-profile-theme-picker__swatch {
	box-shadow: 0 0 0 2px var(--cs-accent);
}

.cs-profile-theme-picker__item.is-disabled {
	opacity: 0.42;
	cursor: not-allowed;
}

.cs-profile-theme-picker__swatch {
	width: 56px;
	height: 56px;
	border-radius: 50%;
	border: 1px solid rgba(255, 255, 255, 0.12);
	box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.18);
	transition: box-shadow 0.15s ease;
}

.cs-profile-theme-picker__swatch--default {
	background: linear-gradient(145deg, #4a5160 0%, #353b48 100%);
}

.cs-profile-theme-picker__swatch--summer {
	background: linear-gradient(145deg, #8b7340 0%, #6b5730 100%);
}

.cs-profile-theme-picker__swatch--midnight {
	background: linear-gradient(145deg, #1a2844 0%, #101828 100%);
}

.cs-profile-theme-picker__swatch--steel {
	background: linear-gradient(145deg, #5a6472 0%, #434b58 100%);
}

.cs-profile-theme-picker__swatch--space {
	background: linear-gradient(145deg, #4a3558 0%, #352748 100%);
}

.cs-profile-theme-picker__swatch--dark {
	background: linear-gradient(145deg, #2a2a2a 0%, #181818 100%);
}

.cs-profile-theme-picker__swatch--transparent {
	background-color: #3a4048;
	background-image:
		linear-gradient(45deg, rgba(255, 255, 255, 0.14) 25%, transparent 25%),
		linear-gradient(-45deg, rgba(255, 255, 255, 0.14) 25%, transparent 25%),
		linear-gradient(45deg, transparent 75%, rgba(255, 255, 255, 0.14) 75%),
		linear-gradient(-45deg, transparent 75%, rgba(255, 255, 255, 0.14) 75%);
	background-size: 10px 10px;
	background-position: 0 0, 0 5px, 5px -5px, -5px 0;
}

.cs-profile-theme-picker__label {
	font-size: 12px;
	line-height: 1.2;
	text-align: center;
}

.cs-settings-link--muted {
	color: var(--cs-text-dim);
}

.cs-settings-link--muted:hover {
	color: #f05d5e;
}

.cs-settings-file {
	font-size: 12px;
	color: var(--cs-text-dim);
	max-width: 220px;
}

.cs-settings-toggle {
	display: inline-flex;
	flex-wrap: wrap;
	gap: 8px;
}

.cs-settings-toggle__btn {
	display: inline-flex;
	align-items: center;
	padding: 8px 14px;
	border-radius: 8px;
	border: 1px solid var(--cs-border);
	background: rgba(0, 0, 0, 0.18);
	color: var(--cs-text-dim);
	font-size: 13px;
	font-weight: 500;
	cursor: pointer;
	margin: 0;
	transition: border-color 0.15s, color 0.15s, background 0.15s;
}

.cs-settings-toggle__btn.active {
	border-color: rgba(92, 157, 255, 0.45);
	background: rgba(92, 157, 255, 0.12);
	color: var(--cs-accent);
}

.cs-settings-account {
	display: flex;
	align-items: center;
	gap: 10px;
	flex-wrap: wrap;
	margin-bottom: 8px;
}

.cs-settings-account__link {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	color: var(--cs-text);
	text-decoration: none;
}

.cs-settings-account__link img {
	width: 36px;
	height: 36px;
	border-radius: 50%;
	object-fit: cover;
}

.cs-settings-account__status {
	font-size: 13px;
	color: var(--cs-text-dim);
}

.cs-settings-referral-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

@media (max-width: 992px) {
	.cs-settings-layout {
		grid-template-columns: 1fr;
	}

	.cs-settings-nav {
		flex-direction: row;
		flex-wrap: nowrap;
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
		border-right: none;
		border-bottom: 1px solid var(--cs-border);
		padding: 0 12px 0 0;
		position: relative;
	}

	.cs-settings-nav__item {
		flex: 0 0 auto;
		padding: 12px 16px;
		white-space: nowrap;
	}

	.cs-settings-row {
		grid-template-columns: 1fr;
		gap: 10px;
		padding: 16px;
	}

	.cs-settings-row__action {
		padding-top: 0;
		text-align: left;
	}
}

.cs-profile-settings-panel .cs-settings-root {
	width: 100%;
}

.cs-profile-settings-panel .cs-settings-layout {
	border: none;
	border-radius: 0;
	background: transparent;
}

.cs-profile-settings-panel .cs-settings-nav {
	background: rgba(0, 0, 0, 0.12);
}

@media (max-width: 900px) {
	.cs-profile-cover .cs-profile-actions-menu > .dropdown-menu {
		z-index: 10050 !important;
		min-width: min(280px, calc(100vw - 32px));
	}

	.cs-profile-cover .cs-profile-actions-menu.open > .dropdown-menu {
		display: block !important;
	}

	.cs-profile-cover__toolbar {
		gap: 12px;
	}

	.cs-profile-actions {
		flex-wrap: wrap;
		gap: 8px;
		width: 100%;
	}

	.cs-profile-actions .cs-btn-balance {
		flex: 1 1 auto;
		min-width: 0;
	}

	.cs-profile-actions-menu {
		margin-left: auto;
	}
}

@media (max-width: 640px) {
	.cs-profile-settings-panel .cs-settings-nav {
		position: sticky;
		top: 8px;
		z-index: 2;
		background: var(--cs-bg-card);
		scrollbar-width: none;
	}

	.cs-profile-settings-panel .cs-settings-nav::-webkit-scrollbar {
		display: none;
	}

	.cs-profile-settings-panel .cs-settings-nav__item {
		font-size: 13px;
		padding: 12px 14px;
	}

	.cs-profile-settings-panel .cs-settings-row {
		padding: 14px 16px;
		gap: 10px;
	}

	.cs-profile-settings-panel .cs-settings-row__action {
		padding-top: 0;
	}

	.cs-profile-settings-panel .cs-settings-birth {
		flex-direction: column;
		align-items: stretch;
	}

	.cs-profile-settings-panel .cs-settings-birth .cs-settings-select {
		width: 100%;
	}
}

/* ========== FORUM ========== */
.cs-forum-page {
	display: flex;
	flex-direction: column;
	gap: 14px;
	min-width: 0;
}

.cs-forum-panel {
	border-radius: var(--cs-radius);
	border: 1px solid var(--cs-border);
	background: var(--cs-bg-card);
	overflow: hidden;
}

.cs-forum-panel--compact {
	margin-bottom: 0;
}

.cs-forum-panel__head {
	padding: 16px 18px;
	border-bottom: 1px solid var(--cs-border);
}

.cs-forum-panel__title {
	margin: 0;
	font-size: 18px;
	font-weight: 700;
	color: var(--cs-text);
	line-height: 1.3;
}

.cs-forum-panel__body {
	padding: 18px;
	color: var(--cs-text-dim);
}

.cs-forum-panel__body--flush {
	padding: 0;
}

.cs-forum-section + .cs-forum-section {
	border-top: 1px solid var(--cs-border);
}

.cs-forum-section__title {
	margin: 0;
	padding: 12px 18px;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--cs-text-dim);
	background: rgba(255, 255, 255, 0.02);
	border-bottom: 1px solid var(--cs-border);
}

.cs-forum-section__list {
	display: flex;
	flex-direction: column;
}

.cs-forum-row {
	display: grid;
	grid-template-columns: 52px minmax(0, 1fr) minmax(180px, 240px);
	gap: 16px;
	align-items: center;
	padding: 14px 18px;
	border-bottom: 1px solid rgba(255, 255, 255, 0.04);
	transition: background 0.15s;
}

.cs-forum-row:last-child {
	border-bottom: none;
}

.cs-forum-row:hover {
	background: rgba(255, 255, 255, 0.02);
}

.cs-forum-row__icon img {
	width: 44px;
	height: 44px;
	border-radius: 12px;
	object-fit: cover;
	display: block;
}

.cs-forum-row__title {
	margin: 0 0 4px;
	font-size: 15px;
	font-weight: 600;
	line-height: 1.35;
}

.cs-forum-row__title a {
	color: var(--cs-text) !important;
	text-decoration: none;
}

.cs-forum-row__title a:hover {
	color: var(--cs-accent) !important;
}

.cs-forum-row__desc {
	margin: 0;
	font-size: 13px;
	line-height: 1.45;
	color: var(--cs-text-dim);
}

.cs-forum-row__meta {
	min-width: 0;
	font-size: 12px;
	line-height: 1.5;
}

.cs-forum-row__meta-line {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	margin: 0 0 4px;
}

.cs-forum-row__meta-line:last-child {
	margin-bottom: 0;
}

.cs-forum-row__meta-label {
	color: var(--cs-text-dim);
	flex-shrink: 0;
}

.cs-forum-row__meta a {
	color: var(--cs-text) !important;
}

.cs-forum-row__empty {
	margin: 0;
	color: var(--cs-text-dim);
	font-style: italic;
}

.cs-forum-topics {
	width: 100%;
	overflow-x: auto;
}

.cs-forum-topics__head,
.cs-forum-topic {
	display: table;
	width: 100%;
	table-layout: fixed;
	border-collapse: collapse;
}

.cs-forum-topics__head > span,
.cs-forum-topic > .cs-ft-cell {
	display: table-cell;
	vertical-align: middle;
	padding: 10px 8px;
}

.cs-forum-topics__head > span {
	padding-top: 11px;
	padding-bottom: 11px;
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--cs-text-dim);
	background: rgba(255, 255, 255, 0.02);
	border-bottom: 1px solid var(--cs-border);
}

.cs-forum-topics__head > .cs-ft-cell--icon {
	padding-left: 16px;
	width: 44px;
}

.cs-forum-topics__head > .cs-ft-cell--title {
	padding-left: 0;
	width: 38%;
}

.cs-forum-topics__head > .cs-ft-cell--stat {
	width: 56px;
	text-align: center;
}

.cs-forum-topics__head > .cs-ft-cell--author {
	width: 14%;
	text-align: center;
}

.cs-forum-topics__head > .cs-ft-cell--last {
	width: 18%;
	padding-right: 16px;
	text-align: left;
}

.cs-forum-topics__list {
	display: block;
	min-width: 0;
}

.cs-forum-topics #forum_topics a {
	white-space: normal !important;
}

.cs-forum-topics__divider {
	padding: 10px 16px;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--cs-text-dim);
	background: rgba(255, 255, 255, 0.02);
	border-top: 1px solid var(--cs-border);
	border-bottom: 1px solid var(--cs-border);
}

.cs-forum-topics__divider--pinned {
	color: #f0b429;
}

.cs-forum-topic {
	border-bottom: 1px solid rgba(255, 255, 255, 0.04);
	transition: background 0.15s;
}

.cs-forum-topic:last-child {
	border-bottom: none;
}

.cs-forum-topic:hover {
	background: rgba(255, 255, 255, 0.03);
}

.cs-forum-topic--pinned {
	background: rgba(240, 180, 41, 0.04);
}

.cs-forum-topic > .cs-ft-cell--icon {
	width: 44px;
	padding-left: 16px;
}

.cs-forum-topic > .cs-ft-cell--icon img {
	width: 32px;
	height: 32px;
	border-radius: 8px;
	object-fit: cover;
	display: block;
}

.cs-forum-topic > .cs-ft-cell--title {
	width: 38%;
	padding-left: 0;
	padding-right: 12px;
}

.cs-forum-topic > .cs-ft-cell--stat {
	width: 56px;
	text-align: center;
	font-size: 13px;
	color: var(--cs-text-dim);
	font-variant-numeric: tabular-nums;
}

.cs-forum-topic > .cs-ft-cell--author {
	width: 14%;
	text-align: center;
	font-size: 13px;
}

.cs-forum-topic > .cs-ft-cell--author a {
	color: var(--cs-text) !important;
	text-decoration: none;
	display: block;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.cs-forum-topic > .cs-ft-cell--author a:hover {
	color: var(--cs-accent) !important;
}

.cs-forum-topic > .cs-ft-cell--last {
	width: 18%;
	padding-right: 16px;
	font-size: 12px;
	color: var(--cs-text-dim);
}

.cs-forum-topic__title {
	display: block;
	font-size: 14px;
	font-weight: 600;
	color: var(--cs-text) !important;
	line-height: 1.35;
	text-decoration: none;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.cs-forum-topic__title:hover {
	color: var(--cs-accent) !important;
}

.cs-forum-topic__last-date {
	display: block;
	margin-bottom: 2px;
	color: var(--cs-text-dim);
}

.cs-forum-topic__last-author {
	display: block;
	color: var(--cs-text) !important;
	text-decoration: none;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.cs-forum-topic__last-author:hover {
	color: var(--cs-accent) !important;
}

.cs-forum-topic__last-empty {
	display: block;
	font-style: italic;
	color: var(--cs-text-dim);
}

.cs-forum-posts {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.cs-forum-post {
	border: 1px solid var(--cs-border);
	border-radius: var(--cs-radius);
	background: var(--cs-bg-card);
	overflow: hidden;
}

.cs-forum-post--topic {
	margin-bottom: 12px;
}

.cs-forum-post__bar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	padding: 10px 16px;
	border-bottom: 1px solid var(--cs-border);
	background: rgba(255, 255, 255, 0.02);
}

.cs-forum-post__author {
	font-size: 15px;
	font-weight: 700;
	color: var(--cs-text) !important;
	text-decoration: none;
}

.cs-forum-post__author:hover {
	color: var(--cs-accent) !important;
}

.cs-forum-post__bar-meta {
	display: flex;
	align-items: center;
	gap: 8px;
	flex-shrink: 0;
}

.cs-forum-post__date,
.cs-forum-post__permalink {
	font-size: 12px;
	color: var(--cs-text-dim) !important;
	text-decoration: none;
}

.cs-forum-post__action {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	padding: 0;
	border: none;
	border-radius: 8px;
	background: transparent;
	color: var(--cs-text-dim);
	cursor: pointer;
	transition: background 0.15s, color 0.15s;
}

.cs-forum-post__action:hover {
	background: var(--cs-bg-hover);
	color: var(--cs-text);
}

.cs-forum-post__body {
	display: grid;
	grid-template-columns: 160px minmax(0, 1fr);
	gap: 0;
}

.cs-forum-post__profile {
	padding: 16px;
	border-right: 1px solid var(--cs-border);
	background: rgba(0, 0, 0, 0.12);
	text-align: center;
}

.cs-forum-post__avatar {
	display: inline-block;
	line-height: 0;
	margin-bottom: 10px;
}

.cs-forum-post__avatar img {
	width: 72px;
	height: 72px;
	border-radius: 50%;
	object-fit: cover;
	border: 2px solid rgba(255, 255, 255, 0.08);
}

.cs-forum-post__group {
	margin: 0 0 12px;
	font-size: 12px;
	font-weight: 600;
	line-height: 1.35;
}

.cs-forum-post__stats {
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 6px;
	text-align: left;
}

.cs-forum-post__stats > div {
	display: flex;
	justify-content: space-between;
	gap: 8px;
	font-size: 12px;
}

.cs-forum-post__stats dt {
	margin: 0;
	color: var(--cs-text-dim);
	font-weight: 500;
}

.cs-forum-post__stats dd {
	margin: 0;
	color: var(--cs-text);
	font-weight: 600;
}

.cs-forum-post__content {
	padding: 16px 18px;
	min-width: 0;
}

/* Текст поста — как в классическом GameCMS (#b7bacd), не чистый белый */
.cs-forum-post__text,
.cs-forum-post__content .with_code {
	color: #b7bacd;
	font-size: 13px;
	font-weight: 400;
	line-height: 1.55;
	word-break: break-word;
}

.cs-forum-post__text p,
.cs-forum-post__content .with_code p {
	margin: 0 0 0.65em;
	color: inherit;
	font-weight: inherit;
}

.cs-forum-post__text p:last-child,
.cs-forum-post__content .with_code p:last-child {
	margin-bottom: 0;
}

.cs-forum-post__text ul,
.cs-forum-post__text ol,
.cs-forum-post__content .with_code ul,
.cs-forum-post__content .with_code ol {
	margin: 0 0 0.65em;
	padding-left: 1.35em;
	color: inherit;
}

.cs-forum-post__text li,
.cs-forum-post__content .with_code li {
	margin-bottom: 0.3em;
	color: inherit;
}

.cs-forum-post__text strong:not([style*="color"]),
.cs-forum-post__text b:not([style*="color"]),
.cs-forum-post__content .with_code strong:not([style*="color"]),
.cs-forum-post__content .with_code b:not([style*="color"]) {
	color: #c8ccd8;
	font-weight: 600;
}

.cs-forum-post__text a:not([style*="color"]),
.cs-forum-post__content .with_code a:not([style*="color"]) {
	color: #8aa4d4;
}

.cs-forum-post__text a:not([style*="color"]):hover,
.cs-forum-post__content .with_code a:not([style*="color"]):hover {
	color: #a8bce8;
}

.cs-forum-post__text table tr td,
.cs-forum-post__content .with_code table tr td {
	border-color: var(--cs-border);
	color: inherit;
}

.cs-forum-post__edited {
	margin: 12px 0 0;
	font-size: 12px;
	color: var(--cs-text-dim);
}

.cs-forum-post__signature {
	margin-top: 16px;
	padding-top: 12px;
	border-top: 1px dashed var(--cs-border);
	font-size: 12px;
	color: #8a91a3;
	line-height: 1.45;
}

.cs-forum-post__foot {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 12px;
	padding: 10px 16px;
	border-top: 1px solid var(--cs-border);
	background: rgba(255, 255, 255, 0.02);
}

.cs-forum-post__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	flex-shrink: 0;
}

.cs-forum-post__thanks {
	font-size: 12px;
	color: var(--cs-text-dim);
	min-width: 0;
}

.cs-forum-post__thanks--full {
	width: 100%;
}

.cs-forum-compose-panel {
	margin-top: 4px;
}

.cs-forum-compose__editor > textarea.form-control {
	min-height: 120px;
	border: none;
	border-radius: 0;
	background: var(--cs-bg-card);
	color: var(--cs-text);
	box-shadow: none;
}

.cs-forum-compose__footer {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 10px 14px;
	border-top: 1px solid var(--cs-border);
	background: rgba(255, 255, 255, 0.02);
}

.cs-forum-compose__smile {
	position: static !important;
	width: 24px !important;
	height: 24px !important;
	min-width: 24px;
	padding: 0 !important;
	border: none !important;
	background: transparent url('../img/smile.svg') center / 22px 22px no-repeat !important;
	opacity: 0.7;
	cursor: pointer;
}

.cs-forum-compose__smile:hover {
	opacity: 1;
}

.cs-forum-closed {
	padding: 14px 18px;
	border-radius: var(--cs-radius-sm);
	border: 1px solid var(--cs-border);
	background: var(--cs-bg-pill);
	color: var(--cs-text-dim);
	text-align: center;
}

.cs-forum-pagination {
	padding: 14px 18px;
	border-top: 1px solid var(--cs-border);
	text-align: center;
}

.cs-forum-sidebar {
	display: flex;
	flex-direction: column;
	gap: 14px;
}

.cs-forum-sidebar__action {
	width: 100%;
	justify-content: center;
	text-align: center;
}

.cs-forum-widget {
	border-radius: var(--cs-radius);
	border: 1px solid var(--cs-border);
	background: var(--cs-bg-card);
	overflow: hidden;
}

.cs-forum-widget__head {
	padding: 12px 16px;
	border-bottom: 1px solid var(--cs-border);
	font-size: 13px;
	font-weight: 700;
	color: var(--cs-text);
}

.cs-forum-widget__body {
	display: flex;
	flex-direction: column;
	padding: 0;
}

.cs-forum-widget__body:has(.cs-forum-widget-item) {
	gap: 8px;
	padding: 10px;
}

.cs-forum-top-user {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 11px 14px;
}

.cs-forum-top-user + .cs-forum-top-user {
	border-top: 1px solid rgba(255, 255, 255, 0.05);
}

.cs-forum-top-user__avatar {
	flex: 0 0 40px;
	width: 40px;
	height: 40px;
	line-height: 0;
}

.cs-forum-top-user__avatar img {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	object-fit: cover;
	border: 2px solid rgba(255, 255, 255, 0.06);
	display: block;
}

.cs-forum-top-user__body {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
	justify-content: center;
	gap: 5px;
}

.cs-forum-top-user__name {
	display: block;
	margin: 0;
	padding: 0;
	font-size: 14px;
	font-weight: 700;
	line-height: 1.2;
	text-decoration: none;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.cs-forum-top-user__name:hover {
	opacity: 0.88;
}

.cs-forum-top-user__metrics {
	display: flex;
	align-items: center;
	flex-wrap: nowrap;
	gap: 12px;
	margin: 0;
	padding: 0;
}

.cs-forum-top-user__metric {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	margin: 0;
	padding: 0;
	font-size: 12px;
	font-weight: 600;
	line-height: 1;
	color: #8b93a7;
	white-space: nowrap;
}

.cs-forum-top-user__metric .glyphicon {
	display: inline-block;
	width: 12px;
	margin: 0;
	padding: 0;
	font-size: 11px;
	line-height: 1;
	text-align: center;
	opacity: 0.8;
	flex-shrink: 0;
}

.cs-forum-sidebar #top_users .cs-forum-top-user a {
	display: inline;
	padding: 0;
	border-bottom: none !important;
	color: inherit;
	font-size: inherit;
	gap: 0;
}

.cs-forum-sidebar #top_users .cs-forum-top-user__avatar {
	display: block;
}

.cs-forum-sidebar #top_users .cs-forum-top-user__name {
	display: block;
}

.cs-forum-top-user__name img,
.cs-forum-top-user__name .g_smile {
	display: none !important;
}

.cs-forum-sidebar #top_users .block {
	margin: 0;
	padding: 10px 12px;
	border: none !important;
	background: transparent !important;
}

.cs-forum-sidebar #top_users .block img {
	float: none !important;
	width: 40px !important;
	height: 40px !important;
	margin: 0 !important;
	border-radius: 50%;
}

.cs-forum-widget-item {
	padding: 10px 12px;
	border-radius: var(--cs-radius-sm);
	border: 1px solid rgba(255, 255, 255, 0.04);
	background: rgba(255, 255, 255, 0.02);
}

.cs-forum-widget-item__title {
	margin: 0 0 6px;
	font-size: 13px;
	font-weight: 600;
	line-height: 1.35;
}

.cs-forum-widget-item__title a {
	color: var(--cs-text) !important;
}

.cs-forum-widget-item__title a:hover {
	color: var(--cs-accent) !important;
}

.cs-forum-widget-item__meta {
	margin: 0;
	font-size: 12px;
	color: var(--cs-text-dim);
}

.cs-forum-widget-item__meta a {
	color: var(--cs-text) !important;
}

.cs-forum-widget-item__dot {
	opacity: 0.5;
}

.cs-forum-widget-stats {
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.cs-forum-widget-stats__row {
	display: flex;
	justify-content: space-between;
	gap: 8px;
	font-size: 12px;
}

.cs-forum-widget-stats__row dt {
	margin: 0;
	color: var(--cs-text-dim);
}

.cs-forum-widget-stats__row dd {
	margin: 0;
	color: var(--cs-text);
	font-weight: 600;
}

/* legacy widgets до очистки кэша */
.cs-forum-widget__body .block.border,
.cs-forum-widget__body .block.last_msg.border {
	margin: 0;
	padding: 10px 12px;
	border-radius: var(--cs-radius-sm);
	border: 1px solid rgba(255, 255, 255, 0.04) !important;
	background: rgba(255, 255, 255, 0.02);
}

.cs-forum-widget__body .block p {
	margin: 0 0 4px;
	font-size: 12px;
	line-height: 1.45;
	color: var(--cs-text-dim);
}

.cs-forum-widget__body .block p:last-child {
	margin-bottom: 0;
}

.cs-forum-widget__body .block a {
	color: var(--cs-text) !important;
}

/* TinyMCE в ответе на форуме */
.cs-forum-compose-panel .tox.tox-tinymce {
	border: none !important;
	border-radius: 0 !important;
	background: var(--cs-bg-card) !important;
	box-shadow: none !important;
}

.cs-forum-compose-panel .tox .tox-editor-header {
	background: var(--cs-bg-card) !important;
	border-bottom: 1px solid var(--cs-border) !important;
}

.cs-forum-compose-panel .tox .tox-toolbar-overlord,
.cs-forum-compose-panel .tox .tox-toolbar,
.cs-forum-compose-panel .tox .tox-toolbar__primary {
	background: transparent !important;
}

.cs-forum-compose-panel .tox .tox-tbtn {
	color: var(--cs-text-dim) !important;
}

.cs-forum-compose-panel .tox .tox-tbtn svg {
	fill: currentColor !important;
}

.cs-forum-compose-panel .tox .tox-edit-area,
.cs-forum-compose-panel .tox .tox-sidebar-wrap {
	background: var(--cs-bg-card) !important;
}

.cs-forum-compose-panel .tox .tox-statusbar {
	display: flex !important;
	background: var(--cs-bg-card) !important;
	border-top: 1px solid var(--cs-border) !important;
	color: var(--cs-text-dim) !important;
}

.cs-forum-compose__editor .tox-tinymce ~ textarea,
.cs-forum-compose.is-editor-ready > .cs-forum-compose__editor > textarea {
	display: none !important;
}

@media (max-width: 768px) {
	.cs-forum-topics {
		overflow-x: auto;
	}

	.cs-forum-topics__head {
		display: none;
	}

	.cs-forum-topics__head,
	.cs-forum-topic {
		min-width: 560px;
	}

	.cs-forum-row {
		grid-template-columns: 44px minmax(0, 1fr);
	}

	.cs-forum-row__meta {
		grid-column: 2;
	}

	.cs-forum-post__body {
		grid-template-columns: 1fr;
	}

	.cs-forum-post__profile {
		display: flex;
		flex-wrap: wrap;
		align-items: center;
		gap: 12px;
		text-align: left;
		border-right: none;
		border-bottom: 1px solid var(--cs-border);
	}

	.cs-forum-post__avatar {
		margin-bottom: 0;
	}

	.cs-forum-post__avatar img {
		width: 48px;
		height: 48px;
	}

	.cs-forum-post__group {
		margin: 0;
		flex: 1;
	}

	.cs-forum-post__stats {
		width: 100%;
		flex-direction: row;
		flex-wrap: wrap;
		gap: 10px 16px;
	}

	.cs-forum-post__stats > div {
		flex: 1 1 auto;
		min-width: 100px;
	}
}

/* ========== FORUM ADMIN (edit_forum, add/edit topic) ========== */
.cs-forum-admin {
	min-width: 0;
}

.cs-forum-admin__toolbar {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-bottom: 18px;
}

.cs-forum-admin__sections {
	display: flex;
	flex-direction: column;
	gap: 14px;
}

.cs-forum-admin__loader {
	display: flex;
	justify-content: center;
	padding: 24px;
}

.cs-forum-admin__loader img {
	width: 32px;
	height: 32px;
	opacity: 0.7;
}

.cs-forum-admin-section {
	border: 1px solid var(--cs-border);
	border-radius: var(--cs-radius-sm);
	background: var(--cs-bg-pill);
	overflow: hidden;
}

.cs-forum-admin-section__head {
	padding: 14px 16px;
	border-bottom: 1px solid var(--cs-border);
	font-size: 15px;
	font-weight: 600;
	color: var(--cs-text);
	background: rgba(0, 0, 0, 0.12);
}

.cs-forum-admin-section .cs-forum-admin-form {
	padding: 16px;
}

.cs-forum-admin-section__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: 4px;
}

.cs-forum-admin-subtitle {
	margin: 16px 16px 10px;
	font-size: 13px;
	font-weight: 600;
	color: var(--cs-text-dim);
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

.cs-forum-admin-field + .cs-forum-admin-field {
	margin-top: 16px;
}

.cs-forum-admin-label {
	display: block;
	margin-bottom: 8px;
	font-size: 13px;
	font-weight: 600;
	color: var(--cs-text-dim);
}

.cs-forum-admin-input,
.cs-forum-admin-select,
.cs-forum-admin .form-control {
	width: 100%;
	max-width: 100%;
	padding: 10px 14px !important;
	border-radius: var(--cs-radius-sm) !important;
	border: 1px solid var(--cs-border) !important;
	background: rgba(0, 0, 0, 0.22) !important;
	color: var(--cs-text) !important;
	font-size: 14px !important;
	line-height: 1.35;
	box-shadow: none !important;
	height: auto !important;
}

.cs-forum-admin-input:focus,
.cs-forum-admin-select:focus,
.cs-forum-admin .form-control:focus {
	outline: none !important;
	border-color: var(--cs-accent) !important;
}

.cs-forum-admin-select {
	appearance: none;
	cursor: pointer;
}

.cs-forum-admin-divider {
	height: 1px;
	margin: 20px 0;
	background: var(--cs-border);
}

.cs-forum-admin-inline-actions {
	margin-top: 10px;
}

.cs-forum-admin-upload {
	display: flex;
	align-items: flex-start;
	gap: 14px;
	flex-wrap: wrap;
}

.cs-forum-admin-upload__preview {
	width: 72px;
	height: 72px;
	border-radius: var(--cs-radius-sm);
	border: 1px solid var(--cs-border);
	object-fit: cover;
	background: rgba(0, 0, 0, 0.2);
}

.cs-forum-admin-upload__controls {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 8px;
	min-width: 0;
	flex: 1;
}

.cs-forum-admin-upload__controls .input-file {
	max-width: 100%;
	font-size: 13px;
	color: var(--cs-text-dim);
}

.cs-forum-admin-access {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}

.cs-forum-admin-access .btn,
.cs-forum-admin-access label.btn {
	margin: 0 !important;
	padding: 6px 12px !important;
	border-radius: 999px !important;
	border: 1px solid var(--cs-border) !important;
	background: rgba(0, 0, 0, 0.18) !important;
	color: var(--cs-text-dim) !important;
	font-size: 12px !important;
	font-weight: 500 !important;
	line-height: 1.2 !important;
	box-shadow: none !important;
	transition: background 0.15s, color 0.15s, border-color 0.15s;
}

.cs-forum-admin-access .btn:hover,
.cs-forum-admin-access label.btn:hover {
	background: var(--cs-bg-hover) !important;
	color: var(--cs-text) !important;
}

.cs-forum-admin-access .btn.active,
.cs-forum-admin-access label.btn.active {
	background: rgba(92, 108, 255, 0.18) !important;
	border-color: rgba(92, 108, 255, 0.45) !important;
	color: var(--cs-text) !important;
}

.cs-forum-admin-access .btn input,
.cs-forum-admin-access label.btn input {
	position: absolute;
	opacity: 0;
	pointer-events: none;
}

.cs-forum-admin-table-wrap {
	margin: 0 16px 16px;
	border: 1px solid var(--cs-border);
	border-radius: var(--cs-radius-sm);
	overflow: hidden;
}

.cs-forum-admin-table {
	margin: 0 !important;
	border: none !important;
	background: transparent !important;
}

.cs-forum-admin-table thead th,
.cs-forum-admin-table thead td {
	padding: 10px 12px !important;
	border: none !important;
	border-bottom: 1px solid var(--cs-border) !important;
	background: rgba(0, 0, 0, 0.18) !important;
	color: var(--cs-text-dim) !important;
	font-size: 11px !important;
	font-weight: 600 !important;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	vertical-align: middle !important;
}

.cs-forum-admin-table tbody td {
	padding: 12px !important;
	border: none !important;
	border-top: 1px solid var(--cs-border) !important;
	background: transparent !important;
	color: var(--cs-text) !important;
	vertical-align: middle !important;
}

.cs-forum-admin-table__row:hover td {
	background: rgba(255, 255, 255, 0.02) !important;
}

.cs-forum-admin-table__img img {
	width: 48px;
	height: 48px;
	border-radius: 8px;
	border: 1px solid var(--cs-border);
	object-fit: cover;
	display: block;
}

.cs-forum-admin-table__file .input-file {
	font-size: 12px;
	color: var(--cs-text-dim);
	max-width: 160px;
}

.cs-forum-admin-table__col-narrow {
	width: 96px;
	white-space: nowrap;
}

.cs-forum-admin-table__actions-col {
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.cs-forum-admin-icon-btn {
	min-width: 34px;
	padding-left: 8px !important;
	padding-right: 8px !important;
}

.cs-forum-admin-form-panel .cs-forum-panel__body {
	padding: 18px;
}

.cs-forum-admin-form__footer {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-top: 18px;
	padding-top: 16px;
	border-top: 1px solid var(--cs-border);
}

.cs-forum-admin-form__actions {
	margin-top: 16px;
}

.cs-forum-admin-result:empty {
	display: none;
}

.cs-forum-admin-editor {
	border: 1px solid var(--cs-border);
	border-radius: var(--cs-radius-sm);
	overflow: hidden;
	background: var(--cs-bg-card);
}

.cs-forum-admin-editor > textarea.form-control {
	border: none !important;
	border-radius: 0 !important;
	background: transparent !important;
	resize: vertical;
	min-height: 120px;
}

.cs-forum-admin-editor.is-editor-ready > textarea.form-control,
.cs-forum-admin-editor .tox-tinymce ~ textarea {
	display: none !important;
}

/* TinyMCE — тёмная тема как в ответе на форуме */
.cs-forum-admin .tox.tox-tinymce,
.cs-forum-admin-editor .tox.tox-tinymce {
	border: none !important;
	border-radius: 0 !important;
	background: var(--cs-bg-card) !important;
	box-shadow: none !important;
}

.cs-forum-admin .tox .tox-editor-header,
.cs-forum-admin-editor .tox .tox-editor-header {
	background: var(--cs-bg-card) !important;
	border-bottom: 1px solid var(--cs-border) !important;
}

.cs-forum-admin .tox .tox-menubar,
.cs-forum-admin-editor .tox .tox-menubar {
	background: transparent !important;
}

.cs-forum-admin .tox .tox-mbtn,
.cs-forum-admin-editor .tox .tox-mbtn {
	color: var(--cs-text-dim) !important;
}

.cs-forum-admin .tox .tox-mbtn:hover,
.cs-forum-admin-editor .tox .tox-mbtn:hover {
	background: var(--cs-bg-hover) !important;
	color: var(--cs-text) !important;
}

.cs-forum-admin .tox .tox-toolbar-overlord,
.cs-forum-admin .tox .tox-toolbar,
.cs-forum-admin .tox .tox-toolbar__primary,
.cs-forum-admin-editor .tox .tox-toolbar-overlord,
.cs-forum-admin-editor .tox .tox-toolbar,
.cs-forum-admin-editor .tox .tox-toolbar__primary {
	background: transparent !important;
}

.cs-forum-admin .tox .tox-tbtn,
.cs-forum-admin-editor .tox .tox-tbtn {
	color: var(--cs-text-dim) !important;
}

.cs-forum-admin .tox .tox-tbtn svg,
.cs-forum-admin-editor .tox .tox-tbtn svg {
	fill: currentColor !important;
}

.cs-forum-admin .tox .tox-tbtn:hover,
.cs-forum-admin .tox .tox-tbtn:focus,
.cs-forum-admin-editor .tox .tox-tbtn:hover,
.cs-forum-admin-editor .tox .tox-tbtn:focus {
	background: var(--cs-bg-hover) !important;
	color: var(--cs-text) !important;
}

.cs-forum-admin .tox .tox-edit-area,
.cs-forum-admin .tox .tox-sidebar-wrap,
.cs-forum-admin-editor .tox .tox-edit-area,
.cs-forum-admin-editor .tox .tox-sidebar-wrap {
	background: var(--cs-bg-card) !important;
}

.cs-forum-admin .tox .tox-statusbar,
.cs-forum-admin-editor .tox .tox-statusbar {
	display: flex !important;
	background: var(--cs-bg-card) !important;
	border-top: 1px solid var(--cs-border) !important;
	color: var(--cs-text-dim) !important;
}

/* Модалки настройки форума */
.cs-forum-admin-modal .modal-content {
	border: 1px solid var(--cs-border);
	border-radius: var(--cs-radius);
	background: var(--cs-bg-card);
	color: var(--cs-text);
	box-shadow: 0 24px 60px rgba(0, 0, 0, 0.55);
}

.cs-forum-admin-modal .modal-header {
	border-bottom: 1px solid var(--cs-border);
	background: rgba(0, 0, 0, 0.12);
}

.cs-forum-admin-modal .modal-title {
	font-size: 18px;
	font-weight: 600;
	color: var(--cs-text);
}

.cs-forum-admin-modal .modal-header .close {
	color: var(--cs-text-dim);
	opacity: 1;
	text-shadow: none;
}

.cs-forum-admin-modal .modal-header .close:hover {
	color: var(--cs-text);
}

.cs-forum-admin-modal .modal-body,
.cs-forum-admin-modal .modal-footer {
	border-color: var(--cs-border);
	background: transparent;
}

.cs-forum-admin-modal .modal-footer {
	padding-top: 12px;
}

.cs-forum-admin #sections .block {
	border: none;
	background: transparent;
	margin: 0;
	padding: 0;
}

.cs-forum-admin #sections .block_head {
	display: none;
}

.cs-forum-admin #forums_list select,
.cs-forum-admin #sections_list select {
	width: 100%;
}

@media (max-width: 768px) {
	.cs-forum-admin-table-wrap {
		overflow-x: auto;
	}

	.cs-forum-admin-table {
		min-width: 720px;
	}

	.cs-forum-admin-upload {
		flex-direction: column;
	}
}

/* ========== PURSE / WALLET ========== */
.cs-purse-page {
	display: flex;
	flex-direction: column;
	gap: 14px;
	min-width: 0;
}

.cs-purse-panel__body--flush {
	padding: 0 !important;
}

.cs-purse-alert {
	padding: 14px 16px;
	border-radius: var(--cs-radius-sm);
	border: 1px solid var(--cs-border);
	background: var(--cs-bg-pill);
}

.cs-purse-alert strong {
	display: block;
	margin-bottom: 4px;
	font-size: 15px;
	color: var(--cs-text);
}

.cs-purse-alert p {
	margin: 0;
	font-size: 13px;
	color: var(--cs-text-dim);
}

.cs-purse-alert--success {
	border-left: 3px solid var(--cs-green);
}

.cs-purse-alert--error {
	border-left: 3px solid #e85d5d;
}

.cs-purse-stats {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 10px;
}

.cs-purse-stat {
	display: flex;
	align-items: center;
	gap: 12px;
	min-height: 76px;
	padding: 14px 16px;
	border: 1px solid var(--cs-border);
	border-radius: var(--cs-radius-sm);
	background: var(--cs-bg-pill);
	color: inherit;
	text-align: left;
}

.cs-purse-stat--balance .cs-purse-stat__value {
	font-size: clamp(16px, 1.6vw, 20px);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

button.cs-purse-stat {
	width: 100%;
	cursor: pointer;
	font: inherit;
	transition: background 0.15s, border-color 0.15s, transform 0.1s;
}

button.cs-purse-stat:hover {
	background: var(--cs-bg-hover);
	border-color: rgba(255, 255, 255, 0.1);
}

button.cs-purse-stat:active {
	transform: scale(0.99);
}

.cs-purse-stat__title {
	flex: 1;
	min-width: 0;
	font-size: 13px;
	font-weight: 600;
	color: var(--cs-text);
	line-height: 1.35;
}

.cs-purse-stat__icon {
	flex-shrink: 0;
	width: 40px;
	height: 40px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 10px;
	background: rgba(92, 108, 255, 0.12);
	color: #8aa4ff;
	font-size: 18px;
	line-height: 1;
}

.cs-purse-stat--balance .cs-purse-stat__icon {
	background: rgba(91, 143, 255, 0.14);
	color: #6ba3ff;
}

.cs-purse-stat--voucher .cs-purse-stat__icon {
	background: rgba(61, 214, 200, 0.14);
	color: #3dd6c8;
}

.cs-purse-stat--discount .cs-purse-stat__icon {
	background: rgba(167, 139, 250, 0.14);
	color: #b794f6;
}

.cs-purse-stat--operations .cs-purse-stat__icon {
	background: rgba(92, 108, 255, 0.12);
	color: #8aa4ff;
}

.cs-purse-stat__body {
	min-width: 0;
}

.cs-purse-stat__label {
	display: block;
	font-size: 12px;
	color: var(--cs-text-dim);
	line-height: 1.3;
}

.cs-purse-stat__value {
	display: block;
	margin-top: 2px;
	font-size: 18px;
	font-weight: 700;
	color: var(--cs-text);
	line-height: 1.2;
}

.cs-purse-bonuses {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 10px;
}

.cs-purse-bonus {
	padding: 14px 16px;
	border-radius: var(--cs-radius-sm);
	border: 1px solid rgba(61, 214, 140, 0.18);
	background: rgba(61, 214, 140, 0.06);
}

.cs-purse-bonus__value {
	font-size: 20px;
	font-weight: 700;
	color: #5ee4a0;
	line-height: 1.1;
}

.cs-purse-bonus__text {
	margin: 8px 0 0;
	font-size: 13px;
	line-height: 1.45;
	color: var(--cs-text-dim);
}

.cs-purse-merchants {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 16px;
	align-items: start;
}

.cs-purse-merchant .cs-forum-panel__title {
	font-size: 13px;
	line-height: 1.35;
}

.cs-purse-merchant__body {
	display: flex;
	flex-direction: column;
	gap: 10px;
	padding: 14px !important;
}

.cs-purse-merchant__logo-wrap {
	display: block;
	width: 100%;
	margin: 0;
	padding: 0;
	border: none;
	border-radius: 8px;
	background: transparent;
	cursor: pointer;
	overflow: visible;
}

.cs-purse-merchant__logo-wrap:hover .cs-purse-merchant__logo {
	opacity: 0.95;
}

.cs-purse-merchant__logo {
	display: block;
	width: 100%;
	height: auto;
	max-width: 100%;
	margin: 0 0 5px;
	padding: 0;
	border: none;
	border-radius: 8px;
	background: transparent;
	opacity: 0.85;
	transition: opacity 0.15s;
}

.cs-purse-merchant__body .cs-purse-input {
	padding: 9px 12px;
	font-size: 13px;
}

.cs-purse-merchant__submit {
	width: 100%;
	margin-top: 0;
	padding: 9px 14px;
	font-size: 13px;
	background: rgba(0, 0, 0, 0.12) !important;
	border: 1px solid var(--cs-accent) !important;
	color: #8aa4ff !important;
	font-weight: 600;
}

.cs-purse-merchant__submit:hover {
	background: rgba(92, 108, 255, 0.12) !important;
	border-color: var(--cs-accent-hover) !important;
	color: #a8b8ff !important;
}

.cs-purse-field-label {
	display: block;
	margin-bottom: 6px;
	font-size: 13px;
	font-weight: 600;
	color: var(--cs-text-dim);
}

.cs-purse-input,
.cs-purse-page .form-control {
	width: 100%;
	max-width: 100%;
	padding: 10px 14px !important;
	border-radius: var(--cs-radius-sm) !important;
	border: 1px solid var(--cs-border) !important;
	background: rgba(0, 0, 0, 0.22) !important;
	color: var(--cs-text) !important;
	font-size: 14px !important;
	line-height: 1.35;
	box-shadow: none !important;
	height: auto !important;
}

.cs-purse-input:focus,
.cs-purse-page .form-control:focus {
	outline: none !important;
	border-color: var(--cs-accent) !important;
}

.cs-purse-result:empty {
	display: none;
}

.cs-purse-result:not(:empty) {
	margin-top: 4px;
	font-size: 13px;
	color: var(--cs-text-dim);
}

.cs-purse-table-wrap {
	border-top: 1px solid var(--cs-border);
}

.cs-purse-table {
	margin: 0 !important;
	border: none !important;
	background: transparent !important;
}

.cs-purse-table thead th,
.cs-purse-table thead td {
	padding: 12px 16px !important;
	border: none !important;
	border-bottom: 1px solid var(--cs-border) !important;
	background: rgba(0, 0, 0, 0.12) !important;
	color: var(--cs-text-dim) !important;
	font-size: 11px !important;
	font-weight: 600 !important;
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

.cs-purse-table tbody td {
	padding: 12px 16px !important;
	border: none !important;
	border-top: 1px solid var(--cs-border) !important;
	color: var(--cs-text) !important;
	font-size: 13px;
	vertical-align: middle !important;
}

.cs-purse-table tbody tr:hover td {
	background: rgba(255, 255, 255, 0.02);
}

.cs-purse-amount {
	display: inline-flex;
	align-items: center;
	padding: 4px 10px;
	border-radius: 999px;
	font-size: 12px;
	font-weight: 600;
	line-height: 1.2;
}

.cs-purse-amount--plus {
	background: rgba(61, 214, 140, 0.14);
	color: var(--cs-green);
}

.cs-purse-amount--minus {
	background: rgba(232, 93, 93, 0.14);
	color: #ff8f8f;
}

.cs-purse-loader {
	display: flex;
	justify-content: center;
	padding: 18px;
}

.cs-purse-loader img {
	width: 28px;
	height: 28px;
	opacity: 0.7;
}

.cs-purse-modal .modal-content {
	border: 1px solid var(--cs-border);
	border-radius: var(--cs-radius);
	background: var(--cs-bg-card);
	color: var(--cs-text);
	box-shadow: 0 24px 60px rgba(0, 0, 0, 0.55);
}

.cs-purse-modal .modal-header {
	border-bottom: 1px solid var(--cs-border);
	background: rgba(0, 0, 0, 0.12);
}

.cs-purse-modal .modal-title {
	font-size: 18px;
	font-weight: 600;
	color: var(--cs-text);
}

.cs-purse-modal .modal-header .close {
	color: var(--cs-text-dim);
	opacity: 1;
	text-shadow: none;
}

.cs-purse-modal .modal-header .close:hover {
	color: var(--cs-text);
}

.cs-purse-modal .modal-body {
	background: transparent;
}

.cs-purse-modal__actions {
	margin-top: 14px;
}

/* Сброс legacy-стилей purse из primary/secondary */
.cs-purse-page .purse,
.cs-purse-page .r_block,
.cs-purse-page .r_block_head,
.cs-purse-page .r_block_c {
	all: unset;
	display: contents;
}

/* Сайдбар кошелька — топ донатеров */
.cs-purse-sidebar {
	position: sticky;
	top: 16px;
}

.cs-purse-sidebar .cs-forum-widget__body {
	padding: 0;
}

/* Сброс глобальных #top_users a { display:flex; border-bottom } */
.cs-purse-sidebar #top_users a {
	display: block !important;
	align-items: stretch !important;
	gap: 0 !important;
	padding: 0 !important;
	border-bottom: none !important;
	color: inherit !important;
	font-size: inherit !important;
}

.cs-purse-sidebar #top_users img {
	width: 36px !important;
	height: 36px !important;
	float: none !important;
	margin: 0 !important;
	border-radius: 50%;
	object-fit: cover;
}

.cs-purse-sidebar .cs-purse-donator {
	display: grid !important;
	grid-template-columns: 20px 36px minmax(0, 1fr);
	align-items: center;
	column-gap: 10px;
	padding: 10px 14px;
	margin: 0;
}

.cs-purse-sidebar .cs-forum-top-user + .cs-forum-top-user {
	border-top: none;
}

.cs-purse-sidebar .cs-purse-donator + .cs-purse-donator {
	border-top: 1px solid rgba(255, 255, 255, 0.05);
}

.cs-purse-sidebar .cs-purse-donator__rank {
	grid-column: 1;
	grid-row: 1;
	align-self: center;
	flex: none;
	width: 20px;
	font-size: 13px;
	font-weight: 700;
	color: #e8a030;
	text-align: center;
	line-height: 1;
}

.cs-purse-sidebar .cs-purse-donator .cs-forum-top-user__avatar {
	grid-column: 2;
	grid-row: 1;
	flex: none;
	width: 36px;
	height: 36px;
	align-self: center;
}

.cs-purse-sidebar .cs-purse-donator .cs-forum-top-user__avatar img {
	width: 36px !important;
	height: 36px !important;
	border-width: 1px;
}

.cs-purse-sidebar .cs-purse-donator .cs-forum-top-user__body {
	grid-column: 3;
	grid-row: 1;
	flex: none;
	min-width: 0;
	align-self: center;
	gap: 2px;
}

.cs-purse-sidebar .cs-purse-donator .cs-forum-top-user__name {
	display: block;
	font-size: 13px;
	font-weight: 600;
	line-height: 1.25;
}

.cs-purse-sidebar .cs-purse-donator .cs-forum-top-user__metrics {
	margin-top: 2px;
}

.cs-purse-sidebar #top_users .block,
.cs-forum-sidebar #top_users .block {
	margin: 0;
	padding: 10px 12px;
	border: none !important;
	background: transparent !important;
}

.cs-purse-sidebar #top_users .online_user,
.cs-purse-sidebar #top_users ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

.cs-purse-sidebar .empty-element {
	display: block;
	padding: 14px 16px;
	font-size: 13px;
	color: var(--cs-text-dim);
}

.cs-purse-donator:nth-child(1) .cs-purse-donator__rank {
	color: #f0b429;
}

.cs-purse-donator:nth-child(2) .cs-purse-donator__rank {
	color: #b8c0d0;
}

.cs-purse-donator:nth-child(3) .cs-purse-donator__rank {
	color: #c98a5a;
}

@media (max-width: 992px) {
	.cs-purse-stats {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.cs-purse-bonuses {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.cs-purse-merchants {
		grid-template-columns: 1fr;
	}

	.cs-purse-sidebar {
		position: static;
	}
}

@media (max-width: 560px) {
	.cs-purse-stats {
		grid-template-columns: 1fr;
	}

	.cs-purse-bonuses {
		grid-template-columns: 1fr;
	}

	.cs-purse-stat {
		min-height: 0;
	}
}

/* ========== NOTIFICATIONS PAGE ========== */
.cs-notifications-page {
	display: flex;
	flex-direction: column;
	gap: 14px;
	min-width: 0;
}

.cs-notifications-panel__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
}

.cs-notifications-panel__clear {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	flex-shrink: 0;
	padding: 6px 12px;
	border: 1px solid var(--cs-border);
	border-radius: var(--cs-radius-sm);
	background: transparent;
	color: var(--cs-text-dim);
	font-size: 12px;
	line-height: 1.3;
	cursor: pointer;
	transition: border-color 0.15s, color 0.15s, background 0.15s;
}

.cs-notifications-panel__clear:hover {
	border-color: #e85d5d;
	color: #f0a8a8;
	background: rgba(232, 93, 93, 0.08);
}

.cs-notifications-list {
	display: flex;
	flex-direction: column;
	gap: 10px;
	padding: 14px 18px;
}

.cs-notifications-empty {
	margin: 0;
	padding: 28px 18px 32px;
	text-align: center;
	font-size: 14px;
	color: var(--cs-text-dim);
}

.cs-notify-card {
	position: relative;
	padding: 14px 44px 14px 16px;
	border: 1px solid var(--cs-border);
	border-left-width: 4px;
	border-radius: var(--cs-radius-sm);
	background: var(--cs-bg-pill);
}

.cs-notify-card--info {
	border-left-color: var(--cs-accent);
}

.cs-notify-card--success {
	border-left-color: var(--cs-green);
}

.cs-notify-card--error {
	border-left-color: #ef4444;
}

.cs-notify-card__close {
	position: absolute;
	top: 10px;
	right: 10px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	padding: 0;
	border: 1px solid transparent;
	border-radius: var(--cs-radius-sm);
	background: transparent;
	color: var(--cs-text-dim);
	cursor: pointer;
	transition: border-color 0.15s, color 0.15s, background 0.15s;
}

.cs-notify-card__close:hover {
	border-color: var(--cs-border);
	color: var(--cs-text);
	background: rgba(255, 255, 255, 0.04);
}

.cs-notify-card__close .glyphicon {
	font-size: 12px;
	line-height: 1;
}

.cs-notify-card__date {
	display: block;
	margin: 0 0 8px;
	font-size: 12px;
	font-weight: 600;
	color: var(--cs-text);
	line-height: 1.3;
}

.cs-notify-card__text {
	font-size: 14px;
	line-height: 1.55;
	color: #b7bacd;
	word-break: break-word;
}

.cs-notify-card__text b,
.cs-notify-card__text strong {
	color: var(--cs-text);
	font-weight: 600;
}

.cs-notify-card__text a {
	color: var(--cs-accent);
	text-decoration: none;
}

.cs-notify-card__text a:hover {
	text-decoration: underline;
}

.cs-notifications-page .pagination > li > a,
.cs-notifications-page .pagination > li > span {
	background: var(--cs-bg-pill);
	border-color: var(--cs-border);
	color: var(--cs-text-dim);
}

.cs-notifications-page .pagination > .active > a,
.cs-notifications-page .pagination > .active > span {
	background: var(--cs-accent);
	border-color: var(--cs-accent);
	color: #fff;
}

@media (max-width: 640px) {
	.cs-notifications-panel__head {
		align-items: flex-start;
		flex-direction: column;
	}

	.cs-notifications-panel__clear {
		width: 100%;
		justify-content: center;
	}
}

/* ========== EDIT USER (admin) ========== */
.cs-edit-user-page {
	display: flex;
	flex-direction: column;
	gap: 14px;
	min-width: 0;
}

.cs-edit-user-grid {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	gap: 14px;
	align-items: start;
}

.cs-edit-user-column {
	display: flex;
	flex-direction: column;
	gap: 14px;
	min-width: 0;
}

.cs-edit-user-panel + .cs-edit-user-panel {
	margin-top: 0;
}

.cs-edit-user-form .cs-settings-row {
	background: transparent;
}

.cs-edit-user-form .cs-native-select {
	width: 100%;
}

.cs-edit-user-row--section {
	grid-template-columns: minmax(0, 1fr);
	background: rgba(92, 108, 255, 0.04);
}

.cs-edit-user-row--section .cs-settings-row__title {
	font-size: 15px;
}

.cs-edit-user-row--danger {
	background: rgba(232, 93, 93, 0.04);
}

.cs-edit-user-row--editor {
	grid-template-columns: minmax(160px, 26%) minmax(0, 1fr);
}

.cs-edit-user-row--editor .cs-settings-row__action {
	display: none;
}

.cs-edit-user-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 8px 14px;
	border: 1px solid var(--cs-border);
	border-radius: var(--cs-radius-sm);
	background: transparent;
	color: var(--cs-text-dim);
	font-size: 13px;
	line-height: 1.3;
	cursor: pointer;
	transition: border-color 0.15s, color 0.15s, background 0.15s;
}

.cs-edit-user-btn--danger {
	border-color: rgba(232, 93, 93, 0.45);
	color: #f0a8a8;
}

.cs-edit-user-btn--danger:hover {
	border-color: #e85d5d;
	color: #fff;
	background: rgba(232, 93, 93, 0.16);
}

.cs-settings-link--inline {
	display: inline;
	padding: 0;
	margin-left: 4px;
	vertical-align: baseline;
}

.cs-edit-user-info-table {
	width: 100%;
	border-collapse: collapse;
}

.cs-edit-user-info-table th,
.cs-edit-user-info-table td {
	padding: 12px 18px;
	border-bottom: 1px solid rgba(255, 255, 255, 0.04);
	text-align: left;
	vertical-align: top;
	font-size: 14px;
	color: #b7bacd;
}

.cs-edit-user-info-table th {
	width: 42%;
	font-weight: 600;
	color: var(--cs-text-dim);
}

.cs-edit-user-info-table tr:last-child th,
.cs-edit-user-info-table tr:last-child td {
	border-bottom: none;
}

.cs-edit-user-info-table a {
	color: var(--cs-accent);
	text-decoration: none;
}

.cs-edit-user-info-table a:hover {
	text-decoration: underline;
}

.cs-edit-user-status {
	font-weight: 600;
}

.cs-edit-user-status--ok {
	color: var(--cs-green);
}

.cs-edit-user-status--warn {
	color: #e8b339;
}

.cs-edit-user-status--bad {
	color: #ef6b6b;
}

.cs-edit-user-note {
	padding: 12px 18px;
	border-bottom: 1px solid var(--cs-border);
	font-size: 13px;
	line-height: 1.5;
	color: var(--cs-text-dim);
	background: rgba(92, 157, 255, 0.06);
}

.cs-edit-user-icon-btn {
	margin-left: 8px;
	font-size: 12px;
	color: var(--cs-text-dim);
	cursor: pointer;
	transition: color 0.15s;
}

.cs-edit-user-icon-btn:hover {
	color: var(--cs-text);
}

.cs-edit-user-icon-btn--danger:hover {
	color: #ef6b6b;
}

.cs-edit-user-loader {
	padding: 24px 18px !important;
	text-align: center;
}

.cs-edit-user-loader img {
	width: 28px;
	height: 28px;
}

.cs-edit-user-page .cs-edit-user-table-wrap {
	width: 100%;
	border-top: 1px solid var(--cs-border);
}

.cs-edit-user-page .cs-edit-user-table {
	width: 100%;
	table-layout: fixed;
	border-collapse: collapse;
	margin: 0 !important;
	border: none !important;
	background: transparent !important;
}

.cs-edit-user-page .cs-edit-user-table thead th {
	padding: 12px 18px !important;
	border: none !important;
	border-bottom: 1px solid var(--cs-border) !important;
	background: rgba(0, 0, 0, 0.12) !important;
	color: var(--cs-text-dim) !important;
	font-size: 11px !important;
	font-weight: 600 !important;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	text-align: left;
	vertical-align: middle !important;
}

.cs-edit-user-page .cs-edit-user-table tbody td {
	padding: 12px 18px !important;
	border: none !important;
	border-top: 1px solid rgba(255, 255, 255, 0.04) !important;
	background: transparent !important;
	color: var(--cs-text) !important;
	font-size: 13px;
	vertical-align: middle !important;
	word-break: break-word;
}

.cs-edit-user-page .cs-edit-user-table tbody tr:hover td {
	background: rgba(255, 255, 255, 0.02) !important;
}

.cs-edit-user-page .cs-edit-user-table--operations th:nth-child(1),
.cs-edit-user-page .cs-edit-user-table--operations td:nth-child(1) {
	width: 120px;
}

.cs-edit-user-page .cs-edit-user-table--operations th:nth-child(3),
.cs-edit-user-page .cs-edit-user-table--operations td:nth-child(3) {
	width: 190px;
	text-align: right;
	white-space: nowrap;
}
.cs-edit-user-page .cs-edit-user-table--accounts th:nth-child(1),
.cs-edit-user-page .cs-edit-user-table--accounts td:nth-child(1) {
	width: 36%;
}

.cs-edit-user-page .cs-edit-user-table--accounts a {
	color: var(--cs-accent);
	text-decoration: none;
}

.cs-edit-user-page .cs-edit-user-table--accounts a:hover {
	text-decoration: underline;
}

.cs-edit-user-page .cs-edit-user-table__empty td {
	padding: 20px 18px !important;
	color: var(--cs-text-dim);
	text-align: center;
}

.cs-edit-user-page .cs-edit-user-note {
	margin: 0;
	border-bottom: 1px solid var(--cs-border);
}

.cs-edit-user-page .cs-edit-user-loader {
	padding: 28px 18px !important;
	text-align: center;
}

.cs-edit-user-page .cs-forum-admin-editor .tox.tox-tinymce,
.cs-edit-user-page .cs-forum-admin-editor > textarea.form-control {
	border-radius: var(--cs-radius-sm);
}

@media (max-width: 1100px) {
	.cs-edit-user-grid {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 768px) {
	.cs-edit-user-row--editor {
		grid-template-columns: 1fr;
	}
}

/* ========== STATS PAGE ========== */
.cs-stats-page {
	min-width: 0;
}

.cs-stats-layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 280px;
	gap: 14px;
	align-items: start;
}

.cs-stats-table-wrap {
	overflow-x: auto;
}

.cs-stats-table {
	width: 100%;
	border-collapse: collapse;
	min-width: 640px;
	table-layout: auto;
}

.cs-stats-table thead th:first-child,
.cs-stats-table tbody td:first-child {
	width: 1%;
	white-space: nowrap;
	text-align: center;
	padding-right: 8px;
}

.cs-stats-table .td-profile {
	min-width: 0;
	width: auto;
}

.cs-stats-table .user-profile {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	max-width: 100%;
	min-width: 0;
	vertical-align: middle;
}

.cs-stats-table .user-profile i {
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	font-style: normal;
}

.cs-stats-table thead th {
	padding: 12px 16px;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--cs-text-dim);
	text-align: left;
	background: rgba(255, 255, 255, 0.02);
	border-bottom: 1px solid var(--cs-border);
	white-space: nowrap;
}

.cs-stats-table tbody tr.cs-stats-row {
	cursor: pointer;
	transition: background 0.15s;
}

.cs-stats-table tbody tr.cs-stats-row:hover {
	background: rgba(255, 255, 255, 0.03);
}

.cs-stats-table tbody td {
	padding: 12px 16px;
	border-bottom: 1px solid rgba(255, 255, 255, 0.04);
	color: #b7bacd;
	font-size: 14px;
	vertical-align: middle;
}

.cs-stats-table tbody tr.cs-stats-row:last-of-type td,
.cs-stats-table tbody tr.cs-stats-row + tr.hidden-tr + tr.cs-stats-row td {
	border-bottom-color: rgba(255, 255, 255, 0.04);
}

.cs-stats-table .td-profile a,
.cs-stats-table .td-profile b {
	color: var(--cs-text);
	font-weight: 600;
}

.cs-stats-table .small_us_av,
.cs-stats-table .user-profile img,
.cs-stats-table .td-profile img {
	border: none !important;
	box-shadow: none;
}

.cs-stats-table .label {
	display: inline-block;
	padding: 3px 8px;
	border-radius: 999px;
	font-size: 11px;
	font-weight: 600;
	border: 1px solid transparent;
}

.cs-stats-table .label-success {
	background: rgba(61, 214, 140, 0.12);
	color: var(--cs-green);
	border-color: rgba(61, 214, 140, 0.25);
}

.cs-stats-table .label-info {
	background: rgba(92, 108, 255, 0.12);
	color: var(--cs-accent);
	border-color: rgba(92, 108, 255, 0.25);
}

.cs-stats-table .label-warning {
	background: rgba(232, 179, 57, 0.12);
	color: #e8b339;
	border-color: rgba(232, 179, 57, 0.25);
}

.cs-stats-table .label-danger {
	background: rgba(239, 107, 107, 0.12);
	color: #ef6b6b;
	border-color: rgba(239, 107, 107, 0.25);
}

.cs-stats-table .label-default {
	background: var(--cs-bg-pill);
	color: var(--cs-text-dim);
	border-color: var(--cs-border);
}

.cs-stats-sidebar {
	display: flex;
	flex-direction: column;
	gap: 14px;
	min-width: 0;
}

.cs-stats-widget .cs-forum-widget__head {
	padding: 14px 16px;
	font-size: 14px;
	font-weight: 700;
	color: var(--cs-text);
}

.cs-stats-widget .cs-forum-widget__body {
	padding: 14px;
}

.cs-stats-main {
	min-width: 0;
}

.cs-stats-empty {
	margin: 0;
	color: var(--cs-text-dim);
	font-size: 14px;
	line-height: 1.5;
}

.cs-stats-search {
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.cs-stats-input {
	width: 100%;
	height: 42px;
	padding: 0 14px;
	border: 1px solid var(--cs-border);
	border-radius: 10px;
	background: rgba(255, 255, 255, 0.03);
	color: var(--cs-text);
	font-size: 14px;
	outline: none;
	transition: border-color 0.15s, background 0.15s;
}

.cs-stats-input::placeholder {
	color: var(--cs-text-muted);
}

.cs-stats-input:focus {
	border-color: rgba(124, 92, 255, 0.45);
	background: rgba(255, 255, 255, 0.05);
}

.cs-stats-search__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	min-height: 42px;
	padding: 0 16px;
	border: none !important;
	border-radius: 10px;
	background: var(--cs-accent);
	color: #fff !important;
	font-size: 13px;
	font-weight: 600;
	line-height: 1;
	transition: background 0.15s;
}

.cs-stats-search__btn:hover,
.cs-stats-search__btn:focus {
	outline: none;
	background: var(--cs-accent-hover);
	color: #fff !important;
}

.cs-stats-server-list {
	margin: 0;
	padding: 0;
	list-style: none;
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.cs-stats-server-list > li > a {
	display: block;
	padding: 0 14px;
	min-height: 42px;
	line-height: 42px;
	border-radius: 10px;
	color: var(--cs-text-dim) !important;
	background: rgba(255, 255, 255, 0.03);
	border: 1px solid var(--cs-border);
	font-size: 13px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.02em;
	transition: background 0.15s, color 0.15s, border-color 0.15s;
}

.cs-stats-server-list > li > a:hover {
	background: rgba(255, 255, 255, 0.06) !important;
	color: var(--cs-text) !important;
	border-color: rgba(255, 255, 255, 0.12);
}

.cs-stats-server-list > li.active > a {
	color: #d8dcff !important;
	border-color: rgba(92, 108, 255, 0.35);
	background: rgba(92, 108, 255, 0.14) !important;
}

.cs-stats-player-panel {
	background:
		radial-gradient(120% 70% at 50% -25%, rgba(92, 108, 255, 0.16), transparent 58%),
		linear-gradient(180deg, rgba(255, 255, 255, 0.025) 0%, transparent 32%),
		var(--cs-bg-card);
	box-shadow: 0 10px 28px rgba(0, 0, 0, 0.2);
}

.cs-stats-player-panel .cs-profile-stats-root,
.cs-stats-player-panel > .cs-forum-panel__body > .cs-profile-stats-group--block {
	background: transparent;
}

.cs-stats-player-panel .cs-profile-stats-summary {
	background: rgba(255, 255, 255, 0.02);
}

.cs-stats-player-panel .cs-profile-stats-card {
	background: rgba(12, 14, 24, 0.55);
	border-color: rgba(255, 255, 255, 0.08);
}

.cs-stats-player-panel .cs-profile-stats-card--accent {
	background: rgba(92, 108, 255, 0.12);
	border-color: rgba(92, 108, 255, 0.28);
}

.cs-stats-page .pagination > li > a,
.cs-stats-page .pagination > li > span {
	background: var(--cs-bg-pill);
	border-color: var(--cs-border);
	color: var(--cs-text-dim);
}

.cs-stats-page .pagination > .active > a,
.cs-stats-page .pagination > .active > span {
	background: var(--cs-accent);
	border-color: var(--cs-accent);
	color: #fff;
}

/* Модалка статистики игрока */
.cs-stats-modal .modal-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	padding: 16px 18px;
	min-height: 0;
	border-bottom: 1px solid var(--cs-border);
	background: rgba(0, 0, 0, 0.12);
}

.cs-stats-modal .modal-title {
	flex: 1;
	min-width: 0;
	margin: 0;
	font-size: 17px;
	font-weight: 700;
	line-height: 1.3;
	letter-spacing: -0.01em;
	color: var(--cs-text);
}

.cs-stats-modal .modal-header .close {
	float: none;
	position: static;
	flex-shrink: 0;
	width: 32px;
	height: 32px;
	margin: 0;
	padding: 0;
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: 8px;
	background: rgba(255, 255, 255, 0.03);
	color: var(--cs-text-dim);
	opacity: 1;
	text-shadow: none;
	display: grid;
	place-items: center;
	font-size: 20px;
	font-weight: 400;
	line-height: 1;
	transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}

.cs-stats-modal .modal-header .close span {
	display: block;
	line-height: 1;
	transform: translateY(-1px);
}

.cs-stats-modal .modal-header .close:hover,
.cs-stats-modal .modal-header .close:focus {
	border-color: rgba(255, 255, 255, 0.14);
	background: rgba(255, 255, 255, 0.08);
	color: var(--cs-text);
	opacity: 1;
	outline: none;
}

.cs-stats-modal .modal-footer {
	display: flex;
	justify-content: flex-end;
	padding: 12px 18px 16px;
	border-top: 1px solid var(--cs-border);
	background: rgba(0, 0, 0, 0.08);
}

.cs-stats-modal .modal-body {
	max-height: min(72vh, 760px);
	overflow-y: auto;
	padding: 0 !important;
}

.cs-stats-modal-sheet {
	padding: 14px 16px 16px;
}

.cs-stats-modal-table-block {
	width: 100%;
	margin: 0 0 12px;
	border-collapse: separate;
	border-spacing: 0;
	border: 1px solid var(--cs-border);
	border-radius: var(--cs-radius-sm);
	overflow: hidden;
	background: rgba(255, 255, 255, 0.015);
}

.cs-stats-modal-table-block:last-child {
	margin-bottom: 0;
}

.cs-stats-modal-block-title {
	display: block;
	margin: 4px 0 10px;
	padding: 0 2px;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--cs-text-dim);
}

.cs-stats-modal-table-wrap {
	margin-bottom: 12px;
	overflow-x: auto;
	border: 1px solid var(--cs-border);
	border-radius: var(--cs-radius-sm);
	background: rgba(255, 255, 255, 0.015);
}

.cs-stats-modal-table-wrap .cs-stats-modal-table-block {
	margin: 0;
	border: none;
	border-radius: 0;
}

.cs-stats-modal__body table.table-bordered {
	border: none;
}

.cs-stats-modal__body table.table-bordered td,
.cs-stats-modal__body table.table-bordered th {
	padding: 11px 14px;
	border: none;
	border-bottom: 1px solid rgba(255, 255, 255, 0.05);
	color: var(--cs-text);
	font-size: 13px;
	vertical-align: middle;
}

.cs-stats-modal__body table.table-bordered tr {
	display: grid;
	grid-template-columns: minmax(150px, 42%) minmax(0, 1fr);
}

.cs-stats-modal__body table.table-bordered tr:last-child td {
	border-bottom: none;
}

.cs-stats-modal__body table.table-bordered td:first-child {
	color: var(--cs-text-dim);
	font-weight: 600;
}

.cs-stats-modal__body table.table-bordered td:first-child b {
	font-weight: 600;
	color: var(--cs-text-dim);
}

.cs-stats-modal__body table.table-bordered td:last-child {
	color: var(--cs-text);
	font-weight: 500;
	text-align: right;
}

.cs-stats-modal__body table.table-bordered td:last-child .user-profile,
.cs-stats-modal__body table.table-bordered td:last-child .small_us_av {
	display: inline-flex;
	align-items: center;
	justify-content: flex-end;
	gap: 8px;
	margin-left: auto;
}

.cs-stats-modal-ops-row td:last-child {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end;
	gap: 8px;
}

.cs-stats-modal__body table.table-bordered thead tr {
	display: table-row;
}

.cs-stats-modal__body table.table-bordered thead td,
.cs-stats-modal__body table.table-bordered thead th {
	font-size: 10px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--cs-text-dim);
	background: rgba(255, 255, 255, 0.03);
	text-align: left;
}

.cs-stats-modal__body table.table-bordered tbody tr {
	display: table-row;
}

.cs-stats-modal__body table.table-bordered tbody td {
	display: table-cell;
	text-align: left;
}

.cs-stats-modal__body table.table-bordered tbody td:last-child {
	text-align: left;
}

.cs-stats-modal__body > b {
	display: block;
	padding: 14px 18px 8px;
	font-size: 13px;
	font-weight: 700;
	color: var(--cs-text);
}

.cs-stats-modal__btn {
	display: inline-flex;
	align-items: center;
	padding: 7px 12px;
	border: 1px solid var(--cs-border);
	border-radius: var(--cs-radius-sm);
	background: transparent;
	color: var(--cs-text-dim);
	font-size: 12px;
	font-weight: 600;
	line-height: 1.3;
	text-decoration: none;
	cursor: pointer;
	transition: border-color 0.15s, color 0.15s, background 0.15s;
}

.cs-stats-modal__btn + .cs-stats-modal__btn {
	margin-left: 0;
}

.cs-stats-modal__btn:hover {
	border-color: var(--cs-accent);
	color: var(--cs-text);
	background: rgba(92, 108, 255, 0.08);
	text-decoration: none;
}

.cs-stats-modal__btn--primary {
	border-color: rgba(92, 108, 255, 0.35);
	color: #d8dcff;
	background: rgba(92, 108, 255, 0.12);
}

.cs-stats-modal__btn--primary:hover {
	border-color: var(--cs-accent);
	color: #fff;
	background: rgba(92, 108, 255, 0.22);
}

.cs-stats-modal__btn--danger:hover {
	border-color: #e85d5d;
	color: #f0a8a8;
	background: rgba(232, 93, 93, 0.08);
}

.cs-stats-modal .progress {
	height: 10px;
	margin: 0;
	border-radius: 999px;
	background: var(--cs-bg-pill);
	box-shadow: none;
	overflow: hidden;
}

.cs-stats-modal .progress-bar {
	background: linear-gradient(90deg, var(--cs-accent), #7080ff);
	box-shadow: none;
	font-size: 10px;
	font-weight: 600;
	color: #fff;
	line-height: 10px;
	min-width: 2.4em;
}

.cs-stats-modal .progress-bar-info {
	background: linear-gradient(90deg, var(--cs-accent), #7080ff);
}

.cs-stats-modal .label {
	display: inline-block;
	padding: 3px 8px;
	border-radius: 999px;
	font-size: 11px;
	font-weight: 600;
}

@media (max-width: 640px) {
	.cs-stats-modal__body table.table-bordered tr {
		grid-template-columns: 1fr;
	}

	.cs-stats-modal__body table.table-bordered td:last-child {
		text-align: left;
		padding-top: 0;
	}

	.cs-stats-modal-ops-row td:last-child {
		justify-content: flex-start;
	}
}

.cs-stats-section-nav {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-bottom: 14px;
}

.cs-stats-section-nav__item {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 38px;
	padding: 0 18px;
	border-radius: 10px;
	border: 1px solid var(--cs-border);
	background: rgba(255, 255, 255, 0.02);
	color: var(--cs-text-dim);
	font-size: 14px;
	font-weight: 600;
	text-decoration: none;
	transition: background 0.15s, border-color 0.15s, color 0.15s;
}

.cs-stats-section-nav__item:hover {
	color: var(--cs-text);
	border-color: rgba(92, 108, 255, 0.35);
	background: rgba(92, 108, 255, 0.08);
	text-decoration: none;
}

.cs-stats-section-nav__item.is-active {
	color: #fff;
	border-color: rgba(92, 108, 255, 0.55);
	background: linear-gradient(135deg, rgba(92, 108, 255, 0.9), rgba(72, 88, 220, 0.95));
}

.cs-stats-layout--timer {
	grid-template-columns: 1fr;
}

.cs-forum-panel__head--timer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	flex-wrap: wrap;
}

.cs-timer-stats__head-actions {
	display: flex;
	align-items: center;
	margin-left: auto;
}

.cs-timer-stats__toolbar {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	padding: 14px 16px;
}

.cs-timer-stats__views {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
}

.cs-timer-stats__view {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 38px;
	padding: 0 18px;
	border-radius: 10px;
	border: 1px solid var(--cs-border);
	background: rgba(255, 255, 255, 0.02);
	color: var(--cs-text-dim);
	font-size: 14px;
	font-weight: 600;
	text-decoration: none;
	transition: background 0.15s, border-color 0.15s, color 0.15s, box-shadow 0.15s;
}

.cs-timer-stats__view:hover {
	color: var(--cs-text);
	border-color: rgba(92, 108, 255, 0.35);
	background: rgba(92, 108, 255, 0.08);
	text-decoration: none;
}

.cs-timer-stats__view.is-active,
.cs-timer-stats__view.is-active:hover {
	background:
		linear-gradient(135deg, rgba(220, 230, 255, 0.16) 0%, rgba(160, 180, 235, 0.08) 100%);
	border-color: rgba(220, 230, 255, 0.32);
	color: var(--cs-moon-bright);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.09);
	text-decoration: none;
}

.cs-timer-stats__mode {
	display: inline-flex;
	align-items: center;
	gap: 10px;
}

.cs-timer-stats__mode--placeholder {
	visibility: hidden;
	pointer-events: none;
	user-select: none;
}

.cs-timer-stats__mode-label {
	font-size: 12px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--cs-text-dim);
	white-space: nowrap;
}

.cs-timer-stats__mode-group {
	display: inline-flex;
	align-items: center;
	padding: 3px;
	border-radius: 10px;
	border: 1px solid var(--cs-border);
	background: rgba(255, 255, 255, 0.02);
	gap: 3px;
}

.cs-timer-stats__mode-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 32px;
	padding: 0 14px;
	border-radius: 8px;
	color: var(--cs-text-dim);
	font-size: 13px;
	font-weight: 600;
	text-decoration: none;
	white-space: nowrap;
	transition: background 0.15s, border-color 0.15s, color 0.15s;
}

.cs-timer-stats__mode-btn:hover {
	color: var(--cs-text);
	text-decoration: none;
}

.cs-timer-stats__mode-btn.is-active {
	color: #fff;
	background: linear-gradient(135deg, rgba(92, 108, 255, 0.9), rgba(72, 88, 220, 0.95));
}

.cs-timer-table .cs-timer-time {
	font-variant-numeric: tabular-nums;
	font-weight: 600;
	color: #dce2ff;
	white-space: nowrap;
}

.cs-timer-row--viewer {
	background: rgba(92, 108, 255, 0.12) !important;
}

.cs-timer-row--viewer td {
	border-bottom-color: rgba(92, 108, 255, 0.25) !important;
}

.cs-timer-row--map {
	cursor: pointer;
	transition: background 0.15s ease;
}

.cs-timer-row--map:hover,
.cs-timer-row--map:focus-visible {
	background: rgba(92, 108, 255, 0.1) !important;
	outline: none;
}

.cs-timer-row--map:hover td,
.cs-timer-row--map:focus-visible td {
	border-bottom-color: rgba(92, 108, 255, 0.22) !important;
}

.cs-timer-row--map:hover .cs-timer-map-thumb,
.cs-timer-row--map:focus-visible .cs-timer-map-thumb {
	border-color: rgba(92, 108, 255, 0.45);
	box-shadow: 0 4px 18px rgba(92, 108, 255, 0.2);
}

.cs-timer-row--map:hover .cs-timer-map-link,
.cs-timer-row--map:focus-visible .cs-timer-map-link {
	color: #dce2ff;
}

.cs-timer-place {
	width: 72px;
	font-weight: 700;
	color: var(--cs-text);
}

.cs-timer-place--gold {
	color: #f0c14b;
}

.cs-timer-place--silver {
	color: #c7d0e8;
}

.cs-timer-place--bronze {
	color: #d49a6a;
}

.cs-timer-map-name {
	min-width: 260px;
}

.cs-timer-map-preview {
	display: flex;
	align-items: center;
	gap: 12px;
	min-width: 0;
	position: relative;
	padding-right: 28px;
}

.cs-timer-map-thumb {
	flex: 0 0 96px;
	width: 96px;
	height: 54px;
	object-fit: cover;
	border-radius: 8px;
	border: 1px solid rgba(255, 255, 255, 0.08);
	background: rgba(0, 0, 0, 0.35);
	box-shadow: 0 4px 14px rgba(0, 0, 0, 0.25);
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.cs-timer-map-info {
	min-width: 0;
	flex: 1 1 auto;
}

.cs-timer-map-link {
	display: inline-block;
	color: var(--cs-text);
	font-weight: 600;
	transition: color 0.15s ease;
}

.cs-timer-map-go {
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%) translateX(6px);
	opacity: 0;
	color: #b8c4ff;
	font-size: 18px;
	font-weight: 700;
	line-height: 1;
	transition: opacity 0.15s ease, transform 0.15s ease, color 0.15s ease;
}

.cs-timer-row--map:hover .cs-timer-map-go,
.cs-timer-row--map:focus-visible .cs-timer-map-go {
	opacity: 1;
	transform: translateY(-50%) translateX(0);
	color: #dce2ff;
}

.cs-timer-map-slug {
	display: block;
	margin-top: 2px;
	font-size: 11px;
	color: var(--cs-text-dim);
}

.cs-timer-map-hero {
	position: relative;
	margin: 12px 16px 0;
	min-height: 180px;
	border-radius: 14px;
	overflow: hidden;
	border: 1px solid var(--cs-border);
	background:
		linear-gradient(135deg, rgba(10, 14, 28, 0.92), rgba(18, 24, 44, 0.78)),
		var(--map-bg) center / cover no-repeat;
}

.cs-timer-map-hero__overlay {
	position: relative;
	z-index: 1;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 10px;
	padding: 20px 22px;
}

.cs-timer-map-back-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	min-height: 36px;
	padding: 0 14px 0 12px;
	border-radius: 999px;
	border: 1px solid rgba(255, 255, 255, 0.14);
	background: rgba(8, 12, 24, 0.55);
	backdrop-filter: blur(8px);
	color: #e8ecff;
	font-size: 13px;
	font-weight: 600;
	text-decoration: none;
	transition: background 0.15s, border-color 0.15s, color 0.15s, transform 0.15s;
}

.cs-timer-map-back-btn:hover {
	color: #fff;
	border-color: rgba(92, 108, 255, 0.55);
	background: rgba(92, 108, 255, 0.22);
	text-decoration: none;
	transform: translateX(-2px);
}

.cs-timer-map-back-btn__icon {
	font-size: 16px;
	line-height: 1;
	opacity: 0.9;
}

.cs-timer-map-hero .cs-timer-map-title {
	margin: 0;
	font-size: clamp(22px, 3vw, 30px);
	font-weight: 700;
	color: #fff;
	text-shadow: 0 2px 16px rgba(0, 0, 0, 0.45);
}

.cs-timer-map-hero__meta {
	margin: 0;
	font-size: 14px;
	color: rgba(232, 236, 255, 0.82);
}

.cs-timer-map-hero__meta strong {
	color: #fff;
	font-weight: 700;
}

.cs-timer-stats--map-detail .cs-stats-table-wrap {
	margin-top: 12px;
}

@media (max-width: 640px) {
	.cs-forum-panel__head--timer {
		align-items: flex-start;
	}

	.cs-timer-stats__head-actions {
		width: 100%;
		margin-left: 0;
	}

	.cs-timer-stats__mode {
		width: 100%;
		justify-content: space-between;
	}
}

@media (max-width: 1100px) {
	.cs-stats-layout {
		grid-template-columns: 1fr;
	}

	.cs-stats-sidebar {
		order: -1;
	}
}

/* ========== SHOP KEY ========== */
.cs-shop-key-page {
	display: flex;
	flex-direction: column;
	gap: 14px;
	min-width: 0;
	max-width: 720px;
}

.cs-shop-key-panel.cs-forum-panel {
	overflow: visible;
}

.cs-shop-key-panel .cs-forum-panel__body {
	display: flex;
	flex-direction: column;
	gap: 16px;
	padding: 20px 22px;
	overflow: visible;
}


.cs-shop-key-empty {
	margin: 0;
	color: var(--cs-text-dim);
	font-size: 14px;
	line-height: 1.5;
}

.cs-shop-key-alert {
	padding: 14px 16px;
	border-radius: var(--cs-radius-sm);
	border: 1px solid var(--cs-border);
	background: var(--cs-bg-pill);
}

.cs-shop-key-alert strong {
	display: block;
	margin-bottom: 4px;
	font-size: 15px;
	color: var(--cs-text);
}

.cs-shop-key-alert p {
	margin: 0;
	font-size: 13px;
	color: var(--cs-text-dim);
	line-height: 1.45;
}

.cs-shop-key-alert--success {
	border-left: 3px solid var(--cs-green);
}

.cs-shop-key-alert--error {
	border-left: 3px solid #ef6b6b;
}

.cs-shop-key-alert--error .cs-shop-key-auth-btn {
	margin-top: 12px;
	width: 100%;
}

.cs-shop-key-form {
	display: flex;
	flex-direction: column;
	gap: 14px;
}

.cs-shop-key-field {
	display: flex;
	flex-direction: column;
	gap: 6px;
	min-width: 0;
}

.cs-shop-key-label {
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--cs-text-dim);
}

.cs-shop-key-select,
.cs-shop-key-page .form-control {
	width: 100%;
	max-width: 100%;
	padding: 10px 14px !important;
	border-radius: var(--cs-radius-sm) !important;
	border: 1px solid var(--cs-border) !important;
	background: rgba(0, 0, 0, 0.22) !important;
	color: var(--cs-text) !important;
	font-size: 14px !important;
	line-height: 1.35;
	box-shadow: none !important;
	height: auto !important;
}

.cs-shop-key-select:focus,
.cs-shop-key-page .form-control:focus {
	outline: none !important;
	border-color: var(--cs-accent) !important;
}

.cs-shop-key-result:empty {
	display: none;
}

.cs-shop-key-result:not(:empty) {
	margin-top: 0;
}

.cs-shop-key-actions {
	margin-top: 0;
}

/* Custom native select (dark dropdown list) */
.cs-native-select {
	position: relative;
	width: 100%;
}

.cs-native-select__source {
	position: absolute;
	width: 1px;
	height: 1px;
	margin: -1px;
	padding: 0;
	border: 0;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	opacity: 0;
	pointer-events: none;
}

.cs-native-select__trigger {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	width: 100%;
	padding: 10px 14px;
	border-radius: var(--cs-radius-sm);
	border: 1px solid var(--cs-border);
	background: rgba(0, 0, 0, 0.22);
	color: var(--cs-text);
	font-size: 14px;
	line-height: 1.35;
	text-align: left;
	cursor: pointer;
	transition: border-color 0.15s, background 0.15s;
}

.cs-native-select__trigger::after {
	content: '';
	width: 8px;
	height: 8px;
	border-right: 2px solid var(--cs-text-dim);
	border-bottom: 2px solid var(--cs-text-dim);
	transform: rotate(45deg) translateY(-2px);
	flex-shrink: 0;
}

.cs-native-select__trigger:hover:not(:disabled) {
	border-color: rgba(92, 108, 255, 0.45);
}

.cs-native-select.is-open .cs-native-select__trigger,
.cs-native-select__trigger:focus {
	outline: none;
	border-color: var(--cs-accent);
}

.cs-native-select__trigger:disabled {
	opacity: 0.55;
	cursor: not-allowed;
}

.cs-native-select__menu {
	display: none;
	position: absolute;
	z-index: 40;
	top: calc(100% + 6px);
	left: 0;
	right: 0;
	max-height: 260px;
	overflow-y: auto;
	padding: 6px;
	border-radius: var(--cs-radius-sm);
	border: 1px solid var(--cs-border);
	background: #1a1a24;
	box-shadow: 0 14px 36px rgba(0, 0, 0, 0.5);
}

.cs-native-select.is-open .cs-native-select__menu {
	display: block;
}

.cs-native-select__menu--fixed {
	position: fixed;
	top: auto;
	left: auto;
	right: auto;
	z-index: 1200;
}

.cs-native-select__option {
	display: block;
	width: 100%;
	padding: 10px 12px;
	border: none;
	border-radius: 6px;
	background: transparent;
	color: #b7bacd;
	font-size: 14px;
	line-height: 1.35;
	text-align: left;
	cursor: pointer;
	transition: background 0.12s, color 0.12s;
}

.cs-native-select__option:hover,
.cs-native-select__option.is-selected {
	background: rgba(92, 108, 255, 0.16);
	color: var(--cs-text);
}

.cs-native-select__option.is-selected {
	color: #a8b8ff;
}

/* ========== BANLIST / MUTLIST ========== */
.cs-punish-page {
	min-width: 0;
}

.cs-punish-layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 280px;
	gap: 14px;
	align-items: start;
}

.cs-punish-table-wrap {
	overflow-x: auto;
}

.cs-punish-table {
	width: 100%;
	border-collapse: collapse;
	min-width: 720px;
}

.cs-punish-table thead th {
	padding: 12px 16px;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--cs-text-dim);
	text-align: left;
	background: rgba(255, 255, 255, 0.02);
	border-bottom: 1px solid var(--cs-border);
	white-space: nowrap;
}

.cs-punish-table tbody tr.cs-punish-row {
	cursor: pointer;
	transition: background 0.15s;
}

.cs-punish-table tbody tr.cs-punish-row:hover {
	background: rgba(255, 255, 255, 0.03);
}

.cs-punish-table tbody td {
	padding: 12px 16px;
	border-bottom: 1px solid rgba(255, 255, 255, 0.04);
	color: #b7bacd;
	font-size: 14px;
	vertical-align: middle;
}

.cs-punish-table .td-profile a,
.cs-punish-table .td-profile b {
	color: var(--cs-text);
	font-weight: 600;
}

.cs-punish-table .t-c {
	text-align: center;
	white-space: nowrap;
}

.cs-punish-buy {
	margin-left: 6px;
	color: var(--cs-accent);
	font-size: 12px;
	text-decoration: none;
}

.cs-punish-buy:hover {
	color: var(--cs-accent-hover);
	text-decoration: underline;
}

.cs-punish-sidebar {
	display: flex;
	flex-direction: column;
	gap: 14px;
	min-width: 0;
}

.cs-punish-sidebar .cs-forum-widget__body {
	padding: 14px 16px;
}

.cs-punish-sidebar .cs-punish-server-list {
	margin: 0;
}

.cs-punish-search {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.cs-punish-input {
	width: 100%;
	padding: 10px 12px;
	border: 1px solid var(--cs-border);
	border-radius: var(--cs-radius-sm);
	background: rgba(0, 0, 0, 0.22);
	color: var(--cs-text);
	font-size: 14px;
	line-height: 1.35;
}

.cs-punish-input:focus {
	outline: none;
	border-color: var(--cs-accent);
}

.cs-punish-search__btn {
	width: 100%;
}

.cs-punish-server-list {
	margin: 0;
	padding: 0;
	list-style: none;
}

.cs-punish-server-list > li > a {
	display: block;
	padding: 9px 12px;
	border-radius: var(--cs-radius-sm);
	color: var(--cs-text-dim);
	font-size: 13px;
	text-decoration: none;
	transition: background 0.15s, color 0.15s;
}

.cs-punish-server-list > li > a:hover,
.cs-punish-server-list > li.active > a {
	background: rgba(92, 108, 255, 0.1);
	color: var(--cs-text);
	text-decoration: none;
}

.cs-punish-server-list > li.active > a {
	background: rgba(92, 108, 255, 0.16);
	color: #a8b8ff;
	font-weight: 600;
}

.cs-punish-stats {
	margin: 0;
}

.cs-punish-stats-table {
	width: 100%;
	border-collapse: collapse;
}

.cs-punish-stats-table th,
.cs-punish-stats-table td {
	padding: 10px 0;
	border-bottom: 1px solid rgba(255, 255, 255, 0.05);
	vertical-align: middle;
}

.cs-punish-stats-table tr:first-child th,
.cs-punish-stats-table tr:first-child td {
	padding-top: 0;
}

.cs-punish-stats-table tr:last-child th,
.cs-punish-stats-table tr:last-child td {
	padding-bottom: 0;
	border-bottom: none;
}

.cs-punish-stats-table th {
	font-size: 13px;
	font-weight: 500;
	color: var(--cs-text-dim);
	text-align: left;
}

.cs-punish-stats-table td {
	font-size: 14px;
	font-weight: 600;
	color: var(--cs-text);
	text-align: right;
	font-variant-numeric: tabular-nums;
	white-space: nowrap;
}

.cs-punish-page .pagination > li > a,
.cs-punish-page .pagination > li > span {
	background: var(--cs-bg-pill);
	border-color: var(--cs-border);
	color: var(--cs-text-dim);
}

.cs-punish-page .pagination > .active > a,
.cs-punish-page .pagination > .active > span {
	background: var(--cs-accent);
	border-color: var(--cs-accent);
	color: #fff;
}

.cs-punish-modal .glyphicon {
	margin-right: 8px;
	color: var(--cs-text-dim);
}

.cs-punish-modal .cs-stats-modal__body table.table-bordered td,
.cs-punish-modal .cs-stats-modal__body table.table-bordered th {
	padding: 12px 22px;
}

.cs-punish-modal .cs-stats-modal__body table.table-bordered td:first-child {
	width: 40%;
	padding-left: 22px;
	color: var(--cs-text-dim);
	font-weight: 600;
}

.cs-punish-modal .cs-stats-modal__body table.table-bordered td:first-child b {
	color: var(--cs-text-dim);
	font-weight: 600;
}

.cs-punish-modal .modal-footer {
	display: flex;
	justify-content: flex-end;
	gap: 8px;
}

.cs-punish-modal-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.cs-punish-modal__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	padding: 7px 12px;
	border: 1px solid var(--cs-border);
	border-radius: var(--cs-radius-sm);
	background: transparent;
	color: var(--cs-text-dim);
	font-size: 13px;
	line-height: 1.3;
	text-decoration: none;
	cursor: pointer;
	transition: border-color 0.15s, color 0.15s, background 0.15s;
}

.cs-punish-modal__btn:hover {
	border-color: var(--cs-accent);
	color: var(--cs-text);
	background: rgba(92, 108, 255, 0.08);
}

.cs-punish-modal__btn--primary {
	border-color: rgba(92, 108, 255, 0.45);
	background: rgba(92, 108, 255, 0.14);
	color: #c5ceff;
}

.cs-punish-modal__btn--primary:hover {
	border-color: var(--cs-accent);
	background: rgba(92, 108, 255, 0.22);
	color: #fff;
}

.cs-punish-modal__btn--icon {
	min-width: 36px;
	padding: 7px 10px;
	font-size: 16px;
	line-height: 1;
}

.cs-punish-modal__btn--icon .glyphicon {
	top: 0;
	font-size: 13px;
}

.cs-punish-modal-edit {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	max-width: 320px;
}

.cs-punish-modal-input {
	flex: 1 1 180px;
	min-width: 0;
	padding: 8px 12px !important;
	border-radius: var(--cs-radius-sm) !important;
	border: 1px solid var(--cs-border) !important;
	background: rgba(0, 0, 0, 0.22) !important;
	color: var(--cs-text) !important;
	font-size: 13px !important;
	box-shadow: none !important;
	height: auto !important;
}

.cs-punish-modal-edit__actions {
	display: flex;
	gap: 6px;
}

.cs-punish-modal .text-success {
	color: var(--cs-green) !important;
}

.cs-punish-modal .text-danger {
	color: #ef6b6b !important;
}

.cs-punish-modal .text-warning {
	color: #e8b339 !important;
}

@media (max-width: 1100px) {
	.cs-punish-layout {
		grid-template-columns: 1fr;
	}
}

/* Flatpickr — тёмная тема (после files/assets/timepicker/timepicker.css) */
.flatpickr-calendar,
.flatpickr-calendar.animate {
	z-index: 12050 !important;
	background: #252836 !important;
	border: 1px solid var(--cs-border) !important;
	box-shadow: 0 14px 36px rgba(0, 0, 0, 0.5) !important;
	color: #b7bacd !important;
}

.flatpickr-calendar .flatpickr-innerContainer,
.flatpickr-calendar .flatpickr-rContainer,
.flatpickr-calendar .dayContainer {
	background: #252836 !important;
}

.flatpickr-calendar .flatpickr-months {
	border-bottom: 1px solid #2f344d !important;
}

.flatpickr-calendar .flatpickr-months .flatpickr-month,
.flatpickr-calendar .flatpickr-months .flatpickr-prev-month,
.flatpickr-calendar .flatpickr-months .flatpickr-next-month {
	color: #b7bacd !important;
	fill: #b7bacd !important;
}

.flatpickr-calendar .flatpickr-months .flatpickr-prev-month:hover,
.flatpickr-calendar .flatpickr-months .flatpickr-next-month:hover {
	background: #313448 !important;
	color: #fff !important;
}

.flatpickr-calendar .flatpickr-months .flatpickr-prev-month:hover svg,
.flatpickr-calendar .flatpickr-months .flatpickr-next-month:hover svg {
	fill: #fff !important;
}

.flatpickr-calendar .flatpickr-current-month .cur-month,
.flatpickr-calendar .flatpickr-current-month input.cur-year,
.flatpickr-calendar .flatpickr-current-month .flatpickr-monthDropdown-months {
	color: #fff !important;
	background: transparent !important;
}

.flatpickr-calendar span.flatpickr-weekday {
	color: #b7bacd !important;
}

.flatpickr-calendar .flatpickr-day {
	color: #b7bacd !important;
	background: transparent !important;
	border-color: transparent !important;
}

.flatpickr-calendar .flatpickr-day:hover,
.flatpickr-calendar .flatpickr-day:focus,
.flatpickr-calendar .flatpickr-day.today {
	background: rgba(49, 52, 72, 0.85) !important;
	border-color: rgba(49, 52, 72, 0.85) !important;
	color: #fff !important;
}

.flatpickr-calendar .flatpickr-day.selected,
.flatpickr-calendar .flatpickr-day.startRange,
.flatpickr-calendar .flatpickr-day.endRange {
	background: rgba(92, 108, 255, 0.35) !important;
	border-color: rgba(92, 108, 255, 0.45) !important;
	color: #fff !important;
}

.flatpickr-calendar .flatpickr-day.flatpickr-disabled,
.flatpickr-calendar .flatpickr-day.prevMonthDay,
.flatpickr-calendar .flatpickr-day.nextMonthDay {
	color: #56596b !important;
}

.flatpickr-calendar .flatpickr-time {
	border-top: 1px solid #2f344d !important;
	background: #252836 !important;
}

.flatpickr-calendar .flatpickr-time input,
.flatpickr-calendar .flatpickr-time .flatpickr-time-separator,
.flatpickr-calendar .flatpickr-time .flatpickr-am-pm {
	color: #b7bacd !important;
	background: transparent !important;
}

.flatpickr-calendar .numInputWrapper span.arrowUp:after {
	border-bottom-color: #b7bacd !important;
}

.flatpickr-calendar .numInputWrapper span.arrowDown:after {
	border-top-color: #b7bacd !important;
}

.flatpickr-calendar .numInputWrapper span:hover {
	background: #313448 !important;
}

.flatpickr-calendar .numInputWrapper input {
	color: #fff !important;
}

/* ========== EVENTS PAGE ========== */
.cs-events-page {
	min-width: 0;
}

.cs-events-layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 280px;
	gap: 14px;
	align-items: start;
}

.cs-events-list {
	display: flex;
	flex-direction: column;
	gap: 12px;
	padding: 16px 18px 18px;
}

.cs-events-sidebar {
	display: flex;
	flex-direction: column;
	gap: 14px;
	min-width: 0;
}

.cs-events-sidebar .cs-forum-widget__body {
	padding: 14px 16px;
}

.cs-events-category-list {
	margin: 0;
	padding: 0;
	list-style: none;
}

.cs-events-category-list > li > a {
	display: block;
	padding: 9px 12px;
	border-radius: var(--cs-radius-sm);
	color: var(--cs-text-dim);
	font-size: 13px;
	text-decoration: none;
	transition: background 0.15s, color 0.15s;
}

.cs-events-category-list > li > a:hover,
.cs-events-category-list > li.active > a {
	background: rgba(92, 108, 255, 0.1);
	color: var(--cs-text);
	text-decoration: none;
}

.cs-events-category-list > li.active > a {
	background: rgba(92, 108, 255, 0.16);
	color: #a8b8ff;
	font-weight: 600;
}

.cs-event-card {
	display: grid;
	grid-template-columns: 52px minmax(0, 1fr);
	gap: 14px;
	padding: 16px 18px;
	border: 1px solid var(--cs-border);
	border-radius: var(--cs-radius);
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.025) 0%, rgba(255, 255, 255, 0.01) 100%);
	box-shadow: 0 1px 0 rgba(255, 255, 255, 0.02) inset;
	transition: border-color 0.18s, background 0.18s, transform 0.18s;
}

.cs-event-card:hover {
	border-color: rgba(92, 108, 255, 0.28);
	background: linear-gradient(180deg, rgba(92, 108, 255, 0.06) 0%, rgba(255, 255, 255, 0.015) 100%);
}

.cs-event-card__avatar-link {
	display: block;
	width: 52px;
	height: 52px;
	flex-shrink: 0;
	border-radius: 50%;
	overflow: hidden;
	border: 2px solid rgba(92, 108, 255, 0.22);
	transition: border-color 0.18s, box-shadow 0.18s;
}

.cs-event-card:hover .cs-event-card__avatar-link {
	border-color: rgba(92, 108, 255, 0.45);
	box-shadow: 0 0 0 4px rgba(92, 108, 255, 0.08);
}

.cs-event-card__avatar {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.cs-event-card__content {
	min-width: 0;
}

.cs-event-card__head {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 12px 16px;
	margin-bottom: 10px;
}

.cs-event-card__meta {
	display: flex;
	flex-direction: column;
	gap: 4px;
	min-width: 0;
}

.cs-event-card__name {
	display: inline-block;
	max-width: 100%;
	font-size: 15px;
	font-weight: 700;
	line-height: 1.3;
	text-decoration: none;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.cs-event-card__name:hover {
	text-decoration: underline;
}

.cs-event-card__date {
	display: inline-flex;
	align-items: center;
	width: fit-content;
	padding: 3px 9px;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.04);
	border: 1px solid rgba(255, 255, 255, 0.06);
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.02em;
	color: var(--cs-text-dim);
	white-space: nowrap;
}

.cs-event-card__actions {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	flex-shrink: 0;
}

.cs-event-card__link {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 7px 13px;
	border-radius: 999px;
	border: 1px solid rgba(92, 108, 255, 0.35);
	background: rgba(92, 108, 255, 0.12);
	color: #c5ceff;
	font-size: 12px;
	font-weight: 600;
	text-decoration: none;
	white-space: nowrap;
	transition: border-color 0.15s, background 0.15s, color 0.15s;
}

.cs-event-card__link:hover {
	border-color: var(--cs-accent);
	background: rgba(92, 108, 255, 0.22);
	color: #fff;
	text-decoration: none;
}

.cs-event-card__link .glyphicon {
	font-size: 10px;
	margin-top: 1px;
}

.cs-event-card__text {
	padding: 12px 14px;
	border-radius: var(--cs-radius-sm);
	background: rgba(0, 0, 0, 0.18);
	border: 1px solid rgba(255, 255, 255, 0.04);
	color: #b7bacd;
	font-size: 14px;
	line-height: 1.55;
}

.cs-event-card__text a {
	color: var(--cs-accent);
	text-decoration: none;
	font-weight: 600;
}

.cs-event-card__text a:hover {
	color: var(--cs-accent-hover);
	text-decoration: underline;
}

.cs-event-card__delete {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	padding: 0;
	border: 1px solid transparent;
	border-radius: 50%;
	background: transparent;
	color: var(--cs-text-dim);
	cursor: pointer;
	transition: border-color 0.15s, color 0.15s, background 0.15s;
}

.cs-event-card__delete:hover {
	border-color: rgba(232, 93, 93, 0.45);
	color: #f0a8a8;
	background: rgba(232, 93, 93, 0.1);
}

.cs-event-card__delete .glyphicon {
	font-size: 13px;
}

.cs-events-page .pagination > li > a,
.cs-events-page .pagination > li > span {
	background: var(--cs-bg-pill);
	border-color: var(--cs-border);
	color: var(--cs-text-dim);
}

.cs-events-page .pagination > .active > a,
.cs-events-page .pagination > .active > span {
	background: var(--cs-accent);
	border-color: var(--cs-accent);
	color: #fff;
}

@media (max-width: 700px) {
	.cs-event-card {
		grid-template-columns: 44px minmax(0, 1fr);
		gap: 12px;
		padding: 14px;
	}

	.cs-event-card__avatar-link {
		width: 44px;
		height: 44px;
	}

	.cs-event-card__head {
		flex-direction: column;
		align-items: stretch;
	}

	.cs-event-card__actions {
		justify-content: flex-start;
	}
}

@media (max-width: 1100px) {
	.cs-events-layout {
		grid-template-columns: 1fr;
	}
}

/* ========== ADMINS PAGE ========== */
.cs-admins-page {
	min-width: 0;
}

.cs-admins-layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 280px;
	gap: 14px;
	align-items: start;
}

.cs-admins-content {
	min-width: 0;
}

.cs-admins-table-wrap {
	overflow-x: auto;
}

.cs-admins-table {
	width: 100%;
	border-collapse: collapse;
	min-width: 720px;
}

.cs-admins-table thead th {
	padding: 12px 16px;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--cs-text-dim);
	text-align: left;
	background: rgba(255, 255, 255, 0.02);
	border-bottom: 1px solid var(--cs-border);
	white-space: nowrap;
}

.cs-admins-table tbody td {
	padding: 14px 16px;
	border-bottom: 1px solid rgba(255, 255, 255, 0.04);
	color: #b7bacd;
	font-size: 14px;
	vertical-align: middle;
}

.cs-admins-table tbody tr.cs-admins-row:last-of-type td {
	border-bottom-color: rgba(255, 255, 255, 0.04);
}

.cs-admins-table tbody tr.cs-admins-row {
	transition: background 0.15s;
}

.cs-admins-table tbody tr.cs-admins-row:hover {
	background: rgba(255, 255, 255, 0.025);
}

.cs-admins-row--suspended {
	background: rgba(239, 107, 107, 0.04);
}

.cs-admins-row__num {
	width: 56px;
	color: var(--cs-text-dim);
	font-size: 13px;
	font-weight: 600;
}

.cs-admins-user {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	min-width: 0;
	color: var(--cs-text);
	text-decoration: none;
}

.cs-admins-user:hover {
	color: var(--cs-text);
	text-decoration: none;
}

.cs-admins-user--unknown {
	display: inline-flex;
	align-items: center;
	gap: 10px;
}

.cs-admins-user__avatar {
	width: 36px;
	height: 36px;
	border-radius: 50%;
	object-fit: cover;
	border: 1px solid var(--cs-border);
	flex-shrink: 0;
}

.cs-admins-user__name {
	font-size: 14px;
	font-weight: 600;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.cs-admins-id {
	display: inline-block;
	font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
	font-size: 13px;
	color: var(--cs-text-dim);
	word-break: break-all;
}

.cs-admins-warn {
	display: inline-flex;
	margin-left: 8px;
	padding: 0;
	border: none;
	background: transparent;
	color: #ef6b6b;
	font-size: 12px;
	font-weight: 600;
	cursor: pointer;
	text-decoration: underline;
}

.cs-admins-warn:hover {
	color: #f0a8a8;
}

.cs-admins-row__services {
	min-width: 180px;
}

.cs-admins-service {
	display: inline-block;
	margin-right: 8px;
	padding: 4px 10px;
	border-radius: 999px;
	background: rgba(92, 108, 255, 0.1);
	border: 1px solid rgba(92, 108, 255, 0.2);
	color: #aeb8ff;
	font-size: 12px;
	font-weight: 600;
	line-height: 1.3;
	vertical-align: middle;
}

.cs-admins-more {
	display: inline-flex;
	align-items: center;
	padding: 5px 10px;
	border: 1px solid var(--cs-border);
	border-radius: 999px;
	background: transparent;
	color: var(--cs-text-dim);
	font-size: 12px;
	font-weight: 600;
	line-height: 1.2;
	vertical-align: middle;
	cursor: pointer;
	transition: border-color 0.15s, color 0.15s, background 0.15s;
}

.cs-admins-more:hover {
	border-color: var(--cs-accent);
	color: var(--cs-text);
	background: rgba(92, 108, 255, 0.08);
}

.cs-admins-sidebar {
	display: flex;
	flex-direction: column;
	gap: 14px;
	min-width: 0;
}

.cs-admins-sidebar .cs-forum-widget__body {
	padding: 14px 16px;
}

.cs-admins-manage {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 44px;
	padding: 0 16px;
	border-radius: var(--cs-radius-sm);
	border: 1px solid rgba(92, 108, 255, 0.35);
	background: rgba(92, 108, 255, 0.14);
	color: #c5ceff;
	font-size: 14px;
	font-weight: 600;
	text-decoration: none;
	transition: border-color 0.15s, background 0.15s, color 0.15s;
}

.cs-admins-manage:hover {
	border-color: var(--cs-accent);
	background: rgba(92, 108, 255, 0.24);
	color: #fff;
	text-decoration: none;
}

.cs-admins-server-list {
	margin: 0;
	padding: 0;
	list-style: none;
}

.cs-admins-server-list > li > a {
	display: block;
	padding: 9px 12px;
	border-radius: var(--cs-radius-sm);
	color: var(--cs-text-dim);
	font-size: 13px;
	text-decoration: none;
	transition: background 0.15s, color 0.15s;
}

.cs-admins-server-list > li > a:hover,
.cs-admins-server-list > li.active > a {
	background: rgba(92, 108, 255, 0.1);
	color: var(--cs-text);
	text-decoration: none;
}

.cs-admins-server-list > li.active > a {
	background: rgba(92, 108, 255, 0.16);
	color: #a8b8ff;
	font-weight: 600;
}

@media (max-width: 1100px) {
	.cs-admins-layout {
		grid-template-columns: 1fr;
	}
}

.cs-admins-row__badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 28px;
	height: 28px;
	padding: 0 8px;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.04);
	border: 1px solid rgba(255, 255, 255, 0.06);
	color: var(--cs-text-dim);
	font-size: 12px;
	font-weight: 700;
	line-height: 1;
}

.cs-admins-comment {
	display: inline-flex;
	align-items: center;
	margin-left: 8px;
	color: var(--cs-text-dim);
	font-size: 12px;
	vertical-align: middle;
}

.cs-admins-end {
	font-size: 13px;
	color: var(--cs-text-dim);
	white-space: nowrap;
}

.cs-admins-table--manage {
	min-width: 900px;
}

.cs-admins-table--manage .cs-admins-row__action {
	width: 110px;
	white-space: nowrap;
}

.cs-admins-table--manage .cs-admins-row__end {
	min-width: 140px;
}

/* ========== EDIT ADMINS PAGE ========== */
.cs-page-main:has(.cs-edit-admins-page) > .left_block,
.cs-page:has(.cs-edit-admins-page) > .left_block {
	display: none;
}

.cs-page-main:has(.cs-edit-admins-page),
.cs-page:has(.cs-edit-admins-page) {
	grid-template-columns: minmax(0, 1fr);
}

.cs-edit-admins-page {
	min-width: 0;
}

.cs-edit-admins-main {
	display: flex;
	flex-direction: column;
	gap: 14px;
	min-width: 0;
}

.cs-edit-admins-panel .cs-forum-panel__body {
	padding: 16px 18px;
}

.cs-edit-admins-panel--list .cs-forum-panel__body {
	padding: 0;
}

.cs-edit-admins-form {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 14px 16px;
}

.cs-edit-admins-field {
	display: flex;
	flex-direction: column;
	gap: 6px;
	min-width: 0;
}

.cs-edit-admins-label {
	font-size: 12px;
	font-weight: 600;
	color: var(--cs-text-dim);
	line-height: 1.35;
}

.cs-edit-admins-select,
.cs-edit-admins-input {
	width: 100%;
	height: 40px;
	padding: 8px 12px;
	border-radius: var(--cs-radius-sm);
	border: 1px solid var(--cs-border);
	background: var(--cs-bg-pill);
	color: var(--cs-text) !important;
	font-size: 14px;
}

.cs-edit-admins-select:focus,
.cs-edit-admins-input:focus {
	border-color: rgba(92, 108, 255, 0.45);
	box-shadow: 0 0 0 2px rgba(92, 108, 255, 0.12);
	outline: none;
}

.cs-edit-admins-result {
	grid-column: 1 / -1;
}

.cs-edit-admins-actions {
	grid-column: 1 / -1;
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.cs-edit-admins-loader {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 48px 16px;
}

.cs-edit-admins-loader img {
	opacity: 0.7;
}

.cs-edit-admins-server__head {
	padding: 14px 18px;
	border-bottom: 1px solid var(--cs-border);
}

.cs-edit-admins-server__title {
	margin: 0;
	font-size: 15px;
	font-weight: 700;
	color: var(--cs-text);
}

.cs-edit-admins-modal__columns {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 14px;
}

.cs-edit-admins-modal__services-head {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
}

.cs-edit-admins-services-wrap {
	overflow-x: hidden;
}

.cs-edit-admins-services-table {
	width: 100%;
	table-layout: fixed;
}

.cs-edit-admins-services-table th,
.cs-edit-admins-services-table td {
	padding: 10px 8px;
	overflow: hidden;
	vertical-align: middle;
	height: auto;
}

.cs-edit-admins-services-table .cs-edit-admins-service-controls,
.cs-edit-admins-services-table .cs-edit-admins-date-edit {
	height: auto;
}

.cs-edit-admins-services-th {
	white-space: normal;
	line-height: 1.3;
}

.cs-edit-admins-services-th--num,
.cs-edit-admins-services-td--num {
	width: 42px;
}

.cs-edit-admins-services-th--service,
.cs-edit-admins-services-td--service {
	width: 12%;
}

.cs-edit-admins-services-th--rights,
.cs-edit-admins-services-td--rights {
	width: 20%;
}

.cs-edit-admins-services-th--immunity,
.cs-edit-admins-services-td--immunity {
	width: 7%;
}

.cs-edit-admins-services-th--bought,
.cs-edit-admins-services-td--bought {
	width: 13%;
}

.cs-edit-admins-services-th--end,
.cs-edit-admins-services-td--end {
	width: 20%;
}

.cs-edit-admins-services-th--left,
.cs-edit-admins-services-td--left {
	width: 12%;
}

.cs-edit-admins-services-th--action,
.cs-edit-admins-services-td--action {
	width: 44px;
	text-align: center;
}

.cs-edit-admins-modal__services .cs-profile-privilege-modal__date {
	white-space: normal;
	font-size: 11px;
	line-height: 1.35;
}

.cs-edit-admins-modal__services .cs-profile-privilege-modal__badge {
	max-width: 100%;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.cs-edit-admins-service-controls,
.cs-edit-admins-date-edit {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	align-items: center;
	gap: 6px;
	min-width: 0;
	width: 100%;
}

.cs-edit-admins-service-controls select,
.cs-edit-admins-service-controls .form-control:not(.cs-edit-admins-service-input) {
	flex: 1 1 100%;
	width: 100%;
	max-width: 100%;
	min-width: 0;
	height: 32px;
	font-size: 12px;
}

.cs-edit-admins-service-controls__actions {
	display: inline-flex;
	flex-shrink: 0;
	gap: 4px;
}

.cs-edit-admins-icon-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	padding: 0;
	flex-shrink: 0;
	border: 1px solid var(--cs-border);
	border-radius: var(--cs-radius-sm);
	background: var(--cs-bg-pill);
	color: var(--cs-text-dim);
	font-size: 13px;
	line-height: 1;
	cursor: pointer;
	transition: border-color 0.15s, color 0.15s, background 0.15s;
}

.cs-edit-admins-icon-btn:hover {
	border-color: rgba(255, 255, 255, 0.12);
	color: var(--cs-text);
	background: var(--cs-bg-hover);
}

.cs-edit-admins-icon-btn--primary {
	border-color: rgba(92, 108, 255, 0.35);
	background: rgba(92, 108, 255, 0.14);
	color: #c5ceff;
}

.cs-edit-admins-icon-btn--primary:hover {
	border-color: var(--cs-accent);
	background: rgba(92, 108, 255, 0.24);
	color: #fff;
}

.cs-edit-admins-service-input {
	flex: 1 1 72px;
	width: auto;
	min-width: 0;
	max-width: 100%;
	height: 32px !important;
	min-height: 32px;
	max-height: 32px;
	padding: 5px 8px;
	border-radius: var(--cs-radius-sm);
	border: 1px solid var(--cs-border);
	background: var(--cs-bg-card);
	color: var(--cs-text) !important;
	font-size: 12px;
	line-height: 1.2;
	box-sizing: border-box;
}

.cs-edit-admins-services-table #admins_services input.cs-edit-admins-service-input {
	height: 32px !important;
	min-height: 32px;
	max-height: 32px;
	width: auto;
	flex: 1 1 72px;
	cursor: text;
}

.cs-edit-admins-service-input--date {
	min-width: 0;
	font-size: 12px;
}

.cs-edit-admins-icon-btn--danger {
	border-color: rgba(239, 107, 107, 0.35);
	color: #ef9a9a;
}

.cs-edit-admins-icon-btn--danger:hover {
	border-color: rgba(239, 107, 107, 0.55);
	background: rgba(239, 107, 107, 0.12);
	color: #ffb4b4;
}

.cs-edit-admins-service-immunity {
	font-size: 13px;
	color: var(--cs-text-dim);
	white-space: nowrap;
}

.cs-edit-admins-btn--danger {
	border-color: rgba(239, 107, 107, 0.35) !important;
	color: #ef9a9a !important;
}

.cs-edit-admins-btn--danger:hover {
	border-color: rgba(239, 107, 107, 0.55) !important;
	background: rgba(239, 107, 107, 0.12) !important;
	color: #ffb4b4 !important;
}

.cs-store-settings-modal .cs-edit-admins-service-row td p {
	float: none !important;
	margin: 0;
}

@media (max-width: 960px) {
	.cs-edit-admins-form {
		grid-template-columns: 1fr;
	}

	.cs-edit-admins-modal__columns {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 720px) {
	.cs-admins-table--manage {
		min-width: 720px;
	}
}

/* ========== UNBAN APPLICATIONS (BANS) ========== */
.cs-page-main:has(.cs-unban-page) > .left_block,
.cs-page:has(.cs-unban-page) > .left_block,
.cs-page-main > .r_block:has(.cs-unban-page) + .left_block,
.cs-page-main > .r_block:has(.cs-unban-page) ~ .left_block {
	display: none !important;
}

.cs-page-main:has(.cs-unban-page),
.cs-page:has(.cs-unban-page),
.cs-page-main:has(> .r_block .cs-unban-page) {
	grid-template-columns: minmax(0, 1fr) !important;
}

.cs-unban-page {
	min-width: 0;
}

.cs-unban-layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 280px;
	gap: 14px;
	align-items: start;
}

.cs-unban-main,
.cs-unban-detail {
	display: flex;
	flex-direction: column;
	gap: 14px;
	min-width: 0;
}

.cs-unban-table-wrap {
	overflow-x: auto;
}

.cs-unban-table {
	width: 100%;
	border-collapse: collapse;
	min-width: 640px;
}

.cs-unban-table thead th {
	padding: 12px 16px;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--cs-text-dim);
	text-align: left;
	background: rgba(255, 255, 255, 0.02);
	border-bottom: 1px solid var(--cs-border);
	white-space: nowrap;
}

.cs-unban-table tbody td {
	padding: 14px 16px;
	border-bottom: 1px solid rgba(255, 255, 255, 0.04);
	color: #b7bacd;
	font-size: 14px;
	vertical-align: middle;
}

.cs-unban-table tbody tr:last-child td {
	border-bottom-color: rgba(255, 255, 255, 0.04);
}

.cs-unban-table tbody tr.cs-unban-row {
	transition: background 0.15s;
}

.cs-unban-table tbody tr.cs-unban-row:hover {
	background: rgba(255, 255, 255, 0.025);
}

.cs-unban-table .empty-element,
.cs-unban-table .table-row-error {
	display: block;
	padding: 28px 16px;
	text-align: center;
	color: var(--cs-text-dim);
	font-size: 14px;
}

.cs-unban-more {
	display: inline-flex;
	align-items: center;
	padding: 5px 10px;
	border: 1px solid var(--cs-border);
	border-radius: 999px;
	background: transparent;
	color: var(--cs-text-dim);
	font-size: 12px;
	font-weight: 600;
	line-height: 1.2;
	text-decoration: none;
	transition: border-color 0.15s, color 0.15s, background 0.15s;
}

.cs-unban-more:hover {
	border-color: var(--cs-accent);
	color: var(--cs-text);
	background: rgba(92, 108, 255, 0.08);
	text-decoration: none;
}

.cs-unban-user {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	min-width: 0;
	color: var(--cs-text);
	text-decoration: none;
}

.cs-unban-user:hover {
	color: var(--cs-text);
	text-decoration: none;
}

.cs-unban-user__avatar {
	width: 36px;
	height: 36px;
	border-radius: 50%;
	object-fit: cover;
	border: 1px solid var(--cs-border);
	flex-shrink: 0;
}

.cs-unban-user__name {
	font-size: 14px;
	font-weight: 600;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.cs-unban-status {
	display: inline-flex;
	align-items: center;
	padding: 4px 10px;
	border-radius: 999px;
	font-size: 12px;
	font-weight: 600;
	line-height: 1.2;
	white-space: nowrap;
}

.cs-unban-status--success {
	background: rgba(61, 214, 140, 0.12);
	border: 1px solid rgba(61, 214, 140, 0.24);
	color: var(--cs-green);
}

.cs-unban-status--warning {
	background: rgba(240, 180, 41, 0.12);
	border: 1px solid rgba(240, 180, 41, 0.24);
	color: var(--cs-gold);
}

.cs-unban-status--danger {
	background: rgba(255, 123, 123, 0.12);
	border: 1px solid rgba(255, 123, 123, 0.24);
	color: #ff8a8a;
}

.cs-unban-row__date {
	font-size: 13px;
	color: var(--cs-text-dim);
	white-space: nowrap;
}

.cs-unban-link {
	padding: 0;
	border: none;
	background: transparent;
	color: var(--cs-text);
	font-size: 14px;
	text-align: left;
	cursor: pointer;
}

.cs-unban-link:hover {
	color: #a8b8ff;
}

.cs-unban-sidebar {
	display: flex;
	flex-direction: column;
	gap: 14px;
	min-width: 0;
}

.cs-unban-create {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 44px;
	padding: 0 16px;
	border-radius: var(--cs-radius-sm);
	border: 1px solid rgba(92, 108, 255, 0.35);
	background: rgba(92, 108, 255, 0.14);
	color: #c5ceff;
	font-size: 14px;
	font-weight: 600;
	text-decoration: none;
	transition: border-color 0.15s, background 0.15s, color 0.15s;
}

.cs-unban-create:hover {
	border-color: var(--cs-accent);
	background: rgba(92, 108, 255, 0.24);
	color: #fff;
	text-decoration: none;
}

.cs-unban-sidebar .cs-forum-widget__body {
	padding: 14px 16px;
}

.cs-unban-server-list {
	margin: 0;
	padding: 0;
	list-style: none;
}

.cs-unban-server-list > li > a {
	display: block;
	padding: 9px 12px;
	border-radius: var(--cs-radius-sm);
	color: var(--cs-text-dim);
	font-size: 13px;
	text-decoration: none;
	transition: background 0.15s, color 0.15s;
}

.cs-unban-server-list > li > a:hover,
.cs-unban-server-list > li.active > a {
	background: rgba(92, 108, 255, 0.1);
	color: var(--cs-text);
	text-decoration: none;
}

.cs-unban-server-list > li.active > a {
	background: rgba(92, 108, 255, 0.16);
	color: #a8b8ff;
	font-weight: 600;
}

.cs-unban-page .pagination > li > a,
.cs-unban-page .pagination > li > span {
	background: var(--cs-bg-pill);
	border-color: var(--cs-border);
	color: var(--cs-text-dim);
}

.cs-unban-page .pagination > .active > a,
.cs-unban-page .pagination > .active > span {
	background: var(--cs-accent);
	border-color: var(--cs-accent);
	color: #fff;
}

.cs-unban-instructions {
	font-size: 14px;
	line-height: 1.6;
	color: var(--cs-text-dim);
}

.cs-unban-form {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.cs-unban-form-section {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.cs-unban-field {
	display: flex;
	flex-direction: column;
	gap: 6px;
	min-width: 0;
}

.cs-unban-label {
	font-size: 13px;
	font-weight: 600;
	color: var(--cs-text);
	line-height: 1.35;
}

.cs-unban-label-note {
	font-size: 12px;
	font-weight: 500;
	color: var(--cs-text-dim);
}

.cs-unban-required {
	color: #ef9a9a;
	font-weight: 700;
}

.cs-unban-select,
.cs-unban-input,
.cs-unban-textarea {
	width: 100%;
	border-radius: var(--cs-radius-sm);
	border: 1px solid var(--cs-border);
	background: var(--cs-bg-pill);
	color: var(--cs-text) !important;
	font-size: 14px;
}

.cs-unban-select,
.cs-unban-input {
	height: 40px;
	padding: 8px 12px;
}

.cs-unban-textarea {
	min-height: 120px;
	padding: 10px 12px;
	resize: vertical;
}

.cs-unban-select:focus,
.cs-unban-input:focus,
.cs-unban-textarea:focus {
	border-color: rgba(92, 108, 255, 0.45);
	box-shadow: 0 0 0 2px rgba(92, 108, 255, 0.12);
	outline: none;
}

.cs-unban-search {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	align-items: stretch;
}

.cs-unban-search .cs-unban-input {
	flex: 1 1 220px;
	min-width: 0;
}

.cs-unban-search__btn {
	flex-shrink: 0;
}

.cs-unban-upload {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 10px;
	margin-top: 8px;
}

.cs-unban-file {
	max-width: 100%;
	font-size: 13px;
	color: var(--cs-text-dim);
}

.cs-unban-upload__msg {
	width: 100%;
	font-size: 13px;
	color: var(--cs-text-dim);
}

.cs-unban-hint {
	margin: 0;
	font-size: 12px;
	color: var(--cs-text-dim);
}

.cs-unban-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.cs-unban-loader {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 24px 16px;
}

.cs-unban-loader img {
	opacity: 0.7;
}

.cs-unban-search-results:not(.is-open) {
	display: none;
}

.cs-unban-search-results.is-open {
	display: block;
}

.cs-unban-meta {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 12px 16px;
}

.cs-unban-meta__item {
	display: flex;
	flex-direction: column;
	gap: 4px;
	min-width: 0;
}

.cs-unban-meta__item--full {
	grid-column: 1 / -1;
}

.cs-unban-meta__label {
	font-size: 12px;
	font-weight: 600;
	color: var(--cs-text-dim);
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

.cs-unban-meta__value {
	font-size: 14px;
	color: var(--cs-text);
	word-break: break-word;
}

.cs-unban-meta__value a {
	color: #a8b8ff;
}

.cs-unban-text-block {
	display: flex;
	flex-direction: column;
	gap: 8px;
	margin-top: 16px;
	padding-top: 16px;
	border-top: 1px solid rgba(255, 255, 255, 0.05);
}

.cs-unban-text {
	font-size: 14px;
	line-height: 1.6;
	color: var(--cs-text-dim);
}

.cs-unban-actions-bar {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	margin-top: 16px;
	padding-top: 16px;
	border-top: 1px solid rgba(255, 255, 255, 0.05);
}

.cs-unban-admin-actions {
	display: inline-flex;
	flex-wrap: wrap;
	gap: 8px;
}

.cs-unban-btn--danger {
	border-color: rgba(239, 107, 107, 0.35) !important;
	color: #ef9a9a !important;
}

.cs-unban-btn--danger:hover {
	border-color: rgba(239, 107, 107, 0.55) !important;
	background: rgba(239, 107, 107, 0.12) !important;
	color: #ffb4b4 !important;
}

.cs-unban-evidence {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.cs-unban-evidence__block {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.cs-unban-evidence__content {
	font-size: 14px;
	color: var(--cs-text-dim);
}

.cs-unban-empty-note {
	font-size: 13px;
	color: var(--cs-text-dim);
	font-style: italic;
}

.cs-unban-comment-form {
	padding-bottom: 0;
	border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.cs-unban-comment-actions {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	margin-top: 10px;
}

.cs-unban-comments {
	padding-top: 16px;
}

.cs-unban-page #bans p,
.cs-unban-page #search_ban_res_min p {
	margin: 0;
	float: none;
}

.cs-unban-search-full {
	margin-top: 14px;
}

.cs-unban-ban-card {
	overflow: hidden;
	border-radius: var(--cs-radius-sm);
	border: 1px solid rgba(255, 255, 255, 0.05);
	background: var(--cs-bg-pill);
}

.cs-unban-ban-card__head {
	padding: 12px 16px;
	border-bottom: 1px solid rgba(255, 255, 255, 0.05);
	font-size: 13px;
	font-weight: 700;
	color: var(--cs-text);
}

.cs-unban-ban-card__meta {
	padding: 14px 16px 16px;
}

.cs-unban-page .panel.panel-default,
.cs-unban-page #search_ban_res_full .panel {
	background: transparent !important;
	border: none !important;
	box-shadow: none !important;
}

.cs-unban-field--editor .tox.tox-tinymce {
	border: 1px solid var(--cs-border) !important;
	border-radius: var(--cs-radius-sm) !important;
	background: var(--cs-bg-pill) !important;
	box-shadow: none !important;
	overflow: hidden;
}

.cs-unban-field--editor .tox .tox-editor-header {
	background: var(--cs-bg-pill) !important;
	border-bottom: 1px solid var(--cs-border) !important;
}

.cs-unban-field--editor .tox .tox-toolbar-overlord,
.cs-unban-field--editor .tox .tox-toolbar,
.cs-unban-field--editor .tox .tox-toolbar__primary {
	background: transparent !important;
}

.cs-unban-field--editor .tox .tox-tbtn {
	color: var(--cs-text-dim) !important;
}

.cs-unban-field--editor .tox .tox-tbtn svg {
	fill: currentColor !important;
}

.cs-unban-field--editor .tox .tox-edit-area,
.cs-unban-field--editor .tox .tox-sidebar-wrap {
	background: var(--cs-bg-pill) !important;
}

.cs-unban-field--editor .tox .tox-statusbar {
	display: flex !important;
	background: var(--cs-bg-pill) !important;
	border-top: 1px solid var(--cs-border) !important;
	color: var(--cs-text-dim) !important;
}

.cs-unban-field--editor .tox .tox-statusbar__path-item,
.cs-unban-field--editor .tox .tox-statusbar__wordcount,
.cs-unban-field--editor .tox .tox-statusbar a {
	color: var(--cs-text-dim) !important;
}

.cs-unban-page .text-success {
	color: var(--cs-green) !important;
}

.cs-unban-page .text-warning {
	color: var(--cs-gold) !important;
}

.cs-unban-page .text-danger {
	color: #ef6b6b !important;
}

@media (max-width: 1100px) {
	.cs-unban-layout {
		grid-template-columns: 1fr;
	}

	.cs-unban-meta {
		grid-template-columns: 1fr;
	}
}

/* ── Sortition (розыгрыши) ── */

.cs-page-main:has(.cs-sortition-page) > .left_block,
.cs-page:has(.cs-sortition-page) > .left_block {
	display: none !important;
}

.cs-page-main:has(.cs-sortition-page),
.cs-page:has(.cs-sortition-page) {
	grid-template-columns: minmax(0, 1fr) !important;
}

.cs-sortition-page {
	min-width: 0;
}

.cs-sortition-panel__body {
	padding: 20px 22px;
}

.cs-sortition-loader__inner {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 48px 16px;
}

.cs-sortition-loader__inner img {
	opacity: 0.7;
}

.cs-sortition {
	display: flex;
	flex-direction: column;
	gap: 24px;
	text-align: center;
}

.cs-sortition__hero {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 10px;
	padding-bottom: 8px;
}

.cs-sortition__hero--finished {
	padding-top: 4px;
}

.cs-sortition__hero--compact {
	gap: 8px;
	padding-bottom: 0;
}

.cs-sortition__badge {
	display: inline-flex;
	align-items: center;
	padding: 4px 10px;
	border-radius: 999px;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

.cs-sortition__badge--finished {
	background: rgba(239, 107, 107, 0.14);
	border: 1px solid rgba(239, 107, 107, 0.35);
	color: #ef9a9a;
}

.cs-sortition__title {
	margin: 0;
	font-size: clamp(22px, 3vw, 30px);
	font-weight: 700;
	color: var(--cs-text);
	line-height: 1.25;
}

.cs-sortition--lite .cs-sortition__title {
	font-size: 18px;
}

.cs-sortition__subtitle {
	margin: 0;
	font-size: 14px;
	color: var(--cs-text-dim);
}

.cs-sortition__section {
	display: flex;
	flex-direction: column;
	gap: 14px;
	text-align: left;
}

.cs-sortition__section-title {
	margin: 0;
	padding-bottom: 10px;
	border-bottom: 1px solid var(--cs-border);
	font-size: 16px;
	font-weight: 700;
	color: var(--cs-text);
}

.cs-sortition__timer {
	display: inline-flex;
	align-items: stretch;
	justify-content: center;
	gap: 0;
	margin: 8px auto 0;
	padding: 12px 8px;
	border: 1px solid var(--cs-border);
	border-radius: var(--cs-radius);
	background: var(--cs-bg-pill);
}

.cs-sortition__timer span {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	min-width: 88px;
	padding: 0 14px;
	font-size: clamp(28px, 4vw, 42px);
	font-weight: 700;
	line-height: 1;
	color: var(--cs-text);
}

.cs-sortition__timer > span:nth-child(2) {
	border-left: 1px solid var(--cs-border);
	border-right: 1px solid var(--cs-border);
}

.cs-sortition__timer span i {
	margin-top: 6px;
	font-style: normal;
	font-size: 12px;
	font-weight: 600;
	color: var(--cs-text-dim);
	text-transform: lowercase;
}

.cs-sortition__winners-stage {
	padding: 16px;
	background: transparent;
}

.cs-sortition__winners,
.cs-sortition-page #winners,
.cs-sortition #winners.cs-sortition__winners,
#sortition #winners.cs-sortition__winners {
	display: flex !important;
	flex-wrap: wrap !important;
	justify-content: center !important;
	align-items: stretch !important;
	gap: 10px !important;
	margin: 0;
	padding: 0;
	text-align: center;
}

.cs-sortition__winners a,
.cs-sortition-page #winners a,
.cs-sortition #winners.cs-sortition__winners a,
#sortition #winners.cs-sortition__winners a {
	display: flex !important;
	flex: 0 1 calc(50% - 8px) !important;
	flex-direction: column !important;
	align-items: center !important;
	box-sizing: border-box !important;
	width: calc(50% - 8px) !important;
	max-width: 132px !important;
	min-width: 0 !important;
	margin: 0 !important;
	padding: 10px 8px 12px !important;
	border: 1px solid var(--cs-border) !important;
	border-radius: var(--cs-radius-sm) !important;
	background: var(--cs-bg-pill) !important;
	box-shadow: none !important;
	opacity: 1 !important;
	color: var(--cs-text) !important;
	text-decoration: none !important;
	transition: border-color 0.15s, background 0.15s;
}

.cs-sortition__winners a:hover,
.cs-sortition-page #winners a:hover,
.cs-sortition #winners.cs-sortition__winners a:hover,
#sortition #winners.cs-sortition__winners a:hover {
	opacity: 1 !important;
	border-color: rgba(92, 108, 255, 0.4) !important;
	background: var(--cs-bg-hover) !important;
	transform: none;
}

.cs-sortition__winners a:nth-child(1),
.cs-sortition-page #winners a:nth-child(1),
.cs-sortition #winners.cs-sortition__winners a:nth-child(1),
#sortition #winners.cs-sortition__winners a:nth-child(1) {
	border-color: rgba(255, 193, 7, 0.45) !important;
	background: rgba(255, 193, 7, 0.08) !important;
}

.cs-sortition__winners a:nth-child(2),
.cs-sortition-page #winners a:nth-child(2),
.cs-sortition #winners.cs-sortition__winners a:nth-child(2),
#sortition #winners.cs-sortition__winners a:nth-child(2) {
	border-color: rgba(192, 192, 192, 0.45) !important;
	background: rgba(192, 192, 192, 0.08) !important;
}

.cs-sortition__winners a:nth-child(3),
.cs-sortition-page #winners a:nth-child(3),
.cs-sortition #winners.cs-sortition__winners a:nth-child(3),
#sortition #winners.cs-sortition__winners a:nth-child(3) {
	border-color: rgba(205, 127, 50, 0.45) !important;
	background: rgba(205, 127, 50, 0.08) !important;
}

.cs-sortition__winners a i,
.cs-sortition-page #winners a i,
.cs-sortition #winners.cs-sortition__winners a i,
#sortition #winners.cs-sortition__winners a i {
	font-style: normal;
	font-size: 13px;
	font-weight: 700;
	color: var(--cs-text-dim);
	line-height: 1.2;
}

.cs-sortition__winners a img,
.cs-sortition-page #winners a img,
.cs-sortition #winners.cs-sortition__winners a img,
#sortition #winners.cs-sortition__winners a img {
	display: block;
	width: 72px;
	height: 72px;
	margin: 8px auto 10px;
	border: 2px solid rgba(255, 255, 255, 0.12);
	border-radius: 50%;
	object-fit: cover;
	background: rgba(255, 255, 255, 0.04);
}

.cs-sortition__winners--compact a img {
	width: 64px;
	height: 64px;
}

.cs-sortition__winners a span,
.cs-sortition-page #winners a span,
.cs-sortition #winners.cs-sortition__winners a span,
#sortition #winners.cs-sortition__winners a span {
	display: block;
	max-width: 100%;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	font-size: 14px;
	font-weight: 600;
	line-height: 1.25;
	color: var(--cs-text) !important;
}

.cs-sortition__winners--compact a span {
	font-size: 13px;
}

.cs-sortition--finished {
	gap: 0 !important;
}

/* Розыгрыш на главной — промо-карточка */
.cs-home-page #sortition .cs-sortition--empty {
	display: none;
}

.cs-sortition-home {
	position: relative;
	margin-bottom: 0;
	overflow: hidden;
}

.cs-sortition-home::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 3px;
	background: linear-gradient(90deg, var(--cs-green), var(--cs-moon, #7c8cff), var(--cs-accent));
	pointer-events: none;
}

.cs-sortition-home__head {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 8px;
	background: linear-gradient(180deg, rgba(92, 108, 255, 0.07) 0%, transparent 100%);
}

.cs-sortition-home__live {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	padding: 4px 11px;
	border-radius: 999px;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--cs-green);
	background: rgba(76, 175, 80, 0.12);
	border: 1px solid rgba(76, 175, 80, 0.32);
}

.cs-sortition-home__live::before {
	content: '';
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: var(--cs-green);
	box-shadow: 0 0 8px rgba(76, 175, 80, 0.65);
	animation: cs-sortition-pulse 1.8s ease-in-out infinite;
}

@keyframes cs-sortition-pulse {
	0%, 100% { opacity: 1; transform: scale(1); }
	50% { opacity: 0.45; transform: scale(0.82); }
}

.cs-sortition-home__title {
	font-size: clamp(20px, 2.5vw, 24px);
	line-height: 1.25;
}

.cs-sortition-home__body {
	display: flex;
	flex-direction: column;
	gap: 20px;
}

.cs-sortition-home__prizes {
	text-align: left;
}

.cs-sortition-home__prizes h5 {
	display: flex;
	align-items: center;
	gap: 8px;
	margin: 14px 0 8px;
	padding: 0;
	border: none;
	font-size: 12px;
	font-weight: 700;
	color: var(--cs-text-dim);
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

.cs-sortition-home__prizes h5:first-child {
	margin-top: 0;
}

.cs-sortition-home__prizes h5::before {
	content: '';
	width: 8px;
	height: 8px;
	border-radius: 50%;
	flex-shrink: 0;
}

.cs-sortition-home__prizes > h5:nth-of-type(1)::before {
	background: linear-gradient(135deg, #ffd54f, #ffb300);
	box-shadow: 0 0 10px rgba(255, 193, 7, 0.4);
}

.cs-sortition-home__prizes > h5:nth-of-type(2)::before {
	background: linear-gradient(135deg, #eceff1, #90a4ae);
}

.cs-sortition-home__prizes > h5:nth-of-type(3)::before {
	background: linear-gradient(135deg, #ffab91, #bf360c);
}

.cs-sortition-home__prizes .prize {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 2px 10px;
	padding: 13px 16px 13px 44px;
	margin: 0;
	border-radius: var(--cs-radius-sm);
	background: rgba(255, 255, 255, 0.03);
	border: 1px solid var(--cs-border);
	cursor: default;
}

.cs-sortition-home__prizes .prize:hover {
	border-color: var(--cs-border);
	background: rgba(255, 255, 255, 0.03);
}

.cs-sortition-home__prizes .prize i.fa,
.cs-sortition-home__prizes .prize i.fas {
	color: var(--cs-green);
}

.cs-sortition-home__prizes .prize span {
	font-size: 15px;
	font-weight: 600;
}

.cs-sortition-home__prizes .prize span small {
	font-size: 12px;
	font-weight: 500;
}

.cs-sortition-home__prizes .well {
	padding: 13px 16px;
	font-size: 14px;
	line-height: 1.45;
}

.cs-sortition-home__meta {
	margin: 0;
	text-align: center;
	font-size: 13px;
	color: var(--cs-text-dim);
}

.cs-sortition-home__actions {
	display: flex;
	flex-direction: column;
	align-items: stretch;
	gap: 12px;
}

.cs-sortition-home__status {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 12px 14px;
	border-radius: var(--cs-radius-sm);
	border: 1px solid var(--cs-border);
	background: rgba(255, 255, 255, 0.03);
}

.cs-sortition-home__status--joined {
	border-color: rgba(61, 214, 140, 0.35);
	background: linear-gradient(135deg, rgba(61, 214, 140, 0.12) 0%, rgba(61, 214, 140, 0.04) 100%);
}

.cs-sortition-home__status--full {
	border-color: rgba(255, 193, 7, 0.35);
	background: linear-gradient(135deg, rgba(255, 193, 7, 0.1) 0%, rgba(255, 193, 7, 0.03) 100%);
}

.cs-sortition-home__status-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	width: 36px;
	height: 36px;
	border-radius: 50%;
	font-size: 16px;
	font-weight: 800;
	line-height: 1;
}

.cs-sortition-home__status--joined .cs-sortition-home__status-icon {
	color: #0d1a12;
	background: var(--cs-green);
	box-shadow: 0 0 16px rgba(61, 214, 140, 0.35);
}

.cs-sortition-home__status--joined .cs-sortition-home__status-icon::before {
	content: '✓';
}

.cs-sortition-home__status--full .cs-sortition-home__status-icon {
	color: #1a1408;
	background: #ffc107;
	box-shadow: 0 0 14px rgba(255, 193, 7, 0.3);
}

.cs-sortition-home__status--full .cs-sortition-home__status-icon::before {
	content: '!';
}

.cs-sortition-home__status-text {
	display: flex;
	flex-direction: column;
	gap: 2px;
	min-width: 0;
	text-align: left;
}

.cs-sortition-home__status-text strong {
	font-size: 14px;
	font-weight: 700;
	color: var(--cs-text);
	line-height: 1.3;
}

.cs-sortition-home__status-text small {
	font-size: 12px;
	font-weight: 500;
	color: var(--cs-text-dim);
	line-height: 1.35;
}

.cs-sortition-home__status--joined .cs-sortition-home__status-text strong {
	color: #b8f5d4;
}

.cs-sortition-home__cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	padding: 12px 20px;
	font-size: 15px;
	font-weight: 700;
	text-align: center;
	text-decoration: none !important;
}

.cs-sortition-home__cta.cs-btn-primary {
	background: var(--cs-green);
	color: #0d1a12 !important;
}

.cs-sortition-home__cta.cs-btn-primary:hover {
	background: #34c47d;
	color: #0d1a12 !important;
}

.cs-sortition-home--finished .cs-sortition__winners-stage {
	margin: 0;
	padding: 0;
	background: transparent;
}

/* Розыгрыш на главной и на странице /sortition */
.cs-home-page #sortition > .cs-sortition--lite.cs-sortition--finished,
.cs-sortition-panel__body #sortition > .cs-sortition--finished {
	border: 1px solid var(--cs-border);
	border-radius: var(--cs-radius);
	background: var(--cs-bg-card);
	overflow: hidden;
	padding: 0;
	gap: 0;
}

.cs-sortition__lite-head {
	padding: 14px 16px;
	border-bottom: 1px solid var(--cs-border);
	font-size: 15px;
	font-weight: 700;
	color: var(--cs-text);
	background: rgba(255, 255, 255, 0.02);
}

.cs-home-page #sortition .cs-sortition__winners-stage,
.cs-sortition-panel__body .cs-sortition__winners-stage {
	margin: 0;
	border-radius: 0;
	background: transparent;
}

.cs-sortition-panel__body #sortition > .cs-sortition--finished .cs-sortition__section {
	margin: 0;
	padding: 0 16px 16px;
	border: none;
	background: transparent;
}

.cs-sortition-panel__body #sortition > .cs-sortition--finished .cs-sortition__section-title {
	margin: 0 0 12px;
	padding: 14px 0 10px;
	border-bottom: 1px solid var(--cs-border);
}

.cs-home-page #sortition .cs-sortition__hero--compact,
.cs-home-page #sortition .cs-sortition__hero--finished {
	padding: 14px 16px 0;
}

.cs-sortition__prizes {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.cs-sortition__prizes h5 {
	margin: 16px 0 8px;
	padding-bottom: 8px;
	border-bottom: 1px solid var(--cs-border);
	font-size: 15px;
	font-weight: 700;
	color: var(--cs-text);
}

.cs-sortition__prizes h5:first-child {
	margin-top: 0;
}

.cs-sortition__prizes .well {
	margin: 0;
	padding: 14px 16px;
	border: 1px solid var(--cs-border);
	border-radius: var(--cs-radius-sm);
	background: var(--cs-bg-pill) !important;
	color: var(--cs-text);
	text-align: left;
}

.cs-sortition__prizes .prize {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 6px 10px;
	position: relative;
	padding: 12px 14px 12px 42px;
	border: 1px solid var(--cs-border);
	border-radius: var(--cs-radius-sm);
	background: var(--cs-bg-pill);
	cursor: pointer;
	transition: border-color 0.15s, background 0.15s;
}

.cs-sortition__prizes .prize:hover {
	border-color: rgba(92, 108, 255, 0.4);
	background: var(--cs-bg-hover);
}

.cs-sortition__prizes .prize i.fa,
.cs-sortition__prizes .prize i.fas {
	position: absolute;
	left: 14px;
	top: 50%;
	transform: translateY(-50%);
	font-size: 18px;
	color: var(--cs-accent);
}

.cs-sortition__prizes .prize span {
	display: block;
	max-width: 100%;
	margin: 0 !important;
	font-size: 14px;
	line-height: 1.35;
	color: var(--cs-text);
	white-space: normal;
}

.cs-sortition__prizes .prize span small {
	font-size: 12px;
	color: var(--cs-text-dim);
}

.cs-sortition__actions {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 12px;
}

.cs-sortition__actions--compact {
	gap: 10px;
}

.cs-sortition__notice {
	margin: 0;
	max-width: 640px;
	font-size: 14px;
	line-height: 1.45;
	color: var(--cs-text-dim);
}

.cs-sortition__notice--success {
	color: var(--cs-green);
}

.cs-sortition__notice--warning {
	color: var(--cs-gold);
}

.cs-sortition__result {
	width: 100%;
	max-width: 640px;
	text-align: center;
}

.cs-sortition__result p {
	margin: 0;
}

.cs-sortition__more {
	font-size: 13px;
	font-weight: 600;
	color: var(--cs-accent) !important;
}

.cs-sortition__more:hover {
	color: var(--cs-accent-hover) !important;
}

.cs-sortition__participants,
.cs-sortition-page #participants,
.cs-sortition #participants {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	text-align: left;
}

.cs-sortition-page #participants a,
.cs-sortition #participants a,
.cs-sortition__participants a {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 4px 10px 4px 4px;
	border: 1px solid var(--cs-border);
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.04) !important;
	color: var(--cs-text) !important;
	font-size: 13px;
	font-weight: 600;
	text-decoration: none !important;
	transition: border-color 0.15s, background 0.15s;
}

.cs-sortition-page #participants a:hover,
.cs-sortition #participants a:hover,
.cs-sortition__participants a:hover {
	border-color: rgba(92, 108, 255, 0.4);
	background: rgba(92, 108, 255, 0.1) !important;
	color: var(--cs-text) !important;
}

.cs-sortition-page #participants a span,
.cs-sortition #participants a span,
.cs-sortition__participants a span {
	color: var(--cs-text) !important;
}

.cs-sortition-page #participants a img,
.cs-sortition #participants a img,
.cs-sortition__participants a img {
	width: 28px;
	height: 28px;
	border-radius: 50%;
	object-fit: cover;
}

.cs-sortition--empty {
	padding: 24px 0;
}

.cs-sortition__empty {
	margin: 0;
	font-size: 15px;
	color: var(--cs-text-dim);
}

.cs-sortition-page .modal-content,
.cs-sortition .modal-content {
	background: var(--cs-bg-elevated);
	border: 1px solid var(--cs-border);
	border-radius: var(--cs-radius);
	color: var(--cs-text);
	box-shadow: 0 16px 40px rgba(0, 0, 0, 0.45);
}

.cs-sortition-page .modal-header,
.cs-sortition .modal-header {
	border-bottom: 1px solid var(--cs-border);
}

.cs-sortition-page .modal-title,
.cs-sortition .modal-title {
	margin: 0;
	font-size: 16px;
	font-weight: 700;
	color: var(--cs-text);
}

.cs-sortition-page .modal-body,
.cs-sortition .modal-body {
	font-size: 14px;
	line-height: 1.5;
	color: var(--cs-text-dim);
}

.cs-sortition-page .modal-body hr,
.cs-sortition .modal-body hr {
	border-color: var(--cs-border);
}

.cs-sortition-page .text-success,
.cs-sortition .text-success {
	color: var(--cs-green) !important;
}

.cs-sortition-page .text-danger,
.cs-sortition .text-danger {
	color: #ef6b6b !important;
}

@media (max-width: 640px) {
	.cs-sortition-panel__body {
		padding: 16px;
	}

	.cs-sortition__timer span {
		min-width: 72px;
		padding: 0 10px;
	}

	.cs-sortition__winners a,
	.cs-sortition-page #winners a,
	.cs-sortition #winners.cs-sortition__winners a,
	.cs-sortition__winners--compact a,
	#sortition #winners.cs-sortition__winners a {
		flex: 0 1 calc(50% - 6px) !important;
		width: calc(50% - 6px) !important;
		max-width: none !important;
	}

	.cs-sortition__participants,
	.cs-sortition-page #participants,
	.cs-sortition #participants.cs-sortition__participants {
		display: flex !important;
		flex-wrap: wrap !important;
		gap: 8px !important;
	}

	.cs-sortition-page #participants a,
	.cs-sortition #participants.cs-sortition__participants a {
		display: inline-flex !important;
		width: auto !important;
		max-width: 100%;
		margin: 0 !important;
	}
}

/* ── Messages (личные сообщения) ── */

.cs-page-main:has(.cs-messages-page) > .left_block,
.cs-page:has(.cs-messages-page) > .left_block {
	display: none !important;
}

.cs-page-main:has(.cs-messages-page),
.cs-page:has(.cs-messages-page) {
	grid-template-columns: minmax(0, 1fr) !important;
}

.cs-messages-page {
	min-width: 0;
}

.cs-messages-layout {
	display: block;
	height: calc(100vh - var(--cs-header) - 62px);
	max-height: calc(100vh - var(--cs-header) - 62px);
	min-height: 0;
}

.cs-messages-page .cs-messages-panel {
	display: flex;
	flex-direction: column;
	min-height: 0;
	height: 100%;
	max-height: 100%;
	overflow: hidden;
	border-radius: var(--cs-radius);
}

.cs-messages-panel__head {
	display: flex;
	align-items: center;
	min-height: 56px;
	padding: 10px 16px !important;
	flex-shrink: 0;
	border-bottom: 1px solid var(--cs-border);
	background: rgba(255, 255, 255, 0.02);
}

.cs-messages-list-head,
.cs-messages-chat-head {
	display: flex;
	align-items: center;
	width: 100%;
	min-width: 0;
}

.cs-messages-list-head .cs-forum-panel__title {
	margin: 0;
}

.cs-messages-chat-head {
	gap: 10px;
}

.cs-messages-chat-head__back {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	padding: 0;
	border: none;
	border-radius: 50%;
	background: transparent;
	color: var(--cs-text-dim);
	cursor: pointer;
	flex-shrink: 0;
	transition: background 0.15s, color 0.15s;
}

.cs-messages-chat-head__back:hover {
	background: rgba(255, 255, 255, 0.08);
	color: var(--cs-text);
}

.cs-messages-chat-head__profile {
	display: flex;
	align-items: center;
	gap: 12px;
	min-width: 0;
	flex: 1;
	text-decoration: none !important;
	color: inherit;
}

.cs-messages-chat-head__profile:hover .cs-messages-chat-head__name {
	text-decoration: underline;
}

.cs-messages-chat-head__avatar {
	width: 42px;
	height: 42px;
	border-radius: 50%;
	object-fit: cover;
	flex-shrink: 0;
}

.cs-messages-chat-head__info {
	display: flex;
	flex-direction: column;
	gap: 2px;
	min-width: 0;
}

.cs-messages-chat-head__name {
	font-size: 15px;
	font-weight: 700;
	line-height: 1.2;
	color: var(--cs-text);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.cs-messages-chat-head__status {
	font-size: 12px;
	line-height: 1.2;
	color: var(--cs-text-dim);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.cs-messages-chat-head__status--online {
	color: #6ee7a0;
}

.cs-messages-chat-head__status--typing,
.cs-messages-chat-head__status--voice {
	color: #6ee7a0;
}

.cs-messages-panel__body {
	display: flex;
	flex-direction: column;
	flex: 1 1 auto;
	min-height: 0;
	overflow: hidden;
}

.cs-messages-page #place_for_messages,
.cs-messages-page #place_for_messages.dialogs_place {
	flex: 1 1 auto;
	min-height: 0;
	max-height: 100% !important;
}

.cs-messages-page #place_for_messages:not(:has(.cs-messages-chat)) {
	display: block;
	overflow-x: hidden !important;
	overflow-y: auto !important;
	padding: 0;
	height: auto !important;
}

.cs-messages-page #place_for_messages:has(.cs-messages-chat) {
	display: flex;
	flex-direction: column;
	height: 100% !important;
	overflow: hidden !important;
}

.cs-messages-page #place_for_messages .cs-messages-dialog {
	flex-shrink: 0;
}

.cs-messages-dialogs {
	display: flex;
	flex-direction: column;
}

.cs-messages-loader {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 48px 16px;
}

.cs-messages-loader--compact {
	padding: 24px 12px;
}

.cs-messages-loader img {
	opacity: 0.7;
}

.cs-messages-dialog {
	position: relative;
	display: flex;
	align-items: stretch;
	margin: 0;
	border: none;
	border-bottom: 1px solid rgba(255, 255, 255, 0.06);
	border-radius: 0;
	background: transparent;
	overflow: visible;
	transition: background 0.15s;
}

.cs-messages-dialog:last-child {
	border-bottom: none;
}

.cs-messages-dialog--unread {
	background: rgba(92, 108, 255, 0.06);
}

.cs-messages-dialog__open {
	display: flex;
	align-items: center;
	gap: 12px;
	flex: 1;
	min-width: 0;
	padding: 10px 14px;
	border: none;
	background: transparent;
	text-align: left;
	cursor: pointer;
	color: inherit;
}

.cs-messages-dialog__open:hover {
	background: rgba(255, 255, 255, 0.04);
}

.cs-messages-dialog:hover .cs-messages-dialog__open {
	padding-right: 44px;
}

.cs-messages-dialog__avatar {
	width: 52px;
	height: 52px;
	border-radius: 50%;
	object-fit: cover;
	flex-shrink: 0;
	border: none !important;
	padding: 0 !important;
	background: none !important;
	float: none !important;
}

.cs-messages-dialog__main {
	display: flex;
	flex-direction: column;
	justify-content: center;
	gap: 4px;
	min-width: 0;
	flex: 1;
}

.cs-messages-dialog__row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
	min-width: 0;
}

.cs-messages-dialog__row--bottom {
	align-items: flex-end;
}

.cs-messages-dialog__name {
	font-size: 15px;
	font-weight: 700;
	line-height: 1.2;
	color: var(--cs-text);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.cs-messages-dialog__date {
	flex-shrink: 0;
	font-size: 12px;
	line-height: 1.2;
	color: var(--cs-text-dim);
	white-space: nowrap;
}

.cs-messages-dialog__aside {
	display: inline-flex;
	align-items: center;
	justify-content: flex-end;
	gap: 4px;
	flex-shrink: 0;
}

.cs-messages-dialog__status {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	line-height: 0;
	color: var(--cs-text-dim);
}

.cs-messages-dialog__status--read {
	color: #8aa4ff;
}

.cs-messages-dialog__status--sent .cs-messages-dialog__status-icon {
	width: 13px;
	height: 13px;
}

.cs-messages-dialog__status--read .cs-messages-dialog__status-icon {
	width: 17px;
	height: 13px;
}

.cs-messages-dialog__status-icon {
	display: block;
	flex-shrink: 0;
}

.cs-messages-dialog--unread .cs-messages-dialog__date {
	color: #8aa4ff;
}

.cs-messages-dialog__preview {
	flex: 1;
	min-width: 0;
	font-size: 13px;
	line-height: 1.35;
	color: var(--cs-text-dim);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.cs-messages-dialog--unread .cs-messages-dialog__preview {
	color: var(--cs-text);
	font-weight: 500;
}

.cs-messages-dialog__preview--mine,
.cs-messages-dialog__preview--sent {
	color: var(--cs-text-dim);
}

.cs-messages-dialog__badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 22px;
	height: 22px;
	padding: 0 6px;
	border-radius: 999px;
	background: #7c6cf0;
	color: #fff;
	font-size: 12px;
	font-weight: 700;
	line-height: 1;
	flex-shrink: 0;
}

.cs-messages-dialog__delete {
	position: absolute;
	top: 50%;
	right: 10px;
	z-index: 2;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	margin-top: -16px;
	padding: 0;
	border: none;
	border-radius: 50%;
	background: rgba(20, 22, 32, 0.92);
	color: var(--cs-text-dim);
	cursor: pointer;
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.15s, color 0.15s, background 0.15s;
}

.cs-messages-dialog:hover .cs-messages-dialog__delete {
	opacity: 1;
	pointer-events: auto;
}

.cs-messages-dialog__delete:hover {
	background: rgba(239, 107, 107, 0.18);
	color: #ef9a9a;
}

.cs-messages-sidebar {
	display: flex;
	flex-direction: column;
	gap: 14px;
	min-width: 0;
}

.cs-messages-companions-wrap {
	padding: 0 !important;
	flex: 1 1 auto;
	min-height: 0;
	display: flex;
	flex-direction: column;
	overflow: hidden;
}

.cs-messages-companions {
	display: flex;
	flex-direction: column;
	gap: 6px;
	flex: 1 1 auto;
	min-height: 0;
	max-height: none;
	overflow-x: hidden;
	overflow-y: auto;
	padding: 10px 12px;
	overscroll-behavior: contain;
	scrollbar-width: thin;
	scrollbar-color: rgba(255, 255, 255, 0.18) transparent;
}

.cs-messages-companions::-webkit-scrollbar {
	width: 6px;
}

.cs-messages-companions::-webkit-scrollbar-thumb {
	background: rgba(255, 255, 255, 0.16);
	border-radius: 999px;
}

.cs-messages-companions::-webkit-scrollbar-thumb:hover {
	background: rgba(255, 255, 255, 0.28);
}

.cs-messages-companion {
	display: flex;
	align-items: stretch;
	gap: 0;
	flex-shrink: 0;
	border: 1px solid var(--cs-border);
	border-radius: var(--cs-radius-sm);
	background: var(--cs-bg-pill);
	margin: 0 !important;
	width: auto !important;
	overflow: hidden;
	transition: border-color 0.15s, background 0.15s;
}

.cs-messages-companion:hover {
	border-color: rgba(92, 108, 255, 0.35);
	background: var(--cs-bg-hover);
}

.cs-messages-companion__open {
	display: flex;
	align-items: center;
	gap: 10px;
	flex: 1;
	min-width: 0;
	padding: 8px 10px;
	border: none;
	background: transparent;
	text-align: left;
	cursor: pointer;
	color: inherit;
}

.cs-messages-companion__avatar {
	display: block !important;
	width: 40px !important;
	height: 40px !important;
	border-radius: 50%;
	object-fit: cover;
	flex-shrink: 0;
	float: none !important;
	margin: 0 !important;
}

.cs-messages-companion__body {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 2px;
	min-width: 0;
	flex: 1;
}

.cs-messages-companion__name {
	font-size: 13px;
	font-weight: 700;
	line-height: 1.3;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	max-width: 100%;
}

.cs-messages-companion__hint {
	font-size: 11px;
	line-height: 1.3;
	color: var(--cs-text-dim);
}

.cs-messages-companion__open:hover .cs-messages-companion__hint {
	color: var(--cs-accent);
}

.cs-messages-companion__profile {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	flex-shrink: 0;
	border: none;
	border-left: 1px solid var(--cs-border);
	background: transparent;
	color: var(--cs-text-dim);
	text-decoration: none !important;
	font-size: 13px;
	transition: background 0.15s, color 0.15s;
}

.cs-messages-companion__profile:hover {
	background: rgba(92, 108, 255, 0.1);
	color: var(--cs-accent);
}

.cs-messages-drop,
.cs-messages-chat-form,
.cs-messages-chat {
	display: flex;
	flex-direction: column;
	flex: 1 1 auto;
	min-height: 0;
	overflow: hidden;
}

.cs-messages-page #drop_zone {
	flex: 1 1 auto;
	min-height: 0;
	overflow: hidden;
}

.cs-messages-log,
.cs-messages-page #messages {
	flex: 1 1 auto;
	min-height: 0;
	height: 0 !important;
	max-height: none !important;
	overflow-x: hidden !important;
	overflow-y: auto !important;
	padding: 12px 14px;
	display: grid !important;
	grid-template-columns: minmax(0, 1fr);
	justify-items: start;
	align-content: start;
	gap: 6px;
	background: rgba(0, 0, 0, 0.12);
	overscroll-behavior: contain;
	scrollbar-width: thin;
	scrollbar-color: rgba(255, 255, 255, 0.18) transparent;
}

.cs-messages-log::-webkit-scrollbar,
.cs-messages-page #messages::-webkit-scrollbar {
	width: 6px;
}

.cs-messages-log::-webkit-scrollbar-thumb,
.cs-messages-page #messages::-webkit-scrollbar-thumb {
	background: rgba(255, 255, 255, 0.16);
	border-radius: 999px;
}

.cs-messages-page #messages .cs-messages-bubble {
	display: inline-flex !important;
	align-items: flex-end;
	width: max-content;
	max-width: min(88%, 640px);
	margin: 0;
	height: auto !important;
	overflow: visible !important;
	float: none !important;
	justify-self: start;
}

.cs-messages-page #messages .cs-messages-bubble--own {
	justify-self: end;
}

.cs-messages-bubble__content {
	display: flex;
	flex-direction: column;
	flex: 0 0 auto;
	width: max-content;
	max-width: min(calc(88vw - 80px), 580px);
}

.cs-messages-bubble__text {
	position: relative;
	display: inline-block;
	width: fit-content;
	max-width: min(calc(88vw - 80px), 580px);
	padding: 7px 11px 8px;
	border-radius: 14px 14px 14px 4px;
	border: none;
	background: #2a3148;
	font-size: 14px;
	line-height: 1.35;
	color: var(--cs-text);
	word-break: break-word;
	box-shadow: 0 1px 1px rgba(0, 0, 0, 0.18);
}

.cs-messages-bubble--own .cs-messages-bubble__text {
	border-radius: 14px 14px 4px 14px;
	background: linear-gradient(145deg, #5c6cff 0%, #7a6cf0 100%);
	color: #fff;
}

.cs-messages-bubble__body {
	display: inline;
}

.cs-messages-bubble__body .g_smile {
	vertical-align: -4px;
}

.cs-messages-bubble__tail {
	float: right;
	clear: right;
	display: inline-flex;
	align-items: center;
	gap: 4px;
	margin-left: 12px;
	margin-top: 1px;
	min-height: 16px;
	vertical-align: bottom;
	position: relative;
	top: 3px;
	white-space: nowrap;
	user-select: none;
}

.cs-messages-bubble__meta {
	display: inline-flex;
	align-items: center;
	justify-content: flex-end;
	gap: 3px;
	line-height: 1;
}

.cs-messages-bubble__time {
	font-size: 11px;
	line-height: 11px;
	color: rgba(255, 255, 255, 0.48);
	font-style: normal;
	font-weight: 500;
	margin: 0;
	cursor: default;
}

.cs-messages-bubble--own .cs-messages-bubble__time {
	color: rgba(255, 255, 255, 0.72);
}

.cs-messages-bubble__status {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	line-height: 0;
	margin-top: 1px;
}

.cs-messages-bubble__status--sent {
	color: rgba(255, 255, 255, 0.78);
}

.cs-messages-bubble--own .cs-messages-bubble__status--sent {
	color: rgba(255, 255, 255, 0.82);
}

.cs-messages-bubble__status--read,
.cs-messages-bubble--own .cs-messages-bubble__status--read {
	color: #fff;
}

.cs-messages-bubble__status--sent .cs-messages-bubble__status-icon {
	width: 14px;
	height: 14px;
}

.cs-messages-bubble__status--read .cs-messages-bubble__status-icon {
	width: 19px;
	height: 14px;
}

.cs-messages-bubble__status-icon {
	display: block;
	flex-shrink: 0;
}

.cs-messages-bubble__edited {
	font-size: 10px;
	line-height: 1;
	color: rgba(255, 255, 255, 0.48);
	font-style: italic;
	font-weight: 500;
}

.cs-messages-bubble--own .cs-messages-bubble__edited {
	color: rgba(255, 255, 255, 0.72);
}

.cs-messages-bubble__actions {
	display: inline-flex;
	align-items: center;
	gap: 0;
	margin-left: 2px;
	opacity: 0;
	transition: opacity 0.15s;
}

.cs-messages-bubble:hover .cs-messages-bubble__actions,
.cs-messages-bubble:focus-within .cs-messages-bubble__actions {
	opacity: 1;
}

.cs-messages-bubble__action {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 18px;
	height: 18px;
	padding: 0;
	border: none;
	border-radius: 4px;
	background: transparent;
	color: rgba(255, 255, 255, 0.55);
	cursor: pointer;
	transition: background 0.15s, color 0.15s;
}

.cs-messages-bubble__action .glyphicon {
	position: static;
	font-size: 10px;
	line-height: 1;
}

.cs-messages-bubble__action:hover {
	background: rgba(255, 255, 255, 0.12);
	color: #fff;
}

.cs-messages-bubble__action--delete:hover {
	background: rgba(239, 107, 107, 0.22);
	color: #ffcdd2;
}

.cs-messages-bubble__action--save,
.cs-messages-bubble__action--save:hover {
	background: rgba(255, 255, 255, 0.18);
	color: #fff;
}

.cs-messages-bubble__edit {
	width: 100%;
	min-width: min(220px, 100%);
	max-width: min(calc(88vw - 80px), 580px);
	min-height: 72px;
	margin-top: 2px;
	padding: 10px 12px;
	border-radius: 14px;
	border: 1px solid rgba(92, 108, 255, 0.35);
	background: var(--cs-bg-pill);
	color: var(--cs-text);
	font-size: 14px;
	line-height: 1.35;
	resize: vertical;
}

.cs-messages-page #messages .cs-messages-bubble--media,
.cs-messages-page #messages .cs-messages-bubble--sticker {
	width: max-content;
	max-width: min(320px, 88%);
}

.cs-messages-bubble--media .cs-messages-bubble__content,
.cs-messages-bubble--sticker .cs-messages-bubble__content {
	width: max-content;
	max-width: min(320px, 100%);
}

.cs-messages-bubble--sticker .cs-messages-bubble__text,
.cs-messages-bubble--media .cs-messages-bubble__text,
.cs-messages-bubble__text:has(> .cs-messages-bubble__body > a.thumbnail:only-child),
.cs-messages-bubble__text:has(> .cs-messages-bubble__body > .cs-messages-photo:only-child) {
	padding: 0;
	background: transparent !important;
	box-shadow: none;
	border-radius: 0;
	display: inline-grid;
	grid-template-columns: minmax(0, max-content);
	grid-template-rows: minmax(0, max-content);
	width: max-content;
	max-width: min(320px, 100%);
	position: relative;
}

.cs-messages-bubble--sticker .cs-messages-bubble__body,
.cs-messages-bubble--media .cs-messages-bubble__body,
.cs-messages-bubble__text:has(> .cs-messages-bubble__body > a.thumbnail:only-child) > .cs-messages-bubble__body,
.cs-messages-bubble__text:has(> .cs-messages-bubble__body > .cs-messages-photo:only-child) > .cs-messages-bubble__body {
	display: block;
	line-height: 0;
	grid-column: 1;
	grid-row: 1;
	min-width: 0;
}

.cs-messages-bubble--sticker .cs-messages-bubble__tail,
.cs-messages-bubble--media .cs-messages-bubble__tail,
.cs-messages-bubble__text:has(> .cs-messages-bubble__body > a.thumbnail:only-child) > .cs-messages-bubble__tail,
.cs-messages-bubble__text:has(> .cs-messages-bubble__body > .cs-messages-photo:only-child) > .cs-messages-bubble__tail {
	float: none;
	position: static;
	grid-column: 1;
	grid-row: 1;
	align-self: end;
	justify-self: end;
	margin: 0 6px 6px 0;
	padding: 2px 7px;
	border-radius: 999px;
	background: rgba(8, 10, 16, 0.58);
	backdrop-filter: blur(4px);
	z-index: 1;
	pointer-events: none;
}

.cs-messages-bubble--sticker .cs-messages-bubble__tail > *,
.cs-messages-bubble--media .cs-messages-bubble__tail > *,
.cs-messages-bubble__text:has(> .cs-messages-bubble__body > a.thumbnail:only-child) > .cs-messages-bubble__tail > *,
.cs-messages-bubble__text:has(> .cs-messages-bubble__body > .cs-messages-photo:only-child) > .cs-messages-bubble__tail > * {
	pointer-events: auto;
}

.cs-messages-bubble--sticker .cs-messages-bubble__time,
.cs-messages-bubble--media .cs-messages-bubble__time,
.cs-messages-bubble--sticker .cs-messages-bubble__edited,
.cs-messages-bubble--media .cs-messages-bubble__edited {
	color: rgba(255, 255, 255, 0.88);
}

.cs-messages-bubble--sticker .cs-messages-bubble__text .g_sticker {
	display: block;
	max-width: min(280px, 100%) !important;
	border-radius: 12px;
}

.cs-messages-bubble--media .cs-messages-bubble__text .thumbnail,
.cs-messages-bubble--media .cs-messages-bubble__text a.thumbnail,
.cs-messages-bubble__text:has(> .cs-messages-bubble__body > a.thumbnail:only-child) .thumbnail,
.cs-messages-bubble__text:has(> .cs-messages-bubble__body > a.thumbnail:only-child) a.thumbnail,
.cs-messages-bubble--media .cs-messages-bubble__text .cs-messages-photo,
.cs-messages-bubble__text:has(> .cs-messages-bubble__body > .cs-messages-photo:only-child) .cs-messages-photo {
	display: block;
	max-width: min(320px, 100%);
	border-radius: 12px;
	overflow: hidden;
}

.cs-messages-bubble--media .cs-messages-bubble__text .thumbnail-img,
.cs-messages-bubble--media .cs-messages-bubble__text .cs-messages-video,
.cs-messages-bubble__text:has(> .cs-messages-bubble__body > a.thumbnail:only-child) .thumbnail-img,
.cs-messages-bubble__text:has(> .cs-messages-bubble__body > .cs-messages-photo:only-child) .cs-messages-photo__img {
	display: block;
	max-width: min(320px, 100%) !important;
	width: auto !important;
	height: auto !important;
	border-radius: 12px;
	vertical-align: top;
}

/* Фото + текст в одном сообщении — без «уезжающего» времени */
.cs-messages-bubble__text:has(.thumbnail):not(:has(> .cs-messages-bubble__body > a.thumbnail:only-child)),
.cs-messages-bubble__text:has(.cs-messages-photo):not(:has(> .cs-messages-bubble__body > .cs-messages-photo:only-child)) {
	display: inline-flex;
	flex-direction: column;
	align-items: flex-start;
	width: max-content;
	max-width: min(calc(88vw - 80px), 580px);
}

.cs-messages-bubble__text:has(.thumbnail):not(:has(> .cs-messages-bubble__body > a.thumbnail:only-child)) .cs-messages-bubble__body,
.cs-messages-bubble__text:has(.cs-messages-photo):not(:has(> .cs-messages-bubble__body > .cs-messages-photo:only-child)) .cs-messages-bubble__body {
	display: block;
	line-height: 1.35;
}

.cs-messages-bubble__text:has(.thumbnail):not(:has(> .cs-messages-bubble__body > a.thumbnail:only-child)) .cs-messages-bubble__tail,
.cs-messages-bubble__text:has(.cs-messages-photo):not(:has(> .cs-messages-bubble__body > .cs-messages-photo:only-child)) .cs-messages-bubble__tail {
	float: none;
	position: static;
	align-self: flex-end;
	margin: 4px 0 0;
	top: auto;
}

.cs-messages-bubble__text a {
	color: var(--cs-accent);
}

.cs-messages-bubble--own .cs-messages-bubble__text a {
	color: rgba(255, 255, 255, 0.95);
}

.cs-messages-bubble__text .thumbnail,
.cs-messages-bubble__text a.thumbnail {
	display: block;
	max-width: min(280px, 100%);
	padding: 0 !important;
	margin: 0 !important;
	background: transparent !important;
	border: none !important;
	border-radius: var(--cs-radius-sm);
	line-height: 0;
	box-shadow: none !important;
	overflow: hidden;
}

.cs-messages-bubble__text a.thumbnail:hover,
.cs-messages-bubble__text a.thumbnail:focus,
.cs-messages-bubble__text a.thumbnail.active {
	background: transparent !important;
	border: none !important;
	opacity: 0.92;
}

.cs-messages-bubble__text .thumbnail-img,
.cs-messages-bubble__text .g_sticker,
.cs-messages-bubble__text img:not(.g_smile) {
	max-width: min(280px, 100%) !important;
	width: auto !important;
	height: auto !important;
	border-radius: var(--cs-radius-sm);
	display: block;
	vertical-align: middle;
}

.cs-messages-photo {
	position: relative;
	display: block;
	max-width: min(320px, 100%);
	border-radius: 12px;
	overflow: hidden;
	line-height: 0;
}

.cs-messages-photo__img {
	display: block;
	max-width: 100%;
	height: auto;
	border-radius: 12px;
}

.cs-messages-photo__download {
	position: absolute;
	top: 8px;
	right: 8px;
	z-index: 2;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 34px;
	height: 34px;
	border-radius: 50%;
	background: rgba(8, 10, 16, 0.62);
	color: rgba(255, 255, 255, 0.95);
	text-decoration: none;
	opacity: 0;
	transition: opacity 0.15s ease, background 0.15s ease;
	backdrop-filter: blur(4px);
}

.cs-messages-photo__download svg {
	width: 18px;
	height: 18px;
}

.cs-messages-photo:hover .cs-messages-photo__download,
.cs-messages-photo:focus-within .cs-messages-photo__download {
	opacity: 1;
}

.cs-messages-photo__download:hover {
	background: rgba(8, 10, 16, 0.82);
	color: #fff;
}

@media (hover: none) {
	.cs-messages-photo__download {
		opacity: 1;
	}
}

.cs-messages-bubble__text .g_sticker,
.cs-messages-page #messages .g_sticker,
.cs-chat-rail #chat_messages .g_sticker,
.cs-messages-page #messages .g_smile,
.cs-messages-bubble__text .g_smile {
	-webkit-user-drag: none;
	user-select: none;
	-webkit-user-select: none;
	-moz-user-select: none;
	pointer-events: auto;
}

.cs-messages-bubble__text .g_smile {
	width: 20px !important;
	height: 20px !important;
}

.cs-messages-compose {
	display: flex;
	flex-direction: row;
	align-items: flex-end;
	gap: 10px;
	padding: 10px 14px 12px;
	border-top: 1px solid var(--cs-border);
	background: rgba(12, 14, 20, 0.96);
	flex-shrink: 0;
}

.cs-messages-compose-main {
	display: flex;
	flex-direction: row;
	align-items: flex-end;
	gap: 10px;
	flex: 1;
	min-width: 0;
}

.cs-messages-voice-recorder {
	display: flex;
	align-items: center;
	gap: 10px;
	flex: 1;
	min-width: 0;
	width: 100%;
}

.cs-messages-voice-recorder__discard {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 42px;
	height: 42px;
	min-width: 42px;
	padding: 0;
	border: none;
	border-radius: 50%;
	background: transparent;
	color: #ff6b6b;
	cursor: pointer;
	flex-shrink: 0;
	align-self: center;
	transition: background 0.15s, transform 0.15s;
}

.cs-messages-voice-recorder__discard svg {
	width: 22px;
	height: 22px;
}

.cs-messages-voice-recorder__discard:hover {
	background: rgba(255, 107, 107, 0.12);
	transform: scale(1.04);
}

.cs-messages-voice-recorder__track {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 10px;
	flex: 1;
	min-width: 0;
	height: 42px;
	padding: 0 8px;
	border-radius: 22px;
	background: #2a3148;
	box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.04);
	overflow: hidden;
}

.cs-messages-voice-recorder__dot,
.cs-messages-voice-recorder__play {
	flex-shrink: 0;
}

.cs-messages-voice-recorder__dot {
	width: 10px;
	height: 10px;
	min-width: 10px;
	border-radius: 50%;
	background: #ff4d4f;
	box-shadow: 0 0 0 4px rgba(255, 77, 79, 0.18);
	flex-shrink: 0;
	animation: cs-pm-voice-pulse 1.2s ease-in-out infinite;
}

.cs-messages-voice-recorder__time {
	flex-shrink: 0;
	font-size: 13px;
	line-height: 1;
	font-variant-numeric: tabular-nums;
	color: rgba(255, 255, 255, 0.92);
	white-space: nowrap;
	min-width: 54px;
	text-align: right;
}

.cs-messages-voice-recorder__pause {
	flex-shrink: 0;
}

@keyframes cs-pm-voice-pulse {
	0%, 100% { opacity: 1; transform: scale(1); }
	50% { opacity: 0.72; transform: scale(0.92); }
}

.cs-messages-voice-recorder__play,
.cs-messages-voice-recorder__pause {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	min-width: 28px;
	padding: 0;
	border: none;
	border-radius: 50%;
	cursor: pointer;
	flex-shrink: 0;
	transition: background 0.15s, transform 0.15s;
}

.cs-messages-voice-recorder__play {
	background: linear-gradient(145deg, #5c6cff 0%, #7a6cf0 100%);
	color: #fff;
}

.cs-messages-voice-recorder__play svg {
	width: 14px;
	height: 14px;
	margin-left: 2px;
}

.cs-messages-voice-recorder__pause {
	background: rgba(255, 255, 255, 0.08);
	color: rgba(255, 255, 255, 0.72);
}

.cs-messages-voice-recorder__pause svg {
	width: 14px;
	height: 14px;
}

.cs-messages-voice-recorder__play:hover,
.cs-messages-voice-recorder__pause:hover {
	transform: scale(1.05);
}

.cs-messages-voice-recorder__wave {
	flex: 0 1 auto;
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 2px;
	min-width: 0;
	max-width: 168px;
	height: 28px;
	max-height: 28px;
	overflow: hidden;
}

.cs-messages-voice-recorder__bar {
	flex: 0 0 3px;
	width: 3px;
	min-height: 4px;
	border-radius: 999px;
	background: #9b8cff;
	opacity: 0.95;
	align-self: center;
}

.cs-messages-voice-recorder__bar.is-dot {
	flex-basis: 4px;
	width: 4px;
	min-height: 4px;
	height: 4px !important;
	border-radius: 50%;
	opacity: 0.45;
}

.cs-messages-voice-recorder.is-paused .cs-messages-voice-recorder__bar {
	background: #9b8cff;
}

.cs-messages-voice-recorder__send {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 42px;
	height: 42px;
	min-width: 42px;
	margin: 0 !important;
	padding: 0;
	border: none;
	border-radius: 50%;
	background: linear-gradient(145deg, #5c6cff 0%, #7a6cf0 100%);
	color: #fff;
	cursor: pointer;
	flex-shrink: 0;
	align-self: center;
	transition: transform 0.15s, opacity 0.15s;
}

.cs-messages-voice-recorder__mic {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 42px;
	height: 42px;
	min-width: 42px;
	padding: 0;
	border: none;
	border-radius: 50%;
	background: transparent;
	color: rgba(255, 255, 255, 0.55);
	cursor: pointer;
	flex-shrink: 0;
	align-self: center;
	transition: color 0.15s, background 0.15s, transform 0.15s;
}

.cs-messages-voice-recorder__mic svg {
	width: 22px;
	height: 22px;
}

.cs-messages-voice-recorder__mic:hover {
	color: rgba(255, 255, 255, 0.88);
	background: rgba(255, 255, 255, 0.06);
	transform: scale(1.04);
}

.cs-messages-voice-recorder__send .glyphicon {
	font-size: 14px;
	line-height: 1;
	margin-left: 2px;
}

.cs-messages-voice-recorder__send:hover {
	opacity: 0.92;
	transform: scale(1.04);
}

.cs-messages-voice-recorder.is-paused .cs-messages-voice-recorder__dot,
.cs-messages-voice-recorder.is-paused .cs-messages-voice-recorder__pause {
	display: none !important;
}

.cs-messages-voice-recorder.is-recording .cs-messages-voice-recorder__play,
.cs-messages-voice-recorder.is-recording .cs-messages-voice-recorder__mic {
	display: none !important;
}

.cs-messages-compose-bar {
	display: flex;
	align-items: flex-end;
	flex: 1;
	min-width: 0;
	background: #2a3148;
	border-radius: 22px;
	padding: 4px 6px 4px 4px;
	gap: 2px;
}

.cs-messages-compose-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 34px;
	height: 34px;
	min-width: 34px;
	margin: 0;
	padding: 0;
	border: none;
	border-radius: 50%;
	background: transparent;
	color: rgba(255, 255, 255, 0.72);
	cursor: pointer;
	flex-shrink: 0;
	transition: color 0.15s, background 0.15s;
}

.cs-messages-compose-icon:hover {
	color: #fff;
	background: rgba(255, 255, 255, 0.08);
}

.cs-messages-compose-icon .glyphicon {
	font-size: 17px;
	line-height: 1;
	transform: rotate(-45deg);
}

.cs-messages-input-wrap {
	position: relative;
	display: flex;
	align-items: stretch;
	flex: 1;
	min-width: 0;
}

.cs-messages-page #personal_message_input,
.cs-messages-input {
	width: 100% !important;
	min-width: 0 !important;
	max-width: 100% !important;
	min-height: 34px !important;
	max-height: 120px !important;
	height: 34px !important;
	padding: 7px 42px 7px 6px !important;
	resize: none;
	background: transparent !important;
	border: none !important;
	border-radius: 0 !important;
	color: var(--cs-text) !important;
	font-size: 14px !important;
	line-height: 1.35 !important;
	box-shadow: none !important;
}

.cs-messages-page #personal_message_input:focus,
.cs-messages-input:focus {
	outline: none;
	box-shadow: none !important;
}

.cs-messages-compose-bar:focus-within {
	box-shadow: 0 0 0 1px rgba(92, 108, 255, 0.35);
}

.cs-messages-smile {
	position: absolute;
	right: 4px;
	bottom: 4px;
}

.cs-messages-page #send_button,
.cs-messages-send,
.cs-messages-voice {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 42px;
	height: 42px;
	min-width: 42px;
	margin: 0 !important;
	padding: 0;
	border: none;
	border-radius: 50%;
	background: linear-gradient(145deg, #5c6cff 0%, #7a6cf0 100%);
	color: #fff;
	cursor: pointer;
	flex-shrink: 0;
	transition: transform 0.15s, opacity 0.15s, background 0.15s;
}

.cs-messages-page #send_button:hover,
.cs-messages-send:hover,
.cs-messages-voice:hover {
	opacity: 0.92;
	transform: scale(1.04);
}

.cs-messages-voice-icon {
	width: 20px;
	height: 20px;
	display: block;
}

.cs-messages-send .glyphicon {
	font-size: 14px;
	line-height: 1;
	margin-left: 2px;
}

.cs-messages-bubble__text .cs-messages-video {
	display: block;
	max-width: min(280px, 100%);
	border-radius: 12px;
}

/* Голосовое сообщение в чате */
.cs-messages-bubble--voice .cs-messages-bubble__text {
	position: relative;
	display: block;
	width: max-content;
	min-width: 248px;
	max-width: min(320px, 100%);
	padding: 8px 10px;
	border-radius: 16px;
	background: #2a3148;
	box-shadow: 0 1px 1px rgba(0, 0, 0, 0.18);
}

.cs-messages-bubble--own.cs-messages-bubble--voice .cs-messages-bubble__text {
	background: linear-gradient(145deg, #8b7cf7 0%, #9d8cf8 55%, #8f82ff 100%);
}

.cs-messages-bubble--voice .cs-messages-bubble__body {
	display: block;
	line-height: 1;
}

.cs-messages-bubble--voice .cs-messages-bubble__tail {
	float: none;
	position: absolute;
	top: auto;
	left: auto;
	right: 10px;
	bottom: 8px;
	width: auto;
	height: 14px;
	margin: 0;
	padding: 0;
	display: inline-flex;
	align-items: center;
	justify-content: flex-end;
	gap: 4px;
	background: transparent;
	backdrop-filter: none;
	border-radius: 0;
	pointer-events: none;
	clear: none;
	vertical-align: baseline;
}

.cs-messages-bubble--voice .cs-messages-bubble__actions {
	display: inline-flex;
	align-items: center;
	gap: 0;
	pointer-events: auto;
}

.cs-messages-bubble--voice .cs-messages-bubble__action {
	width: 16px;
	height: 16px;
}

.cs-messages-bubble--voice .cs-messages-bubble__action .glyphicon {
	font-size: 9px;
}

.cs-messages-bubble--voice-playing .cs-messages-bubble__tail {
	opacity: 0;
	visibility: hidden;
}

.cs-messages-bubble--voice .cs-messages-bubble__time {
	color: rgba(255, 255, 255, 0.55);
	font-size: 11px;
	line-height: 14px;
}

.cs-messages-bubble--own.cs-messages-bubble--voice .cs-messages-bubble__time {
	color: rgba(255, 255, 255, 0.72);
}

.cs-messages-voice-msg {
	display: grid;
	grid-template-columns: 40px minmax(0, 1fr);
	grid-template-rows: 24px 14px;
	column-gap: 10px;
	row-gap: 2px;
	align-items: center;
	width: 100%;
	min-width: 210px;
	padding-bottom: 2px;
}

.cs-messages-voice-msg__play {
	grid-column: 1;
	grid-row: 1 / 3;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	min-width: 40px;
	margin: 0;
	padding: 0;
	border: none;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.96);
	color: #7a6cf0;
	cursor: pointer;
	align-self: center;
	justify-self: center;
	flex-shrink: 0;
	transition: transform 0.15s, opacity 0.15s;
}

.cs-messages-voice-msg__play:hover {
	transform: scale(1.04);
	opacity: 0.94;
}

.cs-messages-voice-msg__icon {
	width: 20px;
	height: 20px;
	display: block;
}

.cs-messages-voice-msg__icon--play {
	margin-left: 2px;
}

.cs-messages-voice-msg__main {
	display: contents;
}

.cs-messages-voice-msg__wave {
	grid-column: 2;
	grid-row: 1;
	display: flex;
	align-items: center;
	gap: 2px;
	height: 24px;
	overflow: hidden;
	width: 100%;
	min-width: 0;
}

.cs-messages-voice-msg__bar {
	flex: 1 1 0;
	min-width: 2px;
	max-width: 4px;
	min-height: 4px;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.3);
	align-self: center;
	will-change: opacity, height;
}

.cs-messages-bubble--own .cs-messages-voice-msg__bar {
	background: rgba(255, 255, 255, 0.34);
}

.cs-messages-voice-msg__bar.is-played {
	background: rgba(255, 255, 255, 0.92);
}

.cs-messages-bubble--own .cs-messages-voice-msg__bar.is-played {
	background: #fff;
}

.cs-messages-voice-msg__bar.is-dot {
	flex-basis: 4px;
	width: 4px;
	height: 4px !important;
	border-radius: 50%;
	opacity: 0.55;
}

.cs-messages-voice-msg__duration {
	grid-column: 2;
	grid-row: 2;
	display: block;
	font-size: 11px;
	line-height: 14px;
	height: 14px;
	color: rgba(255, 255, 255, 0.88);
	font-variant-numeric: tabular-nums;
	justify-self: start;
	align-self: center;
	padding-right: 52px;
	white-space: nowrap;
}

.cs-messages-bubble--voice-playing .cs-messages-voice-msg__duration {
	padding-right: 0;
}

.cs-messages-voice-msg__audio {
	position: absolute;
	width: 0;
	height: 0;
	opacity: 0;
	pointer-events: none;
}

.cs-messages-bubble__text .cs-messages-audio,
.cs-messages-bubble__text audio {
	display: none;
}

.cs-messages-page .empty-element {
	display: block;
	padding: 24px 16px;
	text-align: center;
	color: var(--cs-text-dim);
}

@media (max-width: 1100px) {
	.cs-messages-layout {
		height: calc(100vh - var(--cs-header) - 62px);
		max-height: calc(100vh - var(--cs-header) - 62px);
	}

	.cs-messages-page .cs-messages-panel {
		height: 100%;
		max-height: 100%;
	}
}

@media (max-width: 900px) {
	.cs-page:has(.cs-messages-page),
	.cs-page-main:has(.cs-messages-page) {
		padding: 0 !important;
		overflow: hidden;
	}

	.cs-messages-page {
		margin: 0;
		min-height: calc(100dvh - var(--cs-header));
	}

	.cs-messages-layout {
		height: calc(100dvh - var(--cs-header));
		max-height: calc(100dvh - var(--cs-header));
	}

	.cs-messages-page .cs-forum-panel.cs-messages-panel {
		border-radius: 0;
		border-left: none;
		border-right: none;
		margin-bottom: 0;
	}

	.cs-messages-chat-head__back {
		display: inline-flex !important;
	}

	.cs-messages-page #messages .cs-messages-bubble {
		max-width: min(92%, 640px);
	}

	.cs-messages-bubble__content,
	.cs-messages-bubble__text {
		max-width: min(calc(92vw - 64px), 580px);
	}
}

@media (max-width: 640px) {
	.cs-messages-dialog__avatar {
		width: 44px;
		height: 44px;
	}

	.cs-messages-dialog__open {
		padding: 10px 12px;
	}

	.cs-messages-log,
	.cs-messages-page #messages {
		padding: 10px 10px;
	}
}

/* ── Friends (друзья) ── */

.cs-friends-page {
	min-width: 0;
}

.cs-friends-panel {
	overflow: hidden;
}

.cs-friends-panel__head {
	padding: 14px 18px !important;
}

.cs-friends-panel__body {
	padding: 0 !important;
}

.cs-friends-panel__body:not(:has(.cs-friends-tab-panels)) {
	padding: 18px !important;
}

.cs-friends-tabs {
	padding: 14px 18px 16px;
	border-bottom: 1px solid var(--cs-border);
	background: rgba(255, 255, 255, 0.02);
}

.cs-friends-tabs__track {
	display: inline-flex;
	flex-wrap: wrap;
	gap: 4px;
	max-width: 100%;
	padding: 4px;
	border-radius: 12px;
	border: 1px solid var(--cs-border);
	background: rgba(255, 255, 255, 0.04);
}

.cs-friends-tabs__item {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	min-height: 36px;
	padding: 0 16px;
	border: none !important;
	border-radius: 8px;
	background: transparent !important;
	box-shadow: none !important;
	color: var(--cs-text-dim) !important;
	font-size: 13px;
	font-weight: 600;
	line-height: 1.2;
	text-decoration: none !important;
	white-space: nowrap;
	transition: color 0.15s, background 0.15s;
}

.cs-friends-tabs__item:hover,
.cs-friends-tabs__item:focus {
	outline: none;
	color: var(--cs-text) !important;
	background: rgba(255, 255, 255, 0.06) !important;
	text-decoration: none !important;
}

.cs-friends-tabs__item.active,
.cs-friends-tabs__item.active:hover,
.cs-friends-tabs__item.active:focus {
	color: #fff !important;
	background: var(--cs-accent) !important;
	box-shadow: 0 4px 14px rgba(124, 92, 255, 0.28) !important;
}

.cs-friends-tabs__badge:empty {
	display: none;
}

.cs-friends-tabs__badge:not(:empty) {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 18px;
	height: 18px;
	padding: 0 5px;
	margin-left: 2px;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.18);
	color: #fff;
	font-size: 11px;
	font-weight: 700;
	line-height: 1;
}

.cs-friends-tab-panels {
	padding: 18px;
}

.cs-friends-toolbar {
	margin-bottom: 16px;
}

.cs-friends-search {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	align-items: stretch;
}

.cs-friends-search__input {
	flex: 1 1 220px;
	min-width: 0;
	height: 40px;
	padding: 0 14px;
	border-radius: 10px;
	border: 1px solid var(--cs-border);
	background: rgba(255, 255, 255, 0.03);
	color: var(--cs-text);
	font-size: 14px;
	transition: border-color 0.15s, background 0.15s;
}

.cs-friends-search__input::placeholder {
	color: var(--cs-text-muted);
}

.cs-friends-search__input:focus {
	outline: none;
	border-color: rgba(124, 92, 255, 0.45);
	background: rgba(255, 255, 255, 0.05);
}

.cs-friends-search__actions {
	display: inline-flex;
	flex-shrink: 0;
	gap: 4px;
	padding: 3px;
	border-radius: 10px;
	border: 1px solid var(--cs-border);
	background: rgba(255, 255, 255, 0.04);
}

.cs-friends-search__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 72px;
	min-height: 34px;
	padding: 0 14px;
	border: none;
	border-radius: 7px;
	background: transparent;
	color: var(--cs-text-dim);
	font-size: 13px;
	font-weight: 600;
	line-height: 1;
	transition: color 0.15s, background 0.15s;
}

.cs-friends-search__btn:hover,
.cs-friends-search__btn:focus {
	outline: none;
	color: var(--cs-text);
	background: rgba(255, 255, 255, 0.06);
}

.cs-friends-search__btn--primary,
.cs-friends-search__btn--primary:hover,
.cs-friends-search__btn--primary:focus {
	color: #fff;
	background: var(--cs-accent);
}

.cs-friends-search__btn--primary:hover,
.cs-friends-search__btn--primary:focus {
	background: var(--cs-accent-hover);
}

.cs-friends-grid {
	display: grid;
	grid-template-columns: repeat(6, minmax(0, 1fr));
	gap: 12px;
	min-width: 0;
}

.cs-friends-grid .cs-friends-loader {
	grid-column: 1 / -1;
	display: flex;
	justify-content: center;
	padding: 32px 0;
}

.cs-friends-grid .cs-friends-loader img {
	width: 32px;
	height: 32px;
	opacity: 0.7;
}

.cs-friends-grid .empty-element {
	grid-column: 1 / -1;
	padding: 28px 16px;
	text-align: center;
	color: var(--cs-text-dim);
}

.cs-friends-card {
	display: flex;
	flex-direction: column;
	min-width: 0;
	border-radius: var(--cs-radius);
	border: 1px solid rgba(255, 255, 255, 0.06);
	background: rgba(255, 255, 255, 0.03);
	overflow: hidden;
	transition: background 0.15s, border-color 0.15s, transform 0.15s;
}

.cs-friends-card:hover {
	background: rgba(255, 255, 255, 0.05);
	border-color: rgba(255, 255, 255, 0.1);
}

.cs-friends-card__profile {
	display: block;
	padding: 12px 12px 10px;
	text-decoration: none;
}

.cs-friends-card__profile:hover {
	text-decoration: none;
}

.cs-friends-card__avatar {
	position: relative;
	width: 100%;
	aspect-ratio: 1;
	border-radius: calc(var(--cs-radius-sm) + 2px);
	overflow: hidden;
	background: rgba(255, 255, 255, 0.04);
}

.cs-friends-card__avatar img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.cs-friends-card__name {
	margin-top: 10px;
	font-size: 13px;
	font-weight: 700;
	line-height: 1.3;
	color: var(--cs-text);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.cs-friends-card__actions {
	display: flex;
	flex-direction: column;
	gap: 6px;
	padding: 0 10px 10px;
	margin-top: auto;
}

.cs-friends-card__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	width: 100%;
	min-height: 34px;
	padding: 0 10px;
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: var(--cs-radius-sm);
	background: rgba(255, 255, 255, 0.04);
	color: var(--cs-text);
	font-size: 12px;
	font-weight: 600;
	text-decoration: none;
	transition: background 0.15s, border-color 0.15s, color 0.15s;
}

.cs-friends-card__btn:hover {
	background: rgba(255, 255, 255, 0.08);
	border-color: rgba(255, 255, 255, 0.14);
	color: var(--cs-text);
	text-decoration: none;
}

.cs-friends-card__btn--success {
	background: rgba(69, 212, 131, 0.12);
	border-color: rgba(69, 212, 131, 0.24);
	color: #8ef0b8;
}

.cs-friends-card__btn--success:hover {
	background: rgba(69, 212, 131, 0.18);
	border-color: rgba(69, 212, 131, 0.34);
	color: #b6ffd3;
}

.cs-friends-card__btn--danger {
	background: rgba(255, 92, 122, 0.1);
	border-color: rgba(255, 92, 122, 0.22);
	color: #ff9fb1;
}

.cs-friends-card__btn--danger:hover {
	background: rgba(255, 92, 122, 0.16);
	border-color: rgba(255, 92, 122, 0.32);
	color: #ffc2cd;
}

@media (max-width: 1400px) {
	.cs-friends-grid {
		grid-template-columns: repeat(5, minmax(0, 1fr));
	}
}

@media (max-width: 1200px) {
	.cs-friends-grid {
		grid-template-columns: repeat(4, minmax(0, 1fr));
	}
}

@media (max-width: 900px) {
	.cs-friends-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

@media (max-width: 640px) {
	.cs-friends-tabs {
		padding-inline: 14px;
	}

	.cs-friends-tabs__track {
		display: flex;
		width: 100%;
	}

	.cs-friends-tabs__item {
		flex: 1 1 0;
		min-width: 0;
		padding-inline: 10px;
		font-size: 12px;
	}

	.cs-friends-tab-panels,
	.cs-friends-panel__body:not(:has(.cs-friends-tab-panels)) {
		padding: 14px;
	}

	.cs-friends-search {
		flex-direction: column;
		align-items: stretch;
	}

	.cs-friends-search__actions {
		width: 100%;
	}

	.cs-friends-search__actions .cs-friends-search__btn {
		flex: 1 1 0;
	}

	.cs-friends-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 10px;
	}
}

/* ── Support (поддержка) ── */

.cs-support-page {
	min-width: 0;
}

.cs-support-layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 240px;
	gap: 14px;
	align-items: start;
}

.cs-support-layout--form,
.cs-support-layout--single {
	grid-template-columns: minmax(0, 1fr);
	max-width: 860px;
	margin: 0 auto;
}

.cs-support-layout--ticket {
	grid-template-columns: minmax(0, 1fr) 300px;
}

.cs-support-main {
	display: flex;
	flex-direction: column;
	gap: 14px;
	min-width: 0;
}

.cs-support-sidebar {
	display: flex;
	flex-direction: column;
	gap: 10px;
	min-width: 0;
}

.cs-support-action {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 42px;
	padding: 0 16px;
	border-radius: 10px;
	border: 1px solid var(--cs-border);
	background: rgba(255, 255, 255, 0.04);
	color: var(--cs-text) !important;
	font-size: 13px;
	font-weight: 600;
	text-decoration: none !important;
	cursor: pointer;
	transition: background 0.15s, border-color 0.15s, color 0.15s;
}

.cs-support-action:hover,
.cs-support-action:focus {
	outline: none;
	background: rgba(255, 255, 255, 0.07);
	border-color: rgba(255, 255, 255, 0.12);
	color: var(--cs-text) !important;
	text-decoration: none !important;
}

.cs-support-action--primary {
	background: var(--cs-accent);
	border-color: var(--cs-accent);
	color: #fff !important;
}

.cs-support-action--primary:hover,
.cs-support-action--primary:focus {
	background: var(--cs-accent-hover);
	border-color: var(--cs-accent-hover);
	color: #fff !important;
}

.cs-support-action--danger {
	background: rgba(255, 92, 122, 0.1);
	border-color: rgba(255, 92, 122, 0.24);
	color: #ff9fb1 !important;
}

.cs-support-action--danger:hover,
.cs-support-action--danger:focus {
	background: rgba(255, 92, 122, 0.16);
	border-color: rgba(255, 92, 122, 0.34);
	color: #ffc2cd !important;
}

.cs-support-note {
	border-color: rgba(92, 157, 255, 0.22);
	background: rgba(92, 157, 255, 0.06);
}

.cs-support-note__body {
	display: flex;
	align-items: flex-start;
	gap: 12px;
	padding: 16px 18px;
}

.cs-support-note__icon {
	flex-shrink: 0;
	margin-top: 2px;
	font-size: 18px;
	color: #5c9dff;
}

.cs-support-note__text strong {
	display: block;
	margin-bottom: 6px;
	color: var(--cs-text);
	font-size: 14px;
}

.cs-support-note__text p {
	margin: 0;
	color: var(--cs-text-dim);
	font-size: 13px;
	line-height: 1.55;
}

.cs-support-note__text a {
	color: #8ec0ff;
	text-decoration: underline;
}

.cs-support-table-wrap {
	overflow-x: auto;
}

.cs-support-table {
	width: 100%;
	border-collapse: collapse;
	min-width: 520px;
}

.cs-support-table thead th {
	padding: 12px 16px;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--cs-text-dim);
	text-align: left;
	background: rgba(255, 255, 255, 0.02);
	border-bottom: 1px solid var(--cs-border);
	white-space: nowrap;
}

.cs-support-table tbody td {
	padding: 14px 16px;
	border-bottom: 1px solid rgba(255, 255, 255, 0.04);
	color: #b7bacd;
	font-size: 14px;
	vertical-align: middle;
}

.cs-support-table tbody tr:last-child td {
	border-bottom-color: rgba(255, 255, 255, 0.04);
}

.cs-support-row {
	transition: background 0.15s;
}

.cs-support-row:hover {
	background: rgba(255, 255, 255, 0.025);
}

.cs-support-row__link {
	color: var(--cs-text) !important;
	font-weight: 600;
	text-decoration: none !important;
}

.cs-support-row__link:hover {
	color: #d8cbff !important;
}

.cs-support-row__user {
	color: #8ec0ff !important;
	font-weight: 600;
	text-decoration: none !important;
}

.cs-support-row__user:hover {
	text-decoration: underline !important;
}

.cs-support-row__date {
	color: var(--cs-text-dim);
	font-size: 13px;
	white-space: nowrap;
}

.cs-support-row__answer {
	color: #b7bacd;
	font-size: 13px;
}

.cs-support-answer-tag {
	display: inline-block;
	margin-left: 6px;
	font-size: 12px;
	font-weight: 600;
}

.cs-support-answer-tag--admin {
	color: #8ec0ff;
}

.cs-support-answer-tag--user {
	color: #f0c06a;
}

.cs-support-status {
	display: inline-flex;
	align-items: center;
	padding: 4px 10px;
	border-radius: 999px;
	font-size: 12px;
	font-weight: 700;
	line-height: 1.2;
	white-space: nowrap;
}

.cs-support-status--warning {
	background: rgba(240, 192, 106, 0.14);
	color: #f0c06a;
}

.cs-support-status--info {
	background: rgba(92, 157, 255, 0.14);
	color: #8ec0ff;
}

.cs-support-status--success {
	background: rgba(69, 212, 131, 0.14);
	color: #8ef0b8;
}

.cs-support-table .empty-element,
.cs-support-table .table-row-error {
	display: block;
	padding: 28px 16px;
	text-align: center;
	color: var(--cs-text-dim);
	font-size: 14px;
}

.cs-support-table tbody tr:only-child td[colspan] {
	padding: 28px 16px;
	text-align: center;
	color: var(--cs-text-dim);
	font-size: 14px;
	border-bottom: none;
}

.cs-support-table__loader td {
	padding: 0 !important;
	border-bottom: none !important;
}

.cs-support-loader {
	display: flex;
	justify-content: center;
	padding: 28px 0;
}

.cs-support-loader img {
	width: 32px;
	height: 32px;
	opacity: 0.7;
}

.cs-support-tabs {
	padding: 0 18px 16px;
	border-bottom: 1px solid var(--cs-border);
	background: rgba(255, 255, 255, 0.02);
}

.cs-support-tabs__track {
	display: inline-flex;
	flex-wrap: wrap;
	gap: 4px;
	max-width: 100%;
	padding: 4px;
	border-radius: 12px;
	border: 1px solid var(--cs-border);
	background: rgba(255, 255, 255, 0.04);
}

.cs-support-tabs__item {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 36px;
	padding: 0 16px;
	border: none !important;
	border-radius: 8px;
	background: transparent !important;
	box-shadow: none !important;
	color: var(--cs-text-dim) !important;
	font-size: 13px;
	font-weight: 600;
	line-height: 1.2;
	text-decoration: none !important;
	white-space: nowrap;
	transition: color 0.15s, background 0.15s;
}

.cs-support-tabs__item:hover,
.cs-support-tabs__item:focus {
	outline: none;
	color: var(--cs-text) !important;
	background: rgba(255, 255, 255, 0.06) !important;
	text-decoration: none !important;
}

.cs-support-tabs__item.active,
.cs-support-tabs__item.active:hover,
.cs-support-tabs__item.active:focus {
	color: #fff !important;
	background: var(--cs-accent) !important;
	box-shadow: 0 4px 14px rgba(124, 92, 255, 0.28) !important;
}

.cs-support-tab-panels {
	padding: 0;
}

.cs-support-form {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.cs-support-field {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.cs-support-label {
	font-size: 13px;
	font-weight: 700;
	color: var(--cs-text);
}

.cs-support-input,
.cs-support-textarea,
.cs-support-form .form-control {
	width: 100%;
	padding: 0 14px;
	border-radius: 10px;
	border: 1px solid var(--cs-border);
	background: rgba(255, 255, 255, 0.03);
	color: var(--cs-text);
	font-size: 14px;
	transition: border-color 0.15s, background 0.15s;
}

.cs-support-input {
	height: 42px;
}

.cs-support-textarea {
	min-height: 160px;
	padding: 12px 14px;
	resize: vertical;
}

.cs-support-input:focus,
.cs-support-textarea:focus,
.cs-support-form .form-control:focus {
	outline: none;
	border-color: rgba(124, 92, 255, 0.45);
	background: rgba(255, 255, 255, 0.05);
}

.cs-support-form__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}

.cs-support-ticket-text .with_code {
	color: var(--cs-text);
	font-size: 14px;
	line-height: 1.65;
}

.cs-support-comments {
	display: flex;
	flex-direction: column;
	gap: 18px;
}

.cs-support-reply {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.cs-support-reply__footer {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 10px;
}

.cs-support-smile {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 42px;
	height: 42px;
	border-radius: 10px;
	border: 1px solid var(--cs-border);
	background: rgba(255, 255, 255, 0.04);
	cursor: pointer;
}

.cs-support-closed,
.cs-support-page .disabled_input {
	display: flex;
	align-items: center;
	gap: 8px;
	min-height: 42px;
	padding: 0 14px;
	border-radius: 10px;
	border: 1px dashed var(--cs-border);
	background: rgba(255, 255, 255, 0.02);
	color: var(--cs-text-dim);
	font-size: 14px;
}

.cs-support-answers {
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.cs-support-page .cs-profile-wall-post {
	margin: 0;
}

.cs-support-meta {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.cs-support-meta__row {
	display: grid;
	grid-template-columns: 88px minmax(0, 1fr);
	gap: 10px;
	align-items: start;
}

.cs-support-meta__label {
	color: var(--cs-text-dim);
	font-size: 12px;
	font-weight: 600;
}

.cs-support-meta__value {
	color: var(--cs-text);
	font-size: 13px;
	font-weight: 600;
	line-height: 1.45;
	word-break: break-word;
}

.cs-support-meta__value a {
	color: #8ec0ff;
	text-decoration: none;
}

.cs-support-meta__value a:hover {
	text-decoration: underline;
}

.cs-support-meta__row--file {
	align-items: center;
}

.cs-support-file-link {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 6px 12px;
	border-radius: 999px;
	border: 1px solid rgba(124, 92, 255, 0.28);
	background: rgba(124, 92, 255, 0.14);
	color: #d8cbff !important;
	font-size: 12px;
	font-weight: 600;
	text-decoration: none !important;
}

.cs-support-file-link:hover {
	background: var(--cs-accent);
	border-color: var(--cs-accent);
	color: #fff !important;
}

.cs-support-meta__actions {
	display: flex;
	flex-direction: column;
	gap: 8px;
	padding-top: 8px;
	border-top: 1px solid var(--cs-border);
}

.cs-support-field--editor .tox.tox-tinymce,
.cs-support-reply .tox.tox-tinymce,
.cs-support-field--editor .tox .tox-editor-container,
.cs-support-reply .tox .tox-editor-container,
.cs-support-field--editor .tox .tox-editor-header,
.cs-support-reply .tox .tox-editor-header,
.cs-support-field--editor .tox .tox-toolbar-overlord,
.cs-support-field--editor .tox .tox-toolbar,
.cs-support-field--editor .tox .tox-toolbar__overflow,
.cs-support-field--editor .tox .tox-toolbar__primary,
.cs-support-reply .tox .tox-toolbar-overlord,
.cs-support-reply .tox .tox-toolbar,
.cs-support-reply .tox .tox-toolbar__overflow,
.cs-support-reply .tox .tox-toolbar__primary,
.cs-support-field--editor .tox .tox-sidebar-wrap,
.cs-support-reply .tox .tox-sidebar-wrap,
.cs-support-field--editor .tox .tox-edit-area,
.cs-support-reply .tox .tox-edit-area,
.cs-support-field--editor .tox .tox-edit-area__iframe,
.cs-support-reply .tox .tox-edit-area__iframe,
.cs-support-field--editor .tox .tox-statusbar,
.cs-support-reply .tox .tox-statusbar {
	background: rgb(37, 40, 54) !important;
	background-color: rgb(37, 40, 54) !important;
}

.cs-support-field--editor .tox.tox-tinymce,
.cs-support-reply .tox.tox-tinymce {
	border: 1px solid rgb(47, 53, 83) !important;
	border-radius: 10px !important;
	box-shadow: none !important;
	overflow: hidden;
}

.cs-support-field--editor .tox .tox-editor-header,
.cs-support-reply .tox .tox-editor-header {
	border-bottom: 1px solid rgb(47, 53, 83) !important;
	padding: 8px 10px !important;
}

.cs-support-field--editor .tox .tox-toolbar-overlord,
.cs-support-field--editor .tox .tox-toolbar,
.cs-support-field--editor .tox .tox-toolbar__overflow,
.cs-support-field--editor .tox .tox-toolbar__primary,
.cs-support-reply .tox .tox-toolbar-overlord,
.cs-support-reply .tox .tox-toolbar,
.cs-support-reply .tox .tox-toolbar__overflow,
.cs-support-reply .tox .tox-toolbar__primary {
	border: none !important;
}

.cs-support-field--editor .tox .tox-tbtn,
.cs-support-reply .tox .tox-tbtn {
	color: #b7bacd !important;
	border-radius: 8px !important;
}

.cs-support-field--editor .tox .tox-tbtn svg,
.cs-support-reply .tox .tox-tbtn svg {
	fill: currentColor !important;
}

.cs-support-field--editor .tox .tox-tbtn:hover,
.cs-support-field--editor .tox .tox-tbtn:focus,
.cs-support-reply .tox .tox-tbtn:hover,
.cs-support-reply .tox .tox-tbtn:focus {
	background: rgb(41, 44, 64) !important;
	color: #fff !important;
}

.cs-support-field--editor .tox .tox-edit-area,
.cs-support-reply .tox .tox-edit-area {
	border: none !important;
}

.cs-support-field--editor .tox .tox-statusbar,
.cs-support-reply .tox .tox-statusbar {
	display: flex !important;
	align-items: center;
	height: 22px !important;
	padding: 0 8px !important;
	border-top: 1px solid rgb(47, 53, 83) !important;
	color: #9597a5 !important;
}

.cs-support-field--editor .tox .tox-statusbar__path-item,
.cs-support-field--editor .tox .tox-statusbar__wordcount,
.cs-support-field--editor .tox .tox-statusbar a,
.cs-support-reply .tox .tox-statusbar__path-item,
.cs-support-reply .tox .tox-statusbar__wordcount,
.cs-support-reply .tox .tox-statusbar a {
	color: #9597a5 !important;
}

.cs-support-field--editor .tox .tox-statusbar__resize-handle svg,
.cs-support-reply .tox .tox-statusbar__resize-handle svg {
	fill: #9597a5 !important;
}

.cs-support-field--editor .tox-tinymce ~ textarea,
.cs-support-field--editor.is-editor-ready > textarea,
.cs-support-reply .tox-tinymce ~ textarea {
	display: none !important;
}

.cs-support-field--editor .tox .tox-edit-area iframe,
.cs-support-reply .tox .tox-edit-area iframe {
	min-height: 160px !important;
}

@media (max-width: 1100px) {
	.cs-support-layout,
	.cs-support-layout--ticket {
		grid-template-columns: minmax(0, 1fr);
	}

	.cs-support-sidebar {
		order: -1;
	}

	.cs-support-sidebar .cs-support-action {
		width: 100%;
	}
}

@media (max-width: 640px) {
	.cs-support-tabs {
		padding-inline: 14px;
	}

	.cs-support-tabs__track {
		display: flex;
		width: 100%;
	}

	.cs-support-tabs__item {
		flex: 1 1 0;
		min-width: 0;
		padding-inline: 10px;
		font-size: 12px;
	}

	.cs-support-meta__row {
		grid-template-columns: 1fr;
		gap: 4px;
	}
}

/* ── Users (пользователи) ── */

.cs-users-page {
	min-width: 0;
}

.cs-users-layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 280px;
	gap: 14px;
	align-items: start;
}

.cs-users-panel__body {
	display: flex;
	flex-direction: column;
	gap: 16px;
	min-width: 0;
}

.cs-users-grid {
	display: grid;
	grid-template-columns: repeat(6, minmax(0, 1fr));
	gap: 12px;
	min-width: 0;
}

.cs-users-grid .empty-element {
	grid-column: 1 / -1;
	padding: 28px 16px;
	text-align: center;
	color: var(--cs-text-dim);
	border-radius: var(--cs-radius-sm);
	border: 1px dashed var(--cs-border);
	background: rgba(255, 255, 255, 0.02);
}

.cs-users-card {
	display: flex;
	flex-direction: column;
	min-width: 0;
	border-radius: var(--cs-radius);
	border: 1px solid rgba(255, 255, 255, 0.06);
	background: rgba(255, 255, 255, 0.03);
	overflow: hidden;
	transition: background 0.15s, border-color 0.15s;
}

.cs-users-card:hover {
	background: rgba(255, 255, 255, 0.05);
	border-color: rgba(255, 255, 255, 0.1);
}

.cs-users-card__profile {
	display: block;
	padding: 12px 12px 10px;
	text-decoration: none !important;
}

.cs-users-card__profile:hover {
	text-decoration: none !important;
}

.cs-users-card__avatar {
	position: relative;
	width: 100%;
	aspect-ratio: 1;
	border-radius: calc(var(--cs-radius-sm) + 2px);
	overflow: hidden;
	background: rgba(255, 255, 255, 0.04);
}

.cs-users-card__avatar img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.cs-users-card__name {
	margin-top: 10px;
	font-size: 13px;
	font-weight: 700;
	line-height: 1.3;
	color: var(--cs-text);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.cs-users-card__actions {
	display: flex;
	flex-direction: column;
	gap: 6px;
	padding: 0 10px 10px;
	margin-top: auto;
}

.cs-users-card__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	width: 100%;
	min-height: 34px;
	padding: 0 10px;
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: var(--cs-radius-sm);
	background: rgba(255, 255, 255, 0.04);
	color: var(--cs-text) !important;
	font-size: 12px;
	font-weight: 600;
	text-decoration: none !important;
	transition: background 0.15s, border-color 0.15s, color 0.15s;
	cursor: pointer;
}

.cs-users-card__btn:hover,
.cs-users-card__btn:focus {
	background: rgba(255, 255, 255, 0.08);
	border-color: rgba(255, 255, 255, 0.14);
	color: var(--cs-text) !important;
	text-decoration: none !important;
}

.cs-users-card__btn--danger {
	background: rgba(255, 92, 122, 0.1);
	border-color: rgba(255, 92, 122, 0.22);
	color: #ff9fb1 !important;
}

.cs-users-card__btn--danger:hover,
.cs-users-card__btn--danger:focus {
	background: rgba(255, 92, 122, 0.16);
	border-color: rgba(255, 92, 122, 0.32);
	color: #ffc2cd !important;
}

.cs-users-pagination:empty {
	display: none;
}

.cs-users-page .pagination {
	margin: 0;
}

.cs-users-page .pagination > li > a,
.cs-users-page .pagination > li > span {
	border-color: var(--cs-border);
	background: rgba(255, 255, 255, 0.03);
	color: var(--cs-text-dim);
}

.cs-users-page .pagination > li > a:hover,
.cs-users-page .pagination > li > span:hover {
	background: rgba(255, 255, 255, 0.06);
	color: var(--cs-text);
}

.cs-users-page .pagination > .active > a,
.cs-users-page .pagination > .active > span {
	background: var(--cs-accent);
	border-color: var(--cs-accent);
	color: #fff;
}

.cs-users-sidebar {
	display: flex;
	flex-direction: column;
	gap: 14px;
	min-width: 0;
}

.cs-users-widget .cs-forum-widget__body {
	padding: 14px;
}

.cs-users-filters {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.cs-users-search {
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.cs-users-search__input {
	width: 100%;
	height: 42px;
	padding: 0 14px;
	border-radius: 10px;
	border: 1px solid var(--cs-border);
	background: rgba(255, 255, 255, 0.03);
	color: var(--cs-text);
	font-size: 14px;
	transition: border-color 0.15s, background 0.15s;
}

.cs-users-search__input::placeholder {
	color: var(--cs-text-muted);
}

.cs-users-search__input:focus {
	outline: none;
	border-color: rgba(124, 92, 255, 0.45);
	background: rgba(255, 255, 255, 0.05);
}

.cs-users-search__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	width: 100%;
	min-height: 42px;
	padding: 0 16px;
	border: none;
	border-radius: 10px;
	background: var(--cs-accent);
	color: #fff !important;
	font-size: 13px;
	font-weight: 600;
	line-height: 1;
	transition: background 0.15s;
}

.cs-users-search__btn:hover,
.cs-users-search__btn:focus {
	outline: none;
	background: var(--cs-accent-hover);
	color: #fff !important;
}

.cs-users-filter__label {
	font-size: 12px;
	font-weight: 700;
	color: var(--cs-text-dim);
}

.cs-users-filters .cs-native-select {
	width: 100%;
}

.cs-users-filter__select,
.cs-users-filter__select option {
	background: #1a1a24;
	color: #b7bacd;
}

.cs-users-filter__select {
	width: 100%;
	height: 42px;
	padding: 0 14px;
	border-radius: 10px;
	border: 1px solid var(--cs-border);
	background: rgba(255, 255, 255, 0.03);
	color: var(--cs-text);
	font-size: 14px;
	transition: border-color 0.15s, background 0.15s;
}

.cs-users-filter__select:focus {
	outline: none;
	border-color: rgba(124, 92, 255, 0.45);
	background: rgba(255, 255, 255, 0.05);
}

@media (max-width: 1400px) {
	.cs-users-grid {
		grid-template-columns: repeat(5, minmax(0, 1fr));
	}
}

@media (max-width: 1200px) {
	.cs-users-grid {
		grid-template-columns: repeat(4, minmax(0, 1fr));
	}
}

@media (max-width: 1100px) {
	.cs-users-layout {
		grid-template-columns: minmax(0, 1fr);
	}

	.cs-users-sidebar {
		order: -1;
	}
}

@media (max-width: 900px) {
	.cs-users-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

@media (max-width: 640px) {
	.cs-users-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 10px;
	}
}

/* ========== STATIC PAGES (privacy, rules, knowledge base…) ========== */
.cs-static-page {
	min-width: 0;
}

.cs-static-panel__body {
	padding: 22px 24px;
}

.cs-static-content {
	color: var(--cs-text-dim);
	font-size: 14px;
	line-height: 1.6;
	word-break: break-word;
}

.cs-static-content:focus,
.cs-static-content:focus-visible {
	outline: none;
}

.cs-static-content a:focus,
.cs-static-content a:active,
.cs-static-content a:focus-visible {
	outline: none !important;
	box-shadow: none;
}

.cs-static-content h2,
.cs-static-content h3,
.cs-static-content h4 {
	margin: 1.4em 0 0.65em;
	color: var(--cs-text);
	font-weight: 700;
	line-height: 1.35;
}

.cs-static-content h2:first-child,
.cs-static-content h3:first-child,
.cs-static-content h4:first-child {
	margin-top: 0;
}

.cs-static-content h2 {
	font-size: 18px;
}

.cs-static-content h3 {
	font-size: 16px;
}

.cs-static-content h4 {
	font-size: 15px;
}

.cs-static-content p {
	margin: 0 0 0.85em;
}

.cs-static-content p:last-child {
	margin-bottom: 0;
}

.cs-static-content strong:not([style*="color"]),
.cs-static-content b:not([style*="color"]) {
	color: var(--cs-text);
	font-weight: 600;
}

.cs-static-content a:not([style*="color"]) {
	color: var(--cs-accent);
	text-decoration: none;
}

.cs-static-content a:not([style*="color"]):hover {
	color: var(--cs-accent-hover);
}

.cs-static-content ol {
	margin: 0 0 1em;
	padding-left: 1.4em;
}

.cs-static-content ol li {
	margin-bottom: 0.45em;
}

.cs-static-content ul {
	list-style: none !important;
	margin: 0 0 1em !important;
	padding: 0 !important;
	display: grid;
	gap: 8px;
}

.cs-static-content ul li {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	padding: 10px 14px;
	background: var(--cs-bg-pill);
	border: 1px solid var(--cs-border);
	border-radius: var(--cs-radius-sm);
	color: var(--cs-text) !important;
	margin: 0 !important;
}

.cs-static-content ul li::before {
	content: "";
	flex: 0 0 6px;
	width: 6px;
	height: 6px;
	margin-top: 7px;
	border-radius: 50%;
	background: var(--cs-green);
}

.cs-static-content table {
	width: 100%;
	max-width: 100%;
	margin-bottom: 1em;
	border-collapse: collapse;
}

.cs-static-content table tr td,
.cs-static-content table tr th {
	border: 1px solid var(--cs-border);
	padding: 8px 10px;
}

.cs-static-content img {
	max-width: 100%;
	height: auto;
	border-radius: var(--cs-radius-sm);
}

@media (max-width: 640px) {
	.cs-static-panel__body {
		padding: 16px 18px;
	}
}

/* ========== SERVER PLAYERS MODAL (Cybershoke-inspired) ========== */
.cs-spm {
	--spm-cols: 52px minmax(180px, 1fr) 88px 108px;
	--spm-map-h: 156px;
}

.cs-spm.cs-spm--admin {
	--spm-cols: 52px minmax(160px, 1fr) 88px 108px 52px;
}

.cs-spm .modal-dialog,
.cs-server-mgmt-modal .modal-dialog {
	max-width: 820px;
	width: calc(100% - 32px);
	margin: 24px auto;
}

.cs-spm__content {
	position: relative;
	overflow: hidden;
	border: 1px solid rgba(255, 255, 255, 0.07);
	border-radius: 16px;
	background: #12151d;
	box-shadow: 0 24px 64px rgba(0, 0, 0, 0.55);
}

.cs-spm__map-layer {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: var(--spm-map-h);
	pointer-events: none;
	z-index: 0;
}

.cs-spm__map-layer::before {
	content: '';
	position: absolute;
	inset: -8px 0 0;
	background-image: var(--spm-map);
	background-size: cover;
	background-position: center 42%;
	filter: blur(1px) saturate(1) brightness(0.84);
	opacity: 0.96;
}

.cs-spm__map-layer::after {
	content: '';
	position: absolute;
	inset: 0;
	background:
		linear-gradient(
			180deg,
			rgba(8, 10, 14, 0.06) 0%,
			rgba(8, 10, 14, 0.18) 28%,
			rgba(12, 15, 22, 0.48) 55%,
			rgba(18, 21, 29, 0.82) 78%,
			#12151d 100%
		);
}

.cs-spm__topbar,
.cs-spm__table-wrap,
.cs-spm__footer {
	position: relative;
	z-index: 1;
}

.cs-spm__topbar {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	z-index: 10;
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	padding: 10px 12px;
}

.cs-spm__topbar > * {
	position: relative;
	z-index: 1;
}

.cs-spm__close {
	margin-left: auto;
	padding: 0;
	width: 32px;
	height: 32px;
	border: none;
	border-radius: 8px;
	background: rgba(8, 10, 14, 0.5);
	color: rgba(238, 240, 244, 0.82);
	opacity: 1;
	font-size: 20px;
	line-height: 32px;
	text-align: center;
	text-shadow: none;
	cursor: pointer;
	transition: background 0.15s, color 0.15s;
}

.cs-spm__close:hover {
	background: rgba(8, 10, 14, 0.78);
	color: #fff;
}

.cs-spm__refresh {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	padding: 0;
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: 8px;
	background: rgba(8, 10, 14, 0.5);
	color: rgba(238, 240, 244, 0.72);
	cursor: pointer;
	transition: border-color 0.15s, color 0.15s, background 0.15s;
}

.cs-spm__refresh:hover {
	border-color: rgba(92, 108, 255, 0.4);
	color: #fff;
	background: rgba(8, 10, 14, 0.78);
}

.cs-spm__table-wrap {
	padding-top: calc(var(--spm-map-h) - 52px);
}

.cs-spm__thead,
.cs-spm-row {
	display: grid;
	grid-template-columns: var(--spm-cols);
	align-items: center;
	column-gap: 12px;
}

.cs-spm__thead {
	padding: 12px 18px 12px;
	border-bottom: 1px solid rgba(255, 255, 255, 0.06);
	background: linear-gradient(180deg, rgba(18, 21, 29, 0.08) 0%, rgba(18, 21, 29, 0.72) 100%);
}

.cs-spm__th {
	color: #6f768a;
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.07em;
	text-transform: uppercase;
	white-space: nowrap;
}

.cs-spm__th--count {
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 0;
	text-transform: none;
	font-variant-numeric: tabular-nums;
	text-align: center;
}

.cs-spm__count-val {
	color: #6f768a;
	font-weight: 600;
}

.cs-spm__count-sep,
.cs-spm__count-max {
	color: #6f768a;
	font-weight: 600;
}

.cs-spm__th--frags,
.cs-spm__th--time,
.cs-spm-row__frags,
.cs-spm-row__time {
	text-align: center;
}

.cs-spm__th--action,
.cs-spm-row__action {
	text-align: right;
	overflow: visible;
}

.cs-spm-row:has(.cs-spm-admin.is-open) {
	position: relative;
	z-index: 2;
}

.cs-spm-admin__menu {
	display: none;
	position: absolute;
	top: calc(100% + 6px);
	bottom: auto;
	right: 0;
	z-index: 50;
	min-width: 148px;
	padding: 6px;
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: 10px;
	background: #171b24;
	box-shadow: 0 12px 32px rgba(0, 0, 0, 0.45);
	pointer-events: auto;
}

.cs-spm-admin__menu--portal {
	display: block;
	position: fixed;
	z-index: 10060;
}

.cs-spm__list {
	max-height: min(52vh, 420px);
	overflow: auto;
	padding: 4px 0 8px;
	background: #12151d;
}

.cs-spm-row {
	padding: 0 18px;
	min-height: 52px;
	border-bottom: 1px solid rgba(255, 255, 255, 0.035);
	transition: background 0.12s;
}

.cs-spm-row:hover {
	background: rgba(255, 255, 255, 0.02);
}

.cs-spm-row:last-child {
	border-bottom: none;
}

.cs-spm-row__avatar {
	display: flex;
	align-items: center;
	justify-content: center;
}

.cs-spm-row__player {
	display: flex;
	align-items: center;
	min-width: 0;
}

.cs-spm-row__frags {
	color: #d2d6e3;
	font-size: 13px;
	font-weight: 600;
	font-variant-numeric: tabular-nums;
}

.cs-spm-row__time {
	color: #7d8496;
	font-size: 13px;
	font-variant-numeric: tabular-nums;
	white-space: nowrap;
}

.cs-spm-row__empty {
	color: #7d8496;
}

.cs-spm-player__avatar {
	flex: 0 0 auto;
	display: block;
	width: 36px;
	height: 36px;
	border-radius: 50%;
	overflow: hidden;
	border: 1px solid rgba(255, 255, 255, 0.12);
	background: #1a1f2b;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.28);
	transition: border-color 0.15s;
}

.cs-spm-player__avatar:hover {
	border-color: rgba(92, 108, 255, 0.45);
}

.cs-spm-player__avatar img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.cs-spm-player__avatar--guest {
	opacity: 0.65;
}

.cs-spm-player__name {
	min-width: 0;
	color: #eef0f4;
	font-size: 14px;
	font-weight: 600;
	line-height: 1.25;
	text-decoration: none;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

a.cs-spm-player__name:hover {
	color: var(--cs-accent-hover) !important;
}

.cs-spm-admin {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: flex-end;
}

.cs-spm-admin__gear {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	padding: 0;
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: 8px;
	background: rgba(0, 0, 0, 0.22);
	color: #7d8496;
	cursor: pointer;
	transition: border-color 0.15s, color 0.15s, background 0.15s;
}

.cs-spm-admin__gear .glyphicon {
	font-size: 14px;
	line-height: 1;
}

.cs-spm-admin__gear:hover,
.cs-spm-admin.is-open .cs-spm-admin__gear {
	border-color: rgba(92, 108, 255, 0.45);
	color: #a8b8ff;
	background: rgba(92, 108, 255, 0.1);
}

.cs-spm-admin__menu-item {
	display: block;
	width: 100%;
	padding: 9px 12px;
	border: none;
	border-radius: 7px;
	background: transparent;
	color: #c5c9d8;
	font-size: 13px;
	line-height: 1.25;
	text-align: left;
	cursor: pointer;
	transition: background 0.12s, color 0.12s;
}

.cs-spm-admin__menu-item:hover {
	background: rgba(92, 108, 255, 0.14);
	color: #eef0f4;
}

.cs-spm__state,
.cs-spm__empty {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 120px;
	padding: 24px 18px;
	color: #7d8496;
	font-size: 13px;
	text-align: center;
}

.cs-spm__loader {
	display: flex;
	align-items: center;
	justify-content: center;
}

.cs-spm__loader img {
	opacity: 0.65;
}

.cs-spm__footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	padding: 12px 16px;
	border-top: 1px solid rgba(255, 255, 255, 0.06);
	background: rgba(0, 0, 0, 0.18);
}

.cs-spm__ip {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 0;
	border: none;
	background: transparent;
	color: #7d8496;
	font-size: 13px;
	cursor: pointer;
	transition: color 0.15s;
}

.cs-spm__ip:hover {
	color: #eef0f4;
}

.cs-spm__ip-label {
	color: #6f768a;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
}

.cs-spm__ip-text {
	font-variant-numeric: tabular-nums;
}

.cs-spm__join {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 0;
	border: none;
	background: transparent !important;
	color: #a8b8ff !important;
	font-size: 13px;
	font-weight: 600;
	white-space: nowrap;
	text-decoration: none !important;
	transition: color 0.15s;
}

.cs-spm__join:hover {
	background: transparent !important;
	color: #eef0f4 !important;
}

/* ========== SERVER MANAGEMENT MODAL ========== */
.cs-server-mgmt-modal .modal-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
}

.cs-server-mgmt-modal__body {
	padding: 20px 24px !important;
}

.cs-server-mgmt-action {
	width: 100%;
}

.cs-server-mgmt-action .btn-default {
	white-space: nowrap;
	border-top-right-radius: 0 !important;
	border-bottom-right-radius: 0 !important;
}

.cs-server-mgmt-action .form-control {
	min-height: 34px;
	border-top-left-radius: 0 !important;
	border-bottom-left-radius: 0 !important;
}

.cs-server-mgmt-action .input-group-btn.w-100 {
	display: table-cell;
	width: 100%;
}

.cs-server-mgmt-result {
	margin: 14px 0 0;
	padding: 12px 14px;
	border: 1px solid var(--cs-border);
	border-radius: var(--cs-radius-sm);
	background: rgba(0, 0, 0, 0.22);
	color: var(--cs-text-dim);
	font-size: 12px;
}

@media (max-width: 768px) {
	.cs-spm .modal-dialog,
	.cs-server-mgmt-modal .modal-dialog {
		width: calc(100% - 16px);
		max-width: none;
		margin: 10px auto;
	}

	.cs-spm__content {
		max-height: calc(100dvh - 20px);
		overflow: hidden;
		display: flex;
		flex-direction: column;
	}

	.cs-spm__table-wrap {
		overflow-x: auto;
		overflow-y: auto;
		flex: 1 1 auto;
		min-height: 0;
		-webkit-overflow-scrolling: touch;
	}

	.cs-spm__thead,
	.cs-spm-row {
		min-width: 520px;
	}

	.cs-spm__footer {
		flex-direction: column;
		align-items: stretch;
		flex-shrink: 0;
	}

	.cs-spm__join {
		justify-content: center;
	}

	.cs-spm__topbar {
		z-index: 20;
	}

	.cs-spm__close,
	.cs-spm__refresh,
	.cs-spm__ip,
	.cs-spm__join {
		touch-action: manipulation;
	}
}

/* Profile inventory tab (moon) — CyberShoke-style layout */
.cs-profile-inventory-panel .cs-profile-panel__body--flush {
	padding: 0;
}

.cs-inv {
	display: grid;
	grid-template-columns: 220px minmax(0, 1fr);
	min-height: 420px;
	background: rgba(0, 0, 0, 0.18);
}

.cs-inv__sidebar {
	display: flex;
	flex-direction: column;
	gap: 4px;
	padding: 14px 10px;
	border-right: 1px solid rgba(255, 255, 255, 0.06);
	background: rgba(255, 255, 255, 0.02);
}

.cs-inv__game-switch {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 4px;
	margin-bottom: 10px;
	padding: 4px;
	border-radius: 12px;
	background: rgba(255, 255, 255, 0.04);
}

.cs-inv__game-btn {
	min-height: 34px;
	padding: 6px 8px;
	border: 0;
	border-radius: 8px;
	background: transparent;
	color: rgba(232, 236, 255, 0.72);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.04em;
	cursor: pointer;
	transition: background 0.18s ease, color 0.18s ease, box-shadow 0.18s ease;
}

.cs-inv__game-btn:hover {
	color: #fff;
	background: rgba(255, 255, 255, 0.06);
}

.cs-inv__game-btn.is-active {
	color: #fff;
	background: rgba(92, 108, 255, 0.28);
	box-shadow: inset 0 0 0 1px rgba(124, 136, 255, 0.35);
}

.cs-inv__group {
	display: flex;
	flex-direction: column;
	gap: 4px;
	margin-top: 10px;
}

.cs-inv__group-title {
	padding: 10px 12px 6px;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--cs-text-dim);
}

.cs-inv__nav {
	display: grid;
	grid-template-columns: 28px minmax(0, 1fr) auto;
	align-items: center;
	gap: 10px;
	width: 100%;
	padding: 10px 12px;
	border: 1px solid transparent;
	border-radius: 10px;
	background: transparent;
	color: var(--cs-text-muted);
	font: inherit;
	font-size: 13px;
	font-weight: 600;
	text-align: left;
	cursor: pointer;
	transition: background 0.15s, border-color 0.15s, color 0.15s;
}

.cs-inv__nav[hidden] {
	display: none !important;
}

.cs-inv__nav:hover {
	background: rgba(255, 255, 255, 0.04);
	color: var(--cs-text);
}

.cs-inv__nav.is-active {
	border-color: rgba(92, 108, 255, 0.35);
	background: rgba(92, 108, 255, 0.12);
	color: #fff;
}

.cs-inv__nav-count {
	min-width: 22px;
	padding: 2px 7px;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.06);
	color: var(--cs-text-dim);
	font-size: 11px;
	font-weight: 700;
	text-align: center;
}

.cs-inv__nav.is-active .cs-inv__nav-count {
	background: rgba(92, 108, 255, 0.22);
	color: #dbe2ff;
}

.cs-inv__nav-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	width: 28px;
	height: 28px;
	border-radius: 8px;
	background: rgba(255, 255, 255, 0.05);
	color: rgba(255, 255, 255, 0.88);
	position: relative;
}

.cs-inv__nav-icon img {
	display: block;
	width: 18px;
	height: 18px;
	object-fit: contain;
	filter: brightness(0) invert(1);
	opacity: 0.9;
}

.cs-inv__nav-icon--all::before {
	content: '';
	position: absolute;
	inset: 7px 8px;
	border: 2px solid rgba(92, 108, 255, 0.8);
	border-radius: 3px;
	box-shadow: inset 0 -4px 0 rgba(92, 108, 255, 0.25);
}

.cs-inv__nav-icon--all {
	background: linear-gradient(135deg, rgba(92, 108, 255, 0.4), rgba(61, 78, 214, 0.18));
}

.cs-inv__nav-icon--skin {
	background: linear-gradient(135deg, rgba(91, 106, 240, 0.35), rgba(3, 251, 243, 0.15));
}

.cs-inv__nav-icon--aura {
	background: linear-gradient(135deg, rgba(255, 129, 71, 0.35), rgba(255, 81, 47, 0.15));
}

.cs-inv__nav-icon--aura::before {
	content: '✦';
	position: absolute;
	inset: 0;
	display: grid;
	place-items: center;
	font-size: 12px;
	color: rgba(255, 255, 255, 0.85);
}

.cs-inv__nav-icon--pet {
	background: linear-gradient(135deg, rgba(120, 196, 120, 0.35), rgba(77, 160, 110, 0.15));
}

.cs-inv__nav-icon--pet::before {
	content: '🐾';
	position: absolute;
	inset: 0;
	display: grid;
	place-items: center;
	font-size: 12px;
}

.cs-inv__nav-icon--shop-skin {
	background: linear-gradient(135deg, rgba(91, 106, 240, 0.35), rgba(3, 251, 243, 0.15));
}

.cs-inv__nav-icon--shop-trail {
	background: linear-gradient(135deg, rgba(255, 196, 77, 0.35), rgba(255, 129, 71, 0.15));
}

.cs-inv__nav-icon--shop-aura {
	background: linear-gradient(135deg, rgba(120, 196, 255, 0.35), rgba(91, 106, 240, 0.15));
}

.cs-inv__nav-icon--shop-aura::before {
	content: '✦';
	position: absolute;
	inset: 0;
	display: grid;
	place-items: center;
	font-size: 12px;
	color: rgba(255, 255, 255, 0.85);
}

.cs-inv__nav-icon--shop-hat {
	background: linear-gradient(135deg, rgba(168, 120, 255, 0.35), rgba(91, 106, 240, 0.15));
}

.cs-inv__nav-icon--shop-wing {
	background: linear-gradient(135deg, rgba(77, 196, 255, 0.35), rgba(91, 106, 240, 0.15));
}

.cs-inv__main {
	display: flex;
	flex-direction: column;
	gap: 14px;
	padding: 16px 18px 18px;
	min-width: 0;
}

.cs-inv__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(148px, 1fr));
	gap: 12px;
}

.cs-inv-card {
	display: flex;
	flex-direction: column;
	min-height: 188px;
	border-radius: 12px;
	border: 1px solid rgba(255, 255, 255, 0.07);
	background: rgba(18, 22, 32, 0.92);
	overflow: hidden;
	transition: transform 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease;
}

.cs-inv-card--interactive {
	cursor: pointer;
}

.cs-inv-card--interactive:focus {
	outline: none;
	border-color: rgba(92, 108, 255, 0.45);
	box-shadow: 0 0 0 2px rgba(92, 108, 255, 0.22);
}

.cs-inv-card:hover {
	transform: translateY(-2px);
	border-color: rgba(92, 108, 255, 0.28);
	box-shadow: 0 10px 24px rgba(0, 0, 0, 0.28);
}

.cs-inv-card.is-equipped {
	border-color: rgba(168, 178, 255, 0.82);
	box-shadow:
		0 0 0 1px rgba(124, 136, 255, 0.42),
		0 0 20px rgba(92, 108, 255, 0.18);
}

.cs-inv-card__equipped {
	position: absolute;
	top: 8px;
	right: 8px;
	z-index: 2;
	padding: 2px 8px;
	border-radius: 999px;
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: #eef0ff;
	background: rgba(92, 108, 255, 0.88);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.28);
}

.cs-inv-card.is-filter-hidden {
	display: none !important;
}

.cs-inv-card__preview {
	position: relative;
	height: 118px;
	overflow: hidden;
}

.cs-inv-card__preview--skin,
.cs-inv-card__preview--shop-skin {
	background:
		radial-gradient(circle at 50% 120%, rgba(91, 106, 240, 0.45), transparent 58%),
		linear-gradient(180deg, rgba(35, 42, 68, 0.95) 0%, rgba(16, 19, 30, 0.98) 100%);
}

.cs-inv-card__preview--aura,
.cs-inv-card__preview--shop-aura {
	background:
		radial-gradient(circle at 50% 35%, rgba(255, 129, 71, 0.42), transparent 55%),
		linear-gradient(180deg, rgba(48, 28, 36, 0.95) 0%, rgba(16, 19, 30, 0.98) 100%);
}

.cs-inv-card__preview--shop-aura {
	background:
		radial-gradient(circle at 50% 35%, rgba(120, 196, 255, 0.42), transparent 55%),
		linear-gradient(180deg, rgba(24, 36, 52, 0.95) 0%, rgba(16, 19, 30, 0.98) 100%);
}

.cs-inv-card__preview--pet {
	background:
		radial-gradient(circle at 50% 35%, rgba(120, 196, 120, 0.42), transparent 55%),
		linear-gradient(180deg, rgba(28, 42, 32, 0.95) 0%, rgba(16, 19, 30, 0.98) 100%);
}

.cs-inv-card__preview--shop-trail {
	background:
		radial-gradient(circle at 50% 35%, rgba(255, 196, 77, 0.38), transparent 55%),
		linear-gradient(180deg, rgba(42, 34, 24, 0.95) 0%, rgba(16, 19, 30, 0.98) 100%);
}

.cs-inv-card__preview--shop-hat {
	background:
		radial-gradient(circle at 50% 20%, rgba(168, 120, 255, 0.38), transparent 55%),
		linear-gradient(180deg, rgba(36, 30, 52, 0.95) 0%, rgba(16, 19, 30, 0.98) 100%);
}

.cs-inv-card__preview--shop-wing {
	background:
		radial-gradient(circle at 50% 35%, rgba(77, 196, 255, 0.38), transparent 55%),
		linear-gradient(180deg, rgba(24, 36, 52, 0.95) 0%, rgba(16, 19, 30, 0.98) 100%);
}

.cs-inv-card__preview--has-image .cs-inv-card__watermark {
	display: none;
}

.cs-inv-card__img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: contain;
	object-position: center bottom;
	padding: 10px 12px 6px;
}

.cs-inv-card__preview--aura.cs-inv-card__preview--has-image .cs-inv-card__img,
.cs-inv-card__preview--shop-aura.cs-inv-card__preview--has-image .cs-inv-card__img,
.cs-inv-card__preview--pet.cs-inv-card__preview--has-image .cs-inv-card__img,
.cs-inv-card__preview--shop-trail.cs-inv-card__preview--has-image .cs-inv-card__img,
.cs-inv-card__preview--shop-hat.cs-inv-card__preview--has-image .cs-inv-card__img,
.cs-inv-card__preview--shop-wing.cs-inv-card__preview--has-image .cs-inv-card__img {
	object-position: center center;
	padding: 14px;
}

.cs-inv-card__watermark {
	position: absolute;
	inset: 0;
	opacity: 0.12;
	background:
		repeating-linear-gradient(45deg, rgba(255, 255, 255, 0.08) 0 1px, transparent 1px 12px),
		radial-gradient(circle at 50% 50%, rgba(255, 255, 255, 0.12), transparent 62%);
}

.cs-inv-card__preview--skin .cs-inv-card__watermark::after,
.cs-inv-card__preview--aura .cs-inv-card__watermark::after {
	content: '';
	position: absolute;
	left: 50%;
	bottom: 10px;
	transform: translateX(-50%);
	width: 54px;
	height: 72px;
	border-radius: 50% 50% 42% 42%;
	background: rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(255, 255, 255, 0.08);
}

.cs-inv-card__preview--aura .cs-inv-card__watermark::after {
	width: 64px;
	height: 64px;
	border-radius: 50%;
	bottom: 16px;
	box-shadow: 0 0 24px rgba(255, 129, 71, 0.35);
}

.cs-inv-card__info {
	display: flex;
	flex-direction: column;
	gap: 6px;
	padding: 10px 12px 12px;
	min-height: 70px;
}

.cs-inv-card__type {
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--cs-text-dim);
}

.cs-inv-card__name {
	font-size: 13px;
	font-weight: 700;
	line-height: 1.35;
	color: var(--cs-text);
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.cs-inv-empty {
	padding: 48px 24px;
	text-align: center;
	color: var(--cs-text-dim);
}

.cs-inv-empty__title {
	margin: 0 0 8px;
	font-size: 16px;
	font-weight: 700;
	color: var(--cs-text);
}

.cs-inv-empty__text {
	margin: 0;
	font-size: 13px;
	line-height: 1.5;
}

.cs-inv-empty__link {
	display: inline-block;
	margin-top: 16px;
	font-size: 13px;
	font-weight: 600;
	color: #9aa8ff;
	text-decoration: none;
}

.cs-inv-empty__link:hover {
	color: #c5ceff;
	text-decoration: underline;
}

.cs-inv__hint {
	margin: 2px 0 0;
	font-size: 12px;
	color: var(--cs-text-dim);
}

body.cs-inv-modal-open {
	overflow: hidden;
}

.cs-inv-modal {
	position: fixed;
	inset: 0;
	z-index: 10070;
	display: none;
	align-items: center;
	justify-content: center;
	padding: 24px 16px;
}

.cs-inv-modal.is-open {
	display: flex;
}

.cs-inv-modal__backdrop {
	position: absolute;
	inset: 0;
	background: rgba(6, 8, 14, 0.78);
	backdrop-filter: blur(6px);
}

.cs-inv-modal__dialog {
	position: relative;
	width: min(100%, 560px);
	max-height: calc(100vh - 48px);
	overflow: hidden;
	border-radius: 18px;
	border: 1px solid rgba(255, 255, 255, 0.1);
	background:
		linear-gradient(180deg, rgba(24, 28, 42, 0.98) 0%, rgba(12, 14, 22, 0.99) 100%);
	box-shadow:
		0 24px 64px rgba(0, 0, 0, 0.45),
		0 0 0 1px rgba(92, 108, 255, 0.12);
	animation: cs-inv-modal-in 0.2s ease;
}

@keyframes cs-inv-modal-in {
	from {
		opacity: 0;
		transform: translateY(12px) scale(0.98);
	}

	to {
		opacity: 1;
		transform: translateY(0) scale(1);
	}
}

.cs-inv-modal__close {
	position: absolute;
	top: 12px;
	right: 12px;
	z-index: 2;
	width: 36px;
	height: 36px;
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: 10px;
	background: rgba(255, 255, 255, 0.04);
	color: var(--cs-text);
	font-size: 24px;
	line-height: 1;
	cursor: pointer;
	transition: background 0.15s, border-color 0.15s;
}

.cs-inv-modal__close:hover {
	background: rgba(255, 255, 255, 0.08);
	border-color: rgba(255, 255, 255, 0.14);
}

.cs-inv-modal__preview {
	position: relative;
	min-height: 320px;
	overflow: hidden;
}

.cs-inv-modal__preview--skin,
.cs-inv-modal__preview--shop-skin {
	background:
		radial-gradient(circle at 50% 120%, rgba(91, 106, 240, 0.5), transparent 58%),
		linear-gradient(180deg, rgba(35, 42, 68, 0.95) 0%, rgba(16, 19, 30, 0.98) 100%);
}

.cs-inv-modal__preview--aura,
.cs-inv-modal__preview--shop-aura {
	background:
		radial-gradient(circle at 50% 35%, rgba(255, 129, 71, 0.45), transparent 55%),
		linear-gradient(180deg, rgba(48, 28, 36, 0.95) 0%, rgba(16, 19, 30, 0.98) 100%);
}

.cs-inv-modal__preview--shop-aura {
	background:
		radial-gradient(circle at 50% 35%, rgba(120, 196, 255, 0.45), transparent 55%),
		linear-gradient(180deg, rgba(24, 36, 52, 0.95) 0%, rgba(16, 19, 30, 0.98) 100%);
}

.cs-inv-modal__preview--pet {
	background:
		radial-gradient(circle at 50% 35%, rgba(120, 196, 120, 0.45), transparent 55%),
		linear-gradient(180deg, rgba(28, 42, 32, 0.95) 0%, rgba(16, 19, 30, 0.98) 100%);
}

.cs-inv-modal__preview--shop-trail {
	background:
		radial-gradient(circle at 50% 35%, rgba(255, 196, 77, 0.42), transparent 55%),
		linear-gradient(180deg, rgba(42, 34, 24, 0.95) 0%, rgba(16, 19, 30, 0.98) 100%);
}

.cs-inv-modal__preview--shop-hat {
	background:
		radial-gradient(circle at 50% 20%, rgba(168, 120, 255, 0.42), transparent 55%),
		linear-gradient(180deg, rgba(36, 30, 52, 0.95) 0%, rgba(16, 19, 30, 0.98) 100%);
}

.cs-inv-modal__preview--shop-wing {
	background:
		radial-gradient(circle at 50% 35%, rgba(77, 196, 255, 0.42), transparent 55%),
		linear-gradient(180deg, rgba(24, 36, 52, 0.95) 0%, rgba(16, 19, 30, 0.98) 100%);
}

.cs-inv-modal__img {
	display: block;
	width: 100%;
	height: 100%;
	min-height: 300px;
	max-height: min(52vh, 420px);
	object-fit: contain;
	object-position: center bottom;
	padding: 28px 24px 20px;
}

.cs-inv-modal__preview--aura .cs-inv-modal__img,
.cs-inv-modal__preview--shop-aura .cs-inv-modal__img,
.cs-inv-modal__preview--pet .cs-inv-modal__img,
.cs-inv-modal__preview--shop-trail .cs-inv-modal__img,
.cs-inv-modal__preview--shop-hat .cs-inv-modal__img,
.cs-inv-modal__preview--shop-wing .cs-inv-modal__img {
	object-position: center center;
	padding: 36px 28px;
}

.cs-inv-modal__placeholder {
	position: absolute;
	inset: 0;
	opacity: 0.14;
	background:
		repeating-linear-gradient(45deg, rgba(255, 255, 255, 0.08) 0 1px, transparent 1px 12px),
		radial-gradient(circle at 50% 50%, rgba(255, 255, 255, 0.12), transparent 62%);
}

.cs-inv-modal__meta {
	padding: 18px 22px 22px;
	border-top: 1px solid rgba(255, 255, 255, 0.06);
	background: rgba(8, 10, 16, 0.92);
}

.cs-inv-modal__title {
	margin: 0 0 14px;
	font-size: 18px;
	font-weight: 600;
	line-height: 1.35;
	color: rgba(255, 255, 255, 0.96);
}

.cs-inv-modal__details {
	margin: 0;
	display: grid;
	gap: 10px;
}

.cs-inv-modal__detail {
	display: grid;
	grid-template-columns: minmax(88px, auto) 1fr;
	gap: 10px 14px;
	align-items: baseline;
}

.cs-inv-modal__detail dt {
	margin: 0;
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.42);
}

.cs-inv-modal__detail dd {
	margin: 0;
	font-size: 15px;
	font-weight: 600;
	color: rgba(255, 255, 255, 0.9);
}

.cs-inv-modal__preview--skin .cs-inv-modal__placeholder::after,
.cs-inv-modal__preview--aura .cs-inv-modal__placeholder::after {
	content: '';
	position: absolute;
	left: 50%;
	bottom: 42px;
	transform: translateX(-50%);
	width: 96px;
	height: 128px;
	border-radius: 50% 50% 42% 42%;
	background: rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(255, 255, 255, 0.08);
}

.cs-inv-modal__preview--aura .cs-inv-modal__placeholder::after {
	width: 112px;
	height: 112px;
	border-radius: 50%;
	bottom: 54px;
	box-shadow: 0 0 40px rgba(255, 129, 71, 0.35);
}

@media (max-width: 900px) {
	.cs-inv {
		grid-template-columns: 1fr;
	}

	.cs-inv__sidebar {
		flex-direction: row;
		flex-wrap: wrap;
		border-right: 0;
		border-bottom: 1px solid rgba(255, 255, 255, 0.06);
	}

	.cs-inv__group {
		width: 100%;
		flex-direction: row;
		flex-wrap: wrap;
		margin-top: 0;
	}

	.cs-inv__group-title {
		width: 100%;
	}

	.cs-inv__nav {
		width: auto;
		flex: 1 1 auto;
	}
}

@media (max-width: 640px) {
	.cs-profile-cover .cs-profile-avatar {
		width: 72px;
		height: 72px;
	}

	.cs-profile-name {
		font-size: 20px;
	}

	.cs-profile-cover .cs-profile-actions {
		width: 100%;
	}

	.cs-profile-cover .cs-profile-actions .cs-btn {
		flex: 1 1 auto;
		min-width: 0;
		justify-content: center;
	}

	.cs-inv__grid {
		grid-template-columns: repeat(auto-fill, minmax(132px, 1fr));
	}

	.cs-inv-modal {
		padding: 12px;
	}

	.cs-inv-modal__preview,
	.cs-inv-modal__img {
		min-height: 240px;
	}

	.cs-inv-modal__img {
		max-height: 46vh;
		padding: 20px 16px 16px;
	}
}

