<p>
	CSSWG issues
	<a href="https://github.com/w3c/csswg-drafts/issues/865#issuecomment-350585274"><b>#865</b> (comment)</a>
	and
	<a href="https://github.com/w3c/csswg-drafts/issues/8286"><b>#8286</b></a>
</p>

<p>Mauris egestas lacinia lacinia. Cras in diam in nisl auctor suscipit. Fusce maximus quam nec ante commodo commodo. Maecenas condimentum arcu faucibus leo sollicitudin accumsan. Integer dictum tempor metus. In vitae porta nisl. Praesent ullamcorper faucibus mi, nec mattis libero auctor non. Duis volutpat leo non ornare aliquam. Curabitur non varius nisi. Aliquam blandit lorem dui, nec dictum ligula consequat ac. Quisque quis nunc dolor. In interdum purus nibh. Donec congue vulputate ornare.</p>

<div class="table-wrapper" tabindex="0">
	<table>
		<tr>
			<th>Donec faucibus</th>
			<th>Proin ante</th>
			<th>Mauris</th>
		</tr>
		<tr>
			<td>lacinia&nbsp;sem&nbsp;vestibulum&nbsp;consectetur&nbsp;lacus</td>
			<td>phasellus&nbsp;eu&nbsp;semper&nbsp;nibh</td>
			<td>nulla&nbsp;elementum&nbsp;viverra&nbsp;malesuada</td>
		</tr>
		<tr>
			<td>lacinia sem vestibulum, consectetur lacus</td>
			<td>phasellus eu semper nibh</td>
			<td>nulla elementum viverra malesuada</td>
		</tr>
		<tr>
			<td>lacinia sem vestibulum, consectetur lacus</td>
			<td>phasellus eu semper nibh</td>
			<td>nulla elementum viverra malesuada</td>
		</tr>
		<tr>
			<td>lacinia sem vestibulum, consectetur lacus</td>
			<td>phasellus eu semper nibh</td>
			<td>nulla elementum viverra malesuada</td>
		</tr>
		<tr>
			<td>lacinia sem vestibulum, consectetur lacus</td>
			<td>phasellus eu semper nibh</td>
			<td>nulla elementum viverra malesuada</td>
		</tr>
		<tr>
			<td>lacinia sem vestibulum, consectetur lacus</td>
			<td>phasellus eu semper nibh</td>
			<td>nulla elementum viverra malesuada</td>
		</tr>
		<tr>
			<td>lacinia sem vestibulum, consectetur lacus</td>
			<td>phasellus eu semper nibh</td>
			<td>nulla elementum viverra malesuada</td>
		</tr>
		<tr>
			<td>lacinia sem vestibulum, consectetur lacus</td>
			<td>phasellus eu semper nibh</td>
			<td>nulla elementum viverra malesuada</td>
		</tr>
	</table>
</div>
<p>
	<label>
		<input class="scroll-toggle" type="checkbox" checked>
		Horizontally scrollable
	</label>
</p>

<p>Donec faucibus volutpat eros eget dignissim. Mauris lorem sem, dapibus sit amet molestie quis, ultricies sed erat. Fusce ut velit sit amet odio ornare tempor id non leo. Pellentesque euismod mattis metus, ac feugiat urna elementum non. Curabitur in dui vitae elit vulputate sagittis non at lorem. Vestibulum ante ipsum primis in faucibus orci luctus et ultrices posuere cubilia Curae; Nam ligula orci, rutrum in lorem eu, vehicula dictum diam. Duis semper at urna at mattis. Donec molestie auctor enim. Nullam sem est, egestas vel iaculis eleifend, ornare sed felis. Suspendisse potenti. Nunc a velit non tellus laoreet porta at id nibh. Proin vehicula bibendum lorem vel pretium.</p>

<p>Vivamus in lectus vel purus rhoncus ornare. Fusce pulvinar vehicula velit, vel hendrerit odio iaculis ut. Nunc malesuada est ac erat egestas mattis. Duis consequat ut mauris eget lobortis. In quam ipsum, ultrices at enim nec, hendrerit tincidunt magna. Cras nec neque ut neque facilisis consectetur. Nunc sit amet pulvinar justo, ac venenatis purus. Maecenas congue nisi sit amet nisi lacinia eleifend. Quisque convallis ex in mauris efficitur, in convallis risus rutrum.</p>

<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Orci varius natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus. Sed cursus ex rutrum est tempor, in facilisis massa pulvinar. Proin sit amet consequat dolor, non consequat purus. Aenean pellentesque viverra libero, bibendum dictum arcu facilisis convallis. Fusce molestie tempus neque vitae sodales. Aliquam suscipit convallis ultricies. Proin volutpat magna orci, condimentum dictum nisl cursus ut. Quisque at lectus eget sem semper molestie eget id libero.</p>

<p>Proin sed ante ornare, lacinia sem vestibulum, consectetur lacus. Phasellus eu semper nibh, at lacinia sapien. Nulla elementum viverra malesuada. Aliquam sodales vestibulum auctor. Vestibulum ante ipsum primis in faucibus orci luctus et ultrices posuere cubilia Curae; Praesent maximus mi tincidunt, ultricies nisl sit amet, fermentum est. Etiam sollicitudin suscipit mauris, vitae euismod sem mollis sit amet. Donec in mattis justo.</p>

<p>Mauris egestas lacinia lacinia. Cras in diam in nisl auctor suscipit. Fusce maximus quam nec ante commodo commodo. Maecenas condimentum arcu faucibus leo sollicitudin accumsan. Integer dictum tempor metus. In vitae porta nisl. Praesent ullamcorper faucibus mi, nec mattis libero auctor non. Duis volutpat leo non ornare aliquam. Curabitur non varius nisi. Aliquam blandit lorem dui, nec dictum ligula consequat ac. Quisque quis nunc dolor. In interdum purus nibh. Donec congue vulputate ornare.</p>
.table-wrapper {
	overflow-x: auto;
}

th {
	position: -webkit-sticky;
	position: sticky;
	top: 0;
}


/* Unrelated */

html {
	font: 110%/1.5 -apple-system, BlinkMacSystemFont, 'Segoe UI', Helvetica, Arial, sans-serif;
	background: black;
}

body {
	max-width: 35rem;
	margin: 0 auto;
	padding: 1rem;
	background: white;
}

p {
	margin: 1rem 0;
}

a {
	color: blue;
}
a:not(:hover, :active, :focus) {
	text-decoration-color: #00f7;
}

table {
	line-height: 1.3;
	background: white;
	border-collapse: collapse;
	outline: 1px solid white;
}

th, td {
	padding: 0.5em 1em;
	border: 1px solid black;
}

th {
	text-align: start;
	background: pink;
}

label {
	display: flex;
	align-items: center;
	padding: 0.5em 0.5em;
	border: 2px dashed blue;
	border-radius: 0.3em;
}
label:hover {
	background: hsl(240 100% 97%);
}

input {
	margin-right: 0.5rem;
}
'use strict';

const toggle = document.querySelector('.scroll-toggle');
const wrapper = document.querySelector('.table-wrapper');

toggle.addEventListener('change', (event) => {
	wrapper.classList.toggle('table-wrapper', event.target.checked);
});
Run Pen

External CSS

This Pen doesn't use any external CSS resources.

External JavaScript

This Pen doesn't use any external JavaScript resources.