/* Масла.сайт — Быстрый просмотр товара (Quick View).
   Автоподключается из ProductCard.jsx, поэтому работает на всех страницах.
   Содержит и триггер на карточке (.pc-qv), и модалку (.qv-*), и свою адаптивность. */

/* ---------- триггер на карточке ---------- */
.pc-qv {
  position: absolute; top: 10px; right: 10px; z-index: 3;
  width: 34px; height: 34px; border-radius: var(--r-pill);
  background: #fff; box-shadow: var(--el-1); color: var(--neutral-500);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transform: scale(0.9);
  transition: opacity 150ms var(--ease-out), transform 150ms var(--ease-out), color 150ms, background 150ms;
}
.pc:hover .pc-qv { opacity: 1; transform: scale(1); }
.pc-qv:hover { color: var(--cyan); background: var(--cyan-50); }
/* на тач-устройствах ховера нет — показываем всегда */
@media (hover: none) {
  .pc-qv { opacity: 1; transform: none; }
}

/* ---------- scrim + модалка ---------- */
.qv-scrim {
  position: fixed; inset: 0; z-index: 320; background: rgba(19, 22, 29, 0.55);
  display: flex; align-items: flex-start; justify-content: center;
  padding: 6vh 20px 20px; overflow-y: auto;
  animation: qvFade 160ms var(--ease-out);
}
@keyframes qvFade { from { opacity: 0; } to { opacity: 1; } }
.qv-modal {
  /* Шире — на ширину контента листинга (handoff: была узкой) — и с внутренним
     скроллом, чтобы карточка не вылезала за экран по вертикали. */
  position: relative; width: min(1080px, 100%); background: #fff;
  max-height: calc(100vh - 48px); overflow-y: auto; overscroll-behavior: contain;
  border-radius: var(--r-lg); box-shadow: var(--el-pop);
  padding: 28px 30px 22px; animation: qvPop 200ms var(--ease-out);
  /* модалка монтируется в body вне .mk — задаём семейство явно, чтобы
     вложенные элементы без font-family не падали на системный serif */
  font-family: var(--font-body); color: var(--masla-navy);
}
@keyframes qvPop { from { opacity: 0; transform: translateY(12px) scale(0.98); } to { opacity: 1; transform: none; } }
.qv-x {
  position: absolute; top: 14px; right: 14px; width: 38px; height: 38px;
  display: flex; align-items: center; justify-content: center; border-radius: var(--r-pill);
  color: var(--neutral-400); transition: background 120ms, color 120ms; z-index: 2;
}
.qv-x:hover { background: var(--soft); color: var(--masla-navy); }

/* ---------- верх: маленькое фото + данные ---------- */
.qv-top { display: grid; grid-template-columns: 188px 1fr; gap: 26px; align-items: start; }

.qv-media {
  position: relative; background: linear-gradient(180deg, #fff, var(--soft));
  border-radius: var(--r-md); height: 220px; padding: 16px;
  display: flex; align-items: flex-end; justify-content: center; overflow: hidden;
}
.qv-media .pdrum, .qv-media .pjerry { transform: scale(0.92); }
.qv-badges { position: absolute; top: 12px; left: 12px; display: flex; flex-direction: column; gap: 6px; align-items: flex-start; }

.qv-info { min-width: 0; padding-right: 30px; }
.qv-eyb {
  font-size: 11px; font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase;
  color: var(--cyan-700); margin-bottom: 8px;
}
.qv-title {
  display: block; font-family: var(--font-display); font-weight: 800; font-size: 21px;
  line-height: 1.22; letter-spacing: -0.01em; color: var(--masla-navy); text-wrap: pretty;
  transition: color 130ms;
}
.qv-title:hover { color: var(--cyan-700); }
.qv-sku { font-family: var(--font-mono); font-size: 12px; color: var(--neutral-400); margin-top: 8px; }

/* характеристики — компактная сетка */
.qv-specs {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px;
  background: var(--border-default); border: 1px solid var(--border-default); border-radius: var(--r-sm);
  overflow: hidden; margin: 16px 0 14px;
}
.qv-spec { background: #fff; padding: 9px 12px; display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.qv-spec .k { font-size: 11px; color: var(--neutral-500); }
.qv-spec .v { font-size: 13.5px; font-weight: 600; color: var(--masla-navy); line-height: 1.25; }
/* последняя строка одна — растягиваем на 2 колонки, если нечётная */
.qv-spec:last-child:nth-child(odd) { grid-column: 1 / -1; }

/* выдержка из описания */
.qv-desc { font-size: 13.5px; line-height: 1.55; color: var(--neutral-700); margin: 0 0 14px; text-wrap: pretty; }
.qv-more { color: var(--cyan-700); font-weight: 600; white-space: nowrap; }
.qv-more:hover { color: var(--cyan-900); }

/* преимущества товара — уменьшенные */
.qv-perks { display: flex; flex-direction: column; gap: 8px; }
.qv-perk { display: flex; align-items: center; gap: 9px; font-size: 13px; color: var(--masla-navy); }
.qv-perk .ic { color: var(--cyan); flex-shrink: 0; }

/* ---------- подвал: цена + действия ---------- */
.qv-foot {
  display: flex; align-items: center; justify-content: space-between; gap: 20px; flex-wrap: wrap;
  margin-top: 22px; padding-top: 18px; border-top: var(--hairline);
}
.qv-price { min-width: 0; }
.qv-price-row { display: flex; align-items: baseline; gap: 7px; }
.qv-price .p { font-family: var(--font-display); font-weight: 800; font-size: 26px; color: var(--masla-navy); }
.qv-price .u { font-size: 13px; color: var(--neutral-400); }
.qv-vat { font-size: 12px; color: var(--neutral-400); margin-top: 3px; }

.qv-actions { display: flex; align-items: stretch; gap: 8px; }
.qv-add {
  background: var(--cyan); color: #fff; border-radius: var(--r-sm);
  font-family: var(--font-body); font-size: 15px; font-weight: 600; padding: 0 26px; height: 48px;
  display: inline-flex; align-items: center; gap: 9px; transition: background 150ms;
}
.qv-add:hover { background: var(--cyan-700); }
.qv-qty {
  display: flex; align-items: center; justify-content: space-between; min-width: 132px;
  border: 1px solid var(--cyan); border-radius: var(--r-sm); overflow: hidden;
}
.qv-qty button { width: 46px; align-self: stretch; color: var(--cyan-700); display: flex; align-items: center; justify-content: center; transition: background 120ms; }
.qv-qty button:hover { background: var(--cyan-50); }
.qv-qty .v { font-family: var(--font-display); font-weight: 700; font-size: 17px; color: var(--masla-navy); min-width: 40px; text-align: center; font-variant-numeric: tabular-nums; }
.qv-iconbtn {
  width: 48px; border-radius: var(--r-sm); border: var(--hairline-strong); color: var(--masla-navy);
  display: flex; align-items: center; justify-content: center;
  transition: border-color 150ms, color 150ms, background 150ms;
}
.qv-iconbtn { cursor: pointer; }
/* .wpaic-compare-btn--active / .wpaic-wishlist-btn--active вешают JS темы при добавлении —
   иконка заполняется цветом, показывая что товар в сравнении/избранном. */
.qv-iconbtn:hover, .qv-iconbtn.on, .qv-iconbtn.wpaic-compare-btn--active { border-color: var(--cyan); color: var(--cyan); background: var(--cyan-50); }
.qv-favbtn:hover, .qv-favbtn.on, .qv-favbtn.wpaic-wishlist-btn--active { border-color: var(--danger); color: var(--danger); background: var(--danger-bg); }
.qv-favbtn.wpaic-wishlist-btn--active svg { fill: var(--danger); }

/* ---------- плюсы компании — короткой строкой ---------- */
.qv-guarantees {
  display: flex; align-items: center; flex-wrap: wrap; gap: 8px 18px;
  margin-top: 16px; padding-top: 14px; border-top: var(--hairline);
}
.qv-guar { display: inline-flex; align-items: center; gap: 7px; font-size: 12.5px; color: var(--neutral-500); }
.qv-guar svg { color: var(--cyan); }
.qv-fulllink {
  margin-left: auto; display: inline-flex; align-items: center; gap: 6px;
  font-size: 13.5px; font-weight: 600; color: var(--cyan-700); transition: gap 150ms, color 150ms;
}
.qv-fulllink:hover { color: var(--cyan-900); gap: 9px; }

/* ---------- адаптивность ---------- */
@media (max-width: 620px) {
  .qv-scrim { padding: 0; align-items: flex-end; }
  .qv-modal {
    width: 100%; border-radius: var(--r-lg) var(--r-lg) 0 0; padding: 22px 18px 18px;
    max-height: 94vh; overflow-y: auto; animation: qvSheet 240ms var(--ease-out);
  }
  @keyframes qvSheet { from { transform: translateY(100%); } to { transform: none; } }
  .qv-top { grid-template-columns: 110px 1fr; gap: 16px; }
  .qv-media { height: 150px; padding: 10px; }
  .qv-info { padding-right: 30px; }
  .qv-title { font-size: 18px; }
  .qv-specs { grid-template-columns: 1fr; }
  .qv-spec:last-child:nth-child(odd) { grid-column: auto; }
  .qv-foot { flex-direction: column; align-items: stretch; gap: 14px; }
  .qv-actions { width: 100%; }
  .qv-add { flex: 1; justify-content: center; }
  .qv-qty { flex: 1; }
  .qv-fulllink { margin-left: 0; }
}
@media (max-width: 420px) {
  .qv-top { grid-template-columns: 1fr; }
  .qv-media { height: 160px; }
  .qv-badges { flex-direction: row; flex-wrap: wrap; }
}

/* ---------- индикатор загрузки модалки (vanilla-версия) ---------- */
.qv-loading { min-height: 220px; display: flex; align-items: center; justify-content: center; }
.qv-spin {
  width: 34px; height: 34px; border-radius: 50%;
  border: 3px solid var(--border-default, #e5e7eb); border-top-color: var(--cyan, #2a9bc4);
  animation: qvSpin 0.7s linear infinite;
}
@keyframes qvSpin { to { transform: rotate(360deg); } }
