/* `.mapping-page` layout lives in importMapping.ftlper.css (SPA Сопоставление) */

.mapping-intro {
  flex: 0 0 auto;
}

.mapping-grid {
  display: grid;
  grid-template-columns: 1fr 1.25fr;
  gap: 14px;
  align-items: start;
  flex: 1 1 auto;
  min-height: 0;
}

@media (max-width: 980px) {
  .mapping-grid { grid-template-columns: 1fr; }
}

.mapping-grid > .card {
  display: flex;
  flex-direction: column;
  min-height: 0;
}

.mapping-grid > .card > .card-body {
  flex: 1 1 auto;
  min-height: 0;
  overflow: auto;
}

.mapping-status {
  position: sticky;
  top: 0;
  z-index: 1;
  background: var(--color-surface);
  padding-bottom: 10px;
}

.mapping-field { display: flex; flex-direction: column; gap: 6px; }
.mapping-label { font-size: 11px; font-weight: 600; color: var(--color-text-muted); }
.mapping-textarea {
  width: 100%;
  min-height: 140px;
  resize: vertical;
  padding: 10px 12px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  font-family: var(--font-sans);
  font-size: 12px;
  color: var(--color-text);
  background: var(--color-surface);
}
.mapping-textarea--rows { min-height: 110px; }

.mapping-hint {
  margin-top: 8px;
  font-size: 12px;
  color: var(--color-danger);
  min-height: 16px;
}

.mapping-warn {
  margin-bottom: 10px;
  padding: 10px 12px;
  border: 1px solid color-mix(in srgb, var(--color-danger) 30%, var(--color-border));
  background: var(--color-danger-bg);
  border-radius: var(--radius-md);
  color: var(--color-danger);
  font-size: 12px;
}

.mapping-table { display: flex; flex-direction: column; gap: 10px; }
.mapping-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  padding: 12px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  background: var(--color-surface);
}
@media (max-width: 980px) {
  .mapping-row { grid-template-columns: 1fr; }
}

.mapping-target-title { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.mapping-target-label { font-size: 13px; font-weight: 700; color: var(--color-text); }
.mapping-target-key { margin-top: 2px; font-size: 11px; color: var(--color-text-muted); }

.mapping-source { display: flex; flex-direction: column; gap: 6px; min-width: 0; }
.mapping-select {
  width: 100%;
  min-height: 34px;
  padding: 8px 10px;
  border: 1px solid var(--color-border);
  border-radius: 10px;
  background: var(--color-surface);
  color: var(--color-text);
  font-size: 12px;
  font-weight: 600;
}
.mapping-hintline { font-size: 11px; color: var(--color-text-muted); line-height: 1.35; }

