code[class*=language-],pre[class*=language-]{word-wrap:normal;background:0 0;color:#f8f8f2;font-family:"JetBrains Mono","Fira Code","Consolas","Courier New",monospace;font-size:1em;-webkit-hyphens:none;hyphens:none;line-height:1.5;-moz-tab-size:4;-o-tab-size:4;tab-size:4;text-align:left;text-shadow:0 1px rgba(0,0,0,.3);white-space:pre;word-break:normal;word-spacing:normal}pre[class*=language-]{font-size:14px;border-radius:.25rem;border:1px solid #414c50;margin:1rem 0 !important;overflow:auto;padding:1rem 1.5rem !important;position:relative;background:#272822;box-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,.06)}:not(pre)>code[class*=language-]{padding:.25rem .5rem;border-radius:.25rem;white-space:normal;background-color:rgba(73,103,114,.2784313725);border:1px solid #585b63;box-decoration-break:clone;font-size:.9em;overflow-wrap:break-word;color:#f8f8f2;font-family:"JetBrains Mono","Fira Code","Consolas","Courier New",monospace}:not(pre)>code,:not(pre)>code[class*=language-]{background-color:rgba(73,103,114,.2784313725);border:1px solid #585b63;-webkit-box-decoration-break:clone;box-decoration-break:clone;font-family:"JetBrains Mono","Fira Code","Consolas","Courier New",monospace;font-size:1rem;padding:.1em .5em;font-size:.9em;border-radius:.25rem;overflow-wrap:break-word;color:var(--color-text-primary);font-feature-settings:"rlig" 1,"calt" 1,"ss01" 1}code{border:1px solid #585b63;background:#303136;color:var(--color-text-primary);font-size:.9em;hyphens:none;tab-size:2;text-align:left;word-spacing:normal;word-break:normal;border-radius:.25rem;font-family:"JetBrains Mono","Fira Code","Consolas","Courier New",monospace}pre>code{display:block;overflow-x:auto;overscroll-behavior-x:contain;border:none;background:rgba(0,0,0,0);color:#f8f8f2}.token.comment,.token.prolog,.token.doctype,.token.cdata{color:#708090}.token.punctuation{color:#f8f8f2}.token.namespace{opacity:.7}.token.property,.token.tag,.token.constant,.token.symbol,.token.deleted{color:#f92672}.token.boolean,.token.number{color:#ae81ff}.token.selector,.token.attr-name,.token.string,.token.char,.token.builtin,.token.inserted{color:#a6e22e}.token.operator,.token.entity,.token.url,.language-css .token.string,.style .token.string,.token.variable{color:#f8f8f2}.token.atrule,.token.attr-value,.token.function,.token.class-name{color:#e6db74}.token.keyword{color:#66d9ef}.token.regex,.token.important{color:#fd971f}.token.important,.token.bold{font-weight:bold}.token.italic{font-style:italic}.token.entity{cursor:help}pre[class*=language-]:before{color:#71f7b2;padding:.5em;font-size:.9em;position:absolute;top:0;right:0;content:var(--lang) !important}pre[class*=language-][class*=javascript],pre[class*=language-][class*=js]{--lang: "javascript"}pre[class*=language-][class*=html]{--lang: "html"}pre[class*=language-][class*=scss]{--lang: "scss"}pre[class*=language-][class*=css]{--lang: "css"}pre[class*=language-][class*=bash]{--lang: "bash"}pre[class*=language-][class*=json]{--lang: "json"}pre[class*=language-][class*=typescript]{--lang: "typescript"}pre[class*=language-][class*=markup]{--lang: "markup"}pre[class*=language-][class*=powershell]{--lang: "powershell"}pre[class*=language-][class*=njk]{--lang: "njk"}pre[class*=language-][class*=liquid]{--lang: "liquid"}pre[class*=language-] button{display:none}pre[class*=language-]:hover button{display:block;color:#adb5bd;box-sizing:border-box;transition:150ms ease-in-out;cursor:pointer;user-select:none;background:rgba(0,0,0,.5);border:1px solid rgba(0,0,0,0);padding:5px 10px;font-size:.8em;position:absolute;top:0;right:0;border-radius:0 .15rem}:not(pre)>code[class*=language-]::-webkit-scrollbar,pre[class*=language-]::-webkit-scrollbar,pre>code::-webkit-scrollbar{height:.2rem}:not(pre)>code[class*=language-]::-webkit-scrollbar-thumb,pre[class*=language-]::-webkit-scrollbar-thumb,pre>code::-webkit-scrollbar-thumb{background:#414c50;border-radius:.8rem}:not(pre)>code[class*=language-]::-webkit-scrollbar-track,pre[class*=language-]::-webkit-scrollbar-track,pre>code::-webkit-scrollbar-track{background:rgba(0,0,0,0);border-radius:.8rem}a[rel=tag]{display:inline-block;vertical-align:text-top;text-transform:capitalize;letter-spacing:.1em;font-size:.625em;padding:.25rem .5rem;background-color:#272822;color:#cbd5e0;border-radius:.25rem;text-decoration:none;margin:.25rem;border-bottom:none}a[rel=tag]:hover,a[rel=tag]:focus{background-image:linear-gradient(238deg, red, #ff8000, #ff0, #80ff00, #0f0, #00ff80, #0ff, #0080ff, #00f, #8000ff, #ff0080);background-size:1200% 1200%;background-position:2% 80%;color:#fff;text-shadow:0 0 2px rgba(0,0,0,.9);animation:rainbow 4s ease-out alternate infinite;box-shadow:#000 5px 5px 2px !important}a[rel=tag][aria-label=css],a[rel=tag][aria-label=js],a[rel=tag][aria-label=html],a[rel=tag][aria-label=scss],a[rel=tag][aria-label=http]{text-transform:uppercase !important}@keyframes rainbow{0%{background-position:0% 82%}50%{background-position:100% 19%}100%{background-position:0% 82%}}code[class*=language-md]{white-space:pre-wrap}@media(forced-colors: active){code[class*=language-],pre[class*=language-]{color:windowText;background:window}:not(pre)>code[class*=language-],pre[class*=language-]{background:window}.token.important{background:highlight;color:window;font-weight:normal}.token.atrule,.token.attr-value,.token.function,.token.keyword,.token.operator,.token.selector{font-weight:bold}.token.attr-value,.token.comment,.token.doctype,.token.function,.token.keyword,.token.operator,.token.property,.token.string{color:highlight}.token.attr-value,.token.url{font-weight:normal}}.code-block-wrapper{position:relative;margin:1.5rem 0;display:flex;flex-direction:column;overflow:hidden}.code-block-wrapper pre{margin:0 !important}.code-block-wrapper.code-window{border-radius:8px;box-shadow:0 10px 30px rgba(0,0,0,.3);background-color:#1e1e1e}.code-block-wrapper.code-window .code-block-header{background-color:#333;border-bottom:none}.code-block-wrapper.code-window .code-block-header .window-controls{display:flex;align-items:center;gap:8px;padding:0 15px}.code-block-wrapper.code-window .code-block-header .window-controls .dot{width:12px;height:12px;border-radius:50%}.code-block-wrapper.code-window .code-block-header .window-controls .dot.red{background:#ff5f56}.code-block-wrapper.code-window .code-block-header .window-controls .dot.yellow{background:#ffbd2e}.code-block-wrapper.code-window .code-block-header .window-controls .dot.green{background:#27c93f}.code-block-wrapper.code-window .code-block-tab{background-color:rgba(0,0,0,0);border-right:none;color:#999;margin-left:auto}.code-block-wrapper.code-window pre{background:rgba(0,0,0,0);box-shadow:none;border:none;border-radius:0}.code-block-wrapper.code-window pre::before{display:none}.code-block-wrapper:hover .copy-button{opacity:1;visibility:visible;transform:translateY(0)}.code-block-header{display:flex;align-items:center;justify-content:space-between;padding:0;background-color:var(--color-bg-secondary);border-bottom:1px solid var(--color-border)}.code-block-tab{padding:.5rem 1rem;font-size:.75rem;font-weight:600;color:var(--color-text);background-color:var(--color-bg-code, #1e1e1e);border-right:1px solid var(--color-border);text-transform:lowercase;min-width:max-content;text-align:center}.copy-button{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;padding:0;border-radius:.375rem;color:var(--color-text-secondary);cursor:pointer;z-index:10;opacity:0;visibility:hidden;transform:translateY(5px);transition:all .25s cubic-bezier(0.4, 0, 0.2, 1)}.copy-button:hover{background-color:var(--color-bg-tertiary, var(--color-bg-secondary));border-color:var(--color-text-secondary);color:var(--color-text)}.copy-button:active{transform:scale(0.95)}.copy-button::before{content:"Copied!";position:absolute;right:115%;top:50%;transform:translateY(-50%) translateX(10px);color:#fff;font-size:.7rem;font-weight:700;pointer-events:none;opacity:0;transition:all .2s ease;white-space:nowrap}.copy-button svg{width:1rem;height:1rem}.copy-button .check-icon{display:none}.copy-button.copied{background-color:#10b981;border-color:#10b981;color:#fff;opacity:1 !important;visibility:visible !important;transform:translateY(0) !important}.copy-button.copied .copy-icon{display:none}.copy-button.copied .check-icon{display:block}.copy-button.copied::before{opacity:1;transform:translateY(-50%) translateX(0)}.copy-button--bottom-right{position:absolute;bottom:.5rem;right:.5rem}.copy-button--top-right{position:absolute;top:.5rem;right:.5rem}.copy-button--bottom-left{position:absolute;bottom:.5rem;left:.5rem}.copy-button--top-left{position:absolute;top:.5rem;left:.5rem}@media(max-width: 639px){.copy-button{opacity:1;visibility:visible;width:1.75rem;height:1.75rem}}.post-container__article-title{font-size:2.5rem;font-weight:700;line-height:1.2;color:var(--color-text);margin-bottom:1rem}@media(max-width: 639px){.post-container__article-title{font-size:2rem}}.post-container__article-detail{display:flex;align-items:center;margin:1rem 0 2rem;flex-wrap:wrap}.post-container__article-detail time{color:var(--color-secondary);font-size:.875rem;font-weight:600}.post-container__article-detail a.post-author{cursor:pointer;text-decoration:none;color:var(--color-secondary);transition:color .2s ease}.post-container__article-detail a.post-author:hover{text-decoration:underline;color:var(--color-text)}.post-container__article-detail span.bullets,.post-container__article-detail span.post-reading-time,.post-container__article-detail a.post-author{margin-left:.3rem;color:var(--color-secondary);font-size:.875rem;font-weight:600}.post-container__content{margin:2rem 0;line-height:1.7}.post-container__article-share{margin:2rem 0}@media(max-width: 639px){.post-container__article-share{text-align:center}}.post-container__article-share__thanks{color:inherit;margin-bottom:1rem;opacity:.9;font-size:1.1rem}.post-container__article-share__socialShare{display:flex;flex-direction:column;gap:1rem}.post-container__article-share__socialShare span{color:inherit;opacity:.9}.post-container__article-share__socialShare .share-links{display:flex;flex-direction:row;gap:1rem}@media(max-width: 639px){.post-container__article-share__socialShare .share-links{justify-content:center}}.post-container__article-share__socialShare .share-links .share-post{align-items:center;background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:50%;display:flex;opacity:.8;transition:all .3s ease;width:fit-content;margin:0}.post-container__article-share__socialShare .share-links .share-post:hover{opacity:1;transform:scale(1.1)}.post-container__article-share__socialShare .share-links .share-post a{align-items:center;color:var(--color-text);display:flex;font-size:.8rem;padding:.9rem;text-decoration:none}.post-container__article-share__socialShare .share-links .share-post a svg{height:1rem;width:1rem}.post-container__article__footer{display:flex;width:100%;flex-direction:column;align-items:flex-start;background-color:var(--color-bg-secondary);border-radius:.5rem;padding:1.5rem 2rem;border:1px solid var(--color-border);color:var(--color-text-primary);margin:2rem 0;gap:1.5rem}@media(max-width: 639px){.post-container__article__footer{padding:1rem 1.5rem}}.post-container__article__footer--info{display:flex;flex-direction:column;align-items:flex-start;gap:.875rem;width:100%;font-size:.875rem;color:var(--color-secondary)}.post-container__article__footer--info a:not([rel=tag]){text-decoration:none;color:var(--color-text);transition:opacity .2s ease,transform .2s ease,border-color .2s ease}.post-container__article__footer--info a:not([rel=tag]):hover{opacity:.9;transform:translateY(-1px)}.post-footer-meta{display:flex;flex-wrap:wrap;gap:.75rem}.post-footer-pill{display:inline-flex;align-items:center;gap:.4rem;padding:.45rem .8rem;border-radius:999px;background-color:color-mix(in srgb, var(--color-bg-primary) 72%, transparent);border:1px solid var(--color-border);color:var(--color-text-primary);font-weight:600}.post-footer-pill svg{flex-shrink:0}.post-footer-note{margin:0;color:var(--color-text-secondary);line-height:1.6}.post-footer-actions{display:flex;flex-wrap:wrap;gap:.75rem;width:100%}.post-action-button{display:inline-flex;align-items:center;justify-content:center;padding:.7rem 1rem;border-radius:.75rem;border:1px solid var(--color-border);background-color:var(--color-bg-primary);font-weight:600;box-shadow:0 1px 2px 0 rgba(0,0,0,.05);cursor:pointer}.copy-link-button{display:inline-grid;grid-template-areas:"stack";place-items:center}.copy-link-button__content{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;grid-area:stack;transition:opacity .2s ease,transform .2s ease;white-space:nowrap}.copy-link-button__icon,.copy-link-button__label{display:inline-flex;align-items:center;justify-content:center}.copy-link-button .copy-success-state{opacity:0;transform:translateY(6px);transition:opacity .2s ease,transform .2s ease;pointer-events:none}.copy-link-button.copied .copy-default-state{opacity:0;transform:translateY(-6px)}.copy-link-button.copied .copy-success-state{opacity:1;transform:translateY(0)}.post-meta-footer{display:flex;flex-direction:column;gap:1rem;width:100%}.post-tags-section{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem}@media(max-width: 639px){.post-tags-section{flex-direction:column;align-items:flex-start;gap:.5rem}}.post-tags-label{font-size:.875rem;color:var(--color-secondary);font-weight:600;white-space:nowrap}.post-tags-list{display:flex;flex-wrap:wrap;align-items:center}.post-tag{display:inline-flex;align-items:center;padding:.375rem .875rem;font-size:.75rem;font-weight:600;letter-spacing:.5px;text-decoration:none;background-color:var(--color-bg-secondary);color:var(--color-text);border-radius:.375rem;border:1px solid var(--color-border);transition:all .2s ease;white-space:nowrap}.post-tag:hover{opacity:1;transform:translateY(-2px);box-shadow:0 2px 8px rgba(0,0,0,.15);border-color:var(--color-text)}.post-tag:focus{outline:2px solid var(--color-text);outline-offset:2px}.post-publish-info{font-size:.875rem;color:var(--color-secondary);font-style:italic}.post-publish-info time{font-weight:600;color:var(--color-text)}@media(max-width: 639px){.post-container__article__footer{padding:1rem;gap:1rem}.post-container__article__footer--info{font-size:.8rem}.post-footer-meta{gap:.5rem;width:100%}.post-footer-pill,.post-action-button{width:100%;justify-content:center}}.related-posts-container{position:relative;padding:2rem;background:linear-gradient(135deg, var(--color-bg-secondary) 0%, var(--color-bg-primary) 100%);border:1px solid var(--color-border);border-radius:12px;overflow:hidden;color:var(--color-text-primary);margin:2rem 0;box-shadow:0 2px 8px rgba(0,0,0,.1);transition:box-shadow .3s ease}.related-posts-container:hover{box-shadow:0 4px 16px rgba(0,0,0,.15)}.related-posts-content{position:relative;z-index:2}.related-posts-heading{font-size:1.5rem;font-weight:700;margin:0 0 1.5rem 0;color:var(--color-text);display:flex;align-items:center;gap:.5rem}.heading-icon{font-size:1.75rem;animation:bounce 2s infinite}@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}.related-posts-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.related-post-item{margin:0;padding:0;transition:transform .2s ease}.related-post-item:hover{transform:translateX(8px)}.related-post-link{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;background-color:hsla(0,0%,100%,.05);border:1px solid rgba(0,0,0,0);border-radius:8px;color:var(--color-text-primary);text-decoration:none !important;transition:all .3s ease;position:relative;overflow:hidden}.related-post-link::before{content:"";position:absolute;top:0;left:0;width:3px;height:100%;background:linear-gradient(180deg, var(--color-text) 0%, transparent 100%);opacity:0;transition:opacity .3s ease}.related-post-link:hover{background-color:var(--color-bg-secondary);border-color:var(--color-border);transform:translateX(4px)}.related-post-link:hover::before{opacity:1}.related-post-link:hover .post-icon{transform:scale(1.2) rotate(10deg);opacity:1}.related-post-link:hover .post-title{color:var(--color-text-primary);font-weight:600}.related-post-link:hover .post-arrow{opacity:1;transform:translateX(0)}.related-post-link:focus{outline:2px solid var(--color-text);outline-offset:2px}.post-icon{font-size:1.25rem;flex-shrink:0;opacity:.8;transition:transform .3s ease}.post-title{flex:1;font-weight:500;line-height:1.4;color:var(--color-text);transition:color .2s ease}.post-arrow{font-size:1rem;opacity:0;transform:translateX(-10px);transition:all .3s ease;color:var(--color-text-secondary)}snow-fall{display:block;width:100%;height:100%;position:absolute;top:0;left:0;z-index:1;pointer-events:none;opacity:.6}@media(max-width: 767px){.related-posts-container{padding:1.5rem;margin:1.5rem 0}.related-posts-heading{font-size:1.25rem}.related-post-link{padding:.75rem .875rem;gap:.5rem}.post-icon{font-size:1.1rem}.post-title{font-size:.9rem}.related-post-item:hover{transform:translateX(4px)}}@media(prefers-color-scheme: dark){.related-posts-container{background:linear-gradient(135deg, rgba(255, 255, 255, 0.05) 0%, rgba(255, 255, 255, 0.02) 100%)}.related-post-link{background-color:hsla(0,0%,100%,.03)}.related-post-link:hover{background-color:hsla(0,0%,100%,.08)}}@media(prefers-reduced-motion: reduce){.related-posts-container,.related-post-item,.related-post-link,.post-icon,.post-arrow,.heading-icon{animation:none;transition:none}}@media print{.related-posts-container{background:#fff;border:1px solid #000;box-shadow:none}snow-fall{display:none}.post-arrow{display:none}}.table-of-contents{margin:1.5rem 0 2rem;background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:.75rem;overflow:hidden}.table-of-contents summary{display:flex;align-items:center;gap:.625rem;padding:.875rem 1.25rem;cursor:pointer;user-select:none;list-style:none;font-weight:600;font-size:.925rem;color:var(--color-text);transition:background-color .2s ease}.table-of-contents summary::-webkit-details-marker{display:none}.table-of-contents summary::marker{display:none;content:""}.table-of-contents summary:hover{background-color:color-mix(in srgb, var(--color-bg-primary) 50%, transparent)}.table-of-contents summary:focus-visible{outline:2px solid var(--color-text);outline-offset:-4px;background-color:color-mix(in srgb, var(--color-bg-primary) 60%, transparent)}.table-of-contents .toc-icon{flex-shrink:0;opacity:.6}.table-of-contents .toc-title{flex:1}.table-of-contents .toc-chevron{flex-shrink:0;opacity:.5;transition:transform .3s ease}.table-of-contents[open] .toc-chevron{transform:rotate(180deg)}.table-of-contents nav>ol{list-style:none;margin:0;padding:.25rem 1.25rem 1rem;counter-reset:toc-counter;border-top:1px solid var(--color-border)}.table-of-contents nav>ol>li{counter-increment:toc-counter;display:grid;grid-template-columns:1.75rem minmax(0, 1fr);column-gap:.5rem;align-items:start}.table-of-contents nav>ol>li::before{content:counter(toc-counter) ".";padding-top:.45rem;color:var(--color-secondary);font-size:.8rem;font-weight:600;line-height:1.4;opacity:.6;text-align:right}.table-of-contents nav>ol>li>a{display:block;min-width:0;padding:.35rem .5rem;color:var(--color-text);text-decoration:none;font-size:.9rem;font-weight:500;border-radius:.375rem;transition:all .2s ease}.table-of-contents nav>ol>li>a:hover{color:var(--color-text-primary);background-color:color-mix(in srgb, var(--color-bg-primary) 60%, transparent)}.table-of-contents nav>ol>li>a:focus-visible{color:var(--color-text-primary);outline:2px solid var(--color-text);outline-offset:2px;background-color:color-mix(in srgb, var(--color-bg-primary) 60%, transparent)}.table-of-contents nav>ol ol{display:none}@media(max-width: 639px){.table-of-contents{margin:1rem 0 1.5rem}.table-of-contents summary{padding:.75rem 1rem;font-size:.875rem}.table-of-contents nav>ol{padding:.25rem 1rem .875rem}.table-of-contents nav>ol>li>a{font-size:.85rem;padding:.3rem .45rem}}