/* ===========================================================================
   eSoucoulou — Blog & single post styles
   =========================================================================== */

/* Page header (shared by blog index, archives, search) */
.eso-page-header {
	margin: 24px 0 32px;
	padding-bottom: 16px;
	border-bottom: 1px solid var(--eso-gray-200);
}
.eso-page-title {
	font-family: var(--eso-font-display);
	font-size: clamp(1.75rem, 4vw, 2.5rem);
	font-weight: 700;
	color: var(--eso-black);
	margin: 0 0 8px;
	line-height: 1.2;
}
.eso-page-desc {
	color: var(--eso-gray-600);
	font-size: 1rem;
	max-width: 60ch;
}

/* Breadcrumbs */
.eso-breadcrumbs {
	margin: 16px 0;
	font-size: 0.875rem;
	color: var(--eso-gray-600);
}
.eso-breadcrumbs ol {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	list-style: none;
	margin: 0;
	padding: 0;
}
.eso-breadcrumbs li {
	display: flex;
	align-items: center;
	gap: 8px;
}
.eso-breadcrumbs li:not(:last-child)::after {
	content: "/";
	color: var(--eso-gray-400);
}
.eso-breadcrumbs a {
	color: var(--eso-gray-600);
	text-decoration: none;
	transition: color var(--eso-t-fast);
}
.eso-breadcrumbs a:hover { color: var(--eso-primary); }
.eso-breadcrumbs [aria-current="page"] { color: var(--eso-black); font-weight: 500; }

/* Posts grid */
.eso-posts-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
	gap: 24px;
	margin-top: 24px;
}

/* Post card */
.eso-post-card {
	background: #fff;
	border-radius: var(--eso-radius-lg);
	overflow: hidden;
	border: 1px solid var(--eso-gray-200);
	transition: transform var(--eso-t-base), box-shadow var(--eso-t-base);
}
.eso-post-card:hover {
	transform: translateY(-3px);
	box-shadow: var(--eso-shadow-lg);
}
.eso-post-card__thumb {
	display: block;
	aspect-ratio: 16 / 10;
	overflow: hidden;
	background: var(--eso-gray-100);
}
.eso-post-card__thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--eso-t-slow);
}
.eso-post-card:hover .eso-post-card__thumb img { transform: scale(1.05); }
.eso-post-card__body { padding: 20px; }
.eso-post-card__meta {
	display: flex;
	gap: 12px;
	font-size: 0.8125rem;
	color: var(--eso-gray-600);
	margin-bottom: 10px;
	align-items: center;
}
.eso-post-card__category {
	background: rgba(26, 175, 26, 0.1);
	color: var(--eso-primary-dark);
	padding: 3px 10px;
	border-radius: var(--eso-radius-full);
	text-decoration: none;
	font-weight: 600;
	font-size: 0.75rem;
}
.eso-post-card__category:hover { background: var(--eso-primary); color: #fff; }
.eso-post-card__title {
	font-family: var(--eso-font-display);
	font-size: 1.25rem;
	line-height: 1.35;
	margin: 0 0 10px;
	font-weight: 700;
}
.eso-post-card__title a { color: var(--eso-black); text-decoration: none; }
.eso-post-card__title a:hover { color: var(--eso-primary); }
.eso-post-card__excerpt {
	color: var(--eso-gray-600);
	font-size: 0.9375rem;
	line-height: 1.6;
	margin: 0 0 14px;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.eso-post-card__footer {
	display: flex;
	justify-content: space-between;
	align-items: center;
	font-size: 0.8125rem;
	color: var(--eso-gray-600);
	padding-top: 12px;
	border-top: 1px solid var(--eso-gray-100);
}
.eso-link {
	color: var(--eso-primary-dark);
	text-decoration: none;
	font-weight: 600;
	display: inline-flex;
	align-items: center;
	gap: 4px;
	transition: gap var(--eso-t-fast);
}
.eso-link:hover { gap: 8px; }

/* Pagination */
.eso-pagination {
	margin-top: 40px;
	display: flex;
	justify-content: center;
}
.eso-pagination .nav-links,
.eso-pagination .pagination {
	display: flex;
	gap: 6px;
	flex-wrap: wrap;
}
.eso-pagination .page-numbers {
	min-width: 40px;
	height: 40px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: #fff;
	border: 1px solid var(--eso-gray-200);
	border-radius: var(--eso-radius-md);
	color: var(--eso-gray-700);
	font-weight: 600;
	text-decoration: none;
	padding: 0 12px;
	transition: all var(--eso-t-fast);
}
.eso-pagination .page-numbers:hover {
	border-color: var(--eso-primary);
	color: var(--eso-primary);
}
.eso-pagination .page-numbers.current {
	background: var(--eso-primary);
	color: #fff;
	border-color: var(--eso-primary);
}

/* Empty state */
.eso-empty-state {
	text-align: center;
	padding: 60px 20px;
	background: var(--eso-gray-50);
	border-radius: var(--eso-radius-lg);
}
.eso-empty-state p { color: var(--eso-gray-600); margin-bottom: 20px; }

/* Search form */
.eso-searchform {
	display: flex;
	gap: 8px;
	background: #fff;
	border: 1px solid var(--eso-gray-200);
	border-radius: var(--eso-radius-full);
	padding: 6px;
	max-width: 480px;
	margin: 0 auto;
}
.eso-searchform__input {
	flex: 1;
	border: none;
	background: transparent;
	padding: 10px 16px;
	font-size: 0.9375rem;
	outline: none;
}
.eso-searchform__submit {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	background: var(--eso-primary);
	color: #fff;
	border: none;
	border-radius: var(--eso-radius-full);
	padding: 10px 18px;
	font-weight: 600;
	cursor: pointer;
	transition: background var(--eso-t-fast);
}
.eso-searchform__submit:hover { background: var(--eso-primary-dark); }

/* ----------------------------------------------------------------------------
   Single post
   ---------------------------------------------------------------------------- */
.eso-single-post__header {
	padding: 32px 0 16px;
	background: linear-gradient(180deg, var(--eso-gray-50) 0%, #fff 100%);
}
.eso-single-post__title {
	font-family: var(--eso-font-display);
	font-size: clamp(2rem, 5vw, 3rem);
	font-weight: 800;
	line-height: 1.15;
	margin: 16px 0 16px;
	color: var(--eso-black);
}
.eso-single-post__meta {
	display: flex;
	gap: 8px;
	align-items: center;
	color: var(--eso-gray-600);
	font-size: 0.9375rem;
	flex-wrap: wrap;
}
.eso-author { display: inline-flex; align-items: center; gap: 8px; }
.eso-avatar { border-radius: 50%; }
.eso-dot { color: var(--eso-gray-400); }

.eso-single-post__featured {
	max-width: 1100px;
	margin: 24px auto 32px;
	border-radius: var(--eso-radius-lg);
	overflow: hidden;
}
.eso-single-post__featured img { width: 100%; height: auto; display: block; }

.eso-container--narrow { max-width: 760px; margin: 0 auto; padding: 0 20px; }

.eso-single-post__content {
	font-size: 1.0625rem;
	line-height: 1.75;
	color: var(--eso-gray-800);
}
.eso-single-post__content h2,
.eso-single-post__content h3,
.eso-single-post__content h4 {
	font-family: var(--eso-font-display);
	font-weight: 700;
	color: var(--eso-black);
	margin: 1.8em 0 0.6em;
	line-height: 1.3;
}
.eso-single-post__content h2 { font-size: 1.75rem; }
.eso-single-post__content h3 { font-size: 1.375rem; }
.eso-single-post__content h4 { font-size: 1.125rem; }
.eso-single-post__content p { margin: 0 0 1.2em; }
.eso-single-post__content a {
	color: var(--eso-primary-dark);
	text-decoration: underline;
	text-underline-offset: 3px;
}
.eso-single-post__content blockquote {
	border-left: 4px solid var(--eso-primary);
	background: var(--eso-primary-light);
	padding: 16px 20px;
	margin: 24px 0;
	border-radius: 0 var(--eso-radius-md) var(--eso-radius-md) 0;
	font-style: italic;
}
.eso-single-post__content img {
	max-width: 100%;
	height: auto;
	border-radius: var(--eso-radius-md);
	margin: 1em 0;
}
.eso-single-post__content ul,
.eso-single-post__content ol { padding-left: 1.5em; margin: 0 0 1.2em; }
.eso-single-post__content li { margin: 0.3em 0; }

.eso-single-post__tags,
.eso-single-post__share {
	margin-top: 32px;
	padding: 16px 0;
	border-top: 1px solid var(--eso-gray-200);
	display: flex;
	align-items: center;
	gap: 12px;
	flex-wrap: wrap;
}
.eso-single-post__tags a {
	display: inline-block;
	background: var(--eso-gray-100);
	color: var(--eso-gray-700);
	padding: 4px 12px;
	border-radius: var(--eso-radius-full);
	text-decoration: none;
	font-size: 0.875rem;
	transition: background var(--eso-t-fast), color var(--eso-t-fast);
}
.eso-single-post__tags a:hover { background: var(--eso-primary); color: #fff; }

.eso-single-post__share a {
	width: 36px;
	height: 36px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: var(--eso-gray-100);
	color: var(--eso-gray-700);
	border-radius: 50%;
	transition: all var(--eso-t-fast);
}
.eso-single-post__share a:hover {
	background: var(--eso-primary);
	color: #fff;
	transform: translateY(-2px);
}

.eso-author-box {
	margin-top: 40px;
	padding: 24px;
	background: var(--eso-gray-50);
	border-radius: var(--eso-radius-lg);
	display: flex;
	gap: 16px;
	align-items: flex-start;
}
.eso-author-box img { border-radius: 50%; flex-shrink: 0; }
.eso-author-box h3 { margin: 0 0 6px; font-size: 1.125rem; }
.eso-author-box p { margin: 0; color: var(--eso-gray-600); }

.eso-post-nav {
	margin-top: 32px;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
}
.eso-post-nav__item {
	padding: 18px;
	border: 1px solid var(--eso-gray-200);
	border-radius: var(--eso-radius-md);
	text-decoration: none;
	color: var(--eso-gray-700);
	transition: all var(--eso-t-fast);
}
.eso-post-nav__item:hover {
	border-color: var(--eso-primary);
	background: var(--eso-primary-light);
}
.eso-post-nav__next { text-align: right; }
.eso-post-nav__item span { display: block; font-size: 0.8125rem; color: var(--eso-gray-500); margin-bottom: 6px; }
.eso-post-nav__item strong { color: var(--eso-black); font-size: 0.9375rem; }

/* Comments */
.eso-comments { margin-top: 48px; }
.eso-comments__title {
	font-family: var(--eso-font-display);
	font-size: 1.5rem;
	margin: 0 0 24px;
}
.eso-comments__list { list-style: none; padding: 0; margin: 0; }
.eso-comments__list .comment-body {
	background: var(--eso-gray-50);
	padding: 16px;
	border-radius: var(--eso-radius-md);
	margin-bottom: 16px;
}
.eso-comments__list .children { margin-left: 32px; }
.eso-comments__closed { font-style: italic; color: var(--eso-gray-500); }

/* 404 */
.eso-404 { padding: 80px 0; }
.eso-404__code {
	font-family: var(--eso-font-display);
	font-size: clamp(6rem, 18vw, 12rem);
	font-weight: 800;
	color: var(--eso-primary);
	line-height: 1;
	opacity: 0.18;
	margin-bottom: -20px;
}
.eso-404__title {
	font-family: var(--eso-font-display);
	font-size: clamp(1.5rem, 4vw, 2.25rem);
	margin: 0 0 16px;
}
.eso-404__text {
	color: var(--eso-gray-600);
	margin: 0 0 32px;
	max-width: 48ch;
	margin-left: auto;
	margin-right: auto;
}
.eso-404__actions {
	display: flex;
	gap: 12px;
	justify-content: center;
	flex-wrap: wrap;
	margin-bottom: 40px;
}
.eso-404__search { max-width: 500px; margin: 0 auto; }
.eso-404__search p { color: var(--eso-gray-600); margin-bottom: 16px; }

@media (max-width: 768px) {
	.eso-post-nav { grid-template-columns: 1fr; }
	.eso-author-box { flex-direction: column; }
	.eso-posts-grid { grid-template-columns: 1fr; }
}
