.blog-archive {
	background-color: var(--color-bg-black);
	color: var(--color-text-white);
	padding: 50px 40px 90px;
}

.blog-archive__inner {
	max-width: 1350px;
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	gap: 50px;
}

.blog-archive__heading {
	display: flex;
	flex-direction: column;
	gap: 0;
	width: fit-content;
}

.blog-archive__eyebrow {
	margin: 0;
	font-size: 24px;
	font-weight: 400;
	color: var(--color-main);
}

.blog-archive__title {
	margin: 0;
	font-size: 32px;
	font-weight: 600;
	color: var(--color-text-white);
}

.blog-archive__divider {
	margin-top: 5px;
	height: 2px;
	width: calc(100% + 30px);
	background-color: var(--color-main);
}

.blog-archive__filter {
	background-color: var(--color-panel-bg-gray);
	display: flex;
	align-items: center;
	gap: 30px;
	padding: 20px 40px 20px 20px;
	flex-wrap: wrap;
}

.blog-archive__filter-label {
	font-size: 16px;
	font-weight: 400;
	color: var(--color-text-white);
}

.blog-archive__filter-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
	align-items: center;
}

.category-tag {
	border-radius: 999px;
	padding: 0px 12px;
	min-height: 29px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 15px;
	font-weight: 350;
	line-height: 1;
	color: var(--color-text-white);
	border: none;
}

.category-tag--taikai {
	background-color: #ff5f57;
}

.category-tag--event {
	background-color: #f9ae0e;
}

.category-tag--sponsor {
	background-color: #00c0e8;
}

.category-tag--other {
	background-color: #34c759;
}

.category-tag--office,
.category-tag--tech {
	background-color: #9747ff;
}

.blog-archive__filter-tag {
	appearance: none;
	cursor: pointer;
	transition: box-shadow 0.2s ease, transform 0.2s ease;
}

.blog-archive__filter-tag:hover,
.blog-archive__filter-tag:focus-visible {
	box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.8);
}

.blog-archive__filter-tag.is-active {
	box-shadow: 0 0 0 2px rgba(255, 255, 255, 1);
}

.blog-archive__filter-reset {
	margin-left: auto;
	background: none;
	border: none;
	color: var(--color-text-gray);
	font-size: 14px;
	cursor: pointer;
	padding: 4px 0;
}

.blog-archive__filter-reset.is-active {
	color: var(--color-main);
}

.blog-archive__filter-reset:hover,
.blog-archive__filter-reset:focus-visible {
	text-decoration: underline;
}

.blog-archive__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, 285px);
	column-gap: 60px;
	row-gap: 60px;
	align-items: start;
	justify-content: start;
	justify-items: start;
}

.blog-card {
	display: flex;
	flex-direction: column;
	width: 285px;
	max-width: 100%;
}

.blog-card__link {
	text-decoration: none;
	color: inherit;
	display: flex;
	flex-direction: column;
	gap: 15px;
}

.blog-card__image {
	width: 100%;
	height: 180px;
	background-color: #111111;
	overflow: hidden;
}

.blog-card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.blog-card__image-placeholder {
	width: 100%;
	height: 100%;
	background-color: var(--color-panel-bg-gray);
}

.blog-card__meta {
	display: flex;
	align-items: center;
	gap: 12px;
}

.blog-card__category {
	font-size: 13px;
	padding: 0px 10px;
}

.blog-card__date {
	font-size: 15px;
	font-weight: 300;
	color: var(--color-text-gray);
}

.blog-card__title {
	margin: 0;
	font-size: 18px;
	font-weight: 400;
	line-height: 1.5;
	color: var(--color-text-gray);
}

.blog-card__link:hover .blog-card__title,
.blog-card__link:focus-visible .blog-card__title {
	color: var(--color-main);
}

.blog-archive__empty {
	margin: 0;
	font-size: 15px;
	color: var(--color-text-gray);
	text-align: center;
}

.blog-pagination {
	display: flex;
	justify-content: center;
	margin-top: 10px;
}

.blog-pagination__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	gap: 10px;
	align-items: center;
}

.blog-pagination__item a,
.blog-pagination__item span {
	width: 32px;
	height: 32px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1px solid var(--color-main);
	color: var(--color-main);
	text-decoration: none;
	font-size: 14px;
	box-sizing: border-box;
}

.blog-pagination__item.is-current span {
	background-color: var(--color-main);
	color: var(--color-text-black);
}

.blog-pagination__item.is-dots span {
	border: none;
	width: auto;
}

.blog-pagination__item a:hover,
.blog-pagination__item a:focus-visible {
	background-color: var(--color-main);
	color: var(--color-text-black);
}

@media (max-width: 1024px) {
	.blog-archive {
		padding: 40px 24px 70px;
	}

	.blog-archive__inner {
		gap: 40px;
	}

	.blog-archive__filter {
		padding: 18px 24px;
	}

	.blog-archive__filter-reset {
		margin-left: 0;
	}

	.blog-archive__grid {
		column-gap: 40px;
		row-gap: 60px;
	}
}

@media (max-width: 640px) {
	.blog-archive {
		padding: 40px 16px 60px;
	}

	.blog-archive__title {
		font-size: 28px;
	}

	.blog-archive__filter {
		gap: 16px;
	}

	.blog-archive__filter-tags {
		gap: 12px;
	}

	.blog-archive__grid {
		grid-template-columns: 1fr;
		row-gap: 60px;
	}
}