/*
 * moneytrail — UI / Dear-ImGui–style reference palette
 * Black void UI, cool periwinkle accent, inset frames, monospace lowercase.
 */
@import url("https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500&display=swap");

:root {
	/* Reference: deep black + cool grey + lavender/periwinkle accent */
	--ui-bg: #000000;
	--ui-bg-panel: #0b0b0b;
	--ui-bg-inset: #070707;
	--ui-bg-hover: #101010;
	--ui-border-outer: #4a4a58;
	--ui-border-mid: #252528;
	--ui-border-inner: #0d0d0f;
	--ui-edge-hi: #3a3a44;
	--ui-edge-lo: #000000;
	--ui-text: #b4b4bc;
	--ui-text-muted: #5c5c64;
	--ui-text-bright: #e6e8f0;
	/* default accent: pink (overridable via settings color picker → CSS variables on :root) */
	--ui-accent: #e8a0c8;
	--ui-accent-soft: #a87090;
	--ui-accent-glow: rgba(232, 160, 200, 0.28);
	--ui-danger: #c08080;
	--ui-font: "JetBrains Mono", ui-monospace, "Cascadia Code", "Consolas", monospace;
	/* Scale slightly with viewport; caps keep monospace readable */
	--ui-fs: clamp(9px, 0.35vw + 8px, 12px);
	--ui-fs-sm: clamp(8px, 0.3vw + 7px, 10px);
	--ui-fs-lg: clamp(10px, 0.4vw + 8px, 12px);
}

html,
body {
	margin: 0;
	background: var(--ui-bg);
	overflow: hidden;
}

*,
*::before,
*::after {
	box-sizing: border-box;
}

#app-root {
	position: fixed;
	inset: 0;
	z-index: 10;
	pointer-events: none;
	font-family: var(--ui-font);
	font-size: var(--ui-fs);
	line-height: 1.25;
	color: var(--ui-text);
	text-transform: lowercase;
	-webkit-font-smoothing: none;
	-moz-osx-font-smoothing: grayscale;
	letter-spacing: 0.01em;
	/* Block copying UI chrome / messages; form fields opt back in below */
	user-select: none;
	-webkit-user-select: none;
	-webkit-touch-callout: none;
}

/* user-select does not inherit — apply to all nodes, then re-enable for form fields */
#app-root * {
	pointer-events: auto;
	user-select: none;
	-webkit-user-select: none;
}

#app-root input,
#app-root textarea,
#app-root select,
#app-root [contenteditable="true"] {
	user-select: text;
	-webkit-user-select: text;
}

#app-root textarea[readonly] {
	user-select: none;
	-webkit-user-select: none;
}

/* ---- Scrollbars: thin track, themed thumb; stable gutter avoids overlay on shoutbox del rail ---- */
#app-root .ui-scroll,
#app-root .ui-list,
#app-root .ui-group__body,
#app-root .ui-sidebar__nav,
#app-root textarea.ui-textarea,
#app-root textarea.ui-audit-textarea {
	scrollbar-gutter: stable;
	scrollbar-width: thin;
	scrollbar-color: rgba(100, 100, 112, 0.95) var(--ui-bg-inset);
}

@supports not (scrollbar-gutter: stable) {
	#app-root .ui-shout-scroll--mod.ui-shout-scroll-area {
		padding-inline-end: 14px;
		box-sizing: border-box;
	}
}

#app-root .ui-scroll::-webkit-scrollbar,
#app-root .ui-list::-webkit-scrollbar,
#app-root .ui-group__body::-webkit-scrollbar,
#app-root .ui-sidebar__nav::-webkit-scrollbar,
#app-root textarea.ui-textarea::-webkit-scrollbar,
#app-root textarea.ui-audit-textarea::-webkit-scrollbar {
	width: 8px;
	height: 8px;
}

#app-root .ui-scroll::-webkit-scrollbar-track,
#app-root .ui-list::-webkit-scrollbar-track,
#app-root .ui-group__body::-webkit-scrollbar-track,
#app-root .ui-sidebar__nav::-webkit-scrollbar-track,
#app-root textarea.ui-textarea::-webkit-scrollbar-track,
#app-root textarea.ui-audit-textarea::-webkit-scrollbar-track {
	background: var(--ui-bg-inset);
	border-radius: 4px;
	box-shadow: inset 0 0 0 1px var(--ui-border-inner);
}

#app-root .ui-scroll::-webkit-scrollbar-thumb,
#app-root .ui-list::-webkit-scrollbar-thumb,
#app-root .ui-group__body::-webkit-scrollbar-thumb,
#app-root .ui-sidebar__nav::-webkit-scrollbar-thumb,
#app-root textarea.ui-textarea::-webkit-scrollbar-thumb,
#app-root textarea.ui-audit-textarea::-webkit-scrollbar-thumb {
	background: linear-gradient(180deg, #36363f 0%, #222228 100%);
	border-radius: 4px;
	border: 1px solid var(--ui-border-mid);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

#app-root .ui-scroll::-webkit-scrollbar-thumb:hover,
#app-root .ui-list::-webkit-scrollbar-thumb:hover,
#app-root .ui-group__body::-webkit-scrollbar-thumb:hover,
#app-root .ui-sidebar__nav::-webkit-scrollbar-thumb:hover,
#app-root textarea.ui-textarea::-webkit-scrollbar-thumb:hover,
#app-root textarea.ui-audit-textarea::-webkit-scrollbar-thumb:hover {
	background: linear-gradient(180deg, var(--ui-edge-hi) 0%, #2a2a32 100%);
	border-color: var(--ui-border-outer);
}

.ui-layer {
	position: absolute;
	inset: 0;
	pointer-events: none;
}

.ui-layer > * {
	pointer-events: auto;
}

/* —— outer window: double frame like ImGui —— */
.ui-window {
	position: absolute;
	left: 40px;
	top: 40px;
	width: min(780px, calc(100vw - 20px));
	height: min(540px, calc(100vh - 20px));
	min-width: min(560px, calc(100vw - 20px));
	min-height: min(420px, calc(100vh - 24px));
	background: var(--ui-bg);
	border: 1px solid var(--ui-border-outer);
	box-shadow:
		inset 0 0 0 1px var(--ui-edge-lo),
		inset 0 0 0 2px var(--ui-border-mid),
		0 12px 48px rgba(0, 0, 0, 0.92);
	display: flex;
	flex-direction: column;
	overflow: hidden;
	user-select: none;
}

.ui-window--login {
	min-height: 300px;
	height: auto;
}

.ui-window--audit {
	/* Wide log panel: one line per row, horizontal scroll for long JSON */
	width: min(1200px, calc(100vw - 24px));
	height: min(560px, calc(100vh - 32px));
	min-width: min(720px, calc(100vw - 24px));
	min-height: 240px;
	max-width: 100%;
	position: absolute;
}

.ui-audit-body {
	flex: 1;
	display: flex;
	flex-direction: column;
	min-height: 0;
	padding: 0 6px 6px;
	background: var(--ui-bg);
}

.ui-audit-textarea {
	flex: 1;
	min-height: 160px;
	font-size: var(--ui-fs-sm);
	resize: none;
	white-space: pre;
	overflow-wrap: normal;
	word-break: normal;
	overflow-x: auto;
	overflow-y: auto;
	tab-size: 2;
}

/* —— title bar —— */
.ui-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 8px;
	padding: 4px 10px 5px;
	border-bottom: 1px solid var(--ui-border-mid);
	background: linear-gradient(180deg, #0c0c0e 0%, #000 55%, #000 100%);
	cursor: grab;
	flex-shrink: 0;
}

/* Site-wide admin banner (inside window chrome, above header) */
.ui-announce-bar {
	flex-shrink: 0;
	width: 100%;
	box-sizing: border-box;
	padding: 6px 10px 7px;
	font-size: var(--ui-fs-sm);
	line-height: 1.35;
	color: var(--ui-accent);
	background: linear-gradient(180deg, rgba(154, 174, 232, 0.1) 0%, rgba(0, 0, 0, 0.42) 100%);
	border-bottom: 1px solid var(--ui-border-mid);
	user-select: text;
	cursor: default;
	text-align: center;
}

.ui-announce-bar__text {
	display: block;
	white-space: pre-wrap;
	word-break: break-word;
}

.ui-header:active {
	cursor: grabbing;
}

.ui-header__left,
.ui-header__right {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 0 6px;
	font-size: var(--ui-fs);
	color: var(--ui-text-muted);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	max-width: 52%;
	min-height: 16px;
}

.ui-header__right {
	justify-content: flex-end;
	text-align: right;
	color: var(--ui-text-muted);
}

.ui-h-brand {
	color: var(--ui-text-bright);
	font-weight: 500;
	letter-spacing: 0.04em;
}

.ui-h-ver {
	color: var(--ui-accent-soft);
}

.ui-h-pipe {
	color: var(--ui-border-outer);
	padding: 0 2px;
	font-weight: 400;
}

.ui-h-meta {
	color: var(--ui-text);
	max-width: 240px;
	overflow: hidden;
	text-overflow: ellipsis;
}

/* —— body: sidebar + main —— */
.ui-body {
	flex: 1;
	display: flex;
	min-height: 0;
	border-top: 1px solid var(--ui-edge-lo);
}

.ui-sidebar {
	width: 122px;
	flex-shrink: 0;
	display: flex;
	flex-direction: column;
	border-right: 1px solid var(--ui-border-mid);
	background: linear-gradient(90deg, #050505 0%, #000 100%);
	min-height: 0;
}

.ui-sidebar__nav {
	flex: 1;
	padding: 4px 0;
	overflow-y: auto;
}

.ui-nav-item {
	display: block;
	width: 100%;
	text-align: left;
	padding: 5px 8px 5px 10px;
	margin: 1px 4px;
	border: none;
	border-left: 2px solid transparent;
	background: transparent;
	color: var(--ui-text-muted);
	font: inherit;
	font-size: var(--ui-fs-lg);
	cursor: pointer;
	transition: color 0.08s, border-color 0.08s, background 0.08s;
}

.ui-nav-item:hover {
	color: var(--ui-text);
	background: rgba(255, 255, 255, 0.03);
}

.ui-nav-item--active {
	color: var(--ui-accent);
	border-left-color: var(--ui-accent);
	background: linear-gradient(90deg, var(--ui-accent-glow), transparent);
	text-shadow: 0 0 12px var(--ui-accent-glow);
}

/* user directory / profile — presence */
.ui-presence-dot {
	display: inline-block;
	width: 7px;
	height: 7px;
	margin-right: 5px;
	border-radius: 50%;
	vertical-align: 0.1em;
	flex-shrink: 0;
}

.ui-presence-dot--online {
	background: #5a9a6a;
	box-shadow: 0 0 7px rgba(100, 200, 130, 0.55);
}

.ui-presence-dot--offline {
	background: #3a3a40;
	box-shadow: inset 0 0 2px rgba(0, 0, 0, 0.6);
}

.ui-presence-label {
	display: inline-flex;
	align-items: center;
	margin-left: 10px;
	font-size: var(--ui-fs-sm);
	font-weight: 400;
	vertical-align: middle;
}

.ui-user-directory__name {
	display: inline-flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 0 2px;
	min-width: 0;
}

.ui-user-role-tags {
	display: inline-flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 4px;
	margin-left: 6px;
}

.ui-user-role-tags__tag {
	padding: 1px 5px;
	font-size: var(--ui-fs-sm);
	color: var(--ui-text-muted);
	border: 1px solid var(--ui-border-mid);
	background: var(--ui-bg-inset);
	border-radius: 2px;
	line-height: 1.2;
}

.ui-user-role-tags__tag--danger {
	color: var(--ui-danger);
	border-color: #4a3030;
}

.ui-user-directory__uid {
	margin-right: 6px;
	font-size: var(--ui-fs-sm);
	letter-spacing: 0.02em;
}

.ui-avatar {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	background: var(--ui-bg-inset);
	border: 1px solid var(--ui-border-mid);
	box-shadow: inset 1px 1px 2px rgba(0, 0, 0, 0.6);
	overflow: hidden;
	color: var(--ui-text-muted);
}

.ui-avatar img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.ui-avatar--placeholder {
	background-image: repeating-linear-gradient(
		135deg,
		rgba(255, 255, 255, 0.02) 0 4px,
		transparent 4px 8px
	);
}

.ui-avatar__initial {
	font-size: 22px;
	font-weight: 600;
	color: var(--ui-text-muted);
	letter-spacing: 0.02em;
	user-select: none;
}

.ui-profile-header {
	display: flex;
	align-items: flex-start;
	gap: 12px;
	margin-bottom: 8px;
}

.ui-profile-header__meta {
	display: flex;
	flex-direction: column;
	gap: 2px;
	min-width: 0;
}

/* Profile view: header stays top; comments list scrolls inside lower group */
.ui-profile-stack {
	flex: 1;
	display: flex;
	flex-direction: column;
	min-height: 0;
	gap: 8px;
}

.ui-profile-stack > .ui-group {
	margin-top: 0;
}

.ui-profile-stack > .ui-group:first-child {
	flex: 0 0 auto;
}

.ui-profile-comments-wrap {
	flex: 1 1 0;
	min-height: 0;
	display: flex;
	flex-direction: column;
}

.ui-profile-comments-wrap > .ui-group {
	flex: 1;
	min-height: 0;
	margin-top: 0;
}

.ui-group__body--profile-comments {
	display: flex;
	flex-direction: column;
	overflow: hidden;
	min-height: 0;
	gap: 8px;
}

.ui-profile-comments-scroll {
	flex: 1 1 0;
	min-height: 0;
	overflow-y: auto;
}

.ui-profile-comments-compose {
	flex-shrink: 0;
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.ui-profile-comment-row {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	align-items: start;
	column-gap: 8px;
	margin-bottom: 5px;
}

.ui-profile-comment-row__text {
	min-width: 0;
	word-break: break-word;
	margin-bottom: 0;
}

.ui-profile-comment-row__rail {
	display: flex;
	flex-direction: column;
	align-items: stretch;
	min-width: 2.75rem;
}

.ui-profile-comment-row__del {
	width: 100%;
	min-width: 2.75rem;
}

/* admin: generated invite — click to copy */
.ui-invite-code-btn {
	display: inline-block;
	max-width: 100%;
	overflow: hidden;
	text-overflow: ellipsis;
	padding: 2px 4px;
	margin: 0;
	border: 1px dashed var(--ui-border-mid);
	background: var(--ui-bg-inset);
	color: var(--ui-text-bright);
	font: inherit;
	font-size: var(--ui-fs);
	letter-spacing: 0.04em;
	cursor: pointer;
	text-align: left;
}

.ui-invite-code-btn:hover {
	border-color: var(--ui-accent-soft);
	color: var(--ui-accent);
	box-shadow: 0 0 8px var(--ui-accent-glow);
}

/* —— main column —— */
.ui-main {
	flex: 1;
	display: flex;
	flex-direction: column;
	min-width: 0;
	min-height: 0;
	background: var(--ui-bg);
}

.ui-subtabs {
	display: flex;
	align-items: stretch;
	gap: 0;
	padding: 0 6px;
	border-bottom: 1px solid var(--ui-border-mid);
	flex-shrink: 0;
	background: linear-gradient(180deg, #0a0a0c 0%, #050506 100%);
	min-height: 26px;
}

.ui-subtab {
	padding: 5px 14px 4px;
	background: transparent;
	border: none;
	border-bottom: 2px solid transparent;
	color: var(--ui-text-muted);
	font: inherit;
	font-size: var(--ui-fs-lg);
	cursor: pointer;
	transition: color 0.1s, border-color 0.1s;
}

.ui-subtab:hover {
	color: var(--ui-text);
}

.ui-subtab--active {
	color: var(--ui-accent);
	border-bottom-color: var(--ui-accent);
	text-shadow: 0 0 10px var(--ui-accent-glow);
}

.ui-columns {
	flex: 1;
	display: flex;
	min-height: 0;
	gap: 0;
	background: var(--ui-bg);
}

.ui-col {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
	padding: 5px 6px 6px;
	overflow: hidden;
}

.ui-col + .ui-col {
	border-left: 1px solid var(--ui-border-mid);
}

.ui-col--main {
	flex: 1 1 0;
	min-width: 0;
}

/* Right “panel” column — fixed narrow width */
.ui-col--side {
	flex: 0 0 148px;
	width: 148px;
	max-width: 148px;
	min-width: 0;
	padding-left: 4px;
	padding-right: 4px;
}

/* Shoutbox: message text left, admin rail — gap keeps del clear of scrollbar gutter */
.ui-shout-scroll--mod .ui-shout-row {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	align-items: start;
	column-gap: 12px;
	row-gap: 2px;
	margin-bottom: 6px;
}

.ui-shout-row {
	margin-bottom: 4px;
}

.ui-shout-row__body {
	display: grid;
	grid-template-columns: auto minmax(0, 1fr);
	align-items: start;
	column-gap: 0.45em;
	min-width: 0;
}

.ui-shout-row__ts {
	white-space: nowrap;
	flex-shrink: 0;
}

.ui-shout-row__content {
	min-width: 0;
	word-break: break-word;
}

.ui-shout-row__rail {
	display: flex;
	flex-direction: column;
	align-items: stretch;
	justify-content: flex-start;
	flex-shrink: 0;
	min-width: 2.75rem;
}

.ui-shout-row__del {
	width: 100%;
	min-width: 2.75rem;
}

.ui-group__body--shout {
	display: flex;
	flex-direction: column;
	overflow: hidden;
	min-height: 0;
}

/* Users directory: search stays fixed; list fills remaining group height */
.ui-group__body--user-directory {
	display: flex;
	flex-direction: column;
	overflow: hidden;
	min-height: 0;
}

.ui-user-directory-list.ui-scroll {
	flex: 1 1 0;
	min-height: 0;
	margin-top: 8px;
}

.ui-shout-wrap {
	display: flex;
	flex-direction: column;
	flex: 1;
	min-height: 0;
}

.ui-shout-scroll-area {
	flex: 1 1 0;
	min-height: 0;
}

.ui-shout-composer {
	flex-shrink: 0;
	padding-top: 6px;
	margin-top: 2px;
	border-top: 1px solid var(--ui-border-mid);
}

.ui-shout-composer__row {
	display: flex;
	flex-direction: row;
	align-items: stretch;
	gap: 8px;
}

.ui-shout-composer__input {
	flex: 1 1 auto;
	min-width: 0;
}

.ui-shout-composer__send {
	flex-shrink: 0;
	align-self: center;
}

.ui-voice-layout {
	display: flex;
	flex-direction: row;
	gap: 12px;
	align-items: flex-start;
	min-height: 200px;
}

.ui-voice-sidebar {
	flex: 0 0 180px;
	min-width: 0;
}

.ui-voice-main {
	flex: 1;
	min-width: 0;
}

.ui-voice-channel-list {
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.ui-voice-channel-list .ui-btn {
	width: 100%;
	text-align: left;
}

.ui-voice-channel-row {
	display: flex;
	flex-direction: row;
	align-items: stretch;
	gap: 4px;
}

.ui-voice-channel-row__name {
	flex: 1 1 auto;
	min-width: 0;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	text-align: left;
	gap: 2px;
}

.ui-voice-channel-row__label {
	font-weight: inherit;
}

.ui-voice-channel-row__role {
	font-size: 0.85em;
	color: var(--ui-text-muted);
	font-weight: normal;
}

.ui-voice-new-desc {
	min-height: 64px;
	resize: vertical;
}

.ui-voice-channel-access {
	margin: 4px 0 0;
}

.ui-voice-channel-desc {
	white-space: pre-wrap;
	margin: 8px 0 0;
	padding: 8px 10px;
	background: var(--ui-bg-panel);
	border: 1px solid var(--ui-border-mid);
	border-radius: 4px;
	color: var(--ui-text-muted);
	font-size: var(--ui-fs);
	line-height: 1.35;
}

.ui-voice-peer-line {
	display: flex;
	flex-direction: row;
	align-items: center;
	justify-content: space-between;
	gap: 8px;
	flex-wrap: wrap;
}

.ui-voice-audio-mount {
	position: relative;
	width: 0;
	height: 0;
	overflow: hidden;
}

.ui-voice-audio-hidden {
	position: absolute;
	width: 0;
	height: 0;
	opacity: 0;
	pointer-events: none;
}

.ui-voice-peer-list {
	list-style: none;
	margin: 8px 0 0;
	padding: 0;
}

.ui-voice-peer-list li {
	margin: 4px 0;
}

.ui-voice-peer {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 2px 8px;
	border-radius: 4px;
	transition:
		box-shadow 0.12s ease,
		color 0.12s ease,
		background 0.12s ease;
}

.ui-voice-peer--speaking {
	color: var(--ui-accent);
	box-shadow: 0 0 0 1px var(--ui-accent-glow), 0 0 10px var(--ui-accent-glow);
	animation: ui-voice-speaker-pulse 0.85s ease-in-out infinite;
}

@keyframes ui-voice-speaker-pulse {
	0%,
	100% {
		opacity: 1;
	}
	50% {
		opacity: 0.88;
	}
}

.ui-voice-peer__dot {
	display: inline-block;
	width: 7px;
	height: 7px;
	border-radius: 50%;
	background: var(--ui-accent);
	box-shadow: 0 0 0 2px var(--ui-accent-glow);
	animation: ui-voice-dot 0.55s ease-in-out infinite alternate;
}

@keyframes ui-voice-dot {
	from {
		transform: scale(0.88);
		opacity: 0.75;
	}
	to {
		transform: scale(1.08);
		opacity: 1;
	}
}

/* —— ImGui-style child / group (inset bevel) —— */
.ui-group {
	position: relative;
	flex: 1;
	display: flex;
	flex-direction: column;
	min-height: 0;
	margin-top: 8px;
	background: var(--ui-bg-panel);
	border: 1px solid var(--ui-border-inner);
	box-shadow:
		inset 1px 1px 0 var(--ui-edge-hi),
		inset -1px -1px 0 var(--ui-edge-lo);
}

.ui-group__legend {
	position: absolute;
	top: -6px;
	left: 10px;
	padding: 0 5px;
	background: var(--ui-bg);
	font-size: var(--ui-fs);
	color: var(--ui-text-muted);
	font-weight: 500;
	letter-spacing: 0.06em;
}

.ui-group__body {
	padding: 12px 8px 8px;
	flex: 1;
	overflow: auto;
	min-height: 0;
}

.ui-muted {
	color: var(--ui-text-muted);
	font-size: var(--ui-fs);
}

.ui-row {
	display: flex;
	align-items: center;
	gap: 6px;
	margin-bottom: 5px;
	flex-wrap: wrap;
}

/* Push trailing actions (e.g. delete) to the right edge of the groupbox */
.ui-row.ui-row--spread {
	justify-content: space-between;
	width: 100%;
	flex-wrap: nowrap;
	gap: 10px;
	box-sizing: border-box;
}

.ui-row__fill {
	flex: 1 1 auto;
	min-width: 0;
}

.ui-check {
	display: flex;
	align-items: center;
	gap: 6px;
	cursor: pointer;
	font-size: var(--ui-fs-lg);
}

.ui-check input {
	appearance: none;
	width: 11px;
	height: 11px;
	border: 1px solid var(--ui-edge-hi);
	background: var(--ui-bg-inset);
	box-shadow: inset 1px 1px 0 var(--ui-edge-lo);
	cursor: pointer;
}

.ui-check input:checked {
	background: linear-gradient(135deg, var(--ui-accent-soft), var(--ui-accent));
	border-color: var(--ui-accent);
	box-shadow: inset 0 0 0 1px #000;
}

.ui-btn {
	background: linear-gradient(180deg, #1a1a1e 0%, #121214 100%);
	border: 1px solid var(--ui-border-mid);
	color: var(--ui-text);
	font: inherit;
	font-size: var(--ui-fs-lg);
	padding: 3px 10px;
	cursor: pointer;
	box-shadow:
		inset 0 1px 0 var(--ui-edge-hi),
		0 1px 0 var(--ui-edge-lo);
}

.ui-btn:hover {
	border-color: var(--ui-edge-hi);
	color: var(--ui-text-bright);
}

.ui-btn:active {
	background: #0c0c0e;
	box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.5);
}

.ui-btn--small {
	padding: 2px 6px;
	font-size: var(--ui-fs);
}

.ui-btn--danger {
	border-color: #4a3030;
	color: var(--ui-danger);
}

.ui-input,
.ui-textarea,
.ui-select {
	width: 100%;
	background: var(--ui-bg-inset);
	border: 1px solid var(--ui-border-inner);
	color: var(--ui-text-bright);
	font: inherit;
	font-size: var(--ui-fs-lg);
	padding: 4px 6px;
	box-shadow: inset 1px 1px 2px rgba(0, 0, 0, 0.6);
}

.ui-input:disabled,
.ui-textarea:disabled,
.ui-select:disabled {
	color: var(--ui-text-muted);
	background: #0a0a0c;
	cursor: not-allowed;
	opacity: 0.6;
}

.ui-textarea {
	min-height: 56px;
	resize: vertical;
}

.ui-label {
	display: block;
	font-size: var(--ui-fs);
	color: var(--ui-text-muted);
	margin-bottom: 2px;
	letter-spacing: 0.02em;
}

.ui-slider {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 7px;
}

.ui-slider__track {
	flex: 1;
	height: 9px;
	background: #0a0a0c;
	border: 1px solid var(--ui-border-inner);
	box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.8);
	position: relative;
}

.ui-slider__fill {
	position: absolute;
	left: 0;
	top: 0;
	bottom: 0;
	background: linear-gradient(90deg, var(--ui-accent-soft), var(--ui-accent));
	opacity: 0.9;
	pointer-events: none;
}

.ui-slider__thumb {
	position: absolute;
	top: -2px;
	width: 4px;
	height: 13px;
	background: #1e1e22;
	border: 1px solid var(--ui-edge-hi);
	transform: translateX(-50%);
	pointer-events: none;
	box-shadow: 1px 1px 0 var(--ui-edge-lo);
}

.ui-slider__val {
	min-width: 38px;
	text-align: right;
	font-size: var(--ui-fs);
	color: var(--ui-text-muted);
	background: var(--ui-bg-inset);
	border: 1px solid var(--ui-border-mid);
	padding: 1px 4px;
}

.ui-list {
	border: 1px solid var(--ui-border-inner);
	background: var(--ui-bg-inset);
	max-height: 100%;
	overflow-y: auto;
	flex: 1;
	min-height: 72px;
	box-shadow: inset 0 1px 4px rgba(0, 0, 0, 0.45);
}

.ui-list__item {
	display: block;
	width: 100%;
	text-align: left;
	padding: 3px 6px;
	border: none;
	border-bottom: 1px solid #121214;
	background: transparent;
	color: var(--ui-text-muted);
	font: inherit;
	font-size: var(--ui-fs-lg);
	cursor: pointer;
}

.ui-list__item:last-child {
	border-bottom: none;
}

.ui-list__item:hover {
	background: var(--ui-bg-hover);
	color: var(--ui-text);
}

.ui-list__item--sel {
	color: var(--ui-accent);
	background: rgba(154, 174, 232, 0.08);
	text-shadow: 0 0 8px var(--ui-accent-glow);
}

/* forums: boards (headers) vs threads (nested list) */
.ui-forum-boards {
	display: flex;
	flex-direction: column;
	gap: 14px;
	max-height: min(58vh, 520px);
	overflow-y: auto;
	padding-right: 2px;
}

.ui-forum-board {
	border: 1px solid var(--ui-border-mid);
	background: var(--ui-bg);
	box-shadow: 1px 1px 0 var(--ui-edge-lo);
	overflow: hidden;
}

.ui-forum-board__bar {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 2px;
	padding: 8px 10px 9px 12px;
	border-left: 3px solid var(--ui-accent);
	background: linear-gradient(180deg, #141418 0%, #0a0a0c 100%);
	border-bottom: 1px solid var(--ui-border-inner);
}

.ui-forum-board__title {
	color: var(--ui-text-bright);
	font-size: var(--ui-fs-lg);
	font-weight: 600;
	letter-spacing: 0.02em;
	text-shadow: 0 0 12px var(--ui-accent-glow);
}

.ui-forum-board__desc {
	color: var(--ui-text-muted);
	font-size: var(--ui-fs);
	line-height: 1.3;
	max-width: 100%;
}

.ui-forum-board__body {
	padding: 8px 10px 10px 12px;
	background: var(--ui-bg-inset);
	border-top: 1px solid #0e0e0f;
}

.ui-forum-board__actions {
	flex-wrap: wrap;
	gap: 6px;
	margin-bottom: 4px;
}

.ui-forum-board__empty {
	margin: 4px 0 6px;
}

.ui-forum-thread-list {
	min-height: 0;
	max-height: 220px;
	flex: 0 1 auto;
	border: 1px solid #121214;
	background: #060606;
	box-shadow: inset 0 1px 4px rgba(0, 0, 0, 0.5);
}

.ui-forum-thread-list__item {
	font-size: var(--ui-fs);
	padding: 4px 8px 4px 10px;
	color: var(--ui-text-muted);
	border-bottom-color: #151518;
}

.ui-forum-thread-list__item:hover {
	color: var(--ui-text);
}

.ui-scroll {
	overflow: auto;
	flex: 1;
	min-height: 0;
}

.ui-post {
	border: 1px solid var(--ui-border-mid);
	padding: 5px 6px;
	margin-bottom: 5px;
	background: var(--ui-bg-inset);
	box-shadow: inset 1px 1px 0 var(--ui-edge-lo);
}

.ui-post strong {
	color: var(--ui-text-bright);
}

.ui-err {
	color: var(--ui-danger);
	font-size: var(--ui-fs);
}

.ui-login-body {
	padding: 10px 12px 12px;
	display: flex;
	flex-direction: column;
	gap: 6px;
	background: var(--ui-bg);
}

.ui-login-divider {
	border-top: 1px solid var(--ui-border-mid);
	padding-top: 10px;
	margin-top: 4px;
}

.ui-toasts {
	position: absolute;
	right: 10px;
	bottom: 10px;
	display: flex;
	flex-direction: column;
	gap: 5px;
	pointer-events: none;
	z-index: 50;
}

.ui-toast {
	padding: 5px 9px;
	border: 1px solid var(--ui-border-mid);
	background: rgba(8, 8, 10, 0.97);
	font-size: var(--ui-fs);
	pointer-events: auto;
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.6);
}

.ui-toast--error {
	border-color: #4a3030;
	color: var(--ui-danger);
}

.ui-toast--success {
	border-color: #304a30;
	color: #8aba8a;
}

.ui-context-menu {
	min-width: 180px;
	max-width: min(280px, calc(100vw - 16px));
	border: 1px solid var(--ui-border-outer);
	background: var(--ui-bg-panel);
	padding: 4px;
	box-shadow:
		inset 1px 1px 0 var(--ui-edge-hi),
		inset -1px -1px 0 var(--ui-edge-lo),
		0 10px 28px rgba(0, 0, 0, 0.85);
	font-family: inherit;
	font-size: var(--ui-fs-sm);
	text-transform: lowercase;
}

.ui-context-menu__item {
	display: block;
	width: 100%;
	box-sizing: border-box;
	margin: 0;
	padding: 6px 10px;
	border: 1px solid transparent;
	background: transparent;
	color: var(--ui-text);
	font: inherit;
	text-align: left;
	text-transform: lowercase;
	cursor: pointer;
	-webkit-font-smoothing: none;
}

.ui-context-menu__item:hover,
.ui-context-menu__item:focus-visible {
	outline: none;
	border-color: var(--ui-border-mid);
	background: rgba(154, 174, 232, 0.08);
	color: var(--ui-accent);
	box-shadow: 0 0 10px var(--ui-accent-glow);
}

.ui-context-menu__item--danger:hover,
.ui-context-menu__item--danger:focus-visible {
	color: var(--ui-danger);
	box-shadow: 0 0 10px rgba(200, 96, 96, 0.25);
}

.ui-modal-back {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.62);
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 40;
}

.ui-modal {
	border: 1px solid var(--ui-border-outer);
	background: var(--ui-bg-panel);
	padding: 12px;
	min-width: 260px;
	max-width: 90%;
	box-shadow:
		inset 1px 1px 0 var(--ui-edge-hi),
		0 16px 48px rgba(0, 0, 0, 0.9);
}

.ui-footer-credit {
	padding: 6px 8px 7px;
	border-top: 1px solid var(--ui-border-mid);
	text-align: center;
	font-size: var(--ui-fs-sm);
	line-height: 1.35;
	color: var(--ui-text-muted);
	flex-shrink: 0;
	background: var(--ui-bg);
}

.ui-accent-picker {
	display: flex;
	flex-direction: column;
	gap: 8px;
	margin-top: 4px;
}

.ui-accent-picker__row {
	display: flex;
	flex-direction: row;
	align-items: stretch;
	gap: 10px;
}

.ui-accent-picker__swatch {
	width: 72px;
	height: 72px;
	flex-shrink: 0;
	border: 1px solid var(--ui-border-mid);
	box-shadow:
		inset 1px 1px 0 var(--ui-edge-hi),
		inset -1px -1px 0 var(--ui-edge-lo);
	background: var(--ui-bg-inset);
}

.ui-accent-picker__slider-wrap {
	width: 28px;
	height: 72px;
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: visible;
}

/* Horizontal range rotated 90° so it reads bottom=min hue, top=max hue */
.ui-accent-slider {
	-webkit-appearance: none;
	appearance: none;
	width: 72px;
	height: 22px;
	margin: 0;
	transform: rotate(-90deg);
	transform-origin: center center;
	cursor: pointer;
	background: transparent;
}

.ui-accent-slider:focus {
	outline: 1px solid var(--ui-accent);
	outline-offset: 2px;
}

.ui-accent-slider::-webkit-slider-runnable-track {
	height: 12px;
	border-radius: 2px;
	border: 1px solid var(--ui-border-inner);
	background: linear-gradient(
		to right,
		hsl(0, 65%, 68%),
		hsl(60, 65%, 68%),
		hsl(120, 65%, 68%),
		hsl(180, 65%, 68%),
		hsl(240, 65%, 68%),
		hsl(300, 65%, 68%),
		hsl(360, 65%, 68%)
	);
	box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.45);
}

.ui-accent-slider::-webkit-slider-thumb {
	-webkit-appearance: none;
	appearance: none;
	width: 10px;
	height: 18px;
	margin-top: -4px;
	border-radius: 2px;
	border: 1px solid var(--ui-edge-hi);
	background: linear-gradient(180deg, #2a2a30 0%, #121214 100%);
	box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.6);
}

.ui-accent-slider::-moz-range-track {
	height: 12px;
	border-radius: 2px;
	border: 1px solid var(--ui-border-inner);
	background: linear-gradient(
		to right,
		hsl(0, 65%, 68%),
		hsl(60, 65%, 68%),
		hsl(120, 65%, 68%),
		hsl(180, 65%, 68%),
		hsl(240, 65%, 68%),
		hsl(300, 65%, 68%),
		hsl(360, 65%, 68%)
	);
}

.ui-accent-slider::-moz-range-thumb {
	width: 10px;
	height: 18px;
	border-radius: 2px;
	border: 1px solid var(--ui-edge-hi);
	background: linear-gradient(180deg, #2a2a30 0%, #121214 100%);
	cursor: pointer;
}

.ui-accent-picker__reset {
	align-self: flex-start;
}

.ui-hr {
	border: none;
	border-top: 1px solid var(--ui-border-mid);
	margin: 6px 0;
}

h3.ui-title,
.ui-title {
	margin: 4px 0 6px;
	font-size: clamp(11px, 0.5vw + 9px, 13px);
	font-weight: 500;
	color: var(--ui-text-bright);
	letter-spacing: 0.02em;
}

@media (max-width: 900px) {
	.ui-window--audit {
		width: calc(100vw - 16px);
		min-width: 0;
	}
}

@media (max-width: 560px) {
	.ui-window {
		min-width: 0;
		width: calc(100vw - 12px);
		height: calc(100vh - 12px);
		left: 6px !important;
		top: 6px !important;
	}
	.ui-window--audit {
		min-width: 0 !important;
		width: calc(100vw - 12px) !important;
		height: min(52vh, calc(100vh - 12px)) !important;
		left: 6px !important;
		top: auto !important;
		bottom: 6px !important;
	}
	.ui-columns {
		flex-direction: column;
	}
	.ui-col + .ui-col {
		border-left: none;
		border-top: 1px solid var(--ui-border-mid);
	}

	.ui-col--side {
		flex: 1 1 auto;
		width: auto;
		max-width: none;
	}
}
