:root{--canvas:#ffffff;--surface-soft:#fafafa;--surface-card:#ffffff;--surface-dark:#171717;--hairline:#e5e5e5;--hairline-strong:#d4d4d4;--ink:#000000;--ink-deep:#090909;--charcoal:#525252;--body:#737373;--mute:#a3a3a3;--on-dark:#ffffff;--on-dark-mute:rgba(255, 255, 255, 0.7);--primary:var(--ink);--on-primary:var(--canvas);--bg:var(--canvas);--bg-secondary:var(--surface-soft);--card-bg:var(--canvas);--text:var(--ink);--text-secondary:var(--body);--border:var(--hairline);--accent:var(--ink);--accent-end:var(--charcoal);--meta-color:var(--canvas);--color-success:#1a7f37;--radius-full:9999px;--radius-lg:12px;--radius-md:8px;--radius-sm:6px;--space-section:88px;--space-section-mobile:48px;--space-section-title-pl:0;--space-section-title-border:0;--space-tag-x:0.75rem;--space-tag-y:0.375rem;--space-hero-404-y:5rem;--font-display:"SF Pro Rounded", "Nunito", "PingFang SC", "Hiragino Sans GB",
        system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue",
        Arial, sans-serif;--font-body:ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto,
        "Helvetica Neue", "PingFang SC", "Hiragino Sans GB",
        "Microsoft YaHei", Arial, sans-serif;--font-mono:ui-monospace, SFMono-Regular, "SF Mono", "JetBrains Mono",
        "Fira Code", Menlo, Monaco, Consolas, "Cascadia Code",
        "Liberation Mono", monospace;--focus-ring:2px solid rgba(59, 130, 246, 0.5);--focus-offset:2px}[data-theme=dark]{--canvas:#0a0a0a;--surface-soft:#171717;--surface-card:#0a0a0a;--surface-dark:#ffffff;--hairline:#262626;--hairline-strong:#404040;--ink:#ffffff;--ink-deep:#f5f5f5;--charcoal:#d4d4d4;--body:#a3a3a3;--mute:#737373;--on-dark:#000000;--on-dark-mute:rgba(0, 0, 0, 0.7);--primary:var(--ink);--on-primary:var(--canvas);--bg:var(--canvas);--bg-secondary:var(--surface-soft);--card-bg:var(--canvas);--text:var(--ink);--text-secondary:var(--body);--border:var(--hairline);--accent:var(--ink);--accent-end:var(--charcoal);--meta-color:var(--canvas);--color-success:#56d364}.chroma{color:#3c3f58}.chroma .err{color:#d20f39}.chroma .lnlinks{outline:none;text-decoration:none;color:inherit}.chroma .lntd{vertical-align:top;padding:0;margin:0;border:0}.chroma .lntable{border-spacing:0;padding:0;margin:0;border:0}.chroma .hl{background-color:#eaeaea}.chroma .lnt,.chroma .ln{white-space:pre;-webkit-user-select:none;user-select:none;margin-right:.4em;padding:0 .4em;color:#8c8fa1}.chroma .line{display:flex}.chroma .k,.chroma .kp,.chroma .kr{color:#8839ef}.chroma .kc{color:#fe640b}.chroma .kd,.chroma .kt{color:#d20f39}.chroma .kn{color:#179299}.chroma .na{color:#1e66f5}.chroma .nc,.chroma .no{color:#df8e1d}.chroma .nd{color:#1e66f5;font-weight:700}.chroma .ni{color:#179299}.chroma .ne{color:#fe640b}.chroma .nl{color:#04a5e5}.chroma .nn{color:#fe640b}.chroma .py{color:#fe640b}.chroma .nt{color:#8839ef}.chroma .nb,.chroma .bp{color:#04a5e5}.chroma .nv,.chroma .vc,.chroma .vg,.chroma .vi,.chroma .vm{color:#dc8a78}.chroma .nf,.chroma .fm{color:#1e66f5}.chroma .s,.chroma .sb,.chroma .sc,.chroma .s2,.chroma .si,.chroma .sx,.chroma .s1,.chroma .ss{color:#40a02b}.chroma .sa{color:#d20f39}.chroma .dl,.chroma .se{color:#1e66f5}.chroma .sd,.chroma .sh{color:#9ca0b0}.chroma .sr{color:#179299}.chroma .m,.chroma .mb,.chroma .mf,.chroma .mh,.chroma .mi,.chroma .il,.chroma .mo{color:#fe640b}.chroma .o,.chroma .ow{color:#04a5e5;font-weight:700}.chroma .c,.chroma .cm,.chroma .c1,.chroma .cs,.chroma .cp{color:#9ca0b0;font-style:italic}.chroma .ch{color:#acb0be;font-style:italic}.chroma .cpf{color:#9ca0b0;font-weight:700;font-style:italic}.chroma .gd{color:#d20f39;background-color:#ccd0da}.chroma .ge{font-style:italic}.chroma .gr{color:#d20f39}.chroma .gh,.chroma .gu{color:#fe640b;font-weight:700}.chroma .gi{color:#40a02b;background-color:#ccd0da}.chroma .gs{font-weight:700}.chroma .gt{color:#d20f39}.chroma .gl{text-decoration:underline}[data-theme=dark] .chroma{color:#cdd6f4}[data-theme=dark] .chroma .err{color:#f38ba8}[data-theme=dark] .chroma .hl{background-color:#1f1f1f}[data-theme=dark] .chroma .lnt,[data-theme=dark] .chroma .ln{color:#7f849c}[data-theme=dark] .chroma .k,[data-theme=dark] .chroma .kp,[data-theme=dark] .chroma .kr{color:#cba6f7}[data-theme=dark] .chroma .kc{color:#fab387}[data-theme=dark] .chroma .kd,[data-theme=dark] .chroma .kt{color:#f38ba8}[data-theme=dark] .chroma .kn{color:#94e2d5}[data-theme=dark] .chroma .na{color:#89b4fa}[data-theme=dark] .chroma .nc,[data-theme=dark] .chroma .no{color:#f9e2af}[data-theme=dark] .chroma .nd{color:#89b4fa;font-weight:700}[data-theme=dark] .chroma .ni{color:#94e2d5}[data-theme=dark] .chroma .ne{color:#fab387}[data-theme=dark] .chroma .nl{color:#89dceb}[data-theme=dark] .chroma .nn{color:#fab387}[data-theme=dark] .chroma .py{color:#fab387}[data-theme=dark] .chroma .nt{color:#cba6f7}[data-theme=dark] .chroma .nb,[data-theme=dark] .chroma .bp{color:#89dceb}[data-theme=dark] .chroma .nv,[data-theme=dark] .chroma .vc,[data-theme=dark] .chroma .vg,[data-theme=dark] .chroma .vi,[data-theme=dark] .chroma .vm{color:#f5e0dc}[data-theme=dark] .chroma .nf,[data-theme=dark] .chroma .fm{color:#89b4fa}[data-theme=dark] .chroma .s,[data-theme=dark] .chroma .sb,[data-theme=dark] .chroma .sc,[data-theme=dark] .chroma .s2,[data-theme=dark] .chroma .si,[data-theme=dark] .chroma .sx,[data-theme=dark] .chroma .s1,[data-theme=dark] .chroma .ss{color:#a6e3a1}[data-theme=dark] .chroma .sa{color:#f38ba8}[data-theme=dark] .chroma .dl,[data-theme=dark] .chroma .se{color:#89b4fa}[data-theme=dark] .chroma .sd,[data-theme=dark] .chroma .sh{color:#6c7086}[data-theme=dark] .chroma .sr{color:#94e2d5}[data-theme=dark] .chroma .m,[data-theme=dark] .chroma .mb,[data-theme=dark] .chroma .mf,[data-theme=dark] .chroma .mh,[data-theme=dark] .chroma .mi,[data-theme=dark] .chroma .il,[data-theme=dark] .chroma .mo{color:#fab387}[data-theme=dark] .chroma .o,[data-theme=dark] .chroma .ow{color:#89dceb;font-weight:700}[data-theme=dark] .chroma .c,[data-theme=dark] .chroma .cm,[data-theme=dark] .chroma .c1,[data-theme=dark] .chroma .cs,[data-theme=dark] .chroma .cp{color:#6c7086;font-style:italic}[data-theme=dark] .chroma .ch{color:#585b70;font-style:italic}[data-theme=dark] .chroma .cpf{color:#6c7086;font-weight:700;font-style:italic}[data-theme=dark] .chroma .gd{color:#f38ba8;background-color:#1f1f1f}[data-theme=dark] .chroma .gr{color:#f38ba8}[data-theme=dark] .chroma .gh,[data-theme=dark] .chroma .gu{color:#fab387;font-weight:700}[data-theme=dark] .chroma .gi{color:#a6e3a1;background-color:#1f1f1f}[data-theme=dark] .chroma .gt{color:#f38ba8}*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:var(--font-body);font-size:16px;line-height:1.5;color:var(--ink);background-color:var(--canvas);background-size:cover;background-position:50%;background-attachment:fixed;background-repeat:no-repeat;transition:background-color .2s ease,color .2s ease;min-height:100vh;display:flex;flex-direction:column;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:var(--ink);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px;transition:color .15s ease}a:hover{color:var(--charcoal)}.site-nav a:focus-visible,.menu-toggle:focus-visible,.search-toggle:focus-visible,.theme-toggle:focus-visible,.pagination-link:focus-visible:not(.disabled),.tag:focus-visible,.nav-search-btn:focus-visible,.article-content .code-block .copy-btn:focus-visible{outline:var(--focus-ring);outline-offset:var(--focus-offset)}.search-overlay-input,.search-overlay-input:focus,.search-overlay-input:focus-visible{outline:none;box-shadow:none}img{max-width:100%;height:auto;border-radius:var(--radius-lg)}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);line-height:1.25;font-weight:600;color:var(--ink);letter-spacing:0}h1{font-size:2.25rem;font-weight:500;line-height:1.11}h2{font-size:1.5rem;font-weight:600;line-height:1.33}h3{font-size:1.25rem;font-weight:500;line-height:1.4}.container{width:100%;max-width:960px;margin:0 auto;padding:0 1.5rem}main{flex:1;padding:2.5rem 0 var(--space-section)}.site-header{background:var(--canvas);padding:0;position:sticky;top:0;z-index:100;transition:background-color .2s ease}.site-header .container{display:flex;align-items:center;justify-content:space-between;gap:1rem;height:56px}.site-title{font-family:var(--font-display);font-size:1rem;font-weight:600;letter-spacing:0;white-space:nowrap;position:relative;overflow:hidden;line-height:1.5;padding:.125rem 0}.site-title-brand,.site-title-article{display:block;transition:opacity .25s ease,transform .25s ease}.site-title-article{position:absolute;top:50%;left:0;right:0;opacity:0;transform:translate(0,calc(-50% + 8px));pointer-events:none;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center;color:var(--ink);font-family:var(--font-body);font-size:.875rem;font-weight:500}.site-title a{color:var(--ink);text-decoration:none}.site-title a:hover{color:var(--ink);opacity:.7}.site-logo{height:1.5em;width:auto;vertical-align:middle;border-radius:0}.header-right{display:flex;align-items:center;gap:.5rem}.nav-search-item{display:none}.site-nav ul{display:flex;list-style:none;gap:.25rem;align-items:center}.site-nav a{display:flex;align-items:center;height:36px;padding:0 .875rem;border-radius:var(--radius-full);color:var(--body);font-family:var(--font-body);font-size:.875rem;font-weight:500;text-decoration:none;background:0 0;transition:color .15s ease,background-color .15s ease}.site-nav a:hover,.site-nav a.active{color:var(--ink);background:var(--surface-soft)}.site-nav a.ancestor:not(.active){color:var(--ink)}.site-nav a:active{background:var(--hairline)}.menu-toggle{display:none;background:0 0;border:1px solid var(--hairline);border-radius:var(--radius-full);width:36px;height:36px;padding:0;align-items:center;justify-content:center;cursor:pointer;color:var(--ink);transition:background-color .15s ease,border-color .15s ease}.menu-toggle:hover{background:var(--surface-soft)}.menu-toggle:active{background:var(--hairline)}.menu-toggle svg{display:block;width:18px;height:18px}.search-toggle,.theme-toggle{background:0 0;border:1px solid var(--hairline);border-radius:var(--radius-full);width:36px;height:36px;padding:0;cursor:pointer;color:var(--ink);transition:background-color .15s ease,border-color .15s ease;display:flex;align-items:center;justify-content:center;flex-shrink:0}.search-toggle:hover,.theme-toggle:hover{background:var(--surface-soft)}.search-toggle:active,.theme-toggle:active{background:var(--hairline)}.search-toggle svg,.theme-toggle svg{width:16px;height:16px}.theme-toggle .icon-sun,.theme-toggle .icon-moon{transition:opacity .15s ease}.theme-toggle .icon-sun{display:block}.theme-toggle .icon-moon{display:none}[data-theme=dark] .theme-toggle .icon-sun{display:none}[data-theme=dark] .theme-toggle .icon-moon{display:block}.card{background:var(--surface-card);border:1px solid var(--hairline);border-radius:var(--radius-lg);padding:1.5rem;transition:border-color .2s ease,background-color .2s ease}.card.post-card{transition:border-color .15s ease}.card.post-card:hover{border-color:var(--ink)}.post-card-stretched-link{position:absolute;inset:0;z-index:1;border-radius:inherit}.post-card>:not(.post-card-stretched-link){position:relative;z-index:2}.hero{text-align:center;padding:3.5rem 0 2.5rem}.hero-title{font-family:var(--font-display);font-size:2.25rem;font-weight:500;line-height:1.11;letter-spacing:0;margin-bottom:1rem;color:var(--ink)}.hero-desc{font-family:var(--font-body);font-size:1rem;font-weight:400;line-height:1.5;color:var(--body);max-width:560px;margin:0 auto}.hero-desc p{margin:0}.hero-desc p+p{margin-top:.5rem}.section-title{font-family:var(--font-display);font-size:1.5rem;font-weight:600;line-height:1.33;color:var(--ink);margin-bottom:1.5rem;padding-left:0;border-left:none}.post-grid{display:grid;grid-template-columns:1fr;gap:1rem}.empty-state{text-align:center;padding:2rem 1.5rem;color:var(--body);font-size:1rem;line-height:1.5}.post-card{position:relative;display:flex;flex-direction:column;gap:.5rem;padding:1.5rem}.post-card .post-title{font-family:var(--font-display);font-size:1.25rem;font-weight:600;line-height:1.4}.post-card .post-title a{color:var(--ink);text-decoration:none;transition:color .15s ease}.post-card .post-title a:hover{color:var(--charcoal)}.post-card .post-meta{font-family:var(--font-body);font-size:.8125rem;color:var(--mute);line-height:1.4}.post-card .post-summary{font-family:var(--font-body);font-size:.9375rem;color:var(--body);line-height:1.6;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;margin-top:.25rem}.tags{display:flex;flex-wrap:wrap;gap:.5rem}.tag{display:inline-flex;align-items:center;padding:var(--space-tag-y)var(--space-tag-x);border-radius:var(--radius-full);font-family:var(--font-body);font-size:.8125rem;font-weight:500;color:var(--charcoal);background:var(--surface-soft);border:1px solid transparent;text-decoration:none;transition:background-color .15s ease,color .15s ease,border-color .15s ease}.tag:hover{color:var(--ink);background:var(--canvas);border-color:var(--hairline-strong)}.article-header{margin-bottom:2.5rem}.article-header h1{font-family:var(--font-display);font-size:2.25rem;font-weight:500;line-height:1.15;margin-bottom:.75rem;letter-spacing:0}.article-meta{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;font-family:var(--font-body);font-size:.875rem;color:var(--mute)}.article-content{line-height:1.7;font-size:1rem;color:var(--ink)}.article-content h2{font-family:var(--font-display);font-size:1.5rem;font-weight:600;line-height:1.33;margin:2.5rem 0 1rem}.article-content h3{font-family:var(--font-display);font-size:1.25rem;font-weight:500;line-height:1.4;margin:2rem 0 .75rem}.article-content p{margin-bottom:1.25rem;color:var(--ink)}.article-content ul,.article-content ol{margin-bottom:1.25rem;padding-left:1.5rem;color:var(--ink)}.article-content li{margin-bottom:.5rem}.article-content a{color:var(--ink);text-decoration:underline;text-underline-offset:2px}.article-content a:hover{color:var(--charcoal)}.article-content blockquote{border-left:2px solid var(--hairline-strong);padding:.5rem 1rem;margin:1.5rem 0;background:0 0;border-radius:0;color:var(--body);font-style:normal}.article-content blockquote p{color:var(--body)}.article-content blockquote p:last-child{margin-bottom:0}.article-content hr{border:0;border-top:1px solid var(--hairline);margin:2rem 0}.article-content .code-block{position:relative;margin-bottom:1.5rem;background:var(--surface-soft);border:1px solid var(--hairline);border-radius:var(--radius-md);overflow:hidden}.article-content .code-header{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;justify-content:space-between;padding:.5rem .5rem .5rem .875rem;z-index:1;pointer-events:none;border-bottom:1px solid transparent}.article-content .code-block.has-lang .code-header{border-bottom-color:var(--hairline);background:var(--surface-soft)}.article-content .code-lang{font-family:var(--font-mono);font-size:.75rem;font-weight:500;color:var(--mute);text-transform:uppercase;letter-spacing:.04em;user-select:none;line-height:1}.article-content .code-block .copy-btn{display:flex;align-items:center;justify-content:center;width:1.75rem;height:1.75rem;padding:0;margin-left:auto;border:none;border-radius:var(--radius-sm);background:0 0;color:var(--mute);cursor:pointer;pointer-events:auto;transition:color .15s ease,background .15s ease}.article-content .code-block .copy-btn:hover{color:var(--ink);background:var(--canvas)}.article-content .code-block .copy-btn:active{background:var(--hairline)}.article-content .code-block .copy-btn .icon-check{display:none}.article-content .code-block .copy-btn.copied{color:var(--color-success)}.article-content .code-block .copy-btn.copied .icon-copy{display:none}.article-content .code-block .copy-btn.copied .icon-check{display:block}.article-content .code-block .copy-btn[data-copy-error]{color:#d20f39}[data-theme=dark] .article-content .code-block .copy-btn[data-copy-error]{color:#f38ba8}.article-content pre{background:0 0;border-radius:0;padding:1rem;overflow-x:auto;margin-bottom:0;font-family:var(--font-mono);font-size:.875rem;line-height:1.5}.article-content .code-block pre{padding-top:2.5rem}.article-content .code-block.has-lang pre{padding-top:2.75rem}.article-content .code-block+:not(.code-block),.article-content :not(.code-block)+.code-block{margin-top:1.5rem}.article-content code{font-family:var(--font-mono);font-size:.9em}.article-content p code,.article-content li code{background:var(--surface-soft);padding:.125rem .4rem;border-radius:var(--radius-sm);border:1px solid var(--hairline);font-size:.875em}.article-content img{margin:1.5rem 0;border:1px solid var(--hairline);border-radius:var(--radius-lg);cursor:zoom-in;transition:border-color .2s ease}.article-content img:hover{border-color:var(--ink)}.article-content a[data-pswp-width]{display:block;text-decoration:none;border:none}.pswp{--pswp-bg:var(--canvas)}.article-footer{margin-top:3rem;padding-top:1.5rem;border-top:1px solid var(--hairline)}.tag-cloud-canvas-wrapper{display:flex;align-items:center;justify-content:center;padding:1.5rem;width:100%;box-sizing:border-box;min-height:clamp(380px,min(58vh,52vw),680px)}.tag-cloud-canvas-wrapper canvas{display:block;max-width:100%;height:auto}.search-wrapper{max-width:960px;margin:0 auto;--pagefind-ui-scale:1;--pagefind-ui-primary:var(--ink);--pagefind-ui-text:var(--ink);--pagefind-ui-background:var(--canvas);--pagefind-ui-border:var(--hairline);--pagefind-ui-border-width:1px;--pagefind-ui-border-radius:var(--radius-full);--pagefind-ui-font:var(--font-body)}.search-wrapper .pagefind-ui__form::before{display:none!important}.search-wrapper .pagefind-ui__search-input{background:var(--canvas)!important;color:var(--ink)!important;border:1px solid var(--hairline)!important;border-radius:var(--radius-full)!important;box-shadow:none!important;padding:.625rem 3rem .625rem 1.25rem!important;font-size:.9375rem!important;font-family:inherit!important;outline:none!important;width:100%!important;height:auto!important;transition:border-color .15s ease!important}.search-wrapper .pagefind-ui__search-input::placeholder{color:var(--mute)!important}.search-wrapper .pagefind-ui__search-input:focus{border-color:var(--ink)!important;box-shadow:none!important}.search-wrapper .pagefind-ui__form{position:relative!important;background:0 0!important;border:none!important;box-shadow:none!important;outline:none!important}.search-wrapper .pagefind-ui__drawer{border:none!important;box-shadow:none!important;padding:0!important;margin-top:1.5rem!important}.search-wrapper .pagefind-ui__search-clear{color:transparent!important;background:0 0!important;width:2rem!important;height:2rem!important;min-width:0!important;overflow:hidden!important;position:absolute!important;right:.5rem!important;top:50%!important;transform:translateY(-50%)!important;border-radius:var(--radius-full)!important;transition:background .15s ease!important;cursor:pointer!important;z-index:1!important;padding:0!important;border:none!important;margin:0!important}.search-wrapper .pagefind-ui__search-clear:hover{background:var(--surface-soft)!important}.search-wrapper .pagefind-ui__search-clear::before,.search-wrapper .pagefind-ui__search-clear::after{content:""!important;position:absolute!important;top:50%!important;left:50%!important;width:12px!important;height:1.5px!important;background:var(--mute)!important;border-radius:1px!important;transition:background .15s ease!important}.search-wrapper .pagefind-ui__search-clear::before{transform:translate(-50%,-50%)rotate(45deg)!important}.search-wrapper .pagefind-ui__search-clear::after{transform:translate(-50%,-50%)rotate(-45deg)!important}.search-wrapper .pagefind-ui__search-clear:hover::before,.search-wrapper .pagefind-ui__search-clear:hover::after{background:var(--ink)!important}.search-wrapper .pagefind-ui__result{background:var(--canvas)!important;border:1px solid var(--hairline)!important;border-radius:var(--radius-lg)!important;padding:1.25rem!important;box-shadow:none!important;transition:border-color .15s ease!important;margin-top:.75rem!important}.search-wrapper .pagefind-ui__result:hover{border-color:var(--ink)!important;transform:none!important}.search-wrapper .pagefind-ui__result-link{color:var(--ink)!important;font-family:var(--font-display)!important;font-weight:600!important}.search-wrapper .pagefind-ui__result-link:hover{color:var(--charcoal)!important}.search-wrapper .pagefind-ui__result-excerpt{color:var(--body)!important}.search-wrapper .pagefind-ui__result-nested{border-left-color:var(--hairline-strong)!important}.search-wrapper mark{background:var(--ink)!important;color:var(--canvas)!important;border-radius:2px!important;padding:0 .15rem!important}.search-wrapper .pagefind-ui__message{color:var(--body)!important;font-family:inherit!important}.search-wrapper .pagefind-ui__button{background:var(--canvas)!important;color:var(--ink)!important;border:1px solid var(--hairline-strong)!important;border-radius:var(--radius-full)!important;box-shadow:none!important;font-family:inherit!important;cursor:pointer!important;transition:background-color .15s ease,border-color .15s ease!important;height:auto!important;padding:.5rem 1.25rem!important;font-size:.875rem!important;font-weight:500!important}.search-wrapper .pagefind-ui__button:hover{background:var(--surface-soft)!important;border-color:var(--ink)!important;color:var(--ink)!important}.search-wrapper .pagefind-ui__button:focus-visible{outline:var(--focus-ring)!important;outline-offset:var(--focus-offset)!important}.search-overlay{position:fixed;inset:0;z-index:200;display:flex;align-items:flex-start;justify-content:center;padding-top:10vh;opacity:0;visibility:hidden;transition:opacity .15s ease,visibility .15s ease}.search-overlay.open{opacity:1;visibility:visible}.search-overlay-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.4);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}[data-theme=dark] .search-overlay-backdrop{background:rgba(0,0,0,.6)}.search-overlay-panel{position:relative;width:100%;max-width:600px;max-height:70vh;margin:0 1.5rem;background:var(--canvas);border:1px solid var(--hairline);border-radius:var(--radius-lg);box-shadow:none;display:flex;flex-direction:column;overflow:hidden;transform:translateY(-12px)scale(.98);transition:transform .15s ease}.search-overlay.open .search-overlay-panel{transform:translateY(0)scale(1)}.search-overlay-header{padding:.75rem;border-bottom:1px solid var(--hairline);flex-shrink:0}.search-overlay-input-wrap{display:flex;align-items:center;gap:.5rem;background:var(--surface-soft);border-radius:var(--radius-full);border:1px solid transparent;padding:.5rem .875rem;transition:border-color .15s ease,background-color .15s ease}.search-overlay-input-wrap:focus-within{background:var(--canvas);border-color:var(--ink)}.search-overlay-icon{width:16px;height:16px;flex-shrink:0;color:var(--mute)}.search-overlay-input{flex:1;border:none;background:0 0;outline:none;font-size:.9375rem;font-family:inherit;color:var(--ink);min-width:0}.search-overlay-input::placeholder{color:var(--mute)}.search-overlay-kbd{flex-shrink:0;font-family:var(--font-mono);font-size:.6875rem;padding:.125rem .375rem;border-radius:var(--radius-sm);background:var(--canvas);color:var(--body);border:1px solid var(--hairline);line-height:1.4}.search-overlay-results{overflow-y:auto;padding:.5rem .75rem;flex:1;min-height:0}.search-overlay-results:empty{display:none}.search-overlay-empty{text-align:center;padding:2rem 1rem;color:var(--body);font-size:.875rem}.search-overlay-loading{font-style:normal;color:var(--mute)}.search-overlay-item{display:block;padding:.75rem;border-radius:var(--radius-md);transition:background .12s ease;text-decoration:none;color:var(--ink)}.search-overlay-item:hover,.search-overlay-item.active{background:var(--surface-soft);color:var(--ink)}.search-overlay-item:focus-visible{outline:var(--focus-ring);outline-offset:-2px}.search-overlay-item-title{font-family:var(--font-display);font-weight:600;font-size:.9375rem;margin-bottom:.25rem;color:var(--ink)}.search-overlay-item-excerpt{font-size:.8125rem;color:var(--body);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.search-overlay-item-excerpt mark{background:var(--ink);color:var(--canvas);border-radius:2px;padding:0 .15rem}body.search-open{overflow:hidden}.pagination{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-top:3rem}.pagination-link{display:inline-flex;align-items:center;height:36px;padding:0 1.25rem;border-radius:var(--radius-full);font-family:var(--font-body);font-size:.875rem;font-weight:500;color:var(--ink);background:var(--canvas);border:1px solid var(--hairline-strong);text-decoration:none;transition:background-color .15s ease,border-color .15s ease,color .15s ease}.pagination-link:hover:not(.disabled){background:var(--ink);border-color:var(--ink);color:var(--canvas)}.pagination-link:active:not(.disabled){background:var(--ink-deep);border-color:var(--ink-deep)}.pagination-link.disabled{opacity:.4;cursor:default;pointer-events:none;border-color:var(--hairline);color:var(--mute)}.pagination-info{font-family:var(--font-body);font-size:.875rem;color:var(--body);font-weight:500;min-width:4rem;text-align:center}.site-footer{padding:2rem 0;margin-top:auto}.site-footer .container{text-align:center}.footer-card{background:0 0;border:none;border-radius:0;padding:0;box-shadow:none;color:var(--body);font-family:var(--font-body);font-size:.75rem;line-height:1.5}.footer-card p{margin:0}body.has-bg-image{background-color:initial}body.has-bg-image::before{content:"";position:fixed;inset:0;background:color-mix(in srgb,var(--canvas) 25%,transparent);pointer-events:none;z-index:-1}[data-theme=dark] body.has-bg-image::before{background:color-mix(in srgb,#000000 40%,transparent)}body.has-bg-image .site-header{background:color-mix(in srgb,var(--canvas) 72%,transparent);backdrop-filter:blur(20px)saturate(160%);-webkit-backdrop-filter:blur(20px)saturate(160%)}body.has-bg-image main.container{background:color-mix(in srgb,var(--canvas) 80%,transparent);backdrop-filter:blur(24px)saturate(160%);-webkit-backdrop-filter:blur(24px)saturate(160%);border:1px solid color-mix(in srgb,var(--hairline-strong) 40%,transparent);border-radius:var(--radius-lg);margin:1.5rem auto;padding-left:2rem;padding-right:2rem;padding-top:1.5rem}@media(max-width:768px){body.has-bg-image main.container{width:calc(100% - 1.5rem);margin:.75rem auto;padding-left:1.25rem;padding-right:1.25rem;padding-top:1rem}}body.has-bg-image main .card{background:0 0;backdrop-filter:none;-webkit-backdrop-filter:none}body.has-bg-image main .card.post-card:hover{background:color-mix(in srgb,var(--canvas) 35%,transparent);border-color:var(--ink)}body.has-bg-image main article.card:not(.post-card){background:0 0;border:none;padding-left:0;padding-right:0}body.has-bg-image main .tag-cloud-canvas-wrapper.card{background:0 0;border:none}body.has-bg-image .article-content .code-block,body.has-bg-image .article-content pre{background:color-mix(in srgb,var(--surface-soft) 90%,transparent)}body.has-bg-image .article-content p code,body.has-bg-image .article-content li code{background:color-mix(in srgb,var(--surface-soft) 88%,transparent)}body.has-bg-image .tag{background:color-mix(in srgb,var(--canvas) 60%,transparent)}body.has-bg-image .pagination-link{background:color-mix(in srgb,var(--canvas) 60%,transparent)}body.has-bg-image .pagination-link:hover:not(.disabled){background:var(--ink);color:var(--canvas)}body.has-bg-image .menu-toggle,body.has-bg-image .search-toggle,body.has-bg-image .theme-toggle,body.has-bg-image .nav-search-btn{background:color-mix(in srgb,var(--canvas) 78%,transparent);backdrop-filter:blur(14px)saturate(160%);-webkit-backdrop-filter:blur(14px)saturate(160%);border-color:color-mix(in srgb,var(--hairline-strong) 80%,transparent)}body.has-bg-image .menu-toggle:hover,body.has-bg-image .search-toggle:hover,body.has-bg-image .theme-toggle:hover,body.has-bg-image .nav-search-btn:hover{background:color-mix(in srgb,var(--canvas) 92%,transparent);border-color:var(--ink)}body.has-bg-image .site-nav a:hover,body.has-bg-image .site-nav a.active{background:color-mix(in srgb,var(--canvas) 80%,transparent)}body.has-bg-image .site-footer .container{}body.has-bg-image .footer-card{background:color-mix(in srgb,var(--canvas) 65%,transparent);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:var(--radius-full);padding:.375rem 1rem;display:inline-block;color:var(--ink)}@media(max-width:480px){body.has-bg-image .site-nav{background:color-mix(in srgb,var(--canvas) 96%,transparent);backdrop-filter:blur(24px)saturate(180%);-webkit-backdrop-filter:blur(24px)saturate(180%);border-top-color:color-mix(in srgb,var(--hairline-strong) 60%,transparent);border-bottom-color:color-mix(in srgb,var(--hairline-strong) 60%,transparent)}}@media(min-width:769px){}@media(max-width:768px){main{padding:1.5rem 0 var(--space-section-mobile)}.hero{padding:2rem 0 1.5rem}.hero-title{font-size:1.75rem}h1{font-size:1.75rem}.article-header h1{font-size:1.75rem}.article-content h2{font-size:1.375rem;margin-top:2rem}.article-content h3{font-size:1.125rem}.post-card{padding:1.25rem}}@media(max-width:480px){.site-nav{display:none;position:absolute;top:100%;left:0;right:0;background:var(--canvas);padding:.75rem 1.5rem;border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline);z-index:99}.site-nav.open{display:block}.site-nav ul{flex-direction:column;gap:.25rem;align-items:stretch}.site-nav a{text-align:center;justify-content:center;height:40px;border-radius:var(--radius-full)}.site-header .container{position:relative;justify-content:flex-end}.menu-toggle{display:flex;align-items:center;justify-content:center;position:absolute;left:1.5rem}.site-title{position:absolute;left:50%;transform:translateX(-50%);max-width:55%}.site-title-article{line-height:inherit}.site-title.show-article .site-title-brand{opacity:0;transform:translateY(-8px);pointer-events:none}.site-title.show-article .site-title-article{opacity:1;transform:translate(0,-50%);pointer-events:auto}.search-toggle-inline{display:none}.nav-search-item{display:list-item}.nav-search-item a,.nav-search-item .nav-search-btn{display:flex;align-items:center;justify-content:center;gap:.4rem}.nav-search-item svg{flex-shrink:0}.nav-search-btn{width:100%;cursor:pointer;font-family:var(--font-body);height:40px;padding:0 1rem;border-radius:var(--radius-full);color:var(--ink);font-size:.875rem;font-weight:500;background:0 0;border:1px solid var(--hairline);transition:background-color .15s ease,border-color .15s ease}.nav-search-btn:hover{background:var(--surface-soft);border-color:var(--ink)}.hero-title{font-size:1.625rem}.hero-desc{font-size:.9375rem}body{font-size:15px}.card{padding:1.25rem}.post-card{padding:1.25rem}article.card:not(.post-card){background:0 0;border:none;border-radius:0;padding:0}main>.container:has(article.card:not(.post-card)){padding:0 1rem}article.card:not(.post-card) .article-header{padding:.5rem 0;margin-bottom:1.5rem;border-bottom:1px solid var(--hairline)}article.card:not(.post-card) .article-header h1{font-size:1.5rem;line-height:1.25}article.card:not(.post-card) .article-content{font-size:1rem;line-height:1.75}article.card:not(.post-card) .article-content p code,article.card:not(.post-card) .article-content li code{word-break:break-all;overflow-wrap:anywhere}article.card:not(.post-card) .article-footer{padding:1rem 0 .5rem;border-top:1px solid var(--hairline);margin-top:2rem}}.hero--404{padding:var(--space-hero-404-y)0}.hero--404 .hero-title{font-size:4rem;font-weight:600;margin-bottom:.5rem;letter-spacing:-.02em}@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}.card.post-card:hover,.article-content img:hover,.tag:hover,.pagination-link:hover:not(.disabled),.search-wrapper .pagefind-ui__result:hover{transform:none!important}.search-overlay,.search-overlay-panel{transition:none}}