body.article-mode-body{min-height:100vh;margin:0;padding:0;transition:background-color .3s,color .3s;color:#e5e7eb!important;font-family:var(--font-serif)!important;background-color:#121212!important}html.light body.article-mode-body{color:#1c1917!important;background-color:#fdfbf7!important}.article-navbar{z-index:100;font-family:var(--font-heading);background-color:#121212;border-bottom:1px solid #ffffff14;padding:1rem 2rem;transition:background-color .3s,border-color .3s;position:sticky;top:0}html.light .article-navbar{background-color:#fdfbf7;border-bottom:1px solid #00000014}.article-navbar-container{justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;display:flex}.navbar-left{text-align:left;flex:1}.navbar-left .nav-logo-link{letter-spacing:-.02em;font-size:1.15rem;font-weight:800;font-family:var(--font-heading);align-items:center;gap:6px;text-decoration:none;transition:all .3s;display:inline-flex}.navbar-left .nav-logo-link .logo-icon{flex-shrink:0}.navbar-left .nav-logo-link .logo-text{background:linear-gradient(135deg,#408ac7 0%,#f9a07e 100%);-webkit-text-fill-color:transparent;background-clip:text;display:inline-block}html.light .navbar-left .nav-logo-link .logo-text{background:linear-gradient(135deg,#2d608a 0%,#e27249 100%);-webkit-text-fill-color:transparent;background-clip:text}.navbar-left .nav-logo-link:hover{opacity:.92}.navbar-center{text-align:center;flex:2}.navbar-center .nav-article-title{font-family:var(--font-serif);color:var(--text-title);letter-spacing:-.01em;white-space:nowrap;text-overflow:ellipsis;max-width:400px;font-size:1.05rem;font-weight:600;display:inline-block;overflow:hidden}html.light .navbar-center .nav-article-title{color:#1c1917}@media (width<=768px){.navbar-center .nav-article-title{display:none}}.navbar-right{flex:1;justify-content:flex-end;align-items:center;display:flex}.navbar-right .share-btn,.navbar-right .theme-toggle-btn,.navbar-right .nav-close-link{cursor:pointer;color:var(--text-secondary);background:0 0;border:none;justify-content:center;align-items:center;padding:0;text-decoration:none;transition:color .3s;display:inline-flex}.navbar-right .share-btn:hover,.navbar-right .theme-toggle-btn:hover,.navbar-right .nav-close-link:hover{color:var(--primary)}html.light .navbar-right .share-btn,html.light .navbar-right .theme-toggle-btn,html.light .navbar-right .nav-close-link{color:#57534e}html.light .navbar-right .share-btn:hover,html.light .navbar-right .theme-toggle-btn:hover,html.light .navbar-right .nav-close-link:hover{color:var(--primary)}.navbar-right .share-btn svg,.navbar-right .theme-toggle-btn svg,.navbar-right .nav-close-link svg{transition:transform .2s;display:block}.navbar-right .share-btn:hover svg,.navbar-right .theme-toggle-btn:hover svg,.navbar-right .nav-close-link:hover svg{transform:scale(1.08)}.navbar-right .share-btn svg{width:16px;height:16px}.navbar-right .nav-close-link svg{width:20px;height:20px}.navbar-right .nav-separator{color:#ffffff26;user-select:none;margin:0 .85rem;font-size:.8rem}html.light .navbar-right .nav-separator{color:#0000001a}.navbar-right .theme-toggle-btn svg{width:16px;height:16px}.navbar-right .theme-toggle-btn .sun-icon{display:none}.navbar-right .theme-toggle-btn .moon-icon,html.light .navbar-right .theme-toggle-btn .sun-icon{display:block}html.light .navbar-right .theme-toggle-btn .moon-icon{display:none}.article-container{max-width:900px;margin:0 auto;padding:5rem 2rem 8rem}@media (width<=768px){.article-container{padding:3rem 1.25rem 5rem}}.article-body-content .article-post-header,.article-body-content .article-markdown-body>*{max-width:680px;margin-left:auto;margin-right:auto}.article-body-content .article-post-header{border-bottom:1px solid #ffffff14;margin-bottom:3.5rem;padding-bottom:2rem}html.light .article-body-content .article-post-header{border-bottom:1px solid #00000014}.article-body-content .article-post-header .post-meta-date{font-family:var(--font-heading);color:var(--primary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.75rem;font-size:.85rem;font-weight:600;display:block}.article-body-content .article-post-header .post-main-title{font-family:var(--font-serif);color:var(--text-title);letter-spacing:-.02em;margin-bottom:1rem;font-size:2.85rem;font-weight:600;line-height:1.2}html.light .article-body-content .article-post-header .post-main-title{color:#1c1917}@media (width<=768px){.article-body-content .article-post-header .post-main-title{font-size:2.15rem}}.article-body-content .article-post-header .post-main-subtitle{font-family:var(--font-serif);color:var(--text-secondary);margin-top:.5rem;font-size:1.35rem;font-weight:400;line-height:1.45}html.light .article-body-content .article-post-header .post-main-subtitle{color:#57534e}@media (width<=768px){.article-body-content .article-post-header .post-main-subtitle{font-size:1.15rem}}.article-body-content .article-markdown-body{font-family:var(--font-serif);letter-spacing:-.012em;font-size:1.2rem;line-height:1.9}html.light .article-body-content .article-markdown-body{color:#292524}.article-body-content .article-markdown-body>p:first-of-type{color:var(--text-title);margin-bottom:2.25rem;font-size:1.35rem;line-height:1.85}html.light .article-body-content .article-markdown-body>p:first-of-type{color:#1c1917}.article-body-content .article-markdown-body p{margin-bottom:2rem}.article-body-content .article-markdown-body h2{font-family:var(--font-heading);color:var(--text-title);border-bottom:1px solid #ffffff14;margin-top:3.5rem;margin-bottom:1.25rem;padding-bottom:.5rem;font-size:1.65rem;font-weight:700}html.light .article-body-content .article-markdown-body h2{color:#1c1917;border-bottom:1px solid #00000014}.article-body-content .article-markdown-body h3{font-family:var(--font-heading);color:var(--text-title);margin-top:2.75rem;margin-bottom:1rem;font-size:1.3rem;font-weight:700}html.light .article-body-content .article-markdown-body h3{color:#1c1917}.article-body-content .article-markdown-body ul,.article-body-content .article-markdown-body ol{margin-bottom:2rem;padding-left:2rem}.article-body-content .article-markdown-body ul li,.article-body-content .article-markdown-body ol li{margin-bottom:.75rem}.article-body-content .article-markdown-body>pre,.article-body-content .article-markdown-body>blockquote,.article-body-content .article-markdown-body>table,.article-body-content .article-markdown-body>p:has(>img),.article-body-content .article-markdown-body>img{max-width:840px!important}@media (width<=900px){.article-body-content .article-markdown-body>pre,.article-body-content .article-markdown-body>blockquote,.article-body-content .article-markdown-body>table,.article-body-content .article-markdown-body>p:has(>img),.article-body-content .article-markdown-body>img{max-width:100%!important}}.article-body-content .article-markdown-body blockquote{border-left:3px solid var(--primary);color:var(--text-secondary);margin:2.5rem auto;padding-left:1.5rem;font-size:1.35rem;font-style:italic;line-height:1.65}html.light .article-body-content .article-markdown-body blockquote{color:#57534e}.article-body-content .article-markdown-body pre:not(.gist *){background:#0003;border:1px solid #ffffff0d;border-radius:8px;margin-bottom:2rem;padding:1.5rem;overflow-x:auto}html.light .article-body-content .article-markdown-body pre:not(.gist *){background:#00000008;border:1px solid #0000000d}.article-body-content .article-markdown-body code:not(.gist *){background:#ffffff14;border-radius:4px;padding:.2rem .4rem;font-family:monospace;font-size:.9em}html.light .article-body-content .article-markdown-body code:not(.gist *){background:#0000000d}.article-body-content .article-markdown-body p:has(>img){text-align:center;margin-bottom:.5rem!important}.article-body-content .article-markdown-body p:has(>img) img{margin:2.5rem auto 0;display:block}.article-body-content .article-markdown-body p:has(>img) em{color:var(--text-secondary);text-align:center;margin-top:.5rem;margin-bottom:2.5rem;font-size:.825rem;display:block}html.light .article-body-content .article-markdown-body p:has(>img) em{color:#78716c}.article-body-content .article-markdown-body p:has(>img)+p:has(>em:only-child){text-align:center;margin-top:0!important;margin-bottom:2.5rem!important}.article-body-content .article-markdown-body p:has(>img)+p:has(>em:only-child) em{color:var(--text-secondary);font-size:.825rem;display:inline-block}html.light .article-body-content .article-markdown-body p:has(>img)+p:has(>em:only-child) em{color:#78716c}.article-body-content .article-markdown-body img{border-radius:4px;max-width:100%;height:auto;margin:2.5rem 0}.article-body-content .article-markdown-body .image-grid{grid-template-columns:repeat(3,1fr);gap:.5rem;margin:2.5rem auto;display:grid;max-width:840px!important}.article-body-content .article-markdown-body .image-grid img{object-fit:cover;border-radius:4px;width:100%;height:100%;margin:0!important}@media (width<=640px){.article-body-content .article-markdown-body .image-grid{grid-template-columns:1fr}}.article-body-content .article-markdown-body .gist{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica,Arial,sans-serif;font-size:13px;line-height:1.4;max-width:840px!important;margin:2.5rem auto!important}.article-body-content .article-markdown-body .gist input[type=text]{color:#c9d1d9!important;width:auto!important;height:28px!important;box-shadow:none!important;background:#0d111d!important;border:1px solid #ffffff26!important;border-radius:6px!important;padding:3px 8px 3px 28px!important;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica,Arial,sans-serif!important;font-size:12px!important;transition:none!important}html.light .article-body-content .article-markdown-body .gist input[type=text]{color:#24292f!important;background:#fff!important;border:1px solid #d0d7de!important}.article-body-content .article-markdown-body .gist input[type=text]:focus{border-color:#58a6ff!important;outline:none!important;box-shadow:0 0 0 3px #58a6ff4d!important}.article-body-content .article-markdown-body .gist .csv-search-form{align-items:center!important;padding:8px!important;display:flex!important;position:relative!important}.article-body-content .article-markdown-body .gist .csv-search-form .octicon-search,.article-body-content .article-markdown-body .gist .csv-search-form svg{color:#8b949e!important;pointer-events:none!important;width:14px!important;height:14px!important;margin:0!important;position:absolute!important;top:50%!important;left:16px!important;transform:translateY(-50%)!important}html.light .article-body-content .article-markdown-body .gist .csv-search-form .octicon-search,html.light .article-body-content .article-markdown-body .gist .csv-search-form svg{color:#57606a!important}.article-body-content .article-markdown-body .gist .gist-file{background-color:#0b0f19!important;border:1px solid #ffffff14!important;border-radius:6px!important}html.light .article-body-content .article-markdown-body .gist .gist-file{background-color:#fff!important;border:1px solid #00000014!important}.article-body-content .article-markdown-body .gist .gist-data{background-color:#0d111d!important;border-bottom:1px solid #ffffff14!important}html.light .article-body-content .article-markdown-body .gist .gist-data{background-color:#f6f8fa!important;border-bottom:1px solid #00000014!important}.article-body-content .article-markdown-body .gist .gist-meta{color:var(--text-secondary)!important;font-family:var(--font-heading)!important;background-color:#0b0f19!important}html.light .article-body-content .article-markdown-body .gist .gist-meta{color:#57534e!important;background-color:#f6f8fa!important}.article-body-content .article-markdown-body .gist .gist-meta a{color:var(--primary)!important}.article-body-content .article-markdown-body .gist table{border-collapse:collapse!important;border:none!important;width:auto!important;margin:0!important}.article-body-content .article-markdown-body .gist td{border:none!important;padding:1px 10px!important}.article-body-content .article-markdown-body .gist .blob-num,.article-body-content .article-markdown-body .gist .blob-code{font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace!important;font-size:12px!important;line-height:20px!important}.article-body-content .article-markdown-body .gist .blob-num{color:#ffffff4d!important}html.light .article-body-content .article-markdown-body .gist .blob-num{color:#0000004d!important}.article-body-content .article-markdown-body .gist .blob-code{color:#c9d1d9!important}html.light .article-body-content .article-markdown-body .gist .blob-code{color:#24292f!important}.article-body-content .article-markdown-body .gist .blob-code .pl-s1{color:#c9d1d9!important}.article-body-content .article-markdown-body .gist .blob-code .pl-s{color:#a5d6ff!important}.article-body-content .article-markdown-body .gist .blob-code .pl-k{color:#ff7b72!important}.article-body-content .article-markdown-body .gist .blob-code .pl-c1{color:#79c0ff!important}.article-body-content .article-markdown-body .gist .blob-code .pl-en{color:#d2a8ff!important}.article-body-content .article-markdown-body .gist .blob-code .pl-v{color:#ffa657!important}.article-body-content .article-markdown-body .gist .blob-code .pl-c{color:#8b949e!important}.article-body-content .article-markdown-body .gist .blob-code .pl-ent{color:#7ee787!important}html.light .article-body-content .article-markdown-body .gist .blob-code .pl-s1{color:#24292f!important}html.light .article-body-content .article-markdown-body .gist .blob-code .pl-s{color:#0a3069!important}html.light .article-body-content .article-markdown-body .gist .blob-code .pl-k{color:#cf222e!important}html.light .article-body-content .article-markdown-body .gist .blob-code .pl-c1{color:#0550ae!important}html.light .article-body-content .article-markdown-body .gist .blob-code .pl-en{color:#8250df!important}html.light .article-body-content .article-markdown-body .gist .blob-code .pl-v{color:#e36209!important}html.light .article-body-content .article-markdown-body .gist .blob-code .pl-c{color:#6e7781!important}html.light .article-body-content .article-markdown-body .gist .blob-code .pl-ent{color:#116329!important}.gatekeeper-steps-grid[data-astro-cid-f6c3gbfj]{grid-template-columns:repeat(2,1fr);gap:1.5rem;display:grid;max-width:840px!important;margin:2.5rem auto!important}@media (width<=640px){.gatekeeper-steps-grid[data-astro-cid-f6c3gbfj]{grid-template-columns:1fr}}.step-card[data-astro-cid-f6c3gbfj]{background:#ffffff05;border:1px solid #ffffff0f;border-radius:12px;flex-direction:column;padding:1.25rem;transition:border-color .3s,box-shadow .3s;display:flex;position:relative;overflow:hidden}html.light .step-card[data-astro-cid-f6c3gbfj]{background:#00000004;border:1px solid #0000000a}.step-card[data-astro-cid-f6c3gbfj]:hover{border-color:var(--card-hover-border);box-shadow:0 4px 20px #00000026}.step-badge[data-astro-cid-f6c3gbfj]{background:var(--gradient-primary);color:#fff;z-index:2;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:.85rem;font-weight:700;display:flex;position:absolute;top:1rem;left:1rem}.step-desc[data-astro-cid-f6c3gbfj]{color:var(--text-title);font-size:.95rem;font-weight:600;margin:0 0 1rem 2.2rem!important}.step-image-wrapper[data-astro-cid-f6c3gbfj]{background:#1e1e1e;border:1px solid #ffffff0d;border-radius:8px;justify-content:center;align-items:center;width:100%;height:240px;padding:1.25rem;display:flex;overflow:hidden}html.light .step-image-wrapper[data-astro-cid-f6c3gbfj]{background:#f3f4f6;border:1px solid #0000000d}.step-screenshot[data-astro-cid-f6c3gbfj]{object-fit:contain;width:auto;max-width:100%;height:auto;max-height:100%;display:block;margin:0!important}
