/* ===================================================================
   Mariof.es — Home page styles (Shopkeeper child theme)
   All selectors prefixed with .mfc- and scoped to body.mfc-home so the
   rest of the site (services pages, portfolio archive, single posts,
   WooCommerce) is not affected.
   =================================================================== */

body.mfc-home {
	--paper: #F2EDE3;
	--paper-2: #E8E1D2;
	--ink: #14110E;
	--ink-2: #2A251F;
	--ink-soft: #4A4137;
	--gold: #B89766;
	--gold-soft: #D4B896;
	--terracotta: #B85436;
	--line: rgba(20, 17, 14, 0.12);
	--line-soft: rgba(20, 17, 14, 0.06);
	--muted: rgba(20, 17, 14, 0.55);
	--muted-2: rgba(20, 17, 14, 0.4);

	font-family: 'Manrope', sans-serif;
	font-weight: 300;
	font-size: 16px;
	line-height: 1.6;
	color: var(--ink);
	background: var(--paper);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	overflow-x: hidden;
	margin: 0;
	padding: 0;
}

body.mfc-home,
body.mfc-home * {
	box-sizing: border-box;
}

body.mfc-home::selection,
body.mfc-home *::selection { background: var(--ink); color: var(--paper); }

body.mfc-home img { max-width: 100%; display: block; }
body.mfc-home a { text-decoration: none; }
body.mfc-home h1, body.mfc-home h2, body.mfc-home h3, body.mfc-home h4, body.mfc-home h5 { margin: 0; }
body.mfc-home p { margin: 0; }
body.mfc-home ul { list-style: none; padding: 0; margin: 0; }

/* ========== TYPOGRAPHY ========== */
.mfc-kicker {
	font-family: 'Manrope', sans-serif;
	font-size: 11px;
	font-weight: 500;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--ink-soft);
}
.mfc-kicker-line { display: inline-flex; align-items: center; gap: 14px; }
.mfc-kicker-line::before {
	content: '';
	width: 32px; height: 1px;
	background: var(--ink-soft);
}

/* ========== NAV ========== */
.mfc-nav {
	position: fixed;
	top: 0; left: 0; right: 0;
	z-index: 9999;
	padding: 28px 56px;
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	align-items: center;
	transition: background 0.4s, padding 0.4s, border-color 0.4s;
	border-bottom: 1px solid transparent;
}
.mfc-nav.mfc-scrolled {
	background: rgba(242, 237, 227, 0.92);
	backdrop-filter: blur(20px);
	-webkit-backdrop-filter: blur(20px);
	padding: 18px 56px;
	border-bottom-color: var(--line);
}
.mfc-nav.mfc-scrolled .mfc-brand,
.mfc-nav.mfc-scrolled .mfc-nav-center a,
.mfc-nav.mfc-scrolled .mfc-lang-switch a,
.mfc-nav.mfc-scrolled .mfc-nav-cta { color: var(--ink); }
.mfc-nav.mfc-scrolled .mfc-brand .mfc-dot { background: var(--terracotta); }
.mfc-nav.mfc-scrolled .mfc-nav-cta { border-color: var(--ink); }
.mfc-nav.mfc-scrolled .mfc-nav-cta:hover { background: var(--ink); color: var(--paper); }

.mfc-brand {
	font-family: 'Fraunces', serif;
	font-weight: 400;
	font-size: 20px;
	letter-spacing: -0.01em;
	color: var(--paper);
	display: flex;
	align-items: center;
	gap: 10px;
	transition: color 0.4s;
}
.mfc-brand .mfc-dot {
	width: 7px; height: 7px;
	background: var(--paper);
	border-radius: 50%;
	transition: background 0.4s;
}
.mfc-brand em { font-style: italic; font-weight: 300; }

.mfc-nav-center { display: flex; gap: 40px; }
.mfc-nav-center a {
	font-family: 'Manrope', sans-serif;
	font-size: 12px;
	font-weight: 400;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--paper);
	transition: color 0.3s, opacity 0.3s;
	opacity: 0.85;
}
.mfc-nav-center a:hover { opacity: 1; }

.mfc-nav-right { display: flex; justify-content: flex-end; align-items: center; gap: 24px; }
.mfc-lang-switch {
	display: flex;
	font-family: 'Manrope', sans-serif;
	font-size: 11px;
	letter-spacing: 0.18em;
	font-weight: 400;
}
.mfc-lang-switch a {
	color: var(--paper);
	opacity: 0.5;
	transition: opacity 0.3s;
	padding: 0 6px;
}
.mfc-lang-switch a.active { opacity: 1; }
.mfc-lang-switch a:hover { opacity: 0.85; }
.mfc-lang-switch .mfc-lang-sep { opacity: 0.3; color: var(--paper); }
.mfc-nav.mfc-scrolled .mfc-lang-switch .mfc-lang-sep { color: var(--ink); }

.mfc-nav-cta {
	font-family: 'Manrope', sans-serif;
	font-size: 11px;
	font-weight: 500;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--paper);
	padding: 10px 20px;
	border: 1px solid rgba(242, 237, 227, 0.4);
	border-radius: 100px;
	transition: background 0.3s, color 0.3s, border-color 0.3s;
}
.mfc-nav-cta:hover { background: var(--paper); color: var(--ink); border-color: var(--paper); }

/* ========== HERO ========== */
.mfc-hero {
	position: relative;
	height: 100vh;
	min-height: 720px;
	width: 100%;
	overflow: hidden;
	color: var(--paper);
}
.mfc-hero-image {
	position: absolute; inset: 0;
	background:
		linear-gradient(180deg, transparent 0%, transparent 40%, rgba(20, 17, 14, 0.7) 100%),
		radial-gradient(ellipse 80% 50% at 70% 30%, rgba(232, 178, 60, 0.25), transparent 70%),
		radial-gradient(ellipse 60% 80% at 20% 80%, rgba(184, 84, 54, 0.35), transparent 70%),
		linear-gradient(160deg, #2A1F1A 0%, #4A3025 25%, #8B5A3C 50%, #C5784E 75%, #E8956B 100%);
	animation: mfcHeroBreath 18s ease-in-out infinite alternate;
}
@keyframes mfcHeroBreath {
	0% { transform: scale(1); }
	100% { transform: scale(1.06); }
}
.mfc-hero-scene { position: absolute; inset: 0; pointer-events: none; }
.mfc-hero-scene svg {
	position: absolute;
	bottom: 0;
	width: 100%;
	height: auto;
	filter: drop-shadow(0 -10px 30px rgba(0, 0, 0, 0.3));
}
.mfc-hero-grain {
	position: absolute;
	inset: 0;
	opacity: 0.18;
	mix-blend-mode: overlay;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.6'/></svg>");
	pointer-events: none;
}
.mfc-hero-vignette {
	position: absolute;
	inset: 0;
	background:
		linear-gradient(180deg, rgba(20,17,14,0.45) 0%, transparent 25%, transparent 60%, rgba(20,17,14,0.55) 100%),
		radial-gradient(ellipse 100% 80% at 50% 50%, transparent 40%, rgba(20,17,14,0.4) 100%);
	pointer-events: none;
}

.mfc-hero-content {
	position: relative;
	z-index: 5;
	height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	padding: 0 56px 80px;
}
.mfc-hero-caption {
	position: absolute;
	top: 130px;
	right: 56px;
	text-align: right;
	max-width: 280px;
	animation: mfcFadeIn 1.2s ease 0.6s forwards;
	opacity: 0;
}
.mfc-hero-caption .mfc-num {
	font-family: 'Fraunces', serif;
	font-size: 14px;
	font-weight: 300;
	font-style: italic;
	color: var(--paper);
	opacity: 0.6;
	margin-bottom: 8px;
	letter-spacing: 0.08em;
}
.mfc-hero-caption .mfc-label {
	font-family: 'Manrope', sans-serif;
	font-size: 11px;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	font-weight: 400;
	margin-bottom: 6px;
	color: var(--paper);
}
.mfc-hero-caption .mfc-desc {
	font-family: 'Fraunces', serif;
	font-style: italic;
	font-weight: 300;
	font-size: 13px;
	color: var(--paper);
	opacity: 0.75;
	line-height: 1.5;
}

.mfc-hero-bottom {
	display: grid;
	grid-template-columns: 1fr auto;
	align-items: end;
	gap: 60px;
}
.mfc-hero-name {
	animation: mfcHeroRise 1.4s cubic-bezier(0.2, 0.8, 0.2, 1) 0.2s forwards;
	opacity: 0;
	transform: translateY(40px);
}
.mfc-hero-name .mfc-kicker-line {
	margin-bottom: 24px;
	color: var(--paper);
	opacity: 0.85;
}
.mfc-hero-name .mfc-kicker-line::before { background: var(--paper); opacity: 0.6; }
.mfc-hero-name .mfc-kicker { color: var(--paper); }
.mfc-hero-title {
	font-family: 'Fraunces', serif;
	font-weight: 300;
	font-size: clamp(80px, 14vw, 200px);
	line-height: 0.85;
	letter-spacing: -0.045em;
	color: var(--paper);
}
.mfc-hero-title em {
	font-style: italic;
	font-weight: 200;
	color: var(--gold-soft);
}
.mfc-hero-subtitle {
	font-family: 'Fraunces', serif;
	font-weight: 300;
	font-style: italic;
	font-size: 22px;
	letter-spacing: -0.01em;
	color: var(--paper);
	max-width: 320px;
	text-align: right;
	animation: mfcFadeInOpaque 1.4s ease 0.8s forwards;
	opacity: 0;
}

.mfc-scroll-cue {
	position: absolute;
	bottom: 32px;
	left: 50%;
	transform: translateX(-50%);
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 12px;
	font-family: 'Manrope', sans-serif;
	font-size: 10px;
	letter-spacing: 0.3em;
	text-transform: uppercase;
	color: var(--paper);
	opacity: 0;
	animation: mfcFadeIn 1s ease 1.5s forwards;
}
.mfc-scroll-cue::after {
	content: '';
	width: 1px; height: 36px;
	background: linear-gradient(180deg, var(--paper), transparent);
	animation: mfcScrollLine 2s ease-in-out infinite;
}
@keyframes mfcScrollLine {
	0%, 100% { transform: scaleY(1); transform-origin: top; }
	50% { transform: scaleY(0.4); transform-origin: top; }
}
@keyframes mfcFadeIn { to { opacity: 1; } }
@keyframes mfcFadeInOpaque { to { opacity: 0.85; } }
@keyframes mfcHeroRise { to { opacity: 1; transform: translateY(0); } }

/* ========== INTRO ========== */
.mfc-intro {
	padding: 180px 56px 160px;
	max-width: 1400px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 1fr 5fr 1fr;
	gap: 60px;
	align-items: start;
}
.mfc-intro-meta {
	font-family: 'Manrope', sans-serif;
	font-size: 11px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--ink-soft);
	position: sticky;
	top: 100px;
}
.mfc-intro-meta .mfc-num {
	font-family: 'Fraunces', serif;
	font-style: italic;
	font-size: 32px;
	text-transform: none;
	letter-spacing: -0.01em;
	color: var(--terracotta);
	margin-bottom: 12px;
	display: block;
	font-weight: 300;
}
.mfc-intro-statement {
	font-family: 'Fraunces', serif;
	font-weight: 300;
	font-size: clamp(32px, 4.4vw, 60px);
	line-height: 1.15;
	letter-spacing: -0.025em;
	color: var(--ink);
}
.mfc-intro-statement em {
	font-style: italic;
	font-weight: 300;
	color: var(--terracotta);
}
.mfc-intro-statement .mfc-small {
	display: block;
	font-size: 0.5em;
	font-style: italic;
	color: var(--ink-soft);
	margin-top: 32px;
	font-weight: 300;
	line-height: 1.5;
	max-width: 520px;
}
.mfc-intro-side {
	font-family: 'Manrope', sans-serif;
	font-size: 13px;
	line-height: 1.7;
	color: var(--ink-soft);
	position: sticky;
	top: 100px;
}
.mfc-intro-side strong {
	display: block;
	font-family: 'Fraunces', serif;
	font-style: italic;
	font-weight: 300;
	font-size: 24px;
	color: var(--ink);
	letter-spacing: -0.01em;
	margin-bottom: 12px;
}

/* ========== WORK ========== */
.mfc-work {
	padding: 80px 56px 160px;
	max-width: 1600px;
	margin: 0 auto;
}
.mfc-work-header {
	display: grid;
	grid-template-columns: 1fr 1fr;
	align-items: end;
	gap: 60px;
	margin-bottom: 100px;
	padding-bottom: 28px;
	border-bottom: 1px solid var(--line);
}
.mfc-work-header h2 {
	font-family: 'Fraunces', serif;
	font-weight: 300;
	font-size: clamp(40px, 5vw, 72px);
	letter-spacing: -0.03em;
	line-height: 1;
}
.mfc-work-header h2 em { font-style: italic; color: var(--gold); font-weight: 300; }
.mfc-header-side {
	display: flex;
	justify-content: space-between;
	align-items: end;
	gap: 32px;
}
.mfc-header-side p {
	font-family: 'Fraunces', serif;
	font-style: italic;
	font-weight: 300;
	font-size: 16px;
	color: var(--ink-soft);
	max-width: 320px;
	line-height: 1.55;
}
.mfc-view-all {
	font-family: 'Manrope', sans-serif;
	font-size: 11px;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--ink);
	white-space: nowrap;
	border-bottom: 1px solid var(--ink);
	padding-bottom: 4px;
	transition: color 0.3s, border-color 0.3s;
}
.mfc-view-all:hover { color: var(--terracotta); border-color: var(--terracotta); }

.mfc-spread {
	display: grid;
	grid-template-columns: repeat(12, 1fr);
	gap: 32px;
	margin-bottom: 120px;
}
.mfc-tile {
	position: relative;
	overflow: hidden;
	color: inherit;
	display: block;
}
.mfc-tile-img {
	width: 100%;
	position: relative;
	overflow: hidden;
	background: var(--ink);
	transition: transform 0.8s cubic-bezier(0.2, 0.8, 0.2, 1);
}
.mfc-tile:hover .mfc-tile-img { transform: scale(0.985); }
.mfc-tile-img > .mfc-bg {
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: center;
	transition: transform 1.4s cubic-bezier(0.2, 0.8, 0.2, 1);
}
.mfc-tile:hover .mfc-tile-img > .mfc-bg { transform: scale(1.06); }

.mfc-tile-info {
	margin-top: 18px;
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	gap: 16px;
	position: relative;
}
.mfc-tile-info h3 {
	font-family: 'Fraunces', serif;
	font-weight: 400;
	font-size: 18px;
	letter-spacing: -0.01em;
	flex: 1;
	color: var(--ink);
}
.mfc-tile-info .mfc-tile-meta {
	font-family: 'Manrope', sans-serif;
	font-size: 10px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--muted);
	white-space: nowrap;
}
.mfc-tile-info .mfc-tile-num {
	font-family: 'Fraunces', serif;
	font-style: italic;
	font-size: 14px;
	color: var(--terracotta);
	position: absolute;
	top: -32px;
	right: 0;
}

.mfc-spread-1 .mfc-tile:nth-child(1) { grid-column: 1 / 8; }
.mfc-spread-1 .mfc-tile:nth-child(1) .mfc-tile-img { aspect-ratio: 4/5; }
.mfc-spread-1 .mfc-tile:nth-child(2) { grid-column: 9 / 13; margin-top: 80px; }
.mfc-spread-1 .mfc-tile:nth-child(2) .mfc-tile-img { aspect-ratio: 4/5; }

.mfc-spread-2 .mfc-tile:nth-child(1) { grid-column: 1 / 5; margin-top: 60px; }
.mfc-spread-2 .mfc-tile:nth-child(1) .mfc-tile-img { aspect-ratio: 3/4; }
.mfc-spread-2 .mfc-tile:nth-child(2) { grid-column: 5 / 9; }
.mfc-spread-2 .mfc-tile:nth-child(2) .mfc-tile-img { aspect-ratio: 3/4; }
.mfc-spread-2 .mfc-tile:nth-child(3) { grid-column: 9 / 13; margin-top: 100px; }
.mfc-spread-2 .mfc-tile:nth-child(3) .mfc-tile-img { aspect-ratio: 3/4; }

.mfc-spread-3 .mfc-tile:nth-child(1) { grid-column: 1 / 9; }
.mfc-spread-3 .mfc-tile:nth-child(1) .mfc-tile-img { aspect-ratio: 16/9; }
.mfc-spread-3 .mfc-tile:nth-child(2) { grid-column: 9 / 13; margin-top: 40px; }
.mfc-spread-3 .mfc-tile:nth-child(2) .mfc-tile-img { aspect-ratio: 4/5; }

.mfc-empty {
	font-family: 'Fraunces', serif;
	font-style: italic;
	font-size: 18px;
	color: var(--muted);
	padding: 40px;
	border: 1px dashed var(--line);
	text-align: center;
}

/* ========== CATEGORIES ========== */
.mfc-categories {
	padding: 100px 56px;
	border-top: 1px solid var(--line);
	border-bottom: 1px solid var(--line);
	background: var(--paper-2);
}
.mfc-categories-inner { max-width: 1600px; margin: 0 auto; }
.mfc-categories-inner > .mfc-kicker { display: block; margin-bottom: 40px; }
.mfc-cat-list { display: flex; flex-wrap: wrap; gap: 0; }
.mfc-cat-list a {
	font-family: 'Fraunces', serif;
	font-weight: 300;
	font-size: clamp(28px, 4.5vw, 64px);
	letter-spacing: -0.025em;
	color: var(--ink);
	padding: 12px 28px 12px 0;
	display: inline-flex;
	align-items: baseline;
	gap: 10px;
	transition: color 0.3s, transform 0.3s, font-style 0.3s;
	line-height: 1;
}
.mfc-cat-list a sup {
	font-family: 'Manrope', sans-serif;
	font-size: 12px;
	font-weight: 400;
	letter-spacing: 0.1em;
	color: var(--muted);
	align-self: flex-start;
	margin-top: 6px;
}
.mfc-cat-list a:hover { color: var(--terracotta); font-style: italic; }
.mfc-cat-sep {
	color: var(--gold);
	font-family: 'Fraunces', serif;
	font-size: clamp(28px, 4.5vw, 64px);
	font-weight: 200;
	align-self: center;
	margin: 0 8px;
}

/* ========== SERVICES ========== */
.mfc-services {
	padding: 180px 56px;
	max-width: 1400px;
	margin: 0 auto;
}
.mfc-services-header {
	margin-bottom: 100px;
	display: grid;
	grid-template-columns: 1fr 2fr;
	gap: 60px;
	align-items: end;
	padding-bottom: 28px;
	border-bottom: 1px solid var(--line);
}
.mfc-services-header h2 {
	font-family: 'Fraunces', serif;
	font-weight: 300;
	font-size: clamp(48px, 6vw, 96px);
	line-height: 0.95;
	letter-spacing: -0.035em;
}
.mfc-services-header h2 em { font-style: italic; color: var(--terracotta); font-weight: 300; }
.mfc-services-header p {
	font-family: 'Fraunces', serif;
	font-style: italic;
	font-weight: 300;
	font-size: 18px;
	line-height: 1.5;
	color: var(--ink-soft);
	max-width: 480px;
}

.mfc-service {
	display: grid;
	grid-template-columns: 60px 1fr 2fr 1fr;
	gap: 40px;
	padding: 40px 0;
	border-bottom: 1px solid var(--line);
	align-items: start;
	transition: padding 0.4s;
	position: relative;
}
.mfc-service:hover { padding-left: 16px; }
.mfc-service::before {
	content: '';
	position: absolute;
	left: 0;
	top: 0;
	width: 0;
	height: 100%;
	background: linear-gradient(90deg, var(--terracotta), transparent);
	opacity: 0.08;
	transition: width 0.4s;
}
.mfc-service:hover::before { width: 100%; }
.mfc-service-num {
	font-family: 'Fraunces', serif;
	font-style: italic;
	font-weight: 300;
	font-size: 22px;
	color: var(--terracotta);
}
.mfc-service-title {
	font-family: 'Fraunces', serif;
	font-weight: 400;
	font-size: 28px;
	letter-spacing: -0.02em;
	line-height: 1.1;
	color: var(--ink);
}
.mfc-service-title em { font-style: italic; font-weight: 300; }
.mfc-service-desc {
	font-family: 'Manrope', sans-serif;
	font-size: 15px;
	line-height: 1.7;
	color: var(--ink-soft);
	max-width: 480px;
}
.mfc-service-tags {
	font-family: 'Manrope', sans-serif;
	font-size: 11px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--muted);
	line-height: 1.9;
	text-align: right;
}

/* ========== PROCESS / EQUIPMENT ========== */
.mfc-process {
	padding: 160px 56px;
	background: var(--ink);
	color: var(--paper);
	position: relative;
	overflow: hidden;
}
.mfc-process::before {
	content: '';
	position: absolute;
	top: -10%;
	right: -10%;
	width: 60%;
	height: 60%;
	background: radial-gradient(circle, rgba(184, 84, 54, 0.18), transparent 70%);
	filter: blur(80px);
}
.mfc-process-inner {
	position: relative;
	max-width: 1400px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 1fr 1.2fr;
	gap: 100px;
	align-items: start;
}
.mfc-process h2 {
	font-family: 'Fraunces', serif;
	font-weight: 300;
	font-size: clamp(40px, 5vw, 64px);
	line-height: 1.05;
	letter-spacing: -0.025em;
	margin-bottom: 32px;
	color: var(--paper);
}
.mfc-process h2 em { font-style: italic; color: var(--gold-soft); font-weight: 300; }
.mfc-process p {
	font-family: 'Fraunces', serif;
	font-style: italic;
	font-weight: 300;
	font-size: 19px;
	line-height: 1.55;
	color: rgba(242, 237, 227, 0.75);
	max-width: 440px;
	margin-bottom: 32px;
}
.mfc-process .mfc-kicker { color: var(--gold-soft); }
.mfc-process .mfc-kicker-line::before { background: var(--gold-soft); }

.mfc-equipment {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0;
	border-top: 1px solid rgba(242, 237, 227, 0.15);
}
.mfc-eq-item {
	padding: 32px 0;
	border-bottom: 1px solid rgba(242, 237, 227, 0.15);
}
.mfc-eq-item:nth-child(odd) { padding-right: 32px; border-right: 1px solid rgba(242, 237, 227, 0.15); }
.mfc-eq-item:nth-child(even) { padding-left: 32px; }
.mfc-eq-label {
	font-family: 'Manrope', sans-serif;
	font-size: 10px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: rgba(242, 237, 227, 0.5);
	margin-bottom: 8px;
}
.mfc-eq-name {
	font-family: 'Fraunces', serif;
	font-weight: 400;
	font-size: 20px;
	letter-spacing: -0.01em;
	margin-bottom: 6px;
	color: var(--paper);
}
.mfc-eq-detail {
	font-family: 'Fraunces', serif;
	font-style: italic;
	font-weight: 300;
	font-size: 14px;
	color: rgba(242, 237, 227, 0.6);
	line-height: 1.5;
}

/* ========== ABOUT ========== */
.mfc-about {
	padding: 180px 56px;
	max-width: 1400px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 1fr 1.6fr;
	gap: 100px;
	align-items: start;
}
.mfc-about-portrait {
	position: relative;
	aspect-ratio: 3/4;
	background:
		linear-gradient(180deg, rgba(0,0,0,0.2) 0%, transparent 30%, rgba(0,0,0,0.4) 100%),
		radial-gradient(ellipse 50% 40% at 60% 35%, rgba(255, 220, 170, 0.35), transparent 70%),
		linear-gradient(160deg, #1A1310 0%, #3A2820 35%, #6B4838 65%, #C5784E 100%);
	overflow: hidden;
}
.mfc-about-portrait::after {
	content: 'M·F';
	position: absolute;
	bottom: 32px; left: 32px;
	font-family: 'Fraunces', serif;
	font-style: italic;
	font-weight: 200;
	font-size: 96px;
	color: var(--paper);
	opacity: 0.95;
	letter-spacing: -0.04em;
	line-height: 1;
}
.mfc-about-portrait .mfc-tag {
	position: absolute;
	top: 24px; left: 24px;
	font-family: 'Manrope', sans-serif;
	font-size: 10px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--paper);
	background: rgba(20, 17, 14, 0.4);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	padding: 8px 14px;
	border-radius: 100px;
}
.mfc-about-text h2 {
	font-family: 'Fraunces', serif;
	font-weight: 300;
	font-size: clamp(40px, 5vw, 72px);
	line-height: 1.05;
	letter-spacing: -0.03em;
	margin: 24px 0 32px;
	color: var(--ink);
}
.mfc-about-text h2 em { font-style: italic; color: var(--terracotta); font-weight: 300; }
.mfc-about-text > p {
	font-family: 'Fraunces', serif;
	font-style: italic;
	font-weight: 300;
	font-size: 22px;
	line-height: 1.5;
	color: var(--ink-soft);
	margin-bottom: 24px;
	max-width: 560px;
}
.mfc-about-bio {
	font-family: 'Manrope', sans-serif;
	font-size: 15px;
	line-height: 1.75;
	color: var(--ink-soft);
	max-width: 560px;
	margin-bottom: 48px;
}
.mfc-about-bio p { margin-bottom: 16px; }
.mfc-bio-meta {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 32px;
	padding-top: 32px;
	border-top: 1px solid var(--line);
}
.mfc-meta-label {
	font-family: 'Manrope', sans-serif;
	font-size: 10px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--muted);
	margin-bottom: 8px;
}
.mfc-meta-val {
	font-family: 'Fraunces', serif;
	font-weight: 400;
	font-size: 16px;
	color: var(--ink);
	line-height: 1.4;
}
.mfc-meta-val em { font-style: italic; font-weight: 300; }

/* ========== CONTACT ========== */
.mfc-contact {
	padding: 200px 56px 180px;
	background: var(--paper-2);
	position: relative;
	overflow: hidden;
}
.mfc-contact::before {
	content: '';
	position: absolute;
	inset: -10%;
	background: radial-gradient(ellipse 60% 50% at 30% 70%, rgba(184, 84, 54, 0.08), transparent 70%);
}
.mfc-contact-inner {
	position: relative;
	max-width: 1400px;
	margin: 0 auto;
	text-align: center;
}
.mfc-contact .mfc-kicker-line {
	justify-content: center;
	display: inline-flex;
	margin-bottom: 32px;
}
.mfc-contact h2 {
	font-family: 'Fraunces', serif;
	font-weight: 300;
	font-size: clamp(48px, 7vw, 120px);
	line-height: 0.95;
	letter-spacing: -0.04em;
	margin-bottom: 60px;
	color: var(--ink);
}
.mfc-contact h2 em { font-style: italic; color: var(--terracotta); font-weight: 300; }
.mfc-contact-actions {
	display: flex;
	justify-content: center;
	gap: 16px;
	flex-wrap: wrap;
	margin-bottom: 80px;
}
.mfc-btn {
	display: inline-flex;
	align-items: center;
	gap: 12px;
	padding: 20px 36px;
	border-radius: 100px;
	font-family: 'Manrope', sans-serif;
	font-size: 13px;
	font-weight: 500;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	transition: transform 0.3s, background 0.3s, color 0.3s;
}
.mfc-btn-dark { background: var(--ink); color: var(--paper); }
.mfc-btn-dark:hover { background: var(--terracotta); transform: translateY(-2px); color: var(--paper); }
.mfc-btn-light { background: transparent; color: var(--ink); border: 1px solid var(--ink); }
.mfc-btn-light:hover { background: var(--ink); color: var(--paper); transform: translateY(-2px); }
.mfc-btn svg { transition: transform 0.3s; }
.mfc-btn:hover svg { transform: translateX(4px); }

.mfc-contact-direct {
	display: flex;
	justify-content: center;
	gap: 60px;
	flex-wrap: wrap;
}
.mfc-direct-label {
	font-family: 'Manrope', sans-serif;
	font-size: 10px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--muted);
	margin-bottom: 6px;
}
.mfc-direct-val {
	font-family: 'Fraunces', serif;
	font-weight: 400;
	font-size: 18px;
	letter-spacing: -0.01em;
	color: var(--ink);
}

/* ========== FOOTER ========== */
.mfc-footer {
	padding: 60px 56px 32px;
	background: var(--ink);
	color: var(--paper);
}
.mfc-foot-grid {
	max-width: 1400px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 2fr 1fr 1fr 1fr;
	gap: 60px;
	padding-bottom: 48px;
	border-bottom: 1px solid rgba(242, 237, 227, 0.15);
}
.mfc-foot-grid h5 {
	font-family: 'Manrope', sans-serif;
	font-size: 10px;
	font-weight: 500;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: rgba(242, 237, 227, 0.5);
	margin-bottom: 20px;
}
.mfc-foot-grid ul li { margin-bottom: 8px; }
.mfc-foot-grid ul a {
	font-family: 'Fraunces', serif;
	font-weight: 400;
	font-size: 16px;
	color: var(--paper);
	transition: color 0.3s, padding-left 0.3s;
}
.mfc-foot-grid ul a:hover { color: var(--gold-soft); padding-left: 6px; }
.mfc-foot-brand {
	font-family: 'Fraunces', serif;
	font-weight: 400;
	font-size: 28px;
	letter-spacing: -0.02em;
	margin-bottom: 16px;
	display: flex;
	align-items: center;
	gap: 12px;
	color: var(--paper);
}
.mfc-foot-brand em { font-style: italic; font-weight: 300; }
.mfc-foot-brand .mfc-dot { width: 8px; height: 8px; background: var(--terracotta); border-radius: 50%; }
.mfc-foot-tag {
	font-family: 'Fraunces', serif;
	font-style: italic;
	font-weight: 300;
	font-size: 16px;
	color: rgba(242, 237, 227, 0.6);
	max-width: 320px;
	line-height: 1.5;
}
.mfc-foot-base {
	max-width: 1400px;
	margin: 0 auto;
	padding-top: 24px;
	display: flex;
	justify-content: space-between;
	font-family: 'Manrope', sans-serif;
	font-size: 11px;
	letter-spacing: 0.15em;
	color: rgba(242, 237, 227, 0.4);
}

/* ========== REVEAL ========== */
.mfc-reveal {
	opacity: 0;
	transform: translateY(40px);
	transition: opacity 1s ease, transform 1s cubic-bezier(0.2, 0.8, 0.2, 1);
}
.mfc-reveal.mfc-in { opacity: 1; transform: translateY(0); }

/* ========== RESPONSIVE ========== */
@media (max-width: 980px) {
	.mfc-nav { padding: 18px 24px; grid-template-columns: 1fr 1fr; }
	.mfc-nav-center { display: none; }
	.mfc-hero-content { padding: 0 24px 60px; }
	.mfc-hero-caption { right: 24px; max-width: 200px; top: 100px; }
	.mfc-hero-bottom { grid-template-columns: 1fr; gap: 32px; }
	.mfc-hero-subtitle { text-align: left; }
	.mfc-intro { padding: 100px 24px; grid-template-columns: 1fr; gap: 32px; }
	.mfc-intro-meta, .mfc-intro-side { position: static; }
	.mfc-work, .mfc-services, .mfc-about, .mfc-contact, .mfc-process { padding: 100px 24px; }
	.mfc-work-header, .mfc-services-header, .mfc-about, .mfc-process-inner { grid-template-columns: 1fr; gap: 32px; }
	.mfc-spread { gap: 16px; margin-bottom: 60px; }
	.mfc-spread-1 .mfc-tile:nth-child(1), .mfc-spread-1 .mfc-tile:nth-child(2),
	.mfc-spread-2 .mfc-tile, .mfc-spread-3 .mfc-tile {
		grid-column: 1 / -1; margin-top: 0;
	}
	.mfc-service { grid-template-columns: 40px 1fr; gap: 16px; padding: 24px 0; }
	.mfc-service-desc, .mfc-service-tags { grid-column: 2 / -1; }
	.mfc-service-tags { text-align: left; }
	.mfc-equipment { grid-template-columns: 1fr; }
	.mfc-eq-item:nth-child(odd) { padding-right: 0; border-right: none; }
	.mfc-eq-item:nth-child(even) { padding-left: 0; }
	.mfc-foot-grid { grid-template-columns: 1fr 1fr; gap: 32px; }
	.mfc-foot-base { flex-direction: column; gap: 8px; }
	.mfc-cat-list a { padding: 8px 16px 8px 0; }
}

/* ===== Hide WP admin bar offset adjustment ===== */
body.mfc-home.admin-bar .mfc-nav { top: 32px; }
@media (max-width: 782px) {
	body.mfc-home.admin-bar .mfc-nav { top: 46px; }
}
