.chk-csv-table-outer{
  position: relative;
}

/* Scroll wrapper */
.chk-csv-table-wrapper{
  position: relative;
  display: block;
  max-width: 100%;
  overflow-x: auto !important;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;

  /* ✅ przywraca domyślne gesty (poziom + pion) */
  touch-action: auto;

  overscroll-behavior-x: contain;

  /* ✅ wyłącz “rączkę” */
  cursor: auto;
}

/* ✅ blokada kopiowania/zaznaczania (wszystkie urządzenia + Safari/iOS) */
.chk-csv-table,
.chk-csv-table *{
  -webkit-user-select: none;
  user-select: none;
}

.chk-csv-table{
  -webkit-touch-callout: none; /* iOS Safari: brak menu copy/paste przy long-press */
  cursor: auto;
}

/* Fixed edge shadows */
.chk-csv-scroll-overlay{
  pointer-events: none;
  position: absolute;
  inset: 0;
  z-index: 6;
}

.chk-csv-shadow{
  position: absolute;
  top: 0;
  bottom: 0;
  width: 28px;
  opacity: 0;
  transition: opacity .15s ease;
}

.chk-csv-shadow.left{
  left: 0;
  background: linear-gradient(
    to right,
    var(--e-global-color-secondary, #F5F7F9),
    rgba(245,247,249,0)
  );
}
.chk-csv-shadow.right{
  right: 0;
  background: linear-gradient(
    to left,
    var(--e-global-color-secondary, #F5F7F9),
    rgba(245,247,249,0)
  );
}

.chk-csv-table-outer.can-scroll-left  .chk-csv-shadow.left{ opacity: 1; }
.chk-csv-table-outer.can-scroll-right .chk-csv-shadow.right{ opacity: 1; }

/* Hint (mobile only) */
.chk-csv-scroll-hint{
  text-align: center;
  font-size: 12px;
  opacity: .85;
  color: var(--e-global-color-text, #2F2F2F);
}
.chk-csv-scroll-hint--top{ margin: 0 0 8px; }
.chk-csv-scroll-hint--bottom{ margin: 8px 0 0; }

@media (min-width: 769px){
  .chk-csv-scroll-hint{ display:none; }
}

/* Table sizing */
.chk-csv-table{
  border-collapse: separate;
  border-spacing: 0;
  table-layout: auto;
  width: max-content !important;
  min-width: 100% !important;
  font-size: 14px;
  color: var(--e-global-color-text, #2F2F2F);
  border: none !important;
}

/* Grid */
.chk-csv-table th,
.chk-csv-table td{
  border-right: 1px solid rgba(0,0,0,.10);
  border-bottom: 1px solid rgba(0,0,0,.10);
  border-top: 0;
  border-left: 0;
  padding: 8px;
  vertical-align: top;
  white-space: nowrap;
}

.chk-csv-table thead th{ border-top: 1px solid rgba(0,0,0,.10); }
.chk-csv-table th:first-child,
.chk-csv-table td:first-child{ border-left: 1px solid rgba(0,0,0,.10); }

/* HEADER – ALIGN LEFT */
.chk-csv-table thead th{
  background: var(--e-global-color-primary, #006C93);
  color: #fff;
  text-align: left;
  white-space: nowrap;
}

/* Key column */
.chk-csv-table th:first-child,
.chk-csv-table td:first-child{
  background: var(--e-global-color-secondary, #F5F7F9);
  color: var(--e-global-color-text, #2F2F2F);
  font-weight: 600;
  border-right: 2px solid rgba(0,0,0,.12);
}

/* Sticky behavior (desktop) */
.chk-csv-table[data-features*="sticky"] thead th{
  position: sticky;
  top: 0;
  z-index: 40;
}

.chk-csv-table[data-features*="sticky"] td:first-child{
  position: sticky;
  left: 0;
  z-index: 30;
  background: var(--e-global-color-secondary, #F5F7F9);
  box-shadow: 1px 0 0 0 var(--e-global-color-secondary, #F5F7F9);
}

/* Top-left corner */
.chk-csv-table[data-features*="sticky"] thead th:first-child{
  position: sticky;
  top: 0;
  left: 0;
  z-index: 50;
  background: var(--e-global-color-primary, #006C93);
  color: #fff;
  box-shadow: 1px 0 0 0 var(--e-global-color-primary, #006C93);
}

/* Section rows (empty rows) */
.chk-csv-table tbody tr.chk-csv-empty-row td{
  background: var(--e-global-color-primary, #006C93);
  color: #fff;
  font-weight: 600;
  border-right-color: rgba(255,255,255,.25);
  border-bottom-color: rgba(255,255,255,.25);
}
.chk-csv-table tbody tr.chk-csv-empty-row td:first-child{
  background: var(--e-global-color-primary, #006C93);
  color: #fff;
  border-left-color: rgba(255,255,255,.25);
}

/* Mobile: sticky OFF */
@media (max-width: 768px){
  .chk-csv-table[data-features*="sticky"] thead th,
  .chk-csv-table[data-features*="sticky"] td:first-child{
    position: static !important;
    box-shadow: none !important;
  }
}

.chk-csv-template-list {
  display: flex;
  flex-wrap: wrap;
}