:root {
	--ink: #2f2b32;
	--muted: #706976;
	--paper: #fffaf7;
	--panel: #ffffff;
	--line: #eadbe2;
	--blush: #c9728f;
	--berry: #843a5b;
	--sage: #779783;
	--danger: #b83255;
	--radius: 8px;
	--shadow: 0 14px 36px rgba(70, 42, 58, .11);
}

* {
	box-sizing: border-box;
}

body {
	margin: 0;
	min-height: 100vh;
	color: var(--ink);
	background: #f8f2f4;
	font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	letter-spacing: 0;
}

a {
	color: inherit;
	text-decoration: none;
}

button,
input,
textarea {
	font: inherit;
}

.auth-page {
	display: grid;
	place-items: center;
	padding: 28px;
	background:
		linear-gradient(135deg, rgba(248,242,244,.98), rgba(232,241,235,.88));
}

.auth-box {
	width: min(100%, 430px);
	padding: 30px;
	border: 1px solid var(--line);
	border-radius: var(--radius);
	background: var(--panel);
	box-shadow: var(--shadow);
}

.auth-brand {
	display: grid;
	place-items: center;
	width: 52px;
	height: 52px;
	border-radius: 50%;
	color: #fff;
	background: var(--berry);
}

.auth-box h1,
.admin-topbar h1,
.panel-heading h2 {
	margin: 10px 0 6px;
	font-family: Georgia, "Times New Roman", serif;
	letter-spacing: 0;
}

.auth-box p,
.admin-topbar p,
.panel-heading p {
	margin: 0;
	color: var(--muted);
}

.auth-link {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	margin-top: 18px;
	color: var(--berry);
	font-weight: 800;
}

.admin-page {
	display: grid;
	grid-template-columns: 270px minmax(0, 1fr);
}

.admin-sidebar {
	position: sticky;
	top: 0;
	height: 100vh;
	padding: 18px;
	border-right: 1px solid var(--line);
	background: var(--paper);
	overflow-y: auto;
}

.admin-logo {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 22px;
	font-weight: 900;
}

.admin-logo span {
	display: grid;
	place-items: center;
	width: 42px;
	height: 42px;
	border-radius: 50%;
	color: #fff;
	background: var(--berry);
	font-size: 13px;
}

.admin-nav {
	display: grid;
	gap: 6px;
}

.admin-nav a {
	display: flex;
	align-items: center;
	gap: 10px;
	min-height: 42px;
	padding: 10px 12px;
	border-radius: var(--radius);
	color: var(--muted);
	font-weight: 800;
}

.admin-nav a:hover,
.admin-nav a.is-active {
	color: var(--berry);
	background: #f4e6ec;
}

.admin-shell {
	min-width: 0;
}

.admin-topbar {
	position: sticky;
	top: 0;
	z-index: 10;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	padding: 18px clamp(18px, 4vw, 44px);
	border-bottom: 1px solid var(--line);
	background: rgba(255, 250, 247, .92);
	backdrop-filter: blur(16px);
}

.topbar-actions,
.panel-heading,
.form-actions,
.row-actions,
.message-meta {
	display: flex;
	align-items: center;
	gap: 10px;
}

.topbar-actions,
.form-actions,
.row-actions {
	flex-wrap: wrap;
}

.admin-content {
	padding: clamp(18px, 4vw, 44px);
}

.stat-grid {
	display: grid;
	grid-template-columns: repeat(6, minmax(0, 1fr));
	gap: 14px;
	margin-bottom: 22px;
}

.stat-card {
	padding: 18px;
	border: 1px solid var(--line);
	border-radius: var(--radius);
	background: var(--panel);
	box-shadow: var(--shadow);
}

.stat-card i {
	color: var(--berry);
}

.stat-card.accent i {
	color: var(--sage);
}

.stat-card span {
	display: block;
	margin-top: 12px;
	font-size: 32px;
	font-weight: 900;
}

.stat-card p {
	margin: 2px 0 0;
	color: var(--muted);
	font-weight: 700;
}

.admin-panel {
	padding: 24px;
	border: 1px solid var(--line);
	border-radius: var(--radius);
	background: var(--panel);
	box-shadow: var(--shadow);
}

.panel-heading {
	justify-content: space-between;
	margin-bottom: 20px;
}

.quick-grid {
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 12px;
}

.quick-grid a {
	display: grid;
	gap: 12px;
	min-height: 116px;
	padding: 18px;
	border: 1px solid var(--line);
	border-radius: var(--radius);
	background: #fffdfb;
	font-weight: 900;
}

.quick-grid i {
	color: var(--berry);
	font-size: 22px;
}

.admin-btn,
.icon-action {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	border: 1px solid transparent;
	border-radius: var(--radius);
	font-weight: 900;
	cursor: pointer;
}

.admin-btn {
	min-height: 42px;
	padding: 10px 14px;
}

.admin-btn.primary {
	color: #fff;
	background: var(--berry);
}

.admin-btn.ghost {
	color: var(--berry);
	border-color: var(--line);
	background: #fff;
}

.admin-btn.danger,
.icon-action.danger {
	color: #fff;
	background: var(--danger);
}

.icon-action {
	width: 36px;
	height: 36px;
	color: var(--berry);
	background: #f7edf1;
}

.table-wrap {
	overflow-x: auto;
}

.admin-table {
	width: 100%;
	border-collapse: collapse;
	min-width: 760px;
}

.admin-table th,
.admin-table td {
	padding: 13px 12px;
	border-bottom: 1px solid var(--line);
	text-align: left;
	vertical-align: top;
}

.admin-table th {
	color: var(--muted);
	font-size: 12px;
	text-transform: uppercase;
}

.admin-table code {
	font-size: 12px;
	color: var(--muted);
}

.status {
	display: inline-flex;
	align-items: center;
	min-height: 26px;
	padding: 5px 9px;
	border-radius: 999px;
	font-size: 12px;
	font-weight: 900;
}

.status.on {
	color: #236348;
	background: #e2f3ea;
}

.status.off {
	color: #9a3150;
	background: #f8e1e9;
}

.empty-cell {
	color: var(--muted);
	text-align: center;
}

.admin-form {
	display: grid;
	gap: 18px;
}

.form-grid {
	display: grid;
	gap: 16px;
}

.form-grid.two {
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

label {
	display: grid;
	gap: 8px;
	color: var(--ink);
	font-weight: 900;
}

input,
textarea {
	width: 100%;
	border: 1px solid var(--line);
	border-radius: var(--radius);
	padding: 12px 13px;
	color: var(--ink);
	background: #fffdfb;
}

textarea {
	resize: vertical;
}

input:focus,
textarea:focus {
	outline: 3px solid rgba(201, 114, 143, .2);
	border-color: var(--blush);
}

.check-row {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	margin: 0;
}

.check-row input {
	width: 18px;
	height: 18px;
}

.image-preview {
	width: 156px;
	overflow: hidden;
	border: 1px solid var(--line);
	border-radius: var(--radius);
	background: #fff;
}

.image-preview.wide {
	width: min(420px, 100%);
}

.image-preview img {
	display: block;
	width: 100%;
	aspect-ratio: 1 / 1;
	object-fit: cover;
}

.image-preview.wide img {
	aspect-ratio: 4 / 3;
}

.admin-alert {
	margin-bottom: 14px;
	padding: 12px 14px;
	border-radius: var(--radius);
	font-weight: 800;
}

.admin-alert.success {
	color: #235f45;
	background: #e2f3ea;
}

.admin-alert.danger {
	color: #9a3150;
	background: #f8e1e9;
}

.message-card {
	display: grid;
	gap: 20px;
	padding: 22px;
	border: 1px solid var(--line);
	border-radius: var(--radius);
	background: #fffdfb;
}

.message-meta {
	flex-wrap: wrap;
	color: var(--muted);
	font-weight: 800;
}

.message-card p {
	margin: 0;
	line-height: 1.8;
}

@media (max-width: 1180px) {
	.stat-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.quick-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

@media (max-width: 860px) {
	.admin-page {
		grid-template-columns: 1fr;
	}

	.admin-sidebar {
		position: static;
		height: auto;
	}

	.admin-nav {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.admin-topbar,
	.panel-heading {
		align-items: flex-start;
		flex-direction: column;
	}

	.form-grid.two,
	.quick-grid {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 560px) {
	.auth-page {
		padding: 16px;
	}

	.admin-nav,
	.stat-grid {
		grid-template-columns: 1fr;
	}

	.admin-btn {
		width: 100%;
	}
}
