/* =========================
   ADMIN (только wp-admin)
   ========================= */
body.wp-admin .mfc-wrap{max-width:1200px}
body.wp-admin .mfc-muted{color:#6b7280;font-size:12px}
body.wp-admin .mfc-row{display:flex;gap:12px;flex-wrap:wrap;align-items:center}

body.wp-admin .mfc-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
@media(max-width:980px){body.wp-admin .mfc-grid{grid-template-columns:1fr}}

body.wp-admin .mfc-card{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:16px}

body.wp-admin .mfc-btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:10px 14px;border-radius:12px;
  border:1px solid #d1d5db;background:#111827;color:#fff;
  text-decoration:none;font-weight:700;line-height:1;
}
body.wp-admin .mfc-btn.secondary{background:#fff;color:#111827}

body.wp-admin .mfc-field{
  padding:6px 10px;background:#f3f4f6;border:1px solid #e5e7eb;
  border-radius:10px;cursor:grab;user-select:none
}
body.wp-admin .mfc-field.small{font-size:12px}
body.wp-admin .mfc-field-placeholder{
  background:#eef2ff;border:1px dashed #94a3b8;border-radius:10px;
  min-height:28px;margin:4px 0
}

body.wp-admin .mfc-drop{
  min-height:36px;padding:8px;border:1px dashed #cbd5e1;
  border-radius:10px;background:#fafafa
}
body.wp-admin .mfc-drop .mfc-field{display:inline-flex}

body.wp-admin .mfc-slot{margin-bottom:10px}
body.wp-admin .mfc-slot label{display:block;font-weight:800;margin-bottom:6px}

body.wp-admin .mfc-progress{height:10px;background:#f3f4f6;border-radius:999px;overflow:hidden}
body.wp-admin .mfc-progress > span{display:block;height:100%;background:#111827;width:0%}

body.wp-admin .mfc-keys-box{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:980px){body.wp-admin .mfc-keys-box{grid-template-columns:1fr}}
body.wp-admin .mfc-keys-list{
  min-height:120px;border:1px dashed #cbd5e1;border-radius:12px;
  padding:10px;background:#fafafa
}

/* =========================
   FRONT (не админка)
   ========================= */

/* базовая страховка от конфликтов темы */
body:not(.wp-admin) .mfc-wrap,
body:not(.wp-admin) .mfc-catalog,
body:not(.wp-admin) .mfc-product,
body:not(.wp-admin) .mfc-searchbar,
body:not(.wp-admin) .mfc-searchform{
  box-sizing:border-box;
}
body:not(.wp-admin) .mfc-catalog *,
body:not(.wp-admin) .mfc-product *,
body:not(.wp-admin) .mfc-searchbar *{box-sizing:inherit;}

/* FIX: некоторые темы задают will-change массово (Chrome ругается на память).
   Сбрасываем will-change только внутри блоков MFC — на верстку не влияет. */
body:not(.wp-admin) .mfc-catalog *,
body:not(.wp-admin) .mfc-product *,
body:not(.wp-admin) .mfc-searchbar *,
body:not(.wp-admin) .mfc-searchform *,
body:not(.wp-admin) #mfc-cart-portal *{
  will-change:auto !important;
}

body:not(.wp-admin) .mfc-catalog img,
body:not(.wp-admin) .mfc-product img{
  max-width:100%;
  height:auto;
}

/* Catalog */
body:not(.wp-admin) .mfc-catalog{
  display:grid;
  grid-template-columns:repeat(var(--mfc-cols,4), minmax(0,1fr));
  gap:clamp(12px, 2.2vw, 18px);
}
body:not(.wp-admin) .mfc-catalog-layout{padding-inline:8px;}
/* на планшетах/мобилках — фиксируем читабельные колонки независимо от настройки */
@media(max-width:1100px){body:not(.wp-admin) .mfc-catalog{grid-template-columns:repeat(3, minmax(0,1fr))}}
@media(max-width:820px){body:not(.wp-admin) .mfc-catalog{grid-template-columns:repeat(2, minmax(0,1fr))}}
@media(max-width:520px){body:not(.wp-admin) .mfc-catalog{grid-template-columns:1fr}}

body:not(.wp-admin) .mfc-card-item{
  display:block;text-decoration:none;color:inherit;
  border:1px solid #e5e7eb;border-radius:16px;overflow:hidden;
  background:#fff;transition:transform .18s ease, box-shadow .18s ease;
}
body:not(.wp-admin) .mfc-card-item:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(0,0,0,.08)}
body:not(.wp-admin) .mfc-card-img{aspect-ratio:1/1;background:#f8fafc;display:flex;align-items:center;justify-content:center;overflow:hidden}
body:not(.wp-admin) .mfc-card-img img{width:100%;height:100%;object-fit:cover;display:block}
body:not(.wp-admin) .mfc-card-gallery-ui{display:flex;align-items:center;gap:10px;padding:10px 12px 0}
body:not(.wp-admin) .mfc-card-gallery-bars{display:flex;align-items:center;gap:6px;flex:1 1 auto;min-width:0}
body:not(.wp-admin) .mfc-card-gallery-bar{display:block;flex:1 1 0;height:3px;border-radius:999px;background:rgba(17,24,39,.14);transition:background .18s ease,transform .18s ease}
body:not(.wp-admin) .mfc-card-gallery-bar.is-active{background:#111827;transform:scaleY(1.15)}
body:not(.wp-admin) .mfc-card-gallery-count{flex:0 0 auto;font-size:12px;line-height:1;font-weight:700;color:rgba(17,24,39,.72);white-space:nowrap}
body:not(.wp-admin) .mfc-card-body{padding:14px}
body:not(.wp-admin) .mfc-title{font-size:15px;line-height:1.3;margin:0 0 8px 0;font-weight:800}
body:not(.wp-admin) .mfc-price{font-size:18px;font-weight:900;margin:0}
body:not(.wp-admin) .mfc-muted{color:#6b7280;font-size:12px}

/* Product Layout */
body:not(.wp-admin) .mfc-product{
  display:grid;
  grid-template-columns:minmax(320px,560px) 1fr;
  gap:28px;align-items:start
}
body:not(.wp-admin) .mfc-product > *{min-width:0}
@media(max-width:980px){body:not(.wp-admin) .mfc-product{grid-template-columns:1fr}}

body:not(.wp-admin) .mfc-gallery{position:sticky;top:16px;align-self:start}
@media(max-width:980px){body:not(.wp-admin) .mfc-gallery{position:relative;top:auto}}

body:not(.wp-admin) .mfc-gallery-main{
  border:1px solid #e5e7eb;border-radius:18px;
  background:#f8fafc;overflow:hidden;
  height:min(620px,calc(100vh - 160px));
  display:flex;align-items:center;justify-content:center;
}
body:not(.wp-admin) .mfc-gallery-main img{width:100%;height:100%;object-fit:contain;display:block}
body:not(.wp-admin) .mfc-gallery-empty{color:#6b7280;font-size:13px}

@media(max-width:520px){
  body:not(.wp-admin) .mfc-gallery-main{height:auto;aspect-ratio:1/1}
}

body:not(.wp-admin) .mfc-gallery-thumbs{display:flex;gap:10px;margin-top:12px;overflow:auto;padding-bottom:4px}
body:not(.wp-admin) .mfc-thumb{
  flex:0 0 78px;height:78px;border:1px solid #e5e7eb;border-radius:14px;
  overflow:hidden;background:#fff;padding:0;cursor:pointer
}
body:not(.wp-admin) .mfc-thumb img{width:100%;height:100%;object-fit:cover;display:block}
body:not(.wp-admin) .mfc-thumb.active{border-color:#111827}

body:not(.wp-admin) .mfc-product-title{font-size:clamp(20px,4.5vw,28px);line-height:1.15;margin:0}
body:not(.wp-admin) .mfc-meta{display:flex;flex-wrap:wrap;gap:10px;margin:10px 0 10px}

body:not(.wp-admin) .mfc-badge{
  font-size:12px;padding:6px 10px;border:1px solid #e5e7eb;
  border-radius:999px;background:#fff;color:#111827;
}
body:not(.wp-admin) .mfc-product-price{font-size:clamp(22px,5vw,30px);font-weight:900;margin:10px 0 16px}

body:not(.wp-admin) .mfc-desc{
  color:#374151;font-size:14px;line-height:1.65;
  margin:0 0 14px 0;
  max-height:7.3em;overflow:auto;padding-right:4px;
}

body:not(.wp-admin) .mfc-panel{
  border:1px solid #e5e7eb;border-radius:16px;background:#fff;
  padding:14px;margin:12px 0 14px;
}
body:not(.wp-admin) .mfc-panel-title{font-weight:900;margin:0 0 10px 0}

/* Variations UI */
body:not(.wp-admin) .mfc-var-ui{display:flex;flex-direction:column}
body:not(.wp-admin) .mfc-var-label{font-size:13px;color:#6b7280;margin:0 0 10px 0}
body:not(.wp-admin) .mfc-var-grid{display:flex;gap:10px;flex-wrap:wrap}

body:not(.wp-admin) .mfc-color{
  width:56px;height:56px;
  padding:0;gap:0;
  border:1px solid #e5e7eb;border-radius:14px;
  text-decoration:none;color:inherit;background:#fff;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
  cursor:pointer;
  appearance:none;-webkit-appearance:none;
  font:inherit;
}
body:not(.wp-admin) .mfc-color-thumb{
  width:100%;height:100%;
  border-radius:0;overflow:hidden;
  background:#f3f4f6;flex:1 1 auto;border:0;
  display:flex;align-items:center;justify-content:center
}
body:not(.wp-admin) .mfc-color-thumb img{width:100%;height:100%;object-fit:cover;display:block}
body:not(.wp-admin) .mfc-color-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#374151;background:#f3f4f6;text-transform:uppercase}
body:not(.wp-admin) .mfc-color-name{display:none}
body:not(.wp-admin) .mfc-color.active{border-color:#111827;border-width:2px;box-shadow:none}

body:not(.wp-admin) .mfc-size{
  display:inline-flex;align-items:center;justify-content:center;
  height:38px;min-width:46px;padding:0 12px;
  border:1px solid #e5e7eb;border-radius:999px;
  text-decoration:none;color:inherit;background:#fff;
  font-weight:900;font-size:13px;
  cursor:pointer;
  appearance:none;-webkit-appearance:none;
  font:inherit;
}
body:not(.wp-admin) .mfc-size.active{border-color:#111827;background:#111827;color:#fff}

/* Возможные типы нанесения */
body:not(.wp-admin) .mfc-panel--imprint{
  padding:14px 16px;
}
body:not(.wp-admin) .mfc-imprint-list{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
body:not(.wp-admin) .mfc-imprint-chip{
  display:inline-flex;
  align-items:center;
  max-width:100%;
  padding:7px 12px;
  border:1px solid #e5e7eb;
  border-radius:999px;
  background:#f8fafc;
  color:#111827;
  font-size:13px;
  font-weight:700;
  line-height:1.35;
}

/* Chars 2 columns */
body:not(.wp-admin) .mfc-chars{
  border:1px solid #e5e7eb;border-radius:16px;
  padding:14px;background:#fafafa;
}
body:not(.wp-admin) .mfc-chars-grid{
  list-style:none;margin:10px 0 0 0;padding:0;
  display:grid;grid-template-columns:1fr 1fr;gap:10px 14px;margin-left: 0rem!important;
}
@media(max-width:900px){body:not(.wp-admin) .mfc-chars-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:720px){body:not(.wp-admin) .mfc-chars-grid{grid-template-columns:1fr}}
body:not(.wp-admin) .mfc-char{
  display:flex;align-items:flex-start;justify-content:space-between;
  gap:10px;padding:8px 10px;background:#fff;
  border:1px solid #eef2f7;border-radius:14px;
}
body:not(.wp-admin) .mfc-char-k{color:#6b7280;font-size:12px;max-width:55%}
body:not(.wp-admin) .mfc-char-v{font-weight:800;font-size:13px;color:#111827;text-align:right;max-width:55%}
/* ===== ADMIN FIX: Paramid keys layout ===== */
body.wp-admin .mfc-keys-box{
  display:grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 420px);
  gap:18px;
  align-items:start;
}

@media(max-width:980px){
  body.wp-admin .mfc-keys-box{
    grid-template-columns: 1fr;
  }
}

/* обе колонки не должны "сжиматься" странно */
body.wp-admin .mfc-keys-box > div{min-width:0}

/* делаем списки ключей нормальными флекс-контейнерами */
body.wp-admin .mfc-keys-list{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-content:flex-start;
  min-height:160px;
  padding:10px;
  background:#fff;
  border:1px dashed #cbd5e1;
  border-radius:12px;
}

/* важно: убираем влияние mfc-drop (слоты) на правый список */
body.wp-admin #mfc_param_keys_selected.mfc-drop{
  min-height:160px;
  padding:10px;
  background:#fff;
  border:1px dashed #cbd5e1;
  border-radius:12px;
}

/* сами "пилюли" ключей */
body.wp-admin .mfc-keys-list .mfc-field{
  display:inline-flex;
  margin:0;
}

/* placeholder sortable */
body.wp-admin .mfc-keys-list .mfc-field-placeholder{
  background:#eef2ff;
  border:1px dashed #94a3b8;
  border-radius:10px;
  min-width:120px;
  height:28px;
}
.mfc-param-key{
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.mfc-param-key .mfc-inherit{
  width:14px;
  height:14px;
  margin:0;
}
.mfc-var-extras{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:8px;
}

.mfc-var-extra{
  font-size:12px;
  padding:6px 10px;
  border:1px solid rgba(0,0,0,.08);
  border-radius:999px;
  background:#fff;
  line-height:1.2;
}

.mfc-var-extra-k{ opacity:.7; }
.mfc-var-extra-v{ font-weight:600; }
.mfc-meta{
  display:flex;
  gap:10px;
  align-items:center;
  flex-wrap:wrap;
}

.mfc-price-badge strong{
  font-size:20px;
  line-height:1;
}

.mfc-panel-variations{
  padding-top: 10px;
}

.mfc-var-label-under{
  margin-top:10px;
}
/* === Product meta (SKU + price on one line) === */
.mfc-product .mfc-meta-top{
  display:flex;
  flex-wrap:wrap;
  align-items:baseline;
  gap:12px;
  margin:10px 0 16px;
}

.mfc-product .mfc-sku-pill{
  display:inline-flex;
  align-items:baseline;
  gap:6px;
  padding:6px 10px;
  border:1px solid #e5e7eb;
  border-radius:999px;
  font-size:13px;
  color:#111827;
  background:#fff;
}

.mfc-product .mfc-price-inline{
  display:inline-flex;
  align-items:baseline;
  gap:6px;
  line-height:1;
}

.mfc-product .mfc-price-inline .mfc-price-num{
  font-size:24px;
  font-weight:700;
  letter-spacing:-0.02em;
  color:#111827;
}

.mfc-product .mfc-price-inline .mfc-price-cur{
  font-size:12px;
  font-weight:600;
  color:#6b7280;
  transform: translateY(-1px);
}

.mfc-product .mfc-price-inline--na{
  font-size:14px;
  color:#6b7280;
  font-weight:500;
}

/* === Variations spacing + label under colors === */
.mfc-panel--variations{
  padding:16px;
}

.mfc-var-section{
  margin-top: var(--mfc-v-gap);
}

.mfc-var-section--axis1{
  margin-top: 0;
}

.mfc-var-grid{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.mfc-var-grid--colors{
  margin-bottom: 8px;
}

.mfc-var-label{
  font-size:13px;
  color:#6b7280;
  margin:0;
}

.mfc-var-label strong{
  color:#111827;
  font-weight:600;
}

.mfc-var-label--under{
  margin-top:0;
}

.mfc-var-section--axis2 .mfc-var-label{
  margin-bottom:8px;
}
/* ===== Variations: нормальные отступы между "Цвет" и "Размер" ===== */
.mfc-panel--variations .mfc-var-ui {
  margin: 0 !important;
}

.mfc-panel--variations .mfc-var-section {
  margin: 0 !important;
  padding: 0 !important;
}

/* подпись "Цвет: ..." под миниатюрами — без лишнего низа */
.mfc-panel--variations .mfc-var-label--under {
  margin: 8px 0 10px !important;
}

/* блок размеров не должен отъезжать вниз */
.mfc-panel--variations .mfc-var-section--axis2 {
  margin-top: 0 !important;
}

/* и у подписи "Размер:" тоже аккуратно */
.mfc-panel--variations .mfc-var-section--axis2 > .mfc-var-label {
  margin: 0 0 8px !important;
}
/* фронт: композитные размеры + qty */
.mfc-var-grid--sizes .mfc-size{
  display:inline-flex;
  align-items:center;
  gap:8px;
  white-space:nowrap;
}

.mfc-size-joined{
  font-size:12px;
  opacity:.7;
}

.mfc-size-qty{
  display:inline-flex;
  align-items:center;
  gap:6px;
}

.mfc-size-qty-label{
  font-size:12px;
  opacity:.7;
}

.mfc-qty-input{
  width:62px;
  padding:4px 8px;
  border:1px solid rgba(0,0,0,.12);
  border-radius:10px;
  outline:none;
}
.mfc-axis-plus{
  display:inline-flex; align-items:center; justify-content:center;
  width:18px; height:18px; margin-left:6px;
  border:1px solid #ccc; border-radius:999px;
  cursor:pointer; user-select:none; font-weight:700;
}
.mfc-append-item{
  display:inline-flex; align-items:center; gap:6px;
  padding:2px 8px; margin-left:6px;
  border:1px dashed #bbb; border-radius:999px; font-size:12px;
}
.mfc-append-remove{ cursor:pointer; opacity:.75; }
.mfc-append-pick{ outline:2px dashed #999; outline-offset:4px; }
.mfc-custom-key{
  display:inline-flex; align-items:center;
  padding:4px 10px; border:1px solid #ddd; border-radius:999px;
  cursor:pointer; user-select:none;
}
/* компактная сетка "размер + qty" */
.mfc-var-grid--sizes{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.mfc-size-wrap{
  display:inline-flex;
  align-items:center;
  gap:8px;
}

/* поле количества */
.mfc-size-qty{
  width:62px;
  max-width:62px;
  height:34px;
  padding:0 8px;
  border:1px solid rgba(0,0,0,.12);
  border-radius:10px;
  background:#fff;
  font:inherit;
  text-align:center;
  line-height:34px;
}

/* чуть приятнее фокус */
.mfc-size-qty:focus{
  outline:none;
  box-shadow:0 0 0 3px rgba(0,0,0,.08);
}

/* подсказка под "Размер..." */
.mfc-var-hint{
  margin:4px 0 10px;
  font-size:12px;
  opacity:.75;
}
/* ===== Variations: compact qty ===== */
.mfc-var-grid--sizes{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
}

.mfc-size-wrap{
  display:flex;
  align-items:center;
  gap:8px;
}

.mfc-size-qty{
  width:56px;
  min-width:56px;
  height:34px;
  padding:6px 8px;
  border-radius:10px;
  border:1px solid rgba(0,0,0,.12);
  background:#fff;
  font-size:13px;
  line-height:1;
}

/* убрать “огромные” стрелки где возможно */
.mfc-size-qty::-webkit-outer-spin-button,
.mfc-size-qty::-webkit-inner-spin-button{
  -webkit-appearance: none;
  margin: 0;
}
.mfc-size-qty[type=number]{
  -moz-appearance: textfield;
}

.mfc-var-hint{
  margin:6px 0 10px;
  font-size:13px;
  opacity:.75;
}
/* qty рядом с размером */
.mfc-size-wrap{display:flex; align-items:center; gap:10px; flex-wrap:nowrap;}
.mfc-size-qty{
  width:64px;
  height:36px;
  border-radius:10px;
  border:1px solid rgba(0,0,0,.12);
  background:#fff;
  padding:0 10px;
  font-size:14px;
}

/* линия добавления в корзину */
.mfc-cart-addline{
  margin-top:14px;
  display:flex;
  align-items:center;
  gap:12px;
}

/* мини-корзина (в “шапке”/сверху справа) */
.mfc-cart-mini{
  position:fixed;
  top:16px;
  right:16px;
  z-index:999999;
}
.mfc-cart-mini-btn{
  display:flex;
  align-items:center;
  gap:10px;
  border-radius:999px;
  border:1px solid rgba(0,0,0,.12);
  background:#fff;
  padding:10px 12px;
  cursor:pointer;
}
.mfc-cart-mini-count{
  min-width:22px;
  height:22px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid rgba(0,0,0,.12);
  font-size:12px;
  padding:0 6px;
}
.mfc-cart-mini.is-show{transform:scale(1.03); transition:transform .25s ease;}

/* модалка корзины */
.mfc-cart{position:fixed; inset:0; z-index:999998;}
.mfc-cart-backdrop{position:absolute; inset:0; background:rgba(0,0,0,.35);}
.mfc-cart-panel{
  position:absolute;
  right:18px;
  top:18px;
  width:min(520px, calc(100% - 36px));
  max-height:calc(100% - 36px);
  background:#fff;
  border-radius:18px;
  border:1px solid rgba(0,0,0,.12);
  overflow:hidden;
  display:flex;
  flex-direction:column;
  transform:translateY(10px);
  opacity:0;
  transition:transform .2s ease, opacity .2s ease;
}
.mfc-cart.is-open .mfc-cart-panel{transform:translateY(0); opacity:1;}
.mfc-cart.is-minimizing .mfc-cart-panel{transform:translateY(-8px) scale(.98); opacity:.2;}

.mfc-cart-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 16px;
  border-bottom:1px solid rgba(0,0,0,.08);
}
.mfc-cart-title{font-size:16px; font-weight:700;}
.mfc-cart-close{border:none; background:transparent; font-size:22px; cursor:pointer; line-height:1;}

.mfc-cart-body{padding:12px 16px; overflow:auto;}
.mfc-cart-items{display:flex; flex-direction:column; gap:10px;}

.mfc-cart-item{
  display:grid;
  grid-template-columns:60px 1fr 120px;
  gap:10px;
  align-items:center;
  border:1px solid rgba(0,0,0,.08);
  border-radius:14px;
  padding:10px;
}
.mfc-cart-item-img{
  width:60px; height:60px; border-radius:12px;
  border:1px solid rgba(0,0,0,.08);
  display:flex; align-items:center; justify-content:center;
  overflow:hidden;
  background:#fff;
}
.mfc-cart-item-img img{width:100%; height:100%; object-fit:cover;}
.mfc-cart-item-title{font-size:14px; font-weight:600; line-height:1.2;}
.mfc-cart-item-title a{text-decoration:none;}
.mfc-cart-item-meta{margin-top:6px; font-size:12px; opacity:.8;}
.mfc-cart-item-right{display:flex; flex-direction:column; gap:8px; align-items:flex-end;}
.mfc-cart-qty{
  width:90px;
  height:34px;
  border-radius:10px;
  border:1px solid rgba(0,0,0,.12);
  padding:0 10px;
}
.mfc-cart-rm{border:none; background:transparent; font-size:18px; cursor:pointer; opacity:.6;}
.mfc-cart-item-sum{font-size:12px; opacity:.85;}

.mfc-cart-foot{
  padding:12px 16px;
  border-top:1px solid rgba(0,0,0,.08);
  display:flex;
  flex-direction:column;
  gap:10px;
}
.mfc-cart-total{display:flex; align-items:center; justify-content:space-between;}
.mfc-cart-min{font-size:12px; opacity:.85;}
.mfc-cart-actions{display:flex; gap:10px; justify-content:flex-end; flex-wrap:wrap;}

/* checkout */
.mfc-checkout-grid{
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:18px;
}
@media(max-width:900px){.mfc-checkout-grid{grid-template-columns:1fr;}}
.mfc-checkout-items{display:flex; flex-direction:column; gap:10px; margin-top:8px;}
.mfc-checkout-item{border:1px solid rgba(0,0,0,.08); border-radius:14px; padding:12px;}
.mfc-checkout-item-title{font-weight:700; margin-bottom:6px;}
.mfc-checkout-item-meta{font-size:13px; opacity:.85;}
.mfc-checkout-total{margin-top:12px; font-size:16px;}
.mfc-checkout-warn{margin-top:10px; font-size:13px; color:#b00;}

.mfc-input{
  width:100%;
  border:1px solid rgba(0,0,0,.12);
  border-radius:12px;
  padding:10px 12px;
  font-size:14px;
  background:#fff;
}
.mfc-fieldlab{display:block; margin:10px 0 6px; font-size:13px; opacity:.8;}
/* Кнопка "Добавить в корзину" справа */
.mfc-var-actions{
  display:flex;
  justify-content:flex-end;
  align-items:center;
  gap:10px;
  margin-top:14px;
}

.mfc-var-actions .mfc-btn{
  border-radius:999px;
  padding:12px 18px;
  font-weight:600;
  line-height:1;
  border:1px solid rgba(0,0,0,.12);
  background:rgba(10,10,12,.92);
  color:#fff;
  transition:transform .12s ease, opacity .12s ease, background .12s ease;
}

.mfc-var-actions .mfc-btn:hover{
  opacity:.95;
  transform:translateY(-1px);
}

.mfc-var-actions .mfc-btn:active{
  transform:translateY(0);
}
/* Мини-корзина справа снизу */
.mfc-cart-mini{
  position:fixed;
  right:18px;
  bottom:18px;
  z-index:99999;
}

.mfc-cart-mini-btn{
  display:flex;
  align-items:center;
  gap:10px;
  border-radius:999px;
  padding:12px 14px;
  border:1px solid rgba(0,0,0,.12);
  background:rgba(255,255,255,.78);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  cursor:pointer;
  transition:transform .12s ease, opacity .12s ease;
}

.mfc-cart-mini-btn:hover{
  transform:translateY(-1px);
  opacity:.98;
}

.mfc-cart-mini-ico{
  font-size:18px;
  line-height:1;
}

.mfc-cart-mini-count{
  min-width:26px;
  height:26px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  background:rgba(10,10,12,.92);
  color:#fff;
  font-weight:700;
  font-size:12px;
  padding:0 8px;
}
.mfc-cart-actions{
  display:flex;
  justify-content:flex-end;
  gap:10px;
  flex-wrap:wrap;
}

.mfc-btn{
  border-radius:12px;
  padding:10px 14px;
  font-weight:600;
  border:1px solid rgba(0,0,0,.12);
  background:#111;
  color:#fff;
  cursor:pointer;
  line-height:1;
}

.mfc-btn.secondary{
  background:#fff;
  color:#111;
}

.mfc-btn:hover{ filter:brightness(1.05); }

.mfc-cart-qty{
  width:72px;
  border-radius:10px;
  padding:8px 10px;
  border:1px solid rgba(0,0,0,.12);
}
/* ===== CART PORTAL (актуальная разметка) ===== */
#mfc-cart-portal{
  position:fixed;
  inset:0;
  z-index:999999;
  pointer-events:none;
}

/* кнопка корзины */
#mfc-cart-portal .mfc-cart-btn{
  position:fixed;
  right:18px;
  bottom:18px;
  z-index:1000000;
  pointer-events:auto;

  display:flex;
  align-items:center;
  gap:10px;

  border-radius:999px;
  padding:12px 14px;
  border:1px solid rgba(0,0,0,.12);
  background:rgba(255,255,255,.78);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  cursor:pointer;
}

#mfc-cart-portal .mfc-cart-badge{
  min-width:26px;
  height:26px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  background:rgba(10,10,12,.92);
  color:#fff;
  font-weight:700;
  font-size:12px;
  padding:0 8px;
}

/* оверлей */
#mfc-cart-portal .mfc-cart-overlay{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.35);
  opacity:0;
  pointer-events:none;
  transition:opacity .18s ease;
}

/* шторка */
#mfc-cart-portal .mfc-cart-drawer{
  position:fixed;
  top:18px;
  right:18px;
  width:min(520px, calc(100% - 36px));
  max-height:calc(100% - 36px);

  background:#fff;
  border-radius:18px;
  border:1px solid rgba(0,0,0,.12);
  overflow:hidden;

  display:flex;
  flex-direction:column;

  transform:translateX(110%);
  transition:transform .2s ease;
  pointer-events:auto;
}

/* open state */
#mfc-cart-portal.is-open .mfc-cart-overlay{
  opacity:1;
  pointer-events:auto;
}
#mfc-cart-portal.is-open .mfc-cart-drawer{
  transform:translateX(0);
}

/* когда закрыто aria-hidden — реально прячем */
#mfc-cart-portal .mfc-cart-overlay[aria-hidden="true"],
#mfc-cart-portal .mfc-cart-drawer[aria-hidden="true"]{
  display:none;
}

/* FIX: top button must capture clicks (portal has pointer-events:none) */
#mfc-cart-portal .mfc-top-btn{pointer-events:auto;z-index:1000000;}

/* Catalog: load more */
.mfc-catalog-morewrap{display:flex;justify-content:center;margin:14px 0 0}
.mfc-catalog-more{padding:10px 14px;border-radius:999px;border:1px solid rgba(0,0,0,.15);background:#fff;color:#111;cursor:pointer;position:relative;z-index:2;pointer-events:auto}
.mfc-catalog-more:hover{border-color:rgba(0,0,0,.28)}
.mfc-catalog-more[disabled]{opacity:.5;cursor:not-allowed}

/* Variations qty: make placeholder "Заказать, шт" fully readable */
.mfc-var-ui .mfc-size-qty{
  width:12ch !important;
  min-width:12ch !important;
  text-align:left;
}
.mfc-var-ui .mfc-size-qty::placeholder{
  font-size:12px;
}
@media (max-width:420px){
  .mfc-var-ui .mfc-size-qty{width:11ch !important; min-width:11ch !important;}
}



/* === ALIGN FIX (sidebar + searchbar start at same level) ===
   Причина: у .mfc-catalog-main .mfc-searchbar есть margin-top: 10px (inline в PHP),
   а у sidebar его нет — поэтому блок фильтров стартует выше.
   Фикс: добавляем такой же верхний отступ sidebar и не трогаем остальную верстку.
*/
body:not(.wp-admin) .mfc-catalog-layout{padding-top:0 !important;}
body:not(.wp-admin) .mfc-catalog-layout > .mfc-filters-lazy{min-height:520px}
.mfc-filters-skeleton{display:grid;gap:12px;padding:14px;border:1px solid rgba(0,0,0,.08);border-radius:18px;background:#fff}
.mfc-filters-skeleton-head,.mfc-filters-skeleton-line,.mfc-filters-skeleton-block{border-radius:12px;background:linear-gradient(90deg, rgba(0,0,0,.05) 25%, rgba(0,0,0,.09) 37%, rgba(0,0,0,.05) 63%);background-size:400% 100%;animation:mfcFiltersPulse 1.35s ease infinite}
.mfc-filters-skeleton-head{height:46px}
.mfc-filters-skeleton-line{height:18px}
.mfc-filters-skeleton-line--short{width:62%}
.mfc-filters-skeleton-block{height:96px}
.mfc-filters-lazy.is-error{min-height:0}
.mfc-filters-lazy.is-error .mfc-filters-skeleton{display:none}
.mfc-filters-lazy-error{padding:14px;border:1px solid rgba(0,0,0,.08);border-radius:18px;background:#fff}
@keyframes mfcFiltersPulse{0%{background-position:100% 50%}100%{background-position:0 50%}}

.mfc-catalog-sidebar{margin-top:10px !important;}

/* На случай, если тема/кастом ранее задавали sticky-top через переменную — не ломаем,
   но если переменная не задана, пусть не добавляется лишний сдвиг. */
body:not(.wp-admin) .mfc-catalog-layout{--mfc-sticky-top:0px;}

/* Small page edge breathing room + improved scroll-top button */
#mfc-cart-portal .mfc-top-btn{
  right:18px;
  bottom:12px;
  width:46px;
  height:46px;
  border-radius:14px;
  border:1px solid rgba(17,24,39,.10);
  background:#111827;
  color:#fff;
  box-shadow:0 12px 28px rgba(17,24,39,.22);
}
#mfc-cart-portal .mfc-top-btn:hover{background:#0f172a;border-color:rgba(15,23,42,.22);box-shadow:0 14px 32px rgba(15,23,42,.28)}
#mfc-cart-portal .mfc-top-ico{color:#fff}

/* Hide scroll-to-top button on product page */
body.single-product #mfc-cart-portal .mfc-top-btn,
body:not(.wp-admin):has(.mfc-product) #mfc-cart-portal .mfc-top-btn{display:none !important;}


/* Force 3 columns in product characteristics always */
.mfc-chars-grid{
  display:grid !important;
  grid-template-columns:repeat(3,minmax(0,1fr)) !important;
  gap:10px 14px !important;
}


/* === Mobile adaptive upgrade: catalog, filters, gallery === */
body:not(.wp-admin) .mfc-catalog-layout{
  display:grid;
  grid-template-columns:minmax(260px, 290px) minmax(0, 1fr);
  gap:18px;
  align-items:start;
}
body:not(.wp-admin) .mfc-catalog-main{min-width:0}
body:not(.wp-admin) .mfc-catalog-sidebar{
  min-width:0;
  position:sticky;
  top:var(--mfc-sticky-top, 16px);
  align-self:start;
}
body:not(.wp-admin) .mfc-filters-form{
  border:1px solid rgba(17,24,39,.08);
  border-radius:18px;
  background:#fff;
  padding:14px;
}
body:not(.wp-admin) .mfc-filter-opt{
  min-height:38px;
  padding:4px 0;
}
body:not(.wp-admin) .mfc-card-item{
  border-radius:18px !important;
  overflow:hidden;
}
body:not(.wp-admin) .mfc-card-img{
  position:relative;
  overflow:hidden !important;
  touch-action:pan-y pinch-zoom;
}
body:not(.wp-admin) .mfc-card-mainimg{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
body:not(.wp-admin) .mfc-card-gallery-nav{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:34px;
  height:34px;
  border:0;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(17,24,39,.82);
  color:#fff;
  z-index:3;
  cursor:pointer;
  opacity:0;
  pointer-events:none;
  transition:opacity .18s ease, transform .18s ease;
}
body:not(.wp-admin) .mfc-card-gallery-nav.is-prev{left:10px}
body:not(.wp-admin) .mfc-card-gallery-nav.is-next{right:10px}
body:not(.wp-admin) .mfc-card-item:hover .mfc-card-gallery-nav,
body:not(.wp-admin) .mfc-card-item:focus-within .mfc-card-gallery-nav{
  opacity:1;
  pointer-events:auto;
}

@media (max-width: 980px){
  body:not(.wp-admin) .mfc-card-gallery-nav{
    display:none !important;
  }
}
body:not(.wp-admin) .mfc-searchbar .mfc-filter-openbtn{
  display:none;
}
body:not(.wp-admin) .mfc-search-toolbar{
  flex-wrap:wrap;
}
body:not(.wp-admin) .mfc-catalog-more{
  min-height:44px;
  padding:12px 18px;
}
@media (max-width: 980px){
  body:not(.wp-admin) .mfc-catalog-layout{
    grid-template-columns:1fr;
    gap:14px;
    padding-inline:0 !important;
  }
  body:not(.wp-admin) .mfc-catalog-layout > .mfc-catalog-sidebar{
    display:none;
    margin-top:0 !important;
  }
  body:not(.wp-admin) .mfc-searchbar{
    position:sticky;
    top:calc(var(--mfc-sticky-top, 0px) - 8px);
    z-index:25;
    padding:10px 0 12px;
    background:linear-gradient(to bottom, rgba(255,255,255,.98), rgba(255,255,255,.94));
    backdrop-filter:blur(10px);
    -webkit-backdrop-filter:blur(10px);
  }
  body:not(.wp-admin) .mfc-searchfield{
    border-radius:16px;
  }
  body:not(.wp-admin) .mfc-search-input{
    font-size:16px;
    padding-left:42px;
  }
  body:not(.wp-admin) .mfc-searchbar .mfc-filter-openbtn{
    display:flex;
    min-height:44px;
  }
  body:not(.wp-admin) .mfc-sortbox,
  body:not(.wp-admin) .mfc-sortbox-select{
    width:100%;
    max-width:none;
  }
  body:not(.wp-admin) .mfc-filter-overlay{
    padding-top:max(12px, env(safe-area-inset-top));
    background:rgba(15,23,42,.5);
  }
  body:not(.wp-admin) .mfc-filter-sheet{
    inset:auto 0 0 0;
    max-height:min(92vh, 820px);
    border-radius:22px 22px 0 0;
  }
  body:not(.wp-admin) .mfc-filter-sheet-body{
    padding:14px 14px calc(18px + env(safe-area-inset-bottom));
  }
  body:not(.wp-admin) .mfc-filter-overlay .mfc-filters-form{
    padding:0;
  }
  body:not(.wp-admin) .mfc-filter-list{
    max-height:none;
  }
  body:not(.wp-admin) .mfc-filter-title{
    font-size:15px;
  }
  body:not(.wp-admin) .mfc-filter-opt{
    min-height:42px;
    font-size:14px;
  }
  body:not(.wp-admin) .mfc-card-gallery-nav{
    opacity:1;
    pointer-events:auto;
  }
}
@media (max-width: 820px){
  body:not(.wp-admin) .mfc-catalog{
    grid-template-columns:repeat(2, minmax(0, 1fr)) !important;
    gap:12px;
  }
  body:not(.wp-admin) .mfc-card-body{
    padding:12px;
  }
  body:not(.wp-admin) .mfc-title{
    font-size:14px;
  }
  body:not(.wp-admin) .mfc-price{
    font-size:16px;
  }
}
@media (max-width: 560px){
  body:not(.wp-admin) .mfc-catalog-layout,
  body:not(.wp-admin) .mfc-catalog-main,
  body:not(.wp-admin) .mfc-catalog-wrap{
    min-width:0;
  }
  body:not(.wp-admin) .mfc-catalog-layout{padding-inline:0 !important}
  body:not(.wp-admin) .mfc-catalog{
    grid-template-columns:repeat(2, minmax(0, 1fr)) !important;
    gap:10px;
  }
  body:not(.wp-admin) .mfc-search-actions{
    gap:8px;
    right:6px;
  }
  body:not(.wp-admin) .mfc-search-go{
    padding:0 14px;
  }
  body:not(.wp-admin) .mfc-card-gallery-ui{
    padding:8px 10px 0;
    gap:8px;
  }
  body:not(.wp-admin) .mfc-card-gallery-count{
    font-size:11px;
  }
  body:not(.wp-admin) .mfc-card-gallery-nav{
    width:30px;
    height:30px;
  }
}
@media (max-width: 380px){
  body:not(.wp-admin) .mfc-catalog{
    grid-template-columns:1fr !important;
  }
}


/* Mobile filters drawer hard-fix */
@media (max-width: 980px){
  body:not(.wp-admin) .mfc-filter-overlay{
    display:none;
    position:fixed !important;
    inset:0 !important;
    z-index:999999 !important;
    align-items:flex-end !important;
    justify-content:stretch !important;
    background:rgba(15,23,42,.56) !important;
    -webkit-backdrop-filter:blur(2px);
    backdrop-filter:blur(2px);
  }
  body:not(.wp-admin) .mfc-filter-overlay.is-open{
    display:flex !important;
  }
  body:not(.wp-admin) .mfc-filter-sheet{
    position:relative !important;
    left:auto !important;
    right:auto !important;
    bottom:auto !important;
    width:100% !important;
    min-height:55vh !important;
    max-height:92vh !important;
    margin-top:auto !important;
    background:#fff !important;
    border-radius:22px 22px 0 0 !important;
    box-shadow:0 -18px 44px rgba(0,0,0,.22) !important;
    overflow:hidden !important;
    display:flex !important;
    flex-direction:column !important;
  }
  body:not(.wp-admin) .mfc-filter-sheet-body{
    display:block !important;
    flex:1 1 auto !important;
    min-height:0 !important;
    overflow:auto !important;
    -webkit-overflow-scrolling:touch;
    background:#fff !important;
  }
  body:not(.wp-admin) .mfc-filter-overlay .mfc-filters-form{
    display:block !important;
    min-height:1px !important;
  }
}

/* Runtime mobile filters drawer hard fix */
@media (max-width: 980px){
  html.mfc-filters-open,
  body.mfc-filters-open{
    overflow:hidden !important;
    touch-action:none;
  }
  body:not(.wp-admin) .mfc-filter-overlay--runtime{
    display:none !important;
    position:fixed !important;
    inset:0 !important;
    z-index:2147483000 !important;
    background:rgba(15,23,42,.58) !important;
    align-items:flex-end !important;
    justify-content:stretch !important;
    padding:0 !important;
    margin:0 !important;
    opacity:1 !important;
    visibility:visible !important;
  }
  body:not(.wp-admin) .mfc-filter-overlay--runtime.is-open{
    display:flex !important;
  }
  body:not(.wp-admin) .mfc-filter-sheet--runtime{
    position:relative !important;
    width:100% !important;
    max-width:100% !important;
    min-height:62vh !important;
    max-height:92vh !important;
    margin-top:auto !important;
    background:#fff !important;
    border-radius:22px 22px 0 0 !important;
    box-shadow:0 -20px 50px rgba(0,0,0,.24) !important;
    overflow:hidden !important;
    display:flex !important;
    flex-direction:column !important;
    transform:none !important;
  }
  body:not(.wp-admin) .mfc-filter-sheet-body--runtime{
    flex:1 1 auto !important;
    min-height:0 !important;
    overflow:auto !important;
    -webkit-overflow-scrolling:touch !important;
    padding:14px 14px calc(18px + env(safe-area-inset-bottom)) !important;
    background:#fff !important;
  }
  body:not(.wp-admin) .mfc-filter-overlay--runtime .mfc-filters-form{
    display:block !important;
    border:none !important;
    border-radius:0 !important;
    background:#fff !important;
    padding:0 !important;
    margin:0 !important;
    box-shadow:none !important;
  }
}

/* v54: hide catalog card gallery arrows on all devices */
body:not(.wp-admin) .mfc-card-gallery-nav{display:none !important;}

/* === v56: mobile fix for product characteristics === */
@media (max-width: 767px){
  body:not(.wp-admin) .mfc-product .mfc-chars{
    padding:12px !important;
  }

  body:not(.wp-admin) .mfc-product .mfc-chars-grid,
  body:not(.wp-admin) .mfc-chars-grid{
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
    gap:10px !important;
  }

  body:not(.wp-admin) .mfc-product .mfc-char,
  body:not(.wp-admin) .mfc-char{
    display:flex !important;
    flex-direction:column !important;
    align-items:flex-start !important;
    justify-content:flex-start !important;
    gap:6px !important;
    min-width:0 !important;
    padding:10px 10px 12px !important;
  }

  body:not(.wp-admin) .mfc-product .mfc-char-k,
  body:not(.wp-admin) .mfc-product .mfc-char-v,
  body:not(.wp-admin) .mfc-char-k,
  body:not(.wp-admin) .mfc-char-v{
    display:block !important;
    width:100% !important;
    max-width:100% !important;
    min-width:0 !important;
    text-align:left !important;
    word-break:break-word !important;
    overflow-wrap:anywhere !important;
    hyphens:auto !important;
    white-space:normal !important;
    line-height:1.3 !important;
  }

  body:not(.wp-admin) .mfc-product .mfc-char-k,
  body:not(.wp-admin) .mfc-char-k{
    font-size:12px !important;
    color:#6b7280 !important;
  }

  body:not(.wp-admin) .mfc-product .mfc-char-v,
  body:not(.wp-admin) .mfc-char-v{
    font-size:15px !important;
    font-weight:700 !important;
  }
}

@media (max-width: 420px){
  body:not(.wp-admin) .mfc-product .mfc-chars-grid,
  body:not(.wp-admin) .mfc-chars-grid{
    grid-template-columns:1fr 1fr !important;
    gap:8px !important;
  }

  body:not(.wp-admin) .mfc-product .mfc-char,
  body:not(.wp-admin) .mfc-char{
    padding:9px 9px 10px !important;
    border-radius:12px !important;
  }

  body:not(.wp-admin) .mfc-product .mfc-char-k,
  body:not(.wp-admin) .mfc-char-k{
    font-size:11px !important;
  }

  body:not(.wp-admin) .mfc-product .mfc-char-v,
  body:not(.wp-admin) .mfc-char-v{
    font-size:14px !important;
  }
}

/* no-AJAX catalog: classic pagination + bottom variation rail */
body:not(.wp-admin) .mfc-card-link,
body:not(.wp-admin) .mfc-card-mainlink{
  display:block;
  color:inherit;
  text-decoration:none;
}
body:not(.wp-admin) .mfc-card-mainlink:hover{color:inherit;text-decoration:none}
body:not(.wp-admin) .mfc-card-item{
  display:flex;
  flex-direction:column;
  height:100%;
  position:relative;
  overflow:visible;
}
body:not(.wp-admin) .mfc-card-body{padding-top:12px}
body:not(.wp-admin) .mfc-card-img{
  position:relative !important;
  overflow:hidden !important;
}
body:not(.wp-admin) .mfc-pagination{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap;margin:18px 0 0}
body:not(.wp-admin) .mfc-page{display:inline-flex;align-items:center;justify-content:center;min-width:40px;height:40px;padding:0 12px;border-radius:999px;border:1px solid rgba(17,24,39,.14);background:#fff;color:#111827;text-decoration:none;font-weight:700}
body:not(.wp-admin) .mfc-page:hover{border-color:rgba(17,24,39,.28);text-decoration:none}
body:not(.wp-admin) .mfc-page.is-current{background:#111827;color:#fff;border-color:#111827}
body:not(.wp-admin) .mfc-page-dots{opacity:.5;padding:0 4px}

body:not(.wp-admin) .mfc-card-item .mfc-card-vars{--mfc-vars-strip-h:44px;--mfc-swatch:28px;position:relative;margin:8px 12px 0;min-height:var(--mfc-vars-strip-h);overflow:hidden;z-index:6}
body:not(.wp-admin) .mfc-card-item .mfc-card-vars.is-empty{display:none}
body:not(.wp-admin) .mfc-card-item .mfc-card-vars-panel{position:relative;width:100%;min-height:var(--mfc-vars-strip-h);max-width:100%;overflow:hidden;padding:6px 8px;border-radius:14px;border:1px solid rgba(0,0,0,.10);background:rgba(255,255,255,.96);box-shadow:0 8px 18px rgba(0,0,0,.10);transition:min-height .18s ease,box-shadow .18s ease,border-color .18s ease;backdrop-filter:blur(3px)}
body:not(.wp-admin) .mfc-card-item .mfc-card-vars:hover .mfc-card-vars-panel,
body:not(.wp-admin) .mfc-card-item .mfc-card-vars:focus-within .mfc-card-vars-panel{border-color:rgba(0,0,0,.16);box-shadow:0 16px 36px rgba(0,0,0,.14)}
body:not(.wp-admin) .mfc-card-item .mfc-card-vars-grid{display:flex;flex-wrap:nowrap;gap:8px;align-items:center;align-content:flex-start;overflow:hidden;max-height:30px;padding-bottom:2px;scrollbar-width:none}
body:not(.wp-admin) .mfc-card-item .mfc-card-vars-grid::-webkit-scrollbar{display:none}
body:not(.wp-admin) .mfc-card-item .mfc-card-vars:hover .mfc-card-vars-grid,
body:not(.wp-admin) .mfc-card-item .mfc-card-vars:focus-within .mfc-card-vars-grid{flex-wrap:wrap;max-height:none}
body:not(.wp-admin) .mfc-card-item .mfc-card-var-swatch{width:var(--mfc-swatch);height:var(--mfc-swatch);border-radius:10px;overflow:hidden;border:1px solid rgba(0,0,0,.10);background:rgba(0,0,0,.04);display:flex;align-items:center;justify-content:center;text-decoration:none;flex:0 0 auto}
body:not(.wp-admin) .mfc-card-item .mfc-card-vars-foot{display:none !important}
@media (max-width: 980px){
  body:not(.wp-admin) .mfc-card-item .mfc-card-vars{margin-top:8px}
}


/* swatches: force paint even when browser delays IMG rendering */
body:not(.wp-admin) .mfc-color-thumb{position:relative;background-position:center;background-repeat:no-repeat;background-size:cover}
body:not(.wp-admin) .mfc-color-thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;opacity:0;transition:opacity .12s ease}
body:not(.wp-admin) .mfc-color-thumb.is-ready img{opacity:1}
body:not(.wp-admin) .mfc-color-thumb[data-has-thumb="1"] .mfc-color-fallback{display:none}
body:not(.wp-admin) .mfc-color-thumb:not(.is-ready)[data-has-thumb="1"] .mfc-color-fallback{display:none}


.mfc-loadmore-wrap{display:flex;justify-content:center;align-items:center;margin:26px 0 10px}
.mfc-loadmore-btn{appearance:none;border:0;background:#111827;color:#fff;border-radius:16px;padding:15px 26px;min-width:260px;font-size:16px;font-weight:800;line-height:1;cursor:pointer;transition:transform .15s ease,opacity .15s ease,box-shadow .15s ease;box-shadow:0 12px 28px rgba(17,24,39,.16)}
.mfc-loadmore-btn:hover{transform:translateY(-1px);opacity:.98}
.mfc-loadmore-btn:disabled{opacity:.65;cursor:default;transform:none}
.mfc-loadmore-meta{font-size:14px;color:#6b7280}


/* === v23: practical filters + softer catalog typography === */
body:not(.wp-admin) .mfc-catalog-sidebar{
  max-height:calc(100vh - var(--mfc-sticky-top, 16px) - 8px);
}
body:not(.wp-admin) .mfc-filters-form{
  max-height:calc(100vh - var(--mfc-sticky-top, 16px) - 8px);
  overflow:auto;
  scrollbar-width:thin;
}
body:not(.wp-admin) .mfc-active-filters{
  margin:0 0 12px;
  padding:12px;
  border:1px solid rgba(17,24,39,.08);
  border-radius:14px;
  background:#f8fafc;
}
body:not(.wp-admin) .mfc-active-filters-head{
  margin:0 0 8px;
  font-size:12px;
  font-weight:700;
  color:#5b6472;
  text-transform:uppercase;
  letter-spacing:.04em;
}
body:not(.wp-admin) .mfc-active-filters-list{display:flex;flex-wrap:wrap;gap:8px}
body:not(.wp-admin) .mfc-active-chip{
  display:inline-flex;align-items:center;gap:6px;max-width:100%;
  padding:7px 10px;border-radius:999px;
  background:#fff;border:1px solid rgba(17,24,39,.08);
  color:#2f3440;font-size:12px;line-height:1.2;
}
body:not(.wp-admin) .mfc-active-chip-label{color:#6b7280}
body:not(.wp-admin) .mfc-active-chip-value{font-weight:600}
body:not(.wp-admin) .mfc-filter-list{
  max-height:none !important;
  overflow:visible !important;
  padding-right:0;
}
body:not(.wp-admin) .mfc-filter-block.is-long:not(.is-expanded) .mfc-filter-list{
  max-height:252px !important;
  overflow:hidden !important;
}
body:not(.wp-admin) .mfc-filter-more{
  display:inline-flex;align-items:center;justify-content:center;
  margin-top:8px;padding:0;border:0;background:none;
  cursor:pointer;color:#5b6472;font-size:13px;font-weight:600;
}
body:not(.wp-admin) .mfc-filter-more:hover{color:#20242c}

body:not(.wp-admin) .mfc-filter-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
body:not(.wp-admin) .mfc-filter-head .mfc-filter-title{
  flex:1 1 auto;
  min-width:0;
}
body:not(.wp-admin) .mfc-filter-more{
  flex:0 0 auto;
  margin-top:0;
  font-size:12px;
  font-weight:500;
  opacity:.82;
}
body:not(.wp-admin) .mfc-filter-block.is-expanded .mfc-filter-more{
  opacity:1;
}
body:not(.wp-admin) .mfc-title{
  font-size:15px;
  line-height:1.42;
  font-weight:600;
  color:#2f3440;
  letter-spacing:.01em;
}
body:not(.wp-admin) .mfc-price{
  font-size:18px;
  font-weight:700;
  color:#232831;
}
body:not(.wp-admin) .mfc-card-gallery-count{
  font-weight:600;
  color:rgba(17,24,39,.62);
}
body:not(.wp-admin) .mfc-filter-title{
  font-weight:600;
  color:#2f3440;
}
body:not(.wp-admin) .mfc-filter-opt{
  align-items:flex-start;
  line-height:1.35;
  color:#4b5563;
}
@media (max-width: 980px){
  body:not(.wp-admin) .mfc-filters-form{
    max-height:none;
    overflow:visible;
  }
}


/* v25: quieter filters + calmer product typography */
body:not(.wp-admin) .mfc-filter-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}

body:not(.wp-admin) .mfc-filter-block[data-facet="1"] .mfc-filter-title{
  position:relative;
  padding-right:18px;
  font-weight:500;
  color:#3a4250;
  cursor:pointer;
}

body:not(.wp-admin) .mfc-filter-block[data-facet="1"] .mfc-filter-title::after{
  content:'▸';
  position:absolute;
  right:0;
  top:50%;
  transform:translateY(-50%);
  font-size:11px;
  color:#8a93a2;
  transition:transform .16s ease, color .16s ease;
}

body:not(.wp-admin) .mfc-filter-block[data-facet="1"]:not(.is-collapsed) .mfc-filter-title::after{
  transform:translateY(-50%) rotate(90deg);
  color:#667085;
}

body:not(.wp-admin) .mfc-filter-block.is-collapsed .mfc-filter-list,
body:not(.wp-admin) .mfc-filter-block.is-collapsed .mfc-filter-more{
  display:none !important;
}

body:not(.wp-admin) .mfc-filter-block:not(.is-collapsed) .mfc-filter-more{
  display:inline-flex;
}

body:not(.wp-admin) .mfc-filter-more{
  margin-top:6px;
  padding-left:28px;
  font-size:12px;
  font-weight:500;
  color:#7a8391;
  background:none;
  border:0;
}

body:not(.wp-admin) .mfc-filter-more:hover{
  color:#4c5563;
}

body:not(.wp-admin) .mfc-filter-opt{
  color:#5d6675;
  font-size:14px;
}

body:not(.wp-admin) .mfc-title{
  font-size:15px;
  line-height:1.48;
  font-weight:500;
  color:#374151;
  letter-spacing:0;
}

body:not(.wp-admin) .mfc-price{
  font-size:17px;
  line-height:1.3;
  font-weight:600;
  color:#2f3742;
}

body:not(.wp-admin) .mfc-card-gallery-count{
  font-weight:500;
  color:rgba(17,24,39,.55);
}

@media (max-width: 820px){
  body:not(.wp-admin) .mfc-title{
    font-size:14px;
  }
  body:not(.wp-admin) .mfc-price{
    font-size:15px;
  }
}


/* v26b: reset moved into selected block */
body:not(.wp-admin) .mfc-active-filters-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:12px;
}

body:not(.wp-admin) .mfc-active-filters-title{
  display:inline-block;
}

body:not(.wp-admin) .mfc-filter-reset--top{
  font-size:12px;
  font-weight:500;
  color:#7a8391;
  text-decoration:none;
  white-space:nowrap;
  opacity:1;
}

body:not(.wp-admin) .mfc-filter-reset--top:hover{
  color:#4c5563;
  text-decoration:none;
}

body:not(.wp-admin) .mfc-filter-actions{
  display:none !important;
}



/* v27: compact selected block + tighter filters */
body:not(.wp-admin) .mfc-active-filters{
  padding:12px 12px 10px;
  border-radius:16px;
}

body:not(.wp-admin) .mfc-active-filters-head{
  margin-bottom:10px;
}

body:not(.wp-admin) .mfc-active-filters-title{
  font-size:12px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#5d6675;
  font-weight:600;
}

body:not(.wp-admin) .mfc-active-filters-list{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

body:not(.wp-admin) .mfc-active-chip{
  padding:7px 10px;
  border-radius:999px;
  font-size:13px;
  line-height:1.2;
  background:#fff;
  border:1px solid rgba(15,23,42,.08);
}

body:not(.wp-admin) .mfc-active-chip-label{
  color:#7a8391;
  font-weight:500;
  margin-right:4px;
}

body:not(.wp-admin) .mfc-active-chip-value{
  color:#374151;
  font-weight:500;
}

body:not(.wp-admin) .mfc-filter-block{
  margin-bottom:8px;
}

body:not(.wp-admin) .mfc-filter-block[data-facet="1"]{
  padding:8px 0;
}

body:not(.wp-admin) .mfc-filter-head{
  min-height:28px;
}

body:not(.wp-admin) .mfc-filter-block[data-facet="1"] .mfc-filter-title{
  font-size:14px;
  line-height:1.25;
  padding-right:16px;
}

body:not(.wp-admin) .mfc-filter-block[data-facet="1"] .mfc-filter-title::after{
  font-size:10px;
}

body:not(.wp-admin) .mfc-filter-list{
  margin-top:6px;
}

body:not(.wp-admin) .mfc-filter-opt{
  min-height:30px;
  padding:2px 0;
  font-size:13px;
  line-height:1.25;
  gap:7px;
}

body:not(.wp-admin) .mfc-filter-opt input{
  width:14px;
  height:14px;
  margin-top:1px;
}

body:not(.wp-admin) .mfc-filter-more{
  margin-top:4px;
  padding-left:22px;
  font-size:11px;
}

body:not(.wp-admin) .mfc-input,
body:not(.wp-admin) select.mfc-input,
body:not(.wp-admin) input.mfc-input{
  min-height:38px;
  padding-top:8px;
  padding-bottom:8px;
  font-size:14px;
}

body:not(.wp-admin) .mfc-filter-cat{
  margin-bottom:12px;
}

body:not(.wp-admin) .mfc-active-filters + .mfc-filter-block,
body:not(.wp-admin) .mfc-active-filters + .mfc-filter-cat{
  margin-top:4px;
}



/* v29: picker modal */
body:not(.wp-admin) .mfc-picker-open{
  min-height:44px;
  padding:0 16px;
  border-radius:14px;
  border:1px solid rgba(0,0,0,.12);
  background:#fff;
  color:#2f3742;
  font-size:14px;
  font-weight:600;
  cursor:pointer;
  transition:background .15s ease, border-color .15s ease, transform .12s ease;
}
body:not(.wp-admin) .mfc-picker-open:hover{
  background:rgba(0,0,0,.02);
  border-color:rgba(0,0,0,.18);
}
body:not(.wp-admin) .mfc-picker-open:active{
  transform:translateY(1px);
}

body.mfc-picker-opened,
html.mfc-picker-opened{
  overflow:hidden;
}

body:not(.wp-admin) .mfc-picker-overlay{
  position:fixed;
  inset:0;
  z-index:1000001;
  background:rgba(15,23,42,.42);
  backdrop-filter:blur(4px);
  -webkit-backdrop-filter:blur(4px);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
}
body:not(.wp-admin) .mfc-picker-overlay[hidden]{
  display:none !important;
}
body:not(.wp-admin) .mfc-picker-sheet{
  width:min(1080px, 100%);
  max-height:min(86vh, 860px);
  background:#fff;
  border-radius:24px;
  box-shadow:0 24px 80px rgba(15,23,42,.18);
  display:flex;
  flex-direction:column;
  overflow:hidden;
}
body:not(.wp-admin) .mfc-picker-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  padding:20px 22px 16px;
  border-bottom:1px solid rgba(15,23,42,.08);
}
body:not(.wp-admin) .mfc-picker-title{
  font-size:20px;
  font-weight:600;
  color:#2f3742;
}
body:not(.wp-admin) .mfc-picker-subtitle{
  margin-top:4px;
  font-size:13px;
  color:#7a8391;
}
body:not(.wp-admin) .mfc-picker-close{
  width:38px;
  height:38px;
  border-radius:12px;
  border:1px solid rgba(0,0,0,.1);
  background:#fff;
  color:#445063;
  font-size:24px;
  line-height:1;
  cursor:pointer;
}
body:not(.wp-admin) .mfc-picker-body{
  display:grid;
  grid-template-columns:320px 1fr;
  gap:0;
  min-height:0;
  flex:1 1 auto;
}
body:not(.wp-admin) .mfc-picker-col{
  min-height:0;
  overflow:auto;
  padding:18px 22px 20px;
}
body:not(.wp-admin) .mfc-picker-col--cats{
  border-right:1px solid rgba(15,23,42,.08);
  background:rgba(248,250,252,.7);
}
body:not(.wp-admin) .mfc-picker-col-title{
  font-size:13px;
  font-weight:600;
  color:#5d6675;
  letter-spacing:.04em;
  text-transform:uppercase;
  margin-bottom:12px;
}
body:not(.wp-admin) .mfc-picker-cats{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
body:not(.wp-admin) .mfc-picker-catchip,
body:not(.wp-admin) .mfc-picker-val{
  display:inline-flex;
  align-items:center;
  gap:8px;
  min-height:36px;
  padding:0 12px;
  border-radius:999px;
  border:1px solid rgba(15,23,42,.10);
  background:#fff;
  color:#4b5563;
  font-size:13px;
  font-weight:500;
  cursor:pointer;
}
body:not(.wp-admin) .mfc-picker-catchip em{
  font-style:normal;
  color:#8a93a2;
  font-size:12px;
}
body:not(.wp-admin) .mfc-picker-catchip.is-active,
body:not(.wp-admin) .mfc-picker-val.is-active{
  background:#111827;
  border-color:#111827;
  color:#fff;
}
body:not(.wp-admin) .mfc-picker-catchip.is-active em{
  color:rgba(255,255,255,.76);
}
body:not(.wp-admin) .mfc-picker-group + .mfc-picker-group{
  margin-top:16px;
}
body:not(.wp-admin) .mfc-picker-group-title{
  margin-bottom:10px;
  font-size:14px;
  font-weight:600;
  color:#374151;
}
body:not(.wp-admin) .mfc-picker-values{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
body:not(.wp-admin) .mfc-picker-empty{
  color:#7a8391;
  font-size:14px;
  line-height:1.45;
}
body:not(.wp-admin) .mfc-picker-foot{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:16px 22px 20px;
  border-top:1px solid rgba(15,23,42,.08);
  background:#fff;
}
body:not(.wp-admin) .mfc-picker-total{
  font-size:15px;
  font-weight:600;
  color:#2f3742;
}
body:not(.wp-admin) .mfc-picker-actions{
  display:flex;
  align-items:center;
  gap:10px;
}
body:not(.wp-admin) .mfc-picker-overlay.is-loading .mfc-picker-total{
  opacity:.65;
}
@media (max-width: 980px){
  body:not(.wp-admin) .mfc-search-toolbar{
    gap:10px;
  }
  body:not(.wp-admin) .mfc-picker-open{
    width:100%;
  }
  body:not(.wp-admin) .mfc-picker-overlay{
    align-items:flex-end;
    padding:0;
    background:rgba(15,23,42,.5);
  }
  body:not(.wp-admin) .mfc-picker-sheet{
    width:100%;
    max-height:92vh;
    border-radius:22px 22px 0 0;
  }
  body:not(.wp-admin) .mfc-picker-head{
    padding:16px 16px 12px;
  }
  body:not(.wp-admin) .mfc-picker-title{
    font-size:18px;
  }
  body:not(.wp-admin) .mfc-picker-body{
    grid-template-columns:1fr;
  }
  body:not(.wp-admin) .mfc-picker-col{
    padding:14px 16px 16px;
  }
  body:not(.wp-admin) .mfc-picker-col--cats{
    border-right:0;
    border-bottom:1px solid rgba(15,23,42,.08);
  }
  body:not(.wp-admin) .mfc-picker-foot{
    padding:14px 16px calc(16px + env(safe-area-inset-bottom));
    flex-direction:column;
    align-items:stretch;
  }
  body:not(.wp-admin) .mfc-picker-actions{
    width:100%;
  }
  body:not(.wp-admin) .mfc-picker-actions .mfc-btn{
    flex:1 1 0;
    justify-content:center;
    display:inline-flex;
    align-items:center;
  }
}


/* v30: faster picker + cleaner footer */
body:not(.wp-admin) .mfc-picker-foot{
  justify-content:flex-end;
}
body:not(.wp-admin) .mfc-picker-actions{
  margin-left:auto;
}


body:not(.wp-admin) .mfc-filters-note{
  margin:10px 0 14px;
  padding:12px 14px;
  border:1px dashed rgba(17,24,39,.18);
  border-radius:14px;
  background:#f8fafc;
  color:#4b5563;
  font-size:13px;
  line-height:1.45;
}
body:not(.wp-admin) .mfc-filters-form.has-category .mfc-filters-note{display:none}


/* ===== Product card bottom row: extras + add to cart on one line ===== */
.mfc-var-bottomrow{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:18px;
  margin-top:auto;
  padding-top:16px;
  flex-wrap:wrap;
}

.mfc-var-bottomrow .mfc-var-section--extra{
  margin:0;
  flex:1 1 320px;
}

.mfc-var-bottomrow .mfc-var-label{
  margin-bottom:8px;
}

.mfc-var-bottomrow .mfc-var-extras{
  margin-top:0;
}

.mfc-var-bottomrow .mfc-var-actions{
  margin-top:0;
  margin-left:auto;
  align-self:flex-end;
  flex:0 0 auto;
}

.mfc-product-buybar--inline{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:8px;
}

.mfc-buybar-msg{
  min-height:18px;
  font-size:12px;
  color:#4b5563;
}

@media (max-width: 900px){
  .mfc-var-bottomrow{
    align-items:stretch;
  }

  .mfc-var-bottomrow .mfc-var-actions,
  .mfc-product-buybar--inline{
    width:100%;
    align-items:stretch;
  }

  .mfc-var-actions .mfc-btn{
    width:100%;
    justify-content:center;
  }
}
