:root{--font-sans: "Inter", "Noto Sans SC", system-ui, -apple-system, sans-serif;--radius: 12px;--radius-sm: 8px;--transition: .2s ease;--max-width: 1200px;--header-height: 64px}[data-theme=dark]{--bg-primary: #0a0a0f;--bg-secondary: #12121a;--bg-card: #1a1a26;--bg-card-hover: #22223a;--text-primary: #e8e8f0;--text-secondary: #9898b0;--text-muted: #686888;--accent: #7c6aef;--accent-hover: #9584f7;--accent-subtle: rgba(124, 106, 239, .12);--border: rgba(255, 255, 255, .06);--border-hover: rgba(255, 255, 255, .12);--shadow: 0 4px 24px rgba(0, 0, 0, .3);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .2);--gradient-card: linear-gradient(145deg, #1a1a26 0%, #16162a 100%);--tag-bg: rgba(124, 106, 239, .15);--tag-text: #a899f5;--download-bg: rgba(46, 204, 113, .1);--download-border: rgba(46, 204, 113, .3);--download-text: #2ecc71}[data-theme=light]{--bg-primary: #f5f5fa;--bg-secondary: #ffffff;--bg-card: #ffffff;--bg-card-hover: #f0f0f8;--text-primary: #1a1a2e;--text-secondary: #555570;--text-muted: #888898;--accent: #6350d8;--accent-hover: #4d3bc2;--accent-subtle: rgba(99, 80, 216, .08);--border: rgba(0, 0, 0, .08);--border-hover: rgba(0, 0, 0, .15);--shadow: 0 4px 24px rgba(0, 0, 0, .08);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .04);--gradient-card: linear-gradient(145deg, #ffffff 0%, #f8f8ff 100%);--tag-bg: rgba(99, 80, 216, .1);--tag-text: #6350d8;--download-bg: rgba(39, 174, 96, .08);--download-border: rgba(39, 174, 96, .3);--download-text: #27ae60}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);line-height:1.7;min-height:100vh}a{color:var(--accent);text-decoration:none;transition:color var(--transition)}a:hover{color:var(--accent-hover)}img{max-width:100%;height:auto;border-radius:var(--radius-sm)}.container{max-width:var(--max-width);margin:0 auto;padding:0 20px}.site-header{position:sticky;top:0;z-index:100;background:var(--bg-secondary);border-bottom:1px solid var(--border);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);height:var(--header-height)}.nav{display:flex;align-items:center;justify-content:space-between;height:var(--header-height)}.logo{display:flex;align-items:center;gap:8px;color:var(--text-primary);font-size:1.25rem;font-weight:700}.logo-icon{font-size:1.5rem}.nav-links{display:flex;align-items:center;gap:6px}.nav-link{padding:6px 14px;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.9rem;font-weight:500;transition:all var(--transition)}.nav-link:hover{color:var(--text-primary);background:var(--accent-subtle)}.theme-toggle{background:none;border:none;cursor:pointer;padding:6px 10px;border-radius:var(--radius-sm);font-size:1.1rem;transition:background var(--transition)}.theme-toggle:hover{background:var(--accent-subtle)}.lang-switcher{position:relative}.lang-btn{display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;padding:6px 10px;border-radius:var(--radius-sm);color:var(--text-secondary);transition:all var(--transition)}.lang-btn:hover{background:var(--accent-subtle);color:var(--text-primary)}.lang-btn svg{width:18px;height:18px}.lang-panel{position:absolute;top:calc(100% + 8px);right:0;min-width:180px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 12px 40px #00000026;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:8px;opacity:0;visibility:hidden;transform:translateY(-8px) scale(.96);transform-origin:top right;transition:all .2s cubic-bezier(.16,1,.3,1);z-index:200}.lang-panel.open{opacity:1;visibility:visible;transform:translateY(0) scale(1)}.lang-panel-title{font-size:.7rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;padding:4px 10px 8px}.lang-list{display:flex;flex-direction:column;gap:2px}.lang-option{display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;border:none;border-radius:6px;background:none;color:var(--text-secondary);font-size:.85rem;font-weight:500;font-family:var(--font-sans);cursor:pointer;transition:all .15s ease;text-align:left;min-height:36px}.lang-option:hover{background:var(--accent-subtle);color:var(--text-primary)}.lang-option.active{background:var(--accent-subtle);color:var(--accent);font-weight:600}.translateSelectLanguage,select.translateSelectLanguage{display:none!important}.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:6px;color:var(--text-primary);border-radius:var(--radius-sm);transition:background var(--transition)}.nav-toggle:hover{background:var(--accent-subtle)}.nav-toggle svg{width:22px;height:22px}.nav-item{position:relative}.nav-dropdown-trigger{display:inline-flex;align-items:center;gap:3px}.dropdown-arrow{width:12px;height:12px;transition:transform .2s ease;flex-shrink:0}.nav-item.has-dropdown:hover .dropdown-arrow,.nav-item.dropdown-open .dropdown-arrow{transform:rotate(180deg)}.nav-dropdown{position:absolute;top:100%;left:50%;transform:translate(-50%) translateY(4px);min-width:140px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:0 8px 24px #0000001f;opacity:0;visibility:hidden;transition:all .2s ease;z-index:200;padding:6px}.nav-item.has-dropdown:hover .nav-dropdown{opacity:1;visibility:visible;transform:translate(-50%) translateY(0)}.nav-dropdown-item{display:block;padding:8px 14px;color:var(--text-secondary);font-size:.85rem;font-weight:500;border-radius:6px;transition:all .15s ease;white-space:nowrap}.nav-dropdown-item:hover{color:var(--text-primary);background:var(--accent-subtle)}.main-content{padding:32px 20px;min-height:calc(100vh - var(--header-height) - 120px)}.site-footer{text-align:center;padding:32px 20px;border-top:1px solid var(--border);color:var(--text-muted)}.footer-text{font-size:.95rem;margin-bottom:4px;opacity:.7}.footer-copy{font-size:.8rem;opacity:.5}.card{background:var(--gradient-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;transition:all var(--transition)}.card:hover{border-color:var(--border-hover);box-shadow:var(--shadow);transform:translateY(-2px)}.post-card{display:grid;grid-template-columns:200px 1fr;gap:20px;background:var(--gradient-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:all .3s ease}.post-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow);transform:translateY(-2px)}.post-card-image{width:100%;height:150px;object-fit:cover;border-radius:0}.post-card-image-placeholder{width:100%;height:150px;background:var(--accent-subtle);display:flex;align-items:center;justify-content:center;font-size:2rem;color:var(--accent);border-radius:0}.post-card-body{padding:16px 16px 16px 0;display:flex;flex-direction:column;justify-content:center}.post-card-title{font-size:1.05rem;font-weight:600;color:var(--text-primary);line-height:1.4;margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.post-card-meta{display:flex;align-items:center;gap:12px;font-size:.8rem;color:var(--text-muted);margin-bottom:8px}.post-card-tags{display:flex;flex-wrap:wrap;gap:6px}.tag{display:inline-block;padding:2px 10px;border-radius:20px;background:var(--tag-bg);color:var(--tag-text);font-size:.75rem;font-weight:500;transition:opacity var(--transition)}.tag:hover{opacity:.8}.pagination{display:flex;justify-content:center;align-items:center;gap:6px;margin-top:40px}.pagination a,.pagination span{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 10px;border-radius:var(--radius-sm);font-size:.85rem;font-weight:500;line-height:1}.pagination a{background:var(--bg-card);border:1px solid var(--border);color:var(--text-secondary);transition:all var(--transition)}.pagination a:hover{border-color:var(--accent);color:var(--accent)}.pagination .current{background:var(--accent);color:#fff;border:1px solid var(--accent)}.pagination .page-arrow{font-size:1.1rem;font-weight:700;min-width:36px;padding:0}.pagination .page-arrow.disabled{opacity:.3;cursor:default;background:var(--bg-card);border:1px solid var(--border);color:var(--text-muted)}.pagination .page-dots{min-width:auto;padding:0 4px;color:var(--text-muted);font-size:.9rem;letter-spacing:2px}.download-box{background:var(--bg-card, #fff);border:1px solid var(--border, #e5e7eb);border-radius:var(--radius);padding:20px 24px;margin:28px 0;box-shadow:var(--shadow-sm)}.download-title{color:var(--text-primary);font-weight:700;margin-bottom:16px;font-size:1rem;display:flex;align-items:center;gap:8px}.dl-links{display:flex;flex-wrap:wrap;gap:12px;align-items:center}.download-item{display:flex;align-items:center;gap:8px}.dl-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:8px;color:#fff;font-size:.9rem;font-weight:600;text-decoration:none;transition:transform .15s ease,box-shadow .15s ease;white-space:nowrap}.dl-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0003;color:#fff}.dl-btn svg{width:16px;height:16px;flex-shrink:0}.dl-btn-baidu{background:linear-gradient(135deg,#2b7fff,#06b4f5)}.dl-btn-local{background:linear-gradient(135deg,#ff4081,#ff6b9b)}.dl-btn-default{background:linear-gradient(135deg,#6366f1,#8b5cf6)}.dl-code{display:inline-flex;align-items:center;padding:8px 14px;background:var(--bg-page, #f3f4f6);border:1px solid var(--border, #e5e7eb);border-radius:8px;font-size:.85rem;color:var(--text-secondary);font-weight:500;white-space:nowrap}@media(max-width:640px){.dl-links,.download-item{flex-direction:column;align-items:stretch}.dl-btn,.dl-code{justify-content:center}}.article-header{margin-bottom:32px}.article-title{font-size:1.75rem;font-weight:700;line-height:1.3;margin-bottom:16px}.article-meta{display:flex;flex-wrap:wrap;gap:16px;color:var(--text-muted);font-size:.9rem}.article-content{line-height:1.9;font-size:1rem}.article-content p{margin-bottom:1em}.article-content img{display:block;max-width:100%;height:auto;margin:.5em auto;border-radius:var(--radius-sm);cursor:zoom-in;transition:opacity .2s ease}.article-content img:hover{opacity:.92}.img-lightbox{position:fixed;inset:0;z-index:9999;background:#000000d9;display:flex;align-items:center;justify-content:center;cursor:zoom-out;animation:lightbox-in .2s ease;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}.img-lightbox img{max-width:92vw;max-height:92vh;object-fit:contain;border-radius:6px;box-shadow:0 8px 40px #00000080}@keyframes lightbox-in{0%{opacity:0}to{opacity:1}}.article-content figure{margin:1.5em 0;text-align:center}.article-content h2,.article-content h3{margin-top:2em;margin-bottom:.5em}.article-content blockquote{border-left:3px solid var(--accent);padding:12px 20px;margin:1.5em 0;background:var(--accent-subtle);border-radius:0 var(--radius-sm) var(--radius-sm) 0;color:var(--text-secondary)}.article-content pre{background:#1e293b;color:#e2e8f0;padding:16px 20px;border-radius:var(--radius-sm);overflow-x:auto;font-size:.9rem;line-height:1.6;margin:1em 0}.article-content code{font-family:JetBrains Mono,Fira Code,Consolas,monospace;font-size:.88em}.article-content :not(pre)>code{background:var(--accent-subtle);padding:2px 6px;border-radius:4px;color:var(--accent)}.article-content ul,.article-content ol{padding-left:1.5em;margin-bottom:1em}.article-content li{margin-bottom:.3em}.article-content table{width:100%;border-collapse:collapse;margin:1em 0}.article-content th,.article-content td{padding:10px 14px;border:1px solid var(--border);text-align:left}.article-content th{background:var(--accent-subtle);font-weight:600}.search-input{width:100%;padding:14px 20px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);font-size:1rem;font-family:var(--font-sans);outline:none;transition:border-color var(--transition)}.search-input:focus{border-color:var(--accent)}.search-input::placeholder{color:var(--text-muted)}.page-layout{display:grid;grid-template-columns:1fr 300px;gap:32px}.sidebar-section{margin-bottom:24px}.sidebar-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border)}.sidebar-categories,.sidebar-tags{list-style:none}.sidebar-categories li a{display:flex;justify-content:space-between;padding:6px 0;color:var(--text-secondary);font-size:.9rem;border-bottom:1px solid var(--border);transition:color var(--transition)}.sidebar-categories li a:hover{color:var(--accent)}.sidebar-tags{display:flex;flex-wrap:wrap;gap:8px}.page-title{font-size:1.5rem;font-weight:700;margin-bottom:24px;color:var(--text-primary)}.page-subtitle{color:var(--text-muted);font-size:.9rem;margin-bottom:24px}.post-list{display:flex;flex-direction:column;gap:16px}.grid-cards{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}.grid-card{display:block;background:var(--gradient-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:all .25s ease;text-decoration:none;color:inherit}.grid-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow);transform:translateY(-4px) scale(1.02)}.grid-card-image{width:100%;aspect-ratio:3 / 4;object-fit:cover;display:block;transition:transform .3s ease}.grid-card:hover .grid-card-image{transform:scale(1.05)}.grid-card-thumb{overflow:hidden;aspect-ratio:3 / 4;background:var(--accent-subtle)}.grid-card-placeholder{width:100%;aspect-ratio:3 / 4;background:var(--accent-subtle);display:flex;align-items:center;justify-content:center;font-size:2rem;color:var(--accent)}.broken-image-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:32px 20px;margin:12px 0;background:var(--accent-subtle, #f3f4f6);border:1px dashed var(--border, #e5e7eb);border-radius:var(--radius, 10px);color:var(--text-muted, #9ca3af)}.broken-image-placeholder svg{width:32px;height:32px;opacity:.5}.broken-image-placeholder span{font-size:.8rem;font-weight:500}.grid-card-title{padding:8px 10px 10px;margin:0;font-size:.8rem;font-weight:500;line-height:1.4;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media(max-width:900px){.page-layout{grid-template-columns:1fr}.grid-cards{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.nav-toggle{display:block}.nav-links{display:none;position:absolute;top:var(--header-height);left:0;right:0;background:var(--bg-secondary);border-bottom:1px solid var(--border);flex-direction:column;padding:8px 16px 16px;gap:2px;box-shadow:var(--shadow);z-index:99}.nav-links.open{display:flex}.nav-link{padding:10px 14px;font-size:.9rem;width:100%;border-radius:var(--radius-sm)}.nav-item.has-dropdown{width:100%}.nav-dropdown{position:static;transform:none;opacity:1;visibility:visible;box-shadow:none;border:none;padding:0 0 0 16px;max-height:0;overflow:hidden;transition:max-height .25s ease;background:transparent;min-width:auto}.nav-item.has-dropdown:hover .nav-dropdown{transform:none}.nav-item.dropdown-open .nav-dropdown{max-height:300px}.nav-dropdown-item{padding:8px 12px;font-size:.85rem}}@media(max-width:640px){.post-card{grid-template-columns:1fr}.post-card-image,.post-card-image-placeholder{height:180px}.post-card-body{padding:12px 16px 16px}.article-title{font-size:1.35rem}.grid-cards{grid-template-columns:repeat(2,1fr);gap:10px}.grid-card-title{font-size:.8rem;padding:8px 10px}}.article-body details,.post-content details{border:1px solid var(--border);border-radius:var(--radius, 8px);overflow:hidden;margin:1em 0;background:var(--surface, #fff);transition:box-shadow .2s}.article-body details[open],.post-content details[open]{box-shadow:0 2px 8px #0000000a}.article-body details summary,.post-content details summary{display:flex;align-items:center;gap:8px;padding:12px 16px;font-weight:600;font-size:15px;cursor:pointer;user-select:none;list-style:none;background:var(--accent-subtle, #f8fafc);border-bottom:1px solid transparent;transition:background .15s}.article-body details summary::-webkit-details-marker,.post-content details summary::-webkit-details-marker{display:none}.article-body details summary:before,.post-content details summary:before{content:"▶";font-size:10px;color:var(--accent, #6366f1);transition:transform .2s}.article-body details[open] summary:before,.post-content details[open] summary:before{transform:rotate(90deg)}.article-body details summary:hover,.post-content details summary:hover{background:#6366f10f}.article-body details[open] summary,.post-content details[open] summary{border-bottom-color:var(--border)}.article-body details .details-content,.article-body details>*:not(summary),.post-content details .details-content,.post-content details>*:not(summary){padding:14px 16px;font-size:14px;line-height:1.7}
