.blog-page{background:#fff;min-height:100vh}.blog-lang-switch{font-size:.85rem;position:relative}.blog-lang-switch summary{cursor:pointer;color:#333;-webkit-user-select:none;user-select:none;border:1px solid #ddd;border-radius:6px;align-items:center;gap:6px;padding:6px 12px;list-style:none;transition:border-color .2s;display:flex}.blog-lang-switch summary::-webkit-details-marker{display:none}.blog-lang-switch summary:hover,.blog-lang-switch[open] summary{border-color:#999}.blog-lang-switch[open] summary svg:last-child{transform:rotate(180deg)}.blog-lang-dropdown{z-index:10;background:#fff;border:1px solid #ddd;border-radius:6px;min-width:100%;margin-top:4px;position:absolute;top:100%;right:0;overflow:hidden;box-shadow:0 2px 8px #00000014}.blog-lang-dropdown a{color:#666;padding:8px 12px;text-decoration:none;transition:background .15s;display:block}.blog-lang-dropdown a:hover{color:#000;background:#f5f5f5}.blog-lang-dropdown a.active{color:#000;font-weight:500}.blog-list-container{max-width:1200px;min-height:calc(100vh - 300px);margin:0 auto;padding:140px 2rem 80px}.blog-list-header{margin-bottom:3rem}.blog-list-label{color:#999;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:.5rem;font-size:.85rem;font-weight:600;display:block}.blog-title-row{justify-content:space-between;align-items:center;gap:1rem;display:flex}.blog-list-header h1{color:#1d1d1f;letter-spacing:-.5px;margin:0;font-size:2.25rem;font-weight:700}.blog-search{max-width:360px;margin-top:1.5rem;position:relative}.blog-search-icon{color:#bbb;pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.blog-search-input{color:#1d1d1f;background:#fff;border:1px solid #e5e5e5;border-radius:8px;outline:none;width:100%;padding:.6rem .75rem .6rem 2.25rem;font-family:inherit;font-size:.9rem;transition:border-color .2s}.blog-search-input::placeholder{color:#bbb}.blog-search-input:focus{border-color:#999}.blog-search-spinner{color:#999;animation:.6s linear infinite blog-spin;position:absolute;top:50%;right:12px;transform:translateY(-50%)}@keyframes blog-spin{0%{transform:translateY(-50%)rotate(0)}to{transform:translateY(-50%)rotate(360deg)}}.blog-empty{text-align:center;color:#999;grid-column:1/-1;padding:3rem 0;font-size:.95rem}.blog-grid{grid-template-columns:repeat(3,1fr);gap:1.5rem;display:grid}.blog-card{color:inherit;border:1px solid #eee;border-radius:12px;flex-direction:column;text-decoration:none;transition:all .3s;display:flex;overflow:hidden}.blog-card:hover{border-color:#ccc}.blog-card-cover{aspect-ratio:16/9;background:linear-gradient(90deg,#f0f0f0 25%,#e8e8e8 50%,#f0f0f0 75%) 0 0/200% 100%;width:100%;animation:1.5s ease-in-out infinite shimmer;overflow:hidden}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.blog-card-cover-placeholder{color:#ccc;background:#f0f0f0;justify-content:center;align-items:center;width:100%;height:100%;display:flex}.blog-card-cover img{object-fit:cover;opacity:0;width:100%;height:100%;transition:opacity .3s,transform .3s}.blog-card-cover img.loaded{opacity:1}.blog-card:hover .blog-card-cover img{transform:scale(1.03)}.blog-card-body{flex-direction:column;flex:1;padding:1.25rem;display:flex}.blog-card-tags{flex-wrap:wrap;gap:.4rem;margin-top:.6rem;display:flex}.blog-tag{color:#666;background:#f5f5f5;border-radius:4px;padding:.15rem .5rem;font-size:.75rem;font-weight:500;display:inline-block}.blog-card-title{color:#1d1d1f;margin:0 0 .4rem;font-size:1.15rem;font-weight:700;line-height:1.35}.blog-card-desc{color:#666;-webkit-line-clamp:3;-webkit-box-orient:vertical;flex:1;margin:0;font-size:.88rem;line-height:1.55;display:-webkit-box;overflow:hidden}.blog-card-meta{border-top:1px solid #f0f0f0;align-items:center;gap:12px;margin-top:1rem;padding-top:.75rem;display:flex}.blog-card-date,.blog-card-reading-time{color:#bbb;align-items:center;gap:5px;font-size:.8rem;display:flex}.blog-post-wrapper{max-width:1100px;margin:0 auto;padding:120px 2rem 80px}.blog-post-wrapper.has-cover{padding-top:2rem}.blog-post-body{align-items:flex-start;gap:2rem;display:flex}.blog-toc{flex-shrink:0;width:220px;max-height:calc(100vh - 140px);position:sticky;top:120px;overflow-y:auto}.blog-toc-inner{border-left:2px solid #eee;padding:1rem 0 1rem 1rem}.blog-toc-title{color:#1d1d1f;text-transform:uppercase;letter-spacing:.03em;margin:0 0 .75rem;font-size:.8rem;font-weight:600}.blog-toc-list{margin:0;padding:0;list-style:none}.blog-toc-list li{margin-bottom:.4rem}.blog-toc-list a{color:#999;padding:2px 0;font-size:.82rem;line-height:1.4;text-decoration:none;transition:color .2s;display:block}.blog-toc-list a:hover{color:#333}.blog-toc-list a.active{color:#1d1d1f;font-weight:500}.blog-post-body .blog-article{flex:1;min-width:0}.blog-post-cover{width:100%;height:360px;position:relative;overflow:hidden}.blog-post-cover-img{object-fit:cover;width:100%;height:100%;display:block}.blog-post-cover:after{content:"";pointer-events:none;background:linear-gradient(#0000,#fff);height:120px;position:absolute;bottom:0;left:0;right:0}.blog-post-header{margin-bottom:2.5rem}.blog-back-link{color:#999;align-items:center;gap:6px;margin-bottom:1.5rem;font-size:.9rem;font-weight:500;text-decoration:none;transition:color .2s;display:inline-flex}.blog-back-link:hover{color:#1d1d1f}.blog-post-lang-hint{color:#666;margin:0 0 1.5rem;font-size:.9rem}.blog-post-lang-hint a{color:#1d1d1f;text-underline-offset:2px;text-decoration:underline}.blog-post-lang-hint a:hover{color:#000}.blog-post-header h1{color:#1d1d1f;letter-spacing:-.5px;margin:0 0 1rem;font-size:2.5rem;font-weight:900;line-height:1.25}.blog-post-info{color:#999;flex-wrap:wrap;align-items:center;gap:.75rem 1.25rem;margin-bottom:1rem;font-size:.9rem;display:flex}.blog-post-author,.blog-post-date,.blog-post-reading-time{align-items:center;gap:5px;display:flex}.blog-author-card{background:#f9f9f9;border:1px solid #e5e5e5;border-radius:12px;align-items:flex-start;gap:1rem;margin-top:3rem;margin-left:calc(220px + 2rem);padding:1.5rem;display:flex}@media (max-width:900px){.blog-author-card{margin-left:0}}.blog-author-avatar{color:#fff;background:#1d1d1f;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;font-size:1.25rem;font-weight:600;display:flex}.blog-author-info{flex-direction:column;gap:.375rem;display:flex}.blog-author-name{color:#1d1d1f;font-size:1rem;font-weight:600}.blog-author-bio{color:#666;margin:0;font-size:.875rem;line-height:1.6}.blog-post-wrapper>.blog-post-updated{color:#888;justify-content:flex-end;align-items:center;gap:5px;margin-top:2rem;font-size:.875rem;display:flex}.blog-post-tags{flex-wrap:wrap;gap:.5rem;display:flex}.blog-article{line-height:1.85}.blog-article h2{color:#1d1d1f;margin:2.5rem 0 1rem;font-size:1.5rem;font-weight:700}.blog-article h2:first-child{margin-top:0}.blog-article h3{color:#1d1d1f;margin:2rem 0 .75rem;font-size:1.15rem;font-weight:600}.blog-article p{color:#333;margin:0 0 1.25rem;font-size:1rem}.blog-article ul,.blog-article ol{margin:0 0 1.25rem;padding-left:1.5rem}.blog-article li{color:#333;margin-bottom:.5rem;font-size:1rem;line-height:1.75}.blog-article strong{color:#1d1d1f;font-weight:600}.blog-article a{color:#1d1d1f;text-underline-offset:3px;-webkit-text-decoration:underline #ccc;text-decoration:underline #ccc;transition:text-decoration-color .2s}.blog-article a:hover{text-decoration-color:#1d1d1f}.blog-article blockquote{color:#555;background:#fafafa;border-left:3px solid #1d1d1f;margin:1.25rem 0;padding:1rem 1.5rem}.blog-article blockquote p:last-child{margin-bottom:0}.blog-article code{background:#f5f5f5;border-radius:4px;padding:2px 6px;font-size:.9em}.blog-article pre{color:#f5f5f7;background:#1d1d1f;border-radius:8px;margin:0 0 1.25rem;padding:1.25rem;overflow-x:auto}.blog-article pre code{color:inherit;background:0 0;padding:0}.blog-article table{-webkit-overflow-scrolling:touch;border-collapse:collapse;max-width:100%;margin:1.5rem 0;font-size:.95rem;display:block;overflow-x:auto}.blog-article th{text-align:left;color:#1d1d1f;white-space:nowrap;border-bottom:2px solid #e5e5e5;padding:10px 12px;font-weight:600}.blog-article td{color:#333;border-bottom:1px solid #f0f0f0;padding:10px 12px}.blog-article tr:last-child td{border-bottom:none}.blog-article tbody tr:hover{background:#fafafa}.blog-article img{cursor:zoom-in;border-radius:8px;max-width:100%;height:auto;margin:1rem 0;transition:opacity .2s}.blog-article img:hover{opacity:.9}.blog-lightbox{z-index:9999;cursor:zoom-out;background:#000000d9;justify-content:center;align-items:center;animation:.2s lightboxFadeIn;display:flex;position:fixed;inset:0}.blog-lightbox img{object-fit:contain;cursor:default;border-radius:8px;max-width:90vw;max-height:90vh}.blog-lightbox-close{color:#fff;cursor:pointer;opacity:.7;background:0 0;border:none;transition:opacity .2s;position:absolute;top:20px;right:20px}.blog-lightbox-close:hover{opacity:1}@keyframes lightboxFadeIn{0%{opacity:0}to{opacity:1}}.blog-article hr{border:none;border-top:1px solid #e5e5e5;margin:2rem 0}@media (max-width:850px){.blog-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.blog-list-container{padding:110px 1.25rem 60px}.blog-list-header{margin-bottom:2rem}.blog-list-header h1{font-size:1.6rem}.blog-search{max-width:none}.blog-grid{grid-template-columns:1fr;gap:1.25rem}.blog-card-body{padding:1.25rem 1rem}.blog-card-title{font-size:1.2rem}.blog-card-desc{font-size:.9rem}.blog-post-wrapper{max-width:800px;padding:90px 1.25rem 60px}.blog-toc{display:none}.blog-post-cover{height:200px}.blog-post-header h1{font-size:1.75rem}.blog-article h2{font-size:1.3rem}.blog-article p,.blog-article li{font-size:.95rem}}
