:root {
	font-family: sans-serif;
	font-size: 10pt;
	--border-color: lightgray;
	--padding: 0.2rem;
	--gantt-line: 2.5rem;

	color-scheme: light dark;
}

kv-gantt table {
	border-collapse: collapse;
	width: 100%;
}

kv-gantt th,
kv-gantt td {
	border: thin solid var(--border-color);
	padding: var(--padding);
}

kv-gantt .department {
	background-color: ButtonFace;
	color: ButtonText;
	line-height: 2rem;
	font-weight: bolder;
}

kv-gantt tbody tr:not(.department):not(.selected):hover {
	background-color: ButtonFace;
	color: ButtonText;
	cursor: pointer;
}

kv-gantt tfoot {
	font-weight: bolder;
}

kv-gantt .tasks {
	position: relative;
	overflow: hidden;
	height: 2rem;
}

kv-gantt .tasks div {
	box-sizing: border-box;
	line-height: 2rem;
}

kv-gantt .task {
	position: absolute;
	text-align: center;
	overflow: hidden;
	height: calc(var(--gantt-line) - 0.5rem);
	margin: 0.0625rem 0;
	color: black;
}

kv-gantt .load {
	position: relative;
	width: 2.3rem;
	font-size: smaller;
	text-align: center;
	color: var(--text-color, black); /* Default text color */
	overflow: hidden;
}

kv-gantt .load span {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	z-index: 1;
	white-space: nowrap;
	background: linear-gradient(to right, black 0%, black var(--histogram-width, 0%), var(--text-color, white) var(--histogram-width, 0%), var(--text-color, white) 100%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	pointer-events: none;
}

kv-gantt .load:after {
	content: "%";
}

kv-gantt .load.zero {
	color: transparent;
}

kv-gantt .hour, kv-gantt .bar {
	display: inline-block;
	width: 4.166%;
	font-size: x-small;
	border-right: thin solid var(--border-color);
}

kv-gantt .operator {
	writing-mode: sideways-lr;
	color: black;
}

kv-gantt .selected {
	color: HighLightText;
	background-color: HighLight;
}

@media (prefers-color-scheme: light) {
	:root {
		--text-color: black;
	}
}

@media (prefers-color-scheme: dark) {
	:root {
		--text-color: white;
	}
}