/* 2026-06-08 global theme overrides */

:root {
	--app-bg: #f4f7fb;
	--panel-bg: #ffffff;
	--panel-border: #d9e2ef;
	--panel-shadow: 0 10px 30px rgba(15, 23, 42, 0.08);
	--text-main: #1e293b;
	--text-soft: #64748b;
	--accent: #1d4ed8;
	--accent-soft: #e8f0ff;
	--line-soft: #e2e8f0;
	--menu-border: #cfd8e3;
	--menu-bg: rgba(255, 255, 255, 0.98);
	--button-txt-color: #fff;
	--button-border: #1d4ed8;
	--button-bg: linear-gradient(180deg, #2563eb 0%, #1d4ed8 100%);
}

html,
body {
	background: var(--app-bg);
	color: var(--text-main);
}

body {
	font-size: 16px;
	line-height: 1.45;
	padding: 1rem;
	padding-top: 5em;
}

div#body_bg {
	background:
		radial-gradient(circle at top left, rgba(37, 99, 235, 0.12), transparent 28%),
		linear-gradient(to bottom, #f8fbff 0%, #edf3fa 100%);
}

h1,
h2,
h3,
h4 {
	color: #0f172a;
	line-height: 1.2;
	margin-top: 0;
}

a {
	color: var(--accent);
}

.button,
form.standard a.button,
form.standard input[type=submit],
form.standard input[type=button] {
	border: 1px solid var(--button-border);
	border-radius: 10px;	
	font-weight: 400;
	padding: .65rem 1.1rem;
	transition: transform .15s ease, box-shadow .15s ease, filter .15s ease;
	background: var(--button-bg);
}

.button:hover,
form.standard a.button:hover,
form.standard input[type=submit]:hover,
form.standard input[type=button]:hover {
	filter: brightness(1.02);
	transform: translateY(-1px);
	box-shadow: 0 8px 18px rgba(37, 99, 235, 0.2);
}

.page,
.box,
.folder-panel,
form.standard fieldset {
	background: var(--panel-bg);
	border: 1px solid var(--panel-border);
	border-radius: 16px;
	box-shadow: var(--panel-shadow);
}

.page {
	padding: 1.25rem 1.4rem;
	margin-bottom: 1.5rem;
}

.page > h1,
.page > h2,
.page > h3 {
	margin-bottom: 1rem;
}

.box {
	padding: 1.25rem 1.5rem;
	border-width: 1px;
	background: var(--panel-bg);
}

#header {
	background: linear-gradient(135deg, #0f172a 0%, #1d4ed8 100%);
	height: auto;
	min-height: 88px;
	padding: 1rem 1.25rem 1.1rem;
	margin: -1rem -1rem 1.25rem -1rem;
	border-radius: 0 0 18px 18px;
	box-shadow: 0 12px 28px rgba(15, 23, 42, 0.2);
}

#user_box {
	bottom: 1rem;
	right: 1.25rem;
	font-size: .95rem;
}

nav.menu {
	background: var(--menu-bg);
	backdrop-filter: blur(10px);
	border: 1px solid var(--menu-border);
	border-radius: 0 0 0 18px;
	box-shadow: 0 14px 30px rgba(15, 23, 42, 0.12);
	padding: 1rem 1.1rem .9rem;
}

nav.menu ul {
	padding-top: .75rem;
}

nav.menu ul li {
	margin: .45rem 0 0 0;
}

nav.menu ul a {
	display: block;
	padding: .55rem .75rem;
	border-radius: 10px;
	color: var(--text-main);
	font-size: 1rem;
	transition: background-color .15s ease, color .15s ease;
}

nav.menu ul a:hover {
	background: var(--accent-soft);
	text-decoration: none;
}

nav.menu ul li.selected > a,
nav.menu ul li.active > a.menu_link {
	background: var(--accent-soft);
	color: var(--accent);
	font-weight: 700;
}

nav.menu ul li.selected::before {
	margin-left: -.45rem;
	margin-top: -.15rem;
	font-size: 1.3rem;
	color: var(--accent);
}

nav.menu .has_children ul.sub {
	border-top: 1px solid var(--line-soft);
	margin-top: .35rem;
	padding: .45rem 0 0;
}

a.menu_burger {
	color: #0f172a;
	background: rgba(255, 255, 255, 0.92);
	border: 1px solid var(--panel-border);
	border-radius: 12px;
	box-shadow: 0 10px 24px rgba(15, 23, 42, 0.14);
}

a.menu_close {
	color: #0f172a;
	border: 1px solid var(--panel-border);
}

a.menu_burger {
	padding: 8px 12px;
	margin: .7rem .8rem;
}

a.menu_close {
	padding: 4px 10px;
}

#breadcrumb {
	margin: .5rem 0 1rem;
	padding: .85rem 1rem;
	background: rgba(255, 255, 255, 0.75);
	border: 1px solid var(--panel-border);
	border-radius: 12px;
	box-shadow: 0 8px 22px rgba(15, 23, 42, 0.05);
}

.pages {
	display: flex;
	justify-content: flex-end;
	align-items: center;
	gap: .45rem;
	font-size: .9rem;
	margin: 1rem 0;
}

.pages a,
.pages input[type=number] {
	height: 2.3rem;
	border-radius: 10px;
	border: 1px solid var(--panel-border);
	background: #fff;
}

.pages a {
	width: 2.3rem;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 1rem;
}

.pages input[type=number] {
	width: 4rem;
	background: #fff;
}

table {
	background: transparent;
}

table caption {
	padding: .35rem 0 .75rem;
	color: var(--text-soft);
}

table th {
	padding: .75rem .8rem;
	font-size: .78rem;
	text-transform: uppercase;
	letter-spacing: .04em;
	color: var(--text-soft);
}

table.data {
	border-collapse: separate;
	border-spacing: 0;
	overflow: hidden;
	border: 1px solid var(--panel-border);
	background: #fff;	
}

table.data tbody tr:first-child,
table.data tbody tr:last-child,
table.data tbody {
	border: none;
}

table.data td {
	padding: .8rem;
	border-bottom: 1px solid var(--line-soft);
	vertical-align: middle;
}

table.data tbody td {
	border-left: none;
	border-right: none;
}

table.data tbody tr:nth-child(even),
table.data tbody tr:nth-child(odd) {
	background: #fff;
}

table.data tbody tr:hover {
	background: #f8fbff;
}

table.selectable tbody tr:hover {
	background: #eef4ff;
}

form.standard {
	background: var(--panel-bg);
	border: 1px solid var(--panel-border);
	padding: 1.25rem 1.4rem;
}

form.standard div.field {
	margin-bottom: .9rem;
}

form.standard div.field label:not(.checkbox-label),
form.standard fieldset legend {
	color: var(--text-soft);
	font-size: .8rem;
	font-weight: 600;
	letter-spacing: .02em;
}

form.standard div.field input[type=text],
form.standard div.field input[type=password],
form.standard div.field input[type=number],
form.standard div.field select,
form.standard div.field textarea {
	border: 1px solid var(--panel-border);
	border-radius: 10px;
	padding: .7rem .8rem;
	background: #fff;
	box-shadow: inset 0 1px 2px rgba(15, 23, 42, 0.03);
	transition: border-color .15s ease, box-shadow .15s ease;
}

form.standard div.field input[type=text]:focus,
form.standard div.field input[type=password]:focus,
form.standard div.field input[type=number]:focus,
form.standard div.field select:focus,
form.standard div.field textarea:focus {
	outline: none;
	border-color: #93c5fd;
	box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.12);
}

form.standard fieldset {
	padding: 1rem 1rem .35rem;
	background: #fbfdff;
}

form.standard div.buttons {
	margin-top: 1.5rem;
}

.folder-explorer {
	display: grid;
	grid-template-columns: minmax(280px, 360px) minmax(320px, 1fr);
	gap: 1.5rem;
	padding: .25rem 0 1rem;
}

.folder-panel {
	padding: 1.25rem;
}

.folder-tree,
.folder-content {
	display: flex;
	flex-direction: column;
	gap: .35rem;
}

.folder-node {
	display: block;
}

.folder-link {
	width: 100%;
	display: flex;
	align-items: center;
	gap: .6rem;
	padding: .65rem .8rem;
	border: 0;
	background: transparent;
	border-radius: 10px;
	cursor: pointer;
	text-align: left;
	font: inherit;
	color: var(--text-main);
}

.folder-link:hover,
.folder-node.is-active > .folder-link {
	background: var(--accent-soft);
}

.folder-node.is-loading > .folder-link {
	opacity: .7;
}

.folder-icon::before {
	content: "\f07b";
	font-family: var(--fa-style-family,"Font Awesome 6 Free");
	font-weight: var(--fa-style,900);
	color: var(--accent);
}

.folder-node.is-active > .folder-link .folder-icon::before,
.folder-node.is-open > .folder-link .folder-icon::before {
	content: "\f07c";
}

.folder-children {
	margin-left: 1rem;
	padding-left: .8rem;
	border-left: 1px solid var(--line-soft);
}

.folder-file,
.folder-empty {
	padding: .8rem .9rem;
	border: 1px solid var(--line-soft);
	border-radius: 10px;
	background: #fff;
}

.folder-file {
	font-weight: 600;
	word-break: break-word;
}

.folder-file:hover {
	background: #f8fbff;
}

.folder-empty {
	color: var(--text-soft);
	font-style: italic;
}

@media screen and (max-width: 900px) {
	.folder-explorer {
		grid-template-columns: 1fr;
	}
}

@media screen and (max-width: 600px) {
	body {
		padding: .75rem;
	}

	#header {
		margin: -.75rem -.75rem 1rem -.75rem;
		padding-right: 4rem;
	}

	.page,
	.box,
	form.standard,
	.folder-panel {
		padding: 1rem;
		border-radius: 14px;
	}

	nav.menu {
		width: 100%;
		border-left: none;
		border-radius: 0 0 16px 16px;
		min-width: unset;
	}
}
