:root{--bg-primary:#f9fafb;--bg-secondary:#fff;--bg-tertiary:#f3f4f6;--bg-hover:#f3f4f6;--text-primary:#111827;--text-secondary:#3a3e45;--text-tertiary:#9ca3af;--border-color:#e5e7eb;--border-hover:#d1d5db;--shadow-sm:rgba(0,0,0,.08);--shadow-md:rgba(0,0,0,.12);--shadow-lg:rgba(0,0,0,.18);--accent-color:#3b82f6;--accent-hover:#2563eb;--accent-gradient-start:#3b82f6;--accent-gradient-end:#2563eb;--link-color:#3b82f6;--link-hover:#2563eb;--code-bg:#f9fafb;--code-block-surface:#f6f8fa;--code-block-border-strong:#e5e7eb;--code-block-header-bg:rgba(0,0,0,.03);--code-lang-badge-bg:hsla(0,0%,100%,.8);--code-copy-success-color:#116329;--code-copy-success-bg:#dafbe1;--code-copy-success-border:#116329;--hljs-color:#24292f;--hljs-comment-color:#6a737d;--hljs-keyword-color:#cf222e;--hljs-string-color:#0a3069;--hljs-title-color:#8250df;--hljs-tag-color:#116329;--hljs-attr-color:#0550ae;--hljs-regexp-color:#953800;--hljs-addition-bg:#dafbe1;--hljs-addition-color:#116329;--hljs-deletion-bg:#ffebe9;--hljs-deletion-color:#cf222e;--table-border-color:#777;--copyright-text-color:#4a4a4a;--copyright-card-bg:#e5e7eb;--tag-cloud-color-min:#777;--tag-cloud-color-max:#252525}:root.dark{--bg-primary:#1f2937;--bg-secondary:#111827;--bg-tertiary:#374151;--bg-hover:#374151;--text-primary:#f9fafb;--text-secondary:#d1d5db;--text-tertiary:#9ca3af;--border-color:#374151;--border-hover:#4b5563;--shadow-sm:rgba(0,0,0,.3);--shadow-md:rgba(0,0,0,.4);--shadow-lg:rgba(0,0,0,.5);--accent-color:#60a5fa;--accent-hover:#3b82f6;--accent-gradient-start:#60a5fa;--accent-gradient-end:#3b82f6;--link-color:#60a5fa;--link-hover:#3b82f6;--code-bg:#1f2937;--code-block-surface:#161b22;--code-block-border-strong:#30363d;--code-block-header-bg:hsla(0,0%,100%,.03);--code-lang-badge-bg:rgba(22,27,34,.8);--code-copy-success-color:#7ee787;--code-copy-success-bg:#033a16;--code-copy-success-border:#7ee787;--hljs-color:#c9d1d9;--hljs-comment-color:#8b949e;--hljs-keyword-color:#ff7b72;--hljs-string-color:#a5d6ff;--hljs-title-color:#d2a8ff;--hljs-tag-color:#7ee787;--hljs-attr-color:#79c0ff;--hljs-regexp-color:#ffa657;--hljs-addition-bg:#033a16;--hljs-addition-color:#7ee787;--hljs-deletion-bg:#67060c;--hljs-deletion-color:#ff7b72;--copyright-text-color:#f9fafb;--copyright-card-bg:#374151;--tag-cloud-color-min:#7e7e7e;--tag-cloud-color-max:#cacaca}@media (prefers-color-scheme:dark){:root:not(.light){--bg-primary:#1f2937;--bg-secondary:#111827;--bg-tertiary:#374151;--bg-hover:#374151;--text-primary:#f9fafb;--text-secondary:#d1d5db;--text-tertiary:#9ca3af;--border-color:#374151;--border-hover:#4b5563;--shadow-sm:rgba(0,0,0,.3);--shadow-md:rgba(0,0,0,.4);--shadow-lg:rgba(0,0,0,.5);--accent-color:#60a5fa;--accent-hover:#3b82f6;--accent-gradient-start:#60a5fa;--accent-gradient-end:#3b82f6;--link-color:#60a5fa;--link-hover:#3b82f6;--code-bg:#1f2937;--code-block-surface:#161b22;--code-block-border-strong:#30363d;--code-block-header-bg:hsla(0,0%,100%,.03);--code-lang-badge-bg:rgba(22,27,34,.8);--code-copy-success-color:#7ee787;--code-copy-success-bg:#033a16;--code-copy-success-border:#7ee787;--hljs-color:#c9d1d9;--hljs-comment-color:#8b949e;--hljs-keyword-color:#ff7b72;--hljs-string-color:#a5d6ff;--hljs-title-color:#d2a8ff;--hljs-tag-color:#7ee787;--hljs-attr-color:#79c0ff;--hljs-regexp-color:#ffa657;--hljs-addition-bg:#033a16;--hljs-addition-color:#7ee787;--hljs-deletion-bg:#67060c;--hljs-deletion-color:#ff7b72;--copyright-text-color:#f9fafb;--copyright-card-bg:#374151;--tag-cloud-color-min:#7e7e7e;--tag-cloud-color-max:#cacaca}}*{box-sizing:border-box;padding:0;margin:0}html{scrollbar-gutter:stable}body,html{max-width:100vw;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6;color:var(--text-primary);background-color:var(--bg-secondary);transition:background-color .2s ease,color .2s ease}body{display:flex;flex-direction:column}.app-main{flex:1 0 auto;padding-bottom:3rem}a{color:var(--link-color);text-decoration:none;transition:color .2s ease}a:hover{color:var(--link-hover)}.post-body a[href^="http://"]:not([href*="//blog.mzyyun.com"]):not(.no-external-icon):after,.post-body a[href^="https://"]:not([href*="//blog.mzyyun.com"]):not(.no-external-icon):after{content:"";display:inline-block;width:.85em;height:.85em;margin-left:.2em;vertical-align:-.08em;background-color:currentColor;mask-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 1024 1024' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M426.656 128v85.344H213.344v597.312h597.312v-213.312H896v256A42.688 42.688 0 0 1 853.344 896H170.656A42.688 42.688 0 0 1 128 853.344V170.656A42.656 42.656 0 0 1 170.656 128h256z m323.68 85.344h-195.68V128H896v341.344h-85.344V273.664L512 572.32 451.68 512l298.656-298.656z'/%3E%3C/svg%3E");mask-repeat:no-repeat;mask-position:center;mask-size:contain;-webkit-mask-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 1024 1024' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M426.656 128v85.344H213.344v597.312h597.312v-213.312H896v256A42.688 42.688 0 0 1 853.344 896H170.656A42.688 42.688 0 0 1 128 853.344V170.656A42.656 42.656 0 0 1 170.656 128h256z m323.68 85.344h-195.68V128H896v341.344h-85.344V273.664L512 572.32 451.68 512l298.656-298.656z'/%3E%3C/svg%3E");-webkit-mask-repeat:no-repeat;-webkit-mask-position:center;-webkit-mask-size:contain}.navbar{position:-webkit-sticky;position:sticky;top:0;z-index:9999;background-color:var(--bg-primary);border-bottom:1px solid var(--border-color);transition:background-color .2s ease,border-color .2s ease,backdrop-filter .2s ease,-webkit-backdrop-filter .2s ease}@media (min-width:769px){.navbar{background-color:color-mix(in srgb,var(--bg-primary) 82%,transparent);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%)}}.navbar-container{max-width:1400px;margin:0 auto;padding:0 20px;display:flex;align-items:center;justify-content:space-between;height:56px}.navbar-brand{margin-right:2rem;flex-shrink:0}.brand-link,.navbar-brand{display:flex;align-items:center}.brand-link{gap:.7rem;text-decoration:none;color:inherit;transition:opacity .2s ease}.brand-icon{width:1.6em;height:1.6em;display:block;flex-shrink:0}.brand-link:hover{opacity:.8}.brand-name{font-size:1.25rem;font-weight:600;color:var(--text-primary);line-height:1}.navbar-menu{list-style:none;gap:1.5rem;margin:0;padding:0;flex:1 1}.navbar-menu,.navbar-right{display:flex;align-items:center}.navbar-right{gap:.5rem;flex-shrink:0}.navbar-action-btn,a.navbar-action-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;border-radius:6px;transition:all .2s ease;padding:0;text-decoration:none}.navbar-action-btn:hover{background-color:var(--bg-hover);color:var(--text-primary)}.navbar-action-btn svg{stroke:currentColor}.theme-toggle-wrapper{position:relative;display:inline-block;z-index:10000}.theme-toggle-btn{display:flex;align-items:center;justify-content:center;gap:.25rem;padding:0 .5rem;width:auto;min-width:36px;height:36px}.theme-toggle-btn svg{flex-shrink:0}.theme-toggle-arrow{opacity:.6;transition:transform .2s ease,opacity .2s ease}.theme-toggle-arrow.open{opacity:1;transform:translateY(1px) rotate(180deg)}.theme-dropdown-menu{position:absolute;top:calc(100% + 8px);right:0;width:max-content;min-width:120px;max-width:140px;background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 12px var(--shadow-md);padding:.5rem;opacity:0;visibility:hidden;transform:translateY(-8px);transition:opacity .2s ease,visibility .2s ease,transform .2s ease;z-index:10000;display:flex;flex-direction:column;gap:.25rem}.theme-dropdown-menu.open{opacity:1;visibility:visible;transform:translateY(0)}.theme-dropdown-item{display:flex;align-items:center;gap:.5rem;width:100%;padding:.5rem .75rem;border:none;background:transparent;color:var(--text-primary);font-size:.9rem;text-align:left;border-radius:6px;cursor:pointer;transition:all .2s ease;position:relative;white-space:nowrap}.theme-dropdown-item.active,.theme-dropdown-item:hover{background-color:var(--bg-hover);color:var(--accent-color)}.theme-dropdown-icon{width:16px;height:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.theme-dropdown-icon svg{width:100%;height:100%}.theme-dropdown-label{flex:1 1}.nav-link{color:var(--text-secondary);text-decoration:none;font-size:.95rem;font-weight:500;padding:.375rem .5rem;position:relative;transition:color .2s ease;border-radius:6px}.nav-link:hover{color:var(--text-primary);background-color:var(--bg-hover)}.nav-link.active{color:var(--accent-color);background-color:var(--bg-hover)}.menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:.5rem;flex-direction:column;justify-content:space-around;width:32px;height:32px}.hamburger{display:flex;flex-direction:column;justify-content:space-between;width:24px;height:18px;position:relative}.hamburger span{display:block;height:2px;width:100%;background-color:var(--text-primary);border-radius:2px;transition:all .3s ease}.hamburger.open span:first-child{transform:rotate(45deg) translate(8px,8px)}.hamburger.open span:nth-child(2){opacity:0}.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(7px,-7px)}.mobile-menu{display:none;max-width:1200px;margin:0 auto;padding:0 20px;background-color:var(--bg-primary);border-top:1px solid var(--border-color);max-height:0;overflow:hidden;transition:max-height .3s ease}.mobile-menu.open{max-height:300px}.mobile-menu-list{list-style:none;padding:1rem 0;margin:0}.mobile-menu-list li{margin-bottom:.5rem}.mobile-nav-link{display:block;color:var(--text-secondary);text-decoration:none;font-size:1rem;font-weight:500;padding:.75rem 0;transition:color .2s ease;border-bottom:1px solid var(--bg-tertiary)}.mobile-nav-link:hover{color:var(--text-primary)}.mobile-nav-link.active{color:var(--accent-color)}@media (max-width:768px){.app-main{padding-bottom:1rem}.navbar{position:relative;background-color:var(--bg-primary);backdrop-filter:none;-webkit-backdrop-filter:none}.navbar-container{flex-wrap:wrap;height:auto;padding:.5rem 12px .375rem;gap:.375rem}.navbar-brand{width:100%;justify-content:center;margin-left:0;margin-right:0;margin-bottom:0;order:1;height:36px}.navbar-brand,.navbar-menu{display:flex;align-items:center}.navbar-menu{list-style:none;gap:.75rem;margin:0;padding:0;flex:1 1;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;order:2;min-width:0}.navbar-menu::-webkit-scrollbar{display:none}.navbar-menu li{flex-shrink:0}.navbar-right{margin-left:auto;order:3;flex-shrink:0;gap:.25rem;position:relative}.nav-link{font-size:.9rem;white-space:nowrap;padding:.25rem .375rem}.navbar-action-btn{width:36px;height:36px}.navbar-action-btn svg{width:18px;height:18px}.brand-name{font-size:1.125rem}.theme-toggle-wrapper{z-index:10000}.theme-dropdown-menu{right:0;left:auto;transform:translateY(-8px);min-width:140px;max-width:160px;background-color:var(--bg-primary);border:1px solid var(--border-color);box-shadow:0 4px 12px var(--shadow-md);z-index:10000}.theme-toggle-wrapper:hover .theme-dropdown-menu{transform:translateY(0)}.theme-toggle-btn{min-width:36px;height:36px;padding:0 .375rem}.theme-toggle-arrow{width:12px;height:12px}}.search-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:rgba(0,0,0,.5);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:2000;display:flex;align-items:flex-start;justify-content:center;padding-top:10vh;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.search-modal{width:90%;max-width:600px;max-height:70vh;background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 8px 32px var(--shadow-lg);display:flex;flex-direction:column;overflow:hidden;animation:slideDown .2s ease;transition:background-color .2s ease,border-color .2s ease}:root:not(.dark) .search-modal{box-shadow:0 12px 48px rgba(0,0,0,.15),0 4px 16px rgba(0,0,0,.1)}@keyframes slideDown{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.search-modal-header{display:flex;align-items:center;gap:.5rem;padding:1rem;border-bottom:1px solid var(--border-color);transition:border-color .2s ease}.search-input-wrapper{flex:1 1;display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;transition:all .2s ease}.search-input-wrapper:focus-within{border-color:var(--accent-color);box-shadow:0 0 0 3px rgba(102,126,234,.1)}.search-icon{color:var(--text-tertiary);flex-shrink:0;transition:color .2s ease}.search-input{flex:1 1;border:none;background:transparent;color:var(--text-primary);font-size:1rem;outline:none;transition:color .2s ease}.search-input::-webkit-search-cancel-button{display:none;-webkit-appearance:none}.search-input::-ms-clear{display:none}.search-input::placeholder{color:var(--text-tertiary)}.search-clear-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;background:transparent;color:var(--text-tertiary);cursor:pointer;border-radius:4px;transition:all .2s ease;padding:0}.search-clear-btn:hover{background-color:var(--bg-hover);color:var(--text-primary)}.search-submit-btn{display:flex;align-items:center;justify-content:center;min-width:60px;height:40px;border:none;background-color:var(--accent-color);color:#fff;cursor:pointer;border-radius:8px;transition:all .2s ease;padding:0 1rem;font-size:.9rem;font-weight:500;flex-shrink:0}.search-submit-btn:hover:not(:disabled){background-color:var(--accent-color-hover,#5568d3);transform:translateY(-1px);box-shadow:0 2px 8px rgba(102,126,234,.3)}.search-submit-btn:active:not(:disabled){transform:translateY(0)}.search-submit-btn:disabled{opacity:.5;cursor:not-allowed}.search-close-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;border-radius:8px;transition:all .2s ease}.search-close-btn:hover{background-color:var(--bg-hover);color:var(--text-primary)}.search-results{flex:1 1;overflow-y:auto;padding:.5rem}.search-empty,.search-loading,.search-placeholder{padding:2rem;text-align:center;color:var(--text-secondary);transition:color .2s ease}.search-results-list{list-style:none;padding:0;margin:0}.search-result-item{margin-bottom:.5rem}.search-result-link{width:100%;text-align:left;padding:1rem;border:1px solid var(--border-color);border-radius:8px;background-color:var(--bg-primary);cursor:pointer;transition:all .2s ease;display:block}.search-result-link:hover{background-color:var(--bg-hover);border-color:var(--accent-color);transform:translateY(-1px);box-shadow:0 2px 8px var(--shadow-sm)}.search-result-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:.5rem}.search-result-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0;flex:1 1;transition:color .2s ease}.search-result-category{font-size:.75rem;padding:.25rem .5rem;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:4px;color:var(--text-secondary);white-space:nowrap;transition:background-color .2s ease,color .2s ease,border-color .2s ease}.search-result-excerpt{font-size:.9rem;color:var(--text-secondary);margin:.5rem 0;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;transition:color .2s ease}.search-result-meta{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-top:.5rem}.search-result-date{font-size:.85rem;color:var(--text-tertiary);transition:color .2s ease}.search-result-tags{display:flex;gap:.5rem;flex-wrap:wrap}.search-result-tag{font-size:.75rem;padding:.2rem .5rem;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:4px;color:var(--text-secondary);transition:background-color .2s ease,color .2s ease,border-color .2s ease}.search-highlight{background-color:rgba(102,126,234,.2);color:var(--text-primary);padding:.1em .2em;border-radius:3px;font-weight:600;transition:background-color .2s ease}@media (prefers-color-scheme:dark){.search-highlight{background-color:rgba(102,126,234,.3)}}@media (max-width:768px){.search-modal{width:95%;max-height:80vh}.search-modal-header{padding:.75rem}.search-input-wrapper{padding:.5rem .75rem}.search-result-link{padding:.75rem}.search-result-title{font-size:.95rem}.search-result-excerpt{font-size:.85rem}}.search-page{max-width:800px;margin:0 auto;padding:2rem 0}.search-page-header{margin-bottom:2rem}.search-page-title{font-size:2rem;font-weight:700;color:var(--text-primary);margin-bottom:1.5rem;transition:color .2s ease}.search-input-container{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;transition:all .2s ease}.search-input-container:focus-within{border-color:var(--accent-color);box-shadow:0 0 0 4px rgba(102,126,234,.1)}.search-page-content{min-height:400px}.search-intro{padding:4rem 2rem;text-align:center;color:var(--text-secondary);transition:color .2s ease}.search-intro p{margin:.5rem 0;font-size:1rem}.search-intro-hint{font-size:.9rem;color:var(--text-tertiary)}.search-results-container{margin-top:1rem}.search-results-header{margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color);transition:border-color .2s ease}.search-results-count{margin:0;font-size:.9rem}.search-empty,.search-results-count{color:var(--text-secondary);transition:color .2s ease}.search-empty{padding:4rem 2rem;text-align:center}.search-empty p{margin:.5rem 0;font-size:1rem}.search-empty-hint{font-size:.9rem;color:var(--text-tertiary)}@media (max-width:768px){.search-page{padding:1rem 0}.search-page-title{font-size:1.5rem;margin-bottom:1rem}.search-input-container{padding:.75rem 1rem}.search-intro{padding:3rem 1rem}}.container{max-width:1400px;margin:0 auto;padding:0 10px}.not-found-container{min-height:60vh;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center}.not-found-eyebrow{font-size:.9rem;letter-spacing:.06em;text-transform:uppercase;color:var(--text-tertiary);margin-bottom:.5rem}.not-found-code{font-size:3rem;margin-bottom:.25rem;line-height:1.1}.not-found-title{font-size:1.5rem;font-weight:700;margin-bottom:.75rem}.not-found-text{max-width:560px;font-size:1.05rem;color:var(--text-secondary);line-height:1.8;margin-bottom:2rem}.not-found-actions{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:center}.not-found-link{display:inline-flex;align-items:center;justify-content:center;min-width:120px;font-size:1.1rem;padding:.5rem 1rem;border-radius:8px;border:1px solid transparent;background:var(--accent-color);color:#fff}.not-found-link:hover{color:#fff;opacity:.92}.not-found-link-secondary{background:transparent;color:var(--text-primary);border-color:var(--border-color)}.not-found-link-secondary:hover{color:var(--text-primary);background:var(--bg-tertiary)}@media (max-width:768px){.not-found-container{min-height:55vh}.not-found-title{font-size:1.25rem}.not-found-text{font-size:.98rem;margin-bottom:1.5rem}}@media (min-width:769px) and (max-width:1200px){.container{padding:0 20px}.container,.navbar-container{max-width:1000px}.main-layout{padding-left:0;padding-right:0}}.main-layout{display:grid;grid-template-columns:248px 1fr 248px;grid-template-areas:"left-sidebar main-content right-sidebar";grid-gap:24px;gap:24px;padding-top:1.5rem}.left-sidebar,.right-sidebar{display:block}.left-sidebar{grid-area:left-sidebar;align-self:stretch}.left-sidebar::-webkit-scrollbar,.right-sidebar::-webkit-scrollbar{width:6px}.left-sidebar::-webkit-scrollbar-track,.right-sidebar::-webkit-scrollbar-track{background:transparent}.left-sidebar::-webkit-scrollbar-thumb,.right-sidebar::-webkit-scrollbar-thumb{background:var(--text-tertiary);border-radius:3px}.left-sidebar::-webkit-scrollbar-thumb:hover,.right-sidebar::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.right-sidebar{grid-area:right-sidebar;align-self:stretch}.sidebar-sticky{position:-webkit-sticky;position:sticky;top:80px;display:flex;flex-direction:column;gap:1rem;align-self:start;z-index:10}.main-content{grid-area:main-content;min-width:0}.sidebar-recent-posts-mobile{display:none}@media (max-width:1200px){.main-layout{grid-template-columns:232px 1fr;grid-template-areas:"left-sidebar main-content";gap:20px}.right-sidebar{display:none}.left-sidebar{display:block;align-self:stretch}.sidebar-recent-posts-mobile{display:block!important}}@media (max-width:768px){.main-layout{grid-template-columns:1fr;grid-template-areas:"main-content";gap:24px}.left-sidebar,.right-sidebar{display:none}.sidebar-sticky{position:static}.sidebar-card{padding:1rem}.post-card{padding:0}.post-card:not(:has(.post-card-cover)){padding:1.25rem}.post-card h2{font-size:1.25rem;padding:1.25rem 1.25rem .75rem}.post-card:not(:has(.post-card-cover)) h2{padding:0}.post-card-cover{height:130px}.post-meta-info{padding:0 1.25rem}.post-card:not(:has(.post-card-cover)) .post-meta-info{padding:0}.post-card .excerpt{padding:0 1.25rem}.post-card:not(:has(.post-card-cover)) .excerpt{padding:0}.post-tags{padding:0 1.25rem 1.25rem}.post-card:not(:has(.post-card-cover)) .post-tags{padding:0;margin-top:1rem}}.sidebar-card{background:var(--bg-primary);border-radius:10px;padding:1rem;box-shadow:0 1px 3px var(--shadow-sm),0 1px 2px rgba(0,0,0,.06);transition:box-shadow .2s ease,background-color .2s ease,transform .2s ease}:root:not(.dark) .sidebar-card{box-shadow:0 2px 8px rgba(0,0,0,.08),0 1px 3px rgba(0,0,0,.1)}.sidebar-author-card{margin-bottom:1rem}.sidebar-card:hover{background:var(--bg-primary);border-color:var(--border-color);box-shadow:0 3px 6px var(--shadow-md);transform:translateY(-1px)}.sidebar-card-title{font-size:.95rem;font-weight:600;margin:0 0 .65rem;color:var(--text-primary);padding-bottom:.5rem;border-bottom:1px solid var(--border-color);transition:color .2s ease,border-color .2s ease}.author-info{text-align:center}.author-avatar{display:flex;justify-content:center;margin-bottom:1rem}.avatar-placeholder{background:linear-gradient(135deg,var(--accent-gradient-start) 0,var(--accent-gradient-end) 100%);display:flex;align-items:center;justify-content:center;color:#fff;font-size:2rem;font-weight:600}.avatar-image,.avatar-placeholder{width:80px;height:80px;border-radius:50%}.avatar-image{object-fit:cover;border:2px solid var(--border-color);transition:transform .2s ease,box-shadow .2s ease}.avatar-image:hover{transform:scale(1.05);box-shadow:0 4px 12px rgba(0,0,0,.15)}.author-name{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0 0 .5rem}.author-bio,.author-name{transition:color .2s ease}.author-bio{font-size:.9rem;color:var(--text-secondary);margin:0}.category-list{display:flex;flex-direction:column;gap:.3rem}.category-item{display:flex;justify-content:space-between;align-items:center;padding:.45rem .5rem;border-radius:6px;text-decoration:none;color:var(--text-primary);transition:all .2s ease;border:1px solid transparent}.category-item:hover{background-color:var(--bg-hover);border-color:var(--border-color);color:var(--accent-color)}.category-name{font-weight:500;font-size:.875rem}.category-count{font-size:.78rem;color:var(--text-tertiary);transition:color .2s ease}.tag-list{display:flex;flex-wrap:wrap;gap:.35rem;font-size:.8125rem}.tag-count{margin-left:.2rem;font-size:.75rem;opacity:.7}.toc-nav{max-height:60vh;overflow-y:auto}.toc-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.1rem}.toc-item{margin:0;line-height:1.35}.toc-link{display:block;padding:.3rem .45rem;text-decoration:none;color:var(--text-secondary);font-size:.8125rem;transition:all .2s ease;border-left:2px solid transparent}.toc-link:hover{color:var(--text-primary)}.toc-item.active .toc-link,.toc-link:hover{background-color:var(--bg-hover);border-left-color:var(--accent-color)}.toc-item.active .toc-link{color:var(--accent-color);font-weight:500}.toc-level-2{padding-left:0}.toc-level-3{padding-left:.75rem}.toc-level-4{padding-left:1.5rem}.toc-level-5{padding-left:2.25rem}.toc-level-6{padding-left:3rem}.recent-posts-list{margin:0}.recent-posts{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.45rem}.recent-post-item{margin:0}.recent-post-link{display:block;text-decoration:none;color:inherit;padding:.45rem .5rem;border-radius:6px;transition:all .2s ease;border:1px solid transparent}.recent-post-link:hover{background-color:var(--bg-hover);border-color:var(--border-color)}.recent-post-title{font-size:.875rem;font-weight:500;color:var(--text-primary);margin:0 0 .25rem;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;transition:color .2s ease}.recent-post-link:hover .recent-post-title{color:var(--accent-color)}.recent-post-date{font-size:.72rem;display:block}.empty-text,.recent-post-date{color:var(--text-tertiary);transition:color .2s ease}.empty-text{font-size:.8125rem;text-align:center;margin:.5rem 0}.sidebar-archives{margin-top:0}.archives-list{display:flex;flex-direction:column;gap:.3rem}.sidebar-archives .archive-year-link{display:flex;align-items:center;justify-content:space-between;padding:.45rem .5rem;border-radius:6px;text-decoration:none;color:var(--text-primary);transition:all .2s ease;border:1px solid transparent;font-size:.875rem}.sidebar-archives .archive-year-link:hover{background-color:var(--bg-hover);border-color:var(--border-color);color:var(--accent-color)}.sidebar-archives .archive-year-count{font-size:.78rem;color:var(--text-tertiary);transition:color .2s ease}.sidebar-archives .archive-year-link:hover .archive-year-count{color:var(--accent-color)}.empty-state{padding:3rem 1rem;text-align:center;color:var(--text-secondary);transition:color .2s ease}.empty-state code{background-color:var(--code-bg);padding:.2rem .4rem;border-radius:4px;font-size:.9em;transition:background-color .2s ease}.page-title{font-size:2rem;font-weight:700;color:var(--text-primary);margin-bottom:2rem;transition:color .2s ease}.archive-page{margin:0 auto;padding:2rem;background:var(--bg-primary);border-radius:12px;box-shadow:0 1px 3px var(--shadow-sm),0 1px 2px rgba(0,0,0,.06);overflow:hidden}:root:not(.dark) .archive-page{box-shadow:0 2px 8px rgba(0,0,0,.08),0 1px 3px rgba(0,0,0,.1)}.archive-list{display:flex;flex-direction:column;gap:2.5rem}.archive-year-group{border-bottom:1px solid var(--border-color);padding-bottom:2rem;transition:border-color .2s ease}.archive-year-group:last-child{border-bottom:none;padding-bottom:0}.archive-year-title{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem;display:flex;align-items:center;gap:.75rem;transition:color .2s ease}.archive-year-title .archive-year-link{color:var(--text-primary);text-decoration:none;transition:color .2s ease}.archive-year-title .archive-year-link:hover{color:var(--accent-color)}.archive-year-title .archive-year-count{font-size:1rem;font-weight:400;color:var(--text-secondary);transition:color .2s ease}.archive-posts-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.archive-post-item{margin:0}.archive-post-link{display:flex;flex-direction:row;align-items:stretch;gap:.75rem;padding:.35rem .5rem;margin:0 -.5rem;color:var(--text-secondary);text-decoration:none;transition:background-color .15s ease,color .15s ease;border-radius:8px}.archive-post-link:hover,.archive-post-thumb{background-color:var(--bg-secondary)}.archive-post-thumb{flex-shrink:0;width:88px;height:52px;border-radius:6px;background-size:cover;background-position:50%;background-repeat:no-repeat}.archive-post-thumb--empty{border:1px solid var(--border-color);background-image:none}.archive-post-body{flex:1 1;min-width:0;display:flex;flex-direction:column;justify-content:center;gap:.2rem;padding:.1rem 0}.archive-post-title{font-size:.9375rem;font-weight:500;line-height:1.35;color:var(--text-primary);display:-webkit-box;-webkit-line-clamp:1;line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;transition:color .15s ease}.archive-post-meta{display:flex;align-items:center;flex-wrap:wrap;gap:.35rem .5rem;font-size:.75rem;line-height:1.2;color:var(--text-tertiary)}.archive-post-date{transition:color .15s ease}.archive-post-category,.archive-post-date{color:var(--text-tertiary)}.archive-post-category:before{content:"·";margin-right:.35rem;opacity:.6}.archive-post-link:hover .archive-post-title{color:var(--accent-color)}.archive-post-link:hover .archive-post-date{color:var(--text-secondary)}.archive-year-page{max-width:800px;margin:0 auto;padding:2rem;background:var(--bg-primary);border-radius:12px;box-shadow:0 1px 3px var(--shadow-sm),0 1px 2px rgba(0,0,0,.06);overflow:hidden}:root:not(.dark) .archive-year-page{box-shadow:0 2px 8px rgba(0,0,0,.08),0 1px 3px rgba(0,0,0,.1)}.archive-year-subtitle{font-size:1rem;font-weight:400;color:var(--text-secondary);margin-left:.75rem;transition:color .2s ease}@media (max-width:768px){.page-title{font-size:1.5rem;margin-bottom:1.5rem}.archive-year-title{font-size:1.25rem}.archive-post-link{gap:.625rem;padding:.3rem .35rem;margin:0 -.35rem}.archive-post-thumb{width:72px;height:44px}}.tags-page{margin:0 auto;padding:2rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 1px 3px var(--shadow-sm),0 1px 2px rgba(0,0,0,.06);overflow:hidden}:root:not(.dark) .tags-page{box-shadow:0 2px 8px rgba(0,0,0,.08),0 1px 3px rgba(0,0,0,.1)}.tags-list-card{padding:0;margin-bottom:0}.tags-list{display:flex;flex-wrap:wrap;gap:1.5rem 2rem;align-items:center}.tag-item{display:inline-block;text-decoration:none;color:var(--text-primary);transition:opacity .2s ease;line-height:1.4;word-break:break-word}.tag-item:hover{opacity:.7;color:var(--text-primary)}.tag-posts-page{padding:0}.tag-posts-subtitle{font-size:1rem;font-weight:400;color:var(--text-secondary);margin-left:.75rem;transition:color .2s ease}@media (max-width:768px){.tags-page{padding:1rem}.tags-list{gap:1rem 1.5rem}}.categories-page{padding:0}.categories-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));grid-gap:1rem;gap:1rem;margin-bottom:3rem}.category-card{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.5rem;background:var(--bg-primary);border-radius:12px;text-decoration:none;transition:all .2s ease;box-shadow:0 2px 8px var(--shadow-sm);min-height:120px}:root:not(.dark) .category-card{box-shadow:0 2px 8px rgba(0,0,0,.08),0 1px 3px rgba(0,0,0,.1)}.category-card:hover{box-shadow:0 4px 16px var(--shadow-lg);transform:translateY(-2px)}.category-card-name{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem;transition:color .2s ease}.category-card:hover .category-card-name{color:var(--accent-color)}.category-card-count{font-size:.9rem;color:var(--text-secondary);transition:color .2s ease}.category-posts-page{padding:0}.category-posts-subtitle{font-size:1rem;font-weight:400;color:var(--text-secondary);margin-left:.75rem;transition:color .2s ease}@media (max-width:768px){.categories-list{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.75rem}.category-card{padding:1rem;min-height:100px}.category-card-name{font-size:1.1rem}}.header{border-bottom:1px solid var(--border-color);padding:2rem 0;margin-bottom:3rem;transition:border-color .2s ease}.header h1{font-size:2rem;font-weight:700;color:var(--text-primary);transition:color .2s ease}.post-list{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:3rem}.post-card{padding:0;background:var(--bg-primary);border-radius:12px;transition:box-shadow .2s ease,background-color .2s ease,transform .2s ease;box-shadow:0 1px 3px var(--shadow-sm),0 1px 2px rgba(0,0,0,.06);overflow:hidden}:root:not(.dark) .post-card{box-shadow:0 2px 8px rgba(0,0,0,.08),0 1px 3px rgba(0,0,0,.1)}.post-card:hover{background:var(--bg-primary);box-shadow:0 3px 6px var(--shadow-md)}.post-card-cover-link{position:relative;display:block;width:100%;text-decoration:none;overflow:hidden}.post-card-cover{width:100%;aspect-ratio:3.2/1;background-size:cover;background-position:50%;background-repeat:no-repeat}.post-card h2{margin:0;padding:1.5rem 1.5rem .75rem;font-size:1.5rem;font-weight:600;line-height:1.3}.post-card:has(.post-card-cover) .post-meta-info{padding:0 1.5rem}.post-card:has(.post-card-cover) .excerpt{padding:0 1.5rem}.post-card:has(.post-card-cover) .post-tags{padding:0 1.5rem 1.5rem}.post-card:not(:has(.post-card-cover)){padding:1.5rem}.post-card:not(:has(.post-card-cover)) h2{padding:0}.post-card:not(:has(.post-card-cover)) .post-meta-info{padding:0}.post-card:not(:has(.post-card-cover)) .excerpt{padding:0}.post-card:not(:has(.post-card-cover)) .post-tags{padding:0;margin-top:1rem}.post-card h2 a{color:var(--text-primary);text-decoration:none;transition:color .2s ease}.post-card h2 a:hover{color:var(--accent-color)}.post-meta-info{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}.post-card .date{font-size:.92rem}.post-card .date,.post-card .excerpt{color:var(--text-secondary);transition:color .2s ease}.post-card .excerpt{margin:.75rem 0;line-height:1.6}.post-card:has(.post-card-cover) .excerpt{margin:.75rem 0}.post-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}.post-card:has(.post-card-cover) .post-tags{margin-top:1rem}.post-tags .tag{display:inline-flex;align-items:center;gap:.2rem;font-size:.82rem;color:var(--text-secondary);text-decoration:none;border-bottom:1px dashed transparent;transition:color .2s ease,border-color .2s ease}.post-tags .tag:hover{color:var(--accent-color);border-color:var(--accent-color)}.post-tag-icon{color:var(--text-tertiary);transition:color .2s ease}.post-tags .tag:hover .post-tag-icon{color:var(--accent-color)}.post-read-more-link{margin-left:auto;font-size:.82rem;color:var(--link-color);text-decoration:none;transition:color .2s ease}.post-read-more-link:hover{color:var(--accent-color)}.post-cover-container{width:100%;margin-bottom:0;border-radius:12px 12px 0 0;overflow:hidden}.post-cover{width:100%;aspect-ratio:2.35/1;background-color:var(--bg-primary);background-size:cover;background-position:50%;background-repeat:no-repeat;position:relative;display:flex;align-items:center;justify-content:center}@media (max-width:1024px){.theme-dropdown-menu{background-color:var(--bg-primary);border:1px solid var(--border-color);box-shadow:0 4px 12px var(--shadow-md);z-index:10000}}@media (max-width:768px){.post-cover-container{width:100%;margin-bottom:0}.post-body{padding:1rem}.copyright-card{padding:1.5rem 1rem}.artalk-wrapper{padding:1.25rem 1rem}.archive-page,.archive-year-page{padding:1rem}}.post-content{margin:0 auto;padding:0;background:var(--bg-primary);border-radius:0 0 12px 12px;box-shadow:0 1px 3px var(--shadow-sm),0 1px 2px rgba(0,0,0,.06);overflow:hidden}.post-content.post-content-no-cover{border-radius:12px}.post-article-header{padding:1.5rem 1rem .5rem;border-bottom:1px solid var(--border-color);margin-bottom:1rem}.post-article-title{margin:0;font-size:clamp(1.25rem,.65rem + 3vw,2rem);line-height:1.3;color:var(--text-primary)}.post-article-meta{margin-top:.75rem;display:flex;gap:.75rem;flex-wrap:wrap;font-size:.92rem}.post-article-category,.post-article-meta{align-items:center;color:var(--text-secondary)}.post-article-category{display:inline-flex;gap:.35rem;text-decoration:none;border:1px solid var(--border-color);border-radius:999px;padding:.1rem .65rem;transition:all .2s ease}.post-article-category:hover{color:var(--accent-color);border-color:var(--accent-color)}.post-article-category-icon{color:var(--text-tertiary);transition:color .2s ease}.post-article-category:hover .post-article-category-icon{color:var(--accent-color)}.post-article-tags{margin-top:.75rem;display:flex;flex-wrap:wrap;gap:.5rem}.post-article-tag{display:inline-flex;align-items:center;gap:.2rem;font-size:.82rem;color:var(--text-secondary);text-decoration:none;border-bottom:1px dashed transparent;transition:color .2s ease,border-color .2s ease}.post-article-tag:hover{color:var(--accent-color);border-color:var(--accent-color)}.post-article-tag-icon{color:var(--text-tertiary);transition:color .2s ease}.post-article-tag:hover .post-article-tag-icon{color:var(--accent-color)}.post-stale-notice{margin-top:.85rem;padding:.65rem .8rem;border-left:3px solid #d97706;background:color-mix(in srgb,#f59e0b 10%,var(--bg-primary));color:var(--text-secondary);font-size:.86rem;line-height:1.6}:root.dark .post-stale-notice{border-left-color:#f59e0b;background:color-mix(in srgb,#f59e0b 16%,var(--bg-primary))}:root:not(.dark) .post-content{box-shadow:0 2px 8px rgba(0,0,0,.08),0 1px 3px rgba(0,0,0,.1)}.post-body{line-height:1.8;padding:0 1rem 1.5rem}.post-body h2{margin-top:2rem;margin-bottom:1rem;font-size:1.8rem}.post-body h3{margin-top:1.5rem;margin-bottom:.75rem;font-size:1.4rem}.post-body p{margin-bottom:1rem}.post-body img{max-width:100%;height:auto;display:block;margin:1.25rem auto;border-radius:8px;box-shadow:0 2px 8px var(--shadow-sm),0 1px 3px rgba(0,0,0,.06)}.dark .post-body img{box-shadow:0 4px 14px rgba(0,0,0,.35),0 0 0 1px hsla(0,0%,100%,.04)}.post-body a.post-image-lightbox{display:block;width:-moz-fit-content;width:fit-content;max-width:100%;margin:1.25rem auto;text-decoration:none;color:inherit;cursor:zoom-in}.post-body a.post-image-lightbox img{margin:0 auto}.pswp{z-index:10050}.post-body ol,.post-body ul{margin-left:2rem}.post-body .markdown-alert{margin:.5rem 0;padding:.75rem;border-left:4px solid var(--border-color);border-radius:0;color:var(--text-primary);transition:border-color .2s ease}.post-body .markdown-alert p{margin-bottom:.25rem}.post-body .markdown-alert p:last-child{margin-bottom:0}.post-body .markdown-alert-title{margin-top:0;margin-bottom:.25rem;font-weight:600;display:flex;align-items:center;gap:.5rem}.post-body .markdown-alert-title .octicon{flex-shrink:0;display:inline-block;vertical-align:text-bottom;fill:currentColor}.post-body .markdown-alert-title .mr-2{margin-right:.5rem}.post-body .markdown-alert-note{border-left-color:#0969da}.dark .post-body .markdown-alert-note{border-left-color:#54aeff}.post-body .markdown-alert-note .markdown-alert-title{color:#0969da}.dark .post-body .markdown-alert-note .markdown-alert-title{color:#54aeff}.post-body .markdown-alert-note .octicon-info{fill:#0969da}.dark .post-body .markdown-alert-note .octicon-info{fill:#54aeff}.post-body .markdown-alert-tip{border-left-color:#1a7f37}.dark .post-body .markdown-alert-tip{border-left-color:#3fb950}.post-body .markdown-alert-tip .markdown-alert-title{color:#1a7f37}.dark .post-body .markdown-alert-tip .markdown-alert-title{color:#3fb950}.post-body .markdown-alert-tip .octicon-light-bulb{fill:#1a7f37}.dark .post-body .markdown-alert-tip .octicon-light-bulb{fill:#3fb950}.post-body .markdown-alert-important{border-left-color:#8250df}.dark .post-body .markdown-alert-important{border-left-color:#a475f9}.post-body .markdown-alert-important .markdown-alert-title{color:#8250df}.dark .post-body .markdown-alert-important .markdown-alert-title{color:#a475f9}.post-body .markdown-alert-important .octicon-report{fill:#8250df}.dark .post-body .markdown-alert-important .octicon-report{fill:#a475f9}.post-body .markdown-alert-warning{border-left-color:#9a6700}.dark .post-body .markdown-alert-warning{border-left-color:#d4a72c}.post-body .markdown-alert-warning .markdown-alert-title{color:#9a6700}.dark .post-body .markdown-alert-warning .markdown-alert-title{color:#d4a72c}.post-body .markdown-alert-warning .octicon-alert{fill:#9a6700}.dark .post-body .markdown-alert-warning .octicon-alert{fill:#d4a72c}.post-body .markdown-alert-caution{border-left-color:#cf222e}.dark .post-body .markdown-alert-caution{border-left-color:#ff8182}.post-body .markdown-alert-caution .markdown-alert-title{color:#cf222e}.dark .post-body .markdown-alert-caution .markdown-alert-title{color:#ff8182}.post-body .markdown-alert-caution .octicon-stop{fill:#cf222e}.dark .post-body .markdown-alert-caution .octicon-stop{fill:#ff8182}.post-body table{width:100%;max-width:100%;display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;border-collapse:collapse;margin:1.5rem 0}.post-body table td,.post-body table th{padding:.75rem;text-align:left;border:1px solid var(--table-border-color)}.post-body table th{background-color:var(--bg-tertiary);font-weight:600;color:var(--text-primary)}.post-body table tr:nth-child(2n){background-color:var(--bg-primary)}.post-body table tr:hover{background-color:var(--bg-hover)}.post-body table code{background-color:var(--code-bg);padding:.25rem .5rem;border-radius:4px;font-size:.875em;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,Consolas,Courier New,monospace;color:var(--accent-color);border:1px solid var(--border-color);display:inline-block;transition:background-color .2s ease,border-color .2s ease}.post-body table code:hover{background-color:var(--bg-tertiary);border-color:var(--accent-color)}.post-body code{background-color:var(--code-bg);padding:.2rem .4rem;border-radius:4px;font-size:.9em;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,Consolas,Courier New,monospace;transition:background-color .2s ease}.code-block-wrapper{position:relative;margin:1.5rem 0;border-radius:6px;overflow:hidden}.code-block-wrapper-hljs{background-color:var(--code-block-surface);border:1px solid var(--code-block-border-strong)}.post-body pre{position:relative;margin:0;padding:0;background-color:transparent;border-radius:6px;overflow:hidden;transition:background-color .2s ease}.post-body pre code{display:block;overflow-x:auto;padding:1rem;background-color:transparent;font-size:.875rem;line-height:1.6;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,Consolas,Courier New,monospace}.code-block-with-lines{position:relative;padding-left:0}.code-block-with-lines code{padding:1rem}.post-body pre.hljs{background-color:var(--code-block-surface);border:1px solid var(--code-block-border-strong)}.code-block-wrapper-hljs .code-block-with-lines{background-color:transparent;border:none}.code-block-header{display:flex;justify-content:space-between;align-items:center;padding:.5rem 1rem;background-color:var(--code-block-header-bg);border-bottom:1px solid var(--code-block-border-strong);border-radius:6px 6px 0 0;height:2.25rem;flex-shrink:0}.code-block-header-left{display:flex;align-items:center;flex:1 1}.code-block-header-right{display:flex;align-items:center;gap:.5rem}.code-block-language{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.code-block-copy-btn,.code-block-language{color:var(--text-secondary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.code-block-copy-btn{display:flex;align-items:center;gap:.35rem;padding:.3rem .6rem;font-size:.7rem;font-weight:500;background-color:transparent;border:1px solid var(--border-color);border-radius:4px;cursor:pointer;transition:all .2s ease}.code-block-copy-btn:hover{color:var(--text-primary);background-color:var(--bg-hover);border-color:var(--accent-color)}.code-block-copy-btn:active{transform:scale(.98)}.code-block-copy-btn.copied{color:var(--code-copy-success-color);background-color:var(--code-copy-success-bg);border-color:var(--code-copy-success-border)}.code-block-copy-btn svg{flex-shrink:0}.code-block-wrapper pre.hljs{background-color:transparent;border:none}.code-block-wrapper pre.code-block-with-lines{background-color:transparent}.code-block-line-number{display:block;min-height:1.6em}.post-body pre[data-language]:not(.code-block-with-lines):before{content:attr(data-language);position:absolute;top:0;right:0;padding:.35rem .7rem;font-size:.7rem;font-weight:500;color:var(--text-tertiary);background-color:var(--code-lang-badge-bg);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-bottom-left-radius:6px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;z-index:3;transition:color .2s ease,background-color .2s ease}.code-block-with-lines[data-language]:before{display:none}.post-body pre[data-language]:not(.code-block-with-lines) code{padding-top:2.5rem}.footer{padding:2rem 0 calc(4.5rem + env(safe-area-inset-bottom));background-color:var(--bg-primary);border-top:1px solid var(--border-color);color:var(--text-secondary);font-size:.8125rem;line-height:1.7;letter-spacing:.01em;transition:border-color .2s ease,color .2s ease,background-color .2s ease}.footer-content{display:flex;max-width:1400px;margin:0 auto;padding:0 10px;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}@media (min-width:769px) and (max-width:1200px){.footer-content{max-width:1000px;padding:0 20px}}.footer-left{flex:1 1;text-align:left}.footer-right{flex-shrink:0;text-align:right}.footer-link{color:var(--text-primary);text-decoration:underline;-webkit-text-decoration-color:color-mix(in srgb,var(--text-primary) 35%,transparent);text-decoration-color:color-mix(in srgb,var(--text-primary) 35%,transparent);text-underline-offset:.18em;text-decoration-thickness:1px;font-weight:500;transition:color .2s ease,-webkit-text-decoration-color .2s ease;transition:color .2s ease,text-decoration-color .2s ease;transition:color .2s ease,text-decoration-color .2s ease,-webkit-text-decoration-color .2s ease}.footer-link:hover{color:var(--accent-color);-webkit-text-decoration-color:var(--accent-color);text-decoration-color:var(--accent-color)}.footer-link:focus-visible{color:var(--accent-color);-webkit-text-decoration-color:var(--accent-color);text-decoration-color:var(--accent-color);outline:none}@media (max-width:768px){.footer{padding-bottom:calc(8.5rem + env(safe-area-inset-bottom))}.footer-content{flex-direction:column;align-items:center;gap:.5rem}.footer-left,.footer-right{text-align:center;width:100%}}.pagination{margin-top:3rem;margin-bottom:2rem}.pagination-container{display:flex;gap:.5rem;flex-wrap:wrap}.pagination-button,.pagination-container{align-items:center;justify-content:center}.pagination-button{display:inline-flex;padding:.5rem 1rem;background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);text-decoration:none;font-size:.9rem;transition:all .2s ease;cursor:pointer}.pagination-button:hover:not(.pagination-disabled){background-color:var(--accent-color);border-color:var(--accent-color);color:#fff;transform:translateY(-1px);box-shadow:0 2px 8px rgba(102,126,234,.3)}.pagination-button.pagination-disabled{opacity:.5;cursor:not-allowed;background-color:var(--bg-tertiary)}.pagination-numbers{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.pagination-number{display:inline-flex;align-items:center;justify-content:center;min-width:2.5rem;height:2.5rem;padding:0 .5rem;background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);text-decoration:none;font-size:.9rem;transition:all .2s ease;cursor:pointer}.pagination-number:hover{background-color:var(--bg-hover);border-color:var(--accent-color);color:var(--accent-color);transform:translateY(-1px)}.pagination-number.pagination-active{background-color:var(--accent-color);border-color:var(--accent-color);color:#fff;font-weight:600;box-shadow:0 2px 8px rgba(102,126,234,.3)}.pagination-number.pagination-active:hover{background-color:var(--accent-hover);transform:translateY(-1px)}.pagination-ellipsis{display:inline-flex;align-items:center;justify-content:center;min-width:2.5rem;height:2.5rem;color:var(--text-tertiary)}.pagination-ellipsis,.pagination-info{font-size:.9rem;transition:color .2s ease}.pagination-info{margin-top:1rem;text-align:center;color:var(--text-secondary)}@media (max-width:768px){.pagination-container{gap:.25rem}.pagination-button{padding:.4rem .75rem;font-size:.85rem}.pagination-ellipsis,.pagination-number{min-width:2rem;height:2rem;font-size:.85rem}}.scroll-to-top{position:fixed;bottom:2rem;right:2rem;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:50%;color:var(--text-primary);cursor:pointer;opacity:0;visibility:hidden;transform:translateY(20px);transition:all .3s ease;z-index:999;box-shadow:0 4px 12px var(--shadow-md);padding:0}.scroll-to-top:hover{background-color:var(--accent-color);color:#fff;border-color:var(--accent-color);transform:translateY(-4px);box-shadow:0 6px 16px var(--shadow-lg)}.scroll-to-top.visible{opacity:1;visibility:visible;transform:translateY(0)}.scroll-to-top svg{stroke:currentColor;transition:transform .2s ease}.scroll-to-top:hover svg{transform:translateY(-2px)}@media (max-width:768px){.scroll-to-top{bottom:1.5rem;right:1.5rem;width:44px;height:44px}}.mobile-toc-button{display:none}@media (max-width:768px){.mobile-toc-button{position:fixed;bottom:1.5rem;right:1.5rem;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:50%;color:var(--text-primary);cursor:pointer;z-index:998;box-shadow:0 4px 12px var(--shadow-md);padding:0;transition:all .3s ease}.mobile-toc-button.scroll-to-top-visible{bottom:5.5rem}.mobile-toc-button:hover{background-color:var(--accent-color);color:#fff;border-color:var(--accent-color);transform:translateY(-2px);box-shadow:0 6px 16px var(--shadow-lg)}.mobile-toc-button svg{stroke:currentColor}}.mobile-toc-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:rgba(0,0,0,.5);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:10000;animation:fadeIn .2s ease}.mobile-toc-drawer{position:fixed;top:0;right:0;bottom:0;width:85%;max-width:320px;background-color:var(--bg-primary);border-left:1px solid var(--border-color);box-shadow:-4px 0 24px var(--shadow-lg);z-index:10001;display:flex;flex-direction:column;transform:translateX(100%);transition:transform .3s ease;transition:background-color .2s ease,border-color .2s ease}.mobile-toc-drawer.open{transform:translateX(0)}.mobile-toc-header{display:flex;align-items:center;justify-content:space-between;padding:.85rem 1rem;border-bottom:1px solid var(--border-color);transition:border-color .2s ease}.mobile-toc-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0;transition:color .2s ease}.mobile-toc-close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;border-radius:8px;transition:all .2s ease;padding:0}.mobile-toc-close:hover{background-color:var(--bg-hover);color:var(--text-primary)}.mobile-toc-close svg{stroke:currentColor}.mobile-toc-nav{flex:1 1;overflow-y:auto;padding:.65rem .75rem}.mobile-toc-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.1rem}.mobile-toc-item{margin:0;line-height:1.35}.mobile-toc-link{display:block;padding:.4rem .55rem;text-decoration:none;color:var(--text-secondary);font-size:.8125rem;border-radius:0;transition:all .2s ease;border-left:3px solid transparent}.mobile-toc-link:hover{color:var(--text-primary)}.mobile-toc-item.active .mobile-toc-link,.mobile-toc-link:hover{background-color:var(--bg-hover);border-left-color:var(--accent-color)}.mobile-toc-item.active .mobile-toc-link{color:var(--accent-color);font-weight:500}.mobile-toc-level-2{padding-left:0}.mobile-toc-level-3{padding-left:.75rem}.mobile-toc-level-4{padding-left:1.5rem}.mobile-toc-level-5{padding-left:2.25rem}.mobile-toc-level-6{padding-left:3rem}.hljs{display:block;overflow-x:auto;padding:0;background:transparent;color:var(--hljs-color)}.hljs-comment,.hljs-quote{color:var(--hljs-comment-color);font-style:italic}.hljs-keyword,.hljs-selector-tag,.hljs-type{color:var(--hljs-keyword-color)}.hljs-doctag,.hljs-literal,.hljs-number,.hljs-string{color:var(--hljs-string-color)}.hljs-section,.hljs-selector-id,.hljs-title{color:var(--hljs-title-color)}.hljs-subst{color:var(--hljs-color)}.hljs-class .hljs-title,.hljs-name,.hljs-type{color:var(--hljs-title-color)}.hljs-tag{color:var(--hljs-tag-color)}.hljs-link,.hljs-regexp,.hljs-selector-attr,.hljs-selector-pseudo,.hljs-symbol,.hljs-template-variable,.hljs-variable{color:var(--hljs-regexp-color)}.hljs-attr,.hljs-built_in,.hljs-builtin-name{color:var(--hljs-attr-color)}.hljs-attribute{color:var(--hljs-title-color)}.hljs-meta{color:var(--hljs-comment-color)}.hljs-addition{background-color:var(--hljs-addition-bg);color:var(--hljs-addition-color)}.hljs-deletion{background-color:var(--hljs-deletion-bg);color:var(--hljs-deletion-color)}.hljs-emphasis{font-style:italic}.hljs-strong{font-weight:600}.copyright-card{padding:15px 1rem;background:var(--copyright-card-bg);position:relative;transition:background-color .2s ease;overflow:hidden}.copyright-card>*{position:relative;z-index:1}.copyright-title{font-size:1rem;font-weight:500;color:var(--copyright-text-color);margin-bottom:0;line-height:1.6}.copyright-url{margin-bottom:16px}.copyright-url-link{font-size:.875rem;color:var(--copyright-text-color);text-decoration:underline;word-break:break-all;transition:color .2s ease;line-height:1.6}.copyright-url-link:hover{color:var(--link-color);text-decoration:underline}.copyright-info{display:flex;flex-wrap:wrap;gap:2rem;margin-bottom:1rem}.copyright-info-item{display:flex;flex-direction:column;gap:.25rem}.copyright-info-label{font-size:.8125rem}.copyright-info-label,.copyright-info-value{color:var(--copyright-text-color);line-height:1.5}.copyright-info-value{font-size:.875rem;font-weight:400}.copyright-info-value a{color:var(--copyright-text-color);text-decoration:underline;transition:color .2s ease}.copyright-info-value a:hover{color:var(--link-color)}.copyright-license-link{color:var(--copyright-text-color);text-decoration:underline;border:0 transparent;border-image:none;transition:color .2s ease}.copyright-license-link:hover{color:var(--link-color)}.copyright-notice{font-size:.875rem;color:var(--copyright-text-color);line-height:1.6;margin-top:1rem}.copyright-icon{position:absolute;top:-40px;right:-40px;color:var(--text-tertiary);opacity:.15;flex-shrink:0;width:200px;height:200px;z-index:0;pointer-events:none}.post-taxonomy{padding:1rem;border-top:1px solid var(--border-color);background:var(--bg-primary);display:flex;flex-wrap:wrap;gap:.5rem 1rem;font-size:.875rem}.post-taxonomy,.post-taxonomy-category{align-items:center;color:var(--text-secondary)}.post-taxonomy-category{display:inline-flex;gap:.2rem;text-decoration:none;border-bottom:1px dashed transparent;transition:color .2s ease,border-color .2s ease}.post-taxonomy-category:hover{color:var(--accent-color);border-color:var(--accent-color)}.post-taxonomy-category:hover .post-taxonomy-category-icon{color:var(--accent-color)}.post-taxonomy-category-icon{flex-shrink:0;color:var(--text-tertiary);transition:color .2s ease}.post-taxonomy-tag{display:inline-flex;align-items:center;gap:.2rem;color:var(--text-secondary);text-decoration:none;border-bottom:1px dashed transparent;transition:color .2s ease,border-color .2s ease}.post-taxonomy-tag:hover{border-color:var(--accent-color)}.post-taxonomy-tag:hover,.post-taxonomy-tag:hover .post-taxonomy-tag-icon{color:var(--accent-color)}.post-taxonomy-tag-icon{flex-shrink:0;color:var(--text-tertiary);transition:color .2s ease}@media (max-width:768px){.copyright-card{padding:1.5rem 1rem}.post-taxonomy{padding:1rem}.copyright-info{flex-direction:row;gap:1rem}.post-stale-notice{margin-top:.75rem;font-size:.84rem}.copyright-icon{position:absolute;top:-15px;right:-30px;width:150px;height:150px;opacity:.15;z-index:0;pointer-events:none}}.artalk-wrapper{margin:1.25rem auto 0;padding:1.5rem 1.25rem;background:var(--bg-primary);border-radius:12px;box-shadow:0 1px 3px var(--shadow-sm),0 1px 2px rgba(0,0,0,.06)}.post-pagination{margin:1.25rem auto 0;display:flex;align-items:center;justify-content:space-between;padding:.2rem 0}.post-pagination-side{flex:0 0 50%;width:50%;max-width:50%;min-width:0;padding:0 .5rem;box-sizing:border-box}.post-pagination-link{color:var(--text-primary);display:flex;align-items:center;gap:.4rem;text-decoration:none;line-height:1.5;font-weight:400;word-break:break-word;overflow-wrap:anywhere;transition:color .2s ease;min-width:0;width:100%}.post-pagination-link:hover{color:var(--accent-color)}.post-pagination-link-prev{justify-content:flex-start;text-align:left}.post-pagination-link-next{justify-content:flex-end;text-align:right}.post-pagination-title{min-width:0;word-break:break-word;overflow-wrap:anywhere}.post-pagination-arrow{font-style:normal;color:var(--text-secondary);flex:0 0 auto}.post-pagination-empty{color:var(--text-secondary);line-height:1.5;font-size:.95rem;display:block;width:100%;text-align:left}.post-pagination-empty-next{text-align:right}:root:not(.dark) .artalk-wrapper{box-shadow:0 2px 8px rgba(0,0,0,.08),0 1px 3px rgba(0,0,0,.1)}.artalk-comment-container{margin-top:0}.artalk-fallback-tip{margin:.75rem 0;color:var(--text-secondary);font-size:.95rem}::view-transition-new(root),::view-transition-old(root){animation-duration:.3s;animation-timing-function:ease-in-out}@media (prefers-reduced-motion:reduce){::view-transition-group(*),::view-transition-new(*),::view-transition-old(*){animation:none!important}}::view-transition-new(navbar),::view-transition-new(navbar-brand),::view-transition-new(navbar-menu),::view-transition-old(navbar),::view-transition-old(navbar-brand),::view-transition-old(navbar-menu){animation-duration:.2s;animation-timing-function:ease-out}::view-transition-new(widget-archives),::view-transition-new(widget-author),::view-transition-new(widget-categories-list),::view-transition-new(widget-recent-post),::view-transition-new(widget-tags),::view-transition-old(widget-archives),::view-transition-old(widget-author),::view-transition-old(widget-categories-list),::view-transition-old(widget-recent-post),::view-transition-old(widget-tags){animation-duration:.25s;animation-timing-function:ease-out}::view-transition-new(main),::view-transition-old(main){animation-duration:.28s;animation-timing-function:ease-in-out}nav.navbar{view-transition-name:navbar}.navbar-brand{view-transition-name:navbar-brand}.navbar-menu{view-transition-name:navbar-menu}main.app-main{view-transition-name:main}.vt-widget-author{view-transition-name:widget-author}.vt-widget-categories-list{view-transition-name:widget-categories-list}.vt-widget-tags{view-transition-name:widget-tags}.vt-widget-recent-post{view-transition-name:widget-recent-post}.vt-widget-archives{view-transition-name:widget-archives}.vt-recent-mobile{view-transition-name:none}::view-transition-group(navbar),::view-transition-group(navbar-brand),::view-transition-group(navbar-menu){z-index:10001}::view-transition-group(main){z-index:1}::view-transition-group(widget-archives),::view-transition-group(widget-author),::view-transition-group(widget-categories-list),::view-transition-group(widget-recent-post),::view-transition-group(widget-tags){z-index:10}