/*
Theme Name: macinteract GeneratePress Child
Theme URI: https://macinteract.com
Description: Child theme for GeneratePress - macinteract.com redesign. See project BRANDING.md for tokens.
Author: macinteract
Template: generatepress
Version: 1.0.49
Text Domain: macinteract-gp-child
*/

/* =========================================================================
   1. Design tokens - 8px base unit (all spacing & grid align to multiples of 8px)
   ========================================================================= */
:root {
	--mi-u: 8px;

	/* Colour */
	--mi-black: #000000;
	--mi-white: #ffffff;
	--mi-accent: #00d100;
	--mi-text: #1a1a1a;
	--mi-text-muted: #4a4a4a;

	/* Typography - aligned with VKTRS (Inter + IBM Plex Sans) */
	--mi-font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
	--mi-font-heading: "IBM Plex Sans", "Inter", -apple-system, BlinkMacSystemFont, sans-serif;
	--mi-font-mono: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace;

	--mi-text-xs: 0.8125rem;
	--mi-text-sm: 0.9375rem;
	--mi-text-base: 1.0625rem;
	--mi-text-lg: 1.25rem;
	--mi-text-xl: 1.5rem;
	--mi-text-2xl: 1.875rem;
	--mi-text-3xl: 2.25rem;
	--mi-text-4xl: clamp(2rem, 4vw, 2.75rem);
	--mi-text-display: clamp(1.75rem, 3.15vw, 2.375rem);
	--mi-text-lead: 1.125rem;

	/*
	 * Vertical rhythm (8px base = --mi-u)
	 * - Line boxes use fixed px heights that are integer multiples of 8px so stacked lines don’t
	 *   drift off the background grid as paragraphs grow. Resizing/clamp on font-size is fine:
	 *   line-height stays on-grid; glyphs stay readable (always ≥ font-size on headings).
	 * - Dot pitch is --mi-grid-step (24px) = 3 rhythm rows; padding/margins use --mi-space-*.
	 */
	--mi-lh-2: calc(var(--mi-u) * 2);
	--mi-lh-3: calc(var(--mi-u) * 3);
	--mi-lh-4: calc(var(--mi-u) * 4);
	--mi-lh-5: calc(var(--mi-u) * 5);
	--mi-lh-6: calc(var(--mi-u) * 6);
	--mi-leading-tight: var(--mi-lh-3);
	--mi-leading-snug: var(--mi-lh-4);
	--mi-leading-normal: var(--mi-lh-4);
	--mi-leading-relaxed: var(--mi-lh-5);
	/* Space between prose blocks = one rhythm unit (stacks with line boxes) */
	--mi-prose-p-gap: calc(var(--mi-u) * 4);

	--mi-tracking-tight: -0.02em;

	/* Space scale (multiples of --mi-u) */
	--mi-space-1: calc(var(--mi-u) * 1);
	--mi-space-2: calc(var(--mi-u) * 2);
	--mi-space-3: calc(var(--mi-u) * 3);
	--mi-space-4: calc(var(--mi-u) * 4);
	--mi-space-5: calc(var(--mi-u) * 5);
	--mi-space-6: calc(var(--mi-u) * 6);
	--mi-space-8: calc(var(--mi-u) * 8);
	--mi-space-10: calc(var(--mi-u) * 10);
	--mi-space-12: calc(var(--mi-u) * 12);
	--mi-space-16: calc(var(--mi-u) * 16);
	--mi-space-24: calc(var(--mi-u) * 24);

	/* Shared “box” chrome (nav pills, footer; panels use --mi-panel-* ) */
	--mi-box-border: 1px solid rgba(0, 0, 0, 0.08);
	--mi-box-shadow: 0 var(--mi-space-1) var(--mi-space-2) rgba(0, 0, 0, 0.05);
	--mi-box-shadow-accent: 0 var(--mi-space-1) var(--mi-space-2) rgba(0, 209, 0, 0.12);
	--mi-border-accent: rgba(0, 209, 0, 0.35);
	--mi-border-accent-strong: rgba(0, 209, 0, 0.45);

	--mi-menu-box-height: 36px;
	--mi-menu-font-size: var(--mi-text-sm);
	/* GP default logo cap is often ~60px; 96px = 12×8px scale */
	--mi-header-logo-max-height: 96px;

	/* Layout */
	--mi-content-max: 72rem;
	--mi-narrow-max: 40rem;
	/* Dot field: 24px pitch; layout snap uses same step (see --mi-gutter). */
	--mi-bg: #f4f6f8;
	--mi-grid-step: calc(var(--mi-u) * 3);
	--mi-dot-radius: 1px;
	--mi-snap-origin: 0px;
	/* Fallback for engines without round(); second line overrides when supported. */
	--mi-gutter: clamp(
		calc(var(--mi-grid-step) * 1),
		4vw,
		calc(var(--mi-grid-step) * 3)
	);
	--mi-gutter: clamp(
		calc(var(--mi-grid-step) * 1),
		calc(
			var(--mi-snap-origin) +
				round(
					nearest,
					max(0px, calc(4vw - var(--mi-snap-origin))),
					var(--mi-grid-step)
				)
		),
		calc(var(--mi-grid-step) * 3)
	);

	--mi-radius: calc(var(--mi-u) * 2);
	/*
	 * Dots are centered in each 24×24 tile (radial-gradient at center), so dot columns sit at
	 * half-step offsets. mi-grid-sync phases tile (0 mod step) to the panel border box.
	 * Inset = border + padding is chosen so (border + padding) ≡ step/2 (mod step), aligning
	 * the content box edge with dot centers, not tile edges.
	 */
	--mi-grid-dot-half: calc(var(--mi-grid-step) / 2);
	--mi-panel-border-w: 1px;
	--mi-panel-border: var(--mi-panel-border-w) solid rgba(0, 0, 0, 0.06);
	--mi-panel-pad-x: calc(
		var(--mi-grid-step) * 2 - var(--mi-panel-border-w) - var(--mi-grid-dot-half)
	);
	--mi-panel-pad-y: calc(
		var(--mi-grid-step) * 2 - var(--mi-panel-border-w) - var(--mi-grid-dot-half)
	);
	--mi-panel-pad: var(--mi-panel-pad-y) var(--mi-panel-pad-x);
	--mi-panel-pad-card-x: calc(
		var(--mi-grid-step) * 2 - var(--mi-panel-border-w) - var(--mi-grid-dot-half)
	);
	/* Bio cards: extra top inset (2× dot step) so avatar clears the panel edge; bottom stays 1× step */
	--mi-panel-pad-card-y-top: calc(
		var(--mi-grid-step) * 2 - var(--mi-panel-border-w) - var(--mi-grid-dot-half)
	);
	--mi-panel-pad-card-y-bottom: calc(
		var(--mi-grid-step) * 1 - var(--mi-panel-border-w) - var(--mi-grid-dot-half)
	);
	--mi-panel-shadow: 0 calc(var(--mi-u) * 1) calc(var(--mi-u) * 3) rgba(0, 0, 0, 0.06);

	--mi-bg-shift-x: 0px;
	--mi-bg-shift-y: 0px;
}

/* =========================================================================
   2. Base + full-page dot field
   ========================================================================= */
html {
	min-height: 100%;
	background-color: var(--mi-bg);
	background-image: radial-gradient(
		circle at center,
		var(--mi-accent) var(--mi-dot-radius),
		transparent calc(var(--mi-dot-radius) + 0.5px)
	);
	background-size: var(--mi-grid-step) var(--mi-grid-step);
	background-position: var(--mi-bg-shift-x) var(--mi-bg-shift-y);
	background-repeat: repeat;
}

body {
	color: var(--mi-text);
	font-family: var(--mi-font-sans);
	font-size: var(--mi-text-base);
	line-height: var(--mi-leading-normal);
	background: transparent;
}

:is(body.home, body.page-id-21451) {
	overflow-x: hidden;
}

/* Dot field shows through: strip theme-painted backgrounds from chrome + main */
.site-header,
.inside-header,
.site-info,
.site-footer,
.footer-widgets,
.footer-widgets-container,
.inside-footer-widgets,
.footer-bar,
.inside-site-info,
.site,
.site-main,
#content,
.site-content,
.content-area,
.inside-article,
.site-header .main-navigation,
.site-header .inside-navigation,
.site-header #site-navigation,
.site-header .nav-float-right,
.site-header .main-navigation .main-nav,
.site-header .main-navigation .main-nav > ul {
	background-color: transparent !important;
	background-image: none !important;
	box-shadow: none !important;
}

/* Outer gutter + inner column (matches .mi-hero-shell) */
.site-header {
	padding-inline: var(--mi-gutter);
	padding-block: var(--mi-space-4);
	box-sizing: border-box;
}

.site-footer {
	padding-inline: var(--mi-gutter);
	box-sizing: border-box;
}

.site-header .inside-header {
	max-width: var(--mi-content-max);
	margin-inline: auto !important;
	padding-inline: 0 !important;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: flex-start;
	column-gap: var(--mi-grid-step);
	row-gap: var(--mi-space-3);
}

.site-header .site-branding,
.site-header .site-logo {
	flex: 0 0 auto;
	display: flex;
	align-items: center;
}

.site-header .site-branding img,
.site-header .site-logo img,
.site-header img.custom-logo,
.site-header a.custom-logo-link img {
	max-height: var(--mi-header-logo-max-height) !important;
	width: auto;
	height: auto;
	max-width: min(100%, 320px);
}

.site-header a.custom-logo-link {
	display: inline-flex;
	align-items: center;
	line-height: 0;
}

.site-header .main-navigation {
	margin-left: auto;
	flex: 0 0 auto;
}

/* Menu pill chrome */
.mi-box,
.mi-footer-min__copy,
.mi-footer-min__nav a,
.main-navigation .main-nav ul li a {
	box-sizing: border-box;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-family: var(--mi-font-sans);
	font-weight: 500;
	font-size: var(--mi-menu-font-size);
	letter-spacing: 0.02em;
	color: var(--mi-text);
	min-height: var(--mi-menu-box-height);
	height: var(--mi-menu-box-height);
	padding: 0 var(--mi-space-4);
	line-height: var(--mi-leading-tight);
	border-radius: var(--mi-radius);
	background-color: var(--mi-white);
	border: var(--mi-box-border);
	box-shadow: var(--mi-box-shadow);
	text-decoration: none;
	text-transform: none;
	transition:
		background-color 0.18s ease,
		color 0.18s ease,
		border-color 0.18s ease,
		box-shadow 0.18s ease,
		transform 0.18s ease;
}

/* Header + footer menu links: pure black in every interactive state (font from block above) */
.mi-footer-min__nav a,
.main-navigation .main-nav ul li a {
	color: var(--mi-black);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

.mi-footer-min__nav a:link,
.mi-footer-min__nav a:visited,
.mi-footer-min__nav a:active,
.main-navigation .main-nav ul li a:link,
.main-navigation .main-nav ul li a:visited,
.main-navigation .main-nav ul li a:active {
	color: var(--mi-black);
}

.mi-footer-min__copy {
	margin: 0;
	flex: 0 1 auto;
	min-width: 0;
}

.footer-bar .copyright-bar {
	display: inline-flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--mi-space-2);
	max-width: 100%;
	font-family: var(--mi-font-sans);
	font-weight: 500;
	font-size: var(--mi-text-sm);
	letter-spacing: 0.02em;
	color: var(--mi-text);
	padding: var(--mi-space-2) var(--mi-space-4);
	border-radius: var(--mi-radius);
	background-color: var(--mi-white);
	border: var(--mi-box-border);
	box-shadow: var(--mi-box-shadow);
	text-decoration: none;
	text-transform: none;
}

.footer-bar .copyright-bar a {
	text-decoration: none;
	font-weight: 500;
	padding: 0;
	border: none;
	box-shadow: none;
	background: transparent;
	border-radius: 0;
}

.footer-bar .copyright-bar a:hover {
	color: var(--mi-text);
	text-decoration: underline;
	text-underline-offset: 0.15em;
}

.footer-bar .copyright-bar:hover {
	background-color: var(--mi-white);
	border-color: var(--mi-border-accent);
	box-shadow: var(--mi-box-shadow-accent);
}

/* Nav pills: stay white / black text; hover = solid black shadow offset bottom-right (45°, equal x/y) */
.mi-footer-min__nav a:hover,
.main-navigation .main-nav ul li a:hover {
	background-color: var(--mi-white);
	color: var(--mi-black);
	border-color: rgba(0, 0, 0, 0.1);
	box-shadow: calc(var(--mi-space-1) / 2) calc(var(--mi-space-1) / 2) 0 0 var(--mi-black);
	transform: none;
}

.main-navigation .main-nav ul li.current-menu-item > a,
.mi-footer-min__nav li.current-menu-item > a {
	border-color: rgba(0, 0, 0, 0.22);
	color: var(--mi-black);
}

.main-navigation .main-nav ul li.current-menu-item > a:hover,
.mi-footer-min__nav li.current-menu-item > a:hover {
	border-color: rgba(0, 0, 0, 0.1);
	color: var(--mi-black);
}

.main-navigation .main-nav ul li a:focus-visible,
.mi-footer-min__nav a:focus-visible {
	outline: 2px solid var(--mi-black);
	outline-offset: 2px;
}

.main-navigation .main-nav > ul {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--mi-grid-step);
	list-style: none;
}

.main-navigation .main-nav ul ul li a {
	margin-block: var(--mi-space-1);
}

@media (min-width: 769px) {
	.menu-toggle,
	button.menu-toggle {
		display: none !important;
	}
}

@media (max-width: 768px) {
	.menu-toggle,
	button.menu-toggle {
		box-sizing: border-box !important;
		display: inline-flex !important;
		align-items: center !important;
		justify-content: center !important;
		background-color: var(--mi-white) !important;
		border: var(--mi-box-border) !important;
		border-radius: var(--mi-radius) !important;
		box-shadow: var(--mi-box-shadow) !important;
		height: var(--mi-menu-box-height) !important;
		min-height: var(--mi-menu-box-height) !important;
		padding: 0 var(--mi-space-4) !important;
		line-height: var(--mi-leading-tight) !important;
		font-family: var(--mi-font-sans) !important;
		font-weight: 500 !important;
		font-size: var(--mi-menu-font-size) !important;
		letter-spacing: 0.02em !important;
		color: var(--mi-black) !important;
		-webkit-font-smoothing: antialiased;
		-moz-osx-font-smoothing: grayscale;
	}
}

/* =========================================================================
   3. Layout primitives, hero, team
   ========================================================================= */
.mi-section {
	padding-block: var(--mi-space-12);
	padding-inline: var(--mi-gutter);
}

.mi-section--tight {
	padding-block: var(--mi-space-8);
}

.mi-section--hero {
	padding-block: var(--mi-space-16);
}

.mi-container {
	width: 100%;
	max-width: var(--mi-content-max);
	margin-inline: auto;
	padding-inline: 0;
}

.mi-container--narrow {
	max-width: var(--mi-narrow-max);
}

.mi-stack {
	display: flex;
	flex-direction: column;
	gap: var(--mi-space-4);
}

.mi-stack--lg {
	gap: var(--mi-space-6);
}

.mi-hero-shell {
	width: 100vw;
	max-width: 100vw;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	position: relative;
	box-sizing: border-box;
	padding-block: calc(var(--mi-grid-step) * 3);
	padding-inline: var(--mi-gutter);
	background: transparent;
}

.mi-hero-shell__inner {
	max-width: var(--mi-content-max);
	margin-inline: auto;
}

.mi-panel {
	background: var(--mi-white);
	border: var(--mi-panel-border);
	border-radius: var(--mi-radius);
	box-shadow: var(--mi-panel-shadow);
	padding: var(--mi-panel-pad);
	box-sizing: border-box;
	max-width: 100%;
}

.mi-panel + .mi-panel {
	margin-top: calc(var(--mi-grid-step) * 2);
}

.mi-stack .mi-panel + .mi-panel {
	margin-top: 0;
}

/* Grid gap handles spacing; avoid stacking margin on 2nd+ cards (first follows .mi-team--surface, not .mi-panel). */
.mi-team__grid .mi-panel + .mi-panel {
	margin-top: 0;
}

.mi-hero-shell .mi-stack--lg {
	gap: calc(var(--mi-grid-step) * 2);
}

/* Top hero: narrower than full content column, glass + sharper type (padding via --mi-panel-pad) */
.mi-hero-shell .mi-stack--lg > .mi-panel:first-child {
	max-width: min(48rem, 100%);
	margin-inline: 0;
	background: rgba(255, 255, 255, 0.88);
	background: color-mix(in srgb, var(--mi-white) 82%, transparent);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	color: var(--mi-black);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	text-rendering: optimizeLegibility;
}

.mi-hero-shell .mi-stack--lg > .mi-panel:first-child .mi-prose--wide {
	max-width: min(36rem, 100%);
}

.mi-hero-shell .mi-stack--lg > .mi-panel:first-child .mi-overline {
	color: #3a3d42;
	letter-spacing: 0.1em;
}

.mi-hero-shell .mi-stack--lg > .mi-panel:first-child .mi-lead {
	color: var(--mi-black);
	font-weight: 500;
	line-height: var(--mi-leading-snug);
}

.mi-hero-shell .mi-stack--lg > .mi-panel:first-child .mi-prose {
	color: var(--mi-black);
}

.mi-hero-shell .mi-stack--lg > .mi-panel:first-child .mi-prose a {
	color: var(--mi-black);
	font-weight: 600;
}

.mi-hero-shell .mi-stack--lg > .mi-panel:first-child .mi-heading--display {
	margin-bottom: var(--mi-space-4);
}

.mi-team {
	--mi-team-gap: calc(var(--mi-grid-step) * 2);
	margin-top: calc(var(--mi-grid-step) * 2);
	width: 100%;
	box-sizing: border-box;
}

/* Title + intro only; semi-transparent so page dot grid reads through */
.mi-team--surface {
	background: rgba(255, 255, 255, 0.88);
	background: color-mix(in srgb, var(--mi-white) 82%, transparent);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	border: var(--mi-panel-border);
	border-radius: var(--mi-radius);
	box-shadow: var(--mi-panel-shadow);
	padding: var(--mi-panel-pad);
}

.mi-team__intro {
	font-size: var(--mi-text-base);
	line-height: var(--mi-leading-relaxed);
	color: var(--mi-text);
	margin: 0 0 var(--mi-space-8);
	max-width: 100%;
}

.mi-team--surface .mi-team__intro {
	margin-bottom: 0;
}

.mi-team__grid {
	display: grid;
	gap: var(--mi-team-gap);
	grid-template-columns: 1fr;
	align-items: start;
	justify-items: stretch;
	margin-top: calc(var(--mi-grid-step) * 2);
}

.mi-team__grid > * {
	min-width: 0;
}

@media (min-width: 600px) {
	.mi-team__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (min-width: 960px) {
	.mi-team__grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

/* Column widths snap to dot pitch (24px); surface max-width matches grid track span */
@supports (width: round(down, 12px, 4px)) {
	@media (min-width: 600px) and (max-width: 959px) {
		.mi-team {
			--mi-team-col: round(
				down,
				calc((100% - var(--mi-team-gap)) / 2),
				var(--mi-grid-step)
			);
		}

		.mi-team--surface {
			max-width: calc(2 * var(--mi-team-col) + var(--mi-team-gap));
		}

		.mi-team__grid {
			grid-template-columns: repeat(2, minmax(0, var(--mi-team-col)));
		}
	}

	@media (min-width: 960px) {
		.mi-team {
			--mi-team-col: round(
				down,
				calc((100% - 2 * var(--mi-team-gap)) / 3),
				var(--mi-grid-step)
			);
		}

		.mi-team--surface {
			max-width: calc(3 * var(--mi-team-col) + 2 * var(--mi-team-gap));
		}

		.mi-team__grid {
			grid-template-columns: repeat(3, minmax(0, var(--mi-team-col)));
		}
	}
}

.mi-team-card {
	display: flex;
	flex-direction: column;
	gap: var(--mi-space-4);
	min-width: 0;
	height: 100%;
	box-sizing: border-box;
}

.mi-team-card.mi-panel {
	padding: var(--mi-panel-pad-card-y-top) var(--mi-panel-pad-card-x) var(--mi-panel-pad-card-y-bottom);
}

.mi-team-card__top {
	display: flex;
	flex-direction: row;
	align-items: flex-end;
	justify-content: space-between;
	gap: var(--mi-space-4);
	width: 100%;
}

.mi-team-card__meta {
	flex: 1 1 0;
	min-width: 0;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	text-align: left;
	gap: calc(var(--mi-u) * 0.5);
}

.mi-team-card__avatar {
	width: 100px;
	height: 100px;
	border-radius: 50%;
	object-fit: cover;
	flex-shrink: 0;
	background-color: var(--mi-bg);
}

.mi-team-card__qual {
	font-size: var(--mi-text-sm);
	font-weight: 500;
	color: var(--mi-text-muted);
	margin: 0;
	line-height: var(--mi-leading-snug);
}

.mi-team-card__bio {
	font-size: var(--mi-text-sm);
	line-height: var(--mi-leading-snug);
	color: var(--mi-text);
	margin: 0;
	flex-grow: 1;
}

.mi-prose {
	max-width: var(--mi-narrow-max);
	color: var(--mi-text);
}

.mi-prose--wide {
	max-width: min(40rem, 100%);
}

.mi-prose :where(h1, h2, h3, h4) {
	font-family: var(--mi-font-heading);
	color: var(--mi-black);
	font-weight: 600;
	letter-spacing: var(--mi-tracking-tight);
}

.mi-prose h1 {
	font-size: var(--mi-text-4xl);
	line-height: var(--mi-lh-6);
	margin-block: 0 0 var(--mi-space-6);
}

.mi-prose h2 {
	font-size: var(--mi-text-2xl);
	line-height: var(--mi-lh-5);
	margin-block: var(--mi-space-8) var(--mi-space-4);
}

.mi-prose h3 {
	font-size: var(--mi-text-xl);
	line-height: var(--mi-lh-4);
	margin-block: var(--mi-space-6) var(--mi-space-3);
}

.mi-prose h4 {
	font-size: var(--mi-text-lg);
	line-height: var(--mi-lh-4);
	margin-block: var(--mi-space-6) var(--mi-space-3);
}

.mi-prose p {
	margin-block: 0 var(--mi-prose-p-gap);
	line-height: var(--mi-leading-relaxed);
}

.mi-prose :where(ul, ol) {
	margin-block: 0 var(--mi-prose-p-gap);
	padding-inline-start: 1.25em;
}

.mi-prose a {
	color: var(--mi-text);
	text-decoration-thickness: 1px;
	text-underline-offset: 0.15em;
	font-weight: 500;
}

.mi-prose a:hover {
	color: var(--mi-black);
}

.mi-heading {
	font-family: var(--mi-font-heading);
	font-weight: 600;
	line-height: var(--mi-lh-5);
	letter-spacing: var(--mi-tracking-tight);
	color: var(--mi-black);
}

.mi-team__title {
	font-family: var(--mi-font-heading);
	font-weight: 600;
	font-size: var(--mi-text-2xl);
	line-height: var(--mi-lh-5);
	letter-spacing: var(--mi-tracking-tight);
	color: var(--mi-black);
	margin: 0 0 var(--mi-space-4);
}

.mi-team-card__name {
	font-family: var(--mi-font-heading);
	font-weight: 600;
	font-size: var(--mi-text-xl);
	line-height: var(--mi-lh-4);
	letter-spacing: var(--mi-tracking-tight);
	color: var(--mi-black);
	margin: 0;
}

.mi-heading--heavy,
.mi-display {
	font-family: var(--mi-font-sans);
	font-weight: 900;
	line-height: var(--mi-lh-6);
	letter-spacing: var(--mi-tracking-tight);
	color: var(--mi-black);
}

.mi-overline {
	font-size: var(--mi-text-xs);
	font-weight: 600;
	line-height: max(1.2em, var(--mi-lh-3));
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--mi-text-muted);
	margin-block: 0 var(--mi-space-3);
}

.mi-heading--display {
	font-family: var(--mi-font-heading);
	font-size: var(--mi-text-display);
	font-weight: 600;
	line-height: var(--mi-lh-6);
	letter-spacing: var(--mi-tracking-tight);
	color: var(--mi-black);
	margin: 0 0 var(--mi-space-5);
}

.mi-hero-shell .mi-overline {
	margin-bottom: var(--mi-space-2);
}

.mi-lead {
	font-size: var(--mi-text-lead);
	line-height: var(--mi-leading-snug);
	color: var(--mi-text);
	margin-block: 0 var(--mi-space-5);
}

.mi-lead strong {
	font-weight: 600;
}

.mi-panel .mi-prose > h2:first-child {
	margin-block: 0 0 var(--mi-space-4);
}

.mi-bg-grid--fine {
	background: transparent;
}

/* =========================================================================
   4. Front page: full-width article
   ========================================================================= */
:is(body.home, body.page-id-21451).one-container .site-content {
	display: block;
}

:is(body.home, body.page-id-21451) .site-main .inside-article,
:is(body.home, body.page-id-21451) .site-main .entry-content {
	margin: 0;
	max-width: none;
}

:is(body.home, body.page-id-21451) .site-main .inside-article {
	padding-inline: 0;
}

/* =========================================================================
   5. Footer strip + widgets
   ========================================================================= */
.site-footer .inside-footer-widgets .widget {
	padding-inline: 0 !important;
}

.mi-footer-min {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: flex-start;
	gap: var(--mi-space-3);
	padding-block: 0;
	font-size: var(--mi-text-sm);
	color: var(--mi-text-muted);
	min-height: var(--mi-menu-box-height);
	width: 100%;
	box-sizing: border-box;
}

.mi-footer-min__nav {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: flex-end;
	gap: var(--mi-grid-step);
	list-style: none;
	margin: 0 0 0 auto;
	padding: 0;
	flex: 0 0 auto;
}

.site-footer .inside-footer-widgets {
	max-width: var(--mi-content-max);
	margin-inline: auto !important;
	padding-inline: 0 !important;
	padding-block: calc(var(--mi-grid-step) * 3) !important;
}

.footer-widgets-container .inside-footer-widgets {
	display: block;
}

.footer-widgets-container .widget {
	margin-bottom: 0;
}

.site-info {
	display: none !important;
}
