/* Datagrid — follows oat conventions:
   data-* attributes for selectors, oat CSS variables for colors */

/* Toolbar */
[data-datagrid-toolbar] {
	display: flex;
	align-items: center;
	gap: 0.5rem;
}

[data-datagrid-toolbar] input[type="search"] {
	max-width: 20rem;
}

/* Sortable column headers */
th[data-sortable] {
	user-select: none;
	white-space: nowrap;
}

th[data-sortable] [data-sort-label] {
	cursor: pointer;
	transition: color 150ms;
}

th[data-sortable] [data-sort-label]:hover {
	color: var(--primary);
	text-decoration: underline;
	text-underline-offset: 0.25em;
}

th[data-sortable] [data-sort-icon] {
	font-size: 0.8em;
	opacity: 0.3;
}

th[data-sortable][data-sort] [data-sort-icon] {
	opacity: 1;
	color: var(--primary);
}

/* Pagination */
[data-datagrid-pagination] {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 0.5rem;
}

[data-datagrid-pagination] .pagination-left {
	display: flex;
	align-items: center;
	gap: 1rem;
	font-size: 0.875rem;
	color: var(--muted-foreground);
}

[data-datagrid-pagination] .pagination-left select {
	font-size: 0.8125rem;
	padding: 0.125rem 0.375rem;
	border: 1px solid var(--border, #e2e8f0);
	border-radius: 0.25rem;
	background: var(--card-background, #fff);
	color: var(--foreground, #1e293b);
}

[data-datagrid-pagination] .pagination-pages {
	display: flex;
	align-items: center;
	gap: 0.125rem;
}

[data-datagrid-pagination] .pagination-pages button {
	background: none;
	border: none;
	padding: 0.25rem 0.5rem;
	font-size: 0.8125rem;
	border-radius: 0.25rem;
	cursor: pointer;
	color: var(--muted-foreground, #64748b);
	line-height: 1;
}

[data-datagrid-pagination] .pagination-pages button:hover:not(:disabled) {
	background: var(--muted, #f1f5f9);
	color: var(--foreground, #1e293b);
}

[data-datagrid-pagination] .pagination-pages button[data-current] {
	background: var(--muted, #f1f5f9);
	color: var(--foreground, #1e293b);
	font-weight: 600;
}

[data-datagrid-pagination] .pagination-pages button:disabled {
	cursor: default;
	opacity: 0.4;
}

[data-datagrid-pagination] .pagination-pages .pagination-ellipsis {
	padding: 0.25rem 0.25rem;
	font-size: 0.8125rem;
	color: var(--muted-foreground, #64748b);
	user-select: none;
}

[data-datagrid-info] {
	font-size: 0.875rem;
	color: var(--muted-foreground);
}

/* Toolbar — push compact toggle to the right */
[data-datagrid-toolbar] label:last-child {
	margin-inline-start: auto;
}

/* Checkbox column */
th[data-col="checkbox"],
td[data-col="checkbox"] {
	width: 2.5rem;
	padding-left: 0.75rem;
	text-align: center;
}

/* Compact density */
table[data-compact] th,
table[data-compact] td {
	padding: var(--space-1) var(--space-2);
	font-size: var(--text-8);
}
