/**
 * MisePress frontend styles.
 * - All values use CSS variables prefixed --mp- so they can be overridden by your theme or Automatic.css.
 * - Class names use BEM with `misepress__*` and follow ACSS-friendly conventions
 *   (e.g. they coexist nicely with `section-content`, `text-h2`, `text-body` utility classes).
 */

:root {
	--mp-color-bg: #fffdf8;
	--mp-color-fg: #1a1a1a;
	--mp-color-muted: #6b6b6b;
	--mp-color-accent: #c2410c;
	--mp-color-accent-soft: #fde7d3;
	--mp-color-border: #ececec;
	--mp-color-allergen-bg: #fff1ed;
	--mp-color-allergen-fg: #b1380b;
	--mp-radius: 12px;
	--mp-radius-sm: 6px;
	--mp-space-1: 0.5rem;
	--mp-space-2: 1rem;
	--mp-space-3: 1.5rem;
	--mp-space-4: 2rem;
	--mp-font-display: var(--font-primary, "Playfair Display", Georgia, "Iowan Old Style", serif);
	--mp-font-body: var(--font-secondary, system-ui, sans-serif);
	--mp-shadow-xs: 0 1px 2px rgba(0,0,0,0.06);
	--mp-shadow-sm: 0 2px 8px -2px rgba(0,0,0,0.08);
	--mp-shadow-md: 0 6px 18px -6px rgba(0,0,0,0.14);
	--mp-shadow-lg: 0 16px 36px -12px rgba(0,0,0,0.20);
	--mp-shadow: var(--mp-shadow-md);
	/* Unified focus ring — keyboard accessible, brand-tinted. */
	--mp-focus-ring: 0 0 0 3px color-mix(in srgb, var(--mp-color-accent) 35%, transparent);
	--mp-transition: 180ms cubic-bezier(.2,.7,.2,1);
}

/* Unified focus-visible ring for every interactive MisePress control. */
.misepress :focus-visible,
.misepress__btn:focus-visible,
.misepress__chip:focus-visible,
.misepress__save-btn:focus-visible,
.misepress__density-btn:focus-visible,
.misepress__filter-form input:focus-visible,
.misepress__filter-form select:focus-visible,
.misepress__filter-form textarea:focus-visible {
	outline: none;
	box-shadow: var(--mp-focus-ring);
	border-radius: var(--mp-radius-sm);
}

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

.misepress { font-family: var(--mp-font-body); color: var(--mp-color-fg); line-height: 1.55; }
.misepress__title,
.misepress__menu-title,
.misepress__archive-title { font-family: var(--mp-font-display); line-height: 1.15; margin: 0 0 var(--mp-space-2); }

.misepress__recipe { display: grid; gap: var(--mp-space-3); padding: var(--mp-space-3); background: var(--mp-color-bg); border-radius: var(--mp-radius); box-shadow: var(--mp-shadow); }
.misepress__media img { width: 100%; height: auto; border-radius: var(--mp-radius-sm); display: block; }

.misepress__meta { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: var(--mp-space-2); border-top: 1px solid var(--mp-color-border); border-bottom: 1px solid var(--mp-color-border); padding-block: var(--mp-space-2); }
.misepress__meta-item { display: flex; flex-direction: column; min-width: 90px; }
.misepress__meta-label { font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.06em; color: var(--mp-color-muted); }
.misepress__meta-value { font-weight: 600; }

.misepress__heading { font-family: var(--mp-font-display); font-size: 1.5rem; margin: 0 0 var(--mp-space-2); }

.misepress__ingredients,
.misepress__steps,
.misepress__allergens { padding-left: 1.25rem; margin: 0; }
.misepress__steps { display: grid; gap: var(--mp-space-2); }
.misepress__step { padding-left: var(--mp-space-1); }

.misepress__allergens { list-style: none; padding-left: 0; display: flex; flex-wrap: wrap; gap: var(--mp-space-1); }
.misepress__allergen { background: var(--mp-color-allergen-bg); color: var(--mp-color-allergen-fg); border-radius: 999px; padding: 0.25rem 0.75rem; font-size: 0.85rem; font-weight: 500; }

.misepress__notes { color: var(--mp-color-muted); font-style: italic; }

/* Dish */
.misepress__dish { display: grid; gap: var(--mp-space-1); padding: var(--mp-space-2) 0; border-bottom: 1px dashed var(--mp-color-border); }
.misepress__dish-header { display: flex; justify-content: space-between; align-items: baseline; gap: var(--mp-space-2); }
.misepress__price { font-weight: 700; color: var(--mp-color-accent); }
.misepress__dish-desc { color: var(--mp-color-muted); margin: 0; }
.misepress__diet-tags { list-style: none; padding: 0; margin: 0; display: flex; gap: 0.25rem; flex-wrap: wrap; }
.misepress__diet-tag { font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.05em; padding: 0.15rem 0.5rem; border-radius: var(--mp-radius-sm); background: var(--mp-color-accent-soft); color: var(--mp-color-accent); }

/* Menu */
.misepress__menu { display: grid; gap: var(--mp-space-3); }
.misepress__menu-section { display: grid; gap: var(--mp-space-2); }
.misepress__menu-section-title { font-family: var(--mp-font-display); font-size: 1.25rem; border-bottom: 2px solid var(--mp-color-accent); padding-bottom: var(--mp-space-1); margin: 0; }
.misepress__menu-items { list-style: none; padding: 0; margin: 0; display: grid; gap: var(--mp-space-2); }
.misepress__menu-item-row { display: grid; grid-template-columns: auto 1fr auto; gap: 0.5rem; align-items: end; }
.misepress__menu-item-name { font-weight: 600; }
.misepress__menu-item-dots { border-bottom: 1px dotted var(--mp-color-muted); margin-bottom: 0.4em; }
.misepress__menu-item-price { font-weight: 700; color: var(--mp-color-accent); }
.misepress__menu-item-desc { color: var(--mp-color-muted); margin: 0; font-size: 0.9rem; }

/* Archive */
.misepress__grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: var(--mp-space-3); }
/* Legacy grid-card stub — fully defined in the unified card system below. */
.misepress__grid-card a { color: inherit; text-decoration: none; }

.misepress--error { padding: var(--mp-space-2); border: 1px dashed var(--mp-color-border); color: var(--mp-color-muted); border-radius: var(--mp-radius-sm); }

/* =========================================================================
   Page wrappers — give recipe / dish / menu singles proper container,
   breathing room, and a max content width so they don't squash against a
   sidebar nav or stretch edge-to-edge on wide screens.
   ========================================================================= */
.misepress-page { display: block; width: 100%; padding: clamp(1.25rem, 3vw, 3rem) clamp(1rem, 4vw, 3rem); }
.misepress-page__inner { max-width: var(--mp-page-max-w, 1140px); margin-inline: auto; }
.misepress-page__inner--narrow { max-width: 820px; }

/* Recipe single — responsive 2-col layout (instructions main, sidebar aside) */
.misepress__recipe { display: grid; gap: var(--mp-space-3); padding: var(--mp-space-3); background: var(--mp-color-bg); border-radius: var(--mp-radius); box-shadow: var(--mp-shadow); }
.misepress__recipe .misepress__title { font-size: clamp(1.75rem, 3vw, 2.75rem); margin-bottom: var(--mp-space-2); }
.misepress__excerpt { color: var(--mp-color-muted); font-size: 1.125rem; margin: 0; max-width: 65ch; }

.misepress__body { display: grid; gap: var(--mp-space-4); grid-template-columns: 1fr; }
@media (min-width: 860px) {
	.misepress__body { grid-template-columns: minmax(240px, 320px) 1fr; align-items: start; }
	.misepress__aside { position: sticky; top: var(--mp-space-3); display: grid; gap: var(--mp-space-3); }
}
.misepress__main { display: grid; gap: var(--mp-space-4); min-width: 0; }
.misepress__section { margin: 0; }

.misepress__steps { counter-reset: mp-step; list-style: none; padding: 0; }
.misepress__step { counter-increment: mp-step; position: relative; padding: var(--mp-space-2) var(--mp-space-2) var(--mp-space-2) calc(var(--mp-space-2) + 2rem + var(--mp-space-2)); background: color-mix(in srgb, var(--mp-color-accent-soft) 35%, transparent); border-radius: var(--mp-radius-sm); min-height: calc(2rem + var(--mp-space-2) * 2); }
.misepress__step::before { content: counter(mp-step); position: absolute; left: var(--mp-space-2); top: var(--mp-space-2); width: 2rem; height: 2rem; display: grid; place-items: center; background: var(--mp-color-accent); color: #fff; border-radius: 999px; font-weight: 700; font-size: 0.95rem; line-height: 1; }

/* Dark mode — body class only selects the active mode; variables are scoped to MisePress wrappers. */
body.misepress-theme-dark .misepress {
	--mp-color-bg: #161A20;
	--mp-color-fg: #F5F5F5;
	--mp-color-muted: #9AA4B2;
	--mp-color-border: #2A313A;
	--mp-color-allergen-bg: #2A313A;
	--mp-color-allergen-fg: var(--mp-color-accent);
	--mp-shadow: 0 6px 24px -8px rgba(0, 0, 0, 0.6);
}
body.misepress-theme-dark .misepress .misepress__step { background: color-mix(in srgb, var(--mp-color-accent) 18%, #1C2128); }

/* Dish single — hero treatment */
.misepress__dish--single { display: grid; gap: var(--mp-space-3); padding: var(--mp-space-4); background: var(--mp-color-bg); border-radius: var(--mp-radius); box-shadow: var(--mp-shadow); border-bottom: 0; }
.misepress__dish--single .misepress__title { font-size: clamp(2rem, 4vw, 3rem); }
.misepress__dish--single .misepress__dish-header { align-items: center; }
.misepress__dish--single .misepress__price { font-size: 1.5rem; }
.misepress__dish--single .misepress__dish-desc { font-size: 1.125rem; max-width: 65ch; }
.misepress__media--dish img { width: 100%; max-height: 420px; object-fit: cover; border-radius: var(--mp-radius-sm); display: block; }
.misepress__dish-body { color: var(--mp-color-fg); line-height: 1.6; }
.misepress__dish-body > * + * { margin-top: var(--mp-space-2); }

/* =========================================================================
   ========================================================================= */

/* Breadcrumbs */
.misepress__breadcrumbs { margin: 0 0 var(--mp-space-3); font-size: 0.9rem; color: var(--mp-color-muted); }
.misepress__breadcrumbs ol { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: 0.4rem; }
.misepress__breadcrumbs li + li::before { content: "›"; margin-right: 0.4rem; color: var(--mp-color-muted); }
.misepress__breadcrumbs a { color: inherit; text-decoration: none; border-bottom: 1px dotted currentColor; }
.misepress__breadcrumbs a:hover { color: var(--mp-color-accent); }
.misepress__breadcrumbs [aria-current="page"] { color: var(--mp-color-fg); font-weight: 500; }

/* Archive header */
.misepress__archive-header { margin-bottom: var(--mp-space-4); display: grid; gap: 0.4rem; }
.misepress__archive-header--with-toolbar { display: flex; align-items: flex-end; justify-content: space-between; gap: var(--mp-space-3); flex-wrap: wrap; }
.misepress__archive-header--with-toolbar .misepress__archive-header-text { display: grid; gap: 0.4rem; }
.misepress__archive-header-toolbar { display: inline-flex; align-items: center; gap: 0.5rem; }
.misepress__archive-header-toolbar label { display: inline-flex; align-items: center; gap: 0.4rem; font-size: 0.85rem; color: var(--mp-color-muted); }
.misepress__archive-header-toolbar select { padding: 0.4rem 0.6rem; border: 1px solid var(--mp-color-border); border-radius: var(--mp-radius-sm); background: var(--mp-color-bg); color: var(--mp-color-fg); font: inherit; font-size: 0.85rem; }
.misepress__archive-eyebrow { text-transform: uppercase; letter-spacing: 0.1em; font-size: 0.75rem; color: var(--mp-color-accent); margin: 0; font-weight: 600; }
.misepress__archive-title { font-size: clamp(2rem, 4vw, 3rem); margin: 0; }
.misepress__archive-sub { color: var(--mp-color-muted); margin: 0; }
.misepress__archive-desc { color: var(--mp-color-muted); max-width: 70ch; }

/* Layout: filters sidebar + grid */
.misepress__archive-layout { display: grid; gap: var(--mp-archive-filter-gap, var(--mp-space-4)); grid-template-columns: 1fr; padding-inline: var(--mp-archive-pad-x, 0); text-align: left; }
@media (min-width: 900px) {
  .misepress__archive--filters-sidebar-left  .misepress__archive-layout {
    grid-template-columns: var(--mp-filter-width, 240px) minmax(0, 1fr);
    align-items: start;
  }
  .misepress__archive--filters-sidebar-right .misepress__archive-layout {
    grid-template-columns: minmax(0, 1fr) var(--mp-filter-width, 240px);
    align-items: start;
  }
  .misepress__archive--filters-sidebar-right .misepress__archive-layout > .misepress__filters { grid-column: 2; }
  .misepress__archive--filters-sidebar-right .misepress__archive-layout > .misepress__archive-results { grid-column: 1; grid-row: 1; }
  .mp-filter-sticky.misepress__archive--filters-sidebar-left  .misepress__filters,
  .mp-filter-sticky.misepress__archive--filters-sidebar-right .misepress__filters { position: sticky; top: var(--mp-space-3); }
}
/* Filters above results — full width, collapsible on desktop too */
.misepress__archive--filters-top .misepress__archive-layout { grid-template-columns: 1fr; gap: var(--mp-space-3); }
.misepress__archive--filters-top .misepress__filters {
	position: static;
	padding: var(--mp-space-3);
	background: var(--mp-filter-bg, color-mix(in srgb, var(--mp-color-fg) 3%, transparent));
	border: 1px solid var(--mp-color-border);
	border-radius: var(--mp-radius);
	max-height: none !important;
	overflow: visible !important;
}
.misepress__archive--filters-top .misepress__filter-form {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: var(--mp-space-3);
}
.misepress__archive--filters-top .misepress__filter-group { padding-bottom: 0; border-bottom: 0; }
@media (min-width: 900px) {
	.misepress__archive--filters-top .misepress__filters > .misepress__filter-form { display: none; }
	.misepress__archive--filters-top.misepress__archive--filters-top-open .misepress__filters > .misepress__filter-form {
		display: grid;
	}
	.misepress__archive--filters-top .misepress__filter-trigger { display: inline-flex !important; position: static; margin-bottom: var(--mp-space-2); }
}

/* Filters as a horizontal bar — single-row pill toolbar, no inner scroll. Long lists open in popovers,
   any extras collapse behind a single "More filters" button (no horizontal scroll). */
.misepress__archive--filters-top-bar .misepress__archive-layout { grid-template-columns: 1fr; }
.misepress__archive--filters-top-bar .misepress__filters {
	position: static;
	padding: 0.5rem 0.75rem;
	border-radius: var(--mp-radius);
	background: var(--mp-filter-bg, color-mix(in srgb, var(--mp-color-fg) 3%, transparent));
	border: 1px solid var(--mp-color-border);
	box-shadow: none;
	max-height: none !important;
	overflow: visible !important;
}
.misepress__archive--filters-top-bar .misepress__filter-mobile-bar,
.misepress__archive--filters-top-bar .misepress__filter-header,
.misepress__archive--filters-top-bar .misepress__filter-mobile-actions { display: none !important; }
.misepress__archive--filters-top-bar .misepress__filter-form {
	display: flex; flex-wrap: wrap; align-items: center; gap: .5rem;
}
.misepress__archive--filters-top-bar .misepress__filter-group {
	border: 0; padding: 0; margin: 0;
	min-width: 0; flex: 0 0 auto;
	border-bottom: 0;
}
.misepress__archive--filters-top-bar .misepress__filter-group:not(details) { display: inline-flex; align-items: center; gap: .35rem; }
.misepress__archive--filters-top-bar .misepress__filter-group .misepress__filter-label { display: none; }
.misepress__archive--filters-top-bar .misepress__filter-group input[type="search"],
.misepress__archive--filters-top-bar .misepress__filter-group input[type="number"],
.misepress__archive--filters-top-bar .misepress__filter-group select {
	min-height: 38px; padding: 0 .85rem;
	border: 1px solid var(--mp-color-border);
	border-radius: 999px;
	background: var(--mp-color-bg);
}
.misepress__archive--filters-top-bar details.misepress__filter-group { position: relative; }
.misepress__archive--filters-top-bar details.misepress__filter-group > summary {
	cursor: pointer; list-style: none;
	display: inline-flex; align-items: center; gap: .35rem;
	padding: .5rem 1rem;
	border: 1px solid var(--mp-color-border);
	border-radius: 999px;
	background: var(--mp-color-bg);
	color: var(--mp-color-fg);
	font-weight: 500; font-size: .9rem;
	transition: border-color .15s ease, background .15s ease;
}
.misepress__archive--filters-top-bar details.misepress__filter-group > summary:hover {
	border-color: var(--mp-color-accent);
}
.misepress__archive--filters-top-bar details.misepress__filter-group > summary::-webkit-details-marker { display: none; }
.misepress__archive--filters-top-bar details.misepress__filter-group > summary::after {
	content: "▾"; font-size: .7em; opacity: .65; margin-left: .25rem;
}
.misepress__archive--filters-top-bar details.misepress__filter-group[open] > summary {
	background: var(--mp-color-accent-soft);
	border-color: var(--mp-color-accent);
	color: var(--mp-color-accent);
}
.misepress__archive--filters-top-bar details.misepress__filter-group[open] > :not(summary) {
	position: absolute; top: calc(100% + .4rem); left: 0; z-index: 30;
	min-width: 240px; max-width: 320px;
	max-height: 60vh; overflow-y: auto;
	padding: .75rem;
	background: var(--mp-color-bg);
	border: 1px solid var(--mp-color-border);
	border-radius: var(--mp-radius);
	box-shadow: var(--mp-shadow-md);
}
/* Hide overflow groups behind a "More filters" toggle handled in JS — until JS runs we keep
   them visible so the bar still works. */
.misepress__archive--filters-top-bar .misepress__filter-group.is-mp-overflow { display: none; }
.misepress__archive--filters-top-bar.is-mp-bar-expanded .misepress__filter-group.is-mp-overflow { display: inline-flex; }
.misepress__filter-bar-more {
	display: none;
	cursor: pointer;
	padding: .5rem 1rem;
	border: 1px solid var(--mp-color-border);
	border-radius: 999px;
	background: var(--mp-color-bg);
	color: var(--mp-color-fg);
	font-weight: 500; font-size: .9rem;
}
.misepress__archive--filters-top-bar .misepress__filter-bar-more.is-active { display: inline-flex; align-items: center; gap: .35rem; }
.misepress__archive--filters-top-bar .misepress__filter-bar-more:hover { border-color: var(--mp-color-accent); }


.misepress__archive-results { min-width: 0; text-align: left; }
.misepress__archive-layout > .misepress__filters,
.misepress__archive-layout > .misepress__archive-results { align-self: start; margin-top: 0; padding-top: 0; }
.misepress__filters { padding-top: var(--mp-space-2); }
.misepress__results-toolbar { display: flex !important; align-items: center; justify-content: space-between; gap: 0.75rem; margin: 0 0 var(--mp-space-3); flex-wrap: wrap; text-align: left; min-height: 2.25rem; }
.misepress__results-toolbar > * { margin: 0; }
.misepress__results-toolbar label { display: inline-flex; align-items: center; gap: 0.4rem; font-size: 0.85rem; color: var(--mp-color-muted); }
.misepress__results-toolbar select { padding: 0.4rem 0.6rem; border: 1px solid var(--mp-color-border); border-radius: var(--mp-radius-sm); background: var(--mp-color-bg); color: var(--mp-color-fg); font: inherit; font-size: 0.85rem; }
.misepress__archive--editorial .misepress__editorial { margin: 0; }

/* Filters */
.misepress__filters { background: color-mix(in srgb, var(--mp-color-fg) 4%, transparent); border: 1px solid var(--mp-color-border); border-radius: var(--mp-radius); padding: var(--mp-space-2); min-width: 0; max-width: 100%; overflow-x: hidden; box-sizing: border-box; }
.misepress__filter-form, .misepress__filter-group, .misepress__filter-opts { min-width: 0; max-width: 100%; box-sizing: border-box; }
.misepress__filter-opt { min-width: 0; max-width: 100%; word-break: break-word; }
.misepress__filter-opt span { min-width: 0; word-break: break-word; }
.misepress__filter-opt[data-mp-hidden="1"] { display: none !important; }
.misepress__filter-loadmore { margin-top: 0.4rem; background: none; border: 0; color: var(--mp-color-accent, #e85d2a); cursor: pointer; font: inherit; font-size: 0.85rem; padding: 0.25rem 0; text-align: left; }
.misepress__filter-group--auto .misepress__filter-opts { max-height: none !important; overflow: visible !important; }
.misepress__filter-form { display: grid; gap: var(--mp-space-2); }
.misepress__filter-header { display: flex; justify-content: space-between; align-items: center; }
.misepress__filter-title { font-family: var(--mp-font-display); margin: 0; font-size: 1.1rem; }
.misepress__filter-reset { background: none; border: 0; color: var(--mp-color-accent); font-size: 0.85rem; cursor: pointer; padding: 0.2rem 0.5rem; border-radius: var(--mp-radius-sm); }
.misepress__filter-reset[hidden],
.misepress__filter-mobile-reset[hidden] { display: none !important; }
.misepress__filter-reset:hover { background: var(--mp-color-accent-soft); }
.misepress__filter-group { display: grid; gap: 0.4rem; padding-bottom: 0.6rem; border-bottom: 1px solid var(--mp-color-border); }
.misepress__filter-group:last-child { border-bottom: 0; }
.misepress__filter-label { font-size: 0.8rem; text-transform: uppercase; letter-spacing: 0.06em; color: var(--mp-color-muted); font-weight: 600; }
.misepress__filter-form input[type="search"],
.misepress__filter-form input[type="text"],
.misepress__filter-form input[type="number"],
.misepress__filter-form select { width: 100%; max-width: 100%; box-sizing: border-box; padding: 0.5rem 0.7rem; border: 1px solid var(--mp-color-border); border-radius: var(--mp-radius-sm); background: var(--mp-color-bg); color: var(--mp-color-fg); font: inherit; }
.misepress__filter-form input:focus,
.misepress__filter-form select:focus { outline: 2px solid var(--mp-color-accent); outline-offset: 1px; }
.misepress__filter-group summary { cursor: pointer; font-weight: 600; padding: 0.3rem 0; list-style: none; display: flex; align-items: center; gap: 0.4rem; }
.misepress__filter-group summary::-webkit-details-marker { display: none; }
.misepress__filter-group summary::before { content: "▸"; font-size: 0.7em; transition: transform 0.15s; color: var(--mp-color-muted); }
.misepress__filter-group[open] summary::before { transform: rotate(90deg); }
.misepress__filter-opts { display: grid; gap: 0.25rem; max-height: var(--mp-filter-opts-max, none); overflow-y: auto; overflow-x: hidden; padding-right: 0.3rem; min-width: 0; max-width: 100%; }
.misepress__filter-opt { display: flex; align-items: center; gap: 0.45rem; font-size: 0.9rem; cursor: pointer; padding: 0.2rem 0; }
.misepress__filter-opt span { flex: 1; }
.misepress__filter-opt em { font-style: normal; color: var(--mp-color-muted); font-size: 0.8rem; }
.misepress__filter-opt input[type="checkbox"] { accent-color: var(--mp-color-accent); }

/* Buttons */
.misepress__btn { display: inline-flex; align-items: center; gap: 0.4rem; padding: 0.65rem 1.15rem; border-radius: var(--mp-radius-sm); font: inherit; font-weight: 600; cursor: pointer; border: 1px solid transparent; transition: background var(--mp-transition), border-color var(--mp-transition), color var(--mp-transition), transform 80ms ease, box-shadow var(--mp-transition); will-change: transform; }
.misepress__btn:active:not(:disabled) { transform: translateY(1px) scale(0.99); }
.misepress__btn:disabled, .misepress__btn[aria-disabled="true"] { opacity: 0.55; cursor: not-allowed; transform: none; }
.misepress__btn--primary { background: var(--mp-color-accent); color: #fff; box-shadow: var(--mp-shadow-xs); }
.misepress__btn--primary:hover { background: color-mix(in srgb, var(--mp-color-accent) 90%, #000); box-shadow: var(--mp-shadow-sm); }
.misepress__btn--ghost { background: transparent; color: var(--mp-color-fg); border-color: var(--mp-color-border); }
.misepress__btn--ghost:hover { border-color: var(--mp-color-accent); color: var(--mp-color-accent); background: var(--mp-color-accent-soft); }

/* =========================================================================
   - Consistent 4:3 ratio
   - Unified spacing (var(--mp-space-2))
   - Cohesive hover (lift + soft glow + image zoom)
   - Typography rhythm: title → excerpt → meta → badges
   ========================================================================= */
.misepress__grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: var(--mp-space-3); }
.misepress__grid-card {
	position: relative;
	background: var(--mp-color-bg);
	border: 1px solid var(--mp-color-border);
	border-radius: var(--mp-radius);
	overflow: hidden;
	box-shadow: 0 1px 2px rgba(0,0,0,0.04);
	display: flex;
	flex-direction: column;
	transition: transform .25s cubic-bezier(.2,.7,.2,1), box-shadow .25s, border-color .25s;
}
.misepress__grid-card:hover {
	transform: translateY(-3px);
	box-shadow: 0 18px 40px -18px rgba(0,0,0,0.28);
	border-color: color-mix(in srgb, var(--mp-color-accent) 30%, var(--mp-color-border));
}
.misepress__grid-link { display: flex; flex-direction: column; height: 100%; color: inherit; text-decoration: none; }
.misepress__grid-media {
	aspect-ratio: 4/3;
	overflow: hidden;
	background: color-mix(in srgb, var(--mp-color-accent) 10%, var(--mp-color-bg));
	position: relative;
}
.misepress__grid-media img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .5s cubic-bezier(.2,.7,.2,1); }
.misepress__grid-card:hover .misepress__grid-media img { transform: scale(1.05); }
.misepress__grid-media--empty::after {
	content: ""; position: absolute; inset: 0;
	background: repeating-linear-gradient(45deg, transparent 0 12px, rgba(0,0,0,0.025) 12px 13px);
}
.misepress__grid-body {
	padding: var(--mp-space-2);
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	flex: 1;
}
.misepress__grid-title {
	margin: 0;
	font-family: var(--mp-font-display);
	font-size: 1.2rem;
	line-height: 1.25;
	font-weight: 600;
	letter-spacing: -0.01em;
	color: var(--mp-color-fg);
}
.misepress__grid-card:hover .misepress__grid-title { color: var(--mp-color-accent); }
.misepress__grid-excerpt {
	margin: 0;
	color: var(--mp-color-muted);
	font-size: 0.9rem;
	line-height: 1.5;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.misepress__grid-meta {
	list-style: none; padding: 0;
	margin: auto 0 0;
	display: flex; flex-wrap: wrap; gap: 0.6rem;
	font-size: 0.78rem;
	color: var(--mp-color-muted);
	padding-top: 0.4rem;
	border-top: 1px solid var(--mp-color-border);
}
.misepress__grid-meta li { display: inline-flex; align-items: center; gap: 0.3rem; }
.misepress__grid-allergens {
	list-style: none; padding: 0; margin: 0;
	display: flex; flex-wrap: wrap; gap: 0.3rem;
}

/* Grid card nutrition strip */
.misepress__grid-nut {
	list-style: none; padding: 0.5rem 0 0; margin: 0.5rem 0 0;
	display: grid; grid-template-columns: repeat(4, 1fr); gap: 0.4rem;
	border-top: 1px solid var(--mp-color-border);
}
.misepress__grid-nut-item {
	display: flex; flex-direction: column; align-items: center; justify-content: center;
	text-align: center; line-height: 1.15;
	padding: 0.35rem 0.2rem;
	border-radius: 8px;
	background: var(--mp-color-soft, rgba(0,0,0,0.03));
}
.misepress__grid-nut-item strong { font-size: 0.85rem; font-weight: 700; color: var(--mp-color-text, inherit); }
.misepress__grid-nut-item span { font-size: 0.65rem; text-transform: uppercase; letter-spacing: 0.04em; color: var(--mp-color-muted); margin-top: 2px; }
.misepress__grid-nut-item--kcal { background: color-mix(in srgb, var(--mp-color-accent, #d97706) 12%, transparent); }
.misepress__grid-nut-item--kcal strong { color: var(--mp-color-accent, #d97706); }
.misepress__grid-nut-item--p strong { color: #2563eb; }
.misepress__grid-nut-item--c strong { color: #16a34a; }
.misepress__grid-nut-item--f strong { color: #ea580c; }
.misepress__allergen-badge { width: 28px; height: 28px; display: inline-grid; place-items: center; border-radius: 50%; background: var(--mp-color-allergen-bg); color: var(--mp-color-allergen-fg); }
.mp-allergen-icon { width: 16px; height: 16px; }
.misepress__allergen { display: inline-flex; align-items: center; gap: 0.4rem; }
.misepress__allergen .mp-allergen-icon { width: 14px; height: 14px; }
.misepress__allergen a { color: inherit; text-decoration: none; border-bottom: 1px dotted currentColor; }

/* Load more / loading state */
.misepress__load-more-wrap { display: flex; justify-content: center; margin-top: var(--mp-space-4); }
.misepress__archive-results.is-loading { opacity: 0.5; pointer-events: none; transition: opacity 0.15s; }
.misepress__no-results { padding: var(--mp-space-3); text-align: center; color: var(--mp-color-muted); border: 1px dashed var(--mp-color-border); border-radius: var(--mp-radius); }

/* Related terms */
.misepress__related-terms { margin-top: var(--mp-space-4); padding-top: var(--mp-space-3); border-top: 1px solid var(--mp-color-border); }
.misepress__related-title { font-family: var(--mp-font-display); font-size: 1.25rem; margin: 0 0 var(--mp-space-2); }
.misepress__related-list { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: 0.5rem; }
.misepress__related-list a { display: inline-flex; align-items: center; gap: 0.3rem; padding: 0.35rem 0.75rem; border-radius: 999px; background: var(--mp-color-accent-soft); color: var(--mp-color-accent); text-decoration: none; font-size: 0.85rem; font-weight: 500; }
.misepress__related-list em { font-style: normal; opacity: 0.7; font-size: 0.75rem; }

/* Single recipe — title row with print button */
.misepress__title-row { display: flex; justify-content: space-between; align-items: flex-start; gap: var(--mp-space-2); flex-wrap: wrap; }
.misepress__print-btn { flex-shrink: 0; }

/* Print */
@media print {
  .no-print, .misepress__breadcrumbs, .misepress__filters, .misepress__load-more-wrap,
  header[role="banner"], .site-header, .site-footer, footer[role="contentinfo"], nav, aside.widget-area { display: none !important; }
  body { background: #fff !important; color: #000 !important; font-size: 11pt; }
  .misepress, .misepress * { background: transparent !important; color: #000 !important; box-shadow: none !important; border-color: #ccc !important; }
  .misepress__recipe { padding: 0; box-shadow: none; }
  .misepress__media img { max-height: 280px; object-fit: cover; }
  .misepress__body { display: block !important; }
  .misepress__aside { float: right; width: 38%; margin: 0 0 1rem 1rem; padding: 0.5rem 0.75rem; border: 1px solid #ddd !important; border-radius: 4px; }
  .misepress__main { display: block !important; }
  .misepress__step { background: transparent !important; padding-left: 2.4rem !important; min-height: 0 !important; }
  .misepress__step::before { background: #000 !important; color: #fff !important; }
  .misepress__title { font-size: 22pt; }
  .misepress__heading { font-size: 13pt; margin-top: 1rem; border-bottom: 1px solid #999; padding-bottom: 0.2rem; }
  .misepress__allergen-badge { background: #fff !important; border: 1px solid #999 !important; }
  a { color: #000 !important; text-decoration: none !important; }
  a[href^="http"]::after { content: " (" attr(href) ")"; font-size: 8pt; color: #555 !important; }
  /* Print URL footer */
  .misepress__recipe::after { content: "Printed from " attr(data-url); display: block; margin-top: 1rem; padding-top: 0.5rem; border-top: 1px solid #ccc; font-size: 8pt; color: #555 !important; }
}

/* Onboarding */
.misepress-onboard { max-width: 800px; }
.mp-onboard-card { background: var(--mp-card-bg, #fff); border-radius: 12px; padding: 2rem; box-shadow: 0 10px 30px -10px rgba(0,0,0,0.15); margin-top: 1rem; }
.mp-onboard-head h1 { font-size: 2rem; margin: 0 0 0.5rem; }
.mp-onboard-head .mp-tagline { color: var(--mp-color-muted, #666); margin: 0 0 1.5rem; }
.mp-onboard-form h2 { font-size: 1.1rem; margin: 1.5rem 0 0.75rem; }
.mp-onboard-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 0.75rem; }
.mp-onboard-choice { display: flex; gap: 0.75rem; padding: 1rem; border: 2px solid #e5e5e5; border-radius: 10px; cursor: pointer; transition: border-color 0.15s, background 0.15s; }
.mp-onboard-choice:hover { border-color: #c2410c; }
.mp-onboard-choice input[type="checkbox"] { margin-top: 0.2rem; accent-color: #c2410c; }
.mp-onboard-choice:has(input:checked) { border-color: #c2410c; background: #fff5ed; }
.mp-onboard-choice-body { display: grid; gap: 0.2rem; }
.mp-onboard-choice strong { font-size: 0.95rem; }
.mp-onboard-choice small { color: #666; font-size: 0.8rem; line-height: 1.4; }
.mp-onboard-choice--single { max-width: 100%; }
.mp-onboard-actions { display: flex; align-items: center; gap: 1rem; margin-top: 2rem; }
.mp-skip { color: #888; text-decoration: none; }
.mp-skip:hover { color: #c2410c; }

/* =========================================================================
   skeletons, save button, recently viewed, email capture
   ========================================================================= */

:root {
	/* Spacing scale (4-pt) */
	--mp-s-1: 0.25rem;
	--mp-s-2: 0.5rem;
	--mp-s-3: 0.75rem;
	--mp-s-4: 1rem;
	--mp-s-5: 1.5rem;
	--mp-s-6: 2rem;
	--mp-s-7: 3rem;
	--mp-s-8: 4rem;

	/* Shadows */
	--mp-shadow-xs: 0 1px 2px rgba(15, 23, 42, 0.06);
	--mp-shadow-sm: 0 2px 8px -2px rgba(15, 23, 42, 0.08);
	--mp-shadow-md: 0 8px 24px -8px rgba(15, 23, 42, 0.12);
	--mp-shadow-lg: 0 20px 40px -16px rgba(15, 23, 42, 0.18);
	--mp-shadow-glow: 0 8px 24px -8px color-mix(in srgb, var(--mp-color-accent) 40%, transparent);

	/* Type scale */
	--mp-text-xs: 0.75rem;
	--mp-text-sm: 0.875rem;
	--mp-text-base: 1rem;
	--mp-text-md: 1.125rem;
	--mp-text-lg: 1.375rem;
	--mp-text-xl: 1.75rem;
	--mp-text-2xl: 2.25rem;
	--mp-text-3xl: clamp(2.25rem, 4vw, 3.5rem);
}
body.misepress-theme-dark .misepress {
	--mp-shadow-xs: 0 1px 2px rgba(0, 0, 0, 0.4);
	--mp-shadow-sm: 0 2px 8px -2px rgba(0, 0, 0, 0.5);
	--mp-shadow-md: 0 8px 24px -8px rgba(0, 0, 0, 0.55);
	--mp-shadow-lg: 0 20px 40px -16px rgba(0, 0, 0, 0.7);
}

/* Typography hierarchy refinements */
.misepress h1, .misepress h2, .misepress h3, .misepress h4 { letter-spacing: -0.01em; }
.misepress h2 { font-size: var(--mp-text-xl); }
.misepress h3 { font-size: var(--mp-text-lg); }
.misepress p  { line-height: 1.65; }

/* ----- Skeleton loading ----- */
@keyframes mp-shimmer { 0% { background-position: -400px 0; } 100% { background-position: 400px 0; } }
.misepress__skeleton {
	background: linear-gradient(90deg, color-mix(in srgb, var(--mp-color-fg) 6%, transparent) 25%, color-mix(in srgb, var(--mp-color-fg) 12%, transparent) 50%, color-mix(in srgb, var(--mp-color-fg) 6%, transparent) 75%);
	background-size: 800px 100%;
	animation: mp-shimmer 1.4s infinite linear;
	border-radius: var(--mp-radius-sm);
}
.misepress__skeleton--media { aspect-ratio: 4/3; width: 100%; border-radius: var(--mp-radius); margin-bottom: var(--mp-s-3); }
.misepress__skeleton--line { height: 0.85rem; margin-top: var(--mp-s-2); }
.misepress__skeleton--line-lg { height: 1.25rem; width: 80%; }
.misepress__skeleton--line-sm { width: 50%; }
.misepress__skeleton-card { padding: var(--mp-s-4); border: 1px solid var(--mp-color-border); border-radius: var(--mp-radius); background: var(--mp-color-bg); }
.misepress__grid--skeleton { opacity: 0.85; }

.misepress__fade-in { animation: mp-fade-in 0.35s ease both; }
@keyframes mp-fade-in { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }

/* ----- Save (heart) button ----- */
.misepress__grid-card { position: relative; }
.misepress__save-btn {
	position: absolute; top: 10px; right: 10px;
	z-index: 2; width: 38px; height: 38px;
	display: inline-grid; place-items: center;
	border: 0; border-radius: 999px; cursor: pointer;
	background: rgba(255,255,255,0.95); color: #555;
	box-shadow: 0 2px 10px rgba(0,0,0,0.12);
	backdrop-filter: blur(8px);
	transition: color .2s, transform .2s, background .2s, box-shadow .2s;
}
.misepress__save-btn:hover {
	color: var(--mp-color-accent);
	transform: scale(1.08);
	box-shadow: 0 4px 16px rgba(0,0,0,0.18);
}
.misepress__save-btn:focus-visible { outline: 2px solid var(--mp-color-accent); outline-offset: 2px; }
.misepress__save-btn.is-saved {
	color: #fff;
	background: var(--mp-color-accent);
	box-shadow: 0 4px 14px rgba(194,65,12,0.35);
}
.misepress__save-btn.is-saved svg { animation: mp-heart-pop .4s cubic-bezier(.2,.7,.2,1.4); }
.misepress__save-btn.is-loading { opacity: .55; pointer-events: none; }
@keyframes mp-heart-pop {
	0% { transform: scale(1); }
	50% { transform: scale(1.35); }
	100% { transform: scale(1); }
}
.misepress__save-toast {
	position: fixed; bottom: 24px; left: 50%;
	transform: translateX(-50%) translateY(20px);
	background: #1a1a1a; color: #fff;
	padding: .65rem 1.1rem; border-radius: 999px;
	font-size: .85rem; font-weight: 500;
	box-shadow: 0 10px 30px rgba(0,0,0,.25);
	opacity: 0; pointer-events: none;
	transition: opacity .25s, transform .25s;
	z-index: 99999;
}
.misepress__save-toast.is-visible { opacity: 1; transform: translateX(-50%) translateY(0); }
body.misepress-theme-dark .misepress .misepress__save-btn { background: rgba(22,26,32,0.92); color: #c8c8c8; }

/* ----- List rows ----- */
.misepress__list { list-style: none; padding: 0; margin: 0; display: grid; gap: var(--mp-s-3); }
.misepress__row {
	display: grid; grid-template-columns: 1fr auto; align-items: stretch;
	background: var(--mp-color-bg); border: 1px solid var(--mp-color-border);
	border-radius: var(--mp-radius); overflow: hidden;
	box-shadow: var(--mp-shadow-xs); transition: box-shadow .15s, transform .1s;
}
.misepress__row:hover { box-shadow: var(--mp-shadow-md); }
.misepress__row-link { display: grid; grid-template-columns: 140px 1fr; gap: var(--mp-s-4); color: inherit; text-decoration: none; }
.misepress__row-media { width: 140px; aspect-ratio: 1; background: color-mix(in srgb, var(--mp-color-accent) 10%, var(--mp-color-bg)); }
.misepress__row-media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.misepress__row-body { padding: var(--mp-s-4) var(--mp-s-4) var(--mp-s-4) 0; display: grid; gap: var(--mp-s-2); align-content: center; min-width: 0; }
.misepress__row-title { margin: 0; font-family: var(--mp-font-display); font-size: var(--mp-text-lg); }
.misepress__row-excerpt { margin: 0; color: var(--mp-color-muted); font-size: var(--mp-text-sm); }
.misepress__row-meta { display: flex; gap: var(--mp-s-4); list-style: none; padding: 0; margin: 0; flex-wrap: wrap; font-size: var(--mp-text-xs); color: var(--mp-color-muted); }
.misepress__row-meta li { display: inline-flex; align-items: center; gap: 0.3rem; }
.misepress__row-headline { display: flex; justify-content: space-between; gap: var(--mp-s-3); align-items: baseline; }
.misepress__row .misepress__save-btn { position: static; align-self: center; margin-right: var(--mp-s-3); }
@media (max-width: 600px) {
	.misepress__row-link { grid-template-columns: 90px 1fr; }
	.misepress__row-media { width: 90px; }
}

/* ----- Editorial layout ----- */
.misepress__editorial {
	display: grid; gap: var(--mp-s-6);
	grid-template-columns: repeat(6, 1fr);
}
.misepress__editorial-card { grid-column: span 2; }
.misepress__editorial-card--hero    { grid-column: span 6; }
.misepress__editorial-card--feature { grid-column: span 3; }
@media (max-width: 900px) {
	.misepress__editorial { grid-template-columns: 1fr 1fr; }
	.misepress__editorial-card,
	.misepress__editorial-card--feature { grid-column: span 1; }
	.misepress__editorial-card--hero { grid-column: span 2; }
}
@media (max-width: 600px) {
	.misepress__editorial { grid-template-columns: 1fr; }
	.misepress__editorial-card,
	.misepress__editorial-card--feature,
	.misepress__editorial-card--hero { grid-column: span 1; }
}
.misepress__editorial-link { color: inherit; text-decoration: none; display: block; }
.misepress__editorial-media { aspect-ratio: 16/10; overflow: hidden; border-radius: var(--mp-radius); background: color-mix(in srgb, var(--mp-color-accent) 8%, var(--mp-color-bg)); margin-bottom: var(--mp-s-4); }
.misepress__editorial-media img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s; display: block; }
.misepress__editorial-card:hover .misepress__editorial-media img { transform: scale(1.03); }
.misepress__editorial-eyebrow { text-transform: uppercase; letter-spacing: 0.12em; font-size: var(--mp-text-xs); color: var(--mp-color-accent); font-weight: 700; margin: 0 0 var(--mp-s-2); }
.misepress__editorial-title { font-family: var(--mp-font-display); margin: 0 0 var(--mp-s-2); line-height: 1.15; font-size: var(--mp-text-lg); }
.misepress__editorial-card--hero .misepress__editorial-title    { font-size: clamp(1.75rem, 3.5vw, 2.75rem); }
.misepress__editorial-card--feature .misepress__editorial-title { font-size: var(--mp-text-xl); }
.misepress__editorial-excerpt { margin: 0 0 var(--mp-s-3); color: var(--mp-color-muted); font-size: var(--mp-text-sm); line-height: 1.55; }
.misepress__editorial-card--hero .misepress__editorial-excerpt { font-size: var(--mp-text-md); max-width: 60ch; }
.misepress__editorial-meta { font-size: var(--mp-text-xs); color: var(--mp-color-muted); margin: 0; }

/* ----- Restaurant menu style ----- */
.misepress__restaurant-stack { display: grid; gap: var(--mp-s-7); }
.misepress__menu--restaurant {
	background: var(--mp-color-bg);
	border: 1px solid var(--mp-color-border);
	border-radius: var(--mp-radius);
	padding: clamp(1.5rem, 4vw, 3rem);
	box-shadow: var(--mp-shadow-md);
}
.misepress__menu--restaurant .misepress__menu-header { text-align: center; padding-bottom: var(--mp-s-5); border-bottom: 2px solid var(--mp-color-accent); margin-bottom: var(--mp-s-6); }
.misepress__menu--restaurant .misepress__menu-title { font-family: var(--mp-font-display); font-size: var(--mp-text-2xl); margin: 0; letter-spacing: 0.02em; }
.misepress__menu-availability { color: var(--mp-color-muted); font-size: var(--mp-text-sm); margin: var(--mp-s-2) 0 0; }
.misepress__menu--restaurant .misepress__menu-section { margin-bottom: var(--mp-s-6); }
.misepress__menu--restaurant .misepress__menu-section-title { text-align: center; font-size: var(--mp-text-md); text-transform: uppercase; letter-spacing: 0.18em; border: 0; color: var(--mp-color-accent); padding-bottom: var(--mp-s-3); }
.misepress__menu-section-desc { color: var(--mp-color-muted); text-align: center; font-style: italic; margin: 0 auto var(--mp-s-4); max-width: 60ch; font-size: var(--mp-text-sm); }
.misepress__menu-variants { list-style: none; padding: 0; margin: var(--mp-s-2) 0 0; display: grid; gap: 0.25rem; padding-left: var(--mp-s-4); }
.misepress__menu-variant { display: flex; justify-content: space-between; gap: var(--mp-s-3); font-size: var(--mp-text-sm); color: var(--mp-color-muted); }
.misepress__menu-variant-price { font-variant-numeric: tabular-nums; color: var(--mp-color-fg); }
.misepress__menu-item-allergens { list-style: none; padding: 0; margin: var(--mp-s-2) 0 0; display: flex; gap: 0.3rem; flex-wrap: wrap; }

/* ----- Recently viewed strip ----- */
.misepress__recently {
	margin-bottom: var(--mp-s-6);
	padding: var(--mp-s-4) 0;
	border-top: 1px solid var(--mp-color-border);
	border-bottom: 1px solid var(--mp-color-border);
}
.misepress__recently-title { font-size: var(--mp-text-xs); text-transform: uppercase; letter-spacing: 0.12em; color: var(--mp-color-muted); margin: 0 0 var(--mp-s-3); font-weight: 700; }
.misepress__recently-list { list-style: none; padding: 0; margin: 0; display: flex; gap: var(--mp-s-3); overflow-x: auto; }
.misepress__recently-item { flex: 0 0 180px; }
.misepress__recently-item a { display: block; color: inherit; text-decoration: none; }
.misepress__recently-thumb { width: 100%; aspect-ratio: 4/3; object-fit: cover; border-radius: var(--mp-radius-sm); display: block; margin-bottom: 0.4rem; }
.misepress__recently-name { font-size: var(--mp-text-sm); margin: 0; }

/* ----- Email capture ----- */
.misepress__email-capture {
	margin-top: var(--mp-s-7);
	padding: var(--mp-s-6);
	background: var(--mp-color-accent-soft);
	border-radius: var(--mp-radius);
	display: grid; gap: var(--mp-s-3);
	box-shadow: var(--mp-shadow-sm);
}
.misepress__email-capture h3 { margin: 0; font-family: var(--mp-font-display); color: var(--mp-color-accent); }
.misepress__email-capture form { display: flex; gap: var(--mp-s-2); flex-wrap: wrap; }
.misepress__email-capture input[type="email"] { flex: 1 1 220px; padding: 0.7rem 1rem; border-radius: var(--mp-radius-sm); border: 1px solid var(--mp-color-border); background: #fff; }
body.misepress-theme-dark .misepress .misepress__email-capture input[type="email"] { background: var(--mp-color-bg); color: var(--mp-color-fg); }
.misepress__email-capture .misepress__email-msg { color: var(--mp-color-accent); font-size: var(--mp-text-sm); }

/* ----- Search input with icon ----- */
.misepress__search-input { position: relative; }
.misepress__search-icon { position: absolute; left: 0.75rem; top: 50%; transform: translateY(-50%); color: var(--mp-color-muted); pointer-events: none; }
.misepress__search-input input { padding-left: 2.25rem !important; font-size: var(--mp-text-sm, .875rem); }
.misepress__search-input input::placeholder { font-size: var(--mp-text-sm, .875rem); opacity: .7; }

/* ----- Smoother global transitions ----- */
.misepress__archive-results { transition: opacity .2s ease; }

.misepress__ingredients-head {
	display: flex; align-items: center; justify-content: space-between;
	gap: var(--mp-s-3); flex-wrap: wrap; margin-bottom: var(--mp-s-3);
}
.misepress__ingredients-head .misepress__heading { margin: 0; }

.misepress__scale-inline { display: inline-flex; gap: 0.25rem; align-items: center; padding: 2px; background: color-mix(in srgb, var(--mp-color-fg) 4%, transparent); border-radius: 999px; }
.misepress__scale-pill {
	border: 0; background: transparent; color: var(--mp-color-muted);
	font: inherit; font-size: var(--mp-text-xs); font-weight: 600;
	padding: 0.25rem 0.55rem; border-radius: 999px; cursor: pointer;
	min-width: 2rem; line-height: 1; transition: background .15s, color .15s;
}
.misepress__scale-pill:hover { color: var(--mp-color-fg); }
.misepress__scale-pill.is-active { background: var(--mp-color-bg); color: var(--mp-color-accent); box-shadow: var(--mp-shadow-xs); }
.misepress__scale-pill--more { font-size: 1rem; padding: 0.1rem 0.5rem; }

.misepress__scale-pantry { margin-bottom: var(--mp-s-3); padding: var(--mp-s-3); background: color-mix(in srgb, var(--mp-color-accent-soft) 50%, transparent); border-radius: var(--mp-radius-sm); font-size: var(--mp-text-sm); }
.misepress__scale-pantry-row { display: flex; flex-wrap: wrap; align-items: center; gap: 0.4rem; }
.misepress__scale-pantry-label { color: var(--mp-color-muted); font-weight: 600; font-size: var(--mp-text-xs); text-transform: uppercase; letter-spacing: 0.06em; }
.misepress__scale-pantry input,
.misepress__scale-pantry select { border: 1px solid var(--mp-color-border); border-radius: var(--mp-radius-sm); background: var(--mp-color-bg); color: var(--mp-color-fg); padding: 0.3rem 0.5rem; font: inherit; font-size: var(--mp-text-sm); }
.misepress__scale-pantry input { width: 4.5rem; }
.misepress__btn--sm { padding: 0.3rem 0.7rem; font-size: var(--mp-text-xs); }
.misepress__scale-feedback { margin: var(--mp-s-2) 0 0; color: var(--mp-color-accent); font-size: var(--mp-text-xs); font-weight: 600; }

.misepress__ingredient { display: grid; grid-template-columns: auto auto 1fr; gap: 0.2rem 0.35rem; align-items: baseline; margin-bottom: 0.55rem; }
.misepress__ing-note { color: var(--mp-color-muted); }
.misepress__substitute { grid-column: 1 / -1; display: block; color: var(--mp-color-muted); font-size: var(--mp-text-xs); }
.misepress__story { color: var(--mp-color-fg); }
.misepress__story > *:first-child { margin-top: 0; }

.misepress__title-row { display: flex; justify-content: space-between; align-items: flex-start; gap: var(--mp-s-3); flex-wrap: wrap; }
.misepress__title-actions { display: inline-flex; gap: var(--mp-s-2); align-items: center; flex-shrink: 0; }
.misepress__save-btn--inline { position: static; background: transparent; box-shadow: none; backdrop-filter: none; }
.misepress__save-btn--inline:hover { background: var(--mp-color-accent-soft); }

/* Editorial single recipe: large hero, full-bleed image, distinct hierarchy */
.misepress__recipe--editorial { background: transparent; box-shadow: none; padding: 0; gap: var(--mp-s-7); }
.misepress__header--editorial { display: grid; gap: var(--mp-s-4); text-align: left; }
.misepress__title--editorial { font-size: clamp(2.5rem, 6vw, 4.5rem); line-height: 1.02; letter-spacing: -0.02em; }
.misepress__excerpt--editorial { font-size: var(--mp-text-md); max-width: 60ch; color: var(--mp-color-muted); font-style: italic; }
.misepress__media--editorial { margin-top: var(--mp-s-3); }
.misepress__media--editorial img { width: 100%; aspect-ratio: 16/9; object-fit: cover; border-radius: var(--mp-radius); box-shadow: var(--mp-shadow-lg); }
.misepress__recipe--editorial .misepress__meta { background: color-mix(in srgb, var(--mp-color-accent-soft) 35%, transparent); border-radius: var(--mp-radius); padding: var(--mp-s-4) var(--mp-s-5); border: 0; gap: var(--mp-s-5); }
.misepress__recipe--editorial .misepress__step { background: var(--mp-color-bg); border: 1px solid var(--mp-color-border); }
.misepress__recipe--editorial .misepress__heading { font-size: var(--mp-text-xl); border-left: 3px solid var(--mp-color-accent); padding-left: var(--mp-s-3); }

/* Save modal */
.misepress__save-modal[hidden] { display: none; }
.misepress__save-modal { position: fixed; inset: 0; z-index: 99999; display: grid; place-items: center; padding: 1rem; }
.misepress__save-modal-backdrop { position: absolute; inset: 0; background: rgba(0,0,0,.5); }
.misepress__save-modal-panel { position: relative; max-width: 420px; width: min(100%, 420px); background: var(--mp-color-bg); color: var(--mp-color-fg); border: 1px solid var(--mp-color-border); border-radius: var(--mp-radius); padding: var(--mp-s-5); box-shadow: var(--mp-shadow-lg); display: grid; gap: var(--mp-s-3); }
.misepress__save-modal-panel h3 { margin: 0; font-family: var(--mp-font-display); }
.misepress__save-modal-panel p { margin: 0; color: var(--mp-color-muted); }
.misepress__save-modal-actions { display: flex; gap: var(--mp-s-2); flex-wrap: wrap; }

/* Editorial archive: align top with filters */
.misepress__archive--editorial .misepress__archive-results { margin-top: 0; }
.misepress__archive--editorial .misepress__editorial { margin-top: 0; }

/* Archive grid spacing — tunable via CSS var. ACSS overrides allowed. */
.misepress__archive .misepress__grid { gap: var(--mp-grid-gap, var(--mp-space-3)); grid-template-columns: repeat(auto-fill, minmax(var(--mp-grid-min, 260px), 1fr)); }

/* Onboarding wizard */
.mp-wizard { display: grid; gap: var(--mp-s-5); }
.mp-wizard-progress { display: flex; gap: var(--mp-s-3); align-items: center; font-size: var(--mp-text-xs); color: #888; text-transform: uppercase; letter-spacing: 0.08em; font-weight: 700; }
.mp-wizard-progress-bar { flex: 1; height: 4px; background: #ececec; border-radius: 999px; overflow: hidden; }
.mp-wizard-progress-bar-fill { display: block; height: 100%; background: #c2410c; transition: width .3s ease; width: 0%; }
.mp-wizard-step { display: none; }
.mp-wizard-step.is-active { display: grid; gap: var(--mp-s-4); animation: mp-fade-in .3s ease; }
.mp-wizard-question { font-size: 1.5rem; font-weight: 700; margin: 0; color: #1a1a1a; line-height: 1.25; }
.mp-wizard-help { color: #666; margin: -.5rem 0 .5rem; }
.mp-wizard-nav { display: flex; gap: var(--mp-s-2); justify-content: space-between; align-items: center; margin-top: var(--mp-s-4); padding-top: var(--mp-s-4); border-top: 1px solid #eee; }
.mp-wizard-nav-right { display: flex; gap: var(--mp-s-2); }
.mp-wizard-saved { color: #16a34a; font-size: 0.85rem; opacity: 0; transition: opacity .25s; }
.mp-wizard-saved.is-visible { opacity: 1; }
.mp-wizard-done { text-align: center; padding: var(--mp-s-5); display: grid; gap: var(--mp-s-3); justify-items: center; }
.mp-wizard-done .dashicons { font-size: 3rem; width: 3rem; height: 3rem; color: #16a34a; }


.misepress-slider { position: relative; overflow: hidden; border-radius: var(--mp-radius); }
.misepress-slider__viewport { overflow: hidden; }
.misepress-slider__track { display: flex; list-style: none; padding: 0; margin: 0; transition: transform .55s cubic-bezier(.22,.7,.2,1); }
.misepress-slider__slide { flex: 0 0 100%; min-width: 0; }
.misepress-slider__link  { display: block; color: inherit; text-decoration: none; }
.misepress-slider__media { width: 100%; aspect-ratio: 16/8; background: color-mix(in srgb, var(--mp-color-accent) 10%, var(--mp-color-bg)) center / cover no-repeat; }
.misepress-slider__body  { padding: var(--mp-s-5) var(--mp-s-5); display: grid; gap: var(--mp-s-2); }
.misepress-slider__title { font-family: var(--mp-font-display); font-size: var(--mp-text-xl); margin: 0; }
.misepress-slider__excerpt { color: var(--mp-color-muted); margin: 0; font-size: var(--mp-text-sm); max-width: 60ch; }
.misepress-slider__meta  { list-style: none; padding: 0; margin: 0; display: flex; gap: var(--mp-s-3); flex-wrap: wrap; color: var(--mp-color-muted); font-size: var(--mp-text-xs); }
.misepress-slider__meta li::before { content: '•'; margin-right: 0.4rem; color: var(--mp-color-accent); }
.misepress-slider__meta li:first-child::before { content: ''; margin: 0; }
.misepress-slider__nav   { position: absolute; top: 50%; transform: translateY(-50%); width: 40px; height: 40px; border-radius: 999px; border: 0; background: rgba(255,255,255,.92); color: var(--mp-color-fg); font-size: 1.6rem; line-height: 1; cursor: pointer; box-shadow: var(--mp-shadow-md); transition: background .15s, transform .15s; z-index: 2; }
.misepress-slider__nav:hover { background: var(--mp-color-accent); color: #fff; transform: translateY(-50%) scale(1.05); }
.misepress-slider__nav--prev { left: 14px; }
.misepress-slider__nav--next { right: 14px; }
.misepress-slider__dots  { position: absolute; bottom: 14px; left: 50%; transform: translateX(-50%); display: flex; gap: 0.4rem; z-index: 2; }
.misepress-slider__dot   { width: 8px; height: 8px; border-radius: 999px; border: 0; background: rgba(255,255,255,.5); cursor: pointer; padding: 0; transition: background .2s, transform .2s; }
.misepress-slider__dot.is-active { background: var(--mp-color-accent); transform: scale(1.3); }

/* Slider — Hero variant: overlay text on image */
.misepress-slider--hero .misepress-slider__media { aspect-ratio: 16/7; }
.misepress-slider--hero .misepress-slider__slide { position: relative; }
.misepress-slider--hero .misepress-slider__body  { position: absolute; inset: auto 0 0 0; padding: var(--mp-s-7); color: #fff; background: linear-gradient(180deg, transparent 0%, rgba(0,0,0,.65) 90%); }
.misepress-slider--hero .misepress-slider__title { color: #fff; font-size: clamp(1.5rem, 3vw, 2.6rem); }
.misepress-slider--hero .misepress-slider__excerpt { color: rgba(255,255,255,.85); }
.misepress-slider--hero .misepress-slider__meta { color: rgba(255,255,255,.85); }

/* Slider — Minimal variant: clean side-by-side */
.misepress-slider--minimal .misepress-slider__slide { display: grid; grid-template-columns: 1fr 1fr; align-items: center; gap: var(--mp-s-5); padding: var(--mp-s-4); }
.misepress-slider--minimal .misepress-slider__link { display: contents; }
.misepress-slider--minimal .misepress-slider__media { aspect-ratio: 4/3; border-radius: var(--mp-radius); }
.misepress-slider--minimal .misepress-slider__body  { padding: 0; }
@media (max-width: 720px) { .misepress-slider--minimal .misepress-slider__slide { grid-template-columns: 1fr; } }

/* Slider — Editorial variant: kicker + serif title */
.misepress-slider--editorial .misepress-slider__media { aspect-ratio: 21/9; }
.misepress-slider--editorial .misepress-slider__kicker { text-transform: uppercase; letter-spacing: 0.14em; font-size: var(--mp-text-xs); color: var(--mp-color-accent); font-weight: 800; margin: 0; }
.misepress-slider--editorial .misepress-slider__title { font-family: var(--mp-font-display); font-size: clamp(1.7rem, 3vw, 2.5rem); }
.misepress-slider--editorial .misepress-slider__body  { background: var(--mp-color-bg); }

.misepress-cat-grid { display: grid; gap: var(--mp-s-5); }
.misepress-cat-grid__list { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(var(--mp-cat-cols, 4), minmax(0, 1fr)); gap: var(--mp-s-3); }
@media (max-width: 900px) { .misepress-cat-grid__list { grid-template-columns: repeat(min(var(--mp-cat-cols, 4), 3), minmax(0, 1fr)); } }
@media (max-width: 640px) { .misepress-cat-grid__list { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
.misepress-cat-grid__item { }
.misepress-cat-grid__link { display: block; color: inherit; text-decoration: none; border-radius: var(--mp-radius); overflow: hidden; transition: transform .15s, box-shadow .2s; height: 100%; }
.misepress-cat-grid__link:hover { transform: translateY(-2px); box-shadow: var(--mp-shadow-md); }
.misepress-cat-grid__media { aspect-ratio: 4/3; overflow: hidden; background: color-mix(in srgb, var(--mp-color-accent) 10%, var(--mp-color-bg)); }
.misepress-cat-grid__media img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .4s; }
.misepress-cat-grid__link:hover .misepress-cat-grid__media img { transform: scale(1.04); }
.misepress-cat-grid__body { padding: var(--mp-s-3); display: grid; gap: 2px; }
.misepress-cat-grid__name { font-weight: 700; font-size: var(--mp-text-md); }
.misepress-cat-grid__count { color: var(--mp-color-muted); font-size: var(--mp-text-xs); }
.misepress-cat-grid__desc  { color: var(--mp-color-muted); font-size: var(--mp-text-sm); }

/* Cards (default): outlined card */
.misepress-cat-grid--cards .misepress-cat-grid__link { background: var(--mp-color-bg); border: 1px solid var(--mp-color-border); box-shadow: var(--mp-shadow-xs); }

/* Tiles: full-bleed image with overlay name */
.misepress-cat-grid--tiles .misepress-cat-grid__link { position: relative; aspect-ratio: 1; background: #222; }
.misepress-cat-grid--tiles .misepress-cat-grid__media { position: absolute; inset: 0; aspect-ratio: auto; background-size: cover; background-position: center; }
.misepress-cat-grid--tiles .misepress-cat-grid__body  { position: absolute; inset: auto 0 0 0; padding: var(--mp-s-3) var(--mp-s-4); color: #fff; background: linear-gradient(180deg, transparent, rgba(0,0,0,.7)); }
.misepress-cat-grid--tiles .misepress-cat-grid__count { color: rgba(255,255,255,.85); }

/* Minimal: chips */
.misepress-cat-grid--minimal .misepress-cat-grid__list { display: flex; flex-wrap: wrap; gap: 0.5rem; }
.misepress-cat-grid--minimal .misepress-cat-grid__link { background: color-mix(in srgb, var(--mp-color-accent) 8%, var(--mp-color-bg)); padding: 0.4rem 0.9rem; border-radius: 999px; border: 1px solid var(--mp-color-border); }
.misepress-cat-grid--minimal .misepress-cat-grid__body { padding: 0; display: inline-flex; gap: 0.4rem; align-items: baseline; }
.misepress-cat-grid--minimal .misepress-cat-grid__name { font-size: var(--mp-text-sm); font-weight: 600; }

/* Bordered: centered icon image with bordered tile */
.misepress-cat-grid--bordered .misepress-cat-grid__link { border: 1px solid var(--mp-color-border); background: var(--mp-color-bg); padding: var(--mp-s-4); text-align: center; }
.misepress-cat-grid--bordered .misepress-cat-grid__media { aspect-ratio: 1; max-width: 80px; margin: 0 auto var(--mp-s-2); border-radius: 999px; }
.misepress-cat-grid--bordered .misepress-cat-grid__body { padding: 0; justify-items: center; }

/* Letter separators */
.misepress-cat-grid__separator { font-family: var(--mp-font-display); font-size: var(--mp-text-2xl); margin: var(--mp-s-4) 0 var(--mp-s-3); display: flex; align-items: center; gap: var(--mp-s-3); color: var(--mp-color-accent); }
.misepress-cat-grid__separator::after { content: ''; flex: 1; height: 1px; background: var(--mp-color-border); }


.misepress__scale { margin-top: var(--mp-s-3); display: grid; gap: var(--mp-s-2); padding-top: var(--mp-s-3); border-top: 1px dashed var(--mp-color-border); }
.misepress__scale-label { font-size: var(--mp-text-xs); text-transform: uppercase; letter-spacing: 0.08em; color: var(--mp-color-muted); font-weight: 700; padding-right: 0.4rem; }
.misepress__scale .misepress__scale-inline { display: inline-flex; flex-wrap: wrap; }
.misepress__scale-pill--more { font-size: var(--mp-text-xs); padding: 0.25rem 0.6rem; }
.misepress-pro-badge { display: inline-block; margin-left: .4rem; padding: 1px 6px; border-radius: 999px; background: linear-gradient(135deg,#f59e0b,#ef4444); color:#fff; font-size: 10px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; vertical-align: middle; }

.misepress__filter-search { margin: .5rem 0 .5rem; }
.misepress__filter-search-input {
	width: 100%;
	padding: .5rem .65rem;
	font-size: .875rem;
	border: 1px solid var(--mp-border, #e5e5e5);
	border-radius: 8px;
	background: var(--mp-input-bg, #fff);
	color: var(--mp-fg, #1a1a1a);
	transition: border-color .15s ease, box-shadow .15s ease;
}
.misepress__filter-search-input:focus {
	outline: none;
	border-color: var(--mp-accent, #E85D2A);
	box-shadow: 0 0 0 3px rgba(232, 93, 42, 0.18);
}
.misepress__filter-empty {
	margin: .25rem 0 .25rem;
	font-size: .8125rem;
	color: var(--mp-muted, #6b6b6b);
	font-style: italic;
}
.misepress__filter-group--searchable .misepress__filter-opts {
	max-height: 240px;
	overflow-y: auto;
	padding-right: .25rem;
}
.misepress__hl {
	background: rgba(232, 93, 42, 0.18);
	color: inherit;
	padding: 0 .1em;
	border-radius: 3px;
}

/* =========================================================
   Mobile filter behaviours (floating-bottom / collapsible-top / corner-floater)
   ========================================================= */
.misepress__filter-trigger { display: none; }
.misepress__filter-backdrop { display: none; }

@media (max-width: 900px) {
	/* Make the filters sidebar an off-canvas drawer by default on mobile */
	.misepress__archive .misepress__filters {
		position: fixed;
		left: 0; right: 0; bottom: 0;
		max-height: 85vh;
		overflow: auto;
		z-index: 9999;
		background: var(--mp-color-bg, #fff);
		border-top: 1px solid var(--mp-color-border, rgba(0,0,0,.1));
		border-radius: 18px 18px 0 0;
		box-shadow: 0 -10px 30px rgba(0,0,0,.18);
		transform: translateY(100%);
		transition: transform .25s ease;
		padding: var(--mp-space-3, 1rem);
	}
	.misepress__archive.is-mp-filters-open .misepress__filters { transform: translateY(0); }

	.misepress__filter-backdrop {
		display: block;
		position: fixed; inset: 0;
		background: rgba(0,0,0,.4);
		z-index: 9998;
		opacity: 0;
		pointer-events: none;
		transition: opacity .2s ease;
	}
	.misepress__archive.is-mp-filters-open .misepress__filter-backdrop {
		opacity: 1; pointer-events: auto;
	}
	.misepress__filter-backdrop[hidden] { display: block; } /* keep displayable; visibility via opacity */

	/* Trigger button — visible on mobile only */
	.misepress__filter-trigger {
		display: inline-flex;
		align-items: center;
		gap: 0.5rem;
		position: fixed;
		z-index: 9997;
		border: 0;
		cursor: pointer;
		background: var(--mp-color-accent, #d36a3a);
		color: #fff;
		font-weight: 600;
		font-size: 0.95rem;
		box-shadow: 0 8px 20px rgba(0,0,0,.22);
		-webkit-tap-highlight-color: transparent;
	}
	.misepress__filter-trigger:focus-visible { outline: 2px solid var(--mp-color-fg); outline-offset: 3px; }

	/* Variant: floating-bottom (default) — bottom-center pill with icon + label */
	.misepress__archive--mobile-floating-bottom .misepress__filter-trigger {
		bottom: max(16px, env(safe-area-inset-bottom));
		left: 50%;
		transform: translateX(-50%);
		padding: 0.85rem 1.4rem;
		border-radius: 999px;
	}

	/* Variant: corner-floater — small round icon button in a chosen corner */
	.misepress__archive--mobile-corner-floater .misepress__filter-trigger {
		width: 52px; height: 52px;
		padding: 0;
		border-radius: 50%;
		justify-content: center;
	}
	.misepress__archive--mobile-corner-floater .misepress__filter-trigger-label { display: none; }
	.misepress__archive--mobile-corner-floater.misepress__archive--corner-bottom-right .misepress__filter-trigger { right: 16px; bottom: max(16px, env(safe-area-inset-bottom)); }
	.misepress__archive--mobile-corner-floater.misepress__archive--corner-bottom-left  .misepress__filter-trigger { left: 16px;  bottom: max(16px, env(safe-area-inset-bottom)); }
	.misepress__archive--mobile-corner-floater.misepress__archive--corner-top-right    .misepress__filter-trigger { right: 16px; top: 80px; }
	.misepress__archive--mobile-corner-floater.misepress__archive--corner-top-left     .misepress__filter-trigger { left: 16px;  top: 80px; }

	/* Variant: collapsible-top — inline panel above the recipes, no overlay */
	.misepress__archive--mobile-collapsible-top .misepress__filter-trigger {
		position: static;
		display: inline-flex;
		margin: 0 0 var(--mp-space-3, 1rem);
		padding: 0.7rem 1.1rem;
		border-radius: 10px;
		box-shadow: none;
	}
	.misepress__archive--mobile-collapsible-top .misepress__filters {
		position: static;
		max-height: 0;
		overflow: hidden;
		transform: none;
		border-radius: var(--mp-radius);
		box-shadow: none;
		padding: 0 var(--mp-space-2, .75rem);
		transition: max-height .25s ease, padding .25s ease;
		border: 1px solid var(--mp-color-border, rgba(0,0,0,.1));
	}
	.misepress__archive--mobile-collapsible-top.is-mp-filters-open .misepress__filters {
		max-height: 1000px;
		padding: var(--mp-space-2, .75rem);
	}
	.misepress__archive--mobile-collapsible-top .misepress__filter-backdrop { display: none; }

	/* Hide trigger when no filters needed (defensive) */
	.misepress__archive .misepress__filter-trigger svg { flex: 0 0 auto; }
}

@media (max-width: 900px) {
	/* Drawer already shows the title + Clear all in the sticky bar — hide the in-form header to avoid duplication and overlap */
	.misepress__archive:not(.misepress__archive--mobile-collapsible-top) .misepress__filter-form .misepress__filter-header {
		display: none;
	}
}

/* Desktop: never show the floating trigger or backdrop */
@media (min-width: 901px) {
	.misepress__filter-trigger,
	.misepress__filter-backdrop,
	.misepress__filter-mobile-bar,
	.misepress__filter-mobile-actions { display: none !important; }
}

/* ----- Mobile drawer close affordances ----- */
.misepress__filter-mobile-bar { display: none; }
.misepress__filter-mobile-actions { display: none; }
@media (max-width: 900px) {
	.misepress__archive:not(.misepress__archive--mobile-collapsible-top) .misepress__filter-mobile-bar {
		display: block;
		position: sticky;
		top: 0;
		z-index: 2;
		margin: calc(var(--mp-space-3, 1rem) * -1) calc(var(--mp-space-3, 1rem) * -1) 0.75rem;
		padding: 0.4rem var(--mp-space-3, 1rem) 0.75rem;
		background: var(--mp-color-bg, #fff);
		border-bottom: 1px solid var(--mp-color-border, rgba(0,0,0,.08));
	}
	.misepress__archive:not(.misepress__archive--mobile-collapsible-top) .misepress__filter-form { padding-bottom: 5.25rem; }
	.misepress__archive:not(.misepress__archive--mobile-collapsible-top) .misepress__filter-form > .misepress__filter-group:first-of-type { padding-top: 0.55rem; }
	.misepress__archive:not(.misepress__archive--mobile-collapsible-top) .misepress__search-input { display: flex; align-items: center; }
	.misepress__archive:not(.misepress__archive--mobile-collapsible-top) .misepress__search-input input {
		box-sizing: border-box;
		min-height: 44px;
		padding: 0.65rem 0.85rem 0.65rem 2.4rem !important;
		border: 1px solid var(--mp-color-border, rgba(0,0,0,.14));
		border-radius: var(--mp-radius-sm, 8px);
		background: var(--mp-color-bg, #fff);
		font-size: 1rem;
		line-height: 1.25;
	}
	.misepress__filter-mobile-handle {
		display: block;
		width: 44px; height: 5px;
		border-radius: 999px;
		margin: 4px auto 10px;
		background: color-mix(in srgb, var(--mp-color-fg, #1a1a1a) 18%, transparent);
		cursor: grab;
	}
	.misepress__filter-mobile-bar-row {
		display: flex; align-items: center; justify-content: space-between; gap: 0.5rem;
	}
	.misepress__filter-mobile-title { font-family: var(--mp-font-display); font-size: 1.05rem; }
	.misepress__filter-close {
		appearance: none; border: 0;
		background: color-mix(in srgb, var(--mp-color-fg, #1a1a1a) 8%, transparent);
		color: var(--mp-color-fg, #1a1a1a);
		width: 36px; height: 36px; border-radius: 50%;
		display: inline-flex; align-items: center; justify-content: center;
		cursor: pointer;
	}
	.misepress__filter-close:hover { background: color-mix(in srgb, var(--mp-color-fg, #1a1a1a) 14%, transparent); }
	.misepress__archive:not(.misepress__archive--mobile-collapsible-top) .misepress__filter-mobile-actions {
		display: block;
		position: sticky; bottom: 0;
		margin: 0.75rem -1rem -1rem;
		padding: 0.75rem 1rem max(0.75rem, env(safe-area-inset-bottom));
		background: linear-gradient(to top, var(--mp-color-bg, #fff) 70%, transparent);
		border-top: 1px solid var(--mp-color-border, rgba(0,0,0,.08));
	}
	.misepress__filter-done { width: 100%; padding: 0.85rem 1rem; border-radius: 12px; font-weight: 600; }

	/* Fullscreen drawer option */
	.misepress__archive.mp-filter-mobile-full .misepress__filters {
		max-height: 100dvh; height: 100dvh;
		border-radius: 0;
		padding-top: max(env(safe-area-inset-top), 0.5rem);
	}
}

/* ----- Density variants ----- */
.mp-filter-density-compact .misepress__filter-form { gap: 0.45rem; }
.mp-filter-density-compact .misepress__filter-group { gap: 0.25rem; padding-bottom: 0.35rem; }
.mp-filter-density-compact .misepress__filter-opt { padding: 0.1rem 0; font-size: 0.85rem; }
.mp-filter-density-compact .misepress__filter-opts { max-height: 160px; }
.mp-filter-density-relaxed .misepress__filter-form { gap: 1rem; }
.mp-filter-density-relaxed .misepress__filter-group { gap: 0.65rem; padding-bottom: 0.9rem; }
.mp-filter-density-relaxed .misepress__filter-opt { padding: 0.4rem 0; font-size: 0.95rem; }
.mp-filter-density-relaxed .misepress__filter-opts { max-height: 280px; }

/* ----- Filter shadow + sticky variants (desktop sidebar) ----- */
@media (min-width: 901px) {
	.mp-filter-shadow-none .misepress__filters { box-shadow: none; }
	.mp-filter-shadow-soft .misepress__filters { box-shadow: 0 1px 2px rgba(0,0,0,.04), 0 4px 10px rgba(0,0,0,.05); }
	.mp-filter-shadow-medium .misepress__filters { box-shadow: 0 2px 6px rgba(0,0,0,.06), 0 10px 24px rgba(0,0,0,.08); }
	.mp-filter-shadow-strong .misepress__filters { box-shadow: 0 4px 10px rgba(0,0,0,.08), 0 20px 40px rgba(0,0,0,.14); }
	.mp-filter-sticky.misepress__archive--filters-sidebar-left .misepress__filters,
	.mp-filter-sticky.misepress__archive--filters-sidebar-right .misepress__filters {
		position: sticky; top: var(--mp-space-3);
		max-height: var(--mp-filter-sticky-max, none);
		overflow: var(--mp-filter-sticky-overflow, visible);
	}
}

/* ----- Filter palette overrides (variables set in inline CSS) ----- */
.misepress__filters {
	background: var(--mp-filter-bg, color-mix(in srgb, var(--mp-color-fg) 4%, transparent));
	color: var(--mp-filter-text, inherit);
	border-color: var(--mp-filter-border, var(--mp-color-border));
	border-radius: var(--mp-filter-radius, var(--mp-radius));
}
.misepress__filters .misepress__filter-title { color: var(--mp-filter-text, inherit); }


/* ============================================================
 * ============================================================ */

/* Toolbar layout enhancements */
.misepress__archive-header--with-toolbar { display: flex; flex-wrap: wrap; gap: var(--mp-space-3); align-items: flex-end; justify-content: space-between; }
.misepress__archive-header-toolbar { display: flex; flex-wrap: wrap; gap: var(--mp-space-2); align-items: center; }

/* ---------- Active filter chips ---------- */
.misepress__active-chips {
	display: flex; flex-wrap: wrap; gap: 0.5rem;
	margin: 0 0 var(--mp-space-3);
	padding: 0.75rem; border-radius: var(--mp-radius);
	background: color-mix(in srgb, var(--mp-color-accent-soft) 60%, transparent);
	border: 1px solid var(--mp-color-border);
	animation: mpChipFade .2s ease;
}
.misepress__active-chips[hidden] { display: none; }
.misepress__chip {
	display: inline-flex; align-items: center; gap: 0.4rem;
	padding: 0.35rem 0.75rem; min-height: 32px;
	background: var(--mp-color-bg);
	color: var(--mp-color-fg);
	border: 1px solid var(--mp-color-border);
	border-radius: 999px;
	font-size: 0.85rem; font-family: var(--mp-font-body);
	cursor: pointer;
	transition: background .15s ease, border-color .15s ease, transform .1s ease;
}
.misepress__chip:hover { border-color: var(--mp-color-accent); background: var(--mp-color-accent-soft); }
.misepress__chip:active { transform: scale(0.97); }
.misepress__chip:focus-visible { outline: 2px solid var(--mp-color-accent); outline-offset: 2px; }
.misepress__chip-key { color: var(--mp-color-muted); font-weight: 500; }
.misepress__chip-val { font-weight: 600; }
.misepress__chip-x { font-size: 1rem; line-height: 1; opacity: 0.6; padding-left: 0.2rem; }
.misepress__chip:hover .misepress__chip-x { opacity: 1; color: var(--mp-color-accent); }
.misepress__chip--clear {
	background: transparent;
	border-color: transparent;
	color: var(--mp-color-accent);
	font-weight: 600;
	text-decoration: underline;
}
.misepress__chip--clear:hover { background: transparent; }
@keyframes mpChipFade { from { opacity: 0; transform: translateY(-4px); } to { opacity: 1; transform: none; } }

/* ---------- Quick filter presets ---------- */
.misepress__presets {
	display: flex; flex-wrap: wrap; gap: 0.5rem;
}
.misepress__preset {
	display: inline-flex; align-items: center; gap: 0.35rem;
	padding: 0.5rem 0.9rem; min-height: 36px;
	border-radius: 999px;
	background: var(--mp-color-bg);
	color: var(--mp-color-fg);
	border: 1.5px solid var(--mp-color-border);
	font-family: var(--mp-font-body); font-size: 0.875rem; font-weight: 500;
	cursor: pointer;
	transition: all .15s ease;
}
.misepress__preset:hover {
	border-color: var(--mp-color-accent);
	background: var(--mp-color-accent-soft);
	transform: translateY(-1px);
}
.misepress__preset:focus-visible { outline: 2px solid var(--mp-color-accent); outline-offset: 2px; }
.misepress__preset.is-active {
	background: var(--mp-color-accent);
	color: var(--mp-color-bg);
	border-color: var(--mp-color-accent);
}

/* ---------- Density toggle ---------- */
.misepress__density { display: inline-flex; border: 1px solid var(--mp-color-border); border-radius: 8px; overflow: hidden; }
.misepress__density-btn {
	width: 36px; height: 36px;
	display: inline-flex; align-items: center; justify-content: center;
	background: var(--mp-color-bg); color: var(--mp-color-muted);
	border: none; cursor: pointer; font-size: 1rem;
	transition: background .15s, color .15s;
}
.misepress__density-btn:not(:last-child) { border-right: 1px solid var(--mp-color-border); }
.misepress__density-btn:hover { background: var(--mp-color-accent-soft); color: var(--mp-color-fg); }
.misepress__density-btn.is-active { background: var(--mp-color-accent); color: #fff; }
.misepress__density-btn:focus-visible { outline: 2px solid var(--mp-color-accent); outline-offset: -2px; }

/* Density modes apply to grid — use !important so they win over the
   per-archive `--mp-grid-min` user setting. Compact = denser tiles,
   Comfortable = default, Visual = large hero rows (1–2 per row). */
.misepress__archive--density-compact .misepress__grid,
.misepress__archive.misepress__archive--density-compact .misepress__grid {
	grid-template-columns: repeat(auto-fill, minmax(170px, 1fr)) !important;
	gap: var(--mp-space-2) !important;
}
.misepress__archive--density-compact .misepress__card,
.misepress__archive--density-compact .misepress__grid-card { font-size: 0.875rem; }
.misepress__archive--density-comfortable .misepress__grid,
.misepress__archive.misepress__archive--density-comfortable .misepress__grid {
	grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)) !important;
	gap: var(--mp-space-3) !important;
}
.misepress__archive--density-visual .misepress__grid,
.misepress__archive.misepress__archive--density-visual .misepress__grid {
	grid-template-columns: repeat(auto-fill, minmax(440px, 1fr)) !important;
	gap: var(--mp-space-5, 2rem) !important;
}
.misepress__archive--density-visual .misepress__grid-card { font-size: 1.05rem; }
.misepress__archive--density-visual .misepress__media img,
.misepress__archive--density-visual .misepress__grid-card img { aspect-ratio: 4/3; object-fit: cover; }

/* ---------- Copy search button ---------- */
.misepress__btn--ghost {
	background: transparent;
	color: var(--mp-color-fg);
	border: 1px solid var(--mp-color-border);
	padding: 0.5rem 0.9rem;
	border-radius: 8px;
	display: inline-flex; align-items: center; gap: 0.4rem;
	min-height: 36px;
	font-family: var(--mp-font-body); font-size: 0.875rem;
	cursor: pointer;
	transition: all .15s ease;
}
.misepress__btn--ghost:hover { border-color: var(--mp-color-accent); color: var(--mp-color-accent); }
.misepress__btn--ghost:focus-visible { outline: 2px solid var(--mp-color-accent); outline-offset: 2px; }
.misepress__copy-search.is-copied { background: var(--mp-color-accent); color: var(--mp-color-bg); border-color: var(--mp-color-accent); }
.misepress__copy-search.is-hidden { display: none !important; }

.misepress__sort-label { display: inline-flex; align-items: center; gap: 0.4rem; font-size: 0.875rem; color: var(--mp-color-muted); }
.misepress__sort-label select { min-height: 36px; padding: 0 0.6rem; border-radius: 8px; border: 1px solid var(--mp-color-border); background: var(--mp-color-bg); color: var(--mp-color-fg); }

/* ---------- Empty state ---------- */
.misepress__empty {
	text-align: center;
	padding: clamp(2rem, 4vw, 3rem) var(--mp-space-3);
	background: linear-gradient(180deg, var(--mp-color-bg), color-mix(in srgb, var(--mp-color-accent-soft) 35%, transparent));
	border: 1px dashed var(--mp-color-border);
	border-radius: var(--mp-radius);
	max-width: 540px; margin: var(--mp-space-3) auto;
	animation: mp-fade-in .35s ease both;
}
.misepress__empty-icon {
	font-size: 3rem; margin-bottom: var(--mp-space-2);
	display: inline-grid; place-items: center;
	width: 4.5rem; height: 4.5rem;
	background: var(--mp-color-bg);
	border-radius: 999px;
	box-shadow: var(--mp-shadow-sm);
}
.misepress__empty-title { font-family: var(--mp-font-display); font-size: 1.5rem; margin: 0 0 var(--mp-space-2); color: var(--mp-color-fg); }
.misepress__empty-tips { list-style: none; padding: 0; margin: 0 0 var(--mp-space-3); color: var(--mp-color-muted); display: inline-grid; gap: 0.35rem; text-align: left; }
.misepress__empty-tips li { padding: 0.1rem 0; padding-left: 1.2rem; position: relative; }
.misepress__empty-tips li::before { content: '→'; color: var(--mp-color-accent); position: absolute; left: 0; font-weight: 700; }

/* ---------- Sticky desktop filter bar (only when sticky toggle on) ---------- */
@media (min-width: 1024px) {
	.mp-filter-sticky.misepress__archive--filters-sidebar-left .misepress__filters,
	.mp-filter-sticky.misepress__archive--filters-sidebar-right .misepress__filters {
		position: sticky;
		top: var(--mp-sticky-offset, 80px);
		align-self: flex-start;
	}
	.mp-filter-sticky.mp-filter-scroll-internal .misepress__filters {
		max-height: calc(100vh - var(--mp-sticky-offset, 80px) - 2rem);
		overflow-y: auto;
	}
	/* Subtle scrollbar for sticky filters */
	.misepress__filters::-webkit-scrollbar { width: 6px; }
	.misepress__filters::-webkit-scrollbar-thumb { background: var(--mp-color-border); border-radius: 3px; }
}

/* ---------- Accessibility helpers ---------- */
.screen-reader-text {
	position: absolute !important;
	width: 1px; height: 1px;
	padding: 0; margin: -1px; overflow: hidden;
	clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0;
}
.misepress__filter-opt input:focus-visible + span,
.misepress__filter-opt:focus-within { outline: 2px solid var(--mp-color-accent); outline-offset: 2px; border-radius: 4px; }
.misepress__filter-opt { min-height: 36px; }

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
	.misepress__chip, .misepress__preset, .misepress__btn--ghost, .misepress__density-btn { transition: none; }
	.misepress__active-chips { animation: none; }
}

/* Mobile toolbar wrap */
@media (max-width: 720px) {
	.misepress__archive-header--with-toolbar { flex-direction: column; align-items: stretch; }
	.misepress__archive-header-toolbar { width: 100%; }
	.misepress__presets { width: 100%; overflow-x: auto; flex-wrap: nowrap; padding-bottom: 0.25rem; -webkit-overflow-scrolling: touch; }
	.misepress__preset { flex: 0 0 auto; }
}

/* ================================================================
 * ================================================================ */

/* Autocomplete panel */
.misepress__suggest-panel {
	position: absolute;
	top: calc(100% + 4px);
	left: 0; right: 0;
	background: var(--mp-color-bg);
	border: 1px solid var(--mp-color-border);
	border-radius: 10px;
	box-shadow: 0 12px 32px -16px rgba(0,0,0,0.25);
	z-index: 50;
	max-height: 380px;
	overflow-y: auto;
}
.misepress__suggest-group { padding: 0.35rem 0; border-bottom: 1px solid var(--mp-color-border); }
.misepress__suggest-group:last-child { border-bottom: 0; }
.misepress__suggest-heading {
	font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.08em;
	color: var(--mp-color-muted);
	padding: 0.35rem 0.75rem;
}
.misepress__suggest-item {
	display: flex; align-items: center; gap: 0.6rem;
	padding: 0.45rem 0.75rem;
	color: var(--mp-color-fg); text-decoration: none;
	font-size: 0.92rem;
	transition: background .12s;
}
.misepress__suggest-item:hover,
.misepress__suggest-item.is-active { background: var(--mp-color-accent-soft); color: var(--mp-color-accent); }
.misepress__suggest-thumb {
	width: 32px; height: 32px; border-radius: 6px;
	background: var(--mp-color-border) center/cover no-repeat;
	flex-shrink: 0;
}
.misepress__suggest-thumb--empty { background: var(--mp-color-accent-soft); }
.misepress__suggest-label { flex: 1; }
.misepress__suggest-count { color: var(--mp-color-muted); font-style: normal; font-size: 0.8rem; }
.misepress__suggest-empty { padding: 0.9rem; color: var(--mp-color-muted); text-align: center; font-size: 0.9rem; }
.misepress__suggest-upsell {
	padding: 0.6rem 0.75rem;
	background: var(--mp-color-accent-soft);
	color: var(--mp-color-accent);
	font-size: 0.82rem;
	border-top: 1px solid var(--mp-color-border);
}
.misepress__pro-pill {
	display: inline-block;
	background: var(--mp-color-accent); color: var(--mp-color-bg);
	font-size: 0.65rem; font-weight: 700; letter-spacing: 0.06em;
	padding: 2px 6px; border-radius: 4px; margin-right: 0.3rem;
	text-transform: uppercase;
}

/* Saved filters */
.misepress__saved-wrap { position: relative; display: inline-flex; gap: 0.4rem; }
.misepress__saved-menu {
	position: absolute;
	top: calc(100% + 4px); right: 0;
	min-width: 220px;
	background: var(--mp-color-bg);
	border: 1px solid var(--mp-color-border);
	border-radius: 10px;
	box-shadow: 0 12px 32px -16px rgba(0,0,0,0.25);
	z-index: 60;
	padding: 0.35rem 0;
}
.misepress__saved-heading {
	font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.08em;
	color: var(--mp-color-muted);
	padding: 0.4rem 0.75rem;
}
.misepress__saved-item {
	display: flex; align-items: center; gap: 0.5rem;
	padding: 0.35rem 0.75rem;
}
.misepress__saved-item a { flex: 1; color: var(--mp-color-fg); text-decoration: none; font-size: 0.92rem; }
.misepress__saved-item a:hover { color: var(--mp-color-accent); }
.misepress__saved-item button {
	background: none; border: 0; cursor: pointer;
	color: var(--mp-color-muted);
	width: 24px; height: 24px; border-radius: 4px;
	font-size: 1.1rem; line-height: 1;
}
.misepress__saved-item button:hover { background: var(--mp-color-accent-soft); color: var(--mp-color-accent); }

/* Recently viewed strip */
.misepress__recent-strip {
	margin: var(--mp-space-2) 0 var(--mp-space-3);
	padding: var(--mp-space-2) 0;
	border-bottom: 1px solid var(--mp-color-border);
}
.misepress__recent-title {
	font-family: var(--mp-font-display);
	font-size: 1rem; margin: 0 0 var(--mp-space-1);
	color: var(--mp-color-muted);
	font-weight: 500;
}
.misepress__recent-row {
	display: flex; gap: var(--mp-space-2);
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	padding-bottom: 0.25rem;
}
.misepress__recent-card {
	flex: 0 0 160px;
	display: block;
	color: var(--mp-color-fg); text-decoration: none;
	border-radius: 8px;
	transition: transform .15s ease;
}
.misepress__recent-card:hover { transform: translateY(-2px); }
.misepress__recent-media {
	display: block; width: 100%; aspect-ratio: 4/3;
	background: var(--mp-color-border) center/cover no-repeat;
	border-radius: 8px;
	margin-bottom: 0.4rem;
}
.misepress__recent-label {
	display: block; font-size: 0.85rem; line-height: 1.3;
	display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
	overflow: hidden;
}

/* "You may also like" — related grid */
.misepress__related {
	margin-top: var(--mp-space-4);
	padding-top: var(--mp-space-3);
	border-top: 1px solid var(--mp-color-border);
}
.misepress__related-title {
	font-family: var(--mp-font-display);
	font-size: 1.5rem;
	margin: 0 0 var(--mp-space-3);
}

/* GRID layout — explicit columns instead of auto-fill so the
   admin's "columns" setting actually controls the layout. */
.misepress__related--grid .misepress__related-grid,
.misepress__related--slider .misepress__related-track {
	display: grid;
	gap: var(--mp-grid-gap, 1.5rem);
}
.misepress__related--cols-1 .misepress__related-grid,
.misepress__related--cols-1 .misepress__related-track { grid-template-columns: repeat(1, minmax(0, 1fr)); }
.misepress__related--cols-2 .misepress__related-grid,
.misepress__related--cols-2 .misepress__related-track { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.misepress__related--cols-3 .misepress__related-grid,
.misepress__related--cols-3 .misepress__related-track { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.misepress__related--cols-4 .misepress__related-grid,
.misepress__related--cols-4 .misepress__related-track { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.misepress__related--cols-6 .misepress__related-grid,
.misepress__related--cols-6 .misepress__related-track { grid-template-columns: repeat(6, minmax(0, 1fr)); }
@media (max-width: 900px) {
	.misepress__related--cols-4 .misepress__related-grid,
	.misepress__related--cols-6 .misepress__related-grid,
	.misepress__related--cols-4 .misepress__related-track,
	.misepress__related--cols-6 .misepress__related-track { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 600px) {
	.misepress__related--grid .misepress__related-grid { grid-template-columns: repeat(1, minmax(0, 1fr)); }
}

/* Slider container — themable via CSS vars set inline on the section. */
.misepress__related--slider .misepress__related-slider {
	position: relative;
	width: 100%;
	max-width: none;
	box-sizing: border-box;
	background: var(--mp-rel-slider-bg, transparent);
	padding: var(--mp-rel-slider-pad, 1rem);
	border-radius: var(--mp-rel-slider-radius, 12px);
}
.misepress__related--slider .misepress__related-track {
	display: grid;
	grid-auto-flow: column;
	grid-template-columns: none;
	grid-auto-columns: calc((100% - (var(--mp-rel-cols, 4) - 1) * 1rem) / var(--mp-rel-cols, 4));
	gap: 1rem;
	width: 100%;
	max-width: none;
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	scroll-padding-inline: var(--mp-rel-slider-pad, 1rem);
	scroll-behavior: smooth;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: none;
}
.misepress__related--slider .misepress__related-track::-webkit-scrollbar { display: none; }
.misepress__related--slider.misepress__related--cols-1 .misepress__related-track { --mp-rel-cols: 1; }
.misepress__related--slider.misepress__related--cols-2 .misepress__related-track { --mp-rel-cols: 2; }
.misepress__related--slider.misepress__related--cols-3 .misepress__related-track { --mp-rel-cols: 3; }
.misepress__related--slider.misepress__related--cols-4 .misepress__related-track { --mp-rel-cols: 4; }
.misepress__related--slider.misepress__related--cols-6 .misepress__related-track { --mp-rel-cols: 6; }
@media (max-width: 900px) {
	.misepress__related--slider .misepress__related-track { --mp-rel-cols: 2 !important; }
}
@media (max-width: 600px) {
	.misepress__related--slider .misepress__related-track { --mp-rel-cols: 1.2 !important; }
}
.misepress__related--slider .misepress__related-track > * { scroll-snap-align: center; }
.misepress__related--slider.misepress__related--cols-1 .misepress__related-track {
	grid-auto-columns: minmax(100%, 100%);
	justify-content: stretch;
	scroll-padding-inline: 0;
}
.misepress__related--slider.misepress__related--cols-1 .misepress__related-track > * { scroll-snap-align: start; }
.misepress__related--full .misepress__related-grid,
.misepress__related--full .misepress__related-track,
.misepress__related--full .misepress__related-slider,
.misepress__related--full .misepress__related-grid > *,
.misepress__related--full .misepress__related-track > * { width: 100%; max-width: none; min-width: 0; justify-self: stretch; box-sizing: border-box; }
.misepress__related--full .misepress__related-grid { grid-template-columns: minmax(0, 1fr); justify-items: stretch; }

/* Arrow buttons — appearance and position variants. */
.misepress__related-nav {
	position: absolute; top: 50%; transform: translateY(-50%);
	width: var(--mp-rel-arrow-size, 40px);
	height: var(--mp-rel-arrow-size, 40px);
	background: var(--mp-rel-arrow-bg, #fff);
	color: var(--mp-rel-arrow-color, #1a1a1a);
	border: 1px solid var(--mp-color-border, #e5e5e5);
	box-shadow: 0 2px 8px rgba(0,0,0,0.08);
	font-size: 1.5rem; line-height: 1; cursor: pointer;
	display: flex; align-items: center; justify-content: center;
	z-index: 2; padding: 0;
	transition: opacity 0.15s ease, transform 0.15s ease;
}
.misepress__related--arrow-circle  .misepress__related-nav { border-radius: 50%; }
.misepress__related--arrow-square  .misepress__related-nav { border-radius: 8px; }
.misepress__related--arrow-minimal .misepress__related-nav { background: transparent; border-color: transparent; box-shadow: none; }
.misepress__related-nav:hover { transform: translateY(-50%) scale(1.05); }
.misepress__related-nav:disabled { opacity: 0.35; cursor: not-allowed; }
/* Position variants */
.misepress__related--arrowpos-overlap .misepress__related-nav--prev { left: -10px; }
.misepress__related--arrowpos-overlap .misepress__related-nav--next { right: -10px; }
.misepress__related--arrowpos-inside  .misepress__related-nav--prev { left: 8px; }
.misepress__related--arrowpos-inside  .misepress__related-nav--next { right: 8px; }
.misepress__related--arrowpos-outside .misepress__related-nav--prev { left: calc(-1 * var(--mp-rel-arrow-size, 40px) - 8px); }
.misepress__related--arrowpos-outside .misepress__related-nav--next { right: calc(-1 * var(--mp-rel-arrow-size, 40px) - 8px); }
@media (max-width: 600px) {
	.misepress__related-nav { display: none; }
}

/* LIST layout — vertical compact rows. */
.misepress__related-rows {
	list-style: none; padding: 0; margin: 0;
	display: flex; flex-direction: column; gap: var(--mp-space-2);
}

/* Hidden helper */
.is-hidden { display: none !important; }

/* ============================================================
 * Phase 4 — Advanced filters (PRO)
 * ============================================================ */
.misepress__filter-group--toggle .misepress__filter-opt--toggle {
	display: flex; align-items: center; gap: .5rem; padding: .4rem .6rem;
	border-radius: 999px; background: var(--mp-color-accent-soft, #fff5ef);
	border: 1px solid var(--mp-color-border, #eee); cursor: pointer;
	font-weight: 600;
}
.misepress__filter-opts--stack { display: flex; flex-direction: column; gap: .5rem; min-width: 0; max-width: 100%; }
.misepress__filter-num { display: flex; flex-direction: column; gap: .25rem; font-size: .9rem; min-width: 0; max-width: 100%; }
.misepress__filter-num input {
	padding: .45rem .6rem;
	border: 1px solid var(--mp-color-border, #ddd);
	border-radius: 8px;
	width: 100%;
	min-width: 0;
	max-width: 100%;
	box-sizing: border-box;
}

.misepress__filter-opts--icons {
	display: grid; grid-template-columns: repeat(auto-fit, minmax(110px, 1fr));
	gap: .5rem;
}
.misepress__filter-opt--icon {
	display: flex; flex-direction: column; align-items: center; justify-content: center;
	gap: .25rem; padding: .65rem .5rem; border-radius: 12px;
	border: 1px solid var(--mp-color-border, #e6e6e6);
	background: var(--mp-color-bg, #fff); cursor: pointer; text-align: center;
	transition: all .15s ease;
}
.misepress__filter-opt--icon input { position: absolute; opacity: 0; pointer-events: none; }
.misepress__filter-opt--icon:has(input:checked) {
	border-color: var(--mp-color-accent, #e85d2a);
	background: var(--mp-color-accent-soft, #fff5ef);
	box-shadow: 0 0 0 2px var(--mp-color-accent, #e85d2a) inset;
}
.misepress__filter-opt--icon .misepress__filter-icon { font-size: 1.4rem; line-height: 1; }
.misepress__filter-opt--icon span:last-child { font-size: .85rem; font-weight: 500; }

/* Visual mode: icon — render checkbox lists as icon pills */
.misepress__filters--vmode-icon .misepress__filter-opts:not(.misepress__filter-opts--stack):not(.misepress__filter-opts--icons),
.misepress__filters--vmode-badge .misepress__filter-opts:not(.misepress__filter-opts--stack):not(.misepress__filter-opts--icons),
.misepress__filters--vmode-image .misepress__filter-opts:not(.misepress__filter-opts--stack):not(.misepress__filter-opts--icons) {
	display: flex; flex-wrap: wrap; gap: .35rem;
}
.misepress__filters--vmode-icon .misepress__filter-opt,
.misepress__filters--vmode-badge .misepress__filter-opt,
.misepress__filters--vmode-image .misepress__filter-opt {
	display: inline-flex; align-items: center; gap: .35rem;
	padding: .3rem .7rem; border-radius: 999px;
	border: 1px solid var(--mp-color-border, #e6e6e6);
	background: var(--mp-color-bg, #fff); cursor: pointer;
	font-size: .85rem; transition: all .15s ease;
}
.misepress__filters--vmode-icon .misepress__filter-opt input,
.misepress__filters--vmode-badge .misepress__filter-opt input,
.misepress__filters--vmode-image .misepress__filter-opt input {
	position: absolute; opacity: 0; pointer-events: none;
}
.misepress__filters--vmode-icon .misepress__filter-opt em,
.misepress__filters--vmode-badge .misepress__filter-opt em,
.misepress__filters--vmode-image .misepress__filter-opt em { opacity: .55; font-style: normal; font-size: .75rem; }
.misepress__filters--vmode-icon .misepress__filter-opt:has(input:checked),
.misepress__filters--vmode-badge .misepress__filter-opt:has(input:checked),
.misepress__filters--vmode-image .misepress__filter-opt:has(input:checked) {
	border-color: var(--mp-color-accent, #e85d2a);
	background: var(--mp-color-accent-soft, #fff5ef);
	color: var(--mp-color-accent, #e85d2a);
	font-weight: 600;
}
.misepress__filters--vmode-badge .misepress__filter-opt {
	background: var(--mp-color-accent-soft, #fff5ef);
	border-color: transparent;
}

/* Infinite scroll: hide "Load more" label, show spinner instead */
.misepress__load-more--auto {
	position: relative;
	color: transparent !important;
}
.misepress__load-more--auto::after {
	content: ''; position: absolute; inset: 0; margin: auto;
	width: 22px; height: 22px; border-radius: 50%;
	border: 2px solid currentColor; border-top-color: transparent;
	color: var(--mp-color-accent, #e85d2a);
	animation: mp-spin 0.7s linear infinite;
}
@keyframes mp-spin { to { transform: rotate(360deg); } }

/* ============================================================
 * ============================================================ */
.misepress__collection { margin: 2.5rem 0; }
.misepress__collection-title {
	font-size: clamp(1.25rem, 1.4vw + 1rem, 1.75rem);
	font-weight: 700;
	margin: 0 0 1rem;
	letter-spacing: -0.01em;
}
.misepress__collection-grid {
	display: grid;
	gap: 1rem;
	grid-template-columns: repeat(var(--mp-cols, 4), minmax(0, 1fr));
}
.misepress__collection--cols-1 { --mp-cols: 1; }
.misepress__collection--cols-2 { --mp-cols: 2; }
.misepress__collection--cols-3 { --mp-cols: 3; }
.misepress__collection--cols-4 { --mp-cols: 4; }
.misepress__collection--cols-6 { --mp-cols: 6; }
@media (max-width: 900px) { .misepress__collection-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 540px) { .misepress__collection-grid { grid-template-columns: 1fr; } }
.misepress__collection-rows { list-style: none; padding: 0; margin: 0; display: grid; gap: 0.75rem; }

.misepress__because {
	background: var(--mp-color-surface, #fafafa);
	border-radius: 14px;
	padding: 1.5rem;
}
.misepress__because .misepress__collection-title { margin-bottom: 1rem; }

/* =========================================================================
   ========================================================================= */
.misepress__save-modal { position: fixed; inset: 0; z-index: 99998; display: grid; place-items: center; }
.misepress__save-modal[hidden] { display: none; }
.misepress__save-modal-backdrop {
	position: absolute; inset: 0;
	background: rgba(15,15,15,0.55);
	backdrop-filter: blur(4px);
	animation: mp-fade-in .2s ease both;
}
.misepress__save-modal-panel {
	position: relative;
	background: #fff;
	border-radius: 16px;
	padding: 2rem 2rem 1.5rem;
	max-width: 420px;
	width: calc(100% - 2rem);
	box-shadow: 0 30px 60px -20px rgba(0,0,0,0.4);
	animation: mp-fade-in .25s cubic-bezier(.2,.7,.2,1) both;
	text-align: center;
}
.misepress__save-modal-panel h3 {
	margin: 0 0 .5rem; font-family: var(--mp-font-display);
	font-size: 1.3rem; color: var(--mp-color-fg);
}
.misepress__save-modal-panel p {
	margin: 0 0 1.5rem; color: var(--mp-color-muted); font-size: .95rem;
}
.misepress__save-modal-icon {
	width: 56px; height: 56px; margin: 0 auto 1rem;
	display: grid; place-items: center;
	background: var(--mp-color-accent-soft);
	color: var(--mp-color-accent);
	border-radius: 50%;
}
.misepress__save-modal-actions {
	display: flex; flex-direction: column; gap: .6rem;
}
.misepress__save-modal-actions .misepress__btn { width: 100%; justify-content: center; }

/* Favorites page */
.misepress__favorites-page { padding: clamp(1.5rem, 4vw, 3rem) 0; }
.misepress__favorites-empty {
	text-align: center;
	padding: 3rem 1.5rem;
	background: color-mix(in srgb, var(--mp-color-accent) 4%, var(--mp-color-bg));
	border: 1px dashed color-mix(in srgb, var(--mp-color-accent) 25%, var(--mp-color-border));
	border-radius: var(--mp-radius);
}
.misepress__favorites-empty-icon {
	width: 64px; height: 64px; margin: 0 auto 1rem;
	display: grid; place-items: center;
	color: var(--mp-color-accent);
	background: var(--mp-color-accent-soft);
	border-radius: 50%;
}
.misepress__favorites-empty h3 {
	margin: 0 0 .5rem; font-family: var(--mp-font-display); font-size: 1.4rem;
}
.misepress__favorites-empty p { margin: 0 0 1.25rem; color: var(--mp-color-muted); }
.misepress__favorites-count {
	color: var(--mp-color-muted); font-size: .9rem; margin: 0 0 1rem;
}

.misepress__grid { grid-template-columns: repeat(var(--mp-cards-per-row, 4), minmax(0, 1fr)); }
@media (max-width: 980px) { .misepress__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 560px) { .misepress__grid { grid-template-columns: 1fr; } }
.misepress__grid-card { background: var(--mp-card-bg, var(--mp-color-bg, #fff)); color: var(--mp-card-text, var(--mp-color-fg, inherit)); border: 1px solid var(--mp-card-border, var(--mp-color-border, #ececec)); border-radius: var(--mp-card-radius, 12px); box-shadow: var(--mp-card-shadow, 0 2px 8px -2px rgba(0,0,0,.08)); transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease; }
.misepress__grid-card:hover { border-color: var(--mp-card-accent, var(--mp-color-accent, #E85D2A)); transform: translateY(-2px); }
body.mp-card-overlay .misepress .misepress__grid-card { position: relative; overflow: hidden; }
body.mp-card-overlay .misepress .misepress__grid-media { aspect-ratio: 4/5; }
body.mp-card-overlay .misepress .misepress__grid-body { position: absolute; inset: auto 0 0 0; padding: 1.1rem 1rem 1rem; background: linear-gradient(to top, rgba(0,0,0,.92) 0%, rgba(0,0,0,.7) 45%, rgba(0,0,0,0) 100%); color: #fff; }
body.mp-card-overlay .misepress .misepress__grid-title, body.mp-card-overlay .misepress .misepress__grid-excerpt, body.mp-card-overlay .misepress .misepress__grid-meta, body.mp-card-overlay .misepress .misepress__grid-eyebrow { color: #fff; text-shadow: 0 1px 6px rgba(0,0,0,.4); }
body.mp-card-minimal .misepress .misepress__grid-card { background: transparent; border: 0; box-shadow: none; }
body.mp-card-bordered .misepress .misepress__grid-card { border-width: 2px; box-shadow: none; }

/* Filter bar styles */
body.mp-filter-pills .misepress .misepress__filters label, body.mp-filter-pills .misepress .misepress__filters .misepress__filter-chip { border-radius: 999px !important; padding: .35rem .8rem; border: 1px solid var(--mp-filter-accent, var(--mp-color-border, #ddd)); }
body.mp-filter-boxed .misepress .misepress__filters { background: var(--mp-color-bg, #fafafa); padding: 1rem; border-radius: 12px; border: 1px solid var(--mp-color-border, #ececec); }
body.mp-filter-dark .misepress .misepress__filters { background: #1a1a1a; color: #fff; padding: 1rem; border-radius: 8px; }
body.mp-filter-dark .misepress .misepress__filters label { color: #fff; }
body.mp-filter-underline .misepress .misepress__filters { border: 0; padding: 0; }
body.mp-filter-underline .misepress .misepress__filters select, body.mp-filter-underline .misepress .misepress__filters input { border: 0; border-bottom: 2px solid var(--mp-filter-accent, var(--mp-color-accent, #E85D2A)); border-radius: 0; background: transparent; }

/* Nutrition label */
.misepress__nutrition-label { border: 1px solid var(--mp-color-border, #ececec); border-radius: 12px; padding: 1.1rem 1.25rem; background: color-mix(in srgb, var(--mp-color-accent, #E85D2A) 4%, transparent); }
.misepress__nut-grid { display: flex; align-items: center; gap: 1.5rem; flex-wrap: wrap; }
.misepress__nut-cal { display: flex; flex-direction: column; align-items: center; padding-right: 1.25rem; border-right: 1px solid var(--mp-color-border, #ececec); }
.misepress__nut-cal-num { font-size: 2.25rem; font-weight: 800; line-height: 1; color: var(--mp-color-accent, #E85D2A); }
.misepress__nut-cal-lbl { font-size: .75rem; text-transform: uppercase; letter-spacing: .08em; color: var(--mp-color-muted, #6b6b6b); margin-top: .25rem; }
.misepress__nut-macros { list-style: none; margin: 0; padding: 0; display: grid; grid-template-columns: repeat(3, auto); gap: .35rem 1.25rem; font-size: .9rem; }
.misepress__nut-macros li { display: flex; align-items: center; gap: .4rem; }
.misepress__nut-dot { width: 10px; height: 10px; border-radius: 50%; display: inline-block; }
.misepress__nut-dot--p { background: var(--mp-macro-protein, #4f86d6); }
.misepress__nut-dot--c { background: var(--mp-macro-carbs, #f0a83a); }
.misepress__nut-dot--f { background: var(--mp-macro-fat, #d65555); }
.misepress__nut-dot--fib { background: var(--mp-macro-fiber, #6aa84f); }
.misepress__nut-dot--sug { background: var(--mp-macro-sugar, #c27ba0); }
.misepress__nut-dot--sod { background: var(--mp-macro-sodium, #8e7cc3); }
.misepress__nut-dot--sat { background: var(--mp-macro-saturated-fat, #b45f06); }
.misepress__nut-bar { display: flex; height: 8px; border-radius: 999px; overflow: hidden; margin-top: 1rem; background: #eee; }
.misepress__nut-seg--p { background: var(--mp-macro-protein, #4f86d6); }
.misepress__nut-seg--c { background: var(--mp-macro-carbs, #f0a83a); }
.misepress__nut-seg--f { background: var(--mp-macro-fat, #d65555); }
.misepress__nut-source { margin: .75rem 0 0; font-size: .75rem; color: var(--mp-color-muted, #6b6b6b); font-style: italic; }

.misepress__grid-eyebrow { margin: 0 0 .25rem; font-size: .7rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--mp-card-accent, var(--mp-color-accent, #c2410c)); }

/* Ingredient + step checkboxes */
.misepress__ingredient[data-mp-check],
.misepress__step[data-mp-check] { cursor: pointer; user-select: none; transition: opacity .15s ease, color .15s ease; }
.misepress__ingredient[data-mp-check]:focus-visible,
.misepress__step[data-mp-check]:focus-visible { outline: 2px solid var(--mp-color-accent, #c2410c); outline-offset: 2px; border-radius: 4px; }
.misepress__check { display: inline-flex; align-items: center; justify-content: center; width: 18px; height: 18px; margin-right: .65rem; border: 2px solid var(--mp-color-border, #ccc); border-radius: 4px; vertical-align: middle; flex-shrink: 0; transition: all .15s ease; background: transparent; }
.misepress__ingredient[data-mp-check] { display: flex; flex-wrap: wrap; align-items: baseline; gap: 0 .35rem; }
.misepress__ingredient.is-checked,
.misepress__step.is-checked { opacity: .45; }
.misepress__ingredient.is-checked .misepress__ingredient-name,
.misepress__ingredient.is-checked .misepress__ingredient-qty,
.misepress__ingredient.is-checked .misepress__ingredient-unit,
.misepress__step.is-checked .misepress__step-text { text-decoration: line-through; }
.misepress__ingredient.is-checked .misepress__check,
.misepress__step.is-checked .misepress__check { background: var(--mp-color-accent, #c2410c); border-color: var(--mp-color-accent, #c2410c); }
.misepress__ingredient.is-checked .misepress__check::after,
.misepress__step.is-checked .misepress__check::after { content: ''; width: 5px; height: 9px; border-right: 2px solid #fff; border-bottom: 2px solid #fff; transform: rotate(45deg) translate(-1px, -1px); }

.misepress__step[data-mp-check] { position: relative; }
.misepress__step[data-mp-check] .misepress__check { position: absolute; left: -32px; top: .35em; }

/* Kitchen timer */
.misepress__timer-btn { display: inline-flex; align-items: center; gap: .25rem; padding: .15rem .5rem; margin: 0 .15rem; border: 1px solid var(--mp-color-border, #ddd); border-radius: 999px; background: var(--mp-color-accent-soft, #fde7d3); color: var(--mp-color-accent, #c2410c); font: inherit; font-size: .9em; cursor: pointer; line-height: 1.4; transition: all .15s ease; }
.misepress__timer-btn:hover { background: var(--mp-color-accent, #c2410c); color: #fff; }
.misepress__timer-btn.is-running { background: var(--mp-color-accent, #c2410c); color: #fff; font-variant-numeric: tabular-nums; animation: mp-timer-pulse 1s ease-in-out infinite; }
.misepress__timer-btn.is-done { background: #1e7a3c; color: #fff; }
@keyframes mp-timer-pulse { 0%,100% { opacity: 1; } 50% { opacity: .8; } }

/* Unit toggle */
.misepress__ingredients-head { display: flex; align-items: center; justify-content: space-between; gap: 1rem; flex-wrap: wrap; margin-bottom: .75rem; }
.misepress__units { display: inline-flex; gap: 0; border: 1px solid var(--mp-color-border, #ddd); border-radius: 999px; overflow: hidden; padding: 2px; }
.misepress__units-btn { padding: .25rem .75rem; border: 0; background: transparent; cursor: pointer; font: inherit; font-size: .8rem; font-weight: 600; color: var(--mp-color-muted, #6b6b6b); border-radius: 999px; transition: all .15s ease; }
.misepress__units-btn.is-active { background: var(--mp-color-accent, #c2410c); color: #fff; }
.misepress__units-btn:hover:not(.is-active) { color: var(--mp-color-fg, #1a1a1a); }

/* ---------- Shopping list ---------- */
.misepress__shopping { max-width: 820px; margin: 2rem auto; }
.misepress__shopping-head { display:flex; align-items:center; justify-content:space-between; gap:1rem; flex-wrap:wrap; margin-bottom:1.5rem; padding-bottom:1rem; border-bottom:1px solid var(--mp-color-border,#e5e5e5); }
.misepress__shopping-head h2 { margin:0; }
.misepress__shopping-actions { display:flex; gap:.5rem; }
.misepress__shopping-empty { padding:3rem 1rem; text-align:center; color:var(--mp-color-muted,#6b6b6b); border:1px dashed var(--mp-color-border,#e5e5e5); border-radius:12px; }
.misepress__shopping-recipe { background:var(--mp-color-card,#fff); border:1px solid var(--mp-color-border,#e5e5e5); border-radius:12px; padding:1rem 1.25rem; margin-bottom:1rem; }
.misepress__shopping-recipe-head { display:flex; align-items:baseline; gap:.75rem; margin-bottom:.5rem; }
.misepress__shopping-recipe-head h3 { margin:0; flex:1; font-size:1.1rem; }
.misepress__shopping-recipe-head a { color:inherit; text-decoration:none; }
.misepress__shopping-recipe-head a:hover { text-decoration:underline; }
.misepress__shopping-servings { font-size:.85rem; color:var(--mp-color-muted,#6b6b6b); }
.misepress__shopping-remove { border:0; background:transparent; cursor:pointer; font-size:1.4rem; line-height:1; color:var(--mp-color-muted,#6b6b6b); padding:0 .25rem; }
.misepress__shopping-remove:hover { color:#c00; }
.misepress__shopping-items { list-style:none; padding:0; margin:0; }
.misepress__shopping-item { padding:.4rem 0; border-top:1px solid var(--mp-color-border-soft, #f0f0f0); }
.misepress__shopping-item:first-child { border-top:0; }
.misepress__shopping-item label { display:flex; align-items:baseline; gap:.6rem; cursor:pointer; }
.misepress__shopping-item input[type=checkbox] { width:1.05rem; height:1.05rem; flex-shrink:0; }
.misepress__shopping-item.is-checked span { text-decoration:line-through; color:var(--mp-color-muted,#9a9a9a); }
.misepress__shopping-item em { font-style:italic; color:var(--mp-color-muted,#6b6b6b); margin-left:.25rem; }
.misepress__shopping-btn.is-added { background:var(--mp-color-accent,#c2410c); color:#fff; border-color:var(--mp-color-accent,#c2410c); }

/* Toast */
.misepress__toast { position:fixed; left:50%; bottom:2rem; transform:translateX(-50%) translateY(20px); background:#1a1a1a; color:#fff; padding:.75rem 1.25rem; border-radius:999px; font-size:.9rem; opacity:0; pointer-events:none; transition:all .25s ease; z-index:9999; box-shadow:0 8px 24px rgba(0,0,0,.18); }
.misepress__toast.is-visible { opacity:1; transform:translateX(-50%) translateY(0); }

@media print {
	.misepress__shopping-actions, .misepress__shopping-remove { display:none !important; }
	.misepress__shopping-recipe { break-inside:avoid; border:0; padding:0; margin-bottom:1.5rem; }
}

.misepress__nut-head{display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-wrap:wrap}
.misepress__nut-toggle{display:inline-flex;border:1px solid var(--mp-border,#ececec);border-radius:999px;overflow:hidden}
.misepress__nut-mode{background:transparent;border:0;padding:.25rem .75rem;font-size:.85rem;cursor:pointer;color:inherit}
.misepress__nut-mode.is-active{background:var(--mp-accent,#E85D2A);color:#fff}
.misepress__nut-context{font-size:.8rem;color:var(--mp-muted,#6b6b6b);margin:.25rem 0 0}

/* Reviews */
.misepress__reviews-summary{display:grid;grid-template-columns:auto 1fr;gap:1.5rem;margin:.75rem 0 1rem}
.misepress__reviews-score{display:flex;flex-direction:column;align-items:center;gap:.25rem;min-width:6rem}
.misepress__reviews-avg{font-size:2.4rem;font-weight:700;line-height:1}
.misepress__reviews-count{font-size:.85rem;color:var(--mp-muted,#6b6b6b)}
.misepress__reviews-dist{list-style:none;margin:0;padding:0;display:grid;gap:.25rem}
.misepress__reviews-dist li{display:grid;grid-template-columns:auto 1fr auto;gap:.5rem;align-items:center;font-size:.85rem}
.misepress__reviews-dist-bar{display:block;background:#eee;border-radius:999px;height:.5rem;overflow:hidden}
.misepress__reviews-dist-bar span{display:block;height:100%;background:var(--mp-accent,#E85D2A)}
.misepress__stars{display:inline-flex;font-size:var(--mp-star-size,16px);color:#d0d0d0;line-height:1}
.misepress__star.is-full{color:#f5a623}
.misepress__star.is-half{background:linear-gradient(90deg,#f5a623 50%,#d0d0d0 50%);-webkit-background-clip:text;background-clip:text;color:transparent}
.misepress__review-form{display:grid;gap:.5rem;border-top:1px solid var(--mp-border,#ececec);padding-top:.75rem;margin:.5rem 0}
.misepress__review-stars-input{display:inline-flex;gap:.15rem}
.misepress__star-btn{background:none;border:0;font-size:1.5rem;color:#d0d0d0;cursor:pointer;padding:0 .15rem;line-height:1}
.misepress__star-btn.is-active,.misepress__star-btn:hover{color:#f5a623}
.misepress__review-row{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}
.misepress__review-row label,.misepress__review-comment-label{display:grid;gap:.25rem;font-size:.85rem}
.misepress__review-row input,.misepress__review-comment-label textarea{padding:.4rem .55rem;border:1px solid var(--mp-border,#ececec);border-radius:6px;font:inherit}
.misepress__reviews-list{list-style:none;margin:1rem 0 0;padding:0;display:grid;gap:.75rem}
.misepress__review{padding:.75rem;border:1px solid var(--mp-border,#ececec);border-radius:8px}
.misepress__review-head{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap;margin-bottom:.25rem}
.misepress__review-date{font-size:.8rem;color:var(--mp-muted,#6b6b6b);margin-left:auto}

/* Videos */
.misepress__video{margin:0;position:relative;border-radius:12px;overflow:hidden;background:#000}
.misepress__video--html5 video{display:block;width:100%;height:auto}
.misepress__video--lite{aspect-ratio:16/9;background-size:cover;background-position:center;cursor:pointer;display:block}
.misepress__video--lite iframe{width:100%;height:100%;border:0;display:block}
.misepress__video-play{
	appearance:none;
	-webkit-appearance:none;
	position:absolute;
	top:50%;
	left:50%;
	right:auto;
	bottom:auto;
	z-index:2;
	width:clamp(3.5rem,7vw,4.75rem);
	height:clamp(3.5rem,7vw,4.75rem);
	min-width:0;
	min-height:0;
	margin:0;
	padding:0;
	border:1px solid rgba(255,255,255,.42);
	border:1px solid color-mix(in srgb,#fff 42%,transparent);
	border-radius:999px;
	background:var(--mp-color-accent,#c2410c);
	background:color-mix(in srgb,var(--mp-color-accent,#c2410c) 88%,#111);
	color:#fff;
	box-shadow:0 16px 42px rgba(0,0,0,.24);
	cursor:pointer;
	display:inline-flex;
	align-items:center;
	justify-content:center;
	line-height:1;
	overflow:hidden;
	transform:translate(-50%,-50%);
	transition:background var(--mp-transition),box-shadow var(--mp-transition),transform var(--mp-transition);
}
.misepress__video-play:hover{background:var(--mp-color-accent,#c2410c);box-shadow:0 18px 48px rgba(0,0,0,.3);transform:translate(-50%,-50%) scale(1.04)}
.misepress__video-play::before{
	content:"";
	display:block;
	width:0;
	height:0;
	margin-left:.28rem;
	border-top:.72rem solid transparent;
	border-bottom:.72rem solid transparent;
	border-left:1.05rem solid currentColor;
	pointer-events:none;
}
.misepress__video-play-icon{display:none!important}
.misepress__video-play span:not(.misepress__video-play-icon),
.misepress__video-play img.emoji{
	display:none!important;
	width:0!important;
	height:0!important;
	max-width:0!important;
	max-height:0!important;
}
.misepress__video--step{aspect-ratio:16/9;max-width:480px;margin-top:.5rem}
.misepress__video--gif img,.misepress__video--image img{display:block;width:100%;height:auto}

.misepress__recommended-reason{font-size:.85rem;color:var(--mp-muted,#6b6b6b);margin:0 0 .75rem}

/* ============================================================
 * ============================================================ */
/* Inside Bricks/Gutenberg builders the recipe title-actions row can wrap
 * awkwardly at very narrow column widths. Stack title + actions vertically
 * under 480px so save/print buttons don't push out of the canvas. */
@media (max-width: 480px) {
	.misepress__title-row { flex-direction: column; align-items: flex-start; gap: var(--mp-s-2, .75rem); }
	.misepress__title-actions { flex-wrap: wrap; }
	.misepress__recipe { padding: var(--mp-space-2); }
}
/* Block themes set max-width: var(--wp--style--global--content-size) on
 * .entry-content, which can squeeze our archive/single layouts. Opt out
 * for full-width MisePress chrome while still respecting body padding. */
.wp-site-blocks .misepress__archive,
.wp-site-blocks .misepress__recipe { max-width: none; }
/* Defensive: when ACSS sets `.section-content { max-width }` to a small value,
 * still allow our 2-col recipe body to use the full available width. */
.misepress__recipe .misepress__body { max-width: none; }
/* Ensure cards inside Bricks containers shrink instead of overflow. */
.brxe-container .misepress__grid > *,
.brxe-container .misepress__editorial > * { min-width: 0; }

.misepress-page--recipe { --mp-single-section-gap: 2rem; }
.misepress-page--recipe .misepress__section + .misepress__section,
.misepress-page--recipe .misepress__main > .misepress__section + .misepress__section,
.misepress-page--recipe .misepress__aside > .misepress__section + .misepress__section { margin-top: var(--mp-single-section-gap); }
/* Keep mobile single recipes compact without letting sections collide. */
@media (max-width: 600px){
	.misepress-page--recipe { --mp-single-section-gap: 1.75rem; }
	.misepress-page--recipe .misepress__main { gap: 1.75rem; }
	.misepress-page--recipe .misepress__section + .misepress__section { margin-top: var(--mp-single-section-gap); }
	.misepress-page--recipe .misepress__heading { margin: 0 0 0.8rem; }
	.misepress-page--recipe .misepress__allergens,
	.misepress-page--recipe .misepress__ingredients,
	.misepress-page--recipe .misepress__steps { margin-bottom: 0; }
	.misepress-page--recipe .misepress__steps { gap: 0.85rem; }
	.misepress-page--recipe .misepress__step { padding-block: 0.55rem; }
	.misepress-page--recipe .misepress__recipe.mp-has-step-check .misepress__step { padding-left: 2.35rem; }
	.misepress-page--recipe .misepress__step[data-mp-check] .misepress__check { left: 0.15rem; top: 0.65rem; }
}
/* Body layout variants */
.misepress-single--layout-stacked .misepress__body { display: block; }
.misepress-single--layout-stacked .misepress__aside { width: 100%; margin-bottom: var(--mp-single-section-gap); }
.misepress-single--layout-two-col .misepress__body { display: grid; grid-template-columns: 1fr 1fr; gap: var(--mp-single-section-gap); }
@media (max-width: 760px){ .misepress-single--layout-two-col .misepress__body { grid-template-columns: 1fr; } }
/* Image styles */
.misepress__recipe.mp-img-full-bleed .misepress__media { margin-inline: calc(50% - 50vw); border-radius: 0; }
.misepress__recipe.mp-img-contained .misepress__media img { border-radius: var(--mp-radius); overflow: hidden; }
.misepress__recipe.mp-img-hero-overlay .misepress__media { position: relative; }
.misepress__recipe.mp-img-hero-overlay .misepress__media::after { content:""; position:absolute; inset:0; background: linear-gradient(180deg, transparent 40%, rgba(0,0,0,.55)); border-radius: inherit; pointer-events:none; }
.misepress__recipe.mp-img-hero-overlay .misepress__title { position:relative; margin-top:-3rem; color:#fff; padding:0 1rem; z-index:1; }
.misepress__recipe.mp-img-side .misepress__header { display:grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; align-items:center; }
@media (max-width: 760px){ .misepress__recipe.mp-img-side .misepress__header { grid-template-columns: 1fr; } }
/* Image ratios */
.misepress__recipe.mp-ratio-16-9 .misepress__media img,
.misepress__recipe.mp-ratio-4-3 .misepress__media img,
.misepress__recipe.mp-ratio-3-2 .misepress__media img,
.misepress__recipe.mp-ratio-1-1 .misepress__media img,
.misepress__recipe.mp-ratio-21-9 .misepress__media img { width:100%; height:100%; object-fit: cover; display:block; }
.misepress__recipe.mp-ratio-16-9 .misepress__media { aspect-ratio: 16/9; }
.misepress__recipe.mp-ratio-4-3  .misepress__media { aspect-ratio: 4/3; }
.misepress__recipe.mp-ratio-3-2  .misepress__media { aspect-ratio: 3/2; }
.misepress__recipe.mp-ratio-1-1  .misepress__media { aspect-ratio: 1/1; }
.misepress__recipe.mp-ratio-21-9 .misepress__media { aspect-ratio: 21/9; }
/* Template variants */
.misepress-page--magazine .misepress__title { font-size: clamp(2rem, 5vw, 3.5rem); }
.misepress-page--compact .misepress__recipe { gap: var(--mp-space-2); padding: var(--mp-space-2); }
.misepress-page--compact .misepress__heading { font-size: 1.15rem; }
.misepress-page--centered .misepress-page__inner { text-align: center; }
.misepress-page--centered .misepress__ingredients,
.misepress-page--centered .misepress__steps { text-align: left; }
.misepress-page--minimalist .misepress__recipe { background: transparent; box-shadow: none; padding: 0; }
.misepress-page--minimalist .misepress__step { background: transparent; padding-left: calc(2rem + var(--mp-space-2)); border-left: 2px solid var(--mp-color-border); border-radius: 0; }
/* More breathing room when checkboxes are on */
.misepress__recipe.mp-has-ing-check .misepress__ingredient { margin-bottom: 0.95rem; padding: .35rem .25rem; }
.misepress__recipe.mp-has-ing-check .misepress__ingredient + .misepress__ingredient { border-top: 1px solid color-mix(in srgb, var(--mp-color-border) 60%, transparent); }
.misepress__recipe.mp-has-step-check .misepress__steps { gap: calc(var(--mp-space-2) + .5rem); }
.misepress__recipe.mp-has-step-check .misepress__step { padding-block: calc(var(--mp-space-2) + .25rem); }

/* Tabs (Recipe / Equipment / Reviews) */
.misepress__tabs { display:flex; gap:.5rem; flex-wrap:wrap; border-bottom:1px solid var(--mp-color-border, #ececec); margin: 1rem 0 1.25rem; padding-bottom:.25rem; }
.misepress__tab { background:transparent; border:0; padding:.65rem 1.1rem; font: inherit; font-weight:600; cursor:pointer; color: var(--mp-color-muted, #6b6b6b); border-radius:8px 8px 0 0; border-bottom:2px solid transparent; margin-bottom:-1px; }
.misepress__tab:hover { color: var(--mp-color-fg, #1a1a1a); }
.misepress__tab.is-active { color: var(--mp-color-accent, #E85D2A); border-bottom-color: var(--mp-color-accent, #E85D2A); }
.misepress__tab-panel[hidden] { display:none !important; }
.misepress__tab-loader { padding:2rem 0; text-align:center; color: var(--mp-color-muted, #6b6b6b); }

/* Equipment list */
.misepress__section--equipment .misepress__equipment { list-style:none; padding:0; margin:0; display:grid; gap:.6rem; }
.misepress__equipment-item { padding:.6rem .8rem; background: color-mix(in srgb, var(--mp-color-accent-soft, #fde7d3) 35%, transparent); border-radius:8px; }
.misepress__equipment-note { color: var(--mp-color-muted, #6b6b6b); font-size:.92em; }

/* ============================================================
 * ============================================================ */
/* Hover-overlay card: details revealed over the image on desktop hover */
.misepress__grid-card--hover-overlay { position: relative; overflow: hidden; }
.misepress__grid-card--hover-overlay .misepress__grid-link { display: block; position: relative; }
.misepress__grid-card--hover-overlay .misepress__grid-media { aspect-ratio: 4/5; margin: 0; }
.misepress__grid-card--hover-overlay .misepress__grid-media img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .5s ease; }
.misepress__grid-card--hover-overlay .misepress__grid-body {
	position: absolute; inset: 0; display: flex; flex-direction: column; justify-content: flex-end;
	padding: 1rem 1.1rem 1.15rem;
	background: linear-gradient(180deg, rgba(0,0,0,0) 30%, rgba(0,0,0,.55) 75%, rgba(0,0,0,.85));
	color: #fff; opacity: 0; transition: opacity .25s ease;
}
.misepress__grid-card--hover-overlay .misepress__grid-eyebrow {
	position: absolute; top: .9rem; left: .9rem;
	margin: 0; padding: .3rem .65rem;
	background: rgba(255,255,255,.92); color: #1a1a1a;
	border-radius: 999px; font-size: .68rem; opacity: 1;
}
.misepress__grid-card--hover-overlay .misepress__grid-title,
.misepress__grid-card--hover-overlay .misepress__grid-excerpt { color: #fff; }
.misepress__grid-card--hover-overlay .misepress__grid-title { margin: 0 0 .35rem; font-size: 1.1rem; line-height: 1.25; }
.misepress__grid-card--hover-overlay .misepress__grid-meta { list-style: none; padding: 0; margin: .25rem 0 0; display: flex; flex-wrap: wrap; gap: .9rem; font-size: .82rem; color: rgba(255,255,255,.92); }
.misepress__grid-card--hover-overlay .misepress__grid-meta li { display: inline-flex; align-items: center; gap: .3rem; }
.misepress__grid-card--hover-overlay .misepress__save-btn {
	position: absolute; top: .65rem; right: .65rem;
	background: rgba(255,255,255,.94); border-radius: 999px; width: 36px; height: 36px;
	display: inline-flex; align-items: center; justify-content: center; border: 0; box-shadow: 0 2px 6px rgba(0,0,0,.15);
}
@media (hover: hover) and (min-width: 700px) {
	.misepress__grid-card--hover-overlay:hover .misepress__grid-body,
	.misepress__grid-card--hover-overlay:focus-within .misepress__grid-body { opacity: 1; }
	.misepress__grid-card--hover-overlay:hover .misepress__grid-media img { transform: scale(1.04); }
	.misepress__grid-card--hover-overlay:hover .misepress__grid-eyebrow { opacity: 0; }
}
@media (hover: none), (max-width: 699px) {
	.misepress__grid-card--hover-overlay .misepress__grid-body { opacity: 1; position: absolute; }
}

/* Single recipe — prevent layout breakage from full-bleed in constrained containers */
.misepress-page--single { overflow-x: clip; }
.misepress-page--single .misepress__recipe { max-width: 100%; }
.misepress__recipe.mp-img-full-bleed .misepress__media {
	margin-inline: calc(50% - min(50vw, var(--mp-single-max-w, 960px) / 2 + 50vw));
}
/* Builder-safe fallback: when ancestor has overflow-hidden the negative margin won't escape, so cap it */
.brxe-container .misepress__recipe.mp-img-full-bleed .misepress__media,
.entry-content .misepress__recipe.mp-img-full-bleed .misepress__media,
.wp-block-post-content .misepress__recipe.mp-img-full-bleed .misepress__media { margin-inline: 0; }

/* Hero overlay — make the title legible and properly composited above the image */
.misepress__recipe.mp-img-hero-overlay .misepress__header { position: relative; padding: 0; }
.misepress__recipe.mp-img-hero-overlay .misepress__media { position: relative; overflow: hidden; border-radius: var(--mp-radius, 12px); aspect-ratio: 16/9; }
.misepress__recipe.mp-img-hero-overlay .misepress__media img { width:100%; height:100%; object-fit: cover; display:block; }
.misepress__recipe.mp-img-hero-overlay .misepress__media::after {
	content: ""; position: absolute; inset: 0;
	background: linear-gradient(180deg, rgba(0,0,0,0) 35%, rgba(0,0,0,.65) 100%);
	pointer-events: none;
}
.misepress__recipe.mp-img-hero-overlay .misepress__title-row {
	position: absolute; left: 0; right: 0; bottom: 0;
	margin: 0; padding: 1.5rem 1.5rem 1.25rem;
	display: flex; align-items: flex-end; justify-content: space-between; gap: 1rem; flex-wrap: wrap;
	z-index: 2;
}
.misepress__recipe.mp-img-hero-overlay .misepress__title { color: #fff; margin: 0; text-shadow: 0 2px 14px rgba(0,0,0,.45); }
.misepress__recipe.mp-img-hero-overlay .misepress__excerpt { color: #fff; padding: 0 1.5rem 1.25rem; margin-top: -.25rem; text-shadow: 0 2px 12px rgba(0,0,0,.4); position: relative; z-index: 2; }
.misepress__recipe.mp-img-hero-overlay .misepress__title-actions .misepress__btn,
.misepress__recipe.mp-img-hero-overlay .misepress__title-actions .misepress__save-btn {
	background: rgba(255,255,255,.92); color: #1a1a1a; border-color: transparent;
}
@media (max-width: 600px) {
	.misepress__recipe.mp-img-hero-overlay .misepress__media { aspect-ratio: 4/5; }
	.misepress__recipe.mp-img-hero-overlay .misepress__title { font-size: 1.4rem; }
}

/* Smart Feed — variants from settings (position / icon-only / hover trigger / colors / size) */
.mp-feed--bottom-right { top: auto; bottom: 18px; right: 18px; }
.mp-feed--bottom-left  { top: auto; bottom: 18px; left: 18px; right: auto; }
.mp-feed--top-left     { top: 18px; left: 18px; right: auto; }
.mp-feed--top-right    { top: 18px; right: 18px; }
.mp-feed--inline       { position: static; display: inline-flex; }
body.admin-bar .mp-feed--top-left,
body.admin-bar .mp-feed--top-right { top: calc(var(--wp-admin--admin-bar--height, 32px) + 18px); }
.mp-feed--icon-only .mp-feed__bell { background: transparent; border: 0; box-shadow: none; }
.mp-feed--minimal .mp-feed__bell { background: transparent; border: 0; box-shadow: none; color: var(--mp-feed-color, currentColor); }
.mp-feed--pill .mp-feed__bell { width: auto; padding: 0 .9rem; gap: .4rem; border-radius: 999px; }
.mp-feed--square .mp-feed__bell { border-radius: 8px; }
.mp-feed--sm .mp-feed__bell { width: 32px; height: 32px; }
.mp-feed--lg .mp-feed__bell { width: 48px; height: 48px; }
.mp-feed--lg .mp-feed__bell svg { width: 24px; height: 24px; }
.mp-feed__bell { color: var(--mp-feed-color, #1a1a1a); background: var(--mp-feed-bg, #fff); }
.mp-feed__badge { background: var(--mp-feed-accent, var(--mp-accent, #1a1a1a)); }

.misepress__submit-recipe { display: grid; gap: 1rem; max-width: 720px; }
.misepress__submit-recipe .misepress__field { display: grid; gap: .35rem; }
.misepress__submit-recipe .misepress__field label { font-weight: 600; font-size: .9rem; }
.misepress__submit-recipe input[type=text],
.misepress__submit-recipe input[type=url],
.misepress__submit-recipe input[type=email],
.misepress__submit-recipe input[type=number],
.misepress__submit-recipe textarea,
.misepress__submit-recipe select { width: 100%; padding: .6rem .75rem; border: 1px solid #d9d9d9; border-radius: 8px; font: inherit; background: #fff; }
.misepress__submit-recipe textarea { resize: vertical; }
.misepress__submit-recipe .misepress__row { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 1rem; }
.misepress__submit-recipe--two-column { max-width: 920px; }
.misepress__submit-recipe--two-column { grid-template-columns: 1fr 1fr; column-gap: 1.25rem; }
.misepress__submit-recipe--two-column .misepress__row,
.misepress__submit-recipe--two-column .misepress__field--actions,
.misepress__submit-recipe--two-column .misepress__submit-help { grid-column: 1 / -1; }
.misepress__submit-recipe--compact { gap: .6rem; max-width: 600px; }
.misepress__submit-recipe--compact input,
.misepress__submit-recipe--compact textarea,
.misepress__submit-recipe--compact select { padding: .45rem .6rem; }
.misepress__submit-intro { max-width: 720px; margin: 0 0 1rem; color: #555; }
.misepress__submit-success { padding: 1rem 1.25rem; border-radius: 10px; background: #f1faf3; border: 1px solid #cfe9d6; color: #1a6f2e; }
@media (max-width: 640px) {
	.misepress__submit-recipe .misepress__row,
	.misepress__submit-recipe--two-column { grid-template-columns: 1fr; }
}

/* =====================================================================
 * Automatic.css (ACSS) bridge
 * When the ACSS module is enabled, MisePress's whole token system maps
 * to the user's ACSS palette/scale so the entire plugin inherits the
 * site's design system. Users opt out by toggling the ACSS module off.
 * ===================================================================== */
.misepress.misepress-acss {
	--mp-color-accent:        var(--action, #c2410c);
	--mp-color-accent-active: var(--action-ultra-dark, var(--action-dark, color-mix(in srgb, var(--action, #c2410c) 22%, #000)));
	--mp-color-accent-contrast: var(--action-ultra-light, #fff);
	--mp-color-accent-soft:   var(--action-light-trans-90, rgba(194, 65, 12, .1));
	--mp-color-bg:            var(--base-ultra-light, #fffdf8);
	--mp-color-fg:            var(--base-ultra-dark, #1a1a1a);
	--mp-color-muted:         var(--base, #6b6b6b);
	--mp-color-border:        var(--base-light, #ececec);
	--mp-color-allergen-bg:   var(--action-light-trans-90, rgba(194, 65, 12, .1));
	--mp-color-allergen-fg:   var(--action-dark, color-mix(in srgb, var(--action, #c2410c) 35%, #000));
	--mp-card-bg:             var(--base-ultra-light, #fffdf8);
	--mp-card-accent:         var(--action, #c2410c);
	--mp-filter-accent:       var(--action, #c2410c);
	--mp-radius:              var(--radius-m, var(--mp-radius));
	--mp-radius-sm:           var(--radius-s, var(--mp-radius-sm));
	--mp-shadow-xs:           var(--shadow-xs, var(--mp-shadow-xs));
	--mp-shadow-sm:           var(--shadow-s, var(--mp-shadow-sm));
	--mp-shadow:              var(--shadow-m, var(--mp-shadow));
	--mp-shadow-md:           var(--shadow-l, var(--mp-shadow-md));
	--mp-shadow-lg:           var(--shadow-xl, var(--mp-shadow-lg));
	--mp-focus-ring:          var(--action, var(--mp-focus-ring));
	/* Smart feed bell tokens — keep in sync with the rest of MisePress. */
	--mp-feed-bg:             var(--base-ultra-light, var(--mp-color-bg));
	--mp-feed-color:          var(--base-ultra-dark, var(--mp-color-fg));
	--mp-feed-accent:         var(--action, var(--mp-color-accent));
}

/* ACSS — active controls use a dedicated dark action token, not the raw action color.
   This keeps density/layout/step numbers readable even when --action is pastel/light. */
.misepress.misepress-acss .misepress__density-btn.is-active,
.misepress.misepress-acss .misepress__preset.is-active,
.misepress.misepress-acss .misepress__units-btn.is-active,
.misepress.misepress-acss .misepress__nut-mode.is-active,
.misepress.misepress-acss .misepress__scale-pill.is-active {
	background: var(--mp-color-accent-active) !important;
	border-color: var(--mp-color-accent-active) !important;
	color: var(--mp-color-accent-contrast) !important;
}
.misepress.misepress-acss .misepress__tab.is-active {
	color: var(--mp-color-accent-active);
	border-bottom-color: var(--mp-color-accent-active);
}
.misepress.misepress-acss .misepress__filter-opt:has(input:checked),
.misepress.misepress-acss .misepress__filter-opt--icon:has(input:checked) {
	border-color: var(--mp-color-accent-active);
	color: var(--mp-color-accent-active);
	background: var(--action-light-trans-80, var(--action-light-trans-90, var(--mp-color-accent-soft)));
}
.misepress.misepress-acss .misepress__filter-opt input[type="checkbox"],
.misepress.misepress-acss .misepress__filter-opt input[type="radio"] {
	accent-color: var(--action-dark, var(--action, var(--mp-filter-accent)));
}
.misepress.misepress-acss .misepress__chip {
	color: var(--mp-color-accent-active);
	background: var(--action-light-trans-80, var(--action-light-trans-90, var(--mp-color-accent-soft)));
}
/* Step number circles — guarantee strong contrast (white text on a deep accent) under ACSS,
   even when --action is a soft/light pastel. */
.misepress.misepress-acss .misepress__step::before {
	background: var(--mp-color-accent-active) !important;
	color: var(--mp-color-accent-contrast) !important;
}
/* Non-ACSS fallback for step numbers — make sure they're never washed out either */
.misepress__step::before {
	background: var(--mp-step-number-bg, var(--mp-color-accent-active, var(--mp-color-accent)));
	color: #fff;
}
/* Titles and headings: inherit ACSS base color when user hasn't set custom typography colors */
.misepress.misepress-acss .misepress__title,
.misepress.misepress-acss .misepress__heading,
.misepress.misepress-acss .misepress__archive-title {
	color: var(--base-ultra-dark, var(--mp-color-fg));
}
/* Borders: take ACSS base-light when user hasn't set a custom border color */
.misepress.misepress-acss .misepress__grid-card,
.misepress.misepress-acss .misepress__filters,
.misepress.misepress-acss .misepress__active-chips {
	border-color: var(--base-light, var(--mp-color-border));
}
/* Filter sidebar scroll behaviour controlled by setting (default off => natural height) */
@media (min-width: 901px) {
	.mp-filter-scroll-internal.misepress__archive--filters-sidebar-left .misepress__filters,
	.mp-filter-scroll-internal.misepress__archive--filters-sidebar-right .misepress__filters {
		max-height: calc(100vh - var(--mp-sticky-offset, 80px) - 2rem);
		overflow-y: auto;
	}
	.mp-filter-scroll-page.misepress__archive--filters-sidebar-left .misepress__filters,
	.mp-filter-scroll-page.misepress__archive--filters-sidebar-right .misepress__filters {
		max-height: none;
		overflow: visible;
	}
}

/* ============================================================
 * ============================================================ */
.misepress__filter-mobile-bar-actions { display: flex; align-items: center; gap: 0.4rem; }
.misepress__filter-mobile-reset {
	appearance: none; background: none; border: 0;
	color: var(--mp-color-accent, #c2410c);
	font-size: 0.9rem; font-weight: 500;
	padding: 0.45rem 0.6rem; border-radius: 8px;
	cursor: pointer;
}
.misepress__filter-mobile-reset:hover {
	background: var(--mp-color-accent-soft, rgba(194,65,12,.08));
}

/* Single recipe mobile spacing fix — kill theme h2 line-height bleed
   and tighten the gap between aside (ingredients/allergens) and main (instructions). */
@media (max-width: 760px) {
	.misepress-page--recipe {
		padding-block: 0.75rem;
	}
	.misepress-page--recipe .misepress__recipe {
		gap: 0.85rem;
	}
	.misepress-page--recipe .misepress__header {
		display: grid;
		gap: 0.65rem;
	}
	.misepress-page--recipe .misepress__meta {
		gap: 0.65rem;
		padding-block: 0.65rem;
	}
	.misepress-page--recipe .misepress__heading {
		line-height: 1.15;
		margin: 0 0 1rem;
	}
	.misepress-page--recipe .misepress__section { margin-block: 0 !important; }
	.misepress-page--recipe .misepress__aside:empty { display: none; }
	.misepress-single--layout-stacked .misepress__aside {
		margin-bottom: 0.7rem;
	}
	.misepress-page--recipe .misepress__main { gap: 0.7rem; }
	.misepress-page--recipe .misepress__body { gap: 0; }
	.misepress-page--recipe .misepress__recipe.mp-has-step-check .misepress__steps,
	.misepress-page--recipe .misepress__steps { gap: 0.35rem; }
	.misepress-page--recipe .misepress__recipe.mp-has-step-check .misepress__step,
	.misepress-page--recipe .misepress__step {
		min-height: 0;
		padding-block: 0.45rem;
	}
	.misepress-page--recipe .misepress__recipe.mp-has-ing-check .misepress__ingredient {
		margin-bottom: 0.35rem;
		padding-block: 0.2rem;
	}
	.misepress-page--recipe .misepress__ingredients-head { margin-bottom: 0.45rem; }
	.misepress-page--recipe .misepress__scale { margin-top: 0.6rem; padding-top: 0.6rem; }
	/* Clamp any aspect-ratio'd empty media containers on mobile */
	.misepress-page--recipe .misepress__media:empty { display: none; }
}

/* ---------- Custom (pantry) scale panel ---------- */
.misepress__scale-pantry {
	margin-top: 0.75rem;
	padding: 0.85rem 1rem;
	border: 1px solid var(--mp-color-border, rgba(0,0,0,.08));
	border-radius: 12px;
	background: color-mix(in srgb, var(--mp-color-accent, #E85D2A) 4%, transparent);
}
.misepress__scale-pantry[hidden] { display: none; }
.misepress__scale-pantry-help {
	margin: 0 0 0.6rem;
	font-size: 0.85rem;
	color: color-mix(in srgb, var(--mp-color-fg, #1a1a1a) 70%, transparent);
}
.misepress__scale-pantry-row {
	display: flex; gap: 0.6rem; align-items: flex-end; flex-wrap: wrap;
}
.misepress__scale-pantry-field {
	display: flex; flex-direction: column; gap: 0.25rem; flex: 1 1 140px; min-width: 120px;
	font-size: 0.8rem; font-weight: 600;
	color: color-mix(in srgb, var(--mp-color-fg, #1a1a1a) 70%, transparent);
	text-transform: uppercase; letter-spacing: 0.04em;
}
.misepress__scale-pantry-field input,
.misepress__scale-pantry-field select {
	box-sizing: border-box;
	min-height: 40px;
	padding: 0.5rem 0.7rem;
	border: 1px solid var(--mp-color-border, rgba(0,0,0,.14));
	border-radius: 8px;
	background: var(--mp-color-bg, #fff);
	font-size: 0.95rem;
	font-weight: 400;
	color: var(--mp-color-fg, #1a1a1a);
	text-transform: none; letter-spacing: 0;
}
.misepress__scale-pantry-go {
	min-height: 40px;
	padding: 0 1rem;
	border: 0; border-radius: 8px;
	background: var(--mp-color-accent, #E85D2A);
	color: #fff;
	font-weight: 600;
	cursor: pointer;
}
.misepress__scale-pantry-go:hover { filter: brightness(1.05); }
.misepress__scale-pantry-feedback {
	margin: 0.6rem 0 0; font-size: 0.85rem;
	color: var(--mp-color-accent, #E85D2A);
}
.misepress__scale-pill--more.is-active {
	background: var(--mp-color-accent, #E85D2A);
	color: #fff;
}

/* ---------- Single-recipe mobile: card-style sections so each block
   reads as a clearly separated unit, with tight heading→content rhythm. ---------- */
@media (max-width: 760px) {
	.misepress-page--recipe { --mp-single-section-gap: 0.9rem !important; }
	.misepress-page--recipe .misepress__main { gap: var(--mp-single-section-gap) !important; }

	/* Each section becomes a soft card */
	.misepress-page--recipe .misepress__section {
		background: var(--mp-color-surface, #fff);
		border: 1px solid var(--mp-color-border, rgba(0,0,0,.08));
		border-radius: 14px;
		padding: 1rem 1rem 1.1rem !important;
		margin: 0 !important;
		box-shadow: 0 1px 2px rgba(0,0,0,.03);
	}
	.misepress-page--recipe .misepress__section + .misepress__section {
		margin-top: var(--mp-single-section-gap) !important;
	}

	/* Tight heading→content gap inside the card */
	.misepress-page--recipe .misepress__heading {
		font-size: clamp(1.25rem, 4.5vw, 1.55rem) !important;
		margin: 0 0 0.55rem !important;
		line-height: 1.2 !important;
		text-align: left !important;
	}
	.misepress-page--recipe .misepress__ingredients-head { margin-bottom: 0.55rem !important; }
	.misepress-page--recipe .misepress__ingredients,
	.misepress-page--recipe .misepress__allergens,
	.misepress-page--recipe .misepress__steps,
	.misepress-page--recipe .misepress__notes,
	.misepress-page--recipe .misepress__story { margin: 0 !important; padding: 0 !important; }

	/* Allergens left-aligned chips, not floating in center */
	.misepress-page--recipe .misepress__allergens {
		display: flex; flex-wrap: wrap; gap: 0.4rem; justify-content: flex-start;
	}

	/* Scale row sits inside ingredients card */
	.misepress-page--recipe .misepress__scale {
		margin-top: 0.75rem !important;
		padding-top: 0.65rem !important;
		border-top: 1px solid var(--mp-color-border, rgba(0,0,0,.08));
	}

	/* Nutrition card already has its own background — flatten the double frame */
	.misepress-page--recipe .misepress__nutrition-label {
		padding: 0.9rem 1rem;
	}

	.misepress-page--recipe .misepress__reviews,
	.misepress-page--recipe .misepress__related { margin-top: var(--mp-single-section-gap) !important; }
}

/* All vars are optional — when not set by the inline override, the natural
   stylesheet value (or your theme / Automatic.css) wins. ACSS users can
   override these vars in :root or use their own utilities; the selectors
   below are intentionally low-specificity so ACSS classes always trump. */
/* Use !important so per-area overrides win against later in-file selectors
   (e.g. .misepress-page--single .misepress__title) and theme/ACSS rules. */
.misepress { font-size: var(--mp-font-size-base, inherit); }
.misepress .misepress__card-title,
.misepress .misepress__recipe-card__title,
.misepress .misepress__grid-title,
.misepress .misepress__editorial-title,
.misepress .misepress__row-title { font-size: var(--mp-font-size-card-title, 1rem); }
.misepress .misepress__card-meta,
.misepress .misepress__recipe-card__meta,
.misepress .misepress__grid-meta,
.misepress .misepress__editorial-meta,
.misepress .misepress__row-meta { font-size: var(--mp-font-size-card-meta, .85rem); }
.misepress .misepress__archive-title { font-size: var(--mp-font-size-archive-h1, 2rem); }
.misepress .misepress-page--single .misepress__title,
.misepress .misepress__title { font-size: var(--mp-font-size-single-h1, inherit); }
.misepress .misepress-page--single .misepress__story,
.misepress .misepress-page--single .misepress__notes,
.misepress .misepress__story,
.misepress .misepress__notes { font-size: var(--mp-font-size-single-body, inherit); }
.misepress .misepress-page--single .misepress__step,
.misepress .misepress__step { font-size: var(--mp-font-size-step, inherit); }
.misepress .misepress-page--single .misepress__ingredient,
.misepress .misepress__ingredients li { font-size: var(--mp-font-size-ingredient, inherit); }
.misepress .misepress__filter-form,
.misepress .misepress__filter-group,
.misepress .misepress__filter-opt { font-size: var(--mp-font-size-filter, inherit); }
.misepress .misepress__search-input,
.misepress .misepress__search-input::placeholder { font-size: var(--mp-font-size-search-input, .9rem); }

/* Auto-height filter group: kill the inner scroll. */
.misepress__filter-group--auto .misepress__filter-opts { max-height: none !important; overflow: visible !important; }
/* Load-more behaviour for long filter groups (set via JS data attribute). */
.misepress__filter-group[data-mp-collapsed="1"] .misepress__filter-opt[data-mp-hidden="1"] { display: none; }
.misepress__filter-loadmore {
	margin-top: .35rem;
	background: none; border: 0; padding: .25rem .5rem;
	color: var(--mp-color-accent); font-size: .85rem; cursor: pointer; font-weight: 600;
}
.misepress__filter-loadmore:hover { text-decoration: underline; }

/* Pagination — better-looking, centered, ACSS-overridable. */
.misepress__pagination { margin: 1.5rem 0; display: flex; justify-content: center; }
.misepress__pagination .nav-links,
.misepress__pagination .pagination { display: inline-flex; flex-wrap: wrap; gap: .35rem; align-items: center; }
.misepress__pagination .page-numbers {
	min-width: 2.25rem; height: 2.25rem; padding: 0 .65rem;
	display: inline-flex; align-items: center; justify-content: center;
	border-radius: var(--mp-radius-sm);
	border: 1px solid var(--mp-color-border);
	background: var(--mp-color-bg);
	color: var(--mp-color-fg);
	text-decoration: none; font-weight: 600; font-size: .9rem;
	transition: var(--mp-transition);
}
.misepress__pagination .page-numbers:hover { background: var(--mp-color-accent-soft); border-color: var(--mp-color-accent); }
.misepress__pagination .page-numbers.current { background: var(--mp-color-accent); color: #fff; border-color: var(--mp-color-accent); }
.misepress__pagination .page-numbers.dots { border: 0; background: transparent; }

/* ============================================================
 * Tighter, neater defaults; smarter image ratios; richer
 * meta strip; cleaner typography rhythm. ACSS borders/colors
 * inherit unless the user has explicitly set them via settings.
 * ============================================================ */
.misepress-page--single .misepress__recipe {
	padding: clamp(1rem, 2.5vw, 1.75rem);
	gap: clamp(1rem, 2vw, 1.5rem);
}
.misepress-page--single .misepress__media {
	border-radius: var(--mp-radius);
	overflow: hidden;
	margin: 0;
}
.misepress-page--single .misepress__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	border-radius: 0;
}
/* Default: pleasing 16/9 hero unless an explicit ratio is set */
.misepress-page--single .misepress__recipe.mp-ratio-auto .misepress__media { aspect-ratio: 16 / 9; }
@media (max-width: 600px) {
	.misepress-page--single .misepress__recipe.mp-ratio-auto .misepress__media { aspect-ratio: 4 / 3; }
}
/* Tight, balanced meta row (prep/cook/serves/difficulty/calories) */
.misepress-page--single .misepress__meta {
	gap: clamp(1rem, 3vw, 2.5rem);
	padding-block: 0.85rem;
	border-color: color-mix(in srgb, var(--mp-color-border) 90%, transparent);
}
.misepress-page--single .misepress__meta-item { min-width: 0; gap: 0.15rem; }
.misepress-page--single .misepress__meta-value { font-size: 1.05rem; }

/* Title row: tighter, prevent excessive whitespace between header and meta */
.misepress-page--single .misepress__title-row { margin: 0; }
.misepress-page--single .misepress__title { line-height: 1.1; margin: 0 0 .25rem; }
.misepress-page--single .misepress__excerpt { color: var(--mp-color-muted); margin: 0; max-width: 65ch; }

/* Body grid: keep ingredients & instructions side-by-side from 880px+,
   stack below; reduce dead space between columns. */
@media (min-width: 880px) {
	.misepress-single--layout-sidebar .misepress__body,
	.misepress-page--single .misepress__body {
		display: grid;
		grid-template-columns: minmax(280px, 0.85fr) minmax(0, 1.15fr);
		gap: clamp(1.5rem, 3vw, 2.5rem);
		align-items: start;
	}
	.misepress-single--layout-sidebar .misepress__section--ingredients,
	.misepress-page--single .misepress__section--ingredients { position: sticky; top: var(--mp-sticky-offset, 80px); }
}
.misepress-page--single .misepress__heading { font-size: clamp(1.25rem, 2vw, 1.6rem); margin: 0 0 .9rem; }

/* Ingredients list - tighter rows */
.misepress-page--single .misepress__ingredients { display: grid; gap: .35rem; padding-left: 0; list-style: none; }
.misepress-page--single .misepress__ingredient {
	padding: .55rem .25rem;
	border-bottom: 1px solid color-mix(in srgb, var(--mp-color-border) 70%, transparent);
}
.misepress-page--single .misepress__ingredient:last-child { border-bottom: 0; }

/* Reviews tab — when reviews live in their own tab, give them more breathing room */
.misepress__tab-panel--reviews .misepress__reviews { margin-top: 0; }
.misepress__tab-panel--reviews .misepress__reviews-summary {
	display: grid;
	grid-template-columns: minmax(120px, auto) 1fr;
	gap: clamp(1rem, 3vw, 2rem);
	padding: 1.25rem;
	border-radius: var(--mp-radius);
	background: color-mix(in srgb, var(--mp-color-fg) 3%, transparent);
	border: 1px solid var(--mp-color-border);
	margin-bottom: 1.25rem;
	align-items: center;
}
@media (max-width: 600px) {
	.misepress__tab-panel--reviews .misepress__reviews-summary { grid-template-columns: 1fr; }
}

/* ACSS coverage — anywhere we still have a hardcoded fallback color, the
   var() picks up ACSS first when active; these rules ensure component
   borders/buttons inherit the design system unless overridden inline. */
.misepress.misepress-acss .misepress__recipe,
.misepress.misepress-acss .misepress__grid-card {
	background: var(--mp-card-bg, var(--base-ultra-light, var(--mp-color-bg)));
	border-color: var(--mp-card-border, var(--base-light, var(--mp-color-border)));
}
.misepress.misepress-acss .misepress__btn--primary {
	background: var(--action, var(--mp-color-accent));
	color: #fff;
}
.misepress.misepress-acss .misepress__btn--primary:hover {
	background: color-mix(in srgb, var(--action, var(--mp-color-accent)) 80%, #000);
}
.misepress.misepress-acss .misepress__pagination .page-numbers { border-color: var(--base-light, var(--mp-color-border)); }
.misepress.misepress-acss .misepress__pagination .page-numbers.current {
	background: color-mix(in srgb, var(--action, var(--mp-color-accent)) 80%, #000);
	border-color: color-mix(in srgb, var(--action, var(--mp-color-accent)) 80%, #000);
	color: #fff;
}

/* ============================================================
 * Tighter typographic rhythm, refined hero, neater sidebar
 * cards, balanced gaps. Avoids dead space; reads as one
 * cohesive editorial composition.
 * ============================================================ */
.misepress-page--single { padding-block: clamp(1rem, 3vw, 2.25rem); }
.misepress-page--single .misepress__recipe {
	display: grid;
	gap: clamp(1.25rem, 2.5vw, 2rem);
	background: transparent;
	box-shadow: none;
	padding: 0;
	border: 0;
}
.misepress-page--single .misepress__header { display: grid; gap: .9rem; margin: 0; }
.misepress-page--single .misepress__header .misepress__media {
	border-radius: var(--mp-radius);
	box-shadow: var(--mp-shadow-sm);
}
.misepress-page--single .misepress__title {
	font-size: clamp(1.75rem, 3.5vw, 2.75rem);
	letter-spacing: -0.01em;
	line-height: 1.08;
	margin: 0;
}
.misepress-page--single .misepress__title-row {
	display: flex; align-items: flex-start; justify-content: space-between;
	gap: 1rem; flex-wrap: wrap; margin: 0;
}
.misepress-page--single .misepress__title-actions { display: inline-flex; gap: .5rem; flex-wrap: wrap; }
.misepress-page--single .misepress__excerpt {
	font-size: clamp(1rem, 1.4vw, 1.125rem);
	color: var(--mp-color-muted);
	max-width: 68ch;
	margin: 0;
	line-height: 1.55;
}
/* Meta strip: clean, divided cells, tight vertical stack per item */
.misepress-page--single .misepress__meta {
	display: flex;
	flex-wrap: wrap;
	gap: 0;
	padding: .9rem 0;
	border-top: 1px solid var(--mp-color-border);
	border-bottom: 1px solid var(--mp-color-border);
	background: transparent;
	border-radius: 0;
}
.misepress-page--single .misepress__meta-item {
	flex: 1 1 auto;
	min-width: 110px;
	display: grid;
	gap: .15rem;
	padding: 0 1rem;
	border-right: 1px solid var(--mp-color-border);
	text-align: left;
}
.misepress-page--single .misepress__meta-item:first-child { padding-left: 0; }
.misepress-page--single .misepress__meta-item:last-child { border-right: 0; padding-right: 0; }
.misepress-page--single .misepress__meta-label {
	font-size: .72rem; letter-spacing: .12em; text-transform: uppercase;
	color: var(--mp-color-muted); font-weight: 600;
}
.misepress-page--single .misepress__meta-value {
	font-size: 1.05rem; font-weight: 600; color: var(--mp-color-fg);
}

/* Sidebar layout (default): aside cards on left, instructions/main on right */
@media (min-width: 880px) {
	.misepress-page--single .misepress__body,
	.misepress-single--layout-sidebar .misepress__body {
		display: grid;
		grid-template-columns: minmax(280px, 0.9fr) minmax(0, 1.1fr);
		gap: clamp(1.5rem, 3vw, 2.5rem);
		align-items: start;
	}
	.misepress-page--single .misepress__aside,
	.misepress-single--layout-sidebar .misepress__aside {
		display: grid;
		gap: 1.25rem;
		position: sticky;
		top: var(--mp-sticky-offset, 80px);
	}
}

/* Cards inside aside (ingredients, allergens) feel like cohesive panels */
.misepress-page--single .misepress__aside .misepress__section {
	background: var(--mp-color-bg);
	border: 1px solid var(--mp-color-border);
	border-radius: var(--mp-radius);
	padding: 1.1rem 1.15rem 1.25rem;
	box-shadow: var(--mp-shadow-xs);
}
.misepress-page--single .misepress__main { display: grid; gap: clamp(1.25rem, 2.5vw, 2rem); }
.misepress-page--single .misepress__main .misepress__section { padding: 0; }
.misepress-page--single .misepress__heading {
	font-size: clamp(1.2rem, 1.9vw, 1.5rem);
	letter-spacing: -0.005em;
	line-height: 1.2;
	margin: 0 0 .85rem;
}

/* Steps: airy, easy on the eye */
.misepress-page--single .misepress__steps { display: grid; gap: .85rem; padding: 0; list-style: none; }
.misepress-page--single .misepress__step {
	background: color-mix(in srgb, var(--mp-color-accent-soft) 45%, transparent);
	border-radius: var(--mp-radius-sm);
	padding: 1rem 1rem 1rem calc(2rem + 1.5rem);
	min-height: 2.75rem;
	line-height: 1.55;
}
.misepress-page--single .misepress__step::before {
	left: 1rem;
	top: 1rem;
	width: 2rem; height: 2rem;
	font-size: .95rem;
}

/* Notes / story blocks read as quiet, editorial paragraphs */
.misepress-page--single .misepress__section--story .misepress__story,
.misepress-page--single .misepress__section--notes .misepress__notes {
	font-size: 1rem;
	line-height: 1.65;
	max-width: 68ch;
	color: var(--mp-color-fg);
}

/* Allergen chips align nicely inside the aside card */
.misepress-page--single .misepress__allergens {
	display: flex; flex-wrap: wrap; gap: .4rem; margin: 0; padding: 0; list-style: none;
}

/* Ingredients list — tight, scannable */
.misepress-page--single .misepress__ingredient {
	display: flex; flex-wrap: wrap; align-items: baseline; gap: .35rem;
	padding: .55rem 0;
}
.misepress-page--single .misepress__ingredient-qty,
.misepress-page--single .misepress__ingredient-unit { font-weight: 600; color: var(--mp-color-fg); }
.misepress-page--single .misepress__ingredient-name { color: var(--mp-color-fg); }

/* Mobile: drop the sticky/grid behaviour, keep neat card stack */
@media (max-width: 879px) {
	.misepress-page--single .misepress__aside,
	.misepress-page--single .misepress__main { display: grid; gap: 1.25rem; }
	.misepress-page--single .misepress__aside { position: static; }
}

/* ============================================================
 * Builds the active/contrast tokens from --action with strong fallbacks
 * (color-mix darkens by 45% so even pastel ACSS palettes stay legible),
 * and forces a clean white-on-dark rendering for active controls and
 * step-number circles regardless of selector specificity earlier in the file.
 * Also normalises the ACSS card/filter backgrounds so they don't pick up the
 * murky soft-accent tint that was washing the layout out.
 * ============================================================ */
.misepress.misepress-acss {
	--mp-color-accent-active: color-mix(in srgb, var(--action, var(--mp-color-accent)) 55%, #000);
	--mp-color-accent-contrast: #fff;
	--mp-color-accent-soft: color-mix(in srgb, var(--action, var(--mp-color-accent)) 14%, var(--base-ultra-light, #fff));
	--mp-card-bg: var(--base-ultra-light, #fff);
	--mp-filter-bg: var(--base-ultra-light, #fff);
	--mp-color-border: color-mix(in srgb, var(--base, #6b6b6b) 20%, var(--base-ultra-light, #fff));
}

.misepress.misepress-acss .misepress__density-btn.is-active,
.misepress.misepress-acss .misepress__preset.is-active,
.misepress.misepress-acss .misepress__units-btn.is-active,
.misepress.misepress-acss .misepress__nut-mode.is-active,
.misepress.misepress-acss .misepress__scale-pill.is-active {
	background: var(--mp-color-accent-active, var(--mp-color-accent)) !important;
	border-color: var(--mp-color-accent-active, var(--mp-color-accent)) !important;
	color: #fff !important;
}
.misepress.misepress-acss .misepress__density-btn.is-active svg,
.misepress.misepress-acss .misepress__preset.is-active svg,
.misepress.misepress-acss .misepress__units-btn.is-active svg,
.misepress.misepress-acss .misepress__nut-mode.is-active svg,
.misepress.misepress-acss .misepress__scale-pill.is-active svg { color: currentColor; fill: currentColor; }

.misepress__step::before,
.misepress-page--single .misepress__step::before,
.misepress.misepress-acss .misepress__step::before {
	background: var(--mp-color-accent-active, var(--mp-step-number-bg, var(--mp-color-accent))) !important;
	color: #fff !important;
	box-shadow: 0 0 0 3px var(--mp-color-bg);
}

/* ACSS — restore clean card/step backgrounds and consistent gaps */
.misepress.misepress-acss .misepress-page--single .misepress__aside .misepress__section,
.misepress.misepress-acss .misepress-page--single .misepress__step {
	background: var(--mp-color-bg) !important;
}
.misepress.misepress-acss .misepress-page--single .misepress__recipe { gap: clamp(1.25rem, 2.4vw, 2rem); }
.misepress.misepress-acss .misepress-page--single .misepress__main { gap: clamp(1.5rem, 3vw, 2.25rem); }
.misepress.misepress-acss .misepress__grid { gap: var(--mp-grid-gap, 1.5rem); }



.misepress-page--single .misepress__recipe {
	max-width: 100%;
	padding: 0;
	background: transparent;
	border: 0;
	box-shadow: none;
	gap: clamp(1rem, 2vw, 1.5rem);
}
.misepress-page--single .misepress__header {
	display: grid;
	gap: clamp(.75rem, 1.6vw, 1.1rem);
}
.misepress-page--single .misepress__media {
	aspect-ratio: 16 / 9;
	max-height: min(520px, 52vh);
	border-radius: var(--mp-radius);
	overflow: hidden;
	background: var(--mp-color-accent-soft);
}
.misepress-page--single .misepress__media img,
.misepress-page--single .misepress__media video,
.misepress-page--single .misepress__media iframe {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.misepress-page--single .misepress__title {
	max-width: 16ch;
	font-size: clamp(2rem, 4.4vw, 4rem);
	line-height: 1;
	letter-spacing: 0;
	color: var(--mp-color-fg);
}
.misepress-page--single .misepress__excerpt { max-width: 62ch; color: var(--mp-color-muted); }
.misepress-page--single .misepress__meta {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
	gap: 0;
	padding: .85rem 0;
	border-block: 1px solid var(--mp-color-border);
}
.misepress-page--single .misepress__meta-item {
	min-width: 0;
	padding: .15rem clamp(.75rem, 1.6vw, 1rem);
	border-right: 1px solid var(--mp-color-border);
}
.misepress-page--single .misepress__meta-item:first-child { padding-left: 0; }
.misepress-page--single .misepress__meta-item:last-child { border-right: 0; }

@media (min-width: 880px) {
	.misepress-page--single .misepress__body:not(.misepress__body--no-aside),
	.misepress-single--layout-sidebar .misepress__body:not(.misepress__body--no-aside) {
		grid-template-columns: minmax(260px, 320px) minmax(0, 1fr);
		gap: clamp(1.5rem, 3vw, 2.25rem);
	}
	.misepress-page--single .misepress__body--no-aside { grid-template-columns: minmax(0, 760px); justify-content: center; }
	.misepress-page--single .misepress__aside {
		position: static !important;
		align-self: start;
	}
}
.misepress-page--single .misepress__section--ingredients { position: static !important; }
.misepress-page--single .misepress__aside .misepress__section {
	background: color-mix(in srgb, var(--mp-color-bg) 92%, var(--mp-color-accent-soft));
	border: 1px solid var(--mp-color-border);
	border-radius: var(--mp-radius);
	padding: clamp(1rem, 2vw, 1.25rem);
	box-shadow: var(--mp-shadow-xs);
}
.misepress-page--single .misepress__main {
	display: grid;
	gap: clamp(1.1rem, 2.4vw, 1.75rem);
}
.misepress-page--single .misepress__main .misepress__section {
	padding-bottom: clamp(1rem, 2vw, 1.35rem);
	border-bottom: 1px solid color-mix(in srgb, var(--mp-color-border) 75%, transparent);
}
.misepress-page--single .misepress__main .misepress__section:last-child { border-bottom: 0; padding-bottom: 0; }
.misepress-page--single .misepress__heading {
	margin: 0 0 .65rem;
	font-size: clamp(1.2rem, 1.8vw, 1.45rem);
	line-height: 1.15;
	letter-spacing: 0;
	color: var(--mp-color-fg);
}
.misepress-page--single .misepress__ingredients { display: grid; gap: .15rem; padding: 0; margin: 0; list-style: none; }
.misepress-page--single .misepress__ingredient {
	padding: .48rem 0;
	border-bottom: 1px solid color-mix(in srgb, var(--mp-color-border) 65%, transparent);
}
.misepress-page--single .misepress__ingredient:last-child { border-bottom: 0; }
.misepress-page--single .misepress__steps { gap: .75rem; }
.misepress-page--single .misepress__step {
	padding: .9rem 1rem .9rem 3.65rem;
	min-height: 3.25rem;
	background: color-mix(in srgb, var(--mp-color-bg) 82%, var(--mp-color-accent-soft));
	border: 1px solid color-mix(in srgb, var(--mp-color-border) 80%, transparent);
	border-radius: var(--mp-radius-sm);
	line-height: 1.55;
}
.misepress-page--single .misepress__step::before { left: 1rem; top: .85rem; width: 2rem; height: 2rem; }
.misepress-page--single .misepress__tab-panel--reviews .misepress__reviews,
.misepress-page--single .misepress__tab-panel--reviews [data-mp-reviews] {
	max-width: 760px;
	margin-inline: auto;
}
@media (max-width: 760px) {
	.misepress-page--single .misepress__media { aspect-ratio: 4 / 3; max-height: none; }
	.misepress-page--single .misepress__title { max-width: none; }
	.misepress-page--single .misepress__meta { grid-template-columns: repeat(2, minmax(0, 1fr)); }
	.misepress-page--single .misepress__meta-item { border-right: 0; padding-inline: 0; }
}

@media (min-width: 900px) {
	.misepress__archive--filters-top-bar-sticky .misepress__filters {
		position: sticky;
		top: var(--mp-space-3);
		z-index: 25;
		backdrop-filter: saturate(140%) blur(6px);
		-webkit-backdrop-filter: saturate(140%) blur(6px);
		background: var(--mp-filter-bg, color-mix(in srgb, var(--mp-color-bg) 90%, transparent));
	}
}

.misepress__archive-header--with-toolbar .misepress__archive-header-toolbar {
	margin-left: auto;
	flex-wrap: wrap;
	justify-content: flex-end;
	row-gap: 0.5rem;
}
.misepress__archive-header--with-toolbar .misepress__presets {
	flex: 1 1 auto;
	min-width: 0;
}
@media (min-width: 900px) {
	.misepress__archive-header--with-toolbar { align-items: center; }
}

.misepress-page--single { --mp-single-section-gap: 1.5rem; }
.misepress-page--single .misepress__recipe { gap: 1rem; }
.misepress-page--single .misepress__header { margin-bottom: 0.75rem; }
.misepress-page--single .misepress__heading { margin: 0 0 0.6rem; }
.misepress-page--single .misepress__section + .misepress__section,
.misepress-page--single .misepress__main > .misepress__section + .misepress__section,
.misepress-page--single .misepress__aside > .misepress__section + .misepress__section { margin-top: var(--mp-single-section-gap); }
.misepress-page--single .misepress__steps { gap: 0.6rem; }
.misepress-page--single .misepress__step { padding-block: 0.5rem; }
.misepress-page--single .misepress__related { margin-top: calc(var(--mp-single-section-gap) + 0.25rem); }

.misepress-page--single .misepress__nutrition-label { padding: 1rem 1.1rem; }
.misepress-page--single .misepress__nut-grid { gap: 1rem; }
.misepress-page--single .misepress__nut-bar { margin-top: 0.6rem; }
.misepress-page--single .misepress__nut-context { margin-top: 0.4rem; }
.misepress-page--single .misepress__nut-source { margin-top: 0.5rem; }

.misepress-page--single { --mp-single-section-gap: 1rem; padding-block: clamp(.75rem, 2vw, 1.5rem); }
.misepress-page--single .misepress__recipe { gap: .75rem; }
.misepress-page--single .misepress__header { margin-bottom: .25rem; gap: .5rem; }
.misepress-page--single .misepress__title { margin: 0; }
.misepress-page--single .misepress__excerpt { margin: 0; }
.misepress-page--single .misepress__meta { padding: .55rem 0; }
.misepress-page--single .misepress__heading { margin: 0 0 .45rem; }
.misepress-page--single .misepress__main { gap: var(--mp-single-section-gap); }
.misepress-page--single .misepress__main .misepress__section { padding-bottom: var(--mp-single-section-gap); }
.misepress-page--single .misepress__aside { gap: var(--mp-single-section-gap); }
.misepress-page--single .misepress__section + .misepress__section,
.misepress-page--single .misepress__main > .misepress__section + .misepress__section,
.misepress-page--single .misepress__aside > .misepress__section + .misepress__section { margin-top: 0; }
.misepress-page--single .misepress__steps { gap: .5rem; }
.misepress-page--single .misepress__step { padding: .65rem .85rem .65rem 3.25rem; min-height: 2.5rem; }
.misepress-page--single .misepress__ingredient { padding: .4rem 0; }
.misepress-page--single .misepress__related { margin-top: .75rem; }
@media (min-width: 880px) {
	.misepress-page--single .misepress__body,
	.misepress-single--layout-sidebar .misepress__body { gap: clamp(1rem, 2vw, 1.5rem); }
}

/* ===================================================================== */
/* Dark band wraps the hero image; title, rating, stats, allergens layer */
/* on top in a clean centered stack.                                     */
/* ===================================================================== */
.misepress-page--single .misepress__header--hero {
	position: relative;
	margin: 0;
	padding: 0;
	background: var(--mp-hero-bg, #2a2a2a);
	color: #fff;
	border-radius: 0;
	overflow: hidden;
	display: block;
}
.misepress-page--single .misepress__header--hero .misepress__media--hero {
	margin: 0;
	max-width: var(--mp-hero-media-max, 1140px);
	margin-inline: auto;
	padding: 0;
}
.misepress-page--single .misepress__header--hero .misepress__media--hero img {
	width: 100%;
	height: auto;
	max-height: 520px;
	object-fit: cover;
	border-radius: 0;
	display: block;
}
.misepress-page--single .misepress__header--hero .misepress__hero-overlay {
	max-width: var(--mp-hero-media-max, 1140px);
	margin-inline: auto;
	padding: 1.25rem clamp(1rem, 4vw, 2rem) 4.5rem;
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: .75rem;
	position: relative;
}
.misepress-page--single .misepress__header--hero .misepress__title-actions--hero {
	position: absolute;
	top: 1rem;
	right: clamp(1rem, 4vw, 2rem);
	display: inline-flex;
	gap: .5rem;
}
.misepress-page--single .misepress__header--hero .misepress__title-actions--hero .misepress__save-btn,
.misepress-page--single .misepress__header--hero .misepress__title-actions--hero .misepress__btn {
	width: 44px;
	height: 44px;
	padding: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: rgba(255,255,255,.12);
	color: #fff;
	border: 1px solid rgba(255,255,255,.18);
	border-radius: 999px;
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(6px);
}
.misepress-page--single .misepress__header--hero .misepress__title--hero {
	font-size: clamp(1.6rem, 3.5vw, 2.4rem);
	line-height: 1.15;
	margin: .25rem 0 0;
	color: inherit;
	max-width: 22ch;
}
.misepress-page--single .misepress__header--hero .misepress__hero-rating {
	display: inline-flex;
	gap: .15rem;
	font-size: 1.1rem;
}
.misepress-page--single .misepress__header--hero .misepress__star { color: rgba(255,255,255,.25); }
.misepress-page--single .misepress__header--hero .misepress__star.is-on { color: #f5b942; }
.misepress-page--single .misepress__header--hero .misepress__excerpt--hero {
	color: rgba(255,255,255,.78);
	font-size: 1rem;
	max-width: 60ch;
	margin: 0;
}
.misepress-page--single .misepress__header--hero .misepress__hero-stats {
	display: inline-flex;
	gap: clamp(1.5rem, 4vw, 3rem);
	list-style: none;
	margin: .5rem 0 0;
	padding: 1rem clamp(1.25rem, 3vw, 2.25rem);
	background: #fff;
	color: #1a1a1a;
	border-radius: 14px;
	box-shadow: 0 10px 30px -10px rgba(0,0,0,.45);
	position: relative;
	bottom: -2.5rem;
	margin-bottom: -2.5rem;
}
.misepress-page--single .misepress__header--hero .misepress__hero-stat {
	display: inline-flex;
	flex-direction: column;
	align-items: center;
	gap: .25rem;
	min-width: 60px;
}
.misepress-page--single .misepress__header--hero .misepress__hero-stat-icon { color: #1a1a1a; opacity: .8; }
.misepress-page--single .misepress__header--hero .misepress__hero-stat-icon + .misepress__hero-stat-value { font-size: .95rem; }
.misepress-page--single .misepress__header--hero .misepress__hero-stat:first-child .misepress__hero-stat-value { color: #e85d2a; font-weight: 600; }
.misepress-page--single .misepress__header--hero .misepress__hero-stat-value { font-weight: 500; }
.misepress-page--single .misepress__header--hero .misepress__hero-allergens {
	display: inline-flex;
	gap: .5rem;
	list-style: none;
	margin: 1.25rem 0 0;
	padding: 0;
	position: relative;
	bottom: -2rem;
}
.misepress-page--single .misepress__header--hero .misepress__hero-allergen {
	width: 36px;
	height: 36px;
	background: #fff;
	color: #1a1a1a;
	border-radius: 999px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 4px 12px -4px rgba(0,0,0,.4);
}
.misepress-page--single .misepress__header--hero .misepress__hero-allergen svg { width: 18px; height: 18px; }
/* Push body content down so it doesn't overlap the floating stats card. */
.misepress-page--single .misepress__recipe { gap: 4rem; }
@media (max-width: 700px) {
	.misepress-page--single .misepress__header--hero .misepress__media--hero img { max-height: 300px; }
	.misepress-page--single .misepress__header--hero .misepress__hero-stats { gap: 1.25rem; padding: .75rem 1rem; }
	.misepress-page--single .misepress__header--hero .misepress__title-actions--hero { top: .5rem; right: .75rem; }
}
/* When the page wrapper has no full-bleed (Bricks container), keep hero
   inside its container by removing the negative viewport margin trick. */
.misepress-page--single .misepress-page__inner > .misepress__recipe > .misepress__header--hero {
	margin-left: 0;
	margin-right: 0;
	border-radius: var(--mp-radius);
}


/* =====================================================================
 * ===================================================================== */

/* Remove the forced dark hero band and keep the card feeling integrated with the page. */
.misepress-page--single .misepress__header--hero {
	background: transparent;
	color: var(--mp-color-fg, #1a1a1a);
	border-radius: var(--mp-radius, 18px);
	overflow: visible;
}

.misepress-page--single .misepress__header--hero .misepress__media--hero img {
	border-radius: var(--mp-radius, 18px);
}

.misepress-page--single .misepress__header--hero .misepress__hero-overlay {
	padding: 1rem clamp(1rem, 3vw, 1.5rem) 1.25rem;
	gap: .45rem;
}

.misepress-page--single .misepress__header--hero .misepress__title--hero,
.misepress-page--single .misepress__header--hero .misepress__excerpt--hero {
	color: var(--mp-color-fg, #1a1a1a);
	text-shadow: none;
}

.misepress-page--single .misepress__header--hero .misepress__excerpt--hero {
	opacity: .78;
}

.misepress-page--single .misepress__header--hero .misepress__star {
	color: color-mix(in srgb, var(--mp-color-fg, #1a1a1a) 24%, transparent);
}

/* Keep action buttons readable on the light hero instead of floating glass pills. */
.misepress-page--single .misepress__header--hero .misepress__title-actions--hero .misepress__save-btn,
.misepress-page--single .misepress__header--hero .misepress__title-actions--hero .misepress__btn {
	background: rgba(255,255,255,.86);
	color: var(--mp-color-fg, #1a1a1a);
	border-color: rgba(0,0,0,.12);
}

/* Stop the stats card from creating a fake 4rem hole under the hero. */
.misepress-page--single .misepress__header--hero .misepress__hero-stats {
	position: static;
	bottom: auto;
	margin: .75rem auto 0;
	margin-bottom: 0;
	box-shadow: 0 12px 28px -18px rgba(0,0,0,.35);
}

.misepress-page--single .misepress__header--hero .misepress__hero-allergens {
	position: static;
	bottom: auto;
	margin-top: .75rem;
}

.misepress-page--single .misepress__recipe {
	gap: 1rem;
}

@media (max-width: 700px) {
	.misepress-page--single .misepress__header--hero .misepress__hero-overlay {
		padding-bottom: 1rem;
	}
	.misepress-page--single .misepress__header--hero .misepress__hero-stats {
		gap: .75rem;
		padding: .75rem .85rem;
		width: min(100%, 520px);
		justify-content: center;
	}
}


/* =====================================================================
 * ===================================================================== */

/* Keep the recipe page as a component, not a coloured full-page block. */
.misepress-page--single {
	background: transparent;
	padding-inline: clamp(1rem, 3vw, 2rem);
	padding-block: clamp(.75rem, 2vw, 1.5rem);
}

.misepress-page--single .misepress__recipe {
	background: transparent !important;
	box-shadow: none !important;
	border: 0 !important;
	gap: clamp(1rem, 2vw, 1.5rem) !important;
}

/* Single recipe cards should not inherit a strong ACSS/tint background. */
.misepress-page--single .misepress__aside .misepress__section,
.misepress-page--single .misepress__main .misepress__section,
.misepress-page--single .misepress__section--ingredients,
.misepress-page--single .misepress__section--instructions,
.misepress-page--single .misepress__section--equipment,
.misepress-page--single .misepress__section--nutrition,
.misepress-page--single .misepress__section--reviews {
	background: #fff !important;
	border: 1px solid rgba(20, 32, 45, .12) !important;
	border-radius: var(--mp-radius, 18px) !important;
	box-shadow: 0 10px 30px -24px rgba(0,0,0,.25) !important;
	padding: clamp(1rem, 2.25vw, 1.5rem) !important;
}

.misepress-page--single .misepress__main .misepress__section {
	border-bottom: 1px solid rgba(20, 32, 45, .12) !important;
}

/* Hero: no dark band, no tinted block, no floating overlap. */
.misepress-page--single .misepress__header--hero {
	background: transparent !important;
	color: var(--mp-color-fg, #14202d) !important;
	border-radius: var(--mp-radius, 18px) !important;
	overflow: visible !important;
	box-shadow: none !important;
}

.misepress-page--single .misepress__header--hero .misepress__media--hero {
	border-radius: var(--mp-radius, 18px) !important;
	overflow: hidden !important;
	background: transparent !important;
}

.misepress-page--single .misepress__header--hero .misepress__media--hero img {
	border-radius: var(--mp-radius, 18px) !important;
	max-height: min(520px, 54vh) !important;
	object-fit: cover !important;
}

.misepress-page--single .misepress__header--hero .misepress__hero-overlay {
	background: #fff !important;
	border: 1px solid rgba(20, 32, 45, .10) !important;
	border-top: 0 !important;
	border-radius: 0 0 var(--mp-radius, 18px) var(--mp-radius, 18px) !important;
	padding: clamp(.9rem, 2vw, 1.2rem) clamp(1rem, 3vw, 1.5rem) !important;
	gap: .65rem !important;
	box-shadow: 0 12px 30px -26px rgba(0,0,0,.35) !important;
}

.misepress-page--single .misepress__header--hero .misepress__title--hero,
.misepress-page--single .misepress__header--hero .misepress__excerpt--hero {
	color: var(--mp-color-fg, #14202d) !important;
	max-width: 100% !important;
	text-shadow: none !important;
}

.misepress-page--single .misepress__header--hero .misepress__title--hero {
	font-size: clamp(2rem, 4vw, 3.1rem) !important;
}

.misepress-page--single .misepress__header--hero .misepress__title-actions--hero {
	position: static !important;
	top: auto !important;
	right: auto !important;
	transform: none !important;
	justify-content: center !important;
	gap: .65rem !important;
	width: 100% !important;
	order: 4;
}

.misepress-page--single .misepress__header--hero .misepress__title--hero { order: 1; }
.misepress-page--single .misepress__header--hero .misepress__hero-rating { order: 2; }
.misepress-page--single .misepress__header--hero .misepress__excerpt--hero { order: 3; }
.misepress-page--single .misepress__header--hero .misepress__hero-stats { order: 5; }
.misepress-page--single .misepress__header--hero .misepress__hero-allergens { order: 6; }

.misepress-page--single .misepress__header--hero .misepress__title-actions--hero .misepress__save-btn,
.misepress-page--single .misepress__header--hero .misepress__title-actions--hero .misepress__btn {
	width: auto !important;
	min-width: 56px !important;
	height: 42px !important;
	padding: 0 .95rem !important;
	background: #fff !important;
	color: var(--mp-color-fg, #14202d) !important;
	border: 1px solid rgba(20, 32, 45, .16) !important;
	box-shadow: 0 10px 24px -18px rgba(0,0,0,.35) !important;
	backdrop-filter: none !important;
	-webkit-backdrop-filter: none !important;
}

.misepress-page--single .misepress__header--hero .misepress__hero-stats {
	position: static !important;
	bottom: auto !important;
	margin: .55rem auto 0 !important;
	margin-bottom: 0 !important;
	box-shadow: 0 12px 28px -20px rgba(0,0,0,.35) !important;
}

.misepress-page--single .misepress__header--hero .misepress__hero-allergens {
	position: static !important;
	bottom: auto !important;
	margin-top: .55rem !important;
}

/* Instructions: make checkbox, number, and text stop crashing into each other. */
.misepress-page--single .misepress__steps {
	gap: .65rem !important;
}

.misepress-page--single .misepress__step {
	background: #fff !important;
	border: 1px solid rgba(20, 32, 45, .13) !important;
	border-radius: 12px !important;
	box-shadow: none !important;
	line-height: 1.55 !important;
	padding: .85rem 1rem .85rem 4rem !important;
	min-height: 3.1rem !important;
	overflow: visible !important;
}

.misepress-page--single .misepress__step::before {
	left: .9rem !important;
	top: .8rem !important;
	width: 2rem !important;
	height: 2rem !important;
	z-index: 1 !important;
}

.misepress-page--single .misepress__step[data-mp-check] {
	padding-left: 5.25rem !important;
}

.misepress-page--single .misepress__step[data-mp-check]::before {
	left: 2.6rem !important;
}

.misepress-page--single .misepress__step[data-mp-check] .misepress__check {
	position: absolute !important;
	left: .85rem !important;
	top: 1rem !important;
	margin: 0 !important;
	z-index: 2 !important;
	background: #fff !important;
}

.misepress-page--single .misepress__step-text {
	display: block !important;
	min-width: 0 !important;
}

/* Reduce awkward empty air inside common single recipe panels. */
.misepress-page--single .misepress__heading {
	margin-bottom: .7rem !important;
}

.misepress-page--single .misepress__equipment,
.misepress-page--single .misepress__equipment-list,
.misepress-page--single .misepress__ingredients,
.misepress-page--single .misepress__steps {
	margin-top: 0 !important;
}

@media (max-width: 700px) {
	.misepress-page--single {
		padding-inline: 1rem !important;
	}

	.misepress-page--single .misepress__header--hero .misepress__media--hero img {
		max-height: none !important;
		aspect-ratio: 4 / 3 !important;
	}

	.misepress-page--single .misepress__header--hero .misepress__hero-overlay {
		align-items: stretch !important;
		text-align: center !important;
		padding: .9rem .9rem 1rem !important;
	}

	.misepress-page--single .misepress__header--hero .misepress__title--hero {
		font-size: clamp(1.8rem, 9vw, 2.45rem) !important;
		line-height: 1.05 !important;
	}

	.misepress-page--single .misepress__header--hero .misepress__excerpt--hero {
		font-size: 1rem !important;
		line-height: 1.35 !important;
	}

	.misepress-page--single .misepress__header--hero .misepress__title-actions--hero {
		display: grid !important;
		grid-template-columns: repeat(auto-fit, minmax(84px, 1fr)) !important;
		gap: .6rem !important;
		margin-top: .1rem !important;
	}

	.misepress-page--single .misepress__header--hero .misepress__title-actions--hero .misepress__save-btn,
	.misepress-page--single .misepress__header--hero .misepress__title-actions--hero .misepress__btn {
		width: 100% !important;
		min-width: 0 !important;
		border-radius: 999px !important;
	}

	.misepress-page--single .misepress__header--hero .misepress__hero-stats {
		width: 100% !important;
		display: grid !important;
		grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
		gap: .3rem !important;
		padding: .75rem .6rem !important;
	}

	.misepress-page--single .misepress__header--hero .misepress__hero-stat {
		min-width: 0 !important;
	}

	.misepress-page--single .misepress__aside .misepress__section,
	.misepress-page--single .misepress__main .misepress__section,
	.misepress-page--single .misepress__section--ingredients,
	.misepress-page--single .misepress__section--instructions,
	.misepress-page--single .misepress__section--equipment,
	.misepress-page--single .misepress__section--nutrition,
	.misepress-page--single .misepress__section--reviews {
		padding: 1.15rem 1rem !important;
	}

	.misepress-page--single .misepress__step {
		font-size: 1rem !important;
		padding: .85rem .85rem .85rem 3.75rem !important;
	}

	.misepress-page--single .misepress__step[data-mp-check] {
		padding-left: 5rem !important;
	}

	.misepress-page--single .misepress__step::before {
		left: .8rem !important;
	}

	.misepress-page--single .misepress__step[data-mp-check]::before {
		left: 2.45rem !important;
	}

	.misepress-page--single .misepress__step[data-mp-check] .misepress__check {
		left: .75rem !important;
		top: 1rem !important;
	}
}

/* =====================================================================
 * When Automatic.css inheritance is enabled, MisePress maps its component
 * tokens to ACSS variables and avoids hardcoded white/orange/px surfaces.
 * Native MisePress styling remains unchanged when ACSS is not active or
 * the inheritance setting is turned off.
 * ===================================================================== */
.misepress.misepress-acss {
	--mp-color-accent: var(--action, #c2410c);
	--mp-color-accent-active: var(--action-dark, color-mix(in srgb, var(--action, #c2410c) 55%, #000));
	--mp-color-accent-contrast: var(--action-ultra-light, #fff);
	--mp-color-accent-soft: var(--action-light-trans-90, color-mix(in srgb, var(--action, #c2410c) 10%, transparent));
	--mp-color-bg: var(--base-ultra-light, #fffdf8);
	--mp-color-surface: var(--base-ultra-light, #fff);
	--mp-color-fg: var(--base-ultra-dark, #1a1a1a);
	--mp-color-muted: var(--base, #6b6b6b);
	--mp-color-border: var(--base-light, #ececec);
	--mp-card-bg: var(--base-ultra-light, #fff);
	--mp-card-text: var(--base-ultra-dark, #1a1a1a);
	--mp-card-accent: var(--action, #c2410c);
	--mp-card-border: var(--base-light, #ececec);
	--mp-filter-bg: var(--base-ultra-light, #fff);
	--mp-filter-text: var(--base-ultra-dark, #1a1a1a);
	--mp-filter-accent: var(--action, #c2410c);
	--mp-filter-border: var(--base-light, #ececec);
	--mp-radius: var(--radius-m, 18px);
	--mp-radius-sm: var(--radius-s, 12px);
	--mp-card-radius: var(--radius-m, 18px);
	--mp-filter-radius: var(--radius-m, 18px);
	--mp-single-section-gap: var(--space-m, 1rem);
	--mp-grid-gap: var(--space-m, 1.5rem);
	--mp-archive-filter-gap: var(--space-m, 1.5rem);
	--mp-archive-pad-x: var(--space-m, 1rem);
	--mp-shadow-xs: var(--shadow-xs, 0 2px 8px -2px rgba(0,0,0,.08));
	--mp-shadow-sm: var(--shadow-s, 0 8px 24px -8px rgba(0,0,0,.18));
	--mp-shadow: var(--shadow-m, 0 12px 34px -14px rgba(0,0,0,.22));
	--mp-shadow-md: var(--shadow-l, 0 18px 40px -14px rgba(0,0,0,.28));
	--mp-shadow-lg: var(--shadow-xl, 0 24px 60px -18px rgba(0,0,0,.32));
}

.misepress.misepress-acss .misepress-page--single {
	padding-inline: var(--space-m, clamp(1rem, 3vw, 2rem)) !important;
	padding-block: var(--space-s, clamp(.75rem, 2vw, 1.5rem)) !important;
	background: transparent !important;
}

.misepress.misepress-acss .misepress-page--single .misepress__recipe,
.misepress.misepress-acss .misepress-page--single .misepress__main,
.misepress.misepress-acss .misepress-page--single .misepress__aside,
.misepress.misepress-acss .misepress-page--single .misepress__header {
	gap: var(--mp-single-section-gap, var(--space-m, 1rem)) !important;
}

.misepress.misepress-acss .misepress-page--single .misepress__body,
.misepress.misepress-acss .misepress-single--layout-sidebar .misepress__body {
	gap: var(--space-l, 2rem) !important;
}

.misepress.misepress-acss .misepress-page--single .misepress__aside .misepress__section,
.misepress.misepress-acss .misepress-page--single .misepress__main .misepress__section,
.misepress.misepress-acss .misepress-page--single .misepress__section--ingredients,
.misepress.misepress-acss .misepress-page--single .misepress__section--instructions,
.misepress.misepress-acss .misepress-page--single .misepress__section--equipment,
.misepress.misepress-acss .misepress-page--single .misepress__section--nutrition,
.misepress.misepress-acss .misepress-page--single .misepress__section--reviews,
.misepress.misepress-acss .misepress-page--single .misepress__header--hero .misepress__hero-overlay,
.misepress.misepress-acss .misepress-page--single .misepress__header--hero .misepress__hero-stats {
	background: var(--mp-card-bg, var(--base-ultra-light, #fff)) !important;
	color: var(--mp-card-text, var(--base-ultra-dark, #1a1a1a)) !important;
	border-color: var(--mp-card-border, var(--base-light, #ececec)) !important;
	border-radius: var(--mp-card-radius, var(--radius-m, 18px)) !important;
	box-shadow: var(--mp-shadow-xs, var(--shadow-xs, none)) !important;
}

.misepress.misepress-acss .misepress-page--single .misepress__aside .misepress__section,
.misepress.misepress-acss .misepress-page--single .misepress__main .misepress__section,
.misepress.misepress-acss .misepress-page--single .misepress__section--ingredients,
.misepress.misepress-acss .misepress-page--single .misepress__section--instructions,
.misepress.misepress-acss .misepress-page--single .misepress__section--equipment,
.misepress.misepress-acss .misepress-page--single .misepress__section--nutrition,
.misepress.misepress-acss .misepress-page--single .misepress__section--reviews {
	padding: var(--space-m, clamp(1rem, 2.25vw, 1.5rem)) !important;
}

.misepress.misepress-acss .misepress-page--single .misepress__media,
.misepress.misepress-acss .misepress-page--single .misepress__header--hero,
.misepress.misepress-acss .misepress-page--single .misepress__header--hero .misepress__media--hero,
.misepress.misepress-acss .misepress-page--single .misepress__header--hero .misepress__media--hero img {
	border-radius: var(--mp-radius, var(--radius-m, 18px)) !important;
}

.misepress.misepress-acss .misepress-page--single .misepress__heading,
.misepress.misepress-acss .misepress-page--single .misepress__title,
.misepress.misepress-acss .misepress-page--single .misepress__title--hero,
.misepress.misepress-acss .misepress-page--single .misepress__excerpt--hero,
.misepress.misepress-acss .misepress-page--single .misepress__ingredient-name,
.misepress.misepress-acss .misepress-page--single .misepress__step-text {
	color: var(--mp-color-fg, var(--base-ultra-dark, #1a1a1a)) !important;
}

.misepress.misepress-acss .misepress-page--single .misepress__excerpt,
.misepress.misepress-acss .misepress-page--single .misepress__meta-label {
	color: var(--mp-color-muted, var(--base, #6b6b6b)) !important;
}

.misepress.misepress-acss .misepress-page--single .misepress__header--hero .misepress__title-actions--hero,
.misepress.misepress-acss .misepress-page--single .misepress__steps,
.misepress.misepress-acss .misepress-page--single .misepress__ingredients,
.misepress.misepress-acss .misepress__filter-mobile-bar-actions {
	gap: var(--space-xs, .65rem) !important;
}

.misepress.misepress-acss .misepress-page--single .misepress__header--hero .misepress__title-actions--hero .misepress__save-btn,
.misepress.misepress-acss .misepress-page--single .misepress__header--hero .misepress__title-actions--hero .misepress__btn,
.misepress.misepress-acss .misepress__btn,
.misepress.misepress-acss .misepress__scale-pill,
.misepress.misepress-acss .misepress__nut-mode {
	border-radius: var(--radius-pill, 999px) !important;
	border-color: var(--mp-color-border, var(--base-light, #ececec)) !important;
	background: var(--mp-color-surface, var(--base-ultra-light, #fff)) !important;
	color: var(--mp-color-fg, var(--base-ultra-dark, #1a1a1a)) !important;
	box-shadow: var(--mp-shadow-xs, var(--shadow-xs, none)) !important;
}

.misepress.misepress-acss .misepress__btn--primary,
.misepress.misepress-acss .misepress__density-btn.is-active,
.misepress.misepress-acss .misepress__preset.is-active,
.misepress.misepress-acss .misepress__units-btn.is-active,
.misepress.misepress-acss .misepress__nut-mode.is-active,
.misepress.misepress-acss .misepress__scale-pill.is-active {
	background: var(--mp-color-accent-active, var(--action-dark, var(--action, #c2410c))) !important;
	border-color: var(--mp-color-accent-active, var(--action-dark, var(--action, #c2410c))) !important;
	color: var(--mp-color-accent-contrast, #fff) !important;
}

.misepress.misepress-acss .misepress-page--single .misepress__step {
	background: var(--mp-color-surface, var(--base-ultra-light, #fff)) !important;
	border-color: var(--mp-color-border, var(--base-light, #ececec)) !important;
	border-radius: var(--radius-s, 12px) !important;
	padding-block: var(--space-s, .85rem) !important;
}

.misepress.misepress-acss .misepress-page--single .misepress__step::before {
	background: var(--mp-color-accent-active, var(--action-dark, var(--action, #c2410c))) !important;
	color: var(--mp-color-accent-contrast, #fff) !important;
	box-shadow: 0 0 0 3px var(--mp-color-surface, var(--base-ultra-light, #fff)) !important;
}

.misepress.misepress-acss .misepress-page--single .misepress__ingredient,
.misepress.misepress-acss .misepress-page--single .misepress__main .misepress__section,
.misepress.misepress-acss .misepress-page--single .misepress__meta,
.misepress.misepress-acss .misepress-page--single .misepress__meta-item {
	border-color: var(--mp-color-border, var(--base-light, #ececec)) !important;
}

.misepress.misepress-acss .misepress__grid { gap: var(--mp-grid-gap, var(--space-m, 1.5rem)) !important; }
.misepress.misepress-acss .misepress__filters { gap: var(--mp-archive-filter-gap, var(--space-m, 1.5rem)) !important; }


/* =====================================================================
 * - ACSS active: remaining orange/dark controls now use ACSS action tokens.
 * - Mobile archive: only two useful view modes are exposed: 2-up and 1-up.
 * - Archive cards align with the filter/header edge on mobile.
 * ===================================================================== */
.misepress.misepress-acss {
	--mp-color-accent: var(--action, #c2410c);
	--mp-color-accent-active: var(--action, var(--mp-color-accent));
	--mp-color-accent-contrast: var(--action-ultra-light, #fff);
	--mp-color-accent-soft: var(--action-light-trans-90, color-mix(in srgb, var(--action, #c2410c) 10%, transparent));
	--mp-color-bg: var(--base-ultra-light, #fffdf8);
	--mp-color-surface: var(--base-ultra-light, #fff);
	--mp-color-fg: var(--base-ultra-dark, #1a1a1a);
	--mp-color-muted: var(--base, #6b6b6b);
	--mp-color-border: var(--base-light, #ececec);
	--mp-card-bg: var(--base-ultra-light, #fff);
	--mp-card-text: var(--base-ultra-dark, #1a1a1a);
	--mp-card-accent: var(--action, #c2410c);
	--mp-card-border: var(--base-light, #ececec);
	--mp-card-radius: var(--radius-m, 18px);
	--mp-filter-bg: var(--base-ultra-light, #fff);
	--mp-filter-text: var(--base-ultra-dark, #1a1a1a);
	--mp-filter-accent: var(--action, #c2410c);
	--mp-filter-border: var(--base-light, #ececec);
	--mp-filter-radius: var(--radius-m, 18px);
	--mp-grid-gap: var(--grid-gap, var(--space-m, 1.5rem));
	--mp-archive-filter-gap: var(--content-gap, var(--space-m, 1.5rem));
}

/* ACSS should colour every remaining accent/control consistently. */
.misepress.misepress-acss .misepress__density-btn.is-active,
.misepress.misepress-acss .misepress__preset.is-active,
.misepress.misepress-acss .misepress__units-btn.is-active,
.misepress.misepress-acss .misepress__nut-mode.is-active,
.misepress.misepress-acss .misepress__scale-pill.is-active,
.misepress.misepress-acss .misepress__scale-pill--more.is-active,
.misepress.misepress-acss .misepress__btn--primary,
.misepress.misepress-acss .misepress__filter-trigger,
.misepress.misepress-acss .misepress__scale-pantry-go,
.misepress.misepress-acss .misepress__timer-btn.is-running,
.misepress.misepress-acss .misepress__timer-btn:hover {
	background: var(--action, var(--mp-color-accent)) !important;
	border-color: var(--action, var(--mp-color-accent)) !important;
	color: var(--action-ultra-light, #fff) !important;
}

.misepress.misepress-acss .misepress-page--single .misepress__header--hero .misepress__hero-stat:first-child .misepress__hero-stat-value,
.misepress.misepress-acss .misepress__price,
.misepress.misepress-acss .misepress__scale-pantry-feedback,
.misepress.misepress-acss .misepress__grid-eyebrow,
.misepress.misepress-acss .misepress__grid-card:hover .misepress__grid-title,
.misepress.misepress-acss .misepress__filter-loadmore {
	color: var(--action, var(--mp-color-accent)) !important;
}

.misepress.misepress-acss .misepress__timer-btn,
.misepress.misepress-acss .misepress__scale-inline,
.misepress.misepress-acss .misepress__active-chips,
.misepress.misepress-acss .misepress__filter-opt:has(input:checked),
.misepress.misepress-acss .misepress__filter-opt--icon:has(input:checked),
.misepress.misepress-acss .misepress__chip {
	background: var(--action-light-trans-90, var(--mp-color-accent-soft)) !important;
	border-color: var(--action-light-trans-60, var(--base-light, var(--mp-color-border))) !important;
}

.misepress.misepress-acss .misepress__density,
.misepress.misepress-acss .misepress__density-btn,
.misepress.misepress-acss .misepress__sort-label select,
.misepress.misepress-acss .misepress__preset,
.misepress.misepress-acss .misepress__grid-card,
.misepress.misepress-acss .misepress__filters {
	border-color: var(--base-light, var(--mp-color-border)) !important;
	border-radius: var(--radius-m, var(--mp-radius)) !important;
}

.misepress.misepress-acss .misepress__density-btn:not(.is-active),
.misepress.misepress-acss .misepress__sort-label select,
.misepress.misepress-acss .misepress__preset:not(.is-active),
.misepress.misepress-acss .misepress__grid-card,
.misepress.misepress-acss .misepress__filters {
	background: var(--base-ultra-light, var(--mp-color-bg)) !important;
	color: var(--base-ultra-dark, var(--mp-color-fg)) !important;
}

/* Mobile archive cleanup. The header/filter controls and cards now share the same edge. */
@media (max-width: 720px) {
	.misepress__archive .misepress__archive-layout {
		padding-inline: 0 !important;
	}
	.misepress__archive .misepress__archive-results,
	.misepress__archive .misepress__grid,
	.misepress__archive .misepress__grid-card {
		width: 100% !important;
		max-width: none !important;
		justify-self: stretch !important;
	}
	.misepress__archive .misepress__grid {
		justify-items: stretch !important;
	}

	/* Only two mobile view choices: compact = 2 recipes per row, comfortable = 1 per row. */
	.misepress__archive .misepress__density-btn[data-mp-density="visual"] {
		display: none !important;
	}
	.misepress__archive--density-compact .misepress__grid,
	.misepress__archive.misepress__archive--density-compact .misepress__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
		gap: var(--grid-gap, var(--space-s, .75rem)) !important;
	}
	.misepress__archive--density-comfortable .misepress__grid,
	.misepress__archive.misepress__archive--density-comfortable .misepress__grid,
	.misepress__archive--density-visual .misepress__grid,
	.misepress__archive.misepress__archive--density-visual .misepress__grid {
		grid-template-columns: minmax(0, 1fr) !important;
		gap: var(--grid-gap, var(--space-m, 1rem)) !important;
	}

	/* Make the 2-up card readable on narrow phones. */
	.misepress__archive--density-compact .misepress__grid-body {
		padding: var(--space-xs, .65rem) !important;
	}
	.misepress__archive--density-compact .misepress__grid-title {
		font-size: clamp(.9rem, 4vw, 1.05rem) !important;
	}
	.misepress__archive--density-compact .misepress__grid-excerpt,
	.misepress__archive--density-compact .misepress__grid-meta,
	.misepress__archive--density-compact .misepress__grid-nut,
	.misepress__archive--density-compact .misepress__grid-allergens {
		display: none !important;
	}
}


/* =====================================================================
 * ===================================================================== */
@media (max-width: 900px) {
	/* Collapsible filters above recipes: show all filter groups, and keep the opener visible after scrolling past it. */
	.misepress__archive--mobile-collapsible-top .misepress__filter-trigger {
		position: sticky !important;
		top: max(0px, env(safe-area-inset-top)) !important;
		z-index: 30 !important;
		width: 100% !important;
		justify-content: center !important;
		margin-block: 0 var(--space-s, .85rem) !important;
		border-radius: var(--mp-filter-radius, var(--radius-m, 12px)) !important;
		box-shadow: var(--mp-shadow-xs, 0 6px 18px rgba(0,0,0,.08)) !important;
	}
	.misepress__archive--mobile-collapsible-top .misepress__filters {
		width: 100% !important;
		max-height: 0 !important;
		overflow: hidden !important;
		box-sizing: border-box !important;
	}
	.misepress__archive--mobile-collapsible-top.is-mp-filters-open .misepress__filters {
		max-height: none !important;
		overflow: visible !important;
		padding: var(--space-s, .85rem) !important;
		margin-bottom: var(--space-m, 1rem) !important;
	}
	.misepress__archive--mobile-collapsible-top .misepress__filter-form {
		max-height: none !important;
		overflow: visible !important;
	}
	.misepress__archive--mobile-collapsible-top .misepress__filter-opts {
		max-height: none !important;
		overflow: visible !important;
	}
}

/* Button states: saved favourites and shopping list must read as active everywhere. */
.misepress__save-btn.is-saved,
.misepress__save-btn[aria-pressed="true"] {
	background: var(--mp-color-accent, #c2410c) !important;
	color: var(--mp-color-accent-contrast, #fff) !important;
	border-color: var(--mp-color-accent, #c2410c) !important;
}
.misepress__save-btn.is-saved svg,
.misepress__save-btn[aria-pressed="true"] svg { transform: scale(1.06); }
.misepress__shopping-btn.is-added,
.misepress__shopping-btn[aria-pressed="true"] {
	background: var(--mp-color-accent, #c2410c) !important;
	color: var(--mp-color-accent-contrast, #fff) !important;
	border-color: var(--mp-color-accent, #c2410c) !important;
}
.misepress__shopping-btn.is-added::after,
.misepress__shopping-btn[aria-pressed="true"]::after {
	content: "✓";
	font-size: .85em;
	font-weight: 800;
	margin-left: .35em;
}
.misepress.misepress-acss .misepress__save-btn.is-saved,
.misepress.misepress-acss .misepress__save-btn[aria-pressed="true"],
.misepress.misepress-acss .misepress__shopping-btn.is-added,
.misepress.misepress-acss .misepress__shopping-btn[aria-pressed="true"] {
	background: var(--action, var(--mp-color-accent)) !important;
	border-color: var(--action, var(--mp-color-accent)) !important;
	color: var(--action-ultra-light, #fff) !important;
}

/* Single recipe allergens: visually distinct and centred. */
.misepress-page--single .misepress__section--allergens {
	text-align: center !important;
	align-items: center !important;
}
.misepress-page--single .misepress__allergens,
.misepress-page--single .misepress__header--hero .misepress__hero-allergens {
	justify-content: center !important;
	align-items: center !important;
	gap: var(--space-xs, .65rem) !important;
	width: 100% !important;
}
.misepress-page--single .misepress__allergen,
.misepress-page--single .misepress__header--hero .misepress__hero-allergen {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	min-height: 2.25rem !important;
	padding: .45rem .8rem !important;
	border: 1px solid color-mix(in srgb, var(--mp-color-accent, #c2410c) 35%, var(--mp-color-border, #ececec)) !important;
	background: color-mix(in srgb, var(--mp-color-accent, #c2410c) 10%, var(--mp-color-surface, #fff)) !important;
	color: var(--mp-color-fg, #1a1a1a) !important;
	border-radius: var(--radius-pill, 999px) !important;
	box-shadow: var(--mp-shadow-xs, 0 3px 12px rgba(0,0,0,.05)) !important;
}
.misepress-page--single .misepress__allergen a { border: 0 !important; font-weight: 700 !important; }

/* Nutrition: cleaner label, reliable macro grid, all visible values align correctly. */
.misepress-page--single .misepress__nutrition-label {
	background: var(--mp-card-bg, var(--mp-color-surface, #fff)) !important;
	border: 1px solid var(--mp-color-border, #ececec) !important;
	border-radius: var(--mp-card-radius, 16px) !important;
	padding: var(--space-m, 1.25rem) !important;
}
.misepress__nut-head { display: flex; align-items: center; justify-content: space-between; gap: var(--space-s, .85rem); flex-wrap: wrap; }
.misepress__nut-grid { display: grid; grid-template-columns: minmax(120px, .65fr) minmax(0, 1.35fr); gap: var(--space-m, 1rem); align-items: center; }
.misepress__nut-cal { min-height: 7rem; display: grid; place-items: center; align-content: center; border-radius: var(--radius-m, 16px); background: var(--mp-color-accent-soft, #fde7d3); color: var(--mp-color-fg, #1a1a1a); }
.misepress__nut-cal-num { font-size: clamp(2rem, 7vw, 3.25rem); font-weight: 800; line-height: .95; }
.misepress__nut-cal-lbl { font-size: .85rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--mp-color-muted, #6b6b6b); }
.misepress__nut-macros { list-style: none; margin: 0; padding: 0; display: grid; grid-template-columns: repeat(auto-fit, minmax(9rem, 1fr)); gap: .55rem; }
.misepress__nut-macros li { display: flex; align-items: center; gap: .45rem; min-width: 0; padding: .65rem .75rem; border: 1px solid var(--mp-color-border, #ececec); border-radius: var(--radius-s, 10px); background: var(--mp-color-surface, #fff); }
.misepress__nut-macros strong { margin-right: .15rem; white-space: nowrap; }
.misepress__nut-bar { height: .65rem; margin-top: var(--space-s, .85rem); border-radius: 999px; overflow: hidden; background: color-mix(in srgb, var(--mp-color-border, #ececec) 70%, transparent); display: flex; }
.misepress__nut-seg { display: block; min-width: 0; }
.misepress__nut-context,
.misepress__nut-source { color: var(--mp-color-muted, #6b6b6b); }
@media (max-width: 640px) { .misepress__nut-grid { grid-template-columns: 1fr; } }

/* Reviews: card-like, readable, no cramped rating distribution. */
.misepress-page--single .misepress__section--reviews,
.misepress-page--single .misepress__reviews,
.misepress-page--single [data-mp-reviews] {
	background: var(--mp-card-bg, var(--mp-color-surface, #fff)) !important;
	border-color: var(--mp-card-border, var(--mp-color-border, #ececec)) !important;
	border-radius: var(--mp-card-radius, 16px) !important;
}
.misepress__reviews-summary {
	align-items: center !important;
	padding: var(--space-s, .85rem) !important;
	border: 1px solid var(--mp-color-border, #ececec) !important;
	border-radius: var(--radius-m, 16px) !important;
	background: color-mix(in srgb, var(--mp-color-accent, #c2410c) 5%, var(--mp-color-surface, #fff)) !important;
}
.misepress__reviews-score { justify-content: center; }
.misepress__reviews-dist { gap: .45rem !important; }
.misepress__reviews-dist-bar { background: color-mix(in srgb, var(--mp-color-border, #ececec) 80%, transparent) !important; }
.misepress__reviews-dist-bar span { background: var(--mp-color-accent, #c2410c) !important; }
@media (max-width: 640px) { .misepress__reviews-summary { grid-template-columns: 1fr !important; text-align: center; } }

/* Pro featured-image overlay filters. The class is only printed for Pro users. */
.misepress__recipe[class*="mp-hero-filter-"] .misepress__media--hero,
.misepress__recipe[class*="mp-hero-filter-"] .misepress__media--editorial { position: relative; overflow: hidden; }
.misepress__recipe[class*="mp-hero-filter-"] .misepress__media--hero::after,
.misepress__recipe[class*="mp-hero-filter-"] .misepress__media--editorial::after { content: ""; position: absolute; inset: 0; pointer-events: none; border-radius: inherit; }
.misepress__recipe.mp-hero-filter-soft .misepress__media::after { background: linear-gradient(180deg, transparent 45%, color-mix(in srgb, var(--mp-color-bg, #fffdf8) 72%, transparent)); }
.misepress.misepress-acss .misepress__recipe.mp-hero-filter-brand .misepress__media::after,
.misepress.misepress-acss 

/* =====================================================================
 * ===================================================================== */
/* Archive: keep filter panel, toolbar, and recipe cards on the same edge. */
.misepress__archive .misepress__archive-layout,
.misepress__archive .misepress__archive-results,
.misepress__archive .misepress__archive-results > .misepress__grid,
.misepress__archive .misepress__filters {
	box-sizing: border-box;
}
.misepress__archive .misepress__archive-results > .misepress__grid,
.misepress__archive .misepress__list,
.misepress__archive .misepress__editorial {
	margin-inline: 0 !important;
	padding-inline: 0 !important;
}
@media (max-width: 900px) {
	.misepress__archive .misepress-page__inner { width: 100%; }
	.misepress__archive .misepress__archive-layout { padding-inline: 0 !important; }
	.misepress__archive .misepress__filters,
	.misepress__archive .misepress__archive-results,
	.misepress__archive .misepress__grid-card { margin-inline: 0 !important; }
	.misepress__archive--mobile-collapsible-top .misepress__filter-trigger {
		position: sticky !important;
		top: max(0px, env(safe-area-inset-top)) !important;
		z-index: 60 !important;
	}
	.misepress__archive--mobile-collapsible-top .misepress__filters {
		width: 100% !important;
		max-width: none !important;
		max-height: 0 !important;
		height: auto !important;
		overflow: hidden !important;
	}
	.misepress__archive--mobile-collapsible-top.is-mp-filters-open .misepress__filters {
		max-height: none !important;
		height: auto !important;
		overflow: visible !important;
	}
	.misepress__archive--mobile-collapsible-top .misepress__filter-form,
	.misepress__archive--mobile-collapsible-top .misepress__filter-group,
	.misepress__archive--mobile-collapsible-top .misepress__filter-opts {
		max-height: none !important;
		height: auto !important;
		overflow: visible !important;
	}
}

/* Single recipe: make favourite/shopping states obvious, not just technically active. */
.misepress-page--single .misepress__title-actions .misepress__save-btn,
.misepress-page--single .misepress__title-actions .misepress__shopping-btn,
.misepress-page--single .misepress__title-actions .misepress__print-btn {
	position: static !important;
	width: auto !important;
	min-width: 2.65rem;
	height: 2.65rem;
	padding-inline: .78rem !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	gap: .35rem !important;
	white-space: nowrap;
}
.misepress-page--single .misepress__save-label,
.misepress-page--single [data-mp-shopping-label] {
	font-size: .82rem;
	font-weight: 750;
	line-height: 1;
}
.misepress-page--single .misepress__save-btn.is-saved,
.misepress-page--single .misepress__save-btn[aria-pressed="true"],
.misepress-page--single .misepress__shopping-btn.is-added,
.misepress-page--single .misepress__shopping-btn[aria-pressed="true"] {
	box-shadow: 0 6px 18px color-mix(in srgb, var(--mp-color-accent, #c2410c) 24%, transparent) !important;
}
.misepress-page--single .misepress__shopping-btn.is-added::after,
.misepress-page--single .misepress__shopping-btn[aria-pressed="true"]::after {
	content: none !important;
}
@media (max-width: 480px) {
	.misepress-page--single .misepress__title-actions .misepress__save-btn,
	.misepress-page--single .misepress__title-actions .misepress__shopping-btn,
	.misepress-page--single .misepress__title-actions .misepress__print-btn {
		min-width: 2.45rem;
		height: 2.45rem;
		padding-inline: .62rem !important;
	}
	.misepress-page--single .misepress__save-label,
	.misepress-page--single [data-mp-shopping-label] { font-size: .76rem; }
}

/* Pro featured-image overlays — keep soft blend, replace the old tint filters with edge-cut styles. */
.misepress__recipe.mp-hero-filter-edge-fade .misepress__media--hero,
.misepress__recipe.mp-hero-filter-edge-fade .misepress__media--editorial {
	-webkit-mask-image: linear-gradient(90deg, transparent 0, #000 7%, #000 93%, transparent 100%), linear-gradient(180deg, transparent 0, #000 7%, #000 92%, transparent 100%);
	-webkit-mask-composite: source-in;
	mask-image: linear-gradient(90deg, transparent 0, #000 7%, #000 93%, transparent 100%), linear-gradient(180deg, transparent 0, #000 7%, #000 92%, transparent 100%);
	mask-composite: intersect;
}
.misepress__recipe.mp-hero-filter-brush-frame .misepress__media--hero,
.misepress__recipe.mp-hero-filter-brush-frame .misepress__media--editorial {
	clip-path: polygon(3% 0, 14% 1.8%, 25% .4%, 37% 2%, 49% .6%, 61% 2.2%, 74% .7%, 89% 1.8%, 98% 0, 100% 8%, 98.5% 19%, 100% 31%, 98.2% 44%, 100% 56%, 98.6% 72%, 100% 86%, 96% 100%, 84% 98.5%, 70% 100%, 58% 98.2%, 43% 100%, 30% 98.5%, 16% 100%, 4% 97.6%, 0 89%, 1.6% 75%, 0 61%, 1.7% 48%, 0 35%, 1.4% 21%, 0 8%);
}
.misepress__recipe.mp-hero-filter-torn-edge .misepress__media--hero,
.misepress__recipe.mp-hero-filter-torn-edge .misepress__media--editorial {
	clip-path: polygon(0 4%, 7% 0, 15% 3%, 23% 0, 31% 2%, 40% 0, 49% 3%, 58% 0, 67% 2%, 76% 0, 85% 3%, 94% 0, 100% 5%, 97% 15%, 100% 25%, 97% 36%, 100% 48%, 97% 60%, 100% 73%, 96% 85%, 100% 96%, 91% 100%, 82% 97%, 73% 100%, 64% 98%, 54% 100%, 45% 97%, 35% 100%, 26% 98%, 16% 100%, 7% 97%, 0 100%, 3% 86%, 0 75%, 3% 63%, 0 52%, 3% 40%, 0 28%, 3% 16%);
}
.misepress__recipe.mp-hero-filter-organic-cut .misepress__media--hero,
.misepress__recipe.mp-hero-filter-organic-cut .misepress__media--editorial {
	border-radius: 42% 58% 48% 52% / 7% 8% 10% 9% !important;
	clip-path: ellipse(49% 46% at 50% 50%);
}
.misepress__recipe.mp-hero-filter-edge-fade .misepress__media::after,
.misepress__recipe.mp-hero-filter-brush-frame .misepress__media::after,
.misepress__recipe.mp-hero-filter-torn-edge .misepress__media::after,
.misepress__recipe.mp-hero-filter-organic-cut .misepress__media::after {
	background: linear-gradient(180deg, transparent 50%, color-mix(in srgb, var(--mp-color-bg, #fffdf8) 28%, transparent));
}

/* Nutrition: keep enabled macros visible and avoid squeezed zero-width segments. */
.misepress__nut-seg--p:empty,
.misepress__nut-seg--c:empty,
.misepress__nut-seg--f:empty { min-width: 0; }
.misepress__nut-macros li { justify-content: flex-start; }

/* =====================================================================
 * ===================================================================== */
/* Real single-recipe template widths */
.misepress-single--width-narrow .misepress-page__inner { max-width: 760px; margin-inline: auto; }
.misepress-single--width-normal .misepress-page__inner { max-width: 980px; margin-inline: auto; }
.misepress-single--width-wide .misepress-page__inner { max-width: min(1200px, var(--mp-page-max-w, 1200px)); margin-inline: auto; }
.misepress-single--width-full .misepress-page__inner { max-width: none; }

/* Magazine template: full hero, stacked content */
.misepress-page--magazine .misepress__recipe { background: transparent; box-shadow: none; padding: 0; }
.misepress-page--magazine .misepress__header--hero {
  border-radius: var(--mp-card-radius, var(--mp-radius, 24px));
  overflow: hidden;
  min-height: clamp(360px, 52vw, 680px);
  display: grid;
  align-items: end;
  background: var(--mp-color-surface, #fff);
}
.misepress-page--magazine .misepress__media--hero { grid-area: 1 / 1; height: 100%; }
.misepress-page--magazine .misepress__media--hero img { height: 100%; object-fit: cover; }
.misepress-page--magazine .misepress__hero-overlay {
  grid-area: 1 / 1;
  align-self: end;
  background: linear-gradient(180deg, transparent, rgba(0,0,0,.62));
  color: #fff;
  padding: clamp(1.5rem, 5vw, 4rem);
}
.misepress-page--magazine .misepress__title--hero,
.misepress-page--magazine .misepress__excerpt--hero { color: #fff !important; max-width: 820px; }
.misepress-page--magazine .misepress__hero-stats { justify-content: flex-start; margin-inline: 0; }

/* Compact template: fast-reading dense recipe sheet */
.misepress-page--compact .misepress__recipe { gap: var(--space-s, 1rem) !important; padding: var(--space-s, 1rem) !important; }
.misepress-page--compact .misepress__header--hero,
.misepress-page--compact .misepress__section { border-radius: var(--radius-s, 10px); }
.misepress-page--compact .misepress__title--hero { font-size: clamp(1.7rem, 4vw, 2.4rem); }
.misepress-page--compact .misepress__hero-overlay { padding: var(--space-s, 1rem) !important; }
.misepress-page--compact .misepress__section { padding: var(--space-s, 1rem); }
.misepress-page--compact .misepress__steps { gap: .65rem; }

/* Centered template: landing-page style intro, readable body */
.misepress-page--centered .misepress-page__inner { text-align: center; }
.misepress-page--centered .misepress__recipe { align-items: center; }
.misepress-page--centered .misepress__header--hero,
.misepress-page--centered .misepress__body,
.misepress-page--centered .misepress__section { width: 100%; }
.misepress-page--centered .misepress__hero-stats,
.misepress-page--centered .misepress__hero-allergens { justify-content: center; }
.misepress-page--centered .misepress__ingredients,
.misepress-page--centered .misepress__steps,
.misepress-page--centered .misepress__story,
.misepress-page--centered .misepress__notes { text-align: left; }

/* Minimalist template: theme-led, low chrome */
.misepress-page--minimalist .misepress__recipe { background: transparent !important; border: 0 !important; box-shadow: none !important; padding: 0 !important; }
.misepress-page--minimalist .misepress__header--hero { background: transparent !important; border: 0 !important; box-shadow: none !important; padding-block: var(--space-l, 2rem) var(--space-m, 1.25rem); }
.misepress-page--minimalist .misepress__hero-overlay { padding: 0 !important; }
.misepress-page--minimalist .misepress__title--hero { font-size: clamp(2rem, 7vw, 4.4rem); letter-spacing: -.04em; }
.misepress-page--minimalist .misepress__section { background: transparent !important; border-inline: 0 !important; border-top: 1px solid var(--mp-color-border, #ececec); box-shadow: none !important; border-radius: 0 !important; padding-inline: 0 !important; }
.misepress-page--minimalist .misepress__step { background: transparent !important; border: 0 !important; border-left: 2px solid var(--mp-color-border, #ececec) !important; border-radius: 0 !important; }

/* Archive edge alignment, especially mobile collapsible filters. */
.misepress__archive .misepress-page__inner { box-sizing: border-box; }
.misepress__archive .misepress__archive-layout { align-items: start; }
.misepress__archive .misepress__filters,
.misepress__archive .misepress__archive-results,
.misepress__archive .misepress__grid,
.misepress__archive .misepress__list,
.misepress__archive .misepress__editorial { width: 100%; max-width: 100%; box-sizing: border-box; }
@media (max-width: 900px) {
  .misepress__archive .misepress-page__inner { padding-inline: var(--mp-archive-pad-x, var(--space-m, 1rem)); }
  .misepress__archive .misepress__archive-layout,
  .misepress__archive .misepress__active-chips,
  .misepress__archive .misepress__filters,
  .misepress__archive .misepress__archive-results { margin-inline: 0 !important; padding-inline: 0 !important; }
  .misepress__archive .misepress__grid { gap: var(--mp-grid-gap, var(--space-s, .85rem)); }
}

/* Allergen labels: centered chips with hover/focus explanations. */
.misepress-page--single .misepress__allergen { position: relative; cursor: help; }
.misepress-page--single .misepress__allergen-tip {
  position: absolute;
  left: 50%;
  bottom: calc(100% + .55rem);
  transform: translateX(-50%) translateY(.25rem);
  z-index: 20;
  width: min(18rem, 82vw);
  padding: .65rem .75rem;
  border-radius: var(--radius-s, 10px);
  background: var(--mp-color-fg, #1a1a1a);
  color: var(--mp-color-bg, #fff);
  box-shadow: var(--mp-shadow-sm, 0 10px 28px rgba(0,0,0,.18));
  font-size: .82rem;
  line-height: 1.35;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity .15s ease, transform .15s ease, visibility .15s ease;
}
.misepress-page--single .misepress__allergen-tip::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 100%;
  transform: translateX(-50%);
  border: .4rem solid transparent;
  border-top-color: var(--mp-color-fg, #1a1a1a);
}
.misepress-page--single .misepress__allergen:hover .misepress__allergen-tip,
.misepress-page--single .misepress__allergen:focus-within .misepress__allergen-tip { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0); }

/* Nutrition: tighter <Per serving>, clearer status, all enabled macros remain visible. */
.misepress-page--single .misepress__nutrition-label { padding: var(--space-s, 1rem) !important; }
.misepress__nut-head { margin-bottom: .35rem; }
.misepress__nut-grid { gap: var(--space-s, .85rem) !important; }
.misepress__nut-bar { margin-top: .55rem !important; }
.misepress__nut-context { margin: .28rem 0 0 !important; font-size: .82rem; line-height: 1.2; }
.misepress__nut-source { margin: .4rem 0 0 !important; font-size: .8rem; line-height: 1.35; }
.misepress__nut-source--calc { opacity: .92; }
.misepress__nut-alert { margin: .45rem 0 0; padding: .6rem .75rem; border: 1px solid color-mix(in srgb, var(--mp-color-accent, #c2410c) 28%, var(--mp-color-border, #ececec)); border-radius: var(--radius-s, 10px); background: color-mix(in srgb, var(--mp-color-accent, #c2410c) 7%, var(--mp-color-surface, #fff)); color: var(--mp-color-fg, #1a1a1a); font-size: .86rem; }

/* Reviews: tighter and more useful without the huge empty-card feeling. */
.misepress-page--single .misepress__section--reviews,
.misepress-page--single .misepress__reviews,
.misepress-page--single [data-mp-reviews] { padding: var(--space-s, .95rem) !important; gap: var(--space-xs, .6rem) !important; }
.misepress-page--single .misepress__reviews-summary { grid-template-columns: auto minmax(0, 1fr) !important; gap: var(--space-s, .75rem) !important; margin: .15rem 0 .45rem !important; padding: .65rem !important; align-items: center !important; }
.misepress-page--single .misepress__reviews-score { min-width: 4.4rem !important; gap: .05rem !important; }
.misepress-page--single .misepress__reviews-avg { font-size: clamp(1.45rem, 5vw, 1.95rem) !important; line-height: 1 !important; }
.misepress-page--single .misepress__reviews-count { font-size: .76rem !important; }
.misepress-page--single .misepress__reviews-dist { gap: .14rem !important; }
.misepress-page--single .misepress__reviews-dist li { gap: .32rem !important; font-size: .76rem !important; }
.misepress-page--single .misepress__reviews-dist-bar { height: .34rem !important; }
.misepress-page--single .misepress__review-form { gap: .38rem !important; padding-top: .5rem !important; margin: .28rem 0 0 !important; }
.misepress-page--single .misepress__review-row { gap: .38rem !important; }
.misepress-page--single .misepress__review-row input,
.misepress-page--single .misepress__review-comment-label textarea { padding: .42rem .55rem !important; }
.misepress-page--single .misepress__reviews-list { margin-top: .5rem !important; gap: .4rem !important; }
.misepress-page--single .misepress__review { padding: .52rem .62rem !important; }
.misepress-page--single .misepress__review-head { gap: .32rem !important; margin-bottom: .12rem !important; }
@media (max-width: 640px) {
  .misepress-page--single .misepress__reviews-summary { grid-template-columns: 1fr !important; gap: .45rem !important; text-align: center !important; }
  .misepress-page--single .misepress__reviews-dist li { grid-template-columns: 2.25rem 1fr 1.5rem !important; }
  .misepress-page--single .misepress__review-row { grid-template-columns: 1fr !important; }
}

/* ACSS completion: when inheritance is enabled, no remaining native orange/cream/brown tones should lead. */
.misepress.misepress-acss .misepress,
.misepress.misepress-acss .misepress-page {
  --mp-color-bg: var(--base-ultra-light, #fff);
  --mp-color-surface: var(--base-ultra-light, #fff);
  --mp-color-fg: var(--base-ultra-dark, #111);
  --mp-color-muted: var(--base, #666);
  --mp-color-border: var(--base-light, #e8e8e8);
  --mp-color-accent: var(--action, #c2410c);
  --mp-color-accent-active: var(--action-dark, #9a3412);
  --mp-color-accent-soft: var(--action-light-trans-90, color-mix(in srgb, var(--action, #c2410c) 10%, transparent));
  --mp-card-bg: var(--base-ultra-light, #fff);
  --mp-card-text: var(--base-ultra-dark, #111);
  --mp-card-accent: var(--action, #c2410c);
  --mp-card-border: var(--base-light, #e8e8e8);
  --mp-filter-bg: var(--base-ultra-light, #fff);
  --mp-filter-text: var(--base-ultra-dark, #111);
  --mp-filter-accent: var(--action, #c2410c);
  --mp-filter-border: var(--base-light, #e8e8e8);
  --mp-color-allergen-bg: var(--action-light-trans-90, color-mix(in srgb, var(--action, #c2410c) 10%, transparent));
  --mp-color-allergen-fg: var(--action-dark, var(--base-ultra-dark, #111));
  --mp-macro-protein: var(--action, #c2410c);
  --mp-macro-carbs: var(--primary, var(--action, #c2410c));
  --mp-macro-fat: var(--secondary, var(--action-dark, #9a3412));
  --mp-macro-fiber: var(--success, var(--action, #16a34a));
  --mp-macro-sugar: var(--accent, var(--action, #c2410c));
  --mp-macro-sodium: var(--base, #666);
  --mp-macro-saturated-fat: var(--base-dark, #333);
}
.misepress.misepress-acss .misepress__btn--primary,
.misepress.misepress-acss .misepress__density-btn.is-active,
.misepress.misepress-acss .misepress__preset.is-active,
.misepress.misepress-acss .misepress__units-btn.is-active,
.misepress.misepress-acss .misepress__nut-mode.is-active,
.misepress.misepress-acss .misepress__scale-pill.is-active,
.misepress.misepress-acss .misepress__tab.is-active,
.misepress.misepress-acss .misepress__pagination .page-numbers.current {
  background: var(--action, var(--mp-color-accent)) !important;
  border-color: var(--action, var(--mp-color-accent)) !important;
  color: var(--action-ultra-light, #fff) !important;
}
.misepress.misepress-acss .misepress__filter-opt:has(input:checked),
.misepress.misepress-acss .misepress__filter-opt--icon:has(input:checked),
.misepress.misepress-acss .misepress__chip,
.misepress.misepress-acss .misepress__allergen,
.misepress.misepress-acss .misepress__header--hero .misepress__hero-allergen {
  background: var(--action-light-trans-90, color-mix(in srgb, var(--action, #c2410c) 10%, transparent)) !important;
  border-color: var(--action, var(--mp-color-accent)) !important;
  color: var(--base-ultra-dark, #111) !important;
}
.misepress.misepress-acss .misepress__grid-card,
.misepress.misepress-acss .misepress__filters,
.misepress.misepress-acss .misepress__section,
.misepress.misepress-acss .misepress__step,
.misepress.misepress-acss .misepress__reviews-summary,
.misepress.misepress-acss .misepress__nut-macros li {
  background: var(--base-ultra-light, #fff) !important;
  border-color: var(--base-light, #e8e8e8) !important;
  color: var(--base-ultra-dark, #111) !important;
}
.misepress.misepress-acss .misepress__grid-nut-item--kcal,
.misepress.misepress-acss .misepress__nut-cal { background: var(--action-light-trans-90, color-mix(in srgb, var(--action, #c2410c) 10%, transparent)) !important; }
.misepress.misepress-acss .misepress__grid-nut-item--kcal strong,
.misepress.misepress-acss .misepress__archive-eyebrow,
.misepress.misepress-acss .misepress__grid-title:hover,
.misepress.misepress-acss .misepress__grid-card:hover .misepress__grid-title { color: var(--action, var(--mp-color-accent)) !important; }
.misepress.misepress-acss .misepress__grid-nut-item--p strong,
.misepress.misepress-acss .misepress__nut-dot--p { color: var(--mp-macro-protein) !important; background: var(--mp-macro-protein) !important; }
.misepress.misepress-acss .misepress__grid-nut-item--c strong,
.misepress.misepress-acss .misepress__nut-dot--c { color: var(--mp-macro-carbs) !important; background: var(--mp-macro-carbs) !important; }
.misepress.misepress-acss .misepress__grid-nut-item--f strong,
.misepress.misepress-acss .misepress__nut-dot--f { color: var(--mp-macro-fat) !important; background: var(--mp-macro-fat) !important; }
.misepress.misepress-acss .misepress__reviews-dist-bar span,
.misepress.misepress-acss .misepress__nut-seg--p { background: var(--mp-macro-protein, var(--action)) !important; }
.misepress.misepress-acss .misepress__nut-seg--c { background: var(--mp-macro-carbs, var(--action)) !important; }
.misepress.misepress-acss .misepress__nut-seg--f { background: var(--mp-macro-fat, var(--action-dark)) !important; }

/* =====================================================================
 * and repair Magazine / Centered single templates.
 * ===================================================================== */

/* Featured-image overlays have been removed from the product. Old saved values no-op. */
.misepress__recipe[class*="mp-hero-filter-"] .misepress__media--hero,
.misepress__recipe[class*="mp-hero-filter-"] .misepress__media--editorial {
  -webkit-mask-image: none !important;
  mask-image: none !important;
  clip-path: none !important;
  border-radius: inherit;
}
.misepress__recipe[class*="mp-hero-filter-"] .misepress__media::after { background: transparent !important; }

/* Repair the real templates so they are layout presets, not fragile cosmetic skins. */
.misepress-page--magazine .misepress-page__inner { max-width: min(1180px, calc(100vw - var(--space-m, 1rem) * 2)); }
.misepress-page--magazine .misepress__recipe { background: transparent !important; box-shadow: none !important; border: 0 !important; padding: 0 !important; gap: var(--mp-single-section-gap, var(--space-m, 1.25rem)) !important; }
.misepress-page--magazine .misepress__header--hero {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr);
  min-height: 0 !important;
  overflow: visible !important;
  border-radius: var(--mp-card-radius, var(--mp-radius, 18px)) !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}
.misepress-page--magazine .misepress__media--hero {
  grid-area: auto !important;
  height: auto !important;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  border-radius: var(--mp-card-radius, var(--mp-radius, 18px)) !important;
  border: 1px solid var(--mp-color-border, #ececec);
}
.misepress-page--magazine .misepress__media--hero img { width: 100%; height: 100%; object-fit: cover; }
.misepress-page--magazine .misepress__hero-overlay {
  grid-area: auto !important;
  align-self: auto !important;
  width: min(920px, calc(100% - var(--space-m, 1rem) * 2));
  margin: calc(var(--space-l, 2rem) * -1) auto 0 !important;
  padding: clamp(1rem, 3vw, 2rem) !important;
  border-radius: var(--mp-card-radius, var(--mp-radius, 18px)) !important;
  background: var(--mp-color-surface, #fff) !important;
  border: 1px solid var(--mp-color-border, #ececec) !important;
  box-shadow: var(--mp-shadow-md, 0 18px 40px -14px rgba(0,0,0,.22)) !important;
  color: var(--mp-color-fg, #1a1a1a) !important;
  text-align: center;
}
.misepress-page--magazine .misepress__title--hero,
.misepress-page--magazine .misepress__excerpt--hero { color: var(--mp-color-fg, #1a1a1a) !important; margin-inline: auto; }
.misepress-page--magazine .misepress__title-actions--hero,
.misepress-page--magazine .misepress__hero-stats,
.misepress-page--magazine .misepress__hero-allergens { justify-content: center !important; }

.misepress-page--centered .misepress-page__inner { max-width: min(860px, calc(100vw - var(--space-m, 1rem) * 2)); margin-inline: auto; text-align: center; }
.misepress-page--centered .misepress__recipe { background: transparent !important; box-shadow: none !important; border: 0 !important; padding-inline: 0 !important; align-items: stretch !important; }
.misepress-page--centered .misepress__header--hero,
.misepress-page--centered .misepress__section,
.misepress-page--centered .misepress__body { max-width: 100%; margin-inline: auto; }
.misepress-page--centered .misepress__hero-overlay { text-align: center; }
.misepress-page--centered .misepress__title-actions--hero,
.misepress-page--centered .misepress__title-actions,
.misepress-page--centered .misepress__hero-stats,
.misepress-page--centered .misepress__hero-allergens { justify-content: center !important; }
.misepress-page--centered .misepress__ingredients,
.misepress-page--centered .misepress__instructions,
.misepress-page--centered .misepress__steps,
.misepress-page--centered .misepress__story,
.misepress-page--centered .misepress__notes,
.misepress-page--centered .misepress__scale { text-align: left; }

@media (max-width: 640px) {
  .misepress-page--magazine .misepress-page__inner,
  .misepress-page--centered .misepress-page__inner { max-width: 100%; padding-inline: var(--space-s, .85rem); }
  .misepress-page--magazine .misepress__media--hero { aspect-ratio: 4 / 3; }
  .misepress-page--magazine .misepress__hero-overlay { width: 100%; margin-top: var(--space-s, .85rem) !important; }
  .misepress-page--magazine .misepress__title--hero,
  .misepress-page--centered .misepress__title--hero { font-size: clamp(2.15rem, 13vw, 3.4rem) !important; line-height: .95 !important; overflow-wrap: anywhere; }
}

/* Lock mobile filter panels/drawers to the viewport and prevent side-drag/side-scroll. */
@media (max-width: 900px) {
  html:has(.misepress__archive) { overflow-x: clip; }
  .misepress__archive,
  .misepress__archive * { box-sizing: border-box; }
  .misepress__archive { max-width: 100vw; overflow-x: clip; }
  .misepress__archive .misepress-page__inner,
  .misepress__archive .misepress__archive-layout,
  .misepress__archive .misepress__archive-results,
  .misepress__archive .misepress__filters { min-width: 0; max-width: 100%; }

  .misepress__archive:not(.misepress__archive--mobile-collapsible-top) .misepress__filters {
    position: fixed !important;
    inset-inline: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: 100dvw !important;
    max-width: 100dvw !important;
    margin: 0 !important;
    transform: translate3d(0, 100%, 0) !important;
    overscroll-behavior: contain;
    touch-action: pan-y;
  }
  .misepress__archive:not(.misepress__archive--mobile-collapsible-top).is-mp-filters-open .misepress__filters { transform: translate3d(0, 0, 0) !important; }

  .misepress__archive--mobile-collapsible-top .misepress__filters,
  .misepress__archive--mobile-collapsible-top .misepress__filter-form,
  .misepress__archive--mobile-collapsible-top .misepress__filter-group,
  .misepress__archive--mobile-collapsible-top .misepress__filter-opts {
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: clip !important;
  }
  .misepress__filter-opts,
  .misepress__quick-filters,
  .misepress__active-chips { min-width: 0; max-width: 100%; }
  .misepress__filter-opt,
  .misepress__quick-filter,
  .misepress__chip { max-width: 100%; }
  .misepress__filter-mobile-actions { width: auto !important; max-width: 100% !important; }
}

/* Complete ACSS inheritance: map every public colour/surface/border/radius token, then cover old hard-coded selectors. */
.misepress.misepress-acss .misepress,
.misepress.misepress-acss .misepress-page,
.misepress.misepress-acss .misepress__recipe {
  --mp-color-bg: var(--base-ultra-light, #fff) !important;
  --mp-color-surface: var(--base-ultra-light, #fff) !important;
  --mp-color-fg: var(--base-ultra-dark, #111) !important;
  --mp-color-muted: var(--base, #666) !important;
  --mp-color-border: var(--base-light, #e8e8e8) !important;
  --mp-color-accent: var(--action, #c2410c) !important;
  --mp-color-accent-active: var(--action-dark, var(--action, #c2410c)) !important;
  --mp-color-accent-contrast: var(--action-ultra-light, #fff) !important;
  --mp-color-accent-soft: var(--action-light-trans-90, color-mix(in srgb, var(--action, #c2410c) 10%, transparent)) !important;
  --mp-color-allergen-bg: var(--action-light-trans-90, color-mix(in srgb, var(--action, #c2410c) 10%, transparent)) !important;
  --mp-color-allergen-fg: var(--action-dark, var(--action, #c2410c)) !important;
  --mp-card-bg: var(--base-ultra-light, #fff) !important;
  --mp-card-text: var(--base-ultra-dark, #111) !important;
  --mp-card-accent: var(--action, #c2410c) !important;
  --mp-card-border: var(--base-light, #e8e8e8) !important;
  --mp-filter-bg: var(--base-ultra-light, #fff) !important;
  --mp-filter-text: var(--base-ultra-dark, #111) !important;
  --mp-filter-accent: var(--action, #c2410c) !important;
  --mp-filter-border: var(--base-light, #e8e8e8) !important;
  --mp-radius: var(--radius-m, 18px) !important;
  --mp-radius-sm: var(--radius-s, 12px) !important;
  --mp-card-radius: var(--radius-m, 18px) !important;
  --mp-filter-radius: var(--radius-m, 18px) !important;
  --mp-shadow-xs: var(--shadow-xs, 0 2px 8px -2px rgba(0,0,0,.08)) !important;
  --mp-shadow-sm: var(--shadow-s, 0 8px 24px -8px rgba(0,0,0,.18)) !important;
  --mp-shadow: var(--shadow-m, 0 12px 34px -14px rgba(0,0,0,.22)) !important;
  --mp-shadow-md: var(--shadow-l, 0 18px 40px -14px rgba(0,0,0,.28)) !important;
  --mp-grid-gap: var(--space-m, 1.5rem) !important;
  --mp-archive-filter-gap: var(--space-m, 1.5rem) !important;
}

.misepress.misepress-acss .misepress__header--hero,
.misepress.misepress-acss .misepress__section,
.misepress.misepress-acss .misepress__filters,
.misepress.misepress-acss .misepress__grid-card,
.misepress.misepress-acss .misepress__editorial-card,
.misepress.misepress-acss .misepress__row-card,
.misepress.misepress-acss .misepress__nutrition-label,
.misepress.misepress-acss .misepress__reviews-summary,
.misepress.misepress-acss .misepress__review,
.misepress.misepress-acss .misepress__scale-pantry,
.misepress.misepress-acss .misepress__hero-stats,
.misepress.misepress-acss .misepress__step {
  background: var(--base-ultra-light, #fff) !important;
  border-color: var(--base-light, #e8e8e8) !important;
  color: var(--base-ultra-dark, #111) !important;
}
.misepress.misepress-acss .misepress__scale-inline,
.misepress.misepress-acss .misepress__density-toggle,
.misepress.misepress-acss .misepress__view-toggle,
.misepress.misepress-acss .misepress__filter-toggle,
.misepress.misepress-acss .misepress__search-input,
.misepress.misepress-acss .misepress__filter-opt,
.misepress.misepress-acss .misepress__quick-filter,
.misepress.misepress-acss .misepress__chip,
.misepress.misepress-acss .misepress__allergen,
.misepress.misepress-acss .misepress__hero-allergen,
.misepress.misepress-acss .misepress__title-actions .misepress__btn,
.misepress.misepress-acss .misepress__title-actions .misepress__save-btn {
  background: var(--base-ultra-light, #fff) !important;
  border-color: var(--base-light, #e8e8e8) !important;
  color: var(--base-ultra-dark, #111) !important;
}
.misepress.misepress-acss .misepress__btn--primary,
.misepress.misepress-acss .misepress__filter-trigger,
.misepress.misepress-acss .misepress__filter-done,
.misepress.misepress-acss .misepress__scale-pantry-go,
.misepress.misepress-acss .misepress__density-btn.is-active,
.misepress.misepress-acss .misepress__view-btn.is-active,
.misepress.misepress-acss .misepress__preset.is-active,
.misepress.misepress-acss .misepress__units-btn.is-active,
.misepress.misepress-acss .misepress__nut-mode.is-active,
.misepress.misepress-acss .misepress__scale-pill.is-active,
.misepress.misepress-acss .misepress__scale-pill--more.is-active,
.misepress.misepress-acss .misepress__tab.is-active,
.misepress.misepress-acss .misepress__pagination .page-numbers.current,
.misepress.misepress-acss .misepress__step::before {
  background: var(--action, #c2410c) !important;
  border-color: var(--action, #c2410c) !important;
  color: var(--action-ultra-light, #fff) !important;
}
.misepress.misepress-acss .misepress__save-btn.is-saved,
.misepress.misepress-acss .misepress__save-btn[aria-pressed="true"],
.misepress.misepress-acss .misepress__shopping-btn.is-added,
.misepress.misepress-acss .misepress__shopping-btn[aria-pressed="true"],
.misepress.misepress-acss .misepress__filter-opt:has(input:checked),
.misepress.misepress-acss .misepress__filter-opt--icon:has(input:checked) {
  background: var(--action-light-trans-90, color-mix(in srgb, var(--action, #c2410c) 10%, transparent)) !important;
  border-color: var(--action, #c2410c) !important;
  color: var(--base-ultra-dark, #111) !important;
}
.misepress.misepress-acss .misepress__scale-label,
.misepress.misepress-acss .misepress__archive-eyebrow,
.misepress.misepress-acss .misepress__grid-tag,
.misepress.misepress-acss .misepress__filter-loadmore,
.misepress.misepress-acss .misepress__filter-reset,
.misepress.misepress-acss .misepress__scale-feedback,
.misepress.misepress-acss .misepress__hero-stat-value,
.misepress.misepress-acss .misepress__star.is-on,
.misepress.misepress-acss .misepress__reviews-star.is-on,
.misepress.misepress-acss .misepress__review-stars,
.misepress.misepress-acss .misepress__grid-title:hover,
.misepress.misepress-acss .misepress__grid-card:hover .misepress__grid-title,
.misepress.misepress-acss a.misepress__breadcrumbs-link:hover {
  color: var(--action, #c2410c) !important;
}
.misepress.misepress-acss .misepress__filter-mobile-bar,
.misepress.misepress-acss .misepress__filter-mobile-actions {
  background: var(--base-ultra-light, #fff) !important;
  border-color: var(--base-light, #e8e8e8) !important;
}
.misepress.misepress-acss .misepress__filter-mobile-handle,
.misepress.misepress-acss .misepress__filter-close { background: var(--base-light-trans-40, color-mix(in srgb, var(--base, #666) 14%, transparent)) !important; color: var(--base-ultra-dark, #111) !important; }

/* Remove remaining native brown/orange-looking chrome from normal plugin mode too where it was accidental. */
.misepress__view-btn.is-active,
.misepress__density-btn.is-active { background: var(--mp-color-accent) !important; border-color: var(--mp-color-accent) !important; color: var(--mp-color-accent-contrast, #fff) !important; }
.misepress__step::before { background: var(--mp-color-accent) !important; color: var(--mp-color-accent-contrast, #fff) !important; }

/* =====================================================================
 * stronger single templates, mobile filter stability, tap allergen tooltips.
 * ===================================================================== */

/* One width system for every MisePress page. */
.misepress-page__inner,
.misepress__archive .misepress-page__inner,
.misepress-page--single .misepress-page__inner {
  width: min(100%, var(--mp-page-max-w, 1140px));
  max-width: var(--mp-page-max-w, 1140px);
  margin-inline: auto;
  box-sizing: border-box;
}
.misepress.misepress-acss .misepress-page__inner,
.misepress.misepress-acss .misepress__archive .misepress-page__inner,
.misepress.misepress-acss .misepress-page--single .misepress-page__inner,
.misepress-single--width-acss .misepress-page__inner {
  --mp-page-max-w: var(--content-width, var(--width-xl, var(--container-width, 1140px))) !important;
  width: min(100%, var(--mp-page-max-w)) !important;
  max-width: var(--mp-page-max-w) !important;
}
.misepress.misepress-acss .misepress-single--width-narrow .misepress-page__inner,
.misepress.misepress-acss .misepress-single--width-normal .misepress-page__inner,
.misepress.misepress-acss .misepress-single--width-wide .misepress-page__inner,
.misepress.misepress-acss .misepress-single--width-full .misepress-page__inner {
  max-width: var(--mp-page-max-w) !important;
}

/* ACSS must beat every native palette value when inheritance is on. */
.misepress.misepress-acss .misepress,
.misepress.misepress-acss .misepress-page,
.misepress.misepress-acss .misepress__archive,
.misepress.misepress-acss .misepress__recipe {
  --mp-color-bg: var(--base-ultra-light, #fffdf8) !important;
  --mp-color-surface: var(--base-ultra-light, #fff) !important;
  --mp-color-fg: var(--base-ultra-dark, #1a1a1a) !important;
  --mp-color-muted: var(--base, #6b6b6b) !important;
  --mp-color-border: var(--base-light, #ececec) !important;
  --mp-color-accent: var(--action, #c2410c) !important;
  --mp-color-accent-active: var(--action-dark, var(--action, #c2410c)) !important;
  --mp-color-accent-contrast: var(--action-ultra-light, #fff) !important;
  --mp-color-accent-soft: var(--action-light-trans-90, color-mix(in srgb, var(--action, #c2410c) 10%, transparent)) !important;
  --mp-card-bg: var(--base-ultra-light, #fff) !important;
  --mp-card-text: var(--base-ultra-dark, #111) !important;
  --mp-card-accent: var(--action, #c2410c) !important;
  --mp-card-border: var(--base-light, #e8e8e8) !important;
  --mp-filter-bg: var(--base-ultra-light, #fff) !important;
  --mp-filter-text: var(--base-ultra-dark, #111) !important;
  --mp-filter-accent: var(--action, #c2410c) !important;
  --mp-filter-border: var(--base-light, #e8e8e8) !important;
  --mp-color-allergen-bg: var(--action-light-trans-90, color-mix(in srgb, var(--action, #c2410c) 10%, transparent)) !important;
  --mp-color-allergen-fg: var(--action-dark, var(--action, #c2410c)) !important;
  --mp-radius: var(--radius-m, 12px) !important;
  --mp-radius-sm: var(--radius-s, 8px) !important;
  --mp-card-radius: var(--radius-m, 12px) !important;
  --mp-filter-radius: var(--radius-m, 12px) !important;
  --mp-grid-gap: var(--space-m, 1.5rem) !important;
  --mp-single-section-gap: var(--space-l, 2rem) !important;
  --mp-archive-filter-gap: var(--space-m, 1.5rem) !important;
  --mp-archive-pad-x: 0 !important;
  --mp-shadow-xs: var(--shadow-xs, 0 1px 2px rgba(0,0,0,.06)) !important;
  --mp-shadow-sm: var(--shadow-s, 0 2px 8px -2px rgba(0,0,0,.08)) !important;
  --mp-shadow: var(--shadow-m, 0 6px 18px -6px rgba(0,0,0,.14)) !important;
  --mp-shadow-md: var(--shadow-l, 0 16px 36px -12px rgba(0,0,0,.20)) !important;
}
.misepress.misepress-acss .misepress__grid-card,
.misepress.misepress-acss .misepress__grid-card .misepress__grid-body,
.misepress.misepress-acss .misepress__section,
.misepress.misepress-acss .misepress__filters,
.misepress.misepress-acss .misepress__filter-drawer,
.misepress.misepress-acss .misepress__header--hero,
.misepress.misepress-acss .misepress__hero-overlay,
.misepress.misepress-acss .misepress__hero-stats,
.misepress.misepress-acss .misepress__scale-pantry,
.misepress.misepress-acss .misepress__reviews-summary,
.misepress.misepress-acss .misepress__review,
.misepress.misepress-acss .misepress__nutrition-label,
.misepress.misepress-acss .misepress__step,
.misepress.misepress-acss .misepress__ingredients,
.misepress.misepress-acss .misepress__instructions,
.misepress.misepress-acss .misepress__archive-toolbar,
.misepress.misepress-acss .misepress__results-toolbar {
  background-color: var(--base-ultra-light, #fff) !important;
  border-color: var(--base-light, #ececec) !important;
  color: var(--base-ultra-dark, #111) !important;
}
.misepress.misepress-acss .misepress__btn,
.misepress.misepress-acss .misepress__save-btn,
.misepress.misepress-acss .misepress__shopping-btn,
.misepress.misepress-acss .misepress__print-btn,
.misepress.misepress-acss .misepress__quick-filter,
.misepress.misepress-acss .misepress__filter-trigger,
.misepress.misepress-acss .misepress__filter-toggle,
.misepress.misepress-acss .misepress__view-toggle,
.misepress.misepress-acss .misepress__view-btn,
.misepress.misepress-acss .misepress__density-btn,
.misepress.misepress-acss .misepress__scale-inline,
.misepress.misepress-acss .misepress__scale-pill,
.misepress.misepress-acss .misepress__scale-pill--more,
.misepress.misepress-acss .misepress__preset,
.misepress.misepress-acss .misepress__units-btn,
.misepress.misepress-acss .misepress__nut-mode,
.misepress.misepress-acss .misepress__filter-opt,
.misepress.misepress-acss .misepress__chip,
.misepress.misepress-acss .misepress__allergen,
.misepress.misepress-acss .misepress__hero-allergen,
.misepress.misepress-acss .misepress__search-input,
.misepress.misepress-acss .misepress__filter-form input,
.misepress.misepress-acss .misepress__filter-form select,
.misepress.misepress-acss .misepress__filter-form textarea,
.misepress.misepress-acss .misepress__results-toolbar select {
  background-color: var(--base-ultra-light, #fff) !important;
  border-color: var(--base-light, #ececec) !important;
  color: var(--base-ultra-dark, #111) !important;
  border-radius: var(--radius-m, var(--mp-radius)) !important;
}
.misepress.misepress-acss .misepress__btn--primary,
.misepress.misepress-acss .misepress__filter-done,
.misepress.misepress-acss .misepress__scale-pantry-go,
.misepress.misepress-acss .misepress__view-btn.is-active,
.misepress.misepress-acss .misepress__density-btn.is-active,
.misepress.misepress-acss .misepress__scale-pill.is-active,
.misepress.misepress-acss .misepress__scale-pill--more.is-active,
.misepress.misepress-acss .misepress__preset.is-active,
.misepress.misepress-acss .misepress__units-btn.is-active,
.misepress.misepress-acss .misepress__nut-mode.is-active,
.misepress.misepress-acss .misepress__tab.is-active,
.misepress.misepress-acss .misepress__step::before {
  background-color: var(--action, #c2410c) !important;
  border-color: var(--action, #c2410c) !important;
  color: var(--action-ultra-light, #fff) !important;
}
.misepress.misepress-acss .misepress__save-btn.is-saved,
.misepress.misepress-acss .misepress__save-btn[aria-pressed="true"],
.misepress.misepress-acss .misepress__shopping-btn.is-added,
.misepress.misepress-acss .misepress__shopping-btn[aria-pressed="true"],
.misepress.misepress-acss .misepress__filter-opt:has(input:checked),
.misepress.misepress-acss .misepress__filter-opt--icon:has(input:checked) {
  background-color: var(--action-light-trans-90, color-mix(in srgb, var(--action, #c2410c) 10%, transparent)) !important;
  border-color: var(--action, #c2410c) !important;
  color: var(--base-ultra-dark, #111) !important;
}
.misepress.misepress-acss .misepress__hero-stat-value,
.misepress.misepress-acss .misepress__archive-eyebrow,
.misepress.misepress-acss .misepress__grid-tag,
.misepress.misepress-acss .misepress__filter-loadmore,
.misepress.misepress-acss .misepress__filter-reset,
.misepress.misepress-acss .misepress__star.is-on,
.misepress.misepress-acss .misepress__reviews-star.is-on,
.misepress.misepress-acss .misepress__review-stars,
.misepress.misepress-acss .misepress__grid-card:hover .misepress__grid-title,
.misepress.misepress-acss .misepress__allergen a {
  color: var(--action, #c2410c) !important;
}

/* Make archive cards and filter/toolbar share the exact same content edge. */
.misepress__archive-layout,
.misepress__archive-results,
.misepress__results-toolbar,
.misepress__grid { width: 100%; box-sizing: border-box; }
.misepress__archive .misepress__grid { margin-inline: 0 !important; }
@media (max-width: 900px) {
  .misepress__archive .misepress-page__inner { padding-inline: var(--space-s, .9rem); overflow-x: clip; }
  .misepress__archive-layout { padding-inline: 0 !important; overflow-x: clip; }
  .misepress__archive-results { overflow-x: clip; }
  .misepress__quick-filters { overflow-x: auto; max-width: 100%; scrollbar-width: none; }
  .misepress__quick-filters::-webkit-scrollbar { display: none; }
}

/* Stop mobile filter card/drawer from moving horizontally. */
@media (max-width: 900px) {
  html:has(.misepress__archive),
  body:has(.misepress__archive) { overflow-x: clip !important; }
  .misepress__archive,
  .misepress__archive * { box-sizing: border-box; }
  .misepress__archive .misepress__filters {
    max-width: 100dvw !important;
    width: 100% !important;
    left: 0 !important;
    right: 0 !important;
    margin-inline: 0 !important;
    transform: translate3d(0, 100%, 0) !important;
    will-change: transform;
    touch-action: pan-y;
    overflow-x: clip !important;
  }
  .misepress__archive.is-mp-filters-open .misepress__filters { transform: translate3d(0, 0, 0) !important; }
  .misepress__archive--mobile-collapsible-top .misepress__filters {
    position: sticky !important;
    top: var(--wp-admin--admin-bar--height, 0px) !important;
    inset-inline: auto !important;
    transform: none !important;
    width: 100% !important;
    max-width: 100% !important;
  }
  .misepress__filter-form,
  .misepress__filter-group,
  .misepress__filter-opts,
  .misepress__filter-opt { max-width: 100% !important; overflow-x: clip !important; }
}

/* Remove all featured image overlay/filter effects completely. */
.misepress__recipe[class*="mp-hero-filter-"] .misepress__media,
.misepress__recipe[class*="mp-hero-filter-"] .misepress__media img,
.misepress__recipe[class*="mp-hero-filter-"] .misepress__media::before,
.misepress__recipe[class*="mp-hero-filter-"] .misepress__media::after,
.misepress__media--hero::before,
.misepress__media--hero::after {
  filter: none !important;
  mix-blend-mode: normal !important;
  opacity: 1;
  clip-path: none !important;
  -webkit-mask: none !important;
  mask: none !important;
  background: transparent !important;
}

/* More distinct real single recipe templates. */
.misepress-page--classic .misepress__recipe { background: var(--mp-color-surface); border: 1px solid var(--mp-color-border); }

.misepress-page--editorial .misepress__recipe {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
}
.misepress-page--editorial .misepress__header--editorial {
  display: grid;
  grid-template-columns: minmax(0, .8fr) minmax(0, 1.2fr);
  gap: var(--space-l, 2rem);
  align-items: center;
  padding-block: var(--space-l, 2rem);
  border-bottom: 1px solid var(--mp-color-border);
}
.misepress-page--editorial .misepress__media--editorial { grid-column: 2; grid-row: 1 / span 3; border-radius: var(--mp-card-radius); overflow: hidden; }
.misepress-page--editorial .misepress__media--editorial img { aspect-ratio: 4/5; object-fit: cover; width: 100%; height: 100%; }
.misepress-page--editorial .misepress__editorial-eyebrow,
.misepress-page--editorial .misepress__title-row,
.misepress-page--editorial .misepress__excerpt--editorial { grid-column: 1; }
.misepress-page--editorial .misepress__title--editorial { font-size: clamp(2.8rem, 8vw, 6rem); line-height: .88; letter-spacing: -.055em; }

.misepress-page--magazine .misepress__header--hero {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(300px, .56fr) !important;
  gap: var(--space-l, 2rem) !important;
  align-items: stretch !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}
.misepress-page--magazine .misepress__media--hero {
  grid-column: 1 !important;
  grid-row: 1 !important;
  aspect-ratio: 16/10 !important;
  border-radius: var(--mp-card-radius) !important;
  overflow: hidden !important;
}
.misepress-page--magazine .misepress__hero-overlay {
  grid-column: 2 !important;
  grid-row: 1 !important;
  width: auto !important;
  margin: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  text-align: left !important;
  background: var(--mp-color-surface, #fff) !important;
  border: 1px solid var(--mp-color-border) !important;
  border-radius: var(--mp-card-radius) !important;
  box-shadow: var(--mp-shadow-sm) !important;
}
.misepress-page--magazine .misepress__title--hero { font-size: clamp(2.5rem, 6vw, 5rem) !important; line-height: .9 !important; letter-spacing: -.055em; }
.misepress-page--magazine .misepress__title-actions--hero,
.misepress-page--magazine .misepress__hero-stats,
.misepress-page--magazine .misepress__hero-allergens { justify-content: flex-start !important; }

.misepress-page--centered .misepress__header--hero {
  max-width: min(760px, 100%);
  margin-inline: auto;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}
.misepress-page--centered .misepress__media--hero { max-width: min(620px, 100%); margin-inline: auto; border-radius: 999px 999px var(--mp-radius) var(--mp-radius); overflow: hidden; }
.misepress-page--centered .misepress__media--hero img { aspect-ratio: 1/1; object-fit: cover; }
.misepress-page--centered .misepress__title--hero { font-size: clamp(2.4rem, 8vw, 5.5rem) !important; line-height: .9 !important; max-width: 10ch; margin-inline: auto; }
.misepress-page--centered .misepress__excerpt--hero { max-width: 42ch; margin-inline: auto; }
.misepress-page--centered .misepress__section { max-width: min(760px, 100%); }

.misepress-page--compact .misepress__recipe { max-width: 780px; margin-inline: auto; }
.misepress-page--compact .misepress__media--hero img { max-height: 360px; object-fit: cover; }
.misepress-page--compact .misepress__title--hero { font-size: clamp(1.8rem, 5vw, 3rem) !important; }
.misepress-page--compact .misepress__section { padding: var(--space-s, 1rem) !important; }

.misepress-page--minimalist .misepress__media--hero { display: none !important; }
.misepress-page--minimalist .misepress__title--hero { font-family: inherit; font-weight: 700; }

@media (max-width: 760px) {
  .misepress-page--editorial .misepress__header--editorial,
  .misepress-page--magazine .misepress__header--hero { grid-template-columns: 1fr !important; }
  .misepress-page--editorial .misepress__media--editorial,
  .misepress-page--editorial .misepress__editorial-eyebrow,
  .misepress-page--editorial .misepress__title-row,
  .misepress-page--editorial .misepress__excerpt--editorial,
  .misepress-page--magazine .misepress__media--hero,
  .misepress-page--magazine .misepress__hero-overlay { grid-column: 1 !important; grid-row: auto !important; }
  .misepress-page--magazine .misepress__hero-overlay { text-align: center !important; }
  .misepress-page--magazine .misepress__title-actions--hero,
  .misepress-page--magazine .misepress__hero-stats,
  .misepress-page--magazine .misepress__hero-allergens { justify-content: center !important; }
}

/* Allergen explanation: tap/click friendly, not only hover. */
.misepress__allergens,
.misepress__hero-allergens { justify-content: center; align-items: center; overflow: visible; }
.misepress__allergen,
.misepress__hero-allergen { position: relative; overflow: visible; }
.misepress__allergen-trigger {
  appearance: none;
  border: 0;
  background: transparent;
  color: inherit;
  padding: 0;
  font: inherit;
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  cursor: pointer;
}
.misepress__allergen-tip {
  position: absolute;
  left: 50%;
  bottom: calc(100% + .65rem);
  transform: translateX(-50%) translateY(.25rem);
  width: min(18rem, 82vw);
  z-index: 20;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  background: var(--mp-color-fg, #111);
  color: var(--mp-color-bg, #fff);
  border: 1px solid var(--mp-color-border, #ececec);
  border-radius: var(--mp-radius-sm, 8px);
  box-shadow: var(--mp-shadow-md, 0 12px 30px rgba(0,0,0,.15));
  padding: .7rem .85rem;
  font-size: .86rem;
  line-height: 1.35;
  text-align: left;
  transition: opacity .15s ease, transform .15s ease, visibility .15s ease;
}
.misepress__allergen-tip strong { display: block; margin-bottom: .25rem; color: inherit; }
.misepress__allergen:hover .misepress__allergen-tip,
.misepress__allergen:focus-within .misepress__allergen-tip,
.misepress__allergen.is-open .misepress__allergen-tip,
.misepress__hero-allergen:hover .misepress__allergen-tip,
.misepress__hero-allergen:focus-within .misepress__allergen-tip,
.misepress__hero-allergen.is-open .misepress__allergen-tip {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
  pointer-events: auto;
}
.misepress.misepress-acss .misepress__allergen-tip {
  background: var(--base-ultra-dark, #111) !important;
  color: var(--base-ultra-light, #fff) !important;
  border-color: var(--base-dark, #333) !important;
}

/* =====================================================================
 * ===================================================================== */
.misepress.misepress-acss {
  /* Never fall back to the native MisePress orange while inheritance is on. */
  --mp-acss-accent: var(--primary, var(--action, var(--base, currentColor)));
  --mp-acss-accent-hover: var(--primary-hover, var(--action-hover, var(--primary-dark, var(--action-dark, var(--base-dark, currentColor)))));
  --mp-acss-accent-soft: var(--primary-light-trans-90, var(--action-light-trans-90, var(--base-ultra-light, transparent)));
  --mp-acss-accent-ultra-soft: var(--primary-light-trans-95, var(--action-light-trans-95, var(--base-ultra-light, transparent)));
  --mp-acss-contrast: var(--primary-ultra-light, var(--action-ultra-light, var(--base-ultra-light, #fff)));
  --mp-color-accent: var(--mp-acss-accent) !important;
  --mp-color-accent-active: var(--mp-acss-accent-hover) !important;
  --mp-color-accent-contrast: var(--mp-acss-contrast) !important;
  --mp-color-accent-soft: var(--mp-acss-accent-soft) !important;
  --mp-card-accent: var(--mp-acss-accent) !important;
  --mp-filter-accent: var(--mp-acss-accent) !important;
}

.misepress.misepress-acss .misepress a,
.misepress.misepress-acss .misepress__breadcrumbs a,
.misepress.misepress-acss .misepress__filter-loadmore,
.misepress.misepress-acss .misepress__grid-eyebrow,
.misepress.misepress-acss .misepress__archive-eyebrow,
.misepress.misepress-acss .misepress__hero-stat-value,
.misepress.misepress-acss .misepress__editorial-eyebrow,
.misepress.misepress-acss .misepress__rating-number,
.misepress.misepress-acss .misepress__reviews-star.is-on,
.misepress.misepress-acss .misepress__star.is-on {
  color: var(--mp-acss-accent) !important;
}

.misepress.misepress-acss .misepress__btn--primary,
.misepress.misepress-acss .misepress__filter-mobile-toggle,
.misepress.misepress-acss .misepress__filter-submit,
.misepress.misepress-acss .misepress__density-btn.is-active,
.misepress.misepress-acss .misepress__preset.is-active,
.misepress.misepress-acss .misepress__units-btn.is-active,
.misepress.misepress-acss .misepress__scale-pill.is-active,
.misepress.misepress-acss .misepress__nut-mode.is-active,
.misepress.misepress-acss .misepress__tab.is-active,
.misepress.misepress-acss .misepress__pagination .page-numbers.current,
.misepress.misepress-acss .misepress__save-btn.is-saved,
.misepress.misepress-acss .misepress__shopping-btn.is-added {
  background: var(--mp-acss-accent) !important;
  border-color: var(--mp-acss-accent) !important;
  color: var(--mp-acss-contrast) !important;
  box-shadow: var(--shadow-s, var(--mp-shadow-sm, none)) !important;
}

.misepress.misepress-acss .misepress__btn--primary:hover,
.misepress.misepress-acss .misepress__filter-mobile-toggle:hover,
.misepress.misepress-acss .misepress__filter-submit:hover,
.misepress.misepress-acss .misepress__density-btn.is-active:hover,
.misepress.misepress-acss .misepress__preset.is-active:hover,
.misepress.misepress-acss .misepress__units-btn.is-active:hover,
.misepress.misepress-acss .misepress__scale-pill.is-active:hover,
.misepress.misepress-acss .misepress__tab.is-active:hover {
  background: var(--mp-acss-accent-hover) !important;
  border-color: var(--mp-acss-accent-hover) !important;
}

.misepress.misepress-acss .misepress__filter-opt:has(input:checked),
.misepress.misepress-acss .misepress__filter-opt--icon:has(input:checked),
.misepress.misepress-acss .misepress__chip,
.misepress.misepress-acss .misepress__quick-filter,
.misepress.misepress-acss .misepress__allergen,
.misepress.misepress-acss .misepress__hero-allergen,
.misepress.misepress-acss .misepress__timer-btn,
.misepress.misepress-acss .misepress__scale-controls,
.misepress.misepress-acss .misepress__custom-scale,
.misepress.misepress-acss .misepress__nut-alert {
  background: var(--mp-acss-accent-soft) !important;
  border-color: var(--mp-acss-accent) !important;
  color: var(--base-ultra-dark, var(--mp-color-fg)) !important;
}

.misepress.misepress-acss .misepress__step::before,
.misepress.misepress-acss .misepress-page--single .misepress__step::before,
.misepress.misepress-acss .misepress__check.is-checked,
.misepress.misepress-acss .misepress__step.is-checked .misepress__check,
.misepress.misepress-acss .misepress__reviews-dist-bar span {
  background: var(--mp-acss-accent) !important;
  border-color: var(--mp-acss-accent) !important;
  color: var(--mp-acss-contrast) !important;
}

.misepress.misepress-acss .misepress__grid-card,
.misepress.misepress-acss .misepress__filters,
.misepress.misepress-acss .misepress__filter-form,
.misepress.misepress-acss .misepress__filter-group,
.misepress.misepress-acss .misepress__search-input,
.misepress.misepress-acss .misepress__archive-header-toolbar select,
.misepress.misepress-acss .misepress__results-toolbar select,
.misepress.misepress-acss .misepress__section,
.misepress.misepress-acss .misepress__step,
.misepress.misepress-acss .misepress__hero-overlay,
.misepress.misepress-acss .misepress__hero-stats,
.misepress.misepress-acss .misepress__reviews,
.misepress.misepress-acss .misepress__reviews-summary,
.misepress.misepress-acss .misepress__review-card,
.misepress.misepress-acss .misepress__nutrition,
.misepress.misepress-acss .misepress__nut-card,
.misepress.misepress-acss .misepress__nut-macros li {
  background: var(--base-ultra-light, var(--mp-color-surface)) !important;
  border-color: var(--base-light, var(--mp-color-border)) !important;
  color: var(--base-ultra-dark, var(--mp-color-fg)) !important;
}

.misepress.misepress-acss .misepress__quick-filter,
.misepress.misepress-acss .misepress__filter-opt,
.misepress.misepress-acss .misepress__density-btn,
.misepress.misepress-acss .misepress__preset,
.misepress.misepress-acss .misepress__units-btn,
.misepress.misepress-acss .misepress__scale-pill,
.misepress.misepress-acss .misepress__nut-mode,
.misepress.misepress-acss .misepress__btn,
.misepress.misepress-acss .misepress__save-btn,
.misepress.misepress-acss .misepress__shopping-btn {
  border-color: var(--base-light, var(--mp-color-border)) !important;
}

/* Mobile filter drawer/panel: no horizontal drift, button centered, edges follow ACSS spacing when active. */
@media (max-width: 900px) {
  .misepress__archive .misepress-page__inner,
  .misepress__archive-layout,
  .misepress__archive-results,
  .misepress__filters,
  .misepress__filter-form { max-width: 100% !important; overflow-x: clip !important; }

  .misepress.misepress-acss .misepress__archive .misepress-page__inner {
    padding-inline: var(--section-padding-x, var(--space-m, 1rem)) !important;
  }
  .misepress__archive:not(.misepress-acss) .misepress-page__inner {
    padding-inline: var(--mp-archive-pad-x, 1rem) !important;
  }

  .misepress__archive .misepress__filters {
    left: 0 !important;
    right: 0 !important;
    width: 100dvw !important;
    max-width: 100dvw !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    translate: none !important;
    transform: translate3d(0, 100%, 0) !important;
    border-left: 0 !important;
    border-right: 0 !important;
  }
  .misepress__archive.is-mp-filters-open .misepress__filters { transform: translate3d(0, 0, 0) !important; }
  .misepress__filter-form {
    width: 100% !important;
    display: flex !important;
    flex-direction: column !important;
  }
  .misepress.misepress-acss .misepress__filter-form { gap: var(--space-s, .75rem) !important; padding-inline: var(--section-padding-x, var(--space-m, 1rem)) !important; }
  .misepress:not(.misepress-acss) .misepress__filter-form { gap: var(--mp-archive-filter-gap, .75rem) !important; padding-inline: var(--mp-archive-pad-x, 1rem) !important; }
  .misepress__filter-submit,
  .misepress__filter-mobile-toggle {
    align-self: center !important;
    margin-inline: auto !important;
    min-width: min(18rem, calc(100dvw - 2rem)) !important;
    justify-content: center !important;
  }
}

/* Replace weak/bad single templates with distinct, stable layouts. */
.misepress-page--classic .misepress__recipe {
  max-width: var(--mp-page-max-w, 1040px);
  margin-inline: auto;
}
.misepress-page--classic .misepress__header--hero {
  display: grid;
  gap: var(--mp-single-section-gap, 1.5rem);
}

.misepress-page--editorial .misepress__recipe {
  max-width: var(--mp-page-max-w, 1180px);
  margin-inline: auto;
}
.misepress-page--editorial .misepress__header--editorial {
  display: grid !important;
  grid-template-columns: minmax(0, 5fr) minmax(320px, 4fr) !important;
  gap: var(--space-xl, clamp(2rem, 5vw, 4rem)) !important;
  align-items: end !important;
  border-bottom: 1px solid var(--mp-color-border) !important;
  padding-block-end: var(--space-l, 2rem) !important;
}
.misepress-page--editorial .misepress__media--editorial {
  grid-column: 2 !important;
  grid-row: 1 / span 4 !important;
  border-radius: var(--mp-card-radius) !important;
  overflow: hidden !important;
  box-shadow: var(--mp-shadow-sm) !important;
}
.misepress-page--editorial .misepress__media--editorial img { aspect-ratio: 3 / 4 !important; object-fit: cover !important; width: 100% !important; height: 100% !important; }
.misepress-page--editorial .misepress__editorial-eyebrow { color: var(--mp-color-accent) !important; letter-spacing: .18em; text-transform: uppercase; }
.misepress-page--editorial .misepress__title--editorial { font-size: clamp(3rem, 9vw, 7rem) !important; max-width: 9ch; line-height: .86 !important; }
.misepress-page--editorial .misepress__excerpt--editorial { max-width: 45ch !important; font-size: clamp(1.05rem, 2vw, 1.35rem) !important; }

.misepress-page--centered .misepress__recipe {
  max-width: min(860px, 100%);
  margin-inline: auto;
  text-align: center;
}
.misepress-page--centered .misepress__header--hero {
  display: grid !important;
  justify-items: center !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}
.misepress-page--centered .misepress__media--hero {
  width: min(560px, 100%) !important;
  aspect-ratio: 1 / 1 !important;
  border-radius: 50% 50% var(--radius-l, 2rem) var(--radius-l, 2rem) !important;
  overflow: hidden !important;
}
.misepress-page--centered .misepress__media--hero img { width: 100% !important; height: 100% !important; object-fit: cover !important; }
.misepress-page--centered .misepress__hero-overlay {
  max-width: 760px !important;
  margin-inline: auto !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  text-align: center !important;
}
.misepress-page--centered .misepress__title--hero { max-width: 11ch !important; margin-inline: auto !important; }
.misepress-page--centered .misepress__hero-stats,
.misepress-page--centered .misepress__title-actions--hero,
.misepress-page--centered .misepress__hero-allergens { justify-content: center !important; }
.misepress-page--centered .misepress__section { margin-inline: auto !important; text-align: left; }
.misepress-page--centered .misepress__heading { text-align: center; }

@media (max-width: 760px) {
  .misepress-page--editorial .misepress__header--editorial { grid-template-columns: 1fr !important; align-items: start !important; }
  .misepress-page--editorial .misepress__media--editorial,
  .misepress-page--editorial .misepress__editorial-eyebrow,
  .misepress-page--editorial .misepress__title-row,
  .misepress-page--editorial .misepress__excerpt--editorial { grid-column: 1 !important; grid-row: auto !important; }
  .misepress-page--editorial .misepress__title--editorial { font-size: clamp(2.4rem, 13vw, 4.25rem) !important; }
  .misepress-page--centered .misepress__media--hero { width: min(380px, 100%) !important; }
}


/* ============================================================
 * mobile filter stability.
 * When ACSS inheritance is enabled, every remaining accent-style UI piece
 * uses ACSS tokens through MisePress variables. Native orange only remains
 * when ACSS inheritance is OFF.
 * ============================================================ */
.misepress.misepress-acss {
  --mp-accent: var(--mp-color-accent, var(--primary, var(--action, var(--base, currentColor))));
  --mp-color-accent: var(--primary, var(--action, var(--base, currentColor)));
  --mp-color-accent-active: var(--primary, var(--action, var(--base-dark, var(--base, currentColor))));
  --mp-color-accent-contrast: var(--primary-ultra-light, var(--action-ultra-light, var(--base-ultra-light, #fff)));
  --mp-color-accent-soft: var(--primary-light-trans-90, var(--action-light-trans-90, var(--base-light-trans-90, var(--base-ultra-light, transparent))));
  --mp-step-number-bg: var(--mp-color-accent-active);
  --mp-card-accent: var(--mp-color-accent);
  --mp-filter-accent: var(--mp-color-accent);
  --mp-macro-protein: var(--primary, var(--action, var(--base, currentColor)));
  --mp-macro-carbs: var(--primary, var(--action, var(--base, currentColor)));
  --mp-macro-fat: var(--primary, var(--action, var(--base, currentColor)));
  --mp-macro-fiber: var(--primary, var(--action, var(--base, currentColor)));
  --mp-macro-sugar: var(--primary, var(--action, var(--base, currentColor)));
  --mp-macro-sodium: var(--primary, var(--action, var(--base, currentColor)));
}

.misepress.misepress-acss a,
.misepress.misepress-acss .misepress a,
.misepress.misepress-acss .misepress__breadcrumbs a:hover,
.misepress.misepress-acss .misepress__price,
.misepress.misepress-acss .misepress__archive-eyebrow,
.misepress.misepress-acss .misepress__editorial-eyebrow,
.misepress.misepress-acss .misepress__grid-eyebrow,
.misepress.misepress-acss .misepress__filter-loadmore,
.misepress.misepress-acss .misepress__filter-reset,
.misepress.misepress-acss .misepress__scale-feedback,
.misepress.misepress-acss .misepress__hero-stat:first-child .misepress__hero-stat-value,
.misepress.misepress-acss .misepress__meta-value--time,
.misepress.misepress-acss .misepress__nut-kcal,
.misepress.misepress-acss .misepress__nutrition-kcal,
.misepress.misepress-acss .misepress__nutrition strong,
.misepress.misepress-acss .misepress__section--nutrition strong,
.misepress.misepress-acss .misepress__grid-nut-item--kcal strong,
.misepress.misepress-acss .misepress__tab.is-active {
  color: var(--mp-color-accent) !important;
}

.misepress.misepress-acss .misepress__btn--primary,
.misepress.misepress-acss .misepress__filter-mobile-toggle,
.misepress.misepress-acss .misepress__filter-submit,
.misepress.misepress-acss .misepress__filter-apply,
.misepress.misepress-acss .misepress__density-btn.is-active,
.misepress.misepress-acss .misepress__view-btn.is-active,
.misepress.misepress-acss .misepress__preset.is-active,
.misepress.misepress-acss .misepress__units-btn.is-active,
.misepress.misepress-acss .misepress__nut-mode.is-active,
.misepress.misepress-acss .misepress__scale-pill.is-active,
.misepress.misepress-acss .misepress__shopping-btn.is-added,
.misepress.misepress-acss .misepress__save-btn.is-saved,
.misepress.misepress-acss .misepress__step::before,
.misepress.misepress-acss .misepress__reviews-dist-bar span,
.misepress.misepress-acss .misepress__pagination .page-numbers.current {
  background: var(--mp-color-accent) !important;
  border-color: var(--mp-color-accent) !important;
  color: var(--mp-color-accent-contrast) !important;
}

.misepress.misepress-acss .misepress__timer-btn,
.misepress.misepress-acss .misepress__timer-btn.is-running,
.misepress.misepress-acss .misepress__timer-btn:hover,
.misepress.misepress-acss .misepress__allergen,
.misepress.misepress-acss .misepress__diet-tag,
.misepress.misepress-acss .misepress__chip,
.misepress.misepress-acss .misepress__related-list a,
.misepress.misepress-acss .misepress__grid-nut-item,
.misepress.misepress-acss .misepress__grid-nut-item--kcal,
.misepress.misepress-acss .misepress__equipment-item,
.misepress.misepress-acss .misepress__scale-pantry,
.misepress.misepress-acss .misepress__filter-opt:has(input:checked),
.misepress.misepress-acss .misepress__filter-opt--icon:has(input:checked) {
  background: var(--mp-color-accent-soft) !important;
  border-color: var(--mp-color-accent) !important;
  color: var(--mp-color-accent) !important;
}

.misepress.misepress-acss .misepress__step[data-mp-check]:focus-visible,
.misepress.misepress-acss .misepress__filter-form select:focus,
.misepress.misepress-acss .misepress__save-btn:focus-visible {
  outline-color: var(--mp-color-accent) !important;
}

.misepress.misepress-acss .misepress__filter-opt input[type="checkbox"],
.misepress.misepress-acss .misepress__filter-opt input[type="radio"],
.misepress.misepress-acss .misepress__check,
.misepress.misepress-acss input[type="checkbox"],
.misepress.misepress-acss input[type="radio"] { accent-color: var(--mp-color-accent) !important; }

.misepress.misepress-acss .misepress__heading,
.misepress.misepress-acss .misepress__section-title,
.misepress.misepress-acss .misepress__menu-section-title {
  border-color: var(--mp-color-accent) !important;
}

/* Remove Centered template in practice too: old saved centred values render as Classic. */
.misepress-page--centered .misepress-page__inner,
.misepress-page--centered .misepress__recipe,
.misepress-page--centered .misepress__header--hero,
.misepress-page--centered .misepress__media--hero,
.misepress-page--centered .misepress__hero-overlay,
.misepress-page--centered .misepress__body,
.misepress-page--centered .misepress__section {
  text-align: inherit !important;
  max-width: none !important;
  width: auto !important;
  border-radius: var(--mp-radius) !important;
}
.misepress-page--centered .misepress__media--hero img {
  aspect-ratio: var(--mp-hero-ratio, 16/9) !important;
  object-fit: cover !important;
}

/* Mobile filter drawer: keep it centered, viewport-locked and spaced from ACSS/native tokens. */
@media (max-width: 782px) {
  .misepress__filters-drawer,
  .misepress__filter-drawer,
  .misepress__filter-panel,
  .misepress__archive-filters.is-open,
  .misepress__archive--filters-collapsible .misepress__filter-form {
    left: var(--mp-archive-pad-x, var(--space-m, 1rem)) !important;
    right: var(--mp-archive-pad-x, var(--space-m, 1rem)) !important;
    width: auto !important;
    max-width: calc(100vw - (var(--mp-archive-pad-x, var(--space-m, 1rem)) * 2)) !important;
    margin-inline: auto !important;
    transform: none !important;
    overflow-x: hidden !important;
  }
  .misepress__filter-submit,
  .misepress__filter-apply,
  .misepress__filter-mobile-toggle {
    left: 50% !important;
    right: auto !important;
    transform: translateX(-50%) !important;
    margin-inline: auto !important;
  }
}


/* =====================================================================
 * ===================================================================== */
.misepress.misepress-acss,
.misepress.misepress-acss {
  /* One accent authority. Prefer ACSS primary, then action. Native orange is not a fallback here. */
  --mp-acss-authority: var(--primary, var(--action, var(--base-dark, currentColor)));
  --mp-acss-authority-hover: var(--primary-hover, var(--primary-dark, var(--action-hover, var(--action-dark, var(--base-ultra-dark, currentColor)))));
  --mp-acss-authority-soft: var(--primary-light-trans-90, var(--action-light-trans-90, var(--base-light-trans-90, color-mix(in srgb, var(--mp-acss-authority) 10%, transparent))));
  --mp-acss-authority-contrast: var(--primary-ultra-light, var(--action-ultra-light, var(--base-ultra-light, #fff)));
  --mp-color-accent: var(--mp-acss-authority) !important;
  --mp-color-accent-active: var(--mp-acss-authority) !important;
  --mp-color-accent-soft: var(--mp-acss-authority-soft) !important;
  --mp-color-accent-contrast: var(--mp-acss-authority-contrast) !important;
  --mp-accent: var(--mp-acss-authority) !important;
  --mp-card-accent: var(--mp-acss-authority) !important;
  --mp-filter-accent: var(--mp-acss-authority) !important;
  --mp-step-number-bg: var(--mp-acss-authority) !important;
  --mp-macro-protein: var(--mp-acss-authority) !important;
  --mp-macro-carbs: var(--mp-acss-authority) !important;
  --mp-macro-fat: var(--mp-acss-authority) !important;
}

/* kill the remaining native orange wherever selectors previously missed .misepress.misepress-acss */
.misepress.misepress-acss .misepress__tab.is-active,
.misepress.misepress-acss .misepress__tab[aria-selected="true"],
.misepress.misepress-acss .misepress__tabs a[aria-current="page"],
.misepress.misepress-acss .misepress__tab.is-active,
.misepress.misepress-acss .misepress__tab[aria-selected="true"],
.misepress.misepress-acss .misepress__units-btn.is-active,
.misepress.misepress-acss .misepress__scale-pill.is-active,
.misepress.misepress-acss .misepress__nut-mode.is-active,
.misepress.misepress-acss .misepress__density-btn.is-active,
.misepress.misepress-acss .misepress__view-btn.is-active,
.misepress.misepress-acss .misepress__preset.is-active,
.misepress.misepress-acss .misepress__filter-submit,
.misepress.misepress-acss .misepress__filter-mobile-toggle,
.misepress.misepress-acss .misepress__btn--primary,
.misepress.misepress-acss .misepress__step::before,
.misepress.misepress-acss .misepress__units-btn.is-active,
.misepress.misepress-acss .misepress__scale-pill.is-active,
.misepress.misepress-acss .misepress__nut-mode.is-active,
.misepress.misepress-acss .misepress__density-btn.is-active,
.misepress.misepress-acss .misepress__view-btn.is-active,
.misepress.misepress-acss .misepress__preset.is-active,
.misepress.misepress-acss .misepress__filter-submit,
.misepress.misepress-acss .misepress__filter-mobile-toggle,
.misepress.misepress-acss .misepress__btn--primary,
.misepress.misepress-acss .misepress__step::before {
  background-color: var(--mp-acss-authority) !important;
  background: var(--mp-acss-authority) !important;
  border-color: var(--mp-acss-authority) !important;
  color: var(--mp-acss-authority-contrast) !important;
}

.misepress.misepress-acss .misepress a,
.misepress.misepress-acss .misepress__grid-eyebrow,
.misepress.misepress-acss .misepress__archive-eyebrow,
.misepress.misepress-acss .misepress__editorial-eyebrow,
.misepress.misepress-acss .misepress__hero-stat-value,
.misepress.misepress-acss .misepress__meta-value,
.misepress.misepress-acss .misepress__meta-value--time,
.misepress.misepress-acss .misepress__scale-label,
.misepress.misepress-acss .misepress__nut-kcal,
.misepress.misepress-acss .misepress__nutrition-kcal,
.misepress.misepress-acss .misepress__grid-nut-item strong,
.misepress.misepress-acss .misepress__grid-nut-item--kcal strong,
.misepress.misepress-acss .misepress__filter-loadmore,
.misepress.misepress-acss .misepress__filter-reset,
.misepress.misepress-acss a,
.misepress.misepress-acss .misepress__grid-eyebrow,
.misepress.misepress-acss .misepress__archive-eyebrow,
.misepress.misepress-acss .misepress__editorial-eyebrow,
.misepress.misepress-acss .misepress__hero-stat-value,
.misepress.misepress-acss .misepress__meta-value,
.misepress.misepress-acss .misepress__meta-value--time,
.misepress.misepress-acss .misepress__scale-label,
.misepress.misepress-acss .misepress__nut-kcal,
.misepress.misepress-acss .misepress__nutrition-kcal,
.misepress.misepress-acss .misepress__grid-nut-item strong,
.misepress.misepress-acss .misepress__grid-nut-item--kcal strong,
.misepress.misepress-acss .misepress__filter-loadmore,
.misepress.misepress-acss .misepress__filter-reset {
  color: var(--mp-acss-authority) !important;
}

.misepress.misepress-acss .misepress__heading,
.misepress.misepress-acss .misepress__section-title,
.misepress.misepress-acss .misepress__menu-section-title,
.misepress.misepress-acss .misepress__heading,
.misepress.misepress-acss .misepress__section-title,
.misepress.misepress-acss .misepress__menu-section-title {
  border-color: var(--mp-acss-authority) !important;
}

.misepress.misepress-acss .misepress__timer-btn,
.misepress.misepress-acss .misepress__allergen,
.misepress.misepress-acss .misepress__allergen-badge,
.misepress.misepress-acss .misepress__hero-allergen,
.misepress.misepress-acss .misepress__chip,
.misepress.misepress-acss .misepress__diet-tag,
.misepress.misepress-acss .misepress__grid-nut-item,
.misepress.misepress-acss .misepress__grid-nut-item--kcal,
.misepress.misepress-acss .misepress__scale-controls,
.misepress.misepress-acss .misepress__custom-scale,
.misepress.misepress-acss .misepress__nut-card,
.misepress.misepress-acss .misepress__timer-btn,
.misepress.misepress-acss .misepress__allergen,
.misepress.misepress-acss .misepress__allergen-badge,
.misepress.misepress-acss .misepress__hero-allergen,
.misepress.misepress-acss .misepress__chip,
.misepress.misepress-acss .misepress__diet-tag,
.misepress.misepress-acss .misepress__grid-nut-item,
.misepress.misepress-acss .misepress__grid-nut-item--kcal,
.misepress.misepress-acss .misepress__scale-controls,
.misepress.misepress-acss .misepress__custom-scale,
.misepress.misepress-acss .misepress__nut-card {
  background: var(--mp-acss-authority-soft) !important;
  border-color: var(--mp-acss-authority) !important;
  color: var(--mp-acss-authority) !important;
}

/* Classic template: centered, smoother card flow from hero image into intro and tabs. */
.misepress-page--classic .misepress__recipe.misepress__recipe--classic,
.misepress__recipe.misepress__recipe--classic {
  max-width: var(--mp-page-max-w, min(1120px, 100%));
  margin-inline: auto !important;
}
.misepress-page--classic .misepress__header--hero,
.misepress__recipe--classic .misepress__header--hero {
  max-width: min(980px, 100%);
  margin-inline: auto !important;
  display: grid !important;
  justify-items: center !important;
  gap: 0 !important;
  background: linear-gradient(180deg, var(--mp-color-surface, #fff) 0%, color-mix(in srgb, var(--mp-color-surface, #fff) 72%, var(--mp-color-bg, #fff)) 100%) !important;
  border: 1px solid var(--mp-color-border, #e5e7eb) !important;
  border-radius: calc(var(--mp-card-radius, 18px) * 1.25) !important;
  padding: clamp(.75rem, 2vw, 1.25rem) !important;
  overflow: visible !important;
  box-shadow: var(--mp-shadow-sm, 0 12px 28px -18px rgba(0,0,0,.2)) !important;
}
.misepress-page--classic .misepress__media--hero,
.misepress__recipe--classic .misepress__media--hero {
  width: 100% !important;
  max-width: 860px !important;
  margin-inline: auto !important;
  border-radius: var(--mp-card-radius, 18px) !important;
  overflow: hidden !important;
}
.misepress-page--classic .misepress__hero-overlay,
.misepress__recipe--classic .misepress__hero-overlay {
  width: min(760px, calc(100% - clamp(1rem, 4vw, 3rem))) !important;
  margin: clamp(-2.5rem, -4vw, -1.25rem) auto 0 !important;
  position: relative !important;
  z-index: 2 !important;
  text-align: center !important;
  border-radius: calc(var(--mp-card-radius, 18px) * 1.1) !important;
  background: color-mix(in srgb, var(--mp-color-surface, #fff) 92%, transparent) !important;
  backdrop-filter: blur(12px) saturate(1.05) !important;
  border: 1px solid var(--mp-color-border, #e5e7eb) !important;
  box-shadow: var(--mp-shadow-sm, 0 16px 38px -24px rgba(0,0,0,.25)) !important;
  padding: clamp(1.15rem, 3vw, 2rem) !important;
}
.misepress-page--classic .misepress__title-actions--hero,
.misepress-page--classic .misepress__hero-stats,
.misepress-page--classic .misepress__hero-allergens,
.misepress__recipe--classic .misepress__title-actions--hero,
.misepress__recipe--classic .misepress__hero-stats,
.misepress__recipe--classic .misepress__hero-allergens {
  justify-content: center !important;
}
.misepress-page--classic .misepress__tabs,
.misepress__recipe--classic ~ .misepress__tabs,
.misepress__recipe--classic .misepress__tabs {
  max-width: min(980px, 100%);
  margin: var(--mp-single-section-gap, 1.5rem) auto 0 !important;
  justify-content: center !important;
  border-bottom: 1px solid var(--mp-color-border, #e5e7eb) !important;
}
.misepress-page--classic .misepress__tab,
.misepress__recipe--classic .misepress__tab {
  border-radius: var(--mp-radius-sm, 12px) var(--mp-radius-sm, 12px) 0 0 !important;
}
@media (max-width: 760px) {
  .misepress-page--classic .misepress__header--hero,
  .misepress__recipe--classic .misepress__header--hero { padding: .75rem !important; }
  .misepress-page--classic .misepress__hero-overlay,
  .misepress__recipe--classic .misepress__hero-overlay { width: calc(100% - .5rem) !important; margin-top: -.75rem !important; }
}

/* =====================================================================
 * ===================================================================== */

/* Frontend-only ACSS authority. This is duplicated by inline CSS when ACSS
   inheritance is enabled, but kept here for cached/minified CSS stacks. */
.misepress.misepress-acss .misepress,
.misepress.misepress-acss .misepress-page,
.misepress.misepress-acss .misepress__recipe,
.misepress.misepress-acss {
  --mp-acss-authority: var(--action, var(--primary, var(--base-dark, var(--base, #c2410c)))) !important;
  --mp-acss-authority-hover: var(--action-hover, var(--action-dark, var(--primary-hover, var(--primary-dark, var(--base-ultra-dark, var(--mp-acss-authority)))))) !important;
  --mp-acss-authority-soft: var(--action-light-trans-90, var(--primary-light-trans-90, var(--base-light-trans-90, color-mix(in srgb, var(--mp-acss-authority) 10%, transparent)))) !important;
  --mp-acss-authority-contrast: var(--action-ultra-light, var(--primary-ultra-light, var(--base-ultra-light, #fff))) !important;
  --mp-color-accent: var(--mp-acss-authority) !important;
  --mp-color-accent-active: var(--mp-acss-authority-hover) !important;
  --mp-color-accent-soft: var(--mp-acss-authority-soft) !important;
  --mp-color-accent-contrast: var(--mp-acss-authority-contrast) !important;
  --mp-accent: var(--mp-acss-authority) !important;
  --mp-card-accent: var(--mp-acss-authority) !important;
  --mp-filter-accent: var(--mp-acss-authority) !important;
  --mp-step-number-bg: var(--mp-acss-authority) !important;
}

.misepress.misepress-acss .misepress a:hover,
.misepress.misepress-acss .misepress__hero-stat-value,
.misepress.misepress-acss .misepress__meta-value,
.misepress.misepress-acss .misepress__meta-value--time,
.misepress.misepress-acss .misepress__scale-label,
.misepress.misepress-acss .misepress__nut-cal-num,
.misepress.misepress-acss .misepress__nut-kcal,
.misepress.misepress-acss .misepress__nutrition-kcal,
.misepress.misepress-acss .misepress__grid-nut-item strong,
.misepress.misepress-acss .misepress__grid-nut-item--kcal strong,
.misepress.misepress-acss .misepress__grid-eyebrow,
.misepress.misepress-acss .misepress__archive-eyebrow,
.misepress.misepress-acss .misepress__editorial-eyebrow,
.misepress.misepress-acss .misepress__filter-loadmore,
.misepress.misepress-acss .misepress__filter-reset,
.misepress.misepress-acss a:hover,
.misepress.misepress-acss .misepress__hero-stat-value,
.misepress.misepress-acss .misepress__meta-value,
.misepress.misepress-acss .misepress__meta-value--time,
.misepress.misepress-acss .misepress__scale-label,
.misepress.misepress-acss .misepress__nut-cal-num,
.misepress.misepress-acss .misepress__nut-kcal,
.misepress.misepress-acss .misepress__nutrition-kcal,
.misepress.misepress-acss .misepress__grid-nut-item strong,
.misepress.misepress-acss .misepress__grid-nut-item--kcal strong,
.misepress.misepress-acss .misepress__grid-eyebrow,
.misepress.misepress-acss .misepress__archive-eyebrow,
.misepress.misepress-acss .misepress__editorial-eyebrow,
.misepress.misepress-acss .misepress__filter-loadmore,
.misepress.misepress-acss .misepress__filter-reset {
  color: var(--mp-acss-authority) !important;
}

.misepress.misepress-acss .misepress__btn--primary,
.misepress.misepress-acss .misepress__filter-mobile-toggle,
.misepress.misepress-acss .misepress__filter-submit,
.misepress.misepress-acss .misepress__filter-apply,
.misepress.misepress-acss .misepress__filter-trigger,
.misepress.misepress-acss .misepress__density-btn.is-active,
.misepress.misepress-acss .misepress__view-btn.is-active,
.misepress.misepress-acss .misepress__preset.is-active,
.misepress.misepress-acss .misepress__units-btn.is-active,
.misepress.misepress-acss .misepress__nut-mode.is-active,
.misepress.misepress-acss .misepress__scale-pill.is-active,
.misepress.misepress-acss .misepress__scale-pill--more.is-active,
.misepress.misepress-acss .misepress__shopping-btn.is-added,
.misepress.misepress-acss .misepress__save-btn.is-saved,
.misepress.misepress-acss .misepress__step::before,
.misepress.misepress-acss .misepress__reviews-dist-bar span,
.misepress.misepress-acss .misepress__pagination .page-numbers.current,
.misepress.misepress-acss .misepress__tab.is-active,
.misepress.misepress-acss .misepress__btn--primary,
.misepress.misepress-acss .misepress__filter-mobile-toggle,
.misepress.misepress-acss .misepress__filter-submit,
.misepress.misepress-acss .misepress__filter-apply,
.misepress.misepress-acss .misepress__filter-trigger,
.misepress.misepress-acss .misepress__density-btn.is-active,
.misepress.misepress-acss .misepress__view-btn.is-active,
.misepress.misepress-acss .misepress__preset.is-active,
.misepress.misepress-acss .misepress__units-btn.is-active,
.misepress.misepress-acss .misepress__nut-mode.is-active,
.misepress.misepress-acss .misepress__scale-pill.is-active,
.misepress.misepress-acss .misepress__scale-pill--more.is-active,
.misepress.misepress-acss .misepress__shopping-btn.is-added,
.misepress.misepress-acss .misepress__save-btn.is-saved,
.misepress.misepress-acss .misepress__step::before,
.misepress.misepress-acss .misepress__reviews-dist-bar span,
.misepress.misepress-acss .misepress__pagination .page-numbers.current,
.misepress.misepress-acss .misepress__tab.is-active {
  background: var(--mp-acss-authority) !important;
  background-color: var(--mp-acss-authority) !important;
  border-color: var(--mp-acss-authority) !important;
  color: var(--mp-acss-authority-contrast) !important;
}

.misepress.misepress-acss .misepress__heading,
.misepress.misepress-acss .misepress__section-title,
.misepress.misepress-acss .misepress__menu-section-title,
.misepress.misepress-acss .misepress__heading,
.misepress.misepress-acss .misepress__section-title,
.misepress.misepress-acss .misepress__menu-section-title {
  border-color: var(--mp-acss-authority) !important;
}

/* Classic template: replace the forced floating title card with a calmer,
   centered hero stack. The tabs become a small bridge between hero and body. */
.misepress-page--classic .misepress__recipe.misepress__recipe--classic,
.misepress__recipe.misepress__recipe--classic {
  width: min(100%, var(--mp-page-max-w, 1140px)) !important;
  max-width: var(--mp-page-max-w, 1140px) !important;
  margin-inline: auto !important;
  display: grid !important;
  justify-items: center !important;
  gap: var(--mp-single-section-gap, var(--mp-s-6, 2rem)) !important;
}
.misepress-page--classic .misepress__header--hero,
.misepress__recipe--classic .misepress__header--hero {
  width: min(100%, 980px) !important;
  max-width: 980px !important;
  margin-inline: auto !important;
  padding: 0 !important;
  display: grid !important;
  gap: 0 !important;
  overflow: hidden !important;
  border-radius: var(--mp-card-radius, 18px) !important;
  border: 1px solid var(--mp-color-border, #e5e7eb) !important;
  background: var(--mp-color-surface, #fff) !important;
  box-shadow: var(--mp-shadow-sm, 0 12px 28px -18px rgba(0,0,0,.22)) !important;
}
.misepress-page--classic .misepress__media--hero,
.misepress__recipe--classic .misepress__media--hero {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  border-radius: 0 !important;
}
.misepress-page--classic .misepress__media--hero img,
.misepress__recipe--classic .misepress__media--hero img {
  width: 100% !important;
  aspect-ratio: var(--mp-hero-ratio, 16 / 8) !important;
  object-fit: cover !important;
  display: block !important;
  border-radius: 0 !important;
}
.misepress-page--classic .misepress__hero-overlay,
.misepress__recipe--classic .misepress__hero-overlay {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: clamp(1.25rem, 3vw, 2.25rem) clamp(1rem, 4vw, 3rem) !important;
  position: relative !important;
  z-index: 1 !important;
  text-align: center !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: linear-gradient(180deg, color-mix(in srgb, var(--mp-color-surface, #fff) 88%, transparent), var(--mp-color-surface, #fff)) !important;
  backdrop-filter: none !important;
  box-shadow: none !important;
}
.misepress-page--classic .misepress__title-actions--hero,
.misepress-page--classic .misepress__hero-stats,
.misepress-page--classic .misepress__hero-allergens,
.misepress__recipe--classic .misepress__title-actions--hero,
.misepress__recipe--classic .misepress__hero-stats,
.misepress__recipe--classic .misepress__hero-allergens {
  justify-content: center !important;
}
.misepress-page--classic .misepress__tabs,
.misepress__recipe--classic ~ .misepress__tabs,
.misepress__recipe--classic .misepress__tabs {
  width: fit-content !important;
  max-width: min(100%, 980px) !important;
  margin: calc(var(--mp-single-section-gap, 1.5rem) * -0.35) auto var(--mp-single-section-gap, 1.5rem) !important;
  justify-content: center !important;
  gap: .25rem !important;
  padding: .35rem !important;
  border: 1px solid var(--mp-color-border, #e5e7eb) !important;
  border-radius: 999px !important;
  background: var(--mp-color-surface, #fff) !important;
  box-shadow: var(--mp-shadow-xs, 0 8px 18px -16px rgba(0,0,0,.25)) !important;
}
.misepress-page--classic .misepress__tab,
.misepress__recipe--classic .misepress__tab {
  border-radius: 999px !important;
  border: 0 !important;
  padding-inline: 1rem !important;
}
.misepress-page--classic .misepress__body,
.misepress__recipe--classic .misepress__body {
  width: min(100%, var(--mp-page-max-w, 1140px)) !important;
  margin-inline: auto !important;
  align-items: start !important;
  gap: var(--mp-grid-gap, 1.5rem) !important;
}
@media (max-width: 760px) {
  .misepress-page--classic .misepress__media--hero img,
  .misepress__recipe--classic .misepress__media--hero img { aspect-ratio: 4 / 3 !important; }
  .misepress-page--classic .misepress__tabs,
  .misepress__recipe--classic ~ .misepress__tabs,
  .misepress__recipe--classic .misepress__tabs { width: 100% !important; border-radius: var(--mp-radius-sm, 12px) !important; }
}


/* =====================================================================
 * classic template smoothing.
 * ===================================================================== */

/* The frontend body class must never recolour the WordPress admin bar. */
.misepress.misepress-acss #wpadminbar,
.misepress.misepress-acss #wpadminbar * {
  --mp-color-accent: initial !important;
  --mp-accent: initial !important;
  --mp-card-accent: initial !important;
  --mp-filter-accent: initial !important;
}
.misepress.misepress-acss #wpadminbar a,
.misepress.misepress-acss #wpadminbar a:link,
.misepress.misepress-acss #wpadminbar a:visited,
.misepress.misepress-acss #wpadminbar .ab-item,
.misepress.misepress-acss #wpadminbar .ab-label,
.misepress.misepress-acss #wpadminbar .ab-icon::before {
  color: #f0f0f1 !important;
  background: transparent !important;
  border-color: transparent !important;
  box-shadow: none !important;
}
.misepress.misepress-acss #wpadminbar a:hover,
.misepress.misepress-acss #wpadminbar a:focus,
.misepress.misepress-acss #wpadminbar li:hover > .ab-item,
.misepress.misepress-acss #wpadminbar li.hover > .ab-item,
.misepress.misepress-acss #wpadminbar .ab-item:hover,
.misepress.misepress-acss #wpadminbar .ab-item:focus {
  color: #72aee6 !important;
  background: #2c3338 !important;
  border-color: transparent !important;
  box-shadow: none !important;
}

/* ACSS is action-first. Native orange is not used while inheritance is enabled. */
.misepress.misepress-acss .misepress,
.misepress.misepress-acss .misepress-page,
.misepress.misepress-acss .misepress__recipe,
.misepress.misepress-acss,
.misepress-page.misepress-acss,
.misepress__recipe.misepress-acss {
  --mp-acss-authority: var(--action, var(--primary, var(--base-dark, currentColor))) !important;
  --mp-acss-authority-hover: var(--action-hover, var(--action-dark, var(--primary-hover, var(--primary-dark, var(--base-ultra-dark, var(--mp-acss-authority)))))) !important;
  --mp-acss-authority-soft: var(--action-light-trans-90, var(--action-light-trans-80, var(--primary-light-trans-90, var(--base-light-trans-90, color-mix(in srgb, var(--mp-acss-authority) 10%, transparent))))) !important;
  --mp-acss-authority-ultra-soft: var(--action-light-trans-95, var(--primary-light-trans-95, var(--base-ultra-light, color-mix(in srgb, var(--mp-acss-authority) 5%, transparent)))) !important;
  --mp-acss-authority-contrast: var(--action-ultra-light, var(--primary-ultra-light, var(--base-ultra-light, #fff))) !important;
  --mp-color-accent: var(--mp-acss-authority) !important;
  --mp-color-accent-active: var(--mp-acss-authority-hover) !important;
  --mp-color-accent-soft: var(--mp-acss-authority-soft) !important;
  --mp-color-accent-contrast: var(--mp-acss-authority-contrast) !important;
  --mp-accent: var(--mp-acss-authority) !important;
  --mp-card-accent: var(--mp-acss-authority) !important;
  --mp-filter-accent: var(--mp-acss-authority) !important;
  --mp-step-number-bg: var(--mp-acss-authority) !important;
  --mp-macro-protein: var(--mp-acss-authority) !important;
  --mp-macro-carbs: var(--mp-acss-authority) !important;
  --mp-macro-fat: var(--mp-acss-authority) !important;
}

/* Remaining accent text should follow ACSS, not the native MisePress palette. */
.misepress.misepress-acss .misepress .misepress__hero-stat-value,
.misepress.misepress-acss .misepress .misepress__hero-stat:first-child .misepress__hero-stat-value,
.misepress.misepress-acss .misepress .misepress__meta-value,
.misepress.misepress-acss .misepress .misepress__meta-value--time,
.misepress.misepress-acss .misepress .misepress__scale-label,
.misepress.misepress-acss .misepress .misepress__nut-cal-num,
.misepress.misepress-acss .misepress .misepress__nut-kcal,
.misepress.misepress-acss .misepress .misepress__nutrition-kcal,
.misepress.misepress-acss .misepress .misepress__grid-nut-item strong,
.misepress.misepress-acss .misepress .misepress__grid-nut-item--kcal strong,
.misepress.misepress-acss .misepress .misepress__grid-eyebrow,
.misepress.misepress-acss .misepress .misepress__archive-eyebrow,
.misepress.misepress-acss .misepress .misepress__editorial-eyebrow,
.misepress.misepress-acss .misepress .misepress__grid-title:hover,
.misepress.misepress-acss .misepress .misepress__grid-card:hover .misepress__grid-title,
.misepress.misepress-acss .misepress .misepress__breadcrumbs a:hover,
.misepress.misepress-acss .misepress .misepress__tab.is-active {
  color: var(--mp-acss-authority) !important;
}

/* Active controls, tabs, filters and step numbers use action. */
.misepress.misepress-acss .misepress .misepress__btn--primary,
.misepress.misepress-acss .misepress .misepress__filter-mobile-toggle,
.misepress.misepress-acss .misepress .misepress__filter-submit,
.misepress.misepress-acss .misepress .misepress__filter-apply,
.misepress.misepress-acss .misepress .misepress__filter-trigger,
.misepress.misepress-acss .misepress .misepress__density-btn.is-active,
.misepress.misepress-acss .misepress .misepress__view-btn.is-active,
.misepress.misepress-acss .misepress .misepress__preset.is-active,
.misepress.misepress-acss .misepress .misepress__units-btn.is-active,
.misepress.misepress-acss .misepress .misepress__nut-mode.is-active,
.misepress.misepress-acss .misepress .misepress__scale-pill.is-active,
.misepress.misepress-acss .misepress .misepress__scale-pill--more.is-active,
.misepress.misepress-acss .misepress .misepress__shopping-btn.is-added,
.misepress.misepress-acss .misepress .misepress__save-btn.is-saved,
.misepress.misepress-acss .misepress .misepress__step::before,
.misepress.misepress-acss .misepress .misepress__reviews-dist-bar span,
.misepress.misepress-acss .misepress .misepress__pagination .page-numbers.current,
.misepress.misepress-acss .misepress .misepress__tab.is-active {
  background: var(--mp-acss-authority) !important;
  background-color: var(--mp-acss-authority) !important;
  border-color: var(--mp-acss-authority) !important;
  color: var(--mp-acss-authority-contrast) !important;
}

/* Soft controls should be readable. */
.misepress.misepress-acss .misepress .misepress__quick-filter,
.misepress.misepress-acss .misepress .misepress__filter-opt,
.misepress.misepress-acss .misepress .misepress__chip,
.misepress.misepress-acss .misepress .misepress__allergen,
.misepress.misepress-acss .misepress .misepress__hero-allergen,
.misepress.misepress-acss .misepress .misepress__timer-btn,
.misepress.misepress-acss .misepress .misepress__scale-controls,
.misepress.misepress-acss .misepress .misepress__custom-scale,
.misepress.misepress-acss .misepress .misepress__nut-alert {
  background: var(--mp-acss-authority-ultra-soft) !important;
  border-color: var(--base-light, var(--mp-color-border)) !important;
  color: var(--base-ultra-dark, var(--mp-color-fg)) !important;
}

/* Archive nutrition: no coloured backgrounds behind the numbers. */
.misepress__grid-nut-item strong,
.misepress.misepress-acss .misepress .misepress__grid-nut-item strong,
.misepress.misepress-acss .misepress .misepress__grid-nut-item--p strong,
.misepress.misepress-acss .misepress .misepress__grid-nut-item--c strong,
.misepress.misepress-acss .misepress .misepress__grid-nut-item--f strong,
.misepress.misepress-acss .misepress .misepress__grid-nut-item--kcal strong {
  background: transparent !important;
  background-color: transparent !important;
  box-shadow: none !important;
  color: var(--mp-acss-authority, var(--mp-color-fg)) !important;
}
.misepress.misepress-acss .misepress .misepress__grid-nut-item,
.misepress.misepress-acss .misepress .misepress__grid-nut-item--kcal {
  background: var(--mp-acss-authority-ultra-soft) !important;
  border: 0 !important;
}
.misepress.misepress-acss .misepress .misepress__grid-nut-item span {
  color: var(--base-ultra-dark, var(--mp-color-fg)) !important;
}
.misepress.misepress-acss .misepress .misepress__nut-dot,
.misepress.misepress-acss .misepress .misepress__nut-dot--p,
.misepress.misepress-acss .misepress .misepress__nut-dot--c,
.misepress.misepress-acss .misepress .misepress__nut-dot--f {
  background: var(--mp-acss-authority) !important;
  color: var(--mp-acss-authority) !important;
}

/* Classic template: calmer centered flow, less floating/awkward spacing. */
.misepress-page--classic .misepress__recipe.misepress__recipe--classic,
.misepress__recipe.misepress__recipe--classic {
  width: min(100%, var(--mp-page-max-w, 1120px)) !important;
  max-width: var(--mp-page-max-w, 1120px) !important;
  margin-inline: auto !important;
  display: grid !important;
  justify-items: center !important;
  gap: var(--mp-single-section-gap, 1.5rem) !important;
}
.misepress-page--classic .misepress__header--hero,
.misepress__recipe--classic .misepress__header--hero {
  width: min(100%, 960px) !important;
  max-width: 960px !important;
  margin-inline: auto !important;
  display: grid !important;
  grid-template-rows: auto auto !important;
  gap: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
  border: 1px solid var(--mp-color-border, #e5e7eb) !important;
  border-radius: var(--mp-card-radius, 18px) !important;
  background: var(--mp-color-surface, #fff) !important;
  box-shadow: var(--mp-shadow-sm, 0 12px 28px -18px rgba(0,0,0,.22)) !important;
}
.misepress-page--classic .misepress__media--hero,
.misepress__recipe--classic .misepress__media--hero {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  border-radius: 0 !important;
  overflow: hidden !important;
}
.misepress-page--classic .misepress__media--hero img,
.misepress__recipe--classic .misepress__media--hero img {
  width: 100% !important;
  aspect-ratio: 16 / 7 !important;
  min-height: 300px !important;
  object-fit: cover !important;
  display: block !important;
  border-radius: 0 !important;
}
.misepress-page--classic .misepress__hero-overlay,
.misepress__recipe--classic .misepress__hero-overlay {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: clamp(1.25rem, 3vw, 2.4rem) clamp(1rem, 4vw, 3rem) !important;
  text-align: center !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: linear-gradient(180deg, color-mix(in srgb, var(--mp-color-surface, #fff) 92%, transparent), var(--mp-color-surface, #fff)) !important;
  box-shadow: none !important;
}
.misepress-page--classic .misepress__title--hero,
.misepress__recipe--classic .misepress__title--hero {
  max-width: 12ch !important;
  margin-inline: auto !important;
}
.misepress-page--classic .misepress__title-actions--hero,
.misepress-page--classic .misepress__hero-stats,
.misepress-page--classic .misepress__hero-allergens,
.misepress__recipe--classic .misepress__title-actions--hero,
.misepress__recipe--classic .misepress__hero-stats,
.misepress__recipe--classic .misepress__hero-allergens {
  justify-content: center !important;
}
.misepress-page--classic .misepress__tabs,
.misepress__recipe--classic ~ .misepress__tabs,
.misepress__recipe--classic .misepress__tabs {
  width: fit-content !important;
  max-width: min(100%, 960px) !important;
  margin: .25rem auto var(--mp-single-section-gap, 1.5rem) !important;
  justify-content: center !important;
  gap: .25rem !important;
  padding: .35rem !important;
  border: 1px solid var(--mp-color-border, #e5e7eb) !important;
  border-radius: 999px !important;
  background: var(--mp-color-surface, #fff) !important;
  box-shadow: var(--mp-shadow-xs, 0 8px 18px -16px rgba(0,0,0,.25)) !important;
}
.misepress-page--classic .misepress__body,
.misepress__recipe--classic .misepress__body {
  width: min(100%, var(--mp-page-max-w, 1120px)) !important;
  margin-inline: auto !important;
  align-items: start !important;
}
@media (max-width: 760px) {
  .misepress-page--classic .misepress__media--hero img,
  .misepress__recipe--classic .misepress__media--hero img {
    aspect-ratio: 4 / 3 !important;
    min-height: 220px !important;
  }
  .misepress-page--classic .misepress__tabs,
  .misepress__recipe--classic ~ .misepress__tabs,
  .misepress__recipe--classic .misepress__tabs {
    width: 100% !important;
    border-radius: var(--mp-radius-sm, 12px) !important;
  }
}


/* =====================================================================
 * ===================================================================== */
@media (max-width: 900px) {
  .misepress.misepress-acss .misepress,
  .misepress.misepress-acss .misepress__archive,
  .misepress.misepress-acss,
  .misepress__archive.misepress-acss {
    --mp-mobile-filter-edge: var(--section-padding-x, var(--space-m, 1rem));
    --mp-mobile-filter-inner: var(--space-m, 1rem);
    --mp-mobile-filter-gap: var(--space-s, .75rem);
  }
  .misepress:not(.misepress-acss),
  .misepress__archive:not(.misepress-acss) {
    --mp-mobile-filter-edge: var(--mp-archive-pad-x, 1rem);
    --mp-mobile-filter-inner: var(--mp-space-3, 1rem);
    --mp-mobile-filter-gap: var(--mp-space-2, .75rem);
  }

  /* Drawer/mobile sheet: do not sit flush against the viewport edges. */
  .misepress__archive:not(.misepress__archive--mobile-collapsible-top) .misepress__filters {
    left: max(var(--mp-mobile-filter-edge), env(safe-area-inset-left)) !important;
    right: max(var(--mp-mobile-filter-edge), env(safe-area-inset-right)) !important;
    width: auto !important;
    max-width: none !important;
    margin-inline: 0 !important;
    padding: var(--mp-mobile-filter-inner) !important;
    border-left: 1px solid var(--mp-color-border, rgba(0,0,0,.1)) !important;
    border-right: 1px solid var(--mp-color-border, rgba(0,0,0,.1)) !important;
    border-radius: var(--mp-radius, 18px) var(--mp-radius, 18px) 0 0 !important;
    overflow-x: clip !important;
  }

  .misepress__archive:not(.misepress__archive--mobile-collapsible-top).is-mp-filters-open .misepress__filters {
    transform: translate3d(0, 0, 0) !important;
  }

  .misepress__archive:not(.misepress__archive--mobile-collapsible-top) .misepress__filter-form {
    padding-inline: 0 !important;
    gap: var(--mp-mobile-filter-gap) !important;
  }

  .misepress__archive:not(.misepress__archive--mobile-collapsible-top) .misepress__filter-mobile-bar {
    margin-inline: calc(var(--mp-mobile-filter-inner) * -1) !important;
    padding-inline: var(--mp-mobile-filter-inner) !important;
  }

  .misepress__archive:not(.misepress__archive--mobile-collapsible-top) .misepress__filter-mobile-actions {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    margin: var(--mp-mobile-filter-gap) 0 0 !important;
    padding: var(--mp-mobile-filter-gap) 0 max(var(--mp-mobile-filter-gap), env(safe-area-inset-bottom)) !important;
    width: 100% !important;
    background: linear-gradient(to top, var(--mp-color-bg, #fff) 72%, transparent) !important;
  }

  .misepress__archive:not(.misepress__archive--mobile-collapsible-top) .misepress__filter-done {
    width: auto !important;
    min-width: min(21rem, 100%) !important;
    max-width: 100% !important;
    margin-inline: auto !important;
    padding-inline: clamp(1.25rem, 8vw, 2.5rem) !important;
    display: inline-flex !important;
    justify-content: center !important;
    align-items: center !important;
    text-align: center !important;
  }

  /* Collapsible-top mode should use the same horizontal rhythm as the archive content. */
  .misepress__archive--mobile-collapsible-top .misepress__filters {
    margin-inline: 0 !important;
    padding-inline: var(--mp-mobile-filter-inner) !important;
  }
  .misepress__archive--mobile-collapsible-top .misepress__filter-form {
    padding-inline: 0 !important;
  }
}


/* =====================================================================
 * ===================================================================== */
@media (max-width: 900px) {
  .misepress__archive:not(.misepress__archive--mobile-collapsible-top) {
    --mp-mobile-filter-edge-final: max(var(--mp-mobile-filter-edge, var(--section-padding-x, var(--space-m, 1rem))), env(safe-area-inset-left), env(safe-area-inset-right));
  }

  .misepress__archive:not(.misepress__archive--mobile-collapsible-top) .misepress__filters {
    position: fixed !important;
    left: 50% !important;
    right: auto !important;
    bottom: 0 !important;
    width: min(46rem, calc(100dvw - (var(--mp-mobile-filter-edge-final) * 2))) !important;
    max-width: calc(100dvw - (var(--mp-mobile-filter-edge-final) * 2)) !important;
    min-width: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    margin-inline: 0 !important;
    transform: translate3d(-50%, 100%, 0) !important;
    box-sizing: border-box !important;
    overflow-x: clip !important;
    overscroll-behavior-x: none !important;
    border-left: 1px solid var(--mp-color-border, rgba(0,0,0,.1)) !important;
    border-right: 1px solid var(--mp-color-border, rgba(0,0,0,.1)) !important;
  }

  .misepress__archive:not(.misepress__archive--mobile-collapsible-top).is-mp-filters-open .misepress__filters {
    transform: translate3d(-50%, 0, 0) !important;
  }

  .misepress__archive:not(.misepress__archive--mobile-collapsible-top) .misepress__filter-mobile-actions {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    width: 100% !important;
    padding-inline: 0 !important;
    margin-inline: 0 !important;
  }

  .misepress__archive:not(.misepress__archive--mobile-collapsible-top) .misepress__filter-done,
  .misepress__archive:not(.misepress__archive--mobile-collapsible-top) .misepress__filter-submit,
  .misepress__archive:not(.misepress__archive--mobile-collapsible-top) .misepress__filter-apply {
    position: relative !important;
    left: auto !important;
    right: auto !important;
    transform: none !important;
    width: min(28rem, 100%) !important;
    min-width: 0 !important;
    max-width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
    margin-inline: auto !important;
    text-align: center !important;
    justify-content: center !important;
  }
}

/* =====================================================================
 * Uses inset-inline + auto width instead of 50% transform so Safari/Chrome
 * mobile cannot render a narrow off-centre fixed sheet inside transformed
 * ancestors. Also keeps the sticky submit button inside the sheet rhythm.
 * ===================================================================== */
@media (max-width: 900px) {
  .misepress__archive:not(.misepress__archive--mobile-collapsible-top) {
    --mp-mobile-filter-edge-final: max(1rem, env(safe-area-inset-left), env(safe-area-inset-right));
    --mp-mobile-filter-max-final: 42rem;
  }
  .misepress.misepress-acss .misepress__archive:not(.misepress__archive--mobile-collapsible-top),
  .misepress__archive.misepress-acss:not(.misepress__archive--mobile-collapsible-top) {
    --mp-mobile-filter-edge-final: max(var(--section-padding-x, var(--space-m, 1rem)), env(safe-area-inset-left), env(safe-area-inset-right));
  }

  .misepress__archive:not(.misepress__archive--mobile-collapsible-top) .misepress__filters {
    position: fixed !important;
    inset-block-start: auto !important;
    bottom: 0 !important;
    left: var(--mp-mobile-filter-edge-final) !important;
    right: var(--mp-mobile-filter-edge-final) !important;
    inline-size: auto !important;
    width: auto !important;
    max-inline-size: var(--mp-mobile-filter-max-final) !important;
    max-width: var(--mp-mobile-filter-max-final) !important;
    min-width: 0 !important;
    margin-inline: auto !important;
    transform: translate3d(0, 100%, 0) !important;
    translate: none !important;
    box-sizing: border-box !important;
    padding: var(--mp-mobile-filter-inner, var(--mp-space-3, 1rem)) !important;
    overflow-x: clip !important;
    overflow-y: auto !important;
    max-height: min(85dvh, calc(100dvh - 5rem)) !important;
    border-inline: 1px solid var(--mp-color-border, rgba(0,0,0,.1)) !important;
    border-radius: var(--mp-radius, 18px) var(--mp-radius, 18px) 0 0 !important;
    overscroll-behavior: contain !important;
  }

  .misepress__archive:not(.misepress__archive--mobile-collapsible-top).is-mp-filters-open .misepress__filters {
    transform: translate3d(0, 0, 0) !important;
  }

  .misepress__archive:not(.misepress__archive--mobile-collapsible-top) .misepress__filter-mobile-bar {
    margin-inline: calc(var(--mp-mobile-filter-inner, 1rem) * -1) !important;
    padding-inline: var(--mp-mobile-filter-inner, 1rem) !important;
  }

  .misepress__archive:not(.misepress__archive--mobile-collapsible-top) .misepress__filter-form {
    width: 100% !important;
    max-width: 100% !important;
    padding-inline: 0 !important;
    padding-bottom: 6.25rem !important;
    overflow-x: clip !important;
  }

  .misepress__archive:not(.misepress__archive--mobile-collapsible-top) .misepress__filter-mobile-actions {
    position: sticky !important;
    bottom: calc(var(--mp-mobile-filter-inner, 1rem) * -1) !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    width: auto !important;
    max-width: none !important;
    margin: var(--mp-mobile-filter-gap, .75rem) calc(var(--mp-mobile-filter-inner, 1rem) * -1) calc(var(--mp-mobile-filter-inner, 1rem) * -1) !important;
    padding: var(--mp-mobile-filter-gap, .75rem) var(--mp-mobile-filter-inner, 1rem) max(var(--mp-mobile-filter-gap, .75rem), env(safe-area-inset-bottom)) !important;
    background: linear-gradient(to top, var(--mp-color-bg, #fff) 78%, color-mix(in srgb, var(--mp-color-bg, #fff) 92%, transparent)) !important;
    border-top: 1px solid var(--mp-color-border, rgba(0,0,0,.08)) !important;
    z-index: 3 !important;
  }

  .misepress__archive:not(.misepress__archive--mobile-collapsible-top) .misepress__filter-done,
  .misepress__archive:not(.misepress__archive--mobile-collapsible-top) .misepress__filter-submit,
  .misepress__archive:not(.misepress__archive--mobile-collapsible-top) .misepress__filter-apply {
    width: min(28rem, 100%) !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin-inline: auto !important;
    display: inline-flex !important;
    justify-content: center !important;
    align-items: center !important;
    text-align: center !important;
    position: relative !important;
    left: auto !important;
    right: auto !important;
    transform: none !important;
  }

  .misepress__archive:not(.misepress__archive--mobile-collapsible-top) .misepress__filter-group,
  .misepress__archive:not(.misepress__archive--mobile-collapsible-top) .misepress__filter-search,
  .misepress__archive:not(.misepress__archive--mobile-collapsible-top) .misepress__search-input {
    max-width: 100% !important;
    margin-inline: 0 !important;
  }
}

/* =====================================================================
 * Later centered-sheet fixes were overriding the mp-filter-mobile-full class.
 * This final rule makes the setting authoritative again.
 * ===================================================================== */
@media (max-width: 900px) {
  .misepress__archive.mp-filter-mobile-full:not(.misepress__archive--mobile-collapsible-top) .misepress__filters {
    position: fixed !important;
    inset: 0 0 0 0 !important;
    left: 0 !important;
    right: 0 !important;
    top: 0 !important;
    bottom: 0 !important;
    inline-size: 100dvw !important;
    width: 100dvw !important;
    max-inline-size: none !important;
    max-width: none !important;
    height: 100dvh !important;
    max-height: 100dvh !important;
    margin: 0 !important;
    border-radius: 0 !important;
    border-inline: 0 !important;
    padding: max(var(--mp-mobile-filter-inner, 1rem), env(safe-area-inset-top)) var(--mp-mobile-filter-inner, 1rem) max(var(--mp-mobile-filter-inner, 1rem), env(safe-area-inset-bottom)) !important;
    transform: translate3d(0, 100%, 0) !important;
    overflow-y: auto !important;
    overflow-x: clip !important;
  }

  .misepress__archive.mp-filter-mobile-full:not(.misepress__archive--mobile-collapsible-top).is-mp-filters-open .misepress__filters {
    transform: translate3d(0, 0, 0) !important;
  }

  .misepress__archive.mp-filter-mobile-full:not(.misepress__archive--mobile-collapsible-top) .misepress__filter-mobile-bar {
    margin-inline: calc(var(--mp-mobile-filter-inner, 1rem) * -1) !important;
    padding-inline: var(--mp-mobile-filter-inner, 1rem) !important;
  }

  .misepress__archive.mp-filter-mobile-full:not(.misepress__archive--mobile-collapsible-top) .misepress__filter-mobile-actions {
    margin-inline: calc(var(--mp-mobile-filter-inner, 1rem) * -1) !important;
    padding-inline: var(--mp-mobile-filter-inner, 1rem) !important;
  }
}


/* --------------------------------------------------------------------------
 * ----------------------------------------------------------------------- */

/* Compact/archive cards: keep macro text readable in every density. */
.misepress .misepress__grid-card .misepress__grid-nut {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: .45rem !important;
  align-items: stretch !important;
  overflow: visible !important;
}
.misepress .misepress__grid-card .misepress__grid-nut-item {
  min-width: 0 !important;
  width: auto !important;
  max-width: 100% !important;
  padding: .5rem .35rem !important;
  border-radius: var(--mp-radius-sm, 10px) !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: .08rem !important;
  overflow: hidden !important;
  background: var(--mp-color-accent-soft, rgba(0,0,0,.045)) !important;
  border-color: transparent !important;
  color: var(--mp-color-fg, currentColor) !important;
}
.misepress .misepress__grid-card .misepress__grid-nut-item strong,
.misepress .misepress__grid-card .misepress__grid-nut-item span {
  display: block !important;
  width: 100% !important;
  min-width: 0 !important;
  max-width: 100% !important;
  text-align: center !important;
  overflow: hidden !important;
  text-overflow: clip !important;
  white-space: nowrap !important;
  background: transparent !important;
  background-color: transparent !important;
  box-shadow: none !important;
  line-height: 1.05 !important;
}
.misepress .misepress__grid-card .misepress__grid-nut-item strong {
  font-size: clamp(.78rem, .74rem + .2vw, .95rem) !important;
  color: var(--mp-color-fg, currentColor) !important;
}
.misepress .misepress__grid-card .misepress__grid-nut-item span {
  font-size: clamp(.58rem, .55rem + .12vw, .68rem) !important;
  letter-spacing: .025em !important;
  color: var(--mp-color-muted, currentColor) !important;
}

/* Compact density has narrow cards, so use a 2x2 macro grid instead of clipping. */
.misepress .misepress__archive--density-compact .misepress__grid-nut,
.misepress .misepress__archive[data-density="compact"] .misepress__grid-nut,
.misepress .misepress__archive.is-compact .misepress__grid-nut,
.misepress .misepress__archive--compact .misepress__grid-nut {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}

@media (max-width: 640px) {
  .misepress .misepress__grid-card .misepress__grid-nut {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

/* ACSS inheritance: use ACSS for states but do not paint over macro numbers. */
.misepress.misepress-acss .misepress .misepress__grid-card .misepress__grid-nut-item,
.misepress.misepress-acss .misepress__grid-card .misepress__grid-nut-item {
  background: var(--base-light-trans-20, var(--primary-light-trans-20, var(--action-light-trans-20, rgba(0,0,0,.045)))) !important;
  border-color: var(--base-light-trans-40, var(--primary-light-trans-40, var(--action-light-trans-40, transparent))) !important;
  color: var(--base, var(--mp-color-fg, currentColor)) !important;
}
.misepress.misepress-acss .misepress .misepress__grid-card .misepress__grid-nut-item strong,
.misepress.misepress-acss .misepress .misepress__grid-card .misepress__grid-nut-item span,
.misepress.misepress-acss .misepress__grid-card .misepress__grid-nut-item strong,
.misepress.misepress-acss .misepress__grid-card .misepress__grid-nut-item span {
  background: transparent !important;
  background-color: transparent !important;
  color: var(--base, var(--mp-color-fg, currentColor)) !important;
}
.misepress.misepress-acss .misepress .misepress__grid-card .misepress__grid-nut-item span,
.misepress.misepress-acss .misepress__grid-card .misepress__grid-nut-item span {
  color: var(--base-medium, var(--mp-color-muted, currentColor)) !important;
}

/* Mobile fullscreen/sheet drawer: centre the content and keep button away from edges. */
@media (max-width: 767px) {
  .misepress .misepress__filters-drawer,
  .misepress .misepress__filter-panel,
  .misepress .misepress__filters-panel {
    box-sizing: border-box !important;
  }
  .misepress .misepress__filters-drawer.is-fullscreen,
  .misepress .misepress__filters-drawer--fullscreen,
  .misepress .misepress__filters-drawer[data-fullscreen="1"] {
    left: 0 !important;
    right: 0 !important;
    width: 100vw !important;
    max-width: 100vw !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    transform: none !important;
    padding-left: max(var(--mp-space-md, 1.25rem), env(safe-area-inset-left)) !important;
    padding-right: max(var(--mp-space-md, 1.25rem), env(safe-area-inset-right)) !important;
  }
  .misepress .misepress__filter-actions,
  .misepress .misepress__filters-actions,
  .misepress .misepress__filter-footer {
    display: flex !important;
    justify-content: center !important;
    padding-left: var(--mp-space-md, 1.25rem) !important;
    padding-right: var(--mp-space-md, 1.25rem) !important;
  }
  .misepress .misepress__filter-submit,
  .misepress .misepress__filter-apply {
    width: min(100%, 34rem) !important;
    max-width: calc(100vw - (var(--mp-space-md, 1.25rem) * 2)) !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
}

.misepress.misepress-acss .misepress {
  --mp-space-md: var(--space-m, 1.25rem);
}


/* ============================================================
 * ============================================================ */
.misepress-page--single .misepress__nutrition-label,
.misepress-page--single [data-mp-nutrition] {
  min-height: 0 !important;
  height: auto !important;
  padding: var(--space-m, 1.25rem) !important;
  display: block !important;
}
.misepress-page--single .misepress__nut-head {
  justify-content: center !important;
  text-align: center !important;
  gap: var(--space-xs, .55rem) !important;
  margin: 0 0 var(--space-s, .8rem) !important;
}
.misepress-page--single .misepress__nut-head .misepress__heading {
  width: 100% !important;
  margin: 0 !important;
}
.misepress-page--single .misepress__nut-grid {
  width: min(100%, 560px) !important;
  margin: var(--space-s, .8rem) auto 0 !important;
  display: grid !important;
  grid-template-columns: minmax(130px, 180px) minmax(0, 1fr) !important;
  gap: var(--space-s, .85rem) !important;
  align-items: center !important;
}
.misepress-page--single .misepress__nut-cal {
  min-height: 0 !important;
  height: auto !important;
  padding: var(--space-s, .8rem) !important;
  aspect-ratio: 1 / .82;
}
.misepress-page--single .misepress__nut-macros {
  gap: .45rem !important;
}
.misepress-page--single .misepress__nut-macros li {
  padding: .5rem .65rem !important;
  min-height: 0 !important;
}
.misepress-page--single .misepress__nut-bar {
  width: min(100%, 560px) !important;
  margin: var(--space-s, .75rem) auto 0 !important;
}
.misepress-page--single .misepress__nut-context,
.misepress-page--single .misepress__nut-source {
  width: min(100%, 560px) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  text-align: center !important;
}
@media (max-width: 640px) {
  .misepress-page--single .misepress__nut-grid {
    grid-template-columns: 1fr !important;
    max-width: 360px !important;
  }
  .misepress-page--single .misepress__nut-cal {
    aspect-ratio: auto !important;
    padding: .85rem !important;
  }
}

/* ============================================================
 * ============================================================ */
.misepress-page--single .misepress__tab-panel--reviews,
.misepress-page--single .misepress__section--reviews,
.misepress-page--single .misepress__reviews,
.misepress-page--single [data-mp-reviews] {
  min-height: 0 !important;
  height: auto !important;
  box-sizing: border-box !important;
}
.misepress-page--single .misepress__tab-panel--reviews {
  width: 100% !important;
  padding-block: 0 !important;
}
.misepress-page--single .misepress__tab-panel--reviews .misepress__reviews,
.misepress-page--single .misepress__tab-panel--reviews [data-mp-reviews],
.misepress-page--single .misepress__section--reviews {
  width: min(100%, 720px) !important;
  max-width: 720px !important;
  margin: 0 auto !important;
  padding: var(--space-m, 1.25rem) !important;
  display: grid !important;
  gap: var(--space-s, .85rem) !important;
  align-items: start !important;
  justify-items: stretch !important;
}
.misepress-page--single .misepress__section--reviews > .misepress__heading,
.misepress-page--single .misepress__reviews > .misepress__heading,
.misepress-page--single [data-mp-reviews] > .misepress__heading {
  margin: 0 0 var(--space-xs, .45rem) !important;
  text-align: center !important;
}
.misepress-page--single .misepress__reviews-summary {
  width: min(100%, 430px) !important;
  margin: 0 auto var(--space-xs, .45rem) !important;
  padding: var(--space-xs, .65rem) var(--space-s, .85rem) !important;
  display: grid !important;
  grid-template-columns: auto minmax(0, 1fr) !important;
  gap: var(--space-xs, .65rem) !important;
}
.misepress-page--single .misepress__review-form {
  width: min(100%, 430px) !important;
  margin: 0 auto !important;
  padding-top: var(--space-xs, .55rem) !important;
  display: grid !important;
  gap: var(--space-xs, .55rem) !important;
}
.misepress-page--single .misepress__review-stars-input {
  justify-content: center !important;
}
.misepress-page--single .misepress__review-comment-label,
.misepress-page--single .misepress__review-row label {
  gap: .25rem !important;
}
.misepress-page--single .misepress__review-comment-label textarea {
  min-height: 6rem !important;
  max-height: 9rem !important;
}
.misepress-page--single .misepress__review-form .misepress__btn,
.misepress-page--single .misepress__review-form button[type="submit"] {
  justify-self: center !important;
  width: min(100%, 280px) !important;
  margin: 0 auto !important;
}
.misepress-page--single .misepress__reviews-list {
  width: min(100%, 640px) !important;
  margin: var(--space-s, .85rem) auto 0 !important;
  gap: var(--space-xs, .55rem) !important;
}
.misepress-page--single .misepress__review {
  padding: var(--space-xs, .65rem) var(--space-s, .85rem) !important;
}
.misepress-page--single .misepress__review-body {
  margin: .15rem 0 0 !important;
}
@media (max-width: 640px) {
  .misepress-page--single .misepress__tab-panel--reviews .misepress__reviews,
  .misepress-page--single .misepress__tab-panel--reviews [data-mp-reviews],
  .misepress-page--single .misepress__section--reviews {
    padding: var(--space-s, .9rem) !important;
    max-width: 100% !important;
  }
  .misepress-page--single .misepress__reviews-summary {
    grid-template-columns: 1fr !important;
    width: min(100%, 360px) !important;
  }
  .misepress-page--single .misepress__review-form,
  .misepress-page--single .misepress__reviews-list {
    width: 100% !important;
  }
}

/* ============================================================
 * ============================================================ */
.misepress__single-rating {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: .45rem .6rem;
  width: fit-content;
  max-width: 100%;
  margin: calc(var(--space-xs, .55rem) * -0.25) auto var(--space-s, .85rem);
  padding: .45rem .75rem;
  border: 1px solid var(--mp-border, var(--mp-color-border, #ececec));
  border-radius: var(--radius-full, 999px);
  background: var(--mp-surface, var(--mp-color-bg, #fff));
  color: var(--mp-text, var(--mp-color-fg, #111));
  box-shadow: var(--mp-shadow-soft, 0 8px 22px rgba(0,0,0,.04));
}
.misepress__single-rating .misepress__stars {
  line-height: 1;
}
.misepress__single-rating-score {
  font-weight: 800;
}
.misepress__single-rating-count {
  color: var(--mp-muted, var(--mp-color-muted, #666));
  font-size: .92em;
}
.misepress__header + .misepress__single-rating,
.misepress__header--classic + .misepress__single-rating,
.misepress__header--magazine + .misepress__single-rating,
.misepress__header--compact + .misepress__single-rating,
.misepress__header--minimalist + .misepress__single-rating,
.misepress__header--editorial + .misepress__single-rating {
  display: flex;
}
.misepress__grid-rating {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  margin: .25rem 0 .35rem;
  color: var(--mp-text, var(--mp-color-fg, #111));
  font-size: .92rem;
}
.misepress__grid-rating .misepress__stars {
  line-height: 1;
}
.misepress__stars .is-full,
.misepress__stars .is-half {
  color: var(--mp-acss-authority, var(--action, var(--primary, var(--mp-color-accent, #E85D2A)))) !important;
}
.misepress__stars .is-empty,
.misepress__stars span:not(.is-full):not(.is-half) {
  color: color-mix(in srgb, var(--mp-muted, #777) 35%, transparent) !important;
}

@media (prefers-reduced-motion: no-preference) {
  .misepress.mp-animations .misepress__archive-header,
  .misepress.mp-animations .misepress__filter-panel,
  .misepress.mp-animations .misepress__filters,
  .misepress.mp-animations .misepress__header,
  .misepress.mp-animations .misepress__single-rating,
  .misepress.mp-animations .misepress__section,
  .misepress.mp-animations .misepress__reviews,
  .misepress.mp-animations .misepress__nutrition-label,
  .misepress.mp-animations .mp-anim-item,
  .misepress.mp-animations .misepress__grid-card {
    animation: mpFadeUp .55s cubic-bezier(.2,.7,.2,1) both;
  }
  .misepress.mp-animations .misepress__grid-card:nth-child(2n) { animation-delay: .04s; }
  .misepress.mp-animations .misepress__grid-card:nth-child(3n) { animation-delay: .08s; }
  .misepress.mp-animations .misepress__btn,
  .misepress.mp-animations .misepress__save-btn,
  .misepress.mp-animations .misepress__shopping-btn,
  .misepress.mp-animations .misepress__view-btn,
  .misepress.mp-animations .misepress__scale-pill,
  .misepress.mp-animations .misepress__filter-chip,
  .misepress.mp-animations .misepress__preset,
  .misepress.mp-animations .misepress__grid-card {
    transition: transform .22s ease, box-shadow .22s ease, background-color .22s ease, border-color .22s ease, color .22s ease;
  }
  .misepress.mp-animations .misepress__btn:hover,
  .misepress.mp-animations .misepress__save-btn:hover,
  .misepress.mp-animations .misepress__shopping-btn:hover,
  .misepress.mp-animations .misepress__filter-chip:hover,
  .misepress.mp-animations .misepress__preset:hover {
    transform: translateY(-1px);
  }
  .misepress.mp-animations .misepress__grid-card:hover {
    transform: translateY(-3px);
  }
  @keyframes mpFadeUp {
    from { opacity: 0; transform: translateY(12px); }
    to { opacity: 1; transform: translateY(0); }
  }
}


/* ============================================================
 * ============================================================ */
/* The single recipe rating is now a small action-area link, not a second review summary block. */
.misepress__single-rating {
  display: none !important;
}
.misepress__quick-rating {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .38rem;
  width: fit-content;
  max-width: 100%;
  margin: .1rem auto .35rem;
  color: var(--mp-text, var(--mp-color-fg, currentColor));
  font-size: .94rem;
  line-height: 1.2;
  text-decoration: none !important;
  opacity: .9;
}
.misepress__quick-rating:hover,
.misepress__quick-rating:focus-visible {
  color: var(--mp-acss-authority, var(--action, var(--primary, var(--mp-color-accent, currentColor))));
  opacity: 1;
}
.misepress__quick-rating .misepress__stars {
  line-height: 1;
}
.misepress__quick-rating-score {
  font-weight: 800;
}
.misepress__quick-rating-count {
  color: var(--mp-muted, var(--mp-color-muted, #666));
}
.misepress__hero-overlay > .misepress__quick-rating {
  order: 2;
}
.misepress__title-actions--hero + .misepress__quick-rating + .misepress__title--hero {
  margin-top: .15rem;
}
.misepress__header--editorial > .misepress__quick-rating {
  margin-inline: 0 auto;
}
@media (max-width: 640px) {
  .misepress__quick-rating {
    font-size: .88rem;
    gap: .3rem;
  }
}

/* ============================================================
 * ============================================================ */
.misepress,
.misepress-page {
  --mp-rating-star: var(--mp-color-accent, #E85D2A);
  --mp-rating-star-empty: color-mix(in srgb, var(--mp-color-muted, #777) 34%, transparent);
}
.misepress.misepress-acss .misepress,
.misepress.misepress-acss .misepress-page {
  --mp-rating-star: var(--mp-acss-authority, var(--action, var(--primary, var(--mp-color-accent, #E85D2A))));
  --mp-rating-star-empty: color-mix(in srgb, var(--base, var(--mp-color-muted, #777)) 28%, transparent);
}
.misepress .misepress__stars .is-full,
.misepress .misepress__stars .is-half,
.misepress-page .misepress__stars .is-full,
.misepress-page .misepress__stars .is-half,
.misepress .misepress__star.is-full,
.misepress-page .misepress__star.is-full,
.misepress .misepress__review-stars,
.misepress-page .misepress__review-stars,
.misepress .misepress__rating-summary-stars,
.misepress-page .misepress__rating-summary-stars {
  color: var(--mp-rating-star) !important;
}
.misepress .misepress__star.is-half,
.misepress-page .misepress__star.is-half {
  background: linear-gradient(90deg, var(--mp-rating-star) 50%, var(--mp-rating-star-empty) 50%) !important;
  -webkit-background-clip: text !important;
  background-clip: text !important;
  color: transparent !important;
}
.misepress .misepress__stars .is-empty,
.misepress .misepress__stars span:not(.is-full):not(.is-half),
.misepress-page .misepress__stars .is-empty,
.misepress-page .misepress__stars span:not(.is-full):not(.is-half),
.misepress .misepress__star:not(.is-full):not(.is-half),
.misepress-page .misepress__star:not(.is-full):not(.is-half) {
  color: var(--mp-rating-star-empty) !important;
}
.misepress .misepress__star-btn.is-active,
.misepress .misepress__star-btn:hover,
.misepress .misepress__star-btn:focus-visible,
.misepress-page .misepress__star-btn.is-active,
.misepress-page .misepress__star-btn:hover,
.misepress-page .misepress__star-btn:focus-visible {
  color: var(--mp-rating-star) !important;
}

/* ============================================================
 * ============================================================ */
.misepress__recipe.mp-ratio-16-9 .misepress__media,
.misepress__recipe.mp-ratio-4-3 .misepress__media,
.misepress__recipe.mp-ratio-3-2 .misepress__media,
.misepress__recipe.mp-ratio-1-1 .misepress__media,
.misepress__recipe.mp-ratio-21-9 .misepress__media {
  overflow: hidden;
}
.misepress__recipe.mp-ratio-16-9 .misepress__media img,
.misepress__recipe.mp-ratio-4-3 .misepress__media img,
.misepress__recipe.mp-ratio-3-2 .misepress__media img,
.misepress__recipe.mp-ratio-1-1 .misepress__media img,
.misepress__recipe.mp-ratio-21-9 .misepress__media img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
}
.misepress__recipe.mp-ratio-16-9 .misepress__media { aspect-ratio: 16 / 9 !important; }
.misepress__recipe.mp-ratio-4-3 .misepress__media { aspect-ratio: 4 / 3 !important; }
.misepress__recipe.mp-ratio-3-2 .misepress__media { aspect-ratio: 3 / 2 !important; }
.misepress__recipe.mp-ratio-1-1 .misepress__media { aspect-ratio: 1 / 1 !important; }
.misepress__recipe.mp-ratio-21-9 .misepress__media { aspect-ratio: 21 / 9 !important; }

/* Contained image = normal rounded image card; no accidental overlay treatment. */
.misepress__recipe.mp-img-contained .misepress__media {
  max-width: min(100%, var(--mp-content-narrow, 820px));
  margin-inline: auto !important;
  border-radius: var(--mp-radius, 16px) !important;
  overflow: hidden;
}
.misepress__recipe.mp-img-contained .misepress__media img {
  border-radius: inherit !important;
}

/* Full bleed image = image breaks out but text/content stays aligned. */
.misepress__recipe.mp-img-full-bleed .misepress__media {
  width: 100vw !important;
  max-width: 100vw !important;
  margin-inline: calc(50% - 50vw) !important;
  border-radius: 0 !important;
  overflow: hidden;
}
.misepress__recipe.mp-img-full-bleed .misepress__media img {
  border-radius: 0 !important;
}

/* Side image = image and intro sit beside each other on desktop. */
.misepress__recipe.mp-img-side .misepress__header--hero {
  display: grid !important;
  grid-template-columns: minmax(0, 1.05fr) minmax(320px, .95fr);
  align-items: stretch;
  gap: var(--mp-space-4, 2rem);
  text-align: left;
}
.misepress__recipe.mp-img-side .misepress__header--hero .misepress__media--hero {
  height: 100%;
  min-height: 360px;
  margin: 0 !important;
}
.misepress__recipe.mp-img-side .misepress__header--hero .misepress__media--hero img {
  height: 100% !important;
  object-fit: cover !important;
}
.misepress__recipe.mp-img-side .misepress__hero-overlay {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  text-align: left;
  padding: var(--mp-space-5, 2.5rem) !important;
  margin: 0 !important;
}
.misepress__recipe.mp-img-side .misepress__quick-rating,
.misepress__recipe.mp-img-side .misepress__title-actions--hero {
  margin-inline: 0 auto;
}
@media (max-width: 760px) {
  .misepress__recipe.mp-img-side .misepress__header--hero {
    grid-template-columns: 1fr;
    text-align: center;
  }
  .misepress__recipe.mp-img-side .misepress__hero-overlay {
    align-items: center;
    text-align: center;
    padding: var(--mp-space-3, 1.25rem) !important;
  }
  .misepress__recipe.mp-img-side .misepress__quick-rating,
  .misepress__recipe.mp-img-side .misepress__title-actions--hero {
    margin-inline: auto;
  }
  .misepress__recipe.mp-img-side .misepress__header--hero .misepress__media--hero {
    min-height: 0;
  }
}

/* Hero with title overlay = the title/action area genuinely overlays the image. */
.misepress__recipe.mp-img-hero-overlay .misepress__header--hero {
  position: relative !important;
  display: grid !important;
  min-height: clamp(420px, 58vw, 720px);
  overflow: hidden;
  border-radius: var(--mp-radius, 18px);
  background: var(--mp-surface, var(--mp-color-surface, #fff));
}
.misepress__recipe.mp-img-hero-overlay .misepress__header--hero .misepress__media--hero {
  grid-area: 1 / 1;
  width: 100%;
  height: 100%;
  margin: 0 !important;
  border-radius: inherit;
  overflow: hidden;
}
.misepress__recipe.mp-img-hero-overlay .misepress__header--hero .misepress__media--hero img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block;
}
.misepress__recipe.mp-img-hero-overlay .misepress__header--hero::after {
  content: "";
  grid-area: 1 / 1;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(0,0,0,.08) 0%, rgba(0,0,0,.16) 45%, rgba(0,0,0,.62) 100%);
  z-index: 1;
}
.misepress__recipe.mp-img-hero-overlay .misepress__hero-overlay {
  grid-area: 1 / 1;
  position: relative !important;
  z-index: 2;
  align-self: end;
  width: min(100%, 980px);
  margin: 0 auto !important;
  padding: clamp(1.5rem, 4vw, 3.5rem) !important;
  color: #fff !important;
  background: transparent !important;
  box-shadow: none !important;
  border: 0 !important;
}
.misepress__recipe.mp-img-hero-overlay .misepress__title--hero,
.misepress__recipe.mp-img-hero-overlay .misepress__excerpt--hero,
.misepress__recipe.mp-img-hero-overlay .misepress__quick-rating,
.misepress__recipe.mp-img-hero-overlay .misepress__quick-rating-count {
  color: #fff !important;
}
.misepress__recipe.mp-img-hero-overlay .misepress__hero-stats {
  background: color-mix(in srgb, #ffffff 88%, transparent) !important;
  color: var(--mp-color-fg, #111) !important;
}
.misepress__recipe.mp-img-hero-overlay .misepress__title-actions--hero .misepress__btn,
.misepress__recipe.mp-img-hero-overlay .misepress__title-actions--hero .misepress__save-btn {
  background: color-mix(in srgb, #ffffff 86%, transparent) !important;
  color: var(--mp-color-fg, #111) !important;
  border-color: color-mix(in srgb, #ffffff 75%, transparent) !important;
}

/* Hide featured image choice must also remove image-reserved spacing. */
.misepress__recipe.mp-img-none .misepress__media,
.misepress__recipe.mp-img-none .misepress__media--hero,
.misepress__recipe.mp-img-none .misepress__media--editorial {
  display: none !important;
}

/* Keep the quick rating hidden when the new single rating setting is off via markup. */

/* ============================================================
 * ============================================================ */
/* Keep the single recipe image/header section on the same content rail as
   the rest of the recipe unless the explicit full-bleed image option is used. */
.misepress-page--single .misepress__recipe:not(.mp-img-full-bleed) > .misepress__header--hero,
.misepress-page--single .misepress__recipe:not(.mp-img-full-bleed) > .misepress__header,
.misepress-page--single .misepress__recipe:not(.mp-img-full-bleed) > .misepress__media {
  width: min(100%, var(--mp-single-max-w, var(--mp-content-width, 1140px))) !important;
  max-width: min(100%, var(--mp-single-max-w, var(--mp-content-width, 1140px))) !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

/* Hero overlay should feel like a compact hero, not a giant billboard with a huge
   empty lower area. */
.misepress-page--single .misepress__recipe.mp-img-hero-overlay {
  gap: var(--mp-space-3, 1.25rem) !important;
}
.misepress-page--single .misepress__recipe.mp-img-hero-overlay .misepress__header--hero {
  width: min(100%, var(--mp-single-max-w, var(--mp-content-width, 1140px))) !important;
  max-width: min(100%, var(--mp-single-max-w, var(--mp-content-width, 1140px))) !important;
  min-height: clamp(360px, 42vw, 560px) !important;
  margin: 0 auto !important;
  border-radius: var(--mp-radius, 18px) !important;
  overflow: hidden !important;
}
.misepress-page--single .misepress__recipe.mp-img-hero-overlay .misepress__header--hero::after {
  background:
    linear-gradient(180deg, rgba(0,0,0,.26) 0%, rgba(0,0,0,.18) 32%, rgba(0,0,0,.72) 100%),
    radial-gradient(circle at 50% 68%, rgba(0,0,0,.28), rgba(0,0,0,0) 45%) !important;
}
.misepress-page--single .misepress__recipe.mp-img-hero-overlay .misepress__hero-overlay {
  width: min(100%, 920px) !important;
  padding: clamp(1rem, 2.8vw, 2.25rem) clamp(1rem, 3vw, 2.5rem) clamp(1.1rem, 3vw, 2.4rem) !important;
  gap: clamp(.45rem, 1vw, .75rem) !important;
  text-align: center !important;
  align-items: center !important;
}
.misepress-page--single .misepress__recipe.mp-img-hero-overlay .misepress__title--hero {
  max-width: 18ch !important;
  color: #fff !important;
  text-shadow: 0 3px 22px rgba(0,0,0,.72), 0 1px 3px rgba(0,0,0,.65) !important;
}
.misepress-page--single .misepress__recipe.mp-img-hero-overlay .misepress__excerpt--hero,
.misepress-page--single .misepress__recipe.mp-img-hero-overlay .misepress__quick-rating,
.misepress-page--single .misepress__recipe.mp-img-hero-overlay .misepress__quick-rating-count {
  color: rgba(255,255,255,.94) !important;
  text-shadow: 0 2px 12px rgba(0,0,0,.7), 0 1px 2px rgba(0,0,0,.65) !important;
}
.misepress-page--single .misepress__recipe.mp-img-hero-overlay .misepress__title-actions--hero {
  margin-top: .35rem !important;
}
.misepress-page--single .misepress__recipe.mp-img-hero-overlay .misepress__hero-stats {
  margin-top: .45rem !important;
  margin-bottom: 0 !important;
  background: rgba(255,255,255,.88) !important;
  box-shadow: 0 18px 38px -24px rgba(0,0,0,.55) !important;
  backdrop-filter: blur(8px) !important;
  -webkit-backdrop-filter: blur(8px) !important;
}
.misepress-page--single .misepress__recipe.mp-img-hero-overlay .misepress__hero-allergens {
  margin-top: .45rem !important;
}

/* Pull the tabs/content up closer after hero overlay and keep the same content rail. */
.misepress-page--single .misepress__recipe.mp-img-hero-overlay .misepress__tabs,
.misepress-page--single .misepress__recipe.mp-img-hero-overlay .misepress__tablist,
.misepress-page--single .misepress__recipe.mp-img-hero-overlay .misepress__body {
  max-width: min(100%, var(--mp-single-max-w, var(--mp-content-width, 1140px))) !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
.misepress-page--single .misepress__recipe.mp-img-hero-overlay .misepress__tabs,
.misepress-page--single .misepress__recipe.mp-img-hero-overlay .misepress__tablist {
  margin-top: clamp(.4rem, 1.2vw, .85rem) !important;
}

@media (max-width: 760px) {
  .misepress-page--single .misepress__recipe.mp-img-hero-overlay .misepress__header--hero {
    min-height: clamp(430px, 112vw, 620px) !important;
    width: 100% !important;
    max-width: 100% !important;
  }
  .misepress-page--single .misepress__recipe.mp-img-hero-overlay .misepress__hero-overlay {
    padding: 1rem .9rem 1.15rem !important;
  }
  .misepress-page--single .misepress__recipe.mp-img-hero-overlay .misepress__title--hero {
    max-width: 12ch !important;
  }
}

/* ============================================================
 * Distinguish default/contained/full-bleed, align image rail,
 * and make hero overlay readable on bright food photos.
 * ============================================================ */
.misepress-page--single .misepress__recipe {
  --mp-single-rail: min(100%, var(--mp-single-max-w, var(--mp-content-width, 1140px)));
}

/* Default keeps the template's normal image treatment: same rail, no extra card frame. */
.misepress-page--single .misepress__recipe.mp-img-default > .misepress__header--hero,
.misepress-page--single .misepress__recipe.mp-img-default > .misepress__header {
  width: var(--mp-single-rail) !important;
  max-width: var(--mp-single-rail) !important;
  margin-inline: auto !important;
}
.misepress-page--single .misepress__recipe.mp-img-default .misepress__media--hero,
.misepress-page--single .misepress__recipe.mp-img-default .misepress__media--editorial {
  width: 100% !important;
  max-width: 100% !important;
  margin-inline: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

/* Contained is intentionally different from default: a smaller framed image card. */
.misepress-page--single .misepress__recipe.mp-img-contained > .misepress__header--hero,
.misepress-page--single .misepress__recipe.mp-img-contained > .misepress__header {
  width: var(--mp-single-rail) !important;
  max-width: var(--mp-single-rail) !important;
  margin-inline: auto !important;
}
.misepress-page--single .misepress__recipe.mp-img-contained .misepress__media--hero,
.misepress-page--single .misepress__recipe.mp-img-contained .misepress__media--editorial,
.misepress-page--single .misepress__recipe.mp-img-contained .misepress__media {
  width: min(100%, 920px) !important;
  max-width: min(100%, 920px) !important;
  margin-inline: auto !important;
  padding: clamp(.35rem, .8vw, .65rem) !important;
  border: 1px solid var(--mp-color-border, rgba(0,0,0,.12)) !important;
  border-radius: calc(var(--mp-radius, 16px) + .35rem) !important;
  background: var(--mp-color-bg, #fff) !important;
  box-shadow: var(--mp-shadow-sm, 0 12px 30px rgba(0,0,0,.08)) !important;
  overflow: hidden !important;
}
.misepress-page--single .misepress__recipe.mp-img-contained .misepress__media img {
  border-radius: var(--mp-radius, 16px) !important;
}

/* Full-bleed means flush to the recipe rail edge, not accidentally narrower than content. */
.misepress-page--single .misepress__recipe.mp-img-full-bleed > .misepress__header--hero,
.misepress-page--single .misepress__recipe.mp-img-full-bleed > .misepress__header {
  width: var(--mp-single-rail) !important;
  max-width: var(--mp-single-rail) !important;
  margin-inline: auto !important;
  border-radius: 0 !important;
  overflow: visible !important;
}
.misepress-page--single .misepress__recipe.mp-img-full-bleed .misepress__media--hero,
.misepress-page--single .misepress__recipe.mp-img-full-bleed .misepress__media--editorial,
.misepress-page--single .misepress__recipe.mp-img-full-bleed .misepress__media {
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  border-radius: 0 !important;
  border: 0 !important;
  box-shadow: none !important;
  overflow: hidden !important;
}
.misepress-page--single .misepress__recipe.mp-img-full-bleed .misepress__media img {
  width: 100% !important;
  border-radius: 0 !important;
}

/* Hero overlay: same rail as content, much stronger contrast, less dead space below. */
.misepress-page--single .misepress__recipe.mp-img-hero-overlay > .misepress__header--hero {
  width: var(--mp-single-rail) !important;
  max-width: var(--mp-single-rail) !important;
  margin-inline: auto !important;
  min-height: clamp(390px, 44vw, 610px) !important;
  isolation: isolate;
}
.misepress-page--single .misepress__recipe.mp-img-hero-overlay .misepress__media--hero {
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
}
.misepress-page--single .misepress__recipe.mp-img-hero-overlay .misepress__media--hero img {
  filter: brightness(.62) saturate(.95) contrast(1.08) !important;
}
.misepress-page--single .misepress__recipe.mp-img-hero-overlay .misepress__header--hero::after {
  background:
    linear-gradient(180deg, rgba(0,0,0,.56) 0%, rgba(0,0,0,.36) 34%, rgba(0,0,0,.78) 100%),
    radial-gradient(circle at 50% 42%, rgba(0,0,0,.12) 0%, rgba(0,0,0,.58) 72%) !important;
  box-shadow: inset 0 -180px 160px rgba(0,0,0,.44), inset 0 110px 130px rgba(0,0,0,.32) !important;
}
.misepress-page--single .misepress__recipe.mp-img-hero-overlay .misepress__hero-overlay {
  width: min(100%, 880px) !important;
  padding: clamp(1rem, 2.4vw, 2rem) clamp(1rem, 3vw, 2.25rem) !important;
  gap: clamp(.35rem, .8vw, .65rem) !important;
}
.misepress-page--single .misepress__recipe.mp-img-hero-overlay .misepress__title--hero {
  color: #fff !important;
  text-shadow: 0 4px 30px rgba(0,0,0,.95), 0 1px 5px rgba(0,0,0,.9) !important;
}
.misepress-page--single .misepress__recipe.mp-img-hero-overlay .misepress__excerpt--hero,
.misepress-page--single .misepress__recipe.mp-img-hero-overlay .misepress__quick-rating,
.misepress-page--single .misepress__recipe.mp-img-hero-overlay .misepress__quick-rating-count {
  color: rgba(255,255,255,.98) !important;
  text-shadow: 0 3px 18px rgba(0,0,0,.95), 0 1px 4px rgba(0,0,0,.9) !important;
}
.misepress-page--single .misepress__recipe.mp-img-hero-overlay .misepress__title-actions--hero {
  margin-top: .2rem !important;
}
.misepress-page--single .misepress__recipe.mp-img-hero-overlay .misepress__hero-stats {
  margin-top: .35rem !important;
}
.misepress-page--single .misepress__recipe.mp-img-hero-overlay .misepress__tabs,
.misepress-page--single .misepress__recipe.mp-img-hero-overlay .misepress__tablist {
  margin-top: .25rem !important;
}

@media (max-width: 760px) {
  .misepress-page--single .misepress__recipe.mp-img-contained .misepress__media--hero,
  .misepress-page--single .misepress__recipe.mp-img-contained .misepress__media--editorial,
  .misepress-page--single .misepress__recipe.mp-img-contained .misepress__media {
    width: 100% !important;
    max-width: 100% !important;
    padding: .3rem !important;
  }
  .misepress-page--single .misepress__recipe.mp-img-hero-overlay > .misepress__header--hero {
    min-height: clamp(460px, 118vw, 640px) !important;
  }
}

.misepress.misepress-acss,
.misepress-page.misepress-acss,
.misepress-acss .misepress {
  --mp-action: var(--action, var(--primary, var(--base-dark, #1a1a1a)));
  --mp-action-hover: var(--action-hover, var(--action-dark, var(--primary-hover, var(--primary-dark, var(--mp-action)))));
  --mp-action-soft: var(--action-light-trans-90, var(--primary-light-trans-90, color-mix(in srgb, var(--mp-action) 10%, transparent)));
  --mp-action-contrast: var(--action-ultra-light, var(--primary-ultra-light, #fff));
  --mp-surface: var(--base-ultra-light, var(--white, #fff));
  --mp-surface-alt: var(--base-light-trans-20, color-mix(in srgb, var(--base, #111) 5%, #fff));
  --mp-text: var(--base-ultra-dark, var(--text-dark, #111));
  --mp-text-muted: var(--base, var(--text-light, #666));
  --mp-line: var(--base-light, rgba(0,0,0,.12));
  --mp-radius-main: var(--radius-m, 16px);
  --mp-radius-small: var(--radius-s, 10px);
  --mp-gap-main: var(--space-m, 1.25rem);
  --mp-gap-small: var(--space-s, .85rem);
  --mp-page-padding: var(--space-m, 1rem);
  --mp-color-accent: var(--mp-action) !important;
  --mp-color-accent-active: var(--mp-action-hover) !important;
  --mp-color-accent-soft: var(--mp-action-soft) !important;
  --mp-color-accent-contrast: var(--mp-action-contrast) !important;
  --mp-card-accent: var(--mp-action) !important;
  --mp-filter-accent: var(--mp-action) !important;
  --mp-color-surface: var(--mp-surface) !important;
  --mp-color-bg: var(--body-bg, var(--mp-surface)) !important;
  --mp-color-fg: var(--mp-text) !important;
  --mp-color-muted: var(--mp-text-muted) !important;
  --mp-color-border: var(--mp-line) !important;
  --mp-card-bg: var(--mp-surface) !important;
  --mp-card-text: var(--mp-text) !important;
  --mp-filter-bg: var(--mp-surface) !important;
  --mp-filter-text: var(--mp-text) !important;
  --mp-radius: var(--mp-radius-main) !important;
  --mp-radius-sm: var(--mp-radius-small) !important;
  --mp-grid-gap: var(--mp-gap-main) !important;
  --mp-archive-filter-gap: var(--mp-gap-main) !important;
  --mp-single-section-gap: var(--mp-gap-main) !important;
  --mp-archive-pad-x: var(--mp-page-padding) !important;
}

.misepress.misepress-acss :where(a,.misepress__link,.misepress__grid-title a:hover,.misepress__card-title a:hover,.misepress__meta-value,.misepress__hero-stat-value,.misepress__nut-cal-num,.misepress__nutrition-kcal,.misepress__rating-stars,.misepress__rating-star,.misepress__review-stars,.misepress__quick-rating-stars,.misepress__card-rating-stars,.misepress__allergen-icon,.misepress__filter-reset,.misepress__filter-loadmore) {
  color: var(--mp-action) !important;
}
.misepress.misepress-acss :where(.misepress__btn--primary,.misepress__filter-trigger,.misepress__filter-submit,.misepress__filter-apply,.misepress__density-btn.is-active,.misepress__view-btn.is-active,.misepress__tab.is-active,.misepress__preset.is-active,.misepress__scale-pill.is-active,.misepress__scale-pill--more.is-active,.misepress__save-btn.is-saved,.misepress__shopping-btn.is-added,.misepress__pagination .page-numbers.current,.misepress__step::before) {
  background: var(--mp-action) !important;
  border-color: var(--mp-action) !important;
  color: var(--mp-action-contrast) !important;
}
.misepress.misepress-acss :where(.misepress__chip,.misepress__diet-tag,.misepress__allergen,.misepress__allergen-badge,.misepress__hero-allergen,.misepress__scale-controls,.misepress__custom-scale,.misepress__timer-btn,.misepress__nut-card,.misepress__grid-nut-item,.misepress__filter-panel,.misepress__filters,.misepress__section,.misepress__recipe-card,.misepress__grid-card) {
  background-color: var(--mp-surface) !important;
  border-color: var(--mp-line) !important;
  color: var(--mp-text) !important;
}
.misepress.misepress-acss :where(.misepress__chip:hover,.misepress__timer-btn:hover,.misepress__scale-pill:hover,.misepress__grid-card:hover) {
  border-color: var(--mp-action) !important;
}
.misepress :where(.misepress__grid-nut-item strong,.misepress__nut-card strong,.misepress__macro-value,.misepress__nutrition-value) {
  background: transparent !important;
  background-color: transparent !important;
  box-shadow: none !important;
}

/* Mobile filter sheet consistency: centred sheet by default, true viewport when full-screen is enabled. */
@media (max-width: 767px) {
  .misepress .misepress__filter-panel,
  .misepress .misepress__filters {
    max-width: calc(100vw - (var(--mp-archive-pad-x, 1rem) * 2)) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    box-sizing: border-box !important;
  }
  .misepress__archive--mobile-floating-bottom .misepress__filter-panel,
  .misepress__archive--mobile-corner-floater .misepress__filter-panel {
    left: var(--mp-archive-pad-x, 1rem) !important;
    right: var(--mp-archive-pad-x, 1rem) !important;
    width: auto !important;
    transform: none !important;
  }
  .misepress.mp-filter-mobile-full .misepress__filter-panel,
  .misepress.mp-filter-mobile-full .misepress__filters {
    left: 0 !important;
    right: 0 !important;
    width: 100vw !important;
    max-width: 100vw !important;
    min-height: 100svh !important;
    border-radius: 0 !important;
    margin: 0 !important;
  }
  .misepress .misepress__filter-submit,
  .misepress .misepress__filter-apply {
    display: inline-flex !important;
    width: auto !important;
    min-width: min(76vw, 260px) !important;
    margin-inline: auto !important;
    justify-content: center !important;
  }
  .misepress .misepress__filter-actions,
  .misepress .misepress__filter-footer {
    text-align: center !important;
    justify-content: center !important;
  }
}

.misepress__featured-recipe{--mp-featured-radius:var(--mp-radius,18px);overflow:hidden;border:1px solid var(--mp-color-border,#eadfd6);border-radius:var(--mp-featured-radius);background:var(--mp-color-bg,#fff);box-shadow:var(--mp-shadow-sm,0 8px 20px rgba(0,0,0,.05));}
.misepress__featured-link{display:grid;grid-template-columns:minmax(160px,.9fr) minmax(0,1.1fr);color:inherit;text-decoration:none;min-height:220px;}
.misepress__featured-media{display:block;min-height:220px;background:color-mix(in srgb,var(--mp-color-accent,#E85D2A) 12%,var(--mp-color-bg,#fff)) center/cover no-repeat;}
.misepress__featured-media--empty{background:linear-gradient(135deg,color-mix(in srgb,var(--mp-color-accent,#E85D2A) 18%,#fff),var(--mp-color-bg,#fff));}
.misepress__featured-body{display:grid;align-content:center;gap:.65rem;padding:clamp(1rem,3vw,2rem);}
.misepress__featured-label{text-transform:uppercase;letter-spacing:.13em;font-size:.72rem;font-weight:800;color:var(--mp-color-accent,#E85D2A);}
.misepress__featured-title{font-family:var(--mp-font-display,inherit);font-size:clamp(1.35rem,2.6vw,2.35rem);line-height:1.08;}
.misepress__featured-excerpt{color:var(--mp-color-muted,#666);max-width:55ch;}
.misepress__featured-meta{display:flex;gap:.55rem;flex-wrap:wrap;color:var(--mp-color-muted,#666);font-size:.88rem;}
.misepress__featured-meta em{font-style:normal;border:1px solid var(--mp-color-border,#eadfd6);border-radius:999px;padding:.28rem .6rem;background:color-mix(in srgb,var(--mp-color-bg,#fff) 85%,var(--mp-color-accent,#E85D2A));}
.misepress__featured-recipe--hero .misepress__featured-link{grid-template-columns:1fr;min-height:360px;position:relative;}
.misepress__featured-recipe--hero .misepress__featured-media{position:absolute;inset:0;min-height:100%;}
.misepress__featured-recipe--hero .misepress__featured-body{position:relative;align-content:end;min-height:360px;color:#fff;background:linear-gradient(180deg,rgba(0,0,0,.08),rgba(0,0,0,.78));}
.misepress__featured-recipe--hero .misepress__featured-label,.misepress__featured-recipe--hero .misepress__featured-excerpt,.misepress__featured-recipe--hero .misepress__featured-meta{color:rgba(255,255,255,.88);}
.misepress__featured-recipe--hero .misepress__featured-title{color:#fff;}
.misepress__featured-recipe--hero .misepress__featured-meta em{border-color:rgba(255,255,255,.24);background:rgba(255,255,255,.12);color:#fff;}
.misepress__featured-recipe--compact .misepress__featured-link{grid-template-columns:110px 1fr;min-height:120px;}
.misepress__featured-recipe--compact .misepress__featured-media{min-height:120px;}
.misepress__featured-recipe--compact .misepress__featured-body{padding:1rem;gap:.35rem;}
.misepress__featured-recipe--compact .misepress__featured-title{font-size:1.1rem;}
.misepress__featured-recipe--editorial{border:0;box-shadow:none;background:transparent;}
.misepress__featured-recipe--editorial .misepress__featured-link{grid-template-columns:1fr;gap:.85rem;}
.misepress__featured-recipe--editorial .misepress__featured-media{border-radius:var(--mp-featured-radius);min-height:280px;}
.misepress__featured-recipe--editorial .misepress__featured-body{padding:0;}
@media(max-width:720px){.misepress__featured-link{grid-template-columns:1fr}.misepress__featured-media{min-height:190px}.misepress__featured-recipe--compact .misepress__featured-link{grid-template-columns:88px 1fr}.misepress__featured-recipe--compact .misepress__featured-media{min-height:104px}}


/* Favourites + shopping list live/cache-safe UX */
.misepress__favorites-toolbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin:0 0 var(--mp-space-m,1.5rem);flex-wrap:wrap}.misepress__favorites-toolbar .misepress__favorites-count{margin:0}.misepress__favorite-card-wrap{position:relative}.misepress__favorite-remove{position:absolute;z-index:5;top:.65rem;right:.65rem;width:2.3rem;height:2.3rem;border:0;border-radius:999px;background:var(--mp-surface,#fff);color:var(--mp-text,#111);box-shadow:0 8px 24px rgba(0,0,0,.16);font-size:1.35rem;line-height:1;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.misepress__favorite-remove:hover,.misepress__favorite-remove:focus-visible{background:var(--mp-action,#E85D2A);color:var(--mp-action-text,#fff)}.misepress__shopping-actions{display:flex;gap:.6rem;flex-wrap:wrap}.misepress__shopping-remove{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;border:1px solid var(--mp-border,#e5e7eb);border-radius:999px;background:var(--mp-surface,#fff);color:var(--mp-text,#111);font-size:1.2rem;line-height:1;cursor:pointer}.misepress__shopping-remove:hover,.misepress__shopping-remove:focus-visible{background:var(--mp-action,#E85D2A);color:var(--mp-action-text,#fff)}@media print{body *{visibility:hidden!important}.misepress__shopping,.misepress__shopping *{visibility:visible!important}.misepress__shopping{position:absolute!important;left:0!important;top:0!important;width:100%!important;background:#fff!important;color:#111!important;box-shadow:none!important}.misepress__shopping button{display:none!important}}

/* Shopping list: actionable item state + mobile sharing polish */
.misepress__shopping-item span{display:inline-flex;align-items:baseline;gap:.35rem;flex-wrap:wrap;min-width:0}
.misepress__shopping-got{display:inline-flex;align-items:center;margin-left:.25rem;padding:.12rem .45rem;border-radius:999px;background:var(--mp-surface-alt,#f5f5f5);color:var(--mp-muted,#6b7280);font-size:.72rem;font-weight:700;text-decoration:none!important;white-space:nowrap}
.misepress__shopping-item.is-checked .misepress__shopping-got{background:color-mix(in srgb,var(--mp-action,#E85D2A) 12%,transparent);color:var(--mp-action,#E85D2A)}
.misepress__shopping-item.is-checked label>span{text-decoration:line-through;color:var(--mp-muted,#9a9a9a)}
.misepress__shopping-item.is-checked .misepress__shopping-got{text-decoration:none!important}
@media(max-width:640px){.misepress__shopping-actions{width:100%;justify-content:flex-start}.misepress__shopping-actions .misepress__btn{flex:1 1 30%;min-width:0}.misepress__shopping-recipe-head{align-items:center}.misepress__shopping-item label{align-items:flex-start}.misepress__shopping-item input[type=checkbox]{margin-top:.2rem}}


/* 1.35.24 — shopping list empty state stays clean after removing the last recipe. */
.misepress__shopping.is-empty .misepress__shopping-head,
.misepress__shopping.is-empty .misepress__shopping-actions{display:none!important;}
.misepress__shopping.is-empty .misepress__shopping-empty{margin-top:0;}

/* MisePress v1.35.46 — recipe utility polish */
.misepress__recipe-toolbar{display:flex;gap:.6rem;flex-wrap:wrap;justify-content:flex-end;margin:0 0 1rem}
.misepress__ingredient-group,.misepress__step-group{list-style:none!important;margin:1rem 0 .45rem!important;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:var(--mp-muted,#6b6b6b);font-size:.82rem}
.misepress__step-group{counter-increment:none!important}
.misepress__inline-ingredient{display:inline-block;padding:.05em .38em;border-radius:999px;background:var(--mp-accent-soft,#fde7d3);color:var(--mp-accent,#c2410c);font-weight:700}
.misepress__step-ingredients{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.55rem}
.misepress__step-ingredients span{font-size:.78rem;border:1px solid var(--mp-border,#ececec);border-radius:999px;padding:.18rem .55rem;background:var(--mp-surface,#fff)}
.misepress__recipe-toolbar{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;margin:1rem 0}.misepress__recipe-toolbar--top{justify-content:flex-end}.misepress__recipe-toolbar--after-hero,.misepress__recipe-toolbar--before-body{justify-content:center}.misepress__recipe-toolbar--bottom{justify-content:center;margin-top:2rem;padding-top:1rem;border-top:1px solid var(--mp-border,#ececec)}.misepress__recipe-tool{display:inline-flex!important;align-items:center;gap:.45rem}
.misepress__cook-overlay{position:fixed;inset:0;z-index:999999;background:radial-gradient(circle at top left,rgba(232,93,42,.22),transparent 32%),rgba(15,17,21,.76);backdrop-filter:blur(10px);padding:clamp(.75rem,3vw,2rem);display:flex;align-items:center;justify-content:center}
.misepress__cook-panel{width:min(1040px,100%);max-height:min(920px,94vh);overflow:auto;background:linear-gradient(180deg,var(--mp-bg,#fffdf8),#fff);color:var(--mp-fg,#1a1a1a);border:1px solid rgba(255,255,255,.5);border-radius:28px;box-shadow:0 34px 100px rgba(0,0,0,.38);padding:0}
.misepress__cook-head{position:sticky;top:0;background:rgba(255,253,248,.94);backdrop-filter:blur(12px);z-index:2;display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;border-bottom:1px solid var(--mp-border,#ececec);padding:clamp(1rem,3vw,1.6rem)}
.misepress__cook-eyebrow{margin:0 0 .35rem;color:var(--mp-accent,#E85D2A);font-weight:900;text-transform:uppercase;letter-spacing:.11em;font-size:.78rem}.misepress__cook-head h2{margin:0;font-family:inherit;font-size:clamp(1.65rem,4.5vw,3rem);line-height:1.05}.misepress__cook-meta{display:flex;gap:.45rem;flex-wrap:wrap;margin-top:.75rem}.misepress__cook-meta span{display:inline-flex;border:1px solid var(--mp-border,#ececec);border-radius:999px;padding:.35rem .65rem;background:#fff;font-size:.9rem;color:var(--mp-muted,#666)}
.misepress__cook-close{border:0;border-radius:999px;background:var(--mp-accent-soft,#fde7d3);color:var(--mp-fg,#111);font-size:2rem;width:3.25rem;height:3.25rem;line-height:1;cursor:pointer;box-shadow:0 8px 22px rgba(0,0,0,.1)}.misepress__cook-close:hover{background:var(--mp-accent,#E85D2A);color:#fff}.misepress__cook-tip{margin:1rem clamp(1rem,3vw,1.8rem) 0;padding:.8rem 1rem;border:1px solid var(--mp-border,#ececec);border-radius:16px;background:#fff7ed;color:var(--mp-muted,#666)}
.misepress-cook-mode-active body{overflow:hidden}.misepress__cook-body{display:grid;grid-template-columns:minmax(260px,.8fr) minmax(0,1.2fr);gap:clamp(1rem,3vw,2rem);padding:clamp(1rem,3vw,1.8rem)}.misepress__cook-.misepress .misepress__section{margin:0}.misepress__cook-.misepress .misepress__heading{font-size:clamp(1.25rem,3vw,1.8rem);margin-top:0}.misepress__cook-.misepress .misepress__ingredient,.misepress__cook-.misepress .misepress__step{border:1px solid var(--mp-border,#ececec);border-radius:18px;background:#fff;padding:1rem;margin:.65rem 0;box-shadow:0 10px 26px rgba(0,0,0,.045);cursor:pointer;transition:.18s ease}.misepress__cook-.misepress .misepress__ingredient:hover,.misepress__cook-.misepress .misepress__step:hover{transform:translateY(-1px);box-shadow:0 14px 32px rgba(0,0,0,.07)}.misepress__cook-.misepress .misepress__ingredient.is-checked,.misepress__cook-.misepress .misepress__step.is-checked{opacity:.55;text-decoration:line-through;background:#f7f7f7}.misepress__cook-.misepress .misepress__step{position:relative;padding-left:4rem}.misepress__cook-step-num{position:absolute;left:1rem;top:1rem;display:grid;place-items:center;width:2rem;height:2rem;border-radius:999px;background:var(--mp-accent,#E85D2A);color:#fff;font-weight:900}.misepress__cook-.misepress .misepress__step-text{font-size:clamp(1.08rem,2.4vw,1.38rem);line-height:1.65}
@media(max-width:760px){.misepress__cook-overlay{align-items:flex-end;padding:.5rem}.misepress__cook-panel{max-height:96vh;border-radius:26px 26px 0 0}.misepress__cook-body{grid-template-columns:1fr}.misepress__cook-head{padding:1rem}.misepress__cook-tip{margin:.75rem 1rem 0}.misepress__recipe-toolbar{justify-content:center}.misepress__recipe-tool{flex:1 1 auto;justify-content:center}}
@media print{.misepress__recipe-toolbar,.misepress__cook-overlay{display:none!important}}

/* MisePress 1.35.47: recipe action icon cleanup */
.misepress__recipe-tool-icon{display:inline-block;vertical-align:-0.15em;margin-right:.4rem;flex:0 0 auto}
.misepress__recipe-tool--pin{color:#bd081c}


/* 1.35.51 — Pro notes, collections, author box, schema health and stronger cook/PDF polish */
.misepress__private-notes,.misepress__author-box,.misepress__schema-health,.misepress__saved-collections .misepress__collection{border:1px solid var(--mp-border,#ececec);border-radius:18px;background:var(--mp-surface,#fff);box-shadow:0 14px 34px rgba(0,0,0,.05);padding:clamp(1rem,2.5vw,1.5rem);margin:var(--mp-single-section-gap,2rem) 0}.misepress__private-note-input{width:100%;border:1px solid var(--mp-border,#ececec);border-radius:14px;padding:1rem;background:var(--mp-bg,#fffdf8);color:var(--mp-fg,#111);font:inherit}.misepress__private-note-actions{display:flex;align-items:center;gap:.8rem;margin-top:.75rem}.misepress__private-note-status{color:var(--mp-muted,#666);font-size:.92rem}.misepress__author-box{display:flex;gap:1rem;align-items:center}.misepress__author-avatar img{border-radius:999px}.misepress__author-kicker{font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;color:var(--mp-muted,#666);margin:0}.misepress__author-content h2{margin:.1rem 0 .35rem}.misepress__schema-health{border-left:5px solid var(--mp-action,#E85D2A);background:linear-gradient(90deg,color-mix(in srgb,var(--mp-action,#E85D2A) 8%,transparent),var(--mp-surface,#fff));}.misepress__schema-health p{margin:.45rem 0 0;color:var(--mp-muted,#666)}.misepress__recipe-tool--collection.is-loading{opacity:.65;pointer-events:none}.misepress__cook-progress{height:8px;background:rgba(0,0,0,.07);overflow:hidden}.misepress__cook-progress span{display:block;width:0;height:100%;background:var(--mp-accent,#E85D2A);transition:width .25s ease}.misepress__cook-footer{position:sticky;bottom:0;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem clamp(1rem,3vw,1.6rem);background:rgba(255,253,248,.96);border-top:1px solid var(--mp-border,#ececec);backdrop-filter:blur(12px)}.misepress__cook-count{color:var(--mp-muted,#666);white-space:nowrap}.misepress__cook-.misepress .misepress__step{opacity:.6}.misepress__cook-.misepress .misepress__step.is-current{opacity:1;border-color:var(--mp-accent,#E85D2A);box-shadow:0 18px 44px rgba(232,93,42,.16)}.misepress__cook-.misepress .misepress__step.is-current .misepress__cook-step-num{transform:scale(1.08)}@media(max-width:640px){.misepress__author-box{align-items:flex-start}.misepress__cook-footer{gap:.5rem}.misepress__cook-footer .misepress__btn{padding:.7rem .85rem}.misepress__cook-count{font-size:.9rem}}

/* 1.35.52 — cleaner Pro action tools, notes placement, author archive polish */
.misepress__recipe-toolbar{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;margin:1.25rem 0;justify-content:center}
.misepress__recipe-toolbar--top{justify-content:flex-end}.misepress__recipe-toolbar--after-hero{justify-content:center;margin-top:1.2rem}.misepress__recipe-toolbar--before-body{justify-content:center;margin:1.5rem 0}.misepress__recipe-toolbar--bottom{justify-content:center;margin-top:2rem;padding-top:1.25rem;border-top:1px solid var(--mp-border,#ececec)}
.misepress__recipe-tool{display:inline-flex!important;align-items:center;justify-content:center;gap:.55rem;min-height:46px;padding:.72rem 1.05rem!important;border:1px solid var(--mp-border,#ded8d2)!important;border-radius:999px!important;background:var(--mp-surface,#fff)!important;color:var(--mp-text,#1b1b1b)!important;box-shadow:0 10px 24px rgba(0,0,0,.045);font-weight:800;text-decoration:none!important;line-height:1.1;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease,color .16s ease}
.misepress__recipe-tool:hover{transform:translateY(-1px);border-color:var(--mp-action,var(--mp-accent,#E85D2A))!important;color:var(--mp-action,var(--mp-accent,#E85D2A))!important;box-shadow:0 16px 34px rgba(0,0,0,.075)}
.misepress__recipe-tool--pin{color:#bd081c!important}.misepress__recipe-tool--pin:hover{border-color:#bd081c!important;color:#bd081c!important}.misepress__recipe-tool-icon{display:block;width:18px;height:18px}.misepress__recipe-tool--collection.is-loading{opacity:.65;pointer-events:none}
.misepress__private-notes{max-width:760px;margin:var(--mp-single-section-gap,2rem) auto;border:1px solid var(--mp-border,#ececec);border-radius:22px;background:linear-gradient(180deg,var(--mp-surface,#fff),color-mix(in srgb,var(--mp-action,#E85D2A) 4%,var(--mp-surface,#fff)));box-shadow:0 16px 42px rgba(0,0,0,.055);padding:clamp(1rem,2.5vw,1.5rem)}
.misepress__private-notes-head{display:flex;gap:.9rem;align-items:flex-start;margin-bottom:.9rem}.misepress__private-notes-head>span{display:grid;place-items:center;width:42px;height:42px;border-radius:999px;background:var(--mp-action-soft,var(--mp-color-accent-soft,#fde7d3));color:var(--mp-action,var(--mp-accent,#E85D2A));font-weight:900}.misepress__private-notes .misepress__heading{margin:0}.misepress__private-note-input{width:100%;min-height:120px;border:1px solid var(--mp-border,#ececec);border-radius:16px;padding:1rem;background:var(--mp-bg,#fffdf8);color:var(--mp-fg,#111);font:inherit;resize:vertical}.misepress__private-note-actions{display:flex;align-items:center;gap:.8rem;flex-wrap:wrap;margin-top:.85rem}.misepress__private-note-status{color:var(--mp-muted,#666);font-size:.92rem}
.misepress__author-box{max-width:760px;margin:var(--mp-single-section-gap,2rem) auto;border:1px solid var(--mp-border,#ececec);border-radius:26px;background:var(--mp-surface,#fff);box-shadow:0 16px 42px rgba(0,0,0,.055);padding:clamp(1rem,2.5vw,1.5rem);display:flex;gap:1rem;align-items:center;text-align:left}.misepress__author-avatar img{border-radius:999px;box-shadow:0 10px 28px rgba(0,0,0,.08)}.misepress__author-kicker{font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;color:var(--mp-muted,#666);margin:0 0 .15rem}.misepress__author-content h2{margin:.1rem 0 .35rem;font-size:clamp(1.2rem,2.3vw,1.65rem)}.misepress__author-content p{margin:.35rem 0 .75rem;color:var(--mp-muted,#666)}.misepress__author-content a{font-weight:800}.misepress__author-box--card{max-width:360px;display:block;text-align:center;padding:2rem}.misepress__author-box--card .misepress__author-avatar{margin-bottom:1rem}.misepress__author-box--card .misepress__author-avatar img{width:96px;height:96px}.misepress__author-box--compact{max-width:720px;padding:.85rem 1rem;border-radius:999px}.misepress__author-box--compact .misepress__author-avatar img{width:48px;height:48px}.misepress__author-box--compact .misepress__author-kicker{display:none}.misepress__author-box--compact .misepress__author-content h2{font-size:1.05rem;margin:0}.misepress__author-box--compact .misepress__author-content{display:flex;align-items:center;gap:.9rem;flex-wrap:wrap}.misepress__author-box--horizontal{max-width:860px}
.misepress__author-archive-intro{display:flex;align-items:center;gap:.85rem;margin-top:.75rem;padding:.85rem 1rem;border:1px solid var(--mp-border,#ececec);border-radius:18px;background:var(--mp-surface,#fff);max-width:720px}.misepress__author-archive-intro img{border-radius:999px}.misepress__author-archive-intro p{margin:.1rem 0 .35rem;color:var(--mp-muted,#666)}.misepress__collection-card{border:1px solid var(--mp-border,#ececec);border-radius:18px;overflow:hidden;background:var(--mp-surface,#fff);box-shadow:0 10px 28px rgba(0,0,0,.045)}.misepress__collection-card a{display:block;color:inherit;text-decoration:none}.misepress__collection-card img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block}.misepress__collection-card strong{display:block;padding:.85rem 1rem}
@media(max-width:640px){.misepress__recipe-toolbar{display:grid;grid-template-columns:1fr 1fr}.misepress__recipe-tool{width:100%}.misepress__author-box,.misepress__author-box--horizontal{align-items:flex-start}.misepress__author-box--compact{border-radius:22px}.misepress__author-box--compact .misepress__author-content{display:block}.misepress__author-archive-intro{align-items:flex-start}}


/* 1.35.55 — Cook mode close alignment + notes index */
.misepress__cook-close{
  display:grid!important;
  place-items:center!important;
  padding:0!important;
  text-align:center!important;
  line-height:1!important;
  font-family:Arial,Helvetica,sans-serif!important;
  font-weight:500!important;
  box-sizing:border-box!important;
}
.misepress__private-notes-index{
  display:grid;
  gap:1rem;
}
.misepress__private-note-card{
  border:1px solid var(--mp-border,#ececec);
  border-radius:18px;
  background:var(--mp-surface,#fff);
  box-shadow:0 10px 28px rgba(0,0,0,.045);
  padding:1rem 1.15rem;
}
.misepress__private-note-title{
  display:inline-block;
  font-weight:900;
  color:var(--mp-fg,#111);
  text-decoration:none;
  margin-bottom:.4rem;
}
.misepress__private-note-title:hover{text-decoration:underline}
.misepress__private-note-card p{margin:.25rem 0 .75rem;color:var(--mp-muted,#666)}
.misepress__private-note-edit{font-weight:800;color:var(--mp-accent,#E85D2A)}


/* v1.35.56 — polished private notes */
.misepress__private-notes{
  width:min(100%, var(--mp-content-width, 920px));
  max-width:none;
  margin:var(--mp-single-section-gap,2.25rem) auto;
  padding:0;
  border:0;
  box-shadow:none;
  background:transparent;
}
.misepress__private-notes-card{
  position:relative;
  overflow:hidden;
  border:1px solid var(--mp-border,#e9e2dc);
  border-radius:24px;
  background:
    radial-gradient(circle at top left, color-mix(in srgb,var(--mp-accent,#E85D2A) 10%,transparent), transparent 34%),
    linear-gradient(180deg,var(--mp-surface,#fff), color-mix(in srgb,var(--mp-bg,#fff8ef) 85%,var(--mp-surface,#fff)));
  box-shadow:0 20px 58px rgba(18,18,18,.07);
  padding:clamp(1.25rem,3vw,2rem);
}
.misepress__private-notes-head{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:1rem;
  align-items:flex-start;
  margin:0 0 1rem;
}
.misepress__private-notes-icon,
.misepress__private-notes-head>span{
  display:grid;
  place-items:center;
  width:48px;
  height:48px;
  border-radius:16px;
  background:var(--mp-accent,#E85D2A);
  color:#fff;
  font-weight:900;
  box-shadow:0 12px 24px color-mix(in srgb,var(--mp-accent,#E85D2A) 28%,transparent);
}
.misepress__private-notes-title .misepress__eyebrow{
  margin:0 0 .25rem;
  color:var(--mp-accent,#E85D2A);
  font-size:.74rem;
  font-weight:850;
  letter-spacing:.14em;
  text-transform:uppercase;
}
.misepress__private-notes .misepress__heading{margin:0 0 .25rem;line-height:1.12}
.misepress__private-notes .misepress__muted{max-width:62ch;margin:0;color:var(--mp-muted,#666)}
.misepress__private-note-input{
  display:block;
  width:100%;
  min-height:160px;
  border:1px solid color-mix(in srgb,var(--mp-border,#e9e2dc) 82%,#000 8%);
  border-radius:18px;
  background:rgba(255,255,255,.78);
  color:var(--mp-fg,#111);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.7);
  padding:1rem 1.1rem;
  font:inherit;
  line-height:1.6;
  resize:vertical;
}
.misepress__private-note-input:focus{
  outline:2px solid color-mix(in srgb,var(--mp-accent,#E85D2A) 32%,transparent);
  border-color:var(--mp-accent,#E85D2A);
  background:#fff;
}
.misepress__private-note-actions{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  flex-wrap:wrap;
  margin-top:1rem;
}
.misepress__private-note-status{font-weight:750;color:var(--mp-muted,#666)}
.misepress__private-notes-index{
  width:min(100%, var(--mp-content-width, 1040px));
  margin:0 auto;
  display:grid;
  gap:1rem;
}
.misepress__private-notes-index>.misepress__heading{margin-bottom:.5rem}
.misepress__private-note-card{
  border:1px solid var(--mp-border,#ececec);
  border-radius:18px;
  background:var(--mp-surface,#fff);
  box-shadow:0 14px 34px rgba(0,0,0,.05);
  padding:1rem 1.1rem;
}
.misepress__private-note-title{font-size:1.05rem;font-weight:850;text-decoration:none;color:var(--mp-fg,#111)}
.misepress__private-note-card p{margin:.45rem 0 .85rem;color:var(--mp-muted,#666);line-height:1.55}
@media(max-width:640px){
  .misepress__private-notes-card{border-radius:20px;padding:1rem}
  .misepress__private-notes-head{grid-template-columns:1fr;gap:.75rem}
  .misepress__private-notes-icon,.misepress__private-notes-head>span{width:42px;height:42px;border-radius:14px}
  .misepress__private-note-actions{align-items:stretch}
  .misepress__private-note-actions .misepress__btn{width:100%;justify-content:center}
}

/* 1.35.58 — author box polish: integrated editorial byline instead of a floating random card */
.misepress__author-box{max-width:var(--mp-content-width,980px)!important;margin:var(--mp-single-section-gap,2rem) auto!important;border:1px solid var(--mp-border,#ececec)!important;border-radius:24px!important;background:linear-gradient(135deg,color-mix(in srgb,var(--mp-action,#E85D2A) 7%,#fff),var(--mp-surface,#fff) 45%,var(--mp-surface,#fff))!important;box-shadow:0 18px 50px rgba(17,17,17,.06)!important;padding:clamp(1rem,2.4vw,1.45rem)!important;display:grid!important;grid-template-columns:auto minmax(0,1fr) auto!important;gap:clamp(.9rem,2vw,1.4rem)!important;align-items:center!important;text-align:left!important;position:relative!important;overflow:hidden!important}.misepress__author-box:before{content:"";position:absolute;inset:0 auto 0 0;width:6px;background:var(--mp-action,#E85D2A)}.misepress__author-media{display:flex;align-items:center}.misepress__author-avatar{width:88px;height:88px;border-radius:999px;background:var(--mp-surface,#fff);display:grid;place-items:center;box-shadow:0 12px 32px rgba(0,0,0,.08);border:4px solid color-mix(in srgb,var(--mp-action,#E85D2A) 14%,#fff)}.misepress__author-avatar img{width:80px!important;height:80px!important;border-radius:999px!important;display:block!important;box-shadow:none!important}.misepress__author-kicker{font-size:.72rem!important;text-transform:uppercase!important;letter-spacing:.16em!important;color:var(--mp-action,#E85D2A)!important;font-weight:800!important;margin:0 0 .2rem!important}.misepress__author-name{margin:0!important;font-size:clamp(1.25rem,2.2vw,1.75rem)!important;line-height:1.05!important}.misepress__author-bio{margin:.45rem 0 0!important;color:var(--mp-muted,#666)!important;max-width:62ch!important}.misepress__author-meta{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;margin-top:.7rem;color:var(--mp-muted,#666);font-size:.9rem}.misepress__author-meta span{display:inline-flex;align-items:center;border:1px solid var(--mp-border,#ececec);background:rgba(255,255,255,.72);border-radius:999px;padding:.28rem .65rem}.misepress__author-meta a{font-weight:700}.misepress__author-actions{display:flex;justify-content:flex-end}.misepress__author-recipes-link{white-space:nowrap}.misepress__author-box--card{max-width:var(--mp-content-width,980px)!important;display:grid!important;text-align:left!important}.misepress__author-box--horizontal{max-width:var(--mp-content-width,980px)!important}.misepress__author-box--compact{max-width:var(--mp-content-width,980px)!important;border-radius:999px!important;padding:.85rem 1.1rem!important;grid-template-columns:auto minmax(0,1fr) auto!important}.misepress__author-box--compact .misepress__author-avatar{width:54px;height:54px;border-width:3px}.misepress__author-box--compact .misepress__author-avatar img{width:48px!important;height:48px!important}.misepress__author-box--compact .misepress__author-kicker,.misepress__author-box--compact .misepress__author-bio{display:none!important}.misepress__author-box--compact .misepress__author-meta{margin-top:.25rem}.misepress__author-box--compact .misepress__author-name{font-size:1.1rem!important}@media(max-width:760px){.misepress__author-box,.misepress__author-box--card,.misepress__author-box--horizontal,.misepress__author-box--compact{grid-template-columns:auto minmax(0,1fr)!important;border-radius:22px!important}.misepress__author-actions{grid-column:1 / -1;justify-content:stretch}.misepress__author-actions .misepress__btn{width:100%;justify-content:center}.misepress__author-avatar{width:68px;height:68px}.misepress__author-avatar img{width:60px!important;height:60px!important}}

/* 1.35.59 — under-ingredients placement polish */
.misepress__aside .misepress__private-notes,
.misepress__aside .misepress__author-box{
  max-width:100%!important;
  margin:1.25rem 0!important;
}
.misepress__aside .misepress__author-box,
.misepress__aside .misepress__author-box--card,
.misepress__aside .misepress__author-box--horizontal,
.misepress__aside .misepress__author-box--compact{
  display:grid!important;
  grid-template-columns:1fr!important;
  gap:.75rem!important;
  border-radius:20px!important;
  padding:1rem!important;
  text-align:left!important;
}
.misepress__aside .misepress__author-avatar{
  width:58px;height:58px;border-width:3px;
}
.misepress__aside .misepress__author-avatar img{
  width:52px!important;height:52px!important;
}
.misepress__aside .misepress__author-actions{justify-content:stretch!important;}
.misepress__aside .misepress__author-actions .misepress__btn{width:100%;justify-content:center;}
.misepress__aside .misepress__author-meta{gap:.4rem;}
.misepress__aside .misepress__author-bio{font-size:.95rem;}


/* 1.35.60 — before-ingredients placement and plain section style for author/notes */
.misepress__private-notes--plain,
.misepress__author-box--plain{
  max-width:var(--mp-content-width,980px)!important;
  margin:var(--mp-single-section-gap,2rem) auto!important;
  border:1px solid var(--mp-border,#ececec)!important;
  border-radius:var(--mp-radius-lg,18px)!important;
  background:var(--mp-surface,#fff)!important;
  box-shadow:none!important;
  padding:clamp(1rem,2.2vw,1.35rem)!important;
  overflow:visible!important;
}
.misepress__private-notes--plain .misepress__private-notes-card{
  border:0!important;
  background:transparent!important;
  box-shadow:none!important;
  padding:0!important;
}
.misepress__private-notes--plain .misepress__private-notes-icon,
.misepress__private-notes--plain .misepress__private-notes-head>span{
  display:none!important;
}
.misepress__private-notes--plain .misepress__private-notes-head{
  display:block!important;
  margin-bottom:.9rem!important;
}
.misepress__private-notes--plain .misepress__private-notes-title .misepress__eyebrow{
  color:var(--mp-muted,#666)!important;
}
.misepress__private-notes--plain .misepress__private-note-input{
  background:var(--mp-bg,#fffdf8)!important;
  box-shadow:none!important;
}
.misepress__author-box--plain{
  display:grid!important;
  grid-template-columns:auto minmax(0,1fr) auto!important;
  gap:1rem!important;
  align-items:center!important;
  text-align:left!important;
  background:var(--mp-surface,#fff)!important;
}
.misepress__author-box--plain:before{display:none!important;content:none!important;}
.misepress__author-box--plain .misepress__author-avatar{
  width:64px!important;
  height:64px!important;
  border:1px solid var(--mp-border,#ececec)!important;
  box-shadow:none!important;
  background:var(--mp-bg,#fffdf8)!important;
}
.misepress__author-box--plain .misepress__author-avatar img{
  width:58px!important;
  height:58px!important;
}
.misepress__author-box--plain .misepress__author-kicker{
  color:var(--mp-muted,#666)!important;
}
.misepress__author-box--plain .misepress__author-meta span{
  background:transparent!important;
}
.misepress__aside .misepress__private-notes--plain,
.misepress__aside .misepress__author-box--plain{
  max-width:100%!important;
  margin:1.25rem 0!important;
  padding:1rem!important;
}
@media(max-width:760px){
  .misepress__author-box--plain{grid-template-columns:auto minmax(0,1fr)!important;}
  .misepress__author-box--plain .misepress__author-actions{grid-column:1/-1;justify-content:stretch!important;}
  .misepress__author-box--plain .misepress__author-actions .misepress__btn{width:100%;justify-content:center;}
}


/* 1.35.61 — plain notes clipping fix + cleaner author/no-avatar support */
.misepress__private-notes--plain{overflow:visible!important;}
.misepress__private-notes--plain .misepress__private-notes-card{
  overflow:visible!important;
  border-radius:0!important;
  border:0!important;
  background:transparent!important;
  box-shadow:none!important;
  padding:0!important;
}
.misepress__private-notes--plain .misepress__private-notes-head{padding-left:0!important;overflow:visible!important;}
.misepress__private-notes--plain .misepress__private-notes-title{overflow:visible!important;}
.misepress__private-notes--plain .misepress__eyebrow,
.misepress__private-notes--plain .misepress__heading,
.misepress__private-notes--plain .misepress__muted{padding-left:0!important;margin-left:0!important;text-indent:0!important;}
.misepress__private-notes--plain .misepress__private-note-input{border-radius:var(--mp-radius,14px)!important;background:var(--mp-bg,#fffdf8)!important;}
.misepress__author-box:not(:has(.misepress__author-media)){
  grid-template-columns:minmax(0,1fr) auto!important;
}
.misepress__author-box--compact:not(:has(.misepress__author-media)){
  grid-template-columns:minmax(0,1fr) auto!important;
}
@media(max-width:760px){
  .misepress__author-box:not(:has(.misepress__author-media)){grid-template-columns:1fr!important;}
}


/* 1.35.62 — cleaner Pro settings labels + author box alignment without avatar/website */
.misepress__author-box--no-avatar{
  grid-template-columns:minmax(0,1fr) auto!important;
}
.misepress__author-box--no-avatar .misepress__author-content{
  min-width:0!important;
}
.misepress__author-box--no-avatar .misepress__author-bio{
  max-width:70ch!important;
}
.misepress__author-box--no-avatar.misepress__author-box--card,
.misepress__author-box--no-avatar.misepress__author-box--horizontal{
  align-items:start!important;
}
.misepress__author-box--no-avatar .misepress__author-actions{
  align-self:center!important;
}
.misepress__author-box--no-avatar .misepress__author-kicker{
  white-space:normal!important;
  word-break:normal!important;
  overflow-wrap:normal!important;
}
.misepress__author-box--no-avatar .misepress__author-recipes-link{
  white-space:normal!important;
  text-align:center!important;
}
.misepress__aside .misepress__author-box,
.misepress__aside .misepress__author-box--no-avatar,
.misepress__aside .misepress__author-box--card,
.misepress__aside .misepress__author-box--horizontal,
.misepress__aside .misepress__author-box--plain{
  display:block!important;
  text-align:left!important;
  max-width:100%!important;
  overflow:visible!important;
}
.misepress__aside .misepress__author-box .misepress__author-media{
  margin-bottom:.85rem!important;
}
.misepress__aside .misepress__author-box .misepress__author-content{
  min-width:0!important;
  width:100%!important;
}
.misepress__aside .misepress__author-box .misepress__author-kicker{
  white-space:normal!important;
  word-break:normal!important;
  overflow-wrap:normal!important;
  letter-spacing:.11em!important;
  line-height:1.35!important;
}
.misepress__aside .misepress__author-box .misepress__author-name{
  font-size:clamp(1.25rem,2.1vw,1.6rem)!important;
  word-break:normal!important;
  overflow-wrap:anywhere!important;
}
.misepress__aside .misepress__author-box .misepress__author-bio{
  max-width:100%!important;
  line-height:1.6!important;
}
.misepress__aside .misepress__author-box .misepress__author-meta{
  margin-top:.8rem!important;
}
.misepress__aside .misepress__author-box .misepress__author-actions{
  display:flex!important;
  justify-content:flex-start!important;
  margin-top:1rem!important;
}
.misepress__aside .misepress__author-box .misepress__author-actions .misepress__btn{
  width:100%!important;
  justify-content:center!important;
  white-space:normal!important;
  text-align:center!important;
}
@media(max-width:760px){
  .misepress__author-box--no-avatar{grid-template-columns:1fr!important;}
  .misepress__author-box--no-avatar .misepress__author-actions{justify-content:stretch!important;}
  .misepress__author-box--no-avatar .misepress__author-actions .misepress__btn{width:100%!important;}
}


/* v1.35.63 commercial polish: related recipes, reviews, actions, notes and author controls */
.misepress__related { border: 1px solid var(--mp-color-border,#e8e2d8); border-radius: 22px; padding: clamp(1rem,2vw,1.5rem); background: linear-gradient(180deg,#fff,rgba(255,247,238,.45)); box-shadow: 0 18px 50px rgba(20,16,12,.05); }
.misepress__related-head { display:flex; align-items:flex-end; justify-content:space-between; gap:1rem; margin-bottom:1rem; }
.misepress__related-head .misepress__eyebrow { margin:0; color:var(--mp-color-accent,#e85d2a); letter-spacing:.14em; text-transform:uppercase; font-weight:800; font-size:.72rem; }
.misepress__related-title { margin:.15rem 0 0 !important; font-size:clamp(1.55rem,3vw,2.15rem)!important; }
.misepress__related-item { position:relative; min-width:0; }
.misepress__related-reason { position:absolute; top:.75rem; left:.75rem; z-index:3; display:inline-flex; padding:.25rem .55rem; border-radius:999px; background:rgba(255,255,255,.92); color:var(--mp-color-accent,#e85d2a); font-size:.72rem; font-weight:750; box-shadow:0 8px 20px rgba(0,0,0,.08); }
.misepress__recipe-toolbar, .misepress__title-actions { gap:.55rem!important; align-items:center; flex-wrap:wrap; }
.misepress__recipe-tool, .misepress__print-btn, .misepress__shopping-btn, .misepress__save-btn--inline { border-radius:999px!important; min-height:42px; box-shadow:0 8px 24px rgba(0,0,0,.04); }
.misepress__private-note-actions { display:flex; align-items:center; flex-wrap:wrap; gap:.65rem; }
.misepress__private-note-status { color:var(--mp-color-muted,#666); font-size:.9rem; }
.misepress__private-notes-index-link { margin:.75rem 0 0; font-size:.9rem; }
.misepress__author-box { width:100%; max-width:980px; margin-inline:auto; display:grid; grid-template-columns:auto minmax(0,1fr) auto; align-items:center; gap:1rem; padding:1.25rem; border-radius:22px; border:1px solid var(--mp-color-border,#e8e2d8); background:#fff; box-shadow:0 18px 55px rgba(20,16,12,.05); }
.misepress__author-box--plain { box-shadow:none; border-radius:16px; background:transparent; border-color:var(--mp-color-border,#e8e2d8); }
.misepress__author-box--no-avatar { grid-template-columns:minmax(0,1fr) auto; }
.misepress__author-name { margin:.1rem 0; font-size:clamp(1.35rem,2.5vw,2rem); }
.misepress__author-bio { margin:.35rem 0 0; color:var(--mp-color-muted,#666); max-width:62ch; }
.misepress__author-meta { display:flex; flex-wrap:wrap; gap:.55rem .9rem; align-items:center; margin-top:.6rem; color:var(--mp-color-muted,#666); }
.misepress__author-recipes-link { justify-self:end; white-space:normal!important; text-align:center; }
@media (max-width:720px){ .misepress__author-box,.misepress__author-box--no-avatar{grid-template-columns:1fr;text-align:left}.misepress__author-recipes-link{justify-self:start}.misepress__related-head{display:block} }
.misepress__reviews { border:1px solid var(--mp-color-border,#e8e2d8); border-radius:22px; background:#fff; box-shadow:0 18px 55px rgba(20,16,12,.05); }
.misepress__reviews:before { content:'Reader rating'; display:block; color:var(--mp-color-accent,#e85d2a); font-weight:800; letter-spacing:.13em; text-transform:uppercase; font-size:.72rem; margin-bottom:.5rem; }
.misepress__reviews-form textarea { min-height:110px; border-radius:14px; }
.misepress__reviews-form button, [data-mp-review-form] button { border-radius:999px!important; }
/* MisePress v1.35.68 commercial polish: affiliate equipment cards + roundups */
.misepress__equipment-item--product{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.8rem;border:1px solid var(--mp-color-border,#ececec);background:var(--mp-color-bg,#fff);padding:.8rem;border-radius:14px;box-shadow:0 6px 18px rgba(15,17,21,.05)}
.misepress__equipment-thumb{width:64px;height:64px;border-radius:12px;overflow:hidden;background:color-mix(in srgb,var(--mp-color-accent-soft,#fde7d3) 45%,#fff)}
.misepress__equipment-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.misepress__equipment-body{min-width:0}.misepress__equipment-price{display:block;margin-top:.25rem;font-weight:700;color:var(--mp-color-accent,#E85D2A)}
.misepress__equipment-button{display:inline-flex;align-items:center;justify-content:center;padding:.55rem .75rem;border-radius:999px;background:var(--mp-color-accent,#E85D2A);color:#fff!important;text-decoration:none;font-weight:700;white-space:nowrap}
.misepress__roundup{margin:var(--mp-single-section-gap,2rem) 0}.misepress__roundup-grid{--mp-grid-min:230px}
@media(max-width:720px){.misepress__equipment-item--product{grid-template-columns:56px 1fr}.misepress__equipment-button{grid-column:1/-1;width:100%}}

/* MisePress hard-scope safety: frontend rules target MisePress component wrappers only. */
/* MisePress 1.35.92 empty-state polish */
.misepress .misepress__empty-state,
.misepress__empty-state {
	padding: clamp(2rem, 5vw, 3.5rem) clamp(1rem, 4vw, 2rem);
	text-align: center;
	border: 1px dashed var(--mp-color-border, #e5e5e5);
	border-radius: calc(var(--mp-radius, 16px) + 4px);
	background: color-mix(in srgb, var(--mp-color-surface, #fff) 92%, var(--mp-color-accent, #a85236) 4%);
	color: var(--mp-color-text, #1f1a17);
}
.misepress .misepress__empty-icon,
.misepress__empty-icon {
	width: 3.25rem;
	height: 3.25rem;
	margin: 0 auto 1rem;
	border-radius: 999px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: color-mix(in srgb, var(--mp-color-accent, #a85236) 12%, transparent);
	color: var(--mp-color-accent, #a85236);
	font-size: 1.35rem;
}
.misepress .misepress__empty-state h2,
.misepress .misepress__empty-state h3,
.misepress__empty-state h2,
.misepress__empty-state h3 { margin: 0 0 .55rem; color: var(--mp-color-heading, var(--mp-color-text, #1f1a17)); }
.misepress .misepress__empty-state p,
.misepress__empty-state p { max-width: 42rem; margin: 0 auto 1.25rem; color: var(--mp-color-muted, #6b6b6b); }
.misepress .misepress__empty-state .misepress__btn,
.misepress__empty-state .misepress__btn { margin-top: .25rem; }

.misepress__archive-shortcode .misepress__grid--shortcode{
	display:grid;
	grid-template-columns:repeat(var(--mp-archive-shortcode-cols,3),minmax(0,1fr));
	gap:var(--mp-grid-gap,1.5rem);
}
@media (max-width: 768px){
	.misepress__archive-shortcode .misepress__grid--shortcode{grid-template-columns:1fr;}
}

/* v1.35.97 shortcode polish: make standalone search/slider/category/feed blocks match the archive UI. */
.misepress__smart-search-wrap{max-width:var(--mp-content-width,1140px);margin-inline:auto}
.misepress__smart-search{display:flex;align-items:stretch;gap:.75rem;flex-wrap:wrap;margin:0 0 var(--mp-s-4,1.25rem)}
.misepress__smart-search .misepress__search-input{position:relative;flex:1 1 280px;min-width:min(100%,280px)}
.misepress__smart-search .misepress__search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:var(--mp-color-muted,#777);pointer-events:none}
.misepress__smart-search input[type="search"]{width:100%;min-height:48px;border:1px solid var(--mp-color-border,#ddd);border-radius:var(--mp-radius,14px);background:var(--mp-color-surface,#fff);color:var(--mp-color-fg,#161616);padding:.75rem 1rem .75rem 2.75rem;font:inherit;box-shadow:var(--mp-shadow-xs,0 1px 2px rgba(0,0,0,.04))}
.misepress__smart-search input[type="search"]:focus{outline:2px solid color-mix(in srgb,var(--mp-color-accent,#E85D2A) 35%,transparent);outline-offset:2px;border-color:var(--mp-color-accent,#E85D2A)}
.misepress__smart-search .misepress__btn{min-height:48px;border-radius:var(--mp-radius,14px);padding:.75rem 1.2rem}
@media(max-width:640px){.misepress__smart-search{display:grid}.misepress__smart-search .misepress__btn{width:100%;justify-content:center}}

.misepress-slider{background:var(--mp-color-surface,#fff);border:1px solid var(--mp-color-border,#e7ded2);box-shadow:var(--mp-shadow-sm,0 12px 30px rgba(0,0,0,.06))}
.misepress-slider__track{list-style:none!important;padding:0!important;margin:0!important}
.misepress-slider__slide{list-style:none!important;margin:0!important}
.misepress-slider__meta{list-style:none!important;padding:0!important}
.misepress-slider__meta li{list-style:none!important;margin:0!important}

.misepress-cat-grid__list{list-style:none!important;padding:0!important;margin:0!important}
.misepress-cat-grid__item{list-style:none!important;margin:0!important}
.misepress-cat-grid__link{min-height:100%}

.mp-feed-inline{border:1px solid var(--mp-color-border,#e7ded2);border-radius:var(--mp-radius-lg,20px);background:var(--mp-color-surface,#fffdf8);padding:clamp(1rem,2.5vw,1.5rem);box-shadow:var(--mp-shadow-sm,0 12px 30px rgba(0,0,0,.05));max-width:var(--mp-content-width,1140px);margin-inline:auto}
.mp-feed-inline__head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin:0 0 1rem;padding:0 0 .9rem;border-bottom:1px solid var(--mp-color-border,#eee3d8)}
.mp-feed-inline__heading{margin:0;font-family:var(--mp-font-display,serif);font-size:clamp(1.35rem,2.4vw,2rem);line-height:1.1;color:var(--mp-color-fg,#161616)}
.mp-feed-inline__list{list-style:none!important;padding:0!important;margin:0!important;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}
.mp-feed-inline__item{list-style:none!important;margin:0!important}
.mp-feed-inline__link{border:1px solid var(--mp-color-border,#eee3d8);background:var(--mp-color-bg,#fff);border-radius:var(--mp-radius,14px);padding:.85rem;min-height:86px}
.mp-feed-inline__empty{border-style:solid;background:linear-gradient(180deg,var(--mp-color-surface,#fff) 0%,var(--mp-color-bg,#fff8ee) 100%)}


/* Launch polish: standalone smart search, shortcode slider, and category blocks */
.misepress__smart-search-wrap--polished {
  --mp-smart-search-bg: color-mix(in srgb, var(--mp-color-bg, #fffdf8) 88%, #fff 12%);
  max-width: min(920px, 100%);
  margin: var(--mp-s-5, 1.5rem) auto;
}
.misepress__smart-search-wrap--polished .misepress__smart-search {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: .75rem;
  align-items: stretch;
  padding: .65rem;
  border: 1px solid color-mix(in srgb, var(--mp-color-accent, #a94f34) 22%, var(--mp-color-border, #e7d9d0));
  border-radius: 999px;
  background: var(--mp-smart-search-bg);
  box-shadow: 0 18px 45px rgba(24, 16, 11, .08);
}
.misepress__smart-search-wrap--polished .misepress__search-input {
  position: relative;
  display: flex;
  align-items: center;
  min-height: 54px;
  border-radius: 999px;
  background: #fff;
  border: 1px solid var(--mp-color-border, #e7d9d0);
  overflow: hidden;
}
.misepress__smart-search-wrap--polished .misepress__search-icon {
  margin-inline-start: 1.1rem;
  color: var(--mp-color-accent, #a94f34);
  flex: 0 0 auto;
}
.misepress__smart-search-wrap--polished input[type="search"] {
  width: 100%;
  min-height: 54px;
  border: 0 !important;
  outline: 0;
  box-shadow: none !important;
  background: transparent !important;
  padding: 0 1rem;
  color: var(--mp-color-fg, #1e1713);
  font-size: clamp(1rem, 1.7vw, 1.12rem);
}
.misepress__smart-search-wrap--polished input[type="search"]::placeholder { color: var(--mp-color-muted, #81746b); opacity: .85; }
.misepress__smart-search-submit {
  min-height: 54px;
  padding-inline: 1.45rem;
  border-radius: 999px !important;
  white-space: nowrap;
}
@media (max-width: 640px) {
  .misepress__smart-search-wrap--polished .misepress__smart-search { grid-template-columns: 1fr; border-radius: var(--mp-radius-lg, 22px); }
  .misepress__smart-search-submit { width: 100%; justify-content: center; }
}

.misepress-slider {
  background: var(--mp-color-bg, #fffdf8);
  border: 1px solid var(--mp-color-border, #e7d9d0);
  border-radius: var(--mp-radius-lg, 22px);
  box-shadow: 0 18px 45px rgba(24, 16, 11, .08);
  isolation: isolate;
}
.misepress-slider__viewport { width: 100%; }
.misepress-slider__track { width: 100%; will-change: transform; }
.misepress-slider__slide { list-style: none; }
.misepress-slider__link:focus-visible { outline: 3px solid color-mix(in srgb, var(--mp-color-accent, #a94f34) 55%, transparent); outline-offset: -3px; border-radius: inherit; }
.misepress-slider__body { background: linear-gradient(180deg, color-mix(in srgb, var(--mp-color-bg, #fffdf8) 92%, #fff 8%), var(--mp-color-bg, #fffdf8)); }
.misepress-slider__nav { display: grid; place-items: center; border: 1px solid rgba(0,0,0,.08); }
.misepress-slider__dots { padding: .35rem .5rem; border-radius: 999px; background: rgba(255,255,255,.7); backdrop-filter: blur(8px); }
@supports not (color: color-mix(in srgb, white, black)) {
  .misepress-slider__media { background-color: #f6eee8; }
  .misepress__smart-search-wrap--polished .misepress__smart-search { border-color: #e7d9d0; }
}
@media (max-width: 720px) {
  .misepress-slider__media, .misepress-slider--hero .misepress-slider__media, .misepress-slider--editorial .misepress-slider__media { aspect-ratio: 4/3; }
  .misepress-slider--hero .misepress-slider__body { padding: 1.25rem; }
  .misepress-slider__nav { width: 36px; height: 36px; }
}

.misepress-cat-grid__link {
  border: 1px solid var(--mp-color-border, #e7d9d0);
  background: var(--mp-color-bg, #fffdf8);
}
.misepress-cat-grid__name { color: var(--mp-color-fg, #1e1713); }
.misepress-cat-grid__count { display: inline-flex; align-items: center; justify-content: center; min-width: 1.75rem; min-height: 1.75rem; padding: 0 .5rem; border-radius: 999px; background: color-mix(in srgb, var(--mp-color-accent, #a94f34) 10%, #fff); color: var(--mp-color-accent, #a94f34); font-weight: 700; }


/* Launch polish: standalone Bricks/PHP shortcode embeds */
.misepress.misepress__smart-search-wrap {
  width: min(100%, 980px);
  margin-inline: auto;
}
.misepress .misepress__smart-search {
  display: grid !important;
  grid-template-columns: minmax(220px, 1fr) auto;
  align-items: stretch;
  gap: 14px;
  width: 100%;
}
.misepress .misepress__search-input {
  position: relative;
  display: flex;
  align-items: center;
  min-height: 58px;
  border: 1px solid var(--mp-color-border, #e4d6ca);
  border-radius: 999px;
  background: var(--mp-color-bg, #fffdf8);
  box-shadow: 0 14px 38px rgba(47,36,31,.08);
  overflow: hidden;
}
.misepress .misepress__search-icon {
  flex: 0 0 auto;
  margin-left: 22px;
  color: var(--mp-color-muted, #7b6b61);
}
.misepress .misepress__search-input input[type=search] {
  width: 100%;
  min-height: 58px;
  padding: 0 22px 0 12px;
  border: 0 !important;
  outline: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  color: var(--mp-color-fg, #241b16);
  font: inherit;
  font-size: 18px;
}
.misepress .misepress__search-input input[type=search]::placeholder {
  color: color-mix(in srgb, var(--mp-color-muted, #7b6b61) 72%, transparent);
}
.misepress .misepress__smart-search-submit {
  min-height: 58px;
  padding-inline: 30px;
  border-radius: 999px !important;
  border: 1px solid var(--mp-color-accent, #a94f34) !important;
  background: var(--mp-color-accent, #a94f34) !important;
  color: #fff !important;
  font-weight: 800;
  box-shadow: 0 14px 34px rgba(169,79,52,.18);
}
.misepress .misepress__smart-search-results {
  margin-top: 22px;
}
.misepress .misepress__smart-search-results:empty {
  display: none;
}
.misepress .misepress__smart-search-results .misepress__grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 18px;
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}
.misepress .misepress__smart-search-results ul,
.misepress .misepress__smart-search-results ol,
.misepress .misepress__smart-search-results li {
  list-style: none !important;
}
.misepress .misepress__smart-search-results li::marker { content: ''; }
.misepress.misepress-slider {
  display: block;
  width: min(100%, 1180px);
  margin-inline: auto;
  border: 1px solid var(--mp-color-border, #e4d6ca);
  background: var(--mp-color-bg, #fffdf8);
  box-shadow: 0 18px 48px rgba(47,36,31,.10);
}
.misepress-slider__track {
  display: flex !important;
  flex-wrap: nowrap !important;
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}
.misepress-slider__slide {
  flex: 0 0 100% !important;
  width: 100% !important;
  min-width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}
.misepress-slider__slide::marker { content: ''; }
@media (max-width: 720px) {
  .misepress .misepress__smart-search { grid-template-columns: 1fr; }
  .misepress .misepress__smart-search-submit { width: 100%; }
}

/* Launch polish: submit recipe shortcode should look like the rest of MisePress even inside Bricks/PHP code blocks. */
.misepress__submit-intro,
.misepress__submit-recipe,
.misepress__submit-recipe--login,
.misepress__submit-recipe--off {
	--mp-submit-bg: var(--mp-color-bg, #fffdf8);
	--mp-submit-surface: var(--mp-card-bg, #fff);
	--mp-submit-fg: var(--mp-color-fg, #241a16);
	--mp-submit-muted: var(--mp-color-muted, #6f625a);
	--mp-submit-border: var(--mp-color-border, #eaded3);
	--mp-submit-accent: var(--mp-color-accent, #a55238);
	--mp-submit-accent-contrast: var(--mp-color-accent-contrast, #fffdf8);
	--mp-submit-radius: var(--mp-radius-lg, 22px);
	font-family: var(--mp-font-body, inherit);
	color: var(--mp-submit-fg);
}

.misepress__submit-intro {
	max-width: 920px;
	margin: 0 auto 1rem;
	padding: 1.1rem 1.25rem;
	border: 1px solid var(--mp-submit-border);
	border-radius: var(--mp-submit-radius);
	background: color-mix(in srgb, var(--mp-submit-accent) 7%, var(--mp-submit-surface));
	color: var(--mp-submit-muted);
	line-height: 1.65;
}

.misepress__submit-recipe {
	display: grid;
	gap: 1.15rem;
	width: min(100%, 920px);
	max-width: 920px;
	margin: 0 auto;
	padding: clamp(1.25rem, 3vw, 2.25rem);
	border: 1px solid var(--mp-submit-border);
	border-radius: var(--mp-submit-radius);
	background: var(--mp-submit-surface);
	box-shadow: var(--mp-shadow, 0 18px 55px rgba(47, 36, 31, .08));
}

.misepress__submit-recipe::before {
	content: "Submit your recipe";
	font-family: var(--mp-font-display, "Playfair Display", Georgia, serif);
	font-size: clamp(1.75rem, 4vw, 2.8rem);
	font-weight: 700;
	line-height: 1.05;
	letter-spacing: -.02em;
	color: var(--mp-submit-fg);
}

.misepress__submit-recipe .misepress__field {
	display: grid;
	gap: .45rem;
	min-width: 0;
}

.misepress__submit-recipe .misepress__field label {
	font-size: .88rem;
	font-weight: 800;
	letter-spacing: .01em;
	color: var(--mp-submit-fg);
}

.misepress__submit-recipe input[type="text"],
.misepress__submit-recipe input[type="url"],
.misepress__submit-recipe input[type="email"],
.misepress__submit-recipe input[type="number"],
.misepress__submit-recipe input[type="file"],
.misepress__submit-recipe textarea,
.misepress__submit-recipe select {
	width: 100%;
	min-height: 48px;
	padding: .75rem .9rem;
	border: 1px solid var(--mp-submit-border);
	border-radius: var(--mp-radius-md, 14px);
	background: color-mix(in srgb, var(--mp-submit-bg) 72%, #fff);
	color: var(--mp-submit-fg);
	font: inherit;
	line-height: 1.4;
	box-shadow: none;
	transition: border-color .18s ease, box-shadow .18s ease, background .18s ease;
}

.misepress__submit-recipe input[type="file"] { padding: .65rem .75rem; }
.misepress__submit-recipe textarea { resize: vertical; min-height: 120px; }

.misepress__submit-recipe input:focus,
.misepress__submit-recipe textarea:focus,
.misepress__submit-recipe select:focus {
	outline: none;
	border-color: var(--mp-submit-accent);
	background: #fff;
	box-shadow: 0 0 0 4px color-mix(in srgb, var(--mp-submit-accent) 16%, transparent);
}

.misepress__submit-recipe .misepress__row {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 1rem;
}

.misepress__submit-recipe--two-column {
	grid-template-columns: repeat(2, minmax(0, 1fr));
	column-gap: 1.25rem;
}

.misepress__submit-recipe--two-column::before,
.misepress__submit-recipe--two-column .misepress__row,
.misepress__submit-recipe--two-column .misepress__field--actions,
.misepress__submit-recipe--two-column .misepress__submit-help {
	grid-column: 1 / -1;
}

.misepress__submit-recipe--compact {
	max-width: 680px;
	padding: 1.25rem;
	gap: .8rem;
}

.misepress__submit-recipe--compact::before { font-size: 1.7rem; }

.misepress__submit-recipe .misepress__field--actions {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: .9rem;
	padding-top: .5rem;
}

.misepress__submit-recipe .misepress__btn,
.misepress__submit-recipe button[type="submit"] {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 50px;
	padding: 0 1.25rem;
	border: 1px solid var(--mp-submit-accent);
	border-radius: 999px;
	background: var(--mp-submit-accent);
	color: var(--mp-submit-accent-contrast);
	font-weight: 900;
	line-height: 1;
	text-decoration: none;
	cursor: pointer;
	transition: transform .18s ease, opacity .18s ease, filter .18s ease;
}

.misepress__submit-recipe .misepress__btn:hover,
.misepress__submit-recipe button[type="submit"]:hover {
	filter: brightness(.96);
	transform: translateY(-1px);
}

.misepress__submit-recipe button[disabled] {
	opacity: .62;
	cursor: progress;
	transform: none;
}

.misepress__submit-status {
	color: var(--mp-submit-muted);
	font-size: .92rem;
	font-weight: 700;
}

.misepress__submit-help {
	margin: 0;
	padding-top: .25rem;
	color: var(--mp-submit-muted);
	font-size: .92rem;
	line-height: 1.55;
}

.misepress__submit-success,
.misepress__submit-recipe--login,
.misepress__submit-recipe--off {
	width: min(100%, 720px);
	max-width: 720px;
	margin: 0 auto;
	padding: 1.25rem 1.4rem;
	border-radius: var(--mp-submit-radius);
	border: 1px solid var(--mp-submit-border);
	background: var(--mp-submit-surface);
	box-shadow: var(--mp-shadow, 0 14px 42px rgba(47, 36, 31, .07));
}

.misepress__submit-success {
	border-color: color-mix(in srgb, #1a7f37 32%, var(--mp-submit-border));
	background: color-mix(in srgb, #1a7f37 8%, var(--mp-submit-surface));
	color: #166534;
}

@media (max-width: 700px) {
	.misepress__submit-recipe,
	.misepress__submit-recipe--two-column,
	.misepress__submit-recipe .misepress__row {
		grid-template-columns: 1fr;
	}
	.misepress__submit-recipe { padding: 1.15rem; }
	.misepress__submit-recipe .misepress__field--actions { align-items: stretch; }
	.misepress__submit-recipe .misepress__btn,
	.misepress__submit-recipe button[type="submit"] { width: 100%; }
}


/* v1.36.02 — Smart search visual hardening for Bricks/frontend embeds.
   Keeps the icon inside the input, removes theme bullets from AJAX results,
   and gives the shortcode a polished standalone layout. */
.misepress.misepress__smart-search-wrap,
.misepress__smart-search-wrap.misepress {
  width: min(100%, 920px) !important;
  max-width: 920px !important;
  margin: clamp(1.25rem, 3vw, 2.25rem) auto !important;
  padding: 0 !important;
  color: var(--mp-color-fg, #241b16);
}
.misepress.misepress__smart-search-wrap .misepress__smart-search,
.misepress__smart-search-wrap.misepress .misepress__smart-search {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: .85rem !important;
  width: 100% !important;
  margin: 0 !important;
  padding: .55rem !important;
  border: 1px solid var(--mp-color-border, #e7d9d0) !important;
  border-radius: 999px !important;
  background: color-mix(in srgb, var(--mp-color-surface, #fffdf8) 94%, #fff 6%) !important;
  box-shadow: 0 18px 45px rgba(47, 36, 31, .08) !important;
}
.misepress.misepress__smart-search-wrap .misepress__search-input,
.misepress__smart-search-wrap.misepress .misepress__search-input {
  position: relative !important;
  display: block !important;
  flex: 1 1 auto !important;
  min-width: 220px !important;
  min-height: 58px !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: #fff !important;
  box-shadow: inset 0 0 0 1px rgba(47, 36, 31, .10) !important;
  overflow: hidden !important;
}
.misepress.misepress__smart-search-wrap .misepress__search-icon,
.misepress__smart-search-wrap.misepress .misepress__search-icon {
  position: absolute !important;
  left: 1.3rem !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 18px !important;
  height: 18px !important;
  margin: 0 !important;
  padding: 0 !important;
  color: var(--mp-color-accent, #a85236) !important;
  opacity: .9 !important;
  pointer-events: none !important;
  z-index: 2 !important;
}
.misepress.misepress__smart-search-wrap input[type="search"],
.misepress__smart-search-wrap.misepress input[type="search"],
.misepress.misepress__smart-search-wrap .misepress__search-input input[type="search"],
.misepress__smart-search-wrap.misepress .misepress__search-input input[type="search"] {
  display: block !important;
  width: 100% !important;
  min-height: 58px !important;
  height: 58px !important;
  margin: 0 !important;
  padding: 0 1.25rem 0 3.55rem !important;
  border: 0 !important;
  border-radius: 999px !important;
  outline: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  color: var(--mp-color-fg, #241b16) !important;
  font-family: var(--mp-font-body, inherit) !important;
  font-size: clamp(1rem, 1.55vw, 1.12rem) !important;
  line-height: 58px !important;
  text-align: left !important;
  -webkit-appearance: none !important;
  appearance: none !important;
}
.misepress.misepress__smart-search-wrap input[type="search"]::placeholder,
.misepress__smart-search-wrap.misepress input[type="search"]::placeholder {
  color: color-mix(in srgb, var(--mp-color-muted, #7b6b61) 76%, transparent) !important;
  opacity: 1 !important;
}
.misepress.misepress__smart-search-wrap input[type="search"]:focus,
.misepress__smart-search-wrap.misepress input[type="search"]:focus {
  outline: 0 !important;
}
.misepress.misepress__smart-search-wrap .misepress__search-input:focus-within,
.misepress__smart-search-wrap.misepress .misepress__search-input:focus-within {
  box-shadow: inset 0 0 0 2px var(--mp-color-accent, #a85236), 0 0 0 4px color-mix(in srgb, var(--mp-color-accent, #a85236) 16%, transparent) !important;
}
.misepress.misepress__smart-search-wrap .misepress__smart-search-submit,
.misepress__smart-search-wrap.misepress .misepress__smart-search-submit {
  flex: 0 0 auto !important;
  min-height: 58px !important;
  height: 58px !important;
  margin: 0 !important;
  padding: 0 2rem !important;
  border: 1px solid var(--mp-color-accent, #a85236) !important;
  border-radius: 999px !important;
  background: var(--mp-color-accent, #a85236) !important;
  color: #fff !important;
  font-weight: 800 !important;
  line-height: 1 !important;
  text-decoration: none !important;
  box-shadow: 0 14px 34px rgba(168, 82, 54, .20) !important;
  cursor: pointer !important;
}
.misepress.misepress__smart-search-wrap .misepress__smart-search-submit:hover,
.misepress__smart-search-wrap.misepress .misepress__smart-search-submit:hover {
  filter: brightness(.94) !important;
  transform: translateY(-1px);
}
.misepress.misepress__smart-search-wrap .misepress__smart-search-results,
.misepress__smart-search-wrap.misepress .misepress__smart-search-results {
  margin-top: 1.1rem !important;
}
.misepress.misepress__smart-search-wrap .misepress__smart-search-results ul,
.misepress.misepress__smart-search-wrap .misepress__smart-search-results ol,
.misepress.misepress__smart-search-wrap .misepress__smart-search-results li,
.misepress__smart-search-wrap.misepress .misepress__smart-search-results ul,
.misepress__smart-search-wrap.misepress .misepress__smart-search-results ol,
.misepress__smart-search-wrap.misepress .misepress__smart-search-results li {
  list-style: none !important;
  padding-left: 0 !important;
  margin-left: 0 !important;
}
.misepress.misepress__smart-search-wrap .misepress__smart-search-results li::marker,
.misepress__smart-search-wrap.misepress .misepress__smart-search-results li::marker { content: '' !important; }
@media (max-width: 700px) {
  .misepress.misepress__smart-search-wrap .misepress__smart-search,
  .misepress__smart-search-wrap.misepress .misepress__smart-search {
    display: grid !important;
    grid-template-columns: 1fr !important;
    border-radius: 24px !important;
    padding: .65rem !important;
  }
  .misepress.misepress__smart-search-wrap .misepress__smart-search-submit,
  .misepress__smart-search-wrap.misepress .misepress__smart-search-submit {
    width: 100% !important;
  }
}
@supports not (color: color-mix(in srgb, white, black)) {
  .misepress.misepress__smart-search-wrap .misepress__smart-search,
  .misepress__smart-search-wrap.misepress .misepress__smart-search { background: #fffdf8 !important; }
  .misepress.misepress__smart-search-wrap input[type="search"]::placeholder,
  .misepress__smart-search-wrap.misepress input[type="search"]::placeholder { color: #8b7d73 !important; }
}

/* v1.36.03 — Archive sidebar search visual parity.
   Match the standalone smart search input inside archive filters and protect it from theme/ACSS overrides. */
.misepress .misepress__filters .misepress__filter-group > .misepress__search-input {
  position: relative !important;
  display: block !important;
  width: 100% !important;
  min-height: 56px !important;
  margin: .45rem 0 0 !important;
  padding: 0 !important;
  border: 1px solid var(--mp-color-border, #e7d9d0) !important;
  border-radius: 999px !important;
  background: var(--mp-color-surface, #fffdf8) !important;
  box-shadow: 0 10px 26px rgba(47, 36, 31, .06), inset 0 0 0 1px rgba(47, 36, 31, .035) !important;
  overflow: hidden !important;
}
.misepress .misepress__filters .misepress__filter-group > .misepress__search-input .misepress__search-icon {
  position: absolute !important;
  left: 1.15rem !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 17px !important;
  height: 17px !important;
  margin: 0 !important;
  padding: 0 !important;
  color: var(--mp-color-accent, #a85236) !important;
  opacity: .85 !important;
  pointer-events: none !important;
  z-index: 2 !important;
}
.misepress .misepress__filters .misepress__filter-group > .misepress__search-input input[type="search"] {
  display: block !important;
  width: 100% !important;
  min-height: 56px !important;
  height: 56px !important;
  margin: 0 !important;
  padding: 0 1rem 0 3.25rem !important;
  border: 0 !important;
  border-radius: 999px !important;
  outline: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  color: var(--mp-color-fg, #241b16) !important;
  font-family: var(--mp-font-body, inherit) !important;
  font-size: .98rem !important;
  line-height: 56px !important;
  text-align: left !important;
  -webkit-appearance: none !important;
  appearance: none !important;
}
.misepress .misepress__filters .misepress__filter-group > .misepress__search-input input[type="search"]::placeholder {
  color: color-mix(in srgb, var(--mp-color-muted, #7b6b61) 72%, transparent) !important;
  opacity: 1 !important;
}
.misepress .misepress__filters .misepress__filter-group > .misepress__search-input:focus-within {
  border-color: var(--mp-color-accent, #a85236) !important;
  box-shadow: inset 0 0 0 1px var(--mp-color-accent, #a85236), 0 0 0 4px color-mix(in srgb, var(--mp-color-accent, #a85236) 14%, transparent) !important;
}
.misepress .misepress__filters .misepress__filter-label[for="mp_q"] {
  display: block !important;
  margin-bottom: .35rem !important;
  color: var(--mp-color-muted, #6f625a) !important;
  font-size: .74rem !important;
  font-weight: 800 !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
}

/* MisePress v1.36.04 — shortcode grid/feed hardening for real frontend rendering. */
.misepress.misepress-cat-grid,
.misepress .misepress-cat-grid,
.misepress.mp-feed-inline{
  box-sizing:border-box;
  width:100%;
  max-width:100%;
  clear:both;
}
.misepress.misepress-cat-grid *,
.misepress .misepress-cat-grid *,
.misepress.mp-feed-inline *,
.misepress.mp-feed-inline *::before,
.misepress.mp-feed-inline *::after{
  box-sizing:border-box;
}
.misepress.misepress-cat-grid .misepress-cat-grid__list,
.misepress .misepress-cat-grid .misepress-cat-grid__list{
  list-style:none!important;
  margin:0!important;
  padding:0!important;
  display:grid!important;
  grid-template-columns:repeat(var(--mp-cat-cols,4),minmax(0,1fr))!important;
  gap:clamp(16px,2vw,24px)!important;
  align-items:stretch!important;
  width:100%!important;
}
.misepress.misepress-cat-grid .misepress-cat-grid__item,
.misepress .misepress-cat-grid .misepress-cat-grid__item{
  list-style:none!important;
  margin:0!important;
  padding:0!important;
  position:relative!important;
  min-width:0!important;
  width:auto!important;
  height:auto!important;
  transform:none!important;
  float:none!important;
  clear:none!important;
}
.misepress.misepress-cat-grid .misepress-cat-grid__item::marker,
.misepress .misepress-cat-grid .misepress-cat-grid__item::marker,
.misepress.mp-feed-inline li::marker{content:""!important;font-size:0!important;}
.misepress.misepress-cat-grid .misepress-cat-grid__link,
.misepress .misepress-cat-grid .misepress-cat-grid__link{
  position:relative!important;
  display:flex!important;
  flex-direction:column!important;
  min-height:100%!important;
  height:100%!important;
  width:100%!important;
  overflow:hidden!important;
  text-decoration:none!important;
  color:inherit!important;
  background:var(--mp-color-surface,#fffdf8)!important;
  border:1px solid var(--mp-color-border,#eaded1)!important;
  border-radius:var(--mp-radius-lg,20px)!important;
  box-shadow:var(--mp-shadow-sm,0 10px 28px rgba(37,29,23,.06))!important;
}
.misepress.misepress-cat-grid:not(.misepress-cat-grid--tiles) .misepress-cat-grid__media,
.misepress .misepress-cat-grid:not(.misepress-cat-grid--tiles) .misepress-cat-grid__media{
  position:relative!important;
  inset:auto!important;
  width:100%!important;
  aspect-ratio:16/10!important;
  min-height:0!important;
  overflow:hidden!important;
  display:block!important;
  background:var(--mp-color-bg,#fff8ee)!important;
}
.misepress.misepress-cat-grid .misepress-cat-grid__media img,
.misepress .misepress-cat-grid .misepress-cat-grid__media img{
  width:100%!important;
  height:100%!important;
  max-width:none!important;
  display:block!important;
  object-fit:cover!important;
  position:static!important;
  transform:none;
}
.misepress.misepress-cat-grid .misepress-cat-grid__body,
.misepress .misepress-cat-grid .misepress-cat-grid__body{
  position:relative!important;
  inset:auto!important;
  display:grid!important;
  gap:.45rem!important;
  padding:clamp(1rem,2vw,1.25rem)!important;
  min-width:0!important;
  width:100%!important;
  background:transparent!important;
}
.misepress.misepress-cat-grid .misepress-cat-grid__name,
.misepress .misepress-cat-grid .misepress-cat-grid__name{
  display:block!important;
  overflow-wrap:anywhere!important;
  color:var(--mp-color-fg,#211914)!important;
  line-height:1.15!important;
}
.misepress.misepress-cat-grid--minimal .misepress-cat-grid__list,
.misepress .misepress-cat-grid--minimal .misepress-cat-grid__list{
  display:flex!important;
  flex-wrap:wrap!important;
  gap:.65rem!important;
}
@media (max-width:900px){
  .misepress.misepress-cat-grid .misepress-cat-grid__list,
  .misepress .misepress-cat-grid .misepress-cat-grid__list{grid-template-columns:repeat(2,minmax(0,1fr))!important;}
}
@media (max-width:560px){
  .misepress.misepress-cat-grid .misepress-cat-grid__list,
  .misepress .misepress-cat-grid .misepress-cat-grid__list{grid-template-columns:1fr!important;}
}

.misepress.mp-feed-inline{
  display:block!important;
  position:relative!important;
  overflow:hidden!important;
  border:1px solid var(--mp-color-border,#eaded1)!important;
  border-radius:var(--mp-radius-lg,22px)!important;
  background:var(--mp-color-surface,#fffdf8)!important;
  padding:clamp(1.1rem,2.8vw,1.75rem)!important;
  box-shadow:var(--mp-shadow-sm,0 12px 34px rgba(37,29,23,.07))!important;
}
.misepress.mp-feed-inline .mp-feed-inline__list{
  list-style:none!important;
  margin:0!important;
  padding:0!important;
  display:grid!important;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr))!important;
  gap:clamp(14px,2vw,22px)!important;
  align-items:stretch!important;
  width:100%!important;
}
.misepress.mp-feed-inline .mp-feed-inline__item{
  list-style:none!important;
  margin:0!important;
  padding:0!important;
  min-width:0!important;
  position:relative!important;
  transform:none!important;
  float:none!important;
  width:auto!important;
  height:auto!important;
}
.misepress.mp-feed-inline .mp-feed-inline__link{
  display:grid!important;
  grid-template-columns:86px minmax(0,1fr)!important;
  gap:14px!important;
  align-items:center!important;
  width:100%!important;
  height:100%!important;
  min-height:108px!important;
  padding:12px!important;
  border:1px solid var(--mp-color-border,#eaded1)!important;
  border-radius:var(--mp-radius,16px)!important;
  background:var(--mp-color-bg,#fffaf3)!important;
  color:var(--mp-color-fg,#211914)!important;
  text-decoration:none!important;
  overflow:hidden!important;
}
.misepress.mp-feed-inline .mp-feed-inline__link img{
  display:block!important;
  width:86px!important;
  height:86px!important;
  max-width:none!important;
  object-fit:cover!important;
  border-radius:12px!important;
  flex:none!important;
  position:static!important;
}
.misepress.mp-feed-inline .mp-feed-inline__body{
  min-width:0!important;
  display:grid!important;
  gap:.3rem!important;
}
.misepress.mp-feed-inline .mp-feed-inline__reason{
  display:block!important;
  font-size:.72rem!important;
  line-height:1.2!important;
  font-weight:800!important;
  letter-spacing:.08em!important;
  text-transform:uppercase!important;
  color:var(--mp-color-muted,#7b6f67)!important;
}
.misepress.mp-feed-inline .mp-feed-inline__title{
  display:-webkit-box!important;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden!important;
  font-weight:800!important;
  line-height:1.2!important;
  color:var(--mp-color-fg,#211914)!important;
}
@media (max-width:560px){
  .misepress.mp-feed-inline .mp-feed-inline__list{grid-template-columns:1fr!important;}
  .misepress.mp-feed-inline .mp-feed-inline__link{grid-template-columns:76px minmax(0,1fr)!important;}
  .misepress.mp-feed-inline .mp-feed-inline__link img{width:76px!important;height:76px!important;}
}

/* MisePress v1.36.05 — premium category grid image-card contrast/count polish. */
.misepress.misepress-cat-grid:not(.misepress-cat-grid--minimal):not(.misepress-cat-grid--bordered) .misepress-cat-grid__link,
.misepress .misepress-cat-grid:not(.misepress-cat-grid--minimal):not(.misepress-cat-grid--bordered) .misepress-cat-grid__link{
  position:relative!important;
  isolation:isolate!important;
  min-height:clamp(220px,24vw,340px)!important;
  border:0!important;
  border-radius:var(--mp-radius-xl,24px)!important;
  overflow:hidden!important;
  background:var(--mp-color-surface,#fffdf8)!important;
  box-shadow:0 16px 42px rgba(37,29,23,.10)!important;
}

.misepress.misepress-cat-grid:not(.misepress-cat-grid--minimal):not(.misepress-cat-grid--bordered) .misepress-cat-grid__item.has-image .misepress-cat-grid__media,
.misepress .misepress-cat-grid:not(.misepress-cat-grid--minimal):not(.misepress-cat-grid--bordered) .misepress-cat-grid__item.has-image .misepress-cat-grid__media{
  position:absolute!important;
  inset:0!important;
  width:100%!important;
  height:100%!important;
  aspect-ratio:auto!important;
  z-index:0!important;
  background:#211914!important;
}

.misepress.misepress-cat-grid:not(.misepress-cat-grid--minimal):not(.misepress-cat-grid--bordered) .misepress-cat-grid__item.has-image .misepress-cat-grid__media img,
.misepress .misepress-cat-grid:not(.misepress-cat-grid--minimal):not(.misepress-cat-grid--bordered) .misepress-cat-grid__item.has-image .misepress-cat-grid__media img{
  width:100%!important;
  height:100%!important;
  object-fit:cover!important;
  filter:saturate(1.03) contrast(1.03)!important;
  transition:transform .45s ease, filter .45s ease!important;
}

.misepress.misepress-cat-grid:not(.misepress-cat-grid--minimal):not(.misepress-cat-grid--bordered) .misepress-cat-grid__item.has-image .misepress-cat-grid__link::before,
.misepress .misepress-cat-grid:not(.misepress-cat-grid--minimal):not(.misepress-cat-grid--bordered) .misepress-cat-grid__item.has-image .misepress-cat-grid__link::before{
  content:""!important;
  position:absolute!important;
  inset:0!important;
  z-index:1!important;
  pointer-events:none!important;
  background:
    linear-gradient(180deg, rgba(0,0,0,.58) 0%, rgba(0,0,0,.18) 38%, rgba(0,0,0,.70) 100%),
    radial-gradient(circle at 20% 10%, rgba(0,0,0,.20), transparent 38%)!important;
}

.misepress.misepress-cat-grid:not(.misepress-cat-grid--minimal):not(.misepress-cat-grid--bordered) .misepress-cat-grid__item.has-image .misepress-cat-grid__body,
.misepress .misepress-cat-grid:not(.misepress-cat-grid--minimal):not(.misepress-cat-grid--bordered) .misepress-cat-grid__item.has-image .misepress-cat-grid__body{
  position:relative!important;
  z-index:2!important;
  min-height:100%!important;
  display:flex!important;
  flex-direction:column!important;
  justify-content:space-between!important;
  gap:.9rem!important;
  padding:clamp(1rem,2vw,1.35rem)!important;
  background:transparent!important;
}

.misepress.misepress-cat-grid:not(.misepress-cat-grid--minimal):not(.misepress-cat-grid--bordered) .misepress-cat-grid__item.has-image .misepress-cat-grid__name,
.misepress .misepress-cat-grid:not(.misepress-cat-grid--minimal):not(.misepress-cat-grid--bordered) .misepress-cat-grid__item.has-image .misepress-cat-grid__name{
  max-width:calc(100% - 3.25rem)!important;
  color:#fffdf8!important;
  font-family:var(--mp-font-display,Georgia,serif)!important;
  font-size:clamp(1.2rem,2vw,1.55rem)!important;
  font-weight:800!important;
  line-height:1.05!important;
  text-shadow:0 2px 16px rgba(0,0,0,.55)!important;
}

.misepress.misepress-cat-grid:not(.misepress-cat-grid--minimal):not(.misepress-cat-grid--bordered) .misepress-cat-grid__item.has-image .misepress-cat-grid__count,
.misepress .misepress-cat-grid:not(.misepress-cat-grid--minimal):not(.misepress-cat-grid--bordered) .misepress-cat-grid__item.has-image .misepress-cat-grid__count{
  position:absolute!important;
  top:clamp(.85rem,1.4vw,1.1rem)!important;
  right:clamp(.85rem,1.4vw,1.1rem)!important;
  z-index:3!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  width:2.35rem!important;
  min-width:2.35rem!important;
  height:2.35rem!important;
  min-height:2.35rem!important;
  padding:0!important;
  border-radius:999px!important;
  color:#fffdf8!important;
  background:rgba(0,0,0,.48)!important;
  border:1px solid rgba(255,255,255,.32)!important;
  box-shadow:0 10px 28px rgba(0,0,0,.22)!important;
  backdrop-filter:blur(12px)!important;
  -webkit-backdrop-filter:blur(12px)!important;
  font-size:.86rem!important;
  font-weight:900!important;
  line-height:1!important;
}

.misepress.misepress-cat-grid:not(.misepress-cat-grid--minimal):not(.misepress-cat-grid--bordered) .misepress-cat-grid__item.has-image .misepress-cat-grid__desc,
.misepress .misepress-cat-grid:not(.misepress-cat-grid--minimal):not(.misepress-cat-grid--bordered) .misepress-cat-grid__item.has-image .misepress-cat-grid__desc{
  color:rgba(255,253,248,.88)!important;
  text-shadow:0 2px 12px rgba(0,0,0,.45)!important;
}

.misepress.misepress-cat-grid:not(.misepress-cat-grid--minimal):not(.misepress-cat-grid--bordered) .misepress-cat-grid__item.has-image .misepress-cat-grid__link:hover .misepress-cat-grid__media img,
.misepress .misepress-cat-grid:not(.misepress-cat-grid--minimal):not(.misepress-cat-grid--bordered) .misepress-cat-grid__item.has-image .misepress-cat-grid__link:hover .misepress-cat-grid__media img{
  transform:scale(1.045)!important;
  filter:saturate(1.08) contrast(1.06)!important;
}

.misepress.misepress-cat-grid:not(.misepress-cat-grid--minimal):not(.misepress-cat-grid--bordered) .misepress-cat-grid__item:not(.has-image) .misepress-cat-grid__link,
.misepress .misepress-cat-grid:not(.misepress-cat-grid--minimal):not(.misepress-cat-grid--bordered) .misepress-cat-grid__item:not(.has-image) .misepress-cat-grid__link{
  min-height:160px!important;
  border:1px solid var(--mp-color-border,#eaded1)!important;
}


/* MisePress v1.36.06 — category grid image visibility/count polish.
   Cards template now keeps the image visible with content below; tiles keep overlay behavior. */
.misepress.misepress-cat-grid--cards .misepress-cat-grid__link,
.misepress .misepress-cat-grid--cards .misepress-cat-grid__link{
  position:relative!important;
  display:flex!important;
  flex-direction:column!important;
  min-height:0!important;
  height:100%!important;
  border:1px solid var(--mp-color-border,#eaded1)!important;
  border-radius:var(--mp-radius-xl,24px)!important;
  overflow:hidden!important;
  background:var(--mp-color-surface,#fffdf8)!important;
  box-shadow:0 16px 42px rgba(37,29,23,.08)!important;
  isolation:auto!important;
}
.misepress.misepress-cat-grid--cards .misepress-cat-grid__link::before,
.misepress .misepress-cat-grid--cards .misepress-cat-grid__link::before{
  content:none!important;
  display:none!important;
}
.misepress.misepress-cat-grid--cards .misepress-cat-grid__item.has-image .misepress-cat-grid__media,
.misepress .misepress-cat-grid--cards .misepress-cat-grid__item.has-image .misepress-cat-grid__media{
  position:relative!important;
  inset:auto!important;
  z-index:auto!important;
  width:100%!important;
  height:auto!important;
  aspect-ratio:16/10!important;
  background:var(--mp-color-bg,#fff8ee)!important;
  overflow:hidden!important;
}
.misepress.misepress-cat-grid--cards .misepress-cat-grid__item.has-image .misepress-cat-grid__media::after,
.misepress .misepress-cat-grid--cards .misepress-cat-grid__item.has-image .misepress-cat-grid__media::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:linear-gradient(180deg,rgba(0,0,0,0) 52%,rgba(0,0,0,.18) 100%);
}
.misepress.misepress-cat-grid--cards .misepress-cat-grid__item.has-image .misepress-cat-grid__media img,
.misepress .misepress-cat-grid--cards .misepress-cat-grid__item.has-image .misepress-cat-grid__media img{
  width:100%!important;
  height:100%!important;
  object-fit:cover!important;
  display:block!important;
  opacity:1!important;
  visibility:visible!important;
  filter:saturate(1.04) contrast(1.02)!important;
}
.misepress.misepress-cat-grid--cards .misepress-cat-grid__item.has-image .misepress-cat-grid__body,
.misepress .misepress-cat-grid--cards .misepress-cat-grid__item.has-image .misepress-cat-grid__body{
  position:relative!important;
  z-index:auto!important;
  min-height:0!important;
  display:grid!important;
  grid-template-columns:minmax(0,1fr) auto!important;
  align-items:center!important;
  gap:.65rem!important;
  padding:1rem 1.1rem!important;
  background:var(--mp-color-surface,#fffdf8)!important;
}
.misepress.misepress-cat-grid--cards .misepress-cat-grid__name,
.misepress .misepress-cat-grid--cards .misepress-cat-grid__name,
.misepress.misepress-cat-grid--cards .misepress-cat-grid__item.has-image .misepress-cat-grid__name,
.misepress .misepress-cat-grid--cards .misepress-cat-grid__item.has-image .misepress-cat-grid__name{
  max-width:none!important;
  color:var(--mp-color-fg,#211914)!important;
  font-family:var(--mp-font-display,Georgia,serif)!important;
  font-size:clamp(1.2rem,1.6vw,1.45rem)!important;
  font-weight:800!important;
  line-height:1.08!important;
  text-shadow:none!important;
}
.misepress.misepress-cat-grid--cards .misepress-cat-grid__count,
.misepress .misepress-cat-grid--cards .misepress-cat-grid__count,
.misepress.misepress-cat-grid--cards .misepress-cat-grid__item.has-image .misepress-cat-grid__count,
.misepress .misepress-cat-grid--cards .misepress-cat-grid__item.has-image .misepress-cat-grid__count{
  position:static!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  width:auto!important;
  min-width:2.15rem!important;
  height:2.15rem!important;
  min-height:2.15rem!important;
  padding:0 .72rem!important;
  border-radius:999px!important;
  background:color-mix(in srgb,var(--mp-color-accent,#a94f34) 12%,#fff)!important;
  border:1px solid color-mix(in srgb,var(--mp-color-accent,#a94f34) 22%,#fff)!important;
  color:var(--mp-color-accent,#a94f34)!important;
  box-shadow:none!important;
  backdrop-filter:none!important;
  -webkit-backdrop-filter:none!important;
  font-size:.85rem!important;
  font-weight:900!important;
  line-height:1!important;
}
.misepress.misepress-cat-grid--cards .misepress-cat-grid__item.has-image .misepress-cat-grid__desc,
.misepress .misepress-cat-grid--cards .misepress-cat-grid__item.has-image .misepress-cat-grid__desc{
  grid-column:1 / -1!important;
  color:var(--mp-color-muted,#7b6f67)!important;
  text-shadow:none!important;
}
.misepress.misepress-cat-grid--cards .misepress-cat-grid__link:hover .misepress-cat-grid__media img,
.misepress .misepress-cat-grid--cards .misepress-cat-grid__link:hover .misepress-cat-grid__media img{
  transform:scale(1.035)!important;
}


/* MisePress v1.36.07 — category grid image recovery and clearer card/tiles variants. */
.misepress.misepress-cat-grid--tiles .misepress-cat-grid__media,
.misepress .misepress-cat-grid--tiles .misepress-cat-grid__media{
  background-color:#211914!important;
  background-size:cover!important;
  background-position:center!important;
  background-repeat:no-repeat!important;
  background-blend-mode:normal!important;
}
.misepress.misepress-cat-grid--tiles .misepress-cat-grid__media img,
.misepress .misepress-cat-grid--tiles .misepress-cat-grid__media img{
  display:none!important;
}
.misepress.misepress-cat-grid--tiles .misepress-cat-grid__item.has-image .misepress-cat-grid__link,
.misepress .misepress-cat-grid--tiles .misepress-cat-grid__item.has-image .misepress-cat-grid__link{
  background:#211914!important;
}
.misepress.misepress-cat-grid--tiles .misepress-cat-grid__item.has-image .misepress-cat-grid__link::before,
.misepress .misepress-cat-grid--tiles .misepress-cat-grid__item.has-image .misepress-cat-grid__link::before{
  content:""!important;
  position:absolute!important;
  inset:0!important;
  z-index:1!important;
  pointer-events:none!important;
  background:linear-gradient(180deg,rgba(0,0,0,.66) 0%,rgba(0,0,0,.16) 44%,rgba(0,0,0,.72) 100%)!important;
}
.misepress.misepress-cat-grid--tiles .misepress-cat-grid__body,
.misepress .misepress-cat-grid--tiles .misepress-cat-grid__body{
  position:absolute!important;
  inset:0!important;
  z-index:2!important;
  display:flex!important;
  flex-direction:column!important;
  justify-content:space-between!important;
  padding:clamp(1rem,2vw,1.35rem)!important;
  color:#fffdf8!important;
  background:transparent!important;
}
.misepress.misepress-cat-grid--tiles .misepress-cat-grid__name,
.misepress .misepress-cat-grid--tiles .misepress-cat-grid__name{
  color:#fffdf8!important;
  text-shadow:0 2px 16px rgba(0,0,0,.56)!important;
}
.misepress.misepress-cat-grid--tiles .misepress-cat-grid__count,
.misepress .misepress-cat-grid--tiles .misepress-cat-grid__count{
  position:absolute!important;
  top:clamp(.85rem,1.4vw,1.1rem)!important;
  right:clamp(.85rem,1.4vw,1.1rem)!important;
  width:2.4rem!important;
  min-width:2.4rem!important;
  height:2.4rem!important;
  min-height:2.4rem!important;
  padding:0!important;
  border-radius:999px!important;
  color:#fffdf8!important;
  background:rgba(0,0,0,.46)!important;
  border:1px solid rgba(255,255,255,.34)!important;
  box-shadow:0 10px 28px rgba(0,0,0,.22)!important;
}

/* MisePress v1.36.08 — category grid image fallback/visibility hardening. */
.misepress.misepress-cat-grid .misepress-cat-grid__item.has-image .misepress-cat-grid__media,
.misepress .misepress-cat-grid .misepress-cat-grid__item.has-image .misepress-cat-grid__media{
  opacity:1!important;
  visibility:visible!important;
}
.misepress.misepress-cat-grid--tiles .misepress-cat-grid__item.has-image .misepress-cat-grid__media,
.misepress .misepress-cat-grid--tiles .misepress-cat-grid__item.has-image .misepress-cat-grid__media{
  position:absolute!important;
  inset:0!important;
  width:100%!important;
  height:100%!important;
  background-size:cover!important;
  background-position:center!important;
  background-repeat:no-repeat!important;
  background-color:#211914!important;
}
.misepress.misepress-cat-grid--tiles .misepress-cat-grid__item.has-image .misepress-cat-grid__media[style*="background-image"],
.misepress .misepress-cat-grid--tiles .misepress-cat-grid__item.has-image .misepress-cat-grid__media[style*="background-image"]{
  background-blend-mode:normal!important;
}
.misepress.misepress-cat-grid--cards .misepress-cat-grid__item.has-image .misepress-cat-grid__media img,
.misepress .misepress-cat-grid--cards .misepress-cat-grid__item.has-image .misepress-cat-grid__media img{
  opacity:1!important;
  visibility:visible!important;
  display:block!important;
}


/* MisePress v1.36.09 — category tiles image restoration.
   Tiles now render a real img plus background fallback so CSS/theme quirks cannot hide images. */
.misepress.misepress-cat-grid--tiles .misepress-cat-grid__link,
.misepress .misepress-cat-grid--tiles .misepress-cat-grid__link{
  position:relative!important;
  aspect-ratio:1/1!important;
  overflow:hidden!important;
  background:#211914!important;
  border-radius:var(--mp-radius-xl,24px)!important;
}
.misepress.misepress-cat-grid--tiles .misepress-cat-grid__item.has-image .misepress-cat-grid__media,
.misepress .misepress-cat-grid--tiles .misepress-cat-grid__item.has-image .misepress-cat-grid__media{
  position:absolute!important;
  inset:0!important;
  z-index:0!important;
  width:100%!important;
  height:100%!important;
  aspect-ratio:auto!important;
  display:block!important;
  overflow:hidden!important;
  background-size:cover!important;
  background-position:center!important;
  background-repeat:no-repeat!important;
  opacity:1!important;
  visibility:visible!important;
}
.misepress.misepress-cat-grid--tiles .misepress-cat-grid__item.has-image .misepress-cat-grid__media img,
.misepress .misepress-cat-grid--tiles .misepress-cat-grid__item.has-image .misepress-cat-grid__media img{
  display:block!important;
  position:absolute!important;
  inset:0!important;
  z-index:0!important;
  width:100%!important;
  height:100%!important;
  max-width:none!important;
  object-fit:cover!important;
  opacity:1!important;
  visibility:visible!important;
  filter:saturate(1.05) contrast(1.02)!important;
  transform:none!important;
}
.misepress.misepress-cat-grid--tiles .misepress-cat-grid__item.has-image .misepress-cat-grid__link::before,
.misepress .misepress-cat-grid--tiles .misepress-cat-grid__item.has-image .misepress-cat-grid__link::before{
  content:""!important;
  position:absolute!important;
  inset:0!important;
  z-index:1!important;
  pointer-events:none!important;
  background:linear-gradient(180deg,rgba(0,0,0,.45) 0%,rgba(0,0,0,.14) 42%,rgba(0,0,0,.68) 100%)!important;
}
.misepress.misepress-cat-grid--tiles .misepress-cat-grid__body,
.misepress .misepress-cat-grid--tiles .misepress-cat-grid__body{
  position:absolute!important;
  inset:0!important;
  z-index:2!important;
  display:flex!important;
  flex-direction:column!important;
  justify-content:space-between!important;
  padding:clamp(1rem,2vw,1.35rem)!important;
  background:transparent!important;
  pointer-events:none!important;
}
.misepress.misepress-cat-grid--tiles .misepress-cat-grid__name,
.misepress .misepress-cat-grid--tiles .misepress-cat-grid__name{
  color:#fffdf8!important;
  font-family:var(--mp-font-display,Georgia,serif)!important;
  font-weight:800!important;
  text-shadow:0 2px 16px rgba(0,0,0,.62)!important;
}
.misepress.misepress-cat-grid--tiles .misepress-cat-grid__count,
.misepress .misepress-cat-grid--tiles .misepress-cat-grid__count{
  position:absolute!important;
  top:clamp(.85rem,1.4vw,1.1rem)!important;
  right:clamp(.85rem,1.4vw,1.1rem)!important;
  z-index:3!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  width:2.35rem!important;
  min-width:2.35rem!important;
  height:2.35rem!important;
  min-height:2.35rem!important;
  padding:0!important;
  border-radius:999px!important;
  color:#fffdf8!important;
  background:rgba(0,0,0,.48)!important;
  border:1px solid rgba(255,255,255,.34)!important;
  box-shadow:0 10px 28px rgba(0,0,0,.22)!important;
  backdrop-filter:blur(10px)!important;
  -webkit-backdrop-filter:blur(10px)!important;
}

/* MisePress v1.37.10 - equipment affiliate CTA contrast hardening. */
.misepress .misepress__equipment-item:not(.misepress__equipment-item--product),
.misepress.misepress-acss .misepress__equipment-item:not(.misepress__equipment-item--product){
  background:#fff2eb!important;
  color:#8f2d12!important;
  font-weight:800!important;
}
.misepress .misepress__equipment-item:not(.misepress__equipment-item--product) strong,
.misepress.misepress-acss .misepress__equipment-item:not(.misepress__equipment-item--product) strong{
  color:#8f2d12!important;
}
.misepress .misepress__equipment-item--product,
.misepress.misepress-acss .misepress__equipment-item--product{
  background:#fff4ee!important;
  border-color:#ef7a4b!important;
}
.misepress .misepress__equipment-button,
.misepress .misepress__equipment-button:visited,
.misepress.misepress-acss .misepress__equipment-button,
.misepress.misepress-acss .misepress__equipment-button:visited{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  min-width:8.5rem!important;
  min-height:2.75rem!important;
  padding:.7rem 1.1rem!important;
  border:2px solid #7c260f!important;
  border-radius:999px!important;
  background:#a73514!important;
  color:#fffaf6!important;
  -webkit-text-fill-color:#fffaf6!important;
  text-decoration:none!important;
  text-shadow:0 1px 1px rgba(0,0,0,.22)!important;
  font-size:.95rem!important;
  font-weight:900!important;
  line-height:1!important;
  letter-spacing:0!important;
  text-indent:0!important;
  opacity:1!important;
  visibility:visible!important;
  white-space:nowrap!important;
}
.misepress .misepress__equipment-button:hover,
.misepress .misepress__equipment-button:focus-visible,
.misepress.misepress-acss .misepress__equipment-button:hover,
.misepress.misepress-acss .misepress__equipment-button:focus-visible{
  background:#8f2d12!important;
  border-color:#6d1f0b!important;
  color:#ffffff!important;
  -webkit-text-fill-color:#ffffff!important;
  text-decoration:none!important;
  transform:translateY(-1px);
}
.misepress .misepress__equipment-button:focus-visible,
.misepress.misepress-acss .misepress__equipment-button:focus-visible{
  outline:3px solid rgba(167,53,20,.28)!important;
  outline-offset:3px!important;
}
@media(max-width:720px){
  .misepress .misepress__equipment-button,
  .misepress.misepress-acss .misepress__equipment-button{
    width:100%!important;
    min-width:0!important;
  }
}
