main { display: flex; } main div { padding: 2%; } main #photos { display: grid; grid-template-columns: 1fr 1fr; grid-template-rows: 1fr 1fr; position: sticky; top: 0; /* ⚠ Keep this bigger than vertical displacement of lowest photo, otherwise Firefox glitches: it shows a scrollbar for
, yet refuses to scroll #photos; #bio scrolls into infinite emptiness… */ padding-top: 2em; padding-bottom: 2em; } #photos > * { position: relative; width: 6em; height: 100%; border-color: #ddd; border-width: 0.3em; border-style: solid; border-radius: 0.3em; box-sizing: border-box; overflow: hidden; } #photos img.portrait { position: absolute; width: 100%; height: 100%; object-fit: cover; object-position: center; filter: grayscale(1); transition: filter 1s, transform 1s; } #photos img.portrait:hover { filter: none; transform: scale(1.05); } #photos > *:nth-of-type(1) { top: -0.4em; } #photos > *:nth-of-type(2) { left: -1.6em; top: 1.2em; } #photos > *:nth-of-type(3) { left: 1.6em; top: -1.2em; } #photos > *:nth-of-type(4) { top: 0.4em; }