
/* ARTICLES */
.category-description {
	margin: 0 auto 30px;
	width: 80%;
	border-radius: 20px;
}

.category-description p {
	margin-bottom: 0;
	display: none;
	text-align: center;
	font-weight: 300;
	font-size: 18px;
	line-height: 1.1;
}

.category-description.active {
	padding: 20px 0;
	background: #f4f4f4;
}

.category-description.active p {
	display: block;
}

.articles-container {
	display: flex;
	flex-wrap: wrap;
}

.single-article {
	margin-bottom: 25px;
	margin-right: 3.5%;
	width: 31%;
	box-sizing: border-box;
	display: flex;
	flex-direction: column;
	border-radius: 12px;
	box-shadow: 0 15px 25px rgba(0, 0, 0, .4);
	transition: all .2s linear;
}

.single-article:nth-child(3n) {
	margin-right: 0;
}

.single-article:hover {
	text-decoration: none;
	box-shadow: 0 18px 35px rgba(0, 0, 0, .6);
}

.single-article-image, .image-placeholder {
	border-radius: 12px 12px 0 0;
}

.single-article-image {
	padding-bottom: 100%;
	width: 100%;
	background-position: center;
	background-size: cover;
	background-repeat: no-repeat;
	border-radius: 12px 12px 0 0;
}

/* single article text part */
.single-article-text {
	padding: 30px 20px 10px;
	height: 100%;
	display: flex;
	flex-direction: column;
	color: grey;
}

.article-category {
	margin-bottom: 10px;
	font-size: 16px;
	font-weight: 300;
	text-transform: uppercase;
}

.article-title {
	margin-bottom: 5px;
	font-size: 16px;
	font-weight: bold;
}

.article-date {
	margin-top: auto;
	margin-bottom: 15px;
	display: inline-block;
}

.article-date, .article-reading-duration {
	font-size: 16px;
	font-weight: 300;
}

.article-reading-duration {
	text-align: right;
}

@media screen and (max-width: 959px) {
	.single-article-text {
		padding: 20px 15px 10px;
	}
	
	.article-category, .article-title, .article-date, .article-reading-duration {
		font-size: 15px;
	}
	
	.category-description {
		display: none;
	}
}

@media screen and (max-width: 768px) {
	.single-article {
		width: 48%;
		margin-right: 4%;
	}
	
	.single-article:nth-child(3n) {
		margin-right: 4%;
	}
	
	.single-article:nth-child(2n) {
		margin-right: 0;
	}
	
	.single-article-text {
		padding: 20px 15px 10px;
	}
}

@media screen and (max-width: 500px) {
	.single-article {
		margin: 0 auto 20px;
		width: 95%;
		max-width: 350px;
	}
	
	.single-article:nth-child(3n), .single-article:nth-child(2n) {
		margin-right: auto;
	}
	
	.single-article-text {
		padding: 15px 15px 10px;
	}
	
	.article-category, .article-title, .article-date, .article-reading-duration {
		font-size: 14px;
	}
}
