*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;scroll-padding-top:5rem;font-size:16px;-webkit-text-size-adjust:100%}body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","Noto Sans SC",sans-serif;color:var(--text-primary);background-color:var(--bg-primary);line-height:1.75;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color 250ms,color 250ms}::selection{background:var(--accent);color:var(--bg-primary)}a{color:var(--accent);text-decoration:none;transition:color 150ms}a:hover{color:var(--accent-hover)}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.35;margin-top:3rem;margin-bottom:1rem;color:var(--text-primary)}h1:first-child,h2:first-child,h3:first-child,h4:first-child,h5:first-child,h6:first-child{margin-top:0}h1{font-size:clamp(1.75rem, calc(1.5rem + 1vw), 2.25rem)}h2{font-size:clamp(1.5rem, calc(1.3rem + 0.8vw), 1.875rem);padding-bottom:0.3em;border-bottom:1px solid var(--border)}h3{font-size:clamp(1.25rem, calc(1.1rem + 0.6vw), 1.5rem)}h4{font-size:1.125rem}h5{font-size:1rem}h6{font-size:0.875rem;color:var(--text-secondary)}p{margin-bottom:1rem}ul,ol{margin-bottom:1rem;padding-left:2rem}li{margin-bottom:.25rem}li>ul,li>ol{margin-bottom:0}blockquote{border-left:3px solid var(--accent);padding:.5rem 1.5rem;margin:1.5rem 0;color:var(--text-secondary);background:var(--bg-secondary);border-radius:0 8px 8px 0}blockquote p:last-child{margin-bottom:0}hr{border:none;height:1px;background:var(--border);margin:3rem 0}table{width:100%;border-collapse:collapse;margin:1.5rem 0;font-size:0.9375rem}th,td{padding:.5rem 1rem;border:1px solid var(--border);text-align:left}th{background:var(--bg-secondary);font-weight:600}tbody tr:nth-child(even){background:var(--bg-secondary)}code:not(pre code){font-family:"JetBrains Mono","Cascadia Code","Fira Code","SF Mono","Consolas",monospace;font-size:0.875em;padding:0.15em 0.4em;background:var(--bg-secondary);border:1px solid var(--border);border-radius:4px;font-variant-ligatures:none}img{max-width:100%;height:auto;border-radius:8px;cursor:zoom-in;transition:transform 250ms cubic-bezier(0.16, 1, 0.3, 1)}figure{margin:1.5rem 0;text-align:center}figcaption{font-size:0.8125rem;color:var(--text-muted);margin-top:.5rem}.content a{text-decoration:underline;text-underline-offset:2px;text-decoration-thickness:1px}.content a:hover{text-decoration-thickness:2px}.site-header{position:sticky;top:0;z-index:100;background:color-mix(in srgb, var(--bg-primary) 85%, transparent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);padding:1rem 0}.header-inner{max-width:960px;margin:0 auto;padding:0 1.5rem;display:flex;align-items:center;justify-content:space-between}.site-title{display:inline-flex;align-items:center;gap:.5rem;font-size:1.25rem;font-weight:700;color:var(--text-primary);letter-spacing:-0.02em}.site-title:hover{color:var(--accent)}.site-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover;flex-shrink:0}.site-nav{display:flex;align-items:center;gap:1.5rem}.site-nav a{font-size:0.875rem;color:var(--text-secondary);font-weight:500;letter-spacing:0.01em;transition:color 150ms}.site-nav a:hover{color:var(--text-primary)}.site-nav a.active{color:var(--text-primary)}.theme-toggle{background:none;border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;padding:.5rem;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all 150ms;line-height:1}.theme-toggle:hover{color:var(--text-primary);border-color:var(--border-light);background:var(--bg-secondary)}.theme-toggle svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.container{max-width:780px;margin:0 auto;padding:3rem 1.5rem}.container--wide{max-width:960px}.site-footer{border-top:1px solid var(--border);padding:2rem 0}.footer-inner{max-width:960px;margin:0 auto;padding:0 1.5rem;display:flex;align-items:center;justify-content:space-between;font-size:0.8125rem;color:var(--text-muted)}.footer-links{display:flex;gap:1.5rem}.footer-links a{color:var(--text-muted)}.footer-links a:hover{color:var(--accent)}.social-links{display:flex;gap:1rem}.social-link{display:flex;align-items:center;color:var(--text-muted);transition:color 150ms}.social-link:hover{color:var(--accent)}.social-link svg{width:16px;height:16px;fill:currentColor}.search-container{position:relative}.search-input{background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-primary);padding:.5rem 1rem;border-radius:8px;font-size:0.8125rem;width:200px;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","Noto Sans SC",sans-serif;transition:all 150ms}.search-input::placeholder{color:var(--text-muted)}.search-input:focus{outline:none;border-color:var(--accent);width:260px;box-shadow:0 0 0 3px var(--accent-dim)}.search-results{position:absolute;top:calc(100% + $space-sm);right:0;width:360px;max-height:400px;overflow-y:auto;background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:8px;box-shadow:0 8px 32px rgba(0,0,0,0.5);z-index:200}.search-result-item{display:block;padding:1rem;border-bottom:1px solid var(--border);transition:background 150ms}.search-result-item:last-child{border-bottom:none}.search-result-item:hover{background:var(--bg-tertiary)}.search-result-item .search-result-title{font-weight:600;font-size:0.875rem;color:var(--text-primary);margin-bottom:.25rem}.search-result-item .search-result-excerpt{font-size:0.75rem;color:var(--text-secondary);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.search-result-item .search-result-date{font-size:0.6875rem;color:var(--text-muted);margin-top:.25rem}.search-no-results{padding:1.5rem;text-align:center;color:var(--text-muted);font-size:0.8125rem}@media (max-width: 768px){.header-inner{flex-wrap:wrap;gap:.5rem}.site-nav{order:3;width:100%;justify-content:center;gap:1rem;padding-top:.5rem;border-top:1px solid var(--border)}.footer-inner{flex-direction:column;gap:1rem;text-align:center}.search-input{width:140px}.search-input:focus{width:180px}.search-results{width:calc(100vw - 2rem);right:-2rem}}.post-list{list-style:none;padding:0;display:flex;flex-direction:column;gap:1.5rem}.post-item{padding:0;border-bottom:none}.post-card{display:flex;align-items:center;gap:1.5rem;padding:0 0;border-bottom:1px solid var(--border);transition:all 150ms}.post-card:last-child{border-bottom:none}.post-card:hover .post-card-icon img{transform:scale(1.05)}.post-card-icon{flex-shrink:0;width:96px;height:96px;border-radius:12px;overflow:hidden;background:transparent;display:flex;align-items:center;justify-content:center}.post-card-icon img{width:84px;height:84px;object-fit:contain;border-radius:0;cursor:default;transition:transform 250ms cubic-bezier(0.16, 1, 0.3, 1)}.post-card-content{display:flex;flex-direction:column;min-width:0}.post-meta{font-size:0.8125rem;color:var(--text-muted);display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:.5rem}.post-tag{background:var(--accent-dim);color:var(--accent);padding:0.1em 0.5em;border-radius:4px;font-size:0.75rem;font-weight:500}.post-title{font-size:1.375rem;font-weight:700;letter-spacing:-0.02em;margin:0 0 .5rem}.post-title a{color:var(--text-primary)}.post-title a:hover{color:var(--accent)}.post-excerpt{color:var(--text-secondary);font-size:0.9375rem;line-height:1.7;margin-bottom:.5rem}.post-read-more{font-size:0.8125rem;font-weight:500;color:var(--accent);display:inline-flex;align-items:center;gap:.25rem}.post-read-more:hover{gap:.5rem}.post-content{overflow-x:hidden}.post-content h1,.post-content h2,.post-content h3,.post-content h4,.post-content h5,.post-content h6{scroll-margin-top:5rem}.post-content h1 .anchor,.post-content h2 .anchor,.post-content h3 .anchor,.post-content h4 .anchor,.post-content h5 .anchor,.post-content h6 .anchor{color:var(--text-muted);margin-left:.25rem;text-decoration:none;opacity:0;transition:opacity 150ms}.post-content h1 .anchor:hover,.post-content h2 .anchor:hover,.post-content h3 .anchor:hover,.post-content h4 .anchor:hover,.post-content h5 .anchor:hover,.post-content h6 .anchor:hover{color:var(--accent)}.post-content h1:hover .anchor,.post-content h2:hover .anchor,.post-content h3:hover .anchor,.post-content h4:hover .anchor,.post-content h5:hover .anchor,.post-content h6:hover .anchor{opacity:1}.post-nav{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-top:3rem;padding-top:2rem;border-top:1px solid var(--border)}.post-nav-item{display:block;padding:1rem;border:1px solid var(--border);border-radius:8px;transition:all 150ms}.post-nav-item:hover{border-color:var(--accent);background:var(--bg-secondary)}.post-nav-item.prev .label{color:var(--text-muted)}.post-nav-item.next .label{color:var(--text-muted);text-align:right}.post-nav-item .title{font-size:0.875rem;font-weight:600;color:var(--text-primary);margin-top:.25rem}.post-nav-item.next{text-align:right}.label{font-size:0.75rem;color:var(--text-muted)}.post-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.5rem}.tag-link{background:var(--bg-secondary);color:var(--text-secondary);padding:0.2em 0.6em;border-radius:4px;font-size:0.8125rem;border:1px solid var(--border);transition:all 150ms}.tag-link:hover{border-color:var(--accent);color:var(--accent)}.pagination{display:flex;justify-content:center;gap:.5rem;margin-top:3rem}.pagination a,.pagination span{padding:.5rem 1rem;border:1px solid var(--border);border-radius:4px;font-size:0.875rem;transition:all 150ms}.pagination a:hover{border-color:var(--accent);background:var(--bg-secondary)}.pagination .current{background:var(--accent-dim);border-color:var(--accent);color:var(--accent);font-weight:600}.archive-group{margin-bottom:3rem}.archive-year{font-size:1.25rem;font-weight:700;margin-bottom:1rem;color:var(--text-primary)}.archive-item{display:flex;justify-content:space-between;align-items:baseline;padding:.5rem 0;border-bottom:1px solid var(--border)}.archive-item:last-child{border-bottom:none}.archive-item a{color:var(--text-primary)}.archive-item a:hover{color:var(--accent)}.archive-item .date{font-size:0.8125rem;color:var(--text-muted);white-space:nowrap;margin-left:1rem}.tag-cloud{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:3rem}.tag-size-sm{font-size:0.75rem}.tag-size-md{font-size:0.875rem}.tag-size-lg{font-size:1rem;font-weight:500}.tag-size-xl{font-size:1.25rem;font-weight:600}.tag-size-2xl{font-size:1.5rem;font-weight:700}@media (max-width: 640px){.post-nav{grid-template-columns:1fr}.post-card-icon{width:48px;height:48px}.post-card-icon img{width:36px;height:36px}.post-title{font-size:1.125rem}}.reading-progress-bar{position:fixed;top:0;left:0;height:2px;background:linear-gradient(90deg, var(--accent), var(--accent-hover));width:0%;z-index:101;transition:width 100ms linear;border-radius:0 1px 1px 0}.scroll-top-btn{position:fixed;bottom:2rem;right:2rem;width:44px;height:44px;border-radius:50%;background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(0,0,0,0.4);opacity:0;transform:translateY(8px);pointer-events:none;transition:all 250ms cubic-bezier(0.16, 1, 0.3, 1);z-index:50}.scroll-top-btn.visible{opacity:1;transform:translateY(0);pointer-events:auto}.scroll-top-btn:hover{background:var(--accent);color:var(--bg-primary);border-color:var(--accent);box-shadow:0 8px 32px rgba(0,0,0,0.5)}.scroll-top-btn svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.toc-sidebar{position:fixed;top:5rem;right:calc((100vw - 960px) / 2 - 2rem);width:180px;max-height:calc(100vh - 8rem);overflow-y:auto;font-size:0.75rem;color:var(--text-muted);scrollbar-width:none}.toc-sidebar::-webkit-scrollbar{display:none}.toc-sidebar .toc-title{font-weight:600;color:var(--text-secondary);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:0.05em;font-size:0.6875rem}.toc-sidebar ul{list-style:none;padding:0;margin:0}.toc-sidebar li{margin:0;padding:0}.toc-sidebar a{display:block;padding:0.2em 0;color:var(--text-muted);border-left:2px solid transparent;padding-left:.5rem;transition:all 150ms;line-height:1.4}.toc-sidebar a:hover{color:var(--text-primary)}.toc-sidebar a.active{color:var(--accent);border-left-color:var(--accent)}.toc-sidebar ul ul a{padding-left:1.5rem}.mobile-toc-toggle{display:none;background:none;border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;padding:.5rem 1rem;border-radius:8px;font-size:0.8125rem;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","Noto Sans SC",sans-serif;gap:.5rem;align-items:center;transition:all 150ms;margin-bottom:1rem}.mobile-toc-toggle:hover{border-color:var(--accent);color:var(--text-primary)}.mobile-toc-toggle svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2}.mobile-toc{display:none;background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;padding:1rem;margin-bottom:1.5rem}.mobile-toc.open{display:block}.mobile-toc a{display:block;padding:0.3em 0 0.3em .5rem;color:var(--text-secondary);border-left:2px solid transparent;font-size:0.8125rem}.mobile-toc a.active{color:var(--accent);border-left-color:var(--accent)}.code-block-wrapper{position:relative}.code-block-wrapper .code-copy-btn{position:absolute;top:.25rem;right:.25rem;background:var(--bg-tertiary);border:1px solid var(--border);color:var(--text-muted);padding:.25rem .5rem;border-radius:4px;cursor:pointer;font-size:0.6875rem;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","Noto Sans SC",sans-serif;opacity:0;transition:all 150ms;z-index:10}.code-block-wrapper .code-copy-btn:hover{opacity:1 !important;color:var(--text-primary);background:var(--bg-secondary)}.code-block-wrapper .code-copy-btn.copied{color:var(--success) !important}.code-block-wrapper:hover .code-copy-btn{opacity:0.7}.lightbox{position:fixed;inset:0;z-index:1000;background:rgba(0,0,0,0.9);display:flex;align-items:center;justify-content:center;cursor:zoom-out;opacity:0;transition:opacity 250ms;pointer-events:none}.lightbox.open{opacity:1;pointer-events:auto}.lightbox img{max-width:90vw;max-height:90vh;object-fit:contain;cursor:default;border-radius:0}.lightbox .lightbox-close{position:absolute;top:1rem;right:1rem;background:none;border:none;color:white;font-size:1.5rem;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background 150ms}.lightbox .lightbox-close:hover{background:rgba(255,255,255,0.1)}.fade-in{opacity:0;transform:translateY(16px);transition:opacity 0.5s ease, transform 0.5s ease}.fade-in.visible{opacity:1;transform:translateY(0)}@media (max-width: 1200px){.toc-sidebar{display:none}.mobile-toc-toggle{display:flex}}div.highlighter-rouge,div.highlighter-rouge div.highlight,div.highlighter-rouge pre,div.highlighter-rouge code{background:none;border:none;padding:0;margin:0;border-radius:0;overflow:visible}.highlight{position:relative;margin:1.5rem 0;max-width:100%;width:100%;background:var(--code-bg);border:1px solid var(--code-border);border-radius:8px;overflow-x:auto;overflow-y:hidden}.highlight pre{margin:0;padding:1rem 1.5rem;overflow-x:auto;line-height:1.6;font-size:0.8125rem;font-family:"JetBrains Mono","Cascadia Code","Fira Code","SF Mono","Consolas",monospace;color:var(--text-primary);min-width:0;white-space:pre;word-break:normal;word-wrap:normal}.highlight pre::-webkit-scrollbar{height:6px}.highlight pre::-webkit-scrollbar-track{background:var(--code-bg)}.highlight pre::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:3px}.highlight code{background:none;border:none;padding:0;font-size:inherit;font-variant-ligatures:none;white-space:pre;word-break:normal;word-wrap:normal}.highlight table.rouge-table{border-collapse:collapse;border-spacing:0;border:none;margin:0;padding:0;width:auto;min-width:0;table-layout:fixed}.highlight .rouge-gutter{padding:1rem .5rem;background:var(--bg-secondary);border-right:1px solid var(--code-border);user-select:none;font-size:0.8125rem;font-family:"JetBrains Mono","Cascadia Code","Fira Code","SF Mono","Consolas",monospace;color:var(--text-muted);text-align:right;vertical-align:top;width:1%}.highlight .rouge-code{padding:1rem 1.5rem;vertical-align:top;overflow-x:auto}.highlight .lineno{color:var(--text-muted);user-select:none}.highlight .hll{background-color:#6e768166;display:block}.highlight{background:var(--code-bg)}.highlight .c{color:#8b949e;font-style:italic}.highlight .err{color:#f85149}.highlight .k{color:#ff7b72}.highlight .o{color:#ff7b72}.highlight .cm{color:#8b949e;font-style:italic}.highlight .cp{color:#8b949e;font-weight:bold;font-style:italic}.highlight .c1{color:#8b949e;font-style:italic}.highlight .cs{color:#8b949e;font-weight:bold;font-style:italic}.highlight .gd{color:#f85149;background-color:#490202}.highlight .ge{font-style:italic}.highlight .gr{color:#f85149}.highlight .gh{color:#79c0ff}.highlight .gi{color:#56d364;background-color:#0f5323}.highlight .go{color:#8b949e}.highlight .gp{color:#8b949e}.highlight .gs{font-weight:bold}.highlight .gu{color:#79c0ff}.highlight .gt{color:#ff7b72}.highlight .kc{color:#79c0ff}.highlight .kd{color:#ff7b72}.highlight .kn{color:#ff7b72}.highlight .kp{color:#79c0ff}.highlight .kr{color:#ff7b72}.highlight .kt{color:#ff7b72}.highlight .m{color:#a5d6ff}.highlight .s{color:#a5d6ff}.highlight .na{color:#d2a8ff}.highlight .nb{color:#d2a8ff}.highlight .nc{color:#f0883e}.highlight .no{color:#79c0ff}.highlight .nd{color:#d2a8ff}.highlight .ni{color:#ffa657}.highlight .ne{color:#f0883e}.highlight .nf{color:#d2a8ff}.highlight .nl{color:#79c0ff}.highlight .nn{color:#ff7b72}.highlight .nx{color:#79c0ff}.highlight .nt{color:#7ee787}.highlight .nv{color:#ffa657}.highlight .ow{color:#ff7b72}.highlight .w{color:#6e7681}.highlight .mf{color:#a5d6ff}.highlight .mh{color:#a5d6ff}.highlight .mi{color:#a5d6ff}.highlight .mo{color:#a5d6ff}.highlight .sb{color:#a5d6ff}.highlight .sc{color:#a5d6ff}.highlight .sd{color:#a5d6ff}.highlight .s2{color:#a5d6ff}.highlight .se{color:#79c0ff}.highlight .sh{color:#a5d6ff}.highlight .si{color:#a5d6ff}.highlight .sx{color:#a5d6ff}.highlight .sr{color:#7ee787}.highlight .s1{color:#a5d6ff}.highlight .ss{color:#a5d6ff}.highlight .bp{color:#79c0ff}.highlight .vc{color:#ffa657}.highlight .vg{color:#ffa657}.highlight .vi{color:#ffa657}.highlight .il{color:#a5d6ff}:root{--bg-primary: #0d1117;--bg-secondary: #161b22;--bg-tertiary: #1c2128;--bg-card: #13171d;--text-primary: #e6edf3;--text-secondary: #8b949e;--text-muted: #6e7681;--accent: #58a6ff;--accent-hover: #79b8ff;--accent-dim: rgba(88, 166, 255, 0.15);--border: #21262d;--border-light: #30363d;--code-bg: #0d1117;--code-border: #21262d;--success: #3fb950;--warning: #d29922;--error: #f85149;color-scheme:dark}:root.light-theme{--bg-primary: #ffffff;--bg-secondary: #f6f8fa;--bg-tertiary: #eaeef2;--bg-card: #ffffff;--text-primary: #1f2328;--text-secondary: #656d76;--text-muted: #8c959f;--accent: #0969da;--accent-hover: #0550ae;--accent-dim: rgba(9, 105, 218, 0.1);--border: #d0d7de;--border-light: #d0d7de;--code-bg: #f6f8fa;--code-border: #d0d7de;--success: #1a7f37;--warning: #9a6700;--error: #cf222e;color-scheme:light}@keyframes fadeInUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes slideDown{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.toast{position:fixed;bottom:3rem;left:50%;transform:translateX(-50%) translateY(20px);background:var(--success);color:#000;padding:.5rem 1.5rem;border-radius:8px;font-size:0.8125rem;font-weight:500;opacity:0;pointer-events:none;transition:all 250ms cubic-bezier(0.16, 1, 0.3, 1);z-index:2000}.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
