/**
 * 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, Georgia, "Iowan Old Style", serif);
	--mp-font-body: var(--font-secondary, system-ui, sans-serif);
	--mp-shadow: 0 6px 24px -12px rgba(0, 0, 0, 0.18);
}

.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); }
.misepress__grid-card { background: var(--mp-color-bg); border-radius: var(--mp-radius); overflow: hidden; box-shadow: var(--mp-shadow); }
.misepress__grid-card a { display: block; color: inherit; text-decoration: none; }
.misepress__grid-card img { width: 100%; height: 200px; object-fit: cover; display: block; }
.misepress__grid-title { padding: var(--mp-space-2) var(--mp-space-2) 0; }
.misepress__grid-excerpt { padding: 0 var(--mp-space-2) var(--mp-space-2); color: var(--mp-color-muted); }

.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); }
.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: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%; 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: 200px; overflow-y: auto; padding-right: 0.3rem; }
.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.6rem 1.1rem; border-radius: var(--mp-radius-sm); font: inherit; font-weight: 600; cursor: pointer; border: 1px solid transparent; transition: background 0.15s, transform 0.1s; }
.misepress__btn--primary { background: var(--mp-color-accent); color: #fff; }
.misepress__btn--primary:hover { background: color-mix(in srgb, var(--mp-color-accent) 90%, #000); }
.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); }

/* Grid cards */
.misepress__grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: var(--mp-space-3); }
.misepress__grid-card { background: var(--mp-color-bg); border: 1px solid var(--mp-color-border); border-radius: var(--mp-radius); overflow: hidden; box-shadow: var(--mp-shadow); transition: transform 0.15s, box-shadow 0.15s; display: flex; flex-direction: column; }
.misepress__grid-card:hover { transform: translateY(-2px); box-shadow: 0 12px 32px -12px rgba(0,0,0,0.25); }
.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)); }
.misepress__grid-media img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.4s; }
.misepress__grid-card:hover .misepress__grid-media img { transform: scale(1.04); }
.misepress__grid-body { padding: var(--mp-space-2); display: grid; gap: 0.5rem; flex: 1; }
.misepress__grid-title { margin: 0; font-family: var(--mp-font-display); font-size: 1.25rem; line-height: 1.2; }
.misepress__grid-excerpt { margin: 0; color: var(--mp-color-muted); font-size: 0.9rem; }
.misepress__grid-meta { list-style: none; padding: 0; margin: 0.2rem 0 0; display: flex; flex-wrap: wrap; gap: 0.6rem; font-size: 0.8rem; color: var(--mp-color-muted); }
.misepress__grid-meta li { display: inline-flex; align-items: center; gap: 0.25rem; }
.misepress__grid-allergens { list-style: none; padding: 0; margin: 0.3rem 0 0; display: flex; flex-wrap: wrap; gap: 0.3rem; }

/* Allergen badges (icons) */
.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: var(--mp-s-3); right: var(--mp-s-3);
	z-index: 2; width: 36px; height: 36px;
	display: inline-grid; place-items: center;
	border: 0; border-radius: 999px; cursor: pointer;
	background: rgba(255,255,255,0.92); color: #6b6b6b;
	box-shadow: var(--mp-shadow-sm);
	backdrop-filter: blur(6px);
	transition: color .15s, transform .15s, background .15s;
}
.misepress__save-btn:hover { color: var(--mp-color-accent); transform: scale(1.06); }
.misepress__save-btn.is-saved { color: var(--mp-color-accent); background: var(--mp-color-accent-soft); }
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; }

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

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

/* ============================================================
 * 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: var(--mp-space-4) var(--mp-space-3);
	background: var(--mp-color-bg);
	border: 1px dashed var(--mp-color-border);
	border-radius: var(--mp-radius);
	max-width: 520px; margin: var(--mp-space-3) auto;
}
.misepress__empty-icon { font-size: 3rem; margin-bottom: var(--mp-space-2); }
.misepress__empty-title { font-family: var(--mp-font-display); font-size: 1.5rem; margin: 0 0 var(--mp-space-2); }
.misepress__empty-tips { list-style: none; padding: 0; margin: 0 0 var(--mp-space-3); color: var(--mp-color-muted); }
.misepress__empty-tips li { padding: 0.25rem 0; }
.misepress__empty-tips li::before { content: '· '; color: var(--mp-color-accent); }

/* ---------- 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; }
.misepress__filter-num { display: flex; flex-direction: column; gap: .25rem; font-size: .9rem; }
.misepress__filter-num input { padding: .45rem .6rem; border: 1px solid var(--mp-color-border, #ddd); border-radius: 8px; }

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