/* ============================================================
   CJBB Recipe Comments — WP-native via shadow CPT
   Lazy-loaded by CJBB_Recipe_Shadow_Comments::render_recipe_comments.
   Design tokens from brand-colors.css.
   ============================================================ */

.cjbb-comments {
	margin-top: var(--space-6);
}

/* ----- Comment list ----- */

.cjbb-comment-list {
	list-style: none;
	margin: 0 0 var(--space-6);
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
}

.cjbb-comment-empty {
	padding: var(--space-6);
	text-align: center;
	font-family: 'Rubik', sans-serif;
	color: var(--text-body);
	background: var(--surface-card);
	border: 2px dashed var(--border-default);
	border-radius: 12px;
}

html.theme-dark .cjbb-comment-empty {
	color: var(--dark-text-secondary);
	background: var(--dark-bg-card);
	border-color: var(--dark-border-subtle);
}

.cjbb-comment {
	display: flex;
	gap: var(--space-3);
	padding: var(--space-4);
	background: var(--surface-card);
	border: 2px solid var(--border-default);
	border-radius: 12px;
	box-shadow: var(--shadow-sm);
}

html.theme-dark .cjbb-comment {
	background: var(--dark-bg-card);
	border-color: var(--dark-border-subtle);
}

.cjbb-comment-avatar {
	flex: 0 0 48px;
	width: 48px;
	height: 48px;
}

.cjbb-comment-avatar img {
	width: 48px;
	height: 48px;
	border-radius: 50%;
	display: block;
}

.cjbb-comment-body {
	flex: 1 1 auto;
	min-width: 0;
}

.cjbb-comment-header {
	display: flex;
	align-items: baseline;
	flex-wrap: wrap;
	gap: var(--space-2);
	margin-bottom: var(--space-1);
}

.cjbb-comment-author {
	font-family: 'Saira Extra Condensed', sans-serif;
	font-size: var(--text-lg);
	font-weight: 700;
	color: var(--text-heading);
	letter-spacing: -0.01em;
}

html.theme-dark .cjbb-comment-author {
	color: var(--dark-text-primary);
}

.cjbb-comment-date {
	font-family: 'Rubik', sans-serif;
	font-size: var(--text-xs);
	color: var(--text-muted);
}

html.theme-dark .cjbb-comment-date {
	color: var(--dark-text-secondary);
}

.cjbb-comment-content {
	font-family: 'Rubik', sans-serif;
	font-size: var(--text-base);
	line-height: 1.6;
	color: var(--text-body);
	word-wrap: break-word;
}

.cjbb-comment-content p {
	margin: 0 0 var(--space-2);
}

.cjbb-comment-content p:last-child {
	margin-bottom: 0;
}

html.theme-dark .cjbb-comment-content {
	color: var(--dark-text-primary);
}

/* ----- Comment form ----- */

.cjbb-comment-form,
#commentform {
	margin-top: var(--space-6);
	padding: var(--space-5);
	background: var(--surface-card);
	border: 2px solid var(--border-default);
	border-radius: 12px;
}

html.theme-dark .cjbb-comment-form,
html.theme-dark #commentform {
	background: var(--dark-bg-card);
	border-color: var(--dark-border-subtle);
}

.cjbb-comment-form .comment-reply-title,
#commentform .comment-reply-title {
	font-family: 'Saira Extra Condensed', sans-serif;
	font-size: var(--text-2xl);
	font-weight: 700;
	color: var(--text-heading);
	margin: 0 0 var(--space-3);
	letter-spacing: -0.01em;
}

html.theme-dark .cjbb-comment-form .comment-reply-title,
html.theme-dark #commentform .comment-reply-title {
	color: var(--dark-text-primary);
}

.cjbb-comment-form-field {
	margin: 0 0 var(--space-3);
}

.cjbb-comment-form-field textarea,
#commentform textarea#comment {
	width: 100%;
	min-height: 120px;
	padding: 12px 16px;
	font-family: 'Rubik', sans-serif;
	font-size: var(--text-base);
	line-height: 1.5;
	color: var(--text-body);
	background: var(--surface-input, var(--neutral-000));
	border: 2px solid var(--border-default);
	border-radius: 6px;
	resize: vertical;
	box-sizing: border-box;
}

.cjbb-comment-form-field textarea:focus,
#commentform textarea#comment:focus {
	outline: none;
	border-color: var(--brand-primary);
	box-shadow: 0 0 0 3px rgba(255, 88, 16, 0.15);
}

html.theme-dark .cjbb-comment-form-field textarea,
html.theme-dark #commentform textarea#comment {
	background: var(--dark-bg-input, var(--dark-bg-secondary));
	color: var(--dark-text-primary);
	border-color: var(--dark-border-subtle);
}

/* Submit button — matches CLAUDE.md button spec */
.cjbb-comment-submit,
#commentform .submit {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 44px;
	padding: 15px 25px;
	font-family: 'Work Sans', sans-serif;
	font-size: var(--text-base);
	font-weight: 500;
	text-transform: capitalize;
	letter-spacing: -0.5px;
	background: var(--brand-primary);
	color: var(--neutral-000);
	border: 2px solid var(--brand-primary);
	border-radius: 0;
	cursor: pointer;
	transition: background-color 0.15s ease, filter 0.15s ease;
}

.cjbb-comment-submit:hover,
.cjbb-comment-submit:focus,
#commentform .submit:hover,
#commentform .submit:focus {
	filter: brightness(0.9);
}

.cjbb-comment-login-cta {
	margin: var(--space-6) 0 0;
	padding: var(--space-5);
	text-align: center;
	background: var(--surface-card);
	border: 2px dashed var(--border-default);
	border-radius: 12px;
	font-family: 'Rubik', sans-serif;
	color: var(--text-body);
}

.cjbb-comment-login-cta a {
	color: var(--brand-primary);
	text-decoration: underline;
	font-weight: 500;
}

html.theme-dark .cjbb-comment-login-cta {
	background: var(--dark-bg-card);
	border-color: var(--dark-border-subtle);
	color: var(--dark-text-secondary);
}

@media (max-width: 600px) {
	.cjbb-comment {
		padding: var(--space-3);
	}

	.cjbb-comment-avatar,
	.cjbb-comment-avatar img {
		width: 40px;
		height: 40px;
		flex-basis: 40px;
	}
}
