:root{--brand-primary: #2a7ae2;--brand-primary-soft: #f4f5f7;--brand-ink: #222222;--brand-muted: #5f6368;--brand-line: #e6e8eb;--brand-bg: #ffffff;--brand-surface: #ffffff;--focus-ring: #2a7ae2;--font-sans: "Manrope", "Noto Sans SC", "PingFang SC", sans-serif;--radius: 16px;--radius-pill: 999px;--target-min: 44px;--target-topbar: 38px;--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 0 0 rgba(0, 0, 0, 0);--body-bg: #ffffff;--topbar-bg: rgba(255, 255, 255, .96);--chip-bg: #f7f8fa;--chip-border: #e6e8eb;--chip-text: #6b7280;--surface-soft: #fafafa;--code-bg: #f6f7f9;--code-border: #e1e4e8;--inline-code-bg: #f4f6f8;--inline-code-border: #e3e7eb;--inline-code-text: #333a45;--topbar-height: 58px}html[data-theme=dark]{--brand-primary: #8bb6ff;--brand-primary-soft: #20242d;--brand-ink: #edf1f8;--brand-muted: #b0b9c8;--brand-line: #2a3240;--brand-bg: #0f131a;--brand-surface: #141a24;--focus-ring: #a8c5ff;--link: #8ab4f8;--panel-shadow: 0 16px 34px rgba(2, 8, 20, .35);--body-bg: #0f131a;--topbar-bg: rgba(15, 20, 29, .88);--chip-bg: #1b2230;--chip-border: #2b3443;--chip-text: #b4bdcd;--surface-soft: #121824;--code-bg: #0f1624;--code-border: #2a3448;--inline-code-bg: #1c2433;--inline-code-border: #2e394d;--inline-code-text: #d5deec;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;backdrop-filter:blur(10px);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:1360px;margin:0 auto;padding:.34rem 1rem;display:grid;grid-template-areas:"brand nav actions";grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:.8rem}.menu-toggle{display:none;width:34px;height:34px;border:1px solid var(--line);border-radius:10px;background:var(--card);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:.9rem;font-weight:700;letter-spacing:.01em;white-space:nowrap}.nav{grid-area:nav;display:flex;justify-content:center;flex-wrap:nowrap;gap:.72rem;width:auto}.nav-link{display:inline-flex;align-items:center;justify-content:center;min-height:var(--target-topbar);text-decoration:none;color:var(--muted);font-size:.84rem;font-weight:600;border-bottom:2px solid transparent;padding:.1rem .05rem;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:var(--radius-pill);border:1px solid var(--line);min-height:34px;padding:.06rem .24rem;background:var(--card);color:var(--muted);font-size:.7rem;font-weight:700;white-space:nowrap;cursor:pointer;text-decoration:none}.switch-compact span{display:inline-flex;align-items:center;justify-content:center;padding:.01rem .1rem;border-radius:999px;line-height:1}.switch-compact .switch-sep{padding:0;color:var(--chip-text)}.switch-compact span.active{background:var(--surface-soft);color:var(--ink)}.switch-theme{gap:.08rem;padding-inline:.14rem}.switch-theme span:not(.switch-sep){width:1.26rem;height:1.26rem;padding:0}.switch-theme svg{width:.83rem;height:.83rem;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:.18rem;justify-self:end}.rss-link{display:inline-flex;align-items:center;gap:.16rem;min-height:34px;text-decoration:none;color:var(--muted);font-size:.68rem;font-weight:700;padding:.08rem .26rem;border:1px solid var(--line);border-radius:var(--radius-pill);background:var(--card)}.rss-link img{width:12px;height:12px}.rss-link:hover{color:var(--ink);border-color:color-mix(in srgb,var(--line) 80%,var(--ink) 20%)}.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:0 18px 35px #0003}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:1360px;margin:0 auto;padding:.8rem clamp(.8rem,2vw,1.25rem) 1.1rem}.hero{padding:.95rem 1rem;border-radius:22px;background:var(--card);border:1px solid var(--line);box-shadow:var(--panel-shadow)}.hero h1{margin:0;font-size:clamp(1.5rem,2.8vw,2.2rem);line-height:1.18}.hero p{margin:.52rem 0 0;color:var(--muted);font-size:.96rem}.section{margin-top:.82rem}.first-section{margin-top:0}.section-head{display:flex;align-items:baseline;justify-content:space-between;gap:.8rem;margin-bottom:.46rem}.section-title{margin:0;font-size:1.1rem;font-weight:700;letter-spacing:.01em}.section-more{color:var(--link);text-decoration:none;font-size:.8rem;font-weight:700;min-height:var(--target-min);display:inline-flex;align-items:center}.section-more:hover{color:var(--link)}.grid-cards{display:grid;gap:.62rem}.blog-rows{display:grid;gap:.5rem}.plain-media-list{display:grid;gap:.56rem}.plain-media-item{display:grid;grid-template-columns:minmax(0,1fr);gap:.52rem;padding:.2rem 0 .48rem;border-bottom:1px solid color-mix(in srgb,var(--line) 72%,transparent)}.plain-media-item.has-image{grid-template-columns:minmax(120px,176px) minmax(0,1fr);align-items:start;gap:.75rem}.plain-media-figure{min-width:0}.plain-media-thumb{width:100%;max-width:176px;aspect-ratio:16 / 9;height:auto;border-radius:10px;object-fit:cover;border:1px solid var(--line);background:var(--surface-soft)}.plain-media-body{min-width:0}.plain-media-item:last-child{border-bottom:0;padding-bottom:0}.plain-media-title{margin:0;font-size:.98rem;line-height:1.35}.plain-media-link{color:var(--link);text-decoration:none;border-bottom:2px 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:.86rem;line-height:1.45;overflow-wrap:anywhere}.plain-media-url{margin:.16rem 0 0;font-size:.82rem;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:.32rem 0 0;font-size:.76rem;color:var(--muted);display:flex;gap:.45rem;flex-wrap:wrap}.media-meta span{padding:.04rem .38rem;border-radius:999px;background:var(--chip-bg);border:1px solid var(--chip-border)}.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:999px;padding:.06rem .43rem}.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(--card)}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(--card)}.media-stat-language{color:var(--muted);border:1px solid var(--line);background:var(--card)}.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:grid;justify-content:center;row-gap:.14rem;margin-top:.42rem;font-size:.82rem;color:var(--muted)}.social-row{display:inline-flex;align-items:center;justify-content:center;gap:0}.social-row a{text-decoration:none;color:inherit;font-weight:600;display:inline-flex;align-items:center;min-height:24px;padding:.05rem .02rem;white-space:nowrap}.social-row a:hover{color:var(--accent)}.social-row a+a:before{content:"|";margin:0 .42rem;color:var(--chip-text)}.profile-about-panel{padding:.85rem}.profile-about-grid{display:grid;grid-template-columns:270px minmax(0,1fr);gap:.9rem;align-items:start}.profile-side{text-align:center}.profile-side-meta{min-width:0}.profile-side .social-links{width:100%;margin-inline:auto}.profile-about-copy .section{margin-top:0}.content-single{margin-top:.9rem}.panel .section{margin-top:.66rem}.panel{border-radius:var(--radius);border:1px solid var(--line);background:var(--card);padding:.8rem;box-shadow:var(--panel-shadow)}.wechat-panel{display:flex;justify-content:center}.wechat-qr{width:min(100%,480px);border-radius:12px;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:.8rem;margin-bottom:1rem}.article-title{margin:0;font-size:clamp(1.3rem,2.2vw,1.85rem);line-height:1.22}.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:14px;border:1px solid var(--code-border);background:var(--code-bg);padding:.86rem .95rem;overflow:auto;box-shadow:inset 0 1px #ffffff08}.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:color-mix(in srgb,var(--card) 92%,var(--code-bg));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:color-mix(in srgb,var(--accent-soft) 70%,var(--card));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:.54rem .78rem;border-left:3px solid var(--accent);border-radius:10px;background:color-mix(in srgb,var(--accent-soft) 55%,var(--card));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:12px;border:1px solid var(--line)}.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:.82rem;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%,240px);margin:0 auto;border-radius:14px;border:1px solid var(--line)}.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:.34rem 0;border-bottom:1px solid color-mix(in srgb,var(--line) 70%,transparent)}.archive-item-compact{display:grid;grid-template-columns:118px minmax(0,1fr);gap:.8rem;align-items:start;padding:.34rem 0}.archive-title-link{display:block;text-decoration:none;font-size:.93rem;line-height:1.42}.archive-title-link:hover{color:var(--link)}.archive-date-inline{margin:.06rem 0 0;font-size:.76rem;color:var(--muted);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}footer.site-foot{margin-top:.32rem;padding-bottom:1.2rem;color:var(--muted);font-size:.8rem;text-align:center}.site-foot p{margin:0}.site-foot-signature{font-size:.88rem;color:var(--ink);opacity:.82}.site-foot-sub{margin-top:.22rem!important;font-size:.74rem;color:var(--muted);opacity:.88}.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}html.topbar-collapsed .profile-side .social-links{width:100%;margin-inline:auto;justify-content:center}html.topbar-collapsed .avatar{width:min(100%,240px);margin:0 auto}html.topbar-collapsed .sidebar-title{margin-top:.58rem;text-align:center}html.topbar-collapsed .sidebar-sub{text-align:center}html.topbar-collapsed .social-row{justify-content:center}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){.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}}
