/* Japanese Manga — 日漫风格 + 柔和配色 + 网点纸 + 圆润气泡 */

@import url('https://fonts.googleapis.com/css2?family=Kosugi+Maru&family=M+PLUS+Rounded+1c:wght@400;500;700&family=Noto+Sans+SC:wght@400;500;700&display=swap');

:root {
	--jm-bg: #fffbf5;
	--jm-paper: #ffffff;
	--jm-ink: #2d2d2d;
	--jm-muted: #6b6b6b;
	--jm-pink: #ffb7c5;
	--jm-pink-dark: #ff8fa3;
	--jm-blue: #a8d8ea;
	--jm-blue-dark: #7fc3d7;
	--jm-yellow: #ffeead;
	--jm-lavender: #e6e6fa;
	--jm-mint: #c8e6c9;
	--jm-border: 2px solid #2d2d2d;
	--jm-shadow: 4px 4px 0 rgba(45, 45, 45, 0.15);
	--jm-radius: 20px;
	--jm-radius-lg: 30px;
	--jm-max: 1100px;
	--jm-gutter: clamp(1rem, 4vw, 2.5rem);
	--jm-font: "M PLUS Rounded 1c", "Kosugi Maru", "Noto Sans SC", sans-serif;
}

*,
*::before,
*::after {
	box-sizing: border-box;
}

html {
	-webkit-text-size-adjust: 100%;
}

body {
	margin: 0;
	padding: 0;
	color: var(--jm-ink);
	font-size: 15px;
	line-height: 1.8;
	font-family: var(--jm-font);
	background: var(--jm-bg);
	background-image: 
		radial-gradient(circle at 20% 50%, rgba(255, 183, 197, 0.1) 0%, transparent 50%),
		radial-gradient(circle at 80% 80%, rgba(168, 216, 234, 0.1) 0%, transparent 50%);
	-webkit-font-smoothing: antialiased;
}

a {
	color: var(--jm-pink-dark);
	text-decoration: none;
	font-weight: 700;
	transition: all 0.3s ease;
}

a:hover {
	color: var(--jm-blue-dark);
	transform: translateY(-2px);
}

ol, ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

img {
	border: var(--jm-border);
	border-radius: var(--jm-radius);
	max-width: 100%;
	height: auto;
	box-shadow: var(--jm-shadow);
	transition: transform 0.3s ease;
}

img:hover {
	transform: rotate(2deg) scale(1.02);
}

p, dl, dd, dt, h1, h2, h3, h4, h5, h6 {
	margin: 0;
	padding: 0;
}

.clear {
	clear: both;
}

/* ========== 网点纸背景 ========== */
.screentone {
	position: relative;
}

.screentone::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background-image: radial-gradient(circle, rgba(45, 45, 45, 0.08) 1px, transparent 1px);
	background-size: 6px 6px;
	pointer-events: none;
	border-radius: inherit;
}

/* ========== 外壳布局 ========== */
#divAll {
	width: 100%;
	max-width: var(--jm-max);
	margin: 0 auto;
	padding: var(--jm-gutter);
}

#divPage {
	width: 100%;
}

#divMiddle {
	width: 100%;
}

/* ========== 顶部区域 ========== */
#divTop {
	text-align: center;
	padding: 3rem 2rem 2rem;
	margin-bottom: 2.5rem;
	background: linear-gradient(135deg, var(--jm-pink) 0%, var(--jm-lavender) 50%, var(--jm-blue) 100%);
	border: var(--jm-border);
	border-radius: var(--jm-radius-lg);
	box-shadow: var(--jm-shadow);
	position: relative;
	overflow: hidden;
}

/* 樱花装饰 */
#divTop::before {
	content: "🌸";
	position: absolute;
	top: 15px;
	left: 30px;
	font-size: 2rem;
	animation: float 3s ease-in-out infinite;
}

#divTop::after {
	content: "🌸";
	position: absolute;
	top: 20px;
	right: 40px;
	font-size: 1.5rem;
	animation: float 3s ease-in-out infinite 0.5s;
}

@keyframes float {
	0%, 100% { transform: translateY(0) rotate(0deg); }
	50% { transform: translateY(-10px) rotate(10deg); }
}

/* 网点纸叠加 */
#divTop .screentone-overlay {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background-image: radial-gradient(circle, rgba(255,255,255,0.3) 2px, transparent 2px);
	background-size: 8px 8px;
	pointer-events: none;
}

#BlogTitle {
	font-family: var(--jm-font);
	font-size: clamp(2rem, 5vw, 3.5rem);
	font-weight: 700;
	color: var(--jm-ink);
	letter-spacing: 0.15em;
	margin-bottom: 0.75rem;
	text-shadow: 3px 3px 0 rgba(255,255,255,0.8);
	position: relative;
	display: inline-block;
}

#BlogTitle::after {
	content: "~";
	color: var(--jm-pink-dark);
	margin-left: 0.3em;
}

#BlogTitle a {
	color: var(--jm-ink);
}

#BlogSubTitle {
	font-size: 0.9375rem;
	color: var(--jm-ink);
	background: rgba(255,255,255,0.9);
	display: inline-block;
	padding: 0.6rem 1.5rem;
	border-radius: 999px;
	border: var(--jm-border);
	box-shadow: 3px 3px 0 rgba(0,0,0,0.1);
}

/* ========== 导航栏 ========== */
#divNavBar {
	margin-bottom: 2.5rem;
	padding: 1rem;
	background: var(--jm-paper);
	border: var(--jm-border);
	border-radius: var(--jm-radius);
	box-shadow: var(--jm-shadow);
}

#divNavBar h3 {
	display: none;
}

#divNavBar ul {
	display: flex;
	justify-content: center;
	gap: 1rem;
	flex-wrap: wrap;
}

#divNavBar a {
	display: inline-block;
	padding: 0.75rem 1.5rem;
	font-size: 0.9375rem;
	font-weight: 700;
	color: var(--jm-ink);
	background: var(--jm-yellow);
	border: 2px solid var(--jm-ink);
	border-radius: 999px;
	box-shadow: 3px 3px 0 rgba(0,0,0,0.1);
	transition: all 0.3s ease;
}

#divNavBar a:hover,
#divNavBar a.on {
	background: var(--jm-pink);
	transform: translateY(-3px);
	box-shadow: 5px 5px 0 rgba(0,0,0,0.15);
}

/* ========== 主内容区 ========== */
#divMain {
	float: left;
	width: 65%;
	padding-right: 2.5rem;
}

/* ========== 侧边栏 ========== */
#divSidebar {
	float: right;
	width: 35%;
}

/* ========== 文章卡片 ========== */
div.post {
	margin-bottom: 2.5rem;
	padding: 2rem;
	background: var(--jm-paper);
	border: var(--jm-border);
	border-radius: var(--jm-radius);
	box-shadow: var(--jm-shadow);
	position: relative;
	overflow: hidden;
}

/* 网点纸效果 */
div.post::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background-image: radial-gradient(circle, rgba(45, 45, 45, 0.05) 1px, transparent 1px);
	background-size: 5px 5px;
	pointer-events: none;
}

/* 装饰圆点 */
div.post::after {
	content: "";
	position: absolute;
	top: 15px;
	right: 15px;
	width: 12px;
	height: 12px;
	background: var(--jm-pink);
	border-radius: 50%;
	border: 2px solid var(--jm-ink);
}

/* 不同颜色主题 */
div.post:nth-child(4n+1)::after { background: var(--jm-pink); }
div.post:nth-child(4n+2)::after { background: var(--jm-blue); }
div.post:nth-child(4n+3)::after { background: var(--jm-yellow); }
div.post:nth-child(4n+4)::after { background: var(--jm-mint); }

div.post > * {
	position: relative;
	z-index: 1;
}

div.post:last-of-type {
	margin-bottom: 0;
}

/* 文章日期 */
div.post .post-date {
	display: inline-block;
	font-size: 0.75rem;
	font-weight: 700;
	color: var(--jm-ink);
	background: var(--jm-lavender);
	padding: 0.4rem 1rem;
	margin-bottom: 1rem;
	border-radius: 999px;
	border: 2px solid var(--jm-ink);
	box-shadow: 2px 2px 0 rgba(0,0,0,0.1);
}

/* 文章标题 */
div.post .post-title {
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--jm-ink);
	margin-bottom: 1rem;
	line-height: 1.4;
	border-bottom: 3px dotted var(--jm-pink);
	padding-bottom: 0.75rem;
}

div.post .post-title a {
	color: var(--jm-ink);
}

div.post .post-title a:hover {
	color: var(--jm-pink-dark);
}

/* 文章内容 */
div.post div.post-body {
	color: var(--jm-muted);
	font-size: 0.9375rem;
	line-height: 1.9;
	margin-bottom: 1.25rem;
}

/* 文章底部 */
div.post .post-footer {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.8125rem;
	font-weight: 700;
	color: var(--jm-ink);
	background: var(--jm-mint);
	padding: 0.5rem 1rem;
	border-radius: 999px;
	border: 2px solid var(--jm-ink);
	box-shadow: 2px 2px 0 rgba(0,0,0,0.1);
}

div.post .post-footer::before {
	content: "✿";
	color: var(--jm-pink-dark);
}

/* ========== 单篇文章详情 ========== */
div.post.single {
	padding: 2.5rem;
}

div.post.single .post-title {
	font-size: clamp(1.5rem, 3vw, 2.25rem);
	text-align: center;
	border-bottom: 4px solid var(--jm-pink);
	border-style: wavy;
	padding-bottom: 1.25rem;
	margin-bottom: 2rem;
}

div.post.single .post-date {
	display: block;
	text-align: center;
	margin-bottom: 1.5rem;
	background: var(--jm-pink);
}

/* ========== 侧边栏模块 ========== */
.function {
	margin-bottom: 2rem;
	padding: 1.5rem;
	background: var(--jm-paper);
	border: var(--jm-border);
	border-radius: var(--jm-radius);
	box-shadow: var(--jm-shadow);
	position: relative;
}

/* 标题气泡 */
.function .function_t {
	font-size: 1rem;
	font-weight: 700;
	color: var(--jm-ink);
	background: var(--jm-yellow);
	padding: 0.75rem 1.25rem;
	margin-bottom: 1.25rem;
	border-radius: 20px;
	border: 2px solid var(--jm-ink);
	box-shadow: 3px 3px 0 rgba(0,0,0,0.1);
	position: relative;
}

/* 气泡尾巴 */
.function .function_t::after {
	content: "";
	position: absolute;
	bottom: -10px;
	left: 30px;
	width: 0;
	height: 0;
	border: 10px solid transparent;
	border-top-color: var(--jm-ink);
	border-bottom: 0;
}

.function .function_t::before {
	content: "";
	position: absolute;
	bottom: -6px;
	left: 32px;
	width: 0;
	height: 0;
	border: 8px solid transparent;
	border-top-color: var(--jm-yellow);
	border-bottom: 0;
	z-index: 1;
}

.function li {
	padding: 0.875rem 1rem;
	margin-bottom: 0.75rem;
	font-size: 0.875rem;
	background: var(--jm-bg);
	border-radius: 15px;
	border: 2px solid transparent;
	transition: all 0.3s ease;
}

.function li:hover {
	background: var(--jm-pink);
	border-color: var(--jm-ink);
	transform: translateX(5px);
	box-shadow: 3px 3px 0 rgba(0,0,0,0.1);
}

.function li:last-child {
	margin-bottom: 0;
}

.function a {
	color: var(--jm-ink);
	display: block;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.function li:hover a {
	color: var(--jm-ink);
}

/* ========== 文章内容样式 ========== */
div.post-body {
	color: var(--jm-ink);
	font-size: 1rem;
	line-height: 1.9;
}

div.post-body p {
	margin-bottom: 1.5em;
}

div.post-body a {
	color: var(--jm-pink-dark);
	border-bottom: 2px wavy var(--jm-pink);
	padding: 0 0.2rem;
}

div.post-body a:hover {
	background: var(--jm-pink);
	color: var(--jm-ink);
	border-radius: 5px;
}

div.post-body h1,
div.post-body h2,
div.post-body h3,
div.post-body h4,
div.post-body h5,
div.post-body h6 {
	font-weight: 700;
	color: var(--jm-ink);
	margin: 1.5em 0 0.75em;
	padding: 0.75rem 1.25rem;
	border-radius: 15px;
	border: 2px solid var(--jm-ink);
	box-shadow: 3px 3px 0 rgba(0,0,0,0.1);
	display: inline-block;
}

div.post-body h1 {
	font-size: 1.5rem;
	background: var(--jm-pink);
}

div.post-body h2 {
	font-size: 1.35rem;
	background: var(--jm-blue);
}

div.post-body h3 {
	font-size: 1.2rem;
	background: var(--jm-yellow);
}

div.post-body blockquote {
	margin: 1.5rem 0;
	padding: 1.5rem 2rem;
	background: var(--jm-lavender);
	border-radius: var(--jm-radius);
	border: var(--jm-border);
	position: relative;
	font-style: normal;
}

/* 引用气泡尾巴 */
div.post-body blockquote::after {
	content: "";
	position: absolute;
	bottom: -15px;
	left: 40px;
	width: 0;
	height: 0;
	border: 15px solid transparent;
	border-top-color: var(--jm-ink);
	border-bottom: 0;
}

div.post-body blockquote::before {
	content: "";
	position: absolute;
	bottom: -11px;
	left: 42px;
	width: 0;
	height: 0;
	border: 13px solid transparent;
	border-top-color: var(--jm-lavender);
	border-bottom: 0;
	z-index: 1;
}

div.post-body code {
	font-family: "M PLUS Rounded 1c", monospace;
	font-size: 0.875em;
	font-weight: 700;
	color: var(--jm-ink);
	background: var(--jm-yellow);
	padding: 0.2em 0.5em;
	border-radius: 8px;
	border: 1px solid var(--jm-ink);
}

div.post-body pre {
	background: var(--jm-bg);
	border: var(--jm-border);
	border-radius: var(--jm-radius);
	box-shadow: var(--jm-shadow);
	padding: 1.5rem;
	margin: 1.5rem 0;
	overflow-x: auto;
}

div.post-body pre code {
	background: none;
	border: none;
	padding: 0;
}

div.post-body ul,
div.post-body ol {
	margin: 1.5rem 0;
	padding-left: 1.5rem;
}

div.post-body li {
	margin: 0.75rem 0;
	position: relative;
}

div.post-body ul li::marker {
	content: "🌸";
	font-size: 0.8rem;
}

div.post-body table {
	width: 100%;
	border-collapse: separate;
	border-spacing: 0;
	margin: 1.5rem 0;
	font-size: 0.9375rem;
	border: 2px solid var(--jm-ink);
	border-radius: var(--jm-radius);
	overflow: hidden;
	box-shadow: var(--jm-shadow);
}

div.post-body th,
div.post-body td {
	padding: 1rem;
	border-bottom: 1px solid rgba(0,0,0,0.1);
}

div.post-body th {
	font-weight: 700;
	background: var(--jm-pink);
	color: var(--jm-ink);
}

div.post-body tr:last-child td {
	border-bottom: none;
}

div.post-body tr:nth-child(even) {
	background: var(--jm-bg);
}

/* ========== 分页 ========== */
div.pagebar {
	margin-top: 2.5rem;
	padding-top: 1.5rem;
	border-top: 3px dotted var(--jm-pink);
	text-align: center;
}

span.page,
span.now-page {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 2.75rem;
	height: 2.75rem;
	margin: 0 0.4rem;
	font-size: 0.9375rem;
	font-weight: 700;
	color: var(--jm-ink);
	background: var(--jm-paper);
	border: 2px solid var(--jm-ink);
	border-radius: 50%;
	box-shadow: 3px 3px 0 rgba(0,0,0,0.1);
	transition: all 0.3s ease;
}

span.page:hover {
	background: var(--jm-pink);
	transform: translateY(-3px);
	box-shadow: 5px 5px 0 rgba(0,0,0,0.15);
}

span.now-page {
	background: var(--jm-pink);
	transform: scale(1.1);
}

/* ========== 评论 ========== */
ul.msg {
	margin: 1.5rem 0;
	padding: 1.25rem;
	background: var(--jm-paper);
	border: var(--jm-border);
	border-radius: var(--jm-radius);
	box-shadow: var(--jm-shadow);
}

li.msgname {
	font-weight: 700;
	color: var(--jm-ink);
	background: var(--jm-blue);
	display: inline-block;
	padding: 0.5rem 1rem;
	margin-bottom: 0.75rem;
	border-radius: 15px;
	border: 2px solid var(--jm-ink);
	box-shadow: 2px 2px 0 rgba(0,0,0,0.1);
}

li.msgarticle {
	color: var(--jm-muted);
	line-height: 1.8;
	background: var(--jm-bg);
	padding: 1rem;
	border-radius: 15px;
}

li.msgtime {
	font-size: 0.75rem;
	color: var(--jm-muted);
	margin-top: 1rem;
}

/* 评论表单 */
#divCommentPost {
	margin-top: 2.5rem;
	padding: 1.5rem;
	background: linear-gradient(135deg, var(--jm-blue) 0%, var(--jm-lavender) 100%);
	border: var(--jm-border);
	border-radius: var(--jm-radius);
	box-shadow: var(--jm-shadow);
}

#divCommentPost a[name="comment"] {
	font-size: 1.125rem;
	font-weight: 700;
	color: var(--jm-ink);
	background: var(--jm-paper);
	padding: 0.75rem 1.25rem;
	border-radius: 15px;
	border: 2px solid var(--jm-ink);
	box-shadow: 3px 3px 0 rgba(0,0,0,0.1);
	display: inline-block;
	margin-bottom: 1.25rem;
}

input.text,
#txaArticle {
	width: 100%;
	padding: 1rem 1.25rem;
	font-size: 0.9375rem;
	color: var(--jm-ink);
	background: var(--jm-paper);
	border: 2px solid var(--jm-ink);
	border-radius: 15px;
	box-shadow: 3px 3px 0 rgba(0,0,0,0.1);
	font-family: var(--jm-font);
	transition: all 0.3s ease;
}

input.text:focus,
#txaArticle:focus {
	outline: none;
	transform: translateY(-2px);
	box-shadow: 5px 5px 0 rgba(0,0,0,0.15);
	background: var(--jm-yellow);
}

#txaArticle {
	min-height: 120px;
	resize: vertical;
}

input.button {
	padding: 1rem 2.5rem;
	font-size: 1rem;
	font-weight: 700;
	color: var(--jm-ink);
	background: var(--jm-pink);
	border: 2px solid var(--jm-ink);
	border-radius: 999px;
	box-shadow: 3px 3px 0 rgba(0,0,0,0.1);
	cursor: pointer;
	font-family: var(--jm-font);
	transition: all 0.3s ease;
}

input.button:hover {
	background: var(--jm-pink-dark);
	transform: translateY(-3px);
	box-shadow: 6px 6px 0 rgba(0,0,0,0.15);
}

/* ========== 页脚 ========== */
#divBottom {
	clear: both;
	margin-top: 2.5rem;
	padding: 2rem;
	text-align: center;
	background: var(--jm-paper);
	border: var(--jm-border);
	border-radius: var(--jm-radius);
	box-shadow: var(--jm-shadow);
	position: relative;
}

/* 页脚樱花 */
#divBottom::before {
	content: "🌸 🌸 🌸";
	position: absolute;
	top: -15px;
	left: 50%;
	transform: translateX(-50%);
	background: var(--jm-bg);
	padding: 0 1rem;
	font-size: 1rem;
	letter-spacing: 0.5rem;
}

#BlogCopyRight {
	font-size: 0.8125rem;
	color: var(--jm-muted);
	line-height: 1.8;
}

#BlogCopyRight a {
	color: var(--jm-pink-dark);
	font-weight: 700;
}

/* ========== 响应式 ========== */
@media (max-width: 900px) {
	#divMain {
		float: none;
		width: 100%;
		padding-right: 0;
		margin-bottom: 2rem;
	}
	
	#divSidebar {
		float: none;
		width: 100%;
	}
	
	div.post.single {
		padding: 1.5rem;
	}
	
	#BlogTitle {
		font-size: 1.75rem;
	}
	
	#divTop::before,
	#divTop::after {
		display: none;
	}
}

@media (max-width: 640px) {
	div.post {
		padding: 1.5rem;
	}
	
	.function {
		padding: 1.25rem;
	}
	
	#divCommentPost {
		padding: 1.25rem;
	}
}
