/* assets/css/app.css */

:root {
	--mz-color-primary: #a8924a;
	--mz-color-primary-strong: #8f7633;
	--mz-color-primary-soft: #d8c48a;
	--mz-color-accent: #07111f;
	--mz-color-surface: #0d1a2b;
	--mz-color-surface-2: #12243a;
	--mz-color-surface-3: #172c47;
	--mz-color-card: #ffffff;
	--mz-color-card-muted: #f7f8fb;
	--mz-color-border: rgba(7, 17, 31, 0.1);
	--mz-color-border-strong: rgba(7, 17, 31, 0.18);
	--mz-color-text: #0f1724;
	--mz-color-text-soft: #526075;
	--mz-color-text-inverse: #ffffff;
	--mz-color-success: #12805c;
	--mz-color-warning: #b7791f;
	--mz-color-danger: #b83245;
	--mz-color-info: #215fc3;
	--mz-shadow-xs: 0 2px 8px rgba(15, 23, 36, 0.05);
	--mz-shadow-sm: 0 8px 24px rgba(15, 23, 36, 0.08);
	--mz-shadow-md: 0 16px 40px rgba(15, 23, 36, 0.12);
	--mz-shadow-lg: 0 28px 70px rgba(15, 23, 36, 0.16);
	--mz-radius-xs: 8px;
	--mz-radius-sm: 12px;
	--mz-radius-md: 18px;
	--mz-radius-lg: 26px;
	--mz-radius-pill: 999px;
	--mz-container: 1200px;
	--mz-container-wide: 1380px;
	--mz-space-1: 4px;
	--mz-space-2: 8px;
	--mz-space-3: 12px;
	--mz-space-4: 16px;
	--mz-space-5: 20px;
	--mz-space-6: 24px;
	--mz-space-7: 32px;
	--mz-space-8: 40px;
	--mz-space-9: 56px;
	--mz-space-10: 72px;
	--mz-transition-fast: 0.18s ease;
	--mz-transition-base: 0.28s ease;
	--mz-font-body: "Inter", "Segoe UI", Tahoma, Arial, sans-serif;
	--mz-font-heading: "Inter", "Segoe UI", Tahoma, Arial, sans-serif;
	--mz-header-height: 78px;
	--mz-sidebar-width: 292px;
	--mz-sidebar-collapsed-width: 92px;
}

body {
	background:
		radial-gradient(circle at top right, rgba(168, 146, 74, 0.09), transparent 28%),
		linear-gradient(180deg, #f9fbfd 0%, #f4f7fb 100%);
	color: var(--mz-color-text);
}

.mz-site-shell,
.mz-page-shell,
.mz-layout-shell {
	position: relative;
}

.mz-container,
.mz-container-wide,
.mz-container-narrow {
	width: min(100% - 32px, var(--mz-container));
	margin-inline: auto;
}

.mz-container-wide {
	width: min(100% - 32px, var(--mz-container-wide));
}

.mz-container-narrow {
	width: min(100% - 32px, 860px);
}

.mz-section {
	position: relative;
	padding: var(--mz-space-10) 0;
}

.mz-section-sm {
	padding: var(--mz-space-8) 0;
}

.mz-section-lg {
	padding: calc(var(--mz-space-10) + 24px) 0;
}

.mz-surface,
.mz-card,
.mz-panel,
.mz-widget {
	background: var(--mz-color-card);
	border: 1px solid var(--mz-color-border);
	border-radius: var(--mz-radius-md);
	box-shadow: var(--mz-shadow-sm);
}

.mz-panel,
.mz-card {
	padding: var(--mz-space-7);
}

.mz-panel-muted {
	background: var(--mz-color-card-muted);
}

.mz-glass {
	background: rgba(255, 255, 255, 0.72);
	backdrop-filter: blur(18px);
	-webkit-backdrop-filter: blur(18px);
	border: 1px solid rgba(255, 255, 255, 0.55);
	box-shadow: var(--mz-shadow-md);
}

.mz-eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 8px 14px;
	border-radius: var(--mz-radius-pill);
	background: rgba(168, 146, 74, 0.12);
	color: var(--mz-color-primary-strong);
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

.mz-section-head {
	margin-bottom: var(--mz-space-8);
	max-width: 760px;
}

.mz-section-head h1,
.mz-section-head h2,
.mz-section-head h3 {
	margin-bottom: var(--mz-space-4);
}

.mz-section-head p {
	margin: 0;
	color: var(--mz-color-text-soft);
	font-size: 17px;
	line-height: 1.75;
}

.mz-grid {
	display: grid;
	gap: var(--mz-space-7);
}

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

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

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

.mz-stack > * + * {
	margin-top: var(--mz-space-5);
}

.mz-flex {
	display: flex;
	align-items: center;
	gap: var(--mz-space-4);
}

.mz-flex-between {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--mz-space-4);
}

.mz-cluster {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--mz-space-3);
}

.mz-site-main {
	min-height: 50vh;
}

.mz-hero {
	position: relative;
	padding: calc(var(--mz-space-10) + 20px) 0 var(--mz-space-10);
	overflow: clip;
}

.mz-hero::before {
	content: "";
	position: absolute;
	inset: 0;
	background:
		linear-gradient(135deg, rgba(168, 146, 74, 0.12), transparent 42%),
		radial-gradient(circle at top left, rgba(7, 17, 31, 0.08), transparent 30%);
	pointer-events: none;
}

.mz-hero-grid {
	position: relative;
	display: grid;
	grid-template-columns: minmax(0, 1.2fr) minmax(320px, 0.8fr);
	gap: var(--mz-space-8);
	align-items: center;
}

.mz-hero-copy h1 {
	font-size: clamp(36px, 4.6vw, 64px);
	line-height: 1.02;
	letter-spacing: -0.03em;
	margin-bottom: var(--mz-space-5);
}

.mz-hero-copy p {
	max-width: 700px;
	font-size: clamp(17px, 2vw, 20px);
	line-height: 1.8;
	color: var(--mz-color-text-soft);
	margin-bottom: var(--mz-space-7);
}

.mz-hero-media {
	position: relative;
	min-height: 360px;
	border-radius: var(--mz-radius-lg);
	overflow: hidden;
	background:
		linear-gradient(160deg, rgba(7, 17, 31, 0.95), rgba(18, 36, 58, 0.88)),
		linear-gradient(90deg, rgba(168, 146, 74, 0.18), transparent);
	box-shadow: var(--mz-shadow-lg);
}

.mz-hero-media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.mz-btn,
button.mz-btn,
input[type="submit"].mz-btn,
.wp-element-button.mz-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	min-height: 48px;
	padding: 0 22px;
	border: 1px solid transparent;
	border-radius: var(--mz-radius-pill);
	background: var(--mz-color-accent);
	color: var(--mz-color-text-inverse);
	font-size: 15px;
	font-weight: 700;
	line-height: 1;
	text-decoration: none;
	box-shadow: var(--mz-shadow-xs);
	transition:
		transform var(--mz-transition-fast),
		box-shadow var(--mz-transition-fast),
		background var(--mz-transition-fast),
		color var(--mz-transition-fast),
		border-color var(--mz-transition-fast);
	cursor: pointer;
}

.mz-btn:hover,
.mz-btn:focus-visible {
	transform: translateY(-1px);
	box-shadow: var(--mz-shadow-sm);
	color: var(--mz-color-text-inverse);
}

.mz-btn-primary {
	background: linear-gradient(135deg, var(--mz-color-primary), var(--mz-color-primary-strong));
	color: #111827;
}

.mz-btn-secondary {
	background: var(--mz-color-card);
	color: var(--mz-color-text);
	border-color: var(--mz-color-border-strong);
}

.mz-btn-ghost {
	background: transparent;
	border-color: var(--mz-color-border);
	color: var(--mz-color-text);
	box-shadow: none;
}

.mz-btn-ghost:hover,
.mz-btn-secondary:hover {
	background: var(--mz-color-card-muted);
	color: var(--mz-color-text);
}

.mz-badge,
.mz-pill,
.mz-status {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	min-height: 30px;
	padding: 0 12px;
	border-radius: var(--mz-radius-pill);
	font-size: 13px;
	font-weight: 600;
	line-height: 1;
	border: 1px solid transparent;
}

.mz-badge {
	background: rgba(7, 17, 31, 0.06);
	color: var(--mz-color-text);
}

.mz-pill {
	background: rgba(168, 146, 74, 0.12);
	color: var(--mz-color-primary-strong);
}

.mz-status-success {
	background: rgba(18, 128, 92, 0.12);
	color: var(--mz-color-success);
	border-color: rgba(18, 128, 92, 0.2);
}

.mz-status-warning {
	background: rgba(183, 121, 31, 0.12);
	color: var(--mz-color-warning);
	border-color: rgba(183, 121, 31, 0.2);
}

.mz-status-danger {
	background: rgba(184, 50, 69, 0.12);
	color: var(--mz-color-danger);
	border-color: rgba(184, 50, 69, 0.2);
}

.mz-status-info {
	background: rgba(33, 95, 195, 0.12);
	color: var(--mz-color-info);
	border-color: rgba(33, 95, 195, 0.2);
}

.mz-card-title,
.mz-widget-title {
	margin-bottom: var(--mz-space-3);
	font-size: 22px;
	line-height: 1.25;
}

.mz-card-text,
.mz-meta,
.mz-muted {
	color: var(--mz-color-text-soft);
}

.mz-form-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: var(--mz-space-5);
}

.mz-field {
	display: grid;
	gap: 10px;
}

.mz-field label {
	font-size: 14px;
	font-weight: 700;
	color: var(--mz-color-text);
}

.mz-input,
.mz-select,
.mz-textarea,
input[type="text"],
input[type="email"],
input[type="url"],
input[type="search"],
input[type="password"],
input[type="number"],
select,
textarea {
	width: 100%;
	min-height: 50px;
	padding: 0 16px;
	border: 1px solid var(--mz-color-border-strong);
	border-radius: var(--mz-radius-sm);
	background: #ffffff;
	color: var(--mz-color-text);
	box-shadow: inset 0 1px 1px rgba(15, 23, 36, 0.02);
	transition:
		border-color var(--mz-transition-fast),
		box-shadow var(--mz-transition-fast),
		background var(--mz-transition-fast);
}

.mz-textarea,
textarea {
	min-height: 140px;
	padding-top: 14px;
	padding-bottom: 14px;
	resize: vertical;
}

.mz-input:focus,
.mz-select:focus,
.mz-textarea:focus,
input:focus,
select:focus,
textarea:focus {
	border-color: rgba(168, 146, 74, 0.8);
	box-shadow: 0 0 0 4px rgba(168, 146, 74, 0.12);
	outline: none;
}

.mz-table-wrap {
	overflow-x: auto;
	border-radius: var(--mz-radius-md);
	border: 1px solid var(--mz-color-border);
	background: var(--mz-color-card);
	box-shadow: var(--mz-shadow-xs);
}

.mz-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 15px;
}

.mz-table th,
.mz-table td {
	padding: 16px 18px;
	border-bottom: 1px solid var(--mz-color-border);
	text-align: start;
	vertical-align: middle;
}

.mz-table th {
	background: var(--mz-color-card-muted);
	font-weight: 700;
	color: var(--mz-color-text);
}

.mz-table tbody tr:hover {
	background: rgba(7, 17, 31, 0.02);
}

.mz-list-reset {
	margin: 0;
	padding: 0;
	list-style: none;
}

.mz-divider {
	width: 100%;
	height: 1px;
	background: var(--mz-color-border);
	margin: var(--mz-space-7) 0;
}

.mz-sidebar-layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 320px;
	gap: var(--mz-space-8);
	align-items: start;
}

.mz-sidebar-layout.is-left {
	grid-template-columns: 320px minmax(0, 1fr);
}

.mz-content-box,
.mz-sidebar-box {
	padding: var(--mz-space-7);
	border-radius: var(--mz-radius-md);
	border: 1px solid var(--mz-color-border);
	background: var(--mz-color-card);
	box-shadow: var(--mz-shadow-sm);
}

.mz-shop-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: var(--mz-space-6);
}

.mz-product-card {
	display: grid;
	gap: var(--mz-space-4);
	padding: var(--mz-space-5);
	border-radius: var(--mz-radius-md);
	border: 1px solid var(--mz-color-border);
	background: var(--mz-color-card);
	box-shadow: var(--mz-shadow-xs);
	transition:
		transform var(--mz-transition-fast),
		box-shadow var(--mz-transition-fast),
		border-color var(--mz-transition-fast);
}

.mz-product-card:hover {
	transform: translateY(-3px);
	box-shadow: var(--mz-shadow-md);
	border-color: rgba(168, 146, 74, 0.24);
}

.mz-product-thumb {
	aspect-ratio: 4 / 3;
	border-radius: var(--mz-radius-sm);
	overflow: hidden;
	background: var(--mz-color-card-muted);
}

.mz-product-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.mz-empty-state,
.mz-notice-box {
	padding: var(--mz-space-8);
	text-align: center;
	border-radius: var(--mz-radius-md);
	border: 1px dashed var(--mz-color-border-strong);
	background: rgba(255, 255, 255, 0.78);
}

.mz-empty-state h2,
.mz-notice-box h2,
.mz-empty-state h3,
.mz-notice-box h3 {
	margin-bottom: var(--mz-space-3);
}

.mz-empty-state p,
.mz-notice-box p {
	margin: 0 auto;
	max-width: 720px;
	color: var(--mz-color-text-soft);
}

.mz-portal-shell {
	display: grid;
	grid-template-columns: var(--mz-sidebar-width) minmax(0, 1fr);
	min-height: 100vh;
	background:
		linear-gradient(180deg, #eef3f9 0%, #f6f8fb 100%);
}

.mz-portal-sidebar {
	position: sticky;
	top: 0;
	height: 100vh;
	padding: var(--mz-space-6);
	background: linear-gradient(180deg, var(--mz-color-accent), var(--mz-color-surface));
	color: var(--mz-color-text-inverse);
	box-shadow: 10px 0 28px rgba(7, 17, 31, 0.12);
}

.mz-portal-sidebar a {
	color: inherit;
	text-decoration: none;
}

.mz-portal-main {
	min-width: 0;
	padding: var(--mz-space-7);
}

.mz-portal-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--mz-space-4);
	margin-bottom: var(--mz-space-7);
	padding: var(--mz-space-5) var(--mz-space-6);
	border-radius: var(--mz-radius-md);
	background: rgba(255, 255, 255, 0.88);
	border: 1px solid rgba(255, 255, 255, 0.7);
	backdrop-filter: blur(16px);
	-webkit-backdrop-filter: blur(16px);
	box-shadow: var(--mz-shadow-sm);
}

.mz-portal-grid {
	display: grid;
	grid-template-columns: repeat(12, minmax(0, 1fr));
	gap: var(--mz-space-6);
}

.mz-col-12 { grid-column: span 12; }
.mz-col-8 { grid-column: span 8; }
.mz-col-6 { grid-column: span 6; }
.mz-col-4 { grid-column: span 4; }
.mz-col-3 { grid-column: span 3; }

.mz-stat {
	display: grid;
	gap: 12px;
	padding: var(--mz-space-6);
	border-radius: var(--mz-radius-md);
	background: linear-gradient(180deg, #ffffff, #f7f8fb);
	border: 1px solid var(--mz-color-border);
	box-shadow: var(--mz-shadow-xs);
}

.mz-stat-label {
	font-size: 14px;
	font-weight: 600;
	color: var(--mz-color-text-soft);
}

.mz-stat-value {
	font-size: clamp(24px, 3vw, 38px);
	font-weight: 800;
	line-height: 1;
	color: var(--mz-color-text);
}

.mz-auth-shell {
	min-height: 100vh;
	display: grid;
	place-items: center;
	padding: var(--mz-space-8) 16px;
	background:
		radial-gradient(circle at top left, rgba(168, 146, 74, 0.14), transparent 30%),
		linear-gradient(180deg, #0c1626, #13243a);
}

.mz-auth-card {
	width: min(100%, 480px);
	padding: var(--mz-space-8);
	border-radius: var(--mz-radius-lg);
	background: rgba(255, 255, 255, 0.94);
	box-shadow: var(--mz-shadow-lg);
}

.mz-visually-hidden {
	position: absolute !important;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

@media (max-width: 1200px) {
	.mz-shop-grid,
	.mz-grid-4 {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.mz-col-3 {
		grid-column: span 6;
	}
}

@media (max-width: 1024px) {
	.mz-grid-3,
	.mz-grid-4,
	.mz-shop-grid,
	.mz-sidebar-layout,
	.mz-sidebar-layout.is-left,
	.mz-hero-grid,
	.mz-form-grid {
		grid-template-columns: 1fr;
	}

	.mz-portal-shell {
		grid-template-columns: 1fr;
	}

	.mz-portal-sidebar {
		position: relative;
		height: auto;
	}

	.mz-col-8,
	.mz-col-6,
	.mz-col-4,
	.mz-col-3 {
		grid-column: span 12;
	}
}

@media (max-width: 767px) {
	.mz-section {
		padding: var(--mz-space-8) 0;
	}

	.mz-panel,
	.mz-card,
	.mz-content-box,
	.mz-sidebar-box,
	.mz-auth-card,
	.mz-portal-main {
		padding: var(--mz-space-6);
	}

	.mz-hero-copy h1 {
		font-size: clamp(32px, 10vw, 46px);
	}

	.mz-portal-header,
	.mz-flex-between {
		flex-direction: column;
		align-items: stretch;
	}

	.mz-btn,
	button.mz-btn,
	input[type="submit"].mz-btn {
		width: 100%;
	}
}