/* =========================[ DATALIST MODERNO COMPACTO + BORDAS ]========================= */

.data-list {
  border-radius: var(--radius-tiny);
  overflow: visible;
  border: 1px solid #e5e7eb;
  background: #fff;
  box-shadow: 0 3px 8px rgba(0, 0, 0, 0.08);
  font-size: small;
  transition: box-shadow 0.2s ease, transform 0.2s ease;
}

.data-list:hover {
  box-shadow: 0 6px 14px rgba(0, 0, 0, 0.12);
}

/* =========================[ HEADER ]========================= */
.data-list-header {
  display: flex;
  align-items: center;

  background: linear-gradient(
    135deg,
    var(--color-blue-primary),
    var(--color-blue-light)
  );

  color: white;
  font-size: 12px;

  padding: 6px 4px;

  box-shadow: inset 0 -1px 0 rgba(255,255,255,0.25);

  letter-spacing: 0.3px;
}

.data-list-header .data-list-col {
  color: #fff;
  opacity: 0.95;
}

.data-list-header i {
  color: #fff;
  opacity: 0.9;
  font-size: 12px;
}

/* =========================[ ROWS ]========================= */
.data-list-row {
  display: flex;
  align-items: center;
  transition: background-color 0.2s ease;
  border-bottom: 1px solid #e5e7eb;
  font-size: var(--font-size-small);
  border-left: 3px solid transparent;
}

.data-list-row:nth-child(even) { background-color: #fafafa; }
.data-list-row:nth-child(odd)  { background-color: #fff; }

.data-list-row:hover {
  background-color: #f5faff;
  border-left: 3px solid var(--color-blue-light);
}

/* =========================[ COLS ]========================= */
.data-list-col {
  flex: 1;
  padding: 2px 6px;
  display: block;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.data-list-col[data-wrap="true"] {
  white-space: normal;
  overflow: visible;
  text-overflow: clip;
}

.data-list--no-ellipsis .data-list-col {
  white-space: normal;
  overflow: visible;
  text-overflow: clip;
}

/* Colunas especiais */
.data-list-col.col-tiny {
  flex: 0.2;
  text-align: center;
  padding: 2px 4px;
}

.data-list-col.col-small {
  flex: 0.4;
  text-align: center;
  padding: 2px 4px;
}

.data-list-col.col-medium { flex: 0.8; }
.data-list-col.col-large  { flex: 2; }

/* =========================[ PAGINATION ]========================= */
.data-list-pagination {
  display: flex;
  justify-content: center;
  gap: 6px;
  padding: 10px;
  background: #fff;
  border-top: 2px solid #e5e7eb;
  font-size: small;
}

/* =========================[ CHECKBOX ]========================= */
input[type="checkbox"] {
  transform: scale(1.1);
  cursor: pointer;
}

/* =========================[ ACTION BUTTONS ]========================= */
.data-list-col button {
  color: var(--color-gray);
  background: #fff;
  border: 1px solid #e5e7eb;
  padding: 4px 8px;
  font-size: small;
  border-radius: var(--radius-tiny);
  cursor: pointer;
  transition: all 0.15s ease;
}

.data-list-col button:hover {
  background: var(--color-blue-light);
  color: #fff;
  border: 1px solid var(--color-blue-light);
  padding: 4px 8px;
  font-size: small;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.12);
}

/* =========================[ ARROWS (paginações, setas, etc.) ]========================= */
.datalist-btn-arrow {
  background-color: var(--color-gray-medium);
  color: var(--color-text-light);
  cursor: pointer;
  transition: all 0.15s ease;
  border-radius: var(--radius-tiny);
  border: 1px solid var(--color-gray-medium);
  width: 24px;
  height: 24px;
}

.datalist-btn-arrow:hover {
  background-color: #fff;
  color: var(--color-gray-medium);
  border: 1px solid var(--color-gray-medium);
  cursor: pointer;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.12);
}

/* =========================[ CHIP ]========================= */
.chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 6px;
  border-radius: var(--radius-tiny);
  line-height: 1.2;
  font-size: small;
  color: var(--color-gray);
}

/* =========================[ HTML CELL ]========================= */
.datalist-html-cell {
  display: block;
  max-height: 1.25em;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* =========================[ PAGINATION INLINE - COMPACTO ]========================= */
.data-list-pagination-card {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 8px;
  background: #fff;
  border-top: 1px solid #e5e7eb;
  font-size: var(--font-size-small);
  padding-top: 4px;
}

.data-list-pagination-card .page-numbers {
  justify-self: center;
}

.data-list-pagination-card .info {
  justify-self: end;
}

.data-list-pagination,
.data-list-pagination-card {
  overflow: visible;
}

.page-numbers {
  display: flex;
  gap: 6px;
}

.datalist-btn-page {
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: var(--radius-tiny);
  padding: 4px 10px;
  font-size: small;
  cursor: pointer;
  transition: all 0.2s ease;
  color: var(--color-blue-primary);
}

.datalist-btn-page:hover {
  background: var(--color-blue-light);
  color: #fff;
  border: 1px solid;
  border-color: var(--color-blue-light);
  padding: 4px 10px;
  font-size: small;
  cursor: pointer;
}

.datalist-btn-page.active {
  background: var(--color-blue-primary);
  color: #fff;
  font-weight: bold;
  cursor: default;
}

/* Apenas a coluna de ações pode vazar */
.data-list-col-actions,
.data-list-col-actions * {
  overflow: visible;
}

.datalist-btn-arrow i {
  line-height: 1;
  display: block;
  font-size: smaller;
  margin: -4px;
}

/* ======================================================================
   [ DATALIST - MOBILE MODE | COMPACT (NO COLOR CHANGES) ]
   ====================================================================== */

@media (max-width: 768px) {

  .data-list .data-list-header {
    display: none !important;
  }

  .data-list-row[data-template="true"] {
    display: none !important;
  }

  .data-list-row:not(:has([data-mobile])) {
    display: none !important;
  }

  .data-list {
    border: none;
    box-shadow: none;
    background: transparent;
  }

  .data-list-row:has([data-mobile="img"]):not([data-template="true"]) {
    display: grid !important;
    grid-template-columns: 40px minmax(0, 1fr) auto; /* sem coluna do checkbox */
    column-gap: 8px;
    row-gap: 1px;
  }

  .data-list-row:not(:has([data-mobile="img"])):not([data-template="true"]) {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto; /* sem coluna do checkbox */
    column-gap: 8px;
    row-gap: 1px;
  }

  .data-list-row {
    padding: 4px !important;
    margin: 6px 8px !important;
    border: 1px solid #e5e7eb !important;
    border-radius: var(--radius-tiny) !important;
    background: #fff !important;
    overflow: visible !important;
    box-shadow: 0 2px 8px rgba(0,0,0,0.06) !important;
    min-height: 66px !important;
    align-content: start;
  }

  .data-list-col {
    flex: unset !important;
    padding: 0 !important;
    min-width: 0;
    text-align: left;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .data-list-col[data-mobile="hidden"] {
    display: none !important;
  }

    .data-list-col input[type="checkbox"] {
    grid-column: 1;
    grid-row: 1 / span 10;

    justify-self: center;
    align-self: center;

    width: 18px;
    height: 18px;

    margin: 0 !important;
    transform: none !important;

    accent-color: var(--color-blue-primary);
  }


  .data-list-col[data-mobile="img"] {
    grid-column: 1; /* agora é a 1ª coluna */
    grid-row: 1 / span 10;
    display: flex;
    align-items: flex-start;
    justify-content: flex-start;
    padding-top: 2px;
  }


  .data-list-col[data-mobile="img"] img {
    width: 38px;
    height: 38px;
    border-radius: 50%;
    object-fit: cover;
  }

  .data-list-col[data-mobile="primary"] {
  grid-row: 1;
  font-size: 12.5px;
  font-weight: 650;
  line-height: 1.15;

  white-space: normal !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;

  display: block !important;
  max-height: calc(1.15em * 2) !important;
  margin-top: 10px;
  margin-left: 10px;
}

.data-list-col[data-mobile="primary"] > span,
.data-list-col[data-mobile="primary"] > div {
  display: block !important;
  overflow: hidden !important;
  max-height: calc(1.15em * 2) !important;
}


.data-list-row:has([data-mobile="img"]) .data-list-col[data-mobile="primary"] {
  grid-column: 2; /* era 3, agora 2 */
}

.data-list-row:not(:has([data-mobile="img"])) .data-list-col[data-mobile="primary"] {
  grid-column: 1; /* era 2, agora 1 */
}


  .data-list-col[data-mobile="secondary"] {
  grid-row: 2;
  font-size: 11.5px;
  font-weight: 400;
  color: var(--color-gray-medium);
  line-height: 1.15;

  white-space: normal !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;

  display: block !important;
  max-height: calc(1.15em * 2) !important;
  margin-left: 10px;
}

.data-list-col[data-mobile="secondary"] > span,
.data-list-col[data-mobile="secondary"] > div {
  display: block !important;
  overflow: hidden !important;
  max-height: calc(1.15em * 2) !important;
}


.data-list-row:has([data-mobile="img"]) .data-list-col[data-mobile="secondary"] {
  grid-column: 2;
}

.data-list-row:not(:has([data-mobile="img"])) .data-list-col[data-mobile="secondary"] {
  grid-column: 1;
}


  .data-list-col[data-mobile="show"] {
    grid-row: auto;
    display: block;
    font-size: 12px;
    font-weight: 500;
    line-height: 1.25;
    text-align: left;

    white-space: normal !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;

    display: -webkit-box;
    -webkit-box-orient: vertical;
    margin-left: 10px;
  }

.data-list-row:has([data-mobile="img"]) .data-list-col[data-mobile="show"] {
  grid-column: 2;
}

.data-list-row:not(:has([data-mobile="img"])) .data-list-col[data-mobile="show"] {
  grid-column: 1;
}


  .data-list-col[data-mobile="show"] .mobile-show-field {
    display: flex;
    align-items: baseline;
    gap: 6px;
    min-width: 0;
  }

  .data-list-col[data-mobile="show"] .mobile-show-label {
    font-size: 11px;
    font-weight: 650;
    color: var(--color-gray-medium);
    white-space: nowrap;
    flex: 0 0 auto;
  }

  .data-list-col[data-mobile="show"] .mobile-show-value {
    min-width: 0;
    flex: 1 1 auto;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }


  .data-list-col[data-mobile="actions"] {
    grid-column: -1;
    grid-row: 1 / span 10;
    justify-self: end;
    align-self: start;
    position: relative;
    overflow: visible !important;

    padding: 0 !important;
    margin: 0 !important;
    width: auto !important;
  }

  .data-list-col[data-mobile="actions"] button.icon {
    width: 32px;
    height: 32px;
    padding: 0 !important;

    display: inline-flex;
    align-items: center;
    justify-content: center;

    border-radius: var(--radius-tiny);
  }

  .data-list-col[data-mobile="actions"] button.icon i {
    font-size: 14px;
    line-height: 1;
  }

  .data-list-col[data-mobile="actions"] .dropdown {
    position: absolute;
    top: 100%;
    right: 0;
    z-index: 99999 !important;
  }

  .data-list-pagination-card {
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    align-items: stretch;
    width: 100%;
    overflow: visible !important;
  }

  .data-list-pagination-card > button:nth-of-type(1) { grid-column: 1; grid-row: 1; width: 100%; min-height: 44px; }
  .data-list-pagination-card > button:nth-of-type(2) { grid-column: 2; grid-row: 1; width: 100%; min-height: 44px; }

  .data-list-pagination-card .page-numbers {
    grid-column: 1 / span 2;
    grid-row: 2;

    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 6px;
    width: 100%;
  }

  .data-list-pagination-card .datalist-btn-page {
    width: 100%;
    min-height: 44px;
    padding: 4px 0;
    font-size: 14px;
  }

  .data-list-pagination-card > button:nth-of-type(3) { grid-column: 1; grid-row: 3; width: 100%; min-height: 44px; }
  .data-list-pagination-card > button:nth-of-type(4) { grid-column: 2; grid-row: 3; width: 100%; min-height: 44px; }

  .data-list-pagination-card > span {
    grid-column: 1 / span 2;
    grid-row: 4;
    text-align: center;
    font-size: 12px;
    width: 100%;
  }

  .data-list-pagination-card .rows-per-page {
    grid-column: 1 / span 2;
    grid-row: 5;
    width: 100%;
    max-width: 100%;
    overflow: visible !important;
    position: relative;
    z-index: 20;
  }

  .data-list-pagination-card .rows-per-page * {
    max-width: 100%;
    box-sizing: border-box;
  }

  .data-list-pagination-card .rows-per-page ul,
  .data-list-pagination-card .rows-per-page [role="listbox"],
  .data-list-pagination-card .rows-per-page .dropdown,
  .data-list-pagination-card .rows-per-page .options {
    z-index: 99999 !important;
  }
  
  .data-list-col.mobile-ellipsis {
  position: relative;
  padding-right: 10px !important;
}

.data-list-col.mobile-ellipsis.has-ellipsis::after {
  content: "...";
  position: absolute;
  right: 0;
  bottom: 0;
  background: #fff;
  padding-left: 2px;
}

  /* =========================[ MOBILE FIX - COL-SMALL ALIGN ]========================= */

  .data-list-col.col-small[data-mobile="secondary"],
  .data-list-col.col-small[data-mobile="show"] {
    text-align: left !important;
    justify-self: start !important;
  }

  .data-list-col.col-small[data-mobile="secondary"] .chip,
  .data-list-col.col-small[data-mobile="show"] .chip {
    justify-content: flex-start !important;
  }

  /* ======================================================================
   [ DATALIST ROW SELECTION - MOBILE ]
   ====================================================================== */

    /* Hide checkbox on mobile (keep it functional) */
  .data-list-row:not([data-template="true"]) .data-list-col input.row-checkbox {
    opacity: 0 !important;
    pointer-events: none !important;
  }

  /* Spotify-like mobile selection */
  .data-list-row.mobile-selected {
    background: rgba(0, 123, 255, 0.08) !important;
    border: 1px solid rgba(0, 123, 255, 0.25) !important;

    box-shadow: 
      0 4px 12px rgba(0, 0, 0, 0.08),
      0 0 0 1px rgba(0, 123, 255, 0.15);

    transform: translateY(-1px);
    transition: all 0.2s ease;
  }

  /* Slight scale feedback */
  .data-list-row.mobile-selected:active {
    transform: scale(0.99);
  }


}

/* ======================================================================
   [ DATALIST SEARCH - FIX MOBILE + OVERRIDES ]
   ====================================================================== */

.datalist-search-wrapper {
  position: relative !important;
  display: flex !important;
  align-items: center !important;
  box-sizing: border-box !important;
  margin: 6px 0px 8px 0px !important;
}

.datalist-search-icon {
  position: absolute !important;
  left: 10px !important;
  font-size: 12px !important;
  color: var(--color-gray-medium) !important;
  pointer-events: none !important;
}

.datalist-search-box {
  width: 100% !important;
  box-sizing: border-box !important;

  border: 1px solid #e5e7eb !important;
  border-radius: var(--radius-tiny) !important;

  padding: 8px 10px 8px 30px !important;
  font-size: 12.5px !important;
  height: 36px !important;

  outline: none !important;
  background: #fff !important;
}

.datalist-search-box:focus {
  border-color: var(--color-blue-light) !important;
  box-shadow: 0 0 0 1px var(--color-blue-light) !important;
}

@media (max-width: 768px) {
  .datalist-search-wrapper {
    margin: 6px 8px 4px 8px !important;
  }

  .datalist-search-box {
    height: 38px !important;
    font-size: 13px !important;
  }
}

@media (max-width: 768px) {
  .data-list-row {
    -webkit-touch-callout: none;
    user-select: none;
  }
}

/* =========================[ DATALIST - EMPTY STATE ]========================= */

.datalist-empty {
  padding: 14px 12px;
  margin: 10px 8px;

  border: 1px dashed #e5e7eb;
  border-radius: var(--radius-tiny);
  background: #fff;

  box-shadow: 0 2px 8px rgba(0,0,0,0.06);
}

.datalist-empty-header {
  justify-content: center;
}

.datalist-empty-text {
  text-align: center;
  font-size: 12px;
  color: var(--color-gray-medium);
}

/* =========================[ DATALIST - HIDE HELPERS ]========================= */

.datalist-hidden {
  display: none !important;
}