/**
 * 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);
	/* Shadow scale (1.13.2) — replaces ad-hoc rgba shadows scattered across components. */
	--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: 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 — applied when body has .misepress-theme-dark */
body.misepress-theme-dark {
	--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__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); }

/* =========================================================================
   v1.0.9 — Archives, Filters, Breadcrumbs, Allergen badges, Print
   ========================================================================= */

/* 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,
  .misepress__archive--filters-sidebar-right .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 > .misepress__filters { order: 2; }
  .misepress__archive--filters-sidebar-right .misepress__archive-layout > .misepress__archive-results { order: 1; }
  .misepress__archive--filters-sidebar-left  .misepress__filters,
  .misepress__archive--filters-sidebar-right .misepress__filters { position: sticky; top: var(--mp-space-3); }
}
/* Filters above results — full width */
.misepress__archive--filters-top .misepress__archive-layout { grid-template-columns: 1fr; }
.misepress__archive--filters-top .misepress__filters { position: static; }
/* Filters as a horizontal bar — compact, inline groups */
.misepress__archive--filters-top-bar .misepress__archive-layout { grid-template-columns: 1fr; }
.misepress__archive--filters-top-bar .misepress__filters { position: static; padding: var(--mp-space-2); }
.misepress__archive--filters-top-bar .misepress__filter-form { display: flex; flex-wrap: wrap; align-items: flex-end; gap: 0.75rem; }
.misepress__archive--filters-top-bar .misepress__filter-header { width: 100%; }
.misepress__archive--filters-top-bar .misepress__filter-group { border-bottom: 0; padding-bottom: 0; min-width: 180px; flex: 0 1 auto; }
.misepress__archive--filters-top-bar details.misepress__filter-group > summary { cursor: pointer; padding: 0.4rem 0.6rem; border: 1px solid var(--mp-color-border); border-radius: var(--mp-radius-sm); background: var(--mp-color-bg); }

.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); }

/* =========================================================================
   Unified card system (v1.9.3)
   - 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; }

/* =========================================================================
   v1.1.0 — Spacing system, shadows, hierarchy, list/editorial/restaurant,
   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 {
	--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__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__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; }

/* v1.1.4 — subtle scaling, editorial single, archive grid spacing */
.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; }


/* ===== v1.1.5: Recipe Slider ===== */
.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); }

/* ===== v1.1.5: Category Grid ===== */
.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); }


/* v1.1.6 — scale below ingredients, results toolbar */
.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; }

/* v1.2.6 — searchable filter groups */
.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); }


/* ============================================================
 * Phase 1 (v1.4.0) — UX Polish
 * ============================================================ */

/* 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: var(--mp-color-bg); }
.misepress__density-btn:focus-visible { outline: 2px solid var(--mp-color-accent); outline-offset: -2px; }

/* Density modes apply to grid */
.misepress__archive--density-compact .misepress__grid {
	grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
	gap: var(--mp-space-2);
}
.misepress__archive--density-compact .misepress__card { font-size: 0.875rem; }
.misepress__archive--density-comfortable .misepress__grid {
	grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
	gap: var(--mp-space-3);
}
.misepress__archive--density-visual .misepress__grid {
	grid-template-columns: repeat(auto-fill, minmax(360px, 1fr));
	gap: var(--mp-space-4);
}
.misepress__archive--density-visual .misepress__media 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 ---------- */
@media (min-width: 1024px) {
	.misepress__archive--filters-sidebar-left .misepress__filters,
	.misepress__archive--filters-sidebar-right .misepress__filters {
		position: sticky;
		top: var(--mp-sticky-offset, 80px);
		max-height: calc(100vh - var(--mp-sticky-offset, 80px) - 2rem);
		overflow-y: auto;
		align-self: flex-start;
	}
	/* 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; }
}

/* ================================================================
 * v1.5.0 — Phase 2: Search Intelligence styles
 * ================================================================ */

/* 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); } }

/* ============================================================
 * Discovery (v1.9.0) — Smart Collections + "Because you viewed"
 * ============================================================ */
.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; }

/* =========================================================================
   v1.9.3 — Save modal (register prompt) + Favorites page
   ========================================================================= */
.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;
}

/* === 1.9.4 Archive styling + nutrition label === */
.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__grid-card { position: relative; overflow: hidden; }
body.mp-card-overlay .misepress__grid-media { aspect-ratio: 4/5; }
body.mp-card-overlay .misepress__grid-body { position: absolute; inset: auto 0 0 0; padding: 1rem; background: linear-gradient(to top, rgba(0,0,0,.78), rgba(0,0,0,0)); color: #fff; }
body.mp-card-overlay .misepress__grid-title, body.mp-card-overlay .misepress__grid-excerpt { color: #fff; }
body.mp-card-minimal .misepress__grid-card { background: transparent; border: 0; box-shadow: none; }
body.mp-card-bold .misepress__grid-title { font-size: 1.4rem; font-weight: 800; letter-spacing: -.01em; }
body.mp-card-bold .misepress__grid-media { aspect-ratio: 16/10; }
body.mp-card-bordered .misepress__grid-card { border-width: 2px; box-shadow: none; }

/* Filter bar styles */
body.mp-filter-pills .misepress__filters label, body.mp-filter-pills .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__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__filters { background: #1a1a1a; color: #fff; padding: 1rem; border-radius: 8px; }
body.mp-filter-dark .misepress__filters label { color: #fff; }
body.mp-filter-underline .misepress__filters { border: 0; padding: 0; }
body.mp-filter-underline .misepress__filters select, body.mp-filter-underline .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; }

/* ======= 1.9.8 — Card details, checkboxes, timer, units ======= */
.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; }
}

/* ============== v1.11.0: ratings, videos, nutrition toggle ============== */
.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{position:absolute;inset:0;margin:auto;width:64px;height:64px;border-radius:999px;border:0;background:rgba(0,0,0,.6);color:#fff;font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center}
.misepress__video-play:hover{background:rgba(232,93,42,.85)}
.misepress__video--step{aspect-ratio:16/9;max-width:480px;margin-top:.5rem}
.misepress__video--gif img{display:block;width:100%;height:auto}

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

/* ============================================================
 * v1.16.0 — Builder/theme compatibility polish
 * ============================================================ */
/* 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; }

/* 1.24.0 — Single recipe customization */
.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; }

/* ============================================================
 * v1.27.0 — Hover-overlay card style + single layout safety
 * ============================================================ */
/* 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; }
.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)); }

/* User-submitted recipe form (1.28.0) */
.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.
 * ===================================================================== */
body.misepress-acss,
.misepress-acss {
	--mp-color-accent:      var(--action, var(--mp-color-accent));
	--mp-color-accent-soft: var(--action-light-trans-90, var(--mp-color-accent-soft));
	--mp-color-bg:          var(--base-ultra-light, var(--mp-color-bg));
	--mp-color-fg:          var(--base-ultra-dark, var(--mp-color-fg));
	--mp-color-muted:       var(--base, var(--mp-color-muted));
	--mp-color-border:      var(--base-light, var(--mp-color-border));
	--mp-card-bg:           var(--base-ultra-light, var(--mp-card-bg));
	--mp-card-accent:       var(--action, var(--mp-card-accent));
	--mp-filter-accent:     var(--action, var(--mp-filter-accent));
	--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));
}

/* ============================================================
 * v1.34.3 — Mobile filter bar Clear-all + tighter single recipe gaps
 * ============================================================ */
.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; }
}

/* ============= 1.34.17 — Per-area font sizes & filter load-more ============= */
/* 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. */
.misepress { font-size: var(--mp-font-size-base, inherit); }
.misepress__card-title,
.misepress__recipe-card__title { font-size: var(--mp-font-size-card-title, 1rem); }
.misepress__card-meta,
.misepress__recipe-card__meta { font-size: var(--mp-font-size-card-meta, .85rem); }
.misepress__archive-title { font-size: var(--mp-font-size-archive-h1, 2rem); }
.misepress__title { font-size: var(--mp-font-size-single-h1, inherit); }
.misepress__story,
.misepress__notes { font-size: var(--mp-font-size-single-body, inherit); }
.misepress__step { font-size: var(--mp-font-size-step, inherit); }
.misepress__ingredients li { font-size: var(--mp-font-size-ingredient, inherit); }
.misepress__filter-form { font-size: var(--mp-font-size-filter, inherit); }
.misepress__search-input,
.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; }
