/*
 * BerryFoods Single — post/page content, comments
 */

/* ── Entry header ──────────────────────────────────── */
.entry-header { margin-bottom: var(--space-xl); }

.entry-title {
	font-family: var(--font-display);
	font-size: clamp(1.5rem, 4vw, 2.2rem);
	line-height: 1.2;
	margin-bottom: var(--space-md);
}

/* ── Featured image ────────────────────────────────── */
.post-hero-image {
	border-radius: var(--radius-lg);
	overflow: hidden;
	margin-bottom: var(--space-xl);
	aspect-ratio: 16/7;
}

.post-hero-image img { width: 100%; height: 100%; object-fit: cover; }

/* ── Entry content ─────────────────────────────────── */
.entry-content {
	font-size: 1.05rem;
	line-height: 1.8;
	color: var(--color-text);
}

.entry-content > * + * { margin-top: 1.25rem; }

.entry-content h2 { font-family: var(--font-display); font-size: 1.55rem; margin-top: 2.5rem; color: var(--green-900); }
.entry-content h3 { font-family: var(--font-display); font-size: 1.25rem; margin-top: 2rem; }
.entry-content h4 { font-size: 1.05rem; margin-top: 1.75rem; }

.entry-content a { color: var(--green-600); text-decoration: underline; text-underline-offset: 2px; }
.entry-content a:hover { color: var(--green-800); }

.entry-content ul, .entry-content ol { padding-left: 1.6rem; }
.entry-content li + li { margin-top: 0.35rem; }

.entry-content blockquote {
	margin: var(--space-xl) 0;
	padding: 1.25rem 1.75rem;
	border-left: 4px solid var(--green-400);
	background: var(--green-50);
	border-radius: 0 var(--radius-md) var(--radius-md) 0;
	font-style: italic;
	font-size: 1.05rem;
	color: var(--gray-700);
}

.entry-content pre {
	background: var(--charcoal);
	color: #e2e8f0;
	padding: 1.4rem 1.6rem;
	border-radius: var(--radius-md);
	overflow-x: auto;
	font-size: 0.88rem;
	line-height: 1.65;
}

.entry-content code {
	background: var(--green-100);
	color: var(--green-800);
	padding: 0.15em 0.45em;
	border-radius: 4px;
	font-size: 0.88em;
}

.entry-content pre code { background: none; color: inherit; padding: 0; }
.entry-content img { border-radius: var(--radius-md); margin: var(--space-lg) 0; }

.entry-content table { width: 100%; border-collapse: collapse; font-size: 0.9rem; margin: var(--space-lg) 0; }
.entry-content th, .entry-content td { padding: 0.65rem 1rem; border: 1px solid var(--gray-200); text-align: left; }
.entry-content th { background: var(--green-50); font-weight: 700; }
.entry-content tr:nth-child(even) td { background: var(--gray-50); }

/* ── Entry footer ──────────────────────────────────── */
.entry-footer {
	margin-top: var(--space-xl);
	padding-top: 1.25rem;
	border-top: 1px solid var(--gray-200);
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.85rem;
	color: var(--gray-500);
}

.entry-footer .tags-label { font-weight: 600; }

.entry-footer a {
	display: inline-block;
	padding: 0.2rem 0.65rem;
	background: var(--green-100);
	border-radius: var(--radius-full);
	color: var(--green-700);
	font-size: 0.8rem;
	transition: background var(--duration-fast), color var(--duration-fast);
}

.entry-footer a:hover { background: var(--green-600); color: var(--white); text-decoration: none; }

/* ── Comments ─────────────────────────────────────── */
.comments-area {
	margin-top: var(--space-2xl);
	padding-top: var(--space-xl);
	border-top: 1px solid var(--gray-200);
}

.comments-title { font-size: 1.25rem; margin-bottom: var(--space-lg); }

.comment-list { list-style: none; padding: 0; margin: 0 0 var(--space-xl); }

.comment-list .comment {
	padding: 1.25rem 0;
	border-bottom: 1px solid var(--gray-100);
}

.comment-author { display: flex; align-items: center; gap: 0.75rem; margin-bottom: 0.6rem; }
.comment-author img { border-radius: 50%; width: 40px; height: 40px; border: 2px solid var(--green-200); }
.comment-author .fn { font-weight: 600; font-size: 0.95rem; }
.comment-metadata { font-size: 0.8rem; color: var(--gray-400); }
.comment-content { font-size: 0.95rem; line-height: 1.7; padding-left: 52px; }
.comment-reply-link { font-size: 0.8rem; font-weight: 600; color: var(--green-600); padding-left: 52px; display: inline-block; margin-top: 0.4rem; }

/* Comment form */
.comment-respond {
	background: var(--green-50);
	border-radius: var(--radius-lg);
	padding: var(--space-xl);
	border: 1px solid var(--green-200);
}

.comment-reply-title { font-size: 1.1rem; margin-bottom: 1.25rem; }

.comment-form label { display: block; font-size: 0.85rem; font-weight: 600; margin-bottom: 0.35rem; color: var(--gray-700); }

.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"],
.comment-form textarea {
	width: 100%;
	padding: 0.6rem 0.9rem;
	border: 1.5px solid var(--gray-200);
	border-radius: var(--radius-md);
	font-size: 0.9rem;
	font-family: var(--font-body);
	background: var(--white);
	color: var(--color-text);
	transition: border-color var(--duration-fast);
	margin-bottom: var(--space-md);
	outline: none;
}

.comment-form input:focus,
.comment-form textarea:focus { border-color: var(--green-400); box-shadow: 0 0 0 3px rgba(58,158,82,0.12); }
.comment-form textarea { min-height: 130px; resize: vertical; }

.comment-form .submit {
	padding: 0.6rem 1.4rem;
	background: var(--green-600);
	color: var(--white);
	border: none;
	border-radius: var(--radius-md);
	font-size: 0.9rem;
	font-weight: 700;
	cursor: pointer;
	font-family: var(--font-body);
	transition: background var(--duration-fast), transform var(--duration-fast);
}

.comment-form .submit:hover { background: var(--green-700); transform: translateY(-1px); }