:root{--bg:#0d1117;--bg2:#161b22;--bg3:#21262d;--bgc:#1c2128;--brd:#30363d;--txt:#e6edf3;--txt2:#8b949e;--txtm:#6e7681;--acc:#58a6ff;--acch:#79b8ff;--accm:#388bfd33;--cs:#a5d6ff;--ck:#ff7b72;--cc:#8b949e;--cf:#d2a8ff;--cn:#79c0ff;--co:#ff7b72;--f1:Inter,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--f2:"JetBrains Mono","Fira Code",Consolas,monospace;--rs:6px;--rm:10px;--tr:150ms ease-out;--tr-theme:300ms ease;--sh:0 1px 8px rgba(0,0,0,0.3);--mw:960px;--nh:64px;--shadow:0 1px 8px rgba(0,0,0,0.3)}:root.light{--bg:#f6f8fa;--bg2:#ffffff;--bg3:#eaeef2;--bgc:#f0f2f5;--brd:#d0d7de;--txt:#24292f;--txt2:#57606a;--txtm:#8c959f;--acc:#0969da;--acch:#0550ae;--accm:#0969da1a;--cs:#0a3069;--ck:#cf222e;--cc:#6e7781;--cf:#8250df;--cn:#0550ae;--co:#cf222e;--sh:0 1px 8px rgba(0,0,0,0.1)}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--txt);font-family:var(--f1);font-size:16px;line-height:1.7;min-height:100vh;transition:background var(--tr-theme),color var(--tr-theme)}a{color:var(--acc);text-decoration:none;transition:color var(--tr)}a:hover{color:var(--acch)}.container{max-width:var(--mw);margin:0 auto;padding:0 24px}.page-wrapper{padding-top:calc(var(--nh) + 48px);padding-bottom:80px;min-height:100vh}.nav{position:fixed;top:0;left:0;right:0;height:var(--nh);background:rgba(13,17,23,.85);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--brd);z-index:100;transition:background var(--tr-theme),border-color var(--tr-theme)}:root.light .nav{background:rgba(246,248,250,.85)}.nav-inner{max-width:960px;margin:0 auto;padding:0 24px;height:100%;display:flex;align-items:center;justify-content:space-between}.nav-logo{font-size:20px;font-weight:700;color:var(--txt);letter-spacing:-.5px;transition:color var(--tr-theme)}.nav-logo span{color:var(--acc)}.nav-links{display:flex;align-items:center;gap:8px;list-style:none}.nav-links a{color:var(--txt2);font-size:14px;font-weight:500;padding:6px 14px;border-radius:var(--rs);transition:color var(--tr),background var(--tr)}.nav-links a.active,.nav-links a:hover{color:var(--txt);background:var(--bg3)}.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px;color:var(--txt);border-radius:var(--rs);transition:color var(--tr-theme),background var(--tr)}.nav-toggle:hover{background:var(--bg3)}.theme-toggle{background:none;border:1px solid var(--brd);cursor:pointer;padding:7px;border-radius:var(--rs);color:var(--txt);display:flex;align-items:center;justify-content:center;transition:border-color var(--tr),color var(--tr),background var(--tr),transform var(--tr)}.theme-toggle:hover{border-color:var(--acc);color:var(--acc);background:var(--accm);transform:scale(1.05)}.theme-toggle svg{display:block;width:18px;height:18px}:root.light .theme-toggle .icon-sun{display:none}:root .theme-toggle .icon-sun,:root.light .theme-toggle .icon-moon{display:block}:root .theme-toggle .icon-moon{display:none}.hero{text-align:center;padding:80px 0 64px;border-bottom:1px solid var(--brd);margin-bottom:48px;transition:border-color var(--tr-theme)}.hero-title{font-size:clamp(32px,6vw,52px);font-weight:800;letter-spacing:-1.5px;line-height:1.1;margin-bottom:16px;background:linear-gradient(135deg,var(--txt) 0,var(--acc) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-subtitle{font-size:18px;color:var(--txt2);max-width:520px;margin:0 auto 32px;line-height:1.6;transition:color var(--tr-theme)}.hero-tags{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.hero-tag{font-size:12px;font-weight:500;padding:4px 12px;border-radius:20px;background:var(--accm);color:var(--acc);border:1px solid rgba(88,166,255,.3);transition:background var(--tr-theme),color var(--tr-theme),border-color var(--tr-theme)}.posts-section-title{font-size:13px;font-weight:600;color:var(--txtm);text-transform:uppercase;letter-spacing:1.2px;margin-bottom:24px;transition:color var(--tr-theme)}.post-list{display:flex;flex-direction:column;gap:16px}.post-card{background:var(--bg2);border:1px solid var(--brd);border-radius:var(--rm);padding:28px 32px;transition:border-color var(--tr),box-shadow var(--tr),transform var(--tr),background var(--tr-theme),border-color var(--tr-theme);cursor:pointer;text-decoration:none;color:inherit;display:block}.post-card:hover{border-color:var(--acc);box-shadow:0 0 0 3px var(--accm),var(--sh);transform:translateY(-2px)}.post-card-meta{display:flex;align-items:center;gap:12px;margin-bottom:12px}.post-date{font-size:13px;color:var(--txtm);transition:color var(--tr-theme)}.post-tag{font-size:11px;font-weight:600;padding:2px 8px;border-radius:4px;background:var(--accm);color:var(--acc);text-transform:uppercase;letter-spacing:.5px;transition:background var(--tr-theme),color var(--tr-theme)}.post-card-title{font-size:20px;font-weight:700;letter-spacing:-.3px;margin-bottom:10px;color:var(--txt);transition:color var(--tr-theme)}.post-card-excerpt{font-size:15px;color:var(--txt2);line-height:1.6;margin-bottom:16px;transition:color var(--tr-theme)}.post-card-footer{gap:16px;font-size:13px;color:var(--txtm);transition:color var(--tr-theme)}.post-card-footer,.post-stat{display:flex;align-items:center}.post-stat{gap:5px}.article-layout{display:grid;grid-template-columns:1fr 220px;gap:48px;align-items:start}.article-header{padding-bottom:40px;border-bottom:1px solid var(--brd);margin-bottom:40px;transition:border-color var(--tr-theme)}.article-back{display:inline-flex;align-items:center;gap:6px;font-size:14px;color:var(--txt2);margin-bottom:32px;transition:color var(--tr)}.article-back:hover{color:var(--acc)}.article-title{font-size:clamp(26px,5vw,38px);font-weight:800;letter-spacing:-1px;line-height:1.2;margin-bottom:20px}.article-meta{flex-wrap:wrap;gap:16px;color:var(--txt2);font-size:14px;transition:color var(--tr-theme)}.article-author,.article-meta{display:flex;align-items:center}.article-author{gap:8px}.author-avatar{width:28px;height:28px;border-radius:50%;background:var(--accm);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--acc);transition:background var(--tr-theme),color var(--tr-theme)}.article-content{font-size:16px;line-height:1.8}.article-content,.article-content h2{color:var(--txt);transition:color var(--tr-theme)}.article-content h2{font-size:24px;font-weight:700;margin:40px 0 16px;letter-spacing:-.3px}.article-content h3{font-size:20px;font-weight:600;margin:32px 0 12px;color:var(--txt);transition:color var(--tr-theme)}.article-content p{margin-bottom:20px}.article-content ol,.article-content ul{margin-bottom:20px;padding-left:24px}.article-content li{margin-bottom:8px}.article-content blockquote{border-left:3px solid var(--acc);padding:12px 20px;margin:24px 0;background:var(--bg2);border-radius:0 var(--rs) var(--rs) 0;color:var(--txt2);font-style:italic;transition:background var(--tr-theme),border-color var(--tr-theme),color var(--tr-theme)}.code-block{position:relative;margin:24px 0;border-radius:var(--rm);overflow:hidden;border:1px solid var(--brd);transition:border-color var(--tr-theme)}.code-block-header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:var(--bg3);border-bottom:1px solid var(--brd);transition:background var(--tr-theme),border-color var(--tr-theme)}.code-lang-badge{font-weight:600;text-transform:uppercase;letter-spacing:.5px;font-family:var(--f2);transition:color var(--tr-theme)}.code-copy-btn,.code-lang-badge{font-size:11px;color:var(--txtm)}.code-copy-btn{background:none;border:1px solid var(--brd);border-radius:4px;padding:3px 10px;cursor:pointer;font-family:var(--f1);transition:all var(--tr)}.code-copy-btn:hover{border-color:var(--acc);color:var(--acc)}.article-content pre,.code-block pre{margin:0;padding:20px;background:var(--bgc);overflow-x:auto;font-family:var(--f2);font-size:14px;line-height:1.65;transition:background var(--tr-theme)}code{font-family:var(--f2);font-size:14px}.article-content code:not(pre code){background:var(--bg3);color:var(--cs);padding:2px 6px;border-radius:4px;font-size:13.5px;border:1px solid var(--brd);transition:background var(--tr-theme),color var(--tr-theme),border-color var(--tr-theme)}.toc-aside{position:sticky;top:calc(var(--nh) + 24px)}.toc-title{font-size:11px;font-weight:600;color:var(--txtm);text-transform:uppercase;letter-spacing:1.2px;margin-bottom:12px;transition:color var(--tr-theme)}.toc-list{list-style:none;border-left:1px solid var(--brd);transition:border-color var(--tr-theme)}.toc-list a{display:block;padding:5px 0 5px 14px;font-size:13px;color:var(--txt2);line-height:1.4;border-left:2px solid transparent;margin-left:-1px;transition:color var(--tr),border-color var(--tr)}.toc-list a.active,.toc-list a:hover{color:var(--acc);border-left-color:var(--acc)}.related-section{margin-top:64px;padding-top:40px;border-top:1px solid var(--brd);transition:border-color var(--tr-theme)}.related-title{font-size:18px;font-weight:700;margin-bottom:24px;color:var(--txt);transition:color var(--tr-theme)}.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.related-card{background:var(--bg2);border:1px solid var(--brd);border-radius:var(--rm);padding:20px;text-decoration:none;color:inherit;display:block;transition:border-color var(--tr),box-shadow var(--tr),transform var(--tr),background var(--tr-theme),border-color var(--tr-theme)}.related-card:hover{border-color:var(--acc);box-shadow:0 0 0 3px var(--accm);transform:translateY(-2px)}.related-card-tag{font-size:10px;font-weight:600;padding:2px 7px;border-radius:4px;background:var(--accm);color:var(--acc);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px;display:inline-block;transition:background var(--tr-theme),color var(--tr-theme)}.related-card-title{font-size:14px;font-weight:600;color:var(--txt);line-height:1.4;margin-bottom:8px;transition:color var(--tr-theme)}.related-card-date{font-size:12px;color:var(--txtm);transition:color var(--tr-theme)}.comments-section{margin-top:64px;padding-top:40px;border-top:1px solid var(--brd);transition:border-color var(--tr-theme)}.comments-title{font-size:20px;font-weight:700;transition:color var(--tr-theme)}.comment-placeholder{background:var(--bg2);border:1px solid var(--brd);border-radius:var(--rm);padding:32px;text-align:center;color:var(--txtm);font-size:14px;transition:background var(--tr-theme),border-color var(--tr-theme),color var(--tr-theme)}.comment-placeholder svg{display:block;margin:0 auto 12px;opacity:.5}.about-header{text-align:center;padding:40px 0 48px}.about-avatar{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--accm),var(--bg3));border:2px solid var(--brd);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;transition:background var(--tr-theme),border-color var(--tr-theme)}.about-name{font-size:28px;font-weight:800;letter-spacing:-.5px;margin-bottom:8px;color:var(--txt)}.about-name,.about-role{transition:color var(--tr-theme)}.about-role{font-size:15px;color:var(--acc);font-weight:500;margin-bottom:20px}.about-bio{font-size:16px;color:var(--txt2);max-width:520px;margin:0 auto 32px;line-height:1.7;transition:color var(--tr-theme)}.about-links{display:flex;justify-content:center;gap:12px;flex-wrap:wrap}.about-link{display:inline-flex;align-items:center;gap:6px;font-size:14px;padding:8px 16px;border-radius:var(--rs);background:var(--bg2);border:1px solid var(--brd);color:var(--txt2);transition:all var(--tr)}.about-link:hover{border-color:var(--acc);color:var(--acc);background:var(--accm)}.about-section{margin-bottom:40px}.about-section-title{font-size:13px;font-weight:600;color:var(--txtm);text-transform:uppercase;letter-spacing:1.2px;margin-bottom:16px;transition:color var(--tr-theme)}.about-section-card{background:var(--bg2);border:1px solid var(--brd);border-radius:var(--rm);padding:24px 28px;transition:background var(--tr-theme),border-color var(--tr-theme)}.about-section-card p{font-size:15px;color:var(--txt2);line-height:1.7;transition:color var(--tr-theme)}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-top:16px}.skill-item{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--bg);border:1px solid var(--brd);border-radius:var(--rs);font-size:14px;color:var(--txt2);transition:background var(--tr-theme),border-color var(--tr-theme),color var(--tr-theme)}.skill-icon{width:18px;height:18px;color:var(--acc);flex-shrink:0;transition:color var(--tr-theme)}.footer{border-top:1px solid var(--brd);padding:32px 0;text-align:center;color:var(--txtm);font-size:13px;transition:border-color var(--tr-theme),color var(--tr-theme)}.footer-inner{max-width:960px;margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}.footer-links{display:flex;gap:20px;list-style:none}.footer-links a{color:var(--txtm);font-size:13px;transition:color var(--tr)}.footer-links a:hover{color:var(--acc)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}@media (max-width:768px){.nav-links{display:none;position:fixed;top:var(--nh);left:0;right:0;background:rgba(13,17,23,.97);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--brd);flex-direction:column;padding:16px;gap:4px}:root.light .nav-links{background:rgba(246,248,250,.97)}.nav-links.open{display:flex}.nav-links a{padding:12px 16px;border-radius:var(--rs)}.nav-toggle{display:flex;align-items:center;justify-content:center}.article-layout{grid-template-columns:1fr}.toc-aside{display:none}.related-grid{grid-template-columns:1fr}.hero{padding:48px 0 40px}.hero-subtitle{font-size:16px}.post-card{padding:20px 24px}.post-card-title{font-size:18px}.post-card-footer{gap:12px}.article-title{font-size:26px}.page-wrapper{padding-top:calc(var(--nh) + 32px)}.about-header{padding:24px 0 32px}.about-name{font-size:24px}.footer-inner{flex-direction:column;text-align:center}}@media (max-width:480px){.container{padding:0 16px}.post-card{padding:16px 20px}.article-meta{gap:10px}.skills-grid{grid-template-columns:1fr}}.tag-cloud{display:flex;flex-wrap:wrap;gap:10px}.tag-cloud-item{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:20px;background:var(--bg2);border:1px solid var(--brd);color:var(--txt2);font-size:13px;font-weight:500;text-decoration:none;transition:background var(--tr),border-color var(--tr),color var(--tr),transform var(--tr)}.tag-cloud-item:hover{background:var(--accm);border-color:var(--acc);color:var(--acc);transform:translateY(-2px)}.tag-cloud-name{color:var(--txt);transition:color var(--tr)}.tag-cloud-item:hover .tag-cloud-name{color:var(--acc)}.tag-cloud-count{font-size:11px;color:var(--txtm);background:var(--bg3);border-radius:10px;padding:1px 7px;transition:background var(--tr),color var(--tr)}.tag-cloud-item:hover .tag-cloud-count{background:var(--accm);color:var(--acc)}.category-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.category-card{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;background:var(--bg2);border:1px solid var(--brd);border-radius:var(--rm);text-decoration:none;color:inherit;transition:border-color var(--tr),box-shadow var(--tr),transform var(--tr),background var(--tr-theme),border-color var(--tr-theme)}.category-card:hover{border-color:var(--acc);box-shadow:0 0 0 3px var(--accm),var(--sh);transform:translateY(-2px)}.category-name{font-size:16px;font-weight:600;color:var(--txt);transition:color var(--tr)}.category-card:hover .category-name{color:var(--acc)}.category-count{font-size:12px;color:var(--txtm);background:var(--bg3);border-radius:10px;padding:2px 8px;transition:background var(--tr),color var(--tr)}.category-card:hover .category-count{background:var(--accm);color:var(--acc)}@media (max-width:768px){.tag-cloud{gap:8px}.tag-cloud-item{padding:5px 12px;font-size:12px}.category-grid{grid-template-columns:1fr 1fr}}@media (max-width:480px){.category-grid{grid-template-columns:1fr}.category-card{padding:16px 20px}}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}html{scroll-behavior:auto}}.comments-section{margin-top:48px;padding-top:32px;border-top:1px solid var(--border)}.comments-title{font-size:1.25rem;font-weight:600;margin-bottom:24px;color:var(--txt)}.comments-count{font-size:.875rem;font-weight:400;color:var(--txt2);margin-left:6px}.comment-form{margin-bottom:32px}.comment-form-row{margin-bottom:12px}.comment-input,.comment-textarea{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--txt);font-size:.9rem;font-family:inherit;transition:border-color .2s;box-sizing:border-box}.comment-input:focus,.comment-textarea:focus{outline:none;border-color:var(--accent,#3b82f6)}.comment-textarea{resize:vertical;min-height:100px}.comment-submit{padding:10px 24px;background:var(--accent,#3b82f6);color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:opacity .2s}.comment-submit:hover{opacity:.85}.comment-submit:disabled{opacity:.5;cursor:not-allowed}.comment-msg{padding:8px 12px;border-radius:6px;font-size:.875rem;margin-bottom:12px}.comment-msg--success{background:rgba(34,197,94,.1);color:#16a34a}.comment-msg--error{background:rgba(239,68,68,.1);color:#dc2626}.comment-empty,.comment-error,.comment-loading{padding:24px;text-align:center;color:var(--txt2);font-size:.9rem}.comment-error{color:#dc2626}.comment-list{display:flex;flex-direction:column;gap:16px}.comment-item{padding:16px;border:1px solid var(--border);border-radius:8px;background:var(--card-bg,var(--bg))}.comment-item-header{display:flex;align-items:center;gap:12px;margin-bottom:8px}.comment-author{font-weight:600;font-size:.9rem;color:var(--txt)}.comment-date{font-size:.8rem;color:var(--txt2)}.comment-content{font-size:.9rem;color:var(--txt);line-height:1.6;white-space:pre-wrap;word-break:break-word;margin:0}