*{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;line-height:1.65;color:#1a1a2e;background-color:#fff;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:#4169E1;text-decoration:none;transition:color 0.15s ease}a:hover{color:#2A4ABD}.wrapper{max-width:820px;margin:0 auto;padding:0 30px}.site-header{border-bottom:1px solid #e5e7eb;padding:18px 0;background:#fff;position:sticky;top:0;z-index:100}.site-header .wrapper{display:flex;justify-content:space-between;align-items:center}.site-title{font-size:1.35rem;font-weight:700;color:#1a1a2e;text-decoration:none;letter-spacing:-0.02em}.site-title:hover{color:#4169E1}.site-nav{display:flex;gap:21px}.site-nav a{color:#374151;text-decoration:none;font-size:0.9rem;font-weight:500;padding-bottom:2px;border-bottom:2px solid transparent;transition:color 0.15s ease, border-color 0.15s ease}.site-nav a:hover,.site-nav a.active{color:#4169E1;border-bottom-color:#4169E1}.page-content{padding:45px 0;min-height:calc(100vh - 200px)}.hero{text-align:center;padding:45px 0 30px;border-bottom:1px solid #e5e7eb;margin-bottom:45px}.hero-title{font-size:2.75rem;font-weight:800;letter-spacing:-0.03em;margin-bottom:12px;background:linear-gradient(135deg, #4169E1, #6B8DF5);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-description{font-size:1.15rem;color:#6b7280;max-width:600px;margin:0 auto 18px;line-height:1.6}.hero-stats{display:flex;justify-content:center;align-items:center;gap:12px;font-size:0.9rem;color:#6b7280}.hero-stats .stat{font-weight:600;color:#1a1a2e}.hero-stats .stat-sep{color:#e5e7eb}.features-bar{display:flex;flex-wrap:wrap;gap:9px;justify-content:center;margin-bottom:45px}.feature-pill{display:inline-block;padding:6px 16px;background:#f8f9fb;border:1px solid #e5e7eb;border-radius:20px;font-size:0.8rem;font-weight:500;color:#374151}.section{margin-bottom:45px}.section-title{font-size:1.4rem;font-weight:700;letter-spacing:-0.01em;margin-bottom:21px;padding-bottom:9px;border-bottom:2px solid #4169E1;display:inline-block}.post-cards{display:flex;flex-direction:column;gap:21px}.post-card,.post-card--featured{border:1px solid #e5e7eb;border-radius:8px;padding:21px;transition:border-color 0.15s ease, box-shadow 0.15s ease;background:#fff}.post-card:hover,.post-card--featured:hover{border-color:#6B8DF5;box-shadow:0 2px 12px rgba(65,105,225,0.08)}.post-card-meta{display:flex;flex-wrap:wrap;align-items:center;gap:9px;font-size:0.8rem;color:#6b7280;margin-bottom:9px}.post-card-meta time{font-weight:500}.post-card-title{font-size:1.2rem;line-height:1.35;margin-bottom:7.5px}.post-card-title a{color:#1a1a2e;text-decoration:none}.post-card-title a:hover{color:#4169E1}.post-card-excerpt{font-size:0.92rem;color:#555;line-height:1.55;margin-bottom:9px}.post-card-tags{display:flex;flex-wrap:wrap;gap:6px}.post-list-compact{display:flex;flex-direction:column}.post-row{display:flex;align-items:center;gap:15px;padding:9px 0;border-bottom:1px solid #e5e7eb}.post-row:last-child{border-bottom:none}.post-row time{flex-shrink:0;font-size:0.8rem;color:#6b7280;font-weight:500;width:50px}.post-row .post-row-title{color:#1a1a2e;font-weight:500;font-size:0.95rem;flex:1}.post-row .post-row-title:hover{color:#4169E1}.category-badge{display:inline-block;padding:2px 10px;background:linear-gradient(135deg, #4169E1, #6B8DF5);color:#fff;border-radius:12px;font-size:0.72rem;font-weight:600;text-transform:uppercase;letter-spacing:0.03em;text-decoration:none}.category-badge--sm{padding:1px 8px;font-size:0.68rem}.tag{display:inline-block;background:#f8f9fb;border:1px solid #e5e7eb;padding:2px 10px;border-radius:4px;font-size:0.8rem;color:#374151;margin-right:4px}.tag-sm{display:inline-block;background:#f8f9fb;border:1px solid #e5e7eb;padding:1px 8px;border-radius:4px;font-size:0.72rem;color:#6b7280}.reading-time{font-size:0.8rem;color:#6b7280;font-style:italic}.word-count{font-size:0.8rem;color:#6b7280}.index-columns{display:grid;grid-template-columns:1fr 1fr;gap:30px;margin-bottom:30px}.index-col{margin-bottom:0}.category-list{list-style:none}.category-list li{margin-bottom:2px}.category-list a{display:flex;justify-content:space-between;align-items:center;padding:7.5px 10.5px;border-radius:4px;color:#1a1a2e;text-decoration:none;transition:background 0.1s ease}.category-list a:hover{background:#f8f9fb;color:#4169E1}.category-list .category-name{font-weight:500;text-transform:capitalize}.category-list .category-count{font-size:0.8rem;color:#6b7280;background:#f8f9fb;padding:1px 8px;border-radius:10px;font-weight:600}.tag-cloud{display:flex;flex-wrap:wrap;gap:8px}.tag-cloud-item{display:inline-block;padding:4px 12px;background:#f8f9fb;border:1px solid #e5e7eb;border-radius:16px;font-size:0.8rem;color:#374151;text-decoration:none;transition:background 0.1s ease, border-color 0.1s ease}.tag-cloud-item:hover{background:#4169E1;color:#fff;border-color:#4169E1}.tag-cloud-item:hover sup{color:rgba(255,255,255,0.8)}.tag-cloud-item sup{font-size:0.65rem;color:#6b7280;margin-left:2px}.tag-cloud-item--lg{font-size:0.9rem;font-weight:600;padding:5px 14px}.archive-month{margin-bottom:15px}.archive-month-title{font-size:1rem;font-weight:600;margin-bottom:6px}.archive-month-count{font-size:0.8rem;color:#6b7280;font-weight:400}.archive-list{list-style:none}.archive-list li{display:flex;align-items:center;gap:12px;padding:4.5px 0;font-size:0.92rem}.archive-list li time{flex-shrink:0;color:#6b7280;font-size:0.8rem;width:50px}.archive-list li a{color:#1a1a2e}.archive-list li a:hover{color:#4169E1}.archive-link{margin-top:15px;font-size:0.9rem;font-weight:500}.subscribe-section{text-align:center;padding:30px;background:#f8f9fb;border-radius:8px;border:1px solid #e5e7eb}.subscribe-section p{color:#6b7280;margin-bottom:15px;font-size:0.95rem}.subscribe-section .section-title{display:block;border-bottom:none;padding-bottom:0;margin-bottom:9px}.subscribe-btn{display:inline-block;padding:10px 28px;background:#4169E1;color:#fff;border-radius:8px;font-weight:600;font-size:0.9rem;text-decoration:none;transition:background 0.15s ease}.subscribe-btn:hover{background:#2A4ABD;color:#fff}.archive-page .page-header,.categories-page .page-header{margin-bottom:45px}.archive-page .page-title,.categories-page .page-title{font-size:2.25rem;font-weight:800;letter-spacing:-0.02em;margin-bottom:6px}.archive-page .page-subtitle,.categories-page .page-subtitle{font-size:1rem;color:#6b7280}.archive-year{margin-bottom:45px}.archive-year-title{font-size:1.5rem;font-weight:700;margin-bottom:15px;padding-bottom:6px;border-bottom:2px solid #e5e7eb}.archive-year-count{font-size:0.85rem;color:#6b7280;font-weight:400}.archive-posts{display:flex;flex-direction:column}.archive-entry{display:flex;gap:18px;padding:15px 0;border-bottom:1px solid #e5e7eb}.archive-entry:last-child{border-bottom:none}.archive-entry-date{flex-shrink:0;width:60px}.archive-entry-date time{font-size:0.8rem;color:#6b7280;font-weight:500}.archive-entry-content{flex:1}.archive-entry-title{font-size:1.05rem;font-weight:600;margin-bottom:4px}.archive-entry-title a{color:#1a1a2e}.archive-entry-title a:hover{color:#4169E1}.archive-entry-meta{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin-bottom:4px}.archive-entry-excerpt{font-size:0.88rem;color:#555;line-height:1.5;margin-top:4px}.category-nav{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:45px;padding-bottom:21px;border-bottom:1px solid #e5e7eb}.category-nav-item{display:inline-flex;align-items:center;gap:6px;padding:6px 16px;background:#f8f9fb;border:1px solid #e5e7eb;border-radius:20px;font-size:0.85rem;font-weight:500;color:#1a1a2e;text-decoration:none;text-transform:capitalize;transition:background 0.15s ease, border-color 0.15s ease}.category-nav-item:hover{background:#4169E1;color:#fff;border-color:#4169E1}.category-nav-item:hover .category-nav-count{background:rgba(255,255,255,0.25);color:#fff}.category-nav-count{font-size:0.72rem;font-weight:600;background:#e5e7eb;padding:1px 7px;border-radius:10px;color:#6b7280}.category-section{margin-bottom:45px}.category-section-title{font-size:1.35rem;font-weight:700;text-transform:capitalize;margin-bottom:15px;padding-bottom:6px;border-bottom:2px solid #4169E1}.category-section-count{font-size:0.85rem;color:#6b7280;font-weight:400;margin-left:8px}.category-posts{display:flex;flex-direction:column}.category-post{display:flex;gap:18px;padding:15px 0;border-bottom:1px solid #e5e7eb}.category-post:last-child{border-bottom:none}.category-post-date{flex-shrink:0;width:90px}.category-post-date time{font-size:0.8rem;color:#6b7280;font-weight:500}.category-post-body{flex:1}.category-post-body h3{font-size:1.05rem;font-weight:600;margin-bottom:4px}.category-post-body h3 a{color:#1a1a2e}.category-post-body h3 a:hover{color:#4169E1}.category-post-excerpt{font-size:0.88rem;color:#555;line-height:1.5;margin-bottom:6px}.category-post-tags{display:flex;flex-wrap:wrap;gap:4px}.back-link{margin-top:45px;padding-top:21px;border-top:1px solid #e5e7eb}.back-link a{font-weight:500;font-size:0.9rem}.post-breadcrumb{font-size:0.85rem;margin-bottom:30px;color:#6b7280}.post-breadcrumb a{color:#6b7280}.post-breadcrumb a:hover{color:#4169E1}.post-header{margin-bottom:30px}.post-title{font-size:2.25rem;line-height:1.2;font-weight:800;letter-spacing:-0.02em;margin-bottom:12px}.post-meta-bar{display:flex;flex-wrap:wrap;align-items:center;gap:4px;color:#6b7280;font-size:0.85rem;margin-bottom:9px}.meta-sep{color:#e5e7eb;margin:0 4px}.post-categories-bar{margin-bottom:9px;display:flex;gap:6px}.post-tags-bar{display:flex;flex-wrap:wrap;gap:6px}.toc{margin-bottom:30px;background:#f8f9fb;border:1px solid #e5e7eb;border-radius:8px;padding:15px 21px}.toc-title{font-weight:700;font-size:0.9rem;cursor:pointer;color:#1a1a2e;user-select:none}.toc-title:hover{color:#4169E1}.toc-list{list-style:none;margin-top:10.5px;padding-left:15px}.toc-list li{margin-bottom:4px;font-size:0.88rem;line-height:1.5;position:relative;padding-left:12px}.toc-list li::before{content:"";position:absolute;left:0;top:9px;width:4px;height:4px;border-radius:50%;background:#e5e7eb}.toc-list a{color:#374151}.toc-list a:hover{color:#4169E1}.post-content h2{font-size:1.6rem;font-weight:700;margin:45px 0 15px;padding-bottom:6px;border-bottom:1px solid #e5e7eb}.post-content h3{font-size:1.2rem;font-weight:600;margin:30px 0 12px}.post-content h4{font-size:1.05rem;font-weight:600;margin:24px 0 9px}.post-content p{margin-bottom:16.5px}.post-content ul,.post-content ol{margin-left:30px;margin-bottom:16.5px}.post-content li{margin-bottom:4px}.post-content pre{background:#1e1e2e;color:#cdd6f4;padding:18px;border-radius:8px;overflow-x:auto;margin-bottom:18px;font-size:0.88rem;line-height:1.5}.post-content code{font-family:"SF Mono",Monaco,"Cascadia Code","Courier New",monospace;font-size:0.88em}.post-content p>code,.post-content li>code{background:#f8f9fb;border:1px solid #e5e7eb;padding:1px 6px;border-radius:4px;font-size:0.85em;color:#2A4ABD}.post-content img{max-width:100%;height:auto;border-radius:8px}.post-content blockquote{border-left:4px solid #4169E1;padding:12px 18px;margin:15px 0;background:rgba(65,105,225,0.04);border-radius:0 4px 4px 0;color:#555;font-style:italic}.post-content blockquote p:last-child{margin-bottom:0}.post-content>h2+blockquote,.post-content>h3+blockquote{background:rgba(5,150,105,0.06);border-left-color:#059669}.post-content table{width:100%;border-collapse:collapse;margin-bottom:18px;font-size:0.9rem}.post-content table th{background:#f8f9fb;font-weight:600;text-align:left;padding:8px 12px;border-bottom:2px solid #e5e7eb}.post-content table td{padding:8px 12px;border-bottom:1px solid #e5e7eb}.post-content table tr:hover td{background:rgba(65,105,225,0.02)}.post-content hr{border:none;border-top:1px solid #e5e7eb;margin:30px 0}.post-content blockquote strong{color:#1a1a2e}.post-footer{margin-top:30px;padding-top:15px;border-top:1px solid #e5e7eb}.post-footer-tags{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.post-footer-tags strong{font-size:0.85rem;color:#6b7280;margin-right:4px}.post-nav{display:grid;grid-template-columns:1fr 1fr;gap:15px;margin-top:36px;padding-top:24px;border-top:1px solid #e5e7eb}.post-nav-item{display:flex;flex-direction:column;padding:15px;border:1px solid #e5e7eb;border-radius:8px;text-decoration:none;transition:border-color 0.15s ease, background 0.15s ease}.post-nav-item:hover{border-color:#6B8DF5;background:rgba(65,105,225,0.02)}.post-nav-prev{text-align:left}.post-nav-next{text-align:right}.post-nav-empty{border-color:transparent}.post-nav-empty:hover{background:none;border-color:transparent}.post-nav-label{font-size:0.75rem;color:#6b7280;text-transform:uppercase;letter-spacing:0.05em;font-weight:600;margin-bottom:4px}.post-nav-title{font-size:0.9rem;font-weight:600;color:#1a1a2e;line-height:1.35}.site-footer{border-top:1px solid #e5e7eb;padding:21px 0;text-align:center;color:#6b7280;font-size:0.85rem}.site-footer p{margin-bottom:4px}.site-footer a{color:#6b7280}.site-footer a:hover{color:#4169E1}@media (max-width: 700px){.site-header .wrapper{flex-direction:column;text-align:center}.site-nav{margin-top:9px;gap:12px;flex-wrap:wrap;justify-content:center}.hero-title{font-size:2rem}.hero-description{font-size:1rem}.index-columns{grid-template-columns:1fr;gap:15px}.post-title{font-size:1.6rem}.post-nav{grid-template-columns:1fr}.post-meta-bar{font-size:0.78rem}.archive-entry,.category-post{flex-direction:column;gap:4px}.archive-entry-date,.category-post-date{width:auto}.features-bar{gap:6px}.feature-pill{font-size:0.72rem;padding:4px 10px}}.post-content{color:#1a1a2e}.post-content h2,.post-content h3,.post-content h4{position:relative}.post-content h2 a.header-link,.post-content h3 a.header-link,.post-content h4 a.header-link{position:absolute;left:-1.5em;opacity:0;font-weight:400;color:#e5e7eb;text-decoration:none;transition:opacity 0.15s ease, color 0.15s ease}.post-content h2 a.header-link:hover,.post-content h3 a.header-link:hover,.post-content h4 a.header-link:hover{opacity:1;color:#4169E1}.post-content h2:hover a.header-link,.post-content h3:hover a.header-link,.post-content h4:hover a.header-link{opacity:0.6}.post-content p,.post-content li,.post-content td,.post-content th,.post-content blockquote,.post-content dd,.post-content dt,.post-content figcaption{color:inherit}.post-content img{cursor:zoom-in;transition:transform 0.2s ease, box-shadow 0.2s ease}.post-content img:hover{box-shadow:0 4px 20px rgba(0,0,0,0.12)}.lightbox-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.85);z-index:9999;display:flex;align-items:center;justify-content:center;cursor:zoom-out;animation:fadeIn 0.2s ease}.lightbox-overlay img{max-width:90vw;max-height:90vh;border-radius:4px;box-shadow:0 8px 40px rgba(0,0,0,0.4);cursor:zoom-out}@keyframes fadeIn{from{opacity:0}to{opacity:1}}.mermaid{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:1.5rem 1rem;margin:1.5rem 0;text-align:center;overflow-x:auto}.mermaid svg{max-width:100%;height:auto}
