/* ============================================================
   Milly Willy's Curiosity Cabinet — bespoke stylesheet
   Anti-template signature: paper-texture sections + ornate hairline frames
   + monocle eyebrow + curator's mark watermarks. Not reused.
   ============================================================ */

:root {
  --mw-green:     #1B3B2B;
  --mw-green-d:   #0F2419;
  --mw-parchment: #F9F6F0;
  --mw-parch-d:   #EFEADC;
  --mw-mustard:   #D9A05B;
  --mw-mustard-d: #B07F3D;
  --mw-ink:       #111625;
  --mw-ink-soft:  #2A2F44;
  --mw-rule:      #D8D3C5;
  --mw-rule-d:    rgba(17, 22, 37, .18);
  --mw-muted:     #6B6256;
  --mw-cream:     #FFFBF1;

  --mw-display: 'EB Garamond', Garamond, 'Times New Roman', serif;
  --mw-body:    'Vollkorn', 'Iowan Old Style', Georgia, serif;
  --mw-mono:    'Courier Prime', 'Courier New', Courier, monospace;

  /* Paper texture — subtle two-layer noise on parchment */
  --mw-paper-bg:
    radial-gradient(ellipse 60% 50% at 20% 10%, rgba(217,160,91,.05) 0%, transparent 60%),
    radial-gradient(ellipse 50% 40% at 80% 90%, rgba(27,59,43,.04) 0%, transparent 65%),
    repeating-linear-gradient(0deg, rgba(17,22,37,.018) 0 2px, transparent 2px 4px),
    repeating-linear-gradient(90deg, rgba(17,22,37,.012) 0 1px, transparent 1px 3px),
    #F9F6F0;
  --mw-paper-bg-dim:
    radial-gradient(ellipse 50% 40% at 70% 20%, rgba(217,160,91,.04) 0%, transparent 60%),
    repeating-linear-gradient(0deg, rgba(17,22,37,.016) 0 2px, transparent 2px 5px),
    #EFEADC;
  /* Ornate flourish corners */
  --mw-corner:
    linear-gradient(45deg, transparent 12px, var(--mw-mustard) 12px, var(--mw-mustard) 13px, transparent 13px) top left,
    linear-gradient(-45deg, transparent 12px, var(--mw-mustard) 12px, var(--mw-mustard) 13px, transparent 13px) top right,
    linear-gradient(-45deg, transparent 12px, var(--mw-mustard) 12px, var(--mw-mustard) 13px, transparent 13px) bottom left,
    linear-gradient(45deg, transparent 12px, var(--mw-mustard) 12px, var(--mw-mustard) 13px, transparent 13px) bottom right;
}

/* ===== Reset & base ===== */
*, *::before, *::after { box-sizing: border-box; }
* { min-width: 0; }
html, body { margin: 0; padding: 0; overflow-x: hidden; }
html { -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--mw-body);
  font-size: 16px;
  line-height: 1.6;
  color: var(--mw-ink);
  background: var(--mw-paper-bg);
  background-attachment: fixed;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img, video, svg { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; }
input, textarea, select { font: inherit; }
ul { padding: 0; margin: 0; list-style: none; }

/* ===== Typography ===== */
.mw-display, h1, h2, h3 {
  font-family: var(--mw-display);
  font-weight: 600;
  line-height: 1.1;
  letter-spacing: -.005em;
  margin: 0;
}
h1.mw-display-xl { font-size: clamp(38px, 5.4vw, 68px); font-weight: 500; letter-spacing: -.015em; }
h2.mw-display-lg { font-size: clamp(28px, 3.6vw, 46px); font-weight: 500; }
h3.mw-display-md { font-size: clamp(20px, 2.4vw, 28px); font-weight: 600; }
.mw-display-italic { font-style: italic; color: var(--mw-mustard); }

.mw-eyebrow {
  font-family: var(--mw-mono);
  font-size: 11px;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--mw-mustard-d);
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.mw-eyebrow::before,
.mw-eyebrow::after {
  content: '';
  width: 22px;
  height: 1px;
  background: var(--mw-mustard);
}
.mw-eyebrow--right::before { display: none; }
.mw-eyebrow--left::after { display: none; }

.mw-monocle {
  display: inline-block; width: 18px; height: 18px;
  border: 2px solid var(--mw-mustard);
  border-radius: 50%;
  position: relative; vertical-align: middle;
}
.mw-monocle::after {
  content: ''; position: absolute; left: 100%; top: 50%;
  width: 12px; height: 2px;
  background: var(--mw-mustard);
  transform: translateY(-50%);
}

.mw-lead {
  font-size: 18px; line-height: 1.55;
  color: var(--mw-ink-soft);
  max-width: 60ch;
  font-family: var(--mw-body);
}
.mw-lead--italic { font-style: italic; }

.mw-mono { font-family: var(--mw-mono); }

/* ===== Layout primitives ===== */
.mw-wrap { width: 100%; max-width: 1240px; margin: 0 auto; padding: 0 28px; }
.mw-section { padding: 88px 0; position: relative; }
.mw-section--green {
  background: var(--mw-green);
  color: var(--mw-parchment);
  position: relative;
}
.mw-section--green::before {
  content: ''; position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 60% 50% at 20% 10%, rgba(217,160,91,.04) 0%, transparent 60%),
    repeating-linear-gradient(0deg, rgba(249,246,240,.012) 0 2px, transparent 2px 4px);
  pointer-events: none;
}
.mw-section--green > * { position: relative; }
.mw-section--ink {
  background: var(--mw-ink); color: var(--mw-parchment);
}
.mw-section--parch-d {
  background: var(--mw-paper-bg-dim);
  background-attachment: fixed;
}

/* Ornamental hairline divider with center flourish */
.mw-divider {
  display: flex; align-items: center; justify-content: center;
  gap: 14px;
  padding: 22px 0;
  color: var(--mw-mustard-d);
}
.mw-divider::before,
.mw-divider::after {
  content: ''; flex: 1; height: 1px; background: var(--mw-mustard);
  opacity: .55;
  max-width: 220px;
}
.mw-divider-mark {
  font-family: var(--mw-display);
  font-style: italic; font-size: 22px;
  letter-spacing: .02em;
  line-height: 1;
}

/* ===== Buttons ===== */
.mw-btn {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--mw-display);
  font-size: 16px; font-weight: 500;
  letter-spacing: .03em;
  padding: 14px 26px;
  border: 1.5px solid var(--mw-ink);
  border-radius: 2px;
  background: var(--mw-mustard);
  color: var(--mw-ink);
  cursor: pointer;
  transition: background .15s, color .15s, transform .08s;
  position: relative;
}
.mw-btn::after {
  content: ''; position: absolute; inset: 3px;
  border: 1px solid rgba(17,22,37,.4);
  border-radius: 1px;
  pointer-events: none;
}
.mw-btn:hover { background: var(--mw-ink); color: var(--mw-mustard); border-color: var(--mw-mustard); }
.mw-btn:active { transform: translateY(1px); }

.mw-btn--ghost {
  background: transparent; color: var(--mw-ink);
  border-color: var(--mw-ink);
}
.mw-btn--ghost::after { border-color: transparent; }
.mw-btn--ghost:hover { background: var(--mw-ink); color: var(--mw-parchment); }
.mw-section--green .mw-btn--ghost { color: var(--mw-parchment); border-color: var(--mw-parchment); }
.mw-section--green .mw-btn--ghost:hover { background: var(--mw-parchment); color: var(--mw-green); }

.mw-btn-link {
  font-family: var(--mw-mono);
  font-size: 12px; letter-spacing: .24em; text-transform: uppercase;
  color: var(--mw-mustard-d);
  border-bottom: 1px dotted var(--mw-mustard-d);
  padding-bottom: 2px;
}
.mw-btn-link:hover { color: var(--mw-ink); border-color: var(--mw-ink); }
.mw-section--green .mw-btn-link { color: var(--mw-mustard); border-color: var(--mw-mustard); }
.mw-section--green .mw-btn-link:hover { color: var(--mw-parchment); border-color: var(--mw-parchment); }

/* ===== Header — Victorian cabinet sign ===== */
.mw-shopfront {
  background: var(--mw-green);
  color: var(--mw-parchment);
  position: sticky; top: 0; z-index: 100;
  border-bottom: 1px solid rgba(217,160,91,.32);
}
.mw-shopfront::after {
  content: ''; position: absolute; left: 0; right: 0; bottom: -6px;
  height: 6px;
  background:
    linear-gradient(180deg, var(--mw-green) 0%, transparent 100%);
  pointer-events: none;
}
.mw-shopfront-bar {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 22px;
  padding: 14px 0;
}
.mw-shopfront-nav {
  display: flex;
  gap: 22px;
  font-family: var(--mw-display);
  font-size: 15px;
  font-weight: 500;
}
.mw-shopfront-nav--left  { justify-content: flex-end; }
.mw-shopfront-nav--right { justify-content: flex-start; align-items: center; gap: 16px; }
.mw-shopfront-nav a {
  color: var(--mw-parchment);
  padding: 4px 0;
  border-bottom: 1px solid transparent;
  transition: color .12s, border-color .12s;
  white-space: nowrap;
}
.mw-shopfront-nav a:hover { color: var(--mw-mustard); }
.mw-shopfront-nav a.is-here { color: var(--mw-mustard); border-bottom-color: var(--mw-mustard); }

.mw-brand {
  display: flex; flex-direction: column; align-items: center;
  text-align: center; color: var(--mw-parchment);
  padding: 0 14px;
}
.mw-brand-flourish {
  display: flex; align-items: center; gap: 12px;
  color: var(--mw-mustard);
  font-size: 14px;
  margin-bottom: 2px;
}
.mw-brand-flourish::before, .mw-brand-flourish::after {
  content: ''; width: 30px; height: 1px;
  background: var(--mw-mustard);
}
.mw-brand-name {
  font-family: var(--mw-display);
  font-style: italic;
  font-size: 30px;
  font-weight: 500;
  letter-spacing: -.005em;
  line-height: 1;
  color: var(--mw-parchment);
}
.mw-brand-name .amp {
  color: var(--mw-mustard);
  font-weight: 400;
}
.mw-brand-sub {
  font-family: var(--mw-mono);
  font-size: 9px; letter-spacing: .42em;
  text-transform: uppercase;
  color: var(--mw-mustard);
  margin-top: 4px;
}

/* Header utilities (cart / wishlist / burger) */
.mw-util {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--mw-mono);
  font-size: 12px; letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--mw-parchment);
  padding: 7px 12px;
  border: 1px solid rgba(217,160,91,.5);
  background: rgba(0,0,0,.18);
  transition: border-color .12s, color .12s, background .12s;
}
.mw-util:hover { border-color: var(--mw-mustard); color: var(--mw-mustard); }
.mw-util-badge {
  display: inline-grid; place-items: center;
  min-width: 20px; height: 20px; padding: 0 5px;
  background: var(--mw-mustard); color: var(--mw-ink);
  font-family: var(--mw-display); font-size: 13px; font-weight: 600;
  border-radius: 50%;
}
.mw-util.is-empty .mw-util-badge { background: rgba(217,160,91,.3); color: var(--mw-mustard); }
.mw-util-badge.is-bump { animation: mw-bump .42s ease; }
@keyframes mw-bump { 35% { transform: scale(1.4); } 100% { transform: scale(1); } }

.mw-burger {
  display: none; background: transparent; border: 1px solid var(--mw-mustard);
  color: var(--mw-mustard); padding: 7px 11px;
  font-family: var(--mw-mono); font-size: 13px; letter-spacing: .12em;
  text-transform: uppercase;
}

@media (max-width: 920px) {
  .mw-shopfront-bar { grid-template-columns: auto 1fr auto; padding: 12px 0; gap: 12px; }
  .mw-shopfront-bar > * { min-width: 0; }
  .mw-shopfront-nav--left {
    display: none;
    position: absolute; top: 100%; left: 0; right: 0;
    background: var(--mw-green-d);
    flex-direction: column;
    padding: 18px 28px; gap: 16px;
    border-bottom: 2px solid var(--mw-mustard);
  }
  .mw-shopfront-nav--left.is-open { display: flex; }
  .mw-shopfront-nav--right a:not(.mw-util) { display: none; }
  .mw-burger { display: inline-flex; }
  .mw-brand-name { font-size: 22px; }
  .mw-brand-flourish::before, .mw-brand-flourish::after { width: 18px; }
  .mw-brand-sub { display: none; }
}
@media (max-width: 480px) {
  .mw-wrap { padding: 0 16px; }
  .mw-util { padding: 6px 9px; font-size: 11px; }
  .mw-util span:not(.mw-util-badge) { display: none; }
}

/* ===== Hero — interactive cabinet door ===== */
.mw-hero {
  padding: 100px 0 70px;
  position: relative;
}
.mw-hero-inner {
  display: grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 60px;
  align-items: center;
}
@media (max-width: 880px) {
  .mw-hero-inner { grid-template-columns: 1fr; gap: 36px; }
}
.mw-hero-flourish {
  font-family: var(--mw-display);
  font-style: italic;
  color: var(--mw-mustard-d);
  font-size: 24px;
  letter-spacing: .04em;
  margin-bottom: 14px;
}
.mw-hero h1 { margin: 6px 0 24px; }
.mw-hero h1 em {
  font-style: italic; color: var(--mw-mustard-d);
}
.mw-hero p.mw-lead { margin: 0 0 36px; font-size: 19px; }
.mw-hero-actions { display: flex; gap: 14px; flex-wrap: wrap; }

.mw-hero-meta {
  margin-top: 44px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-top: 1px solid var(--mw-rule);
  border-bottom: 1px solid var(--mw-rule);
}
.mw-hero-meta > div {
  padding: 16px 0;
  border-right: 1px solid var(--mw-rule);
  text-align: center;
}
.mw-hero-meta > div:last-child { border-right: 0; }
.mw-hero-meta dt {
  font-family: var(--mw-mono); font-size: 10px;
  letter-spacing: .22em; text-transform: uppercase;
  color: var(--mw-muted);
  margin-bottom: 4px;
}
.mw-hero-meta dd {
  margin: 0;
  font-family: var(--mw-display);
  font-size: 22px; font-style: italic;
  color: var(--mw-green);
}

/* Hero cabinet showcase — a Victorian display cabinet illustration */
.mw-cabinet {
  position: relative;
  aspect-ratio: 3 / 4;
  background: linear-gradient(165deg, var(--mw-green) 0%, var(--mw-green-d) 100%);
  border: 1px solid var(--mw-ink);
  padding: 14px;
  box-shadow:
    0 0 0 1px var(--mw-mustard) inset,
    14px 14px 0 -1px var(--mw-mustard),
    20px 20px 0 0 var(--mw-ink);
}
.mw-cabinet-frame {
  height: 100%;
  border: 2px solid var(--mw-mustard);
  position: relative;
  overflow: hidden;
}
.mw-cabinet-frame img { width: 100%; height: 100%; object-fit: cover; }
.mw-cabinet-tag {
  position: absolute; top: 22px; right: -8px;
  background: var(--mw-mustard); color: var(--mw-ink);
  padding: 6px 14px;
  font-family: var(--mw-mono); font-size: 11px;
  letter-spacing: .22em; text-transform: uppercase;
  box-shadow: 2px 2px 0 var(--mw-ink);
  z-index: 2;
}

/* ===== Section heads ===== */
.mw-shead {
  text-align: center;
  margin-bottom: 50px;
}
.mw-shead h2 { margin-top: 14px; }
.mw-shead p.mw-lead { margin: 14px auto 0; }
.mw-shead--align-left { text-align: left; }
.mw-shead--align-left p.mw-lead { margin-left: 0; }

/* ===== Product card — Victorian catalogue card with serial No ===== */
.mw-card {
  background: var(--mw-parchment);
  border: 1px solid var(--mw-rule);
  display: flex; flex-direction: column;
  position: relative;
  transition: transform .14s, box-shadow .14s;
  text-decoration: none;
  color: var(--mw-ink);
}
.mw-card::before {
  content: ''; position: absolute; top: -1px; left: 16px; right: 16px; height: 3px;
  background: var(--mw-mustard);
}
.mw-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 14px 30px -16px rgba(17,22,37,.4);
}
.mw-section--green .mw-card { background: var(--mw-cream); }

.mw-card-shot {
  aspect-ratio: 4 / 3;
  background: var(--mw-parch-d);
  overflow: hidden;
  position: relative;
  border-bottom: 1px solid var(--mw-rule);
}
.mw-card-shot img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .35s ease;
}
.mw-card:hover .mw-card-shot img { transform: scale(1.05); }
.mw-card-serial {
  position: absolute; top: 10px; left: 10px;
  font-family: var(--mw-mono);
  font-size: 10px; letter-spacing: .18em;
  text-transform: uppercase;
  background: var(--mw-parchment);
  color: var(--mw-muted);
  padding: 3px 8px;
  border: 1px solid var(--mw-rule);
}
.mw-card-sale {
  position: absolute; top: 10px; right: 10px;
  background: var(--mw-mustard); color: var(--mw-ink);
  padding: 4px 9px;
  font-family: var(--mw-display); font-size: 14px; font-style: italic;
  border: 1px solid var(--mw-ink);
}
.mw-card-oos {
  position: absolute; top: 10px; right: 10px;
  background: var(--mw-ink); color: var(--mw-parchment);
  padding: 4px 9px;
  font-family: var(--mw-mono); font-size: 10px; letter-spacing: .18em;
  text-transform: uppercase;
}

.mw-card-body {
  padding: 16px 18px 14px;
  display: flex; flex-direction: column;
  gap: 8px;
  flex: 1;
}
.mw-card-cat {
  font-family: var(--mw-mono);
  font-size: 10px; letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--mw-muted);
}
.mw-card-name {
  font-family: var(--mw-display);
  font-size: 21px;
  font-weight: 500;
  line-height: 1.1;
  letter-spacing: -.005em;
  margin: 0;
  color: var(--mw-ink);
  overflow-wrap: anywhere;
}
.mw-card-name a { color: inherit; }
.mw-card-desc {
  font-size: 13px; line-height: 1.5;
  color: var(--mw-ink-soft);
  font-style: italic;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  margin: 0;
}
.mw-card-priceline {
  margin-top: auto;
  display: flex; align-items: baseline; gap: 10px;
  padding-top: 8px;
  border-top: 1px dashed var(--mw-rule);
}
.mw-card-price {
  font-family: var(--mw-display);
  font-size: 22px;
  font-weight: 600;
  color: var(--mw-green);
}
.mw-section--green .mw-card .mw-card-price { color: var(--mw-mustard-d); }
.mw-card-price-was {
  font-family: var(--mw-mono); font-size: 12px;
  color: var(--mw-muted);
  text-decoration: line-through;
}
.mw-card-add {
  display: inline-flex; align-items: center; justify-content: center;
  width: 36px; height: 36px;
  background: var(--mw-mustard); color: var(--mw-ink);
  border: 1px solid var(--mw-ink); border-radius: 50%;
  font-family: var(--mw-display); font-size: 22px; line-height: 1;
  font-weight: 500;
  cursor: pointer;
  transition: background .14s, transform .12s;
  margin-left: auto;
}
.mw-card-add:hover { background: var(--mw-ink); color: var(--mw-mustard); transform: scale(1.06); }
.mw-card.is-oos .mw-card-add { background: var(--mw-rule); color: var(--mw-muted); pointer-events: none; }

/* Card grid */
.mw-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(260px, 100%), 1fr));
  gap: 26px;
}

/* ===== Curator-pick (1 large featured product) ===== */
.mw-curator {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: 50px;
  align-items: center;
  background: var(--mw-cream);
  padding: 50px;
  border: 1px solid var(--mw-rule);
  position: relative;
}
.mw-curator::before {
  content: '';
  position: absolute; top: 14px; left: 14px; right: 14px; bottom: 14px;
  border: 1px solid var(--mw-mustard);
  pointer-events: none;
}
@media (max-width: 880px) {
  .mw-curator { grid-template-columns: 1fr; gap: 24px; padding: 32px 22px; }
}
.mw-curator-photo {
  position: relative;
  aspect-ratio: 4 / 5;
  overflow: hidden;
  border: 1px solid var(--mw-rule);
}
.mw-curator-photo img { width: 100%; height: 100%; object-fit: cover; }
.mw-curator-photo::after {
  content: ''; position: absolute; inset: 6px;
  border: 1px solid rgba(217,160,91,.55);
  pointer-events: none;
}
.mw-curator-stamp {
  position: absolute; top: -10px; right: 20px;
  background: var(--mw-ink); color: var(--mw-mustard);
  padding: 8px 14px;
  font-family: var(--mw-display); font-style: italic;
  font-size: 14px; letter-spacing: .04em;
  transform: rotate(-2deg);
}
.mw-curator-text { display: flex; flex-direction: column; gap: 14px; }
.mw-curator-text h2 { margin: 0; }
.mw-curator-text blockquote {
  margin: 8px 0; padding: 14px 18px;
  border-left: 3px solid var(--mw-mustard);
  font-family: var(--mw-display); font-size: 17px; font-style: italic;
  color: var(--mw-ink-soft);
}
.mw-curator-signature {
  font-family: var(--mw-display); font-size: 16px; font-style: italic;
  color: var(--mw-mustard-d);
  margin-top: 8px;
}

/* ===== Cabinet shelves — interactive vertical category list ===== */
.mw-shelves {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(220px, 100%), 1fr));
  gap: 22px;
}
.mw-shelf {
  background: var(--mw-parchment);
  border: 1px solid var(--mw-rule);
  padding: 24px 22px;
  display: flex; flex-direction: column;
  gap: 12px;
  position: relative;
  text-decoration: none;
  color: var(--mw-ink);
  transition: background .14s, transform .14s, border-color .14s;
  min-height: 200px;
  overflow: hidden;
}
.mw-shelf::before {
  content: '';
  position: absolute; inset: 0;
  background-image: var(--mw-shelf-bg);
  background-size: cover; background-position: center;
  opacity: .25;
  filter: sepia(.3) saturate(.7);
  transition: opacity .2s;
}
.mw-shelf > * { position: relative; z-index: 1; }
.mw-shelf:hover { background: var(--mw-green); color: var(--mw-cream); border-color: var(--mw-mustard); transform: translateY(-2px); }
.mw-shelf:hover::before { opacity: .15; }
.mw-shelf:hover .mw-shelf-count { color: var(--mw-mustard); }
.mw-shelf-icon {
  font-family: var(--mw-display); font-style: italic;
  font-size: 38px;
  color: var(--mw-mustard);
}
.mw-shelf-name {
  font-family: var(--mw-display);
  font-size: 26px; font-weight: 500;
  letter-spacing: -.005em;
}
.mw-shelf-count {
  font-family: var(--mw-mono);
  font-size: 11px; letter-spacing: .14em;
  color: var(--mw-muted);
  text-transform: uppercase;
}

/* ===== Genre chips ===== */
.mw-genres {
  display: flex; flex-wrap: wrap; gap: 10px; justify-content: center;
}
.mw-genre-chip {
  display: inline-flex; align-items: baseline; gap: 8px;
  background: var(--mw-parchment);
  border: 1px solid var(--mw-rule);
  padding: 10px 18px;
  font-family: var(--mw-display);
  font-size: 17px;
  color: var(--mw-ink);
  transition: background .14s, color .14s, border-color .14s;
  text-decoration: none;
}
.mw-genre-chip:hover {
  background: var(--mw-mustard); color: var(--mw-ink); border-color: var(--mw-ink);
}
.mw-genre-chip em {
  font-family: var(--mw-mono); font-size: 10px;
  color: var(--mw-muted);
  font-style: normal;
  letter-spacing: .08em;
}
.mw-genre-chip:hover em { color: var(--mw-ink); }

/* ===== Trust strip (parchment, 3-column with hairline frames) ===== */
.mw-trust {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-top: 1px solid var(--mw-rule);
  border-bottom: 1px solid var(--mw-rule);
}
.mw-trust-cell {
  padding: 28px 22px;
  border-right: 1px solid var(--mw-rule);
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  text-align: center;
}
.mw-trust-cell:last-child { border-right: 0; }
.mw-trust-mark {
  font-family: var(--mw-display);
  font-style: italic;
  font-size: 32px;
  color: var(--mw-mustard-d);
  line-height: 1;
  margin-bottom: 4px;
}
.mw-trust-cell strong {
  font-family: var(--mw-display);
  font-size: 20px; font-weight: 500;
  color: var(--mw-ink);
}
.mw-trust-cell span {
  font-family: var(--mw-mono);
  font-size: 11px; letter-spacing: .14em;
  color: var(--mw-muted);
  text-transform: uppercase;
}
@media (max-width: 760px) {
  .mw-trust { grid-template-columns: 1fr; }
  .mw-trust-cell { border-right: 0; border-bottom: 1px solid var(--mw-rule); }
  .mw-trust-cell:last-child { border-bottom: 0; }
}

/* ===== Footer ===== */
.mw-foot {
  background: var(--mw-green-d);
  color: var(--mw-parchment);
  border-top: 1px solid var(--mw-mustard);
}
.mw-foot-top { padding: 56px 0 40px; }
.mw-foot-grid {
  display: grid;
  grid-template-columns: 1.4fr repeat(3, 1fr);
  gap: 36px;
}
@media (max-width: 880px) { .mw-foot-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px) { .mw-foot-grid { grid-template-columns: 1fr; } }
.mw-foot-brand p { color: rgba(249,246,240,.7); font-size: 14px; max-width: 36ch; }
.mw-foot-col h4 {
  font-family: var(--mw-display);
  font-size: 18px; font-style: italic;
  color: var(--mw-mustard);
  margin: 0 0 14px;
}
.mw-foot-col ul { display: flex; flex-direction: column; gap: 8px; }
.mw-foot-col a { color: var(--mw-parchment); font-size: 14px; transition: color .12s; }
.mw-foot-col a:hover { color: var(--mw-mustard); }
.mw-foot-pay {
  padding: 22px 0;
  border-top: 1px solid rgba(217,160,91,.32);
  display: flex; gap: 16px; flex-wrap: wrap; align-items: center;
}
.mw-foot-pay-label {
  font-family: var(--mw-mono); font-size: 11px; letter-spacing: .22em;
  text-transform: uppercase; color: var(--mw-mustard);
}
.mw-foot-pay-icons { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; }
.mw-foot-pay-icon {
  background: var(--mw-parchment); color: var(--mw-ink);
  height: 26px; min-width: 42px;
  padding: 0 10px;
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--mw-display); font-size: 13px; font-style: italic;
  border: 1px solid var(--mw-parchment);
}
.mw-foot-pay-icon img { height: 16px; max-width: 36px; }
.mw-foot-legal {
  padding: 18px 0;
  border-top: 1px solid rgba(217,160,91,.18);
  display: grid; grid-template-columns: 1fr auto;
  gap: 14px;
  font-family: var(--mw-mono);
  font-size: 11px; letter-spacing: .12em;
  color: rgba(249,246,240,.55);
}
.mw-foot-legal a { color: rgba(249,246,240,.55); text-decoration: underline; text-underline-offset: 3px; }
.mw-foot-legal a:hover { color: var(--mw-mustard); }
@media (max-width: 720px) { .mw-foot-legal { grid-template-columns: 1fr; text-align: center; } }

/* ===== Catalogue (the-cabinet) ===== */
.mw-pagehead {
  padding: 60px 0 30px;
  text-align: center;
}
.mw-crumbs {
  font-family: var(--mw-mono);
  font-size: 11px; letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--mw-muted);
  margin-bottom: 24px;
}
.mw-crumbs a { color: var(--mw-muted); }
.mw-crumbs a:hover { color: var(--mw-ink); }
.mw-crumbs span.current { color: var(--mw-mustard-d); }

.mw-cat-layout {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: 36px;
  align-items: start;
}
@media (max-width: 980px) { .mw-cat-layout { grid-template-columns: 1fr; } }

.mw-sidebar {
  background: var(--mw-cream);
  border: 1px solid var(--mw-rule);
  padding: 22px 18px;
  position: sticky; top: 90px;
}
.mw-sidebar h3 {
  font-family: var(--mw-display);
  font-style: italic; font-weight: 500;
  font-size: 19px;
  color: var(--mw-green);
  margin: 0 0 14px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--mw-rule);
}
.mw-sidebar-fset { margin-bottom: 18px; padding-bottom: 14px; border-bottom: 1px dashed var(--mw-rule); }
.mw-sidebar-fset:last-child { border-bottom: 0; padding-bottom: 0; margin-bottom: 0; }
.mw-sidebar-fset legend {
  font-family: var(--mw-mono); font-size: 10px;
  letter-spacing: .22em; text-transform: uppercase;
  color: var(--mw-muted);
  margin-bottom: 10px;
}
.mw-sidebar-list { display: flex; flex-direction: column; gap: 4px; }
.mw-sidebar-list a {
  font-family: var(--mw-body);
  font-size: 14px;
  color: var(--mw-ink);
  display: flex; justify-content: space-between;
  padding: 5px 8px;
  transition: background .12s, color .12s;
}
.mw-sidebar-list a:hover { background: var(--mw-parch-d); color: var(--mw-green); }
.mw-sidebar-list a.is-here { background: var(--mw-mustard); color: var(--mw-ink); font-style: italic; }
.mw-sidebar-list a em { font-family: var(--mw-mono); font-size: 11px; color: var(--mw-muted); font-style: normal; }
.mw-sidebar-list a:hover em { color: var(--mw-green); }
.mw-sidebar-list a.is-here em { color: var(--mw-ink); }

.mw-toolbar {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  margin-bottom: 26px;
  padding: 14px 18px;
  background: var(--mw-cream);
  border: 1px solid var(--mw-rule);
}
.mw-toolbar-count {
  font-family: var(--mw-display);
  font-style: italic;
  font-size: 18px;
  color: var(--mw-green);
}
.mw-toolbar select {
  background: var(--mw-parchment); color: var(--mw-ink);
  border: 1px solid var(--mw-rule);
  padding: 8px 12px;
  font-family: var(--mw-body);
  font-size: 13px;
}

/* ===== Product detail page ===== */
.mw-pdp {
  padding: 50px 0 80px;
}
.mw-pdp-grid {
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 50px;
  align-items: start;
}
.mw-pdp-grid > * { min-width: 0; }
@media (max-width: 880px) { .mw-pdp-grid { grid-template-columns: 1fr; gap: 28px; } }

.mw-gallery {
  position: relative;
  border: 1px solid var(--mw-rule);
  background: var(--mw-cream);
  padding: 12px;
}
.mw-gallery::before {
  content: ''; position: absolute; top: 4px; left: 4px; right: 4px; bottom: 4px;
  border: 1px solid var(--mw-mustard);
  pointer-events: none;
}
.mw-gallery-main {
  aspect-ratio: 4/3;
  overflow: hidden;
  background: var(--mw-parch-d);
  position: relative;
}
.mw-gallery-main img { width: 100%; height: 100%; object-fit: cover; }
.mw-gallery-sale {
  position: absolute; top: 18px; right: 18px;
  background: var(--mw-mustard); color: var(--mw-ink);
  padding: 6px 14px;
  font-family: var(--mw-display); font-style: italic;
  font-size: 17px;
  border: 1px solid var(--mw-ink);
}
.mw-gallery-thumbs {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 6px;
  margin-top: 8px;
}
.mw-gallery-thumb {
  aspect-ratio: 1; overflow: hidden;
  background: var(--mw-parch-d);
  border: 1.5px solid transparent;
  padding: 0; cursor: pointer;
}
.mw-gallery-thumb.is-active { border-color: var(--mw-mustard); }
.mw-gallery-thumb img { width: 100%; height: 100%; object-fit: cover; }

.mw-pdp-info { display: flex; flex-direction: column; gap: 14px; }
.mw-pdp-cat {
  font-family: var(--mw-mono);
  font-size: 11px; letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--mw-muted);
}
.mw-pdp-info h1 {
  font-family: var(--mw-display);
  font-size: clamp(28px, 4vw, 44px);
  font-weight: 500; line-height: 1.05;
  color: var(--mw-ink);
  margin: 0;
}
.mw-price-row {
  display: flex; align-items: baseline; gap: 14px;
  padding: 16px 0 18px;
  border-bottom: 1px dashed var(--mw-rule);
  flex-wrap: wrap;
}
.mw-price-now {
  font-family: var(--mw-display);
  font-size: 38px; font-weight: 600;
  color: var(--mw-green);
}
.mw-price-was {
  font-family: var(--mw-mono); font-size: 18px;
  color: var(--mw-muted);
  text-decoration: line-through;
}
.mw-price-save {
  background: var(--mw-mustard); color: var(--mw-ink);
  padding: 4px 10px;
  font-family: var(--mw-display); font-style: italic;
  font-size: 14px;
}
.mw-pdp-desc {
  font-family: var(--mw-body);
  font-size: 15px; line-height: 1.7;
  color: var(--mw-ink);
  white-space: pre-line;
}

.mw-pdp-form { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 18px; }
.mw-qty {
  display: inline-flex; align-items: stretch;
  background: var(--mw-cream); border: 1px solid var(--mw-rule);
}
.mw-qty button {
  background: transparent; border: 0; color: var(--mw-ink);
  font-family: var(--mw-display); font-size: 20px;
  width: 38px;
}
.mw-qty input {
  width: 42px; background: transparent; border: 0;
  text-align: center; color: var(--mw-ink);
  font-family: var(--mw-body); font-size: 16px;
}

.mw-specs {
  margin-top: 22px;
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px;
}
@media (max-width: 480px) { .mw-specs { grid-template-columns: 1fr; } }
.mw-specs > div {
  background: var(--mw-cream);
  border: 1px solid var(--mw-rule);
  padding: 12px 14px;
}
.mw-specs dt {
  font-family: var(--mw-mono); font-size: 10px;
  letter-spacing: .22em; text-transform: uppercase;
  color: var(--mw-muted);
  margin-bottom: 4px;
}
.mw-specs dd {
  margin: 0;
  font-family: var(--mw-display); font-size: 16px;
  color: var(--mw-ink);
}

.mw-curator-card {
  background: var(--mw-green); color: var(--mw-parchment);
  padding: 18px 20px;
  margin-top: 22px;
  position: relative;
}
.mw-curator-card::before {
  content: ''; position: absolute; inset: 4px;
  border: 1px solid var(--mw-mustard);
  pointer-events: none;
}
.mw-curator-card strong {
  font-family: var(--mw-display); font-style: italic;
  font-size: 17px; color: var(--mw-mustard);
  display: block; margin-bottom: 4px;
}
.mw-curator-card p { font-size: 13px; line-height: 1.55; margin: 0; }

/* ===== Reviews / customer letters ===== */
.mw-letters {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(280px, 100%), 1fr));
  gap: 22px;
}
.mw-letter {
  background: var(--mw-cream);
  border: 1px solid var(--mw-rule);
  padding: 24px 22px;
  position: relative;
}
.mw-letter::before {
  content: ''; position: absolute; top: 8px; right: 8px;
  width: 36px; height: 36px;
  background: var(--mw-mustard); border-radius: 50%;
  opacity: .25;
}
.mw-letter-stars {
  color: var(--mw-mustard); font-size: 17px; letter-spacing: .1em;
  margin-bottom: 10px;
}
.mw-letter-text {
  font-family: var(--mw-display); font-style: italic;
  font-size: 16px; line-height: 1.5;
  color: var(--mw-ink);
}
.mw-letter-signature {
  font-family: var(--mw-mono);
  font-size: 11px; letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--mw-muted);
  margin-top: 14px;
}

/* ===== Gift block — 4 unique variants ===== */
.mw-stencil {
  display: inline-flex; align-items: center;
  background: var(--mw-mustard); color: var(--mw-ink);
  padding: 3px 10px;
  font-family: var(--mw-mono);
  font-size: 11px; letter-spacing: .18em;
  text-transform: uppercase;
  border: 1px solid var(--mw-ink);
}

/* Variant 1: HOME — letterpress-style band */
.mw-gift--letter {
  background: var(--mw-parchment);
  padding: 80px 0;
  border-top: 6px double var(--mw-mustard);
  border-bottom: 6px double var(--mw-mustard);
  position: relative;
}
.mw-gift-letter {
  display: grid;
  grid-template-columns: 1fr 1.3fr;
  gap: 50px;
  align-items: center;
}
@media (max-width: 880px) { .mw-gift-letter { grid-template-columns: 1fr; } }
.mw-gift-letter-photo {
  position: relative;
  aspect-ratio: 4/5;
  overflow: hidden;
  border: 1px solid var(--mw-rule);
  padding: 8px;
  background: var(--mw-cream);
}
.mw-gift-letter-photo img { width: 100%; height: 100%; object-fit: cover; }
.mw-gift-letter-photo::after {
  content: ''; position: absolute; inset: 14px;
  border: 1px solid rgba(217,160,91,.55);
  pointer-events: none;
}
.mw-gift-letter-photo-tag {
  position: absolute; bottom: 16px; left: 16px;
  background: var(--mw-ink); color: var(--mw-mustard);
  padding: 6px 12px;
  font-family: var(--mw-mono);
  font-size: 11px; letter-spacing: .18em; text-transform: uppercase;
}
.mw-gift-letter-text { display: flex; flex-direction: column; gap: 14px; }
.mw-gift-letter-text h2 { font-style: italic; }
.mw-gift-letter-text h2 em {
  background: var(--mw-mustard); color: var(--mw-ink);
  padding: 0 12px; font-style: normal;
  display: inline-block; line-height: 1.1;
}
.mw-gift-list {
  margin-top: 12px;
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px;
}
@media (max-width: 660px) { .mw-gift-list { grid-template-columns: 1fr; } }
.mw-gift-list-item {
  display: flex; flex-direction: column; gap: 4px;
  padding-left: 16px;
  border-left: 2px solid var(--mw-mustard);
}
.mw-gift-list-item strong {
  font-family: var(--mw-display); font-size: 16px;
  color: var(--mw-green);
}
.mw-gift-list-item span {
  font-family: var(--mw-body); font-size: 13px;
  color: var(--mw-ink-soft);
}

/* Variant 2: TRIPTYCHON for category cloak */
.mw-gift--triptychon {
  background: var(--mw-paper-bg-dim);
  background-attachment: fixed;
  padding: 80px 0;
}
.mw-gift-tri-head { text-align: center; max-width: 60ch; margin: 0 auto 40px; }
.mw-gift-tri {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px;
}
@media (max-width: 880px) { .mw-gift-tri { grid-template-columns: 1fr; max-width: 380px; margin: 0 auto; } }
.mw-gift-tri-card {
  background: var(--mw-cream);
  border: 1px solid var(--mw-rule);
  padding: 12px;
  display: flex; flex-direction: column;
  position: relative;
}
.mw-gift-tri-card::before {
  content: ''; position: absolute; top: 4px; left: 4px; right: 4px; bottom: 4px;
  border: 1px solid var(--mw-mustard);
  pointer-events: none;
}
.mw-gift-tri-card-img {
  aspect-ratio: 4/3; overflow: hidden; margin-bottom: 14px;
  position: relative; z-index: 1;
}
.mw-gift-tri-card-img img { width: 100%; height: 100%; object-fit: cover; }
.mw-gift-tri-card-body { padding: 6px 8px 12px; position: relative; z-index: 1; }
.mw-gift-tri-card-body h3 {
  font-family: var(--mw-display); font-style: italic;
  font-size: 22px; font-weight: 500;
  color: var(--mw-green); margin: 6px 0 10px;
}
.mw-gift-tri-card-body p {
  font-family: var(--mw-body); font-size: 13px; line-height: 1.55;
  color: var(--mw-ink); margin: 0;
}

/* Variant 3: EDITORIAL for product cloak */
.mw-gift--editorial {
  background: var(--mw-green);
  color: var(--mw-parchment);
  padding: 80px 0;
}
.mw-gift-edit {
  display: grid; grid-template-columns: 1fr 1.1fr; gap: 50px;
  align-items: stretch;
}
@media (max-width: 880px) { .mw-gift-edit { grid-template-columns: 1fr; } }
.mw-gift-edit-photo {
  position: relative;
  min-height: 360px;
  border: 1px solid var(--mw-mustard);
  overflow: hidden;
}
.mw-gift-edit-photo img { width: 100%; height: 100%; min-height: 360px; object-fit: cover; }
.mw-gift-edit-stamp {
  position: absolute; bottom: 14px; left: 14px; right: 14px;
  background: rgba(15,36,25,.92);
  border: 1px solid var(--mw-mustard);
  padding: 14px 18px;
}
.mw-gift-edit-stamp strong {
  display: block;
  font-family: var(--mw-display); font-style: italic;
  font-size: 19px; color: var(--mw-mustard);
}
.mw-gift-edit-stamp span {
  font-family: var(--mw-mono); font-size: 11px;
  letter-spacing: .14em; color: rgba(249,246,240,.7);
}
.mw-gift-edit-text { display: flex; flex-direction: column; gap: 14px; justify-content: center; }
.mw-gift-edit-text h2 { color: var(--mw-mustard); }
.mw-gift-edit-text h2 em {
  background: var(--mw-mustard); color: var(--mw-green-d);
  padding: 0 10px; font-style: normal;
}
.mw-gift-edit-text p { font-family: var(--mw-body); font-size: 15px; line-height: 1.65; }
.mw-gift-edit-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 6px; }
.mw-gift-edit-tags span {
  background: var(--mw-green-d); color: var(--mw-mustard);
  border: 1px solid var(--mw-mustard);
  padding: 5px 11px;
  font-family: var(--mw-mono);
  font-size: 10px; letter-spacing: .16em; text-transform: uppercase;
}

/* Variant 4: PORTAL (gift cloak hero) */
.mw-gift--portal {
  background: var(--mw-ink);
  position: relative;
  overflow: hidden;
}
.mw-gift-portal {
  position: relative;
  min-height: 460px;
  display: flex; align-items: center;
}
.mw-gift-portal img {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover;
  filter: brightness(.5) sepia(.2);
}
.mw-gift-portal::after {
  content: ''; position: absolute; inset: 0;
  background:
    linear-gradient(90deg, rgba(17,22,37,.92) 0%, rgba(17,22,37,.45) 70%, rgba(17,22,37,.1) 100%);
}
.mw-gift-portal-inner {
  position: relative; z-index: 2;
  padding: 60px 28px;
  max-width: 720px; color: var(--mw-parchment);
  display: flex; flex-direction: column; gap: 18px;
}
.mw-gift-portal-inner h2 { color: var(--mw-parchment); }
.mw-gift-portal-inner h2 em {
  background: var(--mw-mustard); color: var(--mw-ink);
  padding: 2px 14px; font-style: normal;
}
.mw-gift-portal-inner p { font-family: var(--mw-body); }

/* ===== Long-form / legal pages ===== */
.mw-paper {
  background: var(--mw-cream);
  border: 1px solid var(--mw-rule);
  padding: 48px 44px;
  position: relative;
  max-width: 820px; margin: 0 auto;
}
.mw-paper::before {
  content: ''; position: absolute; inset: 10px;
  border: 1px solid var(--mw-mustard);
  pointer-events: none;
}
.mw-paper > * { position: relative; z-index: 1; }
.mw-paper h1 {
  font-family: var(--mw-display);
  font-size: clamp(30px, 4vw, 44px);
  font-style: italic;
  color: var(--mw-green);
  margin: 0 0 22px;
}
.mw-paper h2 {
  font-family: var(--mw-display);
  font-size: 22px; font-weight: 500;
  color: var(--mw-green);
  margin: 30px 0 12px;
}
.mw-paper h3 {
  font-family: var(--mw-display);
  font-size: 18px; font-style: italic; font-weight: 500;
  color: var(--mw-mustard-d);
  margin: 22px 0 8px;
}
.mw-paper p, .mw-paper li {
  font-family: var(--mw-body); font-size: 15px;
  line-height: 1.75; color: var(--mw-ink);
}
.mw-paper ul { padding-left: 22px; list-style: '— ' outside; }
.mw-paper ul li { margin-bottom: 6px; padding-left: 4px; }
.mw-paper a:not(.mw-btn) {
  color: var(--mw-mustard-d); text-decoration: underline;
  text-underline-offset: 3px;
}
.mw-paper a:not(.mw-btn):hover { color: var(--mw-green); }
.mw-paper strong { color: var(--mw-green); }
@media (max-width: 540px) { .mw-paper { padding: 28px 22px; } }

/* ===== Toast & cookies ===== */
.mw-toast {
  position: fixed; bottom: 26px; right: 26px;
  background: var(--mw-green); color: var(--mw-mustard);
  border: 1px solid var(--mw-mustard);
  padding: 14px 20px;
  font-family: var(--mw-display); font-style: italic;
  font-size: 15px;
  box-shadow: 6px 6px 0 var(--mw-ink);
  z-index: 1000;
  opacity: 0; transform: translateY(10px);
  transition: opacity .18s, transform .18s;
}
.mw-toast.is-in { opacity: 1; transform: translateY(0); }
.mw-toast--err { background: #B6403A; color: var(--mw-parchment); border-color: var(--mw-parchment); }

.mw-cookie {
  position: fixed; left: 0; right: 0; bottom: 0;
  background: var(--mw-green-d); color: var(--mw-parchment);
  border-top: 4px solid var(--mw-mustard);
  padding: 20px 28px;
  display: none; z-index: 999;
}
.mw-cookie.is-show { display: block; }
.mw-cookie-inner {
  max-width: 1180px; margin: 0 auto;
  display: grid; grid-template-columns: 1fr auto;
  gap: 24px; align-items: center;
}
.mw-cookie p {
  margin: 0; font-family: var(--mw-body); font-size: 14px;
  color: rgba(249,246,240,.78);
}
.mw-cookie p a { color: var(--mw-mustard); text-decoration: underline; }
.mw-cookie-actions { display: flex; gap: 10px; }
.mw-cookie-actions .mw-btn { padding: 10px 20px; font-size: 14px; }
@media (max-width: 660px) {
  .mw-cookie-inner { grid-template-columns: 1fr; }
  .mw-cookie-actions { flex-direction: column; }
  .mw-cookie-actions .mw-btn { width: 100%; justify-content: center; }
}

/* ===== Slider — auto-rotating cabinet showcase ===== */
.mw-showcase {
  background: var(--mw-green);
  border-top: 6px double var(--mw-mustard);
  border-bottom: 6px double var(--mw-mustard);
  position: relative;
  overflow: hidden;
}
.mw-showcase-track {
  display: flex;
  transition: transform .6s cubic-bezier(.22,.61,.36,1);
  height: clamp(320px, 40vw, 500px);
}
.mw-showcase-slide {
  flex: 0 0 100%; width: 100%; height: 100%;
  position: relative; overflow: hidden;
}
.mw-showcase-slide img {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover;
  filter: sepia(.15) contrast(1.05) brightness(.55);
}
.mw-showcase-slide::after {
  content: ''; position: absolute; inset: 0;
  background:
    linear-gradient(90deg, rgba(15,36,25,.92) 0%, rgba(15,36,25,.4) 70%, rgba(15,36,25,.1) 100%);
}
.mw-showcase-inner {
  position: relative; z-index: 2;
  max-width: 1180px; margin: 0 auto;
  height: 100%; padding: 0 80px;
  display: flex; flex-direction: column; justify-content: center;
  gap: 14px;
}
.mw-showcase-inner h2 {
  font-family: var(--mw-display);
  font-size: clamp(28px, 4.2vw, 50px);
  font-style: italic; font-weight: 500;
  color: var(--mw-parchment);
  margin: 0; max-width: 24ch;
}
.mw-showcase-inner h2 em {
  background: var(--mw-mustard); color: var(--mw-ink);
  padding: 0 10px; font-style: normal;
}
.mw-showcase-inner p {
  font-family: var(--mw-body); font-size: 15px;
  color: var(--mw-parchment); max-width: 52ch; line-height: 1.55;
}
.mw-showcase-arrows {
  position: absolute; top: 50%; left: 0; right: 0;
  display: flex; justify-content: space-between;
  pointer-events: none; transform: translateY(-50%);
  padding: 0 14px; z-index: 3;
}
.mw-showcase-arrow {
  pointer-events: auto;
  background: rgba(15,36,25,.72); border: 1px solid var(--mw-mustard);
  color: var(--mw-mustard);
  width: 36px; height: 60px;
  display: grid; place-items: center;
  cursor: pointer;
  font-family: var(--mw-display); font-size: 22px;
}
.mw-showcase-arrow:hover { background: var(--mw-mustard); color: var(--mw-green); }
.mw-showcase-dots {
  position: absolute; left: 0; right: 0; bottom: 22px;
  display: flex; justify-content: center; gap: 8px;
  z-index: 3;
}
.mw-showcase-dot {
  width: 26px; height: 3px;
  background: rgba(249,246,240,.3); border: 0; cursor: pointer; padding: 0;
}
.mw-showcase-dot.is-active { background: var(--mw-mustard); }
@media (max-width: 660px) {
  .mw-showcase-arrows { display: none; }
  .mw-showcase-inner { padding: 0 22px; }
}

/* ===== Cart / checkout helpers ===== */
.mw-cart-layout { display: grid; grid-template-columns: 1.5fr 1fr; gap: 36px; align-items: start; }
@media (max-width: 880px) { .mw-cart-layout { grid-template-columns: 1fr; } }
.mw-cart-table { width: 100%; border-collapse: collapse; background: var(--mw-cream); border: 1px solid var(--mw-rule); }
.mw-cart-table th { text-align: left; font-family: var(--mw-display); font-size: 13px; font-style: italic; color: var(--mw-green); padding: 14px; border-bottom: 1px solid var(--mw-rule); }
.mw-cart-table td { padding: 12px 14px; border-bottom: 1px solid var(--mw-rule); font-size: 14px; vertical-align: middle; }
.mw-cart-thumb { width: 60px; height: 60px; object-fit: cover; border: 1px solid var(--mw-rule); }
.mw-summary { background: var(--mw-cream); border: 1px solid var(--mw-rule); padding: 28px; position: relative; }
.mw-summary::before { content: ''; position: absolute; inset: 8px; border: 1px solid var(--mw-mustard); pointer-events: none; }
.mw-summary > * { position: relative; }
.mw-summary h3 { font-family: var(--mw-display); font-style: italic; color: var(--mw-green); margin: 0 0 14px; }
.mw-summary-row { display: flex; justify-content: space-between; padding: 8px 0; font-family: var(--mw-body); font-size: 14px; }
.mw-summary-row--total { border-top: 2px solid var(--mw-mustard); margin-top: 12px; padding-top: 14px; font-family: var(--mw-display); font-size: 22px; color: var(--mw-green); }
/* ============================================================
   ANTI-COPYPASTA REWRITE — letterhead, drawers, museum-labels, news-front-page
   ============================================================ */

.sr-only { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }

/* --- Top strap --- */
.mw-strap { background: var(--mw-green-d); color: var(--mw-parchment); font-family: var(--mw-mono); font-size: 11px; letter-spacing: .14em; }
.mw-strap-inner { display:grid; grid-template-columns: 1fr auto 1fr; gap:18px; align-items:center; padding: 9px 28px; }
.mw-strap-tag { color: var(--mw-mustard); text-transform: uppercase; }
.mw-strap-mid { text-align:center; opacity:.78; }
.mw-strap-right { display:flex; gap:14px; justify-content:flex-end; }
.mw-strap-pocket { color: var(--mw-parchment); display:inline-flex; align-items:baseline; gap:4px; padding: 2px 6px; border-bottom: 1px dotted rgba(217,160,91,.4); transition: color .15s; }
.mw-strap-pocket:hover { color: var(--mw-mustard); }
.mw-strap-pocket sup { font-size: 10px; color: var(--mw-mustard); }
.mw-strap-pocket.has-items { color: var(--mw-mustard); border-bottom-color: var(--mw-mustard); }
@media (max-width: 760px) { .mw-strap-inner { grid-template-columns: 1fr 1fr; gap:8px; } .mw-strap-mid { display:none; } }

/* --- Letterhead header --- */
.mw-letterhead {
  background: var(--mw-parchment);
  background-image:
    radial-gradient(ellipse 60% 40% at 50% 0%, rgba(217,160,91,.08) 0%, transparent 70%),
    repeating-linear-gradient(90deg, rgba(17,22,37,.012) 0 1px, transparent 1px 3px);
  border-bottom: 1px solid var(--mw-rule);
  padding: 22px 0 0;
  position: relative;
}
.mw-letterhead .mw-wrap { display: flex; flex-direction: column; align-items: center; gap: 18px; }
.mw-stamp { display: flex; flex-direction: column; align-items: center; gap: 6px; text-decoration: none; color: var(--mw-ink); text-align: center; }
.mw-stamp-flourish { font-family: var(--mw-display); font-style: italic; font-size: 14px; letter-spacing: .4em; color: var(--mw-mustard); }
.mw-stamp-line { font-family: var(--mw-display); font-weight: 500; font-size: clamp(36px, 5.4vw, 60px); line-height: 1; letter-spacing: -.01em; color: var(--mw-green); }
.mw-stamp-line .amp { font-style: italic; color: var(--mw-mustard); font-weight: 400; padding: 0 4px; }
.mw-stamp-sub { font-family: var(--mw-body); font-size: 13px; font-style: italic; color: var(--mw-muted); max-width: 56ch; }
.mw-stamp-sub em { color: var(--mw-mustard-d); font-style: italic; }
.mw-stamp-rule { width: 240px; height: 1px; background: var(--mw-mustard); position: relative; margin: 8px 0 0; }
.mw-stamp-rule::before, .mw-stamp-rule::after { content: "\25C6"; position: absolute; top: 50%; transform: translateY(-50%); color: var(--mw-mustard); font-size: 9px; background: var(--mw-parchment); padding: 0 6px; }
.mw-stamp-rule::before { left: -10px; }
.mw-stamp-rule::after { right: -10px; }

.mw-letterhead-nav { display: flex; gap: 0; flex-wrap: wrap; justify-content: center; font-family: var(--mw-display); font-size: 16px; border-top: 1px solid var(--mw-rule); border-bottom: 1px solid var(--mw-rule); width: 100%; padding: 12px 0; }
.mw-letterhead-nav a { padding: 4px 18px; color: var(--mw-ink-soft); text-decoration: none; border-right: 1px dotted rgba(17,22,37,.18); transition: color .15s; position: relative; }
.mw-letterhead-nav a:last-child { border-right: none; }
.mw-letterhead-nav a:hover { color: var(--mw-green); }
.mw-letterhead-nav a.is-here { color: var(--mw-mustard-d); font-style: italic; }
.mw-letterhead-nav a.is-here::after { content: "\00B7"; position: absolute; bottom: -16px; left: 50%; transform: translateX(-50%); color: var(--mw-mustard); font-size: 20px; }
.mw-letterhead-toggle { display: none; position: absolute; top: 30px; right: 24px; background: none; border: 1px solid var(--mw-rule); padding: 9px 11px; flex-direction: column; gap: 3px; }
.mw-letterhead-toggle span { width: 18px; height: 1.5px; background: var(--mw-ink); display: block; }
@media (max-width: 820px) {
  .mw-letterhead-toggle { display: flex; }
  .mw-letterhead-nav { display: none; flex-direction: column; padding: 0; border-top:none; }
  .mw-letterhead-nav.is-open { display: flex; }
  .mw-letterhead-nav a { border-right: none; border-bottom: 1px dotted rgba(17,22,37,.14); padding: 12px 18px; text-align: center; }
}

/* ===== Frontispiece — newspaper-front-page layout ===== */
.mw-frontispiece { display: grid; grid-template-columns: 1.2fr 1fr; gap: 48px; padding: 56px 0 64px; border-bottom: 2px solid var(--mw-mustard); position: relative; }
.mw-frontispiece::after { content: ""; position: absolute; left: 0; right: 0; bottom: -6px; height: 1px; background: var(--mw-mustard); }
.mw-frontispiece-text { display: flex; flex-direction: column; }
.mw-frontispiece-eyebrow { font-family: var(--mw-mono); font-size: 10.5px; letter-spacing: .32em; text-transform: uppercase; color: var(--mw-mustard-d); margin-bottom: 18px; display: inline-flex; gap: 12px; align-items: center; }
.mw-frontispiece-eyebrow::before { content: ""; width: 28px; height: 1px; background: var(--mw-mustard); }
.mw-frontispiece-title { font-family: var(--mw-display); font-weight: 500; font-size: clamp(36px, 5vw, 64px); line-height: 1.04; letter-spacing: -.012em; color: var(--mw-green); margin: 0 0 22px; }
.mw-frontispiece-title em { font-style: italic; color: var(--mw-mustard-d); }
.mw-frontispiece-byline { font-family: var(--mw-body); font-size: 14px; font-style: italic; color: var(--mw-muted); margin: 0 0 24px; padding-bottom: 18px; border-bottom: 1px dotted var(--mw-rule); }
.mw-frontispiece-columns { column-count: 2; column-gap: 28px; column-rule: 1px dotted var(--mw-rule); font-family: var(--mw-body); font-size: 15px; line-height: 1.7; }
.mw-frontispiece-columns p { margin: 0 0 12px; }
.mw-frontispiece-columns p:first-letter { font-family: var(--mw-display); font-size: 48px; line-height: 38px; float: left; padding: 4px 8px 0 0; color: var(--mw-mustard-d); font-weight: 500; }
.mw-frontispiece-aside { position: relative; }
.mw-frontispiece-photo { position: relative; aspect-ratio: 4/5; background: var(--mw-cream); padding: 10px; border: 1px solid var(--mw-rule); box-shadow: 8px 8px 0 var(--mw-mustard); }
.mw-frontispiece-photo img { width: 100%; height: 100%; object-fit: cover; filter: sepia(.15) saturate(.85); }
.mw-frontispiece-caption { margin-top: 18px; padding: 14px; background: var(--mw-paper-bg-dim); border-left: 3px solid var(--mw-mustard); font-family: var(--mw-display); font-style: italic; font-size: 16px; color: var(--mw-ink-soft); }
@media (max-width: 820px) { .mw-frontispiece { grid-template-columns: 1fr; gap: 32px; } .mw-frontispiece-columns { column-count: 1; } }

/* ===== Card of the week ===== */
.mw-cardweek { margin: 64px 0; border: 1px solid var(--mw-rule); background: var(--mw-cream); padding: 18px; position: relative; }
.mw-cardweek::before { content: "Card-index of the week"; position: absolute; top: -10px; left: 24px; background: var(--mw-parchment); padding: 0 12px; font-family: var(--mw-mono); font-size: 10px; letter-spacing: .26em; text-transform: uppercase; color: var(--mw-mustard-d); }
.mw-cardweek-inner { display: grid; grid-template-columns: 280px 1fr auto; gap: 32px; align-items: center; background: var(--mw-parchment); padding: 28px; border: 1px solid var(--mw-mustard); }
.mw-cardweek-photo { aspect-ratio: 1/1; border: 1px solid var(--mw-rule); overflow: hidden; }
.mw-cardweek-photo img { width: 100%; height: 100%; object-fit: cover; }
.mw-cardweek-body { display: flex; flex-direction: column; gap: 10px; }
.mw-cardweek-serial { font-family: var(--mw-mono); font-size: 11px; letter-spacing: .2em; text-transform: uppercase; color: var(--mw-muted); }
.mw-cardweek-title { font-family: var(--mw-display); font-size: 32px; font-weight: 500; color: var(--mw-green); margin: 0; }
.mw-cardweek-meta { display: flex; gap: 18px; font-family: var(--mw-mono); font-size: 11px; color: var(--mw-muted); letter-spacing: .12em; text-transform: uppercase; }
.mw-cardweek-desc { font-family: var(--mw-body); font-size: 15px; line-height: 1.6; color: var(--mw-ink-soft); margin: 6px 0 0; }
.mw-cardweek-side { display: flex; flex-direction: column; gap: 10px; align-items: flex-end; min-width: 140px; }
.mw-cardweek-price { font-family: var(--mw-display); font-size: 32px; color: var(--mw-green); }
@media (max-width: 760px) { .mw-cardweek-inner { grid-template-columns: 1fr; } .mw-cardweek-side { align-items: flex-start; } }

/* ===== Drawer-index ===== */
.mw-drawers { display: flex; flex-direction: column; gap: 0; border-top: 2px solid var(--mw-green); border-bottom: 2px solid var(--mw-green); }
.mw-drawer { display: grid; grid-template-columns: 90px 140px 1fr auto auto; gap: 24px; align-items: center; padding: 18px; text-decoration: none; border-bottom: 1px solid var(--mw-rule); background: var(--mw-paper-bg); color: var(--mw-ink); transition: background .15s; position: relative; }
.mw-drawer-thumb { width: 140px; height: 90px; overflow: hidden; border: 1px solid var(--mw-rule); background: var(--mw-paper-bg-dim); }
.mw-drawer-thumb img { width: 100%; height: 100%; object-fit: cover; filter: sepia(.2) saturate(.85); transition: filter .15s, transform .15s; }
.mw-drawer:hover .mw-drawer-thumb img { filter: none; transform: scale(1.05); }
@media (max-width: 760px) { .mw-drawer { grid-template-columns: 60px 1fr auto; } .mw-drawer-thumb { display: none; } }
.mw-drawer:last-child { border-bottom: none; }
.mw-drawer:hover { background: var(--mw-cream); }
.mw-drawer-num { font-family: var(--mw-display); font-size: 38px; font-weight: 500; font-style: italic; color: var(--mw-mustard); text-align: center; }
.mw-drawer-text { display: flex; flex-direction: column; gap: 4px; }
.mw-drawer-name { font-family: var(--mw-display); font-size: 26px; color: var(--mw-green); margin: 0; }
.mw-drawer-desc { font-family: var(--mw-body); font-size: 14px; color: var(--mw-muted); font-style: italic; }
.mw-drawer-count { font-family: var(--mw-mono); font-size: 11px; letter-spacing: .18em; text-transform: uppercase; color: var(--mw-ink-soft); padding: 5px 12px; border: 1px dotted var(--mw-rule); background: var(--mw-cream); }
.mw-drawer-handle { width: 28px; height: 28px; border-radius: 50%; border: 2px solid var(--mw-mustard); display: flex; align-items: center; justify-content: center; color: var(--mw-mustard-d); font-family: var(--mw-display); font-size: 18px; transition: background .15s, color .15s; }
.mw-drawer:hover .mw-drawer-handle { background: var(--mw-mustard); color: var(--mw-parchment); }
@media (max-width: 640px) { .mw-drawer-handle { display: none; } .mw-drawer-num { font-size: 26px; } .mw-drawer-name { font-size: 20px; } }

/* ===== Museum-label list ===== */
.mw-labels { display: flex; flex-direction: column; gap: 0; border-top: 1px solid var(--mw-rule); }
.mw-label { display: grid; grid-template-columns: 110px minmax(0, 1fr) auto; gap: 24px; align-items: start; padding: 22px 14px; border-bottom: 1px solid var(--mw-rule); background: var(--mw-paper-bg); text-decoration: none; color: var(--mw-ink); transition: background .15s, transform .15s; position: relative; }
.mw-label:hover { background: var(--mw-cream); transform: translateX(2px); }
.mw-label.is-oos { opacity: .6; }
.mw-label-shot { position: relative; width: 110px; height: 110px; flex: 0 0 110px; overflow: hidden; background: var(--mw-paper-bg-dim); border: 1px solid var(--mw-rule); }
.mw-label-shot img { display: block; width: 100%; height: 100%; max-width: 100%; object-fit: cover; }
.mw-label-tag { position: absolute; bottom: 0; left: 0; background: var(--mw-mustard); color: var(--mw-ink); font-family: var(--mw-mono); font-size: 9.5px; letter-spacing: .18em; text-transform: uppercase; padding: 3px 8px; }
.mw-label-info { display: flex; flex-direction: column; justify-content: center; gap: 8px; }
.mw-label-serial { font-family: var(--mw-mono); font-size: 11px; letter-spacing: .2em; text-transform: uppercase; color: var(--mw-mustard-d); }
.mw-label-name { font-family: var(--mw-display); font-size: 22px; font-weight: 500; color: var(--mw-green); margin: 0; line-height: 1.2; }
.mw-label-meta { font-family: var(--mw-body); font-size: 13px; color: var(--mw-muted); font-style: italic; }
.mw-label-desc { font-family: var(--mw-body); font-size: 14px; color: var(--mw-ink-soft); line-height: 1.55; margin: 4px 0 0; max-width: 64ch; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; text-overflow: ellipsis; }
.mw-label-side { display: flex; flex-direction: column; justify-content: center; align-items: flex-end; gap: 10px; min-width: 140px; }
.mw-label-price { font-family: var(--mw-display); font-size: 24px; font-weight: 500; color: var(--mw-green); }
.mw-label-price-was { font-family: var(--mw-body); font-size: 14px; color: var(--mw-muted); text-decoration: line-through; }
.mw-label-add { background: none; border: 1px solid var(--mw-mustard); color: var(--mw-mustard-d); padding: 6px 14px; font-family: var(--mw-mono); font-size: 10.5px; letter-spacing: .18em; text-transform: uppercase; cursor: pointer; transition: background .15s, color .15s; }
.mw-label-add:hover { background: var(--mw-mustard); color: var(--mw-parchment); }
@media (max-width: 760px) { .mw-label { grid-template-columns: 70px minmax(0, 1fr); gap: 16px; padding: 18px 10px; } .mw-label-shot { width: 70px; height: 70px; flex-basis: 70px; } .mw-label-side { grid-column: 1 / -1; align-items: flex-start; flex-direction: row; justify-content: space-between; min-width: 0; margin-top: 6px; } .mw-label-name { font-size: 18px; } .mw-label-desc { font-size: 13px; -webkit-line-clamp: 3; } }

/* ===== Bench labels ===== */
.mw-bench { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 28px; padding: 12px 8px; }
.mw-bench-tag { background: var(--mw-cream); border: 1px solid var(--mw-rule); padding: 14px; position: relative; text-decoration: none; color: var(--mw-ink); transform: rotate(-.6deg); }
.mw-bench-tag:nth-child(2n) { transform: rotate(.7deg); }
.mw-bench-tag:nth-child(3n) { transform: rotate(-.4deg); }
.mw-bench-tag::before { content: ""; position: absolute; top: -8px; left: 18px; width: 60px; height: 14px; background: rgba(217,160,91,.55); transform: rotate(-3deg); border: 1px dashed rgba(176,127,61,.5); }
.mw-bench-photo { aspect-ratio: 4/3; overflow: hidden; border: 1px solid var(--mw-rule); margin-bottom: 12px; }
.mw-bench-photo img { width: 100%; height: 100%; object-fit: cover; }
.mw-bench-name { font-family: var(--mw-display); font-size: 18px; color: var(--mw-green); margin: 0 0 6px; }
.mw-bench-desc { font-family: var(--mw-body); font-size: 12.5px; line-height: 1.45; color: var(--mw-ink-soft); font-style: italic; margin: 0 0 8px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; text-overflow: ellipsis; max-height: 2.9em; }
.mw-bench-row { display: flex; justify-content: space-between; align-items: center; font-family: var(--mw-mono); font-size: 11px; color: var(--mw-muted); letter-spacing: .14em; text-transform: uppercase; }
.mw-bench-row strong { font-family: var(--mw-display); font-size: 18px; color: var(--mw-mustard-d); letter-spacing: 0; text-transform: none; font-weight: 500; }

/* ===== Section rule header ===== */
.mw-rule { display: grid; grid-template-columns: 1fr auto 1fr; gap: 16px; align-items: center; margin: 0 0 28px; }
.mw-rule::before, .mw-rule::after { content: ""; height: 1px; background: var(--mw-rule); }
.mw-rule-text { font-family: var(--mw-display); font-style: italic; font-size: 22px; color: var(--mw-green); padding: 0 12px; white-space: nowrap; }

/* ===== Customer letters as mail pieces ===== */
.mw-mail { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; padding: 12px 0; }
.mw-mail-piece { background: var(--mw-paper-bg); border: 1px solid var(--mw-rule); padding: 24px 22px; position: relative; font-family: var(--mw-body); font-size: 14px; line-height: 1.65; background-image: repeating-linear-gradient(0deg, rgba(17,22,37,.025) 0 1px, transparent 1px 22px); }
.mw-mail-piece::before { content: ""; position: absolute; top: 0; left: 0; width: 30px; height: 30px; background: linear-gradient(135deg, transparent 50%, var(--mw-paper-bg-dim) 50%); border-right: 1px solid var(--mw-rule); border-bottom: 1px solid var(--mw-rule); }
.mw-mail-postmark { font-family: var(--mw-mono); font-size: 10px; letter-spacing: .26em; text-transform: uppercase; color: var(--mw-mustard-d); margin-bottom: 12px; padding-bottom: 8px; border-bottom: 1px dotted var(--mw-rule); }
.mw-mail-body { margin: 0 0 16px; font-style: italic; color: var(--mw-ink-soft); }
.mw-mail-sign { font-family: var(--mw-display); font-size: 18px; font-style: italic; color: var(--mw-mustard-d); }
@media (max-width: 760px) { .mw-mail { grid-template-columns: 1fr; } }

/* ===== Appointment block ===== */
.mw-appointment { background: var(--mw-green); color: var(--mw-parchment); padding: 56px 48px; margin: 64px 0 0; display: grid; grid-template-columns: 1.2fr 1fr; gap: 48px; align-items: center; border: 1px solid var(--mw-mustard); position: relative; }
.mw-appointment::before { content: ""; position: absolute; inset: 10px; border: 1px dotted rgba(217,160,91,.4); pointer-events: none; }
.mw-appointment-text > * { position: relative; }
.mw-appointment h2 { font-family: var(--mw-display); font-size: clamp(28px, 3.4vw, 40px); color: var(--mw-parchment); margin: 0 0 14px; }
.mw-appointment h2 em { color: var(--mw-mustard); }
.mw-appointment-hours { background: rgba(249,246,240,.06); padding: 22px 24px; border: 1px solid rgba(217,160,91,.3); position: relative; }
.mw-appointment-hours dl { display: grid; grid-template-columns: 1fr auto; gap: 8px 18px; margin: 0; font-family: var(--mw-mono); font-size: 13px; letter-spacing: .1em; }
.mw-appointment-hours dt { color: var(--mw-mustard); text-transform: uppercase; font-size: 11px; letter-spacing: .18em; }
.mw-appointment-hours dd { margin: 0; color: var(--mw-parchment); }
.mw-appointment-hours-title { position: absolute; top: -12px; left: 18px; background: var(--mw-green); padding: 0 12px; font-family: var(--mw-display); font-style: italic; font-size: 16px; color: var(--mw-mustard); }
@media (max-width: 820px) { .mw-appointment { grid-template-columns: 1fr; padding: 40px 28px; } }

/* ===== Quarterly preview strip ===== */
.mw-quarterly-strip { padding: 12px 0; }
.mw-quarterly-set { display: grid; grid-template-columns: repeat(3, 1fr); gap: 36px; }
.mw-quarterly-piece { display: flex; flex-direction: column; gap: 10px; }
.mw-quarterly-piece-photo { aspect-ratio: 16/10; overflow: hidden; border: 1px solid var(--mw-rule); margin-bottom: 4px; background: var(--mw-paper-bg-dim); }
.mw-quarterly-piece-photo img { width: 100%; height: 100%; object-fit: cover; transition: transform .25s, filter .25s; filter: sepia(.18) saturate(.9); }
.mw-quarterly-piece-photo:hover img { transform: scale(1.04); filter: none; }
.mw-quarterly-piece-num { font-family: var(--mw-display); font-style: italic; font-size: 14px; color: var(--mw-mustard-d); letter-spacing: .1em; }
.mw-quarterly-piece-title { font-family: var(--mw-display); font-size: 22px; line-height: 1.18; color: var(--mw-green); margin: 0; }
.mw-quarterly-piece-title a { color: inherit; }
.mw-quarterly-piece-title a:hover { color: var(--mw-mustard-d); }
.mw-quarterly-piece-lede { font-family: var(--mw-body); font-size: 14.5px; color: var(--mw-ink-soft); margin: 0; line-height: 1.6; }
.mw-quarterly-piece-meta { font-family: var(--mw-mono); font-size: 10.5px; letter-spacing: .18em; text-transform: uppercase; color: var(--mw-muted); margin-top: auto; padding-top: 8px; border-top: 1px dotted var(--mw-rule); }
@media (max-width: 820px) { .mw-quarterly-set { grid-template-columns: 1fr; } }

/* ===== Alphabet strip ===== */
.mw-alphabet { display: flex; flex-wrap: wrap; gap: 0; margin: 0 0 36px; border-top: 1px solid var(--mw-mustard); border-bottom: 1px solid var(--mw-mustard); padding: 12px 0; justify-content: center; }
.mw-alphabet a, .mw-alphabet span { font-family: var(--mw-display); font-size: 18px; padding: 4px 10px; color: var(--mw-ink-soft); text-decoration: none; border-right: 1px dotted var(--mw-rule); }
.mw-alphabet a:hover { color: var(--mw-mustard-d); }
.mw-alphabet a.is-here { color: var(--mw-mustard-d); font-style: italic; }
.mw-alphabet span.is-empty { color: rgba(17,22,37,.2); }
.mw-alphabet *:last-child { border-right: none; }

/* ===== Product museum-label layout ===== */
.mw-pdp-label { background: var(--mw-cream); border: 1px solid var(--mw-rule); padding: 28px; position: relative; display: grid; grid-template-columns: 1.1fr 1fr; gap: 44px; }
.mw-pdp-label::before { content: ""; position: absolute; inset: 10px; border: 1px dotted var(--mw-mustard); pointer-events: none; }
.mw-pdp-label > * { position: relative; }
.mw-pdp-stamp { position: absolute; top: -14px; right: 28px; background: var(--mw-mustard); color: var(--mw-ink); font-family: var(--mw-mono); font-size: 10px; letter-spacing: .22em; text-transform: uppercase; padding: 5px 12px; }
.mw-pdp-figure { display: flex; flex-direction: column; gap: 16px; }
.mw-pdp-figure-main { aspect-ratio: 1/1; background: var(--mw-paper-bg); border: 1px solid var(--mw-rule); overflow: hidden; }
.mw-pdp-figure-main img { width: 100%; height: 100%; object-fit: cover; }
.mw-pdp-figure-strip { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; }
.mw-pdp-figure-strip button { aspect-ratio: 1/1; background: none; border: 1px solid var(--mw-rule); cursor: pointer; padding: 4px; overflow: hidden; }
.mw-pdp-figure-strip button.is-active { border-color: var(--mw-mustard); box-shadow: 0 0 0 1px var(--mw-mustard); }
.mw-pdp-figure-strip img { width: 100%; height: 100%; object-fit: cover; }
.mw-pdp-card { display: flex; flex-direction: column; gap: 14px; }
.mw-pdp-card-serial { font-family: var(--mw-mono); font-size: 11px; letter-spacing: .24em; text-transform: uppercase; color: var(--mw-muted); padding-bottom: 8px; border-bottom: 1px dotted var(--mw-rule); }
.mw-pdp-card-title { font-family: var(--mw-display); font-size: clamp(32px, 4vw, 46px); font-weight: 500; color: var(--mw-green); margin: 0; line-height: 1.05; letter-spacing: -.01em; }
.mw-pdp-card-sub { font-family: var(--mw-body); font-size: 14px; font-style: italic; color: var(--mw-muted); margin: -2px 0 0; }
.mw-pdp-card-body { font-family: var(--mw-body); font-size: 15px; line-height: 1.7; color: var(--mw-ink-soft); margin: 12px 0; }
.mw-pdp-card-table { width: 100%; border-collapse: collapse; font-family: var(--mw-body); font-size: 14px; margin: 12px 0; }
.mw-pdp-card-table tr { border-bottom: 1px dotted var(--mw-rule); }
.mw-pdp-card-table td:first-child { font-family: var(--mw-mono); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--mw-mustard-d); padding: 8px 16px 8px 0; width: 38%; vertical-align: top; }
.mw-pdp-card-table td:last-child { padding: 8px 0; color: var(--mw-ink); }
.mw-pdp-card-priceblock { display: flex; align-items: baseline; gap: 18px; padding: 16px 0; margin: 12px 0; border-top: 2px solid var(--mw-mustard); border-bottom: 2px solid var(--mw-mustard); }
.mw-pdp-card-price { font-family: var(--mw-display); font-size: 40px; font-weight: 500; color: var(--mw-green); }
.mw-pdp-card-actions { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; }
@media (max-width: 820px) { .mw-pdp-label { grid-template-columns: 1fr; padding: 22px; } }

/* ===== Letter from Eleanor ===== */
.mw-letter-block { background: var(--mw-cream); background-image: repeating-linear-gradient(0deg, rgba(17,22,37,.025) 0 1px, transparent 1px 28px); border: 1px solid var(--mw-rule); padding: 40px 48px 32px; position: relative; margin: 48px auto; max-width: 800px; }
.mw-letter-block::before { content: ""; position: absolute; top: 0; bottom: 0; left: 38px; width: 1px; background: rgba(184,40,40,.18); }
.mw-letter-head { font-family: var(--mw-mono); font-size: 11px; letter-spacing: .18em; text-transform: uppercase; color: var(--mw-mustard-d); margin-bottom: 16px; display: flex; justify-content: space-between; padding-bottom: 14px; border-bottom: 1px dashed rgba(17,22,37,.18); }
.mw-letter-block h3 { font-family: var(--mw-display); font-style: italic; font-size: 26px; color: var(--mw-green); margin: 0 0 18px; font-weight: 500; }
.mw-letter-block p { font-family: var(--mw-body); font-size: 16px; line-height: 1.85; color: var(--mw-ink-soft); margin: 0 0 16px; }
.mw-letter-sign { text-align: right; font-family: var(--mw-display); font-style: italic; font-size: 22px; color: var(--mw-mustard-d); margin-top: 32px; }

/* ===== Gift receipt-style block ===== */
.mw-giftnew { margin: 56px 0; padding: 48px 0; background: var(--mw-paper-bg-dim); border-top: 1px solid var(--mw-rule); border-bottom: 1px solid var(--mw-rule); position: relative; }
.mw-giftnew::before, .mw-giftnew::after { content: ""; position: absolute; left: 0; right: 0; height: 6px; background: repeating-linear-gradient(45deg, var(--mw-mustard) 0 8px, transparent 8px 16px); opacity: .35; }
.mw-giftnew::before { top: 0; }
.mw-giftnew::after { bottom: 0; }
.mw-giftnew-receipt { max-width: 720px; margin: 0 auto; padding: 36px 40px; background: var(--mw-cream); border: 1px solid var(--mw-rule); box-shadow: 0 8px 20px rgba(17,22,37,.06); position: relative; }
.mw-giftnew-receipt::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 8px; background: repeating-linear-gradient(90deg, var(--mw-mustard) 0 12px, transparent 12px 18px); opacity: .55; }
.mw-giftnew-stamp { display: inline-block; padding: 6px 14px; border: 2px dotted var(--mw-mustard); font-family: var(--mw-mono); font-size: 10.5px; letter-spacing: .22em; text-transform: uppercase; color: var(--mw-mustard-d); margin-bottom: 16px; }
.mw-giftnew-title { font-family: var(--mw-display); font-size: clamp(28px, 3.4vw, 38px); font-weight: 500; color: var(--mw-green); margin: 0 0 14px; line-height: 1.1; }
.mw-giftnew-title em { color: var(--mw-mustard-d); }
.mw-giftnew-lede { font-family: var(--mw-body); font-size: 16px; line-height: 1.7; color: var(--mw-ink-soft); margin: 0 0 18px; }
.mw-giftnew-list { list-style: none; padding: 0; margin: 18px 0 0; font-family: var(--mw-body); font-size: 14.5px; line-height: 1.6; border-top: 1px dotted var(--mw-rule); }
.mw-giftnew-list li { display: grid; grid-template-columns: 80px 1fr; gap: 16px; align-items: baseline; padding: 12px 0; border-bottom: 1px dotted var(--mw-rule); }
.mw-giftnew-list li b { font-family: var(--mw-mono); font-size: 10.5px; letter-spacing: .2em; text-transform: uppercase; color: var(--mw-mustard-d); font-weight: 400; }
.mw-giftnew-foot { margin-top: 22px; padding-top: 16px; border-top: 1px dashed var(--mw-rule); font-family: var(--mw-mono); font-size: 11px; letter-spacing: .18em; text-transform: uppercase; color: var(--mw-muted); text-align: center; }

/* ===== Page banner ===== */
.mw-page-banner { text-align: center; padding: 64px 0 32px; position: relative; }
.mw-page-banner .mw-eyebrow { margin-bottom: 16px; }
.mw-page-banner h1 { font-family: var(--mw-display); font-weight: 500; font-size: clamp(36px, 4.6vw, 56px); margin: 0; color: var(--mw-green); }
.mw-page-banner h1 em { color: var(--mw-mustard-d); }
.mw-page-banner .mw-lead { max-width: 64ch; margin: 18px auto 0; font-size: 17px; }
/* ============================================================
   Extras — full-bleed photo slider, sale theatre, product strips
   ============================================================ */

/* --- Marquee strip with running sale text --- */
.mw-marquee {
  background: var(--mw-mustard);
  color: var(--mw-ink);
  padding: 10px 0;
  overflow: hidden;
  border-top: 1px solid var(--mw-mustard-d);
  border-bottom: 1px solid var(--mw-mustard-d);
  position: relative;
}
.mw-marquee-track {
  display: flex;
  gap: 0;
  animation: mw-marquee 28s linear infinite;
  white-space: nowrap;
  width: max-content;
}
.mw-marquee-item {
  font-family: var(--mw-mono);
  font-size: 12px;
  letter-spacing: .24em;
  text-transform: uppercase;
  padding: 0 32px;
  border-right: 1px solid rgba(17,22,37,.25);
  display: inline-flex;
  align-items: center;
  gap: 14px;
}
.mw-marquee-item strong {
  font-family: var(--mw-display);
  font-style: italic;
  font-size: 16px;
  letter-spacing: 0;
  text-transform: none;
  color: var(--mw-green-d);
  font-weight: 600;
}
.mw-marquee-item::before {
  content: '◆';
  color: var(--mw-green-d);
  font-size: 10px;
}
@keyframes mw-marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* --- Full-bleed photo theatre — replaces showcase carousel --- */
.mw-theatre {
  position: relative;
  width: 100%;
  height: clamp(480px, 70vh, 760px);
  overflow: hidden;
  background: var(--mw-ink);
  margin: 0;
}
.mw-theatre-track {
  position: absolute;
  inset: 0;
  display: flex;
  transition: transform .8s cubic-bezier(.7, .04, .15, 1);
  width: 100%;
  height: 100%;
}
.mw-theatre-slide {
  flex: 0 0 100%;
  position: relative;
  overflow: hidden;
}
.mw-theatre-slide img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(.55) saturate(1.05);
}
.mw-theatre-slide::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(15,36,25,.5) 0%, rgba(15,36,25,.85) 100%),
    radial-gradient(circle at 30% 70%, rgba(217,160,91,.15) 0%, transparent 60%);
  pointer-events: none;
}
.mw-theatre-caption {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  z-index: 2;
}
.mw-theatre-caption-inner {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 32px;
  width: 100%;
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 64px;
  align-items: end;
}
.mw-theatre-text { color: var(--mw-parchment); padding-bottom: 36px; }
.mw-theatre-tag {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-family: var(--mw-mono);
  font-size: 11px;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--mw-mustard);
  margin-bottom: 16px;
}
.mw-theatre-tag::before {
  content: '';
  width: 32px;
  height: 1px;
  background: var(--mw-mustard);
}
.mw-theatre-title {
  font-family: var(--mw-display);
  font-weight: 500;
  font-size: clamp(40px, 6vw, 84px);
  line-height: 1;
  letter-spacing: -.015em;
  margin: 0 0 18px;
  color: var(--mw-parchment);
}
.mw-theatre-title em { font-style: italic; color: var(--mw-mustard); }
.mw-theatre-lede {
  font-family: var(--mw-body);
  font-size: 17px;
  line-height: 1.65;
  color: rgba(249, 246, 240, .85);
  max-width: 56ch;
  margin: 0 0 26px;
}
.mw-theatre-actions { display: flex; gap: 14px; flex-wrap: wrap; }
.mw-theatre-card {
  background: var(--mw-parchment);
  color: var(--mw-ink);
  padding: 24px 26px;
  border: 1px solid var(--mw-mustard);
  margin-bottom: 36px;
  position: relative;
  max-width: 380px;
  justify-self: end;
}
.mw-theatre-card::before {
  content: '';
  position: absolute;
  inset: 6px;
  border: 1px dotted var(--mw-mustard);
  pointer-events: none;
}
.mw-theatre-card-stamp {
  position: absolute;
  top: -12px;
  left: 16px;
  background: var(--mw-mustard);
  color: var(--mw-ink);
  padding: 4px 10px;
  font-family: var(--mw-mono);
  font-size: 10px;
  letter-spacing: .22em;
  text-transform: uppercase;
}
.mw-theatre-card-name {
  font-family: var(--mw-display);
  font-size: 24px;
  font-weight: 500;
  color: var(--mw-green);
  margin: 6px 0 6px;
  line-height: 1.15;
}
.mw-theatre-card-meta {
  font-family: var(--mw-mono);
  font-size: 11px;
  letter-spacing: .14em;
  color: var(--mw-muted);
  margin: 0 0 10px;
}
.mw-theatre-card-price {
  display: flex;
  align-items: baseline;
  gap: 12px;
  padding: 10px 0;
  border-top: 1px dotted var(--mw-rule);
  border-bottom: 1px dotted var(--mw-rule);
  margin: 10px 0;
}
.mw-theatre-card-now { font-family: var(--mw-display); font-size: 28px; color: var(--mw-green); font-weight: 500; }
.mw-theatre-card-was { font-family: var(--mw-body); font-size: 14px; color: var(--mw-muted); text-decoration: line-through; }
.mw-theatre-card-save {
  background: var(--mw-mustard);
  color: var(--mw-ink);
  padding: 3px 8px;
  font-family: var(--mw-mono);
  font-size: 10px;
  letter-spacing: .18em;
  text-transform: uppercase;
  margin-left: auto;
}
.mw-theatre-card-cta {
  width: 100%;
  text-align: center;
  background: var(--mw-green);
  color: var(--mw-parchment);
  padding: 12px;
  font-family: var(--mw-mono);
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  text-decoration: none;
  display: block;
}
.mw-theatre-card-cta:hover { background: var(--mw-green-d); }

.mw-theatre-nav {
  position: absolute;
  bottom: 36px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 12px;
  align-items: center;
  z-index: 3;
}
.mw-theatre-dot {
  width: 38px;
  height: 2px;
  background: rgba(249, 246, 240, .25);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background .2s;
}
.mw-theatre-dot.is-active { background: var(--mw-mustard); }

.mw-theatre-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(15, 36, 25, .5);
  border: 1px solid rgba(217, 160, 91, .4);
  color: var(--mw-parchment);
  width: 52px;
  height: 52px;
  font-size: 22px;
  cursor: pointer;
  z-index: 3;
  font-family: var(--mw-display);
  transition: background .2s;
}
.mw-theatre-arrow:hover { background: rgba(217, 160, 91, .8); color: var(--mw-ink); }
.mw-theatre-arrow--prev { left: 28px; }
.mw-theatre-arrow--next { right: 28px; }

@media (max-width: 820px) {
  .mw-theatre-caption-inner { grid-template-columns: 1fr; gap: 24px; padding: 0 20px; }
  .mw-theatre-card { justify-self: start; max-width: none; width: 100%; }
  .mw-theatre-arrow { display: none; }
}

/* --- Sale theatre — big reduced block with running deal counter --- */
.mw-sale-theatre {
  background: var(--mw-green-d);
  background-image:
    radial-gradient(circle at 10% 10%, rgba(217,160,91,.14) 0%, transparent 50%),
    radial-gradient(circle at 90% 90%, rgba(217,160,91,.10) 0%, transparent 50%);
  color: var(--mw-parchment);
  padding: 64px 0 72px;
  margin: 64px 0;
  position: relative;
  overflow: hidden;
}
.mw-sale-head {
  text-align: center;
  margin-bottom: 36px;
}
.mw-sale-head-tag {
  display: inline-block;
  font-family: var(--mw-mono);
  font-size: 11px;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: var(--mw-mustard);
  margin-bottom: 14px;
  padding: 6px 16px;
  border: 1px dashed var(--mw-mustard);
}
.mw-sale-head h2 {
  font-family: var(--mw-display);
  font-weight: 500;
  font-size: clamp(36px, 5vw, 56px);
  color: var(--mw-parchment);
  line-height: 1.04;
  letter-spacing: -.012em;
  margin: 0;
}
.mw-sale-head h2 em { font-style: italic; color: var(--mw-mustard); }
.mw-sale-head p {
  font-family: var(--mw-body);
  font-size: 16px;
  font-style: italic;
  color: rgba(249, 246, 240, .75);
  max-width: 56ch;
  margin: 14px auto 0;
}

.mw-sale-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}
.mw-sale-item {
  position: relative;
  background: var(--mw-parchment);
  color: var(--mw-ink);
  text-decoration: none;
  border: 1px solid var(--mw-mustard);
  transition: transform .15s, box-shadow .15s;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.mw-sale-item:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 22px rgba(15, 36, 25, .35);
}
.mw-sale-item-shot {
  aspect-ratio: 4/3;
  background: var(--mw-paper-bg-dim);
  overflow: hidden;
  position: relative;
}
.mw-sale-item-shot img {
  width: 100%; height: 100%;
  object-fit: cover;
}
.mw-sale-item-badge {
  position: absolute;
  top: 14px; left: -8px;
  background: var(--mw-mustard);
  color: var(--mw-ink);
  font-family: var(--mw-display);
  font-style: italic;
  font-size: 28px;
  font-weight: 600;
  padding: 6px 22px 6px 16px;
  letter-spacing: -.01em;
  box-shadow: 2px 4px 0 rgba(17, 22, 37, .25);
  z-index: 1;
}
.mw-sale-item-badge::after {
  content: '';
  position: absolute;
  bottom: -8px; left: 0;
  width: 0; height: 0;
  border-left: 8px solid rgba(176, 127, 61, .6);
  border-bottom: 8px solid transparent;
}
.mw-sale-item-body { padding: 18px 18px 16px; display: flex; flex-direction: column; gap: 6px; flex: 1; }
.mw-sale-item-cat {
  font-family: var(--mw-mono);
  font-size: 10px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--mw-mustard-d);
}
.mw-sale-item-name {
  font-family: var(--mw-display);
  font-size: 19px;
  font-weight: 500;
  color: var(--mw-green);
  margin: 0;
  line-height: 1.18;
}
.mw-sale-item-desc {
  font-family: var(--mw-body);
  font-size: 13px;
  line-height: 1.45;
  color: var(--mw-ink-soft);
  margin: 0;
  font-style: italic;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  max-height: 2.9em;
}
.mw-sale-item-prices {
  display: flex;
  align-items: baseline;
  gap: 10px;
  margin-top: auto;
  padding-top: 10px;
  border-top: 1px dotted var(--mw-rule);
}
.mw-sale-item-now { font-family: var(--mw-display); font-size: 24px; color: var(--mw-green); font-weight: 500; }
.mw-sale-item-was { font-family: var(--mw-body); font-size: 13px; color: var(--mw-muted); text-decoration: line-through; }

@media (max-width: 900px) { .mw-sale-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px) { .mw-sale-grid { grid-template-columns: 1fr; } .mw-sale-item-shot { aspect-ratio: 16/9; } }

/* --- Product strip — horizontal scroller for "top of drawer" rows --- */
.mw-strip-row { margin-top: 56px; margin-bottom: 56px; }
.mw-strip-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin: 0 0 18px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--mw-rule);
}
.mw-strip-head h3 {
  font-family: var(--mw-display);
  font-style: italic;
  font-size: 26px;
  font-weight: 500;
  color: var(--mw-green);
  margin: 0;
}
.mw-strip-head h3 em { color: var(--mw-mustard-d); }
.mw-strip-head a {
  font-family: var(--mw-mono);
  font-size: 11px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--mw-mustard-d);
  border-bottom: 1px solid var(--mw-mustard);
  text-decoration: none;
}
.mw-strip-cards {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}
.mw-strip-card {
  background: var(--mw-paper-bg);
  border: 1px solid var(--mw-rule);
  text-decoration: none;
  color: var(--mw-ink);
  transition: background .15s, transform .15s, border-color .15s;
  display: flex;
  flex-direction: column;
  position: relative;
}
.mw-strip-card:hover { background: var(--mw-cream); border-color: var(--mw-mustard); transform: translateY(-2px); }
.mw-strip-card-shot {
  aspect-ratio: 4/3;
  background: var(--mw-paper-bg-dim);
  overflow: hidden;
  border-bottom: 1px solid var(--mw-rule);
  position: relative;
}
.mw-strip-card-shot img { width: 100%; height: 100%; object-fit: cover; }
.mw-strip-card-cond {
  position: absolute;
  bottom: 0;
  right: 0;
  background: var(--mw-parchment);
  color: var(--mw-mustard-d);
  font-family: var(--mw-mono);
  font-size: 9.5px;
  letter-spacing: .18em;
  text-transform: uppercase;
  padding: 3px 8px;
  border-top: 1px solid var(--mw-mustard);
  border-left: 1px solid var(--mw-mustard);
}
.mw-strip-card-body { padding: 14px 16px 16px; display: flex; flex-direction: column; gap: 6px; flex: 1; }
.mw-strip-card-cat {
  font-family: var(--mw-mono);
  font-size: 10px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--mw-muted);
}
.mw-strip-card-name {
  font-family: var(--mw-display);
  font-size: 17px;
  font-weight: 500;
  color: var(--mw-green);
  margin: 0;
  line-height: 1.2;
}
.mw-strip-card-desc {
  font-family: var(--mw-body);
  font-size: 13px;
  line-height: 1.45;
  color: var(--mw-ink-soft);
  margin: 0;
  font-style: italic;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  max-height: 2.9em;
}
.mw-strip-card-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-top: auto;
  padding-top: 8px;
  border-top: 1px dotted var(--mw-rule);
}
.mw-strip-card-price {
  font-family: var(--mw-display);
  font-size: 20px;
  color: var(--mw-mustard-d);
  font-weight: 500;
}
.mw-strip-card-was {
  font-family: var(--mw-body);
  font-size: 12px;
  color: var(--mw-muted);
  text-decoration: line-through;
}

@media (max-width: 900px) { .mw-strip-cards { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px) { .mw-strip-cards { grid-template-columns: 1fr; } }

/* --- Wider main wrap to use viewport better --- */
.mw-wrap--wide {
  width: 100%;
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 28px;
}
