.blog-header{background:#fff;border-bottom:1px solid var(--border-color,#e5e7eb);padding:16px 0}.blog-nav{display:flex;justify-content:space-between;align-items:center}.blog-logo{font-size:20px;font-weight:700;color:var(--primary-color,#4f46e5);text-decoration:none}.blog-nav-links{display:flex;gap:24px}.blog-nav-links a{color:var(--text-color,#374151);text-decoration:none;font-weight:500;transition:color .2s}.blog-nav-links a.active,.blog-nav-links a:hover{color:var(--primary-color,#4f46e5)}.blog-main{max-width:800px;margin:0 auto;padding:40px 20px;min-height:calc(100vh - 200px)}.blog-footer{background:var(--bg-secondary,#f9fafb);padding:24px 0;text-align:center;border-top:1px solid var(--border-color,#e5e7eb);margin-top:60px}.blog-footer p{color:var(--text-light,#6b7280);font-size:14px;margin:4px 0}.blog-footer a{color:var(--primary-color,#4f46e5);text-decoration:none}.blog-index-title{font-size:36px;font-weight:800;margin-bottom:12px;color:var(--text-color,#111827)}.blog-index-subtitle{font-size:18px;color:var(--text-light,#6b7280);margin-bottom:48px}.post-list{display:flex;flex-direction:column;gap:32px}.post-card{padding:24px;border:1px solid var(--border-color,#e5e7eb);border-radius:12px;transition:box-shadow .2s,border-color .2s;text-decoration:none;color:inherit;background:#fff}.post-card:hover{box-shadow:0 4px 12px rgba(0,0,0,.08);border-color:var(--primary-color,#4f46e5)}.post-card-title{font-size:22px;font-weight:700;margin-bottom:8px;color:var(--text-color,#111827)}.post-card-date{font-size:14px;color:var(--text-light,#6b7280);margin-bottom:12px}.post-card-excerpt{font-size:16px;color:var(--text-light,#6b7280);line-height:1.6}.post-header{margin-bottom:40px}.post-title{font-size:36px;font-weight:800;margin-bottom:12px;color:var(--text-color,#111827);line-height:1.3}.post-meta{display:flex;gap:16px;align-items:center;font-size:14px;color:var(--text-light,#6b7280)}.post-content{line-height:1.8;font-size:17px}.post-content h1{font-size:28px;font-weight:700;margin:40px 0 16px}.post-content h2{font-size:24px;font-weight:700;margin:32px 0 12px}.post-content h3{font-size:20px;font-weight:600;margin:24px 0 8px}.post-content p{margin-bottom:16px}.post-content pre{background:#000;color:#fff;padding:24px;border-radius:8px;overflow-x:auto;margin:24px 0;font-size:16px;line-height:1.9;box-shadow:0 4px 12px rgba(0,0,0,.3);border:2px solid #404040;font-family:Fira Code,Consolas,Monaco,Courier New,monospace;letter-spacing:.5px;font-weight:500}.post-content pre code{background:none;padding:0;color:inherit;font-family:inherit;font-size:inherit}.post-content :not(pre)>code{background:#f3f4f6;padding:2px 6px;border-radius:4px;font-size:14px;font-family:Fira Code,Consolas,monospace;color:#e11d48}.post-content pre .keyword{color:#ff7b72;font-weight:600}.post-content pre .string{color:#a5d6ff}.post-content pre .number{color:#79c0ff}.post-content pre .comment{color:#8b949e;font-style:italic}.post-content pre .function{color:#d2a8ff}.post-content pre .operator{color:#79c0ff}.post-content pre .property{color:#7ee787}.post-content pre .boolean{color:#ff7b72}.post-content ol,.post-content ul{margin:16px 0;padding-left:24px}.post-content li{margin-bottom:8px}.post-content blockquote{border-left:4px solid var(--primary-color,#4f46e5);padding:12px 20px;margin:20px 0;background:var(--bg-secondary,#f9fafb);border-radius:0 8px 8px 0}.post-content img{max-width:100%;border-radius:8px;margin:20px 0}.post-content a{color:#3b82f6;text-decoration:underline;font-weight:500;transition:color .2s}.post-content a:hover{color:#2563eb;text-decoration:underline}.post-back-link{display:inline-flex;align-items:center;gap:6px;color:var(--primary-color,#4f46e5);text-decoration:none;font-weight:500;margin-bottom:32px}.post-back-link:hover{text-decoration:underline}.cookie-consent-banner{position:fixed;bottom:0;left:0;right:0;z-index:9999;background:#1f2937;color:#f9fafb;box-shadow:0 -4px 24px rgba(0,0,0,.25);animation:cookie-slide-up .35s ease-out}@keyframes cookie-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.cookie-consent-content{max-width:1200px;margin:0 auto;padding:16px 24px;display:flex;align-items:center;gap:24px;flex-wrap:wrap;justify-content:space-between}.cookie-consent-text{flex:1 1 400px;margin:0;font-size:14px;line-height:1.6;color:#d1d5db}.cookie-consent-link{color:#93c5fd;text-decoration:underline;white-space:nowrap}.cookie-consent-link:hover{color:#bfdbfe}.cookie-consent-actions{display:flex;gap:12px;flex-shrink:0}.cookie-consent-btn{padding:10px 24px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:opacity .15s,transform .1s}.cookie-consent-btn:active{transform:scale(.97)}.cookie-consent-btn-reject{background:#374151;color:#d1d5db;border:1px solid #4b5563}.cookie-consent-btn-reject:hover{background:#4b5563;color:#f9fafb}.cookie-consent-btn-lang{background:transparent;color:#9ca3af;border:1px solid #4b5563;padding:10px 16px}.cookie-consent-btn-lang:hover{background:#374151;color:#d1d5db}.cookie-consent-btn-accept{background:#4f46e5;color:#fff}.cookie-consent-btn-accept:hover{background:#4338ca}@media (max-width:640px){.cookie-consent-content{flex-direction:column;align-items:stretch;gap:12px;padding:14px 16px}.cookie-consent-text{flex:none;font-size:13px}.cookie-consent-actions{justify-content:stretch}.cookie-consent-actions .cookie-consent-btn{flex:1 1;text-align:center}}