/* Light Mode */
.tabulator {
  background-color: var(--color-surface);
  color: var(--color-on-surface);
  font-size: 0.875rem;
  border: 1px solid var(--color-outline);
  border-radius: var(--radius-radius);
  overflow: hidden;
}

.tabulator .tabulator-header {
  background-color: var(--color-surface-alt);
  color: var(--color-on-surface-strong);
  border-bottom: 1px solid var(--color-outline-strong);
}

.tabulator .tabulator-col {
  background-color: var(--color-surface-alt);
  border-right: 1px solid var(--color-outline);
}

.tabulator .tabulator-col-title {
  color: var(--color-on-surface-strong);
}

.tabulator .tabulator-row {
  background-color: var(--color-surface);
  color: var(--color-on-surface);
}

.tabulator .tabulator-row:nth-child(even) {
  background-color: var(--color-surface-alt);
}

.tabulator .tabulator-row:hover {
  background-color: var(--color-secondary);
  color: var(--color-on-secondary);
}

.tabulator .tabulator-row.tabulator-selected {
  background-color: var(--color-primary);
  color: var(--color-on-primary);
}

.tabulator .tabulator-footer {
  background-color: var(--color-surface-alt);
  border-top: 1px solid var(--color-outline-strong);
  color: var(--color-on-surface);
}

.tabulator .tabulator-page.active {
  background-color: var(--color-primary);
  color: var(--color-on-primary);
}

.tabulator .tabulator-cell.tabulator-validation-fail {
  border: 1px solid var(--color-danger);
  color: var(--color-on-danger);
}

/* Dark Mode */
.dark .tabulator {
  background-color: var(--color-surface-dark);
  color: var(--color-on-surface-dark);
  border-color: var(--color-outline-dark);
}

.dark .tabulator .tabulator-header {
  background-color: var(--color-surface-dark-alt);
  color: var(--color-on-surface-dark-strong);
  border-bottom-color: var(--color-outline-dark-strong);
}

.dark .tabulator .tabulator-col {
  background-color: var(--color-surface-dark-alt);
  border-color: var(--color-outline-dark);
}

.dark .tabulator .tabulator-col-title {
  color: var(--color-on-surface-dark-strong);
}

.dark .tabulator .tabulator-row {
  background-color: var(--color-surface-dark);
  color: var(--color-on-surface-dark);
}

.dark .tabulator .tabulator-row:nth-child(even) {
  background-color: var(--color-surface-dark-alt);
}

.dark .tabulator .tabulator-row:hover {
  background-color: var(--color-secondary-dark);
  color: var(--color-on-secondary-dark);
}

.dark .tabulator .tabulator-row.tabulator-selected {
  background-color: var(--color-primary-dark);
  color: var(--color-on-primary-dark);
}

.dark .tabulator .tabulator-footer {
  background-color: var(--color-surface-dark-alt);
  border-top-color: var(--color-outline-dark-strong);
  color: var(--color-on-surface-dark);
}

.dark .tabulator .tabulator-page.active {
  background-color: var(--color-primary-dark);
  color: var(--color-on-primary-dark);
}

.dark .tabulator .tabulator-cell.tabulator-validation-fail {
  border-color: var(--color-danger);
  color: var(--color-on-danger);
}

/* Fix: consistent cell padding and alignment for all cells */
.tabulator .tabulator-cell {
  padding: 0.5rem; /* or match others */
  text-align: left;
  vertical-align: middle;
}

/* Fix: center delete icon in last column */
.tabulator .tabulator-cell:last-child {
  text-align: center;
  padding-left: 0.5rem;
  padding-right: 0.5rem;
  min-width: 40px; /* Optional: make it a consistent size */
}

/* Optional: make ❌ buttons more polished */
.tabulator .tabulator-cell:last-child svg,
.tabulator .tabulator-cell:last-child i {
  color: var(--color-danger);
  font-size: 1rem;
  vertical-align: middle;
}

/* Light Theme */
.tabulator .tabulator-alert {
  background-color: rgba(0, 0, 0, 0.4);
}

.tabulator .tabulator-alert .tabulator-alert-msg {
  background-color: var(--color-surface-alt);
  color: var(--color-on-surface-strong);
  border-radius: var(--radius-radius);
  padding: 12px 24px;
  font-size: 1rem;
  font-weight: 500;
  border: 2px solid var(--color-outline-strong);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
}

/* Default "msg" type */
.tabulator .tabulator-alert .tabulator-alert-msg.tabulator-alert-state-msg {
  border-color: var(--color-surface-alt);
  color: var(--color-on-surface-strong);
}

/* Default "error" type */
.tabulator .tabulator-alert .tabulator-alert-msg.tabulator-alert-state-error {
  background-color: var(--color-danger);
  color: var(--color-on-danger);
  border-color: var(--color-danger);
}

/* Dark Theme override */
.dark .tabulator .tabulator-alert .tabulator-alert-msg {
  background-color: var(--color-surface-dark-alt);
  color: var(--color-on-surface-dark-strong);
  border-color: var(--color-surface-dark-alt);
}

.dark .tabulator .tabulator-alert .tabulator-alert-msg.tabulator-alert-state-msg {
  color: var(--color-on-surface-dark-strong);
  border-color: var(--color-surface-dark-alt);
}

.dark .tabulator .tabulator-alert .tabulator-alert-msg.tabulator-alert-state-error {
  background-color: var(--color-danger);
  color: var(--color-on-danger);
  border-color: var(--color-danger);
}