/* Post List & Detail Styles */

/* ── Page wrapper ── */
.post-list {
	max-width: 860px;
	margin: 0 auto;
	padding: 2.5rem 1.25rem;
}

/* ── Hero header ── */
.page-hero {
	text-align: center;
	margin-bottom: 2.5rem;
	padding-bottom: 2rem;
	border-bottom: 1px solid var(--border);
}

.page-hero h1 {
	color: #fff;
	font-size: 2.4rem;
	font-weight: 700;
	margin: 0 0 0.5rem;
	letter-spacing: -0.5px;
}

.page-hero h1 span {
	color: var(--accent);
}

.page-hero p {
	color: var(--text-muted);
	margin: 0 0 1.25rem;
	font-size: 1rem;
}

/* ── Categories filter ── */
.categories-filter {
	background: var(--bg-card);
	border: 1px solid var(--border);
	border-radius: var(--radius);
	padding: 1rem 1.25rem;
	margin-bottom: 2rem;
}

.categories-filter h3 {
	color: var(--text-muted);
	margin: 0 0 0.75rem;
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
}

.categories-toggle {
	cursor: pointer;
	user-select: none;
	display: flex;
	justify-content: space-between;
	align-items: center;
	transition: color 0.2s;
}

.categories-toggle:hover {
	color: var(--accent);
}

.toggle-icon {
	font-size: 0.75em;
	transition: transform 0.3s;
}

.category-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}

.category-list.collapsed {
	display: none;
}

.category-list li a {
	display: block;
	padding: 0.3rem 0.8rem;
	background: var(--bg-card2);
	color: var(--text-muted);
	border-radius: 20px;
	border: 1px solid var(--border);
	transition: all 0.2s;
	font-size: 0.82rem;
	font-weight: 500;
}

.category-list li a:hover {
	border-color: var(--accent);
	color: #fff;
	background: #1e1e38;
}

.category-list li.active a {
	background: var(--accent);
	border-color: var(--accent);
	color: #fff;
	font-weight: 600;
}

/* ── Category title ── */
.category-title {
	color: #fff;
	font-size: 1.3rem;
	font-weight: 600;
	margin: 0 0 1.5rem;
	display: flex;
	align-items: center;
	gap: 0.5rem;
}

.category-title::before {
	content: '';
	display: inline-block;
	width: 4px;
	height: 1.2em;
	background: var(--accent);
	border-radius: 2px;
}

/* ── Post cards ── */
.posts {
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
}

.post-item {
	background: var(--bg-card);
	border: 1px solid var(--border);
	border-radius: var(--radius);
	padding: 1.5rem;
	transition: border-color 0.2s, transform 0.2s, box-shadow 0.2s;
	position: relative;
}

.post-item::before {
	content: '';
	position: absolute;
	left: 0;
	top: 0;
	bottom: 0;
	width: 3px;
	background: var(--accent);
	border-radius: var(--radius) 0 0 var(--radius);
	opacity: 0;
	transition: opacity 0.2s;
}

.post-item:hover {
	border-color: var(--accent);
	transform: translateX(3px);
	box-shadow: 0 4px 20px rgba(233, 69, 96, 0.1);
}

.post-item:hover::before {
	opacity: 1;
}

.post-item h2 {
	margin: 0 0 0.6rem;
	font-size: 1.25rem;
	font-weight: 600;
	line-height: 1.3;
}

.post-item h2 a {
	color: #fff;
	text-decoration: none;
	transition: color 0.2s;
}

.post-item h2 a:hover {
	color: var(--accent);
}

.post-meta {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 0.6rem;
	color: var(--text-muted);
	font-size: 0.82rem;
	margin-bottom: 0.85rem;
	padding-bottom: 0.85rem;
	border-bottom: 1px solid var(--border);
}

.post-meta .author::before { content: '👤 '; }
.post-meta .date::before   { content: '🕐 '; }

.post-excerpt {
	color: #b0b0c8;
	line-height: 1.7;
	margin-bottom: 1rem;
	font-size: 0.95rem;
}

.post-actions {
	display: flex;
	gap: 0.5rem;
	flex-wrap: wrap;
}

/* ── Category badge ── */
.category-badge {
	background: rgba(233, 69, 96, 0.15);
	color: var(--accent) !important;
	padding: 0.15rem 0.65rem;
	border-radius: 20px;
	font-size: 0.78rem;
	font-weight: 600;
	border: 1px solid rgba(233, 69, 96, 0.3);
	display: inline-block;
}

.category-badge a {
	color: inherit !important;
}

.category-badge a:hover {
	color: #fff !important;
}

/* ── No posts ── */
.no-posts {
	text-align: center;
	padding: 4rem 1rem;
	color: var(--text-muted);
	font-size: 1.1rem;
}

.no-posts p {
	margin-bottom: 1.25rem;
}

.no-posts a.btn {
	color: #fff;
}

/* ────────────────────────────
   Post Detail
──────────────────────────── */
.post-detail {
	max-width: 820px;
	margin: 0 auto;
	padding: 2.5rem 1.25rem;
}

.post {
	background: var(--bg-card);
	border: 1px solid var(--border);
	border-radius: var(--radius);
	padding: 2.5rem;
	margin-bottom: 2rem;
}

.post h1 {
	color: #fff;
	margin: 0 0 1.25rem;
	font-size: 2rem;
	font-weight: 700;
	line-height: 1.3;
	letter-spacing: -0.3px;
}

.post-detail .post-meta {
	font-size: 0.85rem;
	margin-bottom: 1.75rem;
	padding: 0.75rem 1rem;
	background: var(--bg-card2);
	border-radius: 8px;
	border-left: 3px solid var(--accent);
	border-bottom: none;
}

.post-detail .post-meta span {
	display: inline-block;
	margin-right: 1.25rem;
}

.post-content {
	color: #c8c8e0;
	line-height: 1.9;
	font-size: 1.05rem;
	margin-bottom: 2rem;
	padding-bottom: 2rem;
	border-bottom: 1px solid var(--border);
}

.post-detail .post-actions {
	display: flex;
	gap: 0.6rem;
	flex-wrap: wrap;
}

/* ────────────────────────────
   Comments
──────────────────────────── */
.comments {
	background: var(--bg-card);
	border: 1px solid var(--border);
	border-radius: var(--radius);
	padding: 1.75rem;
}

.comments h2 {
	color: #fff;
	font-size: 1.1rem;
	font-weight: 600;
	margin: 0 0 1.25rem;
	padding-bottom: 0.85rem;
	border-bottom: 1px solid var(--border);
	display: flex;
	align-items: center;
	gap: 0.5rem;
}

.comments h2::before {
	content: '💬';
}

.comment {
	background: var(--bg-card2) !important;
	border: 1px solid var(--border) !important;
	border-radius: 8px !important;
	padding: 1rem 1.25rem !important;
	margin-bottom: 0.75rem !important;
}

.comment:last-of-type {
	margin-bottom: 1rem !important;
}

.comment-meta {
	color: var(--text-muted) !important;
	font-size: 0.8rem !important;
	margin-bottom: 0.5rem !important;
}

.comment-meta strong {
	color: var(--text) !important;
}

.comment-content {
	color: #c0c0d8;
	font-size: 0.95rem;
	line-height: 1.6;
}

.comment-actions {
	margin-top: 0.65rem !important;
	display: flex;
	gap: 0.4rem;
}

.text-muted {
	color: var(--text-muted) !important;
}

/* ── Inline comment form ── */
.comment-form {
margin-top: 1.25rem;
padding-top: 1.25rem;
border-top: 1px solid var(--border);
}

.comment-form-field {
margin-bottom: 0.75rem;
}

.comment-textarea {
width: 100%;
padding: 0.65rem 0.9rem;
background: var(--bg-card2);
border: 1px solid var(--border);
color: var(--text);
border-radius: 6px;
font-family: inherit;
font-size: 0.95rem;
box-sizing: border-box;
resize: vertical;
transition: border-color 0.2s, box-shadow 0.2s;
}

.comment-textarea:focus {
outline: none;
border-color: var(--accent);
box-shadow: 0 0 0 3px rgba(233, 69, 96, 0.12);
}

.comment-form-actions {
display: flex;
gap: 0.5rem;
}

.comment-login-hint {
margin-top: 1rem;
color: var(--text-muted);
font-size: 0.9rem;
}

.comment-login-hint a {
color: var(--accent);
font-weight: 600;
}

/* ── Edited badge ── */
.edited-badge {
background: rgba(233, 69, 96, 0.1);
color: var(--accent);
border: 1px solid rgba(233, 69, 96, 0.25);
border-radius: 4px;
padding: 0 0.4rem;
font-size: 0.72rem;
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.05em;
vertical-align: middle;
}

/* ── Inline comment edit form ── */
.comment-edit-form {
margin-top: 0.65rem;
}

.comment-edit-form .comment-textarea {
width: 100%;
box-sizing: border-box;
}

.comment-edit-actions {
display: flex;
gap: 0.4rem;
margin-top: 0.5rem;
}
