.ccl-datatable {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--typography-font-family-sans);
  font-size: var(--typography-font-size-sm);
  color: var(--color-text, #000);
}

.ccl-datatable th,
.ccl-datatable td {
  padding: var(--spacing-sm) var(--spacing-md);
  text-align: left;
}

.ccl-datatable th {
  font-weight: var(--typography-font-weight-bold, 700);
  border-bottom: var(--color-table-border-width) solid var(--color-table-border-color, #e5e7eb);
  background-color: var(--color-background-default, #fff);
  color: var(--color-text-default, #111827);
}

.ccl-datatable__header-label {
  margin-right: 0.25rem;
}

.ccl-datatable__header {
  display: flex;
  align-items: center;
  justify-content: space-between; /* push icon to right */
  width: 100%;
}

.ccl-datatable__sortable {
  cursor: pointer;
  user-select: none;
}

.ccl-datatable__sort-indicator {
  color: var(--color-text-secondary, #6b7280);
  display: flex;
  flex-direction: column; /* vertical arrows */
  gap: 2px;
  align-items: center;
}

.ccl-datatable__arrow {
  opacity: 0.4;
  line-height: 0.8;
  font-size: 0.7rem;
}
.ccl-datatable__arrow.active {
  opacity: 1;
  color: var(--color-primary-default, #0055ff);
}

.ccl-datatable td {
  border-top: var(--color-table-border-width) solid var(--color-table-border-color, #ddd);
}

/* Bordered variant */
.ccl-datatable--bordered th,
.ccl-datatable--bordered td {
  border: var(--color-table-border-width) solid var(--color-table-border-color, #ddd);
}

/* Striped variant */
.ccl-datatable--striped tbody tr:nth-child(even) {
  background-color: var(--color-background-surface, #f5f5f5);
}

/* Compact variant */
.ccl-datatable--compact th,
.ccl-datatable--compact td {
  padding: var(--spacing-xs) var(--spacing-sm);
}

.ccl-datatable__empty {
  text-align: center;
  color: var(--color-text-muted, #666);
  padding: var(--spacing-md);
}

/* Multi-level Header Styles */
.ccl-datatable__parent-header {
  background-color: var(--color-background-surface, #f8f9fa);
}

.ccl-datatable__parent-header-cell {
  font-weight: var(--typography-font-weight-bold, 700);
  color: var(--color-text-default, #000);
  border-bottom: var(--color-table-border-width) solid var(--color-table-border-color, #ddd);
  padding: var(--spacing-sm) var(--spacing-md);
}

/* Header Alignment */
.ccl-datatable__align-left {
  text-align: left;
}

.ccl-datatable__align-center {
  text-align: center;
}

.ccl-datatable__align-right {
  text-align: right;
}

/* Individual Border Controls */
.ccl-datatable__border-left {
  border-left: var(--color-table-border-width) solid var(--color-table-border-color, #ddd) !important;
}

.ccl-datatable__border-right {
  border-right: var(--color-table-border-width) solid var(--color-table-border-color, #ddd) !important;
}

.ccl-datatable__border-top {
  border-top: var(--color-table-border-width) solid var(--color-table-border-color, #ddd) !important;
}

.ccl-datatable__border-bottom {
  border-bottom: var(--color-table-border-width) solid var(--color-table-border-color, #ddd) !important;
}

.ccl-datatable__cell-border-left {
  border-left: var(--color-table-border-width) solid var(--color-table-border-color, #ddd) !important;
}

.ccl-datatable__cell-border-right {
  border-right: var(--color-table-border-width) solid var(--color-table-border-color, #ddd) !important;
}

.ccl-datatable__cell-border-top {
  border-top: var(--color-table-border-width) solid var(--color-table-border-color, #ddd) !important;
}

.ccl-datatable__cell-border-bottom {
  border-bottom: var(--color-table-border-width) solid var(--color-table-border-color, #ddd) !important;
}
