/* =========================================================================
   MelissaKampers News — theme.css (v2, premium editorial)
   Loaded on the front end and in the block editor, so what you edit
   is what ships.

   Design language: high-end digital newspaper. Warm paper light mode,
   deep "control room" dark mode, mono signal-labels, serif reading
   column, layered hero, numbered sections, news-app mobile lists.

   Contents
   1. Design tokens (light + dark)
   2. Base, atmosphere & accessibility
   3. Header & brand
   4. Navigation, search, theme toggle
   5. Kickers & shared labels
   6. Article cards (incl. lead card + mobile list mode)
   7. Hero (layered magazine cover)
   8. Sections & homepage rhythm
   9. Single article (reading experience)
   10. Archives, search, pagination, 404
   11. Related posts, post navigation, comments
   12. Footer, newsletter, dossiers, callouts, pull-quote
   13. Motion & reduced motion
   ========================================================================= */

/* -------------------------------------------------------------------------
   1. Design tokens
   ------------------------------------------------------------------------- */
:root {
	color-scheme: light;

	/* Warm paper — elegant, calm, trustworthy. */
	--mk-bg: #faf9f6;
	--mk-surface: #ffffff;
	--mk-surface-2: #f1efe9;
	--mk-ink: #16171c;
	--mk-muted: #555b66;
	--mk-line: #e5e2d9;
	--mk-line-soft: #eeece4;
	--mk-accent: #2742e0;
	--mk-accent-2: #0b7b86;
	--mk-on-accent: #ffffff;

	--mk-accent-soft: rgba(39, 66, 224, 0.07);
	--mk-pulse: rgba(11, 123, 134, 0.45);

	--mk-alert: #b3173d;
	--mk-alert-soft: rgba(179, 23, 61, 0.07);
	--mk-alert-glow: rgba(179, 23, 61, 0.4);

	--mk-img-dim: none;

	--mk-shadow: 0 1px 2px rgba(22, 23, 28, 0.04), 0 10px 30px rgba(22, 23, 28, 0.06);
	--mk-shadow-up: 0 2px 6px rgba(22, 23, 28, 0.06), 0 24px 60px rgba(22, 23, 28, 0.13);
	--mk-shadow-header: 0 10px 30px rgba(22, 23, 28, 0.07);
	--mk-header-bg: rgba(250, 249, 246, 0.86);

	/* Page-top atmosphere: a soft white wash that fades into the paper. */
	--mk-atmosphere: linear-gradient(180deg, rgba(255, 255, 255, 0.85) 0%, rgba(255, 255, 255, 0) 24rem);

	--mk-radius-s: 10px;
	--mk-radius-m: 16px;
	--mk-radius-l: 22px;
}

/* Dark tokens — deep editorial control-room, subtle neon signals. */
[data-theme="dark"] {
	color-scheme: dark;

	--mk-bg: #0a0c12;
	--mk-surface: #11141d;
	--mk-surface-2: #181d2a;
	--mk-ink: #edf0f7;
	--mk-muted: #99a3b4;
	--mk-line: #252b3b;
	--mk-line-soft: #1d2331;
	--mk-accent: #8da4ff;
	--mk-accent-2: #34d8c5;
	--mk-on-accent: #0a0c12;

	--mk-accent-soft: rgba(141, 164, 255, 0.1);
	--mk-pulse: rgba(52, 216, 197, 0.5);

	--mk-alert: #ff8095;
	--mk-alert-soft: rgba(255, 128, 149, 0.1);
	--mk-alert-glow: rgba(255, 128, 149, 0.45);

	/* Photos glare on near-black; premium dark modes pull them back. */
	--mk-img-dim: brightness(0.9);

	--mk-shadow: 0 1px 2px rgba(0, 0, 0, 0.45), 0 14px 38px rgba(0, 0, 0, 0.45);
	--mk-shadow-up: 0 2px 8px rgba(0, 0, 0, 0.5), 0 28px 70px rgba(0, 0, 0, 0.6), 0 0 0 1px rgba(141, 164, 255, 0.14);
	--mk-shadow-header: 0 12px 36px rgba(0, 0, 0, 0.55);
	--mk-header-bg: rgba(10, 12, 18, 0.8);

	/* Faint accent glow at the top corners — atmosphere, not decoration. */
	--mk-atmosphere:
		radial-gradient(52rem 32rem at 85% -8%, rgba(141, 164, 255, 0.09), transparent 62%),
		radial-gradient(40rem 28rem at -12% 4%, rgba(52, 216, 197, 0.05), transparent 60%);
}

/* System preference, for visitors who never touch the toggle (and no-JS). */
@media (prefers-color-scheme: dark) {
	:root:not([data-theme="light"]) {
		color-scheme: dark;

		--mk-bg: #0a0c12;
		--mk-surface: #11141d;
		--mk-surface-2: #181d2a;
		--mk-ink: #edf0f7;
		--mk-muted: #99a3b4;
		--mk-line: #252b3b;
		--mk-line-soft: #1d2331;
		--mk-accent: #8da4ff;
		--mk-accent-2: #34d8c5;
		--mk-on-accent: #0a0c12;

		--mk-accent-soft: rgba(141, 164, 255, 0.1);
		--mk-pulse: rgba(52, 216, 197, 0.5);

		--mk-alert: #ff8095;
		--mk-alert-soft: rgba(255, 128, 149, 0.1);
		--mk-alert-glow: rgba(255, 128, 149, 0.45);

		--mk-img-dim: brightness(0.9);

		--mk-shadow: 0 1px 2px rgba(0, 0, 0, 0.45), 0 14px 38px rgba(0, 0, 0, 0.45);
		--mk-shadow-up: 0 2px 8px rgba(0, 0, 0, 0.5), 0 28px 70px rgba(0, 0, 0, 0.6), 0 0 0 1px rgba(141, 164, 255, 0.14);
		--mk-shadow-header: 0 12px 36px rgba(0, 0, 0, 0.55);
		--mk-header-bg: rgba(10, 12, 18, 0.8);

		--mk-atmosphere:
			radial-gradient(52rem 32rem at 85% -8%, rgba(141, 164, 255, 0.09), transparent 62%),
			radial-gradient(40rem 28rem at -12% 4%, rgba(52, 216, 197, 0.05), transparent 60%);
	}
}

/* -------------------------------------------------------------------------
   2. Base, atmosphere & accessibility
   ------------------------------------------------------------------------- */
html {
	/* Native checkboxes, radios, progress bars follow the theme accent. */
	accent-color: var(--mk-accent);
}

body {
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
	background-image: var(--mk-atmosphere);
	background-repeat: no-repeat;
}

/* Brief color cross-fade while switching themes. The class is added by
   theme-toggle.js for ~320ms around a switch — never on page load — and
   the whole rule is skipped for reduced-motion visitors. */
@media (prefers-reduced-motion: no-preference) {
	.mk-theme-anim,
	.mk-theme-anim *,
	.mk-theme-anim *::before,
	.mk-theme-anim *::after {
		transition:
			background-color 240ms ease,
			color 240ms ease,
			border-color 240ms ease,
			box-shadow 240ms ease !important;
	}
}

::selection {
	background: var(--mk-accent);
	color: var(--mk-on-accent);
}

:focus-visible {
	outline: 2px solid var(--mk-accent);
	outline-offset: 3px;
	border-radius: 3px;
}

/* On accent-filled controls the accent ring would vanish — use ink. */
.wp-element-button:focus-visible,
.wp-block-search__button:focus-visible,
.wp-block-post-comments-form input[type="submit"]:focus-visible {
	outline-color: var(--mk-ink);
}

/* Themed defaults for every native form control (search, password-protected
   posts, plugin forms) so nothing renders browser-grey in dark mode. */
input[type="text"],
input[type="search"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="number"],
input[type="tel"],
select,
textarea {
	color: var(--mk-ink);
	background-color: var(--mk-surface);
	border: 1px solid var(--mk-line);
	border-radius: var(--mk-radius-s);
}

::placeholder {
	color: var(--mk-muted);
	opacity: 0.85;
}

textarea {
	resize: vertical;
}

/* Browser-default <mark> is hard yellow; keep highlights on-theme. */
mark {
	background: var(--mk-accent-soft);
	color: inherit;
}

/* Calm placeholder for the theme's dynamic blocks inside the editor. */
.mk-editor-placeholder {
	border: 1px dashed var(--mk-line);
	border-radius: var(--mk-radius-s);
	padding: 0.9rem 1.1rem;
	font-family: var(--wp--preset--font-family--mono);
	font-size: 0.78rem;
	letter-spacing: 0.04em;
	color: var(--mk-muted);
	background: var(--mk-surface);
}

/* Outline button variant works in both schemes. */
.wp-block-button.is-style-outline .wp-block-button__link {
	background: transparent;
	border: 1px solid var(--mk-accent);
	color: var(--mk-accent);
}

.wp-block-button.is-style-outline .wp-block-button__link:hover {
	background: var(--mk-accent);
	color: var(--mk-on-accent);
}

.screen-reader-text {
	position: absolute !important;
	width: 1px;
	height: 1px;
	margin: -1px;
	padding: 0;
	overflow: hidden;
	clip: rect(0 0 0 0);
	clip-path: inset(50%);
	white-space: nowrap;
	border: 0;
}

.skip-link.screen-reader-text:focus {
	position: fixed !important;
	top: 0.75rem;
	left: 0.75rem;
	z-index: 1000;
	width: auto;
	height: auto;
	clip: auto;
	clip-path: none;
	padding: 0.6rem 1.2rem;
	background: var(--mk-accent);
	color: var(--mk-on-accent);
	font-weight: 600;
	text-decoration: none;
	border-radius: 999px;
	box-shadow: var(--mk-shadow-up);
}

img {
	height: auto;
	max-width: 100%;
}

/* Editorial imagery follows the active scheme (dimmed slightly in dark). */
.mk-card__media img,
.mk-mini-card__media img,
.mk-hero-card__media img,
.mk-article-hero img,
.wp-block-post-content img {
	filter: var(--mk-img-dim, none);
}

/* -------------------------------------------------------------------------
   3. Header & brand
   ------------------------------------------------------------------------- */
.mk-header {
	position: sticky;
	top: 0;
	z-index: 100;
	background: var(--mk-header-bg);
	border-bottom: 1px solid transparent;
	transition: border-color 240ms ease, box-shadow 240ms ease;
}

/* Signal line: the one piece of neon the masthead allows itself. */
.mk-header::before {
	content: "";
	display: block;
	height: 2px;
	background: linear-gradient(90deg, var(--mk-accent) 0%, var(--mk-accent-2) 45%, transparent 85%);
}

.mk-header.is-scrolled {
	border-bottom-color: var(--mk-line);
	box-shadow: var(--mk-shadow-header);
}

@supports (backdrop-filter: blur(1px)) {
	.mk-header {
		backdrop-filter: blur(16px) saturate(1.5);
		-webkit-backdrop-filter: blur(16px) saturate(1.5);
	}
}

.mk-header__inner {
	max-width: 76rem;
	margin-inline: auto;
	padding: 0.9rem clamp(1rem, 3vw, 1.5rem);
	gap: 1rem 2rem;
}

.mk-brand {
	display: inline-flex;
	flex-direction: column;
	gap: 0.2rem;
	text-decoration: none;
	color: var(--mk-ink);
	line-height: 1.05;
}

.mk-brand__name {
	font-weight: 800;
	font-size: clamp(1.1rem, 2.6vw, 1.4rem);
	letter-spacing: -0.03em;
}

/* The wordmark has hierarchy: "www." recedes, the name carries the
   weight, ".com" takes the accent — a masthead, not a URL. */
.mk-brand__www {
	color: var(--mk-muted);
	font-weight: 600;
}

.mk-brand__tld {
	color: var(--mk-accent);
}

.mk-brand__tagline {
	font-family: var(--wp--preset--font-family--mono);
	font-size: 0.65rem;
	font-weight: 500;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--mk-muted);
}

.mk-brand:hover .mk-brand__name {
	color: var(--mk-accent);
}

.mk-header__tools {
	gap: 0.5rem 1.4rem;
	align-items: center;
}

/* -------------------------------------------------------------------------
   4. Navigation, search, theme toggle
   ------------------------------------------------------------------------- */
.mk-nav a {
	font-weight: 600;
	font-size: 0.9375rem;
	letter-spacing: 0.01em;
	color: var(--mk-ink);
	text-decoration: none;
	padding-bottom: 0.2rem;
	background-image: linear-gradient(90deg, var(--mk-accent), var(--mk-accent-2));
	background-repeat: no-repeat;
	background-position: 0 100%;
	background-size: 0% 2px;
	transition: background-size 220ms ease, color 160ms ease;
}

.mk-nav a:hover,
.mk-nav a[aria-current="page"],
.mk-nav .current-menu-item > a {
	color: var(--mk-accent);
	background-size: 100% 2px;
}

.mk-nav .wp-block-navigation__responsive-container.is-menu-open {
	background: var(--mk-bg);
	background-image: var(--mk-atmosphere);
	background-repeat: no-repeat;
	color: var(--mk-ink);
	padding-top: 5.5rem;
	padding-left: clamp(1.25rem, 6vw, 3rem);
}

.mk-nav .wp-block-navigation__responsive-container.is-menu-open a {
	font-size: clamp(1.5rem, 5vw, 2rem);
	font-weight: 700;
	letter-spacing: -0.02em;
}

.mk-nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__container {
	gap: 1.1rem;
}

.mk-nav .wp-block-navigation__responsive-container-open,
.mk-nav .wp-block-navigation__responsive-container-close {
	color: var(--mk-ink);
}

/* Dropdown submenus: core paints these white by default, which breaks
   dark mode — theme them explicitly in both schemes. */
.mk-nav .wp-block-navigation__submenu-container {
	background-color: var(--mk-surface) !important;
	border: 1px solid var(--mk-line) !important;
	border-radius: var(--mk-radius-s);
	box-shadow: var(--mk-shadow-up);
	padding: 0.4rem;
}

.mk-nav .wp-block-navigation__submenu-container a {
	color: var(--mk-ink) !important;
	padding: 0.5rem 0.8rem;
	border-radius: 7px;
}

.mk-nav .wp-block-navigation__submenu-container a:hover,
.mk-nav .wp-block-navigation__submenu-container a:focus-visible {
	background-color: var(--mk-accent-soft);
	color: var(--mk-accent) !important;
}

/* Compact icon-button search that expands on click (core behavior). */
.mk-search .wp-block-search__button {
	background: transparent;
	border: 1px solid var(--mk-line);
	border-radius: 999px;
	color: var(--mk-ink);
	padding: 0.55rem 0.7rem;
	min-width: 40px;
	min-height: 40px;
	cursor: pointer;
	transition: border-color 160ms ease, color 160ms ease, background 160ms ease;
}

.mk-search .wp-block-search__button:hover {
	border-color: var(--mk-accent);
	color: var(--mk-accent);
	background: var(--mk-accent-soft);
}

.mk-search .wp-block-search__input {
	background: var(--mk-surface);
	border: 1px solid var(--mk-line);
	border-radius: 999px;
	color: var(--mk-ink);
	padding: 0.55rem 1.1rem;
	font-size: 0.9375rem;
	min-width: 0;
}

.mk-search.wp-block-search__button-behavior-expand .wp-block-search__inside-wrapper {
	border: none;
	padding: 0;
}

/* Theme toggle */
.mk-theme-toggle {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	flex-shrink: 0;
	border: 1px solid var(--mk-line);
	border-radius: 999px;
	background: transparent;
	color: var(--mk-ink);
	cursor: pointer;
	transition: border-color 160ms ease, color 160ms ease, background 160ms ease, transform 160ms ease;
}

.mk-theme-toggle:hover {
	border-color: var(--mk-accent);
	color: var(--mk-accent);
	background: var(--mk-accent-soft);
}

.mk-theme-toggle:active {
	transform: scale(0.92);
}

.mk-theme-toggle__icon {
	width: 18px;
	height: 18px;
}

/* Show the icon for the mode you would switch TO. */
.mk-theme-toggle__icon--sun { display: none; }
[data-theme="dark"] .mk-theme-toggle__icon--sun { display: block; }
[data-theme="dark"] .mk-theme-toggle__icon--moon { display: none; }

/* -------------------------------------------------------------------------
   5. Kickers & shared labels
   ------------------------------------------------------------------------- */
.mk-kicker,
.mk-kicker a {
	display: inline-flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 0.25rem 0.6rem;
	font-family: var(--wp--preset--font-family--mono);
	font-size: 0.6875rem;
	font-weight: 600;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--mk-accent-2);
	text-decoration: none;
}

/* Small leading rule before each kicker — quiet editorial signal. */
.mk-kicker::before {
	content: "";
	width: 18px;
	height: 1px;
	background: var(--mk-accent-2);
	flex-shrink: 0;
}

.mk-kicker a::before { content: none; }

.mk-kicker a:hover {
	text-decoration: underline;
	text-underline-offset: 0.35em;
}

/* "Top story" eyebrow with a live pulse. */
.mk-eyebrow {
	display: flex;
	align-items: center;
	gap: 0.6rem;
	margin: 0 0 1.1rem;
	font-family: var(--wp--preset--font-family--mono);
	font-size: 0.6875rem;
	font-weight: 600;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--mk-muted);
}

.mk-eyebrow__dot {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: var(--mk-accent-2);
	animation: mk-pulse 2.6s ease-out infinite;
}

@keyframes mk-pulse {
	0%   { box-shadow: 0 0 0 0 var(--mk-pulse); }
	70%  { box-shadow: 0 0 0 10px transparent; }
	100% { box-shadow: 0 0 0 0 transparent; }
}

/* -------------------------------------------------------------------------
   6. Article cards
   ------------------------------------------------------------------------- */
.mk-card {
	position: relative;
	height: 100%;
	display: flex;
	flex-direction: column;
	background: var(--mk-surface);
	border: 1px solid var(--mk-line);
	border-radius: var(--mk-radius-m);
	overflow: hidden;
	box-shadow: var(--mk-shadow);
	transition: transform 220ms ease, box-shadow 220ms ease, border-color 220ms ease;
}

.mk-card:hover,
.mk-card:focus-within {
	transform: translateY(-4px);
	border-color: var(--mk-accent);
	box-shadow: var(--mk-shadow-up);
}

/* Inset "gallery mat" media — the small frame is what reads as premium. */
.mk-card__media {
	margin: 0.65rem 0.65rem 0;
	border-radius: calc(var(--mk-radius-m) - 6px);
	overflow: hidden;
	background: var(--mk-surface-2);
}

.mk-card__media img {
	display: block;
	width: 100%;
	object-fit: cover;
	transition: transform 500ms cubic-bezier(0.2, 0.6, 0.2, 1);
}

.mk-card:hover .mk-card__media img {
	transform: scale(1.04);
}

.mk-card__body {
	display: flex;
	flex-direction: column;
	flex-grow: 1;
	gap: 0.65rem;
	padding: 1.15rem 1.3rem 1.3rem;
}

.mk-card__title {
	font-size: 1.22rem;
	font-weight: 750;
	line-height: 1.26;
	letter-spacing: -0.015em;
	margin: 0;
}

.mk-card__title a {
	color: var(--mk-ink);
	text-decoration: none;
}

.mk-card__title a:hover {
	color: var(--mk-accent);
	text-decoration: underline;
	text-underline-offset: 0.22em;
	text-decoration-thickness: 2px;
}

.mk-card__excerpt {
	font-size: 0.9375rem;
	line-height: 1.55;
	color: var(--mk-muted);
	margin: 0;
}

.mk-card__excerpt p {
	margin: 0;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.mk-card__excerpt .wp-block-post-excerpt__more-text { display: none; }

.mk-card__meta {
	gap: 0.35rem 0.7rem;
	align-items: baseline;
	margin-top: auto;
	color: var(--mk-muted);
}

.mk-card__date {
	font-family: var(--wp--preset--font-family--mono);
	font-size: 0.72rem;
	letter-spacing: 0.06em;
	text-transform: uppercase;
}

.mk-card__author,
.mk-card__author a {
	font-size: 0.8125rem;
	color: var(--mk-muted);
	text-decoration: none;
}

.mk-card__author a:hover {
	color: var(--mk-accent);
	text-decoration: underline;
}

.mk-card__author::before {
	content: "·";
	content: "·" / "";
	margin-right: 0.7rem;
	color: var(--mk-line);
}

.mk-readmore {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	font-size: 0.8125rem;
	font-weight: 700;
	letter-spacing: 0.02em;
	color: var(--mk-accent);
	text-decoration: none;
}

.mk-readmore::after {
	content: "\2192";
	content: "\2192" / "";
	transition: transform 220ms ease;
}

.mk-readmore:hover {
	text-decoration: underline;
	text-underline-offset: 0.3em;
}

.mk-card:hover .mk-readmore::after { transform: translateX(5px); }

/* Lead card: the first story in the Latest News grid runs wide. */
@media (min-width: 900px) {
	.mk-latest .wp-block-post-template > li:first-child {
		grid-column: span 2;
	}

	.mk-latest .wp-block-post-template > li:first-child .mk-card {
		display: grid;
		grid-template-columns: minmax(0, 1.15fr) minmax(0, 1fr);
		align-items: stretch;
	}

	.mk-latest .wp-block-post-template > li:first-child .mk-card__media {
		margin: 0;
		border-radius: 0;
		height: 100%;
	}

	.mk-latest .wp-block-post-template > li:first-child .mk-card__media img {
		height: 100%;
	}

	.mk-latest .wp-block-post-template > li:first-child .mk-card__body {
		padding: clamp(1.4rem, 2.5vw, 2.2rem);
		justify-content: center;
	}

	.mk-latest .wp-block-post-template > li:first-child .mk-card__title {
		font-size: clamp(1.5rem, 2.4vw, 1.9rem);
		letter-spacing: -0.022em;
	}
}

/* No-featured-image fallbacks: layouts adapt instead of leaving gaps.
   (Older browsers without :has() just keep slightly looser spacing.) */
.mk-card:not(:has(.mk-card__media)) .mk-card__body {
	padding-top: 1.3rem;
}

@media (min-width: 900px) {
	.mk-latest .wp-block-post-template > li:first-child .mk-card:not(:has(.mk-card__media)) {
		display: flex;
	}
}

/* Mobile: cards become a compact news-app list (image right, text left). */
@media (max-width: 640px) {
	.mk-main .wp-block-post-template {
		gap: 0.85rem;
	}

	.mk-card {
		display: grid;
		grid-template-columns: minmax(0, 1fr) 6.25rem;
		align-items: center;
		column-gap: 1rem;
		padding: 0.95rem 1.05rem;
		border-radius: var(--mk-radius-m);
	}

	.mk-card:not(:has(.mk-card__media)),
	.mk-mini-card:not(:has(.mk-mini-card__media)) {
		grid-template-columns: minmax(0, 1fr);
	}

	.mk-card__media {
		order: 2;
		margin: 0;
		width: 6.25rem;
		border-radius: var(--mk-radius-s);
		aspect-ratio: 1 / 1 !important;
	}

	.mk-card__media img {
		height: 100%;
	}

	.mk-card__body {
		order: 1;
		padding: 0;
		gap: 0.45rem;
	}

	.mk-card__title {
		font-size: 1.04rem;
		line-height: 1.3;
	}

	.mk-card__excerpt,
	.mk-readmore,
	.mk-card__author {
		display: none;
	}
}

/* -------------------------------------------------------------------------
   7. Hero — front-page lede package
   ------------------------------------------------------------------------- */
.mk-hero {
	padding-top: clamp(1.5rem, 4vw, 2.75rem);
}

/* Front-page bar: editorial mission + today's date, under a hairline. */
.mk-frontbar {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: baseline;
	gap: 0.35rem 2rem;
	border-bottom: 1px solid var(--mk-line);
	padding-bottom: 0.9rem;
	margin-bottom: clamp(1.5rem, 3.5vw, 2.5rem);
}

.mk-frontbar__mission {
	margin: 0;
	font-family: var(--wp--preset--font-family--serif);
	font-style: italic;
	font-size: 0.98rem;
	color: var(--mk-muted);
}

.mk-frontbar__date {
	margin: 0;
	font-family: var(--wp--preset--font-family--mono);
	font-size: 0.72rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--mk-muted);
}

/* Lede package: cover story left, briefing rail right. */
.mk-lede {
	display: grid;
	gap: clamp(1.75rem, 4vw, 2.75rem);
}

@media (min-width: 1000px) {
	.mk-lede {
		grid-template-columns: minmax(0, 8fr) minmax(0, 4.2fr);
		align-items: start;
	}

	/* One-post site: no briefing rail → the cover story takes the full row. */
	.mk-lede:not(:has(.mk-briefing)) {
		grid-template-columns: minmax(0, 1fr);
	}
}

/* Cover card: image on top, text panel overlapping upward. */
.mk-hero-card {
	display: block;
	background: transparent;
	border: none;
	box-shadow: none;
	overflow: visible;
}

.mk-hero-card__media {
	margin: 0;
	border-radius: var(--mk-radius-l);
	overflow: hidden;
	background: var(--mk-surface-2);
	box-shadow: var(--mk-shadow-up);
}

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

.mk-hero-card__body {
	position: relative;
	z-index: 2;
	display: flex;
	flex-direction: column;
	gap: 0.95rem;
	background: var(--mk-surface);
	border: 1px solid var(--mk-line);
	border-radius: var(--mk-radius-l);
	padding: clamp(1.4rem, 3vw, 2.4rem);
	box-shadow: var(--mk-shadow-up);
	margin: -3.25rem clamp(1rem, 4vw, 2.25rem) 0;
}

.mk-hero-card__title {
	margin: 0;
	font-size: clamp(1.8rem, 4.2vw, 3rem);
	font-weight: 800;
	line-height: 1.06;
	letter-spacing: -0.03em;
	text-wrap: balance;
}

.mk-hero-card__title a {
	color: var(--mk-ink);
	text-decoration: none;
}

.mk-hero-card__title a:hover {
	color: var(--mk-accent);
}

.mk-hero-card__excerpt {
	margin: 0;
	font-family: var(--wp--preset--font-family--serif);
	font-size: clamp(1.02rem, 1.7vw, 1.18rem);
	line-height: 1.62;
	color: var(--mk-muted);
}

.mk-hero-card__excerpt p { margin: 0; }
.mk-hero-card__excerpt .wp-block-post-excerpt__more-text { display: none; }

/* Top story without a featured image: no overlap, the panel stands alone. */
.mk-hero-card:not(:has(.mk-hero-card__media)) .mk-hero-card__body {
	margin: 0;
}

/* Briefing rail: numbered headline stack of the next stories. */
.mk-briefing {
	counter-reset: mkbrief;
}

@media (min-width: 1000px) {
	.mk-briefing {
		border-left: 1px solid var(--mk-line);
		padding-left: clamp(1.5rem, 2.5vw, 2.25rem);
	}
}

.mk-briefing__title {
	margin: 0 0 0.4rem;
	font-family: var(--wp--preset--font-family--mono);
	font-size: 0.6875rem;
	font-weight: 600;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--mk-muted);
}

.mk-briefing .wp-block-post-template {
	display: block;
}

.mk-briefing .wp-block-post-template > li {
	counter-increment: mkbrief;
	border-top: 1px solid var(--mk-line-soft);
}

.mk-briefing .wp-block-post-template > li:first-child {
	border-top: none;
}

.mk-brief-item {
	display: grid;
	grid-template-columns: 2.1rem minmax(0, 1fr);
	column-gap: 0.7rem;
	row-gap: 0.25rem;
	padding: 0.95rem 0;
}

.mk-brief-item::before {
	content: counter(mkbrief, decimal-leading-zero);
	content: counter(mkbrief, decimal-leading-zero) / "";
	grid-row: 1 / span 2;
	font-family: var(--wp--preset--font-family--mono);
	font-size: 0.72rem;
	font-weight: 600;
	letter-spacing: 0.06em;
	color: var(--mk-accent);
	padding-top: 0.25rem;
}

.mk-brief-item__date {
	grid-column: 2;
	font-family: var(--wp--preset--font-family--mono);
	font-size: 0.68rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--mk-muted);
}

.mk-brief-item__title {
	grid-column: 2;
	margin: 0;
	font-size: 1.02rem;
	font-weight: 700;
	line-height: 1.32;
	letter-spacing: -0.012em;
}

.mk-brief-item__title a {
	color: var(--mk-ink);
	text-decoration: none;
}

.mk-brief-item__title a:hover {
	color: var(--mk-accent);
	text-decoration: underline;
	text-underline-offset: 0.22em;
}

/* Welcome panel — shown only when the site has no published posts yet. */
.mk-welcome {
	position: relative;
	padding: clamp(2.25rem, 6vw, 4.25rem);
	background:
		radial-gradient(130% 170% at 0% 0%, var(--mk-accent-soft), transparent 58%),
		var(--mk-surface);
	border: 1px solid var(--mk-line);
	border-radius: var(--mk-radius-l);
	box-shadow: var(--mk-shadow);
}

.mk-welcome__title {
	margin: 0.9rem 0 0.6rem;
	font-size: clamp(1.7rem, 4vw, 2.5rem);
	font-weight: 800;
	letter-spacing: -0.028em;
}

.mk-welcome__text {
	max-width: 44rem;
	margin: 0;
	font-family: var(--wp--preset--font-family--serif);
	font-size: 1.08rem;
	line-height: 1.65;
	color: var(--mk-muted);
}

/* -------------------------------------------------------------------------
   8. Sections & homepage rhythm
   ------------------------------------------------------------------------- */
.mk-section {
	padding-top: clamp(2.75rem, 6vw, 4.75rem);
}

.mk-section:last-of-type {
	padding-bottom: clamp(2.5rem, 6vw, 4.5rem);
}

.mk-section__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	flex-wrap: wrap;
	border-top: 1px solid var(--mk-line);
	padding-top: 1.3rem;
	margin-bottom: 1.75rem;
}

.mk-section__title {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	margin: 0;
	font-size: clamp(1.35rem, 2.6vw, 1.7rem);
	font-weight: 800;
	letter-spacing: -0.024em;
}

.mk-section__title::before {
	content: "";
	width: 10px;
	height: 10px;
	border-radius: 3px;
	background: linear-gradient(135deg, var(--mk-accent), var(--mk-accent-2));
	flex-shrink: 0;
}

/* On the homepage, sections are numbered like a front page rundown. */
.mk-home { counter-reset: mksec; }
.mk-home .mk-section { counter-increment: mksec; }

.mk-home .mk-section__title::before {
	content: counter(mksec, decimal-leading-zero);
	/* CSS alt-text syntax: keeps the number visual-only for screen readers. */
	content: counter(mksec, decimal-leading-zero) / "";
	width: auto;
	height: auto;
	border-radius: 7px;
	background: var(--mk-surface);
	border: 1px solid var(--mk-line);
	color: var(--mk-accent);
	font-family: var(--wp--preset--font-family--mono);
	font-size: 0.72rem;
	font-weight: 600;
	letter-spacing: 0.08em;
	line-height: 1;
	padding: 0.42rem 0.5rem;
}

.mk-section__more {
	margin: 0;
	font-size: 0.85rem;
	font-weight: 650;
}

.mk-section__more a {
	display: inline-flex;
	align-items: center;
	color: var(--mk-ink);
	text-decoration: none;
	border: 1px solid var(--mk-line);
	border-radius: 999px;
	padding: 0.45rem 1rem;
	transition: border-color 180ms ease, color 180ms ease, background 180ms ease;
}

.mk-section__more a:hover {
	border-color: var(--mk-accent);
	color: var(--mk-accent);
	background: var(--mk-accent-soft);
}

/* "Updated <date>" stamp in section heads. */
.mk-section__stamp {
	margin: 0;
	font-family: var(--wp--preset--font-family--mono);
	font-size: 0.72rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--mk-muted);
}

/* More generous editorial rhythm on the front page. */
.mk-home .mk-section {
	padding-top: clamp(3.25rem, 7vw, 5.25rem);
}

/* Lane: a framed panel section (used for AI developments) that breaks
   the rhythm of open grids without shouting. */
.mk-home .mk-lane {
	margin-top: clamp(3.25rem, 7vw, 5.25rem);
	padding: clamp(1.5rem, 3.5vw, 2.6rem);
	background: var(--mk-surface);
	border: 1px solid var(--mk-line);
	border-radius: var(--mk-radius-l);
	box-shadow: var(--mk-shadow);
}

.mk-lane .mk-section__head {
	border-top: none;
	padding-top: 0;
	margin-bottom: 1.4rem;
}

/* Inside the panel, cards sit on the page background for depth. */
.mk-lane .mk-card {
	background: var(--mk-bg);
	border-color: var(--mk-line-soft);
}

/* Headline list lane (used for Analysis): text-led, newspaper rhythm. */
.mk-list .wp-block-post-template {
	display: block;
	max-width: 56rem;
}

.mk-list .wp-block-post-template > li {
	border-top: 1px solid var(--mk-line-soft);
}

.mk-list .wp-block-post-template > li:first-child {
	border-top: none;
}

.mk-list-item {
	display: flex;
	flex-direction: column;
	gap: 0.45rem;
	padding: clamp(1.1rem, 2.5vw, 1.5rem) 0;
}

.mk-list-item__row {
	width: 100%;
	gap: 0.5rem 1.5rem;
	align-items: baseline;
}

.mk-list-item__date {
	font-family: var(--wp--preset--font-family--mono);
	font-size: 0.7rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--mk-muted);
}

.mk-list-item__title {
	margin: 0;
	font-size: clamp(1.18rem, 2.2vw, 1.45rem);
	font-weight: 750;
	line-height: 1.25;
	letter-spacing: -0.018em;
}

.mk-list-item__title a {
	color: var(--mk-ink);
	text-decoration: none;
}

.mk-list-item__title a:hover {
	color: var(--mk-accent);
	text-decoration: underline;
	text-underline-offset: 0.22em;
	text-decoration-thickness: 2px;
}

.mk-list-item__excerpt {
	margin: 0;
	max-width: 46rem;
	font-family: var(--wp--preset--font-family--serif);
	font-size: 0.98rem;
	line-height: 1.6;
	color: var(--mk-muted);
}

.mk-list-item__excerpt p {
	margin: 0;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.mk-list-item__excerpt .wp-block-post-excerpt__more-text { display: none; }

/* -------------------------------------------------------------------------
   9. Single article — the reading experience
   ------------------------------------------------------------------------- */
.mk-main {
	padding-bottom: clamp(3rem, 7vw, 5.5rem);
}

/* Centered editorial title area — calm, balanced, confident. */
.mk-article-header {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 1.15rem;
	max-width: 52rem;
	margin-inline: auto;
	padding-top: clamp(2rem, 5vw, 3.5rem);
	margin-bottom: clamp(1.75rem, 4vw, 2.75rem);
}

/* Category chip(s) above the headline. */
.mk-article-cat {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 0.5rem;
}

.mk-article-cat a {
	display: inline-block;
	padding: 0.38rem 1.05rem;
	border-radius: 999px;
	background: var(--mk-accent-soft);
	border: 1px solid transparent;
	font-family: var(--wp--preset--font-family--mono);
	font-size: 0.7rem;
	font-weight: 600;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--mk-accent);
	text-decoration: none;
	transition: border-color 160ms ease, background 160ms ease;
}

.mk-article-cat a:hover {
	border-color: var(--mk-accent);
}

.mk-article-title {
	margin: 0;
	font-size: clamp(2.1rem, 5.5vw, 3.6rem);
	font-weight: 800;
	line-height: 1.05;
	letter-spacing: -0.032em;
	text-wrap: balance;
}

.mk-standfirst {
	max-width: 42rem;
	font-family: var(--wp--preset--font-family--serif);
	font-size: clamp(1.12rem, 2vw, 1.32rem);
	line-height: 1.65;
	color: var(--mk-muted);
	text-wrap: balance;
}

.mk-standfirst p { margin: 0; }
.mk-standfirst .wp-block-post-excerpt__more-text { display: none; }

/* Byline strip: avatar · author · date · reading time, framed by hairlines. */
.mk-article-meta {
	width: 100%;
	justify-content: center;
	gap: 0.55rem 1rem;
	align-items: center;
	font-size: 0.875rem;
	color: var(--mk-muted);
	border-top: 1px solid var(--mk-line);
	border-bottom: 1px solid var(--mk-line);
	padding: 0.9rem 0;
}

.mk-article-meta a {
	color: var(--mk-ink);
	font-weight: 600;
	text-decoration: none;
}

.mk-article-meta a:hover { color: var(--mk-accent); text-decoration: underline; }

.mk-article-meta .wp-block-avatar img {
	border-radius: 999px;
	display: block;
	box-shadow: 0 0 0 2px var(--mk-bg), 0 0 0 3px var(--mk-line);
}

.mk-article-meta .wp-block-post-date,
.mk-reading-time {
	font-family: var(--wp--preset--font-family--mono);
	font-size: 0.73rem;
	letter-spacing: 0.07em;
	text-transform: uppercase;
}

/* Quiet dot separators between the meta facts. */
.mk-article-meta .wp-block-post-date::before,
.mk-article-meta .mk-reading-time::before {
	content: "\00B7";
	content: "\00B7" / "";
	margin-right: 0.85rem;
	color: var(--mk-line);
}

/* "Updated <date>" — only rendered when the story was genuinely revised. */
.mk-article-meta .mk-updated {
	color: var(--mk-accent-2);
}

.mk-updated__label {
	font-weight: 700;
	margin-right: 0.3rem;
}

/* Featured image: quiet gallery framing with a centered caption. */
.mk-article-hero img {
	border-radius: var(--mk-radius-l);
	box-shadow: var(--mk-shadow-up);
}

.mk-article-hero figcaption {
	text-align: center;
	margin-top: 0.75rem;
	font-size: 0.8125rem;
	color: var(--mk-muted);
}

/* ---- The reading column ------------------------------------------------ */
.wp-block-post-content {
	/* Long URLs and compound words never break the mobile column. */
	overflow-wrap: break-word;
}

.wp-block-post-content > * { margin-block: 1.4em; }
.wp-block-post-content > *:first-child { margin-top: 0; }

/* Serif drop cap on the opening paragraph — quiet newspaper craft. */
.mk-single .wp-block-post-content > p:first-child::first-letter {
	float: left;
	font-family: var(--wp--preset--font-family--serif);
	font-size: 3.55em;
	font-weight: 700;
	line-height: 0.82;
	padding: 0.06em 0.14em 0 0;
	color: var(--mk-ink);
}

.wp-block-post-content a {
	text-decoration-thickness: 1.5px;
	text-underline-offset: 0.18em;
}

/* Section headings: sans, with a short gradient rule above h2. */
.wp-block-post-content h2 {
	font-family: var(--wp--preset--font-family--sans);
	font-size: clamp(1.4rem, 2.4vw, 1.6rem);
	margin-top: 2.4em;
}

.wp-block-post-content h2::before {
	content: "";
	display: block;
	width: 2.5rem;
	height: 3px;
	border-radius: 2px;
	margin-bottom: 0.85rem;
	background: linear-gradient(90deg, var(--mk-accent), var(--mk-accent-2));
}

.wp-block-post-content h3 {
	font-family: var(--wp--preset--font-family--sans);
	font-size: 1.22rem;
	margin-top: 2em;
}

.wp-block-post-content h4 {
	font-family: var(--wp--preset--font-family--mono);
	font-size: 0.8rem;
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--mk-muted);
	margin-top: 2em;
}

/* Lists: accent markers, breathing room. */
.wp-block-post-content ul,
.wp-block-post-content ol {
	padding-left: 1.5rem;
}

.wp-block-post-content li {
	margin-block: 0.55em;
	padding-left: 0.35rem;
}

.wp-block-post-content ul li::marker {
	color: var(--mk-accent);
}

.wp-block-post-content ol li::marker {
	font-family: var(--wp--preset--font-family--mono);
	font-size: 0.82em;
	font-weight: 600;
	color: var(--mk-accent);
}

/* Blockquotes: serif voice in full ink, gradient spine. */
.wp-block-post-content blockquote {
	font-family: var(--wp--preset--font-family--serif);
	font-style: italic;
	font-size: 1.08em;
	line-height: 1.7;
	color: var(--mk-ink);
	border-left: 3px solid var(--mk-accent);
	border-image: linear-gradient(180deg, var(--mk-accent), var(--mk-accent-2)) 1;
	padding: 0.35rem 0 0.35rem 1.4rem;
	margin-inline: 0;
}

.wp-block-post-content blockquote cite {
	display: block;
	margin-top: 0.7rem;
	font-family: var(--wp--preset--font-family--mono);
	font-style: normal;
	font-size: 0.72rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--mk-accent-2);
}

.wp-block-post-content .wp-block-pullquote {
	border-top: 1px solid var(--mk-line);
	border-bottom: 1px solid var(--mk-line);
	padding: clamp(1.5rem, 4vw, 2.25rem) 0;
}

.wp-block-post-content .wp-block-pullquote blockquote {
	border: none;
	padding: 0;
}

/* Images & captions inside the article. */
.wp-block-post-content img {
	border-radius: var(--mk-radius-m);
}

.wp-block-post-content figcaption {
	font-family: var(--wp--preset--font-family--sans);
	font-size: 0.8125rem;
	color: var(--mk-muted);
	text-align: center;
	margin-top: 0.7rem;
}

/* Code: calm, mono, framed. */
.wp-block-post-content code {
	font-family: var(--wp--preset--font-family--mono);
	font-size: 0.85em;
	background: var(--mk-surface-2);
	border: 1px solid var(--mk-line-soft);
	border-radius: 6px;
	padding: 0.12em 0.4em;
}

.wp-block-post-content pre {
	background: var(--mk-surface-2);
	border: 1px solid var(--mk-line);
	border-radius: var(--mk-radius-m);
	padding: 1.2rem 1.4rem;
	overflow-x: auto;
	font-size: 0.875rem;
	line-height: 1.6;
}

.wp-block-post-content pre code {
	background: none;
	border: none;
	padding: 0;
}

/* Separator: a short gradient breath, centered. */
.wp-block-post-content hr {
	border: none;
	width: 5rem;
	height: 2px;
	border-radius: 2px;
	margin: 2.6em auto;
	background: linear-gradient(90deg, var(--mk-accent), var(--mk-accent-2));
}

/* Tables: sans, hairline rows. */
.wp-block-post-content table {
	width: 100%;
	border-collapse: collapse;
	font-family: var(--wp--preset--font-family--sans);
	font-size: 0.9375rem;
}

.wp-block-post-content th,
.wp-block-post-content td {
	padding: 0.6rem 0.75rem;
	text-align: left;
	border-bottom: 1px solid var(--mk-line-soft);
}

.wp-block-post-content th {
	font-weight: 700;
	border-bottom: 2px solid var(--mk-line);
}

/* Tag chips */
.mk-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin-top: clamp(1.75rem, 4vw, 2.75rem);
}

.mk-tags a {
	display: inline-block;
	padding: 0.32rem 0.9rem;
	border: 1px solid var(--mk-line);
	border-radius: 999px;
	background: var(--mk-surface);
	font-size: 0.8125rem;
	font-weight: 600;
	color: var(--mk-muted);
	text-decoration: none;
	transition: border-color 160ms ease, color 160ms ease, background 160ms ease;
}

.mk-tags a:hover {
	border-color: var(--mk-accent);
	color: var(--mk-accent);
	background: var(--mk-accent-soft);
}

.mk-tags .wp-block-post-terms__prefix {
	align-self: center;
	font-family: var(--wp--preset--font-family--mono);
	font-size: 0.6875rem;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--mk-muted);
	margin-right: 0.3rem;
}

/* Breadcrumbs */
.mk-breadcrumbs {
	padding-top: 1.4rem;
	font-family: var(--wp--preset--font-family--mono);
	font-size: 0.72rem;
	letter-spacing: 0.05em;
}

.mk-breadcrumbs ol {
	display: flex;
	flex-wrap: wrap;
	gap: 0.25rem 0.55rem;
	list-style: none;
	margin: 0;
	padding: 0;
	color: var(--mk-muted);
}

.mk-breadcrumbs li + li::before {
	content: "/";
	content: "/" / "";
	margin-right: 0.55rem;
	color: var(--mk-line);
}

.mk-breadcrumbs a {
	color: var(--mk-muted);
	text-decoration: none;
}

.mk-breadcrumbs a:hover { color: var(--mk-accent); text-decoration: underline; }

.mk-breadcrumbs [aria-current="page"] span {
	color: var(--mk-ink);
	display: inline-block;
	max-width: 32ch;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	vertical-align: bottom;
}

/* -------------------------------------------------------------------------
   10. Archives, search, pagination, 404
   ------------------------------------------------------------------------- */
.mk-archive-header {
	padding-top: clamp(2.25rem, 5vw, 3.75rem);
	margin-bottom: clamp(1.5rem, 4vw, 2.75rem);
	border-bottom: 1px solid var(--mk-line);
	padding-bottom: clamp(1.25rem, 3vw, 2rem);
}

.mk-archive-title {
	margin: 0 0 0.6rem;
	font-size: clamp(1.9rem, 5vw, 3rem);
	font-weight: 800;
	letter-spacing: -0.03em;
	text-wrap: balance;
}

.mk-archive-title .search-term { color: var(--mk-accent); }

.mk-archive-description {
	max-width: 52rem;
	color: var(--mk-muted);
	font-family: var(--wp--preset--font-family--serif);
	font-size: 1.08rem;
	line-height: 1.65;
}

.mk-pagination {
	margin-top: clamp(2.25rem, 5vw, 3.5rem);
	font-size: 0.9375rem;
	font-weight: 600;
}

.mk-pagination a,
.mk-pagination .page-numbers {
	color: var(--mk-ink);
	text-decoration: none;
	padding: 0.5rem 0.9rem;
	border-radius: 999px;
	border: 1px solid transparent;
	transition: border-color 160ms ease, color 160ms ease, background 160ms ease;
}

.mk-pagination a:hover {
	border-color: var(--mk-accent);
	color: var(--mk-accent);
	background: var(--mk-accent-soft);
}

.mk-pagination .page-numbers.current {
	background: var(--mk-accent);
	color: var(--mk-on-accent);
}

.mk-search-page-form {
	max-width: 40rem;
	margin-bottom: clamp(1.25rem, 3vw, 2rem);
}

.mk-search-page-form .wp-block-search__input {
	background: var(--mk-surface);
	border: 1px solid var(--mk-line);
	border-radius: 999px;
	color: var(--mk-ink);
	padding: 0.8rem 1.3rem;
}

.mk-search-page-form .wp-block-search__button {
	background: var(--mk-accent);
	color: var(--mk-on-accent);
	border: none;
	border-radius: 999px;
	padding: 0.8rem 1.6rem;
	font-weight: 600;
	cursor: pointer;
}

.mk-search-page-form .wp-block-search__button:hover {
	background: var(--mk-ink);
	color: var(--mk-bg);
}

.mk-no-results {
	padding: clamp(1.5rem, 4vw, 2.5rem);
	background: var(--mk-surface);
	border: 1px dashed var(--mk-line);
	border-radius: var(--mk-radius-m);
	color: var(--mk-muted);
	font-family: var(--wp--preset--font-family--serif);
	font-size: 1.05rem;
}

/* 404 */
.mk-404 {
	padding-top: clamp(3rem, 8vw, 5.5rem);
}

.mk-404__code {
	font-family: var(--wp--preset--font-family--mono);
	font-size: clamp(4rem, 14vw, 8rem);
	font-weight: 700;
	line-height: 1;
	letter-spacing: -0.05em;
	margin: 0 0 0.5rem;
	background: linear-gradient(135deg, var(--mk-accent), var(--mk-accent-2));
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
}

/* -------------------------------------------------------------------------
   11. Related posts, post navigation, comments
   ------------------------------------------------------------------------- */
.mk-related {
	margin-top: clamp(3rem, 7vw, 5rem);
	border-top: 1px solid var(--mk-line);
	padding-top: clamp(1.75rem, 4vw, 2.75rem);
}

.mk-related__heading {
	display: flex;
	flex-direction: column;
	gap: 0.4rem;
	font-size: clamp(1.3rem, 2.5vw, 1.6rem);
	font-weight: 800;
	letter-spacing: -0.022em;
	margin: 0 0 1.6rem;
}

.mk-related__grid {
	display: grid;
	gap: 1.25rem;
	grid-template-columns: repeat(auto-fill, minmax(min(16rem, 100%), 1fr));
}

.mk-mini-card {
	display: flex;
	flex-direction: column;
	background: var(--mk-surface);
	border: 1px solid var(--mk-line);
	border-radius: var(--mk-radius-m);
	overflow: hidden;
	box-shadow: var(--mk-shadow);
	transition: transform 220ms ease, border-color 220ms ease, box-shadow 220ms ease;
}

.mk-mini-card:hover,
.mk-mini-card:focus-within {
	transform: translateY(-4px);
	border-color: var(--mk-accent);
	box-shadow: var(--mk-shadow-up);
}

.mk-mini-card__media {
	display: block;
	margin: 0.6rem 0.6rem 0;
	border-radius: calc(var(--mk-radius-m) - 6px);
	overflow: hidden;
	background: var(--mk-surface-2);
}

.mk-mini-card__media img {
	display: block;
	width: 100%;
	aspect-ratio: 3 / 2;
	object-fit: cover;
	transition: transform 500ms cubic-bezier(0.2, 0.6, 0.2, 1);
}

.mk-mini-card:hover .mk-mini-card__media img { transform: scale(1.04); }

.mk-mini-card__body {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	padding: 1rem 1.15rem 1.15rem;
}

.mk-mini-card__title {
	margin: 0;
	font-size: 1.02rem;
	font-weight: 700;
	line-height: 1.32;
	letter-spacing: -0.01em;
}

.mk-mini-card__title a {
	color: var(--mk-ink);
	text-decoration: none;
}

.mk-mini-card__title a:hover {
	color: var(--mk-accent);
	text-decoration: underline;
	text-underline-offset: 0.22em;
}

.mk-mini-card__date {
	font-family: var(--wp--preset--font-family--mono);
	font-size: 0.72rem;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--mk-muted);
}

@media (max-width: 640px) {
	.mk-related__grid { gap: 0.85rem; }

	.mk-mini-card {
		display: grid;
		grid-template-columns: minmax(0, 1fr) 5.5rem;
		align-items: center;
		column-gap: 1rem;
		padding: 0.9rem 1rem;
	}

	.mk-mini-card__media {
		order: 2;
		margin: 0;
		width: 5.5rem;
		border-radius: var(--mk-radius-s);
	}

	.mk-mini-card__media img { aspect-ratio: 1 / 1; height: 100%; }
	.mk-mini-card__body { order: 1; padding: 0; }
}

/* Author box (renders only when the author has a profile bio). */
.mk-author-box {
	display: flex;
	align-items: flex-start;
	gap: 1.25rem;
	margin-top: clamp(2rem, 5vw, 3rem);
	padding: clamp(1.4rem, 3vw, 2rem);
	background: var(--mk-surface);
	border: 1px solid var(--mk-line);
	border-radius: var(--mk-radius-l);
	box-shadow: var(--mk-shadow);
}

.mk-author-box__avatar img {
	display: block;
	border-radius: 999px;
	box-shadow: 0 0 0 2px var(--mk-surface), 0 0 0 3px var(--mk-line);
}

.mk-author-box__label {
	margin: 0 0 0.3rem;
	font-family: var(--wp--preset--font-family--mono);
	font-size: 0.6875rem;
	font-weight: 600;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--mk-muted);
}

.mk-author-box__name {
	margin: 0 0 0.45rem;
	font-size: 1.18rem;
	font-weight: 800;
	letter-spacing: -0.016em;
}

.mk-author-box__name a {
	color: var(--mk-ink);
	text-decoration: none;
}

.mk-author-box__name a:hover {
	color: var(--mk-accent);
	text-decoration: underline;
	text-underline-offset: 0.22em;
}

.mk-author-box__bio {
	margin: 0 0 0.85rem;
	font-family: var(--wp--preset--font-family--serif);
	font-size: 0.98rem;
	line-height: 1.65;
	color: var(--mk-muted);
}

.mk-author-box__more {
	font-family: var(--wp--preset--font-family--mono);
	font-size: 0.72rem;
	font-weight: 600;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--mk-accent);
	text-decoration: none;
}

.mk-author-box__more::after {
	content: "\2192";
	content: "\2192" / "";
	display: inline-block;
	margin-left: 0.4rem;
	transition: transform 220ms ease;
}

.mk-author-box__more:hover { text-decoration: underline; text-underline-offset: 0.3em; }
.mk-author-box__more:hover::after { transform: translateX(4px); }

/* Previous / next: two quiet panels that read as "keep going". */
.mk-postnav {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(min(16rem, 100%), 1fr));
	gap: 1rem;
	margin-top: clamp(2.5rem, 6vw, 4rem);
}

.mk-postnav .wp-block-post-navigation-link {
	background: var(--mk-surface);
	border: 1px solid var(--mk-line);
	border-radius: var(--mk-radius-m);
	padding: 1.15rem 1.3rem;
	font-weight: 700;
	line-height: 1.35;
	letter-spacing: -0.012em;
	box-shadow: var(--mk-shadow);
	transition: transform 220ms ease, border-color 220ms ease, box-shadow 220ms ease;
}

.mk-postnav .wp-block-post-navigation-link:hover,
.mk-postnav .wp-block-post-navigation-link:focus-within {
	transform: translateY(-3px);
	border-color: var(--mk-accent);
	box-shadow: var(--mk-shadow-up);
}

.mk-postnav .post-navigation-link-next { text-align: right; }

.mk-postnav .post-navigation-link__label {
	display: block;
	font-family: var(--wp--preset--font-family--mono);
	font-size: 0.6875rem;
	font-weight: 600;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--mk-muted);
	margin-bottom: 0.35rem;
}

.mk-postnav a {
	color: var(--mk-ink);
	text-decoration: none;
}

.mk-postnav a:hover { color: var(--mk-accent); text-decoration: underline; }

/* Comments */
.mk-comments {
	margin-top: clamp(3rem, 7vw, 5rem);
	border-top: 1px solid var(--mk-line);
	padding-top: clamp(1.75rem, 4vw, 2.75rem);
}

.mk-comment {
	padding: 1.2rem 0;
	border-bottom: 1px solid var(--mk-line-soft);
	gap: 1rem;
}

.mk-comment .wp-block-avatar img { border-radius: 999px; }

.mk-comment__meta {
	gap: 0.35rem 0.75rem;
	font-size: 0.8125rem;
	color: var(--mk-muted);
}

.mk-comment__meta .wp-block-comment-author-name {
	font-weight: 700;
	color: var(--mk-ink);
}

.mk-comment__meta .wp-block-comment-date {
	font-family: var(--wp--preset--font-family--mono);
	font-size: 0.72rem;
	letter-spacing: 0.05em;
}

.mk-comment .wp-block-comment-content { font-size: 0.9688rem; }
.mk-comment .wp-block-comment-content p { margin: 0.4rem 0; }

.mk-comment .wp-block-comment-reply-link a,
.mk-comment .wp-block-comment-edit-link a {
	font-size: 0.8125rem;
	font-weight: 600;
}

.wp-block-post-comments-form input[type="text"],
.wp-block-post-comments-form input[type="email"],
.wp-block-post-comments-form input[type="url"],
.wp-block-post-comments-form textarea {
	background: var(--mk-surface);
	border: 1px solid var(--mk-line);
	border-radius: var(--mk-radius-s);
	color: var(--mk-ink);
	padding: 0.7rem 0.95rem;
	width: 100%;
}

.wp-block-post-comments-form input[type="submit"] {
	background: var(--mk-accent);
	color: var(--mk-on-accent);
	border: none;
	border-radius: 999px;
	padding: 0.7rem 1.6rem;
	font-weight: 600;
	cursor: pointer;
}

.wp-block-post-comments-form input[type="submit"]:hover {
	background: var(--mk-ink);
	color: var(--mk-bg);
}

/* -------------------------------------------------------------------------
   12. Footer, newsletter, dossiers, callouts, pull-quote
   ------------------------------------------------------------------------- */
.mk-footer {
	margin-top: clamp(3.5rem, 8vw, 6rem);
	position: relative;
	background: var(--mk-surface);
	border-top: 1px solid var(--mk-line);
	padding-top: clamp(2.5rem, 6vw, 4rem);
	padding-bottom: clamp(1.75rem, 4vw, 2.5rem);
}

/* Mirror of the masthead signal line. */
.mk-footer::before {
	content: "";
	position: absolute;
	top: -1px;
	left: 0;
	width: min(34rem, 60%);
	height: 2px;
	background: linear-gradient(90deg, var(--mk-accent), var(--mk-accent-2), transparent);
}

.mk-footer__grid {
	display: grid;
	gap: 2.75rem;
	grid-template-columns: repeat(auto-fit, minmax(min(15rem, 100%), 1fr));
}

.mk-footer__heading {
	font-family: var(--wp--preset--font-family--mono);
	font-size: 0.6875rem;
	font-weight: 600;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--mk-muted);
	margin: 0 0 1rem;
}

.mk-footer p {
	color: var(--mk-muted);
	font-size: 0.9375rem;
	line-height: 1.65;
}

.mk-footer ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 0.55rem;
}

.mk-footer a {
	color: var(--mk-ink);
	font-size: 0.9375rem;
	text-decoration: none;
}

.mk-footer a:hover {
	color: var(--mk-accent);
	text-decoration: underline;
	text-underline-offset: 0.3em;
}

.mk-footer__bottom {
	margin-top: clamp(2.25rem, 5vw, 3.5rem);
	border-top: 1px solid var(--mk-line-soft);
	padding-top: 1.4rem;
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem 2rem;
	justify-content: space-between;
	font-family: var(--wp--preset--font-family--mono);
	font-size: 0.72rem;
	letter-spacing: 0.05em;
	color: var(--mk-muted);
}

/* Newsletter — gradient-framed panel with a soft glow. */
.mk-newsletter {
	position: relative;
	margin-top: clamp(3rem, 7vw, 5rem);
	padding: clamp(1.9rem, 4.5vw, 3.25rem);
	border-radius: var(--mk-radius-l);
	border: 1px solid transparent;
	background:
		linear-gradient(var(--mk-surface), var(--mk-surface)) padding-box,
		linear-gradient(135deg, var(--mk-accent), var(--mk-accent-2)) border-box;
	overflow: hidden;
	box-shadow: var(--mk-shadow);
}

.mk-newsletter::before {
	content: "";
	position: absolute;
	inset: 0;
	background: radial-gradient(120% 170% at 0% 0%, var(--mk-accent-soft), transparent 55%);
	pointer-events: none;
}

.mk-newsletter::after {
	content: "";
	position: absolute;
	inset: auto -18% -65% auto;
	width: 52%;
	aspect-ratio: 1;
	border-radius: 50%;
	background: radial-gradient(circle, var(--mk-accent-soft), transparent 70%);
	pointer-events: none;
}

.mk-newsletter > * { position: relative; }

.mk-newsletter__title {
	margin: 0 0 0.6rem;
	font-size: clamp(1.6rem, 3.4vw, 2.3rem);
	font-weight: 800;
	letter-spacing: -0.026em;
}

.mk-newsletter__text {
	max-width: 42rem;
	font-family: var(--wp--preset--font-family--serif);
	font-size: 1.08rem;
	line-height: 1.65;
	color: var(--mk-muted);
	margin: 0 0 1.4rem;
}

.mk-newsletter__note {
	font-size: 0.8125rem;
	color: var(--mk-muted);
	margin: 0.85rem 0 0;
}

/* Dossiers */
.mk-dossiers {
	display: grid;
	gap: 1.25rem;
	grid-template-columns: repeat(auto-fill, minmax(min(15rem, 100%), 1fr));
}

.mk-dossier {
	position: relative;
	display: flex;
	flex-direction: column;
	gap: 0.65rem;
	padding: 1.5rem 1.6rem;
	background: var(--mk-surface);
	border: 1px solid var(--mk-line);
	border-radius: var(--mk-radius-m);
	text-decoration: none;
	overflow: hidden;
	transition: transform 220ms ease, border-color 220ms ease, box-shadow 220ms ease;
}

.mk-dossier::before {
	content: "";
	position: absolute;
	inset: 0 auto 0 0;
	width: 3px;
	background: linear-gradient(180deg, var(--mk-accent), var(--mk-accent-2));
	opacity: 0;
	transition: opacity 220ms ease;
}

.mk-dossier:hover,
.mk-dossier:focus-visible {
	transform: translateY(-4px);
	border-color: var(--mk-accent);
	box-shadow: var(--mk-shadow-up);
}

.mk-dossier:hover::before,
.mk-dossier:focus-visible::before { opacity: 1; }

.mk-dossier__name {
	font-size: 1.18rem;
	font-weight: 800;
	letter-spacing: -0.018em;
	color: var(--mk-ink);
	margin: 0;
}

.mk-dossier__desc {
	font-size: 0.9rem;
	line-height: 1.55;
	color: var(--mk-muted);
	margin: 0;
}

.mk-dossier__count {
	margin-top: auto;
	padding-top: 0.5rem;
	font-family: var(--wp--preset--font-family--mono);
	font-size: 0.72rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--mk-accent);
}

.mk-dossier__count::after {
	content: "\2192";
	content: "\2192" / "";
	margin-left: 0.4rem;
	display: inline-block;
	transition: transform 220ms ease;
}

.mk-dossier:hover .mk-dossier__count::after { transform: translateX(4px); }

@media (max-width: 640px) {
	.mk-dossiers {
		grid-template-columns: repeat(auto-fill, minmax(min(10rem, 100%), 1fr));
		gap: 0.85rem;
	}

	.mk-dossier { padding: 1.15rem 1.2rem; }
	.mk-dossier__desc { display: none; }
}

/* Editorial callout */
.mk-callout {
	position: relative;
	border: 1px solid var(--mk-line);
	border-left: 3px solid var(--mk-accent);
	background:
		radial-gradient(140% 180% at 0% 0%, var(--mk-accent-soft), transparent 60%),
		var(--mk-surface);
	border-radius: 0 var(--mk-radius-m) var(--mk-radius-m) 0;
	padding: clamp(1.4rem, 3vw, 2.25rem);
}

.mk-callout h2,
.mk-callout h3 { margin-top: 0; }

.mk-callout .mk-kicker { margin: 0 0 0.35rem; }

/* Analysis variant: teal spine, interpretive voice. */
.mk-callout--analysis {
	border-left-color: var(--mk-accent-2);
}

.mk-callout--analysis ul {
	padding-left: 1.4rem;
	margin: 0.75rem 0 0;
}

.mk-callout--analysis li {
	margin-block: 0.45em;
}

.mk-callout--analysis li::marker {
	color: var(--mk-accent-2);
}

/* Breaking news intro — used at the top of a developing story. */
.mk-breaking {
	display: flex;
	flex-direction: column;
	gap: 0.6rem;
	border: 1px solid var(--mk-line);
	border-left: 3px solid var(--mk-alert);
	border-radius: 0 var(--mk-radius-m) var(--mk-radius-m) 0;
	background:
		radial-gradient(140% 200% at 0% 0%, var(--mk-alert-soft), transparent 55%),
		var(--mk-surface);
	padding: clamp(1.25rem, 3vw, 1.9rem);
}

.mk-breaking__label {
	display: flex;
	align-items: center;
	gap: 0.55rem;
	margin: 0;
	font-family: var(--wp--preset--font-family--mono);
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--mk-alert);
}

.mk-breaking__label::before {
	content: "";
	width: 9px;
	height: 9px;
	border-radius: 50%;
	background: var(--mk-alert);
	flex-shrink: 0;
	--mk-pulse: var(--mk-alert-glow);
	animation: mk-pulse 2.2s ease-out infinite;
}

.mk-breaking__lede {
	margin: 0;
	font-family: var(--wp--preset--font-family--serif);
	font-size: 1.12em;
	line-height: 1.62;
	color: var(--mk-ink);
}

.mk-breaking__updated {
	margin: 0;
	font-family: var(--wp--preset--font-family--mono);
	font-size: 0.7rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--mk-muted);
}

/* Featured article banner — editor's pick, manual placement. */
.mk-feature-banner {
	position: relative;
	padding: clamp(1.75rem, 4vw, 2.75rem);
	border-radius: var(--mk-radius-l);
	border: 1px solid transparent;
	background:
		linear-gradient(var(--mk-surface), var(--mk-surface)) padding-box,
		linear-gradient(135deg, var(--mk-accent), var(--mk-accent-2)) border-box;
	box-shadow: var(--mk-shadow);
	overflow: hidden;
}

.mk-feature-banner::before {
	content: "";
	position: absolute;
	inset: 0;
	background: radial-gradient(130% 170% at 100% 0%, var(--mk-accent-soft), transparent 55%);
	pointer-events: none;
}

.mk-feature-banner > * { position: relative; }

.mk-feature-banner .mk-kicker { margin: 0 0 0.5rem; }

.mk-feature-banner__title {
	margin: 0 0 0.5rem;
	font-size: clamp(1.45rem, 3vw, 2rem);
	font-weight: 800;
	letter-spacing: -0.025em;
	text-wrap: balance;
}

.mk-feature-banner__text {
	max-width: 40rem;
	margin: 0 0 1.2rem;
	font-family: var(--wp--preset--font-family--serif);
	font-size: 1.02rem;
	line-height: 1.65;
	color: var(--mk-muted);
}

/* Dossier block (manual, editable). */
.mk-dossier-feature {
	position: relative;
	padding: clamp(1.6rem, 3.5vw, 2.5rem);
	background: var(--mk-surface-2);
	border: 1px solid var(--mk-line);
	border-radius: var(--mk-radius-m);
	overflow: hidden;
}

.mk-dossier-feature::before {
	content: "";
	position: absolute;
	inset: 0 auto 0 0;
	width: 3px;
	background: linear-gradient(180deg, var(--mk-accent), var(--mk-accent-2));
}

.mk-dossier-feature .mk-kicker { margin: 0 0 0.5rem; }

.mk-dossier-feature__title {
	margin: 0 0 0.5rem;
	font-size: clamp(1.35rem, 2.6vw, 1.8rem);
	font-weight: 800;
	letter-spacing: -0.022em;
}

.mk-dossier-feature__text {
	max-width: 42rem;
	margin: 0 0 1.2rem;
	font-size: 0.98rem;
	line-height: 1.65;
	color: var(--mk-muted);
}

/* Analysis pull-quote */
.mk-pullquote {
	position: relative;
	border-top: 1px solid var(--mk-line);
	border-bottom: 1px solid var(--mk-line);
	padding: clamp(1.75rem, 4.5vw, 3rem) 0 clamp(1.5rem, 4vw, 2.5rem);
	margin: 0;
}

.mk-pullquote::before {
	content: "\201C";
	content: "\201C" / "";
	position: absolute;
	top: 0.1em;
	left: -0.05em;
	font-family: var(--wp--preset--font-family--serif);
	font-size: clamp(5rem, 12vw, 8rem);
	line-height: 1;
	color: var(--mk-accent-soft);
	pointer-events: none;
}

.mk-pullquote blockquote {
	position: relative;
	margin: 0;
	border: none;
	padding: 0;
}

.mk-pullquote p {
	font-family: var(--wp--preset--font-family--serif);
	font-size: clamp(1.35rem, 3vw, 1.9rem);
	font-style: italic;
	line-height: 1.42;
	letter-spacing: -0.012em;
	color: var(--mk-ink);
	margin: 0 0 0.85rem;
}

.mk-pullquote cite {
	font-family: var(--wp--preset--font-family--mono);
	font-style: normal;
	font-size: 0.72rem;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--mk-accent-2);
}

/* -------------------------------------------------------------------------
   13. Motion & reduced motion
   ------------------------------------------------------------------------- */
@media (max-width: 781px) {
	.mk-header__inner { flex-wrap: nowrap; }
}

@media (max-width: 480px) {
	/* Keep brand + burger + search + toggle on one calm row on small phones. */
	.mk-header__inner {
		padding-inline: 0.85rem;
		gap: 0.5rem;
	}

	.mk-header__tools { gap: 0.4rem; }

	.mk-brand__name { font-size: 1rem; }
}

@media (max-width: 600px) {
	.mk-brand__tagline { display: none; }

	.mk-frontbar__mission { font-size: 0.9rem; }

	.mk-hero-card__body {
		margin-top: -2.25rem;
		padding: 1.25rem 1.3rem 1.4rem;
	}

	.mk-home .mk-lane { padding: 1.25rem 1.1rem; }

	/* Article reading comfort on phones. */
	.mk-single .wp-block-post-content {
		font-size: 1.0938rem;
		line-height: 1.75;
	}

	.mk-single .wp-block-post-content > p:first-child::first-letter {
		font-size: 3em;
	}

	.mk-article-header { gap: 0.9rem; }

	.mk-article-meta {
		gap: 0.5rem 0.8rem;
		font-size: 0.8125rem;
	}

	.mk-article-hero img { border-radius: var(--mk-radius-m); }

	.mk-author-box {
		gap: 1rem;
		padding: 1.2rem 1.15rem;
	}

	.mk-author-box__avatar img {
		width: 48px;
		height: 48px;
	}

	.wp-block-post-content pre { padding: 1rem 1.1rem; }
}

@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
		scroll-behavior: auto !important;
	}

	.mk-eyebrow__dot,
	.mk-breaking__label::before { animation: none; }

	.mk-card:hover,
	.mk-mini-card:hover,
	.mk-dossier:hover,
	.mk-theme-toggle:active {
		transform: none;
	}

	.mk-card:hover .mk-card__media img,
	.mk-mini-card:hover .mk-mini-card__media img {
		transform: none;
	}
}

/* -------------------------------------------------------------------------
   14. Print — articles print as clean, credible documents
   ------------------------------------------------------------------------- */
@media print {
	.mk-header,
	.mk-footer,
	.mk-breadcrumbs,
	.mk-postnav,
	.mk-related,
	.mk-comments,
	.mk-newsletter,
	.mk-theme-toggle,
	.mk-author-box__more,
	.skip-link {
		display: none !important;
	}

	body {
		background: #fff !important;
		color: #000 !important;
		background-image: none !important;
	}

	.mk-article-header {
		text-align: left;
		align-items: flex-start;
	}

	.mk-article-title { font-size: 24pt; }

	.wp-block-post-content {
		font-size: 11.5pt;
		line-height: 1.6;
	}

	/* Cited sources stay verifiable on paper. */
	.wp-block-post-content a[href^="http"]::after {
		content: " (" attr(href) ")";
		font-size: 88%;
		color: #444;
		word-break: break-all;
	}

	.mk-article-hero img,
	.mk-card,
	.mk-hero-card__body {
		box-shadow: none !important;
	}

	.mk-article-hero img { filter: none; }
}
