.category {
    position: relative;
}

.category:not([style="display: none;"]) + .category {
    margin-top: 3em;
    padding-top: 3em;
}

.category:not([style="display: none;"]) + .category:before {
    background: var(--gradient-2);
    content: "";
    display: block;
    height: 0.25em;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
}

.video-list {
    display: grid;
    gap: 1.6875em 1em;
    grid-template-columns: repeat(auto-fill, minmax(18.75em, 1fr));
}

.video-list article {
    width: 100%;
}

.video-list button {
    background: none;
    border-radius: 0;
    display: grid;
    gap: 0.75em;
    padding: 0;
	text-align: left;
    width: 100%;
}

.video-list .thumbnail {
    cursor: pointer;
    position: relative;
    transition: var(--transition);
    width: 100%;
}

.video-list .thumbnail:before {
    background: url(/images/play-icon-red.svg) no-repeat 50% calc(50% + 0.25em) / 4.5em auto;
    content: "";
    display: block;
    inset: 0;
    position: absolute;
    transition: var(--transition);
}

.video-list button img {
    aspect-ratio: 16/9;
    display: block;
    height: auto;
	object-fit: cover;
	object-position: center;
    width: 100%;
}

.video-list :is(h2, h3) {
    color:#000;
    font-family: var(--roboto-condensed);
    font-size: var(--text-6);
	line-height: 1em;
	margin: 0;
	transition: var(--transition);
}


/* Filters */
.page-videos .video-filters{
	background: #FFFFFF;
	box-shadow: 0 0 0 2px #EBF2F7;
	padding: 1em;
}


.page-videos .video-filters fieldset + fieldset {
	margin-top: 1.3125em;
}

.page-videos .video-filters legend {
	font-size: var(--text-7);
	color:#000;
	font-family: var(--roboto-condensed);
	font-weight:700;
}

.page-videos .video-filters .checkboxes {
	display: grid;
	gap: 0.5em;
	margin-top: 0.25em;
	width: 100%;
}

.page-videos .video-filters .checkboxes > div {
    align-items: flex-start;
    display: flex;
    gap: 0.25em;
	font-size: 0.875em;
	line-height: 1.25em;
}

.page-videos .video-filters .checkboxes > div:has(:checked) {
    color:#000;
}

.page-videos .video-filters .checkboxes label {
	cursor: pointer;
    padding: 0.125em 0 0;
}




/* DESKTOP ONLY */
/* 750px */
@media (min-width: 46.875em) {   
	 
    .page-videos .interior-header {
        z-index: 1;
    }
	
	.page-videos .main-content {
		position: relative;
		overflow: visible;
	}

	.page-videos .main-content .wrap {
		max-width: 100vw;
		overflow: visible;
	}

	.page-videos .main-content .wrap > .content {
		display: grid;
		grid-template-columns: repeat(12, 1fr);
		gap: 3vw;
		float: none;
		align-items: start;
		overflow: visible;
		padding: 0;
		position: static;
		width: 100%;
	}

	.page-videos .video-filters {
        border-radius: 0 10px 10px 0;
        grid-column: 1 / span 2;
        margin-left: -1em;
        margin-top: -8.9375em;
        min-width: 14.375em;
        position: sticky;
        top: 6.25em;
        z-index: 1;
    }

	.page-videos .video-filters .checkboxes div:has(:focus-within),
	.page-videos .video-filters .checkboxes label:is(:hover, :focus-visible) {
		color:#000
	}


	.page-videos .categories {
		grid-column: 3 / span 9;
	}
	
	.video-list button:is(:hover, :focus-visible) .thumbnail {
		box-shadow: 0 0 0 3px var(--bright-green);
	}


	.video-list button:is(:hover, :focus-visible) .thumbnail:before {
		background-color: rgba(0,0,0,0.125);
	}


	.video-list button:is(:hover, :focus-visible) :is(h2, h3) {
		color:var(--violet)
	}

}

@media (min-width: 46.875em) and (max-width: 75em) {   
	 
	.page-videos .video-filters {
        margin-top: 0;
    }

}



/* MOBILE ONLY */
/* 750px */
@media (max-width: 46.875em) {
  	
	.categories {
		margin-top: 3em;
		padding-top: 3em;	
		position: relative;	
	}
  	
	.categories:before {
		background: var(--gradient-2);
		content: "";
		display: block;
		height: 0.25em;
		left: 0;
		position: absolute;
		top: 0;
		width: 100%;	
	}

	.page-videos .show-filters {
		text-align: center;
		margin: 0 0 1em;
	}
	
  	.page-videos .video-filters {
		border-radius: 10px;
		display: none;
	}

  	.page-videos .video-filters.active {
		display: block;
	}
}
