.flex-1{background:var(--color-bg-primary);border-radius:12px;box-shadow:var(--shadow-md);overflow:hidden;position:relative}.flex-1::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient( 90deg,var(--color-primary-light),var(--color-primary-dark),var(--color-primary-light) );z-index:1}.flex-1 h1{font-size:2.5rem;font-weight:700;color:var(--color-text-primary);margin:2rem 0 1rem;line-height:1.2;position:relative}.flex-1 h2{position:relative;padding-left:1.5rem;margin:2rem 0 1rem}.flex-1 h2::before{content:'';position:absolute;left:0;top:.5rem;width:4px;height:1.5rem;background:var(--color-primary);border-radius:2px}.flex-1 h2::after{content:'';position:absolute;bottom:-.5rem;left:1.5rem;right:0;height:2px;background:linear-gradient(90deg,var(--color-primary),transparent)}.flex-1 h3{color:var(--color-text-secondary);font-weight:600;margin:1.5rem 0 .75rem;position:relative}.flex-1 ul,.flex-1 ol{margin:1.25rem 0;padding-left:1.5rem}.flex-1 li{margin-bottom:.5rem;line-height:1.7;color:var(--color-text-secondary)}.flex-1 li::marker{color:var(--color-primary);font-weight:700}.flex-1 h2:last-of-type{margin-top:3rem;margin-bottom:1.5rem;font-size:1.5rem;font-weight:700;color:var(--color-text-primary);border-bottom:none;padding-left:0}.flex-1 h2:last-of-type::before,.flex-1 h2:last-of-type::after{display:none}.dark .flex-1{background:var(--color-dark-bg-primary);color:var(--color-dark-text-primary)}.dark .flex-1 h1{color:var(--color-dark-text-primary)}.dark .flex-1 h2{color:var(--color-dark-text-secondary)}.dark .flex-1 h3{color:var(--color-dark-text-secondary)}@media screen and (max-width:768px){.flex-1 h1{font-size:2rem}.flex-1 h2{font-size:1.5rem;padding-left:1rem}.flex-1 h2::before{width:3px;height:1.25rem}.flex-1 h2::after{left:1rem}}.post-content a{border-bottom:2px solid #06c!important;padding-bottom:1px!important;transition:all .2s ease!important;font-weight:500!important;position:relative!important}.dark .post-content a{color:#4a9eff!important;border-bottom-color:#4a9eff!important}.post-content a:hover{color:#049!important;border-bottom-color:#049!important;background-color:rgba(0,102,204,.1)!important;padding:2px 4px!important;margin:-2px -4px!important;border-radius:4px!important;text-decoration:none!important}.dark .post-content a:hover{color:#66b3ff!important;border-bottom-color:#66b3ff!important;background-color:rgba(74,158,255,.15)!important}.post-content a[href^=http]:not([href*="hobbytp.github.io"]){position:relative!important}.post-content a[href^=http]:not([href*="hobbytp.github.io"])::after{content:"↗"!important;font-size:.8em!important;margin-left:.3em!important;opacity:.7!important;transition:opacity .2s ease!important}.post-content a[href^=http]:not([href*="hobbytp.github.io"]):hover::after{opacity:1!important}.post-content a[href^="/"],.post-content a[href^="#"]{color:#06c!important;border-bottom:2px solid #06c!important}.dark .post-content a[href^="/"],.dark .post-content a[href^="#"]{color:#4a9eff!important;border-bottom-color:#4a9eff!important}.post-content h1 a,.post-content h2 a,.post-content h3 a,.post-content h4 a,.post-content h5 a,.post-content h6 a{color:inherit!important;border-bottom:2px solid!important;opacity:.8!important;transition:opacity .2s ease!important}.post-content h1 a:hover,.post-content h2 a:hover,.post-content h3 a:hover,.post-content h4 a:hover,.post-content h5 a:hover,.post-content h6 a:hover{opacity:1!important;background-color:initial!important;padding:0!important;margin:0!important}.post-content ul a,.post-content ol a{color:#06c!important;border-bottom:1px solid #06c!important;padding-bottom:.5px!important}.dark .post-content ul a,.dark .post-content ol a{color:#4a9eff!important;border-bottom-color:#4a9eff!important}.post-content blockquote a{color:#06c!important;border-bottom:1px dashed #06c!important;opacity:.9!important}.dark .post-content blockquote a{color:#4a9eff!important;border-bottom-color:#4a9eff!important}.post-content code a,.post-content pre a{color:#06c!important;border-bottom:1px solid #06c!important;background-color:rgba(0,102,204,.1)!important;padding:1px 3px!important;border-radius:2px!important}.dark .post-content code a,.dark .post-content pre a{color:#4a9eff!important;border-bottom-color:#4a9eff!important;background-color:rgba(74,158,255,.15)!important}.post-content a[href*="youtube.com"],.post-content a[href*="youtu.be"]{color:red!important;border-bottom-color:red!important}.post-content a[href*="github.com"]{color:#333!important;border-bottom-color:#333!important}.dark .post-content a[href*="github.com"]{color:#f0f6fc!important;border-bottom-color:#f0f6fc!important}.post-content a[href*="arxiv.org"]{color:#b31b1b!important;border-bottom-color:#b31b1b!important}@media screen and (max-width:768px){.post-content a{border-bottom-width:1px!important;padding-bottom:.5px!important}.post-content a:hover{padding:1px 2px!important;margin:-1px -2px!important}}article h1,.max-w-4xl h1,.flex-1 h1{font-size:2.5rem!important;font-weight:700!important;color:#1e40af!important;margin:2.5rem 0 1.5rem!important;padding-bottom:.5rem!important;border-bottom:3px solid #1e40af!important;line-height:1.2!important}article h2:not(.article-card-title),.max-w-4xl h2:not(.article-card-title),.flex-1 h2:not(.article-card-title){font-size:2rem!important;font-weight:600!important;color:#1e40af!important;margin:2rem 0 1rem!important;padding:.75rem 0 .75rem 1rem!important;border-left:4px solid #1e40af!important;background:linear-gradient(90deg,rgba(30,64,175,.1),transparent)!important;border-radius:0 8px 8px 0!important;line-height:1.3!important}article h3,.max-w-4xl h3,.flex-1 h3{font-size:1.5rem!important;font-weight:600!important;color:#374151!important;margin:1.5rem 0 .75rem!important;padding-bottom:.25rem!important;border-bottom:2px solid #e5e7eb!important;line-height:1.4!important}article h4,.max-w-4xl h4,.flex-1 h4{font-size:1.25rem!important;font-weight:600!important;color:#374151!important;margin:1.25rem 0 .5rem!important;padding-left:.75rem!important;border-left:2px solid #e5e7eb!important;line-height:1.4!important}article h5,.max-w-4xl h5,.flex-1 h5{font-size:1.1rem!important;font-weight:600!important;color:#374151!important;margin:1rem 0 .5rem!important;text-transform:uppercase!important;letter-spacing:.5px!important;line-height:1.4!important}article h6,.max-w-4xl h6,.flex-1 h6{font-size:1rem!important;font-weight:600!important;color:#6b7280!important;margin:.75rem 0 .5rem!important;font-style:italic!important;line-height:1.4!important}article h1:hover,article h2:hover,article h3:hover,article h4:hover,article h5:hover,article h6:hover,.max-w-4xl h1:hover,.max-w-4xl h2:hover,.max-w-4xl h3:hover,.max-w-4xl h4:hover,.max-w-4xl h5:hover,.max-w-4xl h6:hover,.flex-1 h1:hover,.flex-1 h2:hover,.flex-1 h3:hover,.flex-1 h4:hover,.flex-1 h5:hover,.flex-1 h6:hover{transform:translateX(2px)!important;transition:transform .2s ease!important}.dark article h1,.dark .max-w-4xl h1,.dark .flex-1 h1{color:#e2e8f0!important;border-bottom-color:#4a9eff!important}.dark article h2,.dark .max-w-4xl h2,.dark .flex-1 h2{color:#cbd5e1!important;border-left-color:#4a9eff!important;background:linear-gradient(90deg,rgba(74,158,255,.1),transparent)!important}.dark article h3,.dark .max-w-4xl h3,.dark .flex-1 h3{color:#94a3b8!important;border-bottom-color:#475569!important}.dark article h4,.dark .max-w-4xl h4,.dark .flex-1 h4{color:#94a3b8!important;border-left-color:#475569!important}.dark article h5,.dark .max-w-4xl h5,.dark .flex-1 h5{color:#64748b!important}.dark article h6,.dark .max-w-4xl h6,.dark .flex-1 h6{color:#64748b!important}@media screen and (max-width:768px){article h1,.max-w-4xl h1,.flex-1 h1{font-size:2rem!important;margin:2rem 0 1rem!important}article h2,.max-w-4xl h2,.flex-1 h2{font-size:1.5rem!important;margin:1.5rem 0 .75rem!important;padding:.5rem 0 .5rem .75rem!important}article h3,.max-w-4xl h3,.flex-1 h3{font-size:1.25rem!important;margin:1.25rem 0 .5rem!important}}article p,.max-w-4xl p,.flex-1 p{margin-bottom:1.25rem!important;line-height:1.7!important;text-align:justify!important}article ul,article ol,.max-w-4xl ul,.max-w-4xl ol,.flex-1 ul,.flex-1 ol{margin-bottom:1.25rem!important;padding-left:1.5rem!important}article li,.max-w-4xl li,.flex-1 li{margin-bottom:.5rem!important;line-height:1.6!important}.post-content blockquote{margin:1.5rem 0!important;padding:1rem 1.5rem!important;border-left:4px solid var(--primary)!important;background:linear-gradient(90deg,rgba(var(--primary-rgb),.05),transparent)!important;border-radius:0 8px 8px 0!important;font-style:italic!important;color:var(--secondary)!important}.dark .post-content blockquote{background:linear-gradient(90deg,rgba(74,158,255,.1),transparent)!important;color:#cbd5e1!important}.post-content code{background:var(--code-bg)!important;color:var(--primary)!important;padding:.2rem .4rem!important;border-radius:4px!important;font-size:.9em!important;font-weight:500!important;border:1px solid var(--border)!important}.post-content pre{background:var(--code-block-bg)!important;border:1px solid var(--border)!important;border-radius:8px!important;padding:1rem!important;margin:1.5rem 0!important;overflow-x:auto!important}.post-content table{border-collapse:collapse!important;width:100%!important;margin:1.5rem 0!important;border-radius:8px!important;overflow:hidden!important;box-shadow:0 2px 8px rgba(0,0,0,.1)!important}.post-content th,.post-content td{padding:.75rem 1rem!important;text-align:left!important;border-bottom:1px solid var(--border)!important}.post-content th{background:var(--code-bg)!important;font-weight:600!important;color:var(--primary)!important}.post-content tr:hover{background:rgba(var(--primary-rgb),.05)!important}.post-content hr{margin:2rem 0!important;height:2px!important;background:linear-gradient(90deg,transparent,var(--border),transparent)!important;border:none!important}.post-content{position:relative!important;max-width:none!important}.post-content::before{content:''!important;position:absolute!important;top:-1rem!important;left:-1rem!important;right:-1rem!important;bottom:-1rem!important;background:linear-gradient(135deg,rgba(var(--primary-rgb),.02),rgba(var(--secondary-rgb),.02))!important;border-radius:12px!important;z-index:-1!important}.post-content p:not(:first-child){text-indent:2em!important}.post-content ul li::marker{color:var(--primary)!important;font-weight:700!important}.post-content ol li::marker{color:var(--primary)!important;font-weight:700!important}.post-content strong{color:var(--primary)!important;font-weight:700!important;background:linear-gradient(120deg,rgba(var(--primary-rgb),.1),transparent)!important;padding:.1rem .3rem!important;border-radius:3px!important}.post-content em{color:var(--secondary)!important;font-style:italic!important;font-weight:500!important}.post-content p a{position:relative!important;z-index:1!important}.post-content img{max-width:100%!important;height:auto!important;display:block!important;margin:1rem auto!important;border-radius:8px!important;box-shadow:0 4px 12px rgba(0,0,0,.1)!important;transition:transform .3s ease,box-shadow .3s ease!important;margin:1.5rem 0!important;max-width:100%!important;height:auto!important;display:block!important}.post-content img:hover{transform:translateY(-2px)!important;box-shadow:0 8px 24px rgba(0,0,0,.15)!important}.post-content pre{position:relative!important;background:var(--code-block-bg)!important;border:1px solid var(--border)!important;border-radius:8px!important;padding:1.5rem!important;margin:1.5rem 0!important;overflow-x:auto!important;box-shadow:0 2px 8px rgba(0,0,0,.1)!important}.post-content pre::before{content:''!important;position:absolute!important;top:0!important;left:0!important;right:0!important;height:3px!important;background:linear-gradient(90deg,var(--primary),var(--secondary))!important;border-radius:8px 8px 0 0!important}.post-content code:not(pre code){background:var(--code-bg)!important;color:var(--primary)!important;padding:.25rem .5rem!important;border-radius:4px!important;font-size:.9em!important;font-weight:600!important;border:1px solid var(--border)!important;box-shadow:0 1px 3px rgba(0,0,0,.1)!important;transition:all .2s ease!important}.post-content code:not(pre code):hover{background:var(--primary)!important;color:var(--theme)!important;transform:translateY(-1px)!important;box-shadow:0 2px 6px rgba(0,0,0,.15)!important}.post-content table{border-collapse:collapse!important;width:100%!important;margin:2rem 0!important;border-radius:8px!important;overflow:hidden!important;box-shadow:0 4px 12px rgba(0,0,0,.1)!important;background:var(--theme)!important}.post-content th{background:linear-gradient(135deg,var(--primary),var(--secondary))!important;color:var(--theme)!important;font-weight:600!important;text-transform:uppercase!important;letter-spacing:.5px!important;font-size:.9em!important}.post-content td{border-bottom:1px solid var(--border)!important;transition:background-color .2s ease!important}.post-content tr:hover td{background:rgba(var(--primary-rgb),.05)!important}.post-content blockquote{position:relative!important;margin:2rem 0!important;padding:1.5rem 2rem!important;border-left:4px solid var(--primary)!important;background:linear-gradient(135deg,rgba(var(--primary-rgb),.05),rgba(var(--secondary-rgb),.02))!important;border-radius:0 12px 12px 0!important;font-style:italic!important;color:var(--secondary)!important;box-shadow:0 2px 8px rgba(0,0,0,5%)!important}.post-content blockquote::before{content:'"'!important;position:absolute!important;top:-.5rem!important;left:1rem!important;font-size:3rem!important;color:var(--primary)!important;opacity:.3!important;font-family:serif!important}.dark .post-content::before{background:linear-gradient(135deg,rgba(74,158,255,5%),rgba(148,163,184,2%))!important}.dark .post-content img{box-shadow:0 4px 12px rgba(0,0,0,.3)!important}.dark .post-content img:hover{box-shadow:0 8px 24px rgba(0,0,0,.4)!important}.dark .post-content pre{box-shadow:0 2px 8px rgba(0,0,0,.2)!important}.dark .post-content table{box-shadow:0 4px 12px rgba(0,0,0,.2)!important}.dark .post-content blockquote{background:linear-gradient(135deg,rgba(74,158,255,.1),rgba(148,163,184,5%))!important;color:#cbd5e1!important;box-shadow:0 2px 8px rgba(0,0,0,.1)!important}@media screen and (max-width:768px){.post-content::before{left:-.5rem!important;right:-.5rem!important}.post-content p:not(:first-child){text-indent:1em!important}.post-content blockquote{padding:1rem 1.5rem!important;margin:1.5rem 0!important}.post-content pre{padding:1rem!important;margin:1rem 0!important}}.nav-item{position:relative;overflow:hidden}.nav-item::before{content:'';position:absolute;left:0;top:0;height:100%;width:3px;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);transform:scaleY(0);transition:transform .3s ease}.nav-item:hover::before,.nav-item.bg-blue-100::before{transform:scaleY(1)}.blog-card{position:relative;overflow:hidden}.blog-card::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.blog-card:hover::before{left:100%}@keyframes shimmer{0%{background-position:-200px 0}100%{background-position:calc(200px + 100%)0}}.loading-shimmer{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);background-size:200px 100%;animation:shimmer 1.5s infinite}html{scroll-behavior:smooth}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#5a6fd8 0%,#6a4190 100%)}@media screen and (max-width:1024px){.fixed.left-0{transform:translateX(-100%);transition:transform .3s ease}.fixed.left-0.mobile-open{transform:translateX(0)}.ml-64{margin-left:0}}@media(prefers-color-scheme:dark){.blog-card{background-color:#1f2937;color:#f9fafb}.blog-card:hover{background-color:#374151}.nav-item{color:#d1d5db}.nav-item:hover{background-color:#374151;color:#f3f4f6}}@media print{.fixed.left-0{display:none}.ml-64{margin-left:0}.blog-card{break-inside:avoid;box-shadow:none;border:1px solid #e5e7eb}}.post-content{background:var(--entry)!important;border-radius:12px!important;box-shadow:0 4px 6px -1px rgba(0,0,0,.1)!important;overflow:hidden!important;position:relative!important}.post-content::before{content:''!important;position:absolute!important;top:0!important;left:0!important;right:0!important;height:4px!important;background:linear-gradient(90deg,#3B82F6,#1D4ED8,#3B82F6)!important;z-index:1!important}.post-content h1{font-size:2.5rem!important;font-weight:700!important;color:var(--color-heading-strong)!important;margin:2rem 0 1rem!important;line-height:1.2!important;position:relative!important}.post-content h1+p{font-size:1.1rem!important;color:#6b7280!important;margin-bottom:1.5rem!important;line-height:1.6!important;font-weight:400!important}.post-meta{display:flex!important;align-items:center!important;gap:1rem!important;margin-bottom:2rem!important;font-size:.9rem!important;color:#6b7280!important}.post-meta .meta-item{display:flex!important;align-items:center!important;gap:.25rem!important}.post-meta .meta-item svg{width:1rem!important;height:1rem!important}.post-content h2{position:relative!important;padding-left:1.5rem!important;margin:2rem 0 1rem!important;color:var(--color-heading-strong)!important}.post-content h2::before{content:''!important;position:absolute!important;left:0!important;top:.5rem!important;width:4px!important;height:1.5rem!important;background:#3b82f6!important;border-radius:2px!important}.post-content h2::after{content:''!important;position:absolute!important;bottom:-.5rem!important;left:1.5rem!important;right:0!important;height:2px!important;background:linear-gradient(90deg,#3B82F6,transparent)!important}.post-content h3{color:var(--color-heading)!important;font-weight:600!important;margin:1.5rem 0 .75rem!important;position:relative!important}.post-content a{color:#3b82f6!important;text-decoration:none!important;border-bottom:1px solid transparent!important;transition:all .2s ease!important}.post-content a:hover{color:#1d4ed8!important;border-bottom-color:#1d4ed8!important;background-color:rgba(59,130,246,.1)!important;padding:.125rem .25rem!important;margin:-.125rem -.25rem!important;border-radius:.25rem!important}[data-theme=dark] .post-content{background:var(--article-surface)!important;color:var(--color-text)!important}[data-theme=dark] .post-content h1,[data-theme=dark] .post-content h2{color:var(--color-heading-strong)!important}[data-theme=dark] .post-content h3{color:var(--color-heading)!important}[data-theme=dark] .post-content a{color:var(--color-primary)!important}[data-theme=dark] .post-content a:hover{color:var(--color-primary-light)!important;background-color:rgba(96,165,250,.1)!important}@media screen and (max-width:768px){.post-content h1{font-size:2rem!important}.post-content h2{font-size:1.5rem!important;padding-left:1rem!important}.post-content h2::before{width:3px!important;height:1.25rem!important}.post-content h2::after{left:1rem!important}}.post-content h2:contains("参考"),.post-content h2:contains("参考文献"),.post-content h2:has(+ol),.post-content h2:has(+ul){margin-top:3rem!important;margin-bottom:1.5rem!important;font-size:1.5rem!important;font-weight:700!important;color:#1f2937!important;border-bottom:none!important;padding-left:0!important}.post-content h2:contains("参考")::before,.post-content h2:contains("参考文献")::before,.post-content h2:has(+ol)::before,.post-content h2:has(+ul)::before{display:none!important}.post-content h2:contains("参考")::after,.post-content h2:contains("参考文献")::after,.post-content h2:has(+ol)::after,.post-content h2:has(+ul)::after{display:none!important}.post-content ol:last-child a,.post-content ul:last-child a{color:#3b82f6!important;text-decoration:none!important;font-weight:500!important;transition:all .2s ease!important;display:inline-block!important;line-height:1.5!important}.post-content ol:last-child a:hover,.post-content ul:last-child a:hover{color:#1d4ed8!important;background-color:rgba(59,130,246,.1)!important;padding:.125rem .25rem!important;margin:-.125rem -.25rem!important;border-radius:.25rem!important}.post-content ol:last-child a[href*="github.com"],.post-content ul:last-child a[href*="github.com"]{color:#3b82f6!important}.post-content ol:last-child a[href*="google.com"],.post-content ul:last-child a[href*="googleblog.com"]{color:#3b82f6!important}.post-content ol:last-child a[href*="modelcontextprotocol.com"],.post-content ul:last-child a[href*="modelcontextprotocol.com"]{color:#3b82f6!important}.dark .post-content h2:has(+ol),.dark .post-content h2:has(+ul){color:#f9fafb!important}.dark .post-content ol:last-child li::before{color:#9ca3af!important}.dark .post-content ol:last-child a,.dark .post-content ul:last-child a{color:#60a5fa!important}.dark .post-content ol:last-child a:hover,.dark .post-content ul:last-child a:hover{color:#93c5fd!important;background-color:rgba(96,165,250,.1)!important}@media screen and (max-width:768px){.post-content h2:has(+ol),.post-content h2:has(+ul){font-size:1.25rem!important;margin-top:2rem!important}.post-content ol:last-child li,.post-content ul:last-child li{margin-bottom:.5rem!important}}.toc-sidebar .toc-container,.toc{background-color:var(--entry)!important;color:var(--primary)!important;border:1px solid var(--border)!important}[data-theme=dark] .toc-sidebar .toc-container,[data-theme=dark] .toc{background-color:var(--entry)!important;color:var(--primary)!important;box-shadow:0 8px 24px rgba(0,0,0,.3)!important}.toc-sidebar a,.toc a{color:var(--secondary)!important;text-decoration:none!important;transition:all .2s ease!important}.toc-sidebar a:hover,.toc-sidebar a.active,.toc a:hover,.toc a.active{color:var(--primary)!important;background:0 0!important}