:root{--brand-primary: #335b84;--brand-primary-soft: #eef2f6;--brand-ink: #1d2430;--brand-muted: #5f6874;--brand-line: #dfe5eb;--brand-bg: #ffffff;--brand-surface: #ffffff;--focus-ring: #335b84;--font-sans: "Manrope", "Noto Sans SC", "PingFang SC", sans-serif;--radius: 10px;--radius-pill: 999px;--target-min: 44px;--target-topbar: 36px;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--bg: var(--brand-bg);--ink: var(--brand-ink);--muted: var(--brand-muted);--line: var(--brand-line);--card: var(--brand-surface);--accent: var(--brand-primary);--accent-soft: var(--brand-primary-soft);--link: #0b57d0;--panel-shadow: 0 1px 0 rgba(15, 23, 42, .04);--body-bg: #ffffff;--topbar-bg: var(--body-bg);--chip-bg: #f2f5f8;--chip-border: #dfe5eb;--chip-text: #68707a;--surface-soft: #f5f7fa;--code-bg: #f7f8fa;--code-border: #dfe5eb;--inline-code-bg: #f1f4f7;--inline-code-border: #dbe1e8;--inline-code-text: #2f3945;--topbar-height: 54px;--home-content-max: 1088px;--home-panel-padding: .68rem;--home-side-width: 300px;--home-avatar-width: 280px;--home-media-thumb-width: 280px}html[data-theme=dark]{--brand-primary: #87aeda;--brand-primary-soft: #1b2330;--brand-ink: #e7ecf2;--brand-muted: #a8b3c2;--brand-line: #273140;--brand-bg: #0d1117;--brand-surface: #111720;--focus-ring: #a8c5ff;--link: #8ab4f8;--panel-shadow: 0 1px 0 rgba(255, 255, 255, .03);--body-bg: #0d1117;--topbar-bg: var(--body-bg);--chip-bg: #171e29;--chip-border: #263142;--chip-text: #b1bac8;--surface-soft: #111720;--code-bg: #0f1520;--code-border: #263244;--inline-code-bg: #1a2230;--inline-code-border: #2b3749;--inline-code-text: #d9e3ef;color-scheme:dark}*{box-sizing:border-box}html,body{margin:0;padding:0;width:100%;overflow-x:hidden}body{font-family:var(--font-sans);background:var(--body-bg);color:var(--ink);line-height:1.6;padding-top:var(--topbar-height)}a{color:var(--link)}img{max-width:100%;display:block}.skip-link{position:absolute;left:var(--space-3);top:-120px;z-index:200;background:var(--ink);color:#fff;padding:var(--space-2) var(--space-3);border-radius:12px;text-decoration:none;font-size:.82rem;font-weight:700}.skip-link:focus-visible{top:var(--space-3)}.sr-only{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:3px solid var(--focus-ring);outline-offset:2px}html[data-lang=en] .lang-zh,html[data-lang=zh] .lang-en{display:none!important}.topbar{position:fixed;top:0;left:0;right:0;z-index:30;background:var(--topbar-bg);border-bottom:1px solid var(--line);transition:transform .2s ease,opacity .2s ease;will-change:transform}html.topbar-hidden .topbar{transform:translateY(calc((-1 * var(--topbar-height)) - 1px))}.topbar-inner{max-width:var(--home-content-max);margin:0 auto;padding:.12rem 1rem;display:grid;grid-template-areas:"brand nav actions";grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);align-items:center;gap:.55rem}.menu-toggle{display:none;width:34px;height:34px;border:1px solid var(--line);border-radius:9px;background:transparent;align-items:center;justify-content:center;flex-direction:column;gap:3px;cursor:pointer}.menu-toggle span{display:block;width:14px;height:1.8px;border-radius:999px;background:var(--ink)}.brand{grid-area:brand;display:inline-flex;align-items:center;gap:0;text-decoration:none;color:var(--ink);justify-self:start}.brand-text{font-size:.88rem;font-weight:700;letter-spacing:-.02em;white-space:nowrap}.nav{grid-area:nav;display:flex;justify-content:center;flex-wrap:nowrap;gap:.56rem;width:auto;justify-self:center}.nav-link{display:inline-flex;align-items:center;justify-content:center;min-height:var(--target-topbar);text-decoration:none;color:var(--muted);font-size:.83rem;font-weight:600;border-bottom:1px solid transparent;padding:.08rem 0;text-align:center;flex:0 0 auto;white-space:nowrap}.nav-link.active,.nav-link:hover{color:var(--ink);border-bottom-color:var(--accent)}.switch-compact{display:inline-flex;align-items:center;gap:.05rem;border-radius:8px;border:1px solid transparent;min-height:30px;padding:.02rem .08rem;background:transparent;color:var(--muted);font-size:.68rem;font-weight:700;white-space:nowrap;cursor:pointer;text-decoration:none;transition:color .15s ease,border-color .15s ease}.switch-compact:hover{color:var(--ink)}.switch-compact span{display:inline-flex;align-items:center;justify-content:center;padding:0;border-radius:0;line-height:1}.switch-compact .switch-sep{padding:0;color:var(--chip-text)}.switch-compact span.active{color:var(--ink);font-weight:800}.switch-theme span.active{text-decoration:none}.switch-theme{gap:.04rem;padding-inline:.04rem}.switch-theme span:not(.switch-sep){width:1.14rem;height:1.14rem;padding:0}.switch-theme svg{width:.78rem;height:.78rem;display:block}.switch-theme .switch-sep{width:auto;height:auto;padding:0;line-height:1}.topbar-actions{grid-area:actions;display:inline-flex;align-items:center;gap:.16rem;justify-self:end}.rss-link{display:inline-flex;align-items:center;gap:.12rem;min-height:34px;text-decoration:none;color:var(--muted);font-size:.67rem;font-weight:700;padding:.02rem 0;border:0;border-radius:0;background:transparent}.rss-link img{width:12px;height:12px}.rss-link:hover{color:var(--ink)}.mobile-drawer,.mobile-drawer-backdrop{display:none}html.topbar-collapsed .topbar-inner{grid-template-areas:"menu brand actions";grid-template-columns:auto minmax(0,1fr) auto;gap:.24rem .5rem}html.topbar-collapsed .menu-toggle{grid-area:menu;display:inline-flex}html.topbar-collapsed .nav-desktop{display:none}html.topbar-collapsed .brand-text{font-size:.84rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}html.topbar-collapsed .mobile-drawer-backdrop{display:block;position:fixed;inset:0;z-index:34;background:#00000047;border:0;opacity:0;pointer-events:none;transition:opacity .18s ease}html.topbar-collapsed .mobile-drawer{display:block;position:fixed;left:0;top:0;z-index:35;width:min(72vw,250px);height:100dvh;background:var(--card);border-right:1px solid var(--line);padding:.56rem;transform:translate(-106%);transition:transform .2s ease;box-shadow:none}html.topbar-collapsed .mobile-drawer-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:.4rem}html.topbar-collapsed .mobile-drawer-title{font-size:.9rem;font-weight:700;padding-left:.34rem}html.topbar-collapsed .mobile-drawer-close{width:32px;height:32px;border:1px solid var(--line);border-radius:9px;background:var(--card);color:var(--ink);font-size:1.1rem;line-height:1;cursor:pointer}html.topbar-collapsed .mobile-nav{display:grid;gap:.2rem}html.topbar-collapsed .mobile-nav-link{display:flex;align-items:center;min-height:38px;padding:.2rem .34rem;border-radius:10px;text-decoration:none;color:var(--muted);font-weight:600}html.topbar-collapsed .mobile-nav-link.active,html.topbar-collapsed .mobile-nav-link:hover{color:var(--ink);background:var(--accent-soft)}html.menu-open.topbar-collapsed .mobile-drawer{transform:translate(0)}html.menu-open.topbar-collapsed .mobile-drawer-backdrop{opacity:1;pointer-events:auto}.page-shell{max-width:var(--home-content-max);margin:0 auto;padding:.74rem clamp(.8rem,2vw,1.25rem) 1.05rem}.hero{padding:.12rem 0 .72rem;border-radius:0;background:transparent;border:0;border-bottom:1px solid color-mix(in srgb,var(--line) 74%,transparent);box-shadow:none}.hero h1{margin:0;font-size:clamp(1.45rem,2.6vw,2.08rem);line-height:1.18;letter-spacing:-.03em}.hero p{margin:.46rem 0 0;color:var(--muted);font-size:.94rem;line-height:1.56;max-width:64ch}.section{margin-top:.84rem}.first-section{margin-top:0}.section-head{display:flex;align-items:baseline;justify-content:space-between;gap:.8rem;margin-bottom:.28rem}.section-title{margin:0;font-size:.99rem;font-weight:700;letter-spacing:-.015em}.section-head-rail{align-items:center;justify-content:center;gap:.62rem;margin-bottom:.3rem}.section-head-rail .section-title{flex:0 0 auto;white-space:nowrap}.section-head-line{flex:1 1 0;min-width:1rem;height:1px;background:color-mix(in srgb,var(--line) 64%,transparent)}.plain-media-list{display:grid;gap:.4rem}.blog-rows{display:grid;gap:.5rem}.plain-media-item{display:grid;grid-template-columns:minmax(0,1fr);gap:.38rem;padding:.16rem 0 .38rem;border-bottom:1px solid color-mix(in srgb,var(--line) 54%,transparent)}.plain-media-item.has-image{grid-template-columns:minmax(0,var(--home-media-thumb-width)) minmax(0,1fr);align-items:start;gap:.62rem}.plain-media-figure{min-width:0}.plain-media-thumb{width:100%;max-width:var(--home-media-thumb-width);aspect-ratio:16 / 9;height:auto;border-radius:8px;object-fit:cover;border:1px solid color-mix(in srgb,var(--line) 78%,transparent);background:var(--surface-soft)}.plain-media-thumb-placeholder{visibility:hidden}.plain-media-body{min-width:0}.plain-media-item:last-child{border-bottom:0;padding-bottom:0}.plain-media-title{margin:0;font-size:.95rem;line-height:1.38}.plain-media-link{color:var(--link);text-decoration:none;border-bottom:1px solid transparent;transition:color .15s ease,border-color .15s ease}.plain-media-link:hover{color:var(--ink);border-bottom-color:var(--accent)}.plain-media-desc{margin:.18rem 0 0;color:var(--muted);font-size:.83rem;line-height:1.52;overflow-wrap:anywhere}.plain-media-url{margin:.12rem 0 0;font-size:.77rem;color:var(--muted);line-height:1.25;overflow-wrap:anywhere}.media-language-dot{width:9px;height:9px;border-radius:999px;border:1px solid rgba(0,0,0,.08)}.media-language-ratio{color:var(--muted)}.media-meta{margin:.28rem 0 0;font-size:.76rem;color:var(--muted);display:flex;gap:.45rem;flex-wrap:wrap}.media-meta span{padding:.02rem .28rem;border-radius:6px;background:transparent;border:1px solid color-mix(in srgb,var(--chip-border) 72%,transparent)}.media-stats{margin:.38rem 0 0;display:flex;flex-wrap:wrap;gap:.46rem}.plain-media-stats{margin-top:.3rem;gap:.72rem}.media-stat{display:inline-flex;align-items:center;gap:.22rem;font-size:.77rem;font-weight:700;line-height:1;font-variant-numeric:tabular-nums;border-radius:6px;padding:.04rem .34rem}.media-stat-icon{width:.9rem;height:.9rem;display:inline-flex;align-items:center;justify-content:center;flex:0 0 .9rem}.media-stat-icon svg{width:100%;height:100%;display:block}.media-stat-icon-view svg,.media-stat-icon-like svg{width:.88rem;height:.88rem}.media-stat-icon-like{transform:translateY(.02em)}.media-stat-value{display:inline-block;line-height:1}.media-stat-github{color:var(--muted);border:1px solid var(--line);background:var(--surface-soft)}html[data-theme=dark] .media-stat-github{color:var(--muted);border-color:var(--line);background:var(--card)}.media-stat-text{font-size:.78rem;font-weight:700;color:var(--muted);border:1px solid var(--line);background:var(--surface-soft)}.media-stat-language{color:var(--muted);border:1px solid var(--line);background:var(--surface-soft)}.plain-media-item .media-stat,.plain-media-item .media-stat-language,.plain-media-item .media-stat-github,.plain-media-item .media-stat-text{padding:0;border:0;border-radius:0;background:transparent;color:var(--muted)}.social-links{display:flex;justify-content:center;flex-wrap:wrap;margin-top:.34rem;font-size:.8rem;color:var(--muted)}.social-row{display:inline-flex;align-items:center;justify-content:center;gap:0;flex-wrap:wrap}.social-row a{text-decoration:none;color:inherit;font-weight:600;display:inline-flex;align-items:center;justify-content:center;min-width:0;min-height:0;padding:.08rem .14rem;line-height:1;white-space:nowrap}.social-row a:hover{color:var(--accent)}.social-row a+a:before{content:"·";margin:0 .16rem;color:var(--chip-text)}.profile-about-panel{padding:var(--home-panel-padding)}.profile-about-grid{display:grid;grid-template-columns:var(--home-side-width) minmax(0,1fr);gap:.76rem;align-items:start}.profile-side{text-align:center}.profile-side-meta{margin-bottom:.72rem;text-align:center;min-width:0}.profile-side-meta .sidebar-title{margin-top:0;margin-bottom:.16rem}.profile-side-meta .sidebar-sub{margin-top:0}.profile-side-meta .social-links{width:100%;margin-inline:auto;justify-content:center}.profile-about-copy .section{margin-top:0}.content-single{margin-top:.76rem}.panel .section{margin-top:.66rem}.panel{border-radius:10px;border:1px solid var(--line);background:var(--card);padding:.68rem;box-shadow:none}.wechat-panel{display:flex;justify-content:center}.wechat-qr{width:min(100%,480px);border-radius:8px;border:1px solid var(--line)}.article-panel{max-width:980px;margin:0 auto;padding:0 clamp(0rem,.6vw,.2rem)}.article-header{border-bottom:1px solid var(--line);padding-bottom:.62rem;margin-bottom:.82rem}.article-title{margin:0;font-size:clamp(1.28rem,2.1vw,1.8rem);line-height:1.22;letter-spacing:-.025em}.article-date{margin:.35rem 0 0;color:var(--muted);font-size:.84rem}.article-date a{overflow-wrap:anywhere;word-break:break-word}.article-prose{color:var(--ink)}.article-prose>:first-child{margin-top:0}.article-prose>.code-block-shell:first-child,.about-prose>.code-block-shell:first-child{margin-top:0}.article-prose h1,.article-prose h2,.article-prose h3{line-height:1.3;margin:1.25rem 0 .62rem}.article-prose p,.article-prose ul,.article-prose ol{margin:.58rem 0}.article-prose li{margin:.24rem 0}.about-prose{color:var(--ink)}.about-prose>:first-child{margin-top:0}.about-prose ul{margin:.2rem 0 0;padding-left:.2rem;list-style-position:inside}.about-prose li{margin:.06rem 0;overflow-wrap:anywhere;line-height:1.5}.about-prose a{color:var(--link)}.article-prose a{color:var(--link);text-decoration-color:color-mix(in srgb,var(--link) 45%,transparent);text-underline-offset:2px;overflow-wrap:anywhere;word-break:break-word}.article-prose a:visited,.about-prose a:visited,.archive-title-link:visited,.plain-media-link:visited{color:var(--link)}.article-prose hr{border:0;border-top:1px solid var(--line);margin:1rem 0}.article-prose pre,.about-prose pre{margin:.72rem 0;border-radius:10px;border:1px solid var(--code-border);background:var(--code-bg);padding:.82rem .9rem;overflow:auto;box-shadow:none}.code-block-shell{position:relative;margin:.72rem 0}.article-prose .code-block-shell pre,.about-prose .code-block-shell pre{margin:0}.code-copy-ready{padding-top:2.9rem}.code-copy-button{position:absolute;top:.68rem;right:.7rem;z-index:1;display:inline-flex;align-items:center;justify-content:center;min-height:32px;padding:.4rem .78rem;border:1px solid var(--code-border);border-radius:999px;background:transparent;color:var(--muted);font-family:var(--font-sans);font-size:.72rem;font-weight:700;line-height:1;white-space:nowrap;cursor:pointer;transition:background .18s ease,color .18s ease,border-color .18s ease,opacity .18s ease,transform .18s ease}.code-copy-button:hover{background:var(--surface-soft);color:var(--ink)}.code-copy-button[data-copy-state=success]{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 35%,var(--code-border))}.code-copy-button[data-copy-state=error]{color:var(--ink)}@media(hover:hover)and (pointer:fine){.code-copy-button{opacity:0;transform:translateY(-4px);pointer-events:none}.code-block-shell:hover .code-copy-button,.code-block-shell:focus-within .code-copy-button{opacity:1;transform:translateY(0);pointer-events:auto}}.article-prose pre code,.about-prose pre code{font-family:SFMono-Regular,ui-monospace,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.84rem;line-height:1.62;color:inherit}.article-prose :not(pre)>code,.about-prose :not(pre)>code{font-family:SFMono-Regular,ui-monospace,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.84em;color:var(--inline-code-text);background:var(--inline-code-bg);border:1px solid var(--inline-code-border);border-radius:8px;padding:.08rem .34rem}.article-prose blockquote{margin:.72rem 0;padding:.48rem .72rem;border-left:2px solid var(--accent);border-radius:0;background:transparent;color:var(--ink)}.article-prose blockquote>:first-child{margin-top:0}.article-prose blockquote>:last-child{margin-bottom:0}.article-prose p:has(>img){margin:.72rem auto .32rem;text-align:center}.article-prose figure.article-figure{margin:.72rem auto .8rem;display:flex;flex-direction:column;align-items:center}.article-prose img{width:min(100%,clamp(220px,66%,760px));height:auto;margin:0 auto;border-radius:8px;border:1px solid color-mix(in srgb,var(--line) 78%,transparent)}.article-prose figcaption.article-figcaption{max-width:min(100%,760px);margin-top:.35rem;text-align:center;color:var(--muted);font-size:.9rem;font-style:italic}.article-prose p:has(>img)+p:has(>em:only-child),.article-prose p:has(>img)+p:has(>a:only-child),.article-prose p:has(>img)+p:has(>em>a:only-child){max-width:min(100%,760px);margin:0 auto .8rem;text-align:center;color:var(--muted);font-size:.9rem}.comments-panel{margin-top:.72rem;max-width:980px;margin-left:auto;margin-right:auto}.giscus-root{margin-top:.3rem;width:100%}.comments-hint{margin:.2rem 0 0;color:var(--muted);font-size:.86rem}.avatar{width:min(100%,var(--home-avatar-width));margin:0 auto;border-radius:10px;border:1px solid var(--line)}.selected-work-list{padding-left:calc(var(--home-panel-padding) + (var(--home-side-width) - var(--home-avatar-width)) / 2)}.sidebar-title{margin:.58rem 0 .2rem;font-size:1.22rem}.sidebar-sub{margin:0;color:var(--muted);font-size:.88rem}.sidebar-sub p{margin:0;line-height:1.4}.list a{color:var(--link)}.list{margin:.2rem 0 0;padding-left:.2rem;list-style-position:inside}.list li{margin:.06rem 0;overflow-wrap:anywhere;line-height:1.5}.section-title+.list,.section-head+.list{margin-top:.2rem}.archive-list{display:grid}.archive-list-compact{gap:0}.archive-item{padding:.3rem 0;border-bottom:1px solid color-mix(in srgb,var(--line) 60%,transparent)}.archive-item-compact{display:flex;flex-wrap:wrap;align-items:baseline;gap:.16rem .42rem;padding:.3rem 0}.archive-title-link{display:inline;text-decoration:none;font-size:.93rem;line-height:1.42}.archive-title-link:hover{color:var(--link)}.archive-date-inline{margin:0;font-size:.76rem;color:var(--muted);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.archive-tag-inline{margin:0;font-size:.8rem;color:var(--muted);font-weight:600}footer.site-foot{margin-top:.18rem;padding-bottom:1.2rem;color:var(--muted);font-size:.8rem;text-align:center}.site-foot p{margin:0}.site-foot-signature{font-size:.84rem;color:var(--ink);opacity:.82;font-style:normal}.site-foot-sub{margin-top:.22rem!important;font-size:.72rem;color:var(--muted);opacity:1}.site-foot-meta{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;white-space:nowrap}.site-foot-sep{color:var(--muted);opacity:.7}.site-foot-sub a{color:inherit;text-underline-offset:2px}html.topbar-collapsed .profile-about-grid{grid-template-columns:1fr}html.topbar-collapsed .profile-side{display:block;width:100%;max-width:100%;margin-inline:auto;text-align:center}html.topbar-collapsed .profile-side-meta{display:block;margin-top:.68rem}html.topbar-collapsed .avatar{width:min(100%,var(--home-avatar-width));margin:0 auto}html.topbar-collapsed .social-row{justify-content:center}html.topbar-collapsed .selected-work-list{padding-left:0}html.topbar-collapsed .plain-media-item.has-image{grid-template-columns:1fr;gap:.46rem}html.topbar-collapsed .plain-media-thumb{max-width:min(100%,360px)}@media(max-width:820px){.selected-work-list{padding-left:0}.plain-media-item.has-image{grid-template-columns:1fr;gap:.46rem}.plain-media-thumb{max-width:min(100%,360px)}.article-prose li,.article-prose p{overflow-wrap:anywhere;word-break:break-word}.article-prose pre code,.about-prose pre code{white-space:pre-wrap;overflow-wrap:anywhere;word-break:break-word}}@media(max-width:640px){.archive-item-compact{grid-template-columns:96px minmax(0,1fr);gap:.62rem}}
