:root{--max-width: 840px;--fg: #1f2937;--bg: #ffffff;--muted: #6b7280;--link: #0366d6;--code-bg: #0d1117;--code-inline-bg: #f6f8fa;--code-inline-fg: inherit;--tag-bg: #f1f5f9;--tag-fg: #334155;--copy-btn-bg: #ffffffaa;--copy-btn-fg: #334155;--toc-bg: #ffffffcc;--toc-border: #e5e7eb}html,body{margin:0;padding:0;color:var(--fg);background:var(--bg);font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji",sans-serif;line-height:1.65}.container{max-width:var(--max-width);margin:0 auto;padding:1rem}.site-header{border-bottom:1px solid #eee}.site-footer{border-top:1px solid #eee;margin-top:3rem;position:relative;z-index:2}.site-footer>.container{text-align:center}.header-inner,.footer-inner{display:flex;align-items:center;justify-content:space-between}.brand{font-weight:700;text-decoration:none;color:inherit}.nav a{margin-left:1rem;text-decoration:none;color:inherit}.nav a i{margin-right:.35rem}.nav a:hover{text-decoration:underline}.footer-icons{position:absolute;right:1rem;top:50%;transform:translateY(-50%);display:flex;align-items:center}.footer-icons a{margin-left:.75rem;text-decoration:none;color:inherit}.footer-icons a:hover{color:var(--link)}.footer-icons svg{width:1.25rem;height:1.25rem;display:block;fill:currentColor}.footer-icons i{font-size:1.25rem;display:block}.site-footer>.container{padding-right:3.5rem}a{color:var(--link)}code{background:var(--code-inline-bg);color:var(--code-inline-fg);padding:.1rem .3rem;border-radius:4px}pre{background:var(--code-bg);padding:1rem;border-radius:8px;overflow:auto;position:relative}.astro-code,.astro-code code,.astro-code .line{background:var(--code-bg)}.astro-code span{background-color:inherit}.astro-code-themes,.astro-code-themes code,.astro-code-themes .line{background-color:var(--shiki-dark-bg, #24292e)!important;color:var(--shiki-dark, #e1e4e8)!important}.astro-code-themes span{color:var(--shiki-dark, #e1e4e8)!important}pre:not(.astro-code){background:var(--code-bg);color:#e5e7eb}pre:not(.astro-code) code{background:transparent;color:inherit}.code-copy-btn{position:absolute;top:8px;right:8px;padding:.2rem .5rem;font-size:12px;line-height:1;border:1px solid #e5e7eb;border-radius:6px;background:var(--copy-btn-bg);color:var(--copy-btn-fg);cursor:pointer;backdrop-filter:saturate(180%) blur(10px)}.code-copy-btn:hover{background:#fff}.code-copy-btn:active{transform:translateY(1px)}ul.post-list{list-style:none;padding-left:0}.post-item{margin:1.2rem 0;padding:.6rem 0;border-bottom:1px solid #eee}.post-meta{color:var(--muted);font-size:.9rem;margin:.25rem 0 .75rem}.post-tags{margin:-.5rem 0 .75rem}.tag,.category{display:inline-block;padding:.1rem .5rem;background:var(--tag-bg);color:var(--tag-fg);border-radius:999px;margin-right:.5rem;font-size:.85rem;text-decoration:none}.blog-layout{display:grid;grid-template-columns:220px 1fr;gap:1.5rem;align-items:start}.blog-sidebar{position:sticky;top:90px;align-self:start}.blog-sidebar .tag-list{list-style:none;padding-left:0;margin:0}.blog-sidebar .tag-list li{margin:0 0 .35rem}.blog-sidebar .tag-list a{text-decoration:none;color:inherit}.blog-sidebar .tag-list a:hover{text-decoration:underline}.blog-sidebar .tag-list .count{color:var(--muted)}@media (max-width: 900px){.blog-layout{grid-template-columns:1fr}.blog-sidebar{display:none}}@media (max-width: 640px){.site-footer{display:flex;flex-direction:column-reverse;align-items:flex-start;gap:.25rem}.footer-icons{position:static;right:auto;top:auto;transform:none;padding-left:1rem;margin-top:.5rem}.footer-icons a:first-child{margin-left:0}.site-footer>.container{padding-right:1rem;width:100%}}.pagination{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-top:1rem}.pagination .page-links{list-style:none;margin:0;padding:0;display:flex;gap:.5rem}.pagination .page-links li{margin:0}.pagination .page-links a,.pagination .page-links span{display:inline-block;min-width:2rem;text-align:center;text-decoration:none;border:1px solid #e5e7eb;border-radius:6px;padding:.25rem .5rem}.pagination .page-links li.active span{background:var(--tag-bg);color:var(--tag-fg);border-color:#cbd5e1}.pagination .prev,.pagination .next{text-decoration:none}.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.card{border:1px solid #eee;border-radius:12px;padding:1rem}img{max-width:100%;height:auto}main.container h2,main.container h3,main.container h4{scroll-margin-top:80px}@media (prefers-color-scheme: dark){:root{--fg: #e5e7eb;--bg: #0f172a;--muted: #94a3b8;--link: #58a6ff;--code-inline-bg: #161b22;--code-inline-fg: #e5e7eb;--tag-bg: #1f2937;--tag-fg: #e5e7eb;--copy-btn-bg: #0b1220cc;--copy-btn-fg: #e5e7eb}}:root[data-theme=light]{--fg: #1f2937;--bg: #ffffff;--muted: #6b7280;--link: #0366d6;--code-inline-bg: #f6f8fa;--code-inline-fg: inherit;--tag-bg: #f1f5f9;--tag-fg: #334155;--copy-btn-bg: #ffffffaa;--copy-btn-fg: #334155;--toc-bg: #ffffffcc;--toc-border: #e5e7eb}:root[data-theme=dark]{--fg: #e5e7eb;--bg: #0f172a;--muted: #94a3b8;--link: #58a6ff;--code-inline-bg: #161b22;--code-inline-fg: #e5e7eb;--tag-bg: #1f2937;--tag-fg: #e5e7eb;--copy-btn-bg: #0b1220cc;--copy-btn-fg: #e5e7eb;--toc-bg: #0b1220cc;--toc-border: #1f2937}.theme-toggle{margin-left:1rem;padding:.25rem .5rem;font-size:14px;border:1px solid #e5e7eb;background:transparent;color:inherit;border-radius:6px;cursor:pointer}.theme-toggle i{margin-right:.35rem}.theme-toggle:hover{background:#0000000a}.theme-toggle:active{transform:translateY(1px)}.toc{position:fixed;top:120px;left:50%;margin-left:calc(var(--max-width) / 2 + 24px);width:260px;max-height:70vh;overflow:auto;padding:.75rem;border:1px solid var(--toc-border);border-radius:8px;background:var(--toc-bg);backdrop-filter:saturate(180%) blur(10px);font-size:.9rem;z-index:1}.toc .toc-title{font-weight:700;margin-bottom:.25rem}.toc .toc-list{list-style:none;margin:0;padding:.25rem 0 0}.toc .toc-item{margin:0;padding:0}.toc .toc-item.level-2{padding-left:0}.toc .toc-item.level-3{padding-left:.75rem}.toc .toc-link{display:block;color:inherit;text-decoration:none;padding:.25rem;border-left:2px solid transparent}.toc .toc-link:hover{text-decoration:underline}.toc .toc-link.active{border-left-color:var(--link);color:var(--link)}@media (max-width: 1200px){.toc{display:none}}
