.blog-section{background:#f8fafc;min-height:60vh;padding:60px 0 80px}.blog-layout{grid-template-columns:240px 1fr;align-items:start;gap:40px;display:grid}.blog-sidebar{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:24px;position:sticky;top:96px;box-shadow:0 1px 3px #0000000a}.blog-sidebar h3{color:#64748b;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid #f1f5f9;margin-bottom:16px;padding-bottom:12px;font-size:.85rem;font-weight:700}.blog-category-list{margin:0;padding:0;list-style:none}.blog-category-list li{margin-bottom:4px}.blog-category-list a{color:#475569;border-radius:10px;justify-content:space-between;align-items:center;padding:8px 12px;font-size:.88rem;font-weight:500;text-decoration:none;transition:all .2s;display:flex}.blog-category-list a:hover{color:#0f172a;background:#f1f5f9}.blog-category-list a.active{color:#dc2626;background:linear-gradient(135deg,#fef2f2,#fff7ed);font-weight:700}.blog-section-title{color:#0f172a;border-bottom:2px solid #e2e8f0;margin-bottom:24px;padding-bottom:12px;font-size:1.2rem;font-weight:700}.blog-loading{color:#94a3b8;justify-content:center;align-items:center;min-height:300px;display:flex}.blog-empty{color:#94a3b8;flex-direction:column;justify-content:center;align-items:center;min-height:300px;font-size:1.1rem;display:flex}.article-grid{grid-template-columns:repeat(auto-fill,minmax(min(100%,300px),1fr));gap:28px;display:grid}.article-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;flex-direction:column;text-decoration:none;transition:all .3s;display:flex;overflow:hidden}.article-card:hover{border-color:#fecaca;transform:translateY(-6px);box-shadow:0 16px 48px #0000001a}.article-card-cover{background:linear-gradient(135deg,#f1f5f9,#e2e8f0);width:100%;height:200px;position:relative;overflow:hidden}.article-card-cover img{object-fit:cover;width:100%;height:100%;transition:transform .4s}.article-card:hover .article-card-cover img{transform:scale(1.05)}.article-card-body{flex-direction:column;flex:1;padding:24px;display:flex}.article-card-body h3{color:#0f172a;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:10px;font-size:1.1rem;font-weight:700;line-height:1.5;display:-webkit-box;overflow:hidden}.article-pin{color:#fff;vertical-align:middle;background:linear-gradient(135deg,#ef4444,#f97316);border-radius:6px;margin-right:6px;padding:2px 8px;font-size:.7rem;font-weight:700;display:inline-block}.article-card-body p{color:#64748b;-webkit-line-clamp:3;-webkit-box-orient:vertical;flex:1;margin-bottom:16px;font-size:.88rem;line-height:1.6;display:-webkit-box;overflow:hidden}.article-card-meta{color:#94a3b8;border-top:1px solid #f1f5f9;flex-wrap:wrap;align-items:center;gap:12px;margin-top:auto;padding-top:16px;font-size:.8rem;display:flex}.article-card-meta span:first-child{color:#dc2626;background:linear-gradient(135deg,#fef2f2,#fff7ed);border-radius:6px;padding:2px 10px;font-size:.75rem;font-weight:600}.article-card-tags{flex-wrap:wrap;gap:6px;margin-top:12px;display:flex}.article-card-tags span{color:#64748b;background:#f1f5f9;border-radius:6px;padding:2px 8px;font-size:.72rem;font-weight:600;transition:all .2s}.article-card:hover .article-card-tags span{background:#e2e8f0}.article-detail{background:#f8fafc;min-height:80vh;padding-top:92px;padding-bottom:80px}.article-layout{grid-template-columns:1fr 240px;align-items:start;gap:40px;margin-top:24px;display:grid}.article-content{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:48px;box-shadow:0 1px 3px #0000000a}.article-content h1{color:#0f172a;margin-bottom:16px;font-size:2rem;font-weight:900;line-height:1.4}.article-meta{color:#94a3b8;border-bottom:1px solid #e2e8f0;flex-wrap:wrap;align-items:center;gap:16px;margin-bottom:24px;padding-bottom:24px;font-size:.85rem;display:flex}.article-meta a{color:#dc2626;background:linear-gradient(135deg,#fef2f2,#fff7ed);border-radius:6px;padding:2px 10px;font-size:.78rem;font-weight:600;text-decoration:none}.article-meta a:hover{opacity:.8}.article-cover{border-radius:12px;width:100%;margin-bottom:32px}.article-body{color:#334155;word-break:break-word;overflow-wrap:break-word;font-size:1rem;line-height:1.8}.article-body h1{color:#0f172a;border-bottom:1px solid #e2e8f0;margin:2em 0 .8em;padding-bottom:.3em;font-size:1.75rem;font-weight:800;line-height:1.4}.article-body h2{color:#0f172a;border-bottom:1px solid #f1f5f9;margin:1.8em 0 .6em;padding-bottom:.25em;font-size:1.5rem;font-weight:700;line-height:1.4}.article-body h3{color:#1e293b;margin:1.5em 0 .5em;font-size:1.25rem;font-weight:700;line-height:1.5}.article-body h4{color:#1e293b;margin:1.4em 0 .4em;font-size:1.1rem;font-weight:600;line-height:1.5}.article-body h5,.article-body h6{color:#334155;margin:1.2em 0 .4em;font-size:1rem;font-weight:600}.article-body h1:first-child,.article-body h2:first-child,.article-body h3:first-child{margin-top:0}.article-body h1 a,.article-body h2 a,.article-body h3 a,.article-body h4 a,.article-body h5 a,.article-body h6 a{color:inherit;text-decoration:none}.article-body h1 a:hover,.article-body h2 a:hover,.article-body h3 a:hover,.article-body h4 a:hover{color:#3b82f6}.article-body p{margin:0 0 1.2em}.article-body a:not(.dl-btn){color:#3b82f6;border-bottom:1px solid #0000;text-decoration:none;transition:color .2s,border-color .2s}.article-body a:not(.dl-btn):hover{color:#2563eb;border-bottom-color:#2563eb}.article-body ul,.article-body ol{margin:0 0 1.2em;padding-left:2em}.article-body ul{list-style-type:disc}.article-body ol{list-style-type:decimal}.article-body li{margin-bottom:.4em}.article-body li>ul,.article-body li>ol{margin-top:.4em;margin-bottom:0}.article-body ul ul{list-style-type:circle}.article-body ul ul ul{list-style-type:square}.article-body blockquote{color:#475569;background:#f8fafc;border-left:4px solid #3b82f6;border-radius:0 8px 8px 0;margin:1.2em 0;padding:12px 20px}.article-body blockquote p:last-child{margin-bottom:0}.article-body :not(pre)>code{color:#e11d48;word-break:break-word;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:4px;padding:2px 6px;font-family:Geist Mono,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.875em}.article-body pre{background:#1e293b;border:1px solid #334155;border-radius:8px;margin:1.2em 0;padding:16px 20px;font-size:.875rem;line-height:1.7;overflow-x:auto}.article-body pre code{font-size:inherit;color:#e2e8f0;background:0 0;border:none;border-radius:0;padding:0;font-family:Geist Mono,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}.article-body .hljs-comment,.article-body .hljs-quote{color:#7c8594;font-style:italic}.article-body .hljs-keyword,.article-body .hljs-selector-tag,.article-body .hljs-type{color:#c678dd}.article-body .hljs-string,.article-body .hljs-template-variable,.article-body .hljs-addition{color:#98c379}.article-body .hljs-number,.article-body .hljs-literal,.article-body .hljs-variable{color:#d19a66}.article-body .hljs-regexp,.article-body .hljs-link{color:#56b6c2}.article-body .hljs-title,.article-body .hljs-function .hljs-title{color:#61afef}.article-body .hljs-attr,.article-body .hljs-attribute{color:#d19a66}.article-body .hljs-built_in,.article-body .hljs-builtin-name{color:#e6c07b}.article-body .hljs-tag,.article-body .hljs-name{color:#e06c75}.article-body .hljs-selector-id,.article-body .hljs-selector-class{color:#61afef}.article-body .hljs-symbol,.article-body .hljs-bullet{color:#56b6c2}.article-body .hljs-meta{color:#61afef}.article-body .hljs-deletion{color:#e06c75}.article-body .hljs-emphasis{font-style:italic}.article-body .hljs-strong{font-weight:700}.article-body table{border-collapse:collapse;width:100%;margin:1.2em 0;font-size:.92em;display:block;overflow-x:auto}.article-body thead{background:#f8fafc}.article-body th{color:#1e293b;text-align:left;white-space:nowrap;border:1px solid #e2e8f0;padding:10px 14px;font-weight:600}.article-body td{color:#475569;border:1px solid #e2e8f0;padding:10px 14px}.article-body tbody tr:hover{background:#f8fafc}.article-body hr{border:none;border-top:1px solid #e2e8f0;margin:2em 0}.article-body img{border-radius:8px;max-width:100%;height:auto;margin:1.2em 0}.article-body strong{color:#0f172a;font-weight:700}.article-body ul.contains-task-list{padding-left:0;list-style:none}.article-body .task-list-item{align-items:flex-start;gap:8px;display:flex}.article-body .task-list-item input[type=checkbox]{accent-color:#3b82f6;margin-top:.35em}.dl-btn-wrapper{text-align:center;margin:24px 0}.dl-btn{--dl-bg:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%);--dl-text:#fff;--dl-radius:12px;--dl-font-size:.95rem;--dl-border:none;background:var(--dl-bg);border-radius:var(--dl-radius);font-size:var(--dl-font-size);border:var(--dl-border);align-items:center;gap:12px;padding:14px 32px;font-weight:600;transition:transform .5s cubic-bezier(.34,1.56,.64,1),box-shadow .5s cubic-bezier(.22,1,.36,1);display:inline-flex;position:relative;overflow:hidden;box-shadow:0 4px 14px #00000026;color:var(--dl-text)!important;text-decoration:none!important}.dl-btn:hover{transform:translateY(-6px);box-shadow:0 12px 28px #00000038}.dl-btn:active{transition:transform .15s,box-shadow .15s;transform:translateY(-1px);box-shadow:0 2px 8px #00000026}.dl-btn:before{content:"";background:linear-gradient(90deg,#0000,#ffffff2e,#0000);width:100%;height:100%;transition:left .7s cubic-bezier(.22,1,.36,1);position:absolute;top:0;left:-100%}.dl-btn:hover:before{left:100%}.dl-btn-icon{flex-shrink:0}.dl-btn-content{text-align:left;flex-direction:column;display:flex}.dl-btn-text{line-height:1.3}.dl-btn-meta{opacity:.75;font-size:.75rem;font-weight:400;line-height:1.3}.article-tags{border-top:1px solid #e2e8f0;flex-wrap:wrap;gap:8px;margin-top:32px;padding-top:24px;display:flex}.article-tags a{color:#64748b;background:#f1f5f9;border-radius:8px;padding:4px 14px;font-size:.82rem;font-weight:600;text-decoration:none;transition:all .2s;display:inline-block}.article-tags a:hover{color:#ef4444;background:#e2e8f0}.article-breadcrumb{color:#94a3b8;z-index:10;background:#f8fafc;border-bottom:1px solid #e2e8f0;align-items:center;gap:8px;margin-bottom:0;padding:12px 0;font-size:.85rem;display:flex;position:sticky;top:72px}.article-breadcrumb a{color:#64748b;text-decoration:none;transition:color .2s}.article-breadcrumb a:hover{color:#ef4444}.article-breadcrumb span{color:#cbd5e1}.article-breadcrumb span:last-child{color:#334155;font-weight:500}.article-body h1[id],.article-body h2[id],.article-body h3[id],.article-body h4[id],.article-body h5[id],.article-body h6[id]{scroll-margin-top:140px}.article-toc{flex-direction:column;gap:16px;max-height:calc(100vh - 160px);display:flex;position:sticky;top:140px}.article-toc-inner{background:#fff;border:1px solid #e2e8f0;border-radius:12px;flex-direction:column;min-height:0;padding:14px 16px;display:flex;overflow:hidden;box-shadow:0 1px 3px #0000000a}.article-toc-inner h3{color:#64748b;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid #f1f5f9;flex-shrink:0;margin-bottom:8px;padding-bottom:8px;font-size:.78rem;font-weight:700}.article-toc-inner nav{scrollbar-width:thin;scrollbar-color:#e2e8f0 transparent;flex-direction:column;gap:0;max-height:40vh;display:flex;overflow-y:auto}.article-toc-inner nav::-webkit-scrollbar{width:3px}.article-toc-inner nav::-webkit-scrollbar-thumb{background:#e2e8f0;border-radius:3px}.article-toc-inner a{color:#64748b;border-left:2px solid #0000;border-radius:4px;padding:3px 8px;font-size:.78rem;line-height:1.6;text-decoration:none;transition:all .2s;display:block}.article-toc-inner a:hover{color:#ef4444;background:#fef2f2;border-left-color:#ef4444}.article-toc-inner a.toc-h3{padding-left:18px;font-size:.74rem}.article-related{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:14px 16px;box-shadow:0 1px 3px #0000000a}.article-related h3{color:#64748b;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid #f1f5f9;margin-bottom:10px;padding-bottom:8px;font-size:.78rem;font-weight:700}.article-related-list{flex-direction:column;gap:4px;display:flex}.article-related-item{border:1px solid #0000;border-radius:6px;padding:8px 10px;text-decoration:none;transition:all .2s;display:block}.article-related-item:hover{background:#f8fafc;border-color:#e2e8f0}.article-related-item h4{color:#1e293b;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0 0 2px;font-size:.8rem;font-weight:600;line-height:1.5;display:-webkit-box;overflow:hidden}.article-related-item:hover h4{color:#ef4444}.article-related-item-meta{color:#94a3b8;align-items:center;gap:6px;font-size:.7rem;display:flex}.article-related-item-meta .article-related-pin{color:#ef4444;font-size:.68rem;font-weight:600}.article-related-empty{text-align:center;color:#cbd5e1;padding:16px 0;font-size:.8rem}.pagination{justify-content:center;align-items:center;gap:12px;margin-top:48px;display:flex}.pagination-btn{color:#475569;background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:10px 24px;font-size:.88rem;font-weight:600;text-decoration:none;transition:all .2s}.pagination-btn:hover{color:#ef4444;background:#fef2f2;border-color:#ef4444}.pagination-info{color:#94a3b8;font-size:.85rem;font-weight:500}.article-related-inline{border-top:1px solid #e2e8f0;margin-top:40px;padding-top:32px;display:none}.article-related-inline h3{color:#64748b;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid #f1f5f9;margin-bottom:12px;padding-bottom:8px;font-size:.85rem;font-weight:700}.mobile-toc-btn{z-index:90;color:#475569;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;display:none;position:fixed;top:50%;left:16px;transform:translateY(-50%);box-shadow:0 4px 16px #0000001f}.mobile-back-to-top{color:#fff;cursor:pointer;opacity:0;pointer-events:none;z-index:90;background:linear-gradient(135deg,#ef4444,#f97316);border:none;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;transition:all .3s;display:none;position:fixed;bottom:24px;right:24px;box-shadow:0 4px 16px #ef44444d}.mobile-back-to-top.visible{opacity:1;pointer-events:auto}.mobile-toc-mask{z-index:91;opacity:0;pointer-events:none;background:#0006;transition:opacity .3s;position:fixed;inset:0}.mobile-toc-mask.visible{opacity:1;pointer-events:auto}.mobile-toc-panel{z-index:92;width:280px;max-width:80vw;height:100dvh;box-shadow:none;background:#fff;flex-direction:column;transition:transform .3s cubic-bezier(.4,0,.2,1),box-shadow .3s;display:flex;position:fixed;top:0;left:0;overflow:hidden;transform:translate(-100%)}.mobile-toc-panel.open{transform:translate(0);box-shadow:4px 0 24px #0000001f}.mobile-toc-header{color:#0f172a;border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding:16px 20px;font-size:.9rem;font-weight:700;display:flex}.mobile-toc-header button{color:#94a3b8;cursor:pointer;background:0 0;border:none;padding:4px 8px;font-size:1.1rem}.mobile-toc-nav{flex-direction:column;gap:2px;padding:12px 20px 24px;display:flex;overflow-y:auto}.mobile-toc-nav a{color:#475569;border-left:2px solid #0000;border-radius:8px;padding:8px 10px;font-size:.85rem;text-decoration:none;transition:all .2s;display:block}.mobile-toc-nav a:active{color:#ef4444;background:#fef2f2;border-left-color:#ef4444}.mobile-toc-nav a.toc-h3{color:#64748b;padding-left:24px;font-size:.8rem}@media (max-width:1024px){.blog-layout{grid-template-columns:1fr}.blog-sidebar{flex-wrap:wrap;align-items:center;gap:8px;display:flex;position:static}.blog-sidebar h3{width:100%;margin-bottom:8px;padding-bottom:8px}.blog-category-list{flex-wrap:wrap;gap:6px;display:flex}.blog-category-list li{margin-bottom:0}.blog-category-list a{padding:6px 14px}.article-layout{grid-template-columns:1fr}.article-toc{flex-flow:wrap;order:-1;gap:16px;max-height:none;position:static}.article-toc-inner,.article-related{flex:1;min-width:280px}.article-related-list{flex-flow:wrap;gap:8px}.article-related-item{flex:1;min-width:200px}}@media (max-width:768px){.blog-section{padding:40px 0 60px}.article-grid{grid-template-columns:1fr;gap:20px}.article-content{padding:28px 20px}.article-content h1{font-size:1.5rem}.article-toc-inner,.article-related{min-width:0}.article-body th{white-space:normal;padding:8px 10px;font-size:.8rem}.article-body td{padding:8px 10px;font-size:.8rem}.article-toc{display:none}.mobile-toc-btn,.mobile-back-to-top{display:flex}.article-related-inline{display:block}.article-related-sidebar{display:none}.article-breadcrumb{flex-wrap:nowrap;padding:10px 16px;font-size:.8rem;overflow:hidden}.article-breadcrumb a,.article-breadcrumb>span:not(:last-child){white-space:nowrap;flex-shrink:0}.article-breadcrumb>span:last-child{white-space:nowrap;text-overflow:ellipsis;min-width:0;overflow:hidden}}@media (max-width:480px){.blog-section{padding:28px 0 40px}.blog-sidebar{padding:16px}.blog-category-list a{padding:5px 10px;font-size:.82rem}.article-content{padding:20px 16px}.article-content h1{font-size:1.3rem}.article-card-body h3{font-size:1rem}.article-card-body p{-webkit-line-clamp:2;font-size:.82rem}.article-cover{border-radius:8px;margin-bottom:24px}}
