.md3-toc-card[data-astro-cid-bis26ech]{background-color:var(--md-surface-1);border-radius:20px;border:1px solid var(--md-outline-variant);box-shadow:var(--md-shadow-1);padding:16px 0;width:100%;max-width:264px;margin:0;overflow:hidden;transition:box-shadow .28s cubic-bezier(.4,0,.2,1),transform .28s cubic-bezier(.4,0,.2,1)}.md3-toc-card[data-astro-cid-bis26ech]:hover{box-shadow:var(--md-shadow-3);transform:translateY(-2px)}.md3-toc-header[data-astro-cid-bis26ech]{display:flex;align-items:center;gap:10px;padding:0 16px 12px;color:var(--md-primary)}.md3-toc-title[data-astro-cid-bis26ech]{font-family:var(--md-font);font-size:var(--md-title-medium);font-weight:500;color:var(--md-on-surface);margin:0;flex:1}.md3-toc-badge[data-astro-cid-bis26ech]{font-size:var(--md-label-small);font-weight:500;color:var(--md-on-surface-variant);background:var(--md-surface-variant);padding:2px 8px;border-radius:9999px}.md3-toc-nav[data-astro-cid-bis26ech]{display:flex;flex-direction:column;gap:4px;max-height:340px;overflow-y:auto;padding:0 10px 0 12px}.md3-toc-link[data-astro-cid-bis26ech]{display:block;padding:8px 12px;padding-left:calc(12px + (var(--toc-depth) - 2) * 14px);border-radius:12px;color:var(--md-on-surface-variant);font-size:var(--md-body-medium);line-height:1.5;text-decoration:none;transform-origin:left center;transition:color .18s ease,background-color .18s ease,transform .18s ease}.md3-toc-link[data-astro-cid-bis26ech]:hover{color:var(--md-primary);background:color-mix(in srgb,var(--md-primary) 10%,transparent);transform:scale(1.03);text-decoration:none}.md3-toc-link-text[data-astro-cid-bis26ech]{display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;overflow:hidden;word-break:break-word}.md3-toc-nav[data-astro-cid-bis26ech]::-webkit-scrollbar{width:4px}.md3-toc-nav[data-astro-cid-bis26ech]::-webkit-scrollbar-thumb{background:var(--md-outline-variant);border-radius:9999px}.md3-post-root{min-height:100vh;display:flex;flex-direction:column;background-color:var(--md-background)}.md3-post-main{flex:1;width:100%;max-width:1440px;margin:0 auto;padding:32px 24px 64px}.md3-post-columns{display:flex;gap:24px;align-items:flex-start}.md3-post-article-wrap{flex:1;min-width:0;margin-left:12px}.md3-post-sidebar{width:280px;flex-shrink:0;display:flex;flex-direction:column;align-items:flex-start;gap:16px;position:sticky;top:88px}.md3-post-sidebar>*{margin-left:-8px}@media (max-width: 1024px){.md3-post-sidebar{display:none}}@media (max-width: 600px){.md3-post-main{padding:16px 12px 48px}}.md3-article-card{background-color:var(--md-surface);border-radius:var(--md-shape-xl);border:1px solid var(--md-outline-variant);box-shadow:var(--md-shadow-1);overflow:hidden}.md3-cover-wrap{width:100%;max-height:420px;overflow:hidden;background:var(--md-surface-variant)}.md3-cover-wrap img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;border-radius:0;display:block;transition:transform .5s cubic-bezier(.4,0,.2,1)}.md3-cover-wrap:hover img{transform:scale(1.02)}.md3-post-meta{padding:24px 32px 0;display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}.md3-post-tags{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.md3-post-tag{display:inline-flex;align-items:center;gap:4px;padding:4px 12px;border-radius:var(--md-shape-sm);border:1px solid var(--md-outline-variant);background:var(--md-surface-1);color:var(--md-on-surface-variant);font-size:var(--md-label-large);font-weight:500;text-decoration:none;transition:background .15s,color .15s}.md3-post-tag:hover{background:var(--md-secondary-container);color:var(--md-on-secondary-container);border-color:transparent;text-decoration:none}.md3-post-category{display:inline-flex;align-items:center;gap:6px;padding:6px 16px;border-radius:var(--md-shape-full);background:var(--md-tertiary-container);color:var(--md-on-tertiary-container);font-size:var(--md-label-large);font-weight:500}.md3-post-ai-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 16px;border-radius:var(--md-shape-full);background:var(--md-primary-container);color:var(--md-on-primary-container);font-size:var(--md-label-large);font-weight:500}.md3-post-views{display:inline-flex;align-items:center;gap:6px;font-size:var(--md-label-large);color:var(--md-on-surface-variant)}.md3-post-date{font-size:var(--md-body-medium);color:var(--md-on-surface-variant);line-height:1.5}.md3-post-date-updated{font-style:italic;font-size:var(--md-body-small);color:var(--md-on-surface-variant)}.md3-post-title-wrap{padding:16px 32px 0;text-align:center}.md3-post-title{font-family:var(--md-font);font-size:var(--md-headline-medium);font-weight:700;color:var(--md-on-surface);line-height:1.3;margin:0 0 24px;letter-spacing:-.25px}.md3-post-title-divider{height:2px;width:64px;background:var(--md-primary);border-radius:1px;margin:0 auto 24px;opacity:.6}.md3-post-content{padding:0 40px 48px;color:var(--md-on-surface);font-size:var(--md-body-large);line-height:1.8}.md3-table-wrap{overflow-x:auto;margin:1.5rem 0;border-radius:var(--md-shape-sm);border:1px solid var(--md-outline-variant)}.md3-copy-btn{position:absolute;top:8px;right:12px;z-index:10;background:#ffffff1f;color:#cdd6f4;border:1px solid rgba(255,255,255,.15);border-radius:6px;padding:3px 10px;font-size:12px;cursor:pointer;font-family:var(--md-font-mono);transition:background .2s}.md3-copy-btn:hover{background:#ffffff38}.md3-copy-btn.is-copied{background:#1a73e880}@media (max-width: 600px){.md3-post-meta{padding:20px 16px 0}.md3-post-title-wrap{padding:16px 16px 0}.md3-post-content{padding:0 16px 32px}.md3-post-title{font-size:var(--md-headline-small)}}.md3-post-content h1{font-size:var(--md-headline-medium);margin-top:2rem}.md3-post-content h2{font-size:var(--md-headline-small);margin-top:2rem;padding-bottom:8px;border-bottom:1px solid var(--md-outline-variant)}.md3-post-content h3{font-size:var(--md-title-large);margin-top:1.5rem}.md3-post-content h4{font-size:var(--md-title-medium);margin-top:1.25rem}.md3-post-content h5,.md3-post-content h6{font-size:var(--md-title-small);margin-top:1rem}.md3-post-content p code,.md3-post-content li code,.md3-post-content blockquote code{background:var(--md-surface-variant);color:var(--md-error);padding:2px 6px;border-radius:var(--md-shape-xs);font-size:.875em;font-family:var(--md-font-mono)}.md3-post-content pre{background:#1e1e2e;border-radius:var(--md-shape-md);padding:1.5em;overflow-x:auto;margin:1.5rem 0;position:relative}.md3-post-content pre:after{content:"";position:absolute;top:10px;left:14px;width:10px;height:10px;border-radius:50%;background:#ff5f57;box-shadow:18px 0 #febc2e,36px 0 #28c840}.md3-post-content pre>code{all:unset;display:block;color:#cdd6f4;line-height:1.6;font-family:var(--md-font-mono);font-size:var(--md-body-medium);padding-top:16px}.md3-post-content img{border-radius:var(--md-shape-md);box-shadow:var(--md-shadow-2);margin:1.5rem auto;cursor:zoom-in}.md3-post-content blockquote{border-left:4px solid var(--md-primary);background:var(--md-primary-container);border-radius:0 var(--md-shape-sm) var(--md-shape-sm) 0;color:var(--md-on-primary-container);padding:16px 20px;margin:1.5rem 0;font-size:var(--md-body-large)}.dark .md3-post-content blockquote{background:var(--md-surface-2);color:var(--md-on-surface)}.md3-post-content table{width:100%;border-collapse:collapse;font-size:var(--md-body-medium);margin:1.5rem 0}.md3-post-content th{background:var(--md-surface-variant);font-weight:500;color:var(--md-on-surface-variant)}.md3-post-content th,.md3-post-content td{border:1px solid var(--md-outline-variant);padding:10px 14px;text-align:left}.md3-post-content ul,.md3-post-content ol{margin:1.5rem 0;padding-left:2rem}.md3-post-content ul{list-style-type:disc}.md3-post-content ol{list-style-type:decimal}.md3-post-content li{margin:.5rem 0;line-height:1.8}.md3-post-content li p{margin:.5rem 0}.md3-post-content ul ul,.md3-post-content ol ol,.md3-post-content ul ol,.md3-post-content ol ul{margin:.5rem 0;padding-left:1.5rem}.giscus[data-astro-cid-an2nl7ar]{margin-top:2rem;min-height:120px}
