/*!
Theme Name: MechanicMate Editorial
Theme URI: https://mechanicmate.net/
Author: MechanicMate
Author URI: https://mechanicmate.net/
Description: Editorial-workshop WooCommerce theme for digital vehicle workshop manuals. Warm paper canvas, ink navy, hot orange accent. Conversion-focused with a Year/Make/Model picker, trust strip, and editorial spec-card product tiles.
Version: 3.2.6
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: LICENSE
Text Domain: mechanicmate
Tags: custom-background, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready, e-commerce, one-column, two-columns
*/

/* ==========================================================================
   Design tokens — Editorial Workshop
   ========================================================================== */

:root {
	/* Ink (deep navy, near-black) */
	--mm-ink:         #0A1628;
	--mm-ink-2:       #13213A;
	--mm-ink-3:       #1E2F4D;

	/* Paper (warm editorial off-white) */
	--mm-paper:       #F4EFE6;
	--mm-paper-2:     #EFE8DC;
	--mm-paper-3:     #E6DDCD;
	--mm-rule:        #D6CBB7;

	/* Text */
	--mm-body:        #2A3344;
	--mm-muted:       #5B6577;

	/* Accent */
	--mm-orange:      #E8541C;
	--mm-orange-2:    #C94415;

	/* Legacy aliases (kept so any older selector keeps working) */
	--mm-navy:        var(--mm-ink);
	--mm-navy-light:  var(--mm-ink-2);
	--mm-navy-dark:   #05101e;
	--mm-orange-hover:var(--mm-orange-2);
	--mm-orange-light:#fce4d6;
	--mm-white:       #FFFFFF;
	--mm-gray-50:     var(--mm-paper-2);
	--mm-gray-100:    var(--mm-paper-3);
	--mm-gray-200:    var(--mm-rule);
	--mm-gray-300:    #B5AC99;
	--mm-gray-400:    #8A8578;
	--mm-gray-500:    var(--mm-muted);
	--mm-gray-600:    #434B5A;
	--mm-gray-700:    #303747;
	--mm-gray-800:    var(--mm-body);
	--mm-gray-900:    var(--mm-ink);

	/* Feedback */
	--mm-success:     #0F6E4A;
	--mm-success-bg:  #E3F0E8;
	--mm-error:       #B3261E;
	--mm-error-bg:    #F8DAD7;
	--mm-info:        #2563EB;
	--mm-info-bg:     #E0E8F7;
	--mm-warning:     #A25A00;
	--mm-warning-bg:  #F5E2C8;

	/* Typography */
	--mm-font-sans:   'Inter', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", sans-serif;
	--mm-font-mono:   'JetBrains Mono', ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace;
	--mm-font-serif:  'Instrument Serif', "Times New Roman", Georgia, serif;

	--mm-text-xs:     0.75rem;
	--mm-text-sm:     0.875rem;
	--mm-text-base:   1rem;
	--mm-text-lg:     1.125rem;
	--mm-text-xl:     1.25rem;
	--mm-text-2xl:    1.5rem;
	--mm-text-3xl:    1.875rem;
	--mm-text-4xl:    2.25rem;
	--mm-text-5xl:    3rem;

	/* Spacing */
	--mm-sp-1:  0.25rem;
	--mm-sp-2:  0.5rem;
	--mm-sp-3:  0.75rem;
	--mm-sp-4:  1rem;
	--mm-sp-5:  1.25rem;
	--mm-sp-6:  1.5rem;
	--mm-sp-8:  2rem;
	--mm-sp-10: 2.5rem;
	--mm-sp-12: 3rem;
	--mm-sp-16: 4rem;
	--mm-sp-20: 5rem;
	--mm-sp-24: 6rem;

	/* Layout */
	--mm-rail:    1280px;
	--mm-gutter:  clamp(18px, 4vw, 28px);
	--mm-content: 760px;

	/* Radius — editorial uses small, square-ish corners */
	--mm-radius-sm:   2px;
	--mm-radius:      3px;
	--mm-radius-lg:   4px;
	--mm-radius-xl:   6px;
	--mm-radius-full: 999px;

	/* Shadows — mostly hard-offset "print shop" shadows */
	--mm-shadow-sm:   0 1px 2px rgba(10, 22, 40, .06);
	--mm-shadow:      0 2px 4px rgba(10, 22, 40, .08);
	--mm-shadow-md:   0 8px 20px -8px rgba(10, 22, 40, .18);
	--mm-shadow-lg:   0 14px 28px -12px rgba(10, 22, 40, .25);
	--mm-shadow-xl:   0 22px 44px -18px rgba(10, 22, 40, .32);
	--mm-shadow-offset-ink:    -4px 6px 0 0 var(--mm-ink);
	--mm-shadow-offset-orange: -4px 6px 0 0 var(--mm-orange);

	/* Motion */
	--mm-ease:        cubic-bezier(.4, 0, .2, 1);
	--mm-duration:    0.2s;
	--mm-duration-md: 0.3s;

	/* Short-name aliases — used by ported design blocks (cart, downloads,
	   blog article) so their source CSS stays 1:1 with the design handoff.
	   Do not change without updating the ported blocks. */
	--font-sans:  var(--mm-font-sans);
	--font-mono:  var(--mm-font-mono);
	--font-serif: var(--mm-font-serif);
	--mm-ok:      var(--mm-success);
	--mm-err:     var(--mm-error);
	--mm-warn:    var(--mm-warning);
}

/* ==========================================================================
   Reset / base
   ========================================================================== */

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

html {
	line-height: 1.55;
	-webkit-text-size-adjust: 100%;
	scroll-behavior: smooth;
}

body {
	margin: 0;
	font-family: var(--mm-font-sans);
	font-size: 15px;
	line-height: 1.6;
	color: var(--mm-body);
	background: var(--mm-paper);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	overflow-x: hidden;
	font-feature-settings: "ss01", "cv11";
}

main { display: block; }

img, svg { border-style: none; height: auto; max-width: 100%; display: block; }
embed, iframe, object { max-width: 100%; }
figure { margin: 1em 0; }

table {
	margin: 0 0 var(--mm-sp-6);
	width: 100%;
	border-collapse: collapse;
	font-size: var(--mm-text-sm);
}
th, td {
	padding: var(--mm-sp-3) var(--mm-sp-4);
	border-bottom: 1px solid var(--mm-rule);
	text-align: left;
}
th { font-weight: 700; color: var(--mm-ink); background: var(--mm-paper-2); }

/* Editorial helpers */
.mono  { font-family: var(--mm-font-mono); font-feature-settings: "ss02"; }
.serif { font-family: var(--mm-font-serif); font-style: italic; letter-spacing: -0.01em; }
.rail  { max-width: var(--mm-rail); margin: 0 auto; padding: 0 var(--mm-gutter); }
.rule-t { border-top: 1px solid var(--mm-rule); }
.rule-b { border-bottom: 1px solid var(--mm-rule); }

/* ==========================================================================
   Typography
   ========================================================================== */

h1, h2, h3, h4, h5, h6 {
	font-family: var(--mm-font-sans);
	font-weight: 800;
	line-height: 1.1;
	letter-spacing: -0.025em;
	color: var(--mm-ink);
	margin-top: 0;
	margin-bottom: var(--mm-sp-4);
}
h1 { font-size: clamp(2rem, 4.5vw, 3.5rem); letter-spacing: -0.035em; }
h2 { font-size: clamp(1.75rem, 3.5vw, 2.75rem); letter-spacing: -0.03em; }
h3 { font-size: clamp(1.25rem, 2vw, 1.5rem); }
h4 { font-size: 1.125rem; }
h5 { font-size: 1rem; }
h6 { font-size: 0.875rem; }

h1 em, h2 em, h3 em {
	font-family: var(--mm-font-serif);
	font-style: italic;
	font-weight: 400;
	color: var(--mm-orange);
	letter-spacing: -0.02em;
}

p { margin: 0 0 var(--mm-sp-4); }
b, strong { font-weight: 700; color: var(--mm-ink); }
small { font-size: 87.5%; }

blockquote {
	margin: var(--mm-sp-8) 0;
	padding: var(--mm-sp-4) var(--mm-sp-6);
	border-top: 1px solid var(--mm-ink);
	border-bottom: 1px solid var(--mm-ink);
	font-family: var(--mm-font-serif);
	font-style: italic;
	font-size: 1.5rem;
	line-height: 1.35;
	color: var(--mm-ink);
	letter-spacing: -0.01em;
	background: transparent;
	border-left: 0;
	border-radius: 0;
}

pre {
	background: var(--mm-ink);
	color: var(--mm-paper);
	font-family: var(--mm-font-mono);
	font-size: var(--mm-text-sm);
	line-height: 1.7;
	padding: var(--mm-sp-6);
	border-radius: var(--mm-radius-lg);
	overflow-x: auto;
	margin-bottom: var(--mm-sp-6);
}

code, kbd, tt, var {
	font-family: var(--mm-font-mono);
	font-size: 0.9em;
	background: var(--mm-paper-3);
	color: var(--mm-ink);
	padding: 0.15em 0.4em;
	border-radius: var(--mm-radius-sm);
}
pre code { background: none; padding: 0; color: inherit; }

hr {
	border: 0;
	height: 1px;
	background: var(--mm-rule);
	margin: var(--mm-sp-8) 0;
}

ul, ol { margin: 0 0 var(--mm-sp-6); padding-left: var(--mm-sp-6); }
li > ul, li > ol { margin-bottom: 0; }
dt { font-weight: 700; color: var(--mm-ink); }
dd { margin: 0 0 var(--mm-sp-4); }

/* ==========================================================================
   Links
   ========================================================================== */

a {
	color: var(--mm-ink);
	text-decoration: none;
	transition: color var(--mm-duration) var(--mm-ease);
}
a:hover, a:focus { color: var(--mm-orange); }
a:focus-visible {
	outline: 2px solid var(--mm-orange);
	outline-offset: 2px;
	border-radius: 2px;
}

/* ==========================================================================
   Buttons
   ========================================================================== */

button,
input[type="button"],
input[type="reset"],
input[type="submit"],
.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--mm-sp-2);
	font-family: var(--mm-font-sans);
	font-size: 13px;
	font-weight: 600;
	line-height: 1.4;
	padding: 11px 18px;
	border: 1px solid transparent;
	border-radius: var(--mm-radius);
	background: var(--mm-ink);
	color: var(--mm-paper);
	cursor: pointer;
	transition: background var(--mm-duration) var(--mm-ease), color var(--mm-duration) var(--mm-ease), transform .05s;
	text-decoration: none;
	white-space: nowrap;
	letter-spacing: -0.005em;
}
button:hover,
input[type="button"]:hover,
input[type="reset"]:hover,
input[type="submit"]:hover,
.btn:hover { background: var(--mm-orange); color: #fff; }
button:active, .btn:active { transform: translateY(1px); }
button:focus-visible, .btn:focus-visible {
	outline: 2px solid var(--mm-orange);
	outline-offset: 2px;
}

.btn-primary, .btn-cta, a.btn-cta {
	background: var(--mm-orange);
	color: #fff;
}
.btn-primary:hover, .btn-cta:hover, a.btn-cta:hover {
	background: var(--mm-orange-2);
	color: #fff;
}

.btn-outline, a.btn-outline {
	background: transparent;
	color: var(--mm-ink);
	border-color: var(--mm-ink);
}
.btn-outline:hover, a.btn-outline:hover {
	background: var(--mm-ink);
	color: var(--mm-paper);
}

.btn-lg, a.btn-lg {
	font-size: 15px;
	padding: 16px 26px;
}
.btn-sm {
	font-size: 12px;
	padding: 8px 12px;
}

/* ==========================================================================
   Forms
   ========================================================================== */

input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="number"],
input[type="tel"],
input[type="date"],
textarea,
select {
	width: 100%;
	font-family: var(--mm-font-sans);
	font-size: 14px;
	color: var(--mm-ink);
	background: #fff;
	border: 1px solid var(--mm-rule);
	border-radius: var(--mm-radius);
	padding: 12px 14px;
	outline: none;
	transition: border-color var(--mm-duration) var(--mm-ease);
}
input:focus, textarea:focus, select:focus {
	border-color: var(--mm-ink);
}
label {
	font-family: var(--mm-font-mono);
	font-size: 10.5px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--mm-muted);
}

::placeholder { color: var(--mm-muted); opacity: 1; }

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

.skip-link {
	position: absolute; left: -9999px; top: 0;
	background: var(--mm-ink); color: var(--mm-paper);
	padding: 12px 18px; font-weight: 700;
}
.skip-link:focus {
	left: 16px; top: 16px;
	z-index: 10000;
	outline: 3px solid var(--mm-orange);
}

/* ==========================================================================
   Chip + shared UI
   ========================================================================== */

.chip {
	display: inline-flex;
	align-items: center;
	font-family: var(--mm-font-mono);
	font-size: 10px;
	padding: 3px 7px;
	border: 1px solid var(--mm-rule);
	color: var(--mm-muted);
	border-radius: 2px;
	letter-spacing: 0.02em;
	white-space: nowrap;
}
.stars { color: var(--mm-orange); letter-spacing: 1px; font-size: 14px; }

/* ==========================================================================
   Utility bar (top trust strip)
   ========================================================================== */

.utility-bar {
	background: var(--mm-ink);
	color: rgba(244, 239, 230, .82);
	font-size: 12px;
	letter-spacing: 0.02em;
}
.utility-bar__inner {
	max-width: var(--mm-rail);
	margin: 0 auto;
	padding: 0 var(--mm-gutter);
	display: flex;
	align-items: center;
	justify-content: space-between;
	min-height: 38px;
}
.utility-bar__items {
	display: flex;
	gap: 22px;
	align-items: center;
	flex-wrap: wrap;
}
.utility-bar__item {
	display: inline-flex;
	align-items: center;
	gap: 8px;
}
.utility-bar__item .dot {
	width: 6px; height: 6px; border-radius: 50%;
	background: #34D399;
	box-shadow: 0 0 0 3px rgba(52, 211, 153, .2);
}
.utility-bar__sep {
	opacity: 0.4;
	user-select: none;
}
.utility-bar__right {
	display: flex;
	gap: 20px;
	align-items: center;
	color: rgba(244, 239, 230, .85);
}
.utility-bar__right a {
	color: inherit;
	text-decoration: none;
	transition: color var(--mm-duration) var(--mm-ease);
}
.utility-bar__right a:hover {
	color: var(--mm-orange);
}

/* ==========================================================================
   Header / navigation
   ========================================================================== */

#page {
	min-height: 100vh;
	display: flex;
	flex-direction: column;
}
.site-content,
main.site-main {
	flex: 1;
}

.site-header {
	background: var(--mm-paper);
	border-bottom: 1px solid var(--mm-rule);
	position: sticky;
	top: 0;
	z-index: 40;
	transition: box-shadow var(--mm-duration) var(--mm-ease);
}
.site-header.scrolled { box-shadow: 0 4px 16px -8px rgba(10, 22, 40, .15); }

.header-main {
	background: var(--mm-paper);
}
.header-main > .mm-container,
.header-main__inner {
	max-width: var(--mm-rail);
	margin: 0 auto;
	padding: 0 var(--mm-gutter);
	display: grid;
	grid-template-columns: auto 1fr auto;
	gap: 32px;
	align-items: center;
	min-height: 76px;
}

/* Branding */
.site-branding {
	display: flex;
	align-items: center;
	gap: 12px;
	color: var(--mm-ink);
}
.custom-logo-link,
.site-branding .custom-logo-link {
	display: inline-flex;
	align-items: center;
	line-height: 0;
}
.custom-logo {
	width: 40px;
	height: 40px;
	border-radius: var(--mm-radius-lg);
	object-fit: contain;
}
.site-branding-text {
	display: flex;
	flex-direction: column;
	line-height: 1.05;
}
.site-title {
	margin: 0;
	font-size: 17px;
	font-weight: 800;
	letter-spacing: -0.01em;
	color: var(--mm-ink);
}
.site-title a { color: inherit; }
.site-description {
	margin: 2px 0 0;
	font-family: var(--mm-font-mono);
	font-size: 10px;
	color: var(--mm-muted);
	text-transform: uppercase;
	letter-spacing: 0.1em;
}

/* Search (inline in header) */
.header-search {
	display: flex;
	align-items: center;
	min-width: 0;
}
.header-search form {
	position: relative;
	display: flex;
	align-items: center;
	flex: 1;
	max-width: 420px;
	margin: 0 auto;
	background: #fff;
	border: 1px solid var(--mm-rule);
	border-radius: var(--mm-radius-full);
	padding: 0;
	transition: border-color var(--mm-duration) var(--mm-ease);
}
.header-search form:focus-within { border-color: var(--mm-ink); }
.header-search input[type="search"] {
	flex: 1;
	min-width: 0;
	border: 0;
	background: transparent;
	padding: 9px 14px;
	font-size: 13.5px;
	border-radius: var(--mm-radius-full);
}
.header-search input[type="search"]:focus { border: 0; }
.header-search button[type="submit"] {
	width: 36px;
	height: 36px;
	padding: 0;
	margin: 2px;
	border-radius: 50%;
	background: var(--mm-ink);
	color: var(--mm-paper);
	flex-shrink: 0;
}
.header-search button[type="submit"]:hover { background: var(--mm-orange); }
.header-search svg { width: 16px; height: 16px; display: block; fill: currentColor; }

/* ---------- Live search results dropdown ---------- */
.header-search,
.mm-hero-search { position: relative; }

.mm-search-results {
	position: absolute;
	top: calc(100% + 8px);
	left: 50%;
	transform: translateX(-50%) translateY(-6px);
	width: 100%;
	max-width: 440px;
	max-height: min(68vh, 540px);
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
	background: #fff;
	border: 1px solid var(--mm-rule);
	border-radius: 10px;
	box-shadow: 0 18px 44px -16px rgba(10, 22, 40, 0.32);
	z-index: 120;
	padding: 6px;
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transition: opacity var(--mm-duration) var(--mm-ease), transform var(--mm-duration) var(--mm-ease), visibility var(--mm-duration);
}
.mm-search-results.is-open {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
	transform: translateX(-50%) translateY(0);
}

/* Result row */
.mm-search-result-item {
	display: flex;
	gap: 12px;
	align-items: center;
	padding: 9px 10px;
	border-radius: 7px;
	text-decoration: none;
	color: var(--mm-ink);
	transition: background 0.12s var(--mm-ease);
}
.mm-search-result-item + .mm-search-result-item { border-top: 1px solid var(--mm-paper-3); }
.mm-search-result-item:hover,
.mm-search-result-item[aria-selected="true"] { background: var(--mm-paper-2); }

/* Thumbnail */
img.mm-search-result-image,
span.mm-search-result-image {
	flex: 0 0 auto;
	width: 52px;
	height: 52px;
	object-fit: cover;
	border-radius: 5px;
	border: 1px solid var(--mm-rule);
	background: var(--mm-paper-2);
	display: block;
}

/* Info column */
.mm-search-result-info {
	display: flex;
	flex-direction: column;
	gap: 2px;
	min-width: 0;
	flex: 1;
}
.mm-search-result-category {
	order: -1;
	font-family: var(--mm-font-mono);
	font-size: 9.5px;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--mm-muted);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.mm-search-result-title {
	font-family: var(--mm-font-sans);
	font-size: 14px;
	font-weight: 700;
	line-height: 1.25;
	letter-spacing: -0.01em;
	color: var(--mm-ink);
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.mm-search-result-description {
	font-family: var(--mm-font-sans);
	font-size: 12px;
	color: var(--mm-body);
	line-height: 1.35;
	display: -webkit-box;
	-webkit-line-clamp: 1;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.mm-search-result-price {
	font-family: var(--mm-font-sans);
	font-size: 14px;
	font-weight: 800;
	color: var(--mm-ink);
	margin-top: 2px;
}
.mm-search-result-price .woocommerce-Price-amount { color: var(--mm-ink); font-weight: 800; }
.mm-search-result-price del { color: var(--mm-muted); font-weight: 500; font-size: 12px; margin-right: 5px; }
.mm-search-result-price ins { background: none; text-decoration: none; color: var(--mm-orange); }

/* Loading / empty / view-all */
.mm-search-loading,
.mm-search-no-results {
	padding: 18px 14px;
	text-align: center;
	font-family: var(--mm-font-mono);
	font-size: 12px;
	letter-spacing: 0.04em;
	color: var(--mm-muted);
}
.mm-search-view-all {
	display: block;
	margin-top: 4px;
	padding: 11px 12px;
	text-align: center;
	font-family: var(--mm-font-mono);
	font-size: 11px;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	font-weight: 600;
	color: var(--mm-paper);
	background: var(--mm-ink);
	border-radius: 7px;
	text-decoration: none;
	transition: background 0.12s var(--mm-ease);
}
.mm-search-view-all:hover,
.mm-search-view-all[aria-selected="true"] { background: var(--mm-orange); color: #fff; }

/* Grouped results: section heading (e.g. "Vehicles" / "Manuals" / "Browse by make") */
.mm-search-group-label {
	padding: 8px 10px 4px;
	font-family: var(--mm-font-mono);
	font-size: 9.5px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--mm-muted);
}
.mm-search-group-label:not(:first-child) {
	margin-top: 4px;
	border-top: 1px solid var(--mm-paper-3);
}
/* Vehicle / make rows reuse the result-item layout; the thumbnail slot shows a
   small car glyph instead of a product image. Higher specificity than the base
   span.mm-search-result-image rule so the glyph wins. */
.mm-search-result-image.mm-search-vehicle-icon {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='22' viewBox='0 0 24 24' fill='none' stroke='%23667085' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 13l1.5-4.5A2 2 0 0 1 8.4 7h7.2a2 2 0 0 1 1.9 1.5L19 13'/%3E%3Cpath d='M3 13h18v4a1 1 0 0 1-1 1h-1a1 1 0 0 1-1-1v-1H6v1a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1z'/%3E%3Ccircle cx='7.5' cy='17.5' r='0.5'/%3E%3Ccircle cx='16.5' cy='17.5' r='0.5'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: center;
	background-size: 24px 24px;
}
/* "Request this manual" recovery link — outlined, distinct from the solid "View all". */
.mm-search-request {
	display: block;
	margin-top: 6px;
	padding: 11px 12px;
	text-align: center;
	font-family: var(--mm-font-mono);
	font-size: 11px;
	letter-spacing: 0.06em;
	font-weight: 600;
	color: var(--mm-ink);
	background: var(--mm-paper-2);
	border: 1px solid var(--mm-rule);
	border-radius: 7px;
	text-decoration: none;
	transition: background 0.12s var(--mm-ease), color 0.12s var(--mm-ease), border-color 0.12s var(--mm-ease);
}
.mm-search-request:hover,
.mm-search-request[aria-selected="true"] { background: var(--mm-orange); color: #fff; border-color: var(--mm-orange); }

/* Primary navigation */
.main-navigation {
	display: flex;
	align-items: center;
	justify-content: center;
}
.main-navigation ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	gap: 4px;
}
.main-navigation li { position: relative; }
.main-navigation a {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 8px 14px;
	font-size: 13.5px;
	font-weight: 500;
	color: var(--mm-body);
	border-radius: var(--mm-radius-full);
	transition: background var(--mm-duration) var(--mm-ease), color var(--mm-duration) var(--mm-ease);
}
.main-navigation a:hover,
.main-navigation li.current-menu-item > a,
.main-navigation li.current-menu-ancestor > a {
	background: var(--mm-paper-3);
	color: var(--mm-ink);
}

/* Dropdown sub-menus */
.main-navigation ul ul {
	position: absolute;
	top: 100%;
	left: 0;
	min-width: 220px;
	flex-direction: column;
	background: #fff;
	border: 1px solid var(--mm-rule);
	border-radius: var(--mm-radius);
	padding: 6px;
	box-shadow: var(--mm-shadow-lg);
	display: none;
	z-index: 45;
}
.main-navigation ul li:hover > ul,
.main-navigation ul li:focus-within > ul { display: flex; }
.main-navigation ul ul a {
	padding: 8px 12px;
	border-radius: var(--mm-radius);
	font-size: 13px;
	width: 100%;
}

/* Header actions (account / cart / currency) */
.header-actions {
	display: flex;
	align-items: center;
	gap: 6px;
}
.header-iconbtn,
.mobile-search-toggle {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: transparent;
	color: var(--mm-body);
	position: relative;
	padding: 0;
	border: 0;
	transition: background var(--mm-duration) var(--mm-ease), color var(--mm-duration) var(--mm-ease);
}
.header-iconbtn:hover,
.mobile-search-toggle:hover { background: var(--mm-paper-3); color: var(--mm-ink); }
.header-action-label {
	display: none;
}
.header-actions svg { width: 18px; height: 18px; display: block; fill: none; stroke: currentColor; stroke-width: 2; }
.header-actions .header-cart-link svg,
.header-iconbtn svg[aria-hidden="true"]:not([stroke]) {
	stroke: currentColor;
}
.header-cart-link { position: relative; }
/* Brief pop when an item is added via AJAX (class toggled in theme.js,
   gated by prefers-reduced-motion). */
.header-cart-link.cart-updated { animation: mm-cart-pop 0.6s ease; }
.header-cart-link.cart-updated .cart-count { animation: mm-cart-badge 0.6s ease; }
@keyframes mm-cart-pop {
	0%   { transform: scale(1); }
	30%  { transform: scale(1.18); }
	60%  { transform: scale(0.96); }
	100% { transform: scale(1); }
}
@keyframes mm-cart-badge {
	0%   { transform: scale(0.4); opacity: 0; }
	60%  { transform: scale(1.25); opacity: 1; }
	100% { transform: scale(1); }
}
.cart-count {
	position: absolute;
	top: 4px;
	right: 4px;
	min-width: 16px;
	height: 16px;
	padding: 0 4px;
	background: var(--mm-orange);
	color: #fff;
	font-family: var(--mm-font-mono);
	font-size: 9px;
	font-weight: 700;
	border-radius: 999px;
	display: grid;
	place-items: center;
	line-height: 1;
}
.header-search-toggle {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	height: 40px;
	padding: 0 14px;
	background: #fff;
	border: 1px solid var(--mm-rule);
	border-radius: var(--mm-radius-full);
	color: var(--mm-body);
	font-size: 13px;
	font-weight: 500;
	white-space: nowrap;
}
.header-search-toggle:hover {
	border-color: var(--mm-ink);
	color: var(--mm-ink);
}
.header-search-toggle kbd {
	font-family: var(--mm-font-mono);
	font-size: 10px;
	letter-spacing: 0.08em;
	color: var(--mm-muted);
	padding: 3px 6px;
	border: 1px solid var(--mm-rule);
	border-radius: 999px;
	background: var(--mm-paper-2);
}
.header-downloads {
	padding: 9px 16px;
	border: 1px solid var(--mm-ink);
	border-radius: var(--mm-radius-full);
	color: var(--mm-ink);
	font-size: 13px;
	font-weight: 600;
	white-space: nowrap;
}
.header-downloads:hover {
	background: var(--mm-ink);
	color: var(--mm-paper);
}
.mobile-search-toggle {
	display: none;
}

.header-currency-switcher {
	margin-right: 6px;
	font-size: 12px;
	color: var(--mm-muted);
}
.header-currency-switcher select {
	padding: 6px 24px 6px 10px;
	font-size: 12px;
	border-color: var(--mm-rule);
	background: var(--mm-paper-2);
}

/* Mobile menu toggle */
.menu-toggle {
	display: none;
	background: transparent;
	color: var(--mm-ink);
	padding: 6px 10px;
	gap: 6px;
	font-size: 13px;
	font-weight: 600;
	border: 1px solid var(--mm-ink);
	border-radius: var(--mm-radius-full);
}
.menu-toggle svg { stroke: currentColor; fill: none; stroke-width: 2; }
.menu-toggle:hover { background: var(--mm-ink); color: var(--mm-paper); }

/* Mobile search overlay */
.mobile-search-overlay {
	position: fixed;
	inset: 0;
	background: var(--mm-paper);
	z-index: 90;
	display: none;
	padding: 80px var(--mm-gutter);
}
.mobile-search-overlay.is-open,
.mobile-search-overlay.open { display: flex; align-items: flex-start; justify-content: center; }
.mobile-search-overlay-inner {
	width: 100%;
	max-width: 560px;
	position: relative;
}
.mobile-search-close {
	position: absolute;
	top: -50px;
	right: 0;
	background: transparent;
	color: var(--mm-ink);
	font-size: 26px;
	padding: 4px 12px;
	border: 1px solid var(--mm-ink);
	border-radius: var(--mm-radius-full);
}
.mobile-search-hint { display: none; }

/* Desktop & tablet: present search as a centered command-palette modal over a
   dimmed page, instead of a full-screen paper takeover (which suits phones). */
@media (min-width: 768px) {
	.mobile-search-overlay {
		background: rgba(10, 22, 40, 0.5);
		-webkit-backdrop-filter: blur(4px);
		backdrop-filter: blur(4px);
		padding: 0;
	}
	.mobile-search-overlay-inner {
		max-width: 580px;
		margin-top: 13vh;
		padding: 26px;
		background: var(--mm-paper);
		border: 1px solid var(--mm-rule);
		border-radius: var(--mm-radius-xl);
		box-shadow: var(--mm-shadow-xl);
	}
	.mobile-search-overlay .header-search input[type="search"] {
		padding: 13px 16px;
		font-size: 15px;
	}
	.mobile-search-overlay .header-search button[type="submit"] {
		width: 40px;
		height: 40px;
	}
	.mobile-search-close {
		top: -52px;
		right: 0;
		width: 40px;
		height: 40px;
		display: inline-flex;
		align-items: center;
		justify-content: center;
		padding: 0;
		font-size: 22px;
		line-height: 1;
		background: var(--mm-paper);
		color: var(--mm-ink);
		border: 1px solid var(--mm-rule);
		box-shadow: var(--mm-shadow);
		transition: background var(--mm-duration) var(--mm-ease), color var(--mm-duration) var(--mm-ease);
	}
	.mobile-search-close:hover {
		background: var(--mm-ink);
		color: var(--mm-paper);
	}
	.mobile-search-hint {
		display: flex;
		gap: 18px;
		margin-top: 16px;
		font-size: 12px;
		color: var(--mm-muted);
	}
	.mobile-search-hint span {
		display: inline-flex;
		align-items: center;
		gap: 6px;
	}
	.mobile-search-hint kbd {
		font-family: var(--mm-font-mono);
		font-size: 10px;
		padding: 2px 6px;
		border: 1px solid var(--mm-rule);
		border-radius: var(--mm-radius);
		background: var(--mm-paper-2);
		color: var(--mm-body);
	}
}

/* ==========================================================================
   Containers
   ========================================================================== */

.mm-container {
	max-width: var(--mm-rail);
	margin: 0 auto;
	padding: 0 var(--mm-gutter);
}
.mm-container-narrow {
	max-width: var(--mm-content);
	margin: 0 auto;
	padding: 0 var(--mm-gutter);
}

/* ==========================================================================
   Breadcrumbs
   ========================================================================== */

.mm-breadcrumbs {
	font-family: var(--mm-font-mono);
	font-size: 11px;
	letter-spacing: 0.06em;
	background: transparent;
	border: 0;
}
.mm-breadcrumbs__list {
	list-style: none;
	margin: 0;
	padding: 14px 0;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 6px 8px;
	color: var(--mm-muted);
}
.mm-breadcrumbs__item {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	min-width: 0;
	text-transform: uppercase;
}
.mm-breadcrumbs__item:not(:last-child)::after {
	content: "/";
	color: var(--mm-muted);
	opacity: 0.4;
}
.mm-breadcrumbs a {
	color: var(--mm-muted);
	text-decoration: none;
	white-space: nowrap;
	transition: color 0.12s var(--mm-ease);
}
.mm-breadcrumbs a:hover { color: var(--mm-orange); }
.mm-breadcrumbs .here,
.mm-breadcrumbs [aria-current="page"] {
	color: var(--mm-ink);
	font-weight: 600;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	max-width: 42ch;
}
/* WooCommerce's own breadcrumb is replaced by mm-breadcrumbs; hide any stray one. */
.woocommerce .woocommerce-breadcrumb { display: none; }

/* ==========================================================================
   Static content pages (Terms, About, Privacy, Disclaimer, DMCA …)
   Scoped away from the front page and WooCommerce pages so their layouts
   aren't constrained.
   ========================================================================== */
body.page:not(.home):not(.woocommerce-page) .site-main {
	max-width: 860px;
	margin: 0 auto;
	padding: 8px var(--mm-gutter) clamp(56px, 8vw, 104px);
}
body.page:not(.home):not(.woocommerce-page) .entry-header { margin: 10px 0 30px; }
body.page:not(.home):not(.woocommerce-page) .entry-title {
	margin: 0;
	font-size: clamp(34px, 6vw, 56px);
	font-weight: 800;
	letter-spacing: -0.03em;
	line-height: 1.03;
	color: var(--mm-ink);
}
body.page:not(.home):not(.woocommerce-page) .entry-content {
	font-size: 16px;
	line-height: 1.7;
	color: var(--mm-body);
}
body.page:not(.home):not(.woocommerce-page) .entry-content p { margin: 0 0 1.1em; }
body.page:not(.home):not(.woocommerce-page) .entry-content h2 {
	margin: 1.8em 0 0.5em;
	font-size: clamp(22px, 3vw, 28px);
	font-weight: 800;
	letter-spacing: -0.02em;
	line-height: 1.15;
	color: var(--mm-ink);
}
body.page:not(.home):not(.woocommerce-page) .entry-content h3 {
	margin: 1.5em 0 0.4em;
	font-size: 18px;
	font-weight: 700;
	color: var(--mm-ink);
}
body.page:not(.home):not(.woocommerce-page) .entry-content ul,
body.page:not(.home):not(.woocommerce-page) .entry-content ol { margin: 0 0 1.1em; padding-left: 1.4em; }
body.page:not(.home):not(.woocommerce-page) .entry-content li { margin: 0.4em 0; }
body.page:not(.home):not(.woocommerce-page) .entry-content li::marker { color: var(--mm-orange); }
body.page:not(.home):not(.woocommerce-page) .entry-content a {
	color: var(--mm-ink);
	text-decoration: underline;
	text-decoration-color: var(--mm-orange);
	text-underline-offset: 2px;
}
body.page:not(.home):not(.woocommerce-page) .entry-content a:hover { color: var(--mm-orange); }
body.page:not(.home):not(.woocommerce-page) .entry-content strong { color: var(--mm-ink); font-weight: 700; }
body.page:not(.home):not(.woocommerce-page) .entry-content hr { border: 0; border-top: 1px solid var(--mm-rule); margin: 2em 0; }
body.page:not(.home):not(.woocommerce-page) .entry-content blockquote {
	margin: 1.4em 0;
	padding: 4px 0 4px 20px;
	border-left: 3px solid var(--mm-orange);
	color: var(--mm-muted);
	font-style: italic;
}
body.page:not(.home):not(.woocommerce-page) .entry-content table { width: 100%; border-collapse: collapse; margin: 1.2em 0; font-size: 14px; }
body.page:not(.home):not(.woocommerce-page) .entry-content th,
body.page:not(.home):not(.woocommerce-page) .entry-content td { border: 1px solid var(--mm-rule); padding: 8px 12px; text-align: left; }
body.page:not(.home):not(.woocommerce-page) .entry-content th { background: var(--mm-paper-2); font-weight: 700; }
body.page:not(.home):not(.woocommerce-page) #secondary { max-width: 860px; margin: 0 auto; padding: 0 var(--mm-gutter); }

/* ==========================================================================
   Section scaffolding
   ========================================================================== */

.mm-section {
	padding: clamp(48px, 7vw, 80px) 0;
	background: var(--mm-paper);
}
.mm-section-alt { background: var(--mm-paper-2); }

.mm-section-header,
.section-head {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 40px;
	margin-bottom: 40px;
	padding-bottom: 20px;
	border-bottom: 1px solid var(--mm-ink);
}
.section-head__num,
.mm-section-header__num {
	font-family: var(--mm-font-mono);
	font-size: 11px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--mm-muted);
	margin-bottom: 10px;
	display: inline-flex;
	align-items: center;
	gap: 10px;
}
.section-head__num .bar,
.mm-section-header__num .bar {
	width: 22px; height: 1px; background: var(--mm-ink);
}
.mm-section-header h2,
.section-head h2 {
	font-size: clamp(28px, 3.4vw, 42px);
	line-height: 1;
	letter-spacing: -0.03em;
	font-weight: 800;
	color: var(--mm-ink);
	margin: 0;
	max-width: 22ch;
}
.mm-section-header > div:last-child,
.section-head > div:last-child {
	display: flex;
	flex-direction: column;
	gap: 14px;
	align-items: flex-end;
	max-width: 48ch;
}
.mm-section-header p,
.section-head p {
	color: var(--mm-muted);
	font-size: 14px;
	margin: 0;
}
.section-head__link {
	font-family: var(--mm-font-mono);
	font-size: 12px;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--mm-ink);
	border-bottom: 1px solid var(--mm-ink);
	padding-bottom: 2px;
	white-space: nowrap;
}
.section-head__link:hover { color: var(--mm-orange); border-color: var(--mm-orange); }

/* ==========================================================================
   Homepage — hero + picker
   ========================================================================== */

.mm-hero {
	background: var(--mm-paper);
	padding: clamp(24px, 3vw, 36px) 0 0;
	position: relative;
	overflow: hidden;
}
.mm-hero::before {
	content: "";
	position: absolute; inset: 0;
	background-image:
		radial-gradient(circle at 20% 30%, rgba(10, 22, 40, .035) 0, transparent 40%),
		radial-gradient(circle at 80% 70%, rgba(232, 84, 28, .04) 0, transparent 40%);
	pointer-events: none;
}
.mm-hero > .mm-container { position: relative; }

.mm-hero__grid {
	display: grid;
	grid-template-columns: 1.1fr 1fr;
	gap: 56px;
	align-items: start;
	padding: 32px 0 60px;
}
.mm-hero__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-family: var(--mm-font-mono);
	font-size: 11px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--mm-muted);
	margin-bottom: 20px;
}
.mm-hero__eyebrow .bar {
	width: 24px; height: 1px; background: var(--mm-ink);
}
.mm-hero h1 {
	font-family: var(--mm-font-sans);
	font-size: clamp(40px, 5.5vw, 72px);
	line-height: 0.98;
	letter-spacing: -0.035em;
	font-weight: 800;
	color: var(--mm-ink);
	margin: 0 0 24px;
}
.mm-hero h1 em {
	font-family: var(--mm-font-serif);
	font-style: italic;
	font-weight: 400;
	letter-spacing: -0.02em;
	color: var(--mm-orange);
}
.mm-hero__sub {
	font-size: 16.5px;
	line-height: 1.55;
	color: var(--mm-body);
	max-width: 520px;
	margin: 0 0 28px;
}

/* Year/Make/Model Picker */
.mm-picker {
	background: #fff;
	border: 1px solid var(--mm-ink);
	border-radius: var(--mm-radius-lg);
	box-shadow: 8px 8px 0 0 var(--mm-ink);
	overflow: hidden;
}
.mm-picker__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 10px 16px;
	background: var(--mm-ink);
	color: var(--mm-paper);
	font-family: var(--mm-font-mono);
	font-size: 11px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
}
.mm-picker__lamp { display: flex; gap: 6px; }
.mm-picker__lamp span {
	width: 9px; height: 9px; border-radius: 50%;
	background: var(--mm-orange);
	opacity: .85;
}
.mm-picker__lamp span:nth-child(2) { background: #F5B400; }
.mm-picker__lamp span:nth-child(3) { background: #3ECF8E; }
.mm-picker__body { padding: 20px; }
.mm-picker__label {
	font-family: var(--mm-font-mono);
	font-size: 10.5px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--mm-muted);
	margin-bottom: 10px;
}
.mm-picker__row {
	display: grid;
	grid-template-columns: 1fr 1fr 1fr;
	gap: 10px;
}
.mm-select select:disabled {
	opacity: 0.6;
	cursor: not-allowed;
}
.mm-select { position: relative; }
.mm-select select {
	appearance: none;
	-webkit-appearance: none;
	width: 100%;
	background: var(--mm-paper-2);
	border: 1px solid var(--mm-rule);
	border-radius: var(--mm-radius);
	padding: 14px 36px 14px 14px;
	font-family: var(--mm-font-sans);
	font-size: 15px;
	font-weight: 600;
	color: var(--mm-ink);
	cursor: pointer;
	transition: border-color var(--mm-duration) var(--mm-ease);
}
.mm-select select:focus { outline: none; border-color: var(--mm-ink); }
.mm-select::after {
	content: "";
	position: absolute;
	right: 16px;
	top: 50%;
	width: 8px;
	height: 8px;
	border-right: 2px solid var(--mm-ink);
	border-bottom: 2px solid var(--mm-ink);
	transform: translateY(-70%) rotate(45deg);
	pointer-events: none;
}

/* Searchable combobox enhancement (JS replaces the native picker selects). */
.mm-combo { position: relative; }
.mm-combo__native { display: none; }
/* Scoped under .mm-combo so these beat the global `input[type="text"]` rule
 * (specificity 0,1,1) — otherwise the typable box loses its paper background,
 * 15px/600 type and chevron gap, and no longer matches the native .mm-select. */
.mm-combo .mm-combo__input {
	appearance: none;
	-webkit-appearance: none;
	width: 100%;
	background: var(--mm-paper-2);
	border: 1px solid var(--mm-rule);
	border-radius: var(--mm-radius);
	padding: 14px 36px 14px 14px;
	font-family: var(--mm-font-sans);
	font-size: 15px;
	font-weight: 600;
	color: var(--mm-ink);
	cursor: pointer;
	transition: border-color var(--mm-duration) var(--mm-ease);
}
.mm-combo .mm-combo__input::placeholder { color: var(--mm-ink); opacity: 1; font-weight: 600; }
.mm-combo .mm-combo__input:focus { outline: none; border-color: var(--mm-ink); }
.mm-combo.is-disabled .mm-combo__input { opacity: 0.55; cursor: not-allowed; }
.mm-combo__list {
	position: absolute;
	top: calc(100% + 4px);
	left: 0;
	right: 0;
	max-height: 264px;
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
	margin: 0;
	padding: 4px;
	list-style: none;
	background: #fff;
	border: 1px solid var(--mm-rule);
	border-radius: 8px;
	box-shadow: 0 16px 40px -16px rgba(10, 22, 40, 0.3);
	z-index: 60;
}
.mm-combo__option {
	padding: 9px 11px;
	border-radius: 5px;
	cursor: pointer;
	font-family: var(--mm-font-sans);
	font-size: 14px;
	color: var(--mm-ink);
}
.mm-combo__option:hover,
.mm-combo__option.is-active { background: var(--mm-paper-2); }
.mm-combo__option[aria-selected="true"] { font-weight: 700; }
.mm-combo__none { padding: 12px; text-align: center; color: var(--mm-muted); font-size: 13px; font-family: var(--mm-font-sans); }

.mm-picker__cta {
	width: 100%;
	margin-top: 14px;
	padding: 16px;
	background: var(--mm-orange);
	color: #fff;
	border: 0;
	border-radius: var(--mm-radius);
	font-size: 15.5px;
	font-weight: 700;
	letter-spacing: -0.005em;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	transition: background var(--mm-duration) var(--mm-ease), transform .05s;
}
.mm-picker__cta:hover { background: var(--mm-orange-2); color: #fff; }
.mm-picker__cta:active { transform: translateY(1px); }
.mm-picker__foot {
	padding: 12px 20px;
	border-top: 1px dashed var(--mm-rule);
	font-family: var(--mm-font-mono);
	font-size: 11px;
	color: var(--mm-muted);
	display: flex;
	justify-content: space-between;
	align-items: center;
	background: var(--mm-paper);
	gap: 12px;
	flex-wrap: wrap;
}
.mm-picker__foot a {
	color: var(--mm-orange);
	font-weight: 600;
	border-bottom: 1px dotted var(--mm-orange);
}
.mm-picker__foot a:hover { color: var(--mm-orange-2); border-color: var(--mm-orange-2); }

/* Or divider + keyword search */
.mm-or-divider {
	display: flex;
	align-items: center;
	gap: 12px;
	font-family: var(--mm-font-mono);
	font-size: 11px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--mm-muted);
	margin: 20px 0 14px;
}
.mm-or-divider::before,
.mm-or-divider::after {
	content: "";
	flex: 1;
	height: 1px;
	background: var(--mm-rule);
}

.mm-hero-search,
.mm-hero__search {
	display: flex;
	align-items: center;
	background: transparent;
	border: 1px solid var(--mm-ink);
	border-radius: var(--mm-radius);
	overflow: hidden;
}
.mm-hero-search input,
.mm-hero__search input {
	flex: 1;
	border: 0;
	background: transparent;
	padding: 14px 16px;
	font-family: var(--mm-font-sans);
	font-size: 14.5px;
	color: var(--mm-ink);
	outline: none;
}
.mm-hero-search input::placeholder,
.mm-hero__search input::placeholder { color: var(--mm-muted); }
.mm-hero-search button,
.mm-hero__search button {
	background: var(--mm-ink);
	color: var(--mm-paper);
	padding: 14px 18px;
	border: 0;
	font-weight: 600;
	font-size: 13px;
	display: flex;
	align-items: center;
	gap: 8px;
	border-radius: 0;
}
.mm-hero-search button:hover,
.mm-hero__search button:hover { background: var(--mm-orange); color: #fff; }
.mm-hero-search svg,
.mm-hero__search svg { width: 14px; height: 14px; fill: none; stroke: currentColor; stroke-width: 2.5; }

/* Hero visual — editorial spec card */
.mm-hero__visual {
	position: relative;
	min-height: 540px;
}
.mm-spec-card {
	background: var(--mm-ink);
	color: var(--mm-paper);
	border-radius: var(--mm-radius-xl);
	padding: 28px 28px 24px;
	font-family: var(--mm-font-mono);
	transform: rotate(1.2deg);
	box-shadow: -8px 12px 0 0 var(--mm-orange);
	position: relative;
	overflow: hidden;
}
.mm-spec-card__corner {
	position: absolute;
	top: 0;
	right: 0;
	background: var(--mm-orange);
	color: #fff;
	font-size: 10px;
	letter-spacing: 0.12em;
	padding: 6px 14px;
	border-bottom-left-radius: var(--mm-radius-xl);
}
.mm-spec-card__sku {
	font-size: 10px;
	opacity: .55;
	letter-spacing: 0.14em;
}
.mm-spec-card__title {
	font-family: var(--mm-font-sans);
	font-weight: 800;
	font-size: 24px;
	letter-spacing: -0.02em;
	color: var(--mm-paper);
	margin: 8px 0 2px;
	line-height: 1.1;
}
.mm-spec-card__year {
	font-family: var(--mm-font-serif);
	font-style: italic;
	font-size: 22px;
	color: var(--mm-orange);
}
.mm-spec-card__rule {
	margin: 18px 0;
	height: 1px;
	background: rgba(244, 239, 230, .15);
}
.mm-spec-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px 24px;
	font-size: 12px;
}
.mm-spec-grid .k {
	color: rgba(244, 239, 230, .5);
	letter-spacing: 0.08em;
	text-transform: uppercase;
	font-size: 10px;
	margin-bottom: 3px;
}
.mm-spec-grid .v { color: var(--mm-paper); font-weight: 500; }
.mm-spec-card__foot {
	margin-top: 22px;
	padding-top: 18px;
	border-top: 1px dashed rgba(244, 239, 230, .2);
	display: flex;
	justify-content: space-between;
	align-items: center;
	font-size: 11px;
}
.mm-spec-card__foot .price {
	font-family: var(--mm-font-sans);
	font-size: 26px;
	font-weight: 800;
	color: var(--mm-paper);
	letter-spacing: -0.02em;
}

.mm-sticker {
	position: absolute;
	background: var(--mm-paper);
	border: 1px solid var(--mm-ink);
	padding: 10px 14px;
	font-family: var(--mm-font-mono);
	font-size: 10.5px;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--mm-ink);
	border-radius: 2px;
	line-height: 1.2;
}
.mm-sticker b {
	display: block;
	font-family: var(--mm-font-sans);
	font-size: 15px;
	font-weight: 800;
	letter-spacing: -0.01em;
	margin-top: 2px;
	text-transform: none;
}
.mm-sticker--1 { top: 6%; right: 6%; transform: rotate(-4deg); }
.mm-sticker--2 {
	bottom: 14%; left: -8px; transform: rotate(3deg);
	background: var(--mm-orange); color: #fff; border-color: var(--mm-orange);
}
.mm-sticker--2 b { color: #fff; }
.mm-sticker--3 { bottom: -14px; right: 10%; transform: rotate(-1.5deg); }

/* Legacy hero stats (kept as fallback on non-redesigned templates) */
.mm-hero-content { display: block; }
.mm-hero-image { margin-top: 32px; }
.mm-hero-image img { border-radius: var(--mm-radius-lg); border: 1px solid var(--mm-rule); }
.mm-hero-badge {
	display: inline-flex;
	align-items: center;
	font-family: var(--mm-font-mono);
	font-size: 11px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--mm-muted);
	margin-bottom: 16px;
}
.mm-hero-subtitle {
	font-size: 16.5px;
	color: var(--mm-body);
	max-width: 520px;
	margin-bottom: 24px;
}
.mm-hero-stats {
	display: flex;
	gap: 24px;
	margin-top: 28px;
	flex-wrap: wrap;
}
.mm-hero-stat {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	color: var(--mm-ink);
	font-size: 13px;
}
.mm-hero-stat svg { width: 20px; height: 20px; stroke: var(--mm-orange); }

/* ==========================================================================
   Trust strip (below hero)
   ========================================================================== */

.mm-trust {
	background: var(--mm-ink);
	color: var(--mm-paper);
	padding: 22px 0;
	border-top: 6px solid var(--mm-orange);
}
.mm-trust__inner {
	max-width: var(--mm-rail);
	margin: 0 auto;
	padding: 0 var(--mm-gutter);
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: 0;
}
.mm-trust__item {
	padding: 4px 24px;
	display: flex;
	flex-direction: column;
	gap: 4px;
	border-left: 1px solid rgba(244, 239, 230, .1);
}
.mm-trust__item:first-child {
	border-left: 0;
	padding-left: 0;
}
.mm-trust__k {
	font-family: var(--mm-font-mono);
	font-size: 10.5px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: rgba(244, 239, 230, .55);
}
.mm-trust__v {
	font-family: var(--mm-font-sans);
	font-size: 22px;
	font-weight: 800;
	color: var(--mm-paper);
	letter-spacing: -0.015em;
	display: flex;
	align-items: baseline;
	gap: 8px;
}
.mm-trust__v small {
	font-family: var(--mm-font-mono);
	font-size: 11px;
	font-weight: 500;
	color: var(--mm-orange);
	letter-spacing: 0.05em;
}

/* ==========================================================================
   Browse by make
   ========================================================================== */

.mm-makes {
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	border: 1px solid var(--mm-rule);
	background: var(--mm-paper);
}
.mm-makes__item {
	padding: 22px 18px;
	border-right: 1px solid var(--mm-rule);
	border-bottom: 1px solid var(--mm-rule);
	display: flex;
	flex-direction: column;
	gap: 8px;
	justify-content: space-between;
	min-height: 120px;
	position: relative;
	transition: background var(--mm-duration) var(--mm-ease);
	color: inherit;
	cursor: pointer;
}
.mm-makes__item:hover { background: var(--mm-paper-2); }
.mm-makes__item:nth-child(6n) { border-right: 0; }
.mm-makes__item:nth-last-child(-n+6) { border-bottom: 0; }
.mm-makes__name {
	font-size: 18px;
	font-weight: 700;
	color: var(--mm-ink);
	letter-spacing: -0.015em;
}
.mm-makes__meta {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	font-family: var(--mm-font-mono);
	font-size: 10.5px;
	letter-spacing: 0.05em;
	color: var(--mm-muted);
}
.mm-makes__meta .count {
	color: var(--mm-ink);
	font-weight: 600;
	font-size: 12px;
}
.mm-makes__arrow {
	position: absolute;
	top: 18px;
	right: 18px;
	font-family: var(--mm-font-mono);
	font-size: 14px;
	color: var(--mm-muted);
	transition: transform var(--mm-duration) var(--mm-ease), color var(--mm-duration) var(--mm-ease);
}
.mm-makes__item:hover .mm-makes__arrow {
	transform: translate(3px, -3px);
	color: var(--mm-orange);
}

/* Make-card brand mark — real logo when available, else a letter monogram. */
.mm-makes__logo {
	display: inline-flex;
	align-items: center;
	height: 30px;
	margin-bottom: 2px;
}
.mm-makes__logo img {
	height: 26px;
	width: auto;
	max-width: 104px;
	object-fit: contain;
	object-position: left center;
	opacity: 0.6;
	transition: opacity var(--mm-duration) var(--mm-ease);
}
.mm-makes__item:hover .mm-makes__logo img { opacity: 0.95; }
.mm-makes__logo--mono {
	font-family: var(--mm-font-sans);
	font-weight: 800;
	font-size: 22px;
	line-height: 1;
	letter-spacing: -0.02em;
	color: var(--mm-muted);
	opacity: 0.5;
}

/* ==========================================================================
   Brand marquee
   ========================================================================== */
.mm-brands {
	padding: clamp(28px, 4vw, 44px) 0;
	border-top: 1px solid var(--mm-rule);
	border-bottom: 1px solid var(--mm-rule);
	background: var(--mm-paper);
	overflow: hidden;
}
.mm-brands__label {
	text-align: center;
	margin: 0 0 clamp(18px, 2.5vw, 28px);
	font-family: var(--mm-font-mono);
	font-size: 11px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--mm-muted);
}
.mm-brands__slider {
	position: relative;
	overflow: hidden;
	-webkit-mask-image: linear-gradient(90deg, transparent 0, #000 8%, #000 92%, transparent 100%);
	mask-image: linear-gradient(90deg, transparent 0, #000 8%, #000 92%, transparent 100%);
}
/* Per-item right margin (not flex gap) so the duplicated track tiles exactly
   and translateX(-50%) loops with no seam jump. */
.mm-brands__track {
	display: flex;
	align-items: center;
	width: max-content;
	animation: mm-brands-scroll 45s linear infinite;
}
.mm-brands__slider:hover .mm-brands__track { animation-play-state: paused; }
.mm-brands__item {
	flex: 0 0 auto;
	margin-right: clamp(40px, 5vw, 72px);
	display: inline-flex;
	align-items: center;
	opacity: 0.5;
	transition: opacity var(--mm-duration) var(--mm-ease);
}
.mm-brands__item:hover { opacity: 1; }
.mm-brands__item img {
	height: clamp(26px, 3vw, 38px);
	width: auto;
	max-width: 132px;
	object-fit: contain;
	display: block;
}
@keyframes mm-brands-scroll {
	from { transform: translateX(0); }
	to   { transform: translateX(-50%); }
}
@media (prefers-reduced-motion: reduce) {
	.mm-brands__track {
		animation: none;
		flex-wrap: wrap;
		justify-content: center;
		width: auto;
		row-gap: 24px;
	}
	.mm-brands__slider {
		-webkit-mask-image: none;
		mask-image: none;
	}
}

/* ==========================================================================
   Can't find it / lead capture
   ========================================================================== */

.mm-cantfind {
	background: var(--mm-ink);
	color: var(--mm-paper);
	position: relative;
	overflow: hidden;
}
.mm-cantfind__inner {
	max-width: var(--mm-rail);
	margin: 0 auto;
	padding: clamp(56px, 7vw, 80px) var(--mm-gutter);
	display: grid;
	grid-template-columns: 1.2fr 1fr;
	gap: 48px;
	align-items: center;
}
.mm-cantfind__eyebrow {
	font-family: var(--mm-font-mono);
	font-size: 11px;
	letter-spacing: 0.14em;
	color: rgba(244, 239, 230, .55);
	text-transform: uppercase;
	margin-bottom: 16px;
}
.mm-cantfind h2 {
	font-family: var(--mm-font-sans);
	font-size: clamp(32px, 4.5vw, 54px);
	line-height: 1;
	letter-spacing: -0.03em;
	font-weight: 800;
	color: var(--mm-paper);
	margin: 0 0 16px;
	max-width: 14ch;
}
.mm-cantfind h2 em {
	font-family: var(--mm-font-serif);
	font-style: italic;
	font-weight: 400;
	color: var(--mm-orange);
}
.mm-cantfind p {
	color: rgba(244, 239, 230, .75);
	font-size: 16px;
	max-width: 48ch;
	margin: 0;
}
.mm-cantfind__pros {
	display: flex;
	gap: 20px;
	flex-wrap: wrap;
	margin-top: 26px;
	font-family: var(--mm-font-mono);
	font-size: 12px;
	color: rgba(244, 239, 230, .75);
	letter-spacing: 0.08em;
	text-transform: uppercase;
}
.mm-cantfind__pros span { display: inline-flex; align-items: center; gap: 6px; }

.mm-cantfind__form-wrap {
	background: var(--mm-paper);
	border-radius: var(--mm-radius-xl);
	padding: 28px;
	color: var(--mm-ink);
}
.mm-cantfind__form-wrap .mm-form-eyebrow {
	font-family: var(--mm-font-mono);
	font-size: 10.5px;
	color: var(--mm-muted);
	letter-spacing: 0.14em;
	text-transform: uppercase;
	margin-bottom: 14px;
}
.mm-cantfind__form-wrap label {
	display: block;
	margin-bottom: 6px;
}
.mm-cantfind__form-wrap input,
.mm-cantfind__form-wrap textarea,
.mm-cantfind__form-wrap select {
	margin-bottom: 14px;
}
.mm-cantfind__form-wrap button[type="submit"] {
	width: 100%;
	background: var(--mm-orange);
	color: #fff;
	padding: 14px;
	font-size: 15px;
	font-weight: 700;
}
.mm-cantfind__form-wrap button[type="submit"]:hover { background: var(--mm-orange-2); }
.mm-cantfind__form-note {
	font-family: var(--mm-font-mono);
	font-size: 11px;
	color: var(--mm-muted);
	margin-top: 8px;
	text-align: center;
}

/* WPForms / CF7 inside the dark lead block */
.mm-cantfind__form-wrap .wpcf7-form-control-wrap input,
.mm-cantfind__form-wrap .wpcf7-form-control-wrap textarea,
.mm-cantfind__form-wrap .wpforms-field input,
.mm-cantfind__form-wrap .wpforms-field textarea {
	background: #fff;
	border: 1px solid var(--mm-rule);
}
.mm-cantfind__form-wrap .wpcf7 label,
.mm-cantfind__form-wrap .wpforms-field-label {
	font-family: var(--mm-font-mono);
	font-size: 10.5px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--mm-muted);
	font-weight: 500;
}

/* ==========================================================================
   Editorial reviews
   ========================================================================== */

.mm-testimonials,
.mm-reviews {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 28px;
}
.mm-testimonial,
.mm-review {
	background: var(--mm-paper);
	border: 1px solid var(--mm-rule);
	padding: 28px 26px 24px;
	position: relative;
	border-radius: var(--mm-radius-lg);
}
.mm-testimonial::before,
.mm-review::before {
	content: "\201C";
	font-family: var(--mm-font-serif);
	font-style: italic;
	font-size: 64px;
	line-height: 0.6;
	color: var(--mm-orange);
	position: absolute;
	top: 22px;
	right: 22px;
	pointer-events: none;
}
.mm-testimonial-stars,
.mm-review__stars {
	color: var(--mm-orange);
	font-size: 14px;
	letter-spacing: 2px;
	margin-bottom: 14px;
	display: flex;
	gap: 2px;
}
.mm-testimonial-stars svg { width: 16px; height: 16px; fill: currentColor; }
.mm-testimonial p,
.mm-review__text {
	font-family: var(--mm-font-serif);
	font-style: italic;
	font-size: 21px;
	line-height: 1.3;
	color: var(--mm-ink);
	margin: 0 0 22px;
	letter-spacing: -0.01em;
}
.mm-testimonial-author,
.mm-review__meta-wrap {
	display: flex;
	flex-direction: column;
	gap: 2px;
}
.mm-testimonial-meta strong,
.mm-review__author {
	font-size: 13.5px;
	font-weight: 700;
	color: var(--mm-ink);
}
.mm-testimonial-meta span,
.mm-review__meta {
	font-family: var(--mm-font-mono);
	font-size: 10.5px;
	color: var(--mm-muted);
	letter-spacing: 0.06em;
}
.mm-review__verified,
.mm-testimonial__verified {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	font-family: var(--mm-font-mono);
	font-size: 10px;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--mm-success);
	margin-top: 8px;
}

/* ==========================================================================
   How it works
   ========================================================================== */

.mm-how,
.mm-trust-bar {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 0;
	border: 1px solid var(--mm-ink);
	border-radius: var(--mm-radius-lg);
	overflow: hidden;
	background: var(--mm-paper);
}
.mm-how__step,
.mm-trust-item {
	padding: 36px 32px;
	border-right: 1px solid var(--mm-rule);
	display: flex;
	flex-direction: column;
	gap: 14px;
	position: relative;
}
.mm-how__step:last-child,
.mm-trust-item:last-child { border-right: 0; }
.mm-how__num {
	font-family: var(--mm-font-serif);
	font-style: italic;
	font-size: 80px;
	line-height: 0.8;
	color: var(--mm-orange);
}
.mm-how__tag {
	font-family: var(--mm-font-mono);
	font-size: 10px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--mm-ink);
	padding: 4px 8px;
	background: var(--mm-paper-3);
	border-radius: 2px;
	align-self: flex-start;
}
.mm-how__step h3,
.mm-trust-item h3 {
	font-size: 20px;
	font-weight: 800;
	color: var(--mm-ink);
	letter-spacing: -0.015em;
	margin: 0;
}
.mm-how__step p,
.mm-trust-item p {
	font-size: 14px;
	color: var(--mm-muted);
	margin: 0;
}

/* Legacy trust-item icons (if rendered by old template) */
.mm-trust-icon {
	width: 48px; height: 48px;
	border-radius: 50%;
	background: var(--mm-paper-3);
	color: var(--mm-orange);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	align-self: flex-start;
}
.mm-trust-icon svg { width: 22px; height: 22px; stroke: currentColor; fill: none; stroke-width: 2; }

/* ==========================================================================
   FAQ (details/summary accordion)
   ========================================================================== */

.mm-faq-list {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0 64px;
}
.mm-faq-item,
details.qa {
	border-top: 1px solid var(--mm-rule);
	padding: 18px 0;
	background: transparent;
	border-radius: 0;
	box-shadow: none;
	border-bottom: 0;
}
.mm-faq-list > .mm-faq-item:nth-last-child(-n+2),
.mm-faq-list > details.qa:nth-last-child(-n+2) {
	border-bottom: 1px solid var(--mm-rule);
}
.mm-faq-item summary,
details.qa summary {
	cursor: pointer;
	list-style: none;
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	gap: 16px;
	font-size: 16px;
	font-weight: 700;
	color: var(--mm-ink);
	letter-spacing: -0.01em;
	padding: 0;
}
.mm-faq-item summary::-webkit-details-marker,
details.qa summary::-webkit-details-marker { display: none; }
.mm-faq-item summary::after,
details.qa summary::after {
	content: "+";
	font-family: var(--mm-font-mono);
	font-size: 22px;
	font-weight: 400;
	color: var(--mm-orange);
	transition: transform var(--mm-duration) var(--mm-ease);
	line-height: 1;
	flex-shrink: 0;
}
.mm-faq-item[open] summary::after,
details.qa[open] summary::after { content: "—"; font-size: 14px; }
.mm-faq-item .faq-answer,
.mm-faq-item > p,
details.qa .a {
	padding-top: 12px;
	font-size: 14.5px;
	color: var(--mm-body);
	line-height: 1.6;
}
.mm-faq-item .faq-answer p { margin: 0; }

/* ==========================================================================
   Big CTA band
   ========================================================================== */

.mm-cta-section,
.mm-bigcta {
	background: var(--mm-orange);
	color: #fff;
	padding: clamp(56px, 7vw, 80px) 0;
	text-align: center;
	position: relative;
	overflow: hidden;
}
.mm-cta-section::before,
.mm-cta-section::after,
.mm-bigcta::before,
.mm-bigcta::after {
	content: "MECHANIC\00B7MATE\00B7";
	position: absolute;
	white-space: nowrap;
	font-family: var(--mm-font-sans);
	font-weight: 900;
	font-style: italic;
	font-size: clamp(90px, 14vw, 160px);
	letter-spacing: -0.04em;
	color: rgba(255, 255, 255, .08);
	top: -20px; left: -40px;
	line-height: 1;
	pointer-events: none;
}
.mm-cta-section::after,
.mm-bigcta::after {
	top: auto; bottom: -20px; left: auto; right: -40px;
}
.mm-cta-section > .mm-container,
.mm-bigcta__inner {
	position: relative;
	z-index: 1;
	max-width: var(--mm-rail);
	margin: 0 auto;
	padding: 0 var(--mm-gutter);
}
.mm-cta-section h2,
.mm-bigcta h2 {
	font-size: clamp(40px, 5.5vw, 72px);
	font-weight: 800;
	letter-spacing: -0.03em;
	line-height: 0.98;
	margin: 0 0 18px;
	color: #fff;
	max-width: 20ch;
	margin-inline: auto;
}
.mm-cta-section h2 em,
.mm-bigcta h2 em {
	font-family: var(--mm-font-serif);
	font-style: italic;
	font-weight: 400;
	color: #fff;
}
.mm-cta-section p,
.mm-bigcta p {
	color: rgba(255, 255, 255, .92);
	font-size: 16.5px;
	max-width: 52ch;
	margin: 0 auto 30px;
}
.mm-cta-section .btn-cta,
.mm-cta-section a.btn-cta,
.mm-bigcta__btn {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	background: var(--mm-ink);
	color: var(--mm-paper);
	padding: 18px 30px;
	border-radius: var(--mm-radius);
	font-size: 15.5px;
	font-weight: 700;
	border: 0;
}
.mm-cta-section .btn-cta:hover,
.mm-cta-section a.btn-cta:hover,
.mm-bigcta__btn:hover { background: #000; color: #fff; }
.mm-bigcta__meta {
	display: flex;
	gap: 24px;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap;
	margin-top: 24px;
	font-family: var(--mm-font-mono);
	font-size: 11px;
	letter-spacing: 0.1em;
	color: rgba(255, 255, 255, .88);
	text-transform: uppercase;
}

/* ==========================================================================
   Sticky buy bar (bottom pill)
   ========================================================================== */

.mm-stickybuy {
	position: fixed;
	left: 50%;
	transform: translateX(-50%);
	bottom: 18px;
	z-index: 60;
	display: flex;
	align-items: center;
	gap: 12px;
	background: var(--mm-ink);
	color: var(--mm-paper);
	padding: 10px 10px 10px 20px;
	border-radius: 999px;
	box-shadow: 0 14px 36px -10px rgba(10, 22, 40, .5);
	font-size: 13px;
	opacity: 0;
	pointer-events: none;
	transition: opacity .25s;
}
.mm-stickybuy.visible { opacity: 1; pointer-events: auto; }
.mm-stickybuy .dot {
	width: 6px; height: 6px;
	background: #34D399;
	border-radius: 50%;
}
.mm-stickybuy a {
	background: var(--mm-orange);
	color: #fff;
	padding: 8px 14px;
	border-radius: 999px;
	font-weight: 700;
	font-size: 12.5px;
}
.mm-stickybuy a:hover { background: var(--mm-orange-2); color: #fff; }

/* ==========================================================================
   Brands carousel (legacy on homepage)
   ========================================================================== */

.mm-brands-section {
	padding: 32px 0;
	background: var(--mm-paper-2);
	border-top: 1px solid var(--mm-rule);
	border-bottom: 1px solid var(--mm-rule);
}
.mm-brands-label {
	font-family: var(--mm-font-mono);
	font-size: 11px;
	letter-spacing: 0.14em;
	color: var(--mm-muted);
	text-transform: uppercase;
	text-align: center;
	margin: 0 0 18px;
}
.mm-brands-slider {
	overflow: hidden;
	position: relative;
	mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
	-webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
}
.mm-brands-track {
	display: flex;
	align-items: center;
	gap: 56px;
	animation: mm-brands-scroll 40s linear infinite;
}
.mm-brand-item {
	flex-shrink: 0;
	opacity: 0.7;
	transition: opacity var(--mm-duration) var(--mm-ease);
}
.mm-brand-item:hover { opacity: 1; }
.mm-brand-item img {
	max-width: 110px;
	height: 38px;
	object-fit: contain;
	filter: grayscale(1);
	transition: filter var(--mm-duration) var(--mm-ease);
}
.mm-brand-item:hover img { filter: grayscale(0); }
@keyframes mm-brands-scroll {
	from { transform: translateX(0); }
	to   { transform: translateX(-50%); }
}

/* ==========================================================================
   Pagination (shared)
   ========================================================================== */

.pagination,
.mm-pagination,
.woocommerce nav.woocommerce-pagination ul {
	display: flex;
	justify-content: center;
	gap: 4px;
	margin-top: 40px;
	padding-top: 28px;
	border-top: 1px solid var(--mm-rule);
	list-style: none;
	padding-left: 0;
	flex-wrap: wrap;
}
.pagination a,
.pagination span,
.mm-pagination a,
.mm-pagination span,
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
	min-width: 38px;
	height: 38px;
	padding: 0 10px;
	background: #fff;
	border: 1px solid var(--mm-rule);
	color: var(--mm-ink);
	font-family: var(--mm-font-mono);
	font-size: 13px;
	border-radius: var(--mm-radius);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition: background var(--mm-duration) var(--mm-ease), color var(--mm-duration) var(--mm-ease);
}
.pagination .current,
.mm-pagination .current,
.woocommerce nav.woocommerce-pagination ul li span.current {
	background: var(--mm-ink);
	color: var(--mm-paper);
	border-color: var(--mm-ink);
	font-weight: 700;
}
.pagination a:hover,
.mm-pagination a:hover,
.woocommerce nav.woocommerce-pagination ul li a:hover { background: var(--mm-paper-2); }

/* ==========================================================================
   Footer
   ========================================================================== */

.site-footer {
	background: var(--mm-ink);
	color: rgba(244, 239, 230, .7);
	padding: 64px 0 24px;
}
.footer-main { padding: 0; }
.footer-grid {
	display: grid;
	grid-template-columns: 1.4fr 1fr 1fr 1fr 1fr;
	gap: 40px;
}
.footer-heading {
	font-family: var(--mm-font-mono);
	font-size: 10.5px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: rgba(244, 239, 230, .5);
	margin: 0 0 16px;
	font-weight: 500;
}
.footer-brand .footer-heading {
	font-family: var(--mm-font-sans);
	font-size: 18px;
	font-weight: 800;
	color: var(--mm-paper);
	letter-spacing: -0.01em;
	text-transform: none;
}
.footer-brand p {
	font-size: 13.5px;
	line-height: 1.6;
	max-width: 34ch;
	color: rgba(244, 239, 230, .75);
}
.footer-links {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.footer-links a,
.site-footer a {
	color: rgba(244, 239, 230, .85);
	font-size: 13.5px;
	text-decoration: none;
}
.footer-links a:hover,
.site-footer a:hover { color: var(--mm-orange); }

.footer-trust-badges {
	display: flex;
	flex-direction: column;
	gap: 10px;
	margin: 18px 0 10px;
}
.footer-trust-badge {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-family: var(--mm-font-mono);
	font-size: 11px;
	letter-spacing: 0.08em;
	color: rgba(244, 239, 230, .7);
	text-transform: uppercase;
}
.footer-trust-badge svg { stroke: var(--mm-orange); fill: none; stroke-width: 2; width: 18px; height: 18px; }

.mm-payment-logos {
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
	margin-top: 14px;
}
.mm-payment-logos svg { width: 42px; height: 28px; }

.footer-menu-placeholder {
	color: rgba(244, 239, 230, .6);
	font-size: 13px;
	margin: 0;
}

.footer-bottom {
	margin-top: 48px;
	padding-top: 20px;
	border-top: 1px solid rgba(244, 239, 230, .1);
}
.footer-bottom .mm-container {
	display: flex;
	justify-content: space-between;
	gap: 16px;
	font-family: var(--mm-font-mono);
	font-size: 11px;
	color: rgba(244, 239, 230, .5);
	letter-spacing: 0.04em;
	align-items: center;
	flex-wrap: wrap;
}
.footer-bottom p { margin: 0; }
.footer-bottom-links { display: flex; gap: 18px; flex-wrap: wrap; }

/* ==========================================================================
   Blog / archive / single
   ========================================================================== */

.mm-blog-main {
	background: var(--mm-paper);
	padding: 0 0 64px;
}
.mm-blog-hero {
	background: var(--mm-paper);
	border-bottom: 1px solid var(--mm-rule);
	padding: 56px 0 40px;
}
.mm-blog-hero__inner { max-width: var(--mm-rail); margin: 0 auto; padding: 0 var(--mm-gutter); }
.mm-blog-hero h1,
.mm-blog-hero .page-title {
	font-size: clamp(36px, 5vw, 58px);
	letter-spacing: -0.035em;
	line-height: 1;
	margin: 0 0 14px;
}
.mm-blog-hero__intro,
.mm-blog-hero__description {
	font-family: var(--mm-font-serif);
	font-style: italic;
	font-size: 20px;
	line-height: 1.4;
	color: var(--mm-body);
	max-width: 60ch;
	margin: 0;
}

.mm-blog-layout {
	display: grid;
	grid-template-columns: 1fr 300px;
	gap: 48px;
	align-items: start;
	padding-top: 40px;
}
.mm-blog-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 24px;
}
.mm-blog-sidebar {
	display: flex;
	flex-direction: column;
	gap: 28px;
}
.mm-blog-sidebar .widget {
	background: transparent;
	padding: 18px 0;
	border-top: 1px solid var(--mm-rule);
}
.mm-blog-sidebar .widget-title {
	font-family: var(--mm-font-mono);
	font-size: 10.5px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--mm-ink);
	margin: 0 0 14px;
}

.mm-blog-card {
	background: #fff;
	border: 1px solid var(--mm-rule);
	border-radius: var(--mm-radius-lg);
	overflow: hidden;
	display: flex;
	flex-direction: column;
	transition: transform .2s, box-shadow .2s;
}
.mm-blog-card:hover {
	transform: translateY(-3px);
	box-shadow: var(--mm-shadow-lg);
}
.mm-blog-card__thumb {
	aspect-ratio: 3/2;
	background: var(--mm-paper-2);
	border-bottom: 1px solid var(--mm-rule);
	overflow: hidden;
}
.mm-blog-card__thumb img { width: 100%; height: 100%; object-fit: cover; }
.mm-blog-card__body {
	padding: 20px;
	display: flex;
	flex-direction: column;
	gap: 12px;
	flex: 1;
}
.mm-blog-card__categories {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}
.mm-blog-card__category,
.mm-blog-card__cat {
	font-family: var(--mm-font-mono);
	font-size: 10px;
	padding: 3px 8px;
	background: var(--mm-paper-3);
	color: var(--mm-ink);
	letter-spacing: 0.08em;
	text-transform: uppercase;
	border-radius: 2px;
}
.mm-blog-card__title {
	font-size: 18px;
	font-weight: 800;
	color: var(--mm-ink);
	letter-spacing: -0.015em;
	line-height: 1.25;
	margin: 0;
}
.mm-blog-card__title a { color: inherit; }
.mm-blog-card__title a:hover { color: var(--mm-orange); }
.mm-blog-card__excerpt {
	font-size: 14px;
	color: var(--mm-body);
	line-height: 1.55;
	margin: 0;
}
.mm-blog-card__footer {
	margin-top: auto;
	padding-top: 12px;
	border-top: 1px dashed var(--mm-rule);
	display: flex;
	justify-content: space-between;
	align-items: center;
	font-family: var(--mm-font-mono);
	font-size: 11px;
	color: var(--mm-muted);
}
.mm-blog-card__footer a {
	color: var(--mm-ink);
	font-weight: 600;
	font-family: var(--mm-font-sans);
	font-size: 13px;
	display: inline-flex;
	align-items: center;
	gap: 4px;
}
.mm-blog-card__footer a:hover { color: var(--mm-orange); }

/* Single post */
.mm-single-post { padding: 40px 0 72px; }
.mm-single-post .mm-container { max-width: 820px; }
.mm-single-header { margin-bottom: 32px; }
.mm-single-header h1 {
	font-size: clamp(32px, 4.5vw, 52px);
	letter-spacing: -0.035em;
	line-height: 1.05;
	margin: 14px 0;
}
.mm-single-meta,
.mm-single-post .entry-meta {
	display: flex;
	align-items: center;
	gap: 14px;
	flex-wrap: wrap;
	font-family: var(--mm-font-mono);
	font-size: 12px;
	color: var(--mm-muted);
	letter-spacing: 0.04em;
}
.mm-single-meta img {
	width: 36px; height: 36px;
	border-radius: 50%;
	border: 1px solid var(--mm-rule);
}
.mm-single-featured {
	margin: 0 0 36px;
	border-radius: var(--mm-radius-lg);
	overflow: hidden;
	border: 1px solid var(--mm-rule);
}
.mm-single-content {
	font-size: 17px;
	line-height: 1.75;
	color: var(--mm-body);
}
.mm-single-content h2 { margin-top: 40px; }
.mm-single-content h3 { margin-top: 32px; }
.mm-single-content img {
	border-radius: var(--mm-radius-lg);
	margin: 28px 0;
}
.mm-single-content a {
	color: var(--mm-ink);
	border-bottom: 1px dotted var(--mm-ink);
}
.mm-single-content a:hover { color: var(--mm-orange); border-color: var(--mm-orange); }

.mm-single-footer {
	margin-top: 40px;
	padding-top: 28px;
	border-top: 1px solid var(--mm-rule);
	display: flex;
	justify-content: space-between;
	gap: 20px;
	flex-wrap: wrap;
	font-family: var(--mm-font-mono);
	font-size: 12px;
}
.mm-post-nav {
	margin-top: 48px;
	padding-top: 32px;
	border-top: 1px solid var(--mm-rule);
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
}
.mm-post-nav a {
	padding: 16px;
	border: 1px solid var(--mm-rule);
	border-radius: var(--mm-radius-lg);
	background: #fff;
	display: block;
}
.mm-post-nav a:hover { border-color: var(--mm-ink); }
.mm-post-nav__label {
	font-family: var(--mm-font-mono);
	font-size: 10.5px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--mm-muted);
	margin-bottom: 4px;
}
.mm-author-box {
	margin: 48px 0 32px;
	padding: 24px;
	background: var(--mm-paper-2);
	border: 1px solid var(--mm-rule);
	border-radius: var(--mm-radius-lg);
	display: flex;
	gap: 20px;
	align-items: flex-start;
}
.mm-author-box img {
	width: 64px; height: 64px; border-radius: 50%;
	border: 1px solid var(--mm-rule);
	flex-shrink: 0;
}

/* ==========================================================================
   Comments
   ========================================================================== */

.comments-area {
	margin-top: 48px;
	padding-top: 32px;
	border-top: 1px solid var(--mm-rule);
}
.comments-title {
	font-family: var(--mm-font-mono);
	font-size: 12px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--mm-muted);
	margin-bottom: 24px;
}
.comment-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 20px;
}
.comment-body {
	padding: 20px;
	background: var(--mm-paper-2);
	border: 1px solid var(--mm-rule);
	border-radius: var(--mm-radius-lg);
}
.comment-author {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-bottom: 12px;
}
.comment-author img {
	width: 40px; height: 40px; border-radius: 50%;
	border: 1px solid var(--mm-rule);
}
.comment-meta,
.comment-metadata {
	font-family: var(--mm-font-mono);
	font-size: 11px;
	color: var(--mm-muted);
	letter-spacing: 0.06em;
}
.comment-respond .form-submit input[type="submit"] {
	background: var(--mm-orange);
	color: #fff;
	padding: 14px 22px;
}

/* ==========================================================================
   Animation helpers
   ========================================================================== */

.fade-in-up {
	opacity: 0;
	transform: translateY(16px);
	transition: opacity .6s var(--mm-ease), transform .6s var(--mm-ease);
}
.fade-in-up.is-visible {
	opacity: 1;
	transform: translateY(0);
}

@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;
	}
	.fade-in-up { opacity: 1; transform: none; }
	.mm-brands-track { animation: none; }
}

/* ==========================================================================
   Responsive
   ========================================================================== */

@media (max-width: 1100px) {
	.header-main > .mm-container,
	.header-main__inner {
		grid-template-columns: auto 1fr auto;
		gap: 14px;
	}
	.main-navigation { display: none; }
	.menu-toggle { display: inline-flex; }
	.header-search,
	.header-search-toggle,
	.header-downloads { display: none; }
	.mobile-search-toggle { display: inline-flex; }
}

@media (max-width: 1024px) {
	.mm-hero__grid { grid-template-columns: 1fr; gap: 40px; }
	.mm-hero__visual { min-height: 420px; }
	.mm-makes { grid-template-columns: repeat(3, 1fr); }
	.mm-makes__item:nth-child(6n) { border-right: 1px solid var(--mm-rule); }
	.mm-makes__item:nth-child(3n) { border-right: 0; }
	.mm-makes__item:nth-last-child(-n+6) { border-bottom: 1px solid var(--mm-rule); }
	.mm-makes__item:nth-last-child(-n+3) { border-bottom: 0; }
	.mm-trust__inner { grid-template-columns: repeat(2, 1fr); gap: 10px 0; }
	.mm-trust__item {
		padding: 8px 0;
		border-left: 0;
		border-top: 1px solid rgba(244, 239, 230, .1);
	}
	.mm-trust__item:first-child,
	.mm-trust__item:nth-child(2) { border-top: 0; }
	.mm-cantfind__inner { grid-template-columns: 1fr; }
	.mm-testimonials,
	.mm-reviews { grid-template-columns: 1fr; }
	.mm-how,
	.mm-trust-bar { grid-template-columns: 1fr; border-radius: var(--mm-radius-lg); }
	.mm-how__step,
	.mm-trust-item {
		border-right: 0;
		border-bottom: 1px solid var(--mm-rule);
	}
	.mm-how__step:last-child,
	.mm-trust-item:last-child { border-bottom: 0; }
	.mm-faq-list { grid-template-columns: 1fr; gap: 0; }
	.mm-faq-list > .mm-faq-item:nth-last-child(-n+2),
	.mm-faq-list > details.qa:nth-last-child(-n+2) { border-bottom: 0; }
	.mm-faq-list > .mm-faq-item:last-child,
	.mm-faq-list > details.qa:last-child { border-bottom: 1px solid var(--mm-rule); }
	.footer-grid { grid-template-columns: 1fr 1fr; }
	.mm-blog-layout { grid-template-columns: 1fr; }
	.mm-post-nav { grid-template-columns: 1fr; }
}

@media (max-width: 640px) {
	.utility-bar { display: none; }
	.mm-picker__row { grid-template-columns: 1fr; }
	.mm-makes { grid-template-columns: repeat(2, 1fr); }
	.mm-makes__item:nth-child(3n) { border-right: 1px solid var(--mm-rule); }
	.mm-makes__item:nth-child(2n) { border-right: 0; }
	.mm-section-header,
	.section-head { flex-direction: column; align-items: flex-start; gap: 18px; }
	.mm-section-header > div:last-child,
	.section-head > div:last-child { align-items: flex-start; }
	.footer-grid { grid-template-columns: 1fr; gap: 28px; }
	.footer-bottom .mm-container { flex-direction: column; align-items: flex-start; }
	.mm-stickybuy { font-size: 12px; padding: 8px 8px 8px 16px; }
	.mm-stickybuy span { display: none; }
}

/* ==========================================================================
   Blog article (single post) — editorial Field Notes layout
   Ported from MechanicMate Blog Article.html design handoff. Rendered by
   single.php. All selectors are prefixed with body.single-post or the
   .mm-article-* class family so they don't bleed into other templates.
   ========================================================================== */

/* Masthead */
.mm-ed-mast {
	background: var(--mm-ink);
	color: var(--mm-paper);
	position: relative;
	overflow: hidden;
	border-bottom: 3px solid var(--mm-orange);
}
.mm-ed-mast::before {
	content: var(--mm-ed-mast-word, "FIELD NOTES \00b7 N\00ba  047");
	position: absolute;
	top: -30px;
	right: -30px;
	white-space: nowrap;
	font-family: var(--mm-font-sans);
	font-weight: 900;
	font-style: italic;
	font-size: 180px;
	letter-spacing: -0.05em;
	color: rgba(244, 239, 230, .04);
	line-height: 1;
	pointer-events: none;
}
.mm-ed-mast__inner { padding: 60px 28px 56px; position: relative; max-width: var(--mm-rail); margin: 0 auto; }
.mm-ed-mast__kicker {
	font-family: var(--mm-font-mono);
	font-size: 11px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--mm-orange);
	margin-bottom: 22px;
	display: inline-flex;
	align-items: center;
	gap: 10px;
}
.mm-ed-mast__kicker .bar { width: 28px; height: 1px; background: var(--mm-orange); display: inline-block; }
.mm-ed-mast__title {
	font-family: var(--mm-font-sans);
	font-weight: 800;
	font-size: clamp(38px, 5.5vw, 76px);
	line-height: 0.96;
	letter-spacing: -0.035em;
	color: var(--mm-paper);
	max-width: 22ch;
	margin: 0 0 22px;
}
.mm-ed-mast__title em {
	font-family: var(--mm-font-serif);
	font-style: italic;
	font-weight: 400;
	color: var(--mm-orange);
	letter-spacing: -0.02em;
}
.mm-ed-mast__dek {
	font-family: var(--mm-font-serif);
	font-style: italic;
	font-size: 22px;
	line-height: 1.4;
	color: rgba(244, 239, 230, .78);
	max-width: 60ch;
	margin: 0 0 28px;
}
.mm-ed-mast__byline {
	display: flex;
	align-items: center;
	gap: 0;
	border-top: 1px solid rgba(244, 239, 230, .2);
	border-bottom: 1px solid rgba(244, 239, 230, .2);
	padding: 16px 0;
	flex-wrap: wrap;
}
.mm-byl-block { padding: 0 24px; border-left: 1px solid rgba(244, 239, 230, .15); }
.mm-byl-block:first-child { padding-left: 0; border-left: none; }
.mm-byl-block.mm-byl-block--author { display: flex; align-items: center; }
.mm-byl-k {
	font-family: var(--mm-font-mono);
	font-size: 9.5px;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: rgba(244, 239, 230, .5);
	margin-bottom: 4px;
}
.mm-byl-v {
	font-size: 14px;
	font-weight: 600;
	color: var(--mm-paper);
	letter-spacing: -0.005em;
}
.mm-byl-v em { font-family: var(--mm-font-serif); font-style: italic; font-weight: 400; color: var(--mm-orange); }
.mm-byl-v a { color: inherit; border-bottom: 1px solid rgba(244, 239, 230, .3); text-decoration: none; }
.mm-byl-v a:hover { border-bottom-color: var(--mm-orange); color: var(--mm-orange); }
.mm-byl-avatar {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background: var(--mm-orange);
	color: #fff;
	display: inline-grid;
	place-items: center;
	font-family: var(--mm-font-mono);
	font-weight: 700;
	font-size: 14px;
	margin-right: 12px;
	box-shadow: 0 0 0 2px rgba(232, 84, 28, .25);
	overflow: hidden;
}
.mm-byl-avatar img { width: 100%; height: 100%; object-fit: cover; border-radius: 50%; display: block; }

/* Body layout */
.mm-article-body {
	background: var(--mm-paper);
	padding: 0 0 60px;
}
.mm-article-grid {
	display: grid;
	grid-template-columns: 220px 1fr 260px;
	gap: 40px;
	align-items: start;
	padding: 48px 28px;
	max-width: var(--mm-rail);
	margin: 0 auto;
}

/* Left meta column */
.mm-meta-col { position: sticky; top: 100px; }
.mm-meta-block {
	padding-bottom: 16px;
	margin-bottom: 16px;
	border-bottom: 1px solid var(--mm-rule);
}
.mm-meta-block:last-child { border-bottom: none; margin-bottom: 0; }
.mm-meta-block__k {
	font-family: var(--mm-font-mono);
	font-size: 10px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--mm-muted);
	margin-bottom: 8px;
}
.mm-meta-block__v {
	font-size: 14px;
	color: var(--mm-ink);
	font-weight: 500;
	line-height: 1.4;
}
.mm-meta-block__v b { font-weight: 700; }
.mm-meta-topics { display: flex; flex-direction: column; gap: 4px; }
.mm-meta-topics a {
	font-family: var(--mm-font-mono);
	font-size: 11px;
	letter-spacing: 0.06em;
	color: var(--mm-ink);
	padding: 3px 0;
	display: inline-flex;
	gap: 6px;
	text-decoration: none;
}
.mm-meta-topics a::before { content: "#"; color: var(--mm-orange); }
.mm-meta-topics a:hover { color: var(--mm-orange); }
.mm-meta-share { display: flex; gap: 6px; }
.mm-meta-share a,
.mm-meta-share button {
	width: 34px;
	height: 34px;
	border-radius: 3px;
	border: 1px solid var(--mm-rule);
	background: #fff;
	display: inline-grid;
	place-items: center;
	color: var(--mm-muted);
	cursor: pointer;
	text-decoration: none;
}
.mm-meta-share a:hover,
.mm-meta-share button:hover { background: var(--mm-ink); color: var(--mm-paper); border-color: var(--mm-ink); }
/* Force the icon stroke so the <button> icons (copy, print) aren't invisible —
   their currentColor was being overridden elsewhere. */
.mm-meta-share a svg,
.mm-meta-share button svg { stroke: var(--mm-muted); width: 14px; height: 14px; display: block; }
.mm-meta-share a:hover svg,
.mm-meta-share button:hover svg { stroke: var(--mm-paper); }

/* Middle prose */
.mm-prose { max-width: 640px; margin: 0 auto; }
.mm-prose h2 {
	font-family: var(--mm-font-sans);
	font-weight: 800;
	font-size: 32px;
	letter-spacing: -0.025em;
	line-height: 1.1;
	color: var(--mm-ink);
	margin: 52px 0 16px;
	position: relative;
	padding-left: 28px;
}
.mm-prose h2::before {
	content: "\00a7 ";
	position: absolute;
	left: 0;
	top: 2px;
	font-family: var(--mm-font-serif);
	font-style: italic;
	color: var(--mm-orange);
	font-size: 32px;
	font-weight: 400;
}
.mm-prose h2 em { font-family: var(--mm-font-serif); font-style: italic; font-weight: 400; color: var(--mm-orange); }
.mm-prose h3 {
	font-family: var(--mm-font-sans);
	font-weight: 700;
	font-size: 20px;
	letter-spacing: -0.015em;
	color: var(--mm-ink);
	margin: 32px 0 10px;
}
.mm-prose p {
	font-size: 17.5px;
	line-height: 1.66;
	color: var(--mm-body);
	margin: 0 0 22px;
	text-wrap: pretty;
}
.mm-prose p.lede::first-letter,
.mm-prose > p:first-of-type::first-letter {
	font-family: var(--mm-font-serif);
	font-style: italic;
	font-size: 78px;
	font-weight: 400;
	float: left;
	line-height: 0.85;
	color: var(--mm-orange);
	margin: 5px 10px -2px 0;
}
.mm-prose p.lede,
.mm-prose > p:first-of-type { font-size: 19px; color: var(--mm-ink); }
.mm-prose a.inl {
	color: var(--mm-ink);
	border-bottom: 1px solid var(--mm-orange);
	font-weight: 500;
	text-decoration: none;
}
.mm-prose a.inl:hover { background: var(--mm-orange); color: #fff; }
.mm-prose strong { color: var(--mm-ink); font-weight: 700; }
.mm-prose em { font-style: italic; }
.mm-prose code {
	font-family: var(--mm-font-mono);
	font-size: 13.5px;
	background: var(--mm-paper-2);
	border: 1px solid var(--mm-rule);
	padding: 1px 6px;
	border-radius: 2px;
	color: var(--mm-ink);
	font-weight: 500;
}

/* Pull-quote */
.mm-pullq {
	margin: 36px -40px;
	padding: 32px 40px 30px;
	border-top: 2px solid var(--mm-ink);
	border-bottom: 2px solid var(--mm-ink);
	position: relative;
}
.mm-pullq::before {
	content: "\201C";
	font-family: var(--mm-font-serif);
	font-style: italic;
	position: absolute;
	top: -12px;
	left: 30px;
	font-size: 90px;
	line-height: 1;
	color: var(--mm-orange);
	background: var(--mm-paper);
	padding: 0 10px;
}
.mm-pullq blockquote {
	font-family: var(--mm-font-serif);
	font-style: italic;
	font-weight: 400;
	font-size: 28px;
	line-height: 1.28;
	letter-spacing: -0.01em;
	color: var(--mm-ink);
	margin: 0;
}
.mm-pullq cite {
	display: block;
	margin-top: 14px;
	font-family: var(--mm-font-mono);
	font-style: normal;
	font-size: 11px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--mm-muted);
}

/* Figure / caption */
.mm-figure { margin: 34px 0 26px; }
.mm-figure__bg {
	aspect-ratio: 16 / 10;
	background: var(--mm-ink);
	color: var(--mm-paper);
	border-radius: 3px;
	padding: 24px;
	position: relative;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
}
.mm-figure__bg::before {
	content: "";
	position: absolute;
	inset: 0;
	background-image:
		linear-gradient(rgba(244, 239, 230, .05) 1px, transparent 1px),
		linear-gradient(90deg, rgba(244, 239, 230, .05) 1px, transparent 1px);
	background-size: 24px 24px;
	pointer-events: none;
}
.mm-figure__tag {
	font-family: var(--mm-font-mono);
	font-size: 10px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--mm-orange);
	position: relative;
}
.mm-figure__art {
	position: relative;
	flex: 1;
	display: grid;
	place-items: center;
	font-family: var(--mm-font-mono);
	color: rgba(244, 239, 230, .6);
	font-size: 12px;
}
.mm-figure__art svg,
.mm-figure__art img { max-width: 100%; height: auto; }
.mm-figure__fn {
	position: relative;
	font-family: var(--mm-font-mono);
	font-size: 9.5px;
	letter-spacing: 0.1em;
	color: rgba(244, 239, 230, .4);
	display: flex;
	justify-content: space-between;
}
.mm-figure__cap {
	margin-top: 14px;
	font-family: var(--mm-font-serif);
	font-style: italic;
	font-size: 13.5px;
	line-height: 1.45;
	color: var(--mm-muted);
	padding-left: 20px;
	border-left: 2px solid var(--mm-orange);
}
.mm-figure__cap b {
	font-family: var(--mm-font-mono);
	font-style: normal;
	font-size: 10px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--mm-ink);
	font-weight: 700;
	margin-right: 6px;
}

/* Step list */
.mm-steplist {
	margin: 28px 0 30px;
	padding: 24px 24px 14px;
	background: var(--mm-paper-2);
	border-left: 3px solid var(--mm-ink);
	border-radius: 0 3px 3px 0;
}
.mm-steplist__hd {
	font-family: var(--mm-font-mono);
	font-size: 10.5px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--mm-muted);
	margin-bottom: 14px;
}
.mm-steplist__hd b {
	color: var(--mm-ink);
	font-family: var(--mm-font-sans);
	font-weight: 800;
	font-size: 14px;
	letter-spacing: -0.005em;
	text-transform: none;
}
.mm-step {
	display: grid;
	grid-template-columns: 36px 1fr;
	gap: 16px;
	padding: 14px 0;
	border-top: 1px dashed var(--mm-rule);
}
.mm-step:first-of-type { border-top: none; padding-top: 0; }
.mm-step__n {
	font-family: var(--mm-font-mono);
	font-size: 14px;
	font-weight: 600;
	color: var(--mm-paper);
	background: var(--mm-ink);
	width: 28px;
	height: 28px;
	border-radius: 50%;
	display: inline-grid;
	place-items: center;
	letter-spacing: 0;
}
.mm-step__body h4 {
	font-family: var(--mm-font-sans);
	font-weight: 700;
	font-size: 15.5px;
	letter-spacing: -0.005em;
	color: var(--mm-ink);
	margin: 0 0 4px;
}
.mm-step__body p {
	font-size: 14.5px;
	line-height: 1.55;
	color: var(--mm-body);
	margin: 0;
}
.mm-step__body code { font-size: 12.5px; }

/* DTC table */
.mm-dtc-table {
	margin: 28px 0;
	border: 1px solid var(--mm-rule);
	border-radius: 3px;
	overflow: hidden;
}
.mm-dtc-table__hd {
	padding: 12px 18px;
	background: var(--mm-ink);
	color: var(--mm-paper);
	font-family: var(--mm-font-mono);
	font-size: 11px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	display: flex;
	align-items: center;
	gap: 12px;
}
.mm-dtc-table__hd .badge {
	font-size: 10px;
	padding: 3px 7px;
	border-radius: 1px;
	background: var(--mm-orange);
	color: #fff;
	letter-spacing: 0.08em;
}
.mm-dtc-row {
	display: grid;
	grid-template-columns: 110px 1fr auto;
	gap: 16px;
	padding: 12px 18px;
	align-items: center;
	border-top: 1px solid var(--mm-rule);
	background: #fff;
}
.mm-dtc-row:first-of-type { border-top: none; }
.mm-dtc-row:hover { background: var(--mm-paper-2); }
.mm-dtc-code {
	font-family: var(--mm-font-mono);
	font-size: 14px;
	font-weight: 700;
	color: var(--mm-orange);
	letter-spacing: 0.02em;
}
.mm-dtc-desc {
	font-size: 14px;
	color: var(--mm-ink);
	font-weight: 500;
}
.mm-dtc-desc small {
	display: block;
	font-size: 12.5px;
	color: var(--mm-muted);
	font-weight: 400;
	margin-top: 1px;
}
.mm-dtc-sev {
	font-family: var(--mm-font-mono);
	font-size: 10px;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	padding: 3px 8px;
	border-radius: 1px;
}
.mm-dtc-sev--hi { background: rgba(200, 47, 47, .1); color: var(--mm-err); }
.mm-dtc-sev--md { background: rgba(232, 84, 28, .1); color: var(--mm-orange); }
.mm-dtc-sev--lo { background: rgba(14, 138, 90, .1); color: var(--mm-ok); }

/* Inline product CTA card */
.mm-prodcta {
	margin: 40px -30px;
	padding: 28px;
	background: var(--mm-ink);
	color: var(--mm-paper);
	border-radius: 4px;
	box-shadow: -5px 6px 0 0 var(--mm-orange);
	display: grid;
	grid-template-columns: 92px 1fr auto;
	gap: 22px;
	align-items: center;
	position: relative;
	overflow: hidden;
}
.mm-prodcta::before {
	content: "\00a7  WORKSHOP MANUAL";
	position: absolute;
	top: 12px;
	right: 18px;
	font-family: var(--mm-font-mono);
	font-size: 9.5px;
	letter-spacing: 0.16em;
	color: rgba(244, 239, 230, .35);
}
.mm-prodcta__book {
	position: relative;
	width: 90px;
	aspect-ratio: 3/4;
	background: #0a1628;
	color: var(--mm-paper);
	border-radius: 1px 3px 3px 1px;
	box-shadow: -4px 3px 0 0 rgba(10, 22, 40, .3);
	overflow: hidden;
	padding: 10px 10px 12px;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	font-family: var(--mm-font-mono);
}
.mm-prodcta__book::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 4px; background: var(--mm-orange); }
.mm-prodcta__book::after { content: ""; position: absolute; inset: 8px 6px 8px 11px; border: 1px solid rgba(244, 239, 230, .2); }
.mm-prodcta__book .br { font-size: 7.5px; letter-spacing: 0.15em; text-transform: uppercase; color: rgba(244, 239, 230, .6); position: relative; }
.mm-prodcta__book .md { font-family: var(--mm-font-sans); font-weight: 800; font-size: 12px; color: var(--mm-paper); line-height: 1.05; letter-spacing: -0.01em; position: relative; margin-top: 3px; }
.mm-prodcta__book .sv { font-family: var(--mm-font-serif); font-style: italic; font-size: 10px; color: var(--mm-orange); position: relative; margin-top: 2px; }
.mm-prodcta__book .dv { height: 1px; background: rgba(244, 239, 230, .2); margin: 3px 0; position: relative; }
.mm-prodcta__book .sp { font-size: 6.5px; color: rgba(244, 239, 230, .6); letter-spacing: 0.08em; line-height: 1.3; position: relative; }
.mm-prodcta__book .st { position: absolute; bottom: 10px; right: 8px; font-family: var(--mm-font-serif); font-style: italic; color: rgba(232, 84, 28, .9); font-size: 9.5px; transform: rotate(-8deg); border: 1px solid rgba(232, 84, 28, .5); padding: 1px 4px; border-radius: 1px; }

.mm-prodcta__body { min-width: 0; }
.mm-prodcta__kicker {
	font-family: var(--mm-font-mono);
	font-size: 10px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--mm-orange);
	margin-bottom: 6px;
}
.mm-prose .mm-prodcta__title,
.mm-prodcta__title {
	font-family: var(--mm-font-sans);
	font-weight: 800;
	font-size: 22px;
	line-height: 1.15;
	letter-spacing: -0.02em;
	color: var(--mm-paper);
	margin: 0 0 6px;
	padding-left: 0;
}
.mm-prose .mm-prodcta__title::before { content: none; }
.mm-prose .mm-prodcta__title em,
.mm-prodcta__title em {
	font-family: var(--mm-font-serif);
	font-style: italic;
	font-weight: 400;
	color: var(--mm-orange);
}
.mm-prose .mm-prodcta__sub,
.mm-prodcta__sub {
	font-family: var(--mm-font-serif);
	font-style: italic;
	font-size: 13.5px;
	color: rgba(244, 239, 230, .7);
	margin: 0;
}
.mm-prodcta__right { text-align: right; }
.mm-prodcta__price {
	font-size: 28px;
	font-weight: 800;
	letter-spacing: -0.02em;
	line-height: 1;
	margin-bottom: 10px;
}
.mm-prodcta__price small {
	font-family: var(--mm-font-mono);
	font-size: 11px;
	letter-spacing: 0.1em;
	color: rgba(244, 239, 230, .5);
	font-weight: 500;
	margin-left: 4px;
}
.mm-prodcta__btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 10px 16px;
	background: var(--mm-orange);
	color: #fff;
	border-radius: 3px;
	font-weight: 700;
	font-size: 13px;
	text-decoration: none;
}
.mm-prodcta__btn:hover { background: #fff; color: var(--mm-ink); }

/* Right sidebar */
.mm-article-sidebar { position: sticky; top: 100px; }
.mm-toc {
	background: #fff;
	border: 1px solid var(--mm-rule);
	border-radius: 3px;
	padding: 18px;
	margin-bottom: 22px;
}
.mm-toc__hd {
	font-family: var(--mm-font-mono);
	font-size: 10px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--mm-muted);
	margin-bottom: 10px;
}
.mm-toc__hd b {
	color: var(--mm-ink);
	font-family: var(--mm-font-sans);
	font-weight: 700;
	font-size: 12.5px;
	letter-spacing: 0;
	text-transform: none;
}
.mm-toc ol { list-style: none; padding: 0; margin: 0; counter-reset: toc; }
.mm-toc li {
	counter-increment: toc;
	font-size: 13px;
	line-height: 1.35;
	padding: 6px 0;
	border-top: 1px dashed var(--mm-rule);
	display: grid;
	grid-template-columns: 24px 1fr;
}
.mm-toc li:first-child { border-top: none; }
.mm-toc li::before {
	content: counter(toc, decimal-leading-zero);
	font-family: var(--mm-font-mono);
	font-size: 10px;
	color: var(--mm-muted);
	letter-spacing: 0.06em;
	padding-top: 2px;
}
.mm-toc a { color: var(--mm-body); text-decoration: none; }
.mm-toc a:hover,
.mm-toc li.active a { color: var(--mm-orange); }
.mm-toc li.active { font-weight: 600; }
.mm-toc li.active::before { color: var(--mm-orange); font-weight: 700; }

.mm-readnext {
	background: var(--mm-ink);
	color: var(--mm-paper);
	border-radius: 3px;
	padding: 20px;
	box-shadow: -4px 5px 0 0 var(--mm-orange);
	margin-bottom: 22px;
}
.mm-readnext__lbl {
	font-family: var(--mm-font-mono);
	font-size: 10px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--mm-orange);
	margin-bottom: 8px;
}
.mm-readnext h4 {
	font-family: var(--mm-font-sans);
	font-weight: 800;
	font-size: 17px;
	letter-spacing: -0.015em;
	line-height: 1.2;
	margin: 0 0 8px;
	color: var(--mm-paper);
}
.mm-readnext h4 em { font-family: var(--mm-font-serif); font-style: italic; font-weight: 400; color: var(--mm-orange); }
.mm-readnext p {
	font-family: var(--mm-font-serif);
	font-style: italic;
	font-size: 13px;
	line-height: 1.45;
	color: rgba(244, 239, 230, .7);
	margin: 0 0 12px;
}
.mm-readnext a {
	font-family: var(--mm-font-mono);
	font-size: 11px;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--mm-orange);
	font-weight: 600;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	text-decoration: none;
}
.mm-readnext a:hover { color: #fff; }

.mm-sb-newsletter {
	background: #fff;
	border: 1px dashed var(--mm-rule);
	border-radius: 3px;
	padding: 18px;
}
.mm-sb-newsletter .k {
	font-family: var(--mm-font-mono);
	font-size: 10px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--mm-muted);
	margin-bottom: 6px;
}
.mm-sb-newsletter h4 {
	font-family: var(--mm-font-sans);
	font-weight: 800;
	font-size: 15px;
	letter-spacing: -0.01em;
	margin: 0 0 6px;
	color: var(--mm-ink);
}
.mm-sb-newsletter p {
	font-size: 12.5px;
	line-height: 1.45;
	color: var(--mm-muted);
	margin: 0 0 12px;
}
.mm-sb-newsletter form {
	display: flex;
	gap: 0;
	border: 1px solid var(--mm-rule);
	border-radius: 2px;
	overflow: hidden;
}
.mm-sb-newsletter input {
	flex: 1;
	border: none;
	outline: none;
	padding: 9px 10px;
	font: inherit;
	font-size: 12.5px;
	background: transparent;
}
.mm-sb-newsletter button {
	border: none;
	background: var(--mm-ink);
	color: var(--mm-paper);
	font-family: var(--mm-font-mono);
	font-size: 10px;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	padding: 0 12px;
	font-weight: 600;
	cursor: pointer;
}
.mm-sb-newsletter button:hover { background: var(--mm-orange); }

/* Related articles */
.mm-related {
	border-top: 1px solid var(--mm-rule);
	background: var(--mm-paper);
	padding: 56px 0 64px;
}
.mm-related__inner { max-width: var(--mm-rail); margin: 0 auto; padding: 0 28px; }
.mm-related__hd {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	margin-bottom: 24px;
}
.mm-related__hd h3 {
	font-family: var(--mm-font-sans);
	font-weight: 800;
	font-size: 34px;
	letter-spacing: -0.025em;
	color: var(--mm-ink);
	margin: 0;
}
.mm-related__hd h3 em { font-family: var(--mm-font-serif); font-style: italic; font-weight: 400; color: var(--mm-orange); }
.mm-related__hd a {
	font-family: var(--mm-font-mono);
	font-size: 11px;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--mm-ink);
	border-bottom: 1px solid var(--mm-ink);
	text-decoration: none;
}
.mm-related__hd a:hover { color: var(--mm-orange); border-bottom-color: var(--mm-orange); }
.mm-related__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 20px;
}
.mm-rel-card {
	background: #fff;
	border: 1px solid var(--mm-rule);
	border-radius: 4px;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	transition: transform .15s, box-shadow .15s, border-color .15s;
	text-decoration: none;
	color: inherit;
}
.mm-rel-card:hover {
	transform: translateY(-2px);
	box-shadow: 0 12px 26px -14px rgba(10, 22, 40, .22);
	border-color: var(--mm-ink);
}
.mm-rel-card__bg {
	aspect-ratio: 16/10;
	background: var(--mm-ink);
	color: var(--mm-paper);
	padding: 18px;
	position: relative;
	background-image:
		linear-gradient(rgba(244, 239, 230, .05) 1px, transparent 1px),
		linear-gradient(90deg, rgba(244, 239, 230, .05) 1px, transparent 1px);
	background-size: 20px 20px;
	overflow: hidden;
}
.mm-rel-card__bg--img { padding: 0; background-image: none; }
.mm-rel-card__bg--img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.mm-rel-card__tag {
	font-family: var(--mm-font-mono);
	font-size: 10px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--mm-orange);
	position: relative;
}
.mm-rel-card__num {
	position: absolute;
	bottom: 14px;
	right: 14px;
	font-family: var(--mm-font-serif);
	font-style: italic;
	font-size: 42px;
	color: rgba(244, 239, 230, .25);
	line-height: 1;
}
.mm-rel-card__art {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	font-family: var(--mm-font-mono);
	font-size: 11px;
	color: rgba(244, 239, 230, .65);
	text-align: center;
	letter-spacing: 0.1em;
}
.mm-rel-card__body {
	padding: 18px 18px 20px;
	display: flex;
	flex-direction: column;
	gap: 6px;
	flex: 1;
}
.mm-rel-card__cat {
	font-family: var(--mm-font-mono);
	font-size: 10px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--mm-muted);
}
.mm-rel-card h4 {
	font-family: var(--mm-font-sans);
	font-weight: 700;
	font-size: 18px;
	letter-spacing: -0.02em;
	line-height: 1.22;
	color: var(--mm-ink);
	margin: 0;
}
.mm-rel-card h4 em { font-family: var(--mm-font-serif); font-style: italic; font-weight: 400; color: var(--mm-orange); }
.mm-rel-card__meta {
	margin-top: auto;
	padding-top: 10px;
	font-family: var(--mm-font-mono);
	font-size: 10.5px;
	letter-spacing: 0.06em;
	color: var(--mm-muted);
	display: flex;
	gap: 12px;
}

/* Key takeaway box */
.mm-keybox {
	margin: 28px 0;
	background: #fff;
	border: 1px solid var(--mm-ink);
	border-radius: 3px;
	padding: 20px 24px;
	position: relative;
}
.mm-keybox::before {
	content: "KEY TAKEAWAY";
	position: absolute;
	top: -8px;
	left: 18px;
	background: var(--mm-orange);
	color: #fff;
	font-family: var(--mm-font-mono);
	font-size: 9.5px;
	letter-spacing: 0.16em;
	padding: 3px 9px;
	border-radius: 2px;
}
.mm-keybox p {
	margin: 0;
	font-size: 16px;
	line-height: 1.55;
	color: var(--mm-ink);
	font-weight: 500;
}
.mm-keybox p b { color: var(--mm-orange); font-weight: 700; }

@media (max-width: 1100px) {
	.mm-article-grid { grid-template-columns: 1fr; gap: 24px; padding: 28px 20px; }
	.mm-meta-col,
	.mm-article-sidebar { position: static; }
	.mm-meta-col { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; padding: 18px; background: var(--mm-paper-2); border-radius: 3px; }
	.mm-meta-block { border-bottom: none; padding-bottom: 0; margin-bottom: 0; }
	.mm-prose { max-width: 100%; }
	.mm-pullq { margin: 28px 0; }
	.mm-prodcta { margin: 32px 0; grid-template-columns: 1fr; text-align: left; }
	.mm-prodcta__right { text-align: left; }
	.mm-related__grid { grid-template-columns: 1fr; }
	.mm-ed-mast__byline { flex-direction: column; align-items: flex-start; gap: 14px; }
	.mm-byl-block { padding: 0 !important; border-left: none !important; }
}

/* ==========================================================================
   Video testimonials (mm-vidtest) — 9:16 portrait customer clips
   Shown on the homepage and on single product pages. Cards autoplay muted on
   scroll and open the shared .mm-lightbox with sound on click.
   ========================================================================== */
.mm-vidtest {
	list-style: none;
	margin: 0;
	/* Horizontal scroll row: any cards beyond what fits slide sideways instead of
	   wrapping onto a new line. With ≤4 the row simply fills (no scrollbar shows). */
	display: flex;
	gap: var(--mm-sp-6);
	overflow-x: auto;
	scroll-snap-type: x proximity;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: thin;
	/* breathing room so the -4px/6px offset shadow isn't clipped by the overflow */
	padding: 4px 6px 16px;
	margin-inline: -6px;
}

.mm-vidtest__card {
	display: flex;
	flex-direction: column;
	gap: var(--mm-sp-3);
	flex: 0 0 calc((100% - 3 * var(--mm-sp-6)) / 4); /* 4 per view on desktop */
	scroll-snap-align: start;
}

.mm-vidtest__open {
	position: relative;
	display: block;
	width: 100%;
	padding: 0;
	margin: 0;
	border: 1px solid var(--mm-rule);
	border-radius: var(--mm-radius-lg);
	overflow: hidden;
	aspect-ratio: 9 / 16;
	background: var(--mm-ink);
	cursor: pointer;
	box-shadow: var(--mm-shadow-offset-orange);
	transition: transform var(--mm-duration) var(--mm-ease);
}
.mm-vidtest__open:hover {
	transform: translateY(-2px);
}
.mm-vidtest__open:focus-visible {
	outline: 2px solid var(--mm-orange);
	outline-offset: 3px;
}

.mm-vidtest__video {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.mm-vidtest__play {
	position: absolute;
	left: 50%;
	bottom: 14px;
	transform: translateX(-50%);
	width: 44px;
	height: 44px;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--mm-ink);
	background: rgba(244, 239, 230, 0.92);
	border-radius: var(--mm-radius-full);
	box-shadow: var(--mm-shadow-md);
	opacity: 0;
	transition: opacity var(--mm-duration) var(--mm-ease), background var(--mm-duration) var(--mm-ease);
	pointer-events: none;
}
.mm-vidtest__play svg {
	margin-left: 2px;
}
.mm-vidtest__open:hover .mm-vidtest__play,
.mm-vidtest__open:focus-visible .mm-vidtest__play,
.mm-vidtest--static .mm-vidtest__play {
	opacity: 1;
}

.mm-vidtest__meta {
	display: flex;
	flex-direction: column;
	gap: 2px;
}
.mm-vidtest__name {
	font-weight: 700;
	color: var(--mm-ink);
	font-size: var(--mm-text-sm);
	line-height: 1.25;
}
.mm-vidtest__role {
	font-family: var(--mm-font-mono);
	font-size: 11px;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--mm-muted);
}

@media (max-width: 1024px) {
	.mm-vidtest__card { flex-basis: calc((100% - 2 * var(--mm-sp-6)) / 3); } /* 3 per view */
}

@media (max-width: 700px) {
	.mm-vidtest {
		gap: var(--mm-sp-4);
		scroll-snap-type: x mandatory;
		/* bleed to the screen edges on phones */
		margin-inline: calc(-1 * var(--mm-gutter));
		padding-inline: var(--mm-gutter);
	}
	.mm-vidtest__card { flex-basis: 72%; } /* one card + a peek of the next */
}

@media (prefers-reduced-motion: reduce) {
	.mm-vidtest__open { transition: none; }
	.mm-vidtest__open:hover { transform: none; }
	.mm-vidtest__play { opacity: 1; }
}
