.m_5cb1b9c8{position:relative}.m_e597c321{border-radius:var(--ch-radius,0px);position:relative;overflow:hidden}:where([data-mantine-color-scheme=light]) .m_e597c321:where([data-with-border]){border:1px solid var(--mantine-color-gray-2)}:where([data-mantine-color-scheme=dark]) .m_e597c321:where([data-with-border]),.m_e597c321:where([data-with-border]):where([data-code-color-scheme=dark]){border:1px solid var(--mantine-color-dark-6)}.m_e597c321:where([data-with-border]):where([data-code-color-scheme=light]){border:1px solid var(--mantine-color-gray-2)}:where([data-mantine-color-scheme=light]) .m_e597c321{--ch-background:var(--mantine-color-gray-0)}:where([data-mantine-color-scheme=dark]) .m_e597c321{--ch-background:var(--mantine-color-dark-8)}.m_dfe9c588{border-radius:var(--ch-radius,var(--mantine-radius-sm));background-color:var(--ch-background);font-size:calc(.8125rem * var(--mantine-scale));padding:calc(.1875rem * var(--mantine-scale)) calc(.3125rem * var(--mantine-scale));overflow:hidden}:where([data-mantine-color-scheme=light]) .m_dfe9c588:where([data-with-border]){border:1px solid var(--mantine-color-gray-2)}:where([data-mantine-color-scheme=dark]) .m_dfe9c588:where([data-with-border]),.m_dfe9c588:where([data-with-border]):where([data-code-color-scheme=dark]){border:1px solid var(--mantine-color-dark-6)}.m_dfe9c588:where([data-with-border]):where([data-code-color-scheme=light]){border:1px solid var(--mantine-color-gray-2)}:where([data-mantine-color-scheme=light]) .m_dfe9c588{--ch-background:var(--mantine-color-gray-0)}:where([data-mantine-color-scheme=dark]) .m_dfe9c588{--ch-background:var(--mantine-color-dark-8)}.m_2c47c4fd{--code-line-height:1.7;margin:0;display:block}.m_2c47c4fd[data-with-offset] .m_5caae6d3{padding-top:calc(3.125rem * var(--mantine-scale))}.m_5caae6d3{padding:var(--mantine-spacing-xs) var(--mantine-spacing-md);background-color:var(--ch-background);font-size:calc(.8125rem * var(--mantine-scale));line-height:var(--code-line-height,var(--mantine-line-height));font-family:var(--mantine-font-family-monospace);width:fit-content;min-width:100%;display:block}.m_5caae6d3:where([data-inline]){padding:calc(.1875rem * var(--mantine-scale)) calc(.3125rem * var(--mantine-scale));background-color:var(--ch-background);display:inline-block}.m_be7e9c9c{top:calc(.5rem * var(--mantine-scale));right:calc(.5rem * var(--mantine-scale));z-index:1;background-color:var(--ch-background);border-bottom-left-radius:var(--mantine-radius-md);position:absolute}.m_be7e9c9c:where([data-with-offset]){top:calc(.75rem * var(--mantine-scale))}.m_d498bab7{color:var(--mantine-color-text);opacity:.5}@media (hover:hover){.m_d498bab7:hover{color:var(--mantine-color-bright);opacity:1}}@media (hover:none){.m_d498bab7:active{color:var(--mantine-color-bright);opacity:1}}.m_d498bab7:where([data-code-color-scheme=dark]){color:var(--mantine-color-dark-0)}@media (hover:hover){.m_d498bab7:where([data-code-color-scheme=dark]):hover{color:var(--mantine-color-white)}}@media (hover:none){.m_d498bab7:where([data-code-color-scheme=dark]):active{color:var(--mantine-color-white)}}.m_d498bab7:where([data-code-color-scheme=light]){color:var(--mantine-color-black)}@media (hover:hover){.m_d498bab7:where([data-code-color-scheme=light]):hover{color:var(--mantine-color-black)}}@media (hover:none){.m_d498bab7:where([data-code-color-scheme=light]):active{color:var(--mantine-color-black)}}.m_d498bab7 :where(svg){width:calc(1.125rem * var(--mantine-scale));height:calc(1.125rem * var(--mantine-scale));display:block}.m_4c3d814c:where([data-code-color-scheme=light]){background-color:var(--mantine-color-gray-9);color:var(--mantine-color-white)}.m_4c3d814c:where([data-code-color-scheme=dark]){background-color:var(--mantine-color-gray-2);color:var(--mantine-color-black)}.m_f744fd40[data-collapsed]{max-height:var(--ch-max-height,180px);position:relative;overflow:hidden}.m_f744fd40[data-collapsed]:after{content:"";height:calc(5rem * var(--mantine-scale));pointer-events:none;background:linear-gradient(0deg, var(--ch-background) 0%, var(--ch-background) 25%, transparent 100%);z-index:1;position:absolute;bottom:0;left:0;right:0}.m_c9378bc2{z-index:2;bottom:0;font-size:var(--mantine-font-size-sm);color:var(--mantine-color-anchor);text-align:center;width:100%;padding-top:var(--mantine-spacing-xs);padding-bottom:var(--mantine-spacing-xs);white-space:nowrap;position:absolute;inset-inline-start:50%;transform:translate(-50%)}.m_c9378bc2[data-hidden]{display:none}.m_c9378bc2:where([data-code-color-scheme=dark]){color:var(--mantine-primary-color-5)}.m_c9378bc2:where([data-code-color-scheme=light]){color:var(--mantine-primary-color-6)}.m_5cac2e62{font-size:var(--mantine-font-size-xs);justify-content:center;align-items:center;gap:calc(.4375rem * var(--mantine-scale));padding:calc(.3125rem * var(--mantine-scale)) calc(.5625rem * var(--mantine-scale));font-family:var(--mantine-font-family-monospace);-webkit-user-select:none;user-select:none;cursor:pointer;opacity:.8;border:calc(.0625rem * var(--mantine-scale)) solid transparent;white-space:nowrap;border-radius:var(--mantine-radius-default);margin:0;font-weight:700;line-height:1;display:flex}.m_5cac2e62:where([data-active]){opacity:1}:where([data-mantine-color-scheme=light]) .m_5cac2e62{border-color:var(--mantine-color-gray-3);color:var(--mantine-color-gray-8)}:where([data-mantine-color-scheme=light]) .m_5cac2e62:where([data-active]){background-color:var(--mantine-color-white);color:var(--mantine-color-black)}:where([data-mantine-color-scheme=dark]) .m_5cac2e62{border-color:var(--mantine-color-dark-4);color:var(--mantine-color-dark-0)}:where([data-mantine-color-scheme=dark]) .m_5cac2e62:where([data-active]){background-color:var(--mantine-color-dark-5);color:var(--mantine-color-white)}.m_5cac2e62:where([data-color-scheme=light]){border-color:var(--mantine-color-gray-3);color:var(--mantine-color-gray-8)}.m_5cac2e62:where([data-color-scheme=light]):where([data-active]){background-color:var(--mantine-color-white);color:var(--mantine-color-black)}.m_5cac2e62:where([data-color-scheme=dark]){border-color:var(--mantine-color-dark-4);color:var(--mantine-color-dark-0)}.m_5cac2e62:where([data-color-scheme=dark]):where([data-active]){background-color:var(--mantine-color-dark-5);color:var(--mantine-color-white)}@media (hover:hover){.m_5cac2e62:hover{opacity:1}}@media (hover:none){.m_5cac2e62:active{opacity:1}}.m_5cac2e62:where(:only-child){cursor:default}.m_b46cddfb :where(svg){display:block}.m_7b14120b{z-index:2;top:0;left:0;right:calc(4.375rem * var(--mantine-scale));position:absolute}.m_38d99e51{padding:calc(.75rem * var(--mantine-scale)) calc(.625rem * var(--mantine-scale));gap:var(--mantine-spacing-xs);padding-bottom:0;display:flex}
body{margin:0;padding:0}.blog-content h2{margin-top:2rem;margin-bottom:1rem}.blog-content h3{margin-top:1.5rem;margin-bottom:.75rem}.blog-content p{margin-bottom:1rem;line-height:1.8}.blog-content ul,.blog-content ol{margin-bottom:1rem;padding-left:1.5rem;line-height:1.8}.blog-content li{margin-bottom:.25rem}.blog-content pre{border:1px solid #0000;border-radius:10px;margin-bottom:1.5rem;padding:1.25rem;font-size:.875rem;line-height:1.7;overflow-x:auto}.blog-content code{font-family:SF Mono,Fira Code,Fira Mono,Menlo,Consolas,monospace;font-size:.875em}[data-mantine-color-scheme=dark] .blog-content pre{background:#0d1117;border-color:#21262d}[data-mantine-color-scheme=light] .blog-content pre{background:#f6f8fa;border-color:#d1d9e0}.blog-content p code,.blog-content li code,.blog-content h2 code,.blog-content h3 code{border-radius:5px;padding:2px 7px;font-size:.85em}[data-mantine-color-scheme=dark] .blog-content p code,[data-mantine-color-scheme=dark] .blog-content li code,[data-mantine-color-scheme=dark] .blog-content h2 code,[data-mantine-color-scheme=dark] .blog-content h3 code{color:#e6edf3;background:#1c2128}[data-mantine-color-scheme=light] .blog-content p code,[data-mantine-color-scheme=light] .blog-content li code,[data-mantine-color-scheme=light] .blog-content h2 code,[data-mantine-color-scheme=light] .blog-content h3 code{color:#1f2328;background:#eff1f3}.blog-content blockquote{border-left:3px solid var(--mantine-color-blue-6);color:var(--mantine-color-dimmed);margin-left:0;padding-left:1rem}.blog-content a{color:var(--mantine-color-blue-4)}[data-mantine-color-scheme=light] .blog-content a{color:var(--mantine-color-blue-7)}[data-mantine-color-scheme=dark] .blog-content strong{color:var(--mantine-color-white)}[data-mantine-color-scheme=light] .blog-content strong{color:var(--mantine-color-black)}.blog-content hr{border:none;border-top:1px solid var(--mantine-color-default-border);margin:2rem 0}.blog-content table{border-collapse:collapse;width:100%;margin-bottom:1.5rem;font-size:.9rem}.blog-content th,.blog-content td{text-align:left;border:1px solid var(--mantine-color-default-border);padding:.6rem .8rem}.blog-content th{font-weight:600}[data-mantine-color-scheme=dark] .blog-content th{background:#1a1a1a}[data-mantine-color-scheme=light] .blog-content th{background:#f1f3f5}.blog-content img{border-radius:8px;max-width:100%;height:auto;margin:1rem 0}[data-mantine-color-scheme=dark] .hljs{color:#e6edf3}[data-mantine-color-scheme=dark] .hljs-keyword,[data-mantine-color-scheme=dark] .hljs-selector-tag{color:#ff7b72}[data-mantine-color-scheme=dark] .hljs-string,[data-mantine-color-scheme=dark] .hljs-attr{color:#a5d6ff}[data-mantine-color-scheme=dark] .hljs-number,[data-mantine-color-scheme=dark] .hljs-literal{color:#79c0ff}[data-mantine-color-scheme=dark] .hljs-built_in,[data-mantine-color-scheme=dark] .hljs-type{color:#ffa657}[data-mantine-color-scheme=dark] .hljs-comment{color:#8b949e;font-style:italic}[data-mantine-color-scheme=dark] .hljs-function,[data-mantine-color-scheme=dark] .hljs-title{color:#d2a8ff}[data-mantine-color-scheme=dark] .hljs-variable,[data-mantine-color-scheme=dark] .hljs-name{color:#7ee787}[data-mantine-color-scheme=dark] .hljs-params{color:#e6edf3}[data-mantine-color-scheme=dark] .hljs-property{color:#79c0ff}[data-mantine-color-scheme=dark] .hljs-symbol{color:#ffa657}[data-mantine-color-scheme=dark] .hljs-meta{color:#8b949e}[data-mantine-color-scheme=dark] .hljs-regexp{color:#7ee787}[data-mantine-color-scheme=light] .hljs{color:#1f2328}[data-mantine-color-scheme=light] .hljs-keyword,[data-mantine-color-scheme=light] .hljs-selector-tag{color:#cf222e}[data-mantine-color-scheme=light] .hljs-string,[data-mantine-color-scheme=light] .hljs-attr{color:#0a3069}[data-mantine-color-scheme=light] .hljs-number,[data-mantine-color-scheme=light] .hljs-literal{color:#0550ae}[data-mantine-color-scheme=light] .hljs-built_in,[data-mantine-color-scheme=light] .hljs-type{color:#953800}[data-mantine-color-scheme=light] .hljs-comment{color:#6e7781;font-style:italic}[data-mantine-color-scheme=light] .hljs-function,[data-mantine-color-scheme=light] .hljs-title{color:#8250df}[data-mantine-color-scheme=light] .hljs-variable,[data-mantine-color-scheme=light] .hljs-name{color:#116329}[data-mantine-color-scheme=light] .hljs-params{color:#1f2328}[data-mantine-color-scheme=light] .hljs-property{color:#0550ae}[data-mantine-color-scheme=light] .hljs-symbol{color:#953800}[data-mantine-color-scheme=light] .hljs-meta{color:#6e7781}[data-mantine-color-scheme=light] .hljs-regexp{color:#116329}
