/* ================================================================
   Blog — single, archive, sidebar, related products
   ================================================================ */

/* ----------------------------------------------------------------
   Breadcrumbs
   ---------------------------------------------------------------- */
.mi-blog-breadcrumbs {
	max-width: 860px;
	margin: 0 auto var(--mi-space-6);
}

.mi-blog-breadcrumbs__list {
	display: flex;
	flex-wrap: wrap;
	gap: var(--mi-space-1) var(--mi-space-2);
	align-items: center;
	margin: 0;
	padding: 0;
	list-style: none;
	font-size: var(--mi-font-size-sm);
	color: var(--mi-color-muted);
}

.mi-blog-breadcrumbs__item {
	display: inline-flex;
	align-items: center;
	gap: var(--mi-space-2);
}

.mi-blog-breadcrumbs__item:not(:last-child)::after {
	content: "/";
	color: var(--mi-color-border-strong);
}

.mi-blog-breadcrumbs__link {
	color: var(--mi-color-muted);
	text-decoration: none;
	transition: color var(--mi-transition-fast);
}

.mi-blog-breadcrumbs__link:hover,
.mi-blog-breadcrumbs__link:focus-visible {
	color: var(--mi-color-primary);
	text-decoration: underline;
}

.mi-blog-breadcrumbs__current {
	color: var(--mi-color-heading);
	font-weight: var(--mi-font-semibold);
}

/* ----------------------------------------------------------------
   Layout
   ---------------------------------------------------------------- */
.mi-blog-layout {
	display: grid;
	grid-template-columns: 1fr;
	gap: clamp(24px, 3.4vw, 48px);
	width: min(100% - 32px, 1920px);
	margin-inline: auto;
	padding: 28px 0 64px;
}

.mi-blog-main {
	min-width: 0;
}

.mi-blog-sidebar {
	min-width: 0;
}

.mi-blog-layout--archive {
	align-items: start;
}

/* ----------------------------------------------------------------
   Single post
   ---------------------------------------------------------------- */
.mi-blog-post__header {
	display: flex;
	align-items: center;
	flex-direction: column;
	max-width: 860px;
	margin: 0 auto clamp(26px, 3vw, 42px);
	padding: clamp(18px, 3vw, 32px) 0 clamp(6px, 1vw, 12px);
	text-align: center;
}

.mi-blog-post__meta {
	display: flex;
	flex-wrap: wrap;
	gap: 8px 12px;
	align-items: center;
	justify-content: center;
	margin-bottom: 12px;
	font-size: var(--mi-font-size-sm);
	color: var(--mi-color-muted);
}

.mi-blog-post__meta a {
	color: var(--mi-color-accent-orange);
	font-weight: 900;
	letter-spacing: 0;
	text-decoration: none;
	text-transform: uppercase;
}

.mi-blog-post__meta a:hover,
.mi-blog-post__meta a:focus-visible {
	text-decoration: underline;
}

.mi-blog-post__title {
	position: relative;
	margin: 0;
	padding-bottom: 22px;
	color: #314574;
	font-size: clamp(2rem, 3.1vw, 3.35rem);
	font-weight: 500;
	line-height: 1.12;
	letter-spacing: 0;
}

.mi-blog-post__title::after {
	position: absolute;
	bottom: 0;
	left: 50%;
	width: min(180px, 42vw);
	height: 3px;
	border-radius: var(--mi-radius-pill);
	background: var(--mi-color-accent-orange);
	content: "";
	transform: translateX(-50%);
}

.mi-blog-post__lead {
	max-width: 720px;
	margin: 18px 0 0;
	color: var(--mi-color-muted);
	font-size: clamp(1rem, 1.15vw, 1.18rem);
	line-height: var(--mi-line-body);
}

.mi-blog-post__media {
	margin-bottom: var(--mi-space-6);
	overflow: hidden;
	border: var(--mi-border);
	border-radius: var(--mi-radius-lg);
	background: var(--mi-color-surface-muted);
}

.mi-blog-post__media img {
	width: 100%;
	height: auto;
	max-height: 480px;
	object-fit: cover;
	display: block;
}

.mi-blog-post__content {
	max-width: var(--mi-container-readable);
	margin-inline: auto;
	color: var(--mi-color-text);
	font-size: clamp(1rem, 0.96vw, 1.08rem);
	line-height: 1.72;
}

.mi-blog-post__content > *:first-child {
	margin-top: 0;
}

.mi-blog-post__content > *:last-child {
	margin-bottom: 0;
}

.mi-blog-post__content h2,
.mi-blog-post__content h3,
.mi-blog-post__content h4 {
	margin: 2.1em 0 0.75em;
	color: #314574;
	line-height: 1.18;
	letter-spacing: 0;
}

.mi-blog-post__content h2 {
	position: relative;
	padding-bottom: 10px;
	font-size: clamp(1.45rem, 1.55vw, 1.9rem);
	font-weight: 900;
}

.mi-blog-post__content h2::after {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 56px;
	height: 2px;
	border-radius: var(--mi-radius-pill);
	background: var(--mi-color-accent-orange);
	content: "";
}

.mi-blog-post__content h3 {
	font-size: clamp(1.15rem, 1.18vw, 1.35rem);
	font-weight: 900;
}

.mi-blog-post__content p {
	margin: 0 0 1.2em;
}

.mi-blog-post__content ul,
.mi-blog-post__content ol {
	margin: 0 0 1.45em;
	padding-left: 1.25em;
}

.mi-blog-post__content blockquote {
	margin: var(--mi-space-6) 0;
	padding: var(--mi-space-5) var(--mi-space-6);
	border-left: 3px solid var(--mi-color-accent-orange);
	background: #f7f7f7;
	border-radius: var(--mi-radius-lg);
	font-style: italic;
}

.mi-blog-post__content img {
	max-width: 100%;
	height: auto;
	border-radius: var(--mi-radius-md);
}

/* ----------------------------------------------------------------
   Gutenberg block basics (content-only, no layout builder)
   ---------------------------------------------------------------- */
.mi-blog-post__content .wp-block-image {
	margin: var(--mi-space-6) 0;
}

.mi-blog-post__content .wp-block-image img {
	display: block;
	border-radius: var(--mi-radius-md);
}

.mi-blog-post__content .wp-block-image figcaption {
	margin-top: var(--mi-space-2);
	font-size: var(--mi-font-size-sm);
	color: var(--mi-color-muted);
	text-align: center;
}

.mi-blog-post__content .wp-block-image.alignleft,
.mi-blog-post__content .wp-block-image .alignleft {
	float: left;
	margin: 0 var(--mi-space-4) var(--mi-space-3) 0;
}

.mi-blog-post__content .wp-block-image.alignright,
.mi-blog-post__content .wp-block-image .alignright {
	float: right;
	margin: 0 0 var(--mi-space-3) var(--mi-space-4);
}

.mi-blog-post__content .wp-block-image.aligncenter,
.mi-blog-post__content .wp-block-image .aligncenter {
	margin-inline: auto;
}

.mi-blog-post__content .wp-block-gallery {
	margin: var(--mi-space-6) 0;
	gap: var(--mi-space-3);
}

.mi-blog-post__content .wp-block-columns {
	gap: var(--mi-space-5);
	margin: var(--mi-space-6) 0;
}

.mi-blog-post__content .wp-block-column > *:first-child {
	margin-top: 0;
}

.mi-blog-post__content .wp-block-column > *:last-child {
	margin-bottom: 0;
}

.mi-blog-post__content .wp-block-separator {
	margin: var(--mi-space-6) auto;
	border: 0;
	border-top: 1px solid var(--mi-color-border);
	max-width: 100%;
}

.mi-blog-post__content .wp-block-table {
	margin: var(--mi-space-6) 0;
	overflow-x: auto;
}

.mi-blog-post__content .wp-block-table table {
	width: 100%;
	border-collapse: collapse;
	font-size: var(--mi-font-size-sm);
}

.mi-blog-post__content .wp-block-table th,
.mi-blog-post__content .wp-block-table td {
	padding: var(--mi-space-2) var(--mi-space-3);
	border: 1px solid var(--mi-color-border);
	text-align: left;
}

.mi-blog-post__content .wp-block-table th {
	background: var(--mi-color-surface-muted);
	font-weight: var(--mi-font-semibold);
}

.mi-blog-post__content .wp-block-embed {
	margin: var(--mi-space-6) 0;
}

.mi-blog-post__content .wp-block-embed iframe {
	max-width: 100%;
}

.mi-blog-post__content .wp-block-group {
	padding: var(--mi-space-5);
	border: var(--mi-border);
	border-radius: var(--mi-radius-lg);
	background: var(--mi-color-surface);
	margin: var(--mi-space-6) 0;
}

.mi-blog-post__content .wp-block-group > *:first-child {
	margin-top: 0;
}

.mi-blog-post__content .wp-block-group > *:last-child {
	margin-bottom: 0;
}

.mi-blog-post__content .wp-block-cover {
	margin: var(--mi-space-6) 0;
	border-radius: var(--mi-radius-lg);
	overflow: hidden;
	min-height: 240px;
}

.mi-blog-post__content .wp-block-media-text {
	margin: var(--mi-space-6) 0;
	gap: var(--mi-space-5);
}

.mi-blog-post__content .wp-block-pullquote {
	margin: var(--mi-space-6) 0;
	padding: var(--mi-space-5);
	border-left: 3px solid var(--mi-color-primary);
	background: var(--mi-color-primary-soft);
	border-radius: 0 var(--mi-radius-md) var(--mi-radius-md) 0;
}

.mi-blog-post__content .wp-block-pullquote p {
	font-size: var(--mi-font-size-lg);
	font-weight: var(--mi-font-semibold);
	line-height: var(--mi-line-heading);
}

.mi-blog-post__content .wp-block-pullquote cite {
	font-size: var(--mi-font-size-sm);
	color: var(--mi-color-muted);
	font-style: normal;
}

.mi-blog-post__content .wp-block-code,
.mi-blog-post__content .wp-block-preformatted {
	margin: var(--mi-space-4) 0;
	padding: var(--mi-space-3) var(--mi-space-4);
	background: var(--mi-color-surface-muted);
	border: var(--mi-border);
	border-radius: var(--mi-radius-md);
	font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
	font-size: var(--mi-font-size-sm);
	overflow-x: auto;
}

.mi-blog-post__content .wp-block-button {
	margin: var(--mi-space-4) 0;
}

.mi-blog-post__content .wp-block-button__link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 44px;
	padding: 0.62rem 1.25rem;
	border-radius: var(--mi-radius-sm);
	background: var(--mi-color-primary);
	color: var(--mi-color-white);
	font-size: var(--mi-font-size-sm);
	font-weight: var(--mi-font-bold);
	text-decoration: none;
	transition: background var(--mi-transition-fast);
}

.mi-blog-post__content .wp-block-button__link:hover {
	background: var(--mi-color-primary-dark);
}

.mi-blog-post__content .wp-block-file {
	display: inline-flex;
	align-items: center;
	gap: var(--mi-space-3);
	margin: var(--mi-space-4) 0;
	padding: var(--mi-space-3) var(--mi-space-4);
	border: var(--mi-border);
	border-radius: var(--mi-radius-md);
	background: var(--mi-color-surface);
	font-size: var(--mi-font-size-sm);
}

.mi-blog-post__content .wp-block-file a {
	color: var(--mi-color-primary);
	text-decoration: none;
	font-weight: var(--mi-font-semibold);
}

.mi-blog-post__content .wp-block-file a:hover {
	text-decoration: underline;
}

/* ----------------------------------------------------------------
   CTA in content
   ---------------------------------------------------------------- */
.mi-blog-post__cta {
	max-width: var(--mi-container-readable);
	margin: clamp(34px, 4vw, 56px) auto;
	padding: clamp(22px, 3vw, 32px);
	border: 0;
	border-radius: var(--mi-radius-lg);
	background: var(--mi-color-black);
	color: var(--mi-color-white);
	text-align: center;
}

.mi-blog-post__cta-label {
	margin: 0 0 var(--mi-space-4);
	color: var(--mi-color-white);
	font-size: clamp(1.1rem, 1.2vw, 1.35rem);
	font-weight: 900;
	line-height: var(--mi-line-heading);
}

.mi-blog-post__cta-button {
	min-height: 44px;
	border-color: var(--mi-color-accent-orange);
	background: var(--mi-color-accent-orange);
	color: var(--mi-color-white);
}

/* ----------------------------------------------------------------
   Archive cards
   ---------------------------------------------------------------- */
.mi-blog-archive__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: clamp(16px, 2vw, 28px);
}

.mi-blog-archive__header {
	display: flex;
	align-items: center;
	flex-direction: column;
	margin-bottom: 0;
	padding: clamp(18px, 3vw, 32px) 0 clamp(6px, 1vw, 12px);
	text-align: center;
}

.mi-blog-archive__eyebrow {
	margin-bottom: 10px;
	color: var(--mi-color-accent-orange);
	font-size: var(--mi-font-size-sm);
	font-weight: 900;
	letter-spacing: 0;
	text-transform: uppercase;
}

.mi-blog-archive__title {
	position: relative;
	margin: 0;
	padding-bottom: 22px;
	color: #314574;
	font-size: clamp(2rem, 3.1vw, 3.4rem);
	font-weight: 500;
	line-height: 1.12;
	letter-spacing: 0;
}

.mi-blog-archive__title::after {
	position: absolute;
	bottom: 0;
	left: 50%;
	width: min(180px, 42vw);
	height: 3px;
	border-radius: var(--mi-radius-pill);
	background: var(--mi-color-accent-orange);
	content: "";
	transform: translateX(-50%);
}

.mi-blog-archive__lead {
	max-width: 700px;
	margin: 18px 0 0;
	color: var(--mi-color-muted);
	font-size: clamp(1rem, 1.15vw, 1.18rem);
	line-height: var(--mi-line-body);
}

.mi-blog-archive__meta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 38px;
	margin: 20px 0 0;
	border-radius: var(--mi-radius-pill);
	padding: 0 18px;
	background: #f7f7f7;
	color: var(--mi-color-heading);
	font-size: var(--mi-font-size-sm);
	font-weight: 900;
}

.mi-blog-archive__description {
	max-width: 760px;
	margin: 18px 0 0;
	color: var(--mi-color-muted);
	font-size: var(--mi-font-size-md);
	line-height: var(--mi-line-body);
}

/* Card */
.mi-blog-card {
	display: flex;
	flex-direction: column;
	min-width: 0;
	border: 0;
	border-radius: var(--mi-radius-lg);
	background: var(--mi-color-white);
	box-shadow: none;
	overflow: hidden;
	transition:
		box-shadow var(--mi-transition-fast),
		transform var(--mi-transition-fast);
}

.mi-blog-card:hover,
.mi-blog-card:focus-within {
	box-shadow: 0 12px 32px rgba(18, 20, 22, 0.08);
	transform: translateY(-2px);
}

.mi-blog-card__media {
	position: relative;
	aspect-ratio: 16 / 9;
	overflow: hidden;
	background: var(--mi-color-primary-soft);
}

.mi-blog-card__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform var(--mi-transition-base);
}

.mi-blog-card:hover .mi-blog-card__media img,
.mi-blog-card:focus-within .mi-blog-card__media img {
	transform: scale(1.03);
}

.mi-blog-card__badge {
	position: absolute;
	top: var(--mi-space-3);
	left: var(--mi-space-3);
	z-index: 2;
	display: inline-flex;
	align-items: center;
	min-height: 24px;
	padding: var(--mi-space-1) var(--mi-space-3);
	border-radius: var(--mi-radius-pill);
	background: var(--mi-color-accent-orange);
	color: var(--mi-color-white);
	font-size: var(--mi-font-size-xs);
	font-weight: var(--mi-font-bold);
	letter-spacing: var(--mi-letter-label);
	text-transform: uppercase;
}

.mi-blog-card__body {
	display: flex;
	flex-direction: column;
	flex: 1 1 auto;
	gap: 12px;
	padding: clamp(18px, 2vw, 24px);
}

.mi-blog-card__meta {
	display: flex;
	flex-wrap: wrap;
	gap: 6px 10px;
	align-items: center;
	min-height: 22px;
	font-size: var(--mi-font-size-sm);
	color: var(--mi-color-muted);
}

.mi-blog-card__meta a {
	color: var(--mi-color-accent-orange);
	font-weight: 900;
	text-decoration: none;
	text-transform: uppercase;
}

.mi-blog-card__meta a:hover,
.mi-blog-card__meta a:focus-visible {
	text-decoration: underline;
}

.mi-blog-card__title {
	position: relative;
	margin: 0;
	padding-bottom: 12px;
	color: #314574;
	font-size: clamp(1.05rem, 1.2vw, 1.28rem);
	font-weight: 900;
	line-height: 1.18;
	letter-spacing: 0;
}

.mi-blog-card__title::after {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 48px;
	height: 2px;
	border-radius: var(--mi-radius-pill);
	background: var(--mi-color-accent-orange);
	content: "";
	opacity: 0.9;
}

.mi-blog-card__title a {
	color: inherit;
	text-decoration: none;
}

.mi-blog-card__title a:hover,
.mi-blog-card__title a:focus-visible {
	color: var(--mi-color-primary);
	text-decoration: none;
}

.mi-blog-card__excerpt {
	margin: 0;
	color: var(--mi-color-muted);
	font-size: var(--mi-font-size-md);
	line-height: 1.55;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.mi-blog-card__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: auto;
	padding-top: 6px;
}

.mi-blog-card__actions .button {
	min-height: 42px;
	border-radius: var(--mi-radius-pill);
	padding: 0.55rem 1rem;
	font-size: var(--mi-font-size-sm);
	font-weight: 900;
}

.mi-blog-card__actions .button--ghost {
	background: transparent;
	color: var(--mi-color-primary);
}

.mi-blog-card__actions .button--ghost:hover,
.mi-blog-card__actions .button--ghost:focus-visible {
	background: var(--mi-color-primary-soft);
	color: var(--mi-color-primary);
	border-color: var(--mi-color-primary);
}

/* ----------------------------------------------------------------
   Sidebar
   ---------------------------------------------------------------- */
.mi-blog-sidebar {
	display: flex;
	flex-direction: column;
	gap: var(--mi-space-6);
}

.mi-blog-sidebar__block {
	padding: var(--mi-space-5);
	border: var(--mi-border);
	border-radius: var(--mi-radius-lg);
	background: var(--mi-color-surface);
	box-shadow: var(--mi-shadow-xs);
}

.mi-blog-sidebar__title {
	margin: 0 0 var(--mi-space-4);
	color: var(--mi-color-heading);
	font-size: var(--mi-font-size-md);
	font-weight: var(--mi-font-bold);
	line-height: var(--mi-line-heading);
}

/* ----------------------------------------------------------------
   Mini product card (sidebar)
   ---------------------------------------------------------------- */
.mi-product-mini {
	display: grid;
	grid-template-columns: 80px minmax(0, 1fr);
	gap: var(--mi-space-3);
	align-items: center;
	padding: var(--mi-space-3) 0;
	border-bottom: 1px solid var(--mi-color-border);
	text-decoration: none;
	color: inherit;
}

.mi-product-mini:first-child {
	padding-top: 0;
}

.mi-product-mini:last-child {
	padding-bottom: 0;
	border-bottom: 0;
}

.mi-product-mini__thumb {
	width: 80px;
	height: 80px;
	border-radius: var(--mi-radius-md);
	background: var(--mi-color-surface-muted);
	overflow: hidden;
	flex-shrink: 0;
}

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

.mi-product-mini__info {
	display: flex;
	flex-direction: column;
	gap: var(--mi-space-1);
	min-width: 0;
}

.mi-product-mini__name {
	margin: 0;
	color: var(--mi-color-heading);
	font-size: var(--mi-font-size-sm);
	font-weight: var(--mi-font-semibold);
	line-height: 1.35;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.mi-product-mini__sku {
	color: var(--mi-color-muted);
	font-size: var(--mi-font-size-xs);
	font-weight: var(--mi-font-medium);
}

.mi-product-mini__price {
	color: var(--mi-color-black);
	font-size: var(--mi-font-size-sm);
	font-weight: var(--mi-font-bold);
}

.mi-product-mini__stock {
	display: inline-flex;
	align-items: center;
	gap: var(--mi-space-1);
	font-size: var(--mi-font-size-xs);
	font-weight: var(--mi-font-medium);
}

.mi-product-mini__stock-dot {
	width: 7px;
	height: 7px;
	border-radius: 50%;
	flex-shrink: 0;
}

/* ----------------------------------------------------------------
   CTA banner
   ---------------------------------------------------------------- */
.mi-cta-banner {
	padding: var(--mi-space-6);
	border-radius: var(--mi-radius-lg);
	background: var(--mi-color-primary);
	color: var(--mi-color-white);
	text-align: center;
}

.mi-cta-banner__text {
	margin: 0 0 var(--mi-space-4);
	font-size: var(--mi-font-size-lg);
	font-weight: var(--mi-font-semibold);
	line-height: var(--mi-line-heading);
}

.mi-cta-banner__button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 44px;
	padding: 0.62rem 1.25rem;
	border: 1px solid var(--mi-color-white);
	border-radius: var(--mi-radius-sm);
	background: var(--mi-color-white);
	color: var(--mi-color-primary);
	font-size: var(--mi-font-size-sm);
	font-weight: var(--mi-font-bold);
	text-decoration: none;
	transition:
		background var(--mi-transition-fast),
		color var(--mi-transition-fast),
		transform var(--mi-transition-fast);
}

.mi-cta-banner__button:hover,
.mi-cta-banner__button:focus-visible {
	background: transparent;
	color: var(--mi-color-white);
	transform: translateY(-1px);
}

/* ----------------------------------------------------------------
   Category list (sidebar)
   ---------------------------------------------------------------- */
.mi-blog-cat-list {
	display: grid;
	gap: var(--mi-space-2);
	margin: 0;
	padding: 0;
	list-style: none;
}

.mi-blog-cat-list__item {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--mi-space-2);
}

.mi-blog-cat-list__link {
	color: var(--mi-color-text);
	font-size: var(--mi-font-size-sm);
	font-weight: var(--mi-font-medium);
	text-decoration: none;
	transition: color var(--mi-transition-fast);
	flex: 1 1 auto;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.mi-blog-cat-list__link:hover,
.mi-blog-cat-list__link:focus-visible {
	color: var(--mi-color-primary);
	text-decoration: underline;
}

.mi-blog-cat-list__count {
	color: var(--mi-color-muted);
	font-size: var(--mi-font-size-xs);
	font-weight: var(--mi-font-medium);
	flex-shrink: 0;
}

/* ----------------------------------------------------------------
   Tag list (sidebar)
   ---------------------------------------------------------------- */
.mi-tag-list {
	display: flex;
	flex-wrap: wrap;
	gap: var(--mi-space-2);
	margin: 0;
	padding: 0;
	list-style: none;
}

.mi-tag-list__item a {
	display: inline-flex;
	align-items: center;
	min-height: 32px;
	padding: var(--mi-space-1) var(--mi-space-3);
	border: var(--mi-border);
	border-radius: var(--mi-radius-pill);
	background: var(--mi-color-surface);
	color: var(--mi-color-muted);
	font-size: var(--mi-font-size-sm);
	font-weight: var(--mi-font-medium);
	text-decoration: none;
	transition:
		background var(--mi-transition-fast),
		color var(--mi-transition-fast),
		border-color var(--mi-transition-fast);
}

.mi-tag-list__item a:hover,
.mi-tag-list__item a:focus-visible {
	border-color: var(--mi-color-primary);
	background: var(--mi-color-primary-soft);
	color: var(--mi-color-primary);
}

/* ----------------------------------------------------------------
   Related products
   ---------------------------------------------------------------- */
.mi-related-products {
	margin-top: var(--mi-section-gap);
	padding-top: var(--mi-space-7);
	border-top: var(--mi-border);
}

.mi-related-products__header {
	display: flex;
	flex-wrap: wrap;
	gap: var(--mi-space-2) var(--mi-space-4);
	align-items: center;
	justify-content: space-between;
	margin-bottom: var(--mi-space-5);
}

.mi-related-products__title {
	margin: 0;
	color: var(--mi-color-heading);
	font-size: var(--mi-font-size-xl);
	font-weight: var(--mi-font-bold);
	line-height: var(--mi-line-heading);
}

.mi-related-products__more {
	color: var(--mi-color-primary);
	font-size: var(--mi-font-size-sm);
	font-weight: var(--mi-font-semibold);
	text-decoration: none;
}

.mi-related-products__more:hover,
.mi-related-products__more:focus-visible {
	text-decoration: underline;
}

.mi-related-products__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: var(--mi-space-6);
}

/* Product card reuse from shop.css where possible */
.mi-related-products__grid .mi-product-mini {
	grid-template-columns: 1fr;
	border-bottom: 0;
	padding: 0;
}

.mi-related-products__grid .mi-product-mini__thumb {
	width: 100%;
	height: auto;
	aspect-ratio: 1 / 1;
}

.mi-related-products__grid .mi-product-mini__name {
	white-space: normal;
	font-size: var(--mi-font-size-md);
}

/* ----------------------------------------------------------------
   Mobile sidebar (simplified, above content)
   ---------------------------------------------------------------- */
.mi-blog-sidebar--mobile {
	gap: var(--mi-space-4);
}

.mi-blog-sidebar--mobile .mi-blog-sidebar__block {
	padding: var(--mi-space-4);
}

.mi-blog-sidebar--mobile .mi-blog-sidebar__block:not(.mi-blog-sidebar__block--products):not(.mi-blog-sidebar__block--cta) {
	display: none;
}

.mi-blog-sidebar--mobile .mi-product-mini-list {
	display: flex;
	gap: var(--mi-space-3);
	overflow-x: auto;
	scroll-snap-type: x proximity;
	padding-bottom: var(--mi-space-2);
}

.mi-blog-sidebar--mobile .mi-product-mini-list .mi-product-mini {
	flex: 0 0 auto;
	width: 240px;
	scroll-snap-align: start;
	grid-template-columns: 64px 1fr;
	border-bottom: 0;
}

/* ----------------------------------------------------------------
   Pagination
   ---------------------------------------------------------------- */
.mi-blog-pagination {
	margin-top: var(--mi-space-7);
}

/* ----------------------------------------------------------------
   Empty state
   ---------------------------------------------------------------- */
.mi-blog-empty {
	max-width: 680px;
	color: var(--mi-color-muted);
}

/* ----------------------------------------------------------------
   Front page blog grid
   ---------------------------------------------------------------- */
.mi-front-blog__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: clamp(16px, 2vw, 28px);
}

/* ----------------------------------------------------------------
   Responsive
   ---------------------------------------------------------------- */
@media (min-width: 721px) {
	.mi-blog-archive__grid,
	.mi-front-blog__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: var(--mi-space-6);
	}
}

@media (min-width: 1101px) {
	.mi-blog-archive__grid,
	.mi-front-blog__grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
		gap: var(--mi-space-6);
	}
}

@media (min-width: 1101px) {
	.mi-blog-layout {
		grid-template-columns: 1fr 300px;
		gap: clamp(24px, 4vw, 48px);
	}

	.mi-blog-layout--archive .mi-blog-archive__header {
		grid-column: 1 / -1;
	}

	.mi-blog-main {
		order: 1;
	}

	.mi-blog-sidebar {
		position: sticky;
		top: 100px;
		align-self: start;
		order: 2;
	}
}

@media (max-width: 720px) {
	.mi-blog-layout {
		width: min(100% - 24px, 1920px);
		padding-top: 22px;
	}

	.mi-blog-archive__header {
		padding-top: 12px;
	}

	.mi-blog-archive__title {
		font-size: clamp(2rem, 13vw, 3rem);
	}

	.mi-blog-post__title {
		font-size: clamp(2rem, 11vw, 2.8rem);
	}

	.mi-blog-post__media img {
		max-height: 280px;
	}

	.mi-blog-post__content {
		font-size: var(--mi-font-size-md);
		line-height: 1.68;
	}

	.mi-blog-post__content .wp-block-table {
		margin-inline: -12px;
		padding-inline: 12px;
	}

	.mi-blog-card__actions .button {
		width: 100%;
	}

	.mi-related-products__grid {
		grid-template-columns: 1fr;
	}
}
