/* ============================================================
   Horta Nutrition — Blog-specific layout polish
   ============================================================ */

/* ---------- Post grid (archive/index/related) ---------- */
.horta-post-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 24px;
}
@media (min-width: 640px)  { .horta-post-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .horta-post-grid { grid-template-columns: repeat(3, 1fr); gap: 32px; } }

/* ---------- Post card ---------- */
.horta-post-card {
	display: flex;
	flex-direction: column;
	overflow: hidden;
}
.horta-post-card__media {
	display: block;
	aspect-ratio: 16 / 9;
	background: var(--color-cream);
	overflow: hidden;
}
.horta-post-card__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 400ms ease;
}
.horta-post-card:hover .horta-post-card__media img { transform: scale(1.05); }
.horta-post-card__placeholder { width: 100%; height: 100%; background: linear-gradient(135deg, var(--color-cream), var(--color-sage-100)); }

.horta-post-card__body {
	padding: 18px 20px 20px;
	display: flex;
	flex-direction: column;
	gap: 10px;
	flex: 1 1 auto;
}
.horta-post-card__title {
	font-family: var(--font-display);
	font-size: 1.125rem;
	line-height: 1.3;
	margin: 0;
	font-weight: 500;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.horta-post-card__title a {
	color: var(--color-charcoal);
	transition: color 200ms ease;
}
.horta-post-card__title a:hover { color: var(--color-forest); }
.horta-post-card__excerpt {
	font-size: 0.875rem;
	color: var(--color-slate-grey);
	line-height: 1.5;
	margin: 0;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
	flex: 1 1 auto;
}
.horta-post-card__meta {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 6px;
	font-size: 0.75rem;
	color: var(--color-slate-grey);
	border-top: 1px solid var(--color-cloud-grey);
	padding-top: 10px;
}
.horta-post-card__avatar { border-radius: 50%; }
.horta-post-card__sep { color: var(--color-cloud-grey); }

/* ---------- Single post ---------- */
.horta-post-single__layout {
	display: grid;
	grid-template-columns: 1fr;
	gap: 40px;
}
@media (min-width: 1024px) {
	.horta-post-single__layout {
		grid-template-columns: minmax(0, 1fr) 320px;
		gap: 56px;
	}
}

.horta-post__header { margin-bottom: 32px; max-width: 720px; }
.horta-post__category { display: inline-flex; margin-bottom: 16px; }
.horta-post__title { margin: 0 0 16px; }
.horta-post__lede { color: var(--color-slate-grey); margin: 0 0 24px; }
.horta-post__meta {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-top: 16px;
}
.horta-post__avatar { border-radius: 50%; }
.horta-post__byline { display: flex; flex-direction: column; }
.horta-post__author { font-weight: 500; color: var(--color-charcoal); font-size: 0.9375rem; }
.horta-post__meta-row { display: flex; align-items: center; gap: 6px; font-size: 0.8125rem; color: var(--color-slate-grey); }
.horta-post__sep { color: var(--color-cloud-grey); }

.horta-post__featured {
	margin: 0 0 32px;
	border-radius: var(--border-radius-card);
	overflow: hidden;
}
.horta-post__featured-img { width: 100%; height: auto; display: block; }
.horta-post__featured-caption {
	padding: 12px 16px 0;
	font-size: 0.875rem;
	color: var(--color-slate-grey);
	font-style: italic;
	text-align: center;
}

.horta-post__content { max-width: 720px; }
.horta-post__tags {
	margin-top: 32px;
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}
.horta-post__footer {
	margin-top: 32px;
	padding-top: 20px;
	border-top: 1px solid var(--color-cloud-grey);
}

/* ---------- Share bar ---------- */
.horta-share-bar {
	display: flex;
	align-items: center;
	gap: 10px;
	flex-wrap: wrap;
}
.horta-share-bar__label {
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--color-slate-grey);
	font-weight: 600;
	margin-right: 4px;
}
.horta-share-bar__link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background: var(--color-cream);
	color: var(--color-slate-grey);
	transition: background-color 200ms ease, color 200ms ease, transform 200ms ease;
}
.horta-share-bar__link svg { width: 16px; height: 16px; }
.horta-share-bar__link:hover {
	color: #fff;
	transform: translateY(-2px);
}
.horta-share-bar__link--twitter:hover  { background: #000; }
.horta-share-bar__link--facebook:hover { background: #1877F2; }
.horta-share-bar__link--linkedin:hover { background: #0A66C2; }
.horta-share-bar__link--whatsapp:hover { background: #25D366; }

/* ---------- Sidebar ---------- */
.horta-sidebar { display: flex; flex-direction: column; gap: 24px; position: sticky; top: calc(var(--header-height) + 16px); }
.horta-sidebar__title {
	font-family: var(--font-display);
	font-size: 1rem;
	font-weight: 600;
	margin: 0 0 12px;
	color: var(--color-charcoal);
}
.horta-sidebar__author { padding: 24px; text-align: center; }
.horta-sidebar__author-avatar { width: 72px; height: 72px; border-radius: 50%; margin: 0 auto 12px; }
.horta-sidebar__author-name { font-family: var(--font-display); font-size: 1.125rem; margin: 0 0 8px; }
.horta-sidebar__author-bio { font-size: 0.875rem; color: var(--color-slate-grey); margin: 0 0 12px; line-height: 1.55; }
.horta-sidebar__newsletter { padding: 24px; }
.horta-sidebar__categories { padding: 20px 24px; }
.horta-sidebar__categories ul {
	list-style: none;
	padding: 0;
	margin: 0;
}
.horta-sidebar__categories li {
	border-bottom: 1px solid var(--color-cloud-grey);
}
.horta-sidebar__categories li:last-child { border-bottom: 0; }
.horta-sidebar__categories a {
	display: flex;
	justify-content: space-between;
	padding: 10px 0;
	color: var(--color-charcoal);
	font-size: 0.9375rem;
}
.horta-sidebar__categories a:hover { color: var(--color-forest); }

/* ---------- Comments ---------- */
.horta-post-single__comments { margin-top: 56px; }
.horta-comments__title {
	font-family: var(--font-display);
	font-size: 1.5rem;
	margin: 0 0 24px;
}
.horta-comments__list {
	list-style: none;
	padding: 0;
	margin: 0 0 32px;
}
.horta-comments__list .comment-body {
	background: #fff;
	border: 1px solid var(--color-cloud-grey);
	padding: 16px 18px;
	border-radius: 12px;
	margin-bottom: 12px;
}
.horta-comments__list .comment-author { display: flex; align-items: center; gap: 12px; margin-bottom: 8px; }
.horta-comments__list .avatar { border-radius: 50%; }
.horta-comments__list .comment-meta { font-size: 0.75rem; color: var(--color-slate-grey); }
.horta-comments__list .reply { margin-top: 8px; }
.horta-comments__list .reply a { font-size: 0.8125rem; color: var(--color-forest); }
.horta-comments__form .comment-form-author,
.horta-comments__form .comment-form-email,
.horta-comments__form .comment-form-url,
.horta-comments__form .comment-form-comment {
	margin-bottom: 16px;
}
.horta-comments__reply-title {
	font-family: var(--font-display);
	font-size: 1.25rem;
	margin: 0 0 16px;
}

/* ---------- Page hero compact (used by archive/blog index) ---------- */
.horta-page-hero--compact { padding: 24px 0 24px; }

/* ---------- Pagination spacing ---------- */
.horta-section .navigation.pagination,
.horta-section .nav-links { margin-top: 56px; }

/* ---------- Widget area ---------- */
.horta-widget {
	background: #fff;
	border-radius: var(--border-radius-card);
	box-shadow: var(--shadow-card);
	padding: 20px 24px;
}
.horta-widget__title {
	font-family: var(--font-display);
	font-size: 1rem;
	font-weight: 600;
	margin: 0 0 12px;
}
.horta-widget ul { list-style: none; padding: 0; margin: 0; }
.horta-widget li { padding: 6px 0; border-bottom: 1px solid var(--color-cloud-grey); font-size: 0.9375rem; }
.horta-widget li:last-child { border-bottom: 0; }
