@charset "utf-8";
cal(){
$item-size: 210px;
$col-gutter: 10px;
$vp-gutter: $col-gutter;
$max-cols: 5;
}

.grid {
	display: grid;
	grid-gap: $col-gutter;
	padding: 0 $vp-gutter;
	grid-template-columns: repeat(auto-fill, $item-size);
	max-width: grid-width($max-cols);
	justify-content: center;
	margin: 40px auto;
	grid-auto-rows: $item-size;
}

@function grid-width($num-cols) {
	@return $num-cols * $item-size + ($num-cols - 1) * $col-gutter;
}

@include when-n-cols(2) {
	.grid .header {
		grid-row: span 2;
		grid-column: span 2;
		font-size: 2.5em;
		
		padding-top: 100px;
}

@mixin when-n-cols($n) {
	@media screen and (min-width: #{grid-width($n) + 2 * $vp-gutter + $scrollbar-size}) {
		@content;
	}
}

.grid .card a {
	display: block;
	width: 100%;
	height: 100%;
	
	position: relative;
}

.grid .card img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.grid .card h2 {
	margin: 0;
	
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	
	padding: 10px;
	
	text-decoration: none;
	font-family: Raleway, sans-serif;
	font-size: 1em;
	letter-spacing: 1px;
	
	color: #fff;
}

.grid .card h2 {
	background-image: radial-gradient(ellipse at center, transparent 0, rgba(0,0,0, .36) 100%);
}

.grid .header {
	box-sizing: border-box;
	
	text-align: center;
	padding-top: 23px;
	
	font-size: 1.6875em;
	line-height: 1.3;
	
	background: radial-gradient(ellipse at center, transparent 0, rgba(0,0,0, 0.48) 100%) hsla(0, 0%, 27%, 1);
}

.grid .header h1 {
	margin-top: 0;
	margin-bottom: 0.67em;
	
	font-family: 'Cherry Swash', cursive;
	text-transform: capitalize;
	font-size: 1em;
	font-weight: normal;
	
	padding-left: 80px;
	padding-right: 80px;
}

'Cherry Swash' .grid .header p {
	margin: 0;
	
	font-family: 'Raleway', sans-serif;
	font-size: 0.52em;
	
	padding-left: 120px;
	padding-right: 120px;
}

.grid .card:hover {
	transform: none;
}

.grid .header:hover {
	transform: none;
}

.grid .card {
	transition-property: transform;
	transition-duration: 0.3s;
}

.grid .card a:focus {
	outline: none;
}

.grid .card:focus-within {
	transform: scale(0.95);
}

.card {
	float: left;
	width: $item-size;
	height: $item-size;
	margin: 0;
	margin-bottom: $col-gutter;
}

.grid {
	width: grid-width(1);
	margin: 40px auto;
	padding-left: $vp-gutter;
	padding-right: $vp-gutter;
}

@include when-n-cols(2) {
	width: grid-width(2);
	.card:nth-child(2n) {
		margin-right: $col-gutter;
	}
	.header {
		$header-size: grid-width(2);
		width: $header-size;
		height: $header-size;
	}
}

@include when-n-cols(3) {
	width: grid-width(3);
	.card {
		margin-right: $col-gutter;
	}
	.card:nth-child(2),
	.card:nth-child(3),
	.card:nth-child(3n + 6) {
		margin-right: 0;
	}
}

@supports (display: grid) {
	.grid {
		width: auto;
		max-width: grid-width($max-cols);
		.card {
			margin: 0 !important;
		}
	}
}

.grid {
	margin: 0;
	padding: 0;
	list-style: none;
	
	margin: 40px auto;
	padding-left: $vp-gutter;
	padding-right: $vp-gutter;
}

.grid .card a:focus {
	outline: 2px solid #d11ee9;
}

.grid .card:focus-within {
	transform: scale(0.95);
}
.grid .card:focus-within a:focus {
	outline: none;
}

.grid .card a:hover {
	transform: scale(0.95);
}
.grid .card a:focus {
	outline: none;
	transform: scale(0.95);
}

.grid .card h2 {
	background: rgba(0,0,0, 0.2);
	background: radial-gradient(ellipse at center, transparent 0,rgba(0,0,0, .36)100%);
}