/* Unified UI helpers.
   Admin gets the full normalization layer.
   Public keeps the original Artanis visual identity and receives only behavior fixes. */
:root {
	--ui-accent: var(--site-color, #008000);
	--ui-accent-soft: color-mix(in srgb, var(--ui-accent) 12%, #fff);
	--ui-accent-border: color-mix(in srgb, var(--ui-accent) 28%, #d8e0eb);
	--ui-text: #1f2937;
	--ui-muted: #667085;
	--ui-line: #dbe4ef;
	--ui-panel: #fff;
	--ui-page: #f4f7fb;
	--ui-radius: 8px;
	--ui-shadow: 0 14px 36px rgba(15, 23, 42, .08);
	--ui-control-height: 44px;
}

html {
	scrollbar-gutter: stable;
}

body.public-template,
body.admin-single-scroll {
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
}

body.public-template {
	overflow-x: hidden;
	overflow-y: auto;
}

body.public-template.no-scroll,
body.admin-single-scroll.no-scroll,
body.public-template.mfp-zoom-out-cur,
body.admin-single-scroll.mfp-zoom-out-cur {
	overflow-y: hidden !important;
	padding-right: var(--ui-scrollbar-compensation, 0px);
}

/* Public template: preserve Artanis layout, colors, buttons and cards. */
body.public-template img {
	max-width: 100%;
	height: auto;
}

body.public-template .mfp-bg,
body.public-template .mfp-wrap,
.global-action-dialog {
	z-index: 100000 !important;
}

body.public-template .zoom-anim-dialog {
	width: min(760px, calc(100vw - 32px));
	max-width: calc(100vw - 32px);
	max-height: calc(100vh - 48px);
	margin: 24px auto;
	border-radius: 10px;
	overflow: auto;
	box-shadow: 0 22px 55px rgba(15, 23, 42, .18);
}

body.public-template .mfp-close {
	top: 12px !important;
	right: 12px !important;
	width: 38px !important;
	height: 38px !important;
	line-height: 36px !important;
	border-radius: 8px !important;
	background: #fff !important;
	border: 1px solid rgba(15, 23, 42, .12) !important;
	color: #344054 !important;
	opacity: 1 !important;
	box-shadow: 0 8px 20px rgba(15, 23, 42, .08);
}

body.public-template .mfp-close:hover {
	background: var(--ui-accent) !important;
	color: #fff !important;
	border-color: var(--ui-accent) !important;
}

body.public-template .input-group,
body.public-template .input-with-icon-left {
	position: relative;
}

body.public-template .input-group > i,
body.public-template .input-with-icon-left > i {
	position: absolute;
	left: 14px;
	top: 50%;
	transform: translateY(-50%);
	z-index: 2;
	color: #98a2b3;
	pointer-events: none;
}

body.public-template .input-group > input,
body.public-template .input-with-icon-left > input {
	padding-left: 42px;
}

/* Admin template: normalize legacy views into one professional system. */
body.admin-single-scroll {
	color: var(--ui-text);
	background: var(--ui-page);
}

body.admin-single-scroll #dashboard,
body.admin-single-scroll .dashboard-content-inner {
	max-width: min(1480px, calc(100vw - 32px));
}

body.admin-single-scroll input:not([type="checkbox"]):not([type="radio"]):not([type="submit"]),
body.admin-single-scroll select,
body.admin-single-scroll textarea {
	min-height: var(--ui-control-height);
	border: 1px solid var(--ui-line) !important;
	border-radius: var(--ui-radius) !important;
	background-color: #fff !important;
	color: var(--ui-text) !important;
	box-shadow: none !important;
	transition: border-color .18s ease, box-shadow .18s ease, background-color .18s ease;
}

body.admin-single-scroll textarea {
	min-height: 110px;
	resize: vertical;
}

body.admin-single-scroll input:focus,
body.admin-single-scroll select:focus,
body.admin-single-scroll textarea:focus {
	border-color: var(--ui-accent) !important;
	box-shadow: 0 0 0 4px color-mix(in srgb, var(--ui-accent) 14%, transparent) !important;
	outline: 0 !important;
}

body.admin-single-scroll label {
	color: #344054;
	font-weight: 800;
	letter-spacing: .01em;
}

body.admin-single-scroll .button,
body.admin-single-scroll a.button,
body.admin-single-scroll button.button,
body.admin-single-scroll input[type="submit"] {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	min-height: 42px;
	border-radius: var(--ui-radius) !important;
	border: 1px solid transparent;
	font-weight: 900;
	line-height: 1.15;
	text-align: center;
	white-space: nowrap;
	transition: transform .18s ease, box-shadow .18s ease, background-color .18s ease, color .18s ease, border-color .18s ease;
}

body.admin-single-scroll .button,
body.admin-single-scroll a.button,
body.admin-single-scroll button.button,
body.admin-single-scroll input[type="submit"] {
	background: var(--ui-accent) !important;
	color: #fff !important;
	box-shadow: 0 10px 22px color-mix(in srgb, var(--ui-accent) 24%, transparent);
}

body.admin-single-scroll .button:hover,
body.admin-single-scroll a.button:hover,
body.admin-single-scroll button.button:hover,
body.admin-single-scroll input[type="submit"]:hover {
	transform: translateY(-1px);
	background: #fff !important;
	color: var(--ui-accent) !important;
	border-color: var(--ui-accent) !important;
}

body.admin-single-scroll .button:active,
body.admin-single-scroll a.button:active,
body.admin-single-scroll button.button:active {
	transform: translateY(0);
	box-shadow: none;
}

body.admin-single-scroll .fa,
body.admin-single-scroll [class^="icon-"],
body.admin-single-scroll [class*=" icon-"] {
	line-height: 1;
}

body.admin-single-scroll table {
	width: 100%;
	border-collapse: separate;
	border-spacing: 0;
	background: #fff;
	border: 1px solid var(--ui-line);
	border-radius: var(--ui-radius);
	overflow: hidden;
}

body.admin-single-scroll table th {
	background: #f8fafc;
	color: #344054;
	font-size: 12px;
	font-weight: 900;
	letter-spacing: .03em;
	text-transform: uppercase;
}

body.admin-single-scroll table td,
body.admin-single-scroll table th {
	border-bottom: 1px solid #edf2f7;
	vertical-align: middle;
}

body.admin-single-scroll img {
	max-width: 100%;
	height: auto;
}

body.admin-single-scroll .mfp-bg,
body.admin-single-scroll .mfp-wrap,
.global-action-dialog__panel {
	z-index: 100001 !important;
}

body.admin-single-scroll .zoom-anim-dialog,
.global-action-dialog__panel {
	width: min(760px, calc(100vw - 32px));
	max-height: calc(100vh - 48px);
	margin: 24px auto;
	border-radius: 10px;
	overflow: auto;
	box-shadow: var(--ui-shadow);
	border: 1px solid rgba(219, 228, 239, .9);
	background: #fff;
}

body.admin-single-scroll .mfp-close {
	top: 14px !important;
	right: 14px !important;
	width: 38px !important;
	height: 38px !important;
	line-height: 38px !important;
	border-radius: 8px !important;
	background: #fff !important;
	border: 1px solid var(--ui-line) !important;
	color: #344054 !important;
	opacity: 1 !important;
	box-shadow: 0 8px 20px rgba(15, 23, 42, .08);
}

body.admin-single-scroll .mfp-close:hover {
	background: var(--ui-accent) !important;
	color: #fff !important;
	border-color: var(--ui-accent) !important;
}

body.admin-single-scroll .content-counter,
body.admin-single-scroll .records-counter,
body.admin-single-scroll [class*="counter"] {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	min-height: 34px;
	padding: 6px 12px;
	border: 1px solid var(--ui-accent-border);
	border-radius: 999px;
	background: var(--ui-accent-soft);
	color: var(--ui-accent);
	font-weight: 900;
}

body.admin-single-scroll .dashboard-box,
body.admin-single-scroll .admin-card,
body.admin-single-scroll .content-card,
body.admin-single-scroll .settings-card {
	border-radius: var(--ui-radius) !important;
	border: 1px solid var(--ui-line);
	background: var(--ui-panel);
	box-shadow: var(--ui-shadow);
}

body.admin-single-scroll .input-group,
body.admin-single-scroll .input-with-icon-left {
	position: relative;
	display: flex;
	align-items: center;
	width: 100%;
}

body.admin-single-scroll .input-group > i,
body.admin-single-scroll .input-with-icon-left > i {
	position: absolute;
	left: 14px;
	top: 50%;
	transform: translateY(-50%);
	z-index: 2;
	color: #98a2b3;
	pointer-events: none;
}

body.admin-single-scroll .input-group > input,
body.admin-single-scroll .input-with-icon-left > input {
	padding-left: 42px !important;
}

@media (max-width: 768px) {
	body.public-template .zoom-anim-dialog,
	body.admin-single-scroll .zoom-anim-dialog,
	.global-action-dialog__panel {
		width: calc(100vw - 24px);
		max-height: calc(100vh - 24px);
		margin: 12px auto;
	}

	body.admin-single-scroll #dashboard,
	body.admin-single-scroll .dashboard-content-inner {
		max-width: calc(100vw - 24px);
		width: calc(100vw - 24px);
	}

	body.admin-single-scroll .button,
	body.admin-single-scroll a.button,
	body.admin-single-scroll button.button {
		min-height: 40px;
		white-space: normal;
	}
}
