@font-face {
	font-family: 'Noto Color Emoji';
	font-style: normal;
	font-weight: 400;
	font-display: swap;
	src: url(/fonts/NotoColorEmoji.subset.woff2) format('woff2');
}

:root {
	--main-bg: white;
	--main-fg: black;
	--table-fg: black;
	--table-bg: white;
	--table-head-bg: #d7efff;
	--table-head-fg: black;
	--table-head-bg-hover: #93d4ff;
	--table-row-bg-hover: #6fe7b0;
	--table-odd-row-bg: #f0f0f0;
	--table-cell-border: 1px solid #d0d0d0;
	--link-fg: #00319f;
	--link-fg-visited: #7f009f;
	--argtype-fg: #006e8f;
}

/* @media (prefers-color-scheme: dark) is detected through JS if needed. */
body[data-theme="dark"] {
	--main-bg: black;
	--main-fg: white;
	--table-fg: #d9d9d9;
	--table-bg: black;
	--table-head-bg: #003a60;
	--table-head-fg: white;
	--table-head-bg-hover: #0066a8;
	--table-odd-row-bg: #0e0e0e;
	--table-row-bg-hover: #002909;
	--table-cell-border: 1px solid #303030;
	--link-fg: #39a7c6;
	--link-fg-visited: #d69ce7;
	--argtype-fg: #15c1c1;
}

#theme-toggle {
	display: inline-block;
	vertical-align: middle;
	width: 40px;
	height: 20px;
	cursor: pointer;
	background-repeat: no-repeat;
	background-image: url("");
}

body[data-theme="dark"] #theme-toggle {
	background-image: url("");
}

body {
	font-family: ui-monospace, consolas, monospace, courier;
	font-size: 12px;
	color: var(--main-fg);
	background-color: var(--main-bg);
	padding-bottom: 3em;
}

select {
	font-size: inherit;
}

a, a:visited {
	color: var(--main-fg);
}

table {
	padding: 5px;
	color: var(--table-fg);
	border-collapse: collapse;
	border-bottom: var(--table-cell-border);
}

table th, table td {
	border-left: var(--table-cell-border);
	border-right: var(--table-cell-border);
}

table th {
	top: 0;
	position: sticky;
	text-align: left;
	padding: 5px;
	color: var(--table-head-fg);
	background-color: var(--table-head-bg);
	border-top: var(--table-cell-border);
	border-bottom: var(--table-cell-border);
	/* Avoid ugly text selection while clicking to sort/collapse */
	user-select: none;
	-moz-user-select: none;
	-webkit-user-select: none;
	-ms-user-select: none;
	/* Avoid collapsed columns overlapping with table headers... for whatever reason*/
	z-index: 1;
}

table th.pad {
	background-color: transparent;
	border: none;
}

table th.sortable {
	cursor: pointer;
}

table td {
	text-align: left;
	padding: 3px 5px 3px;
	background-color: var(--table-bg);
}

table tr:nth-child(odd) td {
	background-color: var(--table-odd-row-bg);
}

table tr.highlight td {
	background-color: var(--table-row-bg-hover);
}

table a {
	color: var(--link-fg);
	text-decoration: none;
}

table a:visited {
	color: var(--link-fg-visited);
}

table span.argtype {
	font-weight: bold;
	color: var(--argtype-fg);
}

.invisible {
	display: none;
}

table td.unknown {
	font-family: sans-serif;
	font-style: italic;
}

#compact-sig-toggle {
	text-decoration: underline;
}

#compact-sig-toggle::before { display: inline-block; content: '['; }
#compact-sig-toggle::after  { display: inline-block; content: ']'; }

/* Collapse columns through CSS trickery so that JS only has to add/remove words
 * from the table's data-collapse attribute. */

table th > .collapse-toggle::before {
	content: '[-]';
}

/* Show [+] instead of [-] for collapsed columns */
table[data-collapse~="name"]      th[data-column="name"]      > .collapse-toggle::before,
table[data-collapse~="symbol"]    th[data-column="symbol"]    > .collapse-toggle::before,
table[data-collapse~="location"]  th[data-column="location"]  > .collapse-toggle::before,
table[data-collapse~="kconfig"]   th[data-column="kconfig"]   > .collapse-toggle::before,
table[data-collapse~="signature"] th[data-column="signature"] > .collapse-toggle::before {
	content: '[+]';
}

/* No column title for collapsed columns, just the toggle */
table[data-collapse~="name"]      th[data-column="name"]      > .collapsible,
table[data-collapse~="symbol"]    th[data-column="symbol"]    > .collapsible,
table[data-collapse~="location"]  th[data-column="location"]  > .collapsible,
table[data-collapse~="kconfig"]   th[data-column="kconfig"]   > .collapsible,
table[data-collapse~="signature"] th[data-column="signature"] > .collapsible {
	display: none;
}

/* Hide the content of collapsed columns */
table[data-collapse~="name"]      td[data-column="name"],
table[data-collapse~="symbol"]    td[data-column="symbol"],
table[data-collapse~="location"]  td[data-column="location"],
table[data-collapse~="kconfig"]   td[data-column="kconfig"],
table[data-collapse~="signature"] td[data-column="signature"] {
	overflow: hidden;
	white-space: nowrap;
	text-overflow: ellipsis;
	max-width: 0px;
	opacity: 0.5;
}

/* Emojis! Use U+202f (narrow no-break space) to space header sort arrows and
   U+2002 (en space) to space emojis for bad locations and esoteric syscalls. */

table th.ascending::before, table th.descending::before, table td.bad::after, table td.esoteric::after {
	font-family: 'Noto Color Emoji';
}

table th.ascending::before  { content: '\2b07\fe0f\202f';  }
table th.descending::before { content: '\2b06\fe0f\202f';  }
table td.bad::after         { content: '\2002\26a0\fe0f';  }
table td.esoteric::after    { content: '\2002\1f984\fe0f'; }

/* Hover effects */

@media (any-hover: hover) {
	table th.sortable:hover {
		cursor: pointer;
		background-color: var(--table-head-bg-hover);
	}

	table tr:hover td {
		background-color: var(--table-row-bg-hover);
	}

	table a:hover {
		text-decoration: underline;
	}

	table .collapse-toggle:hover {
		cursor: pointer;
		text-shadow: 0px 0px 3px var(--main-fg);
	}

	#compact-sig-toggle:hover {
		cursor: pointer;
	}

	#compact-sig-toggle:hover::before,
	#compact-sig-toggle:hover::after {
		text-decoration: none;
		text-shadow: 0px 0px 3px var(--main-fg);
	}
}
