:root,[data-theme=auto]{--text: oklch(.145 0 0);--bg: #fff;--link: oklch(.4 .15 250);--muted: oklch(.55 0 0);--border: oklch(.9 0 0);--code-bg: oklch(.97 0 0);--code-text: oklch(.43 .19 15)}[data-theme=dark]{--text: oklch(.9 0 0);--bg: oklch(.15 0 0);--link: oklch(.7 .15 240);--muted: oklch(.55 0 0);--border: oklch(.25 0 0);--code-bg: oklch(.2 0 0);--code-text: oklch(.72 .14 15)}@media(prefers-color-scheme:dark){[data-theme=auto]{--text: oklch(.9 0 0);--bg: oklch(.15 0 0);--link: oklch(.7 .15 240);--muted: oklch(.55 0 0);--border: oklch(.25 0 0);--code-bg: oklch(.2 0 0);--code-text: oklch(.72 .14 15)}}[data-theme=light]{--text: oklch(.145 0 0);--bg: #fff;--link: oklch(.4 .15 250);--muted: oklch(.55 0 0);--border: oklch(.9 0 0);--code-bg: oklch(.97 0 0);--code-text: oklch(.43 .19 15)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-family:Open Sans,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:18px;line-height:1.7;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{min-height:100vh}.container{max-width:65ch;width:100%;margin:0 auto;padding:2rem 1.25rem 4rem}.site-header{display:flex;flex-direction:column;padding-bottom:1.5rem;margin-bottom:2rem;border-bottom:1px solid var(--border)}.site-header a{color:var(--text);text-decoration:none}.site-header .site-name{font-size:1.5rem;font-weight:700;letter-spacing:-.02em}.site-header .subtitle{font-size:.85rem;color:var(--muted);margin-top:.25rem}.site-nav{display:flex;gap:1.5rem;margin-top:1rem;font-size:.9rem}.site-nav a{color:var(--muted);transition:color .15s}.site-nav a:hover,.site-nav a.active{color:var(--text)}.theme-toggle{margin-left:auto;display:flex;align-items:center;gap:.4rem}.theme-label{display:flex;align-items:center;color:var(--muted);cursor:pointer}.theme-label .t-icon{display:none}[data-theme=light] .t-icon-sun,[data-theme=dark] .t-icon-moon,[data-theme=auto] .t-icon-auto{display:block}.theme-select{background:var(--bg);color:var(--muted);border:1px solid var(--border);border-radius:4px;font-size:.8rem;font-family:inherit;padding:.15rem 1.5rem .15rem .4rem;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .3rem center;transition:color .15s,border-color .15s}.theme-select:hover,.theme-select:focus{color:var(--text);border-color:var(--text);outline:none}.post-list{display:flex;flex-direction:column;gap:1.25rem}.post-item{display:flex;gap:1rem;align-items:baseline}.post-item .post-date{font-size:.85rem;color:var(--muted);font-style:italic;white-space:nowrap;min-width:6.5rem}.post-item a{color:var(--text);text-decoration:none;transition:color .15s}.post-item a:hover{color:var(--link)}article h1{font-family:Mona Sans,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:1.8rem;font-weight:700;line-height:1.3;letter-spacing:-.02em;margin-bottom:.5rem}article .post-meta{color:var(--muted);font-size:.9rem;font-style:italic;margin-bottom:2rem}article h2{font-family:Mona Sans,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:1.3rem;font-weight:600;margin-top:2.5rem;margin-bottom:.75rem;letter-spacing:-.01em}article h3{font-family:Mona Sans,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:1.1rem;font-weight:600;margin-top:2rem;margin-bottom:.5rem}article p{margin-bottom:1.25rem}article a{color:var(--link);text-decoration:underline;text-underline-offset:.15em;text-decoration-color:var(--border)}article a:hover{text-decoration-color:var(--link)}article ul,article ol{margin-bottom:1.25rem;padding-left:1.5rem}article li{margin-bottom:.5rem}article li>ul,article li>ol{margin-top:.5rem;margin-bottom:0}article blockquote{border-left:3px solid var(--link);padding:.5rem 1rem;margin-bottom:1.25rem;color:var(--muted);font-style:italic}article hr{border:none;border-top:1px solid var(--border);margin:2rem 0}article code{font-family:Fira Code,JetBrains Mono,Cascadia Code,Menlo,Monaco,monospace;font-size:.85em;color:var(--code-text);background:var(--code-bg);padding:.15em .35em;border-radius:3px}.code-block{border:1px solid var(--border);border-radius:6px;margin-bottom:1.25rem;overflow:hidden}.code-block .code-title{display:flex;align-items:center;justify-content:space-between;padding:.4rem .75rem .4rem 1rem;font-size:.75rem;font-family:Fira Code,JetBrains Mono,Cascadia Code,Menlo,Monaco,monospace;color:#5d5d5d;background:var(--code-bg);border-bottom:1px solid var(--border);user-select:none}.code-block .code-copy{background:none;border:1px solid oklch(.6 0 0);border-radius:4px;color:#5d5d5d;cursor:pointer;font-size:.7rem;font-family:inherit;padding:.15rem .5rem;transition:color .15s,border-color .15s}.code-block .code-copy:hover{color:var(--text);border-color:var(--text)}.code-block .code-copy.copied{color:#05893e;border-color:#05893e}article pre{background:var(--code-bg);padding:1rem 1.25rem;overflow-x:auto;margin:0;font-size:.85rem;line-height:1.5}.code-block pre{border-radius:0}article pre code{background:none;padding:0;font-size:inherit}article table{width:100%;border-collapse:collapse;margin-bottom:1.25rem}article th,article td{padding:.5rem .75rem;border-bottom:1px solid var(--border);text-align:left}article th{font-weight:600}article .footnotes{margin-top:3rem;padding-top:1rem;border-top:1px solid var(--border);font-size:.85rem;color:var(--muted)}.site-footer{margin-top:3rem;padding-top:1.5rem;border-top:1px solid var(--border);font-size:.8rem;color:var(--muted)}.footer-about{display:flex;gap:.75rem;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.footer-avatar{border-radius:50%;flex-shrink:0}.footer-name{font-weight:600;color:var(--text);margin-bottom:.15rem}.footer-about p{margin:0;line-height:1.5}.footer-social{display:flex;gap:1rem;margin-bottom:.75rem}.footer-social a{color:var(--muted);transition:color .15s;display:flex;align-items:center}.footer-social a:hover{color:var(--text)}article .aside{padding:.75rem 1rem;border-left:3px solid var(--border);border-radius:0 6px 6px 0;margin-bottom:1.25rem;font-size:.95rem}article .aside-note{border-color:#3a93e6;background:#e8f3ff}article .aside-tip{border-color:#3aa85b;background:#e9f6eb}article .aside-caution{border-color:#d0750a;background:#fcefe5}html.dark .astro-code,html.dark .astro-code span{color:var(--shiki-dark)!important}html.dark .astro-code{background-color:var(--shiki-dark-bg)!important}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.blog-nav{display:flex;justify-content:space-between;margin-top:2rem;font-size:.9rem}.blog-nav a{color:var(--link);text-decoration:none;max-width:48%}.blog-nav a:hover{text-decoration:underline}.post-updated{font-style:normal;font-size:.85em}.post-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:2rem}.tag-link{display:inline-block;padding:.2rem .6rem;border:1px solid var(--border);border-radius:4px;font-size:.8rem;color:var(--muted)!important;text-decoration:none!important;transition:color .15s,border-color .15s}.tag-link:hover{color:var(--link)!important;border-color:var(--link)}
