
/* WoW class colors (используется на /citizens) */
.wow-class {
	font-weight: 700;
	white-space: nowrap;
}

.wow-class-WARRIOR { color: #C79C6E; }
.wow-class-PALADIN { color: #F58CBA; }
.wow-class-HUNTER { color: #ABD473; }
.wow-class-ROGUE { color: #FFF569; }
.wow-class-PRIEST { color: #FFFFFF; }
.wow-class-DEATHKNIGHT { color: #C41F3B; }
.wow-class-SHAMAN { color: #0070DE; }
.wow-class-MAGE { color: #40C7EB; }
.wow-class-WARLOCK { color: #8787ED; }
.wow-class-MONK { color: #00FF96; }
.wow-class-DRUID { color: #FF7D0A; }
.wow-class-DEMONHUNTER { color: #A330C9; }
.wow-class-EVOKER { color: #33937F; }

.wow-class-UNKNOWN { color: #999; }


/* ============================================================
 * Основная тема сайта (раньше была в application/renderer.php <style>)
 * ============================================================ */
* {
	box-sizing: border-box;
}

body {
	margin: 0;
	padding: 0;
	font-family: 'Roboto', 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
	background: #121212;
	color: #EAEAEA;
	line-height: 1.5;
	font-size: 0.9rem;
}

/* Fallback если JS/Foundation не поднялись: не показываем "бургер" и не раскрываем подменю. */
.no-js .title-bar {
	display: none;
}

/* Правительственный header */
.gov-header {
	background: #121212;
	color: #EAEAEA;
	padding: 0;
	position: relative;
	z-index: 100;
	border-bottom: 3px solid #850C0C;
}

.gov-header-top {
	background: #121212;
	padding: 0.5rem 0;
	font-size: 0.8rem;
	border-bottom: 1px solid #2C2C2C;
}

.gov-header-top .grid-container {
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.gov-header-main {
	padding: 1.5rem 0;
}

.gov-logo-section {
	display: flex;
	align-items: center;
	gap: 1.5rem;
}

.gov-logo {
	width: 80px;
	height: 80px;
	background: #850C0C;
	border-radius: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 2.25rem;
	font-weight: bold;
	color: #EAEAEA;
	font-family: 'Oswald', sans-serif;
	text-transform: uppercase;
	flex-shrink: 0;
	border: 2px solid #D4AF37;
}

.gov-title {
	flex: 1;
}

.gov-auth-section {
	display: flex;
	align-items: stretch; /* чтобы бейдж и кнопка "ВЫХОД" были одной высоты */
	margin-left: auto;
	flex-shrink: 0;
}

.gov-header-user {
	margin-right: 1rem;
	max-width: 240px;
	display: flex;
	align-items: stretch;
}

.gov-header-user .gov-user-link--medium {
	height: 100%;
	align-items: center; /* в шапке визуально приятнее центрировать по высоте кнопки */
}

.gov-title h1 {
	margin: 0;
	font-size: 1.75rem;
	font-weight: 700;
	font-family: 'Oswald', sans-serif;
	text-transform: uppercase;
	color: #EAEAEA;
	line-height: 1.2;
	letter-spacing: 0.05em;
}

.gov-title .subtitle {
	font-size: 0.85rem;
	color: #EAEAEA;
	margin-top: 0.25rem;
	font-weight: 400;
}

/* Навигация */
.gov-nav {
	background: #121212;
	border-top: 3px solid #850C0C;
}

.gov-nav .top-bar {
	background: transparent;
	padding: 0;
}

.gov-nav .menu {
	background: transparent;
}

.gov-nav .menu > li > a {
	color: #EAEAEA;
	font-weight: 500;
	font-family: 'Oswald', sans-serif;
	text-transform: uppercase;
	padding: 1rem 1.5rem;
	letter-spacing: 0.05em;
}

.gov-nav .menu > li > a:hover,
.gov-nav .menu > li > a:focus {
	background: #850C0C;
	color: #EAEAEA;
}

.gov-nav .menu > li.has-submenu > a::after {
	border-color: #EAEAEA transparent transparent;
}

.gov-nav .submenu {
	background: #2C2C2C;
	border: 1px solid #850C0C;
}

.gov-nav .submenu a {
	color: #EAEAEA;
}

.gov-nav .submenu a:hover {
	background: #850C0C;
	color: #EAEAEA;
}

/* Отключение анимаций для меню */
.gov-nav .dropdown.menu,
.gov-nav .dropdown.menu *,
.gov-nav .is-dropdown-submenu,
.gov-nav .is-dropdown-submenu *,
.gov-nav .submenu,
.gov-nav .submenu *,
.gov-nav [data-dropdown-menu],
.gov-nav [data-dropdown-menu] *,
.gov-nav [data-submenu],
.gov-nav [data-submenu] * {
	transition: none !important;
	animation: none !important;
	-webkit-transition: none !important;
	-webkit-animation: none !important;
	-o-transition: none !important;
	-moz-transition: none !important;
}

/* Разделители */
hr {
	border: none;
	border-top: 3px solid #850C0C;
	margin: 2rem 0;
}

.divider {
	border: none;
	border-top: 5px solid #850C0C;
	margin: 3rem 0;
}

/* Контент */
.main-content {
	min-height: calc(100vh - 300px);
	padding: 2rem 0;
	background: #121212;
}

.content-wrapper {
	background: #707070;
	padding: 2rem;
	border-radius: 0;
	margin-bottom: 2rem;
	color: #EAEAEA;
	border: 1px solid #2C2C2C;
	transition: border-color 0.2s;
}

.content-wrapper:hover {
	border-color: #850C0C;
}

.content-wrapper p {
	color: #EAEAEA;
	text-align: left;
}

.content-wrapper a {
	color: #850C0C;
	text-decoration: none;
}

.content-wrapper a:hover {
	color: #D4AF37;
}

h1 {
	font-size: 1.75rem;
	font-weight: 700;
	font-family: 'Oswald', sans-serif;
	text-transform: uppercase;
	color: #850C0C;
	margin-bottom: 1.5rem;
	padding-bottom: 0.5rem;
	border-bottom: 3px solid #850C0C;
	letter-spacing: 0.05em;
}

h2 {
	font-size: 1.35rem;
	font-weight: 700;
	font-family: 'Oswald', sans-serif;
	text-transform: uppercase;
	color: #850C0C;
	margin-top: 2rem;
	margin-bottom: 1rem;
	letter-spacing: 0.05em;
}

h3 {
	font-size: 1.15rem;
	font-weight: 600;
	font-family: 'Oswald', sans-serif;
	text-transform: uppercase;
	color: #850C0C;
	margin-top: 1.5rem;
	margin-bottom: 0.75rem;
	letter-spacing: 0.05em;
}

/* Callout блоки */
.callout {
	padding: 1.5rem;
	margin: 1.5rem 0;
	border-left: 4px solid #850C0C;
	background: #2C2C2C;
	border-radius: 0;
	color: #EAEAEA;
}

.callout p {
	color: #EAEAEA;
	text-align: left;
}

.callout.alert {
	border-left-color: #850C0C;
	background: #2C2C2C;
	border: 2px solid #850C0C;
}

.callout.success {
	border-left-color: #D4AF37;
	background: #2C2C2C;
	border: 2px solid #D4AF37;
}

.callout.warning {
	border-left-color: #D4AF37;
	background: #4f1818;
	border: 2px solid #D4AF37;
}

/* Карточки услуг - кнопка привязана к нижнему краю */
.callout.service-card {
	display: flex;
	flex-direction: column;
	height: 100%;
	padding: 2rem;
	text-align: center;
}

.callout.service-card p {
	text-align: center;
}

.callout.service-card .button {
	margin-top: auto;
}

/* Таблицы */
table {
	width: 100%;
	border-collapse: collapse;
	margin: 1rem 0;
}

table th {
	background: #850C0C;
	color: #EAEAEA;
	padding: 0.75rem;
	text-align: left;
	font-weight: 700;
	font-family: 'Oswald', sans-serif;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

table td {
	padding: 0.75rem;
	border-bottom: 1px solid #2C2C2C;
	color: #EAEAEA;
	background: #121212;
}

table tr:hover td {
	background: #2C2C2C;
	border-color: #850C0C;
}

/* Футер */
.gov-footer {
	background: #121212;
	color: #EAEAEA;
	padding: 2rem 0 1rem;
	margin-top: 3rem;
	border-top: 3px solid #850C0C;
}

.gov-footer-content {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
	gap: 2rem;
	margin-bottom: 1.5rem;
}

.gov-footer-section h4 {
	color: #EAEAEA;
	font-size: 1rem;
	font-family: 'Oswald', sans-serif;
	text-transform: uppercase;
	margin-bottom: 1rem;
	border-bottom: 2px solid #850C0C;
	padding-bottom: 0.5rem;
	letter-spacing: 0.05em;
}

.gov-footer-section a {
	color: #EAEAEA;
	text-decoration: none;
	transition: color 0.2s;
}

.gov-footer-section a:hover {
	color: #850C0C;
}

.gov-footer-bottom {
	border-top: 1px solid #2C2C2C;
	padding-top: 1rem;
	text-align: center;
	font-size: 0.8rem;
	color: #EAEAEA;
}

/* Футер: пользователи онлайн */
.gov-footer-content .gov-footer-online {
	grid-column: 1 / -1; /* растягиваем секцию на всю ширину grid-контейнера */
}

.gov-online-users {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
}

.gov-online-user {
	min-height: 1.2rem;
}

/* Унифицированный "бейдж" пользователя (шапка/футер/дальше по проекту) */
.gov-user-link {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	color: #EAEAEA;
	text-decoration: none;
	max-width: 100%;
}

.gov-user-link--medium {
	align-items: flex-start;
}

.gov-user-link:hover {
	color: #850C0C;
}

.gov-user-avatar {
	width: 1.1em; /* высотой с строку */
	height: 1.1em;
	border-radius: 0;
	object-fit: cover;
	border: 1px solid #850C0C;
	flex: 0 0 auto;
}

.gov-user-link--medium .gov-user-avatar {
	width: 34px;
	height: 34px;
}

.gov-user-text {
	display: flex;
	flex-direction: column;
	line-height: 1.15;
	min-width: 0; /* чтобы ellipsis работал */
}

.gov-user-name {
	line-height: 1.2;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	max-width: 220px;
}

.gov-user-name--unconfirmed {
	color: #999;
}

.gov-user-link:hover .gov-user-name--unconfirmed {
	color: #850C0C;
}

.gov-user-link--medium .gov-user-name {
	max-width: 180px;
	font-weight: 600;
}

.gov-user-rank {
	font-size: 0.8rem;
	color: #D4AF37;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	max-width: 180px;
}

/* /citizen: карточка гражданина */
.citizen-header {
	display: flex;
	gap: 1.25rem;
	align-items: flex-start;
	margin: 1rem 0 1.25rem;
}

.citizen-avatar-col {
	flex: 0 0 auto;
}

.citizen-info-col {
	flex: 1 1 auto;
	min-width: 0;
}

.citizen-avatar {
	width: 256px;
	height: 256px;
	border-radius: 0;
	object-fit: cover;
	border: 2px solid #850C0C;
	background: #2C2C2C;
	display: block;
}

.citizen-title {
	margin-top: 0;
}

.citizen-login {
	color: #999;
}

.citizen-meta {
	margin: 0 0 1rem;
}

.citizen-meta-row {
	display: flex;
	gap: 1rem;
	padding: 0.4rem 0;
	border-bottom: 1px solid #2C2C2C;
}

.citizen-meta-row dt {
	min-width: 170px;
	color: #1f1f1f;
}

.citizen-meta-row dd {
	margin: 0;
	color: #EAEAEA;
}

/* /citizen: "Досье" (автогенерация канцелярита) */
.citizen-dossier .citizen-dossier-body {
	background: #2C2C2C;
	border: 3px solid #850C0C;
	padding: 1.25rem;
}

.citizen-dossier .citizen-dossier-item + .citizen-dossier-item {
	margin-top: 1rem;
	padding-top: 1rem;
	border-top: 1px solid rgba(212, 175, 55, 0.35);
}

.citizen-dossier .citizen-dossier-item__title {
	font-family: 'Oswald', sans-serif;
	font-size: 1.05rem;
	font-weight: 700;
	color: #D4AF37;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	margin-bottom: 0.5rem;
}

.citizen-dossier .citizen-dossier-item__text {
	margin: 0;
	color: #EAEAEA;
	line-height: 1.8;
}

.gov-online-more,
.gov-online-empty {
	margin-top: 0.5rem;
	font-size: 0.85rem;
	color: #D4AF37;
}

/* Кнопки (CTA) */
button,
.button,
input[type="submit"],
input[type="button"],
a.button {
	background: #850C0C;
	color: #EAEAEA;
	border: none;
	border-radius: 0;
	padding: 0.75rem 1.5rem;
	font-family: 'Oswald', sans-serif;
	text-transform: uppercase;
	font-weight: 600;
	font-size: 0.85rem;
	cursor: pointer;
	transition: all 0.2s;
	letter-spacing: 0.05em;
	text-decoration: none;
	display: inline-block;
}

button:hover,
.button:hover,
input[type="submit"]:hover,
input[type="button"]:hover,
a.button:hover {
	background: #EAEAEA;
	color: #850C0C;
}

button.important,
.button.important {
	border: 2px solid #D4AF37;
}

/* Поля ввода */
input[type="text"],
input[type="search"],
input[type="email"],
input[type="password"],
input[type="number"],
textarea,
select {
	background: #121212;
	border: 1px solid #4A4A4A;
	border-radius: 0;
	padding: 0.75rem;
	color: #EAEAEA;
	font-family: 'Roboto', sans-serif;
	font-size: 0.9rem;
	transition: border-color 0.2s;
}

input[type="text"]:focus,
input[type="search"]:focus,
input[type="email"]:focus,
input[type="password"]:focus,
input[type="number"]:focus,
textarea:focus,
select:focus {
	outline: none;
	border-color: #850C0C;
	background: #121212;
	color: #EAEAEA;
}

input[type="text"]::placeholder,
input[type="search"]::placeholder,
input[type="email"]::placeholder {
	color: #4A4A4A;
}

/* Утилиты */
.grid-container {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 1rem;
}

.text-center {
	text-align: center;
}

.mt-2 { margin-top: 1rem; }
.mb-2 { margin-bottom: 1rem; }

/* Адаптивность */
@media (max-width: 768px) {
	.gov-logo-section {
		flex-direction: column;
		text-align: center;
	}
	
	.gov-auth-section {
		margin-left: 0;
		margin-top: 1rem;
		justify-content: center;
	}
	
	.gov-title h1 {
		font-size: 1.35rem;
	}
	
	.content-wrapper {
		padding: 1rem;
	}
	
	h1 {
		font-size: 1.35rem;
	}
	
	.gov-nav .menu > li > a {
		padding: 0.75rem 1rem;
		font-size: 0.85rem;
	}

	/* /citizen: мобильная верстка карточки (аватар сверху, инфо снизу) */
	.citizen-header {
		flex-direction: column;
		align-items: stretch;
		gap: 0.75rem;
	}

	.citizen-avatar-col {
		width: 100%;
		display: flex;
		justify-content: center;
	}

	.citizen-avatar {
		width: 100%;
		max-width: 256px;
		height: auto;
		aspect-ratio: 1 / 1;
	}

	.citizen-meta-row {
		flex-direction: column;
		gap: 0.25rem;
	}

	.citizen-meta-row dt {
		min-width: 0;
	}
}

/* ============================================================
 * 404 (application/modules/404/index.php)
 * ============================================================ */
.error-404-container {
	text-align: center;
	padding: 4rem 2rem;
	min-height: 60vh;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}

.error-404-agency {
	font-family: 'Oswald', sans-serif;
	font-size: 1.1rem;
	font-weight: 700;
	color: #D4AF37;
	margin-bottom: 2rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	line-height: 1.4;
	max-width: 900px;
	border: 2px solid #D4AF37;
	padding: 1rem 1.5rem;
	background: rgba(212, 175, 55, 0.1);
}

.error-404-main-title {
	font-family: 'Oswald', sans-serif;
	font-size: 3rem;
	font-weight: 700;
	color: #850C0C;
	margin: 1.5rem 0;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	line-height: 1.2;
	text-shadow: 0 0 20px rgba(133, 12, 12, 0.3);
}

.error-404-greeting {
	font-family: 'Roboto', sans-serif;
	font-size: 1.35rem;
	color: #EAEAEA;
	margin: 2rem 0 1.5rem;
	font-weight: 500;
}

.error-404-message {
	background: #2C2C2C;
	border: 3px solid #850C0C;
	padding: 2rem;
	margin: 2rem 0;
	max-width: 800px;
	text-align: left;
}

.error-404-message p {
	color: #EAEAEA;
	font-family: 'Roboto', sans-serif;
	font-size: 1rem;
	line-height: 1.8;
	margin: 0.75rem 0;
}

.error-404-message p:first-child {
	font-weight: 700;
	color: #D4AF37;
	font-size: 1.1rem;
	margin-bottom: 1rem;
}

.error-404-message ul {
	color: #EAEAEA;
	font-family: 'Roboto', sans-serif;
	font-size: 1rem;
	line-height: 1.8;
	margin: 1rem 0;
	padding-left: 1.5rem;
}

.error-404-message ul li {
	margin: 0.75rem 0;
}

.error-404-message h3 {
	font-family: 'Oswald', sans-serif;
	font-size: 1.25rem;
	font-weight: 700;
	color: #D4AF37;
	margin-top: 2rem;
	margin-bottom: 1rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

/* Выдержка из реестра актов (рандомная цитата из horde_legal_acts) */
.error-404-quote {
	margin: 1.25rem 0 1.5rem;
	padding: 1rem 1.25rem;
	border: 2px dashed rgba(212, 175, 55, 0.55);
	background: rgba(212, 175, 55, 0.06);
}

.error-404-quote-title {
	font-family: 'Oswald', sans-serif;
	color: #D4AF37;
	font-weight: 700;
	margin-bottom: 0.5rem;
	letter-spacing: 0.03em;
}

.error-404-quote-text {
	color: #EAEAEA;
	font-family: 'Roboto', sans-serif;
	line-height: 1.8;
}

.error-404-actions {
	margin-top: 2rem;
	display: flex;
	gap: 1rem;
	justify-content: center;
	flex-wrap: wrap;
}

.error-404-signature {
	margin-top: 3rem;
	padding: 1.5rem;
	background: #2C2C2C;
	border-top: 3px solid #850C0C;
	max-width: 800px;
	text-align: center;
}

.error-404-signature p {
	color: #EAEAEA;
	font-family: 'Roboto', sans-serif;
	font-size: 1rem;
	margin: 0.5rem 0;
	font-weight: 500;
}

@media (max-width: 768px) {
	.error-404-agency {
		font-size: 0.85rem;
		padding: 0.75rem 1rem;
	}
	
	.error-404-main-title {
		font-size: 2rem;
	}
	
	.error-404-greeting {
		font-size: 1.1rem;
	}
	
	.error-404-actions {
		flex-direction: column;
		align-items: stretch;
	}
	
	.error-404-actions .button {
		width: 100%;
	}
	
	.error-404-message {
		padding: 1.5rem;
	}
}

/* ============================================================
 * admin: модалки аватара / security-логов (application/modules/admin/index.php)
 * ============================================================ */
/* view_logins: компактный вывод GeoIP под IP (без inline-CSS) */
.admin-geoip-compact {
	display: block;
	color: #D4AF37;
	font-size: 0.65rem;
	line-height: 1.2;
}

.admin-geoip-isp {
	display: block;
	color: #850C0C;
	font-size: 0.6rem;
	font-style: italic;
	line-height: 1.2;
}

/* Модальное окно для аватара */
.avatar-modal {
	display: none;
	position: fixed;
	z-index: 10000;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(0, 0, 0, 0.9);
	overflow: auto;
}

.avatar-modal.active {
	display: flex;
	align-items: center;
	justify-content: center;
}

.avatar-modal-content {
	background-color: #121212;
	border: 3px solid #850C0C;
	padding: 2rem;
	width: 90%;
	max-width: 1200px;
	max-height: 90vh;
	overflow-y: auto;
	position: relative;
	box-shadow: 0 4px 20px rgba(133, 12, 12, 0.5);
}

.avatar-modal-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 1.5rem;
	padding-bottom: 1rem;
	border-bottom: 2px solid #850C0C;
}

.avatar-modal-title {
	color: #850C0C;
	font-size: 1.5rem;
	font-weight: bold;
	text-transform: uppercase;
	margin: 0;
}

/* ============================================================
 * confirm_email: страница подтверждения email
 * ============================================================ */
.content-wrapper.confirm-email-page {
	/* На фоне общей темы `.content-wrapper` (серый) страница подтверждения выглядит “мыльно”.
	   Делаем гарантированно тёмной, чтобы не было светлый+светлый = ничего не читается. */
	background: #121212 !important;
	color: #EAEAEA !important;
	border-color: #850C0C !important;
}

.content-wrapper.confirm-email-page p,
.content-wrapper.confirm-email-page li,
.content-wrapper.confirm-email-page code {
	color: #EAEAEA;
}

.content-wrapper.confirm-email-page a {
	color: #D4AF37;
	text-decoration: underline;
}

.content-wrapper.confirm-email-page a:hover,
.content-wrapper.confirm-email-page a:focus {
	color: #EAEAEA;
}

.avatar-modal-close {
	color: #EAEAEA;
	font-size: 2rem;
	font-weight: bold;
	cursor: pointer;
	line-height: 1;
	transition: color 0.2s;
}

.avatar-modal-close:hover {
	color: #850C0C;
}

.avatar-modal-body {
	text-align: center;
}

.security-log-row {
	cursor: pointer;
	transition: background-color 0.2s;
}

.security-log-row:hover {
	background-color: #2C2C2C !important;
}

.security-log-toggle {
	color: #850C0C;
	font-weight: bold;
	font-size: 0.7rem;
	cursor: pointer;
}

.security-log-toggle:hover {
	color: #D4AF37;
}

/* Модальное окно */
.security-modal {
	display: none;
	position: fixed;
	z-index: 10000;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(0, 0, 0, 0.8);
	overflow: auto;
}

.security-modal.active {
	display: flex;
	align-items: center;
	justify-content: center;
}

.security-modal-content {
	background-color: #121212;
	border: 3px solid #850C0C;
	padding: 2rem;
	width: 90%;
	max-width: 900px;
	max-height: 90vh;
	overflow-y: auto;
	position: relative;
	box-shadow: 0 4px 20px rgba(133, 12, 12, 0.5);
}

.security-modal-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 1.5rem;
	padding-bottom: 1rem;
	border-bottom: 2px solid #850C0C;
}

.security-modal-title {
	color: #850C0C;
	font-size: 1.5rem;
	font-weight: bold;
	text-transform: uppercase;
	margin: 0;
}

.security-modal-close {
	color: #EAEAEA;
	font-size: 2rem;
	font-weight: bold;
	cursor: pointer;
	line-height: 1;
	transition: color 0.2s;
}

.security-modal-close:hover {
	color: #850C0C;
}

.security-modal-details-grid {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 0.75rem 1.5rem;
	font-size: 0.85rem;
}

.security-modal-details-label {
	color: #D4AF37;
	font-weight: bold;
	min-width: 150px;
}

.security-modal-details-value {
	color: #EAEAEA;
	word-break: break-all;
}

.security-modal-section {
	margin-bottom: 1.5rem;
	padding: 1rem;
	background: #1a1a1a;
	border-left: 4px solid #850C0C;
}

.security-modal-section-title {
	color: #850C0C;
	font-size: 1rem;
	font-weight: bold;
	text-transform: uppercase;
	margin-bottom: 0.75rem;
	padding-bottom: 0.5rem;
	border-bottom: 1px solid #2C2C2C;
}

/* ============================================================
 * Служебные страницы (application/lib/functions.php) — только в scope класса body
 * ============================================================ */
.app-fatal {
	margin: 0;
	font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;
	background: #121212;
	color: #EAEAEA;
}

.app-fatal .wrap {
	max-width: 920px;
	margin: 0 auto;
	padding: 48px 16px;
}

.app-fatal .card {
	background: #1b1b1b;
	border: 1px solid #2C2C2C;
	padding: 24px;
}

.app-fatal h1 {
	margin: 0 0 12px;
	color: #850C0C;
	font-size: 22px;
}

.app-fatal p {
	margin: 0 0 10px;
	line-height: 1.5;
}

.app-fatal code {
	background: #111;
	padding: 2px 6px;
	border: 1px solid #333;
}

.app-fatal pre {
	white-space: pre-wrap;
	background: #0e0e0e;
	border: 1px solid #333;
	padding: 12px;
	overflow: auto;
}

.app-fatal .small {
	opacity: .8;
	font-size: 13px;
}

.app-403 {
	font-family: Arial, sans-serif;
	text-align: center;
	padding: 50px;
	background: #121212;
	color: #EAEAEA;
}

.app-403 h1 { color: #850C0C; }
.app-403--subnet p { margin: 20px 0; }
.app-403--attack p { margin: 10px 0; }

/* ============================================================
 * Ордуслуги (/gosuslugi)
 * ============================================================ */
.gov-gosuslugi .gov-gosuslugi-filter {
	margin-bottom: 1rem;
}

.gov-gosuslugi .gov-gosuslugi-filter label {
	font-size: 0.85rem;
}

.gov-gosuslugi .gov-gosuslugi-cards .cell {
	margin-bottom: 1.5rem; /* внешний отступ снизу между карточками */
}

.gov-gosuslugi .gov-gosuslugi-cards .callout.gov-gosuslugi-card {
	height: 100%;
}

.gov-gosuslugi .gov-gosuslugi-card__title {
	margin: 0 0 0.5rem;
	font-size: 1.1rem;
}

.gov-gosuslugi .gov-gosuslugi-card__meta {
	opacity: 0.9;
	font-size: 0.85rem;
	margin-bottom: 0.75rem;
}

.gov-gosuslugi .gov-gosuslugi-card__desc {
	opacity: 0.95;
	margin-bottom: 0.75rem;
}

.gov-gosuslugi .gov-gosuslugi-card__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin-top: auto; /* как на главной: кнопки "прижаты" к низу карточки */
}

.gov-gosuslugi .gov-gosuslugi-required {
	color: #D4AF37;
	font-weight: 700;
}

/* Адаптивные таблицы ордуслуг */
.gov-gosuslugi .gov-gosuslugi-table {
	width: 100%;
	border-collapse: collapse;
}

/* Компактность: уменьшаем padding и размер шрифта */
.gov-gosuslugi .gov-gosuslugi-table th,
.gov-gosuslugi .gov-gosuslugi-table td {
	padding: 0.5rem 0.4rem;
	font-size: 0.85rem;
	word-wrap: break-word;
	overflow-wrap: break-word;
	hyphens: auto;
}

/* Перенос длинного текста */
.gov-gosuslugi .gov-gosuslugi-table td {
	max-width: 0;
	white-space: normal;
}

/* Ячейки с группированной информацией (построчно) */
.gov-gosuslugi .gov-gosuslugi-table-cell-group {
	vertical-align: top;
	padding: 0.75rem !important;
}

/* Ограничиваем ширину первой колонки на десктопе (только для больших экранов) */
@media (min-width: 768px) {
	.gov-gosuslugi .gov-gosuslugi-table-cell-group:first-child {
		width: 35%;
		max-width: 400px;
	}
	
	/* Вторая колонка получает оставшееся пространство */
	.gov-gosuslugi .gov-gosuslugi-table-cell-group:last-child {
		width: 65%;
	}
}

.gov-gosuslugi .gov-gosuslugi-table-cell-row {
	margin-bottom: 0.5rem;
	padding-bottom: 0.5rem;
	border-bottom: 1px solid #2C2C2C;
}

.gov-gosuslugi .gov-gosuslugi-table-cell-row:last-child {
	margin-bottom: 0;
	padding-bottom: 0;
	border-bottom: none;
}

.gov-gosuslugi .gov-gosuslugi-table-cell-row strong {
	color: #D4AF37;
	font-weight: 600;
	margin-right: 0.5rem;
	display: inline-block;
	min-width: 90px;
}

.gov-gosuslugi .gov-gosuslugi-table-cell-row .button {
	margin-top: 0.25rem;
}

/* На мобильных (до 768px) - превращаем таблицу в карточки */
@media (max-width: 767.98px) {
	.gov-gosuslugi .gov-gosuslugi-table,
	.gov-gosuslugi .gov-gosuslugi-table thead,
	.gov-gosuslugi .gov-gosuslugi-table tbody,
	.gov-gosuslugi .gov-gosuslugi-table th,
	.gov-gosuslugi .gov-gosuslugi-table td,
	.gov-gosuslugi .gov-gosuslugi-table tr {
		display: block;
	}
	
	/* Скрываем заголовки таблицы */
	.gov-gosuslugi .gov-gosuslugi-table thead tr {
		position: absolute;
		top: -9999px;
		left: -9999px;
	}
	
	/* Каждая строка становится карточкой */
	.gov-gosuslugi .gov-gosuslugi-table tr {
		border: 1px solid #2C2C2C;
		border-radius: 4px;
		margin-bottom: 1rem;
		padding: 0.75rem;
		background: #1b1b1b;
	}
	
	/* Ячейки с группированной информацией на мобильных */
	.gov-gosuslugi .gov-gosuslugi-table-cell-group {
		border: none !important;
		border-bottom: 1px solid #2C2C2C !important;
		padding: 0.75rem 0.5rem !important;
		padding-left: 0.5rem !important;
		max-width: none !important;
		width: 100% !important;
		position: relative;
		display: block;
	}
	
	.gov-gosuslugi .gov-gosuslugi-table-cell-group:last-child {
		border-bottom: none !important;
	}
	
	/* Заголовки для ячеек на мобильных */
	.gov-gosuslugi .gov-gosuslugi-table-cell-group:first-child:before {
		content: 'Основная информация';
		display: block;
		font-weight: 700;
		color: #D4AF37;
		font-size: 0.85rem;
		text-transform: uppercase;
		margin-bottom: 0.75rem;
		padding-bottom: 0.5rem;
		border-bottom: 1px solid #2C2C2C;
	}
	
	.gov-gosuslugi .gov-gosuslugi-table-cell-group:last-child:before {
		content: 'Обработка';
		display: block;
		font-weight: 700;
		color: #D4AF37;
		font-size: 0.85rem;
		text-transform: uppercase;
		margin-bottom: 0.75rem;
		padding-bottom: 0.5rem;
		border-bottom: 1px solid #2C2C2C;
	}
	
	/* Строки внутри ячеек на мобильных */
	.gov-gosuslugi .gov-gosuslugi-table-cell-row {
		margin-bottom: 0.75rem;
		padding-bottom: 0.5rem;
		border-bottom: 1px solid #1a1a1a;
	}
	
	.gov-gosuslugi .gov-gosuslugi-table-cell-row:last-child {
		margin-bottom: 0;
		padding-bottom: 0;
		border-bottom: none;
	}
	
	/* Убираем отступы у первой ячейки в карточке */
	.gov-gosuslugi .gov-gosuslugi-table tr td:first-child {
		padding-top: 0.75rem;
	}
	
	/* Убираем отступы у последней ячейки в карточке */
	.gov-gosuslugi .gov-gosuslugi-table tr td:last-child {
		padding-bottom: 0.75rem;
	}
}

/* На планшетах (768px - 1024px) - более компактная таблица */
@media (min-width: 768px) and (max-width: 1023.98px) {
	.gov-gosuslugi .gov-gosuslugi-table th,
	.gov-gosuslugi .gov-gosuslugi-table td {
		padding: 0.4rem 0.3rem;
		font-size: 0.8rem;
	}
	
	/* Скрываем менее важные колонки на планшетах */
	.gov-gosuslugi .gov-gosuslugi-table th:nth-child(n+6),
	.gov-gosuslugi .gov-gosuslugi-table td:nth-child(n+6) {
		display: none;
	}
}

/* ============================
 * Gosuslugi: application view
 * ============================ */
.gov-gosuslugi-application .gov-gosuslugi-app-data th {
	width: 38%;
	vertical-align: top;
	color: rgba(0, 0, 0, 0.75);
}
.gov-gosuslugi-application .gov-gosuslugi-app-data td {
	vertical-align: top;
}
.gov-gosuslugi-application .gov-gosuslugi-app-data__v {
	white-space: normal;
	word-break: break-word;
}

/* App head as a compact table */
.gov-gosuslugi-application .gov-gosuslugi-app-head-table th {
	width: 28%;
	vertical-align: top;
	white-space: nowrap;
	color: rgba(0, 0, 0, 0.75);
}
.gov-gosuslugi-application .gov-gosuslugi-app-head-table td {
	vertical-align: top;
}

/* Номер заявления в теге code */
.gov-gosuslugi-table code,
.gov-gosuslugi-app-head-table code {
	display: inline-block;
	padding: 0.25rem 0.5rem;
	border-radius: 4px;
	background: #1b1b1b;
	border: 1px solid #2C2C2C;
	color: #D4AF37;
	font-family: 'Courier New', 'Monaco', 'Consolas', monospace;
	font-size: 0.85rem;
	font-weight: 600;
	line-height: 1.3;
	white-space: nowrap;
}

.gov-gosuslugi-table code:hover,
.gov-gosuslugi-app-head-table code:hover {
	background: #2a2a2a;
	border-color: #D4AF37;
}

.gov-gosuslugi .gov-gosuslugi-status {
	display: inline-block;
	padding: 0.2rem 0.6rem;
	border-radius: 999px;
	border: 1px solid #2C2C2C;
	background: #1b1b1b;
	color: #EAEAEA;
	font-size: 0.75rem;
	line-height: 1.2;
	white-space: nowrap;
}

.gov-gosuslugi .gov-gosuslugi-status--pending {
	border-color: #D4AF37;
	background: #2a2100;
	color: #F6D46B;
}

.gov-gosuslugi .gov-gosuslugi-status--in_progress {
	border-color: #0070DE;
	background: #001b2c;
	color: #40C7EB;
}

.gov-gosuslugi .gov-gosuslugi-status--completed {
	border-color: #22c55e;
	background: #0f2a12;
	color: #86efac;
}

.gov-gosuslugi .gov-gosuslugi-status--rejected {
	border-color: #850C0C;
	background: #2b0a0a;
	color: #ffb4b4;
}

.gov-gosuslugi .gov-gosuslugi-status--cancelled {
	border-color: #666;
	background: #191919;
	color: #bbb;
}

.gov-gosuslugi .gov-gosuslugi-attachments {
	margin: 0;
	padding-left: 1.1rem;
}

.gov-gosuslugi .gov-gosuslugi-attachments__meta {
	opacity: 0.8;
	font-size: 0.85rem;
}

.gov-gosuslugi .gov-gosuslugi-comments {
	display: grid;
	gap: 0.75rem;
	margin: 0 0 1rem;
}

.gov-gosuslugi .gov-gosuslugi-comment {
	background: #141414;
	border: 1px solid #2C2C2C;
	padding: 0.75rem;
}

.gov-gosuslugi .gov-gosuslugi-comment--internal {
	border-color: #D4AF37;
}

.gov-gosuslugi .gov-gosuslugi-comment__meta {
	opacity: 0.9;
	font-size: 0.8rem;
	margin-bottom: 0.5rem;
}

.gov-gosuslugi .gov-gosuslugi-comment__body {
	white-space: pre-wrap;
}

.gov-gosuslugi .gov-gosuslugi-history {
	margin: 0 0 1rem;
	padding-left: 1.1rem;
}

.gov-gosuslugi .gov-gosuslugi-history__item {
	list-style: none;
	padding: 0.6rem 0.75rem;
	border: 1px solid #2C2C2C;
	background: #141414;
	margin-bottom: 0.5rem;
}

.gov-gosuslugi .gov-gosuslugi-history__top {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.75rem;
	flex-wrap: wrap;
}

.gov-gosuslugi .gov-gosuslugi-history__dt {
	opacity: 0.85;
	font-size: 0.85rem;
}

.gov-gosuslugi .gov-gosuslugi-history__change {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
}

.gov-gosuslugi .gov-gosuslugi-history__arrow {
	opacity: 0.8;
}

.gov-gosuslugi .gov-gosuslugi-history__note {
	margin-top: 0.5rem;
	opacity: 0.95;
}

.gov-gosuslugi .gov-gosuslugi-app-head {
	border: 1px solid #2C2C2C;
	background: #141414;
	padding: 0.9rem;
	margin-bottom: 1rem;
}

.gov-gosuslugi .gov-gosuslugi-app-head__top {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 0.75rem;
	flex-wrap: wrap;
	margin-bottom: 0.75rem;
}

.gov-gosuslugi .gov-gosuslugi-app-head__title {
	font-size: 1.15rem;
	font-weight: 700;
	margin: 0;
}

.gov-gosuslugi .gov-gosuslugi-app-head__meta {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 0.5rem 0.75rem;
}

.gov-gosuslugi .gov-gosuslugi-app-head__row {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	min-height: 28px;
}

.gov-gosuslugi .gov-gosuslugi-app-head__k {
	opacity: 0.8;
	min-width: 88px;
	font-size: 0.85rem;
}

.gov-gosuslugi .gov-gosuslugi-app-head__v {
	flex: 1;
}

.gov-gosuslugi .gov-gosuslugi-app-head__sub {
	opacity: 0.8;
	font-size: 0.85rem;
}

.gov-gosuslugi .gov-gosuslugi-queue__title {
	margin-top: 0;
}

.gov-gosuslugi .gov-gosuslugi-queue__counts {
	margin-bottom: 0.75rem;
}

.gov-gosuslugi .gov-gosuslugi-queue__footer {
	margin-top: 0.75rem;
	margin-bottom: 0;
}

.gov-gosuslugi .gov-gosuslugi-json {
	font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, 'Liberation Mono', 'Courier New', monospace;
	font-size: 0.85rem;
}

/* Стили для админки услуг - фиксированные ширины колонок */
.gov-gosuslugi-table-admin {
	table-layout: fixed;
	width: 100%;
}

.gov-gosuslugi-table-admin .gov-gosuslugi-admin-pos {
	width: 80px;
	min-width: 80px;
	max-width: 80px;
	text-align: center;
	overflow: hidden;
}

.gov-gosuslugi-table-admin .gov-gosuslugi-admin-active {
	width: 100px;
	min-width: 100px;
	max-width: 100px;
	text-align: center;
	overflow: hidden;
}

.gov-gosuslugi-table-admin .gov-gosuslugi-admin-actions {
	width: 250px;
	min-width: 250px;
	max-width: 250px;
	padding: 0.5rem 0.4rem !important;
	overflow: hidden;
	box-sizing: border-box;
}

.gov-gosuslugi-admin-actions-wrap {
	display: flex;
	flex-wrap: wrap;
	gap: 0.25rem;
	align-items: center;
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
}

.gov-gosuslugi-admin-actions-wrap .button {
	flex-shrink: 0;
	margin: 0;
	font-size: 0.75rem;
	padding: 0.35rem 0.5rem;
	white-space: nowrap;
}

.gov-gosuslugi-admin-actions-wrap .gov-gosuslugi-inline-form {
	display: inline-block;
	margin: 0;
	flex-shrink: 0;
}

.gov-gosuslugi .gov-gosuslugi-inline-form {
	display: inline-block;
	margin: 0;
	vertical-align: middle;
}

.gov-gosuslugi .gov-gosuslugi-inline-select {
	display: inline-block;
	width: auto;
	margin: 0 0.35rem;
}

.gov-gosuslugi .gov-gosuslugi-inline-label {
	display: inline-block;
	margin: 0 0.35rem;
}

/* --- /gosuslugi admin help modal (вики) --- */
.gosuslugi-help-modal {
	position: fixed;
	inset: 0;
	display: none;
	z-index: 1000;
}

.gosuslugi-help-modal.is-active {
	display: block;
}

.gosuslugi-help-modal__overlay {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.7);
}

.gosuslugi-help-modal__content {
	position: relative;
	max-width: 920px;
	margin: 5vh auto;
	background: #121212;
	border: 1px solid #2C2C2C;
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.35);
	max-height: 90vh;
	overflow: auto;
}

.gosuslugi-help-modal__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	padding: 0.75rem 1rem;
	border-bottom: 1px solid #2C2C2C;
}

.gosuslugi-help-modal__title {
	margin: 0;
	font-size: 1.05rem;
}

.gosuslugi-help-modal__close {
	background: transparent;
	border: 1px solid #2C2C2C;
	color: #EAEAEA;
	width: 36px;
	height: 36px;
	line-height: 34px;
	text-align: center;
	cursor: pointer;
}

.gosuslugi-help-modal__body {
	padding: 1rem;
}

.gosuslugi-help-pre {
	background: #0e0e0e;
	border: 1px solid #333;
	padding: 12px;
	white-space: pre;
	overflow: auto;
	font-size: 0.85rem;
}

.gov-gosuslugi-help-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.75rem;
	flex-wrap: wrap;
}

.gov-gosuslugi-help-btn {
	margin: 0;
}

body.gosuslugi-modal-open {
	overflow: hidden;
}

/* --- /gosuslugi view: attachments as cards + image modal --- */
.gov-gosuslugi .gov-gosuslugi-attachments-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 12px;
}

@media screen and (min-width: 640px) {
	.gov-gosuslugi .gov-gosuslugi-attachments-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media screen and (min-width: 1024px) {
	.gov-gosuslugi .gov-gosuslugi-attachments-grid {
		grid-template-columns: repeat(6, 1fr);
	}
}

.gov-gosuslugi .gov-gosuslugi-att-card {
	background: #121212;
	border: 1px solid #2C2C2C;
	box-shadow: 0 6px 18px rgba(0, 0, 0, 0.25);
	overflow: hidden;
}

.gov-gosuslugi .gov-gosuslugi-att__thumb {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	background: #0e0e0e;
	border-bottom: 1px solid #2C2C2C;
	position: relative;
}

.gov-gosuslugi .gov-gosuslugi-att__trash {
	position: absolute;
	top: 6px;
	right: 6px;
	width: 30px;
	height: 30px;
	display: flex;
	align-items: center;
	justify-content: center;
	border: 1px solid rgba(255, 255, 255, 0.18);
	background: rgba(0, 0, 0, 0.55);
	color: #fff;
	cursor: pointer;
	z-index: 3;
	line-height: 28px;
	font-size: 20px;
	padding: 0;
}

.gov-gosuslugi .gov-gosuslugi-att__trash:hover {
	background: rgba(0, 0, 0, 0.75);
	border-color: rgba(255, 255, 255, 0.35);
}

.gov-gosuslugi .gov-gosuslugi-att__thumbbtn {
	display: block;
	width: 100%;
	padding: 0;
	margin: 0;
	border: 0;
	background: transparent;
	cursor: pointer;
}

.gov-gosuslugi .gov-gosuslugi-att__thumb img {
	display: block;
	width: 100%;
	height: auto;
	aspect-ratio: 1 / 1;
	object-fit: cover;
	background: #0b0b0b;
}

.gov-gosuslugi .gov-gosuslugi-att__icon {
	width: 100%;
	aspect-ratio: 1 / 1;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 700;
	letter-spacing: 0.06em;
	color: #EAEAEA;
	background: #171717;
}

.gov-gosuslugi .gov-gosuslugi-att__icon--pdf { background: #2a1414; }
.gov-gosuslugi .gov-gosuslugi-att__icon--doc { background: #14202a; }
.gov-gosuslugi .gov-gosuslugi-att__icon--xls { background: #152a1a; }
.gov-gosuslugi .gov-gosuslugi-att__icon--zip { background: #2a2514; }
.gov-gosuslugi .gov-gosuslugi-att__icon--txt { background: #1c1c1c; }

.gov-gosuslugi .gov-gosuslugi-att__meta {
	padding: 10px 12px;
}

.gov-gosuslugi .gov-gosuslugi-att__name {
	font-weight: 600;
	line-height: 1.25;
	word-break: break-word;
}

.gov-gosuslugi .gov-gosuslugi-att__sub {
	margin-top: 6px;
	display: flex;
	align-items: center;
	gap: 8px;
	flex-wrap: wrap;
	color: rgba(234, 234, 234, 0.8);
	font-size: 0.85rem;
}

.gov-gosuslugi .gov-gosuslugi-att__del {
	margin: 0;
}

.gov-gosuslugi .gov-gosuslugi-att__dot {
	opacity: 0.6;
}

.gosuslugi-img-modal {
	position: fixed;
	inset: 0;
	display: none;
	z-index: 1100;
}

.gosuslugi-img-modal.is-active {
	display: block;
}

.gosuslugi-img-modal__overlay {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.8);
}

.gosuslugi-img-modal__content {
	position: relative;
	max-width: 1100px;
	margin: 4vh auto;
	background: #121212;
	border: 1px solid #2C2C2C;
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.35);
	max-height: 92vh;
	display: flex;
	flex-direction: column;
}

.gosuslugi-img-modal__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	padding: 0.6rem 0.9rem;
	border-bottom: 1px solid #2C2C2C;
}

.gosuslugi-img-modal__title {
	font-size: 0.95rem;
	font-weight: 600;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.gosuslugi-img-modal__actions {
	display: flex;
	align-items: center;
	gap: 8px;
	flex: 0 0 auto;
}

.gosuslugi-img-modal__close {
	background: transparent;
	border: 1px solid #2C2C2C;
	color: #EAEAEA;
	width: 36px;
	height: 36px;
	line-height: 34px;
	text-align: center;
	cursor: pointer;
}

.gosuslugi-img-modal__body {
	padding: 10px;
	overflow: auto;
}

.gosuslugi-img-modal__img {
	display: block;
	max-width: 100%;
	height: auto;
	margin: 0 auto;
	background: #0b0b0b;
	border: 1px solid #2C2C2C;
}

/* =====================================================
 * Gosuslugi: Visual schema builder for admin_edit_service
 * ===================================================== */
.gosuslugi-schema-builder__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
}
.gosuslugi-schema-builder__title {
	font-weight: 600;
}
.gosuslugi-schema-builder__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}
.gosuslugi-schema-builder__error {
	display: none;
}
.gosuslugi-schema-builder__error.is-visible {
	display: block;
}
.gosuslugi-schema-fields {
	display: grid;
	gap: 12px;
}
.gosuslugi-schema-empty {
	color: rgba(0, 0, 0, 0.65);
	padding: 8px 2px;
}
.gosuslugi-schema-field {
	border: 1px solid rgba(0, 0, 0, 0.12);
	border-radius: 6px;
	padding: 12px;
	background: #484848;
}
.gosuslugi-schema-field__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	margin-bottom: 10px;
}
.gosuslugi-schema-field__title {
	display: flex;
	align-items: center;
	gap: 8px;
	flex-wrap: wrap;
}
.gosuslugi-schema-field__idx {
	display: inline-block;
	font-weight: 600;
	color: rgba(0, 0, 0, 0.75);
}
.gosuslugi-schema-field__name {
	font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
	font-size: 0.95em;
}
.gosuslugi-schema-field__sep {
	color: rgba(0, 0, 0, 0.35);
}
.gosuslugi-schema-field__type {
	color: rgba(0, 0, 0, 0.65);
}
.gosuslugi-schema-field__actions {
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
}
.gosuslugi-schema-field__row {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	align-items: flex-end;
	margin-bottom: 10px;
}
.gosuslugi-schema-field__row:last-child {
	margin-bottom: 0;
}
.gosuslugi-schema-field__row.is-hidden {
	display: none;
}
.gosuslugi-schema-field__cell {
	display: flex;
	flex-direction: column;
	gap: 4px;
	min-width: 140px;
	flex: 1;
	margin: 0;
}
.gosuslugi-schema-field__cell--wide {
	flex: 2;
	min-width: 220px;
}
.gosuslugi-schema-field__cell--check {
	flex-direction: row;
	align-items: center;
	gap: 8px;
	min-width: 140px;
}
.gosuslugi-schema-label {
	font-size: 12px;
	color: rgba(0, 0, 0, 0.65);
}
.gosuslugi-schema-label--inline {
	font-size: 14px;
	color: rgba(0, 0, 0, 0.75);
}
.gosuslugi-schema-input {
	margin: 0;
}
.gosuslugi-schema-input.is-invalid {
	border-color: #cc4b37;
	box-shadow: 0 0 0 1px rgba(204, 75, 55, 0.2);
}
.gosuslugi-schema-raw summary {
	cursor: pointer;
	user-select: none;
	margin: 8px 0;
}

/* --- /profile (личный кабинет): вкладки --- */
.lk-tabs {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin: 0 0 1.25rem 0;
}

.lk-tab {
	display: inline-block;
	padding: 0.65rem 1rem;
	border: 1px solid #2C2C2C;
	background: #141414;
	color: #EAEAEA;
	font-family: 'Oswald', sans-serif;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

/* Перебиваем .content-wrapper a { color: #850C0C; } по специфичности */
.lk-tabs .lk-tab {
	color: #EAEAEA;
}

.lk-tab:hover,
.lk-tab:focus {
	background: #850C0C;
	color: #EAEAEA;
}

.lk-tab.is-active {
	background: #850C0C;
	border-color: #D4AF37;
	color: #EAEAEA;
}

.lk-form {
	max-width: 420px;
}

.lk-form__hint {
	font-size: 0.85rem;
	color: #D4AF37;
	margin-top: 0.25rem;
}

/* --- /citizens?tab=world: чат-интерфейс --- */
.world-chat-toolbar {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	align-items: center;
	margin: 0.5rem 0 0.75rem 0;
}

.world-chat-toolbar__label {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	color: #EAEAEA;
	font-size: 0.9rem;
}

.world-chat-toolbar__date {
	margin: 0;
	height: 2rem;
	padding: 0 0.5rem;
	background: #141414;
	border: 1px solid #2C2C2C;
	color: #EAEAEA;
}

.world-chat-toolbar__btn {
	margin: 0;
}

.world-chat-container {
	max-height: 600px;
	overflow-y: auto;
	overflow-x: hidden;
	background: #1a1a1a;
	border: 1px solid #2C2C2C;
	border-radius: 4px;
	padding: 1rem;
	margin: 1rem 0;
}

.world-chat-messages {
	min-height: 100px;
}

.world-chat-date-separator {
	text-align: center;
	margin: 1.5rem 0 1rem 0;
	padding: 0.5rem 0;
	font-size: 0.85rem;
	color: #D4AF37;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	position: relative;
}

.world-chat-date-separator::before,
.world-chat-date-separator::after {
	content: '';
	position: absolute;
	top: 50%;
	width: 30%;
	height: 1px;
	background: #2C2C2C;
}

.world-chat-date-separator::before {
	left: 0;
}

.world-chat-date-separator::after {
	right: 0;
}

.world-chat-message {
	display: flex;
	flex-wrap: wrap;
	align-items: baseline;
	gap: 0.5rem;
	line-height: 1.4;
}

.world-chat-message:last-child {
	margin-bottom: 0;
}

.world-chat-message-time {
	font-size: 0.75rem;
	color: #888;
	flex-shrink: 0;
}

.world-chat-message-name {
	font-weight: 600;
	font-size: 0.9rem;
	flex-shrink: 0;
	text-decoration: none;
	color: inherit;
}

.world-chat-message-name:hover,
.world-chat-message-name:focus {
	text-decoration: underline;
}

/* WoW class colors inside chat (override .content-wrapper a { color: ... }) */
.world-chat-container .wow-class-WARRIOR { color: #C79C6E; }
.world-chat-container .wow-class-PALADIN { color: #F58CBA; }
.world-chat-container .wow-class-HUNTER { color: #ABD473; }
.world-chat-container .wow-class-ROGUE { color: #FFF569; }
.world-chat-container .wow-class-PRIEST { color: #FFFFFF; }
.world-chat-container .wow-class-DEATHKNIGHT { color: #C41F3B; }
.world-chat-container .wow-class-SHAMAN { color: #0070DE; }
.world-chat-container .wow-class-MAGE { color: #40C7EB; }
.world-chat-container .wow-class-WARLOCK { color: #8787ED; }
.world-chat-container .wow-class-MONK { color: #00FF96; }
.world-chat-container .wow-class-DRUID { color: #FF7D0A; }
.world-chat-container .wow-class-DEMONHUNTER { color: #A330C9; }
.world-chat-container .wow-class-EVOKER { color: #33937F; }
.world-chat-container .wow-class-UNKNOWN { color: #999; }

.world-chat-message-content {
	color: #D0D0D0;
	word-wrap: break-word;
	font-size: 0.9rem;
	flex: 1;
	min-width: 0;
}

.world-chat-loading {
	text-align: center;
	padding: 1rem;
	color: #888;
	font-size: 0.9rem;
}

.world-chat-error {
	text-align: center;
	padding: 1rem;
	color: #cc4b37;
	font-size: 0.9rem;
}

.world-chat-empty {
	text-align: center;
	padding: 2rem;
	color: #888;
	font-size: 0.9rem;
}

/* Адаптивность для мобильных */
@media (max-width: 640px) {
	.world-chat-toolbar__label {
		width: 100%;
		justify-content: space-between;
	}

	.world-chat-toolbar__date {
		width: 160px;
	}

	.world-chat-container {
		max-height: 400px;
		padding: 0.75rem;
	}

	.world-chat-message {
		gap: 0.4rem;
	}

	.world-chat-date-separator {
		margin: 1rem 0 0.75rem 0;
		font-size: 0.8rem;
	}

	.world-chat-message-time {
		font-size: 0.7rem;
	}

	.world-chat-message-name,
	.world-chat-message-content {
		font-size: 0.85rem;
	}
}
