/* =============================================================
   FIELD MAPPING SHELL — XML Alan Eşleştirme
   Reference template (TM homepage / field-mapping.css 268 lines)
   ported to Trendmetrik tokens. Scoped to .xml-field-mapping-page
   so it doesn't leak to other pages. Light + dark mode aware via
   --tm-* tokens (theme-variables.css + dark-mode-namespace-fixes.css).
   ============================================================= */
@import url('https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;600;700&display=swap');

.xml-field-mapping-page {
  /* Local fallback aliases — bind to existing project tokens */
  --fm-card-bg:   var(--tm-bg-card, #ffffff);
  --fm-card-bg-2: var(--tm-bg-secondary, #fafbfc);
  --fm-page-bg:   var(--tm-bg-primary, #f8fafc);
  --fm-text:      var(--tm-text-primary, #0f172a);
  --fm-text-2:    var(--tm-text-secondary, #334155);
  --fm-muted:     var(--tm-text-muted, #64748b);
  --fm-border:    var(--tm-border-color, #e2e8f0);
  --fm-border-2:  var(--tm-border-light, #eef2f7);
  --fm-ink-50:   var(--tm-bg-secondary, #f8fafc);
  --fm-ink-100:  var(--tm-border-light, #f1f5f9);
  --fm-ink-200:  var(--tm-border-color, #e2e8f0);
  --fm-ink-300:  #cbd5e1;
  --fm-ink-400:  #94a3b8;
  --fm-ink-500:  #64748b;
  --fm-ink-600:  #475569;
  --fm-ink-700:  #334155;
  --fm-ink-900:  #0f172a;

  font-family: 'Geist', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}

/* =============================================================
   TMV2 FIELDMAP LAYOUT — sayfa-seviyesi 2-kolon workspace
   ----------------------------------------------------------------
   Eski yapı: Bootstrap .row > .col-lg-5/.col-lg-7 — col flex width
   ile bizim CSS Grid override'ımız çakışıyordu, sol kolon dar
   render oluyordu. Yeni yapı: tek bir CSS Grid container, namespace
   .tmv2-fieldmap-* — tmv2 token'larıyla, scoped, !important'sız.
   Acceptance kriterleri:
     - max-width: 1520px, ortalanmış
     - sidebar minmax(360px, 420px), preview 1fr
     - hero kompakt page-title kartı (full-width banner DEĞİL)
     - viewport-fit preview (max-height: calc(100vh - 240px))
     - background sade (token-driven), grid pattern yok
     - blur overlay kaldırıldı; skeleton kullanılır
   ============================================================= */

.tmv2-fieldmap-page {
  background: var(--tm-bg-primary, #f6f8fb);
  min-height: 100vh;
  position: relative;
  isolation: isolate;
}
html.dark-mode .tmv2-fieldmap-page {
  background: var(--tm-bg-primary, #0f172a);
}

/* Sayfa içinde gridli/dotlu desenleri kapat (parent body'den geliyor olabilir) */
.tmv2-fieldmap-page::before,
.tmv2-fieldmap-page::after {
  content: none;
}

/* Shell — max-width centered container, container-fluid yerine */
.tmv2-fieldmap-shell {
  max-width: 1520px;
  margin: 0 auto;
  padding: 14px 20px 110px; /* alt: sticky bar (60px) + breathing */
  display: flex;
  flex-direction: column;
  gap: 12px;
  width: 100%;
  box-sizing: border-box;
}
@media (max-width: 1200px) {
  .tmv2-fieldmap-shell { padding: 12px 16px 110px; }
}
@media (max-width: 900px) {
  .tmv2-fieldmap-shell { padding: 10px 12px 110px; gap: 10px; }
}

/* Crumb / Steps — kompakt, shell ile aynı hizada */
.tmv2-fieldmap-page .tmv2-fieldmap-crumb {
  padding: 0;
  margin: 0;
  font-size: 12px;
  color: var(--tm-text-muted, #64748b);
}
.tmv2-fieldmap-page .tmv2-fieldmap-steps {
  margin: 0;
}

/* Hero — page-title card, banner DEĞİL: küçük padding, ufak başlık */
.tmv2-fieldmap-page .tmv2-fieldmap-hero {
  padding: 14px 18px;
  border-radius: 12px;
  margin: 0;
  gap: 16px;
  box-shadow: 0 2px 12px -6px rgba(102, 126, 234, .35);
}
.tmv2-fieldmap-page .tmv2-fieldmap-hero .fm-hero-text h1 {
  font-size: 15px;
  margin: 0 0 2px;
  letter-spacing: -0.01em;
}
.tmv2-fieldmap-page .tmv2-fieldmap-hero .fm-hero-text p {
  font-size: 11.5px;
  max-width: 56ch;
}
.tmv2-fieldmap-page .tmv2-fieldmap-hero .fm-hero-stat {
  padding: 6px 12px;
  min-width: 84px;
}
.tmv2-fieldmap-page .tmv2-fieldmap-hero .fm-hero-stat small {
  font-size: 9px;
}
.tmv2-fieldmap-page .tmv2-fieldmap-hero .fm-hero-stat b {
  font-size: 14px;
}

/* 2-kolon grid — sidebar minmax(360, 420) + preview 1fr
   align-items: stretch → iki kolon (Alanlar + Önizleme) AYNI yükseklikte
   render olur; kısa olan, uzun olana uzar. Kart içi scroll ile içerik taşmaz.
   (Eskiden align-items: start idi → her kolon yalnız kendi içerik boyunu
   alıyordu, bu yüzden sol/sağ uzunluklar eşit değildi.) */
.tmv2-fieldmap-page .tmv2-fieldmap-layout {
  display: grid;
  grid-template-columns: minmax(360px, 420px) 1fr;
  gap: 20px;
  align-items: stretch;
  margin: 0;
}
@media (max-width: 1200px) {
  .tmv2-fieldmap-page .tmv2-fieldmap-layout {
    grid-template-columns: 340px 1fr;
    gap: 16px;
  }
}
@media (max-width: 900px) {
  .tmv2-fieldmap-page .tmv2-fieldmap-layout {
    grid-template-columns: 1fr;
    gap: 14px;
  }
}

/* Grid item'ler — min-width: 0 ile overflow taşmasını engelle */
.tmv2-fieldmap-page .tmv2-fieldmap-sidebar,
.tmv2-fieldmap-page .tmv2-fieldmap-preview {
  min-width: 0;
}

/* Eşit yükseklik + viewport-fit: HER İKİ kolon (sidebar + preview) aynı
   davranışı paylaşır → header/stepper/hero alanı çıkarılıp kalan yükseklik
   cap'lenir, içerik kart içinde scroll olur. align-items: stretch sayesinde
   grid satır yüksekliği iki kolonu eşitler; height: 100% kartı o satıra
   doldurur. (Eskiden preview cap'i koşulsuz, sidebar cap'i yalnız ≥1200px
   idi → kolonlar arası yükseklik farkı ve kayma oluşuyordu.) */
@media (min-width: 901px) {
  .tmv2-fieldmap-page .tmv2-fieldmap-sidebar > .card,
  .tmv2-fieldmap-page .tmv2-fieldmap-sidebar > .fm-card,
  .tmv2-fieldmap-page .tmv2-fieldmap-preview > .card,
  .tmv2-fieldmap-page .tmv2-fieldmap-preview > .fm-card {
    height: 100%;
    max-height: calc(100vh - 240px);
    display: flex;
    flex-direction: column;
    overflow: hidden;
  }
  .tmv2-fieldmap-page .tmv2-fieldmap-sidebar > .card > .card-body,
  .tmv2-fieldmap-page .tmv2-fieldmap-sidebar > .fm-card > .card-body,
  .tmv2-fieldmap-page .tmv2-fieldmap-preview > .card > .card-body,
  .tmv2-fieldmap-page .tmv2-fieldmap-preview > .fm-card > .card-body {
    overflow: auto;
    flex: 1 1 auto;
    min-height: 0;
    /* scrollbar-gutter: stable → scrollbar görünüp kaybolduğunda içerik
       yatay kaymaz (async XML önizleme yüklenince oluşan "kayma" fix'i). */
    scrollbar-gutter: stable;
  }
}

/* INLINE STYLE OVERRIDE — eski inline <style> blok'ta
   .xml-field-mapping-page .card { margin-bottom: 1.5rem !important }
   var. Yeni grid layout'ta kart altı extra margin istemiyoruz.
   !important sebebi: inline style blok kuralı !important kullanıyor;
   onu specificity ile kıramazsınız. Bunu kaldırmak için ya inline
   stili silmek gerekirdi (riskli, başka kuralları da tutuyor) ya da
   bu noktada !important. Tek satırda raporlanmıştır. */
.tmv2-fieldmap-page .tmv2-fieldmap-sidebar > .card,
.tmv2-fieldmap-page .tmv2-fieldmap-preview > .card,
.tmv2-fieldmap-page .tmv2-fieldmap-sidebar > .fm-card,
.tmv2-fieldmap-page .tmv2-fieldmap-preview > .fm-card {
  margin-bottom: 0 !important; /* override of inline-style !important */
  /* height: 100% → grid satırını (stretch) doldur, kolon yükseklikleri
     eşitlensin. <=900px tek kolonda max-height kalktığı için height:auto'ya
     döner (aşağıdaki media query). */
  height: 100%;
}
@media (max-width: 900px) {
  .tmv2-fieldmap-page .tmv2-fieldmap-sidebar > .card,
  .tmv2-fieldmap-page .tmv2-fieldmap-preview > .card,
  .tmv2-fieldmap-page .tmv2-fieldmap-sidebar > .fm-card,
  .tmv2-fieldmap-page .tmv2-fieldmap-preview > .fm-card {
    height: auto;
  }
}

/* Skeleton loaders — busy overlay yerine.
   !important sebebi: inline <style>'da .xml-preview-busy-overlay
   { display: flex !important } var; specificity ile kırılamaz. */
.tmv2-fieldmap-page .xml-preview-busy-overlay {
  display: none !important; /* override of inline-style !important */
}

/* =============================================================
   LOADING OVERLAY — "Ürünler içe aktarılıyor" modal
   ----------------------------------------------------------------
   Önceki sürümde Bootstrap shadow-lg (0 1rem 3rem .175 alpha)
   karanlık backdrop üzerinde "gri shoulders" gibi görünüyordu.
   Backdrop'u solid yap, shadow'u modern soft-glow yap, sayfa
   içeriğini overlay açıkken gizle (cards görünmesin).
   ============================================================= */
.tmv2-fieldmap-page #loadingOverlay {
  background: rgba(15, 23, 42, 0.94) !important; /* override inline alpha .75 */
  backdrop-filter: blur(10px) !important;
}
html.dark-mode .tmv2-fieldmap-page #loadingOverlay {
  background: rgba(0, 0, 0, 0.92) !important;
}

/* Modal kart — subtle shadow, no harsh shoulders */
.tmv2-fieldmap-page #loadingOverlay > .bg-white,
.tmv2-fieldmap-page #loadingOverlay > div {
  background: var(--tm-bg-card, #fff) !important;
  border-radius: 14px !important;
  box-shadow:
    0 24px 56px -16px rgba(0, 0, 0, 0.55),
    0 0 0 1px rgba(255, 255, 255, 0.04) !important;
}
html.dark-mode .tmv2-fieldmap-page #loadingOverlay > .bg-white,
html.dark-mode .tmv2-fieldmap-page #loadingOverlay > div {
  background: var(--tm-bg-card, #1e293b) !important;
  color: var(--tm-text-primary, #f8fafc) !important;
}
html.dark-mode .tmv2-fieldmap-page #loadingOverlay h3,
html.dark-mode .tmv2-fieldmap-page #loadingOverlay .text-dark {
  color: var(--tm-text-primary, #f8fafc) !important;
}

/* Loading açıkken sayfanın diğer content'lerini visibility:hidden ile sakla.
   #fieldMappingMainContent zaten display:none (job_id render'ında) ama
   sticky bar / hero / vs kaçabilen elementleri de güvene al. */
.tmv2-fieldmap-page:has(> #loadingOverlay:not(.hidden)) > *:not(#loadingOverlay) {
  visibility: hidden !important;
}
body:has(.tmv2-fieldmap-page > #loadingOverlay:not(.hidden)) .fm-stickybar {
  display: none !important;
}

.tmv2-fieldmap-skeleton {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 14px 16px;
}
.tmv2-fieldmap-skeleton-row {
  height: 12px;
  background: var(--fm-ink-100);
  border-radius: 4px;
  position: relative;
  overflow: hidden;
}
.tmv2-fieldmap-skeleton-row.short  { width: 48%; }
.tmv2-fieldmap-skeleton-row.medium { width: 72%; }
.tmv2-fieldmap-skeleton-row.tall   { height: 56px; }
.tmv2-fieldmap-skeleton-row::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg,
    transparent 0%,
    rgba(255,255,255,.55) 50%,
    transparent 100%);
  animation: tmv2-fm-skel 1.4s infinite;
}
@keyframes tmv2-fm-skel {
  0%   { transform: translateX(-100%); }
  100% { transform: translateX(100%); }
}
html.dark-mode .tmv2-fieldmap-skeleton-row {
  background: var(--tm-bg-secondary, #1e293b);
}
html.dark-mode .tmv2-fieldmap-skeleton-row::after {
  background: linear-gradient(90deg,
    transparent 0%,
    rgba(255,255,255,.06) 50%,
    transparent 100%);
}

/* Sticky bar — full-bleed çubuk (left ray kadar offset); ortalama .inner'da.
   Yuvarlatılmış üst köşeler ortalanmış iç içerikte. (Eskiden outer bar'a
   max-width:1520px+margin:auto veriliyordu ama position:fixed + left/right:0
   ile margin:auto ortalama yapmaz → kaldırıldı, .fm-stickybar-inner devraldı.) */
.tmv2-fieldmap-page ~ .fm-stickybar .fm-stickybar-inner,
body:has(.tmv2-fieldmap-page) .fm-stickybar .fm-stickybar-inner {
  border-radius: 0;
}

/* =============================================================
   Top breadcrumb
   ============================================================= */
.xml-field-mapping-page .fm-crumb {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  padding: 14px 0 !important;
  font-size: 12px !important;
  color: var(--fm-muted) !important;
  background: transparent !important;
}
.xml-field-mapping-page .fm-crumb .sep { color: var(--fm-ink-300) !important; }
.xml-field-mapping-page .fm-crumb b {
  color: var(--fm-ink-900) !important;
  font-weight: 600 !important;
}

/* =============================================================
   Process steps
   ============================================================= */
.xml-field-mapping-page .fm-steps {
  display: flex !important;
  align-items: center !important;
  gap: 0 !important;
  background: var(--fm-card-bg) !important;
  border: 1px solid var(--fm-border) !important;
  border-radius: 12px !important;
  padding: 10px 14px !important;
  margin-bottom: 16px !important;
  overflow: hidden !important;
  flex-wrap: wrap !important;
}
.xml-field-mapping-page .fm-steps .fm-step {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  padding: 6px 14px !important;
  border-radius: 8px !important;
  font-size: 12px !important;
  color: var(--fm-muted) !important;
  font-weight: 500 !important;
  flex-shrink: 0 !important;
  white-space: nowrap !important;
}
.xml-field-mapping-page .fm-step.done { color: #059669; }
.xml-field-mapping-page .fm-step.active {
  background: rgba(37,99,235,.1);
  color: #1d4ed8;
  font-weight: 600;
  box-shadow: inset 0 0 0 1px rgba(37,99,235,.25);
}
.xml-field-mapping-page .fm-step .num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px; height: 18px;
  border-radius: 50%;
  background: var(--fm-ink-100);
  color: var(--fm-muted);
  font-size: 10px;
  font-weight: 700;
}
.xml-field-mapping-page .fm-step.done .num { background: #10b981; color: #fff; }
.xml-field-mapping-page .fm-step.active .num { background: #2563eb; color: #fff; }
.xml-field-mapping-page .fm-step-arr {
  color: var(--fm-ink-300);
  font-size: 14px;
  padding: 0 4px;
  flex-shrink: 0;
}

/* =============================================================
   Hero — yüksek specificity + !important çünkü Bootstrap .card ve
   eski .field-mapping-page-hero rules ile çakışabilir.
   ============================================================= */
.xml-field-mapping-page .fm-hero,
.xml-field-mapping-page div.fm-hero {
  display: grid !important;
  grid-template-columns: 1fr auto !important;
  gap: 24px !important;
  align-items: center !important;
  padding: 18px 22px !important;
  border-radius: 14px !important;
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%) !important;
  background-color: #667eea !important;
  color: #fff !important;
  margin-bottom: 14px !important;
  border: 0 !important;
  box-shadow: 0 4px 18px -8px rgba(102,126,234,.55) !important;
}
.xml-field-mapping-page .fm-hero h1,
.xml-field-mapping-page .fm-hero .fm-hero-text h1 {
  font-size: 18px !important;
  font-weight: 700 !important;
  margin: 0 0 4px !important;
  letter-spacing: -0.02em !important;
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  color: #fff !important;
}
.xml-field-mapping-page .fm-hero p,
.xml-field-mapping-page .fm-hero .fm-hero-text p {
  font-size: 12.5px !important;
  opacity: 0.9 !important;
  margin: 0 !important;
  color: #fff !important;
  max-width: 60ch !important;
}
.xml-field-mapping-page .fm-hero-stats {
  display: flex !important;
  gap: 8px !important;
}
.xml-field-mapping-page .fm-hero-stat {
  background: rgba(255,255,255,.14) !important;
  backdrop-filter: blur(6px);
  border: 1px solid rgba(255,255,255,.2) !important;
  border-radius: 10px !important;
  padding: 8px 14px !important;
  text-align: center !important;
  min-width: 96px !important;
}
.xml-field-mapping-page .fm-hero-stat small {
  display: block !important;
  font-size: 10px !important;
  opacity: 0.85 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em !important;
  font-weight: 600 !important;
  margin-bottom: 2px !important;
  color: #fff !important;
}
.xml-field-mapping-page .fm-hero-stat b {
  font-size: 16px !important;
  font-weight: 700 !important;
  font-variant-numeric: tabular-nums !important;
  color: #fff !important;
}

/* =============================================================
   Two-column grid (form + preview)
   ============================================================= */
.xml-field-mapping-page .fm-grid {
  display: grid;
  grid-template-columns: minmax(0, 5fr) minmax(0, 7fr);
  gap: 16px;
  align-items: start;
}
@media (max-width: 1280px) {
  .xml-field-mapping-page .fm-grid { grid-template-columns: 1fr; }
}

/* =============================================================
   Card chrome
   ============================================================= */
.xml-field-mapping-page .fm-card {
  background: var(--fm-card-bg) !important;
  border: 1px solid var(--fm-border) !important;
  border-radius: 12px !important;
  overflow: hidden !important;
  box-shadow: 0 1px 2px rgba(15,23,42,.04) !important;
}
.xml-field-mapping-page .fm-card-h {
  padding: 12px 16px !important;
  border-bottom: 1px solid var(--fm-border);
  background: var(--fm-card-bg-2) !important;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.xml-field-mapping-page .fm-card-h h2,
.xml-field-mapping-page .fm-card-h h5 {
  font-size: 13px !important;
  font-weight: 600 !important;
  margin: 0 !important;
  color: var(--fm-text);
  display: flex;
  align-items: center;
  gap: 8px;
  letter-spacing: -0.005em;
}
.xml-field-mapping-page .fm-card-h h2 .ic,
.xml-field-mapping-page .fm-card-h h5 .ic { font-size: 14px; color: #2563eb; }
.xml-field-mapping-page .fm-card-h .right {
  display: flex; gap: 6px; align-items: center;
}
.xml-field-mapping-page .fm-badge-pill {
  font-size: 11px;
  font-weight: 600;
  padding: 3px 10px;
  border-radius: 999px;
  background: rgba(37,99,235,.12);
  color: #1d4ed8;
  border: 1px solid rgba(37,99,235,.3);
}

/* =============================================================
   Tabs (form panel)
   ============================================================= */
.xml-field-mapping-page .fm-tabs {
  display: flex !important;
  gap: 0 !important;
  border-bottom: 1px solid var(--fm-border) !important;
  background: var(--fm-card-bg) !important;
  padding: 0 12px !important;
  margin-bottom: 0 !important;
  list-style: none !important;
  flex-wrap: nowrap;
  overflow-x: auto;
}
.xml-field-mapping-page .fm-tabs > .nav-item { margin: 0 !important; }
.xml-field-mapping-page .fm-tab,
.xml-field-mapping-page .fm-tab.nav-link {
  padding: 11px 14px !important;
  font-size: 12.5px !important;
  font-weight: 500 !important;
  color: var(--fm-muted) !important;
  background: transparent !important;
  border: none !important;
  border-bottom: 2px solid transparent !important;
  cursor: pointer;
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
  transition: all 0.15s;
  position: relative;
  text-decoration: none !important;
  border-radius: 0 !important;
}
.xml-field-mapping-page .fm-tab .ic { font-size: 13px; }
.xml-field-mapping-page .fm-tab:hover { color: var(--fm-ink-700) !important; }
.xml-field-mapping-page .fm-tab.active,
.xml-field-mapping-page .fm-tab.nav-link.active {
  color: #2563eb !important;
  border-bottom-color: #2563eb !important;
  font-weight: 600 !important;
  background: transparent !important;
}
.xml-field-mapping-page .fm-tab-badge {
  font-size: 10px;
  background: var(--fm-ink-100);
  color: var(--fm-ink-600);
  padding: 1px 6px;
  border-radius: 999px;
  font-weight: 600;
}
.xml-field-mapping-page .fm-tab.active .fm-tab-badge {
  background: rgba(37,99,235,.15);
  color: #1d4ed8;
}
.xml-field-mapping-page .fm-tab.warn::after {
  content: "";
  position: absolute;
  top: 8px; right: 6px;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: #ef4444;
}

/* =============================================================
   Form fields
   ============================================================= */
.xml-field-mapping-page .fm-form-body {
  padding: 14px 16px !important;
}
.xml-field-mapping-page .fm-grid-fields {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 12px 14px !important;
}
@media (max-width: 780px) {
  .xml-field-mapping-page .fm-grid-fields { grid-template-columns: 1fr !important; }
}
.xml-field-mapping-page .fm-field {
  display: flex !important;
  flex-direction: column !important;
  min-width: 0 !important;
  margin-bottom: 0 !important;
}
.xml-field-mapping-page .fm-field.full { grid-column: 1 / -1 !important; }
.xml-field-mapping-page .fm-label {
  font-size: 11.5px !important;
  font-weight: 600 !important;
  color: var(--fm-ink-700) !important;
  margin-bottom: 5px !important;
  display: flex !important;
  align-items: center !important;
  gap: 5px !important;
}
.xml-field-mapping-page .fm-label .ic { color: #2563eb; font-size: 12px; }
.xml-field-mapping-page .fm-label .req { color: #dc2626; font-weight: 700; }
.xml-field-mapping-page .fm-label .opt {
  color: var(--fm-ink-400);
  font-weight: 500;
  font-size: 10px;
  margin-left: auto;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.xml-field-mapping-page .fm-select,
.xml-field-mapping-page .fm-input,
.xml-field-mapping-page select.fm-select.form-select,
.xml-field-mapping-page input.fm-input.form-control {
  width: 100% !important;
  padding: 7px 10px !important;
  font-size: 12.5px !important;
  background: var(--fm-card-bg) !important;
  border: 1px solid var(--fm-border) !important;
  border-radius: 7px !important;
  color: var(--fm-ink-900) !important;
  transition: all 0.15s !important;
  font-family: inherit !important;
  line-height: 1.4 !important;
}
.xml-field-mapping-page select.fm-select {
  cursor: pointer !important;
  appearance: none !important;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2.5'><path d='m6 9 6 6 6-6'/></svg>") !important;
  background-repeat: no-repeat !important;
  background-position: right 8px center !important;
  background-size: 14px !important;
  padding-right: 30px !important;
}
.xml-field-mapping-page .fm-select:hover,
.xml-field-mapping-page .fm-input:hover {
  border-color: var(--fm-ink-300) !important;
}
.xml-field-mapping-page .fm-select:focus,
.xml-field-mapping-page .fm-input:focus {
  outline: none !important;
  border-color: #2563eb !important;
  box-shadow: 0 0 0 3px rgba(37,99,235,.12) !important;
}
.xml-field-mapping-page .fm-select.empty,
.xml-field-mapping-page select.fm-select:invalid {
  color: var(--fm-ink-400) !important;
}
.xml-field-mapping-page .fm-select.mapped {
  border-color: #10b981 !important;
  background-color: rgba(16,185,129,.08) !important;
  color: #047857 !important;
  font-weight: 500 !important;
}
.xml-field-mapping-page .fm-select.mapped:focus {
  box-shadow: 0 0 0 3px rgba(16,185,129,.18) !important;
}
.xml-field-mapping-page .fm-select.req-empty {
  border-color: #fca5a5 !important;
  background-color: rgba(254,242,242,.6) !important;
}
.xml-field-mapping-page .fm-select.drag-over,
.xml-field-mapping-page .fm-input.drag-over,
.xml-field-mapping-page .droppable-select.drag-over {
  border-color: #667eea !important;
  background-color: rgba(243,240,255,.6) !important;
  box-shadow: 0 0 0 3px rgba(102,126,234,.18) !important;
  transform: scale(1.01) !important;
}
.xml-field-mapping-page .fm-help {
  font-size: 10.5px !important;
  color: var(--fm-muted) !important;
  margin-top: 4px !important;
  line-height: 1.4 !important;
}
.xml-field-mapping-page .fm-help code {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  background: var(--fm-ink-100);
  padding: 1px 5px;
  border-radius: 3px;
  color: #1e40af;
}

/* =============================================================
   BOOTSTRAP -> FM BRIDGE
   Eski şablon hâlâ Bootstrap class'larını (field-mapping-grid /
   field-mapping-item / form-label / form-select.droppable-select /
   form-control) kullanıyor; HTML'i tek tek değiştirmek yerine
   bu class'lara aynı .fm-* davranışını burada bağlıyoruz.
   ============================================================= */

/* Grid: TEK sütun field layout — referans tasarımı tek kolon
   (col-lg-5 form paneli zaten dar, 2-col label/value sığmıyor) */
.xml-field-mapping-page .field-mapping-grid {
  display: flex !important;
  flex-direction: column !important;
  gap: 12px !important;
  align-items: stretch !important;
}

/* Field item — eski .mb-3 padding'lerini sıfırla, dik akış zorla */
.xml-field-mapping-page .field-mapping-grid .field-mapping-item,
.xml-field-mapping-page .field-mapping-grid .field-mapping-item.mb-3 {
  display: flex !important;
  flex-direction: column !important;
  min-width: 0 !important;
  margin-bottom: 0 !important;
  padding: 0 !important;
}

/* Label */
.xml-field-mapping-page .field-mapping-grid .form-label,
.xml-field-mapping-page .field-mapping-grid label.form-label.fw-semibold {
  font-size: 11.5px !important;
  font-weight: 600 !important;
  color: var(--fm-ink-700) !important;
  margin-bottom: 5px !important;
  display: flex !important;
  align-items: center !important;
  gap: 5px !important;
  letter-spacing: -0.005em !important;
}
.xml-field-mapping-page .field-mapping-grid .form-label i.bi {
  color: #2563eb !important;
  font-size: 12px !important;
}
.xml-field-mapping-page .field-mapping-grid .form-label .text-danger {
  color: #dc2626 !important;
  font-weight: 700 !important;
  margin-left: 2px;
}

/* Label flex container — text + tag tek satıra zorla, gerekirse sar */
.xml-field-mapping-page .field-mapping-grid .form-label {
  flex-wrap: nowrap !important;
  min-width: 0 !important;
  justify-content: flex-start !important;
}
.xml-field-mapping-page .field-mapping-grid .form-label > * {
  min-width: 0;
}

/* Optional alanlar için sağda küçük "İSTEĞE BAĞLI" pill - 1-col layout'ta
   her alan kendi satırında olduğu için rahat sığar */
.xml-field-mapping-page .field-mapping-grid .form-label::after {
  content: "İSTEĞE BAĞLI";
  font-size: 8.5px !important;
  font-weight: 600 !important;
  color: var(--fm-ink-400) !important;
  letter-spacing: 0.04em !important;
  margin-left: auto !important;
  text-transform: uppercase !important;
  background: var(--fm-ink-100) !important;
  padding: 1px 5px !important;
  border-radius: 999px !important;
  flex-shrink: 0 !important;
  white-space: nowrap !important;
  align-self: center !important;
}
.xml-field-mapping-page .field-mapping-grid .form-label:has(.text-danger)::after {
  content: none !important;
}

/* Select + input: aynı fm-select görünümü */
.xml-field-mapping-page .field-mapping-grid .form-select,
.xml-field-mapping-page .field-mapping-grid select.form-select.droppable-select,
.xml-field-mapping-page .field-mapping-grid .form-control,
.xml-field-mapping-page .field-mapping-grid input.form-control {
  width: 100% !important;
  padding: 8px 11px !important;
  font-size: 12.5px !important;
  background: var(--fm-card-bg) !important;
  border: 1px solid var(--fm-border) !important;
  border-radius: 8px !important;
  color: var(--fm-ink-900) !important;
  transition: all 0.15s !important;
  font-family: inherit !important;
  line-height: 1.4 !important;
  box-shadow: none !important;
  min-height: 0 !important;
  height: auto !important;
}

/* Select chevron */
.xml-field-mapping-page .field-mapping-grid select.form-select {
  cursor: pointer !important;
  appearance: none !important;
  -webkit-appearance: none !important;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2.5'><path d='m6 9 6 6 6-6'/></svg>") !important;
  background-repeat: no-repeat !important;
  background-position: right 9px center !important;
  background-size: 14px !important;
  padding-right: 30px !important;
}

/* Hover & focus */
.xml-field-mapping-page .field-mapping-grid .form-select:hover,
.xml-field-mapping-page .field-mapping-grid .form-control:hover {
  border-color: var(--fm-ink-300) !important;
}
.xml-field-mapping-page .field-mapping-grid .form-select:focus,
.xml-field-mapping-page .field-mapping-grid .form-control:focus {
  outline: none !important;
  border-color: #2563eb !important;
  box-shadow: 0 0 0 3px rgba(37,99,235,.12) !important;
}

/* Drag-over highlight */
.xml-field-mapping-page .field-mapping-grid .droppable-select.drag-over {
  border-color: #667eea !important;
  background-color: rgba(243,240,255,.6) !important;
  box-shadow: 0 0 0 3px rgba(102,126,234,.18) !important;
}

/* Mapped state — değer dolu olunca yeşil (JS tarafı .fm-mapped uygular) */
.xml-field-mapping-page .field-mapping-grid select.form-select.fm-mapped,
.xml-field-mapping-page .field-mapping-grid input.form-control.fm-mapped,
.xml-field-mapping-page .field-mapping-grid .droppable-select.fm-mapped,
.xml-field-mapping-page .field-mapping-grid select.form-select.mapped,
.xml-field-mapping-page .field-mapping-grid .droppable-select.mapped {
  border-color: #10b981 !important;
  background-color: rgba(16,185,129,.08) !important;
  color: #047857 !important;
  font-weight: 500 !important;
}
/* Mapped chevron yeşilleştir — TÜM background props explicit, çünkü
   sadece `background-image` setlersek bazı tarayıcılarda/cascade'lerde
   background-repeat/size/position default'a (repeat) düşüyor — chevron
   ekran boyunca tekrarlanıyor. */
.xml-field-mapping-page .field-mapping-grid select.form-select.fm-mapped,
.xml-field-mapping-page .field-mapping-grid select.form-select.mapped {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2310b981' stroke-width='2.5'><path d='m6 9 6 6 6-6'/></svg>") !important;
  background-repeat: no-repeat !important;
  background-position: right 9px center !important;
  background-size: 14px 14px !important;
}
/* Empty state chevron'lar da tekrar etmesin (defansif): */
.xml-field-mapping-page .field-mapping-grid select.form-select.fm-req-empty,
.xml-field-mapping-page .field-mapping-grid select.form-select.fm-opt-empty,
.xml-field-mapping-page .field-mapping-grid select.form-select.req-empty {
  background-repeat: no-repeat !important;
  background-position: right 9px center !important;
  background-size: 14px 14px !important;
}
/* Required ama boş — açık kırmızı border + bg */
.xml-field-mapping-page .field-mapping-grid select.form-select.fm-req-empty,
.xml-field-mapping-page .field-mapping-grid input.form-control.fm-req-empty,
.xml-field-mapping-page .field-mapping-grid .droppable-select.fm-req-empty,
.xml-field-mapping-page .field-mapping-grid select.form-select.req-empty,
.xml-field-mapping-page .field-mapping-grid .droppable-select.req-empty {
  border-color: #fca5a5 !important;
  background-color: rgba(254,242,242,.6) !important;
}
/* Optional boş — sade gri */
.xml-field-mapping-page .field-mapping-grid select.form-select.fm-opt-empty,
.xml-field-mapping-page .field-mapping-grid input.form-control.fm-opt-empty {
  color: var(--fm-ink-400) !important;
}

/* Help text (Maksimum 3 karakter, kategori açıklaması, vb.) */
.xml-field-mapping-page .field-mapping-grid .form-text {
  font-size: 10.5px !important;
  color: var(--fm-muted) !important;
  margin-top: 4px !important;
  line-height: 1.4 !important;
}
.xml-field-mapping-page .field-mapping-grid .form-text code {
  font-family: 'JetBrains Mono', monospace !important;
  font-size: 10px !important;
  background: var(--fm-ink-100) !important;
  padding: 1px 5px !important;
  border-radius: 3px !important;
  color: #1e40af !important;
}

/* fm-form-body padding (card-body içinde) */
.xml-field-mapping-page .fm-card .card-body.fm-form-body,
.xml-field-mapping-page .card.fm-card > .card-body {
  padding: 14px 16px !important;
}

/* fm-card chrome — Bootstrap .card override */
.xml-field-mapping-page .card.fm-card {
  background: var(--fm-card-bg) !important;
  border: 1px solid var(--fm-border) !important;
  border-radius: 12px !important;
  box-shadow: 0 1px 2px rgba(15,23,42,.04), 0 4px 12px -8px rgba(15,23,42,.08) !important;
  overflow: hidden !important;
  margin-bottom: 0 !important;
}
.xml-field-mapping-page .card.fm-card > .card-header.fm-card-h {
  background: var(--fm-card-bg-2) !important;
  border-bottom: 1px solid var(--fm-border) !important;
  padding: 11px 14px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 10px !important;
}
.xml-field-mapping-page .card.fm-card > .card-header.fm-card-h h2,
.xml-field-mapping-page .card.fm-card > .card-header.fm-card-h h5 {
  font-size: 13px !important;
  font-weight: 600 !important;
  margin: 0 !important;
  color: var(--fm-text) !important;
  letter-spacing: -0.005em !important;
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
}
.xml-field-mapping-page .card.fm-card > .card-header.fm-card-h h2 i.bi,
.xml-field-mapping-page .card.fm-card > .card-header.fm-card-h h5 i.bi {
  color: #2563eb !important;
  font-size: 14px !important;
}

/* fm-tabs Bootstrap nav-tabs override */
.xml-field-mapping-page .nav.nav-tabs.fm-tabs {
  display: flex !important;
  gap: 0 !important;
  border-bottom: 1px solid var(--fm-border) !important;
  background: var(--fm-card-bg) !important;
  padding: 0 !important;
  margin: 0 0 12px !important;
  list-style: none !important;
  flex-wrap: nowrap !important;
  overflow-x: auto !important;
}
.xml-field-mapping-page .nav.nav-tabs.fm-tabs .nav-item {
  margin: 0 !important;
}
.xml-field-mapping-page .nav.nav-tabs.fm-tabs .nav-link.fm-tab,
.xml-field-mapping-page .nav.nav-tabs.fm-tabs button.nav-link {
  padding: 10px 14px !important;
  font-size: 12.5px !important;
  font-weight: 500 !important;
  color: var(--fm-muted) !important;
  background: transparent !important;
  border: none !important;
  border-bottom: 2px solid transparent !important;
  cursor: pointer !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  transition: all .15s !important;
  position: relative !important;
  text-decoration: none !important;
  border-radius: 0 !important;
  white-space: nowrap !important;
}
.xml-field-mapping-page .nav.nav-tabs.fm-tabs .nav-link.fm-tab i.bi,
.xml-field-mapping-page .nav.nav-tabs.fm-tabs button.nav-link i.bi {
  color: inherit !important;
  font-size: 13px !important;
}
.xml-field-mapping-page .nav.nav-tabs.fm-tabs .nav-link.fm-tab:hover,
.xml-field-mapping-page .nav.nav-tabs.fm-tabs button.nav-link:hover {
  color: var(--fm-ink-700) !important;
  background: transparent !important;
}
.xml-field-mapping-page .nav.nav-tabs.fm-tabs .nav-link.fm-tab.active,
.xml-field-mapping-page .nav.nav-tabs.fm-tabs button.nav-link.active {
  color: #2563eb !important;
  border-bottom-color: #2563eb !important;
  font-weight: 600 !important;
  background: transparent !important;
}
.xml-field-mapping-page .nav.nav-tabs.fm-tabs .nav-link.fm-tab.active i.bi,
.xml-field-mapping-page .nav.nav-tabs.fm-tabs button.nav-link.active i.bi {
  color: #2563eb !important;
}

/* Tab badge "X/Y" — JS tarafı dinamik append eder */
.xml-field-mapping-page .nav.nav-tabs.fm-tabs .nav-link.fm-tab .fm-tab-badge,
.xml-field-mapping-page .nav.nav-tabs.fm-tabs button.nav-link .fm-tab-badge {
  margin-left: 6px !important;
  font-size: 10px !important;
  font-weight: 600 !important;
  background: var(--fm-ink-100) !important;
  color: var(--fm-ink-600) !important;
  padding: 1px 6px !important;
  border-radius: 999px !important;
  font-variant-numeric: tabular-nums !important;
  letter-spacing: -0.01em !important;
}
.xml-field-mapping-page .nav.nav-tabs.fm-tabs .nav-link.active .fm-tab-badge {
  background: rgba(37,99,235,.15) !important;
  color: #1d4ed8 !important;
}
.xml-field-mapping-page .nav.nav-tabs.fm-tabs .nav-link.warn .fm-tab-badge {
  background: rgba(239,68,68,.12) !important;
  color: #b91c1c !important;
}

/* Tab uyarı kırmızı nokta — required boşluk varken */
.xml-field-mapping-page .nav.nav-tabs.fm-tabs .nav-link.fm-tab.warn::after,
.xml-field-mapping-page .nav.nav-tabs.fm-tabs button.nav-link.warn::after {
  content: "" !important;
  position: absolute !important;
  top: 6px; right: 4px !important;
  width: 6px; height: 6px !important;
  border-radius: 50% !important;
  background: #ef4444 !important;
}

/* Tab content padding */
.xml-field-mapping-page .tab-content {
  padding: 0 !important;
}

/* Sticky save bar viewport altta sabit; sayfa alt padding'ı ile içerik
   sticky bar'ın altında kaybolmasın. */
.xml-field-mapping-page #fieldMappingMainContent {
  padding-bottom: 90px !important;
}

/* =============================================================
   PREVIEW PANEL BRIDGE — sağ paneldeki mevcut .xml-* class'larını
   reference template'in .fm-toolbar / .fm-stat-chip / .fm-page /
   .fm-hints / .fm-subtabs görünümlerine bağla.
   ============================================================= */

/* Toolbar (ürün sayacı + export) */
.xml-field-mapping-page .xml-preview-panel-wrap > .d-flex.flex-wrap.align-items-center.justify-content-between {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 8px !important;
  padding: 8px 10px !important;
  background: var(--fm-card-bg-2) !important;
  border: 1px solid var(--fm-border) !important;
  border-radius: 10px !important;
  margin-bottom: 8px !important;
}
.xml-field-mapping-page .xml-stat-badge {
  font-size: 11px !important;
  background: rgba(37,99,235,.08) !important;
  color: #1d4ed8 !important;
  border: 1px solid rgba(37,99,235,.18) !important;
  padding: 4px 10px !important;
  border-radius: 999px !important;
  font-weight: 600 !important;
  font-variant-numeric: tabular-nums !important;
}
.xml-field-mapping-page .xml-preview-page-hint {
  font-size: 11px !important;
  color: var(--fm-muted) !important;
}

/* Export button group */
.xml-field-mapping-page .xml-preview-toolbar-export {
  font-size: 11px !important;
  padding: 5px 10px !important;
  border-radius: 7px !important;
  border: 1px solid var(--fm-border) !important;
  background: var(--fm-card-bg) !important;
  color: var(--fm-ink-700) !important;
  font-weight: 500 !important;
  transition: all .15s !important;
}
.xml-field-mapping-page .xml-preview-toolbar-export:hover:not(:disabled) {
  border-color: #2563eb !important;
  color: #1d4ed8 !important;
  background: rgba(37,99,235,.05) !important;
}
.xml-field-mapping-page .xml-preview-toolbar-export:disabled {
  opacity: .55 !important;
  cursor: not-allowed !important;
}

/* Pagination bar — fm-page görünümü */
.xml-field-mapping-page .xml-pagination-bar.card {
  background: var(--fm-card-bg-2) !important;
  border: 1px solid var(--fm-border) !important;
  border-radius: 10px !important;
  box-shadow: none !important;
  margin-bottom: 8px !important;
}
.xml-field-mapping-page .xml-pagination-bar.card > .card-body {
  padding: 8px 10px !important;
}
.xml-field-mapping-page .xml-pagination-row {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 8px !important;
}
.xml-field-mapping-page .xml-pagination-bar .xml-pg-btn,
.xml-field-mapping-page .xml-pagination-bar .pagination-btn {
  font-size: 11px !important;
  padding: 5px 9px !important;
  border-radius: 6px !important;
  border: 1px solid var(--fm-border) !important;
  background: var(--fm-card-bg) !important;
  color: var(--fm-ink-700) !important;
  font-weight: 500 !important;
  line-height: 1.2 !important;
}
.xml-field-mapping-page .xml-pagination-bar .xml-pg-btn:hover:not(:disabled),
.xml-field-mapping-page .xml-pagination-bar .pagination-btn:hover:not(:disabled) {
  border-color: #2563eb !important;
  color: #1d4ed8 !important;
  background: rgba(37,99,235,.05) !important;
}
.xml-field-mapping-page .xml-pagination-bar .xml-pg-btn:disabled {
  opacity: .45 !important;
  cursor: not-allowed !important;
}
.xml-field-mapping-page .xml-pg-page-badge {
  font-size: 11px !important;
  padding: 4px 12px !important;
  background: rgba(37,99,235,.12) !important;
  color: #1d4ed8 !important;
  border: 1px solid rgba(37,99,235,.25) !important;
  font-weight: 600 !important;
  font-variant-numeric: tabular-nums !important;
  border-radius: 999px !important;
}
.xml-field-mapping-page .xml-page-jump {
  flex-wrap: nowrap !important;
}
.xml-field-mapping-page .xml-page-jump .input-group-text {
  font-size: 11px !important;
  padding: 4px 8px !important;
  background: var(--fm-card-bg-2) !important;
  border: 1px solid var(--fm-border) !important;
  color: var(--fm-muted) !important;
}
.xml-field-mapping-page .xml-page-jump .xml-page-input {
  font-size: 11px !important;
  padding: 4px 8px !important;
  width: 56px !important;
  border: 1px solid var(--fm-border) !important;
  background: var(--fm-card-bg) !important;
  color: var(--fm-ink-900) !important;
  font-weight: 600 !important;
}

/* Hints toolbar */
.xml-field-mapping-page .xml-mapping-hints-toolbar {
  background: linear-gradient(180deg, rgba(37,99,235,.04), rgba(37,99,235,.02)) !important;
  border: 1px solid rgba(37,99,235,.18) !important;
  border-radius: 10px !important;
  padding: 10px 12px !important;
  margin-bottom: 8px !important;
}
.xml-field-mapping-page .xml-mapping-hints-lead {
  font-size: 11.5px !important;
  line-height: 1.45 !important;
  color: var(--fm-ink-700) !important;
}
.xml-field-mapping-page .xml-mapping-hints-lead strong {
  color: #1d4ed8 !important;
  font-weight: 600 !important;
}
.xml-field-mapping-page .xml-mapping-hints-lead code {
  font-family: 'JetBrains Mono', monospace !important;
  font-size: 10px !important;
  background: rgba(37,99,235,.08) !important;
  padding: 1px 5px !important;
  border-radius: 3px !important;
  color: #1d4ed8 !important;
}
.xml-field-mapping-page .xml-mapping-hints-grid {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 6px !important;
}

/* Hint butonları (JS render) */
.xml-field-mapping-page .xml-mapping-hints-grid .btn,
.xml-field-mapping-page .xml-mapping-hints-grid button,
.xml-field-mapping-page .xml-mapping-hints-grid .xml-hint-btn {
  font-size: 10.5px !important;
  padding: 4px 9px !important;
  border-radius: 6px !important;
  border: 1px solid rgba(37,99,235,.25) !important;
  background: var(--fm-card-bg) !important;
  color: #1d4ed8 !important;
  font-weight: 500 !important;
  cursor: pointer !important;
  transition: all .15s !important;
}
.xml-field-mapping-page .xml-mapping-hints-grid .btn:hover,
.xml-field-mapping-page .xml-mapping-hints-grid .xml-hint-btn:hover {
  background: rgba(37,99,235,.08) !important;
  border-color: #2563eb !important;
}

/* Sub-tabs (Alanlar / Örnek Ürün / Ham XML) — fm-subtabs underline */
.xml-field-mapping-page .nav.nav-pills.xml-preview-main-tabs {
  display: flex !important;
  border-bottom: 1px solid var(--fm-border) !important;
  background: transparent !important;
  padding: 0 !important;
  margin: 0 !important;
  gap: 0 !important;
  list-style: none !important;
}
.xml-field-mapping-page .xml-preview-main-tabs .nav-item { margin: 0 !important; }
.xml-field-mapping-page .xml-preview-main-tabs .nav-link {
  padding: 9px 12px !important;
  font-size: 11.5px !important;
  font-weight: 500 !important;
  color: var(--fm-muted) !important;
  background: transparent !important;
  border: none !important;
  border-bottom: 2px solid transparent !important;
  border-radius: 0 !important;
  cursor: pointer !important;
  transition: all .15s !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 4px !important;
}
.xml-field-mapping-page .xml-preview-main-tabs .nav-link.active {
  color: #2563eb !important;
  background: transparent !important;
  border-bottom-color: #2563eb !important;
  font-weight: 600 !important;
}
.xml-field-mapping-page .xml-preview-main-tabs .nav-link:hover:not(.active) {
  color: var(--fm-ink-700) !important;
  background: transparent !important;
}

/* Sub-tab content shell */
.xml-field-mapping-page .xml-preview-tab-shell {
  background: var(--fm-card-bg) !important;
  border: 1px solid var(--fm-border) !important;
  border-top: 0 !important;
  border-radius: 0 0 10px 10px !important;
  margin-top: 0 !important;
}
.xml-field-mapping-page .xml-preview-tab-pane-inner {
  padding: 10px 12px !important;
}
.xml-field-mapping-page .xml-tab-subtitle {
  font-size: 11px !important;
  color: var(--fm-muted) !important;
  line-height: 1.45 !important;
}

/* Raw XML alt sub-tabs (Kod / Ağaç) */
.xml-field-mapping-page .nav.nav-tabs.xml-raw-subtabs {
  background: transparent !important;
  border-bottom: 1px solid var(--fm-border) !important;
  padding: 0 4px !important;
}
.xml-field-mapping-page .xml-raw-subtabs .nav-link {
  padding: 5px 10px !important;
  font-size: 11px !important;
  color: var(--fm-muted) !important;
  background: transparent !important;
  border: none !important;
  border-bottom: 2px solid transparent !important;
  border-radius: 0 !important;
}
.xml-field-mapping-page .xml-raw-subtabs .nav-link.active {
  color: #2563eb !important;
  border-bottom-color: #2563eb !important;
  font-weight: 600 !important;
  background: transparent !important;
}
.xml-field-mapping-page .xml-raw-nested-content {
  border: 0 !important;
  background: transparent !important;
}
.xml-field-mapping-page .xml-preview-box {
  background: var(--fm-card-bg-2) !important;
  border: 1px solid var(--fm-border) !important;
  border-radius: 8px !important;
  padding: 8px !important;
  font-family: 'JetBrains Mono', monospace !important;
  font-size: 11px !important;
  color: var(--fm-ink-700) !important;
}

/* Form save button alanı (eski .fm-save) - sticky bar var, eski save butonu da
   görünmeye devam etsin ama sade kalsın */
.xml-field-mapping-page form#mappingForm > .row.g-3.mt-4,
.xml-field-mapping-page form#mappingForm > div:last-child:has(button[type="submit"]) {
  margin-top: 14px !important;
  padding-top: 14px !important;
  border-top: 1px solid var(--fm-border) !important;
}

/* =============================================================
   Save bar (inside form panel — old, will be replaced by sticky)
   ============================================================= */
.xml-field-mapping-page .fm-save {
  padding: 14px 16px;
  border-top: 1px solid var(--fm-border);
  background: var(--fm-card-bg-2);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.xml-field-mapping-page .fm-tip {
  font-size: 11.5px;
  color: var(--fm-muted);
  display: flex;
  align-items: center;
  gap: 6px;
}
.xml-field-mapping-page .fm-tip .ic { color: #f59e0b; }

.xml-field-mapping-page .fm-btn {
  padding: 8px 14px !important;
  border-radius: 8px !important;
  font-size: 12.5px !important;
  font-weight: 600 !important;
  border: 1px solid transparent !important;
  cursor: pointer;
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  transition: all 0.15s !important;
  font-family: inherit !important;
  line-height: 1.2 !important;
  letter-spacing: -0.005em !important;
  text-decoration: none !important;
}
.xml-field-mapping-page .fm-btn.primary,
.xml-field-mapping-page .btn.fm-btn.primary,
.xml-field-mapping-page .btn-primary.fm-btn {
  background: linear-gradient(180deg, #2563eb, #1d4ed8) !important;
  color: #fff !important;
  border-color: #1d4ed8 !important;
  box-shadow: 0 1px 2px rgba(37,99,235,.3) !important;
}
.xml-field-mapping-page .fm-btn.primary:hover {
  background: linear-gradient(180deg, #1d4ed8, #1e40af) !important;
  color: #fff !important;
}
.xml-field-mapping-page .fm-btn.ghost {
  background: var(--fm-card-bg) !important;
  color: var(--fm-ink-700) !important;
  border-color: var(--fm-border) !important;
}
.xml-field-mapping-page .fm-btn.ghost:hover {
  background: var(--fm-ink-50) !important;
  border-color: var(--fm-ink-300) !important;
}
.xml-field-mapping-page .fm-btn.success {
  background: linear-gradient(180deg, #10b981, #059669) !important;
  color: #fff !important;
  border-color: #059669 !important;
  box-shadow: 0 1px 2px rgba(16,185,129,.3) !important;
}
.xml-field-mapping-page .fm-btn.success:hover {
  background: linear-gradient(180deg, #059669, #047857) !important;
  color: #fff !important;
}
.xml-field-mapping-page .fm-btn.lg {
  padding: 10px 20px !important;
  font-size: 13.5px !important;
}

/* =============================================================
   Preview panel toolbar (stats chips)
   ============================================================= */
.xml-field-mapping-page .fm-toolbar {
  padding: 10px 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  border-bottom: 1px solid var(--fm-border);
  background: var(--fm-card-bg);
  flex-wrap: wrap;
}
.xml-field-mapping-page .fm-tool-stats {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}
.xml-field-mapping-page .fm-stat-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 4px 9px;
  background: var(--fm-ink-50);
  border: 1px solid var(--fm-border);
  border-radius: 999px;
  font-size: 11px;
  color: var(--fm-ink-700);
  font-weight: 500;
}
.xml-field-mapping-page .fm-stat-chip b {
  color: var(--fm-ink-900);
  font-weight: 700;
  font-variant-numeric: tabular-nums;
}
.xml-field-mapping-page .fm-stat-chip.warn {
  background: rgba(254,243,199,.6);
  border-color: rgba(253,230,138,.6);
  color: #92400e;
}
.xml-field-mapping-page .fm-tool-export {
  display: flex;
  border: 1px solid var(--fm-border);
  border-radius: 7px;
  overflow: hidden;
  background: var(--fm-card-bg);
}
.xml-field-mapping-page .fm-tool-export button {
  padding: 5px 10px;
  font-size: 11.5px;
  background: var(--fm-card-bg);
  border: none;
  border-right: 1px solid var(--fm-border);
  color: var(--fm-ink-700);
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 4px;
  font-weight: 500;
}
.xml-field-mapping-page .fm-tool-export button:last-child { border-right: none; }
.xml-field-mapping-page .fm-tool-export button:hover {
  background: var(--fm-ink-50);
  color: #2563eb;
}

/* =============================================================
   Pagination
   ============================================================= */
.xml-field-mapping-page .fm-page {
  padding: 8px 14px;
  display: flex;
  align-items: center;
  gap: 8px;
  border-bottom: 1px solid var(--fm-border);
  background: var(--fm-card-bg-2);
  flex-wrap: wrap;
}
.xml-field-mapping-page .fm-page-grp {
  display: flex;
  border: 1px solid var(--fm-border);
  border-radius: 6px;
  overflow: hidden;
}
.xml-field-mapping-page .fm-page-grp button {
  padding: 4px 9px !important;
  font-size: 11px !important;
  background: var(--fm-card-bg) !important;
  border: none !important;
  border-right: 1px solid var(--fm-border) !important;
  color: #c2410c !important;
  cursor: pointer;
  font-weight: 500 !important;
  display: flex;
  align-items: center;
  gap: 4px;
  border-radius: 0 !important;
}
.xml-field-mapping-page .fm-page-grp button:last-child { border-right: none !important; }
.xml-field-mapping-page .fm-page-grp button:hover:not(:disabled) {
  background: rgba(255,247,237,.6) !important;
}
.xml-field-mapping-page .fm-page-grp button:disabled {
  color: var(--fm-ink-300) !important;
  cursor: not-allowed;
  background: var(--fm-card-bg-2) !important;
}
.xml-field-mapping-page .fm-page-pill {
  padding: 4px 11px;
  background: rgba(255,107,0,.12);
  color: #c2410c;
  border: 1px solid rgba(255,107,0,.35);
  border-radius: 999px;
  font-size: 11px;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
}
.xml-field-mapping-page .fm-page-jump {
  display: flex;
  align-items: center;
  border: 1px solid var(--fm-border);
  border-radius: 6px;
  overflow: hidden;
  background: var(--fm-card-bg);
  margin-left: auto;
}
.xml-field-mapping-page .fm-page-jump span {
  padding: 4px 8px;
  font-size: 10.5px;
  color: var(--fm-muted);
  background: var(--fm-card-bg-2);
  border-right: 1px solid var(--fm-border);
}
.xml-field-mapping-page .fm-page-jump input {
  width: 54px;
  padding: 4px 8px !important;
  border: none !important;
  font-size: 11.5px !important;
  text-align: center;
  font-variant-numeric: tabular-nums;
  font-weight: 600;
  font-family: 'JetBrains Mono', monospace !important;
  background: var(--fm-card-bg) !important;
  color: var(--fm-text) !important;
  border-radius: 0 !important;
}
.xml-field-mapping-page .fm-page-jump input:focus {
  outline: none !important;
  background: rgba(255,247,237,.4) !important;
  box-shadow: none !important;
}
.xml-field-mapping-page .fm-page-jump button {
  padding: 4px 10px !important;
  background: #ff6b00 !important;
  color: #fff !important;
  border: none !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  cursor: pointer;
  border-left: 1px solid #ea580c !important;
  border-radius: 0 !important;
}
.xml-field-mapping-page .fm-page-jump button:hover { background: #ea580c !important; }

/* =============================================================
   Hints
   ============================================================= */
.xml-field-mapping-page .fm-hints {
  padding: 10px 14px;
  background: linear-gradient(180deg, rgba(254,252,232,.55) 0%, rgba(255,251,235,.4) 100%);
  border-bottom: 1px solid var(--fm-border);
}
.xml-field-mapping-page .fm-hints-h {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-size: 11.5px;
  color: #78350f;
  line-height: 1.45;
  margin-bottom: 8px;
}
.xml-field-mapping-page .fm-hints-h .ic {
  color: #d97706;
  font-size: 14px;
  flex-shrink: 0;
  margin-top: 1px;
}
.xml-field-mapping-page .fm-hints-h b { color: #451a03; }
.xml-field-mapping-page .fm-hints-h code {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  background: rgba(217,119,6,.12);
  padding: 1px 5px;
  border-radius: 3px;
  color: #9a3412;
}
.xml-field-mapping-page .fm-hints-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 6px;
}
@media (max-width: 560px) {
  .xml-field-mapping-page .fm-hints-grid { grid-template-columns: 1fr; }
}
.xml-field-mapping-page .fm-hint-btn,
.xml-field-mapping-page .xml-mapping-hints-grid > * {
  text-align: left;
  padding: 6px 9px;
  background: var(--fm-card-bg);
  border: 1px solid var(--fm-border);
  border-radius: 6px;
  font-size: 11px;
  color: var(--fm-ink-700);
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 6px;
  transition: all 0.15s;
  line-height: 1.35;
}
.xml-field-mapping-page .fm-hint-btn:hover {
  border-color: #2563eb;
  background: rgba(37,99,235,.06);
  box-shadow: 0 1px 4px rgba(37,99,235,.12);
}
.xml-field-mapping-page .fm-hint-btn.miss {
  background: var(--fm-ink-50);
  color: var(--fm-muted);
  font-style: italic;
}
.xml-field-mapping-page .fm-hint-btn.miss:hover {
  background: rgba(254,242,242,.6);
  border-color: #fca5a5;
  color: #991b1b;
  font-style: normal;
}
.xml-field-mapping-page .fm-hint-btn b { color: var(--fm-ink-900); font-weight: 600; flex-shrink: 0; }
.xml-field-mapping-page .fm-hint-btn .arr { color: var(--fm-ink-400); font-weight: 400; }
.xml-field-mapping-page .fm-hint-btn code {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  color: #1d4ed8;
  background: rgba(37,99,235,.1);
  padding: 1px 5px;
  border-radius: 3px;
  font-weight: 500;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.xml-field-mapping-page .fm-hint-applied {
  color: #059669;
  margin-left: auto;
  flex-shrink: 0;
  font-size: 12px;
}

/* =============================================================
   Sub-tabs (preview Fields / Sample / Raw XML)
   ============================================================= */
.xml-field-mapping-page .fm-subtabs {
  display: flex;
  gap: 0;
  padding: 0 14px;
  background: var(--fm-card-bg-2);
  border-bottom: 1px solid var(--fm-border);
  flex-wrap: nowrap;
  overflow-x: auto;
}
.xml-field-mapping-page .fm-subtab {
  padding: 9px 12px !important;
  font-size: 11.5px !important;
  font-weight: 600 !important;
  color: var(--fm-muted) !important;
  background: transparent !important;
  border: none !important;
  border-bottom: 2px solid transparent !important;
  cursor: pointer;
  display: flex !important;
  align-items: center !important;
  gap: 5px !important;
  border-radius: 0 !important;
  text-decoration: none !important;
}
.xml-field-mapping-page .fm-subtab .ic { font-size: 12px; }
.xml-field-mapping-page .fm-subtab:hover { color: var(--fm-ink-700) !important; }
.xml-field-mapping-page .fm-subtab.active {
  color: #2563eb !important;
  border-bottom-color: #2563eb !important;
  background: var(--fm-card-bg) !important;
}

/* =============================================================
   Fields table inside preview
   ============================================================= */
.xml-field-mapping-page .fm-fields-wrap {
  max-height: 480px;
  overflow: auto;
  background: var(--fm-card-bg);
}
.xml-field-mapping-page .fm-fields-tbl {
  width: 100%;
  border-collapse: collapse;
  font-size: 11.5px;
}
.xml-field-mapping-page .fm-fields-tbl thead th {
  position: sticky;
  top: 0;
  z-index: 1;
  background: var(--fm-card-bg-2);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--fm-muted);
  font-weight: 700;
  padding: 8px 10px;
  text-align: left;
  border-bottom: 1px solid var(--fm-border);
}
.xml-field-mapping-page .fm-fields-tbl tbody td {
  padding: 7px 10px;
  border-bottom: 1px solid var(--fm-ink-100);
  vertical-align: middle;
}
.xml-field-mapping-page .fm-fields-tbl tbody tr:hover { background: var(--fm-card-bg-2); }
.xml-field-mapping-page .fm-fields-tbl tbody tr.container td {
  background: rgba(148,163,184,.06);
  color: var(--fm-muted);
}

.xml-field-mapping-page .fm-tag-btn,
.xml-field-mapping-page .xml-tag-draggable {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  font-weight: 500;
  padding: 2px 7px;
  background: rgba(14,165,233,.13);
  color: #0369a1;
  border: 1px solid rgba(14,165,233,.4);
  border-radius: 4px;
  cursor: grab;
  user-select: none;
  line-height: 1.5;
  transition: all 0.15s;
  letter-spacing: -0.01em;
}
.xml-field-mapping-page .fm-tag-btn:hover,
.xml-field-mapping-page .xml-tag-draggable:hover {
  background: rgba(37,99,235,.13);
  color: #075985;
  border-color: rgba(37,99,235,.4);
  transform: translateY(-1px);
  box-shadow: 0 1px 3px rgba(59,130,246,.2);
}
.xml-field-mapping-page .fm-tag-btn:active { cursor: grabbing; transform: translateY(0); }

.xml-field-mapping-page .fm-leaf-badge {
  display: inline-block;
  font-size: 10px;
  font-weight: 600;
  padding: 2px 6px;
  border-radius: 4px;
  background: var(--fm-ink-100);
  color: var(--fm-ink-600);
  border: 1px solid rgba(0,0,0,.06);
  font-family: 'JetBrains Mono', monospace;
}
.xml-field-mapping-page .fm-sample {
  color: var(--fm-ink-700);
  font-size: 11px;
  max-width: 200px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  display: block;
}
.xml-field-mapping-page .fm-tip-pill {
  display: inline-block;
  font-size: 10px;
  padding: 1px 6px;
  border-radius: 4px;
  background: var(--fm-ink-100);
  color: var(--fm-ink-600);
  font-weight: 500;
  text-transform: lowercase;
}
.xml-field-mapping-page .fm-tip-pill.multi { background: rgba(167,139,250,.18); color: #6d28d9; }
.xml-field-mapping-page .fm-tip-pill.cont { background: var(--fm-ink-100); color: var(--fm-muted); }

.xml-field-mapping-page .fm-mapped-pill {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  font-size: 10px;
  font-weight: 600;
  padding: 2px 7px;
  border-radius: 4px;
  background: rgba(16,185,129,.12);
  color: #047857;
  border: 1px solid rgba(16,185,129,.3);
}
.xml-field-mapping-page .fm-mapped-pill .dot {
  width: 5px; height: 5px;
  border-radius: 50%;
  background: #10b981;
}

.xml-field-mapping-page .fm-apply-btn {
  padding: 3px 8px;
  font-size: 10.5px;
  font-weight: 600;
  background: var(--fm-card-bg);
  color: #2563eb;
  border: 1px solid rgba(37,99,235,.3);
  border-radius: 5px;
  cursor: pointer;
  transition: all 0.15s;
}
.xml-field-mapping-page .fm-apply-btn:hover {
  background: #2563eb;
  color: #fff;
  border-color: #2563eb;
}
.xml-field-mapping-page .fm-apply-btn.applied {
  background: #10b981;
  color: #fff;
  border-color: #10b981;
}

/* =============================================================
   Sample product card
   ============================================================= */
.xml-field-mapping-page .fm-sample-body { padding: 14px; }
.xml-field-mapping-page .fm-prod {
  border: 1px solid var(--fm-border);
  border-radius: 10px;
  overflow: hidden;
  background: linear-gradient(180deg, var(--fm-card-bg) 0%, var(--fm-ink-50) 100%);
  box-shadow: 0 1px 2px rgba(15,23,42,.04);
}
.xml-field-mapping-page .fm-prod-hero {
  padding: 12px 14px;
  background: linear-gradient(135deg, rgba(59,130,246,.07) 0%, rgba(99,102,241,.05) 100%);
  border-bottom: 1px solid var(--fm-border);
}
.xml-field-mapping-page .fm-prod-eyebrow {
  font-size: 9.5px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 700;
  color: var(--fm-muted);
  margin-bottom: 3px;
}
.xml-field-mapping-page .fm-prod-title {
  font-size: 14.5px;
  font-weight: 700;
  color: var(--fm-ink-900);
  line-height: 1.3;
  letter-spacing: -0.015em;
}
.xml-field-mapping-page .fm-prod-body {
  padding: 12px 14px;
  display: flex;
  flex-direction: column;
  gap: 11px;
}
.xml-field-mapping-page .fm-prod-block {
  border: 1px solid var(--fm-border);
  border-radius: 8px;
  background: var(--fm-card-bg);
  overflow: hidden;
}
.xml-field-mapping-page .fm-prod-block-h {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding: 7px 11px;
  background: var(--fm-card-bg-2);
  border-bottom: 1px solid var(--fm-border);
  color: var(--fm-ink-600);
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.xml-field-mapping-page .fm-prod-block-h .badge {
  background: rgba(37,99,235,.12);
  color: #1d4ed8;
  font-size: 9.5px;
  padding: 2px 7px;
  border-radius: 999px;
  font-weight: 600;
}
.xml-field-mapping-page .fm-prod-block-b {
  padding: 9px 11px;
  font-size: 11.5px;
  line-height: 1.55;
  color: var(--fm-ink-700);
}

/* =============================================================
   Raw XML view
   ============================================================= */
.xml-field-mapping-page .fm-raw {
  background: var(--fm-card-bg-2);
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  line-height: 1.6;
  max-height: 480px;
  overflow: auto;
  border-top: 1px solid var(--fm-border);
}
.xml-field-mapping-page .fm-raw-line {
  display: flex;
  border-bottom: 1px solid var(--fm-border-2);
  min-height: 0;
}
.xml-field-mapping-page .fm-raw-num {
  flex: 0 0 38px;
  text-align: right;
  font-size: 9.5px;
  padding: 3px 8px;
  color: var(--fm-ink-400);
  background: var(--fm-ink-100);
  border-right: 1px solid var(--fm-border);
  user-select: none;
  font-variant-numeric: tabular-nums;
}
.xml-field-mapping-page .fm-raw-c {
  flex: 1;
  padding: 3px 10px;
  background: var(--fm-card-bg-2);
  white-space: pre;
  overflow-x: auto;
  color: var(--fm-ink-700);
}
.xml-field-mapping-page .fm-tag-open {
  display: inline-flex;
  align-items: center;
  background: rgba(37,99,235,.1);
  color: #1d4ed8;
  border: 1px solid rgba(37,99,235,.28);
  border-radius: 3px;
  padding: 0 4px;
  font-size: 10.5px;
  cursor: grab;
  margin: 0 1px;
  font-weight: 600;
  letter-spacing: -0.01em;
  transition: all 0.15s;
}
.xml-field-mapping-page .fm-tag-close {
  display: inline-flex;
  align-items: center;
  background: rgba(217,119,6,.1);
  color: #c2410c;
  border: 1px solid rgba(217,119,6,.3);
  border-radius: 3px;
  padding: 0 4px;
  font-size: 10.5px;
  cursor: grab;
  margin: 0 1px;
  font-weight: 600;
  letter-spacing: -0.01em;
  transition: all 0.15s;
}
.xml-field-mapping-page .fm-tag-open:hover { background: rgba(37,99,235,.18); border-color: #2563eb; transform: translateY(-1px); }
.xml-field-mapping-page .fm-tag-close:hover { background: rgba(217,119,6,.18); border-color: #ea580c; transform: translateY(-1px); }
.xml-field-mapping-page .fm-syn-text { color: var(--fm-ink-700); }
.xml-field-mapping-page .fm-syn-attr { color: #6f42c1; }
.xml-field-mapping-page .fm-syn-val { color: #d63384; }

/* =============================================================
   Tree view
   ============================================================= */
.xml-field-mapping-page .fm-tree {
  padding: 12px 14px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  max-height: 480px;
  overflow: auto;
  background: var(--fm-card-bg);
  color: var(--fm-text);
}
.xml-field-mapping-page .fm-tree details {
  margin: 0 0 0 14px;
  border-left: 2px solid var(--fm-border);
  padding-left: 8px;
}
.xml-field-mapping-page .fm-tree details:first-child { margin-left: 0; border-left: none; padding-left: 0; }
.xml-field-mapping-page .fm-tree summary {
  cursor: pointer;
  list-style: none;
  padding: 2px 0;
  color: #1d4ed8;
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 5px;
}
.xml-field-mapping-page .fm-tree summary::-webkit-details-marker { display: none; }
.xml-field-mapping-page .fm-tree summary::before {
  content: "▸";
  color: var(--fm-ink-400);
  font-size: 10px;
  transition: transform 0.15s;
  display: inline-block;
}
.xml-field-mapping-page .fm-tree details[open] > summary::before { transform: rotate(90deg); }
.xml-field-mapping-page .fm-tree summary .meta {
  color: var(--fm-ink-400);
  font-weight: 400;
  font-size: 10px;
  margin-left: 4px;
}
.xml-field-mapping-page .fm-tree summary .count {
  font-size: 9.5px;
  background: var(--fm-ink-100);
  color: var(--fm-ink-600);
  padding: 1px 5px;
  border-radius: 3px;
  font-weight: 600;
  margin-left: auto;
}
.xml-field-mapping-page .fm-tree-val {
  color: var(--fm-ink-600);
  padding: 2px 0;
  word-break: break-word;
  font-size: 10.5px;
  font-style: italic;
}

/* =============================================================
   Sticky save bar at bottom
   ============================================================= */
.xml-field-mapping-page ~ .fm-stickybar,
.xml-field-mapping-page .fm-stickybar,
div.fm-stickybar,
.fm-stickybar {
  position: fixed !important;
  bottom: 0 !important;
  left: 0 !important;
  right: 0 !important;
  background: var(--tm-bg-card, #fff) !important;
  border-top: 1px solid var(--tm-border-color, #e2e8f0) !important;
  padding: 10px 24px !important;
  /* dış çubuk: sadece full-bleed konum + arka plan; flex/ortalama .inner'da */
  z-index: 1040 !important;
  box-shadow: 0 -4px 16px -8px rgba(15,23,42,.12) !important;
}
/* Desktop: app sol nav rayının ALTINA girme — left'i ray kadar kaydır.
   Ortalamayı .fm-stickybar-inner (max-width:1520px; margin:0 auto) yapar,
   böylece içerik shell ile tam aynı eksende ORTALANIR. (Eski sürüm
   asimetrik padding ile 100%=viewport-ray genişliğine göre hesap yapıp
   içeriği şaşırtıyordu.) */
@media (min-width: 1024px) {
  .fm-stickybar,
  .xml-field-mapping-page ~ .fm-stickybar,
  div.fm-stickybar {
    left: var(--tm-sidebar-w, 280px) !important;
  }
}
/* Ortalanmış iç içerik — shell ile aynı 1520px genişlik */
.fm-stickybar-inner {
  max-width: 1520px;
  margin: 0 auto;
  width: 100%;
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}
.fm-stickybar-l {
  display: flex;
  align-items: center;
  gap: 14px;
  font-size: 12px;
  color: var(--tm-text-secondary, #475569);
  flex: 1;
  min-width: 0;
}
.fm-stickybar-stat {
  display: inline-flex;
  align-items: center;
  gap: 5px;
}
.fm-stickybar-stat b {
  color: var(--tm-text-primary, #0f172a);
  font-weight: 700;
  font-size: 13px;
  font-variant-numeric: tabular-nums;
}
.fm-stickybar-stat.ok  { color: #059669; }
.fm-stickybar-stat.ok b { color: #047857; }
.fm-stickybar-stat.warn { color: #d97706; }
.fm-stickybar-stat.err  { color: #dc2626; }
.fm-stickybar-stat.err b { color: #b91c1c; }

/* "Eksik: x, y" text — kırmızı small */
#fmStickyMissing {
  font-size: 11.5px !important;
  color: #dc2626 !important;
  font-weight: 500 !important;
}

/* Push body up so sticky bar doesn't cover bottom of form */
.xml-field-mapping-page { padding-bottom: 80px; }

@media (max-width: 768px) {
  .xml-field-mapping-page ~ .fm-stickybar,
  .xml-field-mapping-page .fm-stickybar,
  div.fm-stickybar,
  .fm-stickybar {
    padding: 8px 10px calc(8px + env(safe-area-inset-bottom, 0px)) !important;
  }

  .fm-stickybar-inner {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 8px;
    align-items: center;
  }

  .fm-stickybar-l {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 4px 8px;
    font-size: 11px;
    line-height: 1.2;
  }

  .fm-stickybar-stat {
    min-width: 0;
    white-space: normal;
  }

  #fmStickyMissing {
    grid-column: 1 / -1;
    font-size: 10.5px !important;
    line-height: 1.2;
  }

  .fm-stickybar .fm-btn {
    min-height: 38px;
    padding: 8px 10px;
    font-size: 12px;
    line-height: 1.15;
    white-space: nowrap;
  }
}

@media (max-width: 420px) {
  .xml-field-mapping-page { padding-bottom: 108px; }

  .fm-stickybar-inner {
    grid-template-columns: 1fr 1fr;
  }

  .fm-stickybar-l {
    grid-column: 1 / -1;
  }

  #fmStickyMissing {
    display: none !important;
  }
}

/* =============================================================
   Dark mode adjustments — token zaten override ediyor; ek ince
   düzeltmeler.
   ============================================================= */
html.dark-mode .xml-field-mapping-page .fm-hero {
  /* Hero gradient'i koruyoruz, dark için biraz daha derin yap */
  background: linear-gradient(135deg, #4c5db8 0%, #5e3585 100%);
  box-shadow: 0 4px 18px -8px rgba(76,93,184,.6);
}
html.dark-mode .xml-field-mapping-page .fm-step.active {
  background: rgba(96,165,250,.16);
  color: #93c5fd;
}
html.dark-mode .xml-field-mapping-page .fm-step.done { color: #4ade80; }
html.dark-mode .xml-field-mapping-page .fm-tab.active {
  color: #60a5fa !important;
  border-bottom-color: #60a5fa !important;
}
html.dark-mode .xml-field-mapping-page .fm-subtab.active {
  color: #60a5fa !important;
  border-bottom-color: #60a5fa !important;
}
html.dark-mode .xml-field-mapping-page .fm-select.mapped {
  background-color: rgba(74,222,128,.10) !important;
  color: #86efac !important;
  border-color: #4ade80 !important;
}
html.dark-mode .xml-field-mapping-page .fm-select.req-empty {
  background-color: rgba(248,113,113,.10) !important;
  border-color: #fca5a5 !important;
}
html.dark-mode .xml-field-mapping-page .fm-tag-btn,
html.dark-mode .xml-field-mapping-page .xml-tag-draggable {
  background: rgba(96,165,250,.18);
  color: #7dd3fc;
  border-color: rgba(96,165,250,.4);
}
html.dark-mode .xml-field-mapping-page .fm-mapped-pill {
  background: rgba(74,222,128,.16);
  color: #86efac;
  border-color: rgba(74,222,128,.35);
}
html.dark-mode .fm-stickybar {
  background: var(--tm-bg-card, #111b2e);
  border-top-color: var(--tm-border-color, #1a2538);
}
html.dark-mode .fm-stickybar-stat.ok b { color: #86efac; }
html.dark-mode .fm-stickybar-stat.err b { color: #fca5a5; }

/* =============================================================
   Hide legacy header (eski tmv2 page header) when fm-hero present
   ============================================================= */
.xml-field-mapping-page .tmv2-page-header {
  display: none !important;
}
