:root{--color-primary:#10b981;--color-primary-hover:#059669;--color-primary-light:#34d399;--color-primary-bg:#ecfdf5;--color-primary-border:#a7f3d0;--color-bg:#f8fafc;--color-card:#fff;--color-card-hover:#f8fafc;--color-text:#1e293b;--color-text-secondary:#64748b;--color-text-muted:#94a3b8;--color-border:#e2e8f0;--color-border-light:#f1f5f9;--color-dark:#0f172a;--container-max:1200px;--header-height:64px;--sidebar-width:320px;--content-gap:24px;--radius-lg:12px;--radius-md:8px;--radius-sm:6px;--radius-full:9999px;--shadow-sm:0 1px 2px #0000000a;--shadow:0 1px 3px #00000014;--shadow-md:0 4px 6px -1px #00000014;--shadow-lg:0 10px 15px -3px #0000001a;--shadow-hover:0 8px 25px -5px #0000001f;--transition:.2s ease;--font-sans:"LXGW WenKai Screen", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Microsoft YaHei", "Hiragino Sans GB", "Source Han Sans CN", "Noto Sans CJK SC", sans-serif;--font-mono:"JetBrains Mono", "Fira Code", "Cascadia Code", Consolas, monospace}[data-theme=dark]{--color-primary:#10b981;--color-primary-hover:#34d399;--color-primary-light:#6ee7b7;--color-primary-bg:#10b9811a;--color-primary-border:#10b9814d;--color-bg:#0f172a;--color-card:#1e293b;--color-card-hover:#334155;--color-text:#f1f5f9;--color-text-secondary:#94a3b8;--color-text-muted:#64748b;--color-border:#334155;--color-border-light:#1e293b;--color-dark:#f1f5f9;--shadow-sm:0 1px 2px #0003;--shadow:0 1px 3px #0000004d;--shadow-md:0 4px 6px -1px #0000004d;--shadow-lg:0 10px 15px -3px #0006;--shadow-hover:0 8px 25px -5px #0006}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:var(--font-sans);color:var(--color-text);background-color:var(--color-bg);transition:background-color var(--transition), color var(--transition);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:15px;line-height:1.7}a{color:var(--color-primary);transition:color var(--transition);text-decoration:none}a:hover{color:var(--color-primary-hover)}img{max-width:100%;height:auto;display:block}ul,ol{list-style:none}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input,textarea{font-family:inherit;font-size:inherit}.container{max-width:var(--container-max);margin:0 auto;padding:0 20px}.site-header{z-index:100;background:color-mix(in srgb, var(--color-card) 85%, transparent);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid color-mix(in srgb, var(--color-border) 60%, transparent);transition:background-color var(--transition), border-color var(--transition), box-shadow var(--transition);position:sticky;top:0}.site-header.scrolled{box-shadow:0 1px 12px #0000000f}.header-inner{height:var(--header-height);justify-content:space-between;align-items:center;gap:24px;display:flex}.header-logo{transition:opacity var(--transition);flex-shrink:0;align-items:center;gap:10px;display:flex}.header-logo:hover{opacity:.85}.header-logo .logo-icon{background:linear-gradient(135deg, var(--color-primary), var(--color-primary-hover));color:#fff;border-radius:var(--radius-md);width:36px;height:36px;font-family:var(--font-mono);box-shadow:0 2px 8px color-mix(in srgb, var(--color-primary) 30%, transparent);transition:transform var(--transition), box-shadow var(--transition);justify-content:center;align-items:center;font-size:16px;font-weight:700;display:flex}.header-logo:hover .logo-icon{box-shadow:0 4px 12px color-mix(in srgb, var(--color-primary) 40%, transparent);transform:scale(1.05)rotate(-3deg)}.header-logo .logo-image{object-fit:contain;border-radius:var(--radius-md);transition:transform var(--transition);flex-shrink:0}.header-logo:hover .logo-image{transform:scale(1.05)}.header-logo .logo-text{flex-direction:column;line-height:1.3;display:flex}.header-logo .logo-name{color:var(--color-text);letter-spacing:.5px;font-size:17px;font-weight:700}.header-logo .logo-tagline{color:var(--color-text-muted);white-space:nowrap;letter-spacing:.3px;font-size:11px}.header-nav{flex:1;justify-content:center;align-items:center;gap:2px;display:flex}.header-nav a{color:var(--color-text);border-radius:var(--radius-full);letter-spacing:.8px;transition:all var(--transition);align-items:center;gap:6px;padding:7px 16px;font-family:PingFang SC,Microsoft YaHei,Hiragino Sans GB,Source Han Sans CN,Noto Sans CJK SC,-apple-system,BlinkMacSystemFont,sans-serif;font-size:14px;font-weight:600;display:flex;position:relative}.header-nav a .iconfont{transition:transform var(--transition);font-size:16px;line-height:1}.header-nav a:hover .iconfont{transform:scale(1.15)}.header-nav a:hover{color:var(--color-primary);background:var(--color-primary-bg)}.header-nav a.active{color:var(--color-primary);background:var(--color-primary-bg);font-weight:600}.header-nav a.active:after{content:"";background:var(--color-primary);width:20px;height:3px;transition:width var(--transition);border-radius:2px;position:absolute;bottom:-22px;left:50%;transform:translate(-50%)}.header-actions{flex-shrink:0;align-items:center;gap:10px;display:flex}.search-box{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition);align-items:center;gap:8px;padding:7px 14px;display:flex}.search-box:hover{border-color:var(--color-primary);background:var(--color-primary-bg)}.search-box:hover svg{color:var(--color-primary)}.search-box svg{width:16px;height:16px;color:var(--color-text-muted);transition:color var(--transition);flex-shrink:0}.search-box .search-placeholder{color:var(--color-text-muted);font-size:13px}.search-box .search-kbd{font-size:11px;font-family:var(--font-mono);color:var(--color-text-muted);background:var(--color-card);border:1px solid var(--color-border);border-radius:4px;padding:2px 7px;line-height:1.4}.icon-btn{border-radius:var(--radius-full);width:38px;height:38px;color:var(--color-text-secondary);transition:all var(--transition);justify-content:center;align-items:center;display:flex}.icon-btn:hover{background:var(--color-primary-bg);color:var(--color-primary);transform:rotate(15deg)}.icon-btn svg{width:20px;height:20px}.icon-btn .sun-icon{display:none}.icon-btn .moon-icon,[data-theme=dark] .icon-btn .sun-icon{display:block}[data-theme=dark] .icon-btn .moon-icon{display:none}.menu-toggle{border-radius:var(--radius-md);flex-direction:column;justify-content:center;align-items:center;gap:4px;width:36px;height:36px;display:none}.menu-toggle span{background:var(--color-text);width:18px;height:2px;transition:all var(--transition);border-radius:1px}.menu-toggle.active span:first-child{transform:rotate(45deg)translate(4px,4px)}.menu-toggle.active span:nth-child(2){opacity:0}.menu-toggle.active span:nth-child(3){transform:rotate(-45deg)translate(4px,-4px)}.site-main{padding:28px 0 60px}.layout-grid{grid-template-columns:1fr var(--sidebar-width);gap:var(--content-gap);align-items:start;display:grid}.layout-grid.no-sidebar{grid-template-columns:1fr}.post-layout{gap:var(--content-gap);grid-template-columns:56px 1fr 240px;align-items:start;display:grid}.post-actions{top:calc(var(--header-height) + 40px);flex-direction:column;align-items:center;gap:10px;display:flex;position:sticky}.action-btn{border-radius:var(--radius-full);background:var(--color-card);border:1px solid var(--color-border);width:48px;height:48px;color:var(--color-text-secondary);box-shadow:var(--shadow-sm);cursor:pointer;transition:all var(--transition);flex-direction:column;justify-content:center;align-items:center;gap:3px;display:flex;position:relative}.action-btn svg{width:20px;height:20px;transition:transform var(--transition)}.action-btn .action-count{font-size:10px;font-weight:600;line-height:1}.action-btn:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-bg);box-shadow:0 4px 12px color-mix(in srgb, var(--color-primary) 20%, transparent);transform:translateY(-2px)}.action-btn:hover svg{transform:scale(1.1)}.action-btn:active{transform:translateY(0)}.action-upvote.liked{color:#fff;background:var(--color-primary);border-color:var(--color-primary);box-shadow:0 2px 8px color-mix(in srgb, var(--color-primary) 40%, transparent)}.action-upvote.liked svg{fill:#fff;animation:.4s upvotePop}@keyframes upvotePop{0%{transform:scale(1)}50%{transform:scale(1.3)}to{transform:scale(1)}}.action-share-menu{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transition:all var(--transition);z-index:20;flex-direction:column;gap:6px;padding:10px;display:flex;position:absolute;top:0;left:60px;transform:translate(-8px)}.action-share-menu.show{opacity:1;visibility:visible;transform:translate(0)}.share-item{color:var(--color-text-secondary);border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;transition:all var(--transition);background:0 0;border:none;align-items:center;gap:8px;padding:7px 14px;font-size:13px;font-weight:500;display:flex}.share-item svg{flex-shrink:0;width:18px;height:18px}.share-item:hover{color:var(--color-primary);background:var(--color-primary-bg)}.action-backtop{opacity:0;visibility:hidden;transition:all var(--transition)}.action-backtop.show{opacity:1;visibility:visible}.toc-sidebar{top:calc(var(--header-height) + 20px);max-height:calc(100vh - var(--header-height) - 40px);scrollbar-width:thin;scrollbar-color:var(--color-border) transparent;position:sticky;overflow-y:auto}.toc-sidebar::-webkit-scrollbar{width:4px}.toc-sidebar::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:2px}.toc-widget{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:18px 16px}.toc-title{color:var(--color-text);border-bottom:1px solid var(--color-border-light);align-items:center;gap:6px;margin-bottom:12px;padding-bottom:10px;font-size:14px;font-weight:600;display:flex}.toc-title svg{color:var(--color-primary)}.toc-nav{flex-direction:column;gap:2px;display:flex}.toc-children{border-left:2px solid var(--color-border-light);opacity:0;flex-direction:column;gap:2px;max-height:0;margin-top:2px;margin-left:12px;padding-left:4px;transition:max-height .3s,opacity .3s;display:none;overflow:hidden}.toc-children.expanded{opacity:1;max-height:1000px;display:flex}.toc-item.expanded>.toc-link{color:var(--color-primary);font-weight:500}.toc-link{color:var(--color-text-muted);border-radius:var(--radius-sm);transition:all var(--transition);cursor:pointer;padding:5px 10px;font-size:13px;line-height:1.5;display:block}.toc-link:hover{color:var(--color-primary);background:var(--color-primary-bg)}.toc-link.active{color:var(--color-primary);background:var(--color-primary-bg);border-left:2px solid var(--color-primary);font-weight:600}.toc-h2{font-weight:500}.toc-h3{padding-left:8px;font-size:12px}.toc-h4{opacity:.85;padding-left:8px;font-size:12px}.toc-empty{color:var(--color-text-muted);text-align:center;padding:12px 0;font-size:13px}.content-area{min-width:0}.sidebar{top:calc(var(--header-height) + 20px);max-height:calc(100vh - var(--header-height) - 40px);scrollbar-width:thin;scrollbar-color:var(--color-border) transparent;flex-direction:column;gap:20px;display:flex;position:sticky;overflow-y:auto}.sidebar::-webkit-scrollbar{width:4px}.sidebar::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:2px}.card{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition), border-color var(--transition)}.featured-card{grid-template-columns:1.2fr 1fr;gap:0;margin-bottom:28px;display:grid;overflow:hidden}.featured-content{flex-direction:column;justify-content:center;gap:12px;padding:32px;display:flex}.featured-badge{color:var(--color-primary);background:var(--color-primary-bg);border-radius:var(--radius-full);align-items:center;gap:4px;width:fit-content;padding:4px 10px;font-size:12px;font-weight:600;display:inline-flex}.featured-title{color:var(--color-text);font-size:26px;font-weight:700;line-height:1.35}.featured-title a{color:inherit}.featured-title a:hover{color:var(--color-primary)}.featured-subtitle{color:var(--color-text-secondary);font-size:15px;font-weight:500}.featured-desc{color:var(--color-text-secondary);font-size:14px;line-height:1.7}.featured-tags{flex-wrap:wrap;gap:6px;margin-top:4px;display:flex}.featured-meta{color:var(--color-text-muted);align-items:center;gap:16px;margin-top:8px;font-size:13px;display:flex}.featured-meta .meta-item{align-items:center;gap:4px;display:flex}.featured-meta svg{width:14px;height:14px}.featured-image{background:linear-gradient(135deg, var(--color-primary-bg), var(--color-border-light));justify-content:center;align-items:center;min-height:280px;display:flex;position:relative}.featured-image img{object-fit:cover;width:100%;height:100%}.featured-image-placeholder{font-family:var(--font-mono);color:var(--color-primary);opacity:.3;font-size:64px;font-weight:700}.featured-carousel{border-radius:var(--radius-lg);margin-bottom:28px;position:relative;overflow:hidden}.carousel-track{position:relative}.carousel-slide{margin-bottom:0;display:none}.carousel-slide.active{animation:.5s fadeInSlide;display:grid}@keyframes fadeInSlide{0%{opacity:0;transform:translate(12px)}to{opacity:1;transform:translate(0)}}.carousel-arrow{border-radius:var(--radius-full);border:1px solid var(--color-border);width:40px;height:40px;color:var(--color-text-secondary);box-shadow:var(--shadow-md);cursor:pointer;transition:all var(--transition);z-index:10;opacity:0;background:#ffffffe6;justify-content:center;align-items:center;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.featured-carousel:hover .carousel-arrow{opacity:1}.carousel-arrow:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.carousel-arrow svg{width:20px;height:20px}.carousel-prev{left:12px}.carousel-next{right:12px}.carousel-dots{z-index:10;gap:8px;display:flex;position:absolute;bottom:14px;left:50%;transform:translate(-50%)}.carousel-dot{border-radius:var(--radius-full);border:1px solid var(--color-border);cursor:pointer;width:8px;height:8px;transition:all var(--transition);background:#fff9;padding:0}.carousel-dot:hover{background:#ffffffe6}.carousel-dot.active{background:var(--color-primary);border-color:var(--color-primary);width:24px}[data-theme=dark] .carousel-arrow{background:#1e293be6}[data-theme=dark] .carousel-dot{border-color:var(--color-border);background:#64748b66}[data-theme=dark] .carousel-dot.active{background:var(--color-primary);border-color:var(--color-primary)}:is(.featured-carousel:has(.carousel-slide:only-child) .carousel-arrow,.featured-carousel:has(.carousel-slide:only-child) .carousel-dots){display:none}.section-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.section-title{color:var(--color-text);align-items:center;gap:8px;font-size:18px;font-weight:600;display:flex}.section-title:before{content:"";background:var(--color-primary);border-radius:2px;width:4px;height:18px}.filter-tabs{gap:4px;display:flex}.filter-tabs a{color:var(--color-text-muted);border-radius:var(--radius-full);transition:all var(--transition);padding:4px 12px;font-size:13px}.filter-tabs a:hover{color:var(--color-text)}.filter-tabs a.active{color:var(--color-primary);background:var(--color-primary-bg)}.article-card{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:all var(--transition);gap:16px;margin-bottom:12px;padding:20px;display:flex}.article-card:hover{border-color:var(--color-primary-border);box-shadow:var(--shadow-hover);transform:translateY(-2px)}.article-thumb{border-radius:var(--radius-md);background:var(--color-border-light);flex-shrink:0;justify-content:center;align-items:center;width:120px;height:90px;display:flex;overflow:hidden}.article-thumb img{object-fit:cover;width:100%;height:100%}.article-thumb-placeholder{font-family:var(--font-mono);color:var(--color-primary);opacity:.4;font-size:28px;font-weight:700}.article-body{flex-direction:column;flex:1;gap:6px;min-width:0;display:flex}.article-card-title{color:var(--color-text);font-size:16px;font-weight:600;line-height:1.5}.article-card-title a{color:inherit}.article-card-title a:hover{color:var(--color-primary)}.article-card-excerpt{color:var(--color-text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:13px;line-height:1.6;display:-webkit-box;overflow:hidden}.article-card-meta{color:var(--color-text-muted);flex-wrap:wrap;align-items:center;gap:12px;margin-top:auto;font-size:12px;display:flex}.article-card-meta .meta-item{align-items:center;gap:3px;display:flex}.article-card-meta svg{width:13px;height:13px}.article-card-tags{flex-wrap:wrap;gap:4px;display:flex}.pinned-badge{color:#fff;background:var(--color-primary);border-radius:var(--radius-full);align-items:center;gap:3px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.tag{color:var(--color-primary);background:var(--color-primary-bg);border-radius:var(--radius-full);transition:all var(--transition);align-items:center;padding:3px 10px;font-size:12px;font-weight:500;display:inline-flex}.tag:hover{background:var(--color-primary);color:#fff}.tag-gray{color:var(--color-text-secondary);background:var(--color-border-light)}.tag-gray:hover{color:var(--color-text);background:var(--color-border)}.btn{border-radius:var(--radius-full);transition:all var(--transition);white-space:nowrap;align-items:center;gap:6px;padding:8px 20px;font-size:14px;font-weight:500;display:inline-flex}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary-hover);color:#fff;box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-outline{border:1px solid var(--color-border);color:var(--color-text-secondary);background:var(--color-card)}.btn-outline:hover{border-color:var(--color-primary);color:var(--color-primary)}.btn-sm{padding:5px 14px;font-size:13px}.widget{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:20px}.widget-title{color:var(--color-text);justify-content:space-between;align-items:center;margin-bottom:14px;font-size:14px;font-weight:600;display:flex}.widget-title .title-text{align-items:center;gap:6px;display:flex}.widget-title svg{width:16px;height:16px;color:var(--color-primary)}.widget-title .widget-link{color:var(--color-primary);font-size:12px;font-weight:400}.search-widget input{width:100%;color:var(--color-text);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color var(--transition);padding:9px 14px;font-size:13px}.search-widget input:focus{border-color:var(--color-primary);outline:none}.search-widget .search-row{gap:8px;margin-top:10px;display:flex}.search-widget .search-row input{margin-top:0}.hot-tags{flex-wrap:wrap;gap:6px;display:flex}.category-grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.category-item{border-radius:var(--radius-md);background:var(--color-bg);border:1px solid var(--color-border);transition:all var(--transition);align-items:center;gap:10px;padding:12px;display:flex}.category-item:hover{border-color:var(--color-primary);background:var(--color-card-hover)}.category-icon{border-radius:var(--radius-sm);background:var(--color-primary-bg);width:36px;height:36px;color:var(--color-primary);flex-shrink:0;justify-content:center;align-items:center;font-size:18px;display:flex}.category-icon svg{width:18px;height:18px}.category-icon .iconfont{font-size:18px;line-height:1}.category-info{min-width:0}.category-name{color:var(--color-text);font-size:13px;font-weight:600}.category-count{color:var(--color-text-muted);font-size:11px}.recent-list{flex-direction:column;gap:12px;display:flex}.recent-item{align-items:flex-start;gap:10px;display:flex}.recent-item .recent-badge{font-size:10px;font-weight:600;font-family:var(--font-mono);color:var(--color-primary);background:var(--color-primary-bg);border-radius:4px;flex-shrink:0;margin-top:2px;padding:2px 6px}.recent-item .recent-info{flex:1;min-width:0}.recent-item .recent-title{color:var(--color-text);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:13px;font-weight:500;line-height:1.5;display:-webkit-box;overflow:hidden}.recent-item .recent-title a{color:inherit}.recent-item .recent-date{color:var(--color-text-muted);margin-top:2px;font-size:11px}.project-list{flex-direction:column;gap:10px;display:flex}.project-item{border-radius:var(--radius-md);background:var(--color-bg);border:1px solid var(--color-border);transition:all var(--transition);align-items:center;gap:10px;padding:10px;display:flex}.project-item:hover{border-color:var(--color-primary)}.project-icon{border-radius:var(--radius-sm);background:var(--color-primary-bg);flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;display:flex}.project-info{flex:1;min-width:0}.project-name{color:var(--color-text);font-size:13px;font-weight:600}.project-desc{color:var(--color-text-muted);font-size:11px}.project-stats{color:var(--color-text-muted);gap:10px;font-size:11px;display:flex}.project-stats span{align-items:center;gap:2px;display:flex}.pagination{justify-content:center;align-items:center;gap:8px;padding:28px 0 8px;display:flex}.pagination a,.pagination span{min-width:36px;height:36px;color:var(--color-text-secondary);background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:all var(--transition);justify-content:center;align-items:center;padding:0 10px;font-size:14px;display:flex}.pagination a:hover{border-color:var(--color-primary);color:var(--color-primary)}.pagination .current{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.pagination .disabled{opacity:.4;cursor:not-allowed}.article-detail{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:40px}.article-detail-header{border-bottom:1px solid var(--color-border);margin-bottom:28px;padding-bottom:24px}.article-detail-title{color:var(--color-text);margin-bottom:12px;font-size:28px;font-weight:700;line-height:1.4}.article-detail-meta{color:var(--color-text-muted);flex-wrap:wrap;align-items:center;gap:20px;font-size:13px;display:flex}.article-detail-meta .meta-item{align-items:center;gap:5px;display:flex}.article-detail-meta svg{width:15px;height:15px}.article-detail-cover{border-radius:var(--radius-lg) var(--radius-lg) 0 0;height:320px;margin:-40px -40px 28px;overflow:hidden}.article-detail-cover img{object-fit:cover;width:100%;height:100%}.prose{color:var(--color-text);font-size:15px;line-height:1.85}.prose h1,.prose h2,.prose h3,.prose h4,.prose h5,.prose h6{color:var(--color-text);margin-top:1.8em;margin-bottom:.8em;font-weight:600;line-height:1.4}.prose h1{font-size:1.75em}.prose h2{border-bottom:1px solid var(--color-border);padding-bottom:.3em;font-size:1.5em}.prose h3{font-size:1.25em}.prose p{margin-bottom:1em}.prose a{color:var(--color-primary);text-underline-offset:2px;text-decoration:underline}.prose ul,.prose ol{margin-bottom:1em;padding-left:1.5em}.prose ul{list-style:outside}.prose ol{list-style:decimal}.prose li{margin-bottom:.4em}.prose blockquote{border-left:4px solid var(--color-primary);background:var(--color-primary-bg);border-radius:0 var(--radius-md) var(--radius-md) 0;color:var(--color-text-secondary);margin:1.2em 0;padding:12px 20px}.prose code{font-family:var(--font-mono);background:var(--color-border-light);color:var(--color-primary);border-radius:4px;padding:2px 6px;font-size:.88em}.prose pre{border-radius:var(--radius-md);border:1px solid var(--color-border);margin:1.2em 0;padding:16px 20px;overflow-x:auto}.prose pre code{background:0 0;padding:0;font-size:.875em}.prose img{border-radius:var(--radius-md);margin:1.2em 0}.prose table{border-collapse:collapse;width:100%;margin:1.2em 0}.prose th,.prose td{border:1px solid var(--color-border);text-align:left;padding:10px 14px}.prose th{background:var(--color-border-light);font-weight:600}.prose hr{border:none;border-top:1px solid var(--color-border);margin:2em 0}.article-footer{border-top:1px solid var(--color-border);margin-top:32px;padding-top:24px}.article-tags-row{flex-wrap:wrap;gap:8px;margin-bottom:20px;display:flex}.post-nav{grid-template-columns:1fr 1fr;gap:12px;margin-top:24px;display:grid}.post-nav-item{border:1px solid var(--color-border);border-radius:var(--radius-md);transition:all var(--transition);flex-direction:column;gap:4px;padding:16px;display:flex}.post-nav-item:hover{border-color:var(--color-primary)}.post-nav-item.next{text-align:right}.post-nav-label{color:var(--color-text-muted);font-size:12px}.post-nav-title{color:var(--color-text);font-size:14px;font-weight:500}.archive-section{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:28px}.archive-year-header{border-bottom:2px solid var(--color-primary-bg);align-items:baseline;gap:8px;margin-bottom:16px;padding-bottom:12px;display:flex}.archive-year-header h2{color:var(--color-primary);font-size:22px;font-weight:700}.archive-year-header .archive-count{color:var(--color-text-muted);font-size:13px}.archive-month-header{color:var(--color-text-secondary);margin:16px 0 8px;font-size:14px;font-weight:600}.archive-post-list li{border-bottom:1px solid var(--color-border-light);align-items:center;gap:12px;padding:10px 0;display:flex}.archive-post-list li:last-child{border-bottom:none}.archive-post-date{font-size:13px;font-family:var(--font-mono);color:var(--color-text-muted);flex-shrink:0;width:80px}.archive-post-title{color:var(--color-text);font-size:14px}.archive-post-title a{color:inherit}.archive-post-title a:hover{color:var(--color-primary)}.category-cards{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;display:grid}.category-card{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:all var(--transition);padding:24px}.category-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-hover);transform:translateY(-2px)}.category-card .cat-icon{border-radius:var(--radius-md);background:var(--color-primary-bg);justify-content:center;align-items:center;width:44px;height:44px;margin-bottom:14px;display:flex}.category-card .cat-icon svg{width:22px;height:22px;color:var(--color-primary)}.category-card .cat-name{color:var(--color-text);margin-bottom:4px;font-size:16px;font-weight:600}.category-card .cat-count{color:var(--color-text-muted);font-size:13px}.category-card .cat-desc{color:var(--color-text-secondary);margin-top:8px;font-size:13px;line-height:1.5}.tag-cloud{flex-wrap:wrap;gap:10px;display:flex}.tag-cloud .tag{padding:6px 16px;font-size:14px}.page-header-card{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:24px;padding:28px 32px}.page-header-card h1{color:var(--color-text);margin-bottom:6px;font-size:22px;font-weight:700}.page-header-card .page-desc{color:var(--color-text-secondary);font-size:14px}.site-footer{background:var(--color-card);border-top:1px solid var(--color-border);margin-top:40px;padding:48px 0 24px}.footer-author{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);align-items:center;gap:24px;margin-bottom:28px;padding:24px;display:flex}.author-avatar{background:var(--color-card);border:2px solid var(--color-primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:72px;height:72px;display:flex;overflow:hidden}.author-avatar img{object-fit:cover;width:100%;height:100%}.author-avatar-fallback{color:var(--color-primary);font-size:28px;font-weight:600}.author-info{flex:1;min-width:0}.author-name{color:var(--color-text);margin:0 0 4px;font-size:18px;font-weight:600}.author-bio{color:var(--color-text-secondary);margin:0 0 10px;font-size:13px;line-height:1.6}.author-meta{flex-wrap:wrap;gap:10px;display:flex}.author-link{color:var(--color-text-muted);background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-sm);transition:all var(--transition);align-items:center;gap:5px;padding:4px 10px;font-size:12px;display:inline-flex}.author-link:hover{color:var(--color-primary);border-color:var(--color-primary);background:var(--color-card)}.author-link svg{flex-shrink:0;width:14px;height:14px}.footer-bottom{border-top:1px solid var(--color-border);color:var(--color-text-muted);justify-content:space-between;align-items:center;padding-top:20px;font-size:13px;display:flex}.footer-powered a{color:var(--color-text-secondary);transition:color var(--transition)}.footer-powered a:hover{color:var(--color-primary)}.footer-powered span+span:before{content:"";margin:0 6px}@media (width<=640px){.footer-author{text-align:center;flex-direction:column;gap:16px}.author-meta{justify-content:center}.footer-bottom{text-align:center;flex-direction:column;gap:12px}}.text-center{text-align:center}.mt-4{margin-top:1rem}.mt-8{margin-top:2rem}.hidden{display:none!important}.empty-state{text-align:center;color:var(--color-text-muted);padding:60px 20px}.empty-state svg{opacity:.4;width:48px;height:48px;margin:0 auto 12px}@media (width<=1024px){.featured-card{grid-template-columns:1fr}.featured-image{order:-1;min-height:200px}}@media (width<=768px){:root{--header-height:56px}.post-layout{grid-template-columns:1fr}.post-actions{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-full);box-shadow:var(--shadow-lg);z-index:100;flex-direction:row;align-items:center;gap:8px;padding:6px 10px;position:fixed;top:auto;bottom:16px;left:50%;transform:translate(-50%)}.post-actions .action-btn{width:40px;height:40px;box-shadow:none;background:0 0;border:none}.post-actions .action-btn:hover{background:var(--color-primary-bg);box-shadow:none;transform:none}.post-actions .action-share-menu{flex-direction:row;gap:4px;top:auto;bottom:52px;left:50%;transform:translate(-50%)translateY(8px)}.post-actions .action-share-menu.show{transform:translate(-50%)translateY(0)}.post-actions .share-item{flex-direction:column;gap:2px;padding:6px 10px;font-size:11px}.toc-sidebar{display:none}.header-nav{top:var(--header-height);background:var(--color-card);border-top:1px solid var(--color-border);flex-direction:column;align-items:stretch;gap:4px;padding:16px;display:none;position:fixed;bottom:0;left:0;right:0;overflow-y:auto}.header-nav.open{display:flex}.header-nav a{border-radius:var(--radius-md);padding:12px 16px;font-size:15px}.header-nav a.active:after,.header-logo .logo-tagline,.search-box .search-placeholder,.search-box .search-kbd{display:none}.menu-toggle{display:flex}.layout-grid{grid-template-columns:1fr}.sidebar{max-height:none;position:static;overflow:visible}.site-main{padding:20px 0 40px}.featured-content{padding:20px}.featured-title{font-size:20px}.article-card{padding:16px}.article-thumb{width:80px;height:64px}.article-detail{padding:24px 20px}.article-detail-cover{height:200px;margin:-24px -20px 20px}.article-detail-title{font-size:22px}.post-nav{grid-template-columns:1fr}.footer-bottom{text-align:center;flex-direction:column;gap:12px}.category-grid{grid-template-columns:1fr}.archive-post-date{width:auto;font-size:12px}}.toc-fab{background:var(--color-primary);color:#fff;border-radius:var(--radius-full);width:44px;height:44px;box-shadow:0 4px 12px color-mix(in srgb, var(--color-primary) 40%, transparent);cursor:pointer;z-index:90;transition:transform var(--transition);border:none;justify-content:center;align-items:center;display:none;position:fixed;bottom:80px;right:16px}.toc-fab:active{transform:scale(.92)}.toc-fab svg{width:22px;height:22px}.toc-drawer-mask{opacity:0;z-index:200;background:#0006;transition:opacity .25s;display:none;position:fixed;inset:0}.toc-drawer-mask.show{opacity:1}.toc-drawer{background:var(--color-card);border-top:1px solid var(--color-border);z-index:201;visibility:hidden;border-radius:16px 16px 0 0;flex-direction:column;max-height:65vh;transition:transform .28s;display:flex;position:fixed;bottom:0;left:0;right:0;transform:translateY(100%);box-shadow:0 -4px 20px #0000001a}.toc-drawer.open{visibility:visible;transform:translateY(0)}.toc-drawer-header{border-bottom:1px solid var(--color-border-light);flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.toc-drawer-title{color:var(--color-text);font-size:15px;font-weight:600}.toc-drawer-close{width:32px;height:32px;color:var(--color-text-muted);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.toc-drawer-close:hover{color:var(--color-text);background:var(--color-bg)}.toc-drawer-close svg{width:18px;height:18px}.toc-drawer-nav{-webkit-overflow-scrolling:touch;padding:12px 18px 20px;overflow-y:auto}@media (width<=768px){.toc-fab{display:flex}.toc-drawer-mask{display:block}}@media (width<=480px){.container{padding:0 14px}.article-card{flex-direction:column}.article-thumb{width:100%;height:140px}.category-cards{grid-template-columns:1fr}}
