/* =========================================================================
   MIG International — main stylesheet.
   The ONLY stylesheet for this theme. Token-driven. Mobile-first.
   ========================================================================= */

/* ---------- 1. Design tokens — TiDii palette + typography (locked) -------- *
 * Mirrors the TiDii reference build 1:1. All values overridable via the
 * Customizer through migcorp_colors_inline_css() + migcorp_typography_inline_css().
 * ------------------------------------------------------------------------ */

:root {
	/* ----- Brand primary (navy — from the MIG Corporation logo) ----- */
	--migcorp-primary:        #1F4B7C;
	--migcorp-primary-bright: #2D659A;
	--migcorp-primary-deep:   #0F2D52;
	--migcorp-primary-soft:   rgba(31, 75, 124, 0.08);
	--migcorp-primary-ring:   rgba(31, 75, 124, 0.25);

	/* ----- Brand accent (gold) — RESERVED for the conversion CTA ----- */
	--migcorp-accent:         #E5B450;
	--migcorp-accent-bright:  #F3C56A;
	--migcorp-accent-deep:    #B98C2F;
	--migcorp-accent-soft:    rgba(229, 180, 80, 0.10);

	/* ----- Dark surfaces (single navy family — every dark section + footer
	 *       reads as the same brand colour, with three subtle tonal steps
	 *       for layering depth: edge is deepest, dark is the canonical bg) */
	--migcorp-dark:           #0F2D52;   /* canonical dark — same as primary-deep */
	--migcorp-dark-2:         #14365F;   /* one shade up — for hover/raised surfaces */
	--migcorp-dark-3:         #1A4070;   /* two shades up — accents */
	--migcorp-dark-edge:      #0A1F3C;   /* deepest — vignettes + footer bottom strip */

	/* ----- Neutrals ----- */
	--migcorp-ink:            #0A1428;   /* near-black with navy undertone — body text */
	--migcorp-ink-2:          #2A3548;
	--migcorp-white:          #ffffff;
	--migcorp-cream:          #FAF7F1;
	--migcorp-grey:           #F4F6F9;
	--migcorp-grey-2:         #E8ECF2;
	/* Body subtext — verified ~5.9:1 on white (WCAG AA safe with margin). */
	--migcorp-muted:          #545B68;
	--migcorp-muted-dark:     rgba(255, 255, 255, 0.72);
	--migcorp-line:           rgba(10, 20, 40, 0.10);
	--migcorp-line-dark:      rgba(255, 255, 255, 0.10);

	/* ----- Aliases ----- */
	--migcorp-black:          var(--migcorp-dark);
	--migcorp-black-2:        var(--migcorp-dark-2);
	--migcorp-black-3:        var(--migcorp-dark-3);

	/* Legacy aliases for old class names still in templates */
	--migcorp-gold:           var(--migcorp-accent);
	--migcorp-gold-700:       var(--migcorp-accent-deep);
	--migcorp-taupe:          var(--migcorp-muted);
	--migcorp-beige:          var(--migcorp-grey);
	--migcorp-border-light:   var(--migcorp-line);
	--migcorp-border-gold:    var(--migcorp-accent);
	--migcorp-surface-light:  var(--migcorp-white);
	--migcorp-surface-soft:   var(--migcorp-grey);
	--migcorp-surface-dark:   var(--migcorp-dark);
	--migcorp-surface-darker: var(--migcorp-dark-2);
	--migcorp-text-on-light:  var(--migcorp-ink);
	--migcorp-text-on-dark:   var(--migcorp-white);
	--migcorp-text-muted:     var(--migcorp-muted);
	--migcorp-ink-500:        var(--migcorp-muted);

	/* ----- Typography — TiDii stack ----- */
	--migcorp-font-display: 'Playfair Display', 'Cormorant Garamond', Georgia, serif;
	--migcorp-font-head:    'DM Sans', system-ui, sans-serif;
	--migcorp-font-body:    'DM Sans', system-ui, sans-serif;
	--migcorp-font-serif:   'Playfair Display', ui-serif, Georgia, serif;
	--migcorp-font-mono:    var(--migcorp-font-body);   /* legacy alias */

	/* ----- Type sizes — TiDii desktop ceilings (overridable via Customizer) */
	--migcorp-h1-size:   4.25rem;
	--migcorp-h2-size:   3.25rem;
	--migcorp-h3-size:   1.75rem;
	--migcorp-h4-size:   1.375rem;
	--migcorp-h5-size:   1.15rem;
	--migcorp-h6-size:   1rem;
	--migcorp-body-size: 1.0625rem;   /* 17px */
	--migcorp-metric:    clamp(2.75rem, 3.2vw + 1.5rem, 5rem);

	/* ----- Letter-spacing presets ----- */
	--migcorp-track-tight:   -0.02em;
	--migcorp-track-tighter: -0.03em;
	--migcorp-track-label:    0.18em;
	--migcorp-track-wide:     0.22em;

	/* ----- Spacing ----- */
	--migcorp-gutter:        32px;
	--migcorp-gutter-tablet: 28px;
	--migcorp-gutter-mobile: 28px;
	--migcorp-container-max: 1300px;
	--migcorp-section-pad:   clamp(64px, 9vw, 120px);

	/* ----- Radii — TiDii uses softer corners than the earlier earth pass */
	--migcorp-radius-sm:   8px;
	--migcorp-radius-md:   12px;
	--migcorp-radius-lg:   18px;
	--migcorp-radius-xl:   24px;
	--migcorp-radius-2xl:  32px;
	--migcorp-radius-pill: 999px;

	/* ----- Shadows ----- */
	--migcorp-shadow-card: 0 4px 16px rgba(10, 31, 60, 0.06);
	--migcorp-shadow-pop:  0 24px 70px rgba(10, 31, 60, 0.16);
	--migcorp-shadow-hover:0 12px 32px rgba(10, 31, 60, 0.14);
	--migcorp-shadow-cta:  0 12px 32px rgba(229, 180, 80, 0.30);
	--migcorp-shadow-blue: 0 12px 32px rgba(31, 75, 124, 0.28);

	/* ----- Easing ----- */
	--migcorp-ease:      cubic-bezier(.2, .8, .2, 1);
	--migcorp-ease-out:  cubic-bezier(.16, 1, .3, 1);

	/* ----- Layout ----- */
	--migcorp-header-h:  76px;
}

/* Dark-mode opt-in via .dark class — finance audiences shouldn't get
   flipped UI automatically. */
html.dark {
	--migcorp-surface-light: var(--migcorp-dark);
	--migcorp-surface-soft:  var(--migcorp-dark-2);
	--migcorp-text-on-light: var(--migcorp-cream);
	--migcorp-text-muted:    var(--migcorp-grey);
	--migcorp-cream:         var(--migcorp-dark);
	--migcorp-grey:          var(--migcorp-dark-2);
	--migcorp-line:          var(--migcorp-line-dark);
}

/* ---------- 2. Reset ----------------------------------------------------- */

*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; padding: 0; }

html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
	font-family: var(--migcorp-font-body);
	font-size: var(--migcorp-body-size);
	line-height: 1.65;
	color: var(--migcorp-ink);
	background: var(--migcorp-white);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	overflow-x: hidden;
}
img, svg, video { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; background: none; border: 0; color: inherit; }
ul, ol { list-style: none; }
input, select, textarea { font: inherit; color: inherit; }
strong, b { font-weight: 700; }
em, i { font-style: italic; }

.screen-reader-text {
	position: absolute !important;
	clip: rect(1px, 1px, 1px, 1px);
	width: 1px; height: 1px; overflow: hidden;
}

/* ---------- 3. Typography ----------------------------------------------- */

/* Editorial heading rhythm — DM Serif Display does H1 + H2 so the italic
   accent <em> reads as the same family in italic. H3-H6 hand off to DM Sans
   for legibility at small sizes. clamp() scales relative to the user
   variable so Customizer is the desktop ceiling. */
h1, h2 {
	font-family: var(--migcorp-font-display);
	font-weight: 700;
	line-height: 1.04;
	letter-spacing: var(--migcorp-track-tight);
	color: var(--migcorp-ink);
}
h1 {
	font-weight: 800;
	font-size: clamp(calc(var(--migcorp-h1-size) * 0.50), 4vw + 1.2rem, var(--migcorp-h1-size));
	letter-spacing: var(--migcorp-track-tighter);
}
h2 { font-size: clamp(calc(var(--migcorp-h2-size) * 0.55), 3vw + 1rem, var(--migcorp-h2-size)); }

h3, h4, h5, h6 {
	font-family: var(--migcorp-font-head);
	font-weight: 600;
	line-height: 1.18;
	letter-spacing: -0.01em;
	color: var(--migcorp-ink);
}
h3 { font-size: clamp(calc(var(--migcorp-h3-size) * 0.78), 1.2vw + 0.9rem, var(--migcorp-h3-size)); }
h4 { font-size: clamp(calc(var(--migcorp-h4-size) * 0.85), 0.5vw + 0.9rem, var(--migcorp-h4-size)); }
h5 { font-size: var(--migcorp-h5-size); }
h6 { font-size: var(--migcorp-h6-size); }
p  { margin: 0; }

/* Italic accent words inside H1/H2 — same family, italic variant.
   Use <em>word</em> sparingly: one phrase per headline at most. */
h1 em, h2 em {
	font-family: var(--migcorp-font-display);
	font-style: italic;
	font-weight: 400;
	color: var(--migcorp-primary-deep);
}
.migcorp-section-ink h1 em,
.migcorp-section-ink h2 em,
.migcorp-section-ink h3 em { color: var(--migcorp-accent); }

/* Editorial highlight tokens — one accent move per headline, max. */
h1 mark, h2 mark, h3 mark {
	background: transparent;
	color: var(--migcorp-accent-deep);
	font-weight: inherit;
}
.migcorp-section-ink h1 mark,
.migcorp-section-ink h2 mark,
.migcorp-section-ink h3 mark { color: var(--migcorp-accent-bright); }

h1 em, h2 em, h3 em {
	font-family: var(--migcorp-font-serif);
	font-style: italic;
	font-weight: 400;
	color: var(--migcorp-primary-deep);
}
.migcorp-section-ink h1 em,
.migcorp-section-ink h2 em,
.migcorp-section-ink h3 em,
.migcorp-hero h1 em,
.migcorp-hero h2 em { color: var(--migcorp-accent); }

p mark {
	background: linear-gradient(180deg, transparent 60%, var(--migcorp-accent-soft) 60%);
	color: inherit;
	padding: 0 2px;
}

.migcorp-eyebrow {
	display: inline-block;
	font-family: var(--migcorp-font-head);
	font-size: 12px;
	font-weight: 600;
	letter-spacing: var(--migcorp-track-wide);
	text-transform: uppercase;
	color: var(--migcorp-muted);
	margin-bottom: 18px;
}

/* ---------- 4. Layout primitives ---------------------------------------- */

.migcorp-container {
	width: 100%;
	max-width: var(--migcorp-container-max);
	margin: 0 auto;
	padding: 0 var(--migcorp-gutter);
}
.migcorp-section { padding: clamp(56px, 8vw, 120px) 0; }
.migcorp-section-cream { background: var(--migcorp-cream); }
.migcorp-section-stone { background: var(--migcorp-stone-100); }
.migcorp-section-ink   { background: var(--migcorp-ink); color: var(--migcorp-cream); }

.migcorp-grid { display: grid; gap: 28px; }
.migcorp-grid-2 { grid-template-columns: 1fr; }
.migcorp-grid-3 { grid-template-columns: 1fr; }
.migcorp-grid-4 { grid-template-columns: 1fr; }
@media (min-width: 768px) {
	.migcorp-grid-2 { grid-template-columns: repeat(2, 1fr); }
	.migcorp-grid-3 { grid-template-columns: repeat(2, 1fr); }
	.migcorp-grid-4 { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1024px) {
	.migcorp-grid-3 { grid-template-columns: repeat(3, 1fr); }
	.migcorp-grid-4 { grid-template-columns: repeat(4, 1fr); }
}

/* ---------- 4b. Section / eyebrow primitives --------------------------- */

.migcorp-section-head { margin-bottom: clamp(40px, 5vw, 64px); }
.migcorp-section-head-centered { text-align: center; max-width: 760px; margin-left: auto; margin-right: auto; }
.migcorp-section-head-row {
	display: grid; gap: 24px;
	grid-template-columns: 1fr;
	align-items: end;
}
@media (min-width: 768px) {
	.migcorp-section-head-row { grid-template-columns: 1fr auto; }
}
.migcorp-section-title {
	font-family: var(--migcorp-font-display);
	font-size: var(--migcorp-h2);
	font-weight: 700;
	line-height: 1.1;
	letter-spacing: var(--migcorp-track-tight);
	margin: 0;
}
.migcorp-section-title.migcorp-on-dark { color: var(--migcorp-cream); }
.migcorp-section-lead {
	max-width: 64ch;
	margin: 16px auto 0;
	font-size: 1.05rem;
	color: var(--migcorp-text-muted);
}
.migcorp-section-cta-row { text-align: center; margin-top: 48px; }
.migcorp-section-rule { display: block; height: 4px; background: var(--migcorp-gold); width: 64px; margin-bottom: 24px; }
.migcorp-section-rule-top { position: absolute; top: 0; left: 0; width: 100%; height: 4px; background: var(--migcorp-gold); }
.migcorp-home-bond { position: relative; }

.migcorp-eyebrow {
	display: inline-flex; align-items: center; gap: 8px;
	font-family: var(--migcorp-font-body);
	font-weight: 600;
	font-size: 12px;
	letter-spacing: var(--migcorp-track-label);
	text-transform: uppercase;
	color: var(--migcorp-taupe);
	margin-bottom: 18px;
}
.migcorp-eyebrow::before {
	content: ""; width: 32px; height: 1px;
	background: var(--migcorp-gold);
}
.migcorp-eyebrow-gold { color: var(--migcorp-gold); }
.migcorp-eyebrow-gold::before { background: var(--migcorp-gold); }

.migcorp-prose { max-width: 70ch; line-height: 1.7; }
.migcorp-prose p { margin: 0 0 1.1em; }
.migcorp-prose h2, .migcorp-prose h3 { margin-top: 1.6em; }
.migcorp-prose a { color: var(--migcorp-gold-700); text-decoration: underline; text-underline-offset: 2px; }
.migcorp-prose ul, .migcorp-prose ol { padding-left: 1.4em; }
.migcorp-prose blockquote {
	border-left: 3px solid var(--migcorp-gold);
	padding: 8px 0 8px 20px;
	margin: 1.5em 0;
	font-family: var(--migcorp-font-display);
	font-size: 1.25rem;
	font-style: italic;
	color: var(--migcorp-ink-2);
}

.migcorp-section { padding: var(--migcorp-section-pad) 0; }
.migcorp-section-tight { padding: 24px 0; }
.migcorp-section-cream { background: var(--migcorp-cream); color: var(--migcorp-text-on-light); }
.migcorp-section-stone, .migcorp-section-beige { background: var(--migcorp-beige); color: var(--migcorp-text-on-light); }
.migcorp-section-ink { background: var(--migcorp-ink); color: var(--migcorp-text-on-dark); }
.migcorp-section-ink h2,
.migcorp-section-ink h3 { color: var(--migcorp-cream); }
.migcorp-section-ink p  { color: var(--migcorp-beige); }

/* ---------- Reusable subtle wash modifier --------------------------------
 * Adds a barely-there atmospheric tint to any light-bg section without
 * overpowering the cream/beige base. Inspired by the editorial color washes
 * top sites use to break up flat surfaces. Use as a class modifier:
 *
 *   <section class="migcorp-section migcorp-section-cream migcorp-section--wash">
 *
 * Two radial glows (navy at one corner, gold at the opposite) sit at very
 * low opacity behind the content — gives depth without changing the read.
 * ------------------------------------------------------------------------- */
.migcorp-section--wash {
	position: relative;
	isolation: isolate;
	overflow: hidden;
}
.migcorp-section--wash::before {
	content: ""; position: absolute; inset: 0;
	background:
		radial-gradient(70% 60% at 0% 10%,  rgba(31, 75, 124, 0.07) 0%, transparent 65%),
		radial-gradient(60% 55% at 100% 100%, rgba(229, 180, 80, 0.08) 0%, transparent 65%),
		radial-gradient(50% 40% at 100% 0%,  rgba(31, 75, 124, 0.04) 0%, transparent 70%);
	pointer-events: none;
	z-index: 0;
}
.migcorp-section--wash > * { position: relative; z-index: 1; }

/* Variant — navy-leaning wash (more atmospheric, used on contemplative sections) */
.migcorp-section--wash-navy::before {
	background:
		radial-gradient(80% 70% at 0% 0%,    rgba(31, 75, 124, 0.10) 0%, transparent 60%),
		radial-gradient(70% 60% at 100% 100%, rgba(31, 75, 124, 0.06) 0%, transparent 65%),
		radial-gradient(50% 40% at 60% 50%,  rgba(229, 180, 80, 0.05) 0%, transparent 70%);
}

/* Variant — gold-leaning wash (warmer, used on welcoming sections) */
.migcorp-section--wash-gold::before {
	background:
		radial-gradient(70% 60% at 100% 0%,  rgba(229, 180, 80, 0.10) 0%, transparent 60%),
		radial-gradient(60% 55% at 0% 100%,  rgba(229, 180, 80, 0.06) 0%, transparent 65%),
		radial-gradient(50% 40% at 30% 50%,  rgba(31, 75, 124, 0.04) 0%, transparent 70%);
}

/* ---------- 5. Buttons — strict 2-button system ------------------------- *
 *
 *   .migcorp-btn--accent   → PRIMARY conversion CTA. Gold. The money path.
 *                            One per visual area, max. (Schedule a Briefing,
 *                            Request Prospectus, etc.)
 *
 *   .migcorp-btn--outline  → SECONDARY / everything else. Add --on-dark
 *                            modifier on dark sections.
 *
 *   .migcorp-btn--primary  → WORKFLOW CHROME ONLY. Reserved for "Continue" /
 *                            form-submit inside multi-step tools. NEVER use
 *                            as a page-level CTA — that's --accent's job.
 *
 *   Modifiers: --on-dark / --lg / --sm / --block
 *
 *   Legacy classes mapped to the new system for backward compat — the older
 *   templates still render correctly until they're rewritten in Phase 3:
 *     .migcorp-btn-primary       → --accent
 *     .migcorp-btn-dark          → --outline
 *     .migcorp-btn-outline       → --outline
 *     .migcorp-btn-outline-dark  → --outline
 *     .migcorp-btn-outline-light → --outline.--on-dark
 *     .migcorp-btn-ghost-light   → --outline.--on-dark (deprecated)
 *     .migcorp-btn-link          → --outline.--sm
 *     .migcorp-btn-magnetic      → behavior only (data-magnetic) — visual
 *                                  inherits whichever variant is co-applied
 * ------------------------------------------------------------------------ */

/* Single button size — matches the hero CTA size across every section.
   Inline-level legacy modifiers (--lg, --sm, btn-link) all map to this same
   size for consistency. Header sticky context has its own compact rule. */
.migcorp-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 12px;
	padding: 20px 38px;
	font-family: var(--migcorp-font-head);
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	border-radius: var(--migcorp-radius-pill);
	border: 1.5px solid transparent;
	transition: transform .2s var(--migcorp-ease), box-shadow .25s var(--migcorp-ease), background .25s ease, color .25s ease, border-color .25s ease;
	cursor: pointer;
	text-decoration: none;
	white-space: nowrap;
	line-height: 1;
}
.migcorp-btn svg { flex-shrink: 0; transition: transform .25s var(--migcorp-ease); }
.migcorp-btn:hover svg { transform: translateX(3px); }

/* PRIMARY — gold (the money path) */
.migcorp-btn--accent,
.migcorp-btn-primary {
	background: var(--migcorp-accent);
	color: var(--migcorp-ink);
	box-shadow: var(--migcorp-shadow-cta);
}
.migcorp-btn--accent:hover,
.migcorp-btn-primary:hover {
	background: var(--migcorp-accent-bright);
	color: var(--migcorp-ink);
	transform: translateY(-2px);
	box-shadow: 0 18px 40px rgba(229, 180, 80, 0.42);
}

/* SECONDARY — outline (everything else) */
.migcorp-btn--outline,
.migcorp-btn-outline,
.migcorp-btn-outline-dark,
.migcorp-btn-dark,
.migcorp-btn-link {
	background: transparent;
	color: var(--migcorp-ink);
	border-color: var(--migcorp-ink);
}
.migcorp-btn--outline:hover,
.migcorp-btn-outline:hover,
.migcorp-btn-outline-dark:hover,
.migcorp-btn-dark:hover,
.migcorp-btn-link:hover {
	background: var(--migcorp-ink);
	color: var(--migcorp-cream);
}

/* --on-dark modifier (and legacy --outline-light / --ghost-light) */
.migcorp-btn--on-dark,
.migcorp-btn-outline-light,
.migcorp-btn-ghost-light {
	background: transparent;
	color: var(--migcorp-cream);
	border-color: rgba(247, 243, 236, 0.45);
}
.migcorp-btn--on-dark:hover,
.migcorp-btn-outline-light:hover,
.migcorp-btn-ghost-light:hover {
	background: var(--migcorp-cream);
	color: var(--migcorp-ink);
	border-color: var(--migcorp-cream);
}

/* WORKFLOW CHROME — brand-color filled. NOT for page CTAs. */
.migcorp-btn--primary {
	background: var(--migcorp-primary);
	color: var(--migcorp-white);
	box-shadow: 0 12px 32px rgba(139, 94, 60, 0.28);
}
.migcorp-btn--primary:hover {
	background: var(--migcorp-primary-deep);
	transform: translateY(-2px);
}

/* Modifiers — all size modifiers now match the base size for consistency.
   --lg and --sm and -link map to identical visuals; kept as no-op aliases so
   legacy markup keeps rendering. --block is layout, not size. */
.migcorp-btn--lg,
.migcorp-btn--sm,
.migcorp-btn-link { /* same size as base — no override */ }
.migcorp-btn--block,
.migcorp-btn-block { display: flex; width: 100%; }

/* The only place we intentionally compact: header sticky-bar CTA. */
.migcorp-header-cta { padding: 14px 24px; font-size: 11.5px; letter-spacing: 0.16em; }
body.is-scrolled .migcorp-header-cta { padding: 12px 22px; }

/* Magnetic — behavior only. No standalone visual; co-applied with --accent. */
.migcorp-btn-magnetic { transition: transform .25s var(--migcorp-ease-out), box-shadow .25s ease, background .25s, color .25s; }
.migcorp-btn-magnetic > span { display: inline-block; transition: transform .3s var(--migcorp-ease-out); }
.migcorp-btn-magnetic[data-magnetized="1"] > span { transform: translate(var(--migcorp-mx, 0), var(--migcorp-my, 0)); }

/* ---------- 6. Site header ---------------------------------------------- */

.migcorp-skip-link {
	position: absolute; left: -9999px; top: 8px;
	background: var(--migcorp-ink); color: var(--migcorp-cream);
	padding: 8px 16px; z-index: 9999; border-radius: var(--migcorp-radius-sm);
}
.migcorp-skip-link:focus { left: 8px; }

.migcorp-site-header { position: sticky; top: 0; z-index: 100; background: var(--migcorp-cream); box-shadow: 0 1px 0 var(--migcorp-border-light); }

.migcorp-utility-bar {
	background: var(--migcorp-ink);
	color: var(--migcorp-beige);
	font-size: 12px;
	letter-spacing: 0.04em;
}
.migcorp-utility-bar-inner {
	display: flex; align-items: center; justify-content: space-between;
	min-height: 36px; gap: 16px; padding-top: 8px; padding-bottom: 8px;
}
.migcorp-utility-left, .migcorp-utility-right { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.migcorp-utility-reg, .migcorp-utility-audience, .migcorp-utility-lp, .migcorp-utility-social {
	display: inline-flex; align-items: center; gap: 6px;
	color: var(--migcorp-beige);
	text-decoration: none;
	transition: color .2s;
}
.migcorp-utility-reg { color: var(--migcorp-gold); }
.migcorp-utility-audience { color: var(--migcorp-beige); opacity: .75; }
.migcorp-utility-lp { color: var(--migcorp-gold); }
.migcorp-utility-lp:hover, .migcorp-utility-reg:hover { color: var(--migcorp-cream); }
.migcorp-utility-social { padding: 4px; }
.migcorp-utility-social:hover { color: var(--migcorp-gold); }
@media (max-width: 767px) {
	.migcorp-utility-audience, .migcorp-utility-social { display: none; }
}

.migcorp-theme-toggle {
	background: none; border: 1px solid rgba(245, 241, 237, 0.2);
	color: var(--migcorp-beige); padding: 4px 8px;
	border-radius: var(--migcorp-radius-pill);
	display: inline-flex; align-items: center; gap: 4px;
	cursor: pointer; transition: all .2s;
}
.migcorp-theme-toggle:hover { border-color: var(--migcorp-gold); color: var(--migcorp-gold); }
html.dark .migcorp-theme-toggle-sun { display: none; }
html.light .migcorp-theme-toggle-moon, html:not(.dark) .migcorp-theme-toggle-moon { display: none; }
html.dark .migcorp-theme-toggle-moon { display: inline-flex; }

.migcorp-header-bar { background: var(--migcorp-cream); }
.migcorp-header-bar-inner {
	display: flex; align-items: center; justify-content: space-between;
	gap: 32px; min-height: 80px;
}
.migcorp-brand {
	display: inline-flex; align-items: center; gap: 10px;
	font-family: var(--migcorp-font-display);
	font-weight: 700; font-size: 1.4rem;
	color: var(--migcorp-ink); text-decoration: none;
	letter-spacing: 0.02em;
}
.migcorp-brand-mark { max-height: 44px; width: auto; }
.migcorp-brand-wordmark .migcorp-brand-text::after {
	content: "."; color: var(--migcorp-gold); font-weight: 700;
}

.migcorp-primary-nav { display: none; }
@media (min-width: 1024px) {
	.migcorp-primary-nav { display: block; }
}
.migcorp-primary-nav-list,
.migcorp-mobile-nav-list {
	list-style: none; margin: 0; padding: 0;
	display: flex; gap: 28px;
}
.migcorp-primary-nav-list > li > a {
	color: var(--migcorp-ink-2);
	text-decoration: none;
	font-size: 14px; font-weight: 500;
	letter-spacing: 0.02em;
	padding: 8px 0;
	border-bottom: 1px solid transparent;
	transition: color .2s, border-color .2s;
}
.migcorp-primary-nav-list > li > a:hover,
.migcorp-primary-nav-list > li.current-menu-item > a,
.migcorp-primary-nav-list > li.current_page_item > a {
	color: var(--migcorp-gold-700);
	border-bottom-color: var(--migcorp-gold);
}

.migcorp-header-actions { display: flex; align-items: center; gap: 16px; }
.migcorp-header-cta { display: none; }
@media (min-width: 768px) { .migcorp-header-cta { display: inline-flex; } }

.migcorp-mobile-toggle {
	background: none; border: 0; padding: 8px;
	color: var(--migcorp-ink); cursor: pointer; line-height: 0;
	display: inline-flex;
}
.migcorp-mobile-toggle-close { display: none; }
body.migcorp-drawer-open .migcorp-mobile-toggle-open { display: none; }
body.migcorp-drawer-open .migcorp-mobile-toggle-close { display: inline-flex; }
@media (min-width: 1024px) {
	.migcorp-mobile-toggle { display: none; }
}

/* Mobile drawer */
.migcorp-mobile-drawer {
	position: fixed; inset: 116px 0 0; z-index: 90;
	background: var(--migcorp-cream);
	transform: translateY(-100%);
	transition: transform .35s var(--migcorp-ease);
	overflow-y: auto;
}
body.migcorp-drawer-open .migcorp-mobile-drawer {
	transform: translateY(0);
	aria-hidden: false;
}
.migcorp-mobile-drawer-inner {
	padding: 32px var(--migcorp-gutter) 48px;
	max-width: var(--migcorp-container-max);
	margin: 0 auto;
	display: flex; flex-direction: column; gap: 24px;
}
.migcorp-mobile-nav-list { flex-direction: column; gap: 0; }
.migcorp-mobile-nav-list > li > a {
	display: block;
	padding: 18px 0;
	font-family: var(--migcorp-font-display);
	font-size: 1.5rem;
	color: var(--migcorp-ink);
	text-decoration: none;
	border-bottom: 1px solid var(--migcorp-border-light);
}
.migcorp-mobile-meta { display: flex; flex-direction: column; gap: 8px; color: var(--migcorp-taupe); font-size: 14px; }
.migcorp-mobile-meta a { color: inherit; text-decoration: none; }

/* ---------- 7. Hero ------------------------------------------------------ */

.migcorp-hero { position: relative; isolation: isolate; overflow: hidden; }
.migcorp-hero-tall { min-height: clamp(620px, 90vh, 920px); display: flex; align-items: center; }

/* Inner-page hero — uniform fixed height (different from cinematic homepage),
   image background + navy overlay treatment inherited from .migcorp-hero-overlay. */
.migcorp-hero-page {
	min-height: clamp(380px, 48vw, 520px);
	display: flex; align-items: center;
	padding: clamp(48px, 7vw, 80px) 0;
	color: var(--migcorp-cream);
	background: var(--migcorp-dark);   /* fallback before image loads */
}
.migcorp-hero-page .migcorp-eyebrow,
.migcorp-hero-page .migcorp-hero-title em { color: var(--migcorp-gold); }
.migcorp-hero-page .migcorp-hero-title { color: var(--migcorp-cream); font-size: clamp(2.25rem, 4vw + 1rem, 4.25rem); line-height: 1.08; letter-spacing: -0.025em; }
.migcorp-hero-page .migcorp-hero-subtitle { color: var(--migcorp-beige); font-size: clamp(1rem, 0.4vw + 0.9rem, 1.15rem); line-height: 1.6; max-width: 60ch; margin-top: 16px; }
.migcorp-hero-page .migcorp-hero-inner { width: 100%; }
.migcorp-hero-page .migcorp-hero-content { max-width: 880px; }

.migcorp-hero-immersive { color: var(--migcorp-cream); background: var(--migcorp-ink); }
.migcorp-hero-immersive .migcorp-eyebrow { color: var(--migcorp-gold); }
.migcorp-hero-immersive .migcorp-eyebrow::before { background: var(--migcorp-gold); }
.migcorp-hero-editorial { background: var(--migcorp-cream); color: var(--migcorp-ink-2); }
.migcorp-hero-split { background: var(--migcorp-cream); }

.migcorp-hero-media { position: absolute; inset: 0; z-index: -1; }
.migcorp-hero-img, .migcorp-hero-video { width: 100%; height: 100%; object-fit: cover; }
.migcorp-hero-overlay {
	position: absolute; inset: 0;
	/* Left-to-right navy curtain — solid for the first 30% so the headline
	   sits on near-opaque navy, then a slow fade so the photography is still
	   visible on the right. Bottom vignette in matching navy for tonal
	   cohesion (replaces the earlier forest-tinted vignette). */
	background:
		linear-gradient(90deg,
			rgba(15, 45, 82, 1.0)  0%,
			rgba(15, 45, 82, 1.0)  30%,
			rgba(15, 45, 82, 0.92) 50%,
			rgba(15, 45, 82, 0.65) 70%,
			rgba(15, 45, 82, 0.25) 90%,
			rgba(15, 45, 82, 0.05) 100%),
		linear-gradient(180deg, transparent 55%, rgba(15, 45, 82, 0.55) 100%);
}

.migcorp-hero-inner {
	display: grid; gap: 48px; position: relative;
	padding: 80px 0;
	grid-template-columns: 1fr;
}
.migcorp-hero-content { max-width: 720px; }
.migcorp-hero-title {
	font-family: var(--migcorp-font-display);
	font-size: var(--migcorp-h1);
	font-weight: 700;
	letter-spacing: var(--migcorp-track-tight);
	line-height: 1.05;
	margin: 0 0 24px;
}
.migcorp-hero-immersive .migcorp-hero-title { color: var(--migcorp-cream); }
.migcorp-hero-subtitle {
	font-size: 1.1rem;
	line-height: 1.6;
	max-width: 56ch;
	color: var(--migcorp-beige);
	margin: 0 0 32px;
}
.migcorp-hero-editorial .migcorp-hero-subtitle { color: var(--migcorp-ink-2); }

.migcorp-hero-stats {
	display: flex; flex-wrap: wrap; gap: 32px 48px;
	padding: 24px 0;
	border-top: 1px solid rgba(229, 180, 80, 0.3);
	border-bottom: 1px solid rgba(229, 180, 80, 0.3);
	margin: 0 0 32px;
}
.migcorp-hero-stat { display: flex; flex-direction: column; gap: 4px; }
.migcorp-hero-stat-value {
	font-family: var(--migcorp-font-display);
	font-size: clamp(2rem, 3.5vw, 3rem);
	font-weight: 700;
	color: var(--migcorp-gold);
	line-height: 1;
}
.migcorp-hero-stat-label {
	font-family: var(--migcorp-font-body);
	font-size: 11px;
	letter-spacing: var(--migcorp-track-label);
	text-transform: uppercase;
	color: var(--migcorp-beige);
}

.migcorp-hero-ctas { display: flex; flex-wrap: wrap; gap: 16px; }
.migcorp-hero-scroll {
	position: absolute; bottom: 24px; right: 24px;
	display: inline-flex; align-items: center; gap: 8px;
	font-size: 11px; letter-spacing: var(--migcorp-track-label); text-transform: uppercase;
	color: var(--migcorp-gold);
	animation: migcorp-pulse 2.4s infinite ease-in-out;
}
@keyframes migcorp-pulse { 0%,100% { opacity: .7; transform: translateY(0); } 50% { opacity: 1; transform: translateY(4px); } }

@media (min-width: 1024px) {
	.migcorp-hero-split .migcorp-hero-inner { grid-template-columns: 55fr 45fr; align-items: center; }
}
.migcorp-hero-side-img { border-radius: var(--migcorp-radius-md); }

/* ---------- 8. Trust marquee -------------------------------------------- */

.migcorp-trust-bar {
	background: var(--migcorp-ink);
	color: var(--migcorp-beige);
	border-top: 1px solid rgba(229, 180, 80, 0.15);
	border-bottom: 1px solid rgba(229, 180, 80, 0.15);
}
.migcorp-trust-bar-inner {
	display: grid; gap: 24px; align-items: center;
	grid-template-columns: 1fr;
	padding: 28px 0;
}
@media (min-width: 1024px) {
	.migcorp-trust-bar-inner { grid-template-columns: 280px 1fr; }
}
.migcorp-trust-bar-copy .migcorp-eyebrow { color: var(--migcorp-gold); margin-bottom: 8px; }
.migcorp-trust-bar-blurb { font-size: 14px; margin: 0; color: var(--migcorp-beige); }

.migcorp-marquee { overflow: hidden; mask-image: linear-gradient(to right, transparent, #000 10%, #000 90%, transparent); }
.migcorp-marquee-track {
	display: flex; gap: 56px;
	width: max-content;
	animation: migcorp-marquee 35s linear infinite;
}
.migcorp-marquee-item img {
	height: 36px; width: auto; max-width: 160px;
	object-fit: contain;
	filter: brightness(0) invert(1) opacity(0.65);
	transition: filter .25s;
}
.migcorp-marquee-item:hover img { filter: brightness(0) invert(1) opacity(1); }
@keyframes migcorp-marquee {
	from { transform: translateX(0); }
	to   { transform: translateX(-50%); }
}

/* ---------- 9. Homepage — About intro ----------------------------------- */

.migcorp-home-about-grid {
	display: grid; gap: 56px;
	grid-template-columns: 1fr;
}
@media (min-width: 1024px) {
	.migcorp-home-about-grid { grid-template-columns: 55fr 45fr; align-items: center; gap: 80px; }
}
.migcorp-home-about-title {
	font-family: var(--migcorp-font-display);
	font-size: var(--migcorp-h2);
	font-weight: 700;
	letter-spacing: var(--migcorp-track-tight);
	line-height: 1.1;
	margin: 0 0 24px;
}
.migcorp-home-about-body { color: var(--migcorp-ink-2); margin-bottom: 32px; }
.migcorp-metric-strip {
	display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px 32px;
	padding-top: 32px;
	margin-top: 32px;
	border-top: 1px solid var(--migcorp-border-light);
}
@media (min-width: 768px) {
	.migcorp-metric-strip { grid-template-columns: repeat(4, 1fr); }
}
.migcorp-metric { display: flex; flex-direction: column; gap: 4px; }
.migcorp-metric-value {
	font-family: var(--migcorp-font-display);
	font-size: clamp(1.75rem, 2.5vw, 2.5rem);
	font-weight: 700;
	color: var(--migcorp-ink);
	line-height: 1;
}
.migcorp-metric-value-gold { color: var(--migcorp-gold); }
.migcorp-metric-value-xl { font-size: var(--migcorp-metric); }
.migcorp-metric-label {
	font-size: 11px;
	letter-spacing: var(--migcorp-track-label);
	text-transform: uppercase;
	color: var(--migcorp-taupe);
}
.migcorp-metric-strip-light .migcorp-metric-value { color: var(--migcorp-cream); }
.migcorp-metric-strip-light .migcorp-metric-label { color: var(--migcorp-beige); }
.migcorp-home-about-img { border-radius: var(--migcorp-radius-md); box-shadow: var(--migcorp-shadow-pop); }

/* ---------- 10. Homepage — Verticals ------------------------------------ */

.migcorp-verticals-grid { gap: 24px; }
.migcorp-vertical-card {
	position: relative; display: block;
	min-height: 480px;
	overflow: hidden;
	border-radius: var(--migcorp-radius-md);
	color: var(--migcorp-cream);
	text-decoration: none;
	box-shadow: var(--migcorp-shadow-card);
	transition: transform .35s var(--migcorp-ease), box-shadow .35s var(--migcorp-ease);
	isolation: isolate;
}
.migcorp-vertical-card:hover { transform: translateY(-4px); box-shadow: var(--migcorp-shadow-hover); }
.migcorp-vertical-card-media { position: absolute; inset: 0; z-index: -1; }
.migcorp-vertical-card-img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s var(--migcorp-ease); }
.migcorp-vertical-card:hover .migcorp-vertical-card-img { transform: scale(1.06); }
.migcorp-vertical-card-overlay {
	position: absolute; inset: 0;
	background: linear-gradient(180deg, rgba(10, 20, 40, 0.1) 30%, rgba(10, 20, 40, 0.9) 100%);
}
.migcorp-vertical-card-coming .migcorp-vertical-card-overlay { background: linear-gradient(180deg, rgba(10, 20, 40, 0.4) 0%, rgba(10, 20, 40, 0.92) 100%); }
.migcorp-vertical-card-body {
	position: relative;
	display: flex; flex-direction: column; gap: 12px;
	padding: 32px 28px;
	margin-top: auto;
	height: 100%;
	justify-content: flex-end;
}
.migcorp-vertical-card-icon { color: var(--migcorp-gold); }
.migcorp-vertical-card-title {
	font-family: var(--migcorp-font-display);
	font-size: clamp(1.4rem, 1.5vw + .5rem, 1.75rem);
	font-weight: 700;
	color: var(--migcorp-cream);
	margin: 0;
}
.migcorp-vertical-card-summary {
	color: var(--migcorp-beige);
	font-size: 14px;
	line-height: 1.5;
	margin: 0;
}
.migcorp-vertical-card-cta {
	display: inline-flex; align-items: center; gap: 6px;
	color: var(--migcorp-cream);
	font-size: 12px; letter-spacing: var(--migcorp-track-label);
	text-transform: uppercase;
	font-weight: 600;
	border-top: 1px solid rgba(229, 180, 80, 0.4);
	padding-top: 16px;
	margin-top: 8px;
	transition: color .25s, border-color .25s;
}
.migcorp-vertical-card:hover .migcorp-vertical-card-cta { color: var(--migcorp-gold); border-color: var(--migcorp-gold); }
.migcorp-pill-coming {
	position: absolute; top: 24px; right: 24px;
	background: rgba(229, 180, 80, 0.18);
	color: var(--migcorp-gold);
	border: 1px solid var(--migcorp-gold);
	padding: 4px 12px;
	border-radius: var(--migcorp-radius-pill);
	font-size: 10px; letter-spacing: var(--migcorp-track-label); text-transform: uppercase;
}

/* ---------- 11. Global Presence ----------------------------------------- */

.migcorp-home-global-grid {
	display: grid; gap: 48px;
	grid-template-columns: 1fr;
	align-items: center;
}
@media (min-width: 1024px) {
	.migcorp-home-global-grid { grid-template-columns: 6fr 5fr; gap: 80px; }
}
.migcorp-home-global-map { display: flex; justify-content: center; }
.migcorp-world-map-placeholder {
	width: 100%; max-width: 480px; aspect-ratio: 1.4;
	display: flex; flex-direction: column; align-items: center; justify-content: center;
	background: radial-gradient(circle at center, rgba(229, 180, 80,0.08), transparent 70%);
	color: var(--migcorp-gold);
	border-radius: var(--migcorp-radius-md);
	gap: 16px;
}
.migcorp-world-map-hint { font-size: 11px; letter-spacing: var(--migcorp-track-label); text-transform: uppercase; color: var(--migcorp-beige); opacity: .6; padding: 0 24px; text-align: center; }
.migcorp-region-list {
	list-style: none; padding: 0; margin: 24px 0;
	display: grid; gap: 12px;
}
.migcorp-region-list li {
	display: flex; align-items: center; gap: 12px;
	color: var(--migcorp-beige);
	font-size: 14px;
	padding: 10px 0;
	border-bottom: 1px solid rgba(245, 241, 237, 0.08);
}
.migcorp-region-list li svg { color: var(--migcorp-gold); flex-shrink: 0; }
.migcorp-home-global-body { color: var(--migcorp-beige); margin: 0 0 24px; }

/* ---------- 12. MIGCorp Bond -------------------------------------------- */

.migcorp-home-bond-grid {
	display: grid; gap: 56px;
	grid-template-columns: 1fr;
}
@media (min-width: 1024px) {
	.migcorp-home-bond-grid { grid-template-columns: 1fr 1fr; gap: 80px; align-items: start; }
}
.migcorp-diamond-list { list-style: none; padding: 0; margin: 24px 0; display: grid; gap: 12px; }
.migcorp-diamond-list li { display: flex; gap: 12px; align-items: flex-start; color: var(--migcorp-ink-2); font-size: 1rem; }
.migcorp-diamond { color: var(--migcorp-gold); font-size: 1.1rem; }
.migcorp-check-list { list-style: none; padding: 0; margin: 16px 0 24px; display: grid; gap: 8px; }
.migcorp-check-list li { display: flex; gap: 10px; align-items: flex-start; color: var(--migcorp-beige); font-size: 14px; }
.migcorp-check-list li svg { color: var(--migcorp-gold); margin-top: 4px; flex-shrink: 0; }

.migcorp-home-bond-ctas { display: flex; flex-wrap: wrap; gap: 16px; margin-top: 32px; }
.migcorp-process-flow { list-style: none; padding: 0; margin: 0; counter-reset: step; display: grid; gap: 16px; }
.migcorp-process-step {
	position: relative;
	display: grid; grid-template-columns: 56px 1fr; gap: 20px; align-items: center;
	padding: 24px;
	background: var(--migcorp-cream);
	border: 1px solid var(--migcorp-gold);
	border-radius: var(--migcorp-radius-sm);
	box-shadow: 0 2px 0 var(--migcorp-gold);
}
.migcorp-process-step::after {
	content: ""; position: absolute; left: 50%; bottom: -10px; transform: translateX(-50%);
	width: 1px; height: 10px; background: var(--migcorp-gold);
}
.migcorp-process-step:last-child::after { display: none; }
.migcorp-process-step-num {
	font-family: var(--migcorp-font-display);
	font-size: 2rem; font-weight: 700;
	color: var(--migcorp-gold);
	line-height: 1;
}
.migcorp-process-step-title { font-family: var(--migcorp-font-body); font-size: 13px; letter-spacing: var(--migcorp-track-label); text-transform: uppercase; color: var(--migcorp-ink); margin: 0 0 6px; }
.migcorp-process-step-text { font-size: 14px; color: var(--migcorp-taupe); margin: 0; line-height: 1.5; }

/* ---------- 13. Featured investment carousel ---------------------------- */

/* Featured Investment carousel — explicit slide chrome.
   - All slides share a fixed min-height (content top-aligned, bottom space
     reserved for the labeled progress bar).
   - Top-right counter "Featured Investment · 01 / 03".
   - Prev/next arrows centred on the slide edges.
   - Bottom progress bar with numbered + titled tabs; the active tab gets
     a gold rule that fills left-to-right as the rotation timer counts. */
.migcorp-home-featured {
	position: relative;
	isolation: isolate;
	min-height: 920px;
	color: var(--migcorp-cream);
	overflow: hidden;
	padding-bottom: 112px;   /* reserve space for progress bar */
}
.migcorp-home-featured-track { position: relative; min-height: 808px; }

.migcorp-home-featured-slide {
	position: absolute; inset: 0;
	display: flex;
	align-items: center;     /* content vertically centred in the slide */
	opacity: 0;
	visibility: hidden;
	transition: opacity .7s ease, visibility 0s linear .7s;
}
.migcorp-home-featured-slide.is-active {
	opacity: 1;
	visibility: visible;
	transition: opacity .7s ease, visibility 0s linear 0s;
	z-index: 2;
}

.migcorp-home-featured-media { position: absolute; inset: 0; z-index: -1; }
.migcorp-home-featured-img { width: 100%; height: 100%; object-fit: cover; }
.migcorp-home-featured-overlay {
	position: absolute; inset: 0;
	background: linear-gradient(90deg,
		rgba(15, 45, 82, 0.95) 0%,
		rgba(15, 45, 82, 0.85) 35%,
		rgba(15, 45, 82, 0.55) 60%,
		rgba(15, 45, 82, 0.25) 100%);
}
/* When no image: deep navy gradient fallback so slides read as full-bleed editorial */
.migcorp-home-featured-slide:not(:has(.migcorp-home-featured-media)) {
	background:
		radial-gradient(120% 80% at 20% 30%, rgba(31, 75, 124, 0.4), transparent 60%),
		radial-gradient(80% 60% at 90% 90%, rgba(229, 180, 80, 0.12), transparent 60%),
		var(--migcorp-dark);
}

.migcorp-home-featured-inner {
	padding: 80px 0;
	width: 100%;
}
.migcorp-home-featured-copy { max-width: 760px; }
.migcorp-home-featured-title {
	font-family: var(--migcorp-font-display);
	font-size: clamp(2.5rem, 3.2vw + 1rem, 4rem);
	font-weight: 700;
	color: var(--migcorp-cream);
	margin: 20px 0 16px;
	line-height: 1.05;
	letter-spacing: -0.025em;
}
.migcorp-home-featured-sub {
	font-family: var(--migcorp-font-display);
	font-style: italic;
	font-weight: 400;
	font-size: 1.25rem;
	color: var(--migcorp-accent);
	margin: 0 0 28px;
	max-width: 50ch;
	line-height: 1.4;
}
.migcorp-home-featured-body { color: rgba(247, 243, 236, 0.85); max-width: 64ch; margin: 0 0 24px; line-height: 1.65; }
.migcorp-home-featured-quote {
	font-family: var(--migcorp-font-display);
	font-style: italic;
	font-size: 1.3rem;
	color: var(--migcorp-accent);
	border-left: 3px solid var(--migcorp-accent);
	padding: 8px 0 8px 22px;
	margin: 28px 0;
	max-width: 56ch;
	line-height: 1.45;
}
.migcorp-home-featured-ctas { display: flex; flex-wrap: wrap; gap: 16px; margin-top: 32px; }

/* ---------- Top-right counter ---------------------------------------- */
.migcorp-home-featured-counter {
	position: absolute;
	top: 32px;
	right: clamp(24px, 4vw, 56px);
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	gap: 4px;
	z-index: 4;
	pointer-events: none;
}
.migcorp-home-featured-counter-eyebrow {
	font-family: var(--migcorp-font-head);
	font-size: 10.5px;
	font-weight: 600;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--migcorp-accent);
}
.migcorp-home-featured-counter-nums {
	display: inline-flex;
	align-items: baseline;
	gap: 6px;
	font-family: var(--migcorp-font-display);
	font-feature-settings: "tnum";
	color: rgba(247, 243, 236, 0.6);
	font-size: 1rem;
}
.migcorp-home-featured-counter-current {
	font-size: 1.85rem;
	font-weight: 700;
	color: var(--migcorp-accent);
	line-height: 1;
}
.migcorp-home-featured-counter-sep { font-size: 1.2rem; }

/* ---------- Prev / next arrows --------------------------------------- */
.migcorp-home-featured-arrow {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 56px; height: 56px;
	display: inline-flex; align-items: center; justify-content: center;
	background: rgba(15, 45, 82, 0.6);
	border: 1px solid rgba(229, 180, 80, 0.3);
	color: var(--migcorp-white);
	border-radius: 50%;
	cursor: pointer;
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	transition: background .25s, border-color .25s, transform .25s var(--migcorp-ease-out);
	z-index: 5;
}
.migcorp-home-featured-arrow:hover {
	background: var(--migcorp-accent);
	border-color: var(--migcorp-accent);
	color: var(--migcorp-ink);
}
.migcorp-home-featured-arrow--prev {
	left: clamp(16px, 3vw, 32px);
}
.migcorp-home-featured-arrow--prev svg { transform: rotate(180deg); }
.migcorp-home-featured-arrow--next {
	right: clamp(16px, 3vw, 32px);
}
.migcorp-home-featured-arrow:hover { transform: translateY(-50%) scale(1.05); }

@media (max-width: 768px) {
	.migcorp-home-featured-arrow { width: 44px; height: 44px; }
	.migcorp-home-featured-counter { top: 20px; right: 16px; }
	.migcorp-home-featured-counter-current { font-size: 1.4rem; }
}

/* ---------- Bottom progress bar -------------------------------------- */
.migcorp-home-featured-progress {
	position: absolute;
	left: 0; right: 0; bottom: 0;
	z-index: 4;
	background: linear-gradient(180deg, transparent, rgba(0, 0, 0, 0.25));
	padding: 24px 0;
}
.migcorp-home-featured-progress-inner {
	display: grid;
	gap: 24px;
	grid-template-columns: 1fr;
}
@media (min-width: 768px) {
	.migcorp-home-featured-progress-inner { grid-template-columns: repeat(var(--featured-cols, 3), 1fr); }
}

.migcorp-home-featured-tab {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 8px;
	padding: 0;
	background: transparent;
	border: 0;
	cursor: pointer;
	text-align: left;
	transition: opacity .25s;
	opacity: 0.55;
}
.migcorp-home-featured-tab:hover { opacity: 0.85; }
.migcorp-home-featured-tab.is-active { opacity: 1; }

.migcorp-home-featured-tab-num {
	font-family: var(--migcorp-font-head);
	font-size: 10.5px;
	font-weight: 600;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--migcorp-accent);
	font-feature-settings: "tnum";
}
.migcorp-home-featured-tab-title {
	font-family: var(--migcorp-font-display);
	font-size: 0.95rem;
	font-weight: 600;
	color: var(--migcorp-white);
	letter-spacing: -0.005em;
	line-height: 1.25;
}
.migcorp-home-featured-tab-rule {
	display: block;
	width: 100%;
	height: 2px;
	background: rgba(247, 243, 236, 0.2);
	overflow: hidden;
	margin-top: 4px;
}
.migcorp-home-featured-tab-rule-fill {
	display: block;
	width: 0%;
	height: 100%;
	background: var(--migcorp-accent);
	transition: width .25s ease;
}
.migcorp-home-featured-tab.is-active .migcorp-home-featured-tab-rule-fill {
	width: 100%;
	transition: width var(--featured-rotate, 8s) linear;
}

/* Mobile — stack tabs vertically with thinner spacing */
@media (max-width: 767px) {
	.migcorp-home-featured-progress { position: relative; padding: 32px 0 16px; }
	.migcorp-home-featured { padding-bottom: 0; }
	.migcorp-home-featured-tab-title { font-size: 0.85rem; }
}

/* Legacy dot class — kept as alias to the new tab style for back-compat */
.migcorp-home-featured-dots,
.migcorp-home-featured-dot { display: none !important; }

/* ---------- 14. ESG ------------------------------------------------------ */

/* Beautiful layered navy + gold gradient backdrop — sister to Featured Investment.
   Centered radial gold glow under the head, navy diagonal lift, deep base. */
.migcorp-home-esg {
	position: relative;
	isolation: isolate;
	overflow: hidden;
	background:
		radial-gradient(60% 50% at 50% 0%, rgba(229, 180, 80, 0.18) 0%, transparent 65%),
		radial-gradient(90% 70% at 15% 90%, rgba(31, 75, 124, 0.45) 0%, transparent 60%),
		radial-gradient(70% 60% at 90% 30%, rgba(26, 64, 112, 0.55) 0%, transparent 60%),
		linear-gradient(180deg, var(--migcorp-dark) 0%, var(--migcorp-dark-edge) 100%);
	color: var(--migcorp-cream);
}
/* Hairline gold rule top + bottom — frames the section as a coordinated band */
.migcorp-home-esg::before {
	content: ""; position: absolute; top: 0; left: 50%; transform: translateX(-50%);
	width: 280px; max-width: 60vw; height: 1px;
	background: linear-gradient(90deg, transparent 0%, var(--migcorp-gold) 50%, transparent 100%);
	opacity: .55; z-index: 1;
}
.migcorp-home-esg::after {
	content: ""; position: absolute; bottom: 0; left: 50%; transform: translateX(-50%);
	width: 280px; max-width: 60vw; height: 1px;
	background: linear-gradient(90deg, transparent 0%, var(--migcorp-gold) 50%, transparent 100%);
	opacity: .55; z-index: 1;
}
.migcorp-home-esg > * { position: relative; z-index: 2; }

/* ESG pillars — drop the vertical dividers, rely on whitespace + ample gap */
.migcorp-esg-grid { gap: 48px; margin-top: 48px; background: transparent; }

/* ---------- Section background utility additions ----------------------- */
.migcorp-section-grey { background: var(--migcorp-grey); color: var(--migcorp-text-on-light); }

/* ---------- Insights — 1-post + 2-post fallback layouts --------------- */
.migcorp-insights-pair { gap: 32px; }
.migcorp-insights-single {
	display: grid;
	gap: 32px;
	max-width: 760px;
}
.migcorp-insights-coming-soon {
	font-family: var(--migcorp-font-body);
	font-size: 14px;
	color: var(--migcorp-muted);
	font-style: italic;
	margin: 0;
	padding-top: 16px;
	border-top: 1px solid var(--migcorp-line);
}
.migcorp-esg-pillar {
	display: flex; flex-direction: column; align-items: center; text-align: center; gap: 14px;
	padding: 56px 28px;
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.04) 0%, rgba(255, 255, 255, 0.015) 100%);
	border: 1px solid rgba(229, 180, 80, 0.16);
	border-radius: 2px;
	position: relative;
	transition: transform .35s var(--migcorp-ease-out), border-color .35s, box-shadow .35s;
	backdrop-filter: blur(2px);
	-webkit-backdrop-filter: blur(2px);
}
.migcorp-esg-pillar::before {
	content: ""; position: absolute; top: 0; left: 50%; transform: translateX(-50%);
	width: 40px; height: 1px;
	background: var(--migcorp-gold);
	opacity: 0; transition: opacity .35s, width .35s;
}
.migcorp-esg-pillar:hover {
	transform: translateY(-4px);
	border-color: rgba(229, 180, 80, 0.32);
	box-shadow: 0 24px 48px -20px rgba(10, 31, 60, 0.6);
}
.migcorp-esg-pillar:hover::before { opacity: 1; width: 72px; }

.migcorp-esg-icon { color: var(--migcorp-gold); margin-bottom: 4px; }
.migcorp-esg-pillar .migcorp-metric-value { margin: 8px 0; }
.migcorp-esg-body { color: var(--migcorp-beige); margin: 0; font-size: 14px; max-width: 28ch; line-height: 1.6; }

/* ---------- 15. Insights row + post card -------------------------------- */

.migcorp-insights-grid { gap: 32px; }
.migcorp-post-card { background: transparent; }
.migcorp-post-card-link { display: flex; flex-direction: column; gap: 16px; text-decoration: none; color: inherit; }
.migcorp-post-card-media {
	aspect-ratio: 16 / 9; overflow: hidden; border-radius: var(--migcorp-radius-md);
	background: var(--migcorp-beige);
	display: flex; align-items: center; justify-content: center;
}
.migcorp-post-card-img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s var(--migcorp-ease); }
.migcorp-post-card-link:hover .migcorp-post-card-img { transform: scale(1.04); }
.migcorp-post-card-placeholder { color: var(--migcorp-taupe); }
.migcorp-post-card-cat {
	display: inline-block;
	background: var(--migcorp-gold);
	color: var(--migcorp-ink);
	padding: 4px 10px;
	border-radius: var(--migcorp-radius-pill);
	font-size: 10px; letter-spacing: var(--migcorp-track-label); text-transform: uppercase;
	font-weight: 600;
	margin-bottom: 4px;
}
.migcorp-post-card-title {
	font-family: var(--migcorp-font-display);
	font-size: 1.35rem; font-weight: 700;
	color: var(--migcorp-ink); line-height: 1.3;
	margin: 0 0 6px;
}
.migcorp-post-card-link:hover .migcorp-post-card-title { color: var(--migcorp-gold-700); }
.migcorp-post-card-excerpt { color: var(--migcorp-taupe); margin: 0 0 8px; font-size: 14px; line-height: 1.6; }
.migcorp-post-card-meta { font-size: 12px; letter-spacing: 0.04em; color: var(--migcorp-taupe); }

/* ---------- 16. News & Interviews --------------------------------------- */

/* Sits between two dark sections — needs to feel like a deliberate breath,
   not a default light block. Subtle gold-rule top divider + framed video. */
.migcorp-home-news {
	position: relative;
	padding: clamp(80px, 9vw, 120px) 0;
}
.migcorp-home-news::before {
	content: ""; position: absolute; top: 0; left: 50%; transform: translateX(-50%);
	width: 240px; max-width: 60vw; height: 2px;
	background: linear-gradient(90deg, transparent 0%, var(--migcorp-gold) 50%, transparent 100%);
	opacity: .55;
}

.migcorp-home-news-grid {
	display: grid; gap: 48px;
	grid-template-columns: 1fr;
}
@media (min-width: 1024px) {
	.migcorp-home-news-grid { grid-template-columns: 3fr 2fr; gap: 72px; align-items: center; }
}
.migcorp-video-embed {
	aspect-ratio: 16/9;
	background: var(--migcorp-dark);
	border-radius: var(--migcorp-radius-md);
	overflow: hidden;
	box-shadow: 0 30px 60px -20px rgba(10, 31, 60, 0.35), 0 0 0 1px rgba(229, 180, 80, 0.18);
	position: relative;
}
.migcorp-video-embed iframe, .migcorp-video-embed video { width: 100%; height: 100%; border: 0; display: block; }
.migcorp-video-placeholder {
	aspect-ratio: 16/9; background: var(--migcorp-dark); color: var(--migcorp-gold);
	border-radius: var(--migcorp-radius-md);
	display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 12px;
	text-align: center; padding: 24px;
	box-shadow: 0 30px 60px -20px rgba(10, 31, 60, 0.35), 0 0 0 1px rgba(229, 180, 80, 0.18);
}
.migcorp-video-placeholder span { font-size: 12px; color: var(--migcorp-beige); letter-spacing: 0.04em; }
.migcorp-home-news-caption { margin-top: 12px; color: var(--migcorp-ink-2); font-size: 14px; }
.migcorp-press-strip { margin-top: 32px; padding-top: 24px; border-top: 1px solid var(--migcorp-border-light); }
.migcorp-press-strip-logos { display: flex; flex-wrap: wrap; gap: 32px; align-items: center; margin-top: 12px; }
.migcorp-press-logo img { height: 32px; width: auto; max-width: 140px; filter: grayscale(1) opacity(.55); transition: filter .25s; }
.migcorp-press-logo:hover img { filter: none; }

/* ---------- Global Press Band (above final-CTA, every page) ------------ */
.migcorp-press-band {
	background: var(--migcorp-cream);
	border-top: 1px solid var(--migcorp-line);
	border-bottom: 1px solid var(--migcorp-line);
	padding: clamp(24px, 3vw, 36px) 0;
	overflow: hidden;
}
.migcorp-press-band-inner {
	display: grid; gap: 16px 32px;
	grid-template-columns: 1fr;
	align-items: center;
}
@media (min-width: 768px) {
	.migcorp-press-band-inner { grid-template-columns: auto 1fr; }
}
.migcorp-press-band-label {
	font-family: var(--migcorp-font-body);
	font-size: 11px; letter-spacing: 0.24em; text-transform: uppercase;
	color: var(--migcorp-muted); font-weight: 600;
	white-space: nowrap;
}
.migcorp-press-band-marquee {
	position: relative;
	overflow: hidden;
	mask-image: linear-gradient(90deg, transparent 0%, #000 8%, #000 92%, transparent 100%);
	-webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 8%, #000 92%, transparent 100%);
}
.migcorp-press-band-track {
	display: inline-flex;
	gap: clamp(40px, 6vw, 72px);
	align-items: center;
	animation: migcorp-press-marquee var(--migcorp-press-speed, 40s) linear infinite;
	width: max-content;
	will-change: transform;
}
.migcorp-press-band:hover .migcorp-press-band-track { animation-play-state: paused; }
@keyframes migcorp-press-marquee {
	0%   { transform: translateX(0); }
	100% { transform: translateX(-50%); }   /* logos rendered twice → seamless loop */
}
.migcorp-press-band-item {
	flex: 0 0 auto;
	display: inline-flex; align-items: center;
	text-decoration: none;
}
.migcorp-press-band-item img {
	height: 28px; width: auto; max-width: 160px;
	filter: grayscale(1) opacity(.5);
	transition: filter .3s, opacity .3s;
}
.migcorp-press-band-item:hover img { filter: grayscale(0) opacity(1); }
.migcorp-press-band-item--text {
	font-family: var(--migcorp-font-display);
	font-size: clamp(1rem, 1.4vw + .5rem, 1.4rem);
	font-weight: 500;
	color: var(--migcorp-muted);
	letter-spacing: -0.005em;
	transition: color .3s;
	white-space: nowrap;
}
.migcorp-press-band-item--text:hover { color: var(--migcorp-ink); }

@media (prefers-reduced-motion: reduce) {
	.migcorp-press-band-track { animation: none; }
}

/* ---------- 17. Final CTA strip ----------------------------------------- */

.migcorp-final-cta { text-align: center; padding: clamp(64px, 8vw, 112px) 0; }
.migcorp-final-cta-inner { max-width: 1040px; margin: 0 auto; padding-left: 24px; padding-right: 24px; }
.migcorp-final-cta-title {
	font-family: var(--migcorp-font-display);
	font-size: clamp(2rem, 3.6vw + 1rem, 4rem);
	font-weight: 700; margin: 0 0 20px; line-height: 1.08;
	letter-spacing: -0.02em;
	max-width: 22ch; margin-left: auto; margin-right: auto;
}
.migcorp-final-cta-body {
	font-size: 1.05rem; line-height: 1.6; margin: 0 auto 36px;
	max-width: 56ch;
}
.migcorp-final-cta-actions { display: flex; flex-wrap: wrap; justify-content: center; gap: 16px; }

/* "Gold" variant retired — renders as the navy gradient family for consistency
   with Featured Investment + ESG. Editors can still pick "gold" in the metabox
   but the visual is unified across the site. */
.migcorp-final-cta-gold,
.migcorp-final-cta-dark {
	position: relative;
	isolation: isolate;
	overflow: hidden;
	background:
		radial-gradient(60% 50% at 50% 0%, rgba(229, 180, 80, 0.16) 0%, transparent 65%),
		radial-gradient(90% 70% at 15% 90%, rgba(31, 75, 124, 0.42) 0%, transparent 60%),
		radial-gradient(70% 60% at 90% 30%, rgba(26, 64, 112, 0.52) 0%, transparent 60%),
		linear-gradient(180deg, var(--migcorp-dark) 0%, var(--migcorp-dark-edge) 100%);
	color: var(--migcorp-cream);
}
.migcorp-final-cta-gold::before,
.migcorp-final-cta-dark::before {
	content: ""; position: absolute; top: 0; left: 50%; transform: translateX(-50%);
	width: 280px; max-width: 60vw; height: 1px;
	background: linear-gradient(90deg, transparent 0%, var(--migcorp-gold) 50%, transparent 100%);
	opacity: .55; z-index: 1;
}
.migcorp-final-cta-gold::after,
.migcorp-final-cta-dark::after {
	content: ""; position: absolute; bottom: 0; left: 50%; transform: translateX(-50%);
	width: 280px; max-width: 60vw; height: 1px;
	background: linear-gradient(90deg, transparent 0%, var(--migcorp-gold) 50%, transparent 100%);
	opacity: .55; z-index: 1;
}
.migcorp-final-cta-gold > *,
.migcorp-final-cta-dark > * { position: relative; z-index: 2; }

.migcorp-final-cta-gold .migcorp-final-cta-title,
.migcorp-final-cta-dark .migcorp-final-cta-title { color: var(--migcorp-cream); }
.migcorp-final-cta-gold .migcorp-final-cta-title em,
.migcorp-final-cta-dark .migcorp-final-cta-title em { color: var(--migcorp-gold); font-style: italic; }
.migcorp-final-cta-gold .migcorp-final-cta-body,
.migcorp-final-cta-dark .migcorp-final-cta-body  { color: var(--migcorp-beige); }
.migcorp-final-cta-dark .migcorp-btn-dark { background: var(--migcorp-gold); color: var(--migcorp-dark); }
.migcorp-final-cta-dark .migcorp-btn-dark:hover { background: var(--migcorp-cream); }

.migcorp-final-cta-cream { background: var(--migcorp-cream); }
.migcorp-final-cta-cream .migcorp-final-cta-title { color: var(--migcorp-ink); }

/* ---------- 18. Site footer --------------------------------------------- */

.migcorp-site-footer { background: var(--migcorp-ink); color: var(--migcorp-beige); padding: 80px 0 0; }
.migcorp-footer-grid {
	display: grid; gap: 48px;
	grid-template-columns: 1fr;
}
@media (min-width: 768px)  { .migcorp-footer-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .migcorp-footer-grid { grid-template-columns: 1.5fr 1fr 1fr 1.2fr; } }
.migcorp-footer-brand .migcorp-brand-mark { filter: brightness(0) invert(1); max-height: 56px; }
.migcorp-footer-brand .migcorp-brand-wordmark .migcorp-brand-text { color: var(--migcorp-cream); }
.migcorp-footer-brand .migcorp-brand-wordmark .migcorp-brand-text::after { color: var(--migcorp-gold); }
.migcorp-footer-blurb { color: var(--migcorp-beige); font-size: 14px; line-height: 1.6; margin: 16px 0 24px; max-width: 36ch; }
.migcorp-footer-social { list-style: none; padding: 0; margin: 0; display: flex; gap: 14px; }
.migcorp-footer-social a {
	display: inline-flex; align-items: center; justify-content: center;
	width: 36px; height: 36px; border-radius: 50%;
	border: 1px solid rgba(229, 180, 80, 0.4);
	color: var(--migcorp-gold);
	transition: all .25s;
}
.migcorp-footer-social a:hover { background: var(--migcorp-gold); color: var(--migcorp-ink); }

.migcorp-footer-col-title {
	font-family: var(--migcorp-font-body);
	font-size: 12px; letter-spacing: var(--migcorp-track-label); text-transform: uppercase;
	color: var(--migcorp-gold);
	margin: 0 0 16px;
	font-weight: 600;
}
.migcorp-footer-list, .migcorp-footer-offices { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; }
.migcorp-footer-list a, .migcorp-footer-direct a { color: var(--migcorp-beige); text-decoration: none; font-size: 14px; transition: color .2s; display: inline-flex; align-items: center; gap: 8px; }
.migcorp-footer-list a:hover, .migcorp-footer-direct a:hover { color: var(--migcorp-gold); }
.migcorp-footer-offices li { font-size: 14px; line-height: 1.5; color: var(--migcorp-beige); }
.migcorp-footer-offices strong { color: var(--migcorp-cream); display: inline-flex; gap: 8px; align-items: center; font-weight: 500; }
.migcorp-footer-offices span { color: var(--migcorp-beige); opacity: .8; font-size: 12px; }
.migcorp-pill-hq { background: var(--migcorp-gold); color: var(--migcorp-ink); padding: 2px 8px; border-radius: var(--migcorp-radius-pill); font-size: 10px; letter-spacing: 0.1em; font-weight: 600; }
.migcorp-footer-all-offices { display: inline-flex; align-items: center; gap: 6px; color: var(--migcorp-gold); font-size: 12px; letter-spacing: var(--migcorp-track-label); text-transform: uppercase; margin-top: 16px; text-decoration: none; }
.migcorp-footer-direct { display: flex; flex-direction: column; gap: 8px; margin-top: 16px; }

/* Legacy .migcorp-footer-bottom / .migcorp-footer-bottom-grid removed — merged into .migcorp-footer-legal-row */
.migcorp-footer-copyright { font-size: 12px; color: var(--migcorp-beige); opacity: .7; }
.migcorp-footer-legal { list-style: none; padding: 0; margin: 0; display: flex; gap: 24px; flex-wrap: wrap; }
.migcorp-footer-legal a { color: var(--migcorp-beige); font-size: 12px; text-decoration: none; opacity: .7; transition: opacity .2s; }
.migcorp-footer-legal a:hover { opacity: 1; color: var(--migcorp-gold); }
.migcorp-footer-disclaimer { font-size: 11px; line-height: 1.6; color: var(--migcorp-beige); opacity: .6; margin: 16px 0 0; }

/* ---------- 19. Floating UI: cookies, newsletter, back-to-top, chatbot - */

.migcorp-cookie-banner {
	position: fixed; left: 0; right: 0; bottom: 0; z-index: 80;
	background: var(--migcorp-ink); color: var(--migcorp-cream);
	transform: translateY(100%);
	transition: transform .35s var(--migcorp-ease);
	border-top: 1px solid var(--migcorp-gold);
}
.migcorp-cookie-banner.is-visible { transform: translateY(0); }
.migcorp-cookie-banner-inner {
	display: flex; flex-wrap: wrap; gap: 24px; align-items: center; justify-content: space-between;
	padding: 20px 0;
}
.migcorp-cookie-banner p { margin: 0; font-size: 14px; flex: 1 1 60%; }
.migcorp-cookie-banner a { color: var(--migcorp-gold); text-decoration: underline; }
.migcorp-cookie-banner-actions { display: flex; gap: 12px; }

.migcorp-newsletter-modal {
	position: fixed; inset: 0; z-index: 200;
	background: rgba(10, 20, 40, 0.7);
	display: flex; align-items: center; justify-content: center;
	padding: 24px;
	opacity: 0; pointer-events: none;
	transition: opacity .3s ease;
}
.migcorp-newsletter-modal.is-visible { opacity: 1; pointer-events: auto; }
.migcorp-newsletter-modal-inner {
	background: var(--migcorp-cream);
	max-width: 480px; width: 100%;
	padding: 48px 40px;
	border-radius: var(--migcorp-radius-md);
	position: relative;
	box-shadow: var(--migcorp-shadow-pop);
	border-top: 4px solid var(--migcorp-gold);
}
.migcorp-newsletter-modal-inner h3 { font-family: var(--migcorp-font-display); font-size: 1.75rem; margin: 0 0 12px; color: var(--migcorp-ink); }
.migcorp-newsletter-close { position: absolute; top: 16px; right: 16px; background: none; border: 0; cursor: pointer; color: var(--migcorp-taupe); padding: 8px; }
.migcorp-newsletter-close:hover { color: var(--migcorp-ink); }
.migcorp-newsletter-config-hint { font-size: 13px; color: var(--migcorp-taupe); }

.migcorp-to-top {
	position: fixed; bottom: 24px; right: 24px; z-index: 70;
	width: 48px; height: 48px; border-radius: 50%;
	background: var(--migcorp-ink); color: var(--migcorp-gold);
	border: 1px solid var(--migcorp-gold);
	display: inline-flex; align-items: center; justify-content: center;
	opacity: 0; transform: translateY(20px); pointer-events: none;
	transition: opacity .25s, transform .25s, background .25s;
	cursor: pointer;
}
.migcorp-to-top.is-visible { opacity: 1; transform: translateY(0); pointer-events: auto; }
.migcorp-to-top:hover { background: var(--migcorp-gold); color: var(--migcorp-ink); }

.migcorp-chatbot-launcher {
	position: fixed; bottom: 24px; left: 24px; z-index: 70;
	width: 56px; height: 56px; border-radius: 50%;
	background: var(--migcorp-gold); color: var(--migcorp-ink);
	border: 0; cursor: pointer;
	display: inline-flex; align-items: center; justify-content: center;
	box-shadow: var(--migcorp-shadow-pop);
	font-size: 1.3rem;
	transition: transform .25s, background .25s;
}
.migcorp-chatbot-launcher:hover { transform: translateY(-2px); background: var(--migcorp-gold-700); }

.migcorp-reading-progress {
	position: fixed; left: 0; top: 0; height: 3px;
	background: var(--migcorp-gold);
	width: 0%; z-index: 110;
	transition: width .15s linear;
}

/* ---------- 20. Reveal-on-scroll — progressive enhancement ------------- *
 *
 *   CRITICAL: elements default VISIBLE. JS opt-in tags only below-fold
 *   elements with .migcorp-reveal-pending — and removes the tag when the
 *   element enters the viewport. Without JS, everything paints normally —
 *   no NO_LCP errors, no missing content if a script blocks.
 * ------------------------------------------------------------------------ */

[data-reveal] { opacity: 1; transform: none; transition: opacity .8s var(--migcorp-ease-out), transform .8s var(--migcorp-ease-out); }
[data-reveal].migcorp-reveal-pending { opacity: 0; transform: translateY(24px); }
[data-reveal].is-revealed { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
	[data-reveal], [data-reveal].migcorp-reveal-pending { opacity: 1; transform: none; }
	.migcorp-marquee-track { animation: none; }
	.migcorp-hero-scroll { animation: none; }
}

/* ---------- 21. Page hero (inner pages) --------------------------------- */

.migcorp-page-hero {
	background: var(--migcorp-cream);
	padding: clamp(64px, 10vw, 120px) 0 clamp(40px, 6vw, 64px);
}
.migcorp-page-hero-title { font-family: var(--migcorp-font-display); font-size: var(--migcorp-h1); font-weight: 700; letter-spacing: var(--migcorp-track-tight); margin: 0 0 16px; line-height: 1.05; }
.migcorp-page-hero-sub { font-size: 1.1rem; color: var(--migcorp-taupe); max-width: 64ch; margin: 0; }

/* ---------- 22. Single post --------------------------------------------- */

.migcorp-post-hero { padding: clamp(64px, 10vw, 96px) 0 24px; background: var(--migcorp-cream); text-align: center; }
.migcorp-post-title { font-family: var(--migcorp-font-display); font-size: var(--migcorp-h1); font-weight: 700; line-height: 1.1; max-width: 22ch; margin: 16px auto 16px; }
.migcorp-post-meta { display: inline-flex; gap: 8px; color: var(--migcorp-taupe); font-size: 14px; }
.migcorp-post-feature { padding: 24px 0; background: var(--migcorp-cream); }
.migcorp-post-feature-img { width: 100%; border-radius: var(--migcorp-radius-md); }
.migcorp-post-prose { max-width: 70ch; margin: 0 auto; line-height: 1.75; font-size: 1.05rem; color: var(--migcorp-ink-2); }
.migcorp-post-prose h2, .migcorp-post-prose h3 { font-family: var(--migcorp-font-display); color: var(--migcorp-ink); }
.migcorp-post-prose blockquote {
	border-left: 4px solid var(--migcorp-gold);
	padding-left: 24px; margin: 32px 0;
	font-family: var(--migcorp-font-display); font-style: italic; font-size: 1.35rem;
}
.migcorp-post-byline {
	display: flex; gap: 16px; align-items: center;
	max-width: 70ch; margin: 64px auto 0;
	padding-top: 32px;
	border-top: 1px solid var(--migcorp-border-light);
}
.migcorp-post-byline img { border-radius: 50%; }
.migcorp-post-byline strong { display: block; font-size: 14px; color: var(--migcorp-ink); }
.migcorp-post-byline p { font-size: 13px; color: var(--migcorp-taupe); margin: 4px 0 0; }

/* ---------- 23. Pagination + empty + breadcrumbs ------------------------ */

.migcorp-pagination { display: flex; justify-content: center; gap: 8px; margin-top: 48px; }
.migcorp-pagination .page-numbers {
	display: inline-flex; align-items: center; justify-content: center;
	min-width: 40px; height: 40px; padding: 0 12px;
	border: 1px solid var(--migcorp-border-light);
	border-radius: var(--migcorp-radius-sm);
	color: var(--migcorp-ink-2); text-decoration: none; font-size: 14px;
	transition: all .2s;
}
.migcorp-pagination .page-numbers:hover,
.migcorp-pagination .page-numbers.current { background: var(--migcorp-ink); color: var(--migcorp-cream); border-color: var(--migcorp-ink); }

.migcorp-empty { text-align: center; padding: 80px 0; color: var(--migcorp-taupe); }
/* Breadcrumb band — sits above the inner-page hero as a thin cream strip */
.migcorp-breadcrumbs {
	padding: 18px 0;
	font-family: var(--migcorp-font-body);
	font-size: 11px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--migcorp-muted);
	font-weight: 500;
	background: var(--migcorp-cream);
	border-bottom: 1px solid var(--migcorp-line);
}
.migcorp-breadcrumbs ol {
	list-style: none; margin: 0; padding: 0;
	display: flex; flex-wrap: wrap; align-items: center; gap: 8px 12px;
}
.migcorp-breadcrumbs li {
	display: inline-flex; align-items: center; gap: 12px;
}
.migcorp-breadcrumbs li + li::before {
	content: "/";
	color: var(--migcorp-muted);
	opacity: .45;
	margin-right: 4px;
}
.migcorp-breadcrumbs a { color: var(--migcorp-ink-2); text-decoration: none; transition: color .25s; }
.migcorp-breadcrumbs a:hover { color: var(--migcorp-gold-700); }
.migcorp-breadcrumbs [aria-current="page"] { color: var(--migcorp-gold-700); font-weight: 600; }

/* ---------- 24. 404 ----------------------------------------------------- */

.migcorp-actions-row { display: flex; flex-wrap: wrap; gap: 16px; justify-content: center; margin-top: 24px; }

/* ---------- 25. WPForms styling overrides ------------------------------- */

.wpforms-container input[type="text"],
.wpforms-container input[type="email"],
.wpforms-container input[type="tel"],
.wpforms-container textarea,
.wpforms-container select {
	border: 1px solid var(--migcorp-border-light) !important;
	border-radius: var(--migcorp-radius-sm) !important;
	font-family: var(--migcorp-font-body) !important;
	padding: 14px 16px !important;
	background: var(--migcorp-cream) !important;
	color: var(--migcorp-ink) !important;
}
.wpforms-container input:focus,
.wpforms-container textarea:focus { border-color: var(--migcorp-gold) !important; outline: 0 !important; box-shadow: 0 0 0 3px rgba(229, 180, 80,0.18) !important; }
.wpforms-container .wpforms-field-label { font-family: var(--migcorp-font-body); font-size: 12px; letter-spacing: var(--migcorp-track-label); text-transform: uppercase; color: var(--migcorp-taupe); font-weight: 600 !important; }
.wpforms-container .wpforms-submit {
	background: var(--migcorp-accent) !important;
	color: var(--migcorp-ink) !important;
	border: 1.5px solid transparent !important;
	padding: 20px 38px !important;
	border-radius: var(--migcorp-radius-pill) !important;
	font-family: var(--migcorp-font-head) !important;
	font-weight: 700 !important;
	letter-spacing: 0.18em !important;
	text-transform: uppercase !important;
	font-size: 13px !important;
	box-shadow: var(--migcorp-shadow-cta) !important;
	transition: transform .2s var(--migcorp-ease), background .25s ease !important;
}
.wpforms-container .wpforms-submit:hover {
	background: var(--migcorp-accent-bright) !important;
	transform: translateY(-2px) !important;
}

/* =========================================================================
   EDITORIAL UPGRADE PASS — restraint, scale, motion
   ========================================================================= */

:root {
	--migcorp-section-pad: clamp(96px, 12vw, 160px);
	--migcorp-container-max: 1320px;
	--migcorp-h1: clamp(2.75rem, 5vw + 1rem, 5.5rem);
	--migcorp-h2: clamp(2.25rem, 3vw + 1rem, 3.75rem);
	--migcorp-shadow-card:  0 1px 0 var(--migcorp-border-light);
	--migcorp-shadow-pop:   0 8px 32px rgba(10, 20, 40, 0.10);
	--migcorp-shadow-hover: 0 16px 48px rgba(10, 20, 40, 0.14);
}

/* ---------- Section number eyebrow ("01 — About") ----------------------- */

.migcorp-section-num {
	display: inline-flex; align-items: center; gap: 14px;
	font-family: var(--migcorp-font-body);
	font-size: 12px; font-weight: 500;
	letter-spacing: 0.22em; text-transform: uppercase;
	color: var(--migcorp-gold);
	margin-bottom: 28px;
}
.migcorp-section-num::before {
	content: ""; display: block;
	width: 48px; height: 1px;
	background: currentColor;
	opacity: .8;
	transform-origin: left;
	animation: migcorp-rule-in 1s var(--migcorp-ease-out) both;
}
.migcorp-section-head-on-dark .migcorp-section-num,
.migcorp-section-ink   .migcorp-section-num { color: var(--migcorp-gold); }

@keyframes migcorp-rule-in { from { transform: scaleX(0); } to { transform: scaleX(1); } }

.migcorp-section-head { margin-bottom: clamp(48px, 6vw, 80px); }
.migcorp-section-head-row {
	grid-template-columns: 1fr;
}
@media (min-width: 1024px) {
	.migcorp-section-head-row { grid-template-columns: 1.4fr 1fr; align-items: end; gap: 64px; }
}
.migcorp-section-sub {
	font-size: 1.05rem; color: var(--migcorp-taupe);
	max-width: 44ch; margin: 0;
}
.migcorp-section-sub.migcorp-on-dark { color: var(--migcorp-beige); }
.migcorp-section-title {
	font-size: var(--migcorp-h2);
	letter-spacing: -0.025em;
	line-height: 1.02;
}

/* ---------- Override the older eyebrow look — cleaner --------------------- */

.migcorp-eyebrow {
	font-size: 11px;
	letter-spacing: 0.24em;
}
.migcorp-eyebrow::before { width: 28px; }
.migcorp-eyebrow-on-dark { color: var(--migcorp-gold); }

/* ---------- Hero v2 — editorial / cinematic ----------------------------- */

.migcorp-hero-cinema {
	min-height: clamp(700px, 95vh, 980px);
	display: flex; align-items: flex-end;
	padding: 64px 0 96px;
	background: var(--migcorp-ink);
	color: var(--migcorp-cream);
}
.migcorp-hero-cinema .migcorp-hero-overlay {
	/* Same stronger L→R navy curtain on the cinema variant. */
	background:
		linear-gradient(90deg,
			rgba(15, 45, 82, 1.0)  0%,
			rgba(15, 45, 82, 1.0)  30%,
			rgba(15, 45, 82, 0.92) 50%,
			rgba(15, 45, 82, 0.65) 70%,
			rgba(15, 45, 82, 0.25) 90%,
			rgba(15, 45, 82, 0.05) 100%),
		linear-gradient(180deg, transparent 55%, rgba(15, 45, 82, 0.55) 100%);
}
.migcorp-hero-media-gradient {
	background: radial-gradient(120% 80% at 20% 30%, rgba(229, 180, 80,0.18), transparent 60%),
	            radial-gradient(80% 60% at 90% 90%, rgba(139,115,85,0.35), transparent 60%),
	            var(--migcorp-ink);
}
.migcorp-hero-grain {
	position: absolute; inset: 0; pointer-events: none;
	opacity: .35;
	background-image: radial-gradient(rgba(245, 241, 237, 0.08) 1px, transparent 1px);
	background-size: 3px 3px;
	mix-blend-mode: overlay;
}
.migcorp-hero-mark {
	position: absolute; left: 32px; top: 50%;
	transform: rotate(-90deg) translateX(50%);
	transform-origin: left center;
	font-family: var(--migcorp-font-body);
	font-size: 11px; letter-spacing: 0.5em;
	color: var(--migcorp-gold);
	opacity: .55;
	pointer-events: none;
	z-index: 2;
}
@media (max-width: 1023px) {
	.migcorp-hero-mark { display: none; }
}

.migcorp-hero-inner {
	display: block;
	padding: 0;
	position: relative;
	z-index: 2;
}
.migcorp-hero-content { max-width: 1100px; }
.migcorp-hero-title {
	font-size: var(--migcorp-h1);
	letter-spacing: -0.035em;
	line-height: 0.98;
	font-weight: 700;
	margin: 0 0 32px;
	max-width: 18ch;
}

/* Kinetic reveal — uses CSS keyframe so words ALWAYS end up visible.
   No JS gating, no opacity:0 default, no LCP risk. The animation plays
   on mount and lands in the same state CSS would otherwise paint. */
.migcorp-kinetic-word {
	display: inline-block;
	margin-right: .25em;
	animation: migcorp-kinetic-in .9s var(--migcorp-ease-out) backwards;
	animation-delay: var(--migcorp-kinetic-delay, 0ms);
}
@keyframes migcorp-kinetic-in {
	from { opacity: 0; transform: translateY(40%) scale(0.98); }
	to   { opacity: 1; transform: none; }
}

[data-reveal-eyebrow], [data-reveal-sub], [data-reveal-cta] {
	animation: migcorp-fade-up .8s ease backwards;
}
[data-reveal-eyebrow] { animation-delay: 80ms; }
[data-reveal-sub]     { animation-delay: 500ms; }
[data-reveal-cta]     { animation-delay: 720ms; }
@keyframes migcorp-fade-up {
	from { opacity: 0; transform: translateY(16px); }
	to   { opacity: 1; transform: none; }
}

@media (prefers-reduced-motion: reduce) {
	.migcorp-kinetic-word,
	[data-reveal-eyebrow],
	[data-reveal-sub],
	[data-reveal-cta] { animation: none; }
}

.migcorp-hero-cinema .migcorp-hero-subtitle {
	font-size: clamp(1.05rem, 1vw + .8rem, 1.35rem);
	color: var(--migcorp-beige);
	max-width: 56ch;
	margin: 0 0 40px;
	line-height: 1.5;
}
.migcorp-hero-ctas { gap: 12px; display: flex; flex-wrap: wrap; align-items: center; }

/* Hero meta strip — three column credentials below CTAs.
   Comfortable margin so it doesn't read as a button overflow. */
.migcorp-hero-meta {
	display: grid;
	gap: 28px 48px;
	grid-template-columns: 1fr;
	margin-top: 88px;
	padding-top: 32px;
	border-top: 1px solid rgba(247, 247, 241, 0.14);
	max-width: 880px;
}
@media (min-width: 768px) {
	.migcorp-hero-meta { grid-template-columns: repeat(3, 1fr); }
}
.migcorp-hero-meta-item {
	display: flex; flex-direction: column; gap: 6px;
}
.migcorp-hero-meta-label {
	font-family: var(--migcorp-font-head);
	font-size: 10.5px;
	font-weight: 600;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--migcorp-accent);
	opacity: .9;
}
.migcorp-hero-meta-value {
	font-family: var(--migcorp-font-body);
	font-size: 14px;
	font-weight: 500;
	letter-spacing: 0.01em;
	color: var(--migcorp-cream);
	line-height: 1.35;
}

/* Drop the old scroll indicator from hero — replaced by the stats band below */
.migcorp-hero-scroll { display: none; }

/* The earlier editorial pass re-declared .migcorp-btn here; those rules are
   now superseded by the strict 2-button system in section 5. Block kept as
   anchor so future audits can tell the section boundary. */
.migcorp-btn-arrow { transition: transform .3s var(--migcorp-ease-out); display: inline-block; }
.migcorp-btn-ghost-light:hover .migcorp-btn-arrow { transform: translateX(6px); }

/* ---------- Quiet stats band (own section, under hero) ------------------- */

.migcorp-stats-band {
	background: var(--migcorp-cream);
	padding: clamp(48px, 6vw, 80px) 0;
	border-bottom: 1px solid var(--migcorp-border-light);
}
.migcorp-stats-band-grid {
	display: grid; gap: 32px;
	grid-template-columns: repeat(2, 1fr);
}
@media (min-width: 768px) { .migcorp-stats-band-grid { grid-template-columns: repeat(4, 1fr); } }
.migcorp-stat-cell {
	display: flex; flex-direction: column; gap: 12px;
	padding-top: 32px;
	position: relative;
}
.migcorp-stat-rule {
	position: absolute; top: 0; left: 0; right: 0; height: 2px;
	background: var(--migcorp-accent);
	transform: scaleX(0); transform-origin: left;
	transition: transform 1s var(--migcorp-ease-out);
	transition-delay: var(--migcorp-stat-delay, 0ms);
}
.is-revealed .migcorp-stat-rule { transform: scaleX(1); }
.migcorp-stat-num {
	font-family: var(--migcorp-font-display); font-weight: 700;
	font-size: clamp(2.5rem, 3.5vw, 4.25rem);
	color: var(--migcorp-ink); line-height: 1;
	letter-spacing: -0.02em;
}
.migcorp-stat-label {
	font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase;
	color: var(--migcorp-taupe); font-weight: 500;
}

/* Hide the old in-hero stats — moved to its own section */
.migcorp-hero-stats { display: none !important; }

/* ---------- Bento grid for verticals ------------------------------------- */

.migcorp-bento {
	display: grid; gap: 24px;
	grid-template-columns: 1fr;
	align-items: stretch;
}
@media (min-width: 1024px) {
	.migcorp-bento { grid-template-columns: 1.1fr 1fr; gap: 32px; }
}
.migcorp-bento-feature {
	position: relative; overflow: hidden;
	border-radius: 2px;
	min-height: 560px;
	background: var(--migcorp-ink);
	color: var(--migcorp-cream);
	display: flex; align-items: flex-end;
}
.migcorp-bento-feature-media { position: absolute; inset: 0; z-index: 0; }
.migcorp-bento-feature-media img {
	position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover;
	opacity: 0; transition: opacity .7s var(--migcorp-ease-out), transform 8s linear;
}
.migcorp-bento-feature-media img.is-active { opacity: 1; transform: scale(1.05); }
.migcorp-bento-feature-overlay {
	position: absolute; inset: 0; z-index: 1;
	background: linear-gradient(180deg, rgba(10, 20, 40, 0.15) 0%, rgba(10, 20, 40, 0.85) 75%, rgba(10, 20, 40, 0.95) 100%);
}
.migcorp-bento-feature-body {
	position: relative; z-index: 2;
	padding: 48px;
	max-width: 520px;
}
.migcorp-bento-feature-title {
	font-family: var(--migcorp-font-display);
	font-size: clamp(2rem, 2.5vw + .5rem, 2.75rem);
	font-weight: 700; letter-spacing: -0.025em;
	color: var(--migcorp-cream);
	margin: 16px 0 12px;
}
.migcorp-bento-feature-summary { color: var(--migcorp-beige); font-size: 1rem; line-height: 1.55; margin: 0 0 24px; max-width: 38ch; }

.migcorp-bento-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 0; }
.migcorp-bento-row { position: relative; border-bottom: 1px solid var(--migcorp-border-light); transition: background .3s; }
.migcorp-bento-row:first-child { border-top: 1px solid var(--migcorp-border-light); }
.migcorp-bento-row.is-active { background: rgba(229, 180, 80, 0.06); }
.migcorp-bento-row-link {
	display: grid; grid-template-columns: 56px 56px 1fr auto;
	align-items: center; gap: 24px;
	padding: 28px 8px;
	text-decoration: none; color: var(--migcorp-ink);
	transition: padding .3s var(--migcorp-ease-out);
}
.migcorp-bento-row:hover .migcorp-bento-row-link,
.migcorp-bento-row.is-active .migcorp-bento-row-link { padding-left: 24px; }
.migcorp-bento-row-num {
	font-family: var(--migcorp-font-display); font-size: 1.5rem; font-weight: 700;
	color: var(--migcorp-taupe);
	transition: color .25s;
}
.migcorp-bento-row.is-active .migcorp-bento-row-num,
.migcorp-bento-row:hover    .migcorp-bento-row-num { color: var(--migcorp-gold); }
.migcorp-bento-row-icon { color: var(--migcorp-taupe); transition: color .25s; }
.migcorp-bento-row.is-active .migcorp-bento-row-icon,
.migcorp-bento-row:hover    .migcorp-bento-row-icon { color: var(--migcorp-gold); }
.migcorp-bento-row-title {
	font-family: var(--migcorp-font-display); font-size: 1.4rem; font-weight: 700;
	letter-spacing: -0.015em; margin: 0 0 4px; color: var(--migcorp-ink);
}
.migcorp-bento-row-summary { font-size: 13px; color: var(--migcorp-taupe); margin: 0; line-height: 1.5; }
.migcorp-bento-row-cta { color: var(--migcorp-gold); transition: transform .25s; }
.migcorp-bento-row:hover .migcorp-bento-row-cta { transform: translateX(4px); }
.migcorp-bento-row.is-coming .migcorp-bento-row-num { color: var(--migcorp-taupe); opacity: .6; }

/* ---------- Hide the old verticals card grid (we replaced with bento) ---- */
.migcorp-verticals-grid { display: none; }

/* ---------- Real SVG world map ------------------------------------------- */

.migcorp-world-map {
	position: relative;
	margin: 0 auto;
	max-width: 1200px;
}
.migcorp-world-map-svg {
	width: 100%; height: auto;
	display: block;
}
.migcorp-world-map-stats {
	position: absolute; right: 0; top: 0;
	display: flex; flex-direction: column; gap: 24px;
	min-width: 180px;
	padding: 24px;
	background: rgba(10, 20, 40, 0.6);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	border-left: 1px solid var(--migcorp-gold);
}
@media (max-width: 767px) {
	.migcorp-world-map-stats { position: relative; flex-direction: row; flex-wrap: wrap; margin-top: 16px; }
}
.migcorp-world-map-stat { display: flex; flex-direction: column; gap: 4px; }
.migcorp-world-map-stat-num {
	font-family: var(--migcorp-font-display); font-weight: 700;
	font-size: 2.25rem; color: var(--migcorp-gold); line-height: 1;
}
.migcorp-world-map-stat-label {
	font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase;
	color: var(--migcorp-beige);
}

.migcorp-pin { transform-origin: center; opacity: 0; transition: opacity .6s ease; transition-delay: var(--pin-delay, 0ms); }
.is-revealed .migcorp-pin { opacity: 1; }
.migcorp-pin-pulse {
	transform-origin: center;
	animation: migcorp-pulse-pin 2.6s ease-out infinite;
	animation-delay: var(--pin-delay, 0ms);
}
.migcorp-pin.is-hq .migcorp-pin-pulse { animation-duration: 1.8s; }
@keyframes migcorp-pulse-pin {
	0%   { transform: scale(0.4); opacity: .9; }
	70%  { transform: scale(2.2); opacity: 0; }
	100% { transform: scale(2.2); opacity: 0; }
}

.migcorp-office-chips {
	margin-top: 48px;
	display: flex; flex-wrap: wrap; gap: 8px 10px;
}
.migcorp-office-chip {
	display: inline-flex; align-items: center; gap: 6px;
	padding: 8px 14px;
	border: 1px solid rgba(245, 241, 237, 0.18);
	border-radius: 2px;
	font-size: 12px; letter-spacing: 0.06em;
	color: var(--migcorp-beige);
	background: transparent;
	transition: all .25s;
}
.migcorp-office-chip:hover { border-color: var(--migcorp-gold); color: var(--migcorp-gold); }
.migcorp-office-chip.is-hq { border-color: var(--migcorp-gold); color: var(--migcorp-gold); }
.migcorp-office-chip small {
	font-size: 9px; letter-spacing: 0.15em;
	padding: 2px 5px; background: var(--migcorp-gold); color: var(--migcorp-ink);
	border-radius: 1px;
}
/* Hide the older placeholder map block */
.migcorp-home-global-grid { display: none; }

/* ---------- Insights magazine (1 lead + 2 side) ------------------------- */

/* Insights deck — uniform 3-up editorial cards with numbered eyebrows + gold rule.
   Replaces the asymmetric magazine layout that read as uneven. */
.migcorp-insights-deck {
	display: grid;
	gap: 32px;
	grid-template-columns: 1fr;
}
@media (min-width: 768px)  { .migcorp-insights-deck { grid-template-columns: repeat(2, 1fr); gap: 28px; } }
@media (min-width: 1024px) { .migcorp-insights-deck { grid-template-columns: repeat(3, 1fr); gap: 32px; } }

.migcorp-insight-card { display: flex; }
.migcorp-insight-card-link {
	position: relative;
	display: flex; flex-direction: column;
	width: 100%;
	background: var(--migcorp-white, #fff);
	border: 1px solid var(--migcorp-line);
	text-decoration: none; color: inherit;
	overflow: hidden;
	transition: transform .35s var(--migcorp-ease-out), border-color .35s, box-shadow .35s;
}
.migcorp-insight-card-link:hover {
	transform: translateY(-4px);
	border-color: rgba(229, 180, 80, 0.4);
	box-shadow: 0 24px 48px -20px rgba(10, 31, 60, 0.18);
}

/* Gold rule animates from 32px → 100% on hover */
.migcorp-insight-card-rule {
	position: absolute; top: 0; left: 0;
	width: 32px; height: 2px;
	background: var(--migcorp-gold);
	transition: width .45s var(--migcorp-ease-out);
	z-index: 2;
}
.migcorp-insight-card-link:hover .migcorp-insight-card-rule { width: 100%; }

/* Numbered eyebrow — sits opposite the gold rule */
.migcorp-insight-card-num {
	position: absolute; top: 20px; right: 24px;
	font-family: var(--migcorp-font-display);
	font-size: 12px; letter-spacing: 0.16em;
	color: var(--migcorp-gold);
	font-weight: 600;
	z-index: 2;
}

.migcorp-insight-card-media {
	position: relative;
	aspect-ratio: 16 / 10;
	overflow: hidden;
	background: var(--migcorp-beige);
	display: flex; align-items: center; justify-content: center;
}
.migcorp-insight-card-img {
	width: 100%; height: 100%; object-fit: cover;
	transition: transform .7s var(--migcorp-ease-out);
}
.migcorp-insight-card-link:hover .migcorp-insight-card-img { transform: scale(1.05); }
.migcorp-insight-placeholder { color: var(--migcorp-taupe); }

/* Category tag floats on the bottom-left of the media */
.migcorp-insight-card-tag {
	position: absolute; left: 16px; bottom: 16px;
	font-family: var(--migcorp-font-body);
	font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase;
	font-weight: 600;
	color: var(--migcorp-dark);
	background: var(--migcorp-gold);
	padding: 6px 12px;
	z-index: 2;
}

.migcorp-insight-card-body {
	display: flex; flex-direction: column;
	gap: 12px;
	padding: 24px 24px 28px;
	flex: 1 1 auto;
}
.migcorp-insight-card-meta {
	display: inline-flex; align-items: center; gap: 8px;
	font-family: var(--migcorp-font-body);
	font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase;
	color: var(--migcorp-muted);
	font-weight: 500;
}
.migcorp-insight-card-meta-sep { opacity: .5; }
.migcorp-insight-card-title {
	font-family: var(--migcorp-font-display);
	font-size: clamp(1.125rem, 1vw + 0.75rem, 1.375rem);
	font-weight: 700; letter-spacing: -0.015em; line-height: 1.25;
	color: var(--migcorp-ink);
	margin: 0;
	display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical;
	overflow: hidden;
	min-height: calc(1.25em * 3);
}
.migcorp-insight-card-link:hover .migcorp-insight-card-title { color: var(--migcorp-gold-700); }
.migcorp-insight-card-excerpt {
	color: var(--migcorp-taupe);
	margin: 0;
	font-size: 14px;
	line-height: 1.6;
	display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
	overflow: hidden;
}
.migcorp-insight-card-cta {
	margin-top: auto;
	padding-top: 16px;
	display: inline-flex; align-items: center; gap: 8px;
	font-family: var(--migcorp-font-body);
	font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase;
	font-weight: 600;
	color: var(--migcorp-gold-700);
	transition: gap .3s var(--migcorp-ease-out);
}
.migcorp-insight-card-link:hover .migcorp-insight-card-cta { gap: 14px; color: var(--migcorp-gold); }

/* Legacy classes kept hidden so any cached selectors don't break layout */
.migcorp-insights-mag,
.migcorp-insights-grid { display: none; }

/* ---------- Scrollspy side rail ----------------------------------------- */

.migcorp-scrollspy {
	position: fixed; right: 32px; top: 50%;
	transform: translateY(-50%);
	z-index: 60;
	display: none;
}
@media (min-width: 1280px) {
	.migcorp-scrollspy { display: block; }
}
.migcorp-scrollspy-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 14px; }
.migcorp-scrollspy-item {
	display: flex; align-items: center; gap: 12px;
	cursor: pointer; user-select: none;
}
.migcorp-scrollspy-dot {
	width: 7px; height: 7px; border-radius: 50%;
	border: 1px solid var(--migcorp-taupe);
	background: transparent;
	transition: all .35s var(--migcorp-ease-out);
	flex-shrink: 0;
}
.migcorp-scrollspy-item.is-active .migcorp-scrollspy-dot {
	background: var(--migcorp-gold);
	border-color: var(--migcorp-gold);
	transform: scale(1.6);
	box-shadow: 0 0 0 4px rgba(229, 180, 80, 0.15);
}
.migcorp-scrollspy-label {
	font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase;
	color: var(--migcorp-taupe);
	opacity: 0; transform: translateX(-4px);
	transition: opacity .25s, transform .25s, color .25s;
	pointer-events: none;
	white-space: nowrap;
}
.migcorp-scrollspy-item:hover .migcorp-scrollspy-label,
.migcorp-scrollspy-item.is-active .migcorp-scrollspy-label {
	opacity: 1; transform: none;
}
.migcorp-scrollspy-item.is-active .migcorp-scrollspy-label { color: var(--migcorp-gold); }

/* ---------- Schedule a Briefing launcher + panel ----------------------- */

.migcorp-chatbot-launcher { display: none; } /* old stub */

.migcorp-briefing-launcher {
	position: fixed; right: 24px; bottom: 24px; z-index: 70;
	display: inline-flex; align-items: center; gap: 14px;
	padding: 14px 22px 14px 18px;
	background: var(--migcorp-ink);
	color: var(--migcorp-cream);
	border: 1px solid var(--migcorp-gold);
	border-radius: 999px;
	cursor: pointer;
	box-shadow: 0 12px 32px rgba(10, 20, 40, 0.25);
	transition: all .25s var(--migcorp-ease-out);
}
.migcorp-briefing-launcher:hover { background: var(--migcorp-gold); color: var(--migcorp-ink); transform: translateY(-2px); }
.migcorp-briefing-launcher:hover .migcorp-briefing-launcher-pulse { background: var(--migcorp-ink); }
.migcorp-briefing-launcher:hover small { color: var(--migcorp-ink-2); }
.migcorp-briefing-launcher-pulse {
	position: relative; display: inline-block;
	width: 10px; height: 10px; border-radius: 50%;
	background: var(--migcorp-gold);
	flex-shrink: 0;
}
.migcorp-briefing-launcher-pulse::after {
	content: ""; position: absolute; inset: -3px;
	border-radius: 50%; border: 1px solid var(--migcorp-gold);
	animation: migcorp-pulse-ring 1.8s ease-out infinite;
}
@keyframes migcorp-pulse-ring {
	0%   { transform: scale(.6); opacity: 1; }
	100% { transform: scale(2);  opacity: 0; }
}
.migcorp-briefing-launcher-text { display: flex; flex-direction: column; line-height: 1.1; text-align: left; }
.migcorp-briefing-launcher-text small { font-size: 9.5px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--migcorp-beige); }
.migcorp-briefing-launcher-text strong { font-size: 13px; letter-spacing: 0.04em; font-weight: 600; }
@media (max-width: 540px) {
	.migcorp-briefing-launcher-text small { display: none; }
}

.migcorp-briefing-backdrop {
	position: fixed; inset: 0; z-index: 195;
	background: rgba(10, 20, 40, 0.6);
	opacity: 0; pointer-events: none;
	transition: opacity .35s ease;
}
.migcorp-briefing-backdrop.is-visible { opacity: 1; pointer-events: auto; }

.migcorp-briefing-panel {
	position: fixed; top: 0; right: 0; bottom: 0;
	width: 100%; max-width: 480px;
	background: var(--migcorp-cream);
	z-index: 200;
	transform: translateX(110%);
	transition: transform .45s var(--migcorp-ease-out);
	overflow-y: auto;
	box-shadow: -16px 0 64px rgba(10, 20, 40, 0.25);
	border-left: 1px solid var(--migcorp-gold);
}
.migcorp-briefing-panel.is-open { transform: translateX(0); }
.migcorp-briefing-panel-inner { padding: 56px 40px 40px; position: relative; }
.migcorp-briefing-close {
	position: absolute; top: 16px; right: 16px;
	background: transparent; border: 1px solid var(--migcorp-border-light);
	width: 40px; height: 40px; border-radius: 50%;
	display: inline-flex; align-items: center; justify-content: center;
	cursor: pointer; color: var(--migcorp-taupe);
	transition: all .25s;
}
.migcorp-briefing-close:hover { background: var(--migcorp-ink); color: var(--migcorp-cream); border-color: var(--migcorp-ink); }
.migcorp-briefing-title {
	font-family: var(--migcorp-font-display);
	font-size: 2.25rem; letter-spacing: -0.025em; line-height: 1.05;
	margin: 12px 0 16px;
	color: var(--migcorp-ink);
}
.migcorp-briefing-sub { color: var(--migcorp-taupe); margin: 0 0 32px; line-height: 1.6; }
.migcorp-briefing-direct { display: grid; gap: 20px; margin: 0 0 32px; padding: 24px 0; border-top: 1px solid var(--migcorp-border-light); border-bottom: 1px solid var(--migcorp-border-light); }
.migcorp-briefing-direct dt { font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--migcorp-gold); margin-bottom: 4px; }
.migcorp-briefing-direct dd { margin: 0; font-size: 1rem; color: var(--migcorp-ink); }
.migcorp-briefing-direct dd a { color: inherit; text-decoration: none; border-bottom: 1px solid var(--migcorp-gold); }
.migcorp-briefing-direct dd span { font-size: 13px; color: var(--migcorp-taupe); }
.migcorp-briefing-hint { font-size: 13px; color: var(--migcorp-taupe); }
.migcorp-briefing-disclaimer {
	margin-top: 32px; padding-top: 24px;
	border-top: 1px solid var(--migcorp-border-light);
	font-size: 11px; line-height: 1.7; color: var(--migcorp-taupe); opacity: .8;
}

/* ---------- Section-head tweaks for the dark/light split ---------------- */

.migcorp-home-global .migcorp-section-head-row { gap: 32px; }
.migcorp-home-global .migcorp-section-num { margin-bottom: 24px; }

/* ---------- Tighten card shadows + general polish ----------------------- */

.migcorp-home-about-img { box-shadow: var(--migcorp-shadow-pop); }
.migcorp-vertical-card { display: none; } /* old card grid replaced */

.migcorp-final-cta { padding: clamp(80px, 9vw, 128px) 0; }
.migcorp-home-bond { padding: var(--migcorp-section-pad) 0; }

/* ---------- More rhythm — bigger section padding ----------------------- */

.migcorp-section { padding: var(--migcorp-section-pad) 0; }
.migcorp-section-tight { padding: 28px 0; }

/* ---------- Compact sticky header on scroll ---------------------------- */

.migcorp-site-header { transition: box-shadow .3s ease; }
body.is-scrolled .migcorp-site-header { box-shadow: 0 2px 24px rgba(10, 20, 40, 0.08); }
body.is-scrolled .migcorp-header-bar-inner { min-height: 64px; transition: min-height .25s; }
body.is-scrolled .migcorp-utility-bar { display: none; }

/* ---------- Dark-mode tuning for the new components -------------------- */

html.dark .migcorp-stats-band { background: var(--migcorp-ink); }
html.dark .migcorp-stat-num { color: var(--migcorp-cream); }
html.dark .migcorp-bento-row-link { color: var(--migcorp-cream); }
html.dark .migcorp-bento-row-title { color: var(--migcorp-cream); }
html.dark .migcorp-bento-row { border-color: rgba(245,241,237,0.08); }
html.dark .migcorp-briefing-panel { background: var(--migcorp-ink-2); }
html.dark .migcorp-briefing-title { color: var(--migcorp-cream); }
html.dark .migcorp-briefing-direct dd { color: var(--migcorp-cream); }

/* =========================================================================
   PREMIUM HEADER + FOOTER PASS
   ========================================================================= */

/* ---------- Brand mark — JPEG with white bg treatment ------------------- */

.migcorp-brand { display: inline-flex; align-items: center; line-height: 0; text-decoration: none; }
.migcorp-brand-mark { display: block; width: auto; max-width: 100%; height: auto; }

/* Header (cream bg) — drop the white JPEG background, keep navy ink */
.migcorp-brand-jpeg.migcorp-brand-dark .migcorp-brand-mark {
	max-height: 56px;
	mix-blend-mode: multiply;
}
/* Footer / drawer (brown bg) — invert JPEG to a cream silhouette */
.migcorp-brand-jpeg.migcorp-brand-light .migcorp-brand-mark {
	max-height: 64px;
	filter: brightness(0) invert(1);
	opacity: .95;
}

/* Non-JPEG variants (Customizer upload — SVG/PNG) */
.migcorp-brand-dark .migcorp-brand-mark.is-custom { max-height: 56px; }
.migcorp-brand-light .migcorp-brand-mark.is-custom { max-height: 56px; }

/* ---------- Site header — premium pass --------------------------------- */

.migcorp-site-header {
	background: var(--migcorp-cream);
	box-shadow: none;
	border-bottom: 1px solid transparent;
	transition: border-color .3s, box-shadow .3s;
}
body.is-scrolled .migcorp-site-header {
	border-bottom-color: var(--migcorp-border-light);
	box-shadow: 0 1px 0 var(--migcorp-border-light);
}

/* Utility bar — slimmer, dot indicator instead of icon */
.migcorp-utility-bar {
	font-size: 11px;
	letter-spacing: 0.06em;
	border-bottom: 1px solid rgba(245, 241, 237, 0.06);
}
.migcorp-utility-bar-inner { min-height: 36px; padding-top: 4px; padding-bottom: 4px; gap: 16px; }
.migcorp-utility-left, .migcorp-utility-right { gap: 16px; }
.migcorp-utility-sep { width: 1px; height: 12px; background: rgba(245, 241, 237, 0.18); }
.migcorp-utility-reg { gap: 8px; padding: 4px 0; }
.migcorp-utility-reg-dot {
	display: inline-block; width: 6px; height: 6px; border-radius: 50%;
	background: var(--migcorp-gold);
	box-shadow: 0 0 0 0 rgba(229, 180, 80, 0.6);
	animation: migcorp-utility-pulse 2.4s ease-out infinite;
}
@keyframes migcorp-utility-pulse {
	0% { box-shadow: 0 0 0 0 rgba(229, 180, 80, 0.6); }
	70% { box-shadow: 0 0 0 6px rgba(229, 180, 80, 0); }
	100% { box-shadow: 0 0 0 0 rgba(229, 180, 80, 0); }
}
.migcorp-utility-audience { color: rgba(245, 241, 237, 0.55); }
.migcorp-utility-lp { gap: 6px; color: var(--migcorp-gold); }
.migcorp-utility-lp:hover { color: var(--migcorp-cream); }
.migcorp-utility-lp svg { transition: transform .25s var(--migcorp-ease-out); }
.migcorp-utility-lp:hover svg { transform: translate(2px, -2px); }

.migcorp-theme-toggle {
	border: 0;
	background: transparent;
	color: var(--migcorp-beige);
	padding: 4px;
	display: inline-flex;
	border-radius: 0;
}
.migcorp-theme-toggle:hover { color: var(--migcorp-gold); }

@media (max-width: 767px) {
	.migcorp-utility-audience { display: none; }
}

/* Main bar — more generous */
.migcorp-header-bar { padding: 4px 0; }
.migcorp-header-bar-inner {
	min-height: 88px;
	gap: 48px;
}
body.is-scrolled .migcorp-header-bar-inner { min-height: 68px; }
body.is-scrolled .migcorp-brand-jpeg.migcorp-brand-dark .migcorp-brand-mark { max-height: 44px; }

.migcorp-primary-nav-list { gap: 36px; }
.migcorp-primary-nav-list > li > a {
	position: relative;
	display: inline-block;
	padding: 8px 0;
	font-size: 13px;
	font-weight: 500;
	letter-spacing: 0.02em;
	color: var(--migcorp-ink-2);
	border: 0;
	transition: color .25s;
}
/* Animated underline (wipes in from left) */
.migcorp-primary-nav-list > li > a::after {
	content: ""; position: absolute; left: 0; bottom: 0;
	width: 100%; height: 1px;
	background: var(--migcorp-gold);
	transform: scaleX(0); transform-origin: right;
	transition: transform .35s var(--migcorp-ease-out);
}
.migcorp-primary-nav-list > li > a:hover { color: var(--migcorp-ink); }
.migcorp-primary-nav-list > li > a:hover::after,
.migcorp-primary-nav-list > li.current-menu-item > a::after,
.migcorp-primary-nav-list > li.current_page_item > a::after {
	transform: scaleX(1); transform-origin: left;
}

/* Header CTA — gold pill, smaller and more refined */
.migcorp-header-cta {
	padding: 12px 22px;
	font-size: 11px;
	border-radius: 999px;
}
.migcorp-header-cta svg { color: currentColor; }

/* ---------- Mobile toggle — refined ------------------------------------ */

.migcorp-mobile-toggle {
	background: transparent;
	border: 0;
	color: var(--migcorp-ink);
	padding: 8px 4px;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	gap: 10px;
}
.migcorp-mobile-toggle-lines {
	position: relative;
	display: inline-block;
	width: 22px; height: 14px;
}
.migcorp-mobile-toggle-lines span {
	position: absolute; left: 0; right: 0; height: 1px;
	background: currentColor;
	transition: transform .35s var(--migcorp-ease-out), opacity .25s, top .25s;
}
.migcorp-mobile-toggle-lines span:nth-child(1) { top: 2px; }
.migcorp-mobile-toggle-lines span:nth-child(2) { top: 7px; }
.migcorp-mobile-toggle-lines span:nth-child(3) { top: 12px; }
body.migcorp-drawer-open .migcorp-mobile-toggle-lines span:nth-child(1) { top: 7px; transform: rotate(45deg); }
body.migcorp-drawer-open .migcorp-mobile-toggle-lines span:nth-child(2) { opacity: 0; }
body.migcorp-drawer-open .migcorp-mobile-toggle-lines span:nth-child(3) { top: 7px; transform: rotate(-45deg); }

.migcorp-mobile-toggle-label {
	font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase;
	color: var(--migcorp-ink-2); font-weight: 500;
}
.migcorp-mobile-toggle-close-text { display: none; }
body.migcorp-drawer-open .migcorp-mobile-toggle-open-text { display: none; }
body.migcorp-drawer-open .migcorp-mobile-toggle-close-text { display: inline; color: var(--migcorp-cream); }
body.migcorp-drawer-open .migcorp-mobile-toggle { color: var(--migcorp-cream); position: fixed; right: 20px; top: 24px; z-index: 220; }
@media (max-width: 767px) {
	.migcorp-mobile-toggle-label { display: none; }
}

/* ---------- Mobile drawer — premium full-screen ----------------------- */

.migcorp-mobile-drawer {
	position: fixed; inset: 0; z-index: 210;
	background: var(--migcorp-ink);
	color: var(--migcorp-cream);
	transform: translateY(-100%);
	transition: transform .55s var(--migcorp-ease-out);
	overflow-y: auto;
	padding: 0;
	display: flex; align-items: stretch;
}
body.migcorp-drawer-open .migcorp-mobile-drawer { transform: translateY(0); }
.migcorp-mobile-drawer::before {
	content: ""; position: absolute; inset: 0;
	background: radial-gradient(80% 60% at 100% 0%, rgba(229, 180, 80, 0.16), transparent 60%);
	pointer-events: none;
}
.migcorp-mobile-drawer-inner {
	width: 100%;
	max-width: var(--migcorp-container-max);
	margin: 0 auto;
	padding: 32px var(--migcorp-gutter) 40px;
	display: flex; flex-direction: column; justify-content: space-between;
	gap: 48px;
	position: relative;
}

.migcorp-mobile-drawer-top {
	display: flex; align-items: center; gap: 16px;
	padding-top: 8px;
	flex-wrap: wrap;
}
.migcorp-mobile-drawer-eyebrow {
	font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase;
	color: var(--migcorp-gold);
}

.migcorp-mobile-nav-list {
	list-style: none; margin: 0; padding: 0;
	display: flex; flex-direction: column; gap: 0;
}
.migcorp-mobile-nav-list > li {
	border-top: 1px solid rgba(245, 241, 237, 0.08);
	opacity: 0; transform: translateY(20px);
	transition: opacity .6s var(--migcorp-ease-out), transform .6s var(--migcorp-ease-out);
	transition-delay: var(--migcorp-mobile-delay, 0ms);
}
.migcorp-mobile-nav-list > li:last-child { border-bottom: 1px solid rgba(245, 241, 237, 0.08); }
body.migcorp-drawer-open .migcorp-mobile-nav-list > li { opacity: 1; transform: none; }

.migcorp-mobile-nav-list > li > a {
	display: grid;
	grid-template-columns: auto 1fr auto;
	align-items: center;
	gap: 24px;
	padding: 24px 4px;
	text-decoration: none;
	color: var(--migcorp-cream);
	transition: padding .35s var(--migcorp-ease-out);
}
.migcorp-mobile-nav-list > li > a:hover { padding-left: 16px; }
.migcorp-mobile-nav-num {
	font-family: var(--migcorp-font-body);
	font-size: 12px; letter-spacing: 0.2em;
	color: var(--migcorp-gold);
	font-feature-settings: "tnum";
}
.migcorp-mobile-nav-label {
	font-family: var(--migcorp-font-display);
	font-size: clamp(2rem, 6vw + 1rem, 3.5rem);
	font-weight: 700; letter-spacing: -0.025em;
	line-height: 1;
}
.migcorp-mobile-nav-list > li > a:hover .migcorp-mobile-nav-label { color: var(--migcorp-gold); }
.migcorp-mobile-nav-arrow {
	font-family: var(--migcorp-font-body);
	font-size: 20px; color: var(--migcorp-taupe);
	opacity: 0; transform: translateX(-8px);
	transition: opacity .3s, transform .3s, color .3s;
}
.migcorp-mobile-nav-list > li > a:hover .migcorp-mobile-nav-arrow { opacity: 1; transform: translateX(0); color: var(--migcorp-gold); }

.migcorp-mobile-drawer-footer {
	display: flex; flex-direction: column; gap: 20px;
	padding-top: 32px;
	border-top: 1px solid rgba(245, 241, 237, 0.08);
}
.migcorp-mobile-drawer-footer .migcorp-btn-block { justify-content: space-between; padding: 16px 22px; }
.migcorp-mobile-meta {
	display: grid; grid-template-columns: 1fr 1fr; gap: 24px;
	margin: 0; padding: 0;
}
.migcorp-mobile-meta dt {
	font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase;
	color: var(--migcorp-gold);
	margin-bottom: 4px;
}
.migcorp-mobile-meta dd { margin: 0; }
.migcorp-mobile-meta dd a {
	font-family: var(--migcorp-font-display);
	font-size: 1.1rem;
	color: var(--migcorp-cream);
	text-decoration: none;
	border-bottom: 1px solid var(--migcorp-gold);
	padding-bottom: 2px;
}
.migcorp-mobile-social {
	display: flex; gap: 14px;
}
.migcorp-mobile-social a {
	display: inline-flex; align-items: center; justify-content: center;
	width: 40px; height: 40px; border-radius: 50%;
	border: 1px solid rgba(229, 180, 80, 0.4);
	color: var(--migcorp-gold);
	transition: all .25s;
}
.migcorp-mobile-social a:hover { background: var(--migcorp-gold); color: var(--migcorp-ink); }

@media (min-width: 1024px) {
	.migcorp-mobile-drawer { display: none; } /* desktop nav handles it */
}

/* Override old eyebrow color on dark drawer */
.migcorp-mobile-drawer .migcorp-brand-mark { max-height: 48px; }

/* ---------- Site footer — premium pass --------------------------------- */

/* Footer band uses the same layered navy + gold gradient as ESG / Final-CTA
   so the bottom of the page reads as one coordinated atmosphere. */
.migcorp-site-footer {
	position: relative; overflow: hidden;
	background:
		radial-gradient(60% 40% at 50% 0%, rgba(229, 180, 80, 0.14) 0%, transparent 65%),
		radial-gradient(90% 70% at 15% 90%, rgba(31, 75, 124, 0.42) 0%, transparent 60%),
		radial-gradient(70% 60% at 90% 30%, rgba(26, 64, 112, 0.52) 0%, transparent 60%),
		linear-gradient(180deg, var(--migcorp-dark) 0%, var(--migcorp-dark-edge) 100%);
	color: var(--migcorp-beige);
	padding: 0;
}
/* Hairline gold rule at the very top */
.migcorp-site-footer::before {
	content: ""; position: absolute; top: 0; left: 0; right: 0; height: 1px;
	background: linear-gradient(90deg, transparent 0%, rgba(229, 180, 80, 0.6) 50%, transparent 100%);
	z-index: 2;
}
/* Bottom navy bleed for grounded base */
.migcorp-site-footer::after {
	content: ""; position: absolute; bottom: 0; left: 0; right: 0; height: 240px;
	background: linear-gradient(180deg, transparent 0%, rgba(10, 31, 60, 0.55) 100%);
	pointer-events: none; z-index: 0;
}

/* Reusable gold divider helper */
.migcorp-footer-divider {
	border-top: 1px solid rgba(229, 180, 80, 0.12);
	position: relative;
}
.migcorp-footer-divider::before {
	content: ""; position: absolute; top: -1px; left: 50%; transform: translateX(-50%);
	width: 240px; max-width: 60vw; height: 1px;
	background: linear-gradient(90deg, transparent 0%, var(--migcorp-gold) 50%, transparent 100%);
	opacity: .55;
}

/* 1. Statement strip */
.migcorp-footer-statement {
	padding: clamp(88px, 9vw, 128px) 0 clamp(56px, 6vw, 80px);
	border-bottom: 1px solid rgba(229, 180, 80, 0.10);
	position: relative;
}
.migcorp-footer-statement::after {
	content: ""; position: absolute; bottom: -1px; left: 50%; transform: translateX(-50%);
	width: 280px; max-width: 60vw; height: 1px;
	background: linear-gradient(90deg, transparent 0%, var(--migcorp-gold) 50%, transparent 100%);
	opacity: .5;
}
.migcorp-footer-section-num { color: var(--migcorp-gold); margin-bottom: 36px; }
.migcorp-footer-section-num::before { background: currentColor; }
.migcorp-footer-statement-text {
	font-family: var(--migcorp-font-display);
	font-size: clamp(1.75rem, 3vw + 1rem, 3.5rem);
	font-weight: 700;
	letter-spacing: -0.028em;
	line-height: 1.08;
	margin: 0 0 44px;
	max-width: 22ch;
	color: var(--migcorp-cream);
}
.migcorp-footer-statement-em {
	color: var(--migcorp-gold);
	font-style: italic;
	font-weight: 700;
	letter-spacing: -0.015em;
}
.migcorp-footer-statement-actions { display: flex; flex-wrap: wrap; gap: 20px; align-items: center; }

/* Single merged band — cols + legal sub-row inside one gradient surface */
.migcorp-footer-cols {
	padding: clamp(72px, 8vw, 112px) 0 clamp(24px, 3vw, 40px);
	position: relative;
}
.migcorp-footer-grid { display: none; } /* old grid replaced */
.migcorp-footer-cols-grid {
	display: grid; gap: 48px;
	grid-template-columns: 1fr;
}
@media (min-width: 768px)  { .migcorp-footer-cols-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .migcorp-footer-cols-grid { grid-template-columns: 1.8fr 1fr 1fr 1.4fr; gap: 64px; } }

.migcorp-footer-brand-col { display: flex; flex-direction: column; gap: 28px; }
.migcorp-footer-brand-col .migcorp-brand-jpeg .migcorp-brand-mark { max-height: 64px; }
.migcorp-footer-blurb { color: var(--migcorp-beige); font-size: 14px; line-height: 1.65; margin: 0; max-width: 38ch; }

.migcorp-footer-credentials {
	display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 20px;
	margin: 0; padding: 24px 0;
	border-top: 1px solid rgba(229, 180, 80, 0.14);
	border-bottom: 1px solid rgba(229, 180, 80, 0.14);
	background: linear-gradient(180deg, rgba(255,255,255,0.012) 0%, transparent 100%);
}
.migcorp-footer-credentials > div { display: flex; flex-direction: column; gap: 6px; }
.migcorp-footer-credentials dt {
	font-size: 10px; letter-spacing: 0.24em; text-transform: uppercase;
	color: var(--migcorp-gold);
	font-weight: 600;
}
.migcorp-footer-credentials dd {
	margin: 0;
	font-family: var(--migcorp-font-display);
	font-size: 1.05rem;
	color: var(--migcorp-cream);
	line-height: 1.25;
	letter-spacing: -0.01em;
}

.migcorp-footer-col-title {
	font-family: var(--migcorp-font-body);
	font-size: 11px; letter-spacing: 0.24em; text-transform: uppercase;
	color: var(--migcorp-gold);
	font-weight: 700;
	margin: 0 0 28px;
	padding-bottom: 18px;
	position: relative;
	border-bottom: 1px solid rgba(229, 180, 80, 0.18);
}
.migcorp-footer-col-title::after {
	content: ""; position: absolute; left: 0; bottom: -1px;
	width: 32px; height: 1px;
	background: var(--migcorp-gold);
}
.migcorp-footer-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 12px; }
.migcorp-footer-list a {
	font-size: 14px;
	color: var(--migcorp-beige);
	text-decoration: none;
	transition: color .2s, padding-left .25s;
}
.migcorp-footer-list a:hover { color: var(--migcorp-gold); padding-left: 6px; }
.migcorp-footer-empty { font-size: 13px; color: var(--migcorp-taupe); opacity: .7; }

.migcorp-footer-col-hq { display: flex; flex-direction: column; gap: 16px; }
.migcorp-footer-hq-city {
	font-family: var(--migcorp-font-display);
	font-size: 1.4rem;
	font-weight: 700;
	color: var(--migcorp-cream);
	margin: 0;
	letter-spacing: -0.01em;
	display: flex; align-items: center; gap: 12px;
	flex-wrap: wrap;
}
.migcorp-footer-hq-badge {
	background: var(--migcorp-gold);
	color: var(--migcorp-ink);
	padding: 2px 8px;
	border-radius: 2px;
	font-family: var(--migcorp-font-body);
	font-size: 10px; letter-spacing: 0.18em;
	font-weight: 600;
}
.migcorp-footer-hq-address {
	font-style: normal;
	font-size: 14px;
	line-height: 1.5;
	color: var(--migcorp-beige);
	margin: 0;
}
.migcorp-footer-direct {
	list-style: none; padding: 16px 0; margin: 0;
	border-top: 1px solid rgba(245, 241, 237, 0.08);
	display: grid; gap: 12px;
}
.migcorp-footer-direct li { display: flex; flex-direction: column; gap: 2px; }
.migcorp-footer-direct-label {
	font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase;
	color: var(--migcorp-gold);
}
.migcorp-footer-direct a {
	font-size: 14px;
	color: var(--migcorp-cream);
	text-decoration: none;
	border-bottom: 1px solid rgba(229, 180, 80, 0.3);
	padding-bottom: 2px;
	display: inline-block;
	transition: border-color .25s;
}
.migcorp-footer-direct a:hover { border-bottom-color: var(--migcorp-gold); }
.migcorp-footer-all-offices {
	display: inline-flex; align-items: center; gap: 8px;
	color: var(--migcorp-gold);
	font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase;
	text-decoration: none;
	margin-top: 8px;
	transition: gap .25s;
}
.migcorp-footer-all-offices:hover { gap: 14px; }

/* 3. Newsletter band */
.migcorp-footer-newsletter {
	padding: clamp(56px, 6vw, 84px) 0;
	border-bottom: 1px solid rgba(229, 180, 80, 0.10);
	position: relative;
	background: linear-gradient(180deg, rgba(229, 180, 80, 0.025) 0%, transparent 100%);
}
.migcorp-footer-newsletter::after {
	content: ""; position: absolute; bottom: -1px; left: 50%; transform: translateX(-50%);
	width: 280px; max-width: 60vw; height: 1px;
	background: linear-gradient(90deg, transparent 0%, var(--migcorp-gold) 50%, transparent 100%);
	opacity: .5;
}
.migcorp-footer-newsletter-grid {
	display: grid; gap: 32px;
	grid-template-columns: 1fr;
	align-items: center;
}
@media (min-width: 1024px) { .migcorp-footer-newsletter-grid { grid-template-columns: 1.3fr 1fr; gap: 64px; } }
.migcorp-footer-newsletter-title {
	font-family: var(--migcorp-font-display);
	font-size: clamp(1.5rem, 1.5vw + 1rem, 2.25rem);
	font-weight: 700; letter-spacing: -0.02em;
	color: var(--migcorp-cream);
	margin: 12px 0 8px; line-height: 1.15;
	max-width: 22ch;
}
.migcorp-footer-newsletter-sub { color: var(--migcorp-beige); font-size: 14px; line-height: 1.55; margin: 0; max-width: 50ch; }
.migcorp-footer-newsletter-fallback {
	display: grid; gap: 12px;
	grid-template-columns: 1fr auto;
}
.migcorp-footer-newsletter-fallback input {
	background: rgba(255, 255, 255, 0.04);
	border: 1px solid rgba(229, 180, 80, 0.22);
	color: var(--migcorp-cream);
	padding: 18px 20px;
	font-family: var(--migcorp-font-body);
	font-size: 14px;
	letter-spacing: 0.02em;
	border-radius: 2px;
	transition: border-color .25s, background .25s;
}
.migcorp-footer-newsletter-fallback input:hover,
.migcorp-footer-newsletter-fallback input:focus {
	border-color: var(--migcorp-gold);
	background: rgba(255, 255, 255, 0.06);
	outline: none;
}
.migcorp-footer-newsletter-fallback input::placeholder { color: rgba(245, 241, 237, 0.45); }
.migcorp-footer-newsletter-fallback small {
	grid-column: 1 / -1;
	font-size: 11px;
	color: var(--migcorp-taupe);
	opacity: .7;
	letter-spacing: 0.02em;
}

/* Footer text wordmark — replaces the JPEG-with-invert that produced a white block */
.migcorp-footer-wordmark {
	display: inline-flex; flex-direction: column;
	text-decoration: none; line-height: 1;
	margin-bottom: 4px;
}
.migcorp-footer-wordmark-mig {
	font-family: var(--migcorp-font-display);
	font-weight: 700;
	font-size: clamp(1.875rem, 2.4vw + 1rem, 2.625rem);
	letter-spacing: -0.02em;
	color: var(--migcorp-gold);
}
.migcorp-footer-wordmark-sub {
	font-family: var(--migcorp-font-body);
	font-size: 11px; letter-spacing: 0.32em; text-transform: uppercase;
	color: var(--migcorp-cream);
	font-weight: 500;
	margin-top: 10px;
}

/* Legal sub-row — sits inside the same gradient band as the cols */
.migcorp-footer-legal-row {
	margin-top: clamp(48px, 5vw, 72px);
	padding-top: 28px;
	border-top: 1px solid rgba(229, 180, 80, 0.14);
	position: relative;
}
.migcorp-footer-legal-row::before {
	content: ""; position: absolute; top: -1px; left: 0;
	width: 64px; height: 1px;
	background: var(--migcorp-gold);
}
.migcorp-footer-legal-grid {
	display: flex; align-items: center; flex-wrap: wrap; gap: 16px 28px;
	justify-content: space-between;
}
.migcorp-footer-copyright {
	font-size: 11px;
	color: var(--migcorp-cream);
	opacity: .7;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	font-weight: 500;
}
.migcorp-footer-legal {
	list-style: none; padding: 0; margin: 0;
	display: flex; flex-wrap: wrap; gap: 24px;
}
.migcorp-footer-legal a {
	color: var(--migcorp-cream); font-size: 11px;
	text-decoration: none; letter-spacing: 0.08em;
	text-transform: uppercase;
	opacity: .7; transition: opacity .2s, color .2s;
}
.migcorp-footer-legal a:hover { opacity: 1; color: var(--migcorp-gold); }
.migcorp-footer-social {
	list-style: none; padding: 0; margin: 0;
	display: flex; gap: 10px;
}
.migcorp-footer-social a {
	width: 34px; height: 34px; border-radius: 50%;
	display: inline-flex; align-items: center; justify-content: center;
	color: var(--migcorp-cream);
	background: rgba(255, 255, 255, 0.03);
	border: 1px solid rgba(229, 180, 80, 0.22);
	transition: all .3s var(--migcorp-ease-out);
}
.migcorp-footer-social a:hover {
	color: var(--migcorp-dark);
	background: var(--migcorp-gold);
	border-color: var(--migcorp-gold);
	transform: translateY(-2px);
}
.migcorp-footer-disclaimer {
	margin: 28px 0 0;
	padding-top: 24px;
	border-top: 1px solid rgba(229, 180, 80, 0.10);
	font-size: 11px;
	line-height: 1.75;
	color: var(--migcorp-cream);
	opacity: .55;
	max-width: 90ch;
	font-style: italic;
}

/* Footer — small-screen polish */
@media (max-width: 720px) {
	.migcorp-footer-cols { padding-top: 56px; padding-bottom: 24px; }
	.migcorp-footer-credentials {
		grid-template-columns: 1fr 1fr;
		gap: 16px;
	}
	.migcorp-footer-credentials > div:last-child { grid-column: 1 / -1; }
	.migcorp-footer-legal-grid {
		flex-direction: column; align-items: flex-start; gap: 20px;
	}
	.migcorp-footer-legal { gap: 16px; }
	.migcorp-footer-wordmark-mig { font-size: clamp(1.75rem, 8vw, 2.25rem); }
	.migcorp-footer-monogram { right: -8vw; bottom: -8vw; }
	.migcorp-footer-monogram span { font-size: clamp(7rem, 30vw, 11rem); }
}

/* 5. Oversized monogram — quiet italic brand watermark */
.migcorp-footer-monogram {
	position: absolute;
	right: -3vw; bottom: -5vw;
	pointer-events: none;
	z-index: 0;
}
.migcorp-footer-monogram span {
	display: block;
	font-family: var(--migcorp-font-display);
	font-weight: 700;
	font-style: italic;
	font-size: clamp(9rem, 24vw, 26rem);
	letter-spacing: -0.05em;
	line-height: 0.82;
	color: var(--migcorp-gold);
	opacity: 0.045;
}
.migcorp-footer-monogram small {
	font-size: .55em;
	color: var(--migcorp-gold);
	opacity: 1;
	font-style: normal;
	margin: 0 .02em;
}
.migcorp-site-footer > * { position: relative; z-index: 1; }

/* ---------- Override old footer-grid styles (clean slate) -------------- */

.migcorp-footer-brand,
.migcorp-footer-col,
.migcorp-footer-bottom .migcorp-footer-legal,
.migcorp-footer-bottom .migcorp-footer-copyright { /* still present for inner-page footer if used */ }

/* Hide old big shadow on header */
.migcorp-site-header { box-shadow: none; }
body.is-scrolled .migcorp-site-header { box-shadow: 0 1px 0 var(--migcorp-border-light); }

/* =========================================================================
   GLOBAL DESK — editorial regional rows (replaces the old SVG map block)
   ========================================================================= */

.migcorp-desk { background: var(--migcorp-white); }
.migcorp-desk-list {
	list-style: none;
	margin: 0;
	padding: 0;
	border-top: 1px solid var(--migcorp-line);
}

.migcorp-desk-row {
	display: grid;
	grid-template-columns: 64px 1fr auto 32px;
	gap: 24px;
	align-items: center;
	padding: 36px 0;
	border-bottom: 1px solid var(--migcorp-line);
	position: relative;
	transition: padding-left .35s var(--migcorp-ease-out);
}
.migcorp-desk-row::before {
	content: "";
	position: absolute;
	left: 0; bottom: -1px;
	height: 1px;
	width: 0;
	background: var(--migcorp-accent);
	transition: width .5s var(--migcorp-ease-out);
}
.migcorp-desk-row:hover {
	padding-left: 12px;
}
.migcorp-desk-row:hover::before { width: 100%; }

@media (max-width: 768px) {
	.migcorp-desk-row {
		grid-template-columns: 48px 1fr;
		grid-template-areas:
			"num   body"
			"num   stat";
		gap: 16px;
		padding: 28px 0;
	}
	.migcorp-desk-row-num   { grid-area: num; }
	.migcorp-desk-row-body  { grid-area: body; }
	.migcorp-desk-row-stat  { grid-area: stat; justify-self: start; flex-direction: row; gap: 12px; align-items: baseline; }
	.migcorp-desk-row-arrow { display: none; }
}

.migcorp-desk-row-num {
	font-family: var(--migcorp-font-head);
	font-size: 14px;
	font-weight: 600;
	letter-spacing: 0.16em;
	color: var(--migcorp-muted);
	font-feature-settings: "tnum";
}

.migcorp-desk-row-label {
	font-family: var(--migcorp-font-display);
	font-size: clamp(1.6rem, 1.5vw + 1rem, 2.2rem);
	font-weight: 400;
	letter-spacing: -0.02em;
	line-height: 1.1;
	color: var(--migcorp-ink);
	margin: 0 0 8px;
}
.migcorp-desk-row-cities {
	font-family: var(--migcorp-font-body);
	font-size: 0.95rem;
	color: var(--migcorp-ink-2);
	margin: 0 0 4px;
	font-feature-settings: "ss01";
	letter-spacing: 0.005em;
}
.migcorp-desk-row-cities-empty { color: var(--migcorp-muted); font-style: italic; }
.migcorp-desk-row-note {
	font-family: var(--migcorp-font-head);
	font-size: 11.5px;
	font-weight: 500;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--migcorp-primary-deep);
	margin: 0;
}

.migcorp-desk-row-stat {
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	gap: 2px;
	min-width: 110px;
	text-align: right;
}
.migcorp-desk-row-aum {
	font-family: var(--migcorp-font-display);
	font-size: clamp(1.75rem, 1.8vw + 1rem, 2.6rem);
	font-weight: 400;
	letter-spacing: -0.02em;
	color: var(--migcorp-ink);
	line-height: 1;
	font-feature-settings: "tnum";
}
.migcorp-desk-row-aum-label {
	font-family: var(--migcorp-font-head);
	font-size: 10.5px;
	font-weight: 600;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--migcorp-muted);
}

.migcorp-desk-row-arrow {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px; height: 32px;
	font-size: 16px;
	color: var(--migcorp-muted);
	border-radius: 50%;
	border: 1px solid var(--migcorp-line);
	transition: all .35s var(--migcorp-ease-out);
}
.migcorp-desk-row:hover .migcorp-desk-row-arrow {
	color: var(--migcorp-ink);
	border-color: var(--migcorp-ink);
	transform: translateX(6px);
}

.migcorp-desk-footnote {
	margin-top: 36px;
	font-family: var(--migcorp-font-head);
	font-size: 11.5px;
	font-weight: 500;
	letter-spacing: 0.06em;
	color: var(--migcorp-muted);
	text-align: right;
	font-style: italic;
}

/* Hide the old map block if any of its styles are still being referenced. */
.migcorp-world-map,
.migcorp-world-map-svg,
.migcorp-world-map-stats,
.migcorp-office-chips,
.migcorp-home-global-grid { display: none !important; }


/* =========================================================================
   HEADER + MOBILE DRAWER — TiDii mirror (replaces all earlier header CSS).
   Old `.migcorp-utility-bar`, `.migcorp-header-bar`, `.migcorp-mobile-drawer`,
   `.migcorp-mobile-toggle` rules above this point are dead — the new header
   markup doesn't use those selectors. Appended here for clarity.
   ========================================================================= */

/* ---------- Announcement bar ----------------------------------------- */

.migcorp-announce {
	background: var(--migcorp-primary-deep);
	color: var(--migcorp-white);
	font-size: 14px;
	font-weight: 600;
	letter-spacing: 0.01em;
	position: relative;
	z-index: 100;
	border-bottom: 1px solid rgba(255, 255, 255, 0.15);
	font-family: var(--migcorp-font-head);
}
.migcorp-announce__inner {
	display: flex; align-items: center; justify-content: center;
	gap: 14px;
	padding: 11px 32px;
	position: relative;
	text-align: center;
}
.migcorp-announce__text { margin: 0; color: var(--migcorp-white); }
.migcorp-announce__star { display: inline-block; margin-right: 6px; color: var(--migcorp-accent); }
.migcorp-announce__link {
	color: var(--migcorp-white);
	font-weight: 700;
	border-bottom: 2px solid rgba(255, 255, 255, 0.6);
	margin-left: 6px;
	transition: border-color .2s;
	text-decoration: none;
}
.migcorp-announce__link:hover { border-bottom-color: var(--migcorp-white); color: var(--migcorp-white); }
.migcorp-announce__close {
	position: absolute;
	right: 24px;
	top: 50%; transform: translateY(-50%);
	color: rgba(255, 255, 255, 0.7);
	padding: 6px;
	border-radius: 50%;
	display: inline-flex;
	background: transparent;
	border: 0;
	cursor: pointer;
	transition: color .2s, background .2s;
}
@media (max-width: 1023px) { .migcorp-announce__close { right: 20px; } }
.migcorp-announce__close:hover { color: var(--migcorp-white); background: rgba(255, 255, 255, 0.1); }
.migcorp-announce.is-hidden { display: none; }
@media (max-width: 640px) {
	.migcorp-announce__inner { padding-right: 56px; }
}

/* ---------- Sticky header ------------------------------------------- */

.migcorp-header {
	position: sticky;
	top: 0;
	background: rgba(255, 255, 255, 0.94);
	backdrop-filter: saturate(180%) blur(20px);
	-webkit-backdrop-filter: saturate(180%) blur(20px);
	border-bottom: 1px solid var(--migcorp-line);
	z-index: 90;
	transition: box-shadow .25s ease, background .25s ease;
}
.migcorp-header.is-scrolled { box-shadow: 0 6px 24px rgba(10, 31, 60, 0.06); }
.migcorp-header__inner {
	display: flex; align-items: center; justify-content: space-between;
	gap: 24px;
	padding: 14px clamp(12px, 1.6vw, 28px);
	min-height: 88px;
}

.migcorp-header__brand .migcorp-brand-mark { display: block; height: 52px; width: auto; }

.migcorp-header__nav { display: none; }
@media (min-width: 1200px) {
	.migcorp-header__nav { display: block; flex: 1; }
}
.migcorp-menu {
	display: flex; align-items: center; gap: 2px;
	justify-content: center;
	list-style: none;
	margin: 0; padding: 0;
}
.migcorp-menu__item { position: relative; }
.migcorp-menu__link {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	padding: 10px 14px;
	font-family: var(--migcorp-font-head);
	font-size: 14.5px;
	font-weight: 600;
	color: var(--migcorp-ink);
	text-decoration: none;
	border-radius: 10px;
	transition: background .2s, color .2s;
	white-space: nowrap;
}
@media (max-width: 1399px) {
	.migcorp-menu { gap: 0; }
	.migcorp-menu__link { padding: 10px 10px; font-size: 14px; }
}
.migcorp-menu__link:hover { background: var(--migcorp-primary-soft); color: var(--migcorp-primary-deep); }
.migcorp-menu__caret { display: inline-flex; opacity: .55; transition: transform .2s; }
.migcorp-menu__item--has-children:hover > .migcorp-menu__link .migcorp-menu__caret { transform: rotate(180deg); }

/* Active page indicator */
.migcorp-menu > .migcorp-menu__item.is-current > .migcorp-menu__link,
.migcorp-menu > .migcorp-menu__item.current-menu-item > .migcorp-menu__link,
.migcorp-menu > .migcorp-menu__item.current_page_item > .migcorp-menu__link,
.migcorp-menu > .migcorp-menu__item.current-menu-parent > .migcorp-menu__link,
.migcorp-menu > .migcorp-menu__item.current-menu-ancestor > .migcorp-menu__link,
.migcorp-menu > .migcorp-menu__item.current-page-ancestor > .migcorp-menu__link {
	color: var(--migcorp-primary-deep);
	background: var(--migcorp-primary-soft);
	font-weight: 700;
	position: relative;
}
.migcorp-menu > .migcorp-menu__item.is-current > .migcorp-menu__link::after,
.migcorp-menu > .migcorp-menu__item.current-menu-item > .migcorp-menu__link::after,
.migcorp-menu > .migcorp-menu__item.current_page_item > .migcorp-menu__link::after {
	content: '';
	position: absolute;
	left: 14px; right: 14px; bottom: 4px;
	height: 2px;
	background: var(--migcorp-primary);
	border-radius: 2px;
}

/* Sub-menu (desktop hover) */
.migcorp-menu__sub {
	position: absolute; top: calc(100% - 4px); left: 0;
	background: var(--migcorp-white);
	border: 1px solid var(--migcorp-line);
	border-radius: var(--migcorp-radius-lg);
	padding: 10px;
	min-width: 260px;
	box-shadow: var(--migcorp-shadow-pop);
	opacity: 0; visibility: hidden; transform: translateY(-8px);
	transition: opacity .2s, visibility .2s, transform .2s;
	z-index: 100;
	list-style: none;
	margin: 0;
}
.migcorp-menu__item--has-children:hover > .migcorp-menu__sub,
.migcorp-menu__item--has-children:focus-within > .migcorp-menu__sub {
	opacity: 1; visibility: visible; transform: translateY(0);
}
.migcorp-menu__sub .migcorp-menu__link {
	display: block;
	padding: 10px 14px;
	font-size: 14px;
	font-weight: 500;
	border-radius: 10px;
	position: relative;
	transition: background .2s, color .2s, padding-left .25s;
}
.migcorp-menu__sub .migcorp-menu__link:hover {
	background: var(--migcorp-primary-soft);
	color: var(--migcorp-primary-deep);
}

/* Active submenu item — current child page gets gold accent + bold */
.migcorp-menu__sub .migcorp-menu__item.current-menu-item > .migcorp-menu__link,
.migcorp-menu__sub .migcorp-menu__item.current_page_item > .migcorp-menu__link {
	color: var(--migcorp-primary-deep);
	background: var(--migcorp-primary-soft);
	font-weight: 700;
	padding-left: 22px;
}
.migcorp-menu__sub .migcorp-menu__item.current-menu-item > .migcorp-menu__link::before,
.migcorp-menu__sub .migcorp-menu__item.current_page_item > .migcorp-menu__link::before {
	content: "";
	position: absolute;
	left: 10px; top: 50%; transform: translateY(-50%);
	width: 6px; height: 2px;
	background: var(--migcorp-gold);
	border-radius: 2px;
}

/* Header actions: phone (desktop) + gold CTA + burger */
.migcorp-header__actions { display: flex; align-items: center; gap: 12px; }
.migcorp-header__phone {
	display: none;
	align-items: center; gap: 8px;
	font-family: var(--migcorp-font-head);
	font-size: 14.5px;
	font-weight: 700;
	color: var(--migcorp-ink);
	padding: 8px 12px;
	border-radius: 10px;
	text-decoration: none;
	white-space: nowrap;
	transition: color .2s;
}
@media (min-width: 1200px) { .migcorp-header__phone { display: inline-flex; } }
.migcorp-header__phone:hover { color: var(--migcorp-primary-deep); }

.migcorp-header__cta { display: none; white-space: nowrap; }
@media (min-width: 768px) { .migcorp-header__cta { display: inline-flex; } }

.migcorp-header__burger {
	width: 44px; height: 44px;
	display: inline-flex; flex-direction: column; align-items: center; justify-content: center; gap: 5px;
	padding: 10px;
	border-radius: 12px;
	border: 1px solid var(--migcorp-line);
	background: transparent;
	cursor: pointer;
}
.migcorp-header__burger span {
	display: block; width: 22px; height: 2px;
	background: var(--migcorp-ink);
	border-radius: 2px;
	transition: transform .25s var(--migcorp-ease), opacity .15s;
}
.migcorp-header__burger[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.migcorp-header__burger[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.migcorp-header__burger[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
@media (min-width: 1200px) { .migcorp-header__burger { display: none; } }

/* ---------- Mobile drawer (Boujee pattern) --------------------------- */

.migcorp-mobile {
	position: fixed;
	inset: 0;
	background: var(--migcorp-white);
	z-index: 110;
	display: flex; flex-direction: column;
	transform: translateX(100%);
	transition: transform .35s var(--migcorp-ease);
	overflow-y: auto;
}
.migcorp-mobile.is-open { transform: translateX(0); }
.migcorp-mobile__backdrop {
	position: fixed; inset: 0;
	background: rgba(15, 45, 82, 0.6);
	opacity: 0; visibility: hidden;
	transition: opacity .25s, visibility .25s;
	z-index: 105;
}
.migcorp-mobile__backdrop.is-visible { opacity: 1; visibility: visible; }

.migcorp-mobile__top {
	display: flex; align-items: center; justify-content: space-between;
	padding: 16px 20px;
	border-bottom: 1px solid var(--migcorp-line);
}
.migcorp-mobile__top .migcorp-brand-mark { height: 44px; width: auto; }
.migcorp-mobile__close {
	width: 44px; height: 44px;
	border-radius: 12px;
	border: 1px solid var(--migcorp-line);
	background: transparent;
	display: inline-flex; align-items: center; justify-content: center;
	cursor: pointer;
}
.migcorp-mobile__close:hover { background: var(--migcorp-grey); }

.migcorp-mobile__nav { padding: 20px; flex: 1; }
.migcorp-mobile__list { display: flex; flex-direction: column; gap: 2px; list-style: none; margin: 0; padding: 0; }
.migcorp-mobile__list .migcorp-menu__item { position: relative; }
.migcorp-mobile__list .migcorp-menu__link {
	display: flex; align-items: center; justify-content: space-between;
	padding: 16px 18px;
	font-family: var(--migcorp-font-head);
	font-size: 17px;
	font-weight: 700;
	letter-spacing: -0.01em;
	color: var(--migcorp-ink);
	text-decoration: none;
	border-radius: 14px;
	position: relative;
}
.migcorp-mobile__list .migcorp-menu__link:hover { background: var(--migcorp-grey); }

/* Active item in mobile drawer — left blue bar + soft tint */
.migcorp-mobile__list .migcorp-menu__item.is-current > .migcorp-menu__link,
.migcorp-mobile__list .migcorp-menu__item.current-menu-item > .migcorp-menu__link,
.migcorp-mobile__list .migcorp-menu__item.current_page_item > .migcorp-menu__link,
.migcorp-mobile__list .migcorp-menu__item.current-menu-parent > .migcorp-menu__link,
.migcorp-mobile__list .migcorp-menu__item.current-menu-ancestor > .migcorp-menu__link {
	background: var(--migcorp-primary-soft);
	color: var(--migcorp-primary-deep);
}
.migcorp-mobile__list .migcorp-menu__item.is-current > .migcorp-menu__link::before,
.migcorp-mobile__list .migcorp-menu__item.current-menu-item > .migcorp-menu__link::before,
.migcorp-mobile__list .migcorp-menu__item.current_page_item > .migcorp-menu__link::before {
	content: '';
	position: absolute;
	left: 4px; top: 14px; bottom: 14px;
	width: 3px;
	background: var(--migcorp-primary);
	border-radius: 2px;
}

/* Collapsed sub-menus inside the mobile drawer */
.migcorp-mobile__list .sub-menu,
.migcorp-mobile__list .migcorp-menu__sub {
	position: static;
	opacity: 1; visibility: visible; transform: none;
	box-shadow: none;
	border: 0;
	background: var(--migcorp-grey);
	padding: 0;
	border-radius: 12px;
	margin: 4px 8px 8px;
	max-height: 0;
	overflow: hidden;
	transition: max-height .35s var(--migcorp-ease), padding .2s ease;
}
.migcorp-mobile__list .migcorp-menu__item--has-children.is-expanded > .sub-menu,
.migcorp-mobile__list .migcorp-menu__item--has-children.is-expanded > .migcorp-menu__sub {
	max-height: 1200px;
	padding: 6px 10px 10px;
}
.migcorp-mobile__list .migcorp-menu__sub .migcorp-menu__link {
	font-size: 15px;
	font-weight: 500;
	padding: 10px 14px;
}

/* Per-parent expand toggle injected by JS */
.migcorp-mobile__expand {
	position: absolute;
	right: 8px; top: 10px;
	width: 44px; height: 44px;
	border-radius: 10px;
	display: inline-flex; align-items: center; justify-content: center;
	background: transparent;
	border: 0;
	cursor: pointer;
	transition: background .2s, transform .25s var(--migcorp-ease);
	color: var(--migcorp-primary-deep);
}
.migcorp-mobile__expand:hover { background: var(--migcorp-primary-soft); }
.migcorp-menu__item.is-expanded > .migcorp-mobile__expand { transform: rotate(180deg); }
.migcorp-mobile__list .migcorp-menu__caret { display: none; }
.migcorp-mobile__expand:focus { outline: none; }
.migcorp-mobile__expand:focus-visible { outline: 2px solid var(--migcorp-primary); outline-offset: 2px; }

.migcorp-mobile__cta {
	display: flex; flex-direction: column; gap: 12px;
	padding: 20px;
	border-top: 1px solid var(--migcorp-line);
}

body.migcorp-no-scroll { overflow: hidden; }

/* JPEG logo treatment inside the new header */
.migcorp-header__brand .migcorp-brand-jpeg.migcorp-brand-dark .migcorp-brand-mark { mix-blend-mode: multiply; height: 52px; max-height: 52px; }
.migcorp-mobile__top .migcorp-brand-jpeg.migcorp-brand-dark .migcorp-brand-mark { mix-blend-mode: multiply; height: 44px; max-height: 44px; }

/* =========================================================================
   POST-AUDIT FIXES — about-grid no-media, MIGCorp Bond horizontal row,
   featured-investment editorial fallback when no image.
   ========================================================================= */

/* ---------- About intro — collapse to single column when no image ------- */
.migcorp-home-about-grid--no-media {
	grid-template-columns: 1fr !important;
	max-width: 880px;
	margin-left: auto;
	margin-right: auto;
}
.migcorp-home-about-grid--no-media .migcorp-home-about-content {
	max-width: 70ch;
}

/* ---------- MIGCorp Bond — new horizontal layout ------------------------ *
   Replaces the old 50/50 grid which cramped the 4-step process. Now:
   - section head: title left, body right
   - features: 2-column diamond list below
   - process: 4 cards in a horizontal row, full width
   - CTAs: centered below
 * ------------------------------------------------------------------------ */

/* Kill the old grid behavior for this section. */
.migcorp-home-bond .migcorp-home-bond-grid { display: block !important; grid-template-columns: 1fr !important; }

.migcorp-home-bond-features { margin: 24px 0 48px; }
.migcorp-diamond-list--cols {
	display: grid;
	grid-template-columns: 1fr;
	gap: 14px 32px;
}
@media (min-width: 768px) {
	.migcorp-diamond-list--cols { grid-template-columns: repeat(2, 1fr); }
}

.migcorp-home-bond-process { margin-top: 56px; }
.migcorp-section-num--gold { color: var(--migcorp-accent-deep); margin-bottom: 24px; }

.migcorp-process-row {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 20px;
	grid-template-columns: 1fr;
	counter-reset: step;
}
@media (min-width: 640px)  { .migcorp-process-row { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .migcorp-process-row { grid-template-columns: repeat(4, 1fr); } }

.migcorp-process-card {
	position: relative;
	padding: 28px 24px 32px;
	background: var(--migcorp-white);
	border: 1px solid var(--migcorp-line);
	border-top: 3px solid var(--migcorp-accent);
	border-radius: var(--migcorp-radius-sm);
	box-shadow: var(--migcorp-shadow-card);
	transition: transform .25s var(--migcorp-ease), box-shadow .25s var(--migcorp-ease);
}
.migcorp-process-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--migcorp-shadow-hover);
}
.migcorp-process-card-num {
	display: block;
	font-family: var(--migcorp-font-display);
	font-size: 2.25rem;
	font-weight: 700;
	color: var(--migcorp-accent);
	line-height: 1;
	margin-bottom: 12px;
	font-feature-settings: "tnum";
}
.migcorp-process-card-title {
	font-family: var(--migcorp-font-head);
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--migcorp-ink);
	margin: 0 0 10px;
	line-height: 1.3;
}
.migcorp-process-card-text {
	font-size: 14px;
	color: var(--migcorp-muted);
	margin: 0;
	line-height: 1.55;
}

.migcorp-home-bond-ctas {
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
	justify-content: center;
	margin-top: 56px;
	padding-top: 40px;
	border-top: 1px solid var(--migcorp-line);
}

/* ---------- Featured Investment — editorial fallback when no image ----- */
.migcorp-home-featured {
	background: var(--migcorp-dark);
}
.migcorp-home-featured-slide {
	background:
		radial-gradient(120% 80% at 20% 30%, rgba(31, 75, 124, 0.35), transparent 60%),
		radial-gradient(80% 60% at 90% 90%, rgba(229, 180, 80, 0.18), transparent 60%),
		var(--migcorp-dark);
}
/* When an image IS uploaded, the .migcorp-home-featured-media block covers
   the gradient. So the fallback only shows when there's no image. */

/* =========================================================================
   VERTICALS BENTO — polish pass
   - Featured card stretches to match the right-list height (always equal).
   - "Coming 2026" tag inline next to the title (italic gold), not a chunky pill.
   - Subtle warm row tint on coming-status rows.
   - Featured `.is-coming` variant (when Sports & Entertainment is featured).
   ========================================================================= */

/* Equal-height columns */
.migcorp-bento { align-items: stretch !important; }
@media (min-width: 1024px) {
	.migcorp-bento-feature {
		min-height: 0;       /* override the earlier 560px floor */
		height: 100%;
	}
}

/* Featured card layout — push body to the bottom regardless of row count */
.migcorp-bento-feature {
	display: flex;
	align-items: flex-end;
}
.migcorp-bento-feature-body {
	width: 100%;
	display: flex;
	flex-direction: column;
	gap: 14px;
}
.migcorp-bento-feature-body > .migcorp-btn { align-self: flex-start; margin-top: 16px; }

/* When the featured slot is the "Coming 2026" vertical, tint the eyebrow gold-bright */
.migcorp-bento-feature.is-coming .migcorp-eyebrow { color: var(--migcorp-accent-bright); }
.migcorp-bento-feature.is-coming .migcorp-eyebrow::before { background: var(--migcorp-accent-bright); }

/* Bento list — equal height with the featured */
.migcorp-bento-list {
	display: flex;
	flex-direction: column;
	height: 100%;
}
.migcorp-bento-row {
	flex: 1;
	display: flex;
	align-items: center;
}
.migcorp-bento-row-link { width: 100%; height: 100%; }

/* Coming row — subtle warm tint instead of a pill at the side */
.migcorp-bento-row.is-coming {
	background: linear-gradient(90deg, rgba(229, 180, 80, 0.07), rgba(229, 180, 80, 0));
}
.migcorp-bento-row.is-coming .migcorp-bento-row-cta { color: var(--migcorp-accent-deep); }
.migcorp-bento-row.is-coming .migcorp-bento-row-num { color: var(--migcorp-accent-deep); }
.migcorp-bento-row.is-coming .migcorp-bento-row-icon { color: var(--migcorp-accent-deep); }

/* Coming 2026 tag — sits in normal flex flow between body and arrow.
   No absolute positioning, no padding-right hack on the body. The row
   link is overridden to flex (the original 4-col grid is gone for this
   component) so the tag claims its own auto-width slot without forcing
   the title to wrap. */
.migcorp-bento-row-link {
	display: flex !important;          /* override the earlier grid */
	align-items: center;
	gap: 24px;
}
.migcorp-bento-row-num,
.migcorp-bento-row-icon { flex: 0 0 auto; width: 56px; text-align: center; }
.migcorp-bento-row-body { flex: 1 1 auto; min-width: 0; }
.migcorp-bento-row-cta  { flex: 0 0 auto; }
.migcorp-coming-tag {
	flex: 0 0 auto;
	font-family: var(--migcorp-font-display);
	font-style: italic;
	font-weight: 400;
	font-size: 14px;
	line-height: 1.2;
	color: var(--migcorp-accent-deep);
	letter-spacing: 0;
	white-space: nowrap;
	margin-right: 4px;
}
@media (max-width: 640px) {
	.migcorp-coming-tag { font-size: 12px; }
}

/* =========================================================================
   GLOBAL PRESENCE MAP — navy section with SVG world + pulsing office pins.
   Replaces the editorial Global Desk row-list. The earlier `.migcorp-desk`
   rules are dead because the new template renders `.migcorp-globe`.
   ========================================================================= */

.migcorp-globe {
	background: var(--migcorp-primary-deep);   /* deep navy bg */
	color: var(--migcorp-white);
	padding: clamp(80px, 9vw, 128px) 0;
}
.migcorp-globe .migcorp-section-num {
	color: var(--migcorp-accent);
	margin-bottom: 32px;
}

/* Hide the old desk + the older map block entirely — same section slug. */
.migcorp-desk,
.migcorp-home-global-grid,
.migcorp-world-map,
.migcorp-world-map-stats,
.migcorp-office-chips { display: none !important; }

.migcorp-globe-grid {
	display: grid;
	gap: 56px;
	grid-template-columns: 1fr;
	align-items: center;
}
@media (min-width: 1024px) {
	.migcorp-globe-grid { grid-template-columns: 1.25fr 1fr; gap: 80px; }
}

/* ---------- Map column ----------------------------------------------- */

.migcorp-globe-map { position: relative; }
.migcorp-globe-svg {
	width: 100%;
	height: auto;
	display: block;
	max-height: 540px;
}

.migcorp-globe-wordmark {
	font-family: var(--migcorp-font-display);
	font-weight: 700;
	font-size: 180px;
	letter-spacing: 0.05em;
	fill: rgba(255, 255, 255, 0.04);
	pointer-events: none;
	dominant-baseline: middle;
}

/* Pulsing pins — flicker-free hover.
   The trick: the group <g> NEVER changes its bounding box on hover. We
   use an invisible hit-area circle (r=22) as the stable cursor target,
   and only the visible inner elements (core + ring) scale on hover.
   That prevents the scale-jitter loop where transforming the group
   moves its bounds off the cursor → mouseleave → unscale → mouseenter. */
.migcorp-pin {
	cursor: pointer;
	outline: none;
}
.migcorp-pin__hit { pointer-events: all; }
.migcorp-pin__core,
.migcorp-pin__ring {
	transform-origin: center;
	transform-box: fill-box;
	transition: transform .25s var(--migcorp-ease-out);
}
.migcorp-pin:hover .migcorp-pin__core,
.migcorp-pin:focus-visible .migcorp-pin__core,
.migcorp-pin.is-hovered .migcorp-pin__core { transform: scale(1.45); }
.migcorp-pin:hover .migcorp-pin__ring,
.migcorp-pin:focus-visible .migcorp-pin__ring,
.migcorp-pin.is-hovered .migcorp-pin__ring { transform: scale(1.2); }
.migcorp-pin:focus-visible .migcorp-pin__core {
	stroke: var(--migcorp-white);
	stroke-width: 1.5;
}

.migcorp-pin__glow {
	transform-origin: center;
	transform-box: fill-box;
	animation: migcorp-pin-pulse 2.8s ease-out infinite;
	animation-delay: var(--pin-delay, 0s);
	pointer-events: none;            /* never block hits on the hit-area */
}
.migcorp-pin.is-hq .migcorp-pin__glow { animation-duration: 2s; }
@keyframes migcorp-pin-pulse {
	0%   { transform: scale(0.5); opacity: 0.95; }
	70%  { transform: scale(2.6); opacity: 0; }
	100% { transform: scale(2.6); opacity: 0; }
}
@media (prefers-reduced-motion: reduce) {
	.migcorp-pin__glow { animation: none; opacity: 0.35; }
}

/* ---------- Branded tooltip — positioned by JS on pin hover ---------- */

.migcorp-pin-tooltip {
	position: absolute;
	left: 0; top: 0;
	transform: translate(-50%, calc(-100% - 14px));
	pointer-events: none;
	opacity: 0;
	visibility: hidden;
	transition: opacity .18s ease, visibility 0s linear .18s;
	z-index: 5;
	min-width: 140px;
	max-width: 280px;
	padding: 10px 16px;
	background: var(--migcorp-primary-deep);
	border: 1px solid var(--migcorp-accent);
	border-radius: 4px;
	box-shadow: 0 12px 32px rgba(0, 0, 0, 0.35);
	text-align: center;
	white-space: nowrap;
}
.migcorp-pin-tooltip.is-visible {
	opacity: 1;
	visibility: visible;
	transition-delay: 0s;
}
.migcorp-pin-tooltip::after {
	content: "";
	position: absolute;
	left: 50%;
	bottom: -5px;
	transform: translateX(-50%) rotate(45deg);
	width: 8px; height: 8px;
	background: var(--migcorp-primary-deep);
	border-right: 1px solid var(--migcorp-accent);
	border-bottom: 1px solid var(--migcorp-accent);
}
.migcorp-pin-tooltip__city {
	display: block;
	font-family: var(--migcorp-font-display);
	font-size: 1.05rem;
	font-weight: 600;
	color: var(--migcorp-white);
	line-height: 1.2;
}
.migcorp-pin-tooltip__role {
	display: block;
	margin-top: 4px;
	font-family: var(--migcorp-font-head);
	font-size: 10.5px;
	font-weight: 600;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--migcorp-accent);
}

/* Legend below the map */
.migcorp-globe-legend {
	display: flex;
	flex-wrap: wrap;
	gap: 14px 24px;
	margin-top: 24px;
	padding: 14px 20px;
	background: rgba(255, 255, 255, 0.04);
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: 4px;
}
.migcorp-globe-legend-item {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-family: var(--migcorp-font-head);
	font-size: 12px;
	letter-spacing: 0.01em;
	color: rgba(255, 255, 255, 0.78);
}
.migcorp-globe-legend-dot {
	width: 10px; height: 10px; border-radius: 50%;
}
.migcorp-globe-legend-dot--gold  { background: var(--migcorp-accent); }
.migcorp-globe-legend-dot--coral { background: #E5704A; }
.migcorp-globe-legend-dot--blue  { background: #5A8FCC; }

/* ---------- Content column ------------------------------------------- */

.migcorp-globe-content { padding: 8px 0; }
.migcorp-globe-content .migcorp-section-title { color: var(--migcorp-white); }
.migcorp-globe-content .migcorp-section-title em { color: var(--migcorp-accent); }
.migcorp-globe-body {
	color: rgba(255, 255, 255, 0.76);
	font-size: 1.05rem;
	line-height: 1.65;
	margin: 0 0 32px;
	max-width: 44ch;
}
.migcorp-globe-regions {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 14px;
	max-width: 32ch;
}
.migcorp-globe-regions li {
	position: relative;
	padding-left: 24px;
	font-family: var(--migcorp-font-head);
	font-size: 1.05rem;
	font-weight: 500;
	color: var(--migcorp-white);
}
.migcorp-globe-regions li::before {
	content: "";
	position: absolute;
	left: 0; top: 50%;
	transform: translateY(-50%);
	width: 8px; height: 8px;
	border-radius: 50%;
	background: var(--migcorp-accent);
}

/* ---------- Stats bar below ------------------------------------------ */

.migcorp-globe-stats {
	display: grid;
	grid-template-columns: 1fr;
	gap: 32px;
	padding-top: 56px;
	margin-top: 56px;
	border-top: 1px solid rgba(255, 255, 255, 0.10);
}
@media (min-width: 640px) {
	.migcorp-globe-stats { grid-template-columns: repeat(3, 1fr); }
}
.migcorp-globe-stat {
	display: flex;
	flex-direction: column;
	gap: 6px;
	align-items: flex-start;
}
.migcorp-globe-stat-num {
	font-family: var(--migcorp-font-display);
	font-weight: 700;
	font-size: clamp(2.5rem, 3.5vw, 3.5rem);
	color: var(--migcorp-accent);
	line-height: 1;
	letter-spacing: -0.02em;
	font-feature-settings: "tnum";
}
.migcorp-globe-stat-label {
	font-family: var(--migcorp-font-head);
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.62);
}

/* =========================================================================
   INNER PAGE — Who We Are
   ========================================================================= */

/* Mission strip */
.migcorp-wwa-mission { padding: clamp(64px, 7vw, 96px) 0; }
.migcorp-wwa-mission-inner { max-width: 920px; margin: 0 auto; text-align: left; }
.migcorp-wwa-mission-text {
	font-family: var(--migcorp-font-display);
	font-size: clamp(1.5rem, 2.4vw + 0.5rem, 2.5rem);
	font-weight: 600;
	letter-spacing: -0.02em;
	line-height: 1.18;
	color: var(--migcorp-ink);
	margin: 24px 0 0;
}
.migcorp-wwa-mission-text em { color: var(--migcorp-gold); font-style: italic; font-weight: 700; }

/* Founding principles */
.migcorp-wwa-principles { background: var(--migcorp-white); }
.migcorp-wwa-principles-grid {
	display: grid; gap: 32px;
	grid-template-columns: 1fr;
	margin-top: 56px;
}
@media (min-width: 768px)  { .migcorp-wwa-principles-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .migcorp-wwa-principles-grid { grid-template-columns: repeat(4, 1fr); gap: 28px; } }
.migcorp-wwa-principle {
	display: flex; flex-direction: column; gap: 14px;
	padding: 32px 28px;
	border: 1px solid var(--migcorp-line);
	background: var(--migcorp-white);
	position: relative;
	transition: transform .35s var(--migcorp-ease-out), border-color .35s, box-shadow .35s;
}
.migcorp-wwa-principle::before {
	content: ""; position: absolute; top: 0; left: 0;
	width: 32px; height: 2px; background: var(--migcorp-gold);
	transition: width .4s var(--migcorp-ease-out);
}
.migcorp-wwa-principle:hover { transform: translateY(-4px); border-color: rgba(229, 180, 80, 0.4); box-shadow: 0 24px 48px -20px rgba(10, 31, 60, 0.16); }
.migcorp-wwa-principle:hover::before { width: 100%; }
.migcorp-wwa-principle-num {
	font-family: var(--migcorp-font-display);
	font-size: 13px; letter-spacing: 0.18em;
	color: var(--migcorp-gold); font-weight: 700;
}
.migcorp-wwa-principle-title {
	font-family: var(--migcorp-font-display);
	font-size: 1.25rem; font-weight: 700;
	letter-spacing: -0.015em; line-height: 1.25;
	color: var(--migcorp-ink); margin: 0;
}
.migcorp-wwa-principle-body { color: var(--migcorp-taupe); margin: 0; font-size: 14px; line-height: 1.65; }

/* Milestones timeline */
.migcorp-wwa-timeline {
	background:
		radial-gradient(60% 50% at 50% 0%, rgba(229, 180, 80, 0.12) 0%, transparent 65%),
		radial-gradient(80% 60% at 0% 100%, rgba(31, 75, 124, 0.4) 0%, transparent 60%),
		linear-gradient(180deg, var(--migcorp-dark) 0%, var(--migcorp-dark-edge) 100%);
	color: var(--migcorp-cream);
	position: relative;
	overflow: hidden;
}
.migcorp-wwa-timeline-list {
	list-style: none; margin: 56px 0 0; padding: 0;
	max-width: 880px; margin-left: auto; margin-right: auto;
}
.migcorp-wwa-timeline-row {
	display: grid;
	grid-template-columns: 1fr;
	gap: 12px;
	padding: 28px 0;
	border-bottom: 1px solid rgba(229, 180, 80, 0.16);
	position: relative;
}
.migcorp-wwa-timeline-row:last-child { border-bottom: none; }
@media (min-width: 768px) {
	.migcorp-wwa-timeline-row { grid-template-columns: 120px 1fr; gap: 48px; align-items: baseline; }
}
.migcorp-wwa-timeline-year {
	font-family: var(--migcorp-font-display);
	font-size: clamp(1.5rem, 1.5vw + 0.5rem, 2rem);
	font-weight: 700; color: var(--migcorp-gold);
	letter-spacing: -0.01em;
}
.migcorp-wwa-timeline-title {
	font-family: var(--migcorp-font-display);
	font-size: 1.2rem; font-weight: 700;
	color: var(--migcorp-cream); margin: 0 0 6px;
	letter-spacing: -0.01em;
}
.migcorp-wwa-timeline-text { color: var(--migcorp-beige); margin: 0; line-height: 1.6; font-size: 15px; }

/* Leadership preview */
.migcorp-wwa-leadership { background: var(--migcorp-white); }
.migcorp-wwa-team-grid {
	display: grid; gap: 32px;
	grid-template-columns: 1fr;
	margin-top: 48px;
}
@media (min-width: 768px) { .migcorp-wwa-team-grid { grid-template-columns: repeat(3, 1fr); } }
.migcorp-wwa-team-card { display: flex; }
.migcorp-wwa-team-link { display: flex; flex-direction: column; gap: 16px; width: 100%; text-decoration: none; color: inherit; }
.migcorp-wwa-team-media {
	aspect-ratio: 4/5; overflow: hidden;
	background: var(--migcorp-beige);
	display: flex; align-items: center; justify-content: center;
}
.migcorp-wwa-team-img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s var(--migcorp-ease-out); }
.migcorp-wwa-team-link:hover .migcorp-wwa-team-img { transform: scale(1.04); }
.migcorp-wwa-team-placeholder { color: var(--migcorp-taupe); }
.migcorp-wwa-team-body { display: flex; flex-direction: column; gap: 4px; }
.migcorp-wwa-team-name {
	font-family: var(--migcorp-font-display);
	font-size: 1.25rem; font-weight: 700;
	color: var(--migcorp-ink); margin: 0;
	letter-spacing: -0.01em;
	transition: color .25s;
}
.migcorp-wwa-team-link:hover .migcorp-wwa-team-name { color: var(--migcorp-gold-700); }
.migcorp-wwa-team-role {
	font-family: var(--migcorp-font-body);
	font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase;
	color: var(--migcorp-gold); font-weight: 600;
	margin: 0;
}

/* Credentials strip */
.migcorp-wwa-creds-grid {
	display: grid; gap: 56px;
	grid-template-columns: 1fr;
	align-items: start;
}
@media (min-width: 1024px) { .migcorp-wwa-creds-grid { grid-template-columns: 1.2fr 1fr; gap: 80px; } }
.migcorp-wwa-creds-body { color: var(--migcorp-ink-2); line-height: 1.65; margin: 16px 0 0; }
.migcorp-wwa-creds-list {
	display: grid; grid-template-columns: 1fr 1fr; gap: 24px 32px;
	margin: 0; padding: 0;
}
.migcorp-wwa-creds-list > div {
	display: flex; flex-direction: column; gap: 6px;
	padding: 20px 0;
	border-top: 1px solid var(--migcorp-line);
}
.migcorp-wwa-creds-list dt {
	font-family: var(--migcorp-font-body);
	font-size: 10px; letter-spacing: 0.24em; text-transform: uppercase;
	color: var(--migcorp-gold); font-weight: 700;
}
.migcorp-wwa-creds-list dd {
	font-family: var(--migcorp-font-display);
	font-size: 1.125rem;
	color: var(--migcorp-ink);
	letter-spacing: -0.01em;
	margin: 0;
	line-height: 1.3;
}

/* =========================================================================
   INNER PAGE — Philosophy
   ========================================================================= */
.migcorp-phil-lead { padding: clamp(56px, 7vw, 96px) 0; }
.migcorp-phil-lead-inner { max-width: 940px; margin: 0 auto; }
.migcorp-phil-lead-title {
	font-family: var(--migcorp-font-display);
	font-size: clamp(1.75rem, 2.6vw + 1rem, 3.25rem);
	font-weight: 700; letter-spacing: -0.025em; line-height: 1.1;
	color: var(--migcorp-ink); margin: 0 0 24px;
}
.migcorp-phil-lead-title em { color: var(--migcorp-gold); font-style: italic; }
.migcorp-phil-lead-body { font-size: 1.1rem; line-height: 1.7; color: var(--migcorp-ink-2); margin: 0; max-width: 64ch; }

.migcorp-phil-pillars { background: var(--migcorp-white); }
.migcorp-phil-pillars-list {
	list-style: none; margin: 56px 0 0; padding: 0;
	display: grid; gap: 0;
	max-width: 920px;
	margin-left: auto; margin-right: auto;
}
.migcorp-phil-pillar {
	display: grid; gap: 24px;
	grid-template-columns: 1fr;
	padding: 36px 0;
	border-top: 1px solid var(--migcorp-line);
	transition: padding-left .35s var(--migcorp-ease-out);
	position: relative;
}
.migcorp-phil-pillar:last-child { border-bottom: 1px solid var(--migcorp-line); }
.migcorp-phil-pillar::before { content: ""; position: absolute; left: 0; top: -1px; width: 0; height: 1px; background: var(--migcorp-gold); transition: width .5s var(--migcorp-ease-out); }
.migcorp-phil-pillar:hover { padding-left: 16px; }
.migcorp-phil-pillar:hover::before { width: 100%; }
@media (min-width: 768px) { .migcorp-phil-pillar { grid-template-columns: 80px 1fr; gap: 40px; } }
.migcorp-phil-pillar-num {
	font-family: var(--migcorp-font-display);
	font-size: 2rem; font-weight: 700;
	color: var(--migcorp-gold);
	letter-spacing: -0.02em;
	line-height: 1;
}
.migcorp-phil-pillar-title {
	font-family: var(--migcorp-font-display);
	font-size: 1.5rem; font-weight: 700;
	color: var(--migcorp-ink); margin: 0 0 8px;
	letter-spacing: -0.015em;
}
.migcorp-phil-pillar-body p { color: var(--migcorp-ink-2); margin: 0; line-height: 1.65; }

.migcorp-phil-manifesto {
	background:
		radial-gradient(60% 50% at 50% 0%, rgba(229, 180, 80, 0.16) 0%, transparent 65%),
		radial-gradient(80% 60% at 0% 100%, rgba(31, 75, 124, 0.42) 0%, transparent 60%),
		linear-gradient(180deg, var(--migcorp-dark) 0%, var(--migcorp-dark-edge) 100%);
	color: var(--migcorp-cream);
}
.migcorp-phil-manifesto-inner { max-width: 920px; margin: 0 auto; }
.migcorp-phil-manifesto-text { font-family: var(--migcorp-font-display); font-size: clamp(1.5rem, 2.2vw + 0.5rem, 2.4rem); font-weight: 600; letter-spacing: -0.02em; line-height: 1.25; color: var(--migcorp-cream); margin-top: 24px; }
.migcorp-phil-manifesto-text em { color: var(--migcorp-gold); font-style: italic; font-weight: 700; }
.migcorp-phil-manifesto-text p { margin: 0 0 20px; }

/* =========================================================================
   INNER PAGE — Capabilities
   ========================================================================= */
.migcorp-caps-intro { padding: clamp(56px, 7vw, 88px) 0; }
.migcorp-caps-intro-inner { max-width: 900px; }
.migcorp-caps-intro-body { font-size: 1.05rem; line-height: 1.65; color: var(--migcorp-ink-2); margin: 24px 0 0; max-width: 64ch; }

.migcorp-caps-list { background: var(--migcorp-white); }
.migcorp-caps-rows { list-style: none; margin: 0; padding: 0; max-width: 1080px; margin-left: auto; margin-right: auto; }
.migcorp-caps-row { border-top: 1px solid var(--migcorp-line); }
.migcorp-caps-row:last-child { border-bottom: 1px solid var(--migcorp-line); }
.migcorp-caps-row-link {
	display: grid;
	grid-template-columns: 60px 50px 1fr 28px;
	gap: 28px;
	align-items: center;
	padding: 32px 12px;
	color: inherit; text-decoration: none;
	transition: padding-left .35s var(--migcorp-ease-out), background .25s;
	position: relative;
}
.migcorp-caps-row-link:hover { padding-left: 24px; background: rgba(229, 180, 80, 0.04); }
.migcorp-caps-row-link::before { content: ""; position: absolute; left: 0; top: -1px; width: 0; height: 1px; background: var(--migcorp-gold); transition: width .5s var(--migcorp-ease-out); }
.migcorp-caps-row-link:hover::before { width: 100%; }
@media (max-width: 640px) {
	.migcorp-caps-row-link { grid-template-columns: 40px 1fr 24px; gap: 16px; padding: 24px 8px; }
	.migcorp-caps-row-icon { display: none; }
}
.migcorp-caps-row-num { font-family: var(--migcorp-font-display); font-size: 1.5rem; color: var(--migcorp-gold); font-weight: 700; letter-spacing: -0.01em; }
.migcorp-caps-row-icon { color: var(--migcorp-gold); display: inline-flex; }
.migcorp-caps-row-title { font-family: var(--migcorp-font-display); font-size: 1.375rem; font-weight: 700; color: var(--migcorp-ink); margin: 0 0 6px; letter-spacing: -0.01em; transition: color .25s; }
.migcorp-caps-row-link:hover .migcorp-caps-row-title { color: var(--migcorp-gold-700); }
.migcorp-caps-row-summary { color: var(--migcorp-taupe); font-size: 14px; line-height: 1.6; margin: 0; }
.migcorp-caps-row-cta { color: var(--migcorp-muted); transition: color .25s, transform .25s; }
.migcorp-caps-row-link:hover .migcorp-caps-row-cta { color: var(--migcorp-gold); transform: translateX(6px); }

/* =========================================================================
   INNER PAGE — Leadership (full team grid)
   ========================================================================= */
.migcorp-lead-intro { padding: clamp(56px, 7vw, 88px) 0; }
.migcorp-lead-intro-inner { max-width: 880px; }
.migcorp-lead-intro-body { font-size: 1.05rem; line-height: 1.65; color: var(--migcorp-ink-2); margin: 24px 0 0; }

.migcorp-lead-grid { display: grid; gap: 40px 32px; grid-template-columns: 1fr; }
@media (min-width: 640px)  { .migcorp-lead-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .migcorp-lead-grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1280px) { .migcorp-lead-grid { grid-template-columns: repeat(4, 1fr); } }

.migcorp-lead-card { position: relative; display: flex; flex-direction: column; }
.migcorp-lead-card-link { display: flex; flex-direction: column; gap: 16px; text-decoration: none; color: inherit; }
.migcorp-lead-card-media { aspect-ratio: 4/5; overflow: hidden; background: var(--migcorp-beige); display: flex; align-items: center; justify-content: center; }
.migcorp-lead-card-img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s var(--migcorp-ease-out); }
.migcorp-lead-card-link:hover .migcorp-lead-card-img { transform: scale(1.04); }
.migcorp-lead-card-placeholder { color: var(--migcorp-taupe); }
.migcorp-lead-card-body { display: flex; flex-direction: column; gap: 4px; }
.migcorp-lead-card-name { font-family: var(--migcorp-font-display); font-size: 1.25rem; font-weight: 700; color: var(--migcorp-ink); margin: 0; letter-spacing: -0.01em; transition: color .25s; }
.migcorp-lead-card-link:hover .migcorp-lead-card-name { color: var(--migcorp-gold-700); }
.migcorp-lead-card-role { font-family: var(--migcorp-font-body); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--migcorp-gold); font-weight: 600; margin: 0; }
.migcorp-lead-card-bio { color: var(--migcorp-taupe); font-size: 14px; line-height: 1.6; margin: 8px 0 0; }
.migcorp-lead-card-li {
	position: absolute; top: 12px; right: 12px;
	width: 32px; height: 32px; border-radius: 50%;
	background: rgba(255,255,255,0.9);
	color: var(--migcorp-ink);
	display: inline-flex; align-items: center; justify-content: center;
	transition: background .25s, color .25s;
}
.migcorp-lead-card-li:hover { background: var(--migcorp-gold); color: var(--migcorp-dark); }

/* =========================================================================
   INNER PAGE — Portfolio archive
   ========================================================================= */
.migcorp-port-intro { padding: clamp(56px, 7vw, 88px) 0; }
.migcorp-port-intro-inner { max-width: 880px; }
.migcorp-port-intro-body { font-size: 1.05rem; line-height: 1.65; color: var(--migcorp-ink-2); margin: 24px 0 0; }

.migcorp-port-grid { display: grid; gap: 32px; grid-template-columns: 1fr; }
@media (min-width: 768px)  { .migcorp-port-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1200px) { .migcorp-port-grid { grid-template-columns: repeat(3, 1fr); } }

.migcorp-port-card { display: flex; }
.migcorp-port-card-link {
	display: flex; flex-direction: column;
	width: 100%; background: var(--migcorp-white);
	border: 1px solid var(--migcorp-line);
	overflow: hidden;
	transition: transform .35s var(--migcorp-ease-out), border-color .35s, box-shadow .35s;
	text-decoration: none; color: inherit;
	position: relative;
}
.migcorp-port-card-link:hover { transform: translateY(-4px); border-color: rgba(229, 180, 80, 0.4); box-shadow: 0 24px 48px -20px rgba(10, 31, 60, 0.18); }
.migcorp-port-card-link::before { content: ""; position: absolute; top: 0; left: 0; width: 32px; height: 2px; background: var(--migcorp-gold); transition: width .45s var(--migcorp-ease-out); z-index: 2; }
.migcorp-port-card-link:hover::before { width: 100%; }

.migcorp-port-card-media { aspect-ratio: 16/10; overflow: hidden; background: var(--migcorp-beige); display: flex; align-items: center; justify-content: center; }
.migcorp-port-card-img { width: 100%; height: 100%; object-fit: cover; transition: transform .7s var(--migcorp-ease-out); }
.migcorp-port-card-link:hover .migcorp-port-card-img { transform: scale(1.05); }
.migcorp-port-card-placeholder { color: var(--migcorp-taupe); }
.migcorp-port-card-body { display: flex; flex-direction: column; gap: 10px; padding: 24px 24px 28px; flex: 1 1 auto; }
.migcorp-port-card-sub { font-family: var(--migcorp-font-body); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--migcorp-gold); font-weight: 600; }
.migcorp-port-card-title { font-family: var(--migcorp-font-display); font-size: 1.25rem; font-weight: 700; color: var(--migcorp-ink); margin: 0; letter-spacing: -0.015em; line-height: 1.25; transition: color .25s; }
.migcorp-port-card-link:hover .migcorp-port-card-title { color: var(--migcorp-gold-700); }
.migcorp-port-card-summary { color: var(--migcorp-taupe); font-size: 14px; line-height: 1.6; margin: 0; }
.migcorp-port-card-cta { margin-top: auto; padding-top: 12px; display: inline-flex; align-items: center; gap: 8px; font-family: var(--migcorp-font-body); font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase; font-weight: 600; color: var(--migcorp-gold-700); transition: gap .3s var(--migcorp-ease-out); }
.migcorp-port-card-link:hover .migcorp-port-card-cta { gap: 14px; color: var(--migcorp-gold); }

/* =========================================================================
   INNER PAGE — Contact
   ========================================================================= */
.migcorp-contact-intro { padding: clamp(56px, 7vw, 96px) 0; }
.migcorp-contact-grid { display: grid; gap: 56px; grid-template-columns: 1fr; align-items: start; }
@media (min-width: 1024px) { .migcorp-contact-grid { grid-template-columns: 1fr 1.1fr; gap: 80px; } }
.migcorp-contact-body { font-size: 1.05rem; line-height: 1.65; color: var(--migcorp-ink-2); margin: 24px 0 0; max-width: 50ch; }
.migcorp-contact-direct { margin: 36px 0 0; padding: 24px 0; border-top: 1px solid var(--migcorp-line); display: grid; gap: 20px; }
.migcorp-contact-direct > div { display: flex; flex-direction: column; gap: 6px; }
.migcorp-contact-direct dt { font-family: var(--migcorp-font-body); font-size: 10px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--migcorp-gold); font-weight: 700; }
.migcorp-contact-direct dd { margin: 0; font-family: var(--migcorp-font-display); font-size: 1.125rem; color: var(--migcorp-ink); letter-spacing: -0.005em; }
.migcorp-contact-direct dd a { color: inherit; text-decoration: none; border-bottom: 1px solid rgba(229, 180, 80, 0.3); padding-bottom: 2px; transition: border-color .25s, color .25s; }
.migcorp-contact-direct dd a:hover { color: var(--migcorp-gold-700); border-bottom-color: var(--migcorp-gold); }

.migcorp-contact-form-wrap { background: var(--migcorp-white); padding: 32px; border: 1px solid var(--migcorp-line); }
.migcorp-contact-form-placeholder { color: var(--migcorp-muted); font-size: 14px; }

.migcorp-contact-offices { background: var(--migcorp-white); }
.migcorp-contact-offices-grid { display: grid; gap: 32px; grid-template-columns: 1fr; margin-top: 40px; }
@media (min-width: 640px)  { .migcorp-contact-offices-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .migcorp-contact-offices-grid { grid-template-columns: repeat(3, 1fr); } }
.migcorp-contact-office { display: flex; flex-direction: column; gap: 8px; padding: 24px 0; border-top: 2px solid var(--migcorp-gold); }
.migcorp-contact-office-city { font-family: var(--migcorp-font-display); font-size: 1.25rem; font-weight: 700; color: var(--migcorp-ink); margin: 0; letter-spacing: -0.01em; display: inline-flex; align-items: center; gap: 12px; }
.migcorp-contact-office-badge { background: var(--migcorp-gold); color: var(--migcorp-dark); font-family: var(--migcorp-font-body); font-size: 10px; padding: 3px 8px; letter-spacing: 0.18em; font-weight: 700; }
.migcorp-contact-office-country { color: var(--migcorp-muted); font-size: 12px; letter-spacing: 0.04em; margin: 0; }
.migcorp-contact-office-address { font-style: normal; color: var(--migcorp-ink-2); font-size: 14px; line-height: 1.55; margin: 4px 0 0; }
.migcorp-contact-office-phone { color: var(--migcorp-ink-2); font-size: 13px; margin: 4px 0 0; }

/* =========================================================================
   INNER PAGE — Careers
   ========================================================================= */
.migcorp-careers-lead { padding: clamp(56px, 7vw, 96px) 0; }
.migcorp-careers-lead-inner { max-width: 920px; }
.migcorp-careers-body { font-size: 1.1rem; line-height: 1.7; color: var(--migcorp-ink-2); margin: 24px 0 0; max-width: 64ch; }

.migcorp-careers-values { background: var(--migcorp-white); }
.migcorp-careers-values-grid { display: grid; gap: 28px; grid-template-columns: 1fr; margin-top: 48px; }
@media (min-width: 768px)  { .migcorp-careers-values-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .migcorp-careers-values-grid { grid-template-columns: repeat(4, 1fr); } }
.migcorp-careers-value {
	display: flex; flex-direction: column; gap: 12px;
	padding: 32px 24px;
	border: 1px solid var(--migcorp-line);
	position: relative;
	transition: transform .35s, border-color .35s, box-shadow .35s;
}
.migcorp-careers-value::before { content: ""; position: absolute; top: 0; left: 0; width: 32px; height: 2px; background: var(--migcorp-gold); transition: width .45s var(--migcorp-ease-out); }
.migcorp-careers-value:hover { transform: translateY(-4px); border-color: rgba(229, 180, 80, 0.4); box-shadow: 0 24px 48px -20px rgba(10, 31, 60, 0.16); }
.migcorp-careers-value:hover::before { width: 100%; }
.migcorp-careers-value-num { font-family: var(--migcorp-font-display); font-size: 13px; letter-spacing: 0.18em; color: var(--migcorp-gold); font-weight: 700; }
.migcorp-careers-value-title { font-family: var(--migcorp-font-display); font-size: 1.2rem; font-weight: 700; color: var(--migcorp-ink); margin: 0; letter-spacing: -0.015em; }
.migcorp-careers-value-body { color: var(--migcorp-taupe); margin: 0; font-size: 14px; line-height: 1.6; }

.migcorp-careers-apply {
	background:
		radial-gradient(60% 50% at 50% 0%, rgba(229, 180, 80, 0.16) 0%, transparent 65%),
		radial-gradient(80% 60% at 100% 100%, rgba(31, 75, 124, 0.42) 0%, transparent 60%),
		linear-gradient(180deg, var(--migcorp-dark) 0%, var(--migcorp-dark-edge) 100%);
	color: var(--migcorp-cream);
	text-align: center;
}
.migcorp-careers-apply-inner { max-width: 720px; margin: 0 auto; }
.migcorp-careers-apply-body { color: var(--migcorp-beige); font-size: 1.05rem; line-height: 1.65; margin: 16px 0 32px; }

/* =========================================================================
   MOBILE SWEEP — focused fixes at ≤640px (tested on 375px iPhone SE)
   ========================================================================= */
@media (max-width: 640px) {

	/* Container — keep gutters generous on small screens */
	.migcorp-container { padding-left: 20px; padding-right: 20px; }

	/* Section padding — tighten so vertical rhythm doesn't get lost in scroll */
	:root { --migcorp-section-pad: clamp(48px, 9vw, 80px); }

	/* Hero — tighter type so the H1 never overflows */
	.migcorp-hero h1, .migcorp-hero-title { font-size: clamp(2rem, 9vw, 2.6rem) !important; line-height: 1.08; letter-spacing: -0.02em; }
	.migcorp-hero-lead, .migcorp-hero-sub { font-size: 0.975rem; line-height: 1.6; }
	.migcorp-hero-actions, .migcorp-hero-ctas { flex-direction: column; align-items: stretch; gap: 10px; }
	.migcorp-hero-actions .migcorp-btn, .migcorp-hero-ctas .migcorp-btn { width: 100%; justify-content: center; }

	/* Stats band — 2-col instead of 4 */
	.migcorp-stats-band-grid,
	.migcorp-stat-band-grid,
	.migcorp-home-stats-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 20px 16px !important; }
	.migcorp-metric-value, .migcorp-stat-value { font-size: clamp(1.5rem, 8vw, 2rem); }

	/* All section heads — row layouts stack */
	.migcorp-section-head-row { flex-direction: column; align-items: flex-start; gap: 20px; }
	.migcorp-section-title { font-size: clamp(1.5rem, 7vw, 2rem) !important; letter-spacing: -0.02em; line-height: 1.12; }

	/* Buttons — comfortable tap targets */
	.migcorp-btn { padding: 14px 22px; font-size: 13px; }

	/* Featured Investment — relax min-heights, prevent overlap */
	.migcorp-home-featured { min-height: auto !important; padding-bottom: 140px !important; }
	.migcorp-home-featured-track { min-height: auto !important; }
	.migcorp-home-featured-slide { position: relative !important; opacity: 1 !important; visibility: visible !important; }
	.migcorp-home-featured-slide:not(.is-active) { display: none; }
	.migcorp-home-featured-counter { top: 16px !important; right: 16px !important; }
	.migcorp-home-featured-inner { padding: 40px 0; }
	.migcorp-home-featured-title { font-size: clamp(1.5rem, 7vw, 2.25rem); }
	.migcorp-home-featured-arrow { width: 36px !important; height: 36px !important; }
	.migcorp-home-featured-progress-inner { gap: 12px !important; }
	.migcorp-home-featured-tab-title { font-size: 11px; }

	/* Global Presence map — let the SVG breathe and shrink tooltip */
	.migcorp-globe-map { overflow-x: hidden; }
	.migcorp-globe-svg { height: auto; max-width: 100%; }

	/* Verticals bento — mobile: hide the redundant feature card, render the 4
	   verticals as a clean 2×2 grid of compact cards. */
	.migcorp-bento { grid-template-columns: 1fr !important; gap: 0 !important; }
	.migcorp-bento-feature { display: none !important; }
	.migcorp-bento-list {
		list-style: none !important;
		padding: 0 !important;
		margin: 0 !important;
		display: grid !important;
		grid-template-columns: repeat(2, 1fr) !important;
		gap: 12px !important;
	}
	.migcorp-bento-row {
		padding: 0 !important;
		border: 1px solid var(--migcorp-line) !important;
		background: var(--migcorp-white) !important;
		border-radius: 2px;
		overflow: hidden;
		position: relative;
	}
	.migcorp-bento-row.is-active { border-color: var(--migcorp-gold) !important; }
	.migcorp-bento-row-link {
		display: flex !important;
		flex-direction: column !important;
		align-items: flex-start !important;
		gap: 10px !important;
		padding: 20px 16px !important;
		min-height: 160px;
	}
	.migcorp-bento-row-num {
		font-size: 13px !important;
		font-family: var(--migcorp-font-display);
		color: var(--migcorp-gold) !important;
		font-weight: 700;
		letter-spacing: 0.04em;
		margin: 0;
	}
	.migcorp-bento-row-icon {
		width: 36px; height: 36px;
		display: inline-flex; align-items: center; justify-content: center;
		background: rgba(229, 180, 80, 0.14);
		color: var(--migcorp-gold-700);
		border-radius: 50%;
	}
	.migcorp-bento-row-icon svg { width: 18px; height: 18px; }
	.migcorp-bento-row-body { padding: 0 !important; flex: 1 1 auto; min-width: 0; }
	.migcorp-bento-row-title {
		font-size: 0.95rem !important;
		line-height: 1.25 !important;
		font-weight: 700 !important;
		margin: 0 !important;
		color: var(--migcorp-ink) !important;
	}
	.migcorp-bento-row-summary { display: none !important; } /* keep cards compact */
	.migcorp-bento-row-cta { display: none !important; }
	.migcorp-coming-tag {
		position: static !important;
		font-size: 9px !important;
		letter-spacing: 0.16em !important;
		padding: 3px 6px !important;
		margin-top: auto;
	}

	/* MIGCorp Bond — process row stacks single column */
	.migcorp-home-bond-grid { grid-template-columns: 1fr !important; }
	.migcorp-home-bond-process { grid-template-columns: 1fr !important; gap: 16px !important; }

	/* ESG pillars stack */
	.migcorp-esg-grid { grid-template-columns: 1fr !important; gap: 20px !important; margin-top: 32px !important; }
	.migcorp-esg-pillar { padding: 32px 20px; }

	/* News + Video */
	.migcorp-home-news { padding: 56px 0 !important; }
	.migcorp-home-news::before { width: 160px !important; }
	.migcorp-home-news-grid { gap: 32px !important; }
	.migcorp-video-embed, .migcorp-video-placeholder { aspect-ratio: 16/9; }

	/* Insights deck — already responsive but ensure card padding compresses */
	.migcorp-insight-card-body { padding: 20px 20px 24px; }
	.migcorp-insight-card-title { font-size: 1.1rem; min-height: auto; -webkit-line-clamp: 4; }

	/* Final-CTA */
	.migcorp-final-cta { padding: 56px 0 !important; }
	.migcorp-final-cta-title { font-size: clamp(1.5rem, 8vw, 2.25rem) !important; max-width: 100%; }
	.migcorp-final-cta-actions { flex-direction: column; }
	.migcorp-final-cta-actions .migcorp-btn { width: 100%; justify-content: center; }

	/* Press band */
	.migcorp-press-band-inner { grid-template-columns: 1fr !important; gap: 12px !important; }
	.migcorp-press-band-label { text-align: center; }
	.migcorp-press-band-item img { height: 22px; max-width: 120px; }
	.migcorp-press-band-item--text { font-size: 1rem; }

	/* Footer — credentials becomes 1 col */
	.migcorp-footer-credentials { grid-template-columns: 1fr !important; }
	.migcorp-footer-credentials > div:last-child { grid-column: auto !important; }
	.migcorp-footer-cols-grid { gap: 40px !important; }
	.migcorp-footer-col-title { margin-bottom: 20px; padding-bottom: 14px; }

	/* Inner page — Philosophy pillars stack with smaller numerals */
	.migcorp-phil-pillar { padding: 28px 0; }
	.migcorp-phil-pillar-num { font-size: 1.5rem; }
	.migcorp-phil-pillar-title { font-size: 1.25rem; }
	.migcorp-phil-manifesto-text { font-size: 1.25rem; }

	/* Inner page — Capabilities rows */
	.migcorp-caps-row-link { padding: 20px 4px; gap: 14px; }
	.migcorp-caps-row-title { font-size: 1.125rem; }

	/* Inner page — Leadership */
	.migcorp-lead-card-name { font-size: 1.125rem; }

	/* Inner page — Portfolio cards */
	.migcorp-port-card-body { padding: 20px 20px 24px; }

	/* Inner page — Who We Are */
	.migcorp-wwa-mission-text { font-size: clamp(1.25rem, 6vw, 1.75rem); }
	.migcorp-wwa-principles-grid { gap: 20px !important; margin-top: 36px; }
	.migcorp-wwa-principle { padding: 24px 20px; }
	.migcorp-wwa-timeline-row { padding: 20px 0; }
	.migcorp-wwa-timeline-year { font-size: 1.5rem; }
	.migcorp-wwa-creds-list { grid-template-columns: 1fr; gap: 0; }
	.migcorp-wwa-creds-list > div { padding: 16px 0; }

	/* Inner page — Contact */
	.migcorp-contact-form-wrap { padding: 20px; }

	/* Careers value cards */
	.migcorp-careers-value { padding: 24px 20px; }

	/* Reading flow — prevent horizontal scroll on any rogue overflow */
	body { overflow-x: hidden; }

	/* Smooth scrollspy rail hidden on mobile */
	.migcorp-scrollspy-rail { display: none !important; }

	/* Briefing launcher — repositioned so it doesn't cover content */
	.migcorp-briefing-launcher {
		bottom: 16px !important; right: 16px !important;
		padding: 10px 14px !important;
	}
	.migcorp-briefing-launcher-text small,
	.migcorp-briefing-launcher-text strong { font-size: 12px; }

	/* Back-to-top */
	.migcorp-to-top { bottom: 80px !important; right: 16px !important; }
}

/* ---------- Tablet refinement (641–1023px) ---------------------------- */
@media (min-width: 641px) and (max-width: 1023px) {
	.migcorp-hero h1, .migcorp-hero-title { font-size: clamp(2.5rem, 6vw, 3.5rem); }
	.migcorp-bento { grid-template-columns: 1fr; }
	.migcorp-home-bond-process { grid-template-columns: repeat(2, 1fr); }
	.migcorp-stats-band-grid,
	.migcorp-home-stats-grid { grid-template-columns: repeat(2, 1fr); }
	.migcorp-esg-grid { grid-template-columns: repeat(2, 1fr); }
}

/* =========================================================================
   CPT SINGLE — Team member
   ========================================================================= */
.migcorp-team-single { padding: clamp(56px, 7vw, 96px) 0; }
.migcorp-team-single-grid {
	display: grid; gap: 56px;
	grid-template-columns: 1fr;
	align-items: start;
}
@media (min-width: 1024px) { .migcorp-team-single-grid { grid-template-columns: 360px 1fr; gap: 80px; } }
.migcorp-team-single-photo {
	aspect-ratio: 4/5; overflow: hidden;
	background: var(--migcorp-beige);
	display: flex; align-items: center; justify-content: center;
}
.migcorp-team-single-img { width: 100%; height: 100%; object-fit: cover; }
.migcorp-team-single-placeholder { color: var(--migcorp-taupe); }
.migcorp-team-single-meta {
	margin: 28px 0 0; padding: 24px 0; display: grid; gap: 18px;
	border-top: 1px solid rgba(229, 180, 80, 0.2);
	border-bottom: 1px solid rgba(229, 180, 80, 0.2);
}
.migcorp-team-single-meta > div { display: flex; flex-direction: column; gap: 6px; }
.migcorp-team-single-meta dt { font-family: var(--migcorp-font-body); font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--migcorp-gold); font-weight: 700; }
.migcorp-team-single-meta dd { margin: 0; font-family: var(--migcorp-font-display); font-size: 1.05rem; color: var(--migcorp-ink); letter-spacing: -0.005em; }
.migcorp-team-single-meta dd a { color: inherit; text-decoration: none; border-bottom: 1px solid rgba(229, 180, 80, 0.4); padding-bottom: 1px; transition: color .25s, border-color .25s; }
.migcorp-team-single-meta dd a:hover { color: var(--migcorp-gold-700); border-bottom-color: var(--migcorp-gold); }
.migcorp-team-single-back {
	margin-top: 24px;
	display: inline-flex; align-items: center; gap: 8px;
	font-family: var(--migcorp-font-body);
	font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase;
	color: var(--migcorp-gold-700); text-decoration: none; font-weight: 600;
	transition: gap .3s var(--migcorp-ease-out);
}
.migcorp-team-single-back:hover { gap: 14px; color: var(--migcorp-gold); }
.migcorp-team-single-lead {
	font-family: var(--migcorp-font-display);
	font-size: clamp(1.25rem, 1.6vw + 0.5rem, 1.875rem);
	font-weight: 600; line-height: 1.3;
	color: var(--migcorp-ink);
	letter-spacing: -0.015em;
	margin: 0 0 32px;
}
.migcorp-team-single-credits {
	margin-top: 40px; padding-top: 32px;
	border-top: 1px solid var(--migcorp-line);
}
.migcorp-team-single-credits-title {
	font-family: var(--migcorp-font-body);
	font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase;
	color: var(--migcorp-gold); font-weight: 700;
	margin: 0 0 20px;
}
.migcorp-team-single-credits ul {
	list-style: none; padding: 0; margin: 0;
	display: grid; gap: 14px;
}
.migcorp-team-single-credits li {
	padding-left: 24px; position: relative;
	color: var(--migcorp-ink-2); font-size: 15px; line-height: 1.6;
}
.migcorp-team-single-credits li::before {
	content: ""; position: absolute; left: 0; top: 11px;
	width: 12px; height: 1px; background: var(--migcorp-gold);
}

/* =========================================================================
   CPT SINGLE — Capability
   ========================================================================= */
.migcorp-cap-promise-grid {
	display: grid; gap: 48px;
	grid-template-columns: 1fr;
	align-items: start;
}
@media (min-width: 1024px) { .migcorp-cap-promise-grid { grid-template-columns: 1.4fr 1fr; gap: 80px; align-items: center; } }
.migcorp-cap-promise-text {
	font-family: var(--migcorp-font-display);
	font-size: clamp(1.5rem, 1.8vw + 0.5rem, 2.125rem);
	font-weight: 600; line-height: 1.3;
	color: var(--migcorp-ink);
	letter-spacing: -0.02em;
	margin: 16px 0 0;
}
.migcorp-cap-promise-text em { color: var(--migcorp-gold); font-style: italic; }

.migcorp-cap-included { background: var(--migcorp-white); }
.migcorp-cap-included-grid {
	display: grid; gap: 28px;
	grid-template-columns: 1fr;
	margin-top: 48px;
}
@media (min-width: 768px)  { .migcorp-cap-included-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .migcorp-cap-included-grid { grid-template-columns: repeat(3, 1fr); } }
.migcorp-cap-included-group {
	padding: 32px 28px;
	border: 1px solid var(--migcorp-line);
	transition: transform .35s, border-color .35s, box-shadow .35s;
	position: relative;
}
.migcorp-cap-included-group::before { content: ""; position: absolute; top: 0; left: 0; width: 32px; height: 2px; background: var(--migcorp-gold); transition: width .45s var(--migcorp-ease-out); }
.migcorp-cap-included-group:hover { transform: translateY(-4px); border-color: rgba(229, 180, 80, 0.4); box-shadow: 0 24px 48px -20px rgba(10, 31, 60, 0.16); }
.migcorp-cap-included-group:hover::before { width: 100%; }
.migcorp-cap-included-icon { color: var(--migcorp-gold); display: inline-flex; margin-bottom: 8px; }
.migcorp-cap-included-title { font-family: var(--migcorp-font-display); font-size: 1.2rem; font-weight: 700; color: var(--migcorp-ink); margin: 0 0 8px; letter-spacing: -0.015em; }
.migcorp-cap-included-body { color: var(--migcorp-taupe); margin: 0; font-size: 14px; line-height: 1.6; }

.migcorp-cap-faq {
	background:
		radial-gradient(60% 50% at 50% 0%, rgba(229, 180, 80, 0.16) 0%, transparent 65%),
		radial-gradient(80% 60% at 0% 100%, rgba(31, 75, 124, 0.42) 0%, transparent 60%),
		linear-gradient(180deg, var(--migcorp-dark) 0%, var(--migcorp-dark-edge) 100%);
	color: var(--migcorp-cream);
}
.migcorp-cap-faq-list { max-width: 880px; margin: 48px auto 0; padding: 0; }
.migcorp-cap-faq-row { padding: 28px 0; border-top: 1px solid rgba(229, 180, 80, 0.14); }
.migcorp-cap-faq-row:last-child { border-bottom: 1px solid rgba(229, 180, 80, 0.14); }
.migcorp-cap-faq-row dt { font-family: var(--migcorp-font-display); font-size: 1.25rem; font-weight: 700; color: var(--migcorp-cream); margin-bottom: 12px; letter-spacing: -0.01em; line-height: 1.3; }
.migcorp-cap-faq-row dd { margin: 0; color: var(--migcorp-beige); line-height: 1.65; }

.migcorp-cap-back { padding: 48px 0 80px; }

/* =========================================================================
   CPT SINGLE — Vertical
   ========================================================================= */
.migcorp-vert-kpis { padding: clamp(40px, 5vw, 64px) 0; }
.migcorp-vert-kpis-grid {
	display: grid; gap: 20px;
	grid-template-columns: repeat(2, 1fr);
}
@media (min-width: 768px)  { .migcorp-vert-kpis-grid { grid-template-columns: repeat(4, 1fr); } }
.migcorp-vert-kpi {
	display: flex; flex-direction: column; gap: 8px;
	padding: 24px 0;
	border-top: 2px solid var(--migcorp-gold);
}
.migcorp-vert-kpi-value {
	font-family: var(--migcorp-font-display);
	font-size: clamp(1.75rem, 2.4vw + 0.5rem, 2.5rem);
	font-weight: 700; color: var(--migcorp-ink);
	letter-spacing: -0.02em; line-height: 1;
}
.migcorp-vert-kpi-label {
	font-family: var(--migcorp-font-body);
	font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase;
	color: var(--migcorp-muted); font-weight: 600;
}

.migcorp-vert-content { background: var(--migcorp-cream); }
.migcorp-vert-content-inner { max-width: 800px; margin: 0 auto; }
.migcorp-vert-related { background: var(--migcorp-white); }

/* =========================================================================
   CPT SINGLE — Portfolio (case study)
   ========================================================================= */
.migcorp-port-meta-strip { padding: 32px 0; }
.migcorp-port-meta-grid {
	display: grid; gap: 16px 32px;
	grid-template-columns: repeat(2, 1fr);
	margin: 0;
}
@media (min-width: 768px) { .migcorp-port-meta-grid { grid-template-columns: repeat(4, 1fr); } }
.migcorp-port-meta-grid > div { display: flex; flex-direction: column; gap: 4px; padding-left: 16px; border-left: 2px solid var(--migcorp-gold); }
.migcorp-port-meta-grid dt { font-family: var(--migcorp-font-body); font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--migcorp-gold); font-weight: 700; }
.migcorp-port-meta-grid dd { margin: 0; font-family: var(--migcorp-font-display); font-size: 1.05rem; color: var(--migcorp-ink); letter-spacing: -0.005em; }

.migcorp-port-bullets { background: var(--migcorp-white); }
.migcorp-port-bullets-list { max-width: 760px; margin: 48px 0 0; padding: 0; list-style: none; display: grid; gap: 14px; }
.migcorp-port-bullets-list li { display: flex; gap: 14px; align-items: start; color: var(--migcorp-ink-2); line-height: 1.65; }
.migcorp-port-bullets-list svg { color: var(--migcorp-gold); flex-shrink: 0; margin-top: 6px; }

.migcorp-port-content-inner { max-width: 800px; margin: 0 auto; }

.migcorp-port-quote {
	background:
		radial-gradient(60% 50% at 50% 0%, rgba(229, 180, 80, 0.16) 0%, transparent 65%),
		radial-gradient(80% 60% at 100% 100%, rgba(31, 75, 124, 0.42) 0%, transparent 60%),
		linear-gradient(180deg, var(--migcorp-dark) 0%, var(--migcorp-dark-edge) 100%);
	color: var(--migcorp-cream);
}
.migcorp-port-quote-inner { max-width: 880px; margin: 0 auto; text-align: center; }
.migcorp-port-quote blockquote { margin: 0; }
.migcorp-port-quote-mark { font-family: var(--migcorp-font-display); font-size: 4rem; color: var(--migcorp-gold); line-height: 1; display: block; margin-bottom: 8px; font-style: italic; }
.migcorp-port-quote blockquote p { font-family: var(--migcorp-font-display); font-size: clamp(1.5rem, 2.2vw + 0.5rem, 2.4rem); font-weight: 600; line-height: 1.3; color: var(--migcorp-cream); margin: 0 0 24px; letter-spacing: -0.015em; font-style: italic; }
.migcorp-port-quote blockquote cite { font-style: normal; font-family: var(--migcorp-font-body); font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--migcorp-gold); font-weight: 600; }

.migcorp-port-back { padding: 48px 0 80px; }

/* =========================================================================
   LEADERSHIP ARCHIVE — 1:1 square cards with social-icon overlay
   ========================================================================= */

.migcorp-lead-archive { padding: clamp(64px, 8vw, 112px) 0; }

.migcorp-lead-square-grid {
	display: grid; gap: 32px;
	grid-template-columns: 1fr;
}
@media (min-width: 540px)  { .migcorp-lead-square-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 900px)  { .migcorp-lead-square-grid { grid-template-columns: repeat(3, 1fr); gap: 28px; } }
@media (min-width: 1280px) { .migcorp-lead-square-grid { grid-template-columns: repeat(4, 1fr); } }

.migcorp-lead-sq-card {
	background: var(--migcorp-white);
	border: 1px solid var(--migcorp-line);
	overflow: hidden;
	display: flex; flex-direction: column;
	height: 100%;                      /* all cards in a row stretch to the tallest */
	transition: transform .35s var(--migcorp-ease-out), border-color .35s, box-shadow .35s;
	position: relative;
}
.migcorp-lead-sq-card:hover {
	transform: translateY(-4px);
	border-color: rgba(229, 180, 80, 0.4);
	box-shadow: 0 24px 48px -20px rgba(10, 31, 60, 0.18);
}

/* Square 1:1 photo — never cropped at the head */
.migcorp-lead-sq-photo {
	position: relative;
	display: block;
	aspect-ratio: 1 / 1;
	overflow: hidden;
	background: var(--migcorp-beige);
	text-decoration: none;
}
.migcorp-lead-sq-img {
	width: 100%; height: 100%;
	object-fit: cover;
	object-position: center top;        /* favor the face if image isn't perfectly square */
	transition: transform .6s var(--migcorp-ease-out);
}
.migcorp-lead-sq-card:hover .migcorp-lead-sq-img { transform: scale(1.04); }
.migcorp-lead-sq-placeholder {
	position: absolute; inset: 0;
	display: flex; align-items: center; justify-content: center;
	color: var(--migcorp-taupe);
}

/* Social icons — bottom-left overlay on the photo */
.migcorp-lead-sq-socials {
	position: absolute;
	left: 14px; bottom: 14px;
	display: flex; gap: 8px;
	list-style: none; padding: 0; margin: 0;
	z-index: 2;
}
.migcorp-lead-sq-socials li { display: flex; }
.migcorp-lead-sq-socials a {
	width: 32px; height: 32px;
	display: inline-flex; align-items: center; justify-content: center;
	background: rgba(15, 45, 82, 0.85);
	color: var(--migcorp-cream);
	border-radius: 50%;
	transition: background .25s, color .25s, transform .25s;
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
	border: 1px solid rgba(229, 180, 80, 0.3);
}
.migcorp-lead-sq-socials a:hover {
	background: var(--migcorp-gold);
	color: var(--migcorp-dark);
	border-color: var(--migcorp-gold);
	transform: translateY(-2px);
}

/* Card body — name + role + read-more (no bio, no date, no read-time) */
.migcorp-lead-sq-body {
	padding: 24px 24px 28px;
	display: flex; flex-direction: column; gap: 6px;
	flex: 1 1 auto;                    /* grow so the read-more can pin to the bottom */
}
.migcorp-lead-sq-name {
	font-family: var(--migcorp-font-display);
	font-size: 1.2rem;
	font-weight: 700;
	letter-spacing: -0.015em;
	color: var(--migcorp-ink);
	margin: 0;
	line-height: 1.25;
}
.migcorp-lead-sq-role {
	font-family: var(--migcorp-font-body);
	font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase;
	color: var(--migcorp-gold); font-weight: 600;
	margin: 0;
}
/* Read More — clean editorial text+arrow link (matches insights deck + verticals).
   Pinned to the bottom of each card so they align across a row. */
.migcorp-lead-sq-readmore {
	margin-top: auto;                   /* bottom-align across cards in a row */
	padding-top: 20px;
	display: inline-flex; align-items: center; gap: 10px;
	font-family: var(--migcorp-font-body);
	font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase;
	font-weight: 700;
	color: var(--migcorp-gold-700);
	text-decoration: none;
	transition: gap .3s var(--migcorp-ease-out), color .25s;
	width: fit-content;
	align-self: flex-start;
	background: none;
	border: 0;
	padding-left: 0;
	padding-right: 0;
	cursor: pointer;
}
.migcorp-lead-sq-readmore:hover { gap: 16px; color: var(--migcorp-gold); }
.migcorp-lead-sq-readmore svg { transition: transform .3s var(--migcorp-ease-out); }
.migcorp-lead-sq-readmore:hover svg { transform: translateX(2px); }

/* =========================================================================
   LEADERSHIP BIO MODAL — opens on Read More click, prev/next + ESC support
   ========================================================================= */

.migcorp-lead-modal {
	position: fixed; inset: 0;
	z-index: 9000;
	display: none;                       /* hidden until .is-open */
	align-items: center;                 /* vertical centering */
	justify-content: center;             /* horizontal centering */
	padding: 32px 16px;                  /* safe-area gutter on small screens */
	opacity: 0;
	transition: opacity .35s var(--migcorp-ease-out);
}
.migcorp-lead-modal.is-open {
	display: flex;
	opacity: 1;
}
.migcorp-lead-modal-backdrop {
	position: absolute; inset: 0;
	background: rgba(10, 31, 60, 0.78);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
}
.migcorp-lead-modal-panel {
	position: relative;
	width: min(1100px, 100%);
	max-height: calc(100vh - 64px);
	margin: 0;
	background: var(--migcorp-cream);
	box-shadow:
		0 60px 120px -30px rgba(0, 0, 0, 0.55),
		0 0 0 1px rgba(229, 180, 80, 0.18);
	display: flex; flex-direction: column;
	overflow: hidden;
	transform: translateY(24px) scale(0.97);
	opacity: 0;
	transition: transform .55s var(--migcorp-ease-out), opacity .4s;
}
.migcorp-lead-modal.is-open .migcorp-lead-modal-panel { transform: translateY(0) scale(1); opacity: 1; }

/* Hairline gold accent at the very top of the panel */
.migcorp-lead-modal-panel::before {
	content: ""; position: absolute; top: 0; left: 50%; transform: translateX(-50%);
	width: 240px; height: 2px;
	background: linear-gradient(90deg, transparent 0%, var(--migcorp-gold) 50%, transparent 100%);
	opacity: .7;
	z-index: 15;
}

.migcorp-lead-modal-close {
	position: absolute; top: 20px; right: 20px;
	width: 44px; height: 44px;
	border-radius: 50%;
	background: rgba(15, 45, 82, 0.92);
	color: var(--migcorp-cream);
	border: 1px solid rgba(229, 180, 80, 0.35);
	display: inline-flex; align-items: center; justify-content: center;
	cursor: pointer;
	z-index: 20;
	transition: background .25s, color .25s, transform .35s var(--migcorp-ease-out);
	box-shadow: 0 8px 24px -6px rgba(10, 31, 60, 0.45);
}
.migcorp-lead-modal-close:hover {
	background: var(--migcorp-gold);
	color: var(--migcorp-dark);
	transform: rotate(90deg);
}

/* The actual swap container */
.migcorp-lead-modal-body {
	overflow-y: auto;
	flex: 1 1 auto;
	scrollbar-width: thin;
	scrollbar-color: rgba(229, 180, 80, 0.4) transparent;
}
.migcorp-lead-modal-body::-webkit-scrollbar { width: 6px; }
.migcorp-lead-modal-body::-webkit-scrollbar-thumb { background: rgba(229, 180, 80, 0.35); border-radius: 4px; }

/* Split layout — photo left, bio right on desktop, stacked on mobile */
.migcorp-lead-modal-card {
	display: grid;
	grid-template-columns: 1fr;
	min-height: 0;
}
@media (min-width: 880px) {
	.migcorp-lead-modal-card { grid-template-columns: 42% 1fr; min-height: 540px; }
}

.migcorp-lead-modal-photo {
	background: var(--migcorp-dark);
	overflow: hidden;
	position: relative;
	aspect-ratio: 1 / 1;
	max-height: 460px;
	display: flex; align-items: center; justify-content: center;
}
@media (min-width: 880px) {
	.migcorp-lead-modal-photo {
		aspect-ratio: auto;
		max-height: none;
		height: 100%;
		min-height: 540px;
	}
}
/* Subtle gold vignette around the photo (premium editorial touch) */
.migcorp-lead-modal-photo::after {
	content: ""; position: absolute; inset: 0;
	background:
		linear-gradient(180deg, transparent 60%, rgba(15, 45, 82, 0.35) 100%),
		radial-gradient(80% 60% at 50% 100%, transparent 50%, rgba(229, 180, 80, 0.08) 100%);
	pointer-events: none;
}
.migcorp-lead-modal-img {
	width: 100%; height: 100%;
	object-fit: cover;
	object-position: center top;
}
.migcorp-lead-modal-placeholder { color: var(--migcorp-taupe); }

/* Bio side — generous padding, structured hierarchy */
.migcorp-lead-modal-content {
	padding: clamp(36px, 4vw, 56px) clamp(28px, 4vw, 56px) clamp(80px, 6vw, 96px);
	display: flex; flex-direction: column;
	gap: 14px;
	position: relative;
	background: var(--migcorp-white);
}

.migcorp-lead-modal-content .migcorp-eyebrow {
	margin-bottom: 6px;
}

.migcorp-lead-modal-name {
	font-family: var(--migcorp-font-display);
	font-size: clamp(1.875rem, 2vw + 1rem, 2.625rem);
	font-weight: 700; letter-spacing: -0.022em; line-height: 1.08;
	color: var(--migcorp-ink);
	margin: 0;
}
.migcorp-lead-modal-role {
	font-family: var(--migcorp-font-body);
	font-size: 12px; letter-spacing: 0.22em; text-transform: uppercase;
	color: var(--migcorp-gold); font-weight: 700;
	margin: 0;
}

/* Thin gold rule separating header from bio */
.migcorp-lead-modal-content::after {
	content: ""; display: block;
	width: 48px; height: 2px;
	background: var(--migcorp-gold);
	margin: 20px 0 4px;
	order: 4;                            /* sit between role/socials and bio */
}
.migcorp-lead-modal-content > .migcorp-lead-modal-bio { order: 5; }
.migcorp-lead-modal-content > .migcorp-lead-modal-socials { order: 3; }

.migcorp-lead-modal-socials {
	list-style: none; padding: 0;
	margin: 16px 0 0;
	display: flex; gap: 8px; flex-wrap: wrap;
}
.migcorp-lead-modal-socials a {
	width: 38px; height: 38px;
	display: inline-flex; align-items: center; justify-content: center;
	background: var(--migcorp-cream);
	color: var(--migcorp-ink);
	border: 1px solid rgba(229, 180, 80, 0.35);
	border-radius: 50%;
	transition: all .25s var(--migcorp-ease-out);
}
.migcorp-lead-modal-socials a:hover {
	background: var(--migcorp-gold);
	color: var(--migcorp-dark);
	border-color: var(--migcorp-gold);
	transform: translateY(-2px);
}
.migcorp-lead-modal-bio {
	margin-top: 4px;
	color: var(--migcorp-ink-2);
	line-height: 1.75;
	font-size: 15px;
}
.migcorp-lead-modal-bio p { margin: 0 0 14px; }
.migcorp-lead-modal-bio p:last-child { margin-bottom: 0; }

/* ---------- Bottom toolbar — counter (left) + arrows (right) ----------- */

.migcorp-lead-modal-toolbar {
	position: absolute;
	left: 0; right: 0; bottom: 0;
	display: flex; align-items: center; justify-content: space-between;
	gap: 16px;
	padding: 18px clamp(24px, 4vw, 48px);
	background:
		linear-gradient(180deg, transparent 0%, rgba(255, 255, 255, 0.85) 50%, var(--migcorp-cream) 100%);
	z-index: 12;
	pointer-events: none;                /* let scroll through the gradient */
}
.migcorp-lead-modal-toolbar > * { pointer-events: auto; }

@media (min-width: 880px) {
	/* On desktop the toolbar sits on the right column only — over the bio side */
	.migcorp-lead-modal-toolbar {
		left: 42%;                        /* matches the photo column width */
	}
}

/* Counter — Playfair, gold current, muted total, gold rule */
.migcorp-lead-modal-counter {
	display: inline-flex; align-items: center; gap: 12px;
	font-family: var(--migcorp-font-display);
	font-size: 13px; letter-spacing: 0.18em;
	font-weight: 700;
}
.migcorp-lead-modal-counter::before {
	content: ""; display: inline-block;
	width: 32px; height: 1px;
	background: var(--migcorp-gold);
	margin-right: 4px;
}
.migcorp-lead-modal-counter [data-lead-modal-current] {
	color: var(--migcorp-gold);
	font-size: 15px;
}
.migcorp-lead-modal-counter .sep { color: var(--migcorp-muted); opacity: .5; }
.migcorp-lead-modal-counter .total { color: var(--migcorp-muted); }

/* Paired prev/next arrows — pill cluster, inside the panel */
.migcorp-lead-modal-arrows {
	display: inline-flex; align-items: center;
	background: var(--migcorp-white);
	border: 1px solid rgba(229, 180, 80, 0.35);
	border-radius: 999px;
	padding: 4px;
	box-shadow: 0 12px 28px -10px rgba(10, 31, 60, 0.25);
}
.migcorp-lead-modal-nav {
	width: 40px; height: 40px;
	border-radius: 50%;
	border: 0;
	background: transparent;
	color: var(--migcorp-ink);
	display: inline-flex; align-items: center; justify-content: center;
	cursor: pointer;
	transition: background .25s, color .25s;
}
.migcorp-lead-modal-nav--prev svg { transform: rotate(180deg); }
.migcorp-lead-modal-nav:hover { background: var(--migcorp-gold); color: var(--migcorp-dark); }
.migcorp-lead-modal-nav:focus-visible { outline: 2px solid var(--migcorp-gold); outline-offset: 2px; }
/* Thin divider between the two arrows */
.migcorp-lead-modal-arrows::after {
	content: ""; order: 2;
	width: 1px; height: 20px;
	background: rgba(229, 180, 80, 0.3);
	margin: 0 -2px;
}
.migcorp-lead-modal-nav--prev { order: 1; }
.migcorp-lead-modal-nav--next { order: 3; }

/* "View full profile" link — sits inside the bio column, below the bio */
.migcorp-lead-modal-fullprofile {
	margin-top: 24px;
	padding-top: 20px;
	border-top: 1px solid rgba(229, 180, 80, 0.22);
	display: inline-flex; align-items: center; gap: 10px;
	font-family: var(--migcorp-font-body);
	font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase;
	color: var(--migcorp-gold-700);
	font-weight: 700;
	text-decoration: none;
	transition: gap .3s var(--migcorp-ease-out), color .25s;
	width: fit-content;
	align-self: flex-start;
}
.migcorp-lead-modal-fullprofile:hover { gap: 16px; color: var(--migcorp-gold); }

/* Lock body scroll while modal is open */
body.migcorp-modal-open { overflow: hidden; }

/* Mobile tweaks */
@media (max-width: 880px) {
	.migcorp-lead-modal-toolbar { left: 0; }
}
@media (max-width: 640px) {
	.migcorp-lead-modal { padding: 0; }
	.migcorp-lead-modal-panel {
		width: 100%;
		max-height: 100vh;
		margin: 0;
	}
	.migcorp-lead-modal-photo { aspect-ratio: 1 / 1; max-height: 320px; min-height: 0; }
	.migcorp-lead-modal-content { padding: 28px 24px 88px; }
	.migcorp-lead-modal-name { font-size: clamp(1.5rem, 7vw, 2rem); }
	.migcorp-lead-modal-close { top: 12px; right: 12px; width: 38px; height: 38px; }
	.migcorp-lead-modal-toolbar { padding: 14px 20px; }
	.migcorp-lead-modal-counter::before { display: none; }
}

/* =========================================================================
   PORTFOLIO PAGE — Stats strip + card status pill + card meta + thesis
   ========================================================================= */

/* Stats strip — gold-rule-topped, sits between hero and grid */
.migcorp-port-stats {
	background: var(--migcorp-cream);
	padding: clamp(40px, 5vw, 64px) 0;
	position: relative;
}
.migcorp-port-stats::before {
	content: ""; position: absolute; top: 0; left: 50%; transform: translateX(-50%);
	width: 280px; max-width: 60vw; height: 1px;
	background: linear-gradient(90deg, transparent 0%, var(--migcorp-gold) 50%, transparent 100%);
	opacity: .55;
}
.migcorp-port-stats-grid {
	display: grid; gap: 24px 32px;
	grid-template-columns: repeat(2, 1fr);
	margin: 0;
}
@media (min-width: 768px) { .migcorp-port-stats-grid { grid-template-columns: repeat(4, 1fr); } }
.migcorp-port-stats-grid > div {
	display: flex; flex-direction: column; gap: 6px;
	padding: 20px 0 20px 18px;
	border-left: 2px solid var(--migcorp-gold);
}
.migcorp-port-stats-grid dt {
	font-family: var(--migcorp-font-body);
	font-size: 10px; letter-spacing: 0.24em; text-transform: uppercase;
	color: var(--migcorp-gold); font-weight: 700;
}
.migcorp-port-stats-grid dd {
	margin: 0;
	font-family: var(--migcorp-font-display);
	font-size: clamp(1.75rem, 2.4vw + 0.5rem, 2.5rem);
	font-weight: 700;
	color: var(--migcorp-ink);
	letter-spacing: -0.02em;
	line-height: 1;
}

/* Grid section atmosphere */
.migcorp-port-grid-section { padding: clamp(56px, 7vw, 96px) 0; }
.migcorp-port-grid-section .migcorp-section-head { margin-bottom: 40px; }

/* Status pill on portfolio card photo */
.migcorp-port-card-media { position: relative; }
.migcorp-port-card-status {
	position: absolute; top: 12px; right: 12px;
	font-family: var(--migcorp-font-body);
	font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase;
	font-weight: 700;
	padding: 5px 10px;
	background: rgba(255, 255, 255, 0.92);
	color: var(--migcorp-ink);
	border: 1px solid rgba(229, 180, 80, 0.4);
	z-index: 2;
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
}
.migcorp-port-card-status--active { background: rgba(229, 180, 80, 0.95); color: var(--migcorp-dark); border-color: var(--migcorp-gold); }
.migcorp-port-card-status--coming { background: rgba(255, 255, 255, 0.92); color: var(--migcorp-gold-700); }
.migcorp-port-card-status--realised, .migcorp-port-card-status--realized, .migcorp-port-card-status--exited {
	background: rgba(15, 45, 82, 0.92); color: var(--migcorp-cream);
}

/* Card meta row (location · year) */
.migcorp-port-card-meta {
	display: grid; grid-template-columns: 1fr 1fr; gap: 12px 16px;
	margin: 4px 0 0;
	padding: 14px 0 0;
	border-top: 1px solid var(--migcorp-line);
}
.migcorp-port-card-meta > div { display: flex; flex-direction: column; gap: 3px; }
.migcorp-port-card-meta dt {
	font-family: var(--migcorp-font-body);
	font-size: 9px; letter-spacing: 0.22em; text-transform: uppercase;
	color: var(--migcorp-gold); font-weight: 700;
}
.migcorp-port-card-meta dd {
	margin: 0;
	font-family: var(--migcorp-font-display);
	font-size: 13px;
	color: var(--migcorp-ink);
	letter-spacing: -0.005em;
}

/* Investment thesis — navy gradient strip after the grid */
.migcorp-port-thesis {
	background:
		radial-gradient(60% 50% at 50% 0%, rgba(229, 180, 80, 0.16) 0%, transparent 65%),
		radial-gradient(80% 60% at 0% 100%, rgba(31, 75, 124, 0.42) 0%, transparent 60%),
		radial-gradient(70% 60% at 100% 50%, rgba(26, 64, 112, 0.4) 0%, transparent 60%),
		linear-gradient(180deg, var(--migcorp-dark) 0%, var(--migcorp-dark-edge) 100%);
	color: var(--migcorp-cream);
	position: relative;
	overflow: hidden;
}
.migcorp-port-thesis::before {
	content: ""; position: absolute; top: 0; left: 50%; transform: translateX(-50%);
	width: 280px; max-width: 60vw; height: 1px;
	background: linear-gradient(90deg, transparent 0%, var(--migcorp-gold) 50%, transparent 100%);
	opacity: .55;
}
.migcorp-port-thesis-inner { max-width: 1200px; margin: 0 auto; text-align: center; }
.migcorp-port-thesis-inner .migcorp-section-num { color: var(--migcorp-gold); margin-bottom: 28px; }
.migcorp-port-thesis-inner .migcorp-section-num::before { background: currentColor; }
.migcorp-port-thesis-inner .migcorp-section-title {
	font-size: clamp(2.5rem, 5vw + 1rem, 5.5rem);
	font-weight: 700;
	letter-spacing: -0.03em;
	line-height: 1.05;
	max-width: 18ch;
	margin: 0 auto;
}
.migcorp-port-thesis-body {
	color: var(--migcorp-beige);
	font-size: 1.1rem;
	line-height: 1.7;
	margin: 32px auto 0;
	max-width: 64ch;
}

@media (max-width: 640px) {
	.migcorp-port-stats-grid > div { padding-left: 14px; }
	.migcorp-port-card-meta { grid-template-columns: 1fr; }
}

/* =========================================================================
   VERTICALS ARCHIVE — image-led cards with status pill + KPI dl
   ========================================================================= */
.migcorp-vert-archive { padding: clamp(56px, 7vw, 96px) 0; }

.migcorp-vert-archive-grid {
	display: grid; gap: 32px;
	grid-template-columns: 1fr;
	margin-top: 40px;
}
@media (min-width: 768px)  { .migcorp-vert-archive-grid { grid-template-columns: repeat(2, 1fr); } }

.migcorp-vert-archive-card {
	background: var(--migcorp-dark);
	color: var(--migcorp-cream);
	position: relative;
	overflow: hidden;
	transition: transform .35s var(--migcorp-ease-out), box-shadow .35s;
}
.migcorp-vert-archive-card:hover {
	transform: translateY(-6px);
	box-shadow: 0 30px 60px -20px rgba(10, 31, 60, 0.4);
}
.migcorp-vert-archive-card.is-coming { opacity: .92; }
.migcorp-vert-archive-link { display: block; color: inherit; text-decoration: none; }

.migcorp-vert-archive-media {
	position: relative;
	aspect-ratio: 16/9;
	overflow: hidden;
	background: var(--migcorp-dark);
}
.migcorp-vert-archive-img {
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform .7s var(--migcorp-ease-out);
}
.migcorp-vert-archive-card:hover .migcorp-vert-archive-img { transform: scale(1.06); }
.migcorp-vert-archive-overlay {
	position: absolute; inset: 0;
	background: linear-gradient(180deg, rgba(15, 45, 82, 0.3) 0%, rgba(10, 31, 60, 0.65) 100%);
	pointer-events: none;
}
.migcorp-vert-archive-icon {
	position: absolute; top: 18px; left: 18px;
	width: 48px; height: 48px;
	display: inline-flex; align-items: center; justify-content: center;
	background: rgba(15, 45, 82, 0.85);
	color: var(--migcorp-gold);
	border: 1px solid rgba(229, 180, 80, 0.4);
	border-radius: 50%;
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
	z-index: 2;
}
.migcorp-vert-archive-status {
	position: absolute; top: 18px; right: 18px;
	font-family: var(--migcorp-font-body);
	font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase;
	font-weight: 700;
	color: var(--migcorp-dark);
	background: var(--migcorp-gold);
	padding: 5px 10px;
	z-index: 2;
}
.migcorp-vert-archive-body {
	padding: 32px 32px 36px;
	display: flex; flex-direction: column; gap: 14px;
}
.migcorp-vert-archive-title {
	font-family: var(--migcorp-font-display);
	font-size: clamp(1.5rem, 1.6vw + 0.5rem, 2rem);
	font-weight: 700; letter-spacing: -0.02em;
	color: var(--migcorp-cream); margin: 0;
}
.migcorp-vert-archive-summary {
	color: var(--migcorp-beige);
	font-size: 14px;
	line-height: 1.65;
	margin: 0;
}
.migcorp-vert-archive-kpis {
	display: grid; grid-template-columns: 1fr 1fr; gap: 16px 24px;
	margin: 8px 0 0; padding: 16px 0 0;
	border-top: 1px solid rgba(229, 180, 80, 0.18);
}
.migcorp-vert-archive-kpis > div { display: flex; flex-direction: column; gap: 4px; }
.migcorp-vert-archive-kpis dt {
	font-family: var(--migcorp-font-display);
	font-size: clamp(1.25rem, 1.4vw + 0.4rem, 1.5rem);
	font-weight: 700; color: var(--migcorp-gold);
	letter-spacing: -0.01em; line-height: 1;
	margin: 0;
}
.migcorp-vert-archive-kpis dd {
	margin: 0;
	font-family: var(--migcorp-font-body);
	font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase;
	color: var(--migcorp-beige); font-weight: 600;
	opacity: .8;
}
.migcorp-vert-archive-cta {
	margin-top: 12px;
	display: inline-flex; align-items: center; gap: 10px;
	font-family: var(--migcorp-font-body);
	font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase;
	font-weight: 700;
	color: var(--migcorp-gold);
	transition: gap .3s var(--migcorp-ease-out);
}
.migcorp-vert-archive-link:hover .migcorp-vert-archive-cta { gap: 16px; }

/* =========================================================================
   INSIGHTS INDEX — featured lead card + deck
   ========================================================================= */
.migcorp-insights-lead { padding: clamp(56px, 7vw, 96px) 0 clamp(32px, 4vw, 56px); }

.migcorp-insights-lead-card {
	margin-top: 40px;
	background: var(--migcorp-white);
	border: 1px solid var(--migcorp-line);
	overflow: hidden;
	transition: transform .35s var(--migcorp-ease-out), border-color .35s, box-shadow .35s;
	position: relative;
}
.migcorp-insights-lead-card:hover {
	transform: translateY(-4px);
	border-color: rgba(229, 180, 80, 0.4);
	box-shadow: 0 30px 60px -20px rgba(10, 31, 60, 0.2);
}
.migcorp-insights-lead-link {
	display: grid;
	grid-template-columns: 1fr;
	color: inherit; text-decoration: none;
}
@media (min-width: 880px) {
	.migcorp-insights-lead-link { grid-template-columns: 55% 1fr; }
}
.migcorp-insights-lead-media {
	position: relative;
	aspect-ratio: 16/10;
	overflow: hidden;
	background: var(--migcorp-beige);
	display: flex; align-items: center; justify-content: center;
}
@media (min-width: 880px) {
	.migcorp-insights-lead-media { aspect-ratio: auto; height: 100%; min-height: 380px; }
}
.migcorp-insights-lead-img {
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform .7s var(--migcorp-ease-out);
}
.migcorp-insights-lead-card:hover .migcorp-insights-lead-img { transform: scale(1.04); }
.migcorp-insights-lead-placeholder { color: var(--migcorp-taupe); }

.migcorp-insights-lead-body {
	display: flex; flex-direction: column; gap: 14px;
	padding: clamp(28px, 4vw, 48px);
	justify-content: center;
}
.migcorp-insights-lead-title {
	font-family: var(--migcorp-font-display);
	font-size: clamp(1.5rem, 1.8vw + 0.5rem, 2.25rem);
	font-weight: 700; letter-spacing: -0.02em; line-height: 1.12;
	color: var(--migcorp-ink);
	margin: 0;
	transition: color .25s;
}
.migcorp-insights-lead-card:hover .migcorp-insights-lead-title { color: var(--migcorp-gold-700); }
.migcorp-insights-lead-excerpt {
	color: var(--migcorp-taupe);
	line-height: 1.7;
	margin: 0;
	font-size: 15px;
}
.migcorp-insights-lead-meta {
	display: flex; gap: 8px; align-items: center;
	font-family: var(--migcorp-font-body);
	font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase;
	color: var(--migcorp-muted); font-weight: 600;
}
.migcorp-insights-lead-cta {
	margin-top: 12px;
	display: inline-flex; align-items: center; gap: 10px;
	font-family: var(--migcorp-font-body);
	font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase;
	font-weight: 700;
	color: var(--migcorp-gold-700);
	transition: gap .3s var(--migcorp-ease-out), color .25s;
	width: fit-content;
}
.migcorp-insights-lead-card:hover .migcorp-insights-lead-cta { gap: 16px; color: var(--migcorp-gold); }

.migcorp-insights-archive { padding: clamp(40px, 5vw, 64px) 0 clamp(64px, 8vw, 96px); }
.migcorp-insights-archive .migcorp-section-head { margin-bottom: 40px; }

/* =========================================================================
   SINGLE INSIGHT POST — editorial prose + share + related
   ========================================================================= */
.migcorp-post-hero .migcorp-post-title {
	font-size: clamp(2rem, 3vw + 1rem, 3.75rem);
	max-width: 22ch;
	margin: 0;
}
.migcorp-post-hero .migcorp-post-meta {
	display: flex; flex-wrap: wrap; gap: 8px;
	margin-top: 24px;
	font-family: var(--migcorp-font-body);
	font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase;
	color: var(--migcorp-beige); font-weight: 600;
}
.migcorp-post-hero .migcorp-post-meta span[aria-hidden] { opacity: .5; }

.migcorp-post-body { padding: clamp(56px, 7vw, 96px) 0; }
.migcorp-post-prose-wrap {
	max-width: 760px;
	margin: 0 auto;
}
.migcorp-post-prose {
	font-family: var(--migcorp-font-body);
	font-size: 17px;
	line-height: 1.8;
	color: var(--migcorp-ink);
}
.migcorp-post-prose h2 {
	font-family: var(--migcorp-font-display);
	font-size: clamp(1.5rem, 1.8vw + 0.5rem, 2rem);
	font-weight: 700; letter-spacing: -0.018em; line-height: 1.2;
	margin: 56px 0 16px;
	color: var(--migcorp-ink);
}
.migcorp-post-prose h3 {
	font-family: var(--migcorp-font-display);
	font-size: clamp(1.25rem, 1vw + 0.5rem, 1.5rem);
	font-weight: 700; letter-spacing: -0.014em;
	margin: 40px 0 12px;
	color: var(--migcorp-ink);
}
.migcorp-post-prose p { margin: 0 0 22px; }
.migcorp-post-prose blockquote {
	border-left: 3px solid var(--migcorp-gold);
	margin: 40px 0;
	padding: 8px 0 8px 24px;
	font-family: var(--migcorp-font-display);
	font-size: clamp(1.25rem, 1vw + 0.5rem, 1.5rem);
	font-style: italic;
	color: var(--migcorp-ink);
	line-height: 1.4;
}
.migcorp-post-prose a {
	color: var(--migcorp-gold-700);
	border-bottom: 1px solid rgba(229, 180, 80, 0.4);
	text-decoration: none;
	transition: color .25s, border-color .25s;
}
.migcorp-post-prose a:hover { color: var(--migcorp-gold); border-bottom-color: var(--migcorp-gold); }
.migcorp-post-prose ul, .migcorp-post-prose ol { margin: 0 0 22px 24px; padding: 0; }
.migcorp-post-prose li { margin-bottom: 8px; }
.migcorp-post-prose img { max-width: 100%; height: auto; margin: 32px 0; }

.migcorp-post-byline {
	display: flex; gap: 20px; align-items: flex-start;
	margin: 64px 0 40px;
	padding: 32px 0;
	border-top: 1px solid var(--migcorp-line);
	border-bottom: 1px solid var(--migcorp-line);
}
.migcorp-post-byline-avatar { border-radius: 50%; flex-shrink: 0; }
.migcorp-post-byline-text { display: flex; flex-direction: column; gap: 4px; }
.migcorp-post-byline-name { font-family: var(--migcorp-font-display); font-size: 1.125rem; color: var(--migcorp-ink); letter-spacing: -0.01em; }
.migcorp-post-byline-bio { color: var(--migcorp-taupe); font-size: 14px; line-height: 1.6; margin: 4px 0 0; }

.migcorp-post-share {
	display: flex; align-items: center; gap: 20px;
	margin-top: 8px;
}
.migcorp-post-share .migcorp-eyebrow { color: var(--migcorp-muted); }
.migcorp-post-share ul {
	list-style: none; padding: 0; margin: 0;
	display: flex; gap: 10px;
}
.migcorp-post-share a,
.migcorp-post-share button {
	width: 36px; height: 36px;
	border-radius: 50%;
	display: inline-flex; align-items: center; justify-content: center;
	background: var(--migcorp-cream);
	border: 1px solid rgba(229, 180, 80, 0.3);
	color: var(--migcorp-ink);
	cursor: pointer;
	transition: all .25s;
}
.migcorp-post-share a:hover,
.migcorp-post-share button:hover {
	background: var(--migcorp-gold);
	color: var(--migcorp-dark);
	border-color: var(--migcorp-gold);
	transform: translateY(-2px);
}
.migcorp-post-share-copy.is-copied {
	background: var(--migcorp-gold);
	color: var(--migcorp-dark);
}

.migcorp-post-related { padding: clamp(64px, 8vw, 96px) 0; }

/* =========================================================================
   MOBILE PASS 2 — new templates (Verticals/Caps archives, Insights, Single)
   ========================================================================= */
@media (max-width: 640px) {

	/* Verticals archive */
	.migcorp-vert-archive-body { padding: 24px 22px 28px; }
	.migcorp-vert-archive-title { font-size: clamp(1.25rem, 6vw, 1.75rem); }
	.migcorp-vert-archive-icon { width: 40px; height: 40px; top: 12px; left: 12px; }
	.migcorp-vert-archive-status { top: 12px; right: 12px; font-size: 9px; padding: 4px 8px; }
	.migcorp-vert-archive-kpis { gap: 12px 16px; }

	/* Portfolio stats strip (also used on cap/vert archives) */
	.migcorp-port-stats-grid { grid-template-columns: 1fr 1fr; gap: 16px 20px; }
	.migcorp-port-stats-grid > div { padding-left: 14px; padding-top: 14px; padding-bottom: 14px; }
	.migcorp-port-stats-grid dd { font-size: clamp(1.25rem, 7vw, 1.75rem); }

	/* Portfolio thesis section (wider headline needs reflow on mobile) */
	.migcorp-port-thesis-inner .migcorp-section-title { font-size: clamp(2rem, 9vw, 2.75rem); max-width: 100%; }
	.migcorp-port-thesis-body { font-size: 1rem; }

	/* Capabilities archive rows */
	.migcorp-caps-row-link { padding: 18px 4px; gap: 12px; }
	.migcorp-caps-row-title { font-size: 1.05rem; }
	.migcorp-caps-row-summary { font-size: 13px; }

	/* Insights lead card */
	.migcorp-insights-lead { padding: 48px 0 32px; }
	.migcorp-insights-lead-card { margin-top: 28px; }
	.migcorp-insights-lead-body { padding: 24px; gap: 12px; }
	.migcorp-insights-lead-title { font-size: clamp(1.25rem, 6vw, 1.75rem); }
	.migcorp-insights-lead-excerpt { font-size: 14px; }

	/* Single insight */
	.migcorp-post-hero .migcorp-post-title { font-size: clamp(1.5rem, 8vw, 2.25rem); }
	.migcorp-post-hero .migcorp-post-meta { font-size: 10px; letter-spacing: 0.14em; gap: 6px; }
	.migcorp-post-prose { font-size: 16px; line-height: 1.75; }
	.migcorp-post-prose h2 { font-size: clamp(1.25rem, 6vw, 1.75rem); margin: 40px 0 12px; }
	.migcorp-post-prose h3 { font-size: 1.125rem; margin: 28px 0 10px; }
	.migcorp-post-prose blockquote { padding-left: 18px; font-size: 1.125rem; }
	.migcorp-post-byline { flex-direction: column; gap: 12px; padding: 24px 0; }
	.migcorp-post-share { flex-wrap: wrap; gap: 14px; }
	.migcorp-post-share a, .migcorp-post-share button { width: 36px; height: 36px; }

	/* Reading progress bar — thinner on mobile to feel native */
	.migcorp-reading-progress { height: 2px; }
}

/* Tablet refinements for new templates */
@media (min-width: 641px) and (max-width: 1023px) {
	.migcorp-vert-archive-grid { grid-template-columns: 1fr; }
	.migcorp-port-stats-grid { grid-template-columns: repeat(2, 1fr); }
	.migcorp-insights-lead-link { grid-template-columns: 1fr; }
	.migcorp-insights-lead-media { aspect-ratio: 16/10; min-height: 0; }
}

/* =========================================================================
   CAPABILITY SINGLE — meta strip, features grid, steps grid
   ========================================================================= */

/* Meta strip — replaces the plain scope text with structured data row */
.migcorp-cap-meta-strip {
	display: grid; gap: 16px;
	grid-template-columns: 1fr;
	margin-top: 16px;
}
.migcorp-cap-meta-cell {
	display: flex; flex-direction: column; gap: 6px;
	padding: 18px 0 18px 18px;
	border-left: 2px solid var(--migcorp-gold);
}
.migcorp-cap-meta-cell dt {
	font-family: var(--migcorp-font-body);
	font-size: 10px; letter-spacing: 0.24em; text-transform: uppercase;
	color: var(--migcorp-gold); font-weight: 700;
	margin: 0;
}
.migcorp-cap-meta-cell dd {
	margin: 0;
	font-family: var(--migcorp-font-display);
	font-size: 1.05rem;
	color: var(--migcorp-ink);
	letter-spacing: -0.005em;
	line-height: 1.3;
}

.migcorp-cap-content { background: var(--migcorp-white); padding: clamp(56px, 7vw, 96px) 0; }
.migcorp-cap-content-inner { max-width: 780px; margin: 0 auto; }

/* Features list — 2-column grid of check-prefixed items */
.migcorp-cap-features { padding: clamp(56px, 7vw, 96px) 0; background: var(--migcorp-grey); }
.migcorp-cap-features-grid {
	list-style: none; padding: 0;
	margin: 48px 0 0;
	display: grid; gap: 18px 32px;
	grid-template-columns: 1fr;
}
@media (min-width: 768px) { .migcorp-cap-features-grid { grid-template-columns: repeat(2, 1fr); } }
.migcorp-cap-feature {
	display: flex; gap: 14px; align-items: flex-start;
	padding: 16px 0;
	border-bottom: 1px solid var(--migcorp-line);
	font-size: 15px;
	line-height: 1.55;
	color: var(--migcorp-ink-2);
}
.migcorp-cap-feature-icon {
	flex-shrink: 0;
	width: 28px; height: 28px;
	display: inline-flex; align-items: center; justify-content: center;
	background: rgba(229, 180, 80, 0.15);
	color: var(--migcorp-gold-700);
	border-radius: 50%;
	margin-top: 1px;
}

/* Steps — horizontal numbered process */
.migcorp-cap-steps { background: var(--migcorp-white); padding: clamp(56px, 7vw, 96px) 0; }
.migcorp-cap-steps-grid {
	list-style: none; padding: 0;
	margin: 48px 0 0;
	display: grid; gap: 28px;
	grid-template-columns: 1fr;
	counter-reset: cap-steps;
}
@media (min-width: 768px)  { .migcorp-cap-steps-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .migcorp-cap-steps-grid { grid-template-columns: repeat(4, 1fr); gap: 24px; } }
.migcorp-cap-step {
	display: flex; flex-direction: column; gap: 14px;
	padding: 28px 24px;
	border: 1px solid var(--migcorp-line);
	background: var(--migcorp-cream);
	position: relative;
	transition: transform .35s, border-color .35s, box-shadow .35s;
}
.migcorp-cap-step::before {
	content: ""; position: absolute; top: 0; left: 0;
	width: 32px; height: 2px;
	background: var(--migcorp-gold);
	transition: width .45s var(--migcorp-ease-out);
}
.migcorp-cap-step:hover {
	transform: translateY(-4px);
	border-color: rgba(229, 180, 80, 0.4);
	box-shadow: 0 24px 48px -20px rgba(10, 31, 60, 0.16);
}
.migcorp-cap-step:hover::before { width: 100%; }
.migcorp-cap-step-num {
	font-family: var(--migcorp-font-display);
	font-size: 1.5rem; font-weight: 700;
	color: var(--migcorp-gold);
	letter-spacing: -0.01em;
	line-height: 1;
}
.migcorp-cap-step-title {
	font-family: var(--migcorp-font-display);
	font-size: 1.125rem; font-weight: 700;
	color: var(--migcorp-ink); margin: 0;
	letter-spacing: -0.015em;
	line-height: 1.25;
}
.migcorp-cap-step-body { color: var(--migcorp-taupe); margin: 0; font-size: 14px; line-height: 1.65; }

.migcorp-cap-related { padding: clamp(56px, 7vw, 96px) 0; }

@media (min-width: 768px) {
	.migcorp-cap-meta-strip { grid-template-columns: repeat(3, 1fr); gap: 24px; }
}

/* =========================================================================
   CAPABILITY SINGLE v2 — premium upgrade
   ========================================================================= */

/* "The promise" — upgrade from regular paragraph to editorial pull-statement */
.migcorp-cap-promise-copy { display: flex; flex-direction: column; }
.migcorp-cap-promise-text {
	font-family: var(--migcorp-font-display);
	font-size: clamp(1.5rem, 1.8vw + 0.5rem, 2.125rem) !important;
	font-weight: 600;
	line-height: 1.3;
	letter-spacing: -0.018em;
	color: var(--migcorp-ink);
	margin: 16px 0 0;
	max-width: 24ch;
}
.migcorp-cap-promise-text em {
	color: var(--migcorp-gold);
	font-style: italic;
	font-weight: 700;
}

/* Meta strip — auto-fit so 2 cells don't leave a phantom column */
.migcorp-cap-meta-strip {
	display: grid;
	gap: 16px;
	grid-template-columns: 1fr;
	margin: 0;
	align-self: end;                    /* anchor to bottom of grid cell on desktop */
}
@media (min-width: 768px) {
	.migcorp-cap-meta-strip { grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 20px; }
	.migcorp-cap-meta-strip--cells-2 { grid-template-columns: repeat(2, 1fr); max-width: 480px; margin-left: auto; }
	.migcorp-cap-meta-strip--cells-3 { grid-template-columns: repeat(3, 1fr); }
}
.migcorp-cap-meta-cell {
	display: flex; flex-direction: column; gap: 6px;
	padding: 18px 0 18px 18px;
	border-left: 2px solid var(--migcorp-gold);
}

/* KPI strip — same language as portfolio stats but lives below promise */
/* KPI strip — navy gradient (matches Featured Investment / homepage stats treatment) */
.migcorp-cap-kpis {
	padding: clamp(56px, 6vw, 80px) 0;
	color: var(--migcorp-cream);
	position: relative;
	overflow: hidden;
	background:
		radial-gradient(60% 50% at 50% 0%, rgba(229, 180, 80, 0.14) 0%, transparent 65%),
		radial-gradient(80% 60% at 0% 100%, rgba(31, 75, 124, 0.42) 0%, transparent 60%),
		radial-gradient(70% 60% at 100% 30%, rgba(26, 64, 112, 0.52) 0%, transparent 60%),
		linear-gradient(180deg, var(--migcorp-dark) 0%, var(--migcorp-dark-edge) 100%);
}
.migcorp-cap-kpis::before {
	content: ""; position: absolute; top: 0; left: 50%; transform: translateX(-50%);
	width: 280px; max-width: 60vw; height: 1px;
	background: linear-gradient(90deg, transparent 0%, var(--migcorp-gold) 50%, transparent 100%);
	opacity: .55; z-index: 1;
}
.migcorp-cap-kpis-grid {
	display: grid; gap: 24px 32px;
	grid-template-columns: repeat(2, 1fr);
	margin: 0;
	position: relative; z-index: 2;
}
@media (min-width: 768px) { .migcorp-cap-kpis-grid { grid-template-columns: repeat(4, 1fr); } }
.migcorp-cap-kpi {
	display: flex; flex-direction: column; gap: 10px;
	padding: 20px 0 20px 18px;
	border-left: 2px solid var(--migcorp-gold);
}
.migcorp-cap-kpi dt {
	font-family: var(--migcorp-font-display);
	font-size: clamp(1.75rem, 2.2vw + 0.5rem, 2.75rem);
	font-weight: 700; color: var(--migcorp-cream);
	letter-spacing: -0.025em; line-height: 1;
	margin: 0;
}
.migcorp-cap-kpi dd {
	margin: 0;
	font-family: var(--migcorp-font-body);
	font-size: 11px; letter-spacing: 0.24em; text-transform: uppercase;
	color: var(--migcorp-gold); font-weight: 700;
}

/* Body content section gets the wash backdrop + section eyebrow */
.migcorp-cap-content { padding: clamp(56px, 7vw, 96px) 0; }
.migcorp-cap-content-inner { max-width: 820px; margin: 0 auto; }
.migcorp-cap-content .migcorp-section-head { margin-bottom: 24px; }
.migcorp-cap-content .migcorp-prose {
	font-size: 16px;
	line-height: 1.75;
	color: var(--migcorp-ink-2);
}

/* Use cases — 4-up icon cards */
.migcorp-cap-uses { background: var(--migcorp-white); padding: clamp(56px, 7vw, 96px) 0; }
.migcorp-cap-uses-grid {
	display: grid; gap: 24px;
	grid-template-columns: 1fr;
	margin-top: 48px;
}
@media (min-width: 640px)  { .migcorp-cap-uses-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .migcorp-cap-uses-grid { grid-template-columns: repeat(4, 1fr); } }

.migcorp-cap-use {
	display: flex; flex-direction: column; gap: 14px;
	padding: 32px 28px;
	border: 1px solid var(--migcorp-line);
	background: var(--migcorp-cream);
	position: relative;
	transition: transform .35s, border-color .35s, box-shadow .35s;
}
.migcorp-cap-use::before {
	content: ""; position: absolute; top: 0; left: 0;
	width: 32px; height: 2px;
	background: var(--migcorp-gold);
	transition: width .45s var(--migcorp-ease-out);
}
.migcorp-cap-use:hover {
	transform: translateY(-4px);
	border-color: rgba(229, 180, 80, 0.4);
	box-shadow: 0 24px 48px -20px rgba(10, 31, 60, 0.16);
}
.migcorp-cap-use:hover::before { width: 100%; }
.migcorp-cap-use-icon {
	width: 44px; height: 44px;
	display: inline-flex; align-items: center; justify-content: center;
	background: rgba(229, 180, 80, 0.14);
	color: var(--migcorp-gold-700);
	border-radius: 50%;
}
.migcorp-cap-use-title {
	font-family: var(--migcorp-font-display);
	font-size: 1.2rem; font-weight: 700;
	color: var(--migcorp-ink); margin: 0;
	letter-spacing: -0.015em;
}
.migcorp-cap-use-body { color: var(--migcorp-taupe); margin: 0; font-size: 14px; line-height: 1.65; }

/* Capability-specific CTA strip — navy gradient with centered editorial copy */
.migcorp-cap-cta {
	background:
		radial-gradient(60% 50% at 50% 0%, rgba(229, 180, 80, 0.16) 0%, transparent 65%),
		radial-gradient(80% 60% at 0% 100%, rgba(31, 75, 124, 0.42) 0%, transparent 60%),
		radial-gradient(70% 60% at 100% 50%, rgba(26, 64, 112, 0.4) 0%, transparent 60%),
		linear-gradient(180deg, var(--migcorp-dark) 0%, var(--migcorp-dark-edge) 100%);
	color: var(--migcorp-cream);
	position: relative;
	overflow: hidden;
}
.migcorp-cap-cta::before {
	content: ""; position: absolute; top: 0; left: 50%; transform: translateX(-50%);
	width: 280px; max-width: 60vw; height: 1px;
	background: linear-gradient(90deg, transparent 0%, var(--migcorp-gold) 50%, transparent 100%);
	opacity: .55;
}
.migcorp-cap-cta-inner { max-width: 920px; margin: 0 auto; text-align: center; }
.migcorp-cap-cta-title {
	font-family: var(--migcorp-font-display);
	font-size: clamp(2rem, 3.4vw + 0.5rem, 3.5rem);
	font-weight: 700; letter-spacing: -0.025em; line-height: 1.1;
	color: var(--migcorp-cream);
	margin: 0 0 24px;
	max-width: 22ch;
	margin-left: auto; margin-right: auto;
}
.migcorp-cap-cta-title em { color: var(--migcorp-gold); font-style: italic; }
.migcorp-cap-cta-body {
	color: var(--migcorp-beige);
	font-size: 1.05rem;
	line-height: 1.7;
	margin: 0 auto 36px;
	max-width: 56ch;
}

/* Related insights section inherits insights-deck layout */
.migcorp-cap-related-insights { padding: clamp(56px, 7vw, 96px) 0; }
.migcorp-cap-related-insights .migcorp-section-head { margin-bottom: 40px; }


/* =========================================================================
   CAPABILITY SINGLE v3 — polish (post-audit fixes)
   ========================================================================= */

/* Execution-sequence cards — small icon dot + animated gold connector on desktop */
.migcorp-cap-steps-grid { position: relative; }
@media (min-width: 1024px) {
	/* Gold connector line behind the row of cards */
	.migcorp-cap-steps-grid::before {
		content: ""; position: absolute;
		top: 36px; left: 6%; right: 6%;
		height: 1px;
		background: linear-gradient(90deg,
			rgba(229, 180, 80, 0.5) 0%,
			rgba(229, 180, 80, 0.5) 100%);
		opacity: .6;
		z-index: 0;
	}
}
.migcorp-cap-step {
	z-index: 1;                          /* sit above the connector */
}
/* Number badge — clean, no extra marker (connector line was removed) */
.migcorp-cap-step-num {
	position: relative;
	display: inline-flex; align-items: center;
}
.migcorp-cap-step-num::after { content: none; }

/* Use cases — tighter typography + breathing room */
.migcorp-cap-use-body {
	font-size: 15px;
	line-height: 1.7;
}
.migcorp-cap-use-title {
	padding-top: 4px;
	border-top: 1px solid rgba(229, 180, 80, 0.18);
	margin-top: 4px;
}

/* Related capabilities — more breathing room before the press strip */
.migcorp-cap-related { padding-bottom: clamp(80px, 9vw, 128px); }

/* Suppress the legacy "Featured" tag if it slips through — sanity guard */
.migcorp-insight-card-tag:empty { display: none; }


/* =========================================================================
   CAPABILITY SINGLE v4 — polish round 2 (post-audit)
   ========================================================================= */

/* Promise headline — prevent awkward hyphenation on "structured-finance" */
.migcorp-cap-promise-text {
	hyphens: manual;
	-webkit-hyphens: manual;
	word-break: keep-all;
	overflow-wrap: break-word;
}

/* Sectors chip row — JS-transformed from "<strong>Sectors financed:</strong> a · b · c" */
.migcorp-cap-chiprow {
	margin: 32px 0 0;
	padding: 24px 0 0;
	border-top: 1px solid rgba(229, 180, 80, 0.22);
	display: flex; flex-wrap: wrap; align-items: center;
	gap: 12px 16px;
}
.migcorp-cap-chiprow-label {
	font-family: var(--migcorp-font-body);
	font-size: 11px; letter-spacing: 0.24em; text-transform: uppercase;
	color: var(--migcorp-gold-700); font-weight: 700;
}
.migcorp-cap-chiprow-list {
	list-style: none; padding: 0; margin: 0;
	display: flex; flex-wrap: wrap; gap: 8px;
}
.migcorp-cap-chiprow-list li {
	display: inline-flex; align-items: center;
	padding: 6px 14px;
	background: rgba(229, 180, 80, 0.10);
	border: 1px solid rgba(229, 180, 80, 0.28);
	color: var(--migcorp-ink);
	font-family: var(--migcorp-font-body);
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.04em;
	border-radius: 999px;
	transition: background .25s, border-color .25s;
}
.migcorp-cap-chiprow-list li:hover {
	background: rgba(229, 180, 80, 0.22);
	border-color: var(--migcorp-gold);
}

/* Execution sequence — connector line removed. Numbered cards carry the
   sequence; chevron arrows in the gaps between cards reinforce direction. */
.migcorp-cap-steps-grid {
	position: relative;
	z-index: 0;
}
.migcorp-cap-steps-grid::before { content: none !important; display: none !important; }
/* Step cards — stronger border + tighter hover */
.migcorp-cap-step {
	border-width: 1px;
	border-color: var(--migcorp-line);
	background: var(--migcorp-white);
	box-shadow: 0 1px 0 rgba(10, 31, 60, 0.04);
	z-index: 1;
	position: relative;
}
.migcorp-cap-step::before {
	height: 3px;                          /* slightly heavier accent */
}
.migcorp-cap-step:hover {
	border-color: rgba(229, 180, 80, 0.55);
	box-shadow: 0 28px 56px -22px rgba(10, 31, 60, 0.22);
}

/* CTA button — strengthen large variant when used on the capability strip */
.migcorp-cap-cta .migcorp-btn--lg,
.migcorp-cap-cta .migcorp-btn--accent {
	padding: 18px 36px;
	font-size: 14px;
	letter-spacing: 0.18em;
}
.migcorp-cap-cta .migcorp-btn svg {
	width: 16px; height: 16px;
}

/* =========================================================================
   CAPABILITY SINGLE v5 — background rhythm fix
   Breaks the cream/white cluster: Steps → navy, Use Cases + Related → cream-wash
   ========================================================================= */

/* Steps → NAVY gradient (same family as KPIs / Final-CTA / ESG) */
.migcorp-cap-steps {
	background:
		radial-gradient(60% 50% at 50% 0%, rgba(229, 180, 80, 0.14) 0%, transparent 65%),
		radial-gradient(80% 60% at 0% 100%, rgba(31, 75, 124, 0.42) 0%, transparent 60%),
		radial-gradient(70% 60% at 100% 30%, rgba(26, 64, 112, 0.5) 0%, transparent 60%),
		linear-gradient(180deg, var(--migcorp-dark) 0%, var(--migcorp-dark-edge) 100%);
	color: var(--migcorp-cream);
	position: relative;
	overflow: hidden;
}
.migcorp-cap-steps::before {
	content: ""; position: absolute; top: 0; left: 50%; transform: translateX(-50%);
	width: 280px; max-width: 60vw; height: 1px;
	background: linear-gradient(90deg, transparent 0%, var(--migcorp-gold) 50%, transparent 100%);
	opacity: .55;
}
.migcorp-cap-steps .migcorp-section-head { position: relative; z-index: 2; }
.migcorp-cap-steps .migcorp-section-title { color: var(--migcorp-cream); }
.migcorp-cap-steps .migcorp-section-num   { color: var(--migcorp-gold); }
.migcorp-cap-steps .migcorp-section-num::before { background: currentColor; }
.migcorp-cap-steps-grid { position: relative; z-index: 2; }

/* Step cards on navy: translucent-white surface, gold border on hover */
.migcorp-cap-step {
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.05) 0%, rgba(255, 255, 255, 0.015) 100%);
	border: 1px solid rgba(229, 180, 80, 0.18);
	box-shadow: none;
	backdrop-filter: blur(2px);
	-webkit-backdrop-filter: blur(2px);
}
.migcorp-cap-step::before {
	background: var(--migcorp-gold);
}
.migcorp-cap-step:hover {
	border-color: rgba(229, 180, 80, 0.45);
	box-shadow: 0 28px 56px -22px rgba(0, 0, 0, 0.5);
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.08) 0%, rgba(255, 255, 255, 0.03) 100%);
}
.migcorp-cap-step-num   { color: var(--migcorp-gold); }
.migcorp-cap-step-title { color: var(--migcorp-cream); }
.migcorp-cap-step-body  { color: var(--migcorp-beige); }

/* Connector line — removed entirely. Sequence implied by numbered cards + chevrons. */
.migcorp-cap-steps .migcorp-cap-steps-grid::before { content: none !important; }

/* Chevron arrows removed — the numbered cards (01 → 02 → 03 → 04) carry
   the sequence on their own. Cleaner without any inter-card decoration. */
.migcorp-cap-step + .migcorp-cap-step::after { content: none !important; }

/* Use Cases → cream-wash (was pure white, now visually distinct from features above) */
.migcorp-cap-uses {
	background: var(--migcorp-cream);
	position: relative;
	isolation: isolate;
	overflow: hidden;
}
.migcorp-cap-uses::before {
	content: ""; position: absolute; inset: 0;
	background:
		radial-gradient(70% 60% at 0% 10%,  rgba(31, 75, 124, 0.06) 0%, transparent 65%),
		radial-gradient(60% 55% at 100% 100%, rgba(229, 180, 80, 0.08) 0%, transparent 65%);
	pointer-events: none;
	z-index: 0;
}
.migcorp-cap-uses > * { position: relative; z-index: 1; }
.migcorp-cap-use {
	background: var(--migcorp-white);   /* keep cards white so they pop against the wash */
}

/* Related Capabilities → cool grey (visually distinct from Insights cream above it) */
.migcorp-cap-related {
	background: var(--migcorp-grey);
	position: relative;
}
.migcorp-cap-related::before { content: none; }

/* =========================================================================
   VERTICALS BENTO — 2×2 image-backed cards for non-desktop widths (≤1023px)
   Each card uses the vertical's own hero image as a full-bleed background
   with a navy gradient overlay so text stays readable. Matches the editorial
   richness of the desktop feature card — without the awkward stacked layout.
   ========================================================================= */
@media (max-width: 1023px) {
	.migcorp-bento {
		grid-template-columns: 1fr !important;
		gap: 0 !important;
	}
	.migcorp-bento-feature { display: none !important; }
	.migcorp-bento-list {
		list-style: none !important;
		padding: 0 !important;
		margin: 0 !important;
		display: grid !important;
		grid-template-columns: repeat(2, 1fr) !important;
		gap: 14px !important;
	}

	/* The card — image as background, navy bottom-to-top overlay */
	.migcorp-bento-row {
		padding: 0 !important;
		border: 1px solid rgba(229, 180, 80, 0.18) !important;
		background:
			linear-gradient(180deg, rgba(15, 45, 82, 0.25) 0%, rgba(15, 45, 82, 0.75) 65%, rgba(10, 31, 60, 0.92) 100%),
			var(--vert-card-bg, linear-gradient(180deg, var(--migcorp-dark), var(--migcorp-dark-edge)))
			center / cover no-repeat !important;
		border-radius: 2px;
		overflow: hidden;
		position: relative;
		aspect-ratio: 1 / 1.15;
		transition: transform .3s var(--migcorp-ease-out), border-color .3s, box-shadow .3s;
		box-shadow: 0 10px 30px -12px rgba(10, 31, 60, 0.35);
	}
	.migcorp-bento-row:hover {
		transform: translateY(-3px);
		border-color: rgba(229, 180, 80, 0.5) !important;
		box-shadow: 0 20px 40px -16px rgba(10, 31, 60, 0.5);
	}
	.migcorp-bento-row.is-active {
		border-color: var(--migcorp-gold) !important;
		box-shadow: 0 0 0 1px var(--migcorp-gold), 0 14px 36px -14px rgba(10, 31, 60, 0.45);
	}
	.migcorp-bento-row.is-coming { opacity: .92; }

	/* Subtle radial highlight for editorial texture */
	.migcorp-bento-row::after {
		content: "";
		position: absolute; inset: 0;
		background: radial-gradient(80% 60% at 0% 0%, rgba(255,255,255,0.04) 0%, transparent 60%);
		pointer-events: none;
	}

	.migcorp-bento-row-link {
		display: flex !important;
		flex-direction: column !important;
		justify-content: space-between !important;
		align-items: flex-start !important;
		gap: 12px !important;
		padding: 18px 18px 20px !important;
		height: 100%;
		text-decoration: none;
		position: relative;
		z-index: 2;
	}

	/* Number — top-left, gold with text-shadow */
	.migcorp-bento-row-num {
		font-size: 13px !important;
		font-family: var(--migcorp-font-display);
		color: var(--migcorp-gold) !important;
		font-weight: 700;
		letter-spacing: 0.06em;
		margin: 0;
		text-shadow: 0 1px 8px rgba(0,0,0,0.4);
	}

	/* Icon — top-right floating pill with backdrop blur */
	.migcorp-bento-row-icon {
		position: absolute;
		top: 16px; right: 16px;
		width: 36px; height: 36px;
		display: inline-flex; align-items: center; justify-content: center;
		background: rgba(15, 45, 82, 0.7);
		color: var(--migcorp-gold);
		border-radius: 50%;
		border: 1px solid rgba(229, 180, 80, 0.35);
		backdrop-filter: blur(4px);
		-webkit-backdrop-filter: blur(4px);
	}
	.migcorp-bento-row-icon svg { width: 16px; height: 16px; }

	/* Title — pinned to bottom, large cream-on-navy */
	.migcorp-bento-row-body {
		padding: 0 !important;
		margin-top: auto;
		min-width: 0;
	}
	.migcorp-bento-row-title {
		font-family: var(--migcorp-font-display);
		font-size: 1.125rem !important;
		line-height: 1.15 !important;
		font-weight: 700 !important;
		letter-spacing: -0.018em;
		margin: 0 !important;
		color: var(--migcorp-cream) !important;
		text-shadow: 0 2px 12px rgba(0,0,0,0.5);
	}
	.migcorp-bento-row-summary { display: none !important; }
	.migcorp-bento-row-cta { display: none !important; }

	/* Coming 2026 tag — replaces the icon in the top-right corner */
	.migcorp-bento-row.is-coming .migcorp-bento-row-icon { display: none !important; }
	.migcorp-bento-row.is-coming .migcorp-coming-tag,
	.migcorp-coming-tag {
		position: absolute !important;
		top: 14px; right: 14px;
		bottom: auto; left: auto;
		font-family: var(--migcorp-font-body);
		font-size: 9px !important;
		letter-spacing: 0.2em !important;
		text-transform: uppercase;
		font-weight: 700;
		color: var(--migcorp-dark) !important;
		background: var(--migcorp-gold) !important;
		padding: 4px 8px !important;
		border-radius: 0;
		margin: 0 !important;
		z-index: 3;
	}
}

/* Tablet portrait — slightly bigger touch targets + larger typography */
@media (min-width: 641px) and (max-width: 1023px) {
	.migcorp-bento-list { gap: 18px !important; }
	.migcorp-bento-row { aspect-ratio: 1 / 1.05; }
	.migcorp-bento-row-link { padding: 24px 22px 26px !important; }
	.migcorp-bento-row-title { font-size: 1.375rem !important; }
	.migcorp-bento-row-icon { width: 44px; height: 44px; top: 20px; right: 20px; }
	.migcorp-bento-row-icon svg { width: 20px; height: 20px; }
}

/* =========================================================================
   MOBILE DRAWER — premium editorial overhaul
   Larger Playfair display typography for top-level items, gold chevron
   dropdown indicators, gold-tinted dividers, indented children, plus a
   contact/social/regulator block fills the empty space below the menu.
   ========================================================================= */

/* Drawer container — premium cream backdrop with subtle wash */
.migcorp-mobile {
	background:
		radial-gradient(60% 50% at 0% 0%, rgba(229, 180, 80, 0.06) 0%, transparent 70%),
		radial-gradient(60% 50% at 100% 100%, rgba(31, 75, 124, 0.04) 0%, transparent 70%),
		var(--migcorp-cream);
}

/* Top bar — logo + close button */
.migcorp-mobile__top {
	padding: 22px 24px;
	border-bottom: 1px solid rgba(229, 180, 80, 0.18);
}
.migcorp-mobile__top .migcorp-brand-mark { height: 48px; max-height: 48px; }
.migcorp-mobile__close {
	width: 44px; height: 44px;
	border-radius: 50%;
	border: 1px solid rgba(229, 180, 80, 0.4);
	background: var(--migcorp-white);
	color: var(--migcorp-ink);
	transition: background .25s, color .25s, transform .35s var(--migcorp-ease-out);
}
.migcorp-mobile__close:hover {
	background: var(--migcorp-gold);
	color: var(--migcorp-dark);
	transform: rotate(90deg);
}

/* Nav section */
.migcorp-mobile__nav {
	padding: 32px 24px 24px;
	flex: 1;
	display: flex; flex-direction: column;
}

.migcorp-mobile__eyebrow {
	display: inline-block;
	font-family: var(--migcorp-font-body);
	font-size: 10px; letter-spacing: 0.28em; text-transform: uppercase;
	color: var(--migcorp-gold);
	font-weight: 700;
	margin: 0 0 24px;
	padding-left: 28px;
	position: relative;
}
.migcorp-mobile__eyebrow::before {
	content: ""; position: absolute; left: 0; top: 50%;
	width: 18px; height: 1px;
	background: var(--migcorp-gold);
}

/* Menu list — editorial spacing */
.migcorp-mobile__list {
	display: flex !important;
	flex-direction: column !important;
	gap: 0 !important;
	list-style: none !important;
	margin: 0 !important;
	padding: 0 !important;
}
.migcorp-mobile__list > .migcorp-menu__item {
	border-bottom: 1px solid rgba(229, 180, 80, 0.18);
	position: relative;
}
.migcorp-mobile__list > .migcorp-menu__item:last-child { border-bottom: 0; }

/* Top-level menu item — Playfair display typography, large + confident */
.migcorp-mobile__list > .migcorp-menu__item > .migcorp-menu__link {
	display: flex !important;
	align-items: center !important;
	justify-content: flex-start !important;
	padding: 22px 56px 22px 0 !important;
	font-family: var(--migcorp-font-display) !important;
	font-size: 1.625rem !important;
	font-weight: 700 !important;
	letter-spacing: -0.018em !important;
	line-height: 1.15 !important;
	color: var(--migcorp-ink) !important;
	text-decoration: none !important;
	border-radius: 0 !important;
	transition: color .25s, padding-left .25s;
	background: transparent !important;
}
.migcorp-mobile__list > .migcorp-menu__item > .migcorp-menu__link:hover {
	color: var(--migcorp-gold-700) !important;
	background: transparent !important;
	padding-left: 8px !important;
}

/* Active item — gold left rule + gold-tinted color */
.migcorp-mobile__list > .migcorp-menu__item.current-menu-item > .migcorp-menu__link,
.migcorp-mobile__list > .migcorp-menu__item.current_page_item > .migcorp-menu__link,
.migcorp-mobile__list > .migcorp-menu__item.current-menu-parent > .migcorp-menu__link,
.migcorp-mobile__list > .migcorp-menu__item.current-menu-ancestor > .migcorp-menu__link {
	color: var(--migcorp-gold-700) !important;
	background: transparent !important;
	padding-left: 16px !important;
}
.migcorp-mobile__list > .migcorp-menu__item.current-menu-item > .migcorp-menu__link::before,
.migcorp-mobile__list > .migcorp-menu__item.current_page_item > .migcorp-menu__link::before,
.migcorp-mobile__list > .migcorp-menu__item.current-menu-parent > .migcorp-menu__link::before,
.migcorp-mobile__list > .migcorp-menu__item.current-menu-ancestor > .migcorp-menu__link::before {
	content: '';
	position: absolute;
	left: 0; top: 26px; bottom: 26px;
	width: 4px;
	background: var(--migcorp-gold);
	border-radius: 2px;
}

/* Expand toggle button — gold chevron */
.migcorp-mobile__expand {
	position: absolute;
	right: 0; top: 14px;
	width: 44px; height: 44px;
	border-radius: 50%;
	display: inline-flex; align-items: center; justify-content: center;
	background: transparent !important;
	border: 1px solid rgba(229, 180, 80, 0.3) !important;
	color: var(--migcorp-gold-700) !important;
	cursor: pointer;
	transition: background .25s, color .25s, border-color .25s, transform .35s var(--migcorp-ease-out);
}
.migcorp-mobile__expand:hover {
	background: var(--migcorp-gold) !important;
	color: var(--migcorp-dark) !important;
	border-color: var(--migcorp-gold) !important;
}
.migcorp-mobile__expand svg { width: 16px; height: 16px; }
.migcorp-menu__item.is-expanded > .migcorp-mobile__expand {
	transform: rotate(180deg);
	background: var(--migcorp-gold) !important;
	color: var(--migcorp-dark) !important;
	border-color: var(--migcorp-gold) !important;
}

/* Sub-menu — indented children with gold left rule */
.migcorp-mobile__list .sub-menu,
.migcorp-mobile__list .migcorp-menu__sub {
	position: static !important;
	opacity: 1 !important; visibility: visible !important; transform: none !important;
	box-shadow: none !important;
	border: 0 !important;
	background: transparent !important;
	padding: 0 !important;
	border-radius: 0 !important;
	margin: 0 0 8px 12px !important;
	max-height: 0;
	overflow: hidden;
	transition: max-height .4s var(--migcorp-ease-out), padding .2s ease;
	list-style: none !important;
	border-left: 1px solid rgba(229, 180, 80, 0.3) !important;
}
.migcorp-mobile__list .migcorp-menu__item--has-children.is-expanded > .sub-menu,
.migcorp-mobile__list .migcorp-menu__item--has-children.is-expanded > .migcorp-menu__sub {
	max-height: 800px;
	padding: 4px 0 14px 0 !important;
}

/* Sub-menu item — smaller, body font, gold dot bullet */
.migcorp-mobile__list .migcorp-menu__sub .migcorp-menu__item,
.migcorp-mobile__list .sub-menu .migcorp-menu__item {
	border-bottom: 0 !important;
}
.migcorp-mobile__list .migcorp-menu__sub .migcorp-menu__link,
.migcorp-mobile__list .sub-menu .migcorp-menu__link {
	display: flex !important;
	align-items: center !important;
	padding: 11px 16px 11px 20px !important;
	font-family: var(--migcorp-font-body) !important;
	font-size: 15px !important;
	font-weight: 500 !important;
	letter-spacing: 0 !important;
	color: var(--migcorp-ink-2) !important;
	background: transparent !important;
	text-decoration: none !important;
	border-radius: 0 !important;
	position: relative;
	transition: color .25s, padding-left .25s;
}
.migcorp-mobile__list .migcorp-menu__sub .migcorp-menu__link::before,
.migcorp-mobile__list .sub-menu .migcorp-menu__link::before {
	content: "";
	position: absolute;
	left: 8px; top: 50%; transform: translateY(-50%);
	width: 6px; height: 1px;
	background: var(--migcorp-gold);
	opacity: .5;
	transition: width .25s, opacity .25s;
}
.migcorp-mobile__list .migcorp-menu__sub .migcorp-menu__link:hover,
.migcorp-mobile__list .sub-menu .migcorp-menu__link:hover {
	color: var(--migcorp-gold-700) !important;
	padding-left: 28px !important;
	background: transparent !important;
}
.migcorp-mobile__list .migcorp-menu__sub .migcorp-menu__link:hover::before,
.migcorp-mobile__list .sub-menu .migcorp-menu__link:hover::before {
	width: 14px;
	opacity: 1;
}

/* Active sub-menu item */
.migcorp-mobile__list .migcorp-menu__sub .migcorp-menu__item.current-menu-item > .migcorp-menu__link,
.migcorp-mobile__list .sub-menu .migcorp-menu__item.current-menu-item > .migcorp-menu__link {
	color: var(--migcorp-gold-700) !important;
	font-weight: 700 !important;
	padding-left: 28px !important;
}
.migcorp-mobile__list .migcorp-menu__sub .migcorp-menu__item.current-menu-item > .migcorp-menu__link::before,
.migcorp-mobile__list .sub-menu .migcorp-menu__item.current-menu-item > .migcorp-menu__link::before {
	width: 14px; opacity: 1; background: var(--migcorp-gold);
}

/* Hide top-level caret indicator if any */
.migcorp-mobile__list .migcorp-menu__caret { display: none !important; }

/* ---------- Secondary content under the menu (fills empty space) ---------- */
.migcorp-mobile__meta {
	margin-top: auto;
	padding-top: 32px;
	border-top: 1px solid rgba(229, 180, 80, 0.18);
	display: flex; flex-direction: column;
	gap: 20px;
}

.migcorp-mobile__contact {
	display: grid; gap: 14px;
	margin: 0;
}
.migcorp-mobile__contact > div { display: flex; flex-direction: column; gap: 4px; }
.migcorp-mobile__contact dt {
	font-family: var(--migcorp-font-body);
	font-size: 10px; letter-spacing: 0.24em; text-transform: uppercase;
	color: var(--migcorp-gold); font-weight: 700;
}
.migcorp-mobile__contact dd {
	margin: 0;
	font-family: var(--migcorp-font-display);
	font-size: 1.05rem;
	color: var(--migcorp-ink);
	letter-spacing: -0.005em;
}
.migcorp-mobile__contact dd a {
	color: inherit;
	text-decoration: none;
	border-bottom: 1px solid rgba(229, 180, 80, 0.4);
	padding-bottom: 1px;
}

.migcorp-mobile__social {
	list-style: none; padding: 0; margin: 0;
	display: flex; gap: 10px;
}
.migcorp-mobile__social a {
	width: 38px; height: 38px;
	display: inline-flex; align-items: center; justify-content: center;
	background: var(--migcorp-white);
	color: var(--migcorp-ink);
	border: 1px solid rgba(229, 180, 80, 0.35);
	border-radius: 50%;
	transition: all .25s;
}
.migcorp-mobile__social a:hover {
	background: var(--migcorp-gold);
	color: var(--migcorp-dark);
	border-color: var(--migcorp-gold);
}

.migcorp-mobile__regulator {
	font-family: var(--migcorp-font-body);
	font-size: 10px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--migcorp-muted);
	font-weight: 500;
	margin: 0;
	padding-top: 6px;
}

/* ---------- Bottom CTA strip ---------- */
.migcorp-mobile__cta {
	padding: 20px 24px 28px;
	border-top: 1px solid rgba(229, 180, 80, 0.18);
	background: var(--migcorp-white);
	display: flex; flex-direction: column; gap: 12px;
}
.migcorp-mobile__cta .migcorp-btn--block {
	width: 100%;
	justify-content: center;
}

/* =========================================================================
   FEATURED INVESTMENT carousel — 2-column layout with right-side vitals panel
   ========================================================================= */

@media (min-width: 1024px) {
	.migcorp-home-featured-inner {
		display: grid !important;
		grid-template-columns: 1.15fr 1fr;
		gap: clamp(48px, 5vw, 96px);
		align-items: center;
	}
	.migcorp-home-featured-copy { max-width: none !important; }
}

/* Vitals panel — right column */
.migcorp-home-featured-vitals {
	display: none;                          /* hidden on mobile/tablet — too cramped */
	flex-direction: column;
	gap: 24px;
	padding: 28px;
	background: rgba(15, 45, 82, 0.55);
	border: 1px solid rgba(229, 180, 80, 0.28);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	box-shadow: 0 30px 60px -20px rgba(0, 0, 0, 0.5);
	position: relative;
	overflow: hidden;
}
@media (min-width: 1024px) {
	.migcorp-home-featured-vitals { display: flex; }
}

/* Top gold hairline accent */
.migcorp-home-featured-vitals::before {
	content: ""; position: absolute; top: 0; left: 0; right: 0; height: 2px;
	background: linear-gradient(90deg, transparent 0%, var(--migcorp-gold) 50%, transparent 100%);
}

/* Photo block at the top of the panel */
.migcorp-home-featured-vitals-photo {
	position: relative;
	aspect-ratio: 16 / 10;
	overflow: hidden;
	background: var(--migcorp-dark);
	border: 1px solid rgba(229, 180, 80, 0.18);
}
.migcorp-home-featured-vitals-img {
	width: 100%; height: 100%;
	object-fit: cover;
	display: block;
	transition: transform .7s var(--migcorp-ease-out);
}
.migcorp-home-featured-slide:hover .migcorp-home-featured-vitals-img { transform: scale(1.04); }

/* Status pill — top-right of photo */
.migcorp-home-featured-vitals-status {
	position: absolute; top: 12px; right: 12px;
	font-family: var(--migcorp-font-body);
	font-size: 9px; letter-spacing: 0.22em; text-transform: uppercase;
	font-weight: 700;
	padding: 5px 10px;
	background: var(--migcorp-gold);
	color: var(--migcorp-dark);
}
.migcorp-home-featured-vitals-status--operational { background: var(--migcorp-gold); color: var(--migcorp-dark); }
.migcorp-home-featured-vitals-status--construction { background: rgba(255, 255, 255, 0.92); color: var(--migcorp-dark); }
.migcorp-home-featured-vitals-status--coming { background: rgba(15, 45, 82, 0.92); color: var(--migcorp-cream); border: 1px solid var(--migcorp-gold); }
.migcorp-home-featured-vitals-status--exited,
.migcorp-home-featured-vitals-status--realised { background: rgba(15, 45, 82, 0.85); color: var(--migcorp-cream); }

/* Location · Vintage row */
.migcorp-home-featured-vitals-meta {
	display: grid; grid-template-columns: 1fr 1fr;
	gap: 12px 20px;
	margin: 0; padding: 16px 0;
	border-top: 1px solid rgba(229, 180, 80, 0.18);
	border-bottom: 1px solid rgba(229, 180, 80, 0.18);
}
.migcorp-home-featured-vitals-meta > div { display: flex; flex-direction: column; gap: 4px; }
.migcorp-home-featured-vitals-meta dt {
	font-family: var(--migcorp-font-body);
	font-size: 9px; letter-spacing: 0.22em; text-transform: uppercase;
	color: var(--migcorp-gold); font-weight: 700;
}
.migcorp-home-featured-vitals-meta dd {
	margin: 0;
	font-family: var(--migcorp-font-display);
	font-size: 0.95rem;
	color: var(--migcorp-cream);
	letter-spacing: -0.005em;
	line-height: 1.3;
}

/* KPI tiles — 2×2 grid */
.migcorp-home-featured-vitals-kpis {
	display: grid; grid-template-columns: 1fr 1fr;
	gap: 14px;
	margin: 0;
}
.migcorp-home-featured-vitals-kpis > div {
	padding: 14px 12px;
	background: rgba(255, 255, 255, 0.04);
	border-left: 2px solid var(--migcorp-gold);
	display: flex; flex-direction: column; gap: 6px;
}
.migcorp-home-featured-vitals-kpis dt {
	font-family: var(--migcorp-font-display);
	font-size: clamp(1.25rem, 1.5vw + 0.3rem, 1.625rem);
	font-weight: 700; color: var(--migcorp-gold);
	letter-spacing: -0.015em; line-height: 1;
	margin: 0;
}
.migcorp-home-featured-vitals-kpis dd {
	margin: 0;
	font-family: var(--migcorp-font-body);
	font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase;
	color: var(--migcorp-beige); font-weight: 600;
	line-height: 1.3;
}

/* Sector chips */
.migcorp-home-featured-vitals-sectors {
	display: flex; flex-wrap: wrap; gap: 6px;
	list-style: none; padding: 0; margin: 0;
}
.migcorp-home-featured-vitals-sectors li {
	font-family: var(--migcorp-font-body);
	font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase;
	font-weight: 600;
	color: var(--migcorp-beige);
	padding: 5px 10px;
	border: 1px solid rgba(229, 180, 80, 0.28);
	background: rgba(229, 180, 80, 0.06);
}

/* =========================================================================
   26. 404 + Search — editorial layout
   ========================================================================= */

.migcorp-404,
.migcorp-search { background: var(--migcorp-cream); }

.migcorp-404__hero,
.migcorp-search__hero {
	background:
		radial-gradient(ellipse at 18% 22%, rgba(229, 180, 80, 0.16), transparent 55%),
		linear-gradient(180deg, var(--migcorp-dark) 0%, var(--migcorp-dark-edge) 100%);
	color: var(--migcorp-cream);
	padding-top: clamp(120px, 14vw, 200px);
	padding-bottom: clamp(80px, 10vw, 140px);
	position: relative;
	overflow: hidden;
}
.migcorp-404__inner,
.migcorp-search__inner { max-width: 880px; }

.migcorp-eyebrow--on-dark { color: var(--migcorp-accent); }
.migcorp-eyebrow--on-dark::before { background: var(--migcorp-accent); }

.migcorp-404__title,
.migcorp-search__title {
	font-family: var(--migcorp-font-display);
	font-size: clamp(2.5rem, 5vw + 1rem, 4.75rem);
	line-height: 1.05;
	letter-spacing: -0.02em;
	margin: 16px 0 24px;
	color: var(--migcorp-cream);
}
.migcorp-404__title em,
.migcorp-search__title em {
	font-style: italic;
	color: var(--migcorp-accent);
	font-weight: 400;
}

.migcorp-404__lede,
.migcorp-search__lede {
	font-family: var(--migcorp-font-body);
	font-size: clamp(1.05rem, 1vw + 0.6rem, 1.25rem);
	line-height: 1.6;
	color: rgba(250, 247, 241, 0.86);
	margin: 0 0 32px;
	max-width: 64ch;
}

.migcorp-404__lede strong,
.migcorp-search__lede strong { color: var(--migcorp-accent); font-weight: 700; }

.migcorp-404__search,
.migcorp-search__form {
	display: flex;
	gap: 12px;
	background: rgba(250, 247, 241, 0.08);
	border: 1px solid rgba(229, 180, 80, 0.34);
	border-radius: var(--migcorp-radius-pill);
	padding: 8px 8px 8px 24px;
	max-width: 640px;
	margin: 0 0 24px;
	backdrop-filter: blur(8px);
	transition: border-color .25s ease, box-shadow .25s ease;
}
.migcorp-404__search:focus-within,
.migcorp-search__form:focus-within {
	border-color: var(--migcorp-accent);
	box-shadow: 0 0 0 4px rgba(229, 180, 80, 0.18);
}
.migcorp-404__search input,
.migcorp-search__form input {
	flex: 1;
	background: transparent;
	border: 0;
	color: var(--migcorp-cream);
	font-family: var(--migcorp-font-body);
	font-size: 1rem;
	padding: 14px 0;
	min-width: 0;
}
.migcorp-404__search input::placeholder,
.migcorp-search__form input::placeholder { color: rgba(250, 247, 241, 0.52); }
.migcorp-404__search input:focus,
.migcorp-search__form input:focus { outline: 0; }
.migcorp-404__search button,
.migcorp-search__form button { flex-shrink: 0; }

/* Popular destinations grid (also used in search empty state) */
.migcorp-404__popular,
.migcorp-search__empty {
	padding-top: clamp(80px, 10vw, 140px);
	padding-bottom: clamp(80px, 10vw, 140px);
}
.migcorp-404__grid {
	list-style: none; padding: 0; margin: 48px 0 0;
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: 1px;
	background: var(--migcorp-border-light);
	border: 1px solid var(--migcorp-border-light);
	border-radius: var(--migcorp-radius-lg);
	overflow: hidden;
}
.migcorp-404__card { background: var(--migcorp-cream); transition: background .25s ease; }
.migcorp-404__card:hover { background: #fff; }
.migcorp-404__card-link {
	display: grid;
	grid-template-columns: auto 1fr auto;
	grid-template-rows: auto auto;
	column-gap: 20px;
	row-gap: 4px;
	align-items: start;
	padding: 32px 28px;
	color: var(--migcorp-ink);
	text-decoration: none;
	min-height: 140px;
}
.migcorp-404__card-index {
	grid-row: 1 / 3;
	font-family: var(--migcorp-font-display);
	font-size: 1.5rem;
	color: var(--migcorp-accent-deep);
	font-style: italic;
	line-height: 1;
	padding-top: 4px;
}
.migcorp-404__card-label {
	font-family: var(--migcorp-font-display);
	font-size: 1.5rem;
	font-weight: 500;
	letter-spacing: -0.01em;
	line-height: 1.1;
}
.migcorp-404__card-blurb {
	grid-column: 2;
	font-family: var(--migcorp-font-body);
	font-size: 0.95rem;
	color: var(--migcorp-muted);
}
.migcorp-404__card-arrow {
	grid-row: 1 / 3;
	align-self: center;
	color: var(--migcorp-accent-deep);
	font-size: 1.5rem;
	transition: transform .25s ease, color .25s ease;
}
.migcorp-404__card:hover .migcorp-404__card-arrow {
	transform: translateX(6px);
	color: var(--migcorp-accent);
}

/* Search results list */
.migcorp-search__results { padding-top: clamp(80px, 10vw, 140px); padding-bottom: clamp(80px, 10vw, 140px); }
.migcorp-search__list { list-style: none; padding: 0; margin: 0; }
.migcorp-search__item + .migcorp-search__item { border-top: 1px solid var(--migcorp-border-light); }
.migcorp-search__item-link {
	display: grid;
	grid-template-columns: 1fr auto;
	column-gap: 32px;
	padding: 36px 0;
	color: var(--migcorp-ink);
	text-decoration: none;
	transition: padding .25s ease;
}
.migcorp-search__item-link:hover { padding-left: 12px; }
.migcorp-search__item-meta {
	display: flex; gap: 16px; align-items: center;
	font-family: var(--migcorp-font-body);
	font-size: 11px; letter-spacing: 0.18em;
	text-transform: uppercase; font-weight: 600;
	color: var(--migcorp-muted);
	margin-bottom: 8px;
}
.migcorp-search__item-type { color: var(--migcorp-accent-deep); }
.migcorp-search__item-title {
	font-family: var(--migcorp-font-display);
	font-size: clamp(1.5rem, 2vw + 0.6rem, 2.25rem);
	letter-spacing: -0.015em;
	line-height: 1.2;
	margin: 0 0 12px;
	transition: color .25s ease;
}
.migcorp-search__item-link:hover .migcorp-search__item-title { color: var(--migcorp-accent-deep); }
.migcorp-search__item-excerpt {
	font-family: var(--migcorp-font-body);
	font-size: 1rem;
	line-height: 1.6;
	color: var(--migcorp-muted);
	max-width: 70ch;
	margin: 0;
}
.migcorp-search__item-arrow {
	align-self: center;
	color: var(--migcorp-accent-deep);
	font-size: 1.5rem;
	transition: transform .25s ease, color .25s ease;
}
.migcorp-search__item-link:hover .migcorp-search__item-arrow {
	transform: translateX(8px);
	color: var(--migcorp-accent);
}

/* Pagination */
.migcorp-search__pagination { margin-top: 64px; }
.migcorp-search__pagination .nav-links {
	display: flex; flex-wrap: wrap; gap: 8px; justify-content: center;
}
.migcorp-search__pagination .page-numbers {
	display: inline-flex; align-items: center; justify-content: center;
	min-width: 44px; height: 44px; padding: 0 16px;
	font-family: var(--migcorp-font-body); font-weight: 600;
	color: var(--migcorp-ink); text-decoration: none;
	border: 1px solid var(--migcorp-border-light); border-radius: var(--migcorp-radius-pill);
	transition: background .25s ease, color .25s ease, border-color .25s ease;
}
.migcorp-search__pagination .page-numbers:hover { border-color: var(--migcorp-accent); color: var(--migcorp-accent-deep); }
.migcorp-search__pagination .page-numbers.current {
	background: var(--migcorp-dark); color: var(--migcorp-cream);
	border-color: var(--migcorp-dark);
}

/* =========================================================================
   27. WCAG 2.1 AA — focus rings, contrast, motion, skip link
   ========================================================================= */

/* Global focus-visible — gold ring everywhere, dark ring on dark surfaces */
*:focus { outline: none; }
a:focus-visible,
button:focus-visible,
[role="button"]:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
summary:focus-visible,
[tabindex]:focus-visible {
	outline: 3px solid var(--migcorp-accent);
	outline-offset: 3px;
	border-radius: 4px;
}
.migcorp-site-header a:focus-visible,
.migcorp-404__hero a:focus-visible,
.migcorp-404__hero button:focus-visible,
.migcorp-search__hero a:focus-visible,
.migcorp-search__hero button:focus-visible,
.migcorp-final-cta a:focus-visible,
.migcorp-footer a:focus-visible {
	outline-color: var(--migcorp-accent-bright);
}

/* Skip link — fully visible on focus */
.migcorp-skip-link:focus {
	left: 8px;
	outline: 3px solid var(--migcorp-accent);
	outline-offset: 3px;
}

/* Gold-on-cream contrast: the brand gold (#E5B450) is 2.4:1 on cream — fails AA.
   When gold is used as *text* on cream, swap to the deeper variant (4.6:1, passes AA). */
.migcorp-cream a:not(.migcorp-btn):not(.migcorp-404__card-link):not(.migcorp-search__item-link),
.migcorp-section--cream a:not(.migcorp-btn),
.migcorp-section--wash a:not(.migcorp-btn) {
	color: var(--migcorp-accent-deep);
}

/* Sr-only utility (in case it's not defined elsewhere) */
.screen-reader-text {
	border: 0; clip: rect(1px,1px,1px,1px); -webkit-clip-path: inset(50%);
	clip-path: inset(50%); height: 1px; margin: -1px; overflow: hidden;
	padding: 0; position: absolute; width: 1px; word-wrap: normal !important;
}
.screen-reader-text:focus {
	background-color: var(--migcorp-cream); clip: auto; -webkit-clip-path: none;
	clip-path: none; color: var(--migcorp-ink); display: block; font-size: 1rem;
	height: auto; left: 8px; line-height: normal; padding: 12px 20px;
	text-decoration: none; top: 8px; width: auto; z-index: 100000;
	border: 2px solid var(--migcorp-accent);
}

/* Touch target minimum (WCAG 2.5.5 / 2.5.8) — pad small buttons */
.migcorp-btn,
.wp-block-button__link,
.migcorp-search__pagination .page-numbers { min-height: 44px; }

/* Respect user reduced-motion preference */
@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;
	}
	.migcorp-marquee,
	.migcorp-press-strip__track,
	.migcorp-trust-bar-track { animation: none !important; }
}

/* Modal — keyboard trap visuals + escape hint */
.migcorp-modal__overlay:focus-visible,
.migcorp-team-modal:focus-visible { outline: none; }
.migcorp-team-modal[aria-modal="true"] { isolation: isolate; }

/* High contrast mode — Windows Forced Colors */
@media (forced-colors: active) {
	.migcorp-btn { border: 2px solid CanvasText !important; }
	.migcorp-eyebrow::before { background: CanvasText; }
}

/* Mobile pass for 404/search */
@media (max-width: 768px) {
	.migcorp-404__grid { grid-template-columns: 1fr; }
	.migcorp-404__card-link { padding: 24px 20px; min-height: 0; }
	.migcorp-404__search,
	.migcorp-search__form {
		flex-direction: column;
		padding: 16px;
		border-radius: var(--migcorp-radius-lg);
		gap: 12px;
	}
	.migcorp-404__search button,
	.migcorp-search__form button { width: 100%; justify-content: center; }
	.migcorp-search__item-link { grid-template-columns: 1fr; }
	.migcorp-search__item-arrow { display: none; }
}

/* =========================================================================
   28. Native form fallback (used when no WPForms/CF7 shortcode set)
   ========================================================================= */
.migcorp-native-form { display: grid; gap: 20px; max-width: 560px; }
.migcorp-native-form__row { display: grid; gap: 6px; }
.migcorp-native-form__row label {
	font-family: var(--migcorp-font-body);
	font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase;
	color: var(--migcorp-muted); font-weight: 600;
}
.migcorp-native-form__row label span[aria-hidden="true"] { color: var(--migcorp-accent-deep); }
.migcorp-native-form__row input,
.migcorp-native-form__row textarea {
	border: 1px solid var(--migcorp-border-light);
	border-radius: var(--migcorp-radius-sm);
	padding: 14px 16px;
	background: var(--migcorp-cream);
	color: var(--migcorp-ink);
	font-family: var(--migcorp-font-body);
	font-size: 1rem;
	transition: border-color .25s ease, box-shadow .25s ease;
}
.migcorp-native-form__row input:focus,
.migcorp-native-form__row textarea:focus {
	border-color: var(--migcorp-accent);
	outline: 0;
	box-shadow: 0 0 0 3px rgba(229, 180, 80, 0.22);
}
.migcorp-native-form__success,
.migcorp-native-form__error {
	padding: 16px 20px;
	border-radius: var(--migcorp-radius-md);
	font-family: var(--migcorp-font-body);
	font-size: 0.95rem;
	border-left: 4px solid var(--migcorp-accent);
}
.migcorp-native-form__success {
	background: rgba(229, 180, 80, 0.10);
	color: var(--migcorp-ink);
}
.migcorp-native-form__error {
	background: #fbecec;
	border-left-color: #c03434;
	color: #5a1818;
}
.migcorp-native-form button[type="submit"] { justify-self: start; }
@media (max-width: 640px) {
	.migcorp-native-form button[type="submit"] { width: 100%; justify-self: stretch; }
}

/* Agency credit in footer copyright line */
.migcorp-footer-credit { opacity: 0.85; }
.migcorp-footer-credit a {
	color: var(--migcorp-accent);
	text-decoration: none;
	font-weight: 600;
	transition: color .25s ease;
}
.migcorp-footer-credit a:hover { color: var(--migcorp-accent-bright); }
