.blog-hero{text-align:center;padding:var(--space-16) 0 var(--space-10);background:var(--bg)}.blog-hero h1{font-size:clamp(2.2rem, 4vw, 3.25rem);font-weight:900;letter-spacing:-.035em;color:var(--gray-900);margin-bottom:var(--space-3)}.blog-hero p{font-size:var(--text-lg);color:var(--text-secondary);max-width:560px;margin:0 auto}.blog-wrap{padding-bottom:var(--space-16)}.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6);margin-top:var(--space-8)}.blog-card{display:flex;flex-direction:column;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-xl);overflow:hidden;text-decoration:none;transition:transform .2s,box-shadow .2s,border-color .2s}.blog-card:hover{transform:translateY(-3px);box-shadow:0 12px 32px rgba(0,0,0,.08);border-color:var(--primary-200)}.blog-card-cover{aspect-ratio:16/9;overflow:hidden;background:var(--bg-secondary)}.blog-card-cover img{width:100%;height:100%;object-fit:cover;display:block}.blog-card-cover--empty{display:flex;align-items:center;justify-content:center;color:var(--gray-300);font-size:2.5rem;background:linear-gradient(135deg,var(--primary-50),var(--bg-secondary))}.blog-card-body{padding:var(--space-5);display:flex;flex-direction:column;flex:1}.blog-card-tag{align-self:flex-start;font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--primary);background:var(--primary-50);padding:3px 10px;border-radius:var(--radius-full);margin-bottom:var(--space-3)}.blog-card-title{font-size:var(--text-xl);font-weight:700;color:var(--gray-900);line-height:1.3;margin-bottom:var(--space-2);letter-spacing:-.01em}.blog-card-excerpt{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.6;margin-bottom:var(--space-4);flex:1;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.blog-card-meta{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-xs);color:var(--text-tertiary);margin-top:auto}.blog-card-author{font-weight:600;color:var(--text-secondary)}.blog-card-dot{opacity:.5}.blog-card--featured{flex-direction:row;margin-top:var(--space-8);margin-bottom:var(--space-2)}.blog-card--featured .blog-card-cover{flex:0 0 55%;aspect-ratio:auto}.blog-card--featured .blog-card-body{justify-content:center;padding:var(--space-8)}.blog-card--featured .blog-card-title{font-size:var(--text-3xl)}.blog-card--featured .blog-card-excerpt{font-size:var(--text-base);-webkit-line-clamp:4}.blog-pagination{display:flex;align-items:center;justify-content:center;gap:var(--space-4);margin-top:var(--space-12)}.blog-pagination-info{font-size:var(--text-sm);color:var(--text-tertiary)}.blog-empty{text-align:center;padding:var(--space-16) 0;color:var(--text-tertiary)}.blog-empty i{font-size:3rem;opacity:.3;display:block;margin-bottom:var(--space-4)}.blog-empty h3{color:var(--gray-700);margin-bottom:var(--space-2)}.blog-article{padding:var(--space-12) 0 var(--space-16)}.blog-article-head{max-width:760px;text-align:center}.blog-article-breadcrumb{display:flex;align-items:center;justify-content:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-tertiary);margin-bottom:var(--space-5)}.blog-article-breadcrumb a{color:var(--primary);text-decoration:none}.blog-article-breadcrumb i{font-size:.7em;opacity:.5}.blog-article-title{font-size:clamp(2rem, 4vw, 3rem);font-weight:900;letter-spacing:-.03em;line-height:1.15;color:var(--gray-900);margin-bottom:var(--space-5)}.blog-article-meta{display:flex;align-items:center;justify-content:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-tertiary);margin-bottom:var(--space-4)}.blog-article-author{font-weight:600;color:var(--text-secondary)}.blog-article-tags{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--space-2);margin-bottom:var(--space-6)}.blog-tag-chip{font-size:var(--text-xs);font-weight:500;color:var(--text-secondary);background:var(--bg-secondary);border:1px solid var(--border);padding:4px 12px;border-radius:var(--radius-full)}.blog-article-cover{max-width:900px;margin:var(--space-10) auto}.blog-article-cover img{width:100%;border-radius:var(--radius-xl);display:block}.blog-article-content{max-width:720px;font-size:1.0625rem;line-height:1.8;color:var(--text-secondary)}.blog-article-content h2{font-size:var(--text-2xl);font-weight:800;color:var(--gray-900);margin:var(--space-10) 0 var(--space-4);letter-spacing:-.02em}.blog-article-content h3{font-size:var(--text-xl);font-weight:700;color:var(--gray-900);margin:var(--space-8) 0 var(--space-3)}.blog-article-content p{margin-bottom:var(--space-5)}.blog-article-content a{color:var(--primary);text-decoration:underline}.blog-article-content ol,.blog-article-content ul{margin:0 0 var(--space-5) var(--space-6);padding-left:var(--space-4)}.blog-article-content ul{list-style:disc}.blog-article-content ol{list-style:decimal}.blog-article-content li{margin-bottom:var(--space-2);display:list-item}.blog-article-content li[data-list=bullet]{list-style-type:disc}.blog-article-content li[data-list=ordered]{list-style-type:decimal}.blog-article-content ol:has(li[data-list=bullet]){list-style:none}.blog-article-content img{max-width:100%;border-radius:var(--radius-lg);margin:var(--space-6) 0}.blog-article-content blockquote{border-left:4px solid var(--primary);padding:var(--space-2) var(--space-5);margin:var(--space-6) 0;color:var(--text-secondary);font-style:italic;background:var(--bg-secondary);border-radius:0 var(--radius-md) var(--radius-md) 0}.blog-article-content .ql-syntax,.blog-article-content pre{background:var(--gray-900);color:#e2e8f0;padding:var(--space-4) var(--space-5);border-radius:var(--radius-lg);overflow-x:auto;font-family:var(--font-mono);font-size:var(--text-sm);line-height:1.6;margin:var(--space-6) 0}.blog-article-content code{background:var(--bg-secondary);padding:2px 6px;border-radius:4px;font-family:var(--font-mono);font-size:.9em;color:var(--primary)}.blog-article-content .ql-syntax code,.blog-article-content pre code{background:0 0;padding:0;color:inherit}.blog-article-share{max-width:720px;display:flex;align-items:center;gap:var(--space-4);margin-top:var(--space-10);padding-top:var(--space-6);border-top:1px solid var(--border)}.blog-share-label{font-size:var(--text-sm);font-weight:600;color:var(--text-secondary)}.blog-share-buttons{display:flex;gap:var(--space-2)}.blog-share-btn{position:relative;width:38px;height:38px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg);color:var(--text-secondary);cursor:pointer;text-decoration:none;transition:all .15s}.blog-share-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.blog-copy-tip{position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%) translateY(-4px);background:var(--gray-900);color:#fff;font-size:var(--text-xs);font-weight:500;padding:4px 10px;border-radius:var(--radius-md);white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .15s,transform .15s;z-index:10}.blog-copy-tip::before{content:'';position:absolute;bottom:100%;left:50%;transform:translateX(-50%);border:5px solid transparent;border-bottom-color:var(--gray-900)}.blog-copy-tip.show{opacity:1;transform:translateX(-50%) translateY(0)}.blog-related{background:var(--bg-secondary);padding:var(--space-12) 0 var(--space-16);border-top:1px solid var(--border)}.blog-related-title{font-size:var(--text-2xl);font-weight:800;color:var(--gray-900);margin-bottom:var(--space-2);letter-spacing:-.02em}.blog-related .blog-grid{margin-top:var(--space-6)}.blog-edit-grid{display:grid;grid-template-columns:1fr 320px;gap:var(--space-6);align-items:start}.blog-edit-side{position:sticky;top:var(--space-4)}#quillEditor{min-height:420px;background:var(--bg)}.media-modal{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:9999;display:flex;align-items:center;justify-content:center;padding:var(--space-6)}.media-modal-box{background:var(--bg);border-radius:var(--radius-xl);width:100%;max-width:900px;max-height:85vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.3)}.media-modal-head{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border)}.media-modal-head h3{font-size:var(--text-lg);font-weight:700}.media-modal-toolbar{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border)}.media-toolbar-hint{font-size:var(--text-sm);color:var(--text-tertiary)}.media-upload-status{font-size:var(--text-sm);color:var(--primary);margin-left:auto}.media-dropzone{position:relative;flex:1;overflow-y:auto;min-height:200px}.media-grid{padding:var(--space-5);display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--space-3)}.media-drop-overlay{position:absolute;inset:var(--space-3);border:2px dashed var(--primary);border-radius:var(--radius-lg);background:var(--primary-50);display:none;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-2);color:var(--primary);font-weight:600;font-size:var(--text-lg);pointer-events:none;z-index:5}.media-drop-overlay i{font-size:2.5rem}.media-drop-overlay.active{display:flex}.media-empty{grid-column:1/-1;text-align:center;color:var(--text-tertiary);padding:var(--space-10) 0}.media-item{position:relative;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border);background:var(--bg)}.media-item-pick{width:100%;aspect-ratio:1;padding:0;border:none;background:var(--bg-secondary);cursor:pointer;display:block}.media-item-name{font-size:11px;line-height:1.4;color:var(--text-secondary);padding:6px 8px;border-top:1px solid var(--border);word-break:break-word;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;max-height:calc(1.4em * 2 + 10px)}.media-item-pick img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .2s}.media-item:hover .media-item-pick img{transform:scale(1.05)}.media-item-del{position:absolute;top:6px;right:6px;width:28px;height:28px;border-radius:var(--radius-md);border:none;background:rgba(0,0,0,.6);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;opacity:0;transition:opacity .15s}.media-item:hover .media-item-del{opacity:1}.media-item-del:hover{background:var(--red-500,#ef4444)}.blog-preview-overlay{position:fixed;inset:0;background:var(--bg);z-index:9999}.blog-preview-bar{position:sticky;top:0;display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-6);background:var(--gray-900);color:#fff;z-index:2}.blog-preview-label{font-weight:600;font-size:var(--text-sm);display:flex;align-items:center;gap:var(--space-2)}.blog-preview-bar .btn-ghost{color:#fff}.blog-preview-bar .btn-ghost:hover{background:rgba(255,255,255,.1)}.blog-preview-scroll{height:calc(100vh - 56px);overflow-y:auto}.ql-container.ql-snow,.ql-toolbar.ql-snow{border-color:var(--border)}.ql-toolbar.ql-snow{border-radius:var(--radius-md) var(--radius-md) 0 0}.ql-container.ql-snow{border-radius:0 0 var(--radius-md) var(--radius-md);font-size:var(--text-base)}.ql-container.ql-snow{font-family:var(--font-sans)}.ql-container.ql-snow .ql-editor{font-family:var(--font-sans);font-size:1.0625rem;line-height:1.8;color:var(--text-secondary);min-height:420px;padding:var(--space-6);max-width:720px}.ql-container.ql-snow .ql-editor p{margin:0 0 var(--space-5)}.ql-container.ql-snow .ql-editor h2{font-size:var(--text-2xl);font-weight:800;color:var(--gray-900);margin:var(--space-10) 0 var(--space-4);letter-spacing:-.02em}.ql-container.ql-snow .ql-editor h3{font-size:var(--text-xl);font-weight:700;color:var(--gray-900);margin:var(--space-8) 0 var(--space-3)}.ql-editor a{color:var(--primary);text-decoration:underline}.ql-editor ol,.ql-editor ul{margin:0 0 var(--space-4) var(--space-5);padding-left:var(--space-4)}.ql-editor ul{list-style:disc}.ql-editor ol{list-style:decimal}.ql-editor li{margin-bottom:var(--space-1);display:list-item}.ql-editor li[data-list=bullet]{list-style-type:disc}.ql-editor li[data-list=ordered]{list-style-type:decimal}.ql-editor ol:has(li[data-list=bullet]){list-style:none}.ql-editor blockquote{border-left:4px solid var(--primary);padding:var(--space-2) var(--space-4);margin:var(--space-4) 0;color:var(--text-secondary);font-style:italic;background:var(--bg-secondary);border-radius:0 var(--radius-md) var(--radius-md) 0}.ql-container.ql-snow .ql-editor .ql-syntax,.ql-container.ql-snow .ql-editor pre,.ql-container.ql-snow .ql-editor pre.ql-syntax{background:var(--gray-900);color:#e2e8f0;padding:var(--space-4) var(--space-5);border-radius:var(--radius-lg);overflow-x:auto;font-family:var(--font-mono);font-size:var(--text-sm);line-height:1.6;margin:var(--space-6) 0;white-space:pre-wrap}.ql-editor code{background:var(--bg-secondary);padding:2px 6px;border-radius:4px;font-family:var(--font-mono);font-size:.9em;color:var(--primary)}.ql-editor .ql-syntax code,.ql-editor pre code{background:0 0;padding:0;color:inherit}.ql-editor img{max-width:100%;border-radius:var(--radius-md);margin:var(--space-4) 0}@media (max-width:900px){.blog-grid{grid-template-columns:repeat(2,1fr)}.blog-card--featured{flex-direction:column}.blog-card--featured .blog-card-cover{flex:none;aspect-ratio:16/9}.blog-card--featured .blog-card-title{font-size:var(--text-2xl)}.blog-edit-grid{grid-template-columns:1fr}.blog-edit-side{position:static}}@media (max-width:600px){.blog-grid{grid-template-columns:1fr}}