.lay-rowscroll {
	position: relative;
	width: 100%;
	max-width: 100%;
	height: var(--lay-rowscroll-block-height, var(--lay-rowscroll-height, 100vh));
	max-height: var(--lay-rowscroll-block-height, var(--lay-rowscroll-height, 100vh));
	min-height: 0;
	display: flex;
	flex-direction: column;
	box-sizing: border-box;
	overflow: hidden;
	overscroll-behavior: none;
}

.lay-rowscroll-track {
	cursor: grab;
}

.lay-rowscroll.lay-rowscroll-is-dragging .lay-rowscroll-track {
	cursor: grabbing;
}

.lay-rowscroll-filters {
	cursor: default;
}

/* Filter bar position: theme css_output (fixed, align with site title). */
.lay-rowscroll-filters.lay-thumbnailgrid-filter-wrap {
	flex-shrink: 0;
	background: var(--lay-steel-filter-bg, transparent);
	pointer-events: auto;
	opacity: 1 !important;
	visibility: visible !important;
	transform: none !important;
	filter: none !important;
}

.lay-rowscroll-filters.lay-thumbnailgrid-filter-wrap.below {
	opacity: 1 !important;
	visibility: visible !important;
	transform: none !important;
	filter: none !important;
}

.lay-rowscroll-filters .lay-thumbnailgrid-filter {
	pointer-events: auto;
	display: block;
	width: 100%;
	position: relative;
	z-index: 1;
}

.lay-rowscroll-filters .lay-thumbnailgrid-filter-anchor {
	display: inline-flex;
	align-items: center;
	cursor: pointer;
	color: #111111 !important;
	opacity: 1;
}

.lay-rowscroll-filters .lay-thumbnailgrid-filter-anchor:not(.lay-filter-active) .lay-filter-anchor-text {
	opacity: 0.55;
}

.lay-rowscroll-filters .lay-thumbnailgrid-filter-anchor.lay-filter-active .lay-filter-anchor-text {
	opacity: 1;
}

/* Legacy cached markup (plain buttons). */
.lay-rowscroll-filters .lay-rowscroll-filter {
	display: inline-block;
	background: transparent;
	border: none;
	border-bottom: 1px solid transparent;
	cursor: pointer;
	font: inherit;
	padding: 0;
	margin-right: 10px;
	color: #111111 !important;
	opacity: 0.55;
}

.lay-rowscroll-filters .lay-rowscroll-filter.is-active,
.lay-rowscroll-filters .lay-rowscroll-filter.lay-filter-active {
	border-bottom-color: currentColor;
	opacity: 1;
}

.lay-rowscroll-viewport {
	flex: 1 1 0;
	display: flex;
	flex-direction: column;
	min-height: 0;
	height: 0;
	min-width: 0;
	width: 100%;
	max-width: 100%;
	overflow: hidden;
}

/* Fixed category filters sit outside flex flow — reserve space before rows (see rowscroll.js). */
.lay-rowscroll.lay-rowscroll--fixed-filters .lay-rowscroll-viewport {
	box-sizing: border-box;
	padding-top: var(--lay-rowscroll-viewport-pad, var(--lay-rowscroll-viewport-pad-min, 0px));
}

.lay-rowscroll--booting .lay-rowscroll-viewport {
	visibility: hidden;
}

.lay-rowscroll--booting .lay-rowscroll-row {
	transition: none !important;
}

/* Visible rows resize instantly; only the filtered row animates closed/open. */
.lay-rowscroll--layout-lock .lay-rowscroll-row:not(.is-filtered-out) {
	transition: none !important;
}

.lay-rowscroll-row {
	flex: 1 1 0;
	min-height: 0;
	min-width: 0;
	width: 100%;
	max-width: 100%;
	display: flex;
	flex-direction: column;
	overflow: hidden;
	contain: layout style paint;
}

.lay-rowscroll-row.is-filtered-out {
	flex: 0 0 0 !important;
	max-height: 0 !important;
	min-height: 0 !important;
	pointer-events: none;
	overflow: hidden;
	margin: 0;
	padding: 0;
	transition:
		flex 0.4s cubic-bezier(0.4, 0, 0.2, 1),
		max-height 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

@media (prefers-reduced-motion: reduce) {
	.lay-rowscroll-row,
	.lay-rowscroll-row.is-filtered-out {
		transition: none;
	}
}

.lay-rowscroll-track {
	flex: 1 1 0;
	min-height: 0;
	min-width: 0;
	width: 100%;
	max-width: 100%;
	overflow-x: hidden;
	overflow-y: hidden;
	box-sizing: border-box;
	padding-left: 15vw;
	padding-right: 5vw;
	scrollbar-width: none;
	touch-action: none;
	-webkit-overflow-scrolling: touch;
	direction: ltr;
	contain: paint;
	isolation: isolate;
	position: relative;
}

.lay-rowscroll {
	touch-action: manipulation;
	-webkit-overflow-scrolling: touch;
}

@media (max-width: 782px) {
	.lay-rowscroll-track {
		padding-left: 0;
		padding-right: 0;
	}

	.lay-rowscroll.lay-rowscroll--fixed-filters .lay-rowscroll-viewport {
		padding-top: var(
			--lay-rowscroll-viewport-pad,
			var(--lay-rowscroll-viewport-pad-min, 0px)
		);
	}

	/* Full-bleed rowscroll on phone — cancel Lay grid side inset (steel no longer shows as side bars). */
	.lay-content.nocustomphonegrid #grid .col.type-rowscroll,
	.lay-content.nocustomphonegrid .lay-fixed-rows-layer-desktop .col.type-rowscroll,
	.lay-content.nocustomphonegrid .cover-region-desktop .col.type-rowscroll,
	.lay-content.footer-nocustomphonegrid #footer .col.type-rowscroll {
		width: 100vw !important;
		max-width: 100vw !important;
		margin-left: calc(50% - 50vw) !important;
		left: auto !important;
		right: auto !important;
	}
}

.lay-rowscroll-track::-webkit-scrollbar {
	display: none;
}

.lay-rowscroll-track-inner {
	display: inline-block;
	white-space: nowrap;
	height: 100%;
	vertical-align: bottom;
	font-size: 0;
	letter-spacing: 0;
	word-spacing: 0;
}

.lay-rowscroll-list {
	display: inline-block;
	vertical-align: bottom;
	height: 100%;
	margin: 0;
	padding: 0;
	list-style: none;
	white-space: nowrap;
}

.lay-rowscroll-list:not(.lay-rowscroll-list--clone) .lay-rowscroll-item {
	pointer-events: auto;
}

/* Clone lists must stay clickable — they are what users see while the primary list is off-screen. */
.lay-rowscroll-list.lay-rowscroll-list--clone {
	pointer-events: none;
}

.lay-rowscroll-list.lay-rowscroll-list--clone .lay-rowscroll-item {
	pointer-events: auto;
}

.lay-rowscroll-item,
.lay-rowscroll-item a,
.lay-rowscroll-item .thumb,
.lay-rowscroll-item img {
	cursor: pointer;
}

.lay-rowscroll.lay-rowscroll-is-dragging .lay-rowscroll-item,
.lay-rowscroll.lay-rowscroll-is-dragging .lay-rowscroll-item a,
.lay-rowscroll.lay-rowscroll-is-dragging .lay-rowscroll-item img {
	cursor: grabbing;
}

.lay-rowscroll-item {
	display: inline-block;
	vertical-align: bottom;
	height: 100%;
	margin: 0 var(--lay-rowscroll-thumb-gutter, 10px) 0 0;
	position: relative;
	box-sizing: border-box;
	font-size: 1rem;
	overflow: hidden;
	isolation: isolate;
}

.lay-rowscroll-item .thumbnail-wrap,
.lay-rowscroll-item .thumb-rel,
.lay-rowscroll-item .thumb,
.lay-rowscroll-item .lay-rowscroll-link {
	display: block;
	overflow: hidden;
	max-height: 100%;
}

/* Lay project titles (below/above/on-image) are replaced by the rowscroll pill caption. */
.lay-rowscroll-item .lay-textformat-parent.below-image,
.lay-rowscroll-item .lay-textformat-parent.above-image,
.lay-rowscroll-item .titlewrap-on-image {
	display: none !important;
}

.lay-rowscroll-item .thumbnail-wrap,
.lay-rowscroll-item .thumb-rel,
.lay-rowscroll-item .thumb {
	height: 100%;
	display: block;
}

.lay-rowscroll-item .ph {
	height: 100% !important;
	padding-bottom: 0 !important;
	position: relative;
}

.lay-rowscroll-item .ph img,
.lay-rowscroll-item img,
.lay-rowscroll-item .lay-rowscroll-img {
	height: 100% !important;
	width: auto !important;
	max-height: 100%;
	max-width: none;
	display: block;
	object-fit: contain;
	vertical-align: bottom;
}

/* Project title pill on hover — light gray background, black text, _Default typography. */
.lay-rowscroll-item .lay-rowscroll-caption {
	position: absolute;
	left: 8px;
	bottom: 8px;
	z-index: 20;
	margin: 0;
	max-width: calc(100% - 16px);
	pointer-events: none;
	opacity: 0;
	visibility: hidden;
	transition:
		opacity 0.15s ease,
		visibility 0.15s ease;
}

.lay-rowscroll-item:hover .lay-rowscroll-caption,
.lay-rowscroll-item:focus-within .lay-rowscroll-caption,
.lay-rowscroll-item.lay-rowscroll-item--show-title .lay-rowscroll-caption,
.lay-rowscroll-item:active .lay-rowscroll-caption {
	opacity: 1;
	visibility: visible;
}

.lay-rowscroll-item .lay-rowscroll-title {
	display: inline-block;
	box-sizing: border-box;
	max-width: 100%;
	padding: 6px 14px;
	border-radius: 999px;
	background-color: #e8e8e8 !important;
	color: #000 !important;
	font-size: 12px !important;
	font-weight: normal !important;
	line-height: 1.35;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	vertical-align: bottom;
	opacity: 1 !important;
	visibility: visible !important;
}

.lay-rowscroll-item .lay-rowscroll-title strong,
.lay-rowscroll-item .lay-rowscroll-title b {
	font-weight: normal !important;
}

.lay-rowscroll-item--empty span {
	display: inline-block;
	padding: 20px;
	opacity: 0.5;
}

/* Clip horizontal strips to the grid column width. */
.col.type-rowscroll {
	overflow: hidden;
	max-width: 100%;
}

.col.type-rowscroll .lay-rowscroll {
	overflow: hidden;
}

/* Prevent the wide strip from widening the page. */
#grid:has(.lay-rowscroll),
.col.type-rowscroll {
	max-width: 100%;
}

body:has(.lay-rowscroll) {
	overflow-x: hidden;
}

/* Fallback project modal (when Lay project overlays are off). */
.lay-rowscroll-project-modal {
	position: fixed;
	inset: 0;
	z-index: 1000000;
}

.lay-rowscroll-project-modal[hidden] {
	display: none !important;
}

.lay-rowscroll-project-modal__backdrop {
	position: absolute;
	inset: 0;
	background-color: var(--lay-steel-project-bg, #d2d6da);
	background-image: var(--lay-steel-project-gradient, none);
	background-size: cover;
	background-repeat: no-repeat;
	opacity: 1;
	transition: opacity 0.48s cubic-bezier(0.4, 0, 0.2, 1);
}

.lay-rowscroll-project-modal__panel {
	position: absolute;
	inset: 0;
	z-index: 1;
	width: 100%;
	max-width: 100vw;
	overflow: hidden;
}

.lay-rowscroll-project-modal--closing .lay-rowscroll-project-modal__backdrop {
	opacity: 0;
}

.lay-rowscroll-project-modal--closing .lay-rowscroll-project-modal__scroll {
	transform: translateY(36px);
	opacity: 0;
	transition:
		transform 0.48s cubic-bezier(0.4, 0, 0.2, 1),
		opacity 0.48s cubic-bezier(0.4, 0, 0.2, 1);
}

@media (prefers-reduced-motion: reduce) {
	.lay-rowscroll-project-modal__backdrop,
	.lay-rowscroll-project-modal__scroll {
		transition-duration: 0.01ms;
	}

	.lay-rowscroll-project-modal--closing .lay-rowscroll-project-modal__scroll {
		transform: none;
	}
}

.lay-rowscroll-project-modal:not([hidden]) .lay-rowscroll-project-modal__toolbar {
	--lay-rowscroll-toolbar-h: 56px;
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 1000002;
	transform: none !important;
	will-change: auto;
	min-height: calc(var(--lay-rowscroll-toolbar-h) + env(safe-area-inset-top, 0px));
	padding-top: env(safe-area-inset-top, 0px);
	padding-bottom: 10px;
	box-sizing: border-box;
	pointer-events: none;
	isolation: isolate;
	background: linear-gradient(
		180deg,
		rgba(255, 255, 255, 0.45) 0%,
		rgba(236, 240, 244, 0.22) 45%,
		rgba(236, 240, 244, 0) 100%
	);
	-webkit-backdrop-filter: blur(22px) saturate(165%);
	backdrop-filter: blur(22px) saturate(165%);
	border-bottom: none;
	box-shadow: none;
}

@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))) {
	.lay-rowscroll-project-modal__toolbar {
		background: rgba(232, 236, 240, 0.94);
	}
}

.lay-rowscroll-project-modal__close {
	position: absolute;
	top: max(14px, env(safe-area-inset-top, 0px));
	right: max(18px, env(safe-area-inset-right, 0px));
	left: auto !important;
	bottom: auto !important;
	pointer-events: auto;
	box-sizing: content-box;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	margin: 0 !important;
	padding: 0 !important;
	border: 0 !important;
	background: transparent !important;
	color: #111111 !important;
	font: inherit;
	line-height: 1;
	cursor: pointer;
	border-radius: 0 !important;
	box-shadow: none !important;
	-webkit-appearance: none;
	appearance: none;
}

.lay-rowscroll-project-modal__close-icon {
	position: relative;
	display: block;
	width: 22px;
	height: 22px;
}

.lay-rowscroll-project-modal__close-line {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 22px;
	height: 2px;
	margin-top: -1px;
	margin-left: -11px;
	background: currentColor;
	border-radius: 1px;
	transform: rotate(0deg);
	transition: transform 0.28s cubic-bezier(0.4, 0, 0.2, 1);
}

.lay-rowscroll-project-modal__close:hover .lay-rowscroll-project-modal__close-line:nth-child(1),
.lay-rowscroll-project-modal__close:focus-visible .lay-rowscroll-project-modal__close-line:nth-child(1) {
	transform: rotate(45deg);
}

.lay-rowscroll-project-modal__close:hover .lay-rowscroll-project-modal__close-line:nth-child(2),
.lay-rowscroll-project-modal__close:focus-visible .lay-rowscroll-project-modal__close-line:nth-child(2) {
	transform: rotate(-45deg);
}

@media (prefers-reduced-motion: reduce) {
	.lay-rowscroll-project-modal__close-line {
		transition: none;
	}

	.lay-rowscroll-project-modal__close:hover .lay-rowscroll-project-modal__close-line:nth-child(1),
	.lay-rowscroll-project-modal__close:focus-visible .lay-rowscroll-project-modal__close-line:nth-child(1) {
		transform: rotate(45deg);
	}

	.lay-rowscroll-project-modal__close:hover .lay-rowscroll-project-modal__close-line:nth-child(2),
	.lay-rowscroll-project-modal__close:focus-visible .lay-rowscroll-project-modal__close-line:nth-child(2) {
		transform: rotate(-45deg);
	}
}

.lay-rowscroll-project-modal__scroll {
	position: absolute;
	inset: 0;
	z-index: 1;
	min-width: 0;
	width: 100%;
	overflow-x: hidden;
	overflow-y: auto;
	overscroll-behavior-y: contain;
	-webkit-overflow-scrolling: touch;
	padding-top: calc(56px + env(safe-area-inset-top, 0px));
	box-sizing: border-box;
	background-color: var(--lay-steel-project-bg, #d2d6da);
	background-image: var(--lay-steel-project-gradient, none);
	background-size: cover;
	background-repeat: no-repeat;
	transform: translateY(calc(var(--lay-rowscroll-close-progress, 0) * 28px));
	opacity: calc(1 - var(--lay-rowscroll-close-progress, 0) * 0.12);
	transition:
		transform 0.2s cubic-bezier(0.4, 0, 0.2, 1),
		opacity 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

.lay-rowscroll-project-modal__loading {
	display: none !important;
	visibility: hidden !important;
	height: 0 !important;
	margin: 0 !important;
	padding: 0 !important;
	overflow: hidden !important;
	opacity: 0 !important;
}

.lay-rowscroll-project-modal__error {
	padding: 72px 24px 24px;
	opacity: 0.7;
}

/* Never show transient "Loading" copy while Lay overlay or rowscroll modal fetches a project. */
#lay-project-overlay.po-content-loading .lay-rowscroll-project-modal__loading,
#lay-project-overlay .lay-rowscroll-project-modal__loading {
	display: none !important;
	visibility: hidden !important;
	height: 0 !important;
	margin: 0 !important;
	padding: 0 !important;
	overflow: hidden !important;
	opacity: 0 !important;
}

/* Lay lazyload + scroll-animation styles assume in-page viewport; reset inside modal/overlay. */
.lay-rowscroll-project-modal__scroll .col img.lazyload,
.lay-rowscroll-project-modal__scroll .col img.lazyloading,
.lay-rowscroll-project-modal__scroll .col img.lazyloaded,
.lay-rowscroll-project-modal__scroll .col img.loaded,
.lay-rowscroll-project-modal__scroll .col img[data-src],
.lay-rowscroll-project-modal__scroll .col img.setsizes,
#lay-project-overlay .col img.lazyload,
#lay-project-overlay .col img.lazyloading,
#lay-project-overlay .col img.lazyloaded,
#lay-project-overlay .col img.loaded,
#lay-project-overlay .col img[data-src],
#lay-project-overlay .col img.setsizes {
	opacity: 1 !important;
}

.lay-rowscroll-project-modal__scroll .col img {
	height: auto !important;
	width: auto !important;
	max-width: 100%;
}

.lay-rowscroll-project-modal__scroll [data-lay-scroll-anim],
.lay-rowscroll-project-modal__scroll .col {
	opacity: 1 !important;
	transform: none !important;
	filter: none !important;
}

.lay-rowscroll-project-modal__scroll .lay-content,
.lay-rowscroll-project-modal__scroll .grid,
.lay-rowscroll-project-modal__scroll .grid-inner {
	max-width: 100%;
}

html.lay-rowscroll-modal-open,
html.lay-rowscroll-modal-open body {
	overflow: hidden;
}

/* Pull-to-close progress when Lay project overlay is open (touch / wheel at scroll end). */
html.show-project-overlay #lay-project-overlay > .lay-content {
	transform: translateY(calc(var(--lay-rowscroll-close-progress, 0) * 28px));
	opacity: calc(1 - var(--lay-rowscroll-close-progress, 0) * 0.12);
	transition:
		transform 0.2s cubic-bezier(0.4, 0, 0.2, 1),
		opacity 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Site title above overlay: see stainless-steel.css (desktop .sitetitle + phone .mobile-title). */
