/* =========================================================
   Brands Page
   File: assets/css/brands-page.css
   ========================================================= */

:root {
	--mmn-brands-page-bg: #f8f8f8;
	--mmn-brands-header-bg: #000000;
	--mmn-brands-text-dark: #222222;
	--mmn-brands-card-bg: #ffffff;
	--mmn-brands-border: #e5e5e5;
	--mmn-brands-border-hover: #d0d0d0;
	--mmn-brands-text-muted: #444444;
	--mmn-brands-shadow: 0 1px 2px rgba(0, 0, 0, 0.02);
	--mmn-brands-shadow-hover: 0 6px 12px rgba(0, 0, 0, 0.08);
}

/* =========================================================
   Scoped page root reset
   ========================================================= */
body.vss-route-brands,
body .mmn-brands-page-root,
body .mmn-brands-page-main,
body .mmn-brands-page-shell,
body .mmn-brands-page {
	background-color: var(--mmn-brands-page-bg);
}

body.vss-route-brands {
	overflow-x: hidden !important;
}

body .mmn-brands-page-root {
	display: block !important;
	width: 100% !important;
	max-width: 100% !important;
	margin: 0 !important;
	padding: 0 !important;
	float: none !important;
	clear: both !important;
	overflow-x: hidden !important;
}

body .mmn-brands-page-main {
	display: block !important;
	width: 100% !important;
	max-width: 100% !important;
	margin: 0 !important;
	padding: 0 !important;
	float: none !important;
	clear: both !important;
	overflow-x: hidden !important;
}

body .mmn-brands-page-shell {
	display: block !important;
	width: 100% !important;
	max-width: 100% !important;
	margin: 0 !important;
	padding: 0 !important;
	float: none !important;
	clear: both !important;
	overflow-x: hidden !important;
}

body .mmn-brands-page {
	display: block !important;
	width: 100% !important;
	max-width: 100% !important;
	margin: 0 !important;
	padding: 0 !important;
	float: none !important;
	clear: both !important;
}

/* Remove any inherited page heading blocks if theme injects them */
body .mmn-brands-page .brands-page__header,
body .mmn-brands-page .brands-page__header-content,
body .mmn-brands-page .brands-page__eyebrow,
body .mmn-brands-page .brands-page__title,
body .mmn-brands-page .brands-page__subtitle {
	display: none !important;
	margin: 0 !important;
	padding: 0 !important;
}

/* =========================================================
   Full width header bar
   ========================================================= */
body .mmn-full-bleed {
	width: auto !important;
	max-width: none !important;
	margin-left: calc(50% - 50vw) !important;
	margin-right: calc(50% - 50vw) !important;
}

body .mmn-brands-hero {
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: auto !important;
	max-width: none !important;
	min-height: 60px !important;
	margin-top: 0 !important;
	margin-bottom: 0 !important;
	padding: 16px 0 !important;
	background: var(--mmn-brands-header-bg) !important;
	border: 0 !important;
	box-shadow: none !important;
	text-align: center !important;
	position: relative !important;
	float: none !important;
	clear: both !important;
}

body .mmn-brands-hero__inner {
	display: block !important;
	width: 100% !important;
	max-width: none !important;
	margin: 0 !important;
	padding: 0 16px !important;
}

body .mmn-brands-hero__title {
	display: block !important;
	margin: 0 !important;
	padding: 0 !important;
	color: #ffffff !important;
	font-family: "Poppins", sans-serif !important;
	font-size: 16px !important;
	font-weight: 600 !important;
	line-height: 1.3 !important;
	letter-spacing: 0.5px !important;
	text-align: center !important;
	text-transform: none !important;
}

/* =========================================================
   Container
   ========================================================= */
body .mmn-brands-page__container {
	display: block !important;
	width: 100% !important;
	max-width: 1200px !important;
	margin: 32px auto !important;
	padding: 0 16px !important;
	float: none !important;
	clear: both !important;
	box-sizing: border-box !important;
}

body .mmn-brands-page__content {
	display: block !important;
	width: 100% !important;
	max-width: 100% !important;
	margin: 0 !important;
	padding: 0 !important;
	float: none !important;
	clear: both !important;
}

body .mmn-brands-grid-wrap {
	display: block !important;
	width: 100% !important;
	max-width: 100% !important;
	margin: 0 !important;
	padding: 0 !important;
	float: none !important;
	clear: both !important;
	box-sizing: border-box !important;
}

/* =========================================================
   Grid layout
   ========================================================= */
body .mmn-brands-grid {
	display: grid !important;
	grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
	gap: 12px !important;
	align-items: stretch !important;
	justify-items: stretch !important;
	width: 100% !important;
	max-width: 100% !important;
	margin: 0 !important;
	padding: 0 !important;
	list-style: none !important;
	float: none !important;
	clear: both !important;
	box-sizing: border-box !important;
}

@media (min-width: 480px) {
	body .mmn-brands-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
	}
}

@media (min-width: 768px) {
	body .mmn-brands-grid {
		grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
	}
}

@media (min-width: 1024px) {
	body .mmn-brands-grid {
		grid-template-columns: repeat(8, minmax(0, 1fr)) !important;
	}
}

/* =========================================================
   Card
   ========================================================= */
body .mmn-brands-grid > .mmn-brand-card,
body .mmn-brands-grid > a.mmn-brand-card {
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: 100% !important;
	min-width: 0 !important;
	min-height: 0 !important;
	height: auto !important;
	aspect-ratio: 3 / 2 !important;
	margin: 0 !important;
	padding: 12px !important;
	float: none !important;
	position: relative !important;
	overflow: hidden !important;
	box-sizing: border-box !important;
	background: var(--mmn-brands-card-bg) !important;
	border: 1px solid var(--mmn-brands-border) !important;
	border-radius: 6px !important;
	box-shadow: var(--mmn-brands-shadow) !important;
	text-decoration: none !important;
	cursor: pointer !important;
}

body .mmn-brands-grid > .mmn-brand-card:hover,
body .mmn-brands-grid > .mmn-brand-card:focus-visible,
body .mmn-brands-grid > a.mmn-brand-card:hover,
body .mmn-brands-grid > a.mmn-brand-card:focus-visible {
	transform: translateY(-3px) !important;
	box-shadow: var(--mmn-brands-shadow-hover) !important;
	border-color: var(--mmn-brands-border-hover) !important;
	text-decoration: none !important;
	outline: none !important;
	transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease !important;
}

body .mmn-brands-grid > .mmn-brand-card:focus-visible,
body .mmn-brands-grid > a.mmn-brand-card:focus-visible {
	box-shadow:
		0 0 0 2px rgba(255, 255, 255, 0.95),
		0 0 0 4px rgba(0, 0, 0, 0.85),
		var(--mmn-brands-shadow-hover) !important;
}

/* =========================================================
   Media/Image
   ========================================================= */
body .mmn-brand-card__media {
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: 100% !important;
	height: 100% !important;
	margin: 0 !important;
	padding: 0 !important;
	min-width: 0 !important;
	min-height: 0 !important;
	line-height: 0 !important;
	float: none !important;
	box-sizing: border-box !important;
}

body .mmn-brand-card__image,
body .brands-grid__image.mmn-brand-card__image,
body .mmn-brand-card img,
body .mmn-brands-grid .mmn-brand-card img {
	display: block !important;
	float: none !important;
	position: static !important;
	max-width: 100% !important;
	width: auto !important;
	height: auto !important;
	max-height: 100% !important;
	margin: 0 auto !important;
	padding: 0 !important;
	border: 0 !important;
	box-shadow: none !important;
	object-fit: contain !important;
	object-position: center center !important;
	vertical-align: middle !important;
}

/* =========================================================
   Text fallback
   ========================================================= */
body .mmn-brand-card__text {
	display: block !important;
	width: 100% !important;
	margin: 0 !important;
	padding: 0 !important;
	text-align: center !important;
	font-family: "Poppins", sans-serif !important;
	font-weight: 600 !important;
	font-size: 13px !important;
	line-height: 1.35 !important;
	color: var(--mmn-brands-text-muted) !important;
	text-transform: capitalize !important;
	word-break: break-word !important;
	overflow-wrap: anywhere !important;
	white-space: normal !important;
}

/* =========================================================
   Empty state
   ========================================================= */
body .mmn-brands-grid__empty,
body .brands-grid__empty.mmn-brands-grid__empty {
	display: block !important;
	background: #ffffff !important;
	border: 1px solid var(--mmn-brands-border) !important;
	border-radius: 10px !important;
	padding: 24px 18px !important;
	text-align: center !important;
	color: var(--mmn-brands-text-dark) !important;
}

body .mmn-brands-grid__empty p {
	margin: 0 !important;
	font-size: 15px !important;
	line-height: 1.6 !important;
}

/* =========================================================
   Mobile
   ========================================================= */
@media (max-width: 479px) {
	body .mmn-brands-page__container {
		margin-top: 24px !important;
		margin-bottom: 24px !important;
		padding-left: 16px !important;
		padding-right: 16px !important;
	}

	body .mmn-brands-grid {
		gap: 12px !important;
	}

	body .mmn-brands-grid > .mmn-brand-card,
	body .mmn-brands-grid > a.mmn-brand-card {
		padding: 10px !important;
	}

	body .mmn-brand-card__text {
		font-size: 12px !important;
	}
}

/* =========================================================
   Reduced motion
   ========================================================= */
@media (prefers-reduced-motion: reduce) {
	body .mmn-brands-grid > .mmn-brand-card,
	body .mmn-brands-grid > a.mmn-brand-card {
		transition: none !important;
	}
}