/**
 * 创想鸟主题主样式
 *
 * @package ChuangXiangBird
 */

/* ===========================
   变量 & 基础
   =========================== */
:root {
	--cxb-primary: #2d8cf0;
	--cxb-primary-dark: #0056b3;
	--cxb-primary-light: #5cabf5;
	--cxb-primary-bg: rgba(45, 140, 240, 0.06);
	--cxb-accent: #F59E0B;
	--cxb-text: #222222;
	--cxb-text-light: #555555;
	--cxb-text-lighter: #999999;
	--cxb-bg: #f5f7fa;
	--cxb-bg-white: #FFFFFF;
	--cxb-border: #e8e8e8;
	--cxb-border-light: #f0f0f0;
	--cxb-success: #10B981;
	--cxb-error: #EF4444;
	--cxb-warning: #F59E0B;

	--cxb-font-base: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', 'PingFang SC', 'Hiragino Sans GB', 'Microsoft YaHei', 'Helvetica Neue', Arial, sans-serif;
	--cxb-font-mono: 'JetBrains Mono', 'SFMono-Regular', Consolas, 'Liberation Mono', Menlo, Courier, monospace;

	--cxb-font-size-xs: 0.75rem;
	--cxb-font-size-sm: 0.875rem;
	--cxb-font-size-base: 1rem;
	--cxb-font-size-lg: 1.125rem;
	--cxb-font-size-xl: 1.35rem;
	--cxb-font-size-2xl: 1.625rem;
	--cxb-font-size-3xl: 2.25rem;
	--cxb-font-size-4xl: 3rem;

	--cxb-spacing-xs: 0.25rem;
	--cxb-spacing-sm: 0.5rem;
	--cxb-spacing-md: 1rem;
	--cxb-spacing-lg: 1.5rem;
	--cxb-spacing-xl: 2rem;
	--cxb-spacing-2xl: 3.5rem;
	--cxb-spacing-3xl: 5rem;

	--cxb-radius-sm: 6px;
	--cxb-radius-md: 12px;
	--cxb-radius-lg: 16px;
	--cxb-radius-xl: 24px;

	--cxb-shadow-sm: 0 1px 2px rgba(15, 23, 42, 0.04), 0 1px 4px rgba(15, 23, 42, 0.04);
	--cxb-shadow-md: 0 4px 12px rgba(15, 23, 42, 0.06), 0 1px 3px rgba(15, 23, 42, 0.04);
	--cxb-shadow-lg: 0 8px 24px rgba(15, 23, 42, 0.08), 0 2px 6px rgba(15, 23, 42, 0.04);
	--cxb-shadow-xl: 0 16px 40px rgba(15, 23, 42, 0.1), 0 4px 12px rgba(15, 23, 42, 0.06);

	--cxb-transition: 0.2s cubic-bezier(0.4, 0, 0.2, 1);
	--cxb-header-height: 64px;
	--cxb-sidebar-width: 320px;
	--cxb-container-max: 1280px;
}

/* ===========================
   深色模式
   =========================== */
[data-theme="dark"],
.dark-mode {
	--cxb-primary: #818CF8;
	--cxb-primary-dark: #6366F1;
	--cxb-primary-light: #A5B4FC;
	--cxb-primary-bg: rgba(129, 140, 248, 0.1);
	--cxb-accent: #FBBF24;
	--cxb-text: #F1F5F9;
	--cxb-text-light: #CBD5E1;
	--cxb-text-lighter: #64748B;
	--cxb-bg: #0F172A;
	--cxb-bg-white: #1E293B;
	--cxb-border: #334155;
	--cxb-border-light: #1E293B;

	--cxb-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.2), 0 1px 4px rgba(0, 0, 0, 0.2);
	--cxb-shadow-md: 0 4px 12px rgba(0, 0, 0, 0.3), 0 1px 3px rgba(0, 0, 0, 0.2);
	--cxb-shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.4), 0 2px 6px rgba(0, 0, 0, 0.2);
	--cxb-shadow-xl: 0 16px 40px rgba(0, 0, 0, 0.5), 0 4px 12px rgba(0, 0, 0, 0.3);
}

/* 深色模式切换按钮 */
.cxb-dark-toggle {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border-radius: 8px;
	border: none;
	background: transparent;
	color: var(--cxb-text-light);
	cursor: pointer;
	transition: all 0.18s ease;
}

.cxb-dark-toggle:hover {
	background: var(--cxb-primary-bg);
	color: var(--cxb-primary);
}

.cxb-dark-toggle .sun-icon { display: none; }
.cxb-dark-toggle .moon-icon { display: block; }

[data-theme="dark"] .cxb-dark-toggle .sun-icon { display: block; }
[data-theme="dark"] .cxb-dark-toggle .moon-icon { display: none; }

/* ===========================
   搜索面板
   =========================== */
.cxb-search-overlay {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 10001;
	background: rgba(0, 0, 0, 0.5);
	display: flex;
	align-items: flex-start;
	justify-content: center;
	padding-top: 100px;
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.3s ease, visibility 0.3s ease;
}

.cxb-search-overlay--show {
	opacity: 1;
	visibility: visible;
}

.cxb-search-modal {
	width: 100%;
	max-width: 600px;
	background: var(--cxb-bg-white);
	border-radius: var(--cxb-radius-lg);
	padding: var(--cxb-spacing-lg);
	box-shadow: var(--cxb-shadow-xl);
	transform: translateY(-20px);
	transition: transform 0.3s ease;
}

.cxb-search-overlay--show .cxb-search-modal {
	transform: translateY(0);
}

.cxb-search-modal-form {
	display: flex;
	gap: 8px;
}

.cxb-search-input {
	flex: 1;
	padding: 14px 18px;
	border: 2px solid var(--cxb-border);
	border-radius: var(--cxb-radius-md);
	font-family: inherit;
	font-size: 16px;
	background: var(--cxb-bg);
	color: var(--cxb-text);
	transition: border-color var(--cxb-transition);
}

.cxb-search-input:focus {
	outline: none;
	border-color: var(--cxb-primary);
	background: var(--cxb-bg-white);
}

.cxb-search-close {
	width: 46px;
	height: 46px;
	background: var(--cxb-border);
	border: none;
	border-radius: var(--cxb-radius-md);
	font-size: 24px;
	cursor: pointer;
	color: var(--cxb-text-light);
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background var(--cxb-transition);
	flex-shrink: 0;
}

.cxb-search-close:hover {
	background: var(--cxb-error);
	color: #fff;
}

.cxb-search-results {
	margin-top: var(--cxb-spacing-md);
	max-height: 400px;
	overflow-y: auto;
}

.cxb-search-result-item {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 10px;
	border-radius: var(--cxb-radius-sm);
	transition: background var(--cxb-transition);
	text-decoration: none;
	color: var(--cxb-text);
}

.cxb-search-result-item:hover {
	background: var(--cxb-primary-bg);
}

.cxb-search-result-img {
	width: 44px;
	height: 44px;
	border-radius: 6px;
	object-fit: cover;
	flex-shrink: 0;
	background: var(--cxb-bg);
}

.cxb-search-result-title {
	font-size: 14px;
	font-weight: 600;
	line-height: 1.3;
}

.cxb-search-result-date {
	font-size: 11px;
	color: var(--cxb-text-lighter);
}

.cxb-search-empty {
	padding: 30px;
	text-align: center;
	color: var(--cxb-text-lighter);
	font-size: 14px;
}

/* ===========================
   文章评分
   =========================== */
.cxb-rating {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: var(--cxb-spacing-lg) 0;
	border-top: 1px solid var(--cxb-border-light);
	margin-top: var(--cxb-spacing-lg);
}

.cxb-rating-stars {
	display: flex;
	gap: 4px;
}

.cxb-star {
	cursor: pointer;
	display: inline-flex;
	transition: transform 0.15s ease;
}

.cxb-star:hover {
	transform: scale(1.2);
}

.cxb-star--full svg,
.cxb-star--half svg {
	fill: #f59e0b;
}

.cxb-rating-text {
	font-size: 14px;
	color: var(--cxb-text-lighter);
	display: flex;
	align-items: center;
	gap: 4px;
}

.cxb-rating-text strong {
	font-size: 18px;
	color: var(--cxb-text);
}

/* ===========================
   归档筛选
   =========================== */
.cxb-archive-filter {
	margin-bottom: var(--cxb-spacing-xl);
	padding: var(--cxb-spacing-lg);
	background: var(--cxb-bg-white);
	border-radius: var(--cxb-radius-lg);
	box-shadow: var(--cxb-shadow-sm);
}

.cxb-filter-form {
	display: flex;
	align-items: flex-end;
	gap: 12px;
	flex-wrap: wrap;
}

.cxb-filter-group {
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.cxb-filter-group label {
	font-size: 12px;
	font-weight: 600;
	color: var(--cxb-text-lighter);
	text-transform: uppercase;
	letter-spacing: 0.3px;
}

.cxb-filter-group select {
	padding: 10px 36px 10px 14px;
	border: 1px solid var(--cxb-border);
	border-radius: var(--cxb-radius-sm);
	font-family: inherit;
	font-size: 14px;
	background: var(--cxb-bg);
	color: var(--cxb-text);
	appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 12px center;
	cursor: pointer;
	min-width: 160px;
}

.cxb-filter-group select:focus {
	outline: none;
	border-color: var(--cxb-primary);
}

.cxb-filter-form .btn-sm {
	padding: 10px 24px;
	height: 42px;
}

/* ===========================
   重置 & 全局
   =========================== */
*,
*::before,
*::after {
	box-sizing: border-box;
}

html {
	font-size: 16px;
	scroll-behavior: smooth;
}

body {
	margin: 0;
	padding: 0;
	font-family: var(--cxb-font-base);
	font-size: var(--cxb-font-size-base);
	line-height: 1.7;
	color: var(--cxb-text);
	background-color: var(--cxb-bg);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

/* ===========================
   容器
   =========================== */
.container {
	max-width: var(--cxb-container-max);
	margin: 0 auto;
	padding: 0 var(--cxb-spacing-lg);
}

/* ===========================
   辅助类
   =========================== */
.screen-reader-text {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
	width: 1px;
	word-wrap: normal !important;
}

/* ===========================
   链接
   =========================== */
a {
	color: var(--cxb-primary);
	text-decoration: none;
	transition: color var(--cxb-transition);
}

a:hover,
a:focus {
	color: var(--cxb-primary-dark);
	text-decoration: underline;
}

a:focus-visible {
	outline: 2px solid var(--cxb-primary);
	outline-offset: 2px;
}

/*** ===========================
  跳转链接
  =========================== */
.skip-link {
	position: absolute;
	top: -100px;
	left: 50%;
	transform: translateX(-50%);
	z-index: 9999;
	padding: var(--cxb-spacing-sm) var(--cxb-spacing-lg);
	background: var(--cxb-primary);
	color: #fff;
	border-radius: var(--cxb-radius-sm);
	transition: top var(--cxb-transition);
}

.skip-link:focus {
	top: var(--cxb-spacing-md);
}

/* ===========================
   页头 & 导航
   =========================== */
.site-header {
	position: sticky;
	top: 0;
	z-index: 1000;
	background: rgba(255, 255, 255, 0.92);
	backdrop-filter: blur(20px);
	-webkit-backdrop-filter: blur(20px);
	border-bottom: 1px solid var(--cxb-border-light);
	height: 64px;
}

.header-inner {
	height: 100%;
}

.header-container {
	display: flex;
	align-items: center;
	justify-content: space-between;
	height: 100%;
	gap: var(--cxb-spacing-lg);
}

/* Logo */
.site-branding {
	flex-shrink: 0;
	display: flex;
	align-items: center;
}

.site-title {
	margin: 0;
	font-size: 1.15rem;
	font-weight: 800;
	line-height: 1;
	letter-spacing: -0.5px;
}

.site-title a {
	color: var(--cxb-text);
	text-decoration: none;
	transition: color var(--cxb-transition);
}

.site-title a:hover {
	color: var(--cxb-primary);
}

.custom-logo {
	max-height: 30px;
	width: auto;
}

/* 主导航 */
.main-navigation {
	flex: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	height: 100%;
}

.main-navigation > div {
	height: 100%;
}

.main-navigation ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	align-items: center;
	gap: 2px;
	height: 100%;
}

.main-navigation li {
	position: relative;
	display: flex;
	align-items: center;
	height: 100%;
}

.main-navigation > ul > li > a {
	display: flex;
	align-items: center;
	padding: 0 14px;
	height: 34px;
	color: var(--cxb-text-light);
	font-size: 0.8125rem;
	font-weight: 500;
	text-decoration: none;
	border-radius: 8px;
	transition: all 0.18s ease;
	white-space: nowrap;
	position: relative;
}

.main-navigation > ul > li > a::after {
	content: '';
	position: absolute;
	bottom: -4px;
	left: 50%;
	transform: translateX(-50%) scaleX(0);
	width: 20px;
	height: 2px;
	background: var(--cxb-primary);
	border-radius: 2px;
	transition: transform 0.2s ease;
}

.main-navigation > ul > li > a:hover {
	color: var(--cxb-primary);
	background: var(--cxb-primary-bg);
}

.main-navigation > ul > li.current-menu-item > a,
.main-navigation > ul > li.current-page-ancestor > a {
	color: var(--cxb-text);
	font-weight: 600;
	background: var(--cxb-primary-bg);
}

.main-navigation > ul > li.current-menu-item > a::after {
	transform: translateX(-50%) scaleX(1);
}

/* 子菜单 */
.main-navigation .sub-menu {
	position: absolute;
	top: calc(100% - 2px);
	left: 50%;
	transform: translateX(-50%) translateY(6px) scale(0.96);
	min-width: 200px;
	background: var(--cxb-bg-white);
	border: 1px solid var(--cxb-border);
	border-radius: 12px;
	box-shadow: 0 8px 30px rgba(15, 23, 42, 0.1), 0 2px 8px rgba(15, 23, 42, 0.04);
	opacity: 0;
	visibility: hidden;
	transition: all 0.2s ease;
	z-index: 100;
	padding: 6px;
	transform-origin: top center;
}

.main-navigation li:hover > .sub-menu,
.main-navigation li:focus-within > .sub-menu {
	opacity: 1;
	visibility: visible;
	transform: translateX(-50%) translateY(0) scale(1);
}

.main-navigation .sub-menu li {
	display: block;
	height: auto;
}

.main-navigation .sub-menu a {
	display: block;
	padding: 7px 14px;
	border-radius: 8px;
	font-size: 0.8125rem;
	font-weight: 500;
	color: var(--cxb-text-light);
	text-decoration: none;
	transition: all 0.18s ease;
}

.main-navigation .sub-menu a:hover {
	color: var(--cxb-primary);
	background: var(--cxb-primary-bg);
}

/* 右侧操作区 */
.header-actions {
	display: flex;
	align-items: center;
	gap: 8px;
	flex-shrink: 0;
}

.header-action-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border-radius: 8px;
	color: var(--cxb-text-light);
	text-decoration: none;
	transition: all 0.18s ease;
	position: relative;
}

.header-action-btn:hover {
	background: var(--cxb-primary-bg);
	color: var(--cxb-primary);
}

.header-badge {
	position: absolute;
	top: 2px;
	right: 2px;
	min-width: 16px;
	height: 16px;
	padding: 0 4px;
	background: #EF4444;
	color: #fff;
	font-size: 10px;
	font-weight: 700;
	border-radius: 8px;
	display: flex;
	align-items: center;
	justify-content: center;
	line-height: 1;
	box-shadow: 0 0 0 2px var(--cxb-bg-white);
}

.header-login-btn {
	gap: 6px;
	width: auto;
	padding: 0 14px;
	font-size: 0.8125rem;
	font-weight: 500;
}

.header-user-btn {
	display: flex;
	align-items: center;
	border-radius: 50%;
	transition: box-shadow 0.18s ease;
}

.header-user-btn:hover {
	box-shadow: 0 0 0 3px var(--cxb-primary-bg);
}

.header-avatar {
	width: 30px;
	height: 30px;
	border-radius: 50%;
	object-fit: cover;
}

/* 汉堡菜单按钮 */
.menu-toggle {
	display: none;
	background: none;
	border: none;
	padding: 8px;
	border-radius: 8px;
	cursor: pointer;
	transition: background 0.18s ease;
}

.menu-toggle:hover {
	background: var(--cxb-primary-bg);
}

.menu-toggle-icon {
	display: flex;
	flex-direction: column;
	gap: 5px;
	width: 20px;
}

.menu-toggle-icon .bar {
	display: block;
	width: 100%;
	height: 2px;
	background: var(--cxb-text);
	border-radius: 2px;
	transition: transform 0.25s ease, opacity 0.2s ease;
}

.menu-toggle[aria-expanded="true"] .bar:nth-child(1) {
	transform: rotate(45deg) translate(5px, 5px);
}

.menu-toggle[aria-expanded="true"] .bar:nth-child(2) {
	opacity: 0;
}

.menu-toggle[aria-expanded="true"] .bar:nth-child(3) {
	transform: rotate(-45deg) translate(5px, -5px);
}

/* ===========================
   内容区域
   =========================== */
.site-main {
	min-height: 60vh;
	padding: var(--cxb-spacing-3xl) 0;
}

.content-area {
	display: flex;
	flex-direction: column;
	gap: var(--cxb-spacing-xl);
}

.has-sidebar .content-area {
	width: 100%;
}

/* 单篇文章/页面：侧边栏与内容并排 */
.singular.has-sidebar .container {
	display: flex;
	gap: var(--cxb-spacing-xl);
	align-items: flex-start;
}

.singular.has-sidebar .content-area {
	width: calc(100% - 340px - var(--cxb-spacing-xl));
	flex-shrink: 0;
}

.singular.has-sidebar .widget-area {
	width: 340px;
	margin-top: 0;
	flex-shrink: 0;
	position: sticky;
	top: calc(var(--cxb-header-height) + var(--cxb-spacing-lg));
}

.content-area-full {
	width: 100% !important;
}

/* ===========================
   文章网格
   =========================== */
.posts-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
	gap: var(--cxb-spacing-xl);
}

/* ===========================
   文章卡片
   =========================== */
.post-card {
	background: var(--cxb-bg-white);
	border-radius: var(--cxb-radius-lg);
	overflow: hidden;
	box-shadow: var(--cxb-shadow-sm);
	transition: box-shadow var(--cxb-transition), transform var(--cxb-transition);
}

.post-card:hover {
	box-shadow: var(--cxb-shadow-md);
	transform: translateY(-4px);
}

.post-card-thumbnail {
	display: block;
	overflow: hidden;
	position: relative;
}

.post-card-thumbnail::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(15, 23, 42, 0.02), transparent 40%);
	pointer-events: none;
}

.post-card-thumbnail img {
	display: block;
	width: 100%;
	height: 220px;
	object-fit: cover;
	transition: transform 0.5s ease;
}

.post-card:hover .post-card-thumbnail img {
	transform: scale(1.08);
}

.post-card-body {
	padding: var(--cxb-spacing-lg);
}

.post-card-meta {
	display: flex;
	align-items: center;
	gap: var(--cxb-spacing-md);
	margin-bottom: var(--cxb-spacing-sm);
	font-size: var(--cxb-font-size-xs);
	color: var(--cxb-text-lighter);
}

.post-card-category a {
	display: inline-block;
	padding: 2px 10px;
	background: var(--cxb-primary-bg);
	color: var(--cxb-primary);
	border-radius: 20px;
	font-size: var(--cxb-font-size-xs);
	font-weight: 600;
	text-decoration: none;
	transition: all var(--cxb-transition);
}

.post-card-category a:hover {
	background: var(--cxb-primary);
	color: #fff;
}

.post-card-title {
	margin: 0 0 var(--cxb-spacing-sm);
	font-size: var(--cxb-font-size-lg);
	font-weight: 700;
	line-height: 1.35;
	letter-spacing: -0.3px;
}

.post-card-title a {
	color: var(--cxb-text);
	text-decoration: none;
}

.post-card-title a:hover {
	color: var(--cxb-primary);
}

.post-card-excerpt {
	font-size: var(--cxb-font-size-sm);
	color: var(--cxb-text-light);
	line-height: 1.65;
	margin-bottom: var(--cxb-spacing-md);
}

.post-card-excerpt p {
	margin: 0;
}

.post-card-body {
	padding: var(--cxb-spacing-lg);
}

.post-card-meta {
	display: flex;
	align-items: center;
	gap: var(--cxb-spacing-md);
	margin-bottom: var(--cxb-spacing-sm);
	font-size: var(--cxb-font-size-sm);
	color: var(--cxb-text-lighter);
}

.post-card-category a {
	display: inline-block;
	padding: 2px 10px;
	background: rgba(74, 144, 217, 0.1);
	color: var(--cxb-primary);
	border-radius: 20px;
	font-size: var(--cxb-font-size-xs);
	font-weight: 500;
	text-decoration: none;
}

.post-card-category a:hover {
	background: var(--cxb-primary);
	color: #fff;
}

.post-card-title {
	margin: 0 0 var(--cxb-spacing-sm);
	font-size: var(--cxb-font-size-lg);
	font-weight: 600;
	line-height: 1.4;
}

.post-card-title a {
	color: var(--cxb-text);
	text-decoration: none;
}

.post-card-title a:hover {
	color: var(--cxb-primary);
}

.post-card-excerpt {
	font-size: var(--cxb-font-size-sm);
	color: var(--cxb-text-light);
	line-height: 1.6;
	margin-bottom: var(--cxb-spacing-md);
}

.post-card-excerpt p {
	margin: 0;
}

.read-more {
	display: inline-block;
	margin-top: var(--cxb-spacing-xs);
	font-weight: 600;
	color: var(--cxb-primary);
	text-decoration: none;
	transition: color var(--cxb-transition);
}

.read-more:hover {
	color: var(--cxb-primary-dark);
	text-decoration: underline;
}

.post-card-footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	font-size: var(--cxb-font-size-xs);
	color: var(--cxb-text-lighter);
	padding-top: var(--cxb-spacing-md);
	border-top: 1px solid var(--cxb-border-light);
}

.post-card-footer a {
	color: var(--cxb-text-lighter);
}

.post-card-footer a:hover {
	color: var(--cxb-primary);
}

/* ===========================
   单篇文章
   =========================== */
.singular .site-main {
	padding: var(--cxb-spacing-2xl) 0;
}

/* 内容区域白底卡片（文章/页面） */
.singular .content-area {
	background: var(--cxb-bg-white);
	border-radius: var(--cxb-radius-lg);
	padding: var(--cxb-spacing-xl);
	box-shadow: var(--cxb-shadow-sm);
}

/* 文章正文限制宽度，提升阅读体验 */
.singular .entry-content {
	max-width: 740px;
	margin-left: auto;
	margin-right: auto;
}

.singular .entry-header,
.singular .entry-footer,
.singular .post-thumbnail {
	max-width: 860px;
	margin-left: auto;
	margin-right: auto;
}

/* 宽屏优化：1400px 布局增强 */
@media (min-width: 1280px) {
	.container {
		padding: 0 var(--cxb-spacing-xl);
	}

	.singular .content-area {
		padding: var(--cxb-spacing-xl) var(--cxb-spacing-2xl);
	}

	.hero-title {
		font-size: calc(var(--cxb-font-size-4xl) + 0.5rem);
	}

	.hero-content {
		max-width: 800px;
	}

	/* 文章列表：宽屏下卡片略大 */
	.posts-grid {
		grid-template-columns: repeat(auto-fill, minmax(360px, 1fr));
		gap: var(--cxb-spacing-xl);
	}

	/* 相关文章宽屏微调 */
	.cxb-related-grid {
		gap: var(--cxb-spacing-xl);
	}

	/* 页脚小工具间距 */
	.footer-widgets-grid {
		gap: var(--cxb-spacing-2xl);
	}
}

/* 有侧边栏时减去 padding，由容器控制 */
.singular.has-sidebar .content-area {
	background: var(--cxb-bg-white);
	border-radius: var(--cxb-radius-lg);
	padding: var(--cxb-spacing-xl);
	box-shadow: var(--cxb-shadow-sm);
}

.featured-image {
	display: block;
	width: 100%;
	max-height: 500px;
	object-fit: cover;
	border-radius: var(--cxb-radius-lg);
	margin-bottom: var(--cxb-spacing-xl);
}

.entry-title {
	margin: 0 0 var(--cxb-spacing-lg);
	font-size: var(--cxb-font-size-3xl);
	font-weight: 800;
	line-height: 1.25;
	color: var(--cxb-text);
	letter-spacing: -0.5px;
}

.entry-meta {
	display: flex;
	flex-wrap: wrap;
	gap: var(--cxb-spacing-lg);
	margin-bottom: var(--cxb-spacing-md);
	font-size: var(--cxb-font-size-sm);
	color: var(--cxb-text-lighter);
}

.entry-meta a {
	color: var(--cxb-text-light);
}

.entry-meta a:hover {
	color: var(--cxb-primary);
}

.entry-categories {
	margin-bottom: var(--cxb-spacing-xl);
}

.entry-categories .cat-links a {
	display: inline-block;
	padding: 4px 14px;
	margin: 0 4px 4px 0;
	background: rgba(74, 144, 217, 0.1);
	color: var(--cxb-primary);
	border-radius: 20px;
	font-size: var(--cxb-font-size-sm);
	font-weight: 500;
	text-decoration: none;
}

.entry-categories .cat-links a:hover {
	background: var(--cxb-primary);
	color: #fff;
}

.entry-content {
	font-size: var(--cxb-font-size-base);
	line-height: 1.85;
	color: var(--cxb-text);
}

.entry-content h2,
.entry-content h3,
.entry-content h4 {
	margin-top: var(--cxb-spacing-2xl);
	margin-bottom: var(--cxb-spacing-md);
	letter-spacing: -0.3px;
}

.entry-content p {
	margin: 0 0 var(--cxb-spacing-lg);
}

.entry-content img {
	max-width: 100%;
	height: auto;
	border-radius: var(--cxb-radius-md);
}

.entry-content a {
	color: var(--cxb-primary);
	text-decoration: underline;
	text-underline-offset: 2px;
	text-decoration-thickness: 1px;
}

.entry-content a:hover {
	color: var(--cxb-primary-dark);
}

.entry-content ul,
.entry-content ol {
	padding-left: var(--cxb-spacing-xl);
}

.entry-content li {
	margin-bottom: var(--cxb-spacing-xs);
}

.tag-links {
	margin-top: var(--cxb-spacing-xl);
	padding-top: var(--cxb-spacing-lg);
	border-top: 1px solid var(--cxb-border-light);
}

.tag-links a {
	display: inline-block;
	padding: 4px 14px;
	margin: 0 4px 4px 0;
	background: var(--cxb-bg);
	color: var(--cxb-text-light);
	border-radius: 20px;
	font-size: var(--cxb-font-size-sm);
	text-decoration: none;
	transition: background var(--cxb-transition), color var(--cxb-transition);
}

.tag-links a:hover {
	background: var(--cxb-primary);
	color: #fff;
}

/* ===========================
   文章导航
   =========================== */
.post-navigation {
	margin-top: var(--cxb-spacing-2xl);
	padding: var(--cxb-spacing-lg) 0;
	border-top: 1px solid var(--cxb-border-light);
}

.post-navigation .nav-links {
	display: flex;
	justify-content: space-between;
	gap: var(--cxb-spacing-lg);
}

.post-navigation .nav-previous,
.post-navigation .nav-next {
	flex: 1;
}

.post-navigation a {
	display: block;
	padding: var(--cxb-spacing-md) var(--cxb-spacing-lg);
	background: var(--cxb-bg);
	border-radius: var(--cxb-radius-md);
	transition: background var(--cxb-transition);
}

.post-navigation a:hover {
	background: rgba(91, 127, 255, 0.06);
}

.post-navigation .nav-subtitle {
	display: block;
	font-size: var(--cxb-font-size-xs);
	color: var(--cxb-text-lighter);
	margin-bottom: var(--cxb-spacing-xs);
}

.post-navigation .nav-title {
	font-weight: 600;
	font-size: var(--cxb-font-size-sm);
}

/* ===========================
   分页导航
   =========================== */
.pagination {
	margin-top: var(--cxb-spacing-2xl);
}

.pagination .nav-links {
	display: flex;
	justify-content: center;
	gap: 4px;
}

.pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 38px;
	height: 38px;
	padding: 0 10px;
	border: none;
	border-radius: 8px;
	background: transparent;
	color: var(--cxb-text-light);
	font-size: var(--cxb-font-size-sm);
	font-weight: 500;
	text-decoration: none;
	transition: all var(--cxb-transition);
}

.pagination .page-numbers:hover {
	background: var(--cxb-primary-bg);
	color: var(--cxb-primary);
}

.pagination .page-numbers.current {
	background: var(--cxb-primary);
	color: #fff;
}

.pagination .dots {
	background: none;
}

/* ===========================
   页面标题
   =========================== */
.page-header {
	margin-bottom: var(--cxb-spacing-xl);
}

.page-title {
	margin: 0 0 var(--cxb-spacing-sm);
	font-size: var(--cxb-font-size-3xl);
	font-weight: 700;
}

.page-subtitle {
	margin: 0;
	font-size: var(--cxb-font-size-lg);
	color: var(--cxb-text-lighter);
	font-weight: 400;
}

.archive-description {
	margin-top: var(--cxb-spacing-md);
	font-size: var(--cxb-font-size-base);
	color: var(--cxb-text-light);
}

/* 归档增强 */
.archive-meta-info {
	display: flex;
	gap: var(--cxb-spacing-lg);
	margin-top: var(--cxb-spacing-sm);
	font-size: var(--cxb-font-size-sm);
	color: var(--cxb-text-lighter);
}

.archive-meta-item {
	display: inline-flex;
	align-items: center;
	gap: var(--cxb-spacing-xs);
}

/* 子分类列表 */
.archive-subterms {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--cxb-spacing-sm);
	margin-top: var(--cxb-spacing-md);
	padding: var(--cxb-spacing-md);
	background: var(--cxb-bg);
	border-radius: var(--cxb-radius-md);
}

.subterms-label {
	font-size: var(--cxb-font-size-sm);
	font-weight: 600;
	color: var(--cxb-text);
	margin-right: var(--cxb-spacing-xs);
}

.subterm-link {
	display: inline-flex;
	align-items: center;
	gap: 2px;
	padding: 4px 12px;
	background: var(--cxb-bg-white);
	border: 1px solid var(--cxb-border);
	border-radius: 20px;
	font-size: var(--cxb-font-size-sm);
	color: var(--cxb-text-light);
	text-decoration: none;
	transition: all var(--cxb-transition);
}

.subterm-link:hover {
	border-color: var(--cxb-primary);
	color: var(--cxb-primary);
	background: rgba(74, 144, 217, 0.04);
	text-decoration: none;
}

.subterm-link small {
	color: var(--cxb-text-lighter);
	font-size: var(--cxb-font-size-xs);
}

/* 日期归档导航 */
.archive-date-nav {
	margin-top: var(--cxb-spacing-md);
	padding: var(--cxb-spacing-md);
	background: var(--cxb-bg);
	border-radius: var(--cxb-radius-md);
}

.date-nav-links,
.date-nav-month {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--cxb-spacing-lg);
	font-size: var(--cxb-font-size-sm);
}

.date-nav-month {
	margin-top: var(--cxb-spacing-sm);
}

.date-nav-links a,
.date-nav-month a {
	color: var(--cxb-primary);
	font-weight: 500;
	text-decoration: none;
}

.date-nav-links a:hover,
.date-nav-month a:hover {
	text-decoration: underline;
}

.date-nav-current {
	font-weight: 700;
	font-size: var(--cxb-font-size-lg);
	color: var(--cxb-text);
	padding: 0 var(--cxb-spacing-md);
}

/* 作者归档信息 */
.archive-author-info {
	display: flex;
	align-items: center;
	gap: var(--cxb-spacing-lg);
	margin-top: var(--cxb-spacing-md);
	padding: var(--cxb-spacing-md) var(--cxb-spacing-lg);
	background: var(--cxb-bg);
	border-radius: var(--cxb-radius-md);
}

.archive-author-avatar img {
	border-radius: 50%;
	width: 60px;
	height: 60px;
	object-fit: cover;
}

.archive-author-meta {
	display: flex;
	flex-direction: column;
	gap: var(--cxb-spacing-xs);
	font-size: var(--cxb-font-size-sm);
	color: var(--cxb-text-light);
}

/* 标签云（标签页专用） */
.archive-tag-cloud {
	margin-bottom: var(--cxb-spacing-xl);
	padding: var(--cxb-spacing-lg);
	background: var(--cxb-bg-white);
	border: 1px solid var(--cxb-border-light);
	border-radius: var(--cxb-radius-lg);
}

.tag-cloud-title {
	margin: 0 0 var(--cxb-spacing-md);
	font-size: var(--cxb-font-size-base);
	font-weight: 700;
	color: var(--cxb-text);
}

.tag-cloud-list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--cxb-spacing-sm) var(--cxb-spacing-md);
	line-height: 1.8;
}

.tag-cloud-link {
	display: inline-flex;
	align-items: center;
	gap: 3px;
	padding: 2px 10px;
	background: var(--cxb-bg);
	border-radius: 20px;
	color: var(--cxb-text-light);
	text-decoration: none;
	transition: all var(--cxb-transition);
}

.tag-cloud-link:hover {
	background: var(--cxb-primary);
	color: #fff;
	text-decoration: none;
}

.tag-cloud-link--current {
	background: var(--cxb-primary);
	color: #fff;
	font-weight: 600;
}

.tag-cloud-link small {
	font-size: var(--cxb-font-size-xs);
	opacity: 0.7;
}

.tag-cloud-link:hover small {
	opacity: 1;
}

/* 归档响应式 */
@media (max-width: 768px) {
	.archive-subterms {
		flex-direction: column;
		align-items: flex-start;
	}

	.date-nav-links,
	.date-nav-month {
		flex-direction: column;
		gap: var(--cxb-spacing-sm);
	}

	.archive-author-info {
		flex-direction: column;
		align-items: center;
		text-align: center;
	}
}

/* ===========================
   按钮
   =========================== */
.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 10px 24px;
	font-family: inherit;
	font-size: var(--cxb-font-size-sm);
	font-weight: 600;
	border: none;
	border-radius: 8px;
	cursor: pointer;
	text-decoration: none;
	transition: all var(--cxb-transition);
	gap: 6px;
	line-height: 1.4;
	letter-spacing: 0.2px;
}

.btn-primary {
	background: var(--cxb-primary);
	color: #fff;
}

.btn-primary:hover {
	background: var(--cxb-primary-dark);
	color: #fff;
	text-decoration: none;
	box-shadow: 0 4px 12px rgba(99, 102, 241, 0.3);
	transform: translateY(-1px);
}

.btn-outline {
	background: transparent;
	color: var(--cxb-text-light);
	border: 1.5px solid var(--cxb-border);
}

.btn-outline:hover {
	border-color: var(--cxb-primary);
	color: var(--cxb-primary);
	background: var(--cxb-primary-bg);
	text-decoration: none;
}

/* ===========================
   首页模块
   =========================== */
.home-featured {
	padding: var(--cxb-spacing-xl) 0;
}

.home-featured .section-title {
	margin-bottom: var(--cxb-spacing-lg);
}

.featured-grid {
	display: grid;
	grid-template-columns: 2fr 1fr;
	grid-template-rows: auto auto;
	gap: var(--cxb-spacing-md);
}

.featured-card--large {
	grid-row: span 2;
}

.featured-thumb {
	position: relative;
	display: block;
	border-radius: var(--cxb-radius-lg);
	overflow: hidden;
	height: 100%;
}

.featured-thumb img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.5s ease;
	min-height: 200px;
}

.featured-thumb:hover img {
	transform: scale(1.06);
}

.featured-overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(0,0,0,0.7) 0%, rgba(0,0,0,0.1) 60%, transparent 100%);
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	padding: var(--cxb-spacing-lg);
}

.featured-cat {
	display: inline-block;
	padding: 2px 10px;
	background: rgba(255,255,255,0.2);
	backdrop-filter: blur(4px);
	border-radius: 20px;
	font-size: 12px;
	font-weight: 600;
	color: #fff;
	margin-bottom: var(--cxb-spacing-sm);
	width: fit-content;
}

.featured-title {
	margin: 0;
	font-size: 20px;
	font-weight: 700;
	color: #fff;
	line-height: 1.3;
	text-shadow: 0 1px 4px rgba(0,0,0,0.3);
}

.featured-card--small .featured-title {
	font-size: 15px;
}

.featured-card--small .featured-overlay {
	padding: var(--cxb-spacing-md);
}

/* 批量操作 */
.cxb-bulk-bar {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 10px 16px;
	background: var(--cxb-bg);
	border-radius: var(--cxb-radius-md);
	margin-bottom: var(--cxb-spacing-md);
	flex-wrap: wrap;
}

.cxb-bulk-bar .cxb-selected-count {
	font-size: 13px;
	color: var(--cxb-text-light);
	margin-right: auto;
}

.cxb-bulk-bar select {
	padding: 6px 12px;
	border: 1px solid var(--cxb-border);
	border-radius: 6px;
	font-size: 13px;
	font-family: inherit;
	background: var(--cxb-bg-white);
}

.cxb-bulk-bar .btn-sm {
	padding: 6px 16px;
	font-size: 13px;
}

.post-select-cb {
	width: 18px;
	height: 18px;
	cursor: pointer;
	accent-color: var(--cxb-primary);
}

/* ===========================
   英雄区域
   =========================== */
.hero-section {
	position: relative;
	padding: var(--cxb-spacing-3xl) 0;
	background: linear-gradient(135deg, #1E1B4B 0%, #312E81 40%, #3730A3 70%, #4338CA 100%);
	color: #fff;
	text-align: center;
	overflow: hidden;
}

.hero-section::before {
	content: '';
	position: absolute;
	inset: 0;
	background:
		radial-gradient(ellipse 600px 400px at 20% 30%, rgba(99, 102, 241, 0.3) 0%, transparent 70%),
		radial-gradient(ellipse 500px 300px at 80% 70%, rgba(139, 92, 246, 0.2) 0%, transparent 70%),
		radial-gradient(ellipse 400px 300px at 50% 10%, rgba(129, 140, 248, 0.15) 0%, transparent 70%);
	animation: cxbHeroBg 15s ease-in-out infinite alternate;
}

@keyframes cxbHeroBg {
	0% { transform: scale(1) translate(0, 0); }
	100% { transform: scale(1.05) translate(-1%, -1%); }
}

.hero-content {
	position: relative;
	z-index: 1;
	max-width: 680px;
	margin: 0 auto;
}

.hero-title {
	margin: 0 0 var(--cxb-spacing-md);
	font-size: var(--cxb-font-size-4xl);
	font-weight: 800;
	line-height: 1.1;
	letter-spacing: -1px;
}

.hero-description {
	margin: 0 auto var(--cxb-spacing-xl);
	font-size: var(--cxb-font-size-lg);
	opacity: 0.85;
	line-height: 1.65;
	max-width: 520px;
	color: rgba(255, 255, 255, 0.85);
}

.hero-actions {
	display: flex;
	justify-content: center;
	gap: var(--cxb-spacing-md);
	flex-wrap: wrap;
}

.hero-actions .btn {
	min-width: 150px;
	padding: 12px 28px;
}

.hero-actions .btn-primary {
	background: #fff;
	color: var(--cxb-primary);
}

.hero-actions .btn-primary:hover {
	background: rgba(255, 255, 255, 0.9);
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.2);
}

.hero-actions .btn-outline {
	color: #fff;
	border-color: rgba(255, 255, 255, 0.3);
	background: rgba(255, 255, 255, 0.08);
}

.hero-actions .btn-outline:hover {
	background: rgba(255, 255, 255, 0.15);
	color: #fff;
	border-color: rgba(255, 255, 255, 0.5);
}

/* ===========================
   区块标题
   =========================== */
.section-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: var(--cxb-spacing-xl);
	flex-wrap: wrap;
	gap: var(--cxb-spacing-md);
}

.section-title {
	margin: 0;
	font-size: var(--cxb-font-size-2xl);
	font-weight: 800;
	letter-spacing: -0.5px;
	color: var(--cxb-text);
}

.section-link {
	font-size: var(--cxb-font-size-sm);
	font-weight: 500;
	color: var(--cxb-primary);
}

/* ===========================
   侧边栏
   =========================== */
.widget-area {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	gap: var(--cxb-spacing-xl);
	margin-top: var(--cxb-spacing-2xl);
}

.widget {
	background: var(--cxb-bg-white);
	border-radius: var(--cxb-radius-lg);
	padding: var(--cxb-spacing-lg);
	box-shadow: var(--cxb-shadow-sm);
	flex: 1 1 300px;
}

.widget-title {
	margin: 0 0 var(--cxb-spacing-md);
	font-size: var(--cxb-font-size-sm);
	font-weight: 700;
	position: relative;
	padding-bottom: var(--cxb-spacing-sm);
	color: var(--cxb-text);
	letter-spacing: 0.3px;
}

.widget ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

.widget ul li {
	padding: 8px 0;
	border-bottom: 1px solid var(--cxb-border-light);
}

.widget ul li:first-child {
	padding-top: 0;
}

.widget ul li:last-child {
	border-bottom: none;
	padding-bottom: 0;
}

.widget a {
	font-size: var(--cxb-font-size-sm);
	color: var(--cxb-text-light);
	transition: color var(--cxb-transition);
}

.widget a:hover {
	color: var(--cxb-primary);
}

/* 搜索表单 */
.widget_search .search-form {
	display: flex;
	gap: var(--cxb-spacing-sm);
}

.widget_search input[type="search"] {
	flex: 1;
	padding: 8px 12px;
	border: 1px solid var(--cxb-border);
	border-radius: var(--cxb-radius-sm);
	font-family: inherit;
	font-size: var(--cxb-font-size-sm);
}

.widget_search input[type="search"]:focus {
	outline: none;
	border-color: var(--cxb-primary);
}

.widget_search .search-submit {
	padding: 8px 16px;
	background: var(--cxb-primary);
	color: #fff;
	border: none;
	border-radius: var(--cxb-radius-sm);
	cursor: pointer;
	font-size: var(--cxb-font-size-sm);
	transition: background var(--cxb-transition);
}

.widget_search .search-submit:hover {
	background: var(--cxb-primary-dark);
}

/* 标签云 */
.tagcloud {
	display: flex;
	flex-wrap: wrap;
	gap: var(--cxb-spacing-xs);
}

.tagcloud a {
	display: inline-block;
	padding: 4px 12px;
	background: var(--cxb-bg);
	color: var(--cxb-text-light);
	border-radius: 20px;
	font-size: var(--cxb-font-size-sm) !important;
	text-decoration: none;
	transition: all var(--cxb-transition);
}

.tagcloud a:hover {
	background: var(--cxb-primary);
	color: #fff;
}

/* ===========================
   搜索页面
   =========================== */
.search-result .post-card-body {
	border-left: 3px solid var(--cxb-primary);
}

.post-type-label {
	display: inline-block;
	padding: 2px 10px;
	background: var(--cxb-primary);
	color: #fff;
	border-radius: 4px;
	font-size: var(--cxb-font-size-xs);
	font-weight: 500;
}

/* ===========================
   404页面
   =========================== */
.error-404 {
	text-align: center;
	max-width: 600px;
	margin: 0 auto;
}

.error-404 .page-title {
	font-size: 8rem;
	font-weight: 900;
	line-height: 1;
	margin-bottom: var(--cxb-spacing-xs);
	background: linear-gradient(135deg, var(--cxb-primary), #8B5CF6);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
	letter-spacing: -6px;
}

.error-404 .page-content p {
	font-size: var(--cxb-font-size-lg);
	color: var(--cxb-text-light);
	margin-bottom: var(--cxb-spacing-xl);
}

.error-actions {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--cxb-spacing-lg);
	margin-bottom: var(--cxb-spacing-2xl);
}

.error-actions .search-form {
	display: flex;
	gap: var(--cxb-spacing-sm);
	max-width: 400px;
	width: 100%;
}

.error-actions input[type="search"] {
	flex: 1;
	padding: 12px 16px;
	border: 2px solid var(--cxb-border);
	border-radius: var(--cxb-radius-md);
	font-family: inherit;
	font-size: var(--cxb-font-size-base);
}

.error-actions input[type="search"]:focus {
	outline: none;
	border-color: var(--cxb-primary);
}

.error-actions .search-submit {
	padding: 12px 24px;
	background: var(--cxb-primary);
	color: #fff;
	border: none;
	border-radius: var(--cxb-radius-md);
	cursor: pointer;
	font-size: var(--cxb-font-size-base);
}

.error-suggestions {
	margin-bottom: var(--cxb-spacing-2xl);
}

.error-suggestions h3 {
	margin-bottom: var(--cxb-spacing-md);
}

.error-suggestions ul {
	list-style: none;
	padding: 0;
}

.error-suggestions li {
	padding: var(--cxb-spacing-xs) 0;
	color: var(--cxb-text-light);
}

/* ===========================
   文章互动区（点赞 & 打赏）
   =========================== */
.cxb-post-actions {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--cxb-spacing-lg);
	margin: var(--cxb-spacing-2xl) 0;
	padding: var(--cxb-spacing-lg) 0;
	border-top: 1px solid var(--cxb-border-light);
	border-bottom: 1px solid var(--cxb-border-light);
}

/* 点赞按钮 */
.cxb-like-btn {
	display: inline-flex;
	align-items: center;
	gap: var(--cxb-spacing-sm);
	padding: 9px 20px;
	background: var(--cxb-bg);
	border: none;
	border-radius: 8px;
	cursor: pointer;
	font-family: inherit;
	font-size: var(--cxb-font-size-sm);
	font-weight: 500;
	color: var(--cxb-text-light);
	transition: all var(--cxb-transition);
	line-height: 1;
}

.cxb-like-btn:hover {
	background: rgba(239, 68, 68, 0.08);
	color: #EF4444;
}

.cxb-like-btn.cxb-liked {
	background: rgba(239, 68, 68, 0.1);
	color: #EF4444;
}

.cxb-like-btn svg {
	flex-shrink: 0;
}

.cxb-like-count {
	font-weight: 600;
	font-size: var(--cxb-font-size-xs);
	min-width: 16px;
	text-align: center;
}

/* 打赏按钮 */
.cxb-tip-area {
	display: inline-flex;
}

.cxb-tip-btn {
	display: inline-flex;
	align-items: center;
	gap: var(--cxb-spacing-sm);
	padding: 9px 20px;
	background: rgba(245, 158, 11, 0.1);
	border: none;
	border-radius: 8px;
	cursor: pointer;
	font-family: inherit;
	font-size: var(--cxb-font-size-sm);
	font-weight: 500;
	color: #D97706;
	transition: all var(--cxb-transition);
	line-height: 1;
}

.cxb-tip-btn:hover {
	background: #F59E0B;
	color: #fff;
}

/* 打赏弹窗 */
.cxb-tip-modal {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 10000;
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.3s ease, visibility 0.3s ease;
}

.cxb-tip-modal--show {
	opacity: 1;
	visibility: visible;
}

.cxb-tip-modal-overlay {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: rgba(0, 0, 0, 0.6);
}

.cxb-tip-modal-content {
	position: relative;
	background: var(--cxb-bg-white);
	border-radius: var(--cxb-radius-xl);
	padding: var(--cxb-spacing-2xl);
	max-width: 420px;
	width: 90%;
	text-align: center;
	box-shadow: var(--cxb-shadow-xl);
	transform: scale(0.9);
	transition: transform 0.3s ease;
}

.cxb-tip-modal--show .cxb-tip-modal-content {
	transform: scale(1);
}

.cxb-tip-modal-close {
	position: absolute;
	top: var(--cxb-spacing-sm);
	right: var(--cxb-spacing-md);
	background: none;
	border: none;
	font-size: 1.5rem;
	cursor: pointer;
	color: var(--cxb-text-lighter);
	line-height: 1;
	padding: 4px;
}

.cxb-tip-modal-close:hover {
	color: var(--cxb-text);
}

.cxb-tip-modal-content h3 {
	margin: 0 0 var(--cxb-spacing-sm);
	font-size: var(--cxb-font-size-xl);
	font-weight: 700;
}

.cxb-tip-desc {
	margin: 0 0 var(--cxb-spacing-lg);
	font-size: var(--cxb-font-size-sm);
	color: var(--cxb-text-light);
	line-height: 1.5;
}

.cxb-tip-qr-list {
	display: flex;
	justify-content: center;
	gap: var(--cxb-spacing-xl);
}

.cxb-tip-qr-item {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--cxb-spacing-sm);
}

.cxb-tip-qr-item img {
	width: 150px;
	height: 150px;
	border-radius: var(--cxb-radius-md);
	border: 1px solid var(--cxb-border);
	object-fit: cover;
}

.cxb-tip-qr-label {
	font-size: var(--cxb-font-size-sm);
	font-weight: 600;
	color: var(--cxb-text);
}

/* 互动区响应式 */
@media (max-width: 768px) {
	.cxb-post-actions {
		flex-direction: column;
		gap: var(--cxb-spacing-md);
	}

	.cxb-tip-qr-list {
		flex-direction: column;
		align-items: center;
	}
}

/* ===========================
   相关文章推荐
   =========================== */
.cxb-related-posts {
	margin-top: var(--cxb-spacing-2xl);
}

.cxb-related-title {
	margin: 0 0 var(--cxb-spacing-lg);
	font-size: var(--cxb-font-size-xl);
	font-weight: 800;
	letter-spacing: -0.3px;
	color: var(--cxb-text);
}

.cxb-related-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--cxb-spacing-lg);
}

.cxb-related-item {
	background: var(--cxb-bg-white);
	border-radius: var(--cxb-radius-md);
	overflow: hidden;
	box-shadow: var(--cxb-shadow-sm);
	transition: box-shadow var(--cxb-transition), transform var(--cxb-transition);
}

.cxb-related-item:hover {
	box-shadow: var(--cxb-shadow-md);
	transform: translateY(-3px);
}

.cxb-related-thumb {
	display: block;
	overflow: hidden;
}

.cxb-related-thumb img {
	display: block;
	width: 100%;
	height: 140px;
	object-fit: cover;
	transition: transform 0.4s ease;
}

.cxb-related-item:hover .cxb-related-thumb img {
	transform: scale(1.06);
}

.cxb-related-body {
	padding: var(--cxb-spacing-md);
}

.cxb-related-cat {
	display: inline-block;
	padding: 1px 8px;
	background: rgba(91, 127, 255, 0.08);
	color: var(--cxb-primary);
	border-radius: 4px;
	font-size: var(--cxb-font-size-xs);
	font-weight: 500;
	margin-bottom: var(--cxb-spacing-xs);
}

.cxb-related-post-title {
	margin: 0;
	font-size: var(--cxb-font-size-sm);
	font-weight: 600;
	line-height: 1.4;
}

.cxb-related-post-title a {
	color: var(--cxb-text);
	text-decoration: none;
}

.cxb-related-post-title a:hover {
	color: var(--cxb-primary);
}

@media (max-width: 768px) {
	.cxb-related-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.cxb-related-thumb img {
		height: 110px;
	}
}

@media (max-width: 480px) {
	.cxb-related-grid {
		grid-template-columns: 1fr;
	}
}

/* ===========================
   作者信息框（文章详情页）
   =========================== */
.cxb-author-box {
	margin-top: var(--cxb-spacing-2xl);
	padding: var(--cxb-spacing-xl);
	background: var(--cxb-bg-white);
	border-radius: var(--cxb-radius-lg);
	box-shadow: var(--cxb-shadow-sm);
}

.cxb-author-box-top {
	display: flex;
	gap: var(--cxb-spacing-lg);
	align-items: flex-start;
}

.cxb-author-avatar {
	flex-shrink: 0;
}

.cxb-author-avatar img {
	border-radius: 50%;
	width: 80px;
	height: 80px;
	object-fit: cover;
}

.cxb-author-info {
	flex: 1;
	min-width: 0;
}

.cxb-author-name {
	margin: 0 0 var(--cxb-spacing-xs);
	font-size: var(--cxb-font-size-lg);
	font-weight: 700;
}

.cxb-author-name a {
	color: var(--cxb-text);
	text-decoration: none;
}

.cxb-author-name a:hover {
	color: var(--cxb-primary);
}

.cxb-author-meta {
	display: flex;
	align-items: center;
	gap: var(--cxb-spacing-lg);
	margin-bottom: var(--cxb-spacing-sm);
	font-size: var(--cxb-font-size-sm);
	color: var(--cxb-text-lighter);
	flex-wrap: wrap;
}

.cxb-author-archive-link {
	font-weight: 500;
	color: var(--cxb-primary);
	font-size: var(--cxb-font-size-sm);
}

.cxb-author-archive-link:hover {
	text-decoration: underline;
}

.cxb-author-bio {
	font-size: var(--cxb-font-size-sm);
	color: var(--cxb-text-light);
	line-height: 1.7;
}

.cxb-author-bio p {
	margin: 0;
}

/* 关联文章 */
.cxb-author-posts {
	margin-top: var(--cxb-spacing-lg);
	padding-top: var(--cxb-spacing-lg);
	border-top: 1px solid var(--cxb-border-light);
}

.cxb-author-posts-title {
	margin: 0 0 var(--cxb-spacing-md);
	font-size: var(--cxb-font-size-base);
	font-weight: 600;
	color: var(--cxb-text);
}

.cxb-author-posts-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--cxb-spacing-md);
}

.cxb-author-post-item {
	display: flex;
	flex-direction: column;
	gap: var(--cxb-spacing-xs);
}

.cxb-author-post-thumb {
	display: block;
	overflow: hidden;
	border-radius: var(--cxb-radius-sm);
}

.cxb-author-post-thumb img {
	display: block;
	width: 100%;
	height: 100px;
	object-fit: cover;
	border-radius: var(--cxb-radius-sm);
	transition: transform var(--cxb-transition);
}

.cxb-author-post-thumb:hover img {
	transform: scale(1.05);
}

.cxb-author-post-title {
	margin: 0;
	font-size: var(--cxb-font-size-sm);
	font-weight: 500;
	line-height: 1.4;
}

.cxb-author-post-title a {
	color: var(--cxb-text);
	text-decoration: none;
}

.cxb-author-post-title a:hover {
	color: var(--cxb-primary);
}

.cxb-author-post-date {
	font-size: var(--cxb-font-size-xs);
	color: var(--cxb-text-lighter);
}

@media (max-width: 768px) {
	.cxb-author-box-top {
		flex-direction: column;
		align-items: center;
		text-align: center;
	}

	.cxb-author-meta {
		justify-content: center;
	}

	.cxb-author-posts-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 480px) {
	.cxb-author-posts-grid {
		grid-template-columns: 1fr;
	}
}

/* ===========================
   评论
   =========================== */
.comments-area {
	margin-top: var(--cxb-spacing-2xl);
	padding-top: var(--cxb-spacing-xl);
	border-top: 1px solid var(--cxb-border-light);
}

.comments-title {
	margin: 0 0 var(--cxb-spacing-lg);
	font-size: var(--cxb-font-size-xl);
	font-weight: 700;
}

.comment-list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.comment-list ol.children {
	list-style: none;
	margin-left: var(--cxb-spacing-xl);
	padding-left: var(--cxb-spacing-lg);
	border-left: 2px solid var(--cxb-border-light);
}

.comment {
	padding: var(--cxb-spacing-lg) 0;
	border-bottom: 1px solid var(--cxb-border-light);
}

.comment-body {
	display: flex;
	gap: var(--cxb-spacing-lg);
}

.comment-author .avatar {
	border-radius: 50%;
	width: 48px;
	height: 48px;
}

.comment-content {
	flex: 1;
}

.comment-author .fn {
	font-weight: 600;
	font-style: normal;
}

.comment-metadata {
	font-size: var(--cxb-font-size-xs);
	color: var(--cxb-text-lighter);
	margin-bottom: var(--cxb-spacing-sm);
}

.comment-metadata a {
	color: var(--cxb-text-lighter);
}

.reply a {
	font-size: var(--cxb-font-size-sm);
	color: var(--cxb-primary);
}

/* 评论表单 */
.comment-respond {
	margin-top: var(--cxb-spacing-xl);
}

.comment-reply-title {
	margin: 0 0 var(--cxb-spacing-lg);
	font-size: var(--cxb-font-size-xl);
	font-weight: 700;
}

.comment-form {
	display: flex;
	flex-direction: column;
	gap: var(--cxb-spacing-lg);
}

.comment-form label {
	display: block;
	font-size: var(--cxb-font-size-sm);
	font-weight: 500;
	margin-bottom: var(--cxb-spacing-xs);
}

.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"],
.comment-form textarea {
	width: 100%;
	padding: 12px 16px;
	border: 1px solid var(--cxb-border);
	border-radius: var(--cxb-radius-md);
	font-family: inherit;
	font-size: var(--cxb-font-size-base);
	transition: all var(--cxb-transition);
	background: var(--cxb-bg);
}

.comment-form input:focus,
.comment-form textarea:focus {
	outline: none;
	border-color: var(--cxb-primary);
	box-shadow: 0 0 0 4px var(--cxb-primary-bg);
	background: var(--cxb-bg-white);
}

.comment-form textarea {
	min-height: 150px;
	resize: vertical;
}

.comment-form-cookies-consent {
	display: flex;
	align-items: center;
	gap: var(--cxb-spacing-sm);
}

.comment-form-cookies-consent label {
	margin: 0;
}

.form-submit .submit {
	margin-top: var(--cxb-spacing-md);
}

/* ===========================
   页脚
   =========================== */
.site-footer {
	background: #1a1a2e;
	color: #64748B;
	margin-top: var(--cxb-spacing-3xl);
}

.footer-widgets {
	padding: var(--cxb-spacing-3xl) 0;
}

.footer-widgets-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--cxb-spacing-xl);
}

.footer-column .widget {
	background: transparent;
	box-shadow: none;
	padding: 0;
}

.footer-column .widget-title {
	color: #F1F5F9;
	font-weight: 700;
	font-size: var(--cxb-font-size-sm);
	border-bottom: none;
	padding-bottom: 0;
	margin-bottom: var(--cxb-spacing-md);
	letter-spacing: 0.5px;
	text-transform: uppercase;
}

.footer-column a {
	color: #64748B;
	font-size: var(--cxb-font-size-sm);
	transition: color var(--cxb-transition);
}

.footer-column a:hover {
	color: #F1F5F9;
}

.footer-column ul li {
	border-bottom: none;
	padding: 3px 0;
}

.footer-bottom {
	padding: var(--cxb-spacing-lg) 0;
	border-top: 1px solid rgba(255, 255, 255, 0.05);
}

.footer-bottom-content {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--cxb-spacing-lg);
	flex-wrap: wrap;
}

.footer-nav ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	gap: var(--cxb-spacing-lg);
}

.footer-nav a {
	color: #64748B;
	font-size: var(--cxb-font-size-sm);
	text-decoration: none;
}

.footer-nav a:hover {
	color: #F1F5F9;
}

.site-info {
	text-align: right;
}

.site-info p {
	margin: 0;
	font-size: var(--cxb-font-size-sm);
	color: #475569;
}

.site-info a {
	color: #818CF8;
}

.site-info a:hover {
	color: #A5B4FC;
}

.theme-info {
	margin-top: var(--cxb-spacing-xs);
	opacity: 0.6;
}

/* ===========================
   编辑器内容样式
   =========================== */
.wp-block-button__link {
	background: var(--cxb-primary);
	color: #fff;
	padding: 12px 28px;
	border-radius: var(--cxb-radius-md);
	text-decoration: none;
}

.wp-block-table {
	border-collapse: collapse;
	width: 100%;
}

.wp-block-table td,
.wp-block-table th {
	padding: var(--cxb-spacing-sm) var(--cxb-spacing-md);
	border: 1px solid var(--cxb-border);
}

.wp-block-table th {
	background: var(--cxb-bg);
	font-weight: 600;
}

.wp-block-quote {
	border-left: 3px solid var(--cxb-primary);
	padding: var(--cxb-spacing-lg) var(--cxb-spacing-xl);
	margin: var(--cxb-spacing-xl) 0;
	background: var(--cxb-primary-bg);
	border-radius: 0 var(--cxb-radius-md) var(--cxb-radius-md) 0;
}

.wp-block-quote p {
	margin: 0;
	font-style: italic;
	color: var(--cxb-text-light);
	font-size: var(--cxb-font-size-lg);
}

.wp-block-code {
	border-radius: var(--cxb-radius-md);
}

/* ===========================
   响应式设计
   =========================== */
@media (max-width: 1024px) {

	.footer-widgets-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 768px) {
	:root {
		--cxb-font-size-3xl: 1.75rem;
		--cxb-font-size-4xl: 2rem;
	}

	/* 移动端导航 */
	.menu-toggle {
		display: flex;
	}

	.main-navigation {
		position: fixed;
		top: 64px;
		left: 0;
		right: 0;
		bottom: 0;
		background: rgba(255, 255, 255, 0.98);
		backdrop-filter: blur(20px);
		z-index: 999;
		padding: var(--cxb-spacing-lg);
		opacity: 0;
		visibility: hidden;
		transform: translateY(-8px);
		transition: all 0.25s ease;
		overflow-y: auto;
		justify-content: flex-start;
	}

	.main-navigation.toggled {
		opacity: 1;
		visibility: visible;
		transform: translateY(0);
	}

	.main-navigation > div {
		height: auto;
		width: 100%;
	}

	.main-navigation ul {
		flex-direction: column;
		align-items: stretch;
		height: auto;
		gap: 4px;
	}

	.main-navigation li {
		height: auto;
	}

	.main-navigation > ul > li > a {
		height: 44px;
		padding: 0 16px;
		font-size: 0.9375rem;
		justify-content: flex-start;
	}

	.main-navigation > ul > li > a::after {
		display: none;
	}

	.main-navigation .sub-menu {
		position: static;
		opacity: 1;
		visibility: visible;
		transform: none;
		box-shadow: none;
		border: none;
		border-radius: 0;
		background: transparent;
		padding: 0 0 0 var(--cxb-spacing-lg);
		margin-top: 2px;
	}

	.main-navigation .sub-menu a {
		padding: 10px 16px;
		font-size: 0.875rem;
	}

	/* 隐藏桌面端操作按钮，移动端只看汉堡 */
	.header-login-btn span,
	.header-action-btn:not(.menu-toggle) {
		display: none;
	}

	.posts-grid {
		grid-template-columns: 1fr;
	}

	.hero-section {
		padding: var(--cxb-spacing-2xl) 0;
	}

	.hero-title {
		font-size: var(--cxb-font-size-3xl);
	}

	.hero-actions {
		flex-direction: column;
		align-items: center;
	}

	.hero-actions .btn {
		width: 100%;
		max-width: 280px;
	}

	/* 单页/文章：移动端隐藏侧边栏 */
	.singular.has-sidebar .container {
		flex-direction: column;
	}

	.singular.has-sidebar .content-area {
		width: 100%;
	}

	.singular.has-sidebar .widget-area {
		display: none;
	}

	.entry-title {
		font-size: var(--cxb-font-size-2xl);
	}

	.entry-meta {
		flex-direction: column;
		gap: var(--cxb-spacing-xs);
	}

	.footer-widgets-grid {
		grid-template-columns: 1fr;
	}

	.footer-bottom-content {
		flex-direction: column;
		text-align: center;
	}

	.site-info {
		text-align: center;
	}

	.footer-nav ul {
		justify-content: center;
	}

	.comment-list ol.children {
		margin-left: var(--cxb-spacing-md);
		padding-left: var(--cxb-spacing-md);
	}

	.post-navigation .nav-links {
		flex-direction: column;
		gap: var(--cxb-spacing-md);
	}

	.error-404 .page-title {
		font-size: 5rem;
	}
}

@media (max-width: 480px) {
	.container {
		padding: 0 var(--cxb-spacing-md);
	}

	.site-main {
		padding: var(--cxb-spacing-xl) 0;
	}

	.hero-section {
		padding: var(--cxb-spacing-xl) 0;
	}

	.post-card-body {
		padding: var(--cxb-spacing-md);
	}

	.widget {
		padding: var(--cxb-spacing-md);
	}
}

/* ===========================
   自定义小工具
   =========================== */
.cxb-widget-list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.cxb-widget-list li {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 8px 0;
	border-bottom: 1px solid var(--cxb-border-light);
	flex-wrap: wrap;
}

.cxb-widget-list li:first-child {
	padding-top: 0;
}

.cxb-widget-list li:last-child {
	border-bottom: none;
	padding-bottom: 0;
}

.cxb-widget-rank {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 22px;
	height: 22px;
	border-radius: 4px;
	background: var(--cxb-border);
	color: var(--cxb-text-lighter);
	font-size: 11px;
	font-weight: 700;
	flex-shrink: 0;
}

.cxb-widget-list li:nth-child(1) .cxb-widget-rank {
	background: #f59e0b;
	color: #fff;
}

.cxb-widget-list li:nth-child(2) .cxb-widget-rank {
	background: #94a3b8;
	color: #fff;
}

.cxb-widget-list li:nth-child(3) .cxb-widget-rank {
	background: #d97706;
	color: #fff;
}

.cxb-widget-list a {
	flex: 1;
	font-size: 13px;
	line-height: 1.4;
}

.cxb-widget-list small {
	width: 100%;
	font-size: 11px;
	color: var(--cxb-text-lighter);
}

/* 最新评论小工具 */
.cxb-comment-list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.cxb-comment-list li {
	display: flex;
	gap: 8px;
	padding: 8px 0;
	border-bottom: 1px solid var(--cxb-border-light);
}

.cxb-comment-list li:first-child {
	padding-top: 0;
}

.cxb-comment-list li:last-child {
	border-bottom: none;
	padding-bottom: 0;
}

.cxb-comment-avatar {
	flex-shrink: 0;
}

.cxb-comment-avatar img {
	border-radius: 50%;
	width: 32px;
	height: 32px;
}

.cxb-comment-body {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.cxb-comment-author {
	font-size: 12px;
	color: var(--cxb-text);
}

.cxb-comment-text {
	font-size: 12px;
	color: var(--cxb-text-lighter);
	line-height: 1.4;
}

.cxb-comment-post {
	font-size: 11px;
	color: var(--cxb-primary);
}

/* ===========================
   评论投票
   =========================== */
.cxb-comment-votes {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	margin-right: 8px;
}

.cxb-vote-btn {
	display: inline-flex;
	align-items: center;
	gap: 3px;
	padding: 3px 8px;
	background: var(--cxb-bg);
	border: 1px solid var(--cxb-border);
	border-radius: 4px;
	cursor: pointer;
	font-size: 11px;
	color: var(--cxb-text-lighter);
	font-family: inherit;
	transition: all 0.2s ease;
}

.cxb-vote-up:hover {
	color: #10b981;
	border-color: #10b981;
	background: rgba(16, 185, 129, 0.06);
}

.cxb-vote-down:hover {
	color: #ef4444;
	border-color: #ef4444;
	background: rgba(239, 68, 68, 0.06);
}

/* ===========================
   站点公告
   =========================== */
.cxb-announcement {
	font-size: 14px;
	position: relative;
	z-index: 99;
}

.cxb-announcement .container {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 10px 16px;
}

/* ===========================
   管理面板
   =========================== */
.cxb-admin {
	max-width: 1400px;
	margin: 0 auto;
}

.cxb-admin-header h1 {
	font-size: var(--cxb-font-size-2xl);
}

.cxb-admin-tabs .tab-link {
	padding: var(--cxb-spacing-md) var(--cxb-spacing-xl);
}

.cxb-admin-content {
	padding: var(--cxb-spacing-xl);
}

/* 宽屏下审核卡片列表优化 */
.cxb-review-card {
	padding: var(--cxb-spacing-lg);
	gap: var(--cxb-spacing-xl);
}

.cxb-review-thumb {
	width: 140px;
	height: 90px;
}

.cxb-review-excerpt {
	font-size: var(--cxb-font-size-base);
}

@media (min-width: 1280px) {
	.cxb-review-list {
		display: grid;
		grid-template-columns: repeat(2, 1fr);
		gap: var(--cxb-spacing-lg);
	}

	.cxb-review-card {
		margin: 0;
	}
}

.cxb-admin-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: var(--cxb-spacing-xl);
	flex-wrap: wrap;
	gap: var(--cxb-spacing-md);
}

.cxb-admin-header h1 {
	margin: 0;
	font-size: var(--cxb-font-size-2xl);
	font-weight: 700;
}

.cxb-admin-tabs {
	display: flex;
	gap: 0;
	margin-bottom: var(--cxb-spacing-xl);
	border-bottom: 2px solid var(--cxb-border-light);
	overflow-x: auto;
}

.cxb-admin-tabs .tab-link {
	display: flex;
	align-items: center;
	gap: var(--cxb-spacing-sm);
	padding: var(--cxb-spacing-md) var(--cxb-spacing-lg);
	color: var(--cxb-text-lighter);
	font-size: var(--cxb-font-size-sm);
	font-weight: 500;
	text-decoration: none;
	border-bottom: 2px solid transparent;
	margin-bottom: -2px;
	transition: all var(--cxb-transition);
	white-space: nowrap;
}

.cxb-admin-tabs .tab-link:hover {
	color: var(--cxb-text);
	background: rgba(74, 144, 217, 0.04);
}

.cxb-admin-tabs .tab-link.active {
	color: var(--cxb-primary);
	border-bottom-color: var(--cxb-primary);
}

.cxb-admin-tabs .tab-badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 20px;
	height: 20px;
	padding: 0 6px;
	background: var(--cxb-primary);
	color: #fff;
	font-size: 11px;
	font-weight: 600;
	border-radius: 10px;
	line-height: 1;
}

.cxb-admin-content {
	background: var(--cxb-bg-white);
	border-radius: var(--cxb-radius-lg);
	padding: var(--cxb-spacing-xl);
	box-shadow: var(--cxb-shadow-sm);
}

.cxb-tab-panel {
	min-height: 300px;
}

.cxb-tab-title {
	margin: 0 0 var(--cxb-spacing-lg);
	font-size: var(--cxb-font-size-lg);
	font-weight: 700;
}

.cxb-tab-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: var(--cxb-spacing-lg);
	flex-wrap: wrap;
	gap: var(--cxb-spacing-md);
}

.cxb-tab-header .cxb-tab-title {
	margin: 0;
}

.cxb-search-form {
	display: flex;
	gap: var(--cxb-spacing-sm);
}

.cxb-search-form input[type="search"] {
	padding: 8px 14px;
	border: 1px solid var(--cxb-border);
	border-radius: var(--cxb-radius-sm);
	font-family: inherit;
	font-size: var(--cxb-font-size-sm);
	min-width: 220px;
}

.cxb-search-form input:focus {
	outline: none;
	border-color: var(--cxb-primary);
}

.cxb-search-form button {
	padding: 8px 18px;
	background: var(--cxb-primary);
	color: #fff;
	border: none;
	border-radius: var(--cxb-radius-sm);
	cursor: pointer;
	font-size: var(--cxb-font-size-sm);
	transition: background var(--cxb-transition);
}

.cxb-search-form button:hover {
	background: var(--cxb-primary-dark);
}

/* 审核卡片 */
.cxb-review-list {
	display: flex;
	flex-direction: column;
	gap: var(--cxb-spacing-lg);
}

.cxb-review-card {
	display: flex;
	gap: var(--cxb-spacing-lg);
	padding: var(--cxb-spacing-lg);
	border: 1px solid var(--cxb-border-light);
	border-radius: var(--cxb-radius-md);
	transition: box-shadow var(--cxb-transition);
}

.cxb-review-card:hover {
	box-shadow: var(--cxb-shadow-sm);
	border-color: var(--cxb-border);
}

.cxb-review-thumb {
	flex-shrink: 0;
	width: 120px;
	height: 80px;
	overflow: hidden;
	border-radius: var(--cxb-radius-sm);
}

.cxb-review-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.cxb-review-thumb-placeholder {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--cxb-bg);
	color: var(--cxb-text-lighter);
}

.cxb-review-body {
	flex: 1;
	min-width: 0;
}

.cxb-review-title {
	margin: 0 0 var(--cxb-spacing-xs);
	font-size: var(--cxb-font-size-base);
	font-weight: 600;
}

.cxb-review-title a {
	color: var(--cxb-text);
}

.cxb-review-title a:hover {
	color: var(--cxb-primary);
}

.cxb-review-meta {
	display: flex;
	flex-wrap: wrap;
	gap: var(--cxb-spacing-md);
	margin-bottom: var(--cxb-spacing-sm);
	font-size: var(--cxb-font-size-xs);
	color: var(--cxb-text-lighter);
}

.cxb-review-excerpt {
	font-size: var(--cxb-font-size-sm);
	color: var(--cxb-text-light);
	margin-bottom: var(--cxb-spacing-sm);
	line-height: 1.5;
}

.cxb-review-actions {
	display: flex;
	gap: var(--cxb-spacing-sm);
	flex-wrap: wrap;
}

.btn-approve {
	background: #e8f5e9;
	color: #2e7d32;
}

.btn-approve:hover {
	background: #2e7d32;
	color: #fff;
	text-decoration: none;
}

.btn-reject {
	background: #fbe9e7;
	color: #c62828;
}

.btn-reject:hover {
	background: #c62828;
	color: #fff;
	text-decoration: none;
}

/* 用户管理 */
.cxb-user-table-wrap {
	overflow-x: auto;
}

.cxb-user-cell {
	display: flex;
	align-items: center;
	gap: var(--cxb-spacing-sm);
}

.cxb-user-cell img {
	border-radius: 50%;
	width: 32px;
	height: 32px;
}

.cxb-user-cell small {
	display: block;
	color: var(--cxb-text-lighter);
	font-size: var(--cxb-font-size-xs);
}

.cxb-role-tag {
	display: inline-block;
	padding: 2px 10px;
	background: #e3f2fd;
	color: #1565c0;
	border-radius: 20px;
	font-size: var(--cxb-font-size-xs);
	font-weight: 500;
}

.cxb-inline-role-form {
	margin-top: var(--cxb-spacing-xs);
}

.cxb-inline-role-form select {
	padding: 4px 8px;
	border: 1px solid var(--cxb-border);
	border-radius: var(--cxb-radius-sm);
	font-size: var(--cxb-font-size-xs);
}

.cxb-visible {
	display: block !important;
}

/* 用户详情 */
.cxb-back-link {
	display: inline-block;
	margin-bottom: var(--cxb-spacing-lg);
	font-size: var(--cxb-font-size-sm);
	color: var(--cxb-text-lighter);
}

.cxb-back-link:hover {
	color: var(--cxb-primary);
}

.cxb-user-detail-header {
	display: flex;
	align-items: center;
	gap: var(--cxb-spacing-lg);
	margin-bottom: var(--cxb-spacing-xl);
	padding-bottom: var(--cxb-spacing-lg);
	border-bottom: 1px solid var(--cxb-border-light);
}

.cxb-user-detail-avatar img {
	border-radius: 50%;
	width: 80px;
	height: 80px;
	object-fit: cover;
}

.cxb-user-detail-info h2 {
	margin: 0 0 var(--cxb-spacing-xs);
	font-size: var(--cxb-font-size-xl);
	font-weight: 700;
}

.cxb-user-detail-email {
	margin: 0 0 var(--cxb-spacing-xs);
	color: var(--cxb-text-lighter);
	font-size: var(--cxb-font-size-sm);
}

.cxb-user-detail-meta {
	margin: 0;
	font-size: var(--cxb-font-size-xs);
	color: var(--cxb-text-lighter);
	display: flex;
	gap: var(--cxb-spacing-lg);
}

/* 设置 */
.cxb-settings-form {
	max-width: 600px;
}

.cxb-field-desc {
	margin: var(--cxb-spacing-xs) 0 0;
	font-size: var(--cxb-font-size-xs);
	color: var(--cxb-text-lighter);
}

/* ===========================
   私信中心
   =========================== */
.cxb-messages {
	max-width: 1200px;
	margin: 0 auto;
}

.cxb-msg-item {
	padding: var(--cxb-spacing-lg);
}

.cxb-msg-subject {
	font-size: var(--cxb-font-size-lg);
}

@media (min-width: 1280px) {
	.cxb-msg-list {
		display: grid;
		grid-template-columns: 1fr;
	}
}

.cxb-msg-list {
	display: flex;
	flex-direction: column;
	gap: var(--cxb-spacing-md);
}

.cxb-msg-item {
	display: flex;
	gap: var(--cxb-spacing-lg);
	padding: var(--cxb-spacing-lg);
	border: 1px solid var(--cxb-border-light);
	border-radius: var(--cxb-radius-md);
	transition: box-shadow var(--cxb-transition);
}

.cxb-msg-item:hover {
	box-shadow: var(--cxb-shadow-sm);
}

.cxb-msg-unread {
	background: rgba(74, 144, 217, 0.03);
	border-left: 3px solid var(--cxb-primary);
}

.cxb-msg-avatar {
	flex-shrink: 0;
}

.cxb-msg-avatar img {
	border-radius: 50%;
	width: 40px;
	height: 40px;
	object-fit: cover;
}

.cxb-msg-body {
	flex: 1;
	min-width: 0;
}

.cxb-msg-header {
	display: flex;
	align-items: center;
	gap: var(--cxb-spacing-md);
	margin-bottom: var(--cxb-spacing-xs);
	flex-wrap: wrap;
}

.cxb-msg-from {
	font-weight: 600;
	font-size: var(--cxb-font-size-sm);
	color: var(--cxb-text);
}

.cxb-msg-date {
	font-size: var(--cxb-font-size-xs);
	color: var(--cxb-text-lighter);
}

.cxb-msg-badge {
	display: inline-block;
	padding: 1px 8px;
	background: var(--cxb-primary);
	color: #fff;
	border-radius: 10px;
	font-size: 10px;
	font-weight: 600;
}

.cxb-msg-subject {
	margin: 0 0 var(--cxb-spacing-xs);
	font-size: var(--cxb-font-size-base);
	font-weight: 600;
}

.cxb-msg-content {
	font-size: var(--cxb-font-size-sm);
	color: var(--cxb-text-light);
	line-height: 1.5;
	margin-bottom: var(--cxb-spacing-sm);
}

.cxb-msg-actions {
	display: flex;
	gap: var(--cxb-spacing-sm);
}

.cxb-reply-form-wrap {
	margin-top: var(--cxb-spacing-md);
	padding: var(--cxb-spacing-md);
	background: var(--cxb-bg);
	border-radius: var(--cxb-radius-md);
}

.cxb-reply-form-wrap .cxb-form {
	gap: var(--cxb-spacing-sm);
}

.cxb-reply-form-wrap input[type="text"],
.cxb-reply-form-wrap textarea {
	width: 100%;
	padding: 8px 12px;
	border: 1px solid var(--cxb-border);
	border-radius: var(--cxb-radius-sm);
	font-family: inherit;
	font-size: var(--cxb-font-size-sm);
}

.cxb-reply-form-wrap input:focus,
.cxb-reply-form-wrap textarea:focus {
	outline: none;
	border-color: var(--cxb-primary);
}

/* 通知列表 */
.cxb-notice-section {
	border-left: 3px solid var(--cxb-primary);
}

.cxb-notice-list {
	display: flex;
	flex-direction: column;
}

.cxb-notice-item {
	display: flex;
	align-items: flex-start;
	gap: var(--cxb-spacing-sm);
	padding: var(--cxb-spacing-sm) 0;
	border-bottom: 1px solid var(--cxb-border-light);
	font-size: var(--cxb-font-size-sm);
}

.cxb-notice-item:last-child {
	border-bottom: none;
}

.cxb-notice-item--unread {
	font-weight: 600;
}

.cxb-notice-icon {
	flex-shrink: 0;
	width: 24px;
	text-align: center;
	font-size: var(--cxb-font-size-sm);
}

.cxb-notice-content {
	flex: 1;
}

.cxb-notice-content a {
	color: var(--cxb-text);
}

.cxb-notice-content a:hover {
	color: var(--cxb-primary);
}

.cxb-notice-content small {
	display: block;
	font-size: var(--cxb-font-size-xs);
	color: var(--cxb-text-lighter);
	font-weight: 400;
	margin-top: 2px;
}

/* 徽标 */
.cxb-badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 18px;
	height: 18px;
	padding: 0 5px;
	background: #e53935;
	color: #fff;
	font-size: 10px;
	font-weight: 700;
	border-radius: 9px;
	line-height: 1;
	margin-left: 4px;
}

/* 管理面板响应式 */
@media (max-width: 768px) {
	.cxb-review-card {
		flex-direction: column;
	}

	.cxb-review-thumb {
		width: 100%;
		height: 160px;
	}

	.cxb-user-detail-header {
		flex-direction: column;
		text-align: center;
	}

	.cxb-user-detail-meta {
		flex-direction: column;
		align-items: center;
		gap: var(--cxb-spacing-xs);
	}

	.cxb-tab-header {
		flex-direction: column;
		align-items: stretch;
	}

	.cxb-search-form {
		flex-direction: column;
	}

	.cxb-search-form input[type="search"] {
		min-width: auto;
	}
}

/* ===========================
   用户投稿 & 个人中心
   =========================== */

/* 通知消息 */
.cxb-notice {
	padding: var(--cxb-spacing-md) var(--cxb-spacing-lg);
	border-radius: var(--cxb-radius-md);
	margin-bottom: var(--cxb-spacing-lg);
	font-size: var(--cxb-font-size-sm);
	animation: cxbFadeIn 0.3s ease;
}

.cxb-notice--success {
	background: #e8f5e9;
	color: #2e7d32;
	border: 1px solid #c8e6c9;
}

.cxb-notice--error {
	background: #fbe9e7;
	color: #c62828;
	border: 1px solid #ffccbc;
}

.cxb-notice p {
	margin: 0;
}

/* 登录/注册 */
.cxb-auth-wrap {
	display: flex;
	justify-content: center;
	padding: var(--cxb-spacing-3xl) 0;
}

.cxb-auth-box {
	width: 100%;
	max-width: 440px;
	background: var(--cxb-bg-white);
	border-radius: var(--cxb-radius-lg);
	padding: var(--cxb-spacing-2xl);
	box-shadow: var(--cxb-shadow-md);
}

.cxb-auth-title {
	margin: 0 0 var(--cxb-spacing-xl);
	font-size: var(--cxb-font-size-2xl);
	font-weight: 700;
	text-align: center;
	color: var(--cxb-text);
}

.cxb-auth-links {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--cxb-spacing-sm);
	margin-top: var(--cxb-spacing-lg);
	font-size: var(--cxb-font-size-sm);
}

.cxb-auth-links a {
	color: var(--cxb-text-lighter);
}

.cxb-auth-links a:hover {
	color: var(--cxb-primary);
}

/* 表单通用 */
.cxb-form {
	display: flex;
	flex-direction: column;
	gap: var(--cxb-spacing-lg);
}

.cxb-form-field label {
	display: block;
	margin-bottom: var(--cxb-spacing-xs);
	font-size: var(--cxb-font-size-sm);
	font-weight: 600;
	color: var(--cxb-text);
}

.cxb-form-field input[type="text"],
.cxb-form-field input[type="email"],
.cxb-form-field input[type="password"],
.cxb-form-field input[type="url"],
.cxb-form-field select,
.cxb-form-field textarea {
	width: 100%;
	padding: 12px 16px;
	border: 1px solid var(--cxb-border);
	border-radius: var(--cxb-radius-md);
	font-family: inherit;
	font-size: var(--cxb-font-size-base);
	transition: border-color var(--cxb-transition);
	background: var(--cxb-bg-white);
}

.cxb-form-field input:focus,
.cxb-form-field select:focus,
.cxb-form-field textarea:focus {
	outline: none;
	border-color: var(--cxb-primary);
	box-shadow: 0 0 0 3px rgba(74, 144, 217, 0.1);
}

.cxb-form-checkbox label {
	display: flex;
	align-items: center;
	gap: var(--cxb-spacing-sm);
	font-weight: 400;
	cursor: pointer;
}

.cxb-form-checkbox input[type="checkbox"] {
	width: 18px;
	height: 18px;
	cursor: pointer;
}

.cxb-form-submit {
	margin-top: var(--cxb-spacing-sm);
}

.btn-block {
	display: flex;
	width: 100%;
	justify-content: center;
}

/* 个人中心 */
.cxb-dashboard {
	max-width: 1200px;
	margin: 0 auto;
}

.cxb-dashboard-header {
	padding: var(--cxb-spacing-xl);
}

.cxb-dashboard-stats {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--cxb-spacing-lg);
}

.cxb-dashboard-section {
	padding: var(--cxb-spacing-xl);
}

.cxb-post-table th,
.cxb-post-table td {
	padding: var(--cxb-spacing-md) var(--cxb-spacing-lg);
}

@media (min-width: 1280px) {
	.cxb-dashboard-header {
		display: flex;
		flex-direction: row;
		justify-content: space-between;
		align-items: center;
	}

	.cxb-user-info {
		flex-direction: row;
		text-align: left;
	}

	.cxb-dashboard-stats {
		gap: var(--cxb-spacing-xl);
	}
}

.cxb-dashboard-header {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	gap: var(--cxb-spacing-lg);
	margin-bottom: var(--cxb-spacing-2xl);
	padding: var(--cxb-spacing-xl);
	background: var(--cxb-bg-white);
	border-radius: var(--cxb-radius-lg);
	box-shadow: var(--cxb-shadow-sm);
	flex-wrap: wrap;
}

.cxb-user-info {
	display: flex;
	align-items: center;
	gap: var(--cxb-spacing-lg);
}

.cxb-user-avatar img {
	border-radius: 50%;
	width: 80px;
	height: 80px;
	object-fit: cover;
}

.cxb-user-meta h2 {
	margin: 0 0 var(--cxb-spacing-xs);
	font-size: var(--cxb-font-size-xl);
	font-weight: 700;
}

.cxb-user-email {
	margin: 0 0 var(--cxb-spacing-xs);
	font-size: var(--cxb-font-size-sm);
	color: var(--cxb-text-lighter);
}

.cxb-user-joined {
	font-size: var(--cxb-font-size-xs);
	color: var(--cxb-text-lighter);
}

.cxb-dashboard-actions {
	display: flex;
	gap: var(--cxb-spacing-sm);
	flex-wrap: wrap;
}

/* 统计数据 */
.cxb-dashboard-stats {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--cxb-spacing-lg);
	margin-bottom: var(--cxb-spacing-2xl);
}

.stat-card {
	background: var(--cxb-bg-white);
	border-radius: var(--cxb-radius-lg);
	padding: var(--cxb-spacing-lg);
	text-align: center;
	box-shadow: var(--cxb-shadow-sm);
	transition: box-shadow var(--cxb-transition);
}

.stat-card:hover {
	box-shadow: var(--cxb-shadow-md);
}

.stat-number {
	display: block;
	font-size: var(--cxb-font-size-3xl);
	font-weight: 800;
	color: var(--cxb-primary);
	line-height: 1.2;
}

.stat-label {
	display: block;
	font-size: var(--cxb-font-size-sm);
	color: var(--cxb-text-lighter);
	margin-top: var(--cxb-spacing-xs);
}

/* 投稿列表 */
.cxb-dashboard-section {
	background: var(--cxb-bg-white);
	border-radius: var(--cxb-radius-lg);
	padding: var(--cxb-spacing-xl);
	box-shadow: var(--cxb-shadow-sm);
}

.cxb-section-title {
	margin: 0 0 var(--cxb-spacing-lg);
	font-size: var(--cxb-font-size-lg);
	font-weight: 700;
	padding-bottom: var(--cxb-spacing-md);
	border-bottom: 2px solid var(--cxb-border-light);
}

.cxb-post-table {
	width: 100%;
	border-collapse: collapse;
}

.cxb-post-table th {
	text-align: left;
	padding: var(--cxb-spacing-sm) var(--cxb-spacing-md);
	font-size: var(--cxb-font-size-xs);
	color: var(--cxb-text-lighter);
	text-transform: uppercase;
	letter-spacing: 0.5px;
	border-bottom: 2px solid var(--cxb-border-light);
}

.cxb-post-table td {
	padding: var(--cxb-spacing-md);
	border-bottom: 1px solid var(--cxb-border-light);
	font-size: var(--cxb-font-size-sm);
}

.cxb-post-table tr:last-child td {
	border-bottom: none;
}

.cxb-post-table tr:hover td {
	background: rgba(74, 144, 217, 0.02);
}

.post-title-col a {
	font-weight: 600;
	color: var(--cxb-text);
}

.post-title-col a:hover {
	color: var(--cxb-primary);
}

.post-date-col {
	color: var(--cxb-text-lighter);
	font-size: var(--cxb-font-size-xs);
	white-space: nowrap;
}

.post-actions-col {
	white-space: nowrap;
}

/* 状态标签 */
.cxb-status {
	display: inline-block;
	padding: 2px 10px;
	border-radius: 20px;
	font-size: var(--cxb-font-size-xs);
	font-weight: 500;
}

.cxb-status--publish {
	background: #e8f5e9;
	color: #2e7d32;
}

.cxb-status--pending {
	background: #fff8e1;
	color: #f57f17;
}

.cxb-status--draft {
	background: #f3f3f3;
	color: #666;
}

.cxb-status--trash {
	background: #fbe9e7;
	color: #c62828;
}

/* 操作按钮 */
.btn-sm {
	display: inline-block;
	padding: 4px 14px;
	font-size: var(--cxb-font-size-xs);
	border-radius: var(--cxb-radius-sm);
	text-decoration: none;
	font-weight: 500;
	transition: all var(--cxb-transition);
	margin: 0 2px;
}

.btn-edit {
	background: rgba(74, 144, 217, 0.1);
	color: var(--cxb-primary);
}

.btn-edit:hover {
	background: var(--cxb-primary);
	color: #fff;
	text-decoration: none;
}

.btn-delete {
	background: rgba(198, 40, 40, 0.1);
	color: #c62828;
}

.btn-delete:hover {
	background: #c62828;
	color: #fff;
	text-decoration: none;
}

/* 空状态 */
.cxb-empty-state {
	text-align: center;
	padding: var(--cxb-spacing-3xl) 0;
	color: var(--cxb-text-lighter);
}

.cxb-empty-state p {
	margin-bottom: var(--cxb-spacing-lg);
	font-size: var(--cxb-font-size-lg);
}

/* ===========================
   用户列表
   =========================== */
.cxb-user-list-page {
	max-width: 1200px;
	margin: 0 auto;
}

.cxb-user-grid {
	grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
}

@media (min-width: 1280px) {
	.cxb-user-grid {
		grid-template-columns: repeat(5, 1fr);
	}
}

.cxb-user-list-header {
	margin-bottom: var(--cxb-spacing-xl);
	text-align: center;
}

.cxb-user-list-title {
	margin: 0 0 var(--cxb-spacing-xs);
	font-size: var(--cxb-font-size-3xl);
	font-weight: 800;
	letter-spacing: -0.5px;
}

.cxb-user-list-desc {
	margin: 0;
	font-size: var(--cxb-font-size-base);
	color: var(--cxb-text-lighter);
}

.cxb-user-list-toolbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--cxb-spacing-lg);
	margin-bottom: var(--cxb-spacing-xl);
	flex-wrap: wrap;
}

.cxb-user-search-form {
	display: flex;
	gap: var(--cxb-spacing-sm);
	flex: 1;
	max-width: 360px;
}

.cxb-user-search-form input[type="search"] {
	flex: 1;
	padding: 10px 16px;
	border: 1px solid var(--cxb-border);
	border-radius: 8px;
	font-family: inherit;
	font-size: var(--cxb-font-size-sm);
	background: var(--cxb-bg);
	transition: all var(--cxb-transition);
}

.cxb-user-search-form input[type="search"]:focus {
	outline: none;
	border-color: var(--cxb-primary);
	box-shadow: 0 0 0 4px var(--cxb-primary-bg);
	background: var(--cxb-bg-white);
}

.cxb-user-search-form button {
	padding: 10px 20px;
	background: var(--cxb-primary);
	color: #fff;
	border: none;
	border-radius: 8px;
	cursor: pointer;
	font-size: var(--cxb-font-size-sm);
	font-weight: 600;
	transition: all var(--cxb-transition);
}

.cxb-user-search-form button:hover {
	background: var(--cxb-primary-dark);
}

.cxb-user-sort {
	display: flex;
	gap: 4px;
}

.sort-link {
	display: inline-flex;
	padding: 8px 16px;
	border-radius: 8px;
	font-size: var(--cxb-font-size-sm);
	font-weight: 500;
	color: var(--cxb-text-light);
	text-decoration: none;
	transition: all var(--cxb-transition);
}

.sort-link:hover {
	background: var(--cxb-primary-bg);
	color: var(--cxb-primary);
}

.sort-link.active {
	background: var(--cxb-primary);
	color: #fff;
}

.cxb-user-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
	gap: var(--cxb-spacing-lg);
}

.cxb-user-card {
	background: var(--cxb-bg-white);
	border-radius: var(--cxb-radius-lg);
	padding: var(--cxb-spacing-xl);
	text-align: center;
	box-shadow: var(--cxb-shadow-sm);
	transition: box-shadow var(--cxb-transition), transform var(--cxb-transition);
}

.cxb-user-card:hover {
	box-shadow: var(--cxb-shadow-md);
	transform: translateY(-3px);
}

.cxb-user-card-avatar {
	margin-bottom: var(--cxb-spacing-md);
}

.cxb-user-card-avatar img {
	width: 72px;
	height: 72px;
	border-radius: 50%;
	object-fit: cover;
	background: var(--cxb-bg);
}

.cxb-user-card-name {
	margin: 0 0 var(--cxb-spacing-sm);
	font-size: var(--cxb-font-size-base);
	font-weight: 700;
}

.cxb-user-card-name a {
	color: var(--cxb-text);
	text-decoration: none;
}

.cxb-user-card-name a:hover {
	color: var(--cxb-primary);
}

.cxb-user-card-meta {
	display: flex;
	flex-direction: column;
	gap: 2px;
	margin-bottom: var(--cxb-spacing-md);
	font-size: var(--cxb-font-size-xs);
	color: var(--cxb-text-lighter);
}

.cxb-user-card-link {
	font-size: var(--cxb-font-size-sm);
	font-weight: 500;
	color: var(--cxb-primary);
	text-decoration: none;
}

.cxb-user-card-link:hover {
	text-decoration: underline;
}

@media (max-width: 768px) {
	.cxb-user-list-toolbar {
		flex-direction: column;
		align-items: stretch;
	}

	.cxb-user-search-form {
		max-width: none;
	}

	.cxb-user-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 480px) {
	.cxb-user-grid {
		grid-template-columns: 1fr;
	}
}

/* 分页 */
.cxb-pagination {
	margin-top: var(--cxb-spacing-xl);
	display: flex;
	justify-content: center;
}

.cxb-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 36px;
	height: 36px;
	padding: 0 8px;
	border: 1px solid var(--cxb-border);
	border-radius: var(--cxb-radius-sm);
	background: var(--cxb-bg-white);
	color: var(--cxb-text);
	font-size: var(--cxb-font-size-sm);
	text-decoration: none;
	transition: all var(--cxb-transition);
	margin: 0 2px;
}

.cxb-pagination .page-numbers:hover {
	border-color: var(--cxb-primary);
	color: var(--cxb-primary);
}

.cxb-pagination .page-numbers.current {
	background: var(--cxb-primary);
	border-color: var(--cxb-primary);
	color: #fff;
}

/* 投稿表单 */
.cxb-submit-wrap {
	max-width: 1100px;
	margin: 0 auto;
}

.cxb-submit-form {
	padding: var(--cxb-spacing-xl);
}

.cxb-submit-form .cxb-form-field textarea {
	min-height: 300px;
}

@media (min-width: 1280px) {
	.cxb-submit-form .cxb-form-field textarea {
		min-height: 400px;
	}

	.cxb-submit-header h1 {
		font-size: var(--cxb-font-size-2xl);
	}
}

.cxb-submit-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: var(--cxb-spacing-xl);
	flex-wrap: wrap;
	gap: var(--cxb-spacing-md);
}

.cxb-submit-header h1 {
	margin: 0;
	font-size: var(--cxb-font-size-2xl);
	font-weight: 700;
}

.cxb-submit-header a {
	font-size: var(--cxb-font-size-sm);
	color: var(--cxb-text-lighter);
}

.cxb-submit-header a:hover {
	color: var(--cxb-primary);
}

.cxb-submit-form {
	background: var(--cxb-bg-white);
	border-radius: var(--cxb-radius-lg);
	padding: var(--cxb-spacing-xl);
	box-shadow: var(--cxb-shadow-sm);
}

.cxb-form-row {
	display: flex;
	gap: var(--cxb-spacing-lg);
}

.cxb-form-field--half {
	flex: 1;
}

.cxb-current-image {
	margin-bottom: var(--cxb-spacing-sm);
}

.cxb-current-image img {
	border-radius: var(--cxb-radius-sm);
	max-height: 120px;
	width: auto;
}

.cxb-image-hint {
	margin: var(--cxb-spacing-xs) 0 0;
	font-size: var(--cxb-font-size-xs);
	color: var(--cxb-text-lighter);
}

.btn-lg {
	padding: 14px 36px;
	font-size: var(--cxb-font-size-base);
}

/* 动画 */
@keyframes cxbFadeIn {
	from {
		opacity: 0;
		transform: translateY(-10px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* 响应式 */
@media (max-width: 768px) {
	.cxb-dashboard-header {
		flex-direction: column;
		align-items: center;
		text-align: center;
	}

	.cxb-user-info {
		flex-direction: column;
		text-align: center;
	}

	.cxb-dashboard-stats {
		grid-template-columns: 1fr;
	}

	.cxb-post-table thead {
		display: none;
	}

	.cxb-post-table tr {
		display: block;
		padding: var(--cxb-spacing-md);
		border-bottom: 1px solid var(--cxb-border-light);
	}

	.cxb-post-table td {
		display: block;
		padding: var(--cxb-spacing-xs) 0;
		border: none;
	}

	.cxb-post-table td::before {
		content: attr(data-label);
		font-size: var(--cxb-font-size-xs);
		color: var(--cxb-text-lighter);
		text-transform: uppercase;
		font-weight: 600;
		display: block;
		margin-bottom: 2px;
	}

	.cxb-form-row {
		flex-direction: column;
	}

	.cxb-auth-box {
		padding: var(--cxb-spacing-lg);
	}
}

/* ===========================
   社交分享
   =========================== */
.cxb-share-wrap {
	display: flex;
	align-items: center;
	gap: var(--cxb-spacing-md);
	margin: var(--cxb-spacing-xl) 0;
	padding: var(--cxb-spacing-lg) 0;
	border-top: 1px solid var(--cxb-border-light);
	flex-wrap: wrap;
}

.cxb-share-label {
	font-size: var(--cxb-font-size-sm);
	font-weight: 600;
	color: var(--cxb-text-lighter);
}

.cxb-share-buttons {
	display: flex;
	gap: 8px;
}

.cxb-share-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 38px;
	height: 38px;
	border-radius: 8px;
	border: none;
	cursor: pointer;
	text-decoration: none;
	transition: all var(--cxb-transition);
	color: #fff;
}

.cxb-share-weibo {
	background: #E6162D;
}

.cxb-share-weibo:hover {
	background: #C81023;
	transform: translateY(-2px);
}

.cxb-share-qq {
	background: #12B7F5;
}

.cxb-share-qq:hover {
	background: #0E9FD6;
	transform: translateY(-2px);
}

.cxb-share-twitter {
	background: #1DA1F2;
}

.cxb-share-twitter:hover {
	background: #1A91DA;
	transform: translateY(-2px);
}

.cxb-share-link {
	background: var(--cxb-border);
	color: var(--cxb-text-light);
}

.cxb-share-link:hover {
	background: var(--cxb-primary);
	color: #fff;
	transform: translateY(-2px);
}

.cxb-share-toast {
	position: fixed;
	bottom: 80px;
	left: 50%;
	transform: translateX(-50%);
	background: #1f2937;
	color: #fff;
	padding: 10px 24px;
	border-radius: 8px;
	font-size: 14px;
	z-index: 10000;
	opacity: 0;
	visibility: hidden;
	transition: all 0.3s ease;
}

.cxb-share-toast.show {
	opacity: 1;
	visibility: visible;
	bottom: 100px;
}

/* ===========================
   收藏按钮
   =========================== */
.cxb-fav-btn {
	display: inline-flex;
	align-items: center;
	gap: var(--cxb-spacing-sm);
	padding: 9px 20px;
	background: var(--cxb-bg);
	border: none;
	border-radius: 8px;
	cursor: pointer;
	font-family: inherit;
	font-size: var(--cxb-font-size-sm);
	font-weight: 500;
	color: var(--cxb-text-light);
	transition: all var(--cxb-transition);
	line-height: 1;
}

.cxb-fav-btn:hover {
	background: rgba(99, 102, 241, 0.08);
	color: var(--cxb-primary);
}

.cxb-fav-btn.cxb-faved {
	background: rgba(99, 102, 241, 0.1);
	color: var(--cxb-primary);
}

/* ===========================
   文章目录
   =========================== */
.cxb-toc {
	background: var(--cxb-primary-bg);
	border: 1px solid rgba(99, 102, 241, 0.15);
	border-radius: var(--cxb-radius-md);
	padding: var(--cxb-spacing-lg);
	margin-bottom: var(--cxb-spacing-xl);
}

.cxb-toc-header {
	font-size: var(--cxb-font-size-sm);
	font-weight: 700;
	color: var(--cxb-primary);
	margin-bottom: var(--cxb-spacing-sm);
	letter-spacing: 0.3px;
}

.cxb-toc-body ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

.cxb-toc-body li {
	margin-bottom: 4px;
}

.cxb-toc-body a {
	font-size: var(--cxb-font-size-sm);
	color: var(--cxb-text-light);
	text-decoration: none;
	display: block;
	padding: 4px 0;
	border-radius: 4px;
	transition: all var(--cxb-transition);
}

.cxb-toc-body a:hover {
	color: var(--cxb-primary);
	background: rgba(99, 102, 241, 0.05);
	padding-left: 8px;
}

/* ===========================
   图片灯箱
   =========================== */
.cxb-lightbox {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 10001;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(0, 0, 0, 0.85);
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.3s ease, visibility 0.3s ease;
}

.cxb-lightbox--show {
	opacity: 1;
	visibility: visible;
}

.cxb-lightbox img {
	max-width: 90%;
	max-height: 90%;
	border-radius: 8px;
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5);
	transform: scale(0.9);
	transition: transform 0.3s ease;
}

.cxb-lightbox--show img {
	transform: scale(1);
}

.cxb-lightbox-close {
	position: absolute;
	top: 20px;
	right: 30px;
	background: none;
	border: none;
	color: #fff;
	font-size: 32px;
	cursor: pointer;
	opacity: 0.7;
	transition: opacity 0.2s ease;
	line-height: 1;
}

.cxb-lightbox-close:hover {
	opacity: 1;
}

.cxb-lightbox-prev,
.cxb-lightbox-next {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	background: rgba(255, 255, 255, 0.1);
	border: none;
	color: #fff;
	width: 50px;
	height: 50px;
	border-radius: 50%;
	cursor: pointer;
	font-size: 20px;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background 0.2s ease;
}

.cxb-lightbox-prev:hover,
.cxb-lightbox-next:hover {
	background: rgba(255, 255, 255, 0.2);
}

.cxb-lightbox-prev { left: 20px; }
.cxb-lightbox-next { right: 20px; }

/* ===========================
   阅读进度条
   =========================== */
.cxb-progress-bar {
	position: fixed;
	top: 0;
	left: 0;
	width: 0;
	height: 3px;
	background: linear-gradient(90deg, var(--cxb-primary), #8B5CF6);
	z-index: 10001;
	transition: width 0.1s linear;
	border-radius: 0 2px 2px 0;
}

/* ===========================
   文章阅读工具条
   =========================== */
.cxb-reading-toolbar {
	position: fixed;
	bottom: 0;
	left: 0;
	right: 0;
	z-index: 999;
	background: rgba(255, 255, 255, 0.95);
	backdrop-filter: blur(12px);
	border-top: 1px solid var(--cxb-border-light);
	padding: 0 16px;
	height: 50px;
	display: none;
	align-items: center;
	justify-content: space-between;
	transition: transform 0.3s ease;
}

[data-theme="dark"] .cxb-reading-toolbar {
	background: rgba(15, 23, 42, 0.95);
}

.cxb-reading-toolbar--show {
	display: flex;
}

.cxb-reading-toolbar-progress {
	position: absolute;
	top: -2px;
	left: 0;
	height: 2px;
	background: linear-gradient(90deg, var(--cxb-primary), #8B5CF6);
	transition: width 0.1s linear;
	border-radius: 0 2px 2px 0;
	width: 0;
}

.cxb-toolbar-left {
	display: flex;
	align-items: center;
	gap: 12px;
	font-size: 12px;
	color: var(--cxb-text-lighter);
}

.cxb-toolbar-right {
	display: flex;
	align-items: center;
	gap: 6px;
}

.cxb-toolbar-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 34px;
	height: 34px;
	border-radius: 6px;
	border: none;
	background: transparent;
	color: var(--cxb-text-light);
	cursor: pointer;
	transition: all 0.18s ease;
}

.cxb-toolbar-btn:hover {
	background: var(--cxb-primary-bg);
	color: var(--cxb-primary);
}

.cxb-toolbar-toc-btn.active {
	background: var(--cxb-primary-bg);
	color: var(--cxb-primary);
}

/* 工具条移动端显示 */
@media (max-width: 768px) {
	.cxb-reading-toolbar--show {
		display: flex;
	}
}

/* 文章摘要 */
.cxb-post-summary {
	background: var(--cxb-primary-bg);
	border: 1px solid rgba(99, 102, 241, 0.15);
	border-left: 3px solid var(--cxb-primary);
	border-radius: var(--cxb-radius-md);
	padding: var(--cxb-spacing-md) var(--cxb-spacing-lg);
	margin-bottom: var(--cxb-spacing-xl);
	font-size: var(--cxb-font-size-sm);
	color: var(--cxb-text-light);
	line-height: 1.7;
}

.cxb-post-summary strong {
	color: var(--cxb-text);
}

/* ===========================
   回到顶部
   =========================== */
.back-to-top {
	position: fixed;
	bottom: 30px;
	right: 30px;
	z-index: 999;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	background: var(--cxb-primary);
	color: #fff;
	border: none;
	border-radius: 50%;
	cursor: pointer;
	opacity: 0;
	visibility: hidden;
	transform: translateY(20px);
	transition: all var(--cxb-transition);
	box-shadow: 0 4px 12px rgba(99, 102, 241, 0.3);
}

.back-to-top.show {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.back-to-top:hover {
	background: var(--cxb-primary-dark);
	transform: translateY(-3px);
	box-shadow: 0 6px 20px rgba(99, 102, 241, 0.4);
}

/* ===========================
   用户等级徽章
   =========================== */
.cxb-badge-tag {
	display: inline-flex;
	align-items: center;
	gap: 2px;
	padding: 1px 10px;
	border-radius: 20px;
	font-size: 11px;
	font-weight: 600;
	line-height: 1.6;
	vertical-align: middle;
	margin-left: 4px;
}

/* 作者名旁徽章 */
.cxb-author-name .cxb-badge-tag {
	font-size: 10px;
	padding: 0 8px;
}

.entry-meta .cxb-badge-tag {
	font-size: 10px;
}

/* ===========================
   代码高亮
   =========================== */
.cxb-code-block {
	position: relative;
	margin: var(--cxb-spacing-lg) 0;
	background: #1e293b;
	border-radius: var(--cxb-radius-md);
	overflow: hidden;
}

.cxb-code-block pre {
	margin: 0;
	padding: 20px;
	overflow-x: auto;
	background: transparent;
}

.cxb-code-block code {
	font-family: 'JetBrains Mono', 'SFMono-Regular', Consolas, monospace;
	font-size: 13px;
	line-height: 1.7;
	color: #e2e8f0;
	tab-size: 4;
}

.cxb-code-lang {
	display: inline-block;
	padding: 4px 12px;
	background: rgba(255, 255, 255, 0.08);
	color: #94a3b8;
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.5px;
	position: absolute;
	top: 8px;
	right: 8px;
	border-radius: 4px;
}

.cxb-code-copy {
	position: absolute;
	top: 8px;
	left: 8px;
	padding: 4px 12px;
	background: rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(255, 255, 255, 0.1);
	border-radius: 4px;
	color: #94a3b8;
	font-size: 11px;
	cursor: pointer;
	font-family: inherit;
	transition: all 0.2s ease;
}

.cxb-code-copy:hover {
	background: rgba(255, 255, 255, 0.15);
	color: #fff;
}

.cxb-code-copy.copied {
	background: #10b981;
	color: #fff;
	border-color: #10b981;
}

/* 深色模式代码块不变 */
[data-theme="dark"] .cxb-code-block {
	background: #0f172a;
}

/* ===========================
   文章分页导航
   =========================== */
.cxb-page-links {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 6px;
	margin: var(--cxb-spacing-2xl) 0;
	padding: var(--cxb-spacing-lg);
	background: var(--cxb-bg);
	border-radius: var(--cxb-radius-md);
}

.cxb-page-links-label {
	font-size: 13px;
	font-weight: 600;
	color: var(--cxb-text-lighter);
	margin-right: var(--cxb-spacing-sm);
}

.cxb-page-links a,
.cxb-page-links span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 36px;
	height: 36px;
	padding: 0 10px;
	border-radius: 6px;
	font-size: 13px;
	font-weight: 500;
	text-decoration: none;
	transition: all var(--cxb-transition);
}

.cxb-page-links a {
	background: var(--cxb-bg-white);
	border: 1px solid var(--cxb-border);
	color: var(--cxb-text-light);
}

.cxb-page-links a:hover {
	border-color: var(--cxb-primary);
	color: var(--cxb-primary);
	background: var(--cxb-primary-bg);
}

.cxb-page-links .post-page-numbers.current span,
.cxb-page-links .post-page-numbers.current {
	background: var(--cxb-primary);
	color: #fff;
	border-color: var(--cxb-primary);
}

/* ===========================
   选中文字快捷工具条
   =========================== */
.cxb-selection-toolbar {
	position: fixed;
	z-index: 10001;
	display: flex;
	gap: 2px;
	background: #1f2937;
	border-radius: 8px;
	padding: 4px;
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.3);
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.2s ease, visibility 0.2s ease;
	pointer-events: none;
}

.cxb-selection-toolbar--show {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
}

.cxb-sel-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 30px;
	height: 30px;
	border: none;
	border-radius: 6px;
	background: transparent;
	color: #94a3b8;
	cursor: pointer;
	transition: all 0.15s ease;
}

.cxb-sel-btn:hover {
	background: rgba(255, 255, 255, 0.1);
	color: #fff;
}

/* ===========================
   通知面板（header 下拉）
   =========================== */
.cxb-notif-panel {
	position: fixed;
	top: 64px;
	right: 16px;
	width: 360px;
	max-width: calc(100vw - 32px);
	background: var(--cxb-bg-white);
	border: 1px solid var(--cxb-border);
	border-radius: var(--cxb-radius-lg);
	box-shadow: var(--cxb-shadow-lg);
	z-index: 10000;
	opacity: 0;
	visibility: hidden;
	transform: translateY(-8px);
	transition: all 0.25s ease;
}

.cxb-notif-panel--show {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.cxb-notif-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 14px 16px;
	border-bottom: 1px solid var(--cxb-border-light);
}

.cxb-notif-header h4 {
	margin: 0;
	font-size: 15px;
	font-weight: 700;
}

.cxb-notif-mark-read {
	background: none;
	border: none;
	font-size: 12px;
	color: var(--cxb-primary);
	cursor: pointer;
	padding: 4px 8px;
	border-radius: 4px;
	transition: background 0.15s ease;
}

.cxb-notif-mark-read:hover {
	background: var(--cxb-primary-bg);
}

.cxb-notif-list {
	max-height: 360px;
	overflow-y: auto;
}

.cxb-notif-item {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	padding: 12px 16px;
	border-bottom: 1px solid var(--cxb-border-light);
	transition: background 0.15s ease;
	font-size: 13px;
	color: var(--cxb-text-light);
	text-decoration: none;
}

.cxb-notif-item:hover {
	background: var(--cxb-bg);
}

.cxb-notif-item--unread {
	background: var(--cxb-primary-bg);
}

.cxb-notif-item--unread:hover {
	background: rgba(99, 102, 241, 0.12);
}

.cxb-notif-item:last-child {
	border-bottom: none;
}

.cxb-notif-icon {
	font-size: 16px;
	flex-shrink: 0;
	width: 24px;
	text-align: center;
}

.cxb-notif-text {
	flex: 1;
	min-width: 0;
	line-height: 1.4;
}

.cxb-notif-text a {
	color: var(--cxb-text);
	font-weight: 500;
}

.cxb-notif-time {
	display: block;
	font-size: 11px;
	color: var(--cxb-text-lighter);
	margin-top: 2px;
}

.cxb-notif-loading,
.cxb-notif-empty {
	padding: 30px;
	text-align: center;
	font-size: 13px;
	color: var(--cxb-text-lighter);
}

/* ===========================
   侧边目录
   =========================== */
.cxb-sidebar-toc {
	background: var(--cxb-bg-white);
	border-radius: var(--cxb-radius-lg);
	padding: var(--cxb-spacing-lg);
	box-shadow: var(--cxb-shadow-sm);
	margin-bottom: var(--cxb-spacing-lg);
}

.cxb-sidebar-toc-title {
	font-size: 13px;
	font-weight: 700;
	color: var(--cxb-text);
	margin-bottom: var(--cxb-spacing-sm);
	letter-spacing: 0.3px;
}

.cxb-sidebar-toc-list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.cxb-sidebar-toc-list li {
	margin-bottom: 3px;
}

.cxb-sidebar-toc-list a {
	display: block;
	font-size: 12px;
	color: var(--cxb-text-light);
	text-decoration: none;
	padding: 4px 0;
	border-radius: 4px;
	transition: all 0.15s ease;
	line-height: 1.4;
}

.cxb-sidebar-toc-list a:hover {
	color: var(--cxb-primary);
}

.cxb-sidebar-toc-list li.active a {
	color: var(--cxb-primary);
	font-weight: 600;
}

/* ===========================
   用户成就
   =========================== */
.cxb-achievements {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.cxb-achievement {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 12px 16px;
	background: var(--cxb-bg);
	border-radius: var(--cxb-radius-md);
	transition: all var(--cxb-transition);
}

.cxb-achievement--unlocked {
	background: rgba(16, 185, 129, 0.06);
	border: 1px solid rgba(16, 185, 129, 0.15);
}

.cxb-achievement--locked {
	opacity: 0.5;
	filter: grayscale(0.8);
}

.cxb-ach-icon {
	font-size: 24px;
	flex-shrink: 0;
	width: 36px;
	text-align: center;
}

.cxb-ach-info {
	flex: 1;
}

.cxb-ach-info strong {
	display: block;
	font-size: 14px;
	color: var(--cxb-text);
}

.cxb-ach-info small {
	font-size: 12px;
	color: var(--cxb-text-lighter);
}

.cxb-ach-check {
	flex-shrink: 0;
	width: 24px;
	height: 24px;
	background: #10b981;
	color: #fff;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 12px;
	font-weight: 700;
}

/* ===========================
   互动气泡
   =========================== */
.cxb-bubble {
	position: fixed;
	bottom: 80px;
	right: 30px;
	z-index: 998;
}

.cxb-bubble-btn {
	width: 50px;
	height: 50px;
	border-radius: 50%;
	background: var(--cxb-primary);
	color: #fff;
	border: none;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 4px 16px rgba(99, 102, 241, 0.3);
	transition: all 0.2s ease;
}

.cxb-bubble-btn:hover {
	transform: scale(1.1);
	box-shadow: 0 6px 24px rgba(99, 102, 241, 0.4);
}

.cxb-bubble-menu {
	position: absolute;
	bottom: 60px;
	right: 0;
	display: flex;
	flex-direction: column;
	gap: 6px;
	opacity: 0;
	visibility: hidden;
	transform: translateY(10px);
	transition: all 0.2s ease;
}

.cxb-bubble--open .cxb-bubble-menu {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.cxb-bubble-item {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 10px 16px;
	background: var(--cxb-bg-white);
	border: 1px solid var(--cxb-border);
	border-radius: 12px;
	cursor: pointer;
	font-family: inherit;
	font-size: 13px;
	color: var(--cxb-text-light);
	text-decoration: none;
	transition: all 0.15s ease;
	box-shadow: var(--cxb-shadow-sm);
	white-space: nowrap;
}

.cxb-bubble-item:hover {
	border-color: var(--cxb-primary);
	color: var(--cxb-primary);
	background: var(--cxb-primary-bg);
}

/* ===========================
   打印按钮
   =========================== */
.cxb-print-wrap {
	text-align: right;
	margin-top: var(--cxb-spacing-lg);
}

.cxb-print-btn {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 8px 18px;
	background: var(--cxb-bg);
	border: 1px solid var(--cxb-border);
	border-radius: 8px;
	cursor: pointer;
	font-family: inherit;
	font-size: 13px;
	font-weight: 500;
	color: var(--cxb-text-light);
	transition: all var(--cxb-transition);
}

.cxb-print-btn:hover {
	border-color: var(--cxb-primary);
	color: var(--cxb-primary);
	background: var(--cxb-primary-bg);
}

/* ===========================
   打印样式
   =========================== */
/* ===========================
   面包屑导航
   =========================== */
.cxb-breadcrumb {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 4px;
	margin-bottom: var(--cxb-spacing-lg);
	padding: 10px 16px;
	background: var(--cxb-bg);
	border-radius: var(--cxb-radius-md);
	font-size: 13px;
	color: var(--cxb-text-lighter);
}

.cxb-breadcrumb a {
	color: var(--cxb-text-light);
	text-decoration: none;
	transition: color var(--cxb-transition);
}

.cxb-breadcrumb a:hover {
	color: var(--cxb-primary);
}

.cxb-breadcrumb-sep {
	margin: 0 4px;
	color: var(--cxb-border);
	font-size: 16px;
	font-weight: 300;
}

.cxb-breadcrumb .breadcrumb-current {
	color: var(--cxb-text);
	font-weight: 500;
}

/* ===========================
   改进的文章卡片
   =========================== */
.post-card {
	background: var(--cxb-bg-white);
	border: 1px solid var(--cxb-border);
	border-radius: var(--cxb-radius-lg);
	overflow: hidden;
	transition: all var(--cxb-transition);
}

.post-card:hover {
	box-shadow: var(--cxb-shadow-md);
	border-color: var(--cxb-primary-light);
	transform: translateY(-2px);
}

.post-card-thumbnail {
	display: block;
	overflow: hidden;
	position: relative;
	padding-top: 56.25%;
	background: var(--cxb-bg);
}

.post-card-thumbnail img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.4s ease;
}

.post-card:hover .post-card-thumbnail img {
	transform: scale(1.05);
}

.post-card-body {
	padding: var(--cxb-spacing-lg);
}

.post-card-meta {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: var(--cxb-spacing-sm);
}

.post-card-category a {
	display: inline-block;
	padding: 2px 10px;
	background: var(--cxb-primary-bg);
	color: var(--cxb-primary);
	border-radius: 20px;
	font-size: 12px;
	font-weight: 600;
	text-decoration: none;
	transition: all var(--cxb-transition);
}

.post-card-category a:hover {
	background: var(--cxb-primary);
	color: #fff;
}

.post-card-date {
	font-size: 12px;
	color: var(--cxb-text-lighter);
}

.post-card-title {
	margin: 0 0 var(--cxb-spacing-sm);
	font-size: 18px;
	font-weight: 700;
	line-height: 1.4;
}

.post-card-title a {
	color: var(--cxb-text);
	text-decoration: none;
	transition: color var(--cxb-transition);
}

.post-card-title a:hover {
	color: var(--cxb-primary);
}

.post-card-excerpt {
	font-size: 14px;
	color: var(--cxb-text-light);
	line-height: 1.6;
	margin-bottom: var(--cxb-spacing-md);
}

.post-card-excerpt p {
	margin: 0;
}

.post-card-footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding-top: var(--cxb-spacing-sm);
	border-top: 1px solid var(--cxb-border-light);
}

.post-card-author {
	display: flex;
	align-items: center;
	gap: 6px;
	font-size: 13px;
	color: var(--cxb-text-light);
}

.post-card-author-avatar {
	border-radius: 50%;
	width: 24px;
	height: 24px;
}

.post-card-author a {
	color: var(--cxb-text);
	font-weight: 500;
	text-decoration: none;
}

.post-card-author a:hover {
	color: var(--cxb-primary);
}

.post-card-stats {
	display: flex;
	align-items: center;
	gap: 12px;
	font-size: 12px;
	color: var(--cxb-text-lighter);
}

.post-card-stats span {
	display: inline-flex;
	align-items: center;
	gap: 3px;
}

/* ===========================
   404 页面改进
   =========================== */
.error-404-inner {
	max-width: 600px;
	margin: 60px auto;
	text-align: center;
}

.error-404-icon {
	margin-bottom: var(--cxb-spacing-lg);
}

.error-404-title {
	font-size: 120px;
	font-weight: 900;
	color: var(--cxb-primary);
	line-height: 1;
	margin: 0 0 var(--cxb-spacing-sm);
	opacity: 0.8;
}

.error-404-subtitle {
	font-size: 24px;
	font-weight: 700;
	color: var(--cxb-text);
	margin: 0 0 var(--cxb-spacing-sm);
}

.error-404-desc {
	font-size: 15px;
	color: var(--cxb-text-light);
	margin-bottom: var(--cxb-spacing-xl);
	line-height: 1.6;
}

.error-actions {
	margin-bottom: var(--cxb-spacing-xl);
}

.error-search {
	margin-bottom: var(--cxb-spacing-xl);
}

.error-search h3 {
	font-size: 16px;
	font-weight: 600;
	margin-bottom: var(--cxb-spacing-sm);
	color: var(--cxb-text);
}

.error-suggestions-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 16px;
	text-align: left;
}

.error-suggestion-card {
	background: var(--cxb-bg);
	border-radius: var(--cxb-radius-md);
	padding: var(--cxb-spacing-lg);
}

.error-suggestion-card h4 {
	font-size: 14px;
	font-weight: 700;
	margin: 0 0 var(--cxb-spacing-sm);
	color: var(--cxb-text);
}

.error-suggestion-card ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

.error-suggestion-card li {
	margin-bottom: 4px;
}

.error-suggestion-card a {
	font-size: 13px;
	color: var(--cxb-text-light);
	text-decoration: none;
	transition: color var(--cxb-transition);
}

.error-suggestion-card a:hover {
	color: var(--cxb-primary);
}

@media (max-width: 640px) {
	.error-suggestions-grid {
		grid-template-columns: 1fr;
	}
}

/* ===========================
   通知面板底部
   =========================== */
.cxb-notif-panel-inner {
	position: relative;
}

.cxb-notif-footer {
	padding: 10px 16px;
	border-top: 1px solid var(--cxb-border-light);
	text-align: center;
}

.cxb-notif-footer a {
	font-size: 12px;
	color: var(--cxb-primary);
	text-decoration: none;
	font-weight: 500;
}

.cxb-notif-footer a:hover {
	text-decoration: underline;
}

/* ===========================
   通知切换按钮徽章
   =========================== */
.notif-badge {
	background: var(--cxb-accent) !important;
}

@-webkit-keyframes notifPulse {
	0% { transform: scale(1); }
	50% { transform: scale(1.2); }
	100% { transform: scale(1); }
}

@keyframes notifPulse {
	0% { transform: scale(1); }
	50% { transform: scale(1.2); }
	100% { transform: scale(1); }
}

.notif-badge.has-new {
	-webkit-animation: notifPulse 1s ease infinite;
	animation: notifPulse 1s ease infinite;
}

/* ===========================
   评论排序工具栏
   =========================== */
.cxb-comment-toolbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: var(--cxb-spacing-md);
}

.cxb-comment-sort {
	display: flex;
	align-items: center;
	gap: 4px;
	font-size: 13px;
}

.cxb-comment-sort-label {
	color: var(--cxb-text-lighter);
}

.cxb-comment-sort-link {
	padding: 4px 10px;
	border-radius: 6px;
	color: var(--cxb-text-light);
	text-decoration: none;
	transition: all var(--cxb-transition);
	font-weight: 500;
}

.cxb-comment-sort-link:hover {
	color: var(--cxb-primary);
	background: var(--cxb-primary-bg);
}

.cxb-comment-sort-link.active {
	background: var(--cxb-primary);
	color: #fff;
}

/* ===========================
   评论表情选择
   =========================== */
.cxb-comment-emojis {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	margin-bottom: var(--cxb-spacing-sm);
	padding: 8px;
	background: var(--cxb-bg);
	border-radius: var(--cxb-radius-md);
}

.cxb-comment-emoji {
	cursor: pointer;
	font-size: 20px;
	padding: 4px;
	border-radius: 4px;
	transition: all 0.15s ease;
	line-height: 1;
}

.cxb-comment-emoji:hover {
	background: var(--cxb-primary-bg);
	transform: scale(1.2);
}

/* ===========================
   关注按钮
   =========================== */
.cxb-follow-btn {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	padding: 6px 14px;
	border-radius: 20px;
	border: 1px solid var(--cxb-primary);
	background: var(--cxb-primary);
	color: #fff;
	font-size: 13px;
	font-weight: 500;
	cursor: pointer;
	font-family: inherit;
	transition: all var(--cxb-transition);
}

.cxb-follow-btn:hover {
	background: var(--cxb-primary-dark);
	border-color: var(--cxb-primary-dark);
}

.cxb-follow-btn.cxb-following {
	background: transparent;
	color: var(--cxb-primary);
}

.cxb-follow-btn.cxb-following:hover {
	background: #fef2f2;
	color: #ef4444;
	border-color: #fecaca;
}

/* ===========================
   积分徽章
   =========================== */
.cxb-points-badge {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	padding: 2px 10px;
	background: rgba(245, 158, 11, 0.1);
	color: #d97706;
	border-radius: 20px;
	font-size: 13px;
	font-weight: 600;
}

/* ===========================
   阅读模式
   =========================== */
.cxb-reading-mode-btn {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 6px 14px;
	background: var(--cxb-bg);
	border: 1px solid var(--cxb-border);
	border-radius: 8px;
	cursor: pointer;
	font-family: inherit;
	font-size: 13px;
	color: var(--cxb-text-light);
	transition: all var(--cxb-transition);
	margin: var(--cxb-spacing-sm) 0;
}

.cxb-reading-mode-btn:hover,
.cxb-reading-mode-btn.active {
	border-color: var(--cxb-primary);
	color: var(--cxb-primary);
	background: var(--cxb-primary-bg);
}

body.cxb-reading-mode .widget-area,
body.cxb-reading-mode .cxb-share-wrap,
body.cxb-reading-mode .cxb-post-actions,
body.cxb-reading-mode .cxb-author-box,
body.cxb-reading-mode .cxb-related-posts,
body.cxb-reading-mode .cxb-bubble,
body.cxb-reading-mode .cxb-reading-toolbar,
body.cxb-reading-mode .comments-area,
body.cxb-reading-mode .post-navigation,
body.cxb-reading-mode .entry-footer,
body.cxb-reading-mode .cxb-breadcrumb {
	display: none !important;
}

body.cxb-reading-mode .content-area {
	max-width: 720px;
	margin: 0 auto;
}

body.cxb-reading-mode .entry-content {
	font-size: 18px;
	line-height: 1.9;
}

/* ===========================
   首页轮播图
   =========================== */
.cxb-carousel {
	margin-bottom: var(--cxb-spacing-xl);
}

.cxb-carousel-wrap {
	position: relative;
	overflow: hidden;
	border-radius: var(--cxb-radius-lg);
	background: var(--cxb-bg);
}

.cxb-carousel-track {
	display: flex;
	transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}

.cxb-carousel-slide {
	flex: 0 0 100%;
	position: relative;
	display: block;
	text-decoration: none;
	color: #fff;
}

.cxb-carousel-img {
	aspect-ratio: 21/9;
	overflow: hidden;
}

.cxb-carousel-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.cxb-carousel-overlay {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	padding: 40px 24px 24px;
	background: linear-gradient(transparent, rgba(0,0,0,0.8));
}

.cxb-carousel-cat {
	display: inline-block;
	padding: 2px 10px;
	background: var(--cxb-primary);
	color: #fff;
	border-radius: 20px;
	font-size: 12px;
	font-weight: 600;
	margin-bottom: 8px;
}

.cxb-carousel-title {
	margin: 0 0 6px;
	font-size: 22px;
	font-weight: 700;
	line-height: 1.3;
}

.cxb-carousel-meta {
	display: flex;
	gap: 16px;
	font-size: 13px;
	opacity: 0.8;
}

.cxb-carousel-nav {
	position: absolute;
	top: 50%;
	left: 0;
	right: 0;
	transform: translateY(-50%);
	display: flex;
	justify-content: space-between;
	padding: 0 16px;
	pointer-events: none;
}

.cxb-carousel-prev,
.cxb-carousel-next {
	pointer-events: auto;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background: rgba(255,255,255,0.9);
	border: none;
	font-size: 24px;
	color: #1f2937;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: all 0.2s ease;
	box-shadow: 0 2px 8px rgba(0,0,0,0.15);
}

.cxb-carousel-prev:hover,
.cxb-carousel-next:hover {
	background: #fff;
	transform: scale(1.1);
}

.cxb-carousel-dots {
	position: absolute;
	bottom: 12px;
	left: 50%;
	transform: translateX(-50%);
	display: flex;
	gap: 8px;
	pointer-events: none;
}

.cxb-carousel-dot {
	pointer-events: auto;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: rgba(255,255,255,0.5);
	cursor: pointer;
	transition: all 0.2s ease;
}

.cxb-carousel-dot.active {
	background: #fff;
	width: 24px;
	border-radius: 4px;
}

/* ===========================
   改进的相关文章网格
   =========================== */
.cxb-related-grid--improved {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 16px;
}

@media (max-width: 768px) {
	.cxb-related-grid--improved {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 480px) {
	.cxb-related-grid--improved {
		grid-template-columns: 1fr;
	}
}

.cxb-related-thumb-placeholder {
	aspect-ratio: 16/9;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--cxb-bg);
	color: var(--cxb-text-lighter);
}

.cxb-related-date {
	display: block;
	font-size: 12px;
	color: var(--cxb-text-lighter);
	margin-top: 4px;
}

/* ===========================
   热度标签
   =========================== */
.cxb-hot-badge {
	display: inline-block;
	padding: 2px 8px;
	border-radius: 4px;
	font-size: 11px;
	font-weight: 700;
	color: #fff;
	letter-spacing: 0.3px;
	margin-left: 8px;
	vertical-align: middle;
}

/* ===========================
   举报按钮 & 弹窗
   =========================== */
.cxb-report-btn {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	padding: 6px 12px;
	background: none;
	border: 1px solid var(--cxb-border);
	border-radius: 8px;
	cursor: pointer;
	font-family: inherit;
	font-size: 13px;
	color: var(--cxb-text-lighter);
	transition: all var(--cxb-transition);
}

.cxb-report-btn:hover {
	border-color: var(--cxb-error);
	color: var(--cxb-error);
	background: rgba(239, 68, 68, 0.05);
}

.cxb-report-modal {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 10002;
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0;
	visibility: hidden;
	transition: all 0.2s ease;
}

.cxb-report-modal--show {
	opacity: 1;
	visibility: visible;
}

.cxb-report-overlay {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: rgba(0,0,0,0.5);
}

.cxb-report-box {
	position: relative;
	background: var(--cxb-bg-white);
	border-radius: var(--cxb-radius-lg);
	padding: 24px;
	width: 400px;
	max-width: 90vw;
	box-shadow: var(--cxb-shadow-lg);
}

.cxb-report-box h3 {
	margin: 0 0 var(--cxb-spacing-md);
	font-size: 18px;
}

.cxb-report-box textarea {
	width: 100%;
	padding: 10px;
	border: 1px solid var(--cxb-border);
	border-radius: var(--cxb-radius-md);
	font-family: inherit;
	font-size: 14px;
	resize: vertical;
	box-sizing: border-box;
	margin-bottom: var(--cxb-spacing-md);
}

.cxb-report-actions {
	display: flex;
	gap: 8px;
	justify-content: flex-end;
}

/* ===========================
   键盘快捷键帮助
   =========================== */
.cxb-shortcuts-help {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 10003;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(0,0,0,0.5);
	opacity: 0;
	visibility: hidden;
	transition: all 0.2s ease;
}

.cxb-shortcuts-help--show {
	opacity: 1;
	visibility: visible;
}

.cxb-shortcuts-help-inner {
	background: var(--cxb-bg-white);
	border-radius: var(--cxb-radius-lg);
	padding: 24px;
	width: 320px;
	max-width: 90vw;
	box-shadow: var(--cxb-shadow-lg);
}

.cxb-shortcuts-help-inner h4 {
	margin: 0 0 var(--cxb-spacing-md);
	font-size: 16px;
	font-weight: 700;
}

.cxb-shortcut-row {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 8px 0;
	font-size: 14px;
}

.cxb-shortcut-row kbd {
	display: inline-block;
	padding: 2px 8px;
	background: var(--cxb-bg);
	border: 1px solid var(--cxb-border);
	border-radius: 4px;
	font-size: 12px;
	font-weight: 600;
	font-family: var(--cxb-font-mono);
	min-width: 24px;
	text-align: center;
}

.cxb-shortcut-row span {
	color: var(--cxb-text-light);
}

.cxb-shortcuts-close {
	margin-top: var(--cxb-spacing-md);
	width: 100%;
	padding: 8px;
	background: var(--cxb-primary);
	color: #fff;
	border: none;
	border-radius: var(--cxb-radius-md);
	font-size: 14px;
	cursor: pointer;
	font-family: inherit;
}

/* ===========================
   移动端底部导航栏
   =========================== */
.cxb-bottom-nav {
	display: none;
	position: fixed;
	bottom: 0;
	left: 0;
	right: 0;
	height: 60px;
	background: var(--cxb-bg-white);
	border-top: 1px solid var(--cxb-border);
	z-index: 999;
	justify-content: space-around;
	align-items: center;
	padding-bottom: env(safe-area-inset-bottom, 0);
}

@media (max-width: 768px) {
	.cxb-bottom-nav {
		display: flex;
	}

	.site-footer {
		padding-bottom: 70px;
	}

	body.cxb-reading-mode .cxb-bottom-nav {
		display: none;
	}
}

.cxb-bottom-nav-item {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 2px;
	text-decoration: none;
	color: var(--cxb-text-lighter);
	font-size: 10px;
	transition: color 0.15s ease;
	position: relative;
	padding: 4px 8px;
}

.cxb-bottom-nav-item.active,
.cxb-bottom-nav-item:hover {
	color: var(--cxb-primary);
}

.cxb-bottom-nav-item svg {
	width: 22px;
	height: 22px;
}

.cxb-bottom-nav-avatar {
	border-radius: 50%;
	width: 22px;
	height: 22px;
}

.cxb-bottom-nav-badge {
	position: absolute;
	top: 0;
	right: 4px;
	min-width: 16px;
	height: 16px;
	padding: 0 4px;
	background: var(--cxb-error);
	color: #fff;
	font-size: 10px;
	font-weight: 700;
	border-radius: 10px;
	display: flex;
	align-items: center;
	justify-content: center;
}

/* ===========================
   移动端搜索触发
   =========================== */
.cxb-bottom-nav-search {
	cursor: pointer;
}

/* ===========================
   改进文章热标签在卡片中的位置
   =========================== */
.post-card .cxb-hot-badge {
	position: absolute;
	top: 8px;
	right: 8px;
	z-index: 2;
}

.post-card-thumbnail {
	position: relative;
}

/* ===========================
   语音朗读按钮
   =========================== */
.cxb-tts-btn {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 6px 14px;
	background: var(--cxb-bg);
	border: 1px solid var(--cxb-border);
	border-radius: 8px;
	cursor: pointer;
	font-family: inherit;
	font-size: 13px;
	color: var(--cxb-text-light);
	transition: all var(--cxb-transition);
	margin: var(--cxb-spacing-sm) 0;
}

.cxb-tts-btn:hover {
	border-color: var(--cxb-primary);
	color: var(--cxb-primary);
	background: var(--cxb-primary-bg);
}

.cxb-tts-btn.cxb-tts-active {
	border-color: var(--cxb-error);
	color: var(--cxb-error);
	background: rgba(239, 68, 68, 0.05);
}

@-webkit-keyframes ttsPulse {
	0%, 100% { opacity: 1; }
	50% { opacity: 0.5; }
}

@keyframes ttsPulse {
	0%, 100% { opacity: 1; }
	50% { opacity: 0.5; }
}

.cxb-tts-active svg {
	-webkit-animation: ttsPulse 1s ease infinite;
	animation: ttsPulse 1s ease infinite;
}

/* ===========================
   Markdown 导出链接
   =========================== */
.cxb-md-export {
	margin-top: var(--cxb-spacing-sm);
	text-align: right;
}

.cxb-md-link {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 13px;
	color: var(--cxb-text-lighter);
	text-decoration: none;
	padding: 4px 10px;
	border-radius: 6px;
	transition: all var(--cxb-transition);
}

.cxb-md-link:hover {
	color: var(--cxb-primary);
	background: var(--cxb-primary-bg);
}

/* ===========================
   收藏标签选择器
   =========================== */
.cxb-fav-tag-select {
	z-index: 1000;
	background: var(--cxb-bg-white);
	border: 1px solid var(--cxb-border);
	border-radius: 8px;
	padding: 6px;
	box-shadow: 0 4px 12px rgba(0,0,0,0.1);
}

.cxb-fav-tag-select select {
	padding: 4px 8px;
	border: 1px solid var(--cxb-border);
	border-radius: 6px;
	font-size: 13px;
	font-family: inherit;
}

.cxb-fav-tag-select .btn {
	padding: 4px 10px;
	font-size: 12px;
}

/* ===========================
   打赏排行榜
   =========================== */
.cxb-tip-leaderboard {
	background: var(--cxb-bg-white);
	border: 1px solid var(--cxb-border);
	border-radius: var(--cxb-radius-lg);
	padding: var(--cxb-spacing-lg);
	margin-bottom: var(--cxb-spacing-lg);
}

.cxb-tip-leaderboard h3 {
	margin: 0 0 var(--cxb-spacing-sm);
	font-size: 15px;
	font-weight: 700;
}

.cxb-tip-leaderboard ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

.cxb-tip-leaderboard li {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 8px 0;
	border-bottom: 1px solid var(--cxb-border-light);
	font-size: 14px;
}

.cxb-tip-leaderboard li:last-child {
	border-bottom: none;
}

.cxb-tip-leaderboard li img {
	border-radius: 50%;
	width: 30px;
	height: 30px;
}

.cxb-tip-leaderboard li span {
	flex: 1;
	font-weight: 500;
	color: var(--cxb-text);
}

.cxb-tip-leaderboard li small {
	font-size: 12px;
	color: var(--cxb-text-lighter);
}

/* ===========================
   维护模式提示
   =========================== */
.cxb-maintenance-bar {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	background: #fef3c7;
	color: #92400e;
	padding: 6px 16px;
	text-align: center;
	font-size: 13px;
	z-index: 9999;
}

/* ===========================
   收藏夹管理
   =========================== */
.cxb-fav-folders {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-bottom: var(--cxb-spacing-md);
}

.cxb-fav-folder {
	padding: 6px 14px;
	border: 1px solid var(--cxb-border);
	border-radius: 20px;
	font-size: 13px;
	color: var(--cxb-text-light);
	background: var(--cxb-bg);
	cursor: pointer;
	transition: all var(--cxb-transition);
	text-decoration: none;
}

.cxb-fav-folder:hover,
.cxb-fav-folder.active {
	border-color: var(--cxb-primary);
	color: var(--cxb-primary);
	background: var(--cxb-primary-bg);
}

.cxb-fav-folder .count {
	background: var(--cxb-border);
	padding: 0 6px;
	border-radius: 10px;
	font-size: 11px;
	margin-left: 4px;
}

.cxb-fav-folder.active .count {
	background: var(--cxb-primary);
	color: #fff;
}

/* ===========================
   用户个人中心统计行
   =========================== */
.cxb-user-stats-row {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	margin-top: 8px;
}

.cxb-user-stat {
	font-size: 13px;
	color: var(--cxb-text-light);
	background: var(--cxb-bg);
	padding: 2px 10px;
	border-radius: 20px;
}

/* ===========================
   后台统计图表
   =========================== */
.cxb-stats-wrap {
	padding: 16px 0;
}

.cxb-stats-wrap .bar-container {
	display: flex;
	gap: 12px;
	align-items: flex-end;
	height: 100px;
}

.cxb-stats-wrap .bar-column {
	flex: 1;
	text-align: center;
}

.cxb-stats-wrap .bar-group {
	display: flex;
	justify-content: center;
	gap: 4px;
	height: 80px;
	align-items: flex-end;
}

.cxb-stats-wrap .bar {
	width: 8px;
	border-radius: 4px 4px 0 0;
	min-height: 2px;
}

.cxb-stats-wrap .bar-label {
	font-size: 10px;
	color: #9ca3af;
	margin-top: 4px;
}

@media (max-width: 768px) {
	.cxb-stats-wrap .bar-label {
		font-size: 8px;
	}
}

/* ===========================
   重新设计的文章页样式
   =========================== */

/* 特色图片 */
.cxb-featured-media {
	position: relative;
	border-radius: var(--cxb-radius-lg);
	overflow: hidden;
	margin-bottom: var(--cxb-spacing-lg);
}

.cxb-featured-image {
	width: 100%;
	height: auto;
	display: block;
}

.cxb-featured-overlay {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	padding: 60px 24px 20px;
	background: linear-gradient(transparent, rgba(0,0,0,0.6));
}

.cxb-cat-badge {
	display: inline-block;
	padding: 4px 14px;
	background: var(--cxb-primary);
	color: #fff;
	border-radius: 20px;
	font-size: 12px;
	font-weight: 600;
	text-decoration: none;
	margin-right: 6px;
	transition: opacity 0.2s;
}

.cxb-cat-badge:hover {
	color: #fff;
	opacity: 0.85;
}

/* 文章标题区 */
.cxb-entry-header {
	margin-bottom: var(--cxb-spacing-xl);
}

.cxb-entry-title {
	font-size: 28px;
	font-weight: 800;
	line-height: 1.35;
	margin: 0 0 var(--cxb-spacing-md);
	color: var(--cxb-text);
}

.cxb-entry-meta {
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap: 8px;
	font-size: 13px;
	color: var(--cxb-text-light);
}

.cxb-meta-left,
.cxb-meta-right {
	display: flex;
	align-items: center;
	gap: 6px;
}

.cxb-meta-author {
	display: flex;
	align-items: center;
	gap: 6px;
	white-space: nowrap;
}

.cxb-meta-author a {
	color: var(--cxb-text);
	font-weight: 600;
	text-decoration: none;
}

.cxb-meta-author a:hover {
	color: var(--cxb-primary);
}

.cxb-meta-avatar {
	border-radius: 50%;
	width: 28px;
	height: 28px;
}

.cxb-meta-sep {
	color: var(--cxb-border);
	font-weight: 300;
}

.cxb-meta-views {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	color: var(--cxb-text-lighter);
}

.cxb-meta-views svg {
	vertical-align: -2px;
}

/* 文章内容 */
.cxb-entry-content {
	font-size: 16px;
	line-height: 1.8;
	color: var(--cxb-text);
	margin-bottom: var(--cxb-spacing-lg);
}

.cxb-entry-content p {
	margin-bottom: 1.2em;
}

.cxb-entry-content img {
	max-width: 100%;
	height: auto;
	border-radius: var(--cxb-radius-md);
}

/* 文章底部 */
.cxb-entry-footer {
	margin-bottom: var(--cxb-spacing-lg);
	padding-top: var(--cxb-spacing-md);
	border-top: 1px solid var(--cxb-border-light);
}

.cxb-tags-list {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}

.cxb-tags-list a {
	display: inline-block;
	padding: 3px 12px;
	background: var(--cxb-bg);
	border: 1px solid var(--cxb-border);
	border-radius: 6px;
	font-size: 13px;
	color: var(--cxb-text-light);
	text-decoration: none;
	transition: all var(--cxb-transition);
}

.cxb-tags-list a:hover {
	border-color: var(--cxb-primary);
	color: var(--cxb-primary);
}

/* 互动操作栏 */
.cxb-action-bar {
	display: flex;
	justify-content: center;
	gap: 24px;
	padding: var(--cxb-spacing-lg) 0;
	margin-bottom: var(--cxb-spacing-md);
	border-top: 1px solid var(--cxb-border-light);
	border-bottom: 1px solid var(--cxb-border-light);
}

.cxb-action-group {
	display: flex;
	gap: 8px;
}

/* 上下篇导航 */
.cxb-post-nav {
	display: flex;
	justify-content: space-between;
	gap: 16px;
	margin-top: var(--cxb-spacing-lg);
	padding-top: var(--cxb-spacing-lg);
	border-top: 1px solid var(--cxb-border-light);
}

.cxb-post-nav-prev,
.cxb-post-nav-next {
	flex: 1;
	max-width: 48%;
}

.cxb-post-nav-next {
	text-align: right;
}

.cxb-nav-label {
	display: block;
	font-size: 12px;
	color: var(--cxb-text-lighter);
	margin-bottom: 4px;
	text-transform: uppercase;
	letter-spacing: 1px;
}

.cxb-nav-title {
	font-size: 14px;
	font-weight: 600;
	color: var(--cxb-text);
	text-decoration: none;
	transition: color var(--cxb-transition);
	display: block;
	line-height: 1.4;
}

.cxb-nav-title:hover {
	color: var(--cxb-primary);
}

@media (max-width: 640px) {
	.cxb-entry-title {
		font-size: 22px;
	}

	.cxb-action-bar {
		flex-direction: column;
		align-items: center;
		gap: 12px;
	}

	.cxb-post-nav {
		flex-direction: column;
	}

	.cxb-post-nav-prev,
	.cxb-post-nav-next {
		max-width: 100%;
	}
}

/* ===========================
   全面 UI 美化样式
   =========================== */

/* 容器和内边距增强 */
.cxb-single-article {
	background: #fff;
	border-radius: 16px;
	padding: 32px;
	box-shadow: 0 1px 3px rgba(0,0,0,0.06);
	margin-bottom: 24px;
}

@media (max-width: 640px) {
	.cxb-single-article {
		padding: 16px;
		border-radius: 12px;
	}
}

/* 按钮组 - 点赞/收藏/打赏/举报 */
.cxb-like-btn,
.cxb-fav-btn,
.cxb-tip-btn,
.cxb-report-btn {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 8px 18px;
	border: 1px solid #e5e7eb;
	border-radius: 24px;
	background: #fff;
	color: #6b7280;
	font-size: 13px;
	font-weight: 500;
	cursor: pointer;
	font-family: inherit;
	transition: all 0.2s ease;
	line-height: 1;
	white-space: nowrap;
}

.cxb-like-btn:hover,
.cxb-fav-btn:hover,
.cxb-tip-btn:hover,
.cxb-report-btn:hover {
	border-color: #6366f1;
	color: #6366f1;
	background: rgba(99,102,241,0.05);
	transform: translateY(-1px);
}

.cxb-liked,
.cxb-faved {
	border-color: #6366f1;
	color: #6366f1;
	background: rgba(99,102,241,0.08);
}

.cxb-like-count,
.cxb-fav-count {
	margin-left: 2px;
	font-weight: 600;
}

/* 星评分 */
.cxb-star-rating {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 16px 0;
	margin: 0 0 8px;
}

.cxb-stars {
	display: inline-flex;
	gap: 2px;
}

.cxb-star {
	cursor: pointer;
	padding: 2px;
	transition: transform 0.15s ease;
}

.cxb-star:hover {
	transform: scale(1.2);
}

.cxb-star svg {
	display: block;
}

.cxb-rating-text {
	font-size: 14px;
	color: #6b7280;
}

.cxb-rating-text strong {
	font-size: 18px;
	color: #f59e0b;
}

/* 社交分享 */
.cxb-share-wrap {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	padding: 16px 0;
	margin-bottom: 24px;
}

.cxb-share-label {
	font-size: 13px;
	color: #9ca3af;
}

.cxb-share-buttons {
	display: flex;
	gap: 8px;
}

.cxb-share-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 6px 16px;
	border-radius: 20px;
	font-size: 12px;
	font-weight: 600;
	text-decoration: none;
	border: none;
	cursor: pointer;
	transition: all 0.2s ease;
	background: #f3f4f6;
	color: #374151;
	font-family: inherit;
}

.cxb-share-btn:hover {
	background: #6366f1;
	color: #fff;
	transform: translateY(-1px);
}

.cxb-share-weibo:hover { background: #e6162d; color: #fff; }
.cxb-share-twitter:hover { background: #1da1f2; color: #fff; }
.cxb-share-link:hover { background: #10b981; color: #fff; }

/* 作者框 */
.cxb-author-box {
	background: #fff;
	border-radius: 16px;
	padding: 28px;
	box-shadow: 0 1px 3px rgba(0,0,0,0.06);
	margin-bottom: 24px;
}

.cxb-author-box-top {
	display: flex;
	align-items: flex-start;
	gap: 20px;
}

@media (max-width: 480px) {
	.cxb-author-box-top {
		flex-direction: column;
		align-items: center;
		text-align: center;
	}
}

.cxb-author-avatar a {
	display: block;
}

.cxb-author-avatar img {
	border-radius: 50%;
	width: 72px;
	height: 72px;
	object-fit: cover;
	border: 3px solid #f3f4f6;
}

.cxb-author-name {
	margin: 0 0 6px;
	font-size: 18px;
	font-weight: 700;
}

.cxb-author-name a {
	color: #1f2937;
	text-decoration: none;
}

.cxb-author-name a:hover {
	color: #6366f1;
}

.cxb-author-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-bottom: 8px;
	font-size: 13px;
	color: #6b7280;
}

.cxb-author-meta a {
	color: #6366f1;
	text-decoration: none;
	font-weight: 500;
}

.cxb-author-bio {
	font-size: 14px;
	line-height: 1.6;
	color: #4b5563;
}

/* 用户徽章 */
.cxb-user-badge {
	display: inline-block;
	padding: 1px 8px;
	border-radius: 10px;
	font-size: 10px;
	font-weight: 700;
	color: #fff;
	letter-spacing: 0.3px;
	vertical-align: middle;
	margin-left: 4px;
}

/* 关注按钮 */
.cxb-follow-btn {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	padding: 6px 16px;
	border-radius: 20px;
	border: 1px solid #6366f1;
	background: #6366f1;
	color: #fff;
	font-size: 13px;
	font-weight: 500;
	cursor: pointer;
	font-family: inherit;
	transition: all 0.2s ease;
	margin-top: 8px;
}

.cxb-follow-btn:hover {
	background: #4f46e5;
}

.cxb-following {
	background: transparent;
	color: #6366f1;
}

/* 相关文章 */
.cxb-related-posts {
	background: #fff;
	border-radius: 16px;
	padding: 28px;
	box-shadow: 0 1px 3px rgba(0,0,0,0.06);
	margin-bottom: 24px;
}

.cxb-related-title {
	font-size: 18px;
	font-weight: 700;
	margin: 0 0 20px;
	color: #1f2937;
}

.cxb-related-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 16px;
}

@media (max-width: 768px) { .cxb-related-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .cxb-related-grid { grid-template-columns: 1fr; } }

.cxb-related-item {
	overflow: hidden;
	border-radius: 12px;
	background: #f9fafb;
	transition: all 0.2s ease;
}

.cxb-related-item:hover {
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(0,0,0,0.08);
}

.cxb-related-thumb {
	display: block;
	aspect-ratio: 16/9;
	overflow: hidden;
}

.cxb-related-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.3s ease;
}

.cxb-related-item:hover .cxb-related-thumb img {
	transform: scale(1.05);
}

.cxb-related-body {
	padding: 12px 14px;
}

.cxb-related-post-title {
	margin: 0;
	font-size: 14px;
	font-weight: 600;
	line-height: 1.4;
}

.cxb-related-post-title a {
	color: #1f2937;
	text-decoration: none;
}

.cxb-related-post-title a:hover {
	color: #6366f1;
}

/* 上下篇导航 */
.cxb-post-nav {
	display: flex;
	justify-content: space-between;
	gap: 16px;
	margin-top: 24px;
	padding: 24px 0 0;
	border-top: 1px solid #e5e7eb;
}

.cxb-post-nav-prev,
.cxb-post-nav-next {
	flex: 1;
	max-width: 48%;
	padding: 16px 20px;
	background: #fff;
	border-radius: 12px;
	box-shadow: 0 1px 3px rgba(0,0,0,0.06);
	transition: all 0.2s ease;
}

.cxb-post-nav-prev:hover,
.cxb-post-nav-next:hover {
	box-shadow: 0 4px 12px rgba(0,0,0,0.08);
	transform: translateY(-1px);
}

.cxb-post-nav-next { text-align: right; }

.cxb-nav-label {
	display: block;
	font-size: 12px;
	color: #9ca3af;
	margin-bottom: 4px;
	text-transform: uppercase;
	letter-spacing: 1px;
}

.cxb-nav-title {
	font-size: 14px;
	font-weight: 600;
	color: #1f2937;
	text-decoration: none;
	transition: color 0.2s;
	display: block;
	line-height: 1.4;
}

.cxb-nav-title:hover { color: #6366f1; }

/* 评论区域 */
.comments-area {
	background: #fff;
	border-radius: 16px;
	padding: 28px;
	box-shadow: 0 1px 3px rgba(0,0,0,0.06);
	margin-bottom: 24px;
}

.comments-title {
	font-size: 18px;
	font-weight: 700;
	margin: 0 0 16px;
	color: #1f2937;
}

.comment-list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.comment {
	padding: 16px 0;
	border-bottom: 1px solid #f3f4f6;
}

.comment-body { position: relative; padding-left: 56px; }

.comment-meta { margin-bottom: 6px; }

.comment-author { font-size: 14px; font-weight: 600; color: #1f2937; }

.comment-author img { position: absolute; left: 0; top: 0; border-radius: 50%; }

.comment-metadata { font-size: 12px; color: #9ca3af; }

.comment-content { font-size: 14px; line-height: 1.7; color: #4b5563; }

.reply a {
	font-size: 12px;
	color: #6366f1;
	text-decoration: none;
	font-weight: 500;
}

/* 评论表单 */
.comment-respond { margin-top: 24px; padding-top: 24px; border-top: 1px solid #f3f4f6; }

.comment-reply-title {
	font-size: 16px;
	font-weight: 700;
	margin: 0 0 16px;
	color: #1f2937;
}

.comment-form label { display: block; font-size: 13px; font-weight: 600; color: #374151; margin-bottom: 4px; }

.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"],
.comment-form textarea {
	width: 100%;
	padding: 10px 14px;
	border: 1px solid #e5e7eb;
	border-radius: 10px;
	font-size: 14px;
	font-family: inherit;
	transition: border-color 0.2s;
	box-sizing: border-box;
}

.comment-form input:focus,
.comment-form textarea:focus {
	outline: none;
	border-color: #6366f1;
	box-shadow: 0 0 0 3px rgba(99,102,241,0.1);
}

.form-submit .submit {
	padding: 10px 28px;
	border: none;
	border-radius: 24px;
	background: #6366f1;
	color: #fff;
	font-size: 14px;
	font-weight: 600;
	cursor: pointer;
	font-family: inherit;
	transition: all 0.2s ease;
}

.form-submit .submit:hover {
	background: #4f46e5;
	transform: translateY(-1px);
}

/* 评论排序 */
.cxb-comment-toolbar {
	margin-bottom: 16px;
}

.cxb-comment-sort {
	display: flex;
	align-items: center;
	gap: 6px;
	font-size: 13px;
}

.cxb-comment-sort-label { color: #9ca3af; }

.cxb-comment-sort-link {
	padding: 4px 12px;
	border-radius: 6px;
	color: #6b7280;
	text-decoration: none;
	font-weight: 500;
	transition: all 0.2s;
}

.cxb-comment-sort-link:hover {
	color: #6366f1;
	background: rgba(99,102,241,0.08);
}

.cxb-comment-sort-link.active {
	background: #6366f1;
	color: #fff;
}

/* 打赏弹窗 */
.cxb-tip-modal { display: none; position: fixed; top: 0; left: 0; right: 0; bottom: 0; z-index: 10000; align-items: center; justify-content: center; }
.cxb-tip-modal-overlay { position: absolute; top: 0; left: 0; right: 0; bottom: 0; background: rgba(0,0,0,0.5); }
.cxb-tip-modal-content { position: relative; background: #fff; border-radius: 16px; padding: 32px; width: 360px; max-width: 90vw; box-shadow: 0 20px 60px rgba(0,0,0,0.2); text-align: center; }
.cxb-tip-modal-close { position: absolute; top: 12px; right: 16px; background: none; border: none; font-size: 24px; color: #9ca3af; cursor: pointer; }
.cxb-tip-modal-content h3 { margin: 0 0 8px; font-size: 20px; }
.cxb-tip-desc { font-size: 14px; color: #6b7280; margin-bottom: 20px; }
.cxb-tip-qr-list { display: flex; justify-content: center; gap: 24px; }
.cxb-tip-qr-item { text-align: center; }
.cxb-tip-qr-item img { width: 140px; height: 140px; border-radius: 12px; object-fit: cover; }
.cxb-tip-qr-label { display: block; font-size: 12px; color: #6b7280; margin-top: 6px; }

/* Toast 提示 */
.cxb-toast {
	position: fixed; bottom: 30px; left: 50%; transform: translateX(-50%) translateY(20px);
	background: #1f2937; color: #fff; padding: 10px 24px; border-radius: 10px;
	font-size: 14px; z-index: 99999; opacity: 0; transition: all 0.3s ease;
	pointer-events: none;
}
.cxb-toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }

/* ===========================
   打印样式
   =========================== */
@media print {
	.site-header,
	.site-footer,
	.widget-area,
	.comments-area,
	.post-navigation,
	.pagination,
	.menu-toggle,
	.cxb-breadcrumb,
	.cxb-share-wrap,
	.cxb-post-actions,
	.cxb-tip-area,
	.cxb-interaction-bubble,
	.cxb-reading-toolbar {
		display: none !important;
	}

	.site-main {
		padding: 0;
	}

	a {
		color: #000 !important;
	}
}

/* ===========================
   Toast 提示消息
   =========================== */
.cxb-toast {
	position: fixed;
	bottom: 30px;
	left: 50%;
	transform: translateX(-50%) translateY(20px);
	background: #1f2937;
	color: #fff;
	padding: 10px 24px;
	border-radius: 10px;
	font-size: 14px;
	z-index: 99999;
	opacity: 0;
	transition: all 0.3s ease;
	pointer-events: none;
	max-width: 90vw;
	text-align: center;
	line-height: 1.5;
}
.cxb-toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }
.cxb-toast--error { background: #dc2626; }
.cxb-toast--success { background: #059669; }

/* ===========================
   全局 AJAX 加载动画
   =========================== */
#cxb-global-loader {
	position: fixed;
	top: 0; left: 0; right: 0; bottom: 0;
	background: rgba(255,255,255,0.7);
	display: none;
	align-items: center;
	justify-content: center;
	z-index: 99998;
}
.cxb-loader-spinner {
	width: 40px;
	height: 40px;
	border: 3px solid #e5e7eb;
	border-top-color: #2d8cf0;
	border-radius: 50%;
	animation: cxb-spin 0.8s linear infinite;
}
@keyframes cxb-spin {
	to { transform: rotate(360deg); }
}
.cxb-loading {
	position: relative;
	color: transparent !important;
	pointer-events: none;
}
.cxb-loading::after {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	width: 16px;
	height: 16px;
	margin: -8px 0 0 -8px;
	border: 2px solid rgba(255,255,255,0.3);
	border-top-color: #fff;
	border-radius: 50%;
	animation: cxb-spin 0.8s linear infinite;
}

/* ===========================
   评论区楼层号 + 投票按钮
   =========================== */
.comment-floor {
	display: inline-block;
	background: #f3f4f6;
	color: #6b7280;
	font-size: 11px;
	font-weight: 600;
	padding: 1px 8px;
	border-radius: 4px;
	margin-left: 6px;
	vertical-align: middle;
}
.comment-footer {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-top: 8px;
	padding-top: 8px;
	border-top: 1px solid #f3f4f6;
}
.cxb-comment-votes {
	display: flex;
	align-items: center;
	gap: 4px;
}
.cxb-vote-btn {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	padding: 4px 10px;
	border: 1px solid #e5e7eb;
	border-radius: 6px;
	background: #fff;
	color: #6b7280;
	font-size: 12px;
	cursor: pointer;
	font-family: inherit;
	transition: all 0.2s;
}
.cxb-vote-btn:hover {
	border-color: #2d8cf0;
	color: #2d8cf0;
	background: rgba(45,140,240,0.05);
}
.cxb-vote-btn.cxb-voted {
	border-color: #2d8cf0;
	background: #2d8cf0;
	color: #fff;
}
.comment-reply-link-wrap a {
	font-size: 12px;
	color: #2d8cf0;
	text-decoration: none;
	font-weight: 500;
}
.comment-reply-link-wrap a:hover {
	text-decoration: underline;
}

/* ===========================
   全站响应式适配
   =========================== */
@media(max-width:900px) {
	.content-area { grid-template-columns: 1fr !important; }
	.cxb-author-box-top { flex-direction: column; align-items: center; text-align: center; }
	.cxb-entry-meta { flex-direction: column; align-items: flex-start; gap: 4px; }
	.cxb-action-bar { flex-wrap: wrap; }
	.cxb-related-grid { grid-template-columns: repeat(2,1fr) !important; }
	.posts-grid { grid-template-columns: repeat(auto-fill,minmax(260px,1fr)) !important; }
	.hero-title { font-size: 28px !important; }
	.hero-section { padding: 40px 0 !important; }
}
@media(max-width:640px) {
	.cxb-entry-title { font-size: 22px !important; }
	.cxb-single-article { padding: 16px !important; }
	.cxb-dashboard-stats { grid-template-columns: 1fr !important; }
	.site-header .header-container { padding: 0 12px; }
	.posts-grid { grid-template-columns: 1fr !important; }
	.cxb-related-grid { grid-template-columns: 1fr !important; }
	.cxb-post-nav { flex-direction: column; }
	.cxb-post-nav-prev, .cxb-post-nav-next { max-width: 100% !important; }
	.cxb-bulk-bar { flex-wrap: wrap; }
	.cxb-comment-toolbar { flex-direction: column; align-items: flex-start; }
	.cxb-cat-badge { font-size: 11px; padding: 2px 10px; }
	.comment-body { padding-left: 44px !important; }
	.comment-author img { width: 36px !important; height: 36px !important; }
	.cxb-dashboard-header { flex-direction: column; }
	.cxb-admin-tabs { flex-wrap: wrap; }
	.cxb-admin-tabs .tab-link { font-size: 13px; padding: 6px 12px; }
	.cxb-user-grid { grid-template-columns: repeat(2,1fr) !important; }
}
@media(max-width:480px) {
	.cxb-user-grid { grid-template-columns: 1fr !important; }
	.cxb-user-card { padding: 16px !important; }
	.cxb-bottom-nav { height: 52px !important; }
	.cxb-bottom-nav-item { font-size: 10px !important; }
	.cxb-bottom-nav-item svg { width: 18px !important; height: 18px !important; }
	.cxb-dashboard-actions .btn { font-size: 12px !important; padding: 5px 12px !important; }
}
