@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500&display=swap";nav[data-astro-cid-dmqpwcec]{display:flex;align-items:center;justify-content:space-between;max-width:1080px;margin:0 auto;padding:20px 32px;border-bottom:1px solid var(--border)}.nav-brand[data-astro-cid-dmqpwcec]{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--text-primary)}.nav-brand[data-astro-cid-dmqpwcec]:hover{color:var(--text-primary)}.nav-avatar[data-astro-cid-dmqpwcec]{width:36px;height:36px;border-radius:50%;object-fit:cover}.nav-name[data-astro-cid-dmqpwcec]{font-weight:700;font-size:15px}.nav-right[data-astro-cid-dmqpwcec]{display:flex;align-items:center;gap:24px}.nav-links[data-astro-cid-dmqpwcec]{display:flex;gap:28px}.nav-links[data-astro-cid-dmqpwcec] a[data-astro-cid-dmqpwcec]{text-decoration:none;color:var(--text-secondary);font-size:14px;font-weight:500;transition:color .15s}.nav-links[data-astro-cid-dmqpwcec] a[data-astro-cid-dmqpwcec]:hover,.nav-links[data-astro-cid-dmqpwcec] a[data-astro-cid-dmqpwcec].active{color:var(--accent)}footer[data-astro-cid-sz7xmlte]{max-width:1080px;margin:60px auto 0;padding:24px 32px;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;font-size:13px;color:var(--text-secondary)}.footer-links[data-astro-cid-sz7xmlte] a[data-astro-cid-sz7xmlte]{color:var(--accent);text-decoration:none}.dot[data-astro-cid-sz7xmlte]{margin:0 4px}:root{--bg: #fafaf9;--bg-surface: #ffffff;--text-primary: #1c1917;--text-secondary: #78716c;--accent: #0d9488;--accent-secondary: #2563eb;--border: #e7e5e4;--code-bg: #1c1917;--tag-bg: rgba(13, 148, 136, .08);--tag-border: rgba(13, 148, 136, .2)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased}a{color:var(--accent);text-decoration:none;transition:color .15s}a:hover{color:var(--accent-secondary)}code,pre{font-family:JetBrains Mono,monospace}pre{background:var(--code-bg);color:#e2e8f0;border-radius:10px;padding:24px;font-size:13px;line-height:1.7;overflow-x:auto}code:not(pre code){background:#0d948814;color:var(--accent);padding:2px 6px;border-radius:4px;font-size:.9em}img{max-width:100%;height:auto}h1,h2,h3,h4{color:var(--text-primary);line-height:1.3}h1{font-size:2.25rem;font-weight:800}h2{font-size:1.5rem;font-weight:700}h3{font-size:1.25rem;font-weight:600}blockquote{border-left:3px solid var(--accent);padding:2px 0 2px 20px;margin:24px 0;font-size:1.05rem;color:var(--text-secondary);font-style:italic;line-height:1.7}hr{border:none;border-top:1px solid var(--border);margin:2rem 0}table{width:100%;border-collapse:collapse;margin:1.5rem 0}th,td{padding:10px 14px;border-bottom:1px solid var(--border);text-align:left;font-size:.9rem}th{font-weight:600;color:var(--text-secondary);font-size:.8rem;text-transform:uppercase;letter-spacing:.05em}.tag-filter-bar{display:flex;gap:8px;padding:20px 0;flex-wrap:wrap}.filter-tag{font-size:12px;font-weight:500;padding:5px 14px;border-radius:99px;border:1px solid var(--border);background:transparent;color:var(--text-secondary);cursor:pointer;font-family:inherit;transition:all .15s}.filter-tag:hover{border-color:var(--accent);color:var(--accent)}.filter-tag.active{background:var(--accent);color:#fff;border-color:var(--accent)}.posts-list .post-cover{width:160px;height:100px;object-fit:cover;border-radius:8px;flex-shrink:0}.posts-list .post-card{display:flex;gap:20px;align-items:flex-start;padding:24px 0;border-bottom:1px solid var(--border);text-decoration:none;color:inherit;transition:background .15s}.posts-list .post-card:hover{background:#0d948805;margin:0 -16px;padding:24px 16px;border-radius:8px}.posts-list .post-card-body{flex:1;min-width:0}.posts-list .post-meta{display:flex;align-items:center;gap:12px;margin-bottom:8px}.posts-list .post-date,.posts-list .post-reading{font-size:13px;color:var(--text-secondary)}.posts-list .post-meta-dot{color:var(--border);font-size:10px}.posts-list h3{font-size:20px;font-weight:700;margin-bottom:6px;line-height:1.35}.posts-list p{font-size:15px;color:var(--text-secondary);line-height:1.6;max-width:680px}.posts-list .post-tags{display:flex;gap:6px;margin-top:10px;flex-wrap:wrap}:root{--callout-info-bg: rgba(13, 148, 136, .06);--callout-info-border: #0d9488;--callout-warning-bg: rgba(217, 119, 6, .06);--callout-warning-border: #d97706;--callout-tip-bg: rgba(37, 99, 235, .06);--callout-tip-border: #2563eb;--callout-insight-bg: rgba(124, 58, 237, .06);--callout-insight-border: #7c3aed}.callout{border-left:3px solid var(--callout-info-border);background:var(--callout-info-bg);border-radius:0 8px 8px 0;padding:16px 20px;margin:24px 0;max-width:680px}.callout-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;color:var(--callout-info-border)}.callout-content{font-size:16px;line-height:1.7;color:#292524}.callout-content p{margin:0}.callout-content p+p{margin-top:8px}.callout.warning{border-left-color:var(--callout-warning-border);background:var(--callout-warning-bg)}.callout.warning .callout-label{color:var(--callout-warning-border)}.callout.tip{border-left-color:var(--callout-tip-border);background:var(--callout-tip-bg)}.callout.tip .callout-label{color:var(--callout-tip-border)}.callout.insight{border-left-color:var(--callout-insight-border);background:var(--callout-insight-bg)}.callout.insight .callout-label{color:var(--callout-insight-border)}.expandable{border:1px solid var(--border);border-radius:8px;margin:24px 0;max-width:680px;overflow:hidden}.expandable-trigger{display:flex;align-items:center;justify-content:space-between;width:100%;padding:14px 20px;background:var(--bg-surface);border:none;cursor:pointer;font-family:inherit;font-size:15px;font-weight:600;color:var(--text-primary);text-align:left;transition:background .15s}.expandable-trigger:hover{background:var(--bg)}.expandable-arrow{font-size:12px;color:var(--accent);transition:transform .2s}.expandable-arrow.open{transform:rotate(90deg)}.expandable-body{padding:0 20px 16px;font-size:16px;line-height:1.7;color:#292524}.expandable-body p{margin:0 0 8px}.code-comparison{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:24px 0;max-width:680px}.code-comparison-panel{min-width:0}.code-comparison-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);margin-bottom:6px;padding-left:4px}.code-comparison-panel pre{font-size:12px;padding:16px;margin:0}@media(max-width:640px){.code-comparison{grid-template-columns:1fr}}.copy-code-block{position:relative;margin:24px 0;max-width:680px}.copy-code-block pre{margin:0}.copy-code-header{display:flex;align-items:center;justify-content:space-between;background:#141e30;padding:8px 16px;border-radius:10px 10px 0 0;border-bottom:1px solid rgba(255,255,255,.08)}.copy-code-header+pre{border-radius:0 0 10px 10px}.copy-code-filename{font-family:JetBrains Mono,monospace;font-size:12px;color:#94a3b8}.copy-code-btn{background:transparent;border:1px solid rgba(255,255,255,.15);border-radius:4px;padding:3px 10px;font-size:11px;color:#94a3b8;cursor:pointer;font-family:inherit;transition:all .15s}.copy-code-btn:hover,.copy-code-btn.copied{border-color:var(--accent);color:var(--accent)}.toc{padding-top:4px}.toc-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--text-secondary);margin-bottom:12px;padding-left:12px}.toc-list{list-style:none;padding:0;margin:0}.toc-item{margin:0}.toc-indent{padding-left:12px}.toc-link{display:block;padding:4px 12px;font-size:13px;line-height:1.4;color:var(--text-secondary);text-decoration:none;border-left:2px solid transparent;transition:all .15s}.toc-link:hover{color:var(--text-primary)}.toc-link.active{color:var(--accent);border-left-color:var(--accent);font-weight:500}.search-trigger{display:flex;align-items:center;gap:8px;background:transparent;border:1px solid var(--border);border-radius:6px;padding:5px 10px;color:var(--text-secondary);cursor:pointer;font-family:inherit;font-size:13px;transition:all .15s}.search-trigger:hover{border-color:var(--accent);color:var(--accent)}.search-shortcut{display:flex;gap:3px}.search-shortcut kbd{font-family:inherit;font-size:11px;padding:1px 5px;border-radius:3px;background:var(--bg);border:1px solid var(--border);color:var(--text-secondary)}.search-overlay{position:fixed;inset:0;background:#0006;z-index:1000;display:flex;align-items:flex-start;justify-content:center;padding-top:120px}.search-modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;width:560px;max-width:90vw;max-height:70vh;overflow:hidden;box-shadow:0 16px 48px #00000026}.search-input-wrapper{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--border);color:var(--text-secondary)}.search-input{flex:1;border:none;outline:none;font-size:16px;font-family:inherit;color:var(--text-primary);background:transparent}.search-input::placeholder{color:var(--text-secondary)}.search-esc{font-family:inherit;font-size:11px;padding:2px 6px;border-radius:3px;background:var(--bg);border:1px solid var(--border);color:var(--text-secondary)}.search-results{list-style:none;padding:0;margin:0;max-height:calc(70vh - 60px);overflow-y:auto}.search-result{display:block;padding:12px 16px;text-decoration:none;color:inherit;border-bottom:1px solid var(--border);transition:background .1s}.search-result:hover{background:var(--bg)}.search-result-title{display:block;font-size:15px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.search-result-excerpt{display:block;font-size:13px;color:var(--text-secondary);line-height:1.5}.search-result-excerpt mark{background:#0d948826;color:var(--accent);padding:0 2px;border-radius:2px}.search-empty{padding:24px 16px;text-align:center;color:var(--text-secondary);font-size:14px}.lightbox-overlay{position:fixed;inset:0;background:#0f1729eb;z-index:2000;display:flex;align-items:center;justify-content:center;padding:5vh 5vw;cursor:zoom-out;animation:lightbox-fade-in .2s ease-out}@keyframes lightbox-fade-in{0%{opacity:0}to{opacity:1}}.lightbox-image{max-width:100%;max-height:100%;object-fit:contain;border-radius:8px;box-shadow:0 20px 60px #0006;cursor:default}.lightbox-close{position:fixed;top:20px;right:28px;background:transparent;border:none;color:#fff;font-size:36px;line-height:1;cursor:pointer;padding:6px 14px;opacity:.7;transition:opacity .15s;font-family:inherit}.lightbox-close:hover{opacity:1}main[data-astro-cid-37fxchfa]{max-width:1080px;margin:0 auto;padding:0 32px}
