/* ==============================================
   Blog Page Styles
   Beautiful blog layout with category filters,
   responsive grid, and modern card design.
   ============================================== */

/* --- Hero Breadcrumb --- */
.blog-breadcrumb {
	margin-top: 2rem;
	font-size: 1.4rem;
	color: rgba(255, 255, 255, 0.7);
}
.blog-breadcrumb a {
	color: rgba(255, 255, 255, 0.85);
	transition: color 0.3s ease;
}
.blog-breadcrumb a:hover {
	color: var(--primary-color);
}
.blog-breadcrumb .sep {
	margin: 0 0.8rem;
	font-size: 1rem;
	opacity: 0.5;
}
.blog-breadcrumb .current {
	color: var(--white-color);
	font-weight: 600;
}

/* --- Category Filter Tabs --- */
.blog-category-filter {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	margin-bottom: 4rem;
	padding-bottom: 2rem;
	border-bottom: 1px solid #e8e8e8;
	justify-content: center;
}
.cat-tab {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.8rem 2rem;
	font-size: 1.4rem;
	font-weight: 600;
	color: var(--base-color);
	background: var(--gray-color);
	border-radius: 5rem;
	transition: var(--smooth-transition);
	white-space: nowrap;
}
.cat-tab:hover {
	color: var(--white-color);
	background: var(--secondary-color);
}
.cat-tab.active {
	color: var(--white-color);
	background: var(--primary-color);
}
.cat-count {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.2rem;
	height: 2.2rem;
	font-size: 1.1rem;
	font-weight: 700;
	background: rgba(255, 255, 255, 0.25);
	border-radius: 50%;
	line-height: 1;
}

/* --- Blog Grid — 4 columns --- */
.blog-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 3rem;
}

/* --- Blog Card --- */
.blog-card {
	background: var(--white-color);
	border-radius: 1.2rem;
	overflow: hidden;
	box-shadow: 0 0.4rem 2rem rgba(0, 0, 0, 0.06);
	transition: var(--smooth-transition);
	display: flex;
	flex-direction: column;
}
.blog-card:hover {
	box-shadow: 0 1.5rem 4rem rgba(0, 0, 0, 0.12);
	transform: translateY(-6px);
}

/* --- Card Thumbnail --- */
.blog-card-thumb {
	position: relative;
	overflow: hidden;
	aspect-ratio: 16 / 11;
}
.blog-card-thumb a {
	display: block;
	width: 100%;
	height: 100%;
}
.blog-card-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.blog-card:hover .blog-card-thumb img {
	transform: scale(1.08);
}
.blog-card-placeholder {
	width: 100%;
	height: 100%;
	background: linear-gradient(135deg, #1a0a2e 0%, #2d1b4e 50%, #0e1422 100%);
	display: flex;
	align-items: center;
	justify-content: center;
}
.blog-card-placeholder i {
	font-size: 4rem;
	color: rgba(255, 255, 255, 0.15);
}
.blog-card:nth-child(3n+2) .blog-card-placeholder {
	background: linear-gradient(135deg, #2a1a0a 0%, #4a2a0a 50%, #2a1a0a 100%);
}
.blog-card:nth-child(3n) .blog-card-placeholder {
	background: linear-gradient(135deg, #0a2a1a 0%, #0a4a2a 50%, #0a2a1a 100%);
}

/* --- Card Body --- */
.blog-card-body {
	padding: 2rem 2rem 2.5rem;
	display: flex;
	flex-direction: column;
	flex: 1;
}
.blog-card-title {
	font-size: 1.7rem;
	font-weight: 700;
	line-height: 1.4;
	margin-bottom: 1rem;
	color: var(--secondary-color);
	/* Clamp to 2 lines */
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.blog-card-title a {
	color: inherit;
	transition: color 0.3s ease;
}
.blog-card-title a:hover {
	color: var(--primary-color);
}

/* --- Card Meta — single line --- */
.blog-card-meta {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 0.6rem;
	font-size: 1.2rem;
	color: var(--base-color);
	margin-bottom: 1rem;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.blog-card-meta i {
	color: var(--primary-color);
	font-size: 1.1rem;
	margin-right: 0.2rem;
}
.blog-card-meta .meta-sep {
	color: #ddd;
	font-size: 1rem;
}
.blog-card-cat {
	color: var(--primary-color);
	font-weight: 600;
}

/* --- Card Excerpt --- */
.blog-card-excerpt {
	font-size: 1.4rem;
	line-height: 1.6;
	color: var(--base-color);
	margin-bottom: 1.2rem;
	/* Clamp to 2 lines */
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	flex: 1;
}
.blog-card-readmore {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 1.4rem;
	font-weight: 600;
	color: var(--primary-color);
	text-decoration: none;
	transition: gap 0.3s ease;
}
.blog-card-readmore:hover {
	gap: 0.8rem;
	color: var(--secondary-color);
}

/* --- Pagination --- */
.blog-pagination {
	margin-top: 5rem;
	display: flex;
	justify-content: center;
}
.blog-pagination .page-numbers {
	list-style: none;
	display: flex;
	align-items: center;
	gap: 0.8rem;
	flex-wrap: wrap;
	justify-content: center;
}
.blog-pagination .page-numbers li {
	list-style: none;
}
.blog-pagination .page-numbers a,
.blog-pagination .page-numbers span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 4.4rem;
	height: 4.4rem;
	padding: 0 1.2rem;
	font-size: 1.5rem;
	font-weight: 600;
	color: var(--secondary-color);
	background: var(--white-color);
	border: 1px solid #e0e0e0;
	border-radius: 0.8rem;
	transition: var(--smooth-transition);
}
.blog-pagination .page-numbers a:hover {
	color: var(--white-color);
	background: var(--secondary-color);
	border-color: var(--secondary-color);
}
.blog-pagination .page-numbers .current {
	color: var(--white-color);
	background: var(--primary-color);
	border-color: var(--primary-color);
}
.blog-pagination .page-numbers .prev,
.blog-pagination .page-numbers .next {
	font-size: 1.4rem;
	gap: 0.5rem;
}
.blog-pagination .page-numbers .dots {
	border: none;
	background: none;
	color: var(--base-color);
	min-width: auto;
	padding: 0 0.5rem;
}

/* --- No Posts Found --- */
.blog-no-posts {
	text-align: center;
	padding: 8rem 2rem;
}
.blog-no-posts-icon {
	width: 10rem;
	height: 10rem;
	margin: 0 auto 3rem;
	background: var(--gray-color);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
}
.blog-no-posts-icon i {
	font-size: 4rem;
	color: var(--primary-color);
}
.blog-no-posts h2 {
	font-size: 2.8rem;
	margin-bottom: 1.5rem;
}
.blog-no-posts p {
	font-size: 1.6rem;
	color: var(--base-color);
	max-width: 50rem;
	margin: 0 auto;
}

/* ==============================================
   Responsive — Blog Page
   ============================================== */

/* Tablet */
@media (max-width: 61.95em) {
	.blog-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 2.5rem;
	}
	.blog-category-filter {
		gap: 0.8rem;
		margin-bottom: 3rem;
	}
	.cat-tab {
		padding: 0.6rem 1.5rem;
		font-size: 1.3rem;
	}
}

/* Mobile */
@media (max-width: 35.95em) {
	.blog-grid {
		grid-template-columns: 1fr;
		gap: 2rem;
	}
	.blog-card {
		border-radius: 0.8rem;
	}
	.blog-card-body {
		padding: 1.5rem 1.5rem 2rem;
	}
	.blog-card-title {
		font-size: 1.6rem;
	}
	.blog-card-meta {
		font-size: 1.1rem;
	}
	.blog-category-filter {
		gap: 0.6rem;
		margin-bottom: 2.5rem;
		padding-bottom: 1.5rem;
	}
	.cat-tab {
		padding: 0.5rem 1.2rem;
		font-size: 1.2rem;
	}
	.blog-pagination .page-numbers a,
	.blog-pagination .page-numbers span {
		min-width: 3.8rem;
		height: 3.8rem;
		font-size: 1.3rem;
	}
	.blog-breadcrumb {
		font-size: 1.2rem;
	}
}

/* Small mobile */
@media (max-width: 25em) {
	.blog-card-excerpt {
		-webkit-line-clamp: 1;
	}
	.blog-card-meta .meta-sep:last-of-type,
	.blog-card-meta .blog-card-cat {
		display: none;
	}
}

/* ==============================================
   Global Breadcrumb Styles (used across pages)
   ============================================== */
.breadcrumb-nav {
	padding: 1.5rem 0;
	font-size: 1.3rem;
	color: var(--base-color);
}
.breadcrumb-nav .container {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 0;
}
.breadcrumb-nav a {
	color: var(--primary-color);
	transition: color 0.3s ease;
}
.breadcrumb-nav a:hover {
	color: var(--secondary-color);
}
.breadcrumb-nav .sep {
	margin: 0 0.8rem;
	color: #ccc;
	font-size: 1rem;
}
.breadcrumb-nav .current {
	color: var(--secondary-color);
	font-weight: 600;
}

/* Single post breadcrumb (inside page-title-section) */
.page-title-section .breadcrumb {
	margin-top: 1.5rem;
	font-size: 1.4rem;
	color: rgba(255, 255, 255, 0.7);
}
.page-title-section .archive-desc {
	font-size: 1.6rem;
	color: rgba(255, 255, 255, 0.75);
	margin-top: 1rem;
	margin-bottom: 0;
}
.page-title-section .breadcrumb a {
	color: rgba(255, 255, 255, 0.85);
	transition: color 0.3s ease;
}
.page-title-section .breadcrumb a:hover {
	color: var(--primary-color);
}
.page-title-section .breadcrumb .sep {
	margin: 0 0.8rem;
	opacity: 0.5;
}
.page-title-section .breadcrumb .current {
	color: var(--white-color);
	font-weight: 600;
}

/* === Single Post Enhancements === */
.post-featured-image {
	margin-bottom: 3rem;
	border-radius: 1.2rem;
	overflow: hidden;
}
.post-featured-image img {
	width: 100%;
	height: auto;
	display: block;
}
.post-meta-single {
	display: flex;
	flex-wrap: wrap;
	gap: 2rem;
	font-size: 1.4rem;
	color: var(--base-color);
	padding-bottom: 2rem;
	margin-bottom: 3rem;
	border-bottom: 1px solid #e8e8e8;
}
.post-meta-single i {
	color: var(--primary-color);
	margin-right: 0.5rem;
}
.post-meta-single a {
	color: var(--primary-color);
}
.post-tags {
	margin-top: 3rem;
	padding-top: 2rem;
	border-top: 1px solid #e8e8e8;
	font-size: 1.4rem;
	color: var(--base-color);
}
.post-tags i {
	color: var(--primary-color);
	margin-right: 0.5rem;
}
.post-tags a {
	color: var(--primary-color);
	transition: color 0.3s ease;
}
.post-tags a:hover {
	color: var(--secondary-color);
}
.post-navigation {
	display: flex;
	justify-content: space-between;
	gap: 2rem;
	margin-top: 4rem;
	padding-top: 3rem;
	border-top: 2px solid var(--gray-color);
}
.post-navigation a {
	color: var(--secondary-color);
	font-weight: 600;
	transition: color 0.3s ease;
}
.post-navigation a:hover {
	color: var(--primary-color);
}
.post-navigation .nav-previous,
.post-navigation .nav-next {
	max-width: 48%;
}
.post-navigation .nav-next {
	text-align: right;
	margin-left: auto;
}

@media (max-width: 35.95em) {
	.post-navigation {
		flex-direction: column;
	}
	.post-navigation .nav-previous,
	.post-navigation .nav-next {
		max-width: 100%;
		text-align: left;
	}
	.post-meta-single {
		gap: 1rem;
		font-size: 1.3rem;
	}
}
