:root{--accent:#1e80ff;--accent-hover:#0066cc;--accent-bg:#f0f8ff;--accent-light:#e6f3ff;--ink:#1d2129;--ink-secondary:#4e5969;--ink-tertiary:#86909c;--ink-light:#c9cdd4;--surface:#ffffff;--surface-raised:#f7f8fa;--surface-hover:#f2f3f5;--border:#e4e6ea;--border-light:#f2f3f5;--nav-bg:#ffffff;--nav-shadow:0 1px 2px 0 rgba(0,0,0,0.05);--nav-height:60px;--max-width:1400px;--sidebar-w:280px;--content-max:none;--r-sm:4px;--r-md:8px;--r-lg:12px;--r-xl:16px;--gap:24px;--shadow-sm:0 1px 3px rgba(0,0,0,0.1);--shadow-md:0 4px 12px rgba(0,0,0,0.1);--shadow-lg:0 8px 24px rgba(0,0,0,0.12)}*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:-apple-system,BlinkMacSystemFont,segoe ui,pingfang sc,hiragino sans gb,microsoft yahei,helvetica neue,Helvetica,Arial,sans-serif;color:var(--ink);background:var(--surface-raised);line-height:1.6;min-height:100vh;display:flex;flex-direction:column;font-size:14px}a{color:var(--accent);text-decoration:none;transition:color .2s ease}a:hover{color:var(--accent-hover)}::selection{background:var(--accent);color:#fff}.site-header{position:fixed;top:0;left:0;right:0;height:var(--nav-height);background:var(--nav-bg);z-index:200;border-bottom:1px solid var(--border);box-shadow:var(--nav-shadow)}.header-container{max-width:var(--max-width);margin:0 auto;padding:0 12px;height:100%;display:flex;align-items:center;justify-content:space-between}.site-logo{display:flex;align-items:center;gap:8px;font-size:18px;font-weight:600;color:var(--ink);letter-spacing:-.01em}.site-logo:hover{color:var(--accent)}.site-logo i{font-size:20px;color:var(--accent)}.site-nav{display:flex;gap:32px}.nav-item{color:var(--ink-secondary);font-size:14px;font-weight:500;padding:8px 0;position:relative;transition:color .2s}.nav-item::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--accent);border-radius:1px;transform:scaleX(0);transition:transform .25s ease}.nav-item:hover,.nav-item.current{color:var(--accent)}.nav-item.current::after,.nav-item:hover::after{transform:scaleX(1)}.menu-btn{display:none;background:0 0;border:none;color:var(--ink);font-size:18px;cursor:pointer;padding:4px}.layout{max-width:var(--max-width);width:100%;margin:0 auto;padding:calc(var(--nav-height) + 32px)12px 64px;display:grid;grid-template-columns:1fr var(--sidebar-w);gap:24px;flex:1}.article-layout{display:grid;grid-template-columns:260px 1fr;gap:24px;align-items:start}.article-layout .article{min-width:0;max-width:none}.article-toc{position:sticky;top:calc(var(--nav-height) + 24px);height:fit-content;max-height:calc(100vh - var(--nav-height) - 48px);overflow-y:auto}.article-toc .toc{background:var(--surface);border-radius:var(--r-lg);border:1px solid var(--border);padding:20px 18px;box-shadow:0 4px 20px rgba(0,0,0,6%)}.article-toc .toc-label{font-size:14px;font-weight:600;color:var(--ink-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px;display:flex;align-items:center;gap:4px}.article-toc .toc a{color:var(--ink-secondary);font-size:14px;display:block;padding:6px 0;border-radius:var(--r-sm);border:none;transition:all .15s;position:relative;line-height:1.4;outline:none;text-decoration:none}.article-toc .toc a:focus{outline:none;box-shadow:none}.article-toc .toc a:hover{color:var(--accent)}.article-toc .toc .toc-h3{padding-left:0}.article-toc .toc .toc-h4{padding-left:0}.article-toc .toc ol,.article-toc .toc ul{list-style:none;padding-left:0;margin:0}.article-toc .toc li{margin-bottom:2px}.article-toc .toc ol ol,.article-toc .toc ul ul{padding-left:16px}.article-toc .toc ol ol ol,.article-toc .toc ul ul ul{padding-left:32px}.sidebar{position:sticky;top:calc(var(--nav-height) + 24px);height:fit-content;max-height:calc(100vh - var(--nav-height) - 48px);overflow-y:auto;background:var(--surface);border-radius:var(--r-lg);border:1px solid var(--border);padding:28px 24px;box-shadow:0 4px 20px rgba(0,0,0,6%)}.sidebar-block{padding:20px 0;margin-bottom:20px;border-bottom:1px solid var(--border-light)}.sidebar-block:last-child{border-bottom:none;margin-bottom:0}.author-card{display:flex;flex-direction:column;text-align:center;gap:16px;align-items:center}.author-icon{width:80px;height:80px;background:0 0;border:3px solid var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 16px rgba(30,128,255,.2)}.author-icon i{font-size:32px;color:var(--accent)}.author-name{font-size:18px;font-weight:600;margin-bottom:6px;color:var(--ink)}.author-bio{font-size:14px;color:var(--ink-secondary);line-height:1.5}.block-title{font-size:13px;font-weight:600;color:var(--ink-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:16px;display:flex;align-items:center;gap:8px}.block-title i{color:var(--accent);font-size:16px}.tag-list{display:flex;flex-wrap:wrap;gap:10px}.tag-pill{background:var(--surface-raised);color:var(--ink-secondary);padding:8px 12px;border-radius:var(--r-md);font-size:13px;font-weight:500;transition:all .2s;display:inline-flex;align-items:center;gap:6px;border:1px solid var(--border);text-decoration:none}.tag-pill::before{content:'#';opacity:.6;font-weight:400}.tag-pill:hover{background:var(--accent-light);color:var(--accent);border-color:var(--accent);transform:translateY(-1px)}.pill-count{font-size:11px;opacity:.7;background:var(--surface);padding:2px 6px;border-radius:8px}.recent-list{list-style:none}.recent-list li{display:block;padding:12px 0;border-bottom:1px solid var(--border-light);font-size:14px}.recent-list li:last-child{border-bottom:none}.recent-list a{color:var(--ink-secondary);font-weight:500;display:block;line-height:1.4;transition:all .2s;padding:4px 0;border-radius:var(--r-sm)}.recent-list a:hover{color:var(--accent);padding-left:8px;background:var(--surface-hover)}.recent-list time{font-size:12px;color:var(--ink-tertiary);display:block;margin-top:6px;font-weight:400}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.stat-item{background:var(--surface-raised);border:1px solid var(--border);border-radius:var(--r-md);padding:16px 12px;text-align:center;transition:all .2s ease}.stat-item:hover{background:var(--accent-light);border-color:var(--accent);transform:translateY(-2px)}.stat-number{font-size:20px;font-weight:700;color:var(--accent);line-height:1;margin-bottom:4px}.stat-label{font-size:11px;color:var(--ink-secondary);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.archive-list{display:flex;flex-direction:column;gap:8px}.archive-year{display:block}.year-link{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--surface-raised);border:1px solid var(--border);border-radius:var(--r-md);color:var(--ink-secondary);text-decoration:none;font-size:13px;font-weight:500;transition:all .2s ease}.year-link:hover{background:var(--accent-light);border-color:var(--accent);color:var(--accent);transform:translateX(4px)}.year-count{font-size:11px;background:var(--surface);padding:2px 6px;border-radius:8px;color:var(--ink-tertiary)}.links-list{display:flex;flex-direction:column;gap:6px}.link-item{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--surface-raised);border:1px solid var(--border);border-radius:var(--r-md);color:var(--ink-secondary);text-decoration:none;font-size:13px;font-weight:500;transition:all .2s ease}.link-item:hover{background:var(--accent-light);border-color:var(--accent);color:var(--accent);transform:translateX(4px)}.link-item i{font-size:12px;opacity:.7}.contact-list{display:flex;flex-direction:column;gap:6px}.contact-item{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--surface-raised);border:1px solid var(--border);border-radius:var(--r-md);color:var(--ink-secondary);text-decoration:none;font-size:13px;font-weight:500;transition:all .2s ease}.contact-item:hover{background:var(--accent-light);border-color:var(--accent);color:var(--accent);transform:translateX(4px)}.contact-item i{font-size:14px;opacity:.8}.contact-item span{flex:1}.hero{grid-column:1/2;padding:48px 0 10px;margin-bottom:10px;max-width:800px;margin-left:auto;margin-right:auto;text-align:center;position:relative}.hero::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:60px;height:4px;background:linear-gradient(90deg,var(--accent),#6366f1);border-radius:2px}.hero-title{font-size:32px;font-weight:700;color:var(--ink);line-height:1.2;margin-bottom:16px;margin-top:24px;letter-spacing:-.02em}.hero-desc{font-size:16px;color:var(--ink-secondary);line-height:1.6;max-width:480px;margin:0 auto 32px}.contribution-graph{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:24px;margin-bottom:32px;margin-top:24px;box-shadow:0 2px 8px rgba(0,0,0,4%)}.graph-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-wrap:wrap;gap:12px}.graph-title{font-size:14px;font-weight:600;color:var(--ink);margin:0}.graph-legend{display:flex;align-items:center;gap:4px}.legend-text{font-size:11px;color:var(--ink-tertiary)}.legend-colors{display:flex;gap:2px;margin:0 4px}.legend-square{width:10px;height:10px;border-radius:2px;border:1px solid var(--border-light)}.legend-square.level-0{background:var(--surface-raised)}.legend-square.level-1{background:#c6e48b}.legend-square.level-2{background:#7bc96f}.legend-square.level-3{background:#239a3b}.legend-square.level-4{background:#196127}.graph-container{position:relative}.month-labels{display:flex;justify-content:space-between;gap:0;margin-bottom:8px;padding-left:0;margin-left:44px}.month-label{font-size:10px;color:var(--ink-tertiary);text-align:center;white-space:nowrap;flex-shrink:0}.graph-grid{display:flex;gap:4px;margin-left:20px}.weekday-labels{display:flex;flex-direction:column;justify-content:space-around;width:20px;height:105px}.weekday-label{font-size:9px;color:var(--ink-tertiary);text-align:right;line-height:1}.contribution-grid{display:grid;grid-template-columns:repeat(53,1fr);grid-template-rows:repeat(7,1fr);gap:2px;grid-auto-flow:column;width:100%;max-width:580px}.contribution-day{width:11px;height:11px;border-radius:2px;border:1px solid var(--border-light);cursor:pointer;transition:all .1s ease;position:relative}.contribution-day:hover{border-color:var(--ink-tertiary);transform:scale(1.1)}.contribution-day.level-0{background:var(--surface-raised)}.contribution-day.level-1{background:#c6e48b}.contribution-day.level-2{background:#7bc96f}.contribution-day.level-3{background:#239a3b}.contribution-day.level-4{background:#196127}.graph-footer{margin-top:24px;text-align:center}.contribution-stats{font-size:12px;color:var(--ink-secondary)}.contribution-stats strong{color:var(--ink);font-weight:600}.stat-separator{margin:0 8px;color:var(--ink-tertiary)}[data-theme=dark] .legend-square.level-0,[data-theme=dark] .contribution-day.level-0{background:var(--surface-hover)}[data-theme=dark] .legend-square.level-1,[data-theme=dark] .contribution-day.level-1{background:#0e4429}[data-theme=dark] .legend-square.level-2,[data-theme=dark] .contribution-day.level-2{background:#006d32}[data-theme=dark] .legend-square.level-3,[data-theme=dark] .contribution-day.level-3{background:#26a641}[data-theme=dark] .legend-square.level-4,[data-theme=dark] .contribution-day.level-4{background:#39d353}.post-list{grid-column:1/2;display:flex;flex-direction:column;gap:0;background:var(--surface);border-radius:var(--r-lg);border:1px solid var(--border);overflow:hidden;box-shadow:0 1px 3px rgba(0,0,0,4%);max-width:800px;margin-left:auto;margin-right:auto}.card{background:0 0;border-bottom:1px solid var(--border-light);transition:background-color .15s ease;overflow:hidden}.card:last-child{border-bottom:none}.card:hover{background:var(--surface-hover)}.card-link{display:block;padding:16px 20px;color:inherit;text-decoration:none}.card-link:hover{color:inherit}.card-main{display:flex;gap:16px;align-items:flex-start}.card-content{flex:1;min-width:0}.card-title{font-size:16px;font-weight:600;line-height:1.4;margin-top:12px;margin-bottom:12px;color:var(--ink);transition:color .15s;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;word-break:break-word}.card:hover .card-title{color:var(--accent)}.card-excerpt{color:var(--ink-secondary);font-size:13px;line-height:1.5;margin-bottom:12px;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;max-height:20px;word-break:break-word}.card-action{display:inline-flex;align-items:center;gap:4px;color:var(--accent);font-size:13px;font-weight:500;margin-top:8px;transition:all .2s ease}.card-action:hover{color:var(--accent-hover);transform:translateX(2px)}.card-action i{font-size:12px;transition:transform .2s ease}.card:hover .card-action i{transform:translateX(2px)}.card-meta{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--ink-tertiary);flex-wrap:wrap}.card-author{display:flex;align-items:center;gap:6px}.card-author i{font-size:12px}.card-date{display:flex;align-items:center;gap:4px}.card-date i{font-size:12px}.card-tags{display:flex;gap:6px;flex-wrap:wrap}.tag{background:var(--surface-raised);color:var(--ink-secondary);padding:2px 6px;border-radius:10px;font-size:11px;font-weight:500;border:1px solid var(--border);transition:all .15s;text-decoration:none;cursor:pointer}.tag:hover{background:var(--accent-light);color:var(--accent);border-color:var(--accent)}.card-thumbnail{width:160px;height:100px;background:var(--surface-raised);border-radius:var(--r-md);border:1px solid var(--border);flex-shrink:0;display:flex;align-items:center;justify-content:center;color:var(--ink-tertiary);transition:all .15s}.card-thumbnail i{font-size:24px}.card:hover .card-thumbnail{background:var(--accent-light);color:var(--accent)}.pagination{grid-column:1/2;display:flex;justify-content:center;align-items:center;gap:16px;padding:32px 0;margin-top:20px;max-width:800px;margin-left:auto;margin-right:auto}.page-btn{background:var(--surface);border:1px solid var(--border);padding:8px 16px;border-radius:var(--r-md);color:var(--ink-secondary);font-size:13px;font-weight:500;display:inline-flex;align-items:center;gap:4px;transition:all .2s;text-decoration:none}.page-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.page-info{color:var(--ink-tertiary);font-size:13px;font-weight:500;padding:0 8px}.taxonomy-page{background:var(--surface);border-radius:var(--r-lg);border:1px solid var(--border);padding:32px 40px;box-shadow:var(--shadow-sm);max-width:800px;margin-left:auto;margin-right:auto}.taxonomy-header{text-align:center;padding-bottom:24px;margin-bottom:24px;border-bottom:1px solid var(--border-light)}.taxonomy-icon{width:48px;height:48px;background:linear-gradient(135deg,var(--accent),#6366f1);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 12px}.taxonomy-icon i{font-size:20px;color:#fff}.taxonomy-title{font-size:24px;font-weight:700;letter-spacing:-.02em;color:var(--ink)}.taxonomy-count{font-size:13px;color:var(--ink-tertiary);margin-top:6px}.taxonomy-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px}.taxonomy-item{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--surface-raised);border-radius:var(--r-md);border:1px solid var(--border);transition:all .2s}.taxonomy-item:hover{background:var(--accent);border-color:var(--accent);transform:translateY(-1px)}.taxonomy-item:hover .term-name,.taxonomy-item:hover .term-count{color:#fff}.term-name{font-size:13px;font-weight:500;color:var(--ink)}.term-count{font-size:11px;color:var(--ink-tertiary);background:var(--surface);padding:2px 6px;border-radius:8px}.term-page{background:var(--surface);border-radius:var(--r-lg);border:1px solid var(--border);padding:32px 40px;box-shadow:var(--shadow-sm);max-width:800px;margin-left:auto;margin-right:auto}.term-header{margin-bottom:32px;padding-bottom:20px;border-bottom:1px solid var(--border-light)}.term-badge{display:inline-flex;align-items:center;gap:6px;background:var(--accent-bg);color:var(--accent);padding:6px 12px;border-radius:16px;font-size:14px;font-weight:600}.term-desc{font-size:13px;color:var(--ink-tertiary);margin-top:8px}.term-posts{display:flex;flex-direction:column;gap:12px}.archive{background:var(--surface);border-radius:var(--r-lg);border:1px solid var(--border);padding:32px 40px;box-shadow:var(--shadow-sm);max-width:800px;margin-left:auto;margin-right:auto}.archive-header{margin-bottom:32px;padding-bottom:20px;border-bottom:1px solid var(--border-light)}.archive-title{font-size:24px;font-weight:700;letter-spacing:-.02em;color:var(--ink)}.archive-desc{font-size:13px;color:var(--ink-tertiary);margin-top:6px}.archive-list{display:flex;flex-direction:column;gap:24px}.archive-year{position:relative}.year-label{font-size:18px;font-weight:700;color:var(--accent);margin-bottom:12px;letter-spacing:-.01em;display:flex;align-items:baseline;gap:12px}.year-label::after{content:'';flex:1;height:1px;background:linear-gradient(to right,var(--border),transparent)}.year-posts{display:flex;flex-direction:column;gap:4px}.archive-item{display:flex;align-items:center;gap:16px;padding:10px 12px;border-radius:var(--r-md);transition:background .15s}.archive-item:hover{background:var(--surface-raised)}.item-date{font-size:12px;color:var(--ink-tertiary);font-weight:500;font-variant-numeric:tabular-nums;flex-shrink:0;width:36px}.item-title{flex:1;font-size:14px;font-weight:500;color:var(--ink);transition:color .15s}.archive-item:hover .item-title{color:var(--accent)}.item-tags{display:flex;gap:6px;flex-shrink:0}.article{background:var(--surface);border-radius:var(--r-lg);border:1px solid var(--border);padding:48px 56px;min-width:0;width:100%;box-shadow:0 4px 20px rgba(0,0,0,6%)}.about-page{max-width:800px;margin-left:auto;margin-right:auto}.article-header{margin-bottom:48px;padding:24px 0 32px;border-bottom:2px solid var(--border-light);position:relative}.article-header::after{content:'';position:absolute;bottom:-2px;left:0;width:80px;height:2px;background:var(--accent)}.article-date,.article-reading-time,.article-view-count{display:inline-flex;align-items:center;gap:6px;font-size:14px;color:var(--ink-tertiary);font-weight:500}.article-title{font-size:32px;font-weight:700;margin-top:36px;margin-bottom:36px;line-height:1.3;letter-spacing:-.02em;color:var(--ink);text-align:center}.article-tags{display:flex;gap:12px;margin-top:8px;margin-bottom:32px;flex-wrap:wrap;justify-content:center}.article-body{font-size:16px;line-height:1.8;color:var(--ink);letter-spacing:.01em;max-width:none}.article-body h2{font-size:24px;font-weight:600;margin:48px 0 24px;padding-bottom:12px;border-bottom:2px solid var(--border-light);line-height:1.3;letter-spacing:-.02em;color:var(--ink);position:relative}.article-body h2::before{content:'';position:absolute;bottom:-2px;left:0;width:60px;height:2px;background:var(--accent)}.article-body h3{font-size:20px;font-weight:600;margin:36px 0 18px;line-height:1.4;color:var(--ink)}.article-body h4{font-size:18px;font-weight:600;margin:28px 0 14px;color:var(--ink)}.article-body p{margin-bottom:24px;line-height:1.8}.article-body ul,.article-body ol{margin:24px 0;padding-left:28px}.article-body li{margin-bottom:12px;line-height:1.7}.article-body li p{margin-bottom:12px}.article-body strong{font-weight:600;color:var(--ink)}.article-body em{color:var(--ink-secondary);font-style:italic}.article-body blockquote{border-left:4px solid var(--accent);padding:24px 28px;margin:32px 0;background:var(--surface-raised);border-radius:0 var(--r-md)var(--r-md)0;color:var(--ink-secondary);font-size:15px;line-height:1.7;position:relative}.article-body blockquote::before{content:'"';position:absolute;top:8px;left:12px;font-size:32px;color:var(--accent);opacity:.3;font-family:serif}.article-body a{color:var(--accent);text-decoration:none;border-bottom:1px solid transparent;transition:all .2s;padding:2px 0}.article-body a:hover{border-bottom-color:var(--accent);background:var(--accent-light);padding:2px 4px;border-radius:4px}.article-body img{max-width:100%;border-radius:var(--r-lg);margin:32px 0;display:block;box-shadow:0 4px 20px rgba(0,0,0,.1)}.article-body hr{border:none;border-top:2px solid var(--border-light);margin:48px 0;position:relative}.article-body hr::after{content:'***';position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--surface);padding:0 16px;color:var(--ink-tertiary);font-size:14px;letter-spacing:8px}.article-body code{background:var(--surface-raised);color:#e11d48;padding:4px 8px;border-radius:var(--r-sm);font-size:14px;font-family:jetbrains mono,fira code,cascadia code,sf mono,Consolas,monospace;border:1px solid var(--border);font-weight:500}.article-body pre{margin:32px 0;border-radius:var(--r-lg);overflow-x:auto;border:1px solid var(--border);background:#1e293b;position:relative}.article-body pre code{background:0 0;color:#e2e8f0;padding:28px 32px;display:block;font-size:14px;line-height:1.7;border-radius:0;border:none;font-weight:400}.article-body table{width:100%;border-collapse:collapse;margin:32px 0;font-size:14px;border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;box-shadow:0 2px 8px rgba(0,0,0,4%)}.article-body th,.article-body td{padding:16px 20px;border-bottom:1px solid var(--border-light);text-align:left;line-height:1.5}.article-body th{background:var(--surface-raised);font-weight:600;font-size:13px;color:var(--ink-secondary);text-transform:uppercase;letter-spacing:.5px}.article-body tbody tr:hover{background:var(--surface-raised)}.article-body tbody tr:last-child td{border-bottom:none}.toc{margin-bottom:32px;padding:20px 24px;background:var(--surface-raised);border-radius:var(--r-md);border:1px solid var(--border)}.toc-label{font-size:12px;font-weight:600;color:var(--ink-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px;display:flex;align-items:center;gap:6px}.toc ul{list-style:none}.toc li{margin-bottom:4px}.toc a{color:var(--ink-secondary);font-size:13px;display:block;padding:4px 8px;border-radius:var(--r-sm);border:none;transition:all .15s;position:relative}.toc a:hover{background:var(--surface);color:var(--accent)}.toc .toc-h3{padding-left:20px}.toc .toc-h4{padding-left:32px}.toc a.active,.article-toc .toc a.active{background:0 0;color:var(--accent);font-weight:500}.toc a.active::before,.article-toc .toc a.active::before{content:'';position:absolute;left:-8px;top:50%;transform:translateY(-50%);width:4px;height:16px;background:var(--accent);border-radius:2px}.toc a,.article-toc .toc a{position:relative}.site-footer{margin-top:auto;background:var(--surface);border-top:1px solid var(--border);padding:24px}.footer-container{max-width:var(--max-width);margin:0 auto;text-align:center}.footer-text{font-size:12px;color:var(--ink-tertiary);font-weight:400;letter-spacing:.02em}.footer-text a{color:var(--ink-secondary)}.footer-text a:hover{color:var(--accent)}.sidebar::-webkit-scrollbar{width:3px}.sidebar::-webkit-scrollbar-track{background:0 0}.sidebar::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.sidebar::-webkit-scrollbar-thumb:hover{background:var(--ink-tertiary)}@media(max-width:1024px){.layout{grid-template-columns:1fr;padding:calc(var(--nav-height) + 20px)8px 40px;gap:24px}.header-container{padding:0 8px}.sidebar{order:2;position:static;max-height:none}.article-layout{grid-template-columns:1fr;gap:20px}.article-toc{position:static;order:-1;max-height:none}.article-toc .toc{margin-bottom:20px}.hero{grid-column:1;padding:40px 24px 28px;margin-bottom:28px}.hero-title{font-size:28px;margin-top:20px}.hero-desc{font-size:15px;margin-bottom:24px}.contribution-graph{padding:20px;margin-bottom:24px}.graph-header{flex-direction:column;align-items:flex-start;gap:8px}.month-labels{padding-left:20px}.month-label{font-size:9px}.weekday-labels{width:18px}.weekday-label{font-size:8px}.contribution-day{width:12px;height:12px}.contribution-stats{font-size:11px}.post-list{grid-column:1}.pagination{grid-column:1}.article{padding:32px}.article-title{font-size:28px;margin-top:28px;margin-bottom:28px}}@media(max-width:768px){.site-nav{display:none;position:absolute;top:var(--nav-height);left:0;right:0;background:var(--nav-bg);flex-direction:column;padding:20px 16px;gap:16px;border-top:1px solid var(--border);box-shadow:var(--shadow-md)}.site-nav.open{display:flex}.menu-btn{display:block}.layout{padding:calc(var(--nav-height) + 16px)8px 32px;gap:20px}.sidebar{position:fixed;top:var(--nav-height);left:0;bottom:0;width:300px;background:var(--surface);z-index:150;padding:24px 20px;overflow-y:auto;max-height:none;transform:translateX(-100%);transition:transform .3s ease;box-shadow:var(--shadow-lg);border-right:1px solid var(--border);border-radius:0}.sidebar.open{transform:translateX(0);display:block}.article-layout{grid-template-columns:1fr;gap:16px}.article-toc{position:static;order:-1;max-height:none}.article-toc .toc{margin-bottom:20px;padding:16px 18px}.hero{padding:32px 0 8px;margin-bottom:16px}.hero-title{font-size:24px;margin-top:16px}.hero-desc{font-size:14px;margin-bottom:20px}.contribution-graph{padding:16px 12px;margin-bottom:20px;margin-top:16px}.graph-header{flex-direction:column;align-items:flex-start;gap:8px}.graph-title{font-size:13px}.legend-text{font-size:10px}.legend-square{width:8px;height:8px}.month-labels{display:flex;justify-content:space-between;padding-left:12px;margin-left:16px}.graph-grid{display:flex;gap:2px;justify-content:center;width:100%;margin-left:0}.month-label{font-size:8px}.weekday-labels{width:14px;height:120px;justify-content:space-between;padding:10px 0}.weekday-label{font-size:7px;line-height:1.2;text-align:right;display:block;margin:0}.weekday-label{font-size:7px}.contribution-grid{display:grid;grid-template-columns:repeat(53,1fr);grid-template-rows:repeat(7,1fr);gap:1px;grid-auto-flow:column;width:100%;max-width:100%;overflow-x:auto}.contribution-day{width:100%;height:15px;min-width:6px;min-height:6px}.graph-footer{margin-top:16px}.contribution-stats{font-size:11px}.stat-item{font-size:11px}.stat-separator{margin:0 4px}.content-nav{margin-bottom:16px}.nav-tab{margin-right:20px;font-size:14px}.card-link{padding:12px 16px}.card-main{flex-direction:column;gap:12px}.card-thumbnail{width:100%;height:120px;order:-1}.card-title{font-size:15px;margin-top:10px;margin-bottom:10px}.card-excerpt{font-size:12px;margin-bottom:8px;-webkit-line-clamp:1}.card-action{font-size:12px;margin-top:6px}.card-meta{flex-wrap:wrap;gap:6px}.card-stats{gap:8px;margin-left:0;margin-top:4px}.article{padding:24px 16px;margin:0 -4px}.article-title{font-size:24px;margin-top:24px;margin-bottom:24px}.article-body{font-size:15px;line-height:1.7}.article-body h2{font-size:20px;margin:32px 0 16px}.article-body h3{font-size:18px;margin:24px 0 12px}.article-body p{margin-bottom:20px}.article-body ul,.article-body ol{margin:20px 0;padding-left:20px}.article-header{margin-bottom:32px;padding-bottom:20px}.header-container{padding:0 8px}.site-footer{padding:20px 8px}.author-icon{width:60px;height:60px}.author-icon i{font-size:24px}.author-name{font-size:16px}.stats-grid{grid-template-columns:1fr 1fr;gap:8px}.stat-item{padding:12px 8px}.stat-number{font-size:18px}.stat-label{font-size:10px}.year-link,.link-item,.contact-item{padding:6px 10px;font-size:12px}.year-count{font-size:10px}}.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.3);z-index:140;backdrop-filter:blur(2px)}@media(max-width:768px){.sidebar-overlay.open{display:block}}.sidebar::-webkit-scrollbar{width:4px}.sidebar::-webkit-scrollbar-track{background:0 0}.sidebar::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.sidebar::-webkit-scrollbar-thumb:hover{background:var(--ink-tertiary)}::selection{background:var(--accent-light);color:var(--accent)}.page-btn:active{transform:scale(.95)}.article-body img{opacity:0;transition:opacity .3s ease}.article-body img.loaded{opacity:1}.article-body pre{position:relative}.copy-btn{position:absolute;top:8px;right:8px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:#e2e8f0;padding:4px 8px;border-radius:4px;font-size:11px;cursor:pointer;opacity:0;transition:opacity .2s}.article-body pre:hover .copy-btn{opacity:1}.copy-btn:hover{background:rgba(255,255,255,.2)}@media print{.site-header,.sidebar,.pagination,.site-footer{display:none!important}.layout{grid-template-columns:1fr;padding:0}.article{border:none;box-shadow:none;padding:0}.card{break-inside:avoid}}.error-page{display:flex;align-items:center;justify-content:center;min-height:60vh;padding:40px 20px}.error-content{text-align:center;max-width:400px}.error-icon{width:80px;height:80px;background:var(--accent-light);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px}.error-icon i{font-size:36px;color:var(--accent)}.error-title{font-size:72px;font-weight:800;color:var(--accent);margin-bottom:16px;line-height:1}.error-message{font-size:20px;font-weight:600;color:var(--ink);margin-bottom:8px}.error-desc{font-size:14px;color:var(--ink-secondary);margin-bottom:32px;line-height:1.5}.error-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.btn-primary,.btn-secondary{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;border-radius:var(--r-md);font-size:14px;font-weight:500;text-decoration:none;transition:all .2s ease}.btn-primary{background:var(--accent);color:#fff;border:1px solid var(--accent)}.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover);color:#fff;transform:translateY(-1px)}.btn-secondary{background:var(--surface);color:var(--ink-secondary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--surface-hover);color:var(--accent);border-color:var(--accent);transform:translateY(-1px)}@media(max-width:768px){.error-title{font-size:56px}.error-message{font-size:18px}.error-actions{flex-direction:column;align-items:center}.btn-primary,.btn-secondary{width:200px;justify-content:center}}.search-page{max-width:800px;margin:0 auto}.search-header{margin-bottom:32px}.search-title{font-size:24px;font-weight:600;color:var(--ink);margin-bottom:20px;text-align:center}.search-box{position:relative;max-width:500px;margin:0 auto}.search-box input{width:100%;padding:12px 50px 12px 16px;border:2px solid var(--border);border-radius:var(--r-lg);font-size:16px;background:var(--surface);color:var(--ink);transition:border-color .2s ease}.search-box input:focus{outline:none;border-color:var(--accent)}.search-box button{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:var(--accent);border:none;border-radius:var(--r-md);width:36px;height:36px;display:flex;align-items:center;justify-content:center;color:#fff;cursor:pointer;transition:background .2s ease}.search-box button:hover{background:var(--accent-hover)}.search-results{min-height:300px}.search-placeholder,.search-empty{text-align:center;padding:60px 20px;color:var(--ink-tertiary)}.search-placeholder i,.search-empty i{font-size:48px;margin-bottom:16px;display:block}.search-placeholder p,.search-empty p{font-size:16px;margin-bottom:8px}.search-empty small{font-size:14px;opacity:.7}.search-count{font-size:14px;color:var(--ink-secondary);margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid var(--border-light)}.search-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);margin-bottom:16px;transition:all .2s ease}.search-item:hover{border-color:var(--accent);box-shadow:var(--shadow-md);transform:translateY(-1px)}.search-link{display:block;padding:20px 24px;color:inherit;text-decoration:none}.search-item-title{font-size:16px;font-weight:600;color:var(--ink);margin-bottom:8px;line-height:1.4}.search-item:hover .search-item-title{color:var(--accent)}.search-item-summary{font-size:13px;color:var(--ink-secondary);line-height:1.5;margin-bottom:12px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.search-item-meta{display:flex;align-items:center;gap:12px;font-size:12px}.search-item-meta time{color:var(--ink-tertiary)}.search-item-tags{display:flex;gap:6px;flex-wrap:wrap}.search-item-tags .tag{font-size:10px;padding:2px 6px}.search-item mark{background:var(--accent-light);color:var(--accent);padding:2px 4px;border-radius:3px;font-weight:600}[data-theme=dark] .search-item mark{background:var(--accent);color:#fff}@media(max-width:768px){.search-box input{font-size:16px}.search-link{padding:16px 20px}.search-item-title{font-size:15px}.search-item-summary{font-size:12px}}.article-meta{display:flex;align-items:center;gap:8px;margin-top:16px;margin-bottom:24px;flex-wrap:wrap;justify-content:center;font-size:14px;color:var(--ink-tertiary)}.article-author,.article-date,.article-reading-time{display:inline-flex;align-items:center;gap:4px;font-size:14px;color:var(--ink-tertiary);font-weight:500}.article-author i,.article-date i,.article-reading-time i{font-size:14px}.meta-separator{color:var(--ink-light);font-weight:300}.article-footer{margin-top:48px;padding-top:32px;border-top:1px solid var(--border-light)}.article-nav{display:grid;grid-template-columns:1fr 1fr;gap:16px}.nav-prev,.nav-next{display:flex;align-items:center;gap:12px;padding:16px 20px;background:var(--surface-raised);border:1px solid var(--border);border-radius:var(--r-lg);color:var(--ink-secondary);text-decoration:none;transition:all .2s ease}.nav-prev:hover,.nav-next:hover{background:var(--accent-light);border-color:var(--accent);color:var(--accent);transform:translateY(-1px)}.nav-prev{justify-content:flex-start}.nav-next{justify-content:flex-end}.nav-content{display:flex;flex-direction:column;gap:4px}.nav-label{font-size:12px;color:var(--ink-tertiary);font-weight:500}.nav-title{font-size:14px;font-weight:600;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.nav-prev .nav-content{text-align:left}.nav-next .nav-content{text-align:right}.article-nav:has(.nav-prev:only-child){grid-template-columns:1fr}.article-nav:has(.nav-next:only-child){grid-template-columns:1fr}@media(max-width:768px){.article-meta{gap:6px;font-size:13px;flex-direction:column;text-align:center}.article-meta>div{display:flex;align-items:center;gap:6px}.meta-separator{display:none}.article-nav{grid-template-columns:1fr;gap:12px}.nav-prev,.nav-next{padding:12px 16px}.nav-next .nav-content{text-align:left}}@media(max-width:1024px){.toc{position:sticky;top:calc(var(--nav-height) + 20px);margin-bottom:24px}}@media(max-width:768px){.toc{position:static;margin-bottom:20px}.article-toc{display:none}.toc-label{font-size:13px}.toc a{font-size:13px;padding:3px 6px}.toc .toc-h3{padding-left:16px}.toc .toc-h4{padding-left:24px}}.article-body h2,.article-body h3,.article-body h4{scroll-margin-top:calc(var(--nav-height) + 20px)}.loading{opacity:.6;pointer-events:none}.loading::after{content:'';position:absolute;top:50%;left:50%;width:20px;height:20px;margin:-10px 0 0 -10px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.sidebar-block .block-title i{color:var(--accent)}.recent-list a{transition:all .2s ease;padding:4px 0;border-radius:var(--r-sm)}.recent-list a:hover{padding-left:8px;background:var(--surface-hover)}@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}.header-actions{display:flex;align-items:center;gap:8px}.theme-toggle{position:relative;width:36px;height:36px;background:0 0;border:1px solid var(--border);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;color:var(--ink-secondary)}.theme-toggle:hover{background:var(--surface-hover);border-color:var(--accent);color:var(--accent)}.theme-toggle i{font-size:16px;position:absolute;transition:all .3s ease}.dark-icon{opacity:0;transform:rotate(180deg)}[data-theme=dark] .light-icon{opacity:0;transform:rotate(180deg)}[data-theme=dark] .dark-icon{opacity:1;transform:rotate(0)}[data-theme=dark]{--accent:#3b82f6;--accent-hover:#2563eb;--accent-bg:#1e3a8a;--accent-light:#1e40af;--ink:#f8fafc;--ink-secondary:#cbd5e1;--ink-tertiary:#94a3b8;--ink-light:#64748b;--surface:#1e293b;--surface-raised:#0f172a;--surface-hover:#334155;--border:#334155;--border-light:#475569;--nav-bg:#0f172a;--nav-shadow:0 1px 2px 0 rgba(0,0,0,0.3)}[data-theme=dark] body{background:var(--surface-raised)}[data-theme=dark] .article-body code{background:#334155;color:#fbbf24;border-color:#475569}[data-theme=dark] .article-body pre{background:#020617;border-color:#334155}[data-theme=dark] .search-box input{background:var(--surface);border-color:var(--border);color:var(--ink)}[data-theme=dark] .theme-toggle{border-color:var(--border);color:var(--ink-secondary)}[data-theme=dark] .theme-toggle:hover{background:var(--surface-hover);border-color:var(--accent);color:var(--accent)}@media(max-width:768px){.header-actions{gap:4px}.theme-toggle{width:32px;height:32px}.theme-toggle i{font-size:14px}}.card-meta time{background:var(--surface-raised);padding:4px 8px;border-radius:12px;border:1px solid var(--border)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--surface-raised)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--ink-tertiary)}button:focus,input:focus,a:focus{outline:none;box-shadow:none}.article-toc .toc a:focus,.toc a:focus{outline:none!important;box-shadow:none!important}.article-body>*:first-child{margin-top:0}.article-body>*:last-child{margin-bottom:0}.article-body pre[class*=language-]::before{content:attr(class);position:absolute;top:8px;right:50px;background:rgba(255,255,255,.1);color:#e2e8f0;padding:2px 8px;border-radius:4px;font-size:11px;text-transform:uppercase;opacity:.7}.article-body a[href^=http]::after{content:'↗';font-size:12px;margin-left:2px;opacity:.6}.article-body table{display:block;overflow-x:auto;white-space:nowrap}@media(max-width:768px){.article-body table{font-size:12px}.article-body th,.article-body td{padding:8px 12px}}.article-body img{background:var(--surface-raised);transition:opacity .3s ease}.article-body img:not(.loaded){opacity:.3}[data-theme=dark] .hero::before{background:linear-gradient(90deg,var(--accent),#3b82f6)}[data-theme=dark] .feature-item:hover,[data-theme=dark] .stat-box:hover{background:var(--accent);color:#fff}[data-theme=dark] .stat-box:hover .stat-number,[data-theme=dark] .stat-box:hover .stat-text{color:#fff}[data-theme=dark] .hero-btn.primary{background:var(--accent);color:#fff}[data-theme=dark] .hero-btn.secondary:hover{background:var(--accent);color:#fff}[data-theme=dark] .card-meta time{background:var(--surface-hover)}[data-theme=dark] .author-icon{background:0 0;box-shadow:0 4px 16px rgba(59,130,246,.3)}[data-theme=dark] .stat-item:hover{background:var(--accent);color:#fff}[data-theme=dark] .stat-number{color:var(--accent)}[data-theme=dark] .stat-item:hover .stat-number,[data-theme=dark] .stat-item:hover .stat-label{color:#fff}[data-theme=dark] .year-link:hover,[data-theme=dark] .link-item:hover,[data-theme=dark] .contact-item:hover{background:var(--accent);color:#fff}.content-nav{grid-column:1/2;margin-bottom:20px;border-bottom:1px solid var(--border-light);max-width:800px;margin-left:auto;margin-right:auto}.nav-tabs{display:flex;gap:0}.nav-tab{padding:12px 0;margin-right:32px;font-size:16px;font-weight:500;color:var(--ink-secondary);text-decoration:none;position:relative;transition:color .2s ease}.nav-tab:hover{color:var(--ink)}.nav-tab.active{color:var(--ink)}.nav-tab.active::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:2px;background:var(--accent);border-radius:1px}@media(max-width:768px){.nav-tab{margin-right:24px;font-size:15px}}.post-list{box-shadow:0 2px 8px rgba(0,0,0,4%)}.tag{cursor:pointer}.card-stat:hover{color:var(--accent)}.card-thumbnail:hover{background:var(--accent-light);color:var(--accent)}.card-title{word-break:break-word;hyphens:auto}.card-excerpt{word-break:break-word;hyphens:auto}[data-theme=dark] .post-list{box-shadow:0 2px 8px rgba(0,0,0,.2)}[data-theme=dark] .card-thumbnail{background:var(--surface-hover);border-color:var(--border)}@media(max-width:1024px){.card-thumbnail{width:140px;height:90px}.card-main{gap:12px}.card-link{padding:14px 18px}}@media(max-width:480px){.card-meta{font-size:11px}.card-stats{font-size:11px}.tag{font-size:10px;padding:1px 4px}.card-thumbnail{height:100px}}@media(max-width:480px){.contribution-graph{padding:12px 8px;margin:12px -4px 16px}.graph-header{margin-bottom:12px}.graph-title{font-size:12px}.legend-colors{margin:0 2px}.legend-square{width:6px;height:6px}.month-labels{padding-left:8px;margin-bottom:4px}.graph-grid{gap:1px;margin-left:0}.month-label{font-size:7px}.graph-grid{gap:1px}.weekday-labels{width:10px;height:105px;justify-content:space-between;padding:8px 0}.weekday-label{font-size:6px;line-height:1.2;text-align:right;display:block;margin:0}.contribution-grid{gap:1px}.contribution-day{width:100%;height:13px;min-width:4px;min-height:4px}.graph-footer{margin-top:12px}.contribution-stats{font-size:10px;display:flex;flex-direction:row;gap:2px;align-items:center;justify-content:center}.stat-item{font-size:11px;padding:4px 8px}.stat-separator{margin:0 4px;font-size:9px}.card-meta{font-size:11px}.tag{font-size:10px;padding:1px 4px}.card-thumbnail{height:100px}}