/* v3_1_37 — product fields / structure / bulk fields page-specific CSS.
   Extracted from legacy_overrides.css by page zone.
   Do not add catalog/order/upload rules here. */

/* Fields editor: avoid right side stretching left side */
.fields-layout-fixed {
  display: grid;
  grid-template-columns: minmax(340px, 420px) minmax(0, 1fr);
  gap: 22px;
  align-items: start;
}

.fields-list-panel {
  min-width: 0;
  display: grid;
  gap: 16px;
}

.fields-section-list,
.structure-list.fields-section-list {
  display: grid;
  gap: 18px;
}

.fields-section-card {
  border: 1px solid var(--jit-line, var(--line));
  border-radius: 12px;
  background: var(--panel);
  padding: 18px;
  box-shadow: 0 10px 24px rgba(22, 19, 15, .04);
}

.fields-section-card-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 14px;
  padding-bottom: 12px;
  margin-bottom: 12px;
  border-bottom: 1px solid rgba(222, 212, 198, .75);
}

.fields-section-card-head h4 {
  margin: 0 0 4px;
  font-size: 14px;
  font-weight: 500; /* v3.8.53: было 400 — заголовок секции теперь полужирный (heading) */
}

/* v3.8.53: имя поля в списке не имело своего font-size → падало на дефолт 16px
   (крупнее заголовка секции). Канон как у эталона structure (.field-name 12/500). */
.field-row-card strong {
  font-size: 12px;
  font-weight: 500;
}

.fields-rows {
  display: grid;
  gap: 10px;
}

.field-row-card {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) auto auto;
  gap: 12px;
  align-items: center;
  padding: 12px;
  border: 1px solid rgba(222, 212, 198, .75);
  border-radius: 12px;
  background: rgba(255,255,255,.42);
}

.field-badges {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.field-badges span {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 0 8px;
  border-radius: 999px;
  background: #f1eadf;
  border: 1px solid rgba(222, 212, 198, .85);
  font-size: 11px;
  color: #5c5348;
}

.field-row-actions {
  justify-content: flex-end;
}

.field-row-empty {
  padding: 12px;
  border: 1px dashed var(--jit-line, var(--line));
  border-radius: 12px;
}

/* Bulk editor: configurable columns, horizontal scroll */
.bulk-column-filter {
  border: 1px solid var(--jit-line, var(--line));
  border-radius: 12px;
  background: var(--panel);
  padding: 18px;
  margin-bottom: 18px;
}

.bulk-scroll-strong {
  width: 100%;
  max-width: 100%;
  overflow-x: auto;
  overflow-y: visible;
  border: 1px solid var(--jit-line, var(--line));
  border-radius: 12px;
  background: var(--panel);
}

.bulk-table-wide {
  min-width: 1180px;
  width: max-content;
  border-collapse: separate;
  border-spacing: 0;
}

.bulk-table-wide th,
.bulk-table-wide td {
  white-space: nowrap;
  min-width: 110px;
  padding: 10px;
}

.bulk-table-wide th:first-child,
.bulk-table-wide td:first-child {
  position: sticky;
  left: 0;
  z-index: 2;
  background: var(--panel);
}

.bulk-table-wide input[type="text"],
.bulk-table-wide input:not([type]),
.bulk-table-wide input[type="number"],
.bulk-table-wide select {
  min-width: 150px;
}

.bulk-static {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 10px;
  border-radius: 12px;
  background: #f1eadf;
  color: #5c5348;
}

@media (max-width: 1100px) {

  .field-row-card {
    grid-template-columns: 1fr;
  }

  .field-badges {
    justify-content: flex-start;
  }
}

/* v54: requested UI fixes */

/* 1. Bulk fields filter: cleaner visual filter */
.bulk-column-filter {
  padding: 22px;
  border-radius: 12px;
  background: linear-gradient(180deg, var(--panel), rgba(247,241,232,.96));
  border: 1px solid var(--jit-line, var(--line));
  box-shadow: 0 12px 30px rgba(22,19,15,.045);
}

.bulk-column-filter h3 {
  margin: 0 0 14px;
  font-size: 14px;
}

/* 3-5. Fields cards: required attribute and delete actions */
.field-badges span:first-child {
  background: #fff6e4;
}

.field-row-actions {
  display: flex;
  gap: 8px;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: nowrap;
}
/* Structure pages: avoid huge table-like stretching */
.fields-section-card .field-row-card {
  grid-template-columns: minmax(220px, 1fr) minmax(220px, auto) auto;
}

@media (max-width: 900px) {
  .fields-section-card .field-row-card {
    grid-template-columns: 1fr;
  }
}

/* Excel-like massive table: horizontal scroll retained and better */
.bulk-scroll-strong {
  max-width: 100%;
  overflow-x: auto;
  overflow-y: visible;
  scrollbar-width: thin;
}

.bulk-table-wide {
  table-layout: auto;
}

.bulk-table-wide th {
  position: sticky;
  top: 0;
  z-index: 3;
  background: var(--panel);
}
/* 1. Compact grouped filter for bulk fields editor */
.bulk-column-filter-v55 {
  padding: 16px;
  border-radius: 12px;
  background: var(--panel);
  border: 1px solid var(--jit-line, var(--line));
  box-shadow: 0 8px 22px rgba(22, 19, 15, .035);
}

.bulk-filter-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 12px;
}

.bulk-filter-head h3 {
  margin: 0 0 4px;
  font-size: 14px;
  line-height: 1.2;
}

.bulk-filter-head p {
  margin: 0;
  font-size: 12px;
}

.bulk-filter-actions {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-shrink: 0;
}

.bulk-filter-groups {
  display: grid;
  grid-template-columns: 1.05fr 1.05fr 1.5fr;
  gap: 10px;
  align-items: stretch;
}

.bulk-filter-group {
  margin: 0;
  padding: 10px;
  border: 1px solid rgba(222, 212, 198, .9);
  border-radius: 12px;
  background: rgba(255,255,255,.44);
  min-width: 0;
}

.bulk-filter-group legend {
  padding: 0 7px;
  font-size: 11px;
  font-weight: 500;
  color: #746a5d;
  text-transform: uppercase;
  letter-spacing: .06em;
}

.bulk-filter-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}

.bulk-filter-pill {
  display: inline-flex;
  grid-template-columns: none;
  align-items: center;
  gap: 6px;
  width: auto;
  min-height: 30px;
  padding: 6px 9px;
  border: 1px solid rgba(222, 212, 198, .9);
  border-radius: 999px;
  background: rgba(255,255,255,.68);
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
}

.bulk-filter-pill input {
  width: 13px;
  height: 13px;
  margin: 0;
  padding: 0;
}

.bulk-filter-pill.is-selected,
.bulk-filter-pill:has(input:checked) {
  border-color: var(--dark);
  background: var(--panel);
  box-shadow: inset 0 0 0 1px var(--dark);
}

/* neutralize old large grid inside the new filter */
.bulk-column-filter-v55 .bulk-column-grid,
.bulk-column-filter-v55 .bulk-column-grid label {
  all: unset;
}
@media (max-width: 1100px) {
  .bulk-filter-groups {
    grid-template-columns: 1fr;
  }
  .bulk-filter-head {
    display: grid;
  }
}

/* v3_1_38 — field edit hint block, scoped to product field pages. */
.product-fields-page-v37 .field-type-help,
.product-structure-page-v37 .field-type-help,
.fields-builder-page-v37 .field-type-help,
.field-edit-page-v37 .field-type-help,
.section-form-page-v37 .field-type-help {
  padding: 14px 16px;
  border: 1px solid var(--jit-border, var(--line));
  border-radius: var(--jit-radius-md, 12px);
  background: var(--jit-surface-soft, rgba(255,255,255,.62));
  color: var(--jit-text, var(--ink));
  box-shadow: var(--jit-shadow-soft, 0 10px 26px rgba(0,0,0,.04));
}

.product-fields-page-v37 .field-type-help strong,
.product-structure-page-v37 .field-type-help strong,
.fields-builder-page-v37 .field-type-help strong,
.field-edit-page-v37 .field-type-help strong{
  display: block;
  margin-bottom: 7px;
  color: var(--jit-text, var(--ink));
  font-size: 12px;
  font-weight: 500;
}

.product-fields-page-v37 .field-type-help ul,
.product-structure-page-v37 .field-type-help ul,
.fields-builder-page-v37 .field-type-help ul,
.field-edit-page-v37 .field-type-help ul{
  margin: 0;
  padding-left: 18px;
}

.product-fields-page-v37 .field-type-help li,
.product-structure-page-v37 .field-type-help li,
.fields-builder-page-v37 .field-type-help li,
.field-edit-page-v37 .field-type-help li{
  margin: 0;
  color: var(--jit-muted, var(--muted));
  font-size: 12px;
  line-height: 1.45;
}

.product-fields-page-v37 .field-type-help li[style*="display: none"],
.product-structure-page-v37 .field-type-help li[style*="display: none"],
.fields-builder-page-v37 .field-type-help li[style*="display: none"],
.field-edit-page-v37 .field-type-help li[style*="display: none"]{
  display: none;
}

.fields-builder-page-v37 .palette-builder-card-v329,
.field-edit-page-v37 .palette-builder-card-v329,
.fields-builder-page-v37 .select-manual-settings-v329,
.fields-builder-page-v37 .select-double-manual-settings-v329,
.field-edit-page-v37 .select-manual-settings-v329,
.field-edit-page-v37 .select-double-manual-settings-v329 {
  display: grid;
  gap: 10px;
  padding: 12px;
  border: 1px solid var(--jit-line, var(--line));
  border-radius: 12px;
  background: rgba(255,255,255,.42);
}

.fields-builder-page-v37 .palette-builder-grid-v329,
.field-edit-page-v37 .palette-builder-grid-v329 {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 54px minmax(0, 1fr) auto;
  gap: 8px;
  align-items: end;
}

.fields-builder-page-v37 .palette-builder-grid-v329 input[type="color"],
.field-edit-page-v37 .palette-builder-grid-v329 input[type="color"] {
  width: 54px;
  min-width: 54px;
  height: 40px;
  padding: 3px;
}

.fields-builder-page-v37 .palette-preview-v329,
.field-edit-page-v37 .palette-preview-v329 {
  display: grid;
  gap: 6px;
}

.fields-builder-page-v37 .palette-preview-list-v329,
.field-edit-page-v37 .palette-preview-list-v329 {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.fields-builder-page-v37 .palette-pill-v329,
.field-edit-page-v37 .palette-pill-v329 {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  min-height: 30px;
  padding: 5px 9px;
  border: 1px solid var(--jit-line, var(--line));
  border-radius: 999px;
  background: var(--jit-surface-bg, var(--panel));
  color: var(--jit-text, #17130f);
  font: inherit;
  font-size: 12px;
  cursor: pointer;
}

.fields-builder-page-v37 .palette-pill-dot-v329,
.field-edit-page-v37 .palette-pill-dot-v329 {
  width: 16px;
  height: 16px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.18);
  background: #fff;
}

@media (max-width: 760px) {
  .fields-builder-page-v37 .palette-builder-grid-v329,
  .field-edit-page-v37 .palette-builder-grid-v329 {
    grid-template-columns: 1fr;
  }
}

/* v3_2_10 — product field editor UX correction.
   Scoped to product field pages. Existing field/options logic is preserved. */
.fields-builder-page-v37 .field-type-help-v3210,
.field-edit-page-v37 .field-type-help-v3210 {
  margin: 2px 0 8px;
  padding: 12px 14px;
  border: 1px solid var(--jit-line, var(--line));
  border-radius: 12px;
  background: rgba(255,255,255,.58);
  box-shadow: 0 10px 26px rgba(22,19,15,.045);
}

.fields-builder-page-v37 .field-type-help-v3210 strong,
.field-edit-page-v37 .field-type-help-v3210 strong {
  display: block;
  margin-bottom: 6px;
  font-size: 12px;
  font-weight: 500;
  color: var(--jit-text, #17130f);
}

.fields-builder-page-v37 .field-type-help-v3210 p,
.field-edit-page-v37 .field-type-help-v3210 p {
  margin: 0;
  color: var(--jit-muted, #6f6256);
  font-size: 12px;
  line-height: 1.45;
}

.fields-builder-page-v37 .field-type-help-v3210 p[style*="display: none"],
.field-edit-page-v37 .field-type-help-v3210 p[style*="display: none"] {
  display: none;
}

.fields-builder-page-v37 .palette-builder-card-v329,
.field-edit-page-v37 .palette-builder-card-v329 {
  padding: 14px;
  border-radius: 12px;
  background: rgba(255,255,255,.54);
}

.fields-builder-page-v37 .palette-builder-grid-v329,
.field-edit-page-v37 .palette-builder-grid-v329 {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 62px;
  gap: 8px;
  align-items: center;
}

.fields-builder-page-v37 .palette-builder-grid-v329 [data-palette-name],
.field-edit-page-v37 .palette-builder-grid-v329 [data-palette-name],
.fields-builder-page-v37 .palette-builder-grid-v329 [data-palette-add],
.field-edit-page-v37 .palette-builder-grid-v329 [data-palette-add] {
  grid-column: 1 / -1;
}

.fields-builder-page-v37 .palette-builder-grid-v329 input,
.field-edit-page-v37 .palette-builder-grid-v329 input {
  min-width: 0;
}

.fields-builder-page-v37 .palette-builder-grid-v329 input[type="color"],
.field-edit-page-v37 .palette-builder-grid-v329 input[type="color"] {
  width: 62px;
  min-width: 62px;
  height: 42px;
  border-radius: 12px;
}

.fields-builder-page-v37 .palette-builder-grid-v329 .button,
.field-edit-page-v37 .palette-builder-grid-v329 .button {
  width: 100%;
  justify-content: center;
}

/* ════════════════════════════════════════════════════════════════
   v3.8.5 — Редизайн «Разделы и поля продукта».
   Всё scoped под .product-structure-page-v37, т.к. имена classes
   field-row / section-header используются на других страницах.
   Переменные проекта: --text/--muted/--line/--panel/--section-bg/--radius.
   ════════════════════════════════════════════════════════════════ */
.product-structure-page-v37 .section-block { margin-bottom: 10px; }

.product-structure-page-v37 .section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 14px;
  background: var(--panel, #fff);
  border: 0.5px solid var(--line, #e8e8e8);
  border-radius: var(--radius, 12px) var(--radius, 12px) 0 0;
  border-bottom: none;
}
.product-structure-page-v37 .section-left {
  display: flex; align-items: center; gap: 10px; min-width: 0;
}
.product-structure-page-v37 .section-name {
  font-size: 12px; font-weight: 500; color: var(--text, #111);
}
.product-structure-page-v37 .section-meta {
  display: flex; align-items: center; flex-wrap: wrap; gap: 5px;
  margin-top: 2px; font-size: 10px; color: var(--muted, #999);
}
.product-structure-page-v37 .meta-dot {
  width: 2px; height: 2px; border-radius: 50%;
  background: var(--muted, #999); display: inline-block; flex-shrink: 0;
}
.product-structure-page-v37 .meta-badge {
  display: inline-flex; align-items: center; gap: 3px;
  padding: 1px 5px; border-radius: 8px; font-size: 9px; font-weight: 500;
}
.product-structure-page-v37 .meta-badge i { font-size: 9px; }
.product-structure-page-v37 .badge-yes { background: #eaf3de; color: #3b6d11; }
.product-structure-page-v37 .badge-no  { background: var(--section-bg, #f2f2f2); color: var(--muted, #999); }

.product-structure-page-v37 .section-right {
  display: flex; align-items: center; gap: 4px; flex-shrink: 0;
}
.product-structure-page-v37 .section-right form,
.product-structure-page-v37 .field-right form { display: inline-flex; margin: 0; }

.product-structure-page-v37 .fields-list {
  border: 0.5px solid var(--line, #e8e8e8);
  border-top: none;
  border-radius: 0 0 var(--radius, 12px) var(--radius, 12px);
  overflow: hidden;
  background: var(--panel, #fff);
}

.product-structure-page-v37 .field-row {
  display: flex; align-items: center; justify-content: space-between;
  gap: 10px; padding: 8px 14px;
  border-top: 0.5px solid var(--line, #e8e8e8);
  transition: background 0.1s;
}
.product-structure-page-v37 .field-row:first-child { border-top: none; }
.product-structure-page-v37 .field-row:hover { background: var(--section-bg, #fafafa); }

.product-structure-page-v37 .field-left {
  display: flex; align-items: center; gap: 8px; flex: 1; min-width: 0;
}
/* Массовое удаление полей */
.product-structure-page-v37 .fld-sel-v41 { flex-shrink: 0; }
.sh-btn[disabled] { opacity: .45; cursor: default; }
.bulk-del-btn-v41:not([disabled]) {
  color: var(--danger);
  border-color: color-mix(in srgb, var(--danger) 35%, var(--line));
}
.bulk-del-btn-v41:not([disabled]):hover { background: #FEF2F2; }
.product-structure-page-v37 .field-name {
  font-size: 12px; font-weight: 500; color: var(--text, #111);
}
.product-structure-page-v37 .field-type {
  font-size: 10px; font-weight: 400; color: var(--muted, #999); margin-top: 1px;
}
.product-structure-page-v37 .field-right {
  display: flex; align-items: center; gap: 3px;
  flex-shrink: 0; flex-wrap: wrap; justify-content: flex-end;
}
.product-structure-page-v37 .vis-badge {
  display: inline-flex; align-items: center; gap: 3px;
  padding: 2px 6px; border-radius: 8px; font-size: 9px; font-weight: 500;
  white-space: nowrap;
}
.product-structure-page-v37 .vis-badge i { font-size: 9px; }
.product-structure-page-v37 .vis-on  { background: #eaf3de; color: #3b6d11; }
.product-structure-page-v37 .vis-off { background: var(--section-bg, #f2f2f2); color: var(--muted, #999); }
.product-structure-page-v37 .vis-req { background: #fbe6cc; color: #8a5a00; }
.product-structure-page-v37 .vis-sep {
  width: 0.5px; height: 12px; background: var(--line, #ddd); margin: 0 2px; flex-shrink: 0;
}

/* v3.8.49: канон иконочной кнопки 28/r8/1px/14px (общий с .act-btn/.cmp-action-btn) */
.product-structure-page-v37 .icon-btn {
  width: 28px; height: 28px;
  border: 1px solid var(--line, #e8e8e8); border-radius: 8px;
  background: transparent; display: inline-flex; align-items: center; justify-content: center;
  cursor: pointer; color: var(--muted, #666); font-size: 14px; flex-shrink: 0;
  text-decoration: none; padding: 0;
}
.product-structure-page-v37 .icon-btn:hover { background: var(--section-bg, #f5f5f5); }
.product-structure-page-v37 .icon-btn.danger:hover {
  border-color: #f09595; color: #CC2200; background: #fcebeb;
}

.product-structure-page-v37 .add-field-row {
  border-top: 0.5px solid var(--line, #e8e8e8); padding: 7px 14px;
}
.product-structure-page-v37 .add-field-link {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 11px; font-weight: 400; color: var(--muted, #999);
  text-decoration: none; cursor: pointer;
}
.product-structure-page-v37 .add-field-link:hover { color: var(--text, #111); }
.product-structure-page-v37 .add-field-link i { font-size: 11px; }

.product-structure-page-v37 .field-row-empty {
  padding: 8px 14px; font-size: 11px; color: var(--muted, #999);
}
