@import"https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:wght@400;500;600;700&family=IBM+Plex+Mono:wght@400;500&display=swap";:root{color-scheme:light;--bg: #ffffff;--bg-elev: #f8fafc;--text: #0f172a;--text-muted: #64748b;--border: #e5e7eb;--accent: #2563eb;--code-bg: #f6f8fa;--code-border: #e5e7eb;--code-bg-top: #f8fafc;--code-bg-bottom: #f3f6f9;--code-shadow: 0 10px 24px rgba(15, 23, 42, .05);--inline-code-bg: #eef2ff;--bg-grad-1: #f4f7fb;--bg-grad-2: #fbfcfe;--header-bg: rgba(255, 255, 255, .82);--surface-soft: #ffffff;--surface-accent-soft: color-mix(in srgb, var(--accent) 4%, var(--bg) 96%);--surface-accent-strong: color-mix(in srgb, var(--accent) 8%, var(--bg) 92%);--border-soft: color-mix(in srgb, var(--border) 85%, transparent 15%);--border-faint: color-mix(in srgb, var(--border) 65%, transparent 35%);--shadow-strong: rgba(15, 23, 42, .06);--toc-bg: color-mix(in srgb, var(--bg) 94%, var(--bg-elev) 6%);--toc-shadow: 0 8px 20px rgba(15, 23, 42, .04);--toggle-bg: color-mix(in srgb, var(--bg-elev) 70%, var(--bg) 30%);--toggle-thumb: var(--bg);--toggle-icon: color-mix(in srgb, var(--text-muted) 90%, var(--text) 10%);--toggle-knob-icon: color-mix(in srgb, var(--text) 78%, var(--accent) 22%);--toggle-knob-shadow: 0 1px 2px rgba(15, 23, 42, .12), 0 6px 14px rgba(15, 23, 42, .06);--max-width: 980px;--content-width: 760px;font-family:IBM Plex Sans,sans-serif;line-height:1.75}:root[data-theme=dark]{color-scheme:dark;--bg: #0b0f14;--bg-elev: #12151b;--text: #edf2f7;--text-muted: #b0bac7;--border: #263041;--accent: #7cc0ff;--code-bg: #0d1117;--code-border: #314055;--code-bg-top: #111927;--code-bg-bottom: #0b111b;--code-shadow: 0 14px 32px rgba(0, 0, 0, .28);--inline-code-bg: rgba(124, 192, 255, .12);--bg-grad-1: #182033;--bg-grad-2: #121823;--header-bg: rgba(11, 15, 20, .68);--surface-soft: rgba(18, 21, 27, .92);--surface-accent-soft: color-mix(in srgb, var(--accent) 6%, var(--bg-elev) 94%);--surface-accent-strong: color-mix(in srgb, var(--accent) 8%, var(--bg-elev) 92%);--border-soft: color-mix(in srgb, var(--text) 10%, transparent 90%);--border-faint: color-mix(in srgb, var(--text) 5%, transparent 95%);--shadow-strong: rgba(0, 0, 0, .2);--toc-bg: rgba(18, 21, 27, .82);--toc-shadow: none;--toggle-bg: color-mix(in srgb, var(--bg-elev) 78%, var(--bg) 22%);--toggle-thumb: #f4f7fb;--toggle-icon: color-mix(in srgb, var(--text-muted) 86%, var(--text) 14%);--toggle-knob-icon: #0f172a;--toggle-knob-shadow: 0 1px 2px rgba(15, 23, 42, .15), 0 6px 14px rgba(0, 0, 0, .2)}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:radial-gradient(1200px 600px at 20% -10%,var(--bg-grad-1) 0%,transparent 55%),radial-gradient(900px 600px at 100% 0%,var(--bg-grad-2) 0%,transparent 60%),var(--bg);color:var(--text);text-rendering:optimizeLegibility;transition:background-color .18s ease,color .18s ease}a{color:var(--text);text-decoration:none}a:hover{color:var(--accent)}main{padding:48px 20px 80px}.container{max-width:var(--max-width);margin:0 auto}.content{max-width:var(--content-width)}.site-header{display:flex;justify-content:space-between;align-items:center;padding:28px 20px;border-bottom:1px solid var(--border);background:var(--header-bg);backdrop-filter:blur(8px);position:sticky;top:0;z-index:10}.site-header .container{display:flex;justify-content:space-between;align-items:center;width:100%}.logo{display:inline-flex;align-items:center;font-weight:700;letter-spacing:.5px}.site-header .logo{font-size:20px}.site-header .logo:hover{color:color-mix(in srgb,var(--text) 82%,var(--accent) 18%)}.nav{display:flex;gap:16px;align-items:center;font-size:15px;color:var(--text-muted)}.theme-toggle{position:relative;display:inline-flex;align-items:center;justify-content:center;min-width:76px;height:40px;padding:0;border:1px solid var(--border);background:var(--toggle-bg);color:var(--toggle-icon);border-radius:999px;font:inherit;cursor:pointer;transition:border-color .18s ease,background-color .18s ease,box-shadow .18s ease}.theme-toggle:hover{border-color:color-mix(in srgb,var(--accent) 35%,var(--border) 65%);box-shadow:0 6px 18px var(--shadow-strong)}.theme-toggle:focus-visible{outline:none;box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 22%,transparent 78%)}.theme-toggle-track{position:relative;display:flex;align-items:center;justify-content:space-between;width:68px;height:32px;padding:0 8px}.theme-toggle-glyph{display:inline-flex;align-items:center;justify-content:center;color:var(--toggle-icon);width:14px;height:14px;flex:0 0 14px;transition:opacity .18s ease,color .18s ease}.theme-toggle-glyph svg,.theme-toggle-knob-icon svg{width:14px;height:14px;display:block}.theme-toggle-knob{position:absolute;top:2px;left:2px;width:28px;height:28px;border-radius:50%;background:var(--toggle-thumb);box-shadow:var(--toggle-knob-shadow);display:flex;align-items:center;justify-content:center;transition:transform .18s ease,background-color .18s ease,box-shadow .18s ease;will-change:transform}.theme-toggle-knob-icon{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--toggle-knob-icon);transition:opacity .14s ease}.theme-toggle-knob-moon{opacity:0}:root[data-theme=dark] .theme-toggle-knob{transform:translate(36px)}:root[data-theme=dark] .theme-toggle-knob-sun{opacity:0}:root[data-theme=dark] .theme-toggle-knob-moon{opacity:1}:root[data-theme=dark] .theme-toggle-glyph-dark{color:color-mix(in srgb,var(--accent) 60%,var(--text) 40%);opacity:1}:root[data-theme=dark] .theme-toggle-glyph-light{opacity:.55}:root[data-theme=light] .theme-toggle-glyph-light{color:color-mix(in srgb,var(--accent) 45%,var(--text) 55%);opacity:1}:root[data-theme=light] .theme-toggle-glyph-dark{opacity:.5}.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}.hero{display:grid;gap:16px;margin:40px 0 32px}.hero-title{font-size:clamp(26px,3.6vw,48px);font-weight:700;line-height:1.25;margin:0 0 16px;max-width:65ch}.hero-subtitle{color:color-mix(in srgb,var(--text-muted) 88%,var(--text) 12%);font-size:18px;margin:0;max-width:650px}.card-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin:28px 0 48px}.card{padding:12px 14px;border:1px solid var(--border);border-radius:12px;background:linear-gradient(180deg,var(--surface-accent-soft) 0%,var(--bg-elev) 100%);box-shadow:inset 0 1px 0 var(--border-faint)}.card h3{margin:0 0 4px;font-size:17px;line-height:1.22}.card p{margin:0;color:var(--text-muted);font-size:15px;line-height:1.45}.card-desc{display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;overflow:hidden}.card:hover{border-color:color-mix(in srgb,var(--accent) 35%,var(--border) 65%)}.section-title{margin:0 0 16px;font-size:18px;letter-spacing:.4px;text-transform:uppercase;color:var(--text-muted)}.about-page{display:grid;gap:36px;padding-bottom:8px}.about-section p{margin:12px 0;font-size:18px;line-height:1.75}.about-section ul{margin:0;padding-left:20px}.about-section li{margin:10px 0;font-size:18px;line-height:1.7}.about-links a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}.post-list{display:grid;gap:16px}.post-item{padding:16px;border:1px solid var(--border);border-radius:12px;background:var(--bg-elev)}.post-item.featured{border-color:color-mix(in srgb,var(--accent) 50%,var(--border) 50%);box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 20%,transparent 80%);background:linear-gradient(180deg,var(--surface-accent-soft) 0%,var(--bg-elev) 100%)}.post-item.featured h3{font-size:20px}.post-item h3{margin:0 0 6px;font-size:19px}.post-meta{display:flex;flex-wrap:wrap;gap:10px;font-size:13px;color:var(--text-muted)}.post-item p{margin:10px 0 0;font-size:14px;color:var(--text-muted);line-height:1.6}.section-action{margin-top:18px;display:flex;justify-content:flex-end}.section-link{display:inline-block;padding:9px 12px;border:1px solid var(--border);border-radius:10px;font-size:14px;color:var(--text-muted);background:var(--surface-soft)}.section-link:hover{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 40%,var(--border) 60%)}.post-layout{display:grid;grid-template-columns:minmax(0,1fr) 220px;gap:48px}.post-layout h1{font-size:clamp(28px,4vw,40px);margin:0 0 12px;line-height:1.15}.post-layout h2{margin-top:40px;font-size:24px}.post-layout h3{margin-top:28px;font-size:20px}.toc{position:sticky;top:88px;align-self:start;max-height:calc(100vh - 120px);overflow-y:auto;padding:16px 14px 16px 16px;border:1px solid var(--border);border-left:3px solid color-mix(in srgb,var(--accent) 42%,transparent 58%);border-radius:12px;background:var(--toc-bg);box-shadow:var(--toc-shadow);font-size:14px;color:var(--text-muted)}.toc::-webkit-scrollbar{width:4px}.toc::-webkit-scrollbar-thumb{background:color-mix(in srgb,var(--text) 20%,transparent 80%);border-radius:999px}.toc::-webkit-scrollbar-track{background:transparent}.toc-title{margin:0 0 14px;font-size:12px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);opacity:.84}.toc ul{list-style:none;padding:0;margin:0;display:grid;gap:8px}.toc-sections{gap:10px}.toc-section{display:grid;gap:8px}.toc-children{display:none;gap:5px;margin-left:12px;padding-left:12px;border-left:1px solid color-mix(in srgb,var(--border) 80%,transparent 20%)}.toc-section.is-open .toc-children{display:grid}.toc li{margin:0}.toc a{color:var(--text);opacity:.82;display:block;padding:6px 10px 6px 12px;margin-left:-10px;border-left:3px solid transparent;border-radius:8px;line-height:1.8;transition:color .18s ease,opacity .18s ease,border-color .18s ease,background-color .18s ease,transform .18s ease}.toc a:hover{color:color-mix(in srgb,var(--accent) 72%,var(--text) 28%);opacity:1;transform:translate(3px);background:color-mix(in srgb,var(--accent) 6%,transparent 94%)}.toc a.is-active{color:var(--accent);opacity:1;border-left-color:color-mix(in srgb,var(--accent) 80%,transparent 20%);font-weight:600;background:color-mix(in srgb,var(--accent) 12%,transparent 88%)}.toc-section.is-open>a{opacity:.96}.toc a[data-toc-child=true]{font-size:13px;color:var(--text-muted);padding-left:10px;margin-left:-2px;opacity:.74}.toc a[data-toc-child=true].is-active{color:var(--accent);opacity:1}.post-layout article{font-size:clamp(18px,1.2vw,20px);line-height:1.8}.post-layout article p{margin:16px 0}.post-layout article ul,.post-layout article ol{margin:16px 0 20px 20px;padding:0}.post-layout article li{margin:8px 0}.post-layout article h2{margin-top:56px;margin-bottom:16px}.post-layout article h3{margin-top:36px;margin-bottom:14px}.post-layout article img{display:block;width:100%;max-width:100%;height:auto;margin:28px auto;border:1px solid var(--border);border-radius:14px;background:var(--bg-elev);box-shadow:0 10px 24px var(--shadow-strong)}.post-layout article code{font-family:IBM Plex Mono,monospace;font-size:.92em;background:var(--inline-code-bg);border:1px solid var(--border-faint);padding:2px 6px;border-radius:6px}.post-layout article pre{position:relative;background:linear-gradient(180deg,var(--code-bg-top) 0%,var(--code-bg-bottom) 100%)!important;border:1px solid var(--code-border);border-radius:12px;box-shadow:inset 0 1px color-mix(in srgb,var(--text) 5%,transparent 95%),var(--code-shadow);padding:20px;margin:24px 0;overflow-x:auto;overflow-y:hidden}.post-layout article pre.astro-code{background:linear-gradient(180deg,var(--code-bg-top) 0%,var(--code-bg-bottom) 100%)!important;color:var(--code-text)}:root[data-theme=light] .post-layout article pre.astro-code,:root[data-theme=light] .post-layout article pre.astro-code span{color:var(--shiki-light, inherit)!important}:root[data-theme=dark] .post-layout article pre.astro-code,:root[data-theme=dark] .post-layout article pre.astro-code span{color:var(--shiki-dark, inherit)!important}.post-layout article pre code{display:block;background:transparent!important;border:0!important;border-radius:0!important;box-shadow:none!important;padding:0;margin:0;font-size:.95em;line-height:1.7}.post-layout article pre code span,.post-layout article pre code>span,.post-layout article pre code .line,.post-layout article pre code .token{border:none!important;border-top:none!important;border-bottom:none!important;box-shadow:none!important;background-image:none!important}.code-copy-button{position:absolute;top:10px;right:10px;z-index:1;border:1px solid var(--border);border-radius:8px;background:color-mix(in srgb,var(--bg-elev) 78%,var(--bg) 22%);color:var(--text-muted);padding:6px 10px;font:inherit;font-size:12px;line-height:1;cursor:pointer;transition:border-color .16s ease,color .16s ease,background-color .16s ease,transform .16s ease}.code-copy-button:hover{color:var(--text);border-color:color-mix(in srgb,var(--accent) 35%,var(--border) 65%);background:color-mix(in srgb,var(--surface-accent-soft) 70%,var(--bg-elev) 30%)}.code-copy-button:active{transform:translateY(1px)}.code-copy-button[data-copied=true]{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 35%,var(--border) 65%)}.post-layout article a{color:var(--accent);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px}.post-layout article a:hover{color:color-mix(in srgb,var(--accent) 72%,var(--text) 28%)}.post-layout article table{display:table;width:100%;table-layout:auto;border-collapse:collapse;margin:24px 0;border:1px solid var(--border);background:var(--bg-elev);font-size:16px;line-height:1.6}.post-layout article thead{display:table-header-group}.post-layout article tbody{display:table-row-group}.post-layout article tr{display:table-row}.post-layout article thead{background:var(--surface-accent-strong)}.post-layout article th,.post-layout article td{display:table-cell;padding:12px 14px;text-align:left;border-bottom:1px solid var(--border);border-right:1px solid var(--border);vertical-align:top}.post-layout article th{font-weight:600}.post-layout article th:last-child,.post-layout article td:last-child{border-right:none}.post-layout article tr:last-child td{border-bottom:none}.post-layout article blockquote{margin:24px 0;padding:14px 18px;border-left:3px solid color-mix(in srgb,var(--accent) 45%,transparent 55%);background:var(--surface-accent-soft);color:var(--text);border-radius:0 10px 10px 0}.post-layout article hr{border:0;border-top:1px solid var(--border);margin:40px 0}.author-note{margin-top:40px;padding:16px 18px;border:1px solid var(--border);border-radius:12px;background:linear-gradient(180deg,var(--surface-accent-soft) 0%,var(--bg-elev) 100%)}.author-note-label{margin:0 0 8px;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted)}.author-note p{margin:0;font-size:15px;line-height:1.65;color:var(--text)}.author-note-link{display:block;margin-top:10px;font-size:14px;color:var(--accent);text-align:right;text-decoration:none!important}.author-note-link:hover{text-decoration:none!important}.post-nav{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:40px;padding-top:20px;border-top:1px solid var(--border)}.post-nav-link{display:flex;flex-direction:column;gap:4px;padding:12px 14px;border:1px solid var(--border);border-radius:12px;background:var(--bg-elev);text-decoration:none!important;transition:border-color .16s ease,background-color .16s ease,transform .16s ease}.post-nav-link-disabled{opacity:.58;pointer-events:none}.post-nav-link:hover{border-color:color-mix(in srgb,var(--accent) 35%,var(--border) 65%);background:var(--surface-accent-soft);transform:translateY(-1px);text-decoration:none!important}.post-nav-label{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted)}.post-nav-title{font-size:15px;font-weight:600;line-height:1.35;color:var(--text);display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;overflow:hidden}.post-layout article .post-nav-link,.post-layout article .post-nav-link:hover,.post-layout article .post-nav-title{text-decoration:none}footer{border-top:1px solid var(--border);padding:48px 20px;color:var(--text-muted);font-size:13px}.site-footer .container{display:flex;justify-content:space-between;gap:28px;align-items:center}.footer-left{display:flex;flex-direction:column;gap:6px}.footer-brand{font-size:17px;font-weight:600;letter-spacing:-.01em;color:var(--text);line-height:1.2}.footer-desc{font-size:14px;line-height:1.6;color:var(--text-muted)}.footer-links{display:flex;gap:14px;flex-wrap:wrap;font-size:14px}.footer-link{display:inline-flex;align-items:center;gap:6px;min-height:36px;padding:8px 10px;border-radius:999px;color:var(--text-muted);transition:color .2s ease,background-color .2s ease,box-shadow .2s ease}.footer-link-icon{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;flex:0 0 14px;opacity:.7;transition:opacity .2s ease,transform .2s ease}.footer-link-icon svg{width:14px;height:14px;display:block}.footer-link:hover{color:var(--text);background:var(--surface-accent-soft);box-shadow:inset 0 0 0 1px var(--border-faint)}.footer-link:hover .footer-link-icon,.footer-link:focus-visible .footer-link-icon{opacity:1;transform:translateY(-1px)}.footer-link:focus-visible{outline:none;color:var(--text);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 18%,transparent 82%)}@media(max-width:900px){.post-layout{grid-template-columns:1fr}.toc{position:static;margin-top:24px}.site-footer .container{flex-direction:column;align-items:flex-start}}@media(max-width:640px){main{padding:32px 16px 64px}.post-layout article{font-size:18px;line-height:1.76}.post-layout article pre{padding:18px}.card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.nav{gap:10px}.theme-toggle{padding:6px 10px}}@media(max-width:640px){.card-grid{grid-template-columns:1fr}.nav-home{display:none}.nav{gap:12px;font-size:14px}}
