#search-overlay[data-astro-cid-qk3db3zz]{position:fixed;inset:0;z-index:500;display:flex;align-items:flex-start;justify-content:center;padding-top:clamp(4rem,10vh,8rem)}#search-overlay[data-astro-cid-qk3db3zz][hidden]{display:none}.search-backdrop[data-astro-cid-qk3db3zz]{position:absolute;inset:0;background:#000000b3;backdrop-filter:blur(4px)}.search-box[data-astro-cid-qk3db3zz]{position:relative;width:100%;max-width:620px;margin:0 1rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:0 24px 80px #0009;overflow:hidden}.search-top[data-astro-cid-qk3db3zz]{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-bottom:1px solid var(--color-border)}.search-input-wrap[data-astro-cid-qk3db3zz]{display:flex;align-items:center;gap:.6rem;flex:1}.search-icon[data-astro-cid-qk3db3zz]{color:var(--color-text-muted);flex-shrink:0}#search-input[data-astro-cid-qk3db3zz]{flex:1;background:none;border:none;outline:none;font-family:inherit;font-size:1rem;color:var(--color-text)}#search-input[data-astro-cid-qk3db3zz]::placeholder{color:var(--color-text-muted)}.search-esc[data-astro-cid-qk3db3zz]{flex-shrink:0;padding:.2rem .5rem;background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:4px;font-size:.75rem;color:var(--color-text-muted);cursor:pointer;font-family:inherit}.search-esc[data-astro-cid-qk3db3zz]:hover{color:var(--color-text)}.search-results[data-astro-cid-qk3db3zz]{max-height:400px;overflow-y:auto}.search-result-item[data-astro-cid-qk3db3zz]{display:block;padding:.9rem 1.25rem;text-decoration:none;border-bottom:1px solid var(--color-border);transition:background .15s}.search-result-item[data-astro-cid-qk3db3zz]:last-child{border-bottom:none}.search-result-item[data-astro-cid-qk3db3zz]:hover{background:var(--color-surface-2);text-decoration:none}.search-result-title[data-astro-cid-qk3db3zz]{font-size:.9rem;font-weight:600;color:var(--color-text);margin:0 0 .25rem}.search-result-excerpt[data-astro-cid-qk3db3zz]{font-size:.8rem;color:var(--color-text-muted);margin:0;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.search-result-excerpt[data-astro-cid-qk3db3zz] mark[data-astro-cid-qk3db3zz]{background:#6c63ff40;color:var(--color-primary-hover);border-radius:2px;padding:0 2px}.search-hint[data-astro-cid-qk3db3zz]{padding:1rem 1.25rem;font-size:.8rem;color:var(--color-text-muted);margin:0}.search-build-note[data-astro-cid-qk3db3zz]{color:#f59e0b}.search-no-results[data-astro-cid-qk3db3zz]{padding:1.5rem 1.25rem;font-size:.875rem;color:var(--color-text-muted);margin:0}.header-right[data-astro-cid-3ef6ksr2]{display:flex;align-items:center;gap:.75rem}.search-trigger[data-astro-cid-3ef6ksr2]{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem .85rem;background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text-muted);font-family:inherit;font-size:.85rem;cursor:pointer;transition:all .2s;white-space:nowrap}.search-trigger[data-astro-cid-3ef6ksr2]:hover{border-color:var(--color-primary);color:var(--color-text)}.search-kbd[data-astro-cid-3ef6ksr2]{padding:.1rem .35rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:4px;font-size:.7rem;color:var(--color-text-muted);font-family:inherit;margin-left:.2rem}@media (max-width: 640px){.search-trigger-label[data-astro-cid-3ef6ksr2],.search-kbd[data-astro-cid-3ef6ksr2]{display:none}.search-trigger[data-astro-cid-3ef6ksr2]{padding:.4rem .5rem}}.footer-inner[data-astro-cid-sz7xmlte]{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.footer-copy[data-astro-cid-sz7xmlte]{margin:0;color:var(--color-text-muted);font-size:.875rem}.footer-links[data-astro-cid-sz7xmlte]{display:flex;gap:1.5rem;font-size:.875rem}.footer-links[data-astro-cid-sz7xmlte] a[data-astro-cid-sz7xmlte]{color:var(--color-text-muted);text-decoration:none;transition:color .2s}.footer-links[data-astro-cid-sz7xmlte] a[data-astro-cid-sz7xmlte]:hover{color:var(--color-primary)}@media (max-width: 640px){.footer-inner[data-astro-cid-sz7xmlte]{flex-direction:column;text-align:center}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg: #0f1117;--color-surface: #1a1d27;--color-surface-2: #252836;--color-border: #2e3347;--color-primary: #6c63ff;--color-primary-hover: #8b85ff;--color-text: #e2e8f0;--color-text-muted: #8892a4;--color-accent: #00d4aa;--color-code-bg: #1e2130;--font-sans: "Inter", system-ui, -apple-system, sans-serif;--font-mono: "Fira Code", "Cascadia Code", monospace;--radius: 8px;--radius-lg: 14px;--shadow: 0 4px 20px rgba(0, 0, 0, .4);--max-width: 900px}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-sans);background:var(--color-bg);color:var(--color-text);line-height:1.7;min-height:100vh}h1{font-size:2.2rem;font-weight:800;line-height:1.2}h2{font-size:1.6rem;font-weight:700;margin-top:2.5rem;margin-bottom:1rem}h3{font-size:1.25rem;font-weight:600;margin-top:1.8rem;margin-bottom:.75rem}h4{font-size:1.1rem;font-weight:600;margin-top:1.5rem;margin-bottom:.5rem}p{margin-bottom:1.25rem}a{color:var(--color-primary);text-decoration:none;transition:color .2s}a:hover{color:var(--color-primary-hover);text-decoration:underline}strong{font-weight:700;color:#fff}ul,ol{padding-left:1.5rem;margin-bottom:1.25rem}li{margin-bottom:.4rem}code{font-family:var(--font-mono);font-size:.875em;background:var(--color-code-bg);border:1px solid var(--color-border);border-radius:4px;padding:.1em .4em;color:var(--color-accent)}pre{background:var(--color-code-bg);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.25rem;overflow-x:auto;margin-bottom:1.5rem;font-size:.9rem}pre code{background:none;border:none;padding:0;color:var(--color-text)}table{width:100%;border-collapse:collapse;margin-bottom:1.5rem;font-size:.9rem}th{background:var(--color-surface-2);padding:.75rem 1rem;text-align:left;border:1px solid var(--color-border);font-weight:600}td{padding:.65rem 1rem;border:1px solid var(--color-border)}tr:nth-child(2n) td{background:#ffffff05}blockquote{border-left:4px solid var(--color-primary);padding:.75rem 1.25rem;margin:1.5rem 0;background:#6c63ff14;border-radius:0 var(--radius) var(--radius) 0;color:var(--color-text-muted);font-style:italic}.container{max-width:var(--max-width);margin:0 auto;padding:0 1.5rem}.site-header{background:#0f1117d9;backdrop-filter:blur(12px);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:100;padding:.875rem 0}.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem}.logo{font-size:1.4rem;font-weight:800;color:#fff;text-decoration:none;display:flex;align-items:center;gap:.5rem}.logo span{color:var(--color-primary)}.lang-switcher{display:flex;gap:.5rem}.lang-btn{padding:.35rem .8rem;border-radius:6px;font-size:.85rem;font-weight:600;border:1px solid var(--color-border);color:var(--color-text-muted);background:transparent;text-decoration:none;transition:all .2s}.lang-btn:hover,.lang-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff;text-decoration:none}.tag{display:inline-block;font-size:.75rem;font-weight:600;padding:.2rem .6rem;background:#6c63ff26;border:1px solid rgba(108,99,255,.35);border-radius:100px;color:var(--color-primary-hover)}.tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:1.5rem}.youtube-wrapper{position:relative;padding-bottom:56.25%;height:0;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);background:#000;margin-bottom:2rem}.youtube-wrapper iframe{position:absolute;inset:0;width:100%;height:100%;border:0}.share-section{margin-top:3rem;padding-top:2rem;border-top:1px solid var(--color-border)}.share-buttons{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1rem}.share-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.55rem 1.1rem;border-radius:var(--radius);font-size:.875rem;font-weight:600;text-decoration:none;transition:all .2s}.share-btn:hover{transform:translateY(-2px);text-decoration:none}.share-btn.twitter{background:#000;color:#fff;border:1px solid #333}.share-btn.linkedin{background:#0077b5;color:#fff}.share-btn.copy{background:var(--color-surface-2);color:var(--color-text);border:1px solid var(--color-border);cursor:pointer}.card-thumb{width:100%;aspect-ratio:16/9;object-fit:cover}.card-body{padding:1.25rem}.card-title{font-size:1.05rem;font-weight:700;margin-bottom:.5rem;color:#fff}.card-desc{font-size:.875rem;color:var(--color-text-muted);line-height:1.5;margin-bottom:.75rem}.docs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;margin-top:2rem}.hero{padding:5rem 0 3rem;text-align:center}.hero-badge{display:inline-block;font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--color-accent);background:#00d4aa1a;border:1px solid rgba(0,212,170,.3);border-radius:100px;padding:.3rem .8rem;margin-bottom:1.5rem}.hero h1{margin-bottom:1rem}.hero p{font-size:1.15rem;color:var(--color-text-muted);max-width:600px;margin:0 auto 2rem}.hero-langs{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:var(--radius);font-weight:700;font-size:1rem;text-decoration:none;transition:all .2s}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary-hover);text-decoration:none}.btn-ghost{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border)}.btn-ghost:hover{border-color:var(--color-primary);color:var(--color-primary);text-decoration:none}.yt-clip{display:block;position:relative;margin:1.5rem 0 2rem;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--color-border);background:#000;text-decoration:none;cursor:pointer}.yt-clip:hover{border-color:var(--color-accent);text-decoration:none}.yt-clip-thumb{display:block;width:100%;aspect-ratio:16/9;object-fit:cover;transition:opacity .2s}.yt-clip:hover .yt-clip-thumb{opacity:.75}.yt-clip-play{position:absolute;top:50%;left:50%;transform:translate(-50%,calc(-50% - 14px));width:56px;height:56px;background:#000000b3;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.4rem;color:#fff;transition:background .2s,transform .2s;pointer-events:none}.yt-clip:hover .yt-clip-play{background:var(--color-accent);transform:translate(-50%,calc(-50% - 14px)) scale(1.1)}.yt-clip-time{position:absolute;bottom:2.6rem;right:.6rem;background:#000000bf;color:#fff;font-size:.72rem;font-family:var(--font-mono);padding:.1rem .4rem;border-radius:3px;pointer-events:none}.yt-clip-label{padding:.55rem 1rem;font-size:.82rem;color:var(--color-text-muted);background:var(--color-surface);margin:0;border-top:1px solid var(--color-border)}.article-header{padding:3rem 0 2rem}.article-meta{display:flex;align-items:center;gap:1rem;color:var(--color-text-muted);font-size:.875rem;margin-bottom:1rem;flex-wrap:wrap}.article-content{padding-bottom:4rem}.page-layout{display:flex;align-items:flex-start;min-height:calc(100vh - 60px)}.sidebar{width:260px;flex-shrink:0;position:sticky;top:60px;height:calc(100vh - 60px);overflow-y:auto;border-right:1px solid var(--color-border);background:var(--color-surface)}.sidebar-inner{padding:1.5rem 0}.sidebar-heading{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-muted);padding:0 1.25rem;margin-bottom:.75rem}.sidebar-link{display:flex;flex-direction:column;gap:.2rem;padding:.65rem 1.25rem;text-decoration:none;color:var(--color-text-muted);font-size:.85rem;border-left:3px solid transparent;transition:all .15s}.sidebar-link:hover{color:var(--color-text);background:var(--color-surface-2);text-decoration:none}.sidebar-link.active{color:var(--color-primary);border-left-color:var(--color-primary);background:#6c63ff14}.sidebar-title{font-weight:500;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.sidebar-date{font-size:.75rem;color:var(--color-text-muted)}.content-area{flex:1;min-width:0}.sidebar-divider{height:1px;background:var(--color-border);margin:.5rem 0}.toc-link{display:block;padding:.4rem 1.25rem;font-size:.82rem;color:var(--color-text-muted);text-decoration:none;border-left:3px solid transparent;transition:all .15s;line-height:1.4}.toc-link:hover{color:var(--color-text);text-decoration:none}.toc-link.active{color:var(--color-primary);border-left-color:var(--color-primary)}.toc-h3{padding-left:2rem;font-size:.78rem}.sidebar-toggle{display:none;align-items:center;gap:.5rem;margin:.75rem 1.25rem 0;padding:.5rem .9rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text-muted);font-size:.85rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all .15s}.sidebar-toggle:hover{border-color:var(--color-primary);color:var(--color-primary)}.sidebar-overlay{display:none;position:fixed;inset:0;background:#00000080;z-index:149}.sidebar-overlay.open{display:block}@media (max-width: 900px){.sidebar{display:none;position:fixed;top:0;left:0;height:100vh;z-index:150;transform:translate(-100%);transition:transform .25s ease}.sidebar.open{display:block;transform:translate(0)}.sidebar-toggle{display:inline-flex}}.site-footer{background:var(--color-surface);border-top:1px solid var(--color-border);padding:2rem 0;text-align:center;color:var(--color-text-muted);font-size:.875rem}#read-progress{position:fixed;top:0;left:0;height:3px;width:0%;background:linear-gradient(90deg,var(--color-primary),var(--color-accent));z-index:999;transition:width .08s linear;pointer-events:none}.reading-time{display:inline-flex;align-items:center;gap:.3rem;font-size:.8rem;color:var(--color-text-muted)}.reading-time:before{content:"";display:inline-block;width:4px;height:4px;border-radius:50%;background:var(--color-border)}pre{position:relative!important}.copy-code-btn{position:absolute;top:.55rem;right:.55rem;display:inline-flex;align-items:center;gap:.3rem;padding:.25rem .55rem;background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:5px;color:var(--color-text-muted);font-family:var(--font-sans);font-size:.72rem;cursor:pointer;transition:all .15s;opacity:0}pre:hover .copy-code-btn,.copy-code-btn:focus-visible{opacity:1}.copy-code-btn:hover{background:var(--color-border);color:var(--color-text)}.copy-code-btn.copied{opacity:1;color:var(--color-accent);border-color:var(--color-accent)}#back-to-top{position:fixed;bottom:2rem;right:2rem;width:42px;height:42px;background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:50%;color:var(--color-text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transform:translateY(12px);transition:opacity .25s,transform .25s,background .2s,border-color .2s;z-index:49}#back-to-top.visible{opacity:1;transform:translateY(0)}#back-to-top:hover{background:var(--color-primary);border-color:var(--color-primary);color:#fff}a.tag{text-decoration:none;transition:background .15s,border-color .15s,color .15s}a.tag:hover{background:#6c63ff4d;border-color:var(--color-primary);color:#fff;text-decoration:none}@media (max-width: 640px){h1{font-size:1.75rem}h2{font-size:1.35rem}.hero{padding:3rem 0 2rem}#back-to-top{bottom:1.25rem;right:1.25rem}}
