/* Mapping – Light, modern, sicher (kein HTML-Render in der Preview) */

/* Karten / Grundlayout */
.mapping-card {
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  background: #ffffff;
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 16px;
}
.mapping-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 24px rgba(0,0,0,.06);
  border-color: rgba(0,128,96,.22);
}

/* Metafeld-Karten – eigener Look */
.mapping-card--meta {
  border-color: rgba(8, 126, 164, 0.35);
  background: #f6fbff;
}
.mapping-card--meta:hover {
  border-color: rgba(8, 126, 164, 0.55);
  box-shadow: 0 6px 24px rgba(8,126,164,.10);
}
.text-meta {
  color: #085f79; /* dunkles Türkis */
}

/* Badges */
.badge-type,
.badge-owner {
  font-size: .72rem;
  padding: .28rem .5rem;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.06);
  background: #f3f4f6;
  color: #374151;
}
.badge-type {
  background: #ecfdf5;
  border-color: #a7f3d0;
  color: #065f46;
}
.badge-type--meta {
  background: #e6f6fb;
  border-color: #9be0f5;
  color: #075985;
}
.badge-owner--product {
  background: #eef2ff;
  border-color: #c7d2fe;
  color: #3730a3;
}
.badge-owner--variant {
  background: #fff7ed;
  border-color: #fed7aa;
  color: #9a3412;
}

/* Sektionstitel / Divider */
.section-divider {
  display: flex;
  flex-direction: column;
  gap: .25rem;
  margin: 1.25rem 0 .75rem;
  padding-top: .5rem;
  border-top: 2px solid rgba(0,0,0,.06);
}
.section-title {
  font-weight: 700;
  letter-spacing: -0.01em;
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  color: #111827;
}
.section-subtitle {
  color: #6b7280;
  font-size: .9rem;
}

/* Zustände Karte (nur „ignoriert“ bleibt sichtbar) */
.mapping-card.is-ignored {
  background: #fbfbfb;
  border-color: rgba(0,0,0,.05);
  box-shadow: none;
  opacity: .92;
}

/* Wizard-Header */
.wizard-card .wizard-card-header {
  background: linear-gradient(90deg, #00a37a, #008060);
  color: #fff;
}

/* Advanced Drawer */
.mapping-advanced { animation-duration: .18s; animation-fill-mode: forwards; animation-name: fadeInUp; }
@keyframes fadeInUp { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: translateY(0); } }
.toggle-adv-link { cursor: pointer; font-weight: 600; color:#008060; }
.toggle-adv-link:hover { text-decoration: underline; }

/* Map/Fixed Umschalten smooth */
.map-field, .fixed-field { transition: opacity .15s ease, transform .15s ease; }
.map-field.d-none, .fixed-field.d-none { opacity: 0; transform: translateY(-4px); }

/* Preview-Toolbar */
.preview-toolbar { display:flex; align-items:center; gap:.75rem; }
.preview-nav .btn { padding: .25rem .5rem; }
.preview-toggles { display:flex; align-items:center; gap:.75rem; }

/* ===== Legend (Live-Preview) ======================================= */
.fs-legend {
  display:flex;
  flex-wrap:wrap;
  gap:.5rem;
  margin-bottom:.75rem;
}
.legend-item{
  display:inline-flex;
  align-items:center;
  gap:.4rem;
  font-size:.85rem;
  padding:.28rem .6rem;
  border-radius:999px;
  border:1px solid #e5e7eb;
  background:#f8fafc;
  color:#374151;
  line-height:1;
  white-space:nowrap;
}
.legend-changed{
  background:#ecfdf5;
  border-color:#a7f3d0;
  color:#065f46;
}
.legend-ignored{
  background:#f3f4f6;
  border-color:#e5e7eb;
  color:#6b7280;
}
.legend-na{
  background:#fff7ed;
  border-color:#fed7aa;
  color:#9a3412;
}

/* Chips */
.fs-chip {
  display: inline-flex;
  align-items: center;
  padding: .35rem .6rem;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 999px;
  font-size: .85rem;
  line-height: 1;
  white-space: nowrap;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  color: #2c2c2c;
  background: #f5f7f9;
}
.fs-chip--src { background: #eef2ff; border-color: rgba(0,0,0,.06); }
.fs-chip--dst { background: #f5f7f9; border-color: rgba(0,0,0,.08); }
.fs-chip--dst.is-changed { background: #eaf7f3; border-color: rgba(0,128,96,.22); }
.fs-chip--dst.is-na { background: #fff7e6; border-color: rgba(245,158,11,.28); }
.fs-chip + .fs-chip { margin-left: .35rem; }

.fs-chip-row { display: flex; flex-wrap: wrap; align-items: center; gap: .4rem; }
.fs-chip-arrow {
  display: inline-flex; align-items: center; justify-content: center;
  width: 28px; height: 28px; border-radius: 999px;
  border: 1px dashed rgba(0,0,0,.18); font-size: .8rem; flex: 0 0 auto;
  color: #6b7280; background: #ffffff;
}

/* Live-Preview – Liste */
.fs-list { display: grid; grid-template-columns: 1fr; gap: 0; }

.fs-row {
  display: grid;
  grid-template-columns: 260px 1fr;
  align-items: stretch;
  border-top: 1px solid rgba(0,0,0,.06);
  transition: background .2s ease, box-shadow .2s ease;
  background: #ffffff;
}
.fs-row:first-child { border-top: 0; }
.fs-col { padding: .85rem 1rem; }

.fs-field {
  background: #fbfbfb;
  border-right: 1px solid rgba(0,0,0,.06);
}
.fs-field .fs-field-name { font-weight: 600; color: #008060; }
.fs-note { font-size: .75rem; color: #6c757d; margin-top: .25rem; }

/* Zustände einzelner Felder */
.fs-row--changed { background: #f1fbf7; box-shadow: inset 2px 0 0 0 rgba(0,128,96,.28); }
.fs-row--ignored { background: #fafafa; opacity: .95; }
.fs-row--na { background: #fffaf1; box-shadow: inset 2px 0 0 0 rgba(245,158,11,.28); }

/* Leere-/Info-Hinweise */
.fs-empty { font-size: .9rem; color: #6c757d; }

/* Preview-Card Body */
#preview-panel .card-body { padding-top: .75rem; }

/* Responsive */
@media (max-width: 820px) {
  .fs-row { grid-template-columns: 1fr; }
  .fs-field { border-right: 0; border-bottom: 1px solid rgba(0,0,0,.06); }
}
