@font-face{font-family:Outfit;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/b2ea385cb5ae8625-s.866357a4.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Outfit;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/1b99372b3eaef0c8-s.p.758e15a8.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Outfit Fallback;src:local(Arial);ascent-override:100.18%;descent-override:26.05%;line-gap-override:0.0%;size-adjust:99.82%}.outfit_9f4f9187-module__4LtYgq__className{font-family:Outfit,Outfit Fallback;font-style:normal}.outfit_9f4f9187-module__4LtYgq__variable{--font-outfit:"Outfit","Outfit Fallback"}
@font-face{font-family:Merriweather;font-style:normal;font-weight:300;font-stretch:100%;font-display:swap;src:url(../media/02046ca7e906ed9f-s.78def622.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Merriweather;font-style:normal;font-weight:300;font-stretch:100%;font-display:swap;src:url(../media/6bbcb5b36acd717c-s.656fbe30.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Merriweather;font-style:normal;font-weight:300;font-stretch:100%;font-display:swap;src:url(../media/0797a9ffe47acb65-s.a9cc7c2a.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Merriweather;font-style:normal;font-weight:300;font-stretch:100%;font-display:swap;src:url(../media/7c2c7251ac640798-s.d6988a53.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Merriweather;font-style:normal;font-weight:300;font-stretch:100%;font-display:swap;src:url(../media/248e1dc0efc99276-s.p.8a6b2436.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Merriweather;font-style:normal;font-weight:400;font-stretch:100%;font-display:swap;src:url(../media/02046ca7e906ed9f-s.78def622.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Merriweather;font-style:normal;font-weight:400;font-stretch:100%;font-display:swap;src:url(../media/6bbcb5b36acd717c-s.656fbe30.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Merriweather;font-style:normal;font-weight:400;font-stretch:100%;font-display:swap;src:url(../media/0797a9ffe47acb65-s.a9cc7c2a.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Merriweather;font-style:normal;font-weight:400;font-stretch:100%;font-display:swap;src:url(../media/7c2c7251ac640798-s.d6988a53.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Merriweather;font-style:normal;font-weight:400;font-stretch:100%;font-display:swap;src:url(../media/248e1dc0efc99276-s.p.8a6b2436.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Merriweather;font-style:normal;font-weight:700;font-stretch:100%;font-display:swap;src:url(../media/02046ca7e906ed9f-s.78def622.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Merriweather;font-style:normal;font-weight:700;font-stretch:100%;font-display:swap;src:url(../media/6bbcb5b36acd717c-s.656fbe30.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Merriweather;font-style:normal;font-weight:700;font-stretch:100%;font-display:swap;src:url(../media/0797a9ffe47acb65-s.a9cc7c2a.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Merriweather;font-style:normal;font-weight:700;font-stretch:100%;font-display:swap;src:url(../media/7c2c7251ac640798-s.d6988a53.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Merriweather;font-style:normal;font-weight:700;font-stretch:100%;font-display:swap;src:url(../media/248e1dc0efc99276-s.p.8a6b2436.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Merriweather;font-style:normal;font-weight:900;font-stretch:100%;font-display:swap;src:url(../media/02046ca7e906ed9f-s.78def622.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Merriweather;font-style:normal;font-weight:900;font-stretch:100%;font-display:swap;src:url(../media/6bbcb5b36acd717c-s.656fbe30.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Merriweather;font-style:normal;font-weight:900;font-stretch:100%;font-display:swap;src:url(../media/0797a9ffe47acb65-s.a9cc7c2a.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Merriweather;font-style:normal;font-weight:900;font-stretch:100%;font-display:swap;src:url(../media/7c2c7251ac640798-s.d6988a53.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Merriweather;font-style:normal;font-weight:900;font-stretch:100%;font-display:swap;src:url(../media/248e1dc0efc99276-s.p.8a6b2436.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Merriweather Fallback;src:local(Times New Roman);ascent-override:80.59%;descent-override:22.36%;line-gap-override:0.0%;size-adjust:122.09%}.merriweather_97f465e9-module__9O5KkW__className{font-family:Merriweather,Merriweather Fallback;font-style:normal}.merriweather_97f465e9-module__9O5KkW__variable{--font-merriweather:"Merriweather","Merriweather Fallback"}
@font-face{font-family:Fira Code;font-style:normal;font-weight:300 700;font-display:swap;src:url(../media/88731e1a74492905-s.047a472f.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Fira Code;font-style:normal;font-weight:300 700;font-display:swap;src:url(../media/861011d7404b02f6-s.7861847e.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Fira Code;font-style:normal;font-weight:300 700;font-display:swap;src:url(../media/3381337b621a9a6a-s.29df3230.woff2)format("woff2");unicode-range:U+1F??}@font-face{font-family:Fira Code;font-style:normal;font-weight:300 700;font-display:swap;src:url(../media/5413d6e6d8960ee4-s.af0c84fa.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Fira Code;font-style:normal;font-weight:300 700;font-display:swap;src:url(../media/0951afe60dbf5d36-s.ce79b48e.woff2)format("woff2");unicode-range:U+2000-2001,U+2004-2008,U+200A,U+23B8-23BD,U+2500-259F}@font-face{font-family:Fira Code;font-style:normal;font-weight:300 700;font-display:swap;src:url(../media/97e7b204180d1274-s.9fe1d481.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Fira Code;font-style:normal;font-weight:300 700;font-display:swap;src:url(../media/b8b552e8609c5636-s.p.25aba60b.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Fira Code Fallback;src:local(Arial);ascent-override:73.56%;descent-override:23.92%;line-gap-override:0.0%;size-adjust:134.59%}.fira_code_a166c59a-module__Tv_4pG__className{font-family:Fira Code,Fira Code Fallback;font-style:normal}.fira_code_a166c59a-module__Tv_4pG__variable{--font-fira-code:"Fira Code","Fira Code Fallback"}
:root{--font-outfit:var(--font-outfit);--font-merriweather:var(--font-merriweather);--font-fira-code:var(--font-fira-code)}@media (prefers-color-scheme:dark){:root{--background:#181a1b;--foreground:#ededed;--border-color:#2a2a2a;--hover-color:#999;--code-background:#1a1a1a;--code-foreground:#e0e0e0;--blockquote-background:#1a1a1a;--blockquote-border:#333;--link-color:#66b3ff;--link-hover:#9cf}}:root[data-theme=dark]{--background:#23272f;--foreground:#ededed;--border-color:#2a2a2a;--hover-color:#999;--code-background:#1a1a1a;--code-foreground:#e0e0e0;--blockquote-background:#1a1a1a;--blockquote-border:#333;--link-color:#66b3ff;--link-hover:#9cf;--color-dark:#fff;--rgb-dark:255,255,255;--color-light:#1a1d24;--rgb-light:26,29,36;--color-text:#eef5ff;--rgb-text:238,245,255;--color-white:#fff;--rgb-white:255,255,255;--color-header-bg:#252627;--rgb-header-bg:37,38,39;--color-bg:#1a1d24;--rgb-bg:26,29,36;--color-main-bg:#191c22;--rgb-main-bg:25,28,34;--color-border:#3f4245;--rgb-border:63,66,69;--color-main:#49abff;--rgb-main:73,171,255;--color-main-dark-01:#9dadbe;--rgb-main-dark-01:157,173,190;--color-main-dark-02:#9dadbe;--rgb-main-dark-02:157,173,190;--color-card-time:#9fb0b9;--rgb-card-time:159,176,185;--color-card-excerpt:#78868e;--rgb-card-excerpt:120,134,142;--color-nav-link:#c0d1dc;--rgb-nav-link:192,209,220;--color-header-link:#c0d1dc;--rgb-header-link:192,209,220;--color-footer-link:#c0d1dc;--rgb-footer-link:192,209,220;--color-footer-copy:#c0d1dc;--rgb-footer-copy:192,209,220;--color-box-default-bg:#5b6e7e;--rgb-box-default-bg:91,110,126;--color-box-success-bg:#336c91;--rgb-box-success-bg:51,108,145;--color-box-warning-bg:#d3ae63;--rgb-box-warning-bg:211,174,99;--color-demo-box-title:#6180a3;--rgb-demo-box-title:97,128,163;--color-editor-bg:#171b25;--rgb-editor-bg:23,27,37;--color-editor-border:#334155;--rgb-editor-border:51,65,85;--color-editor-highlight:#75b1ff;--rgb-editor-highlight:117,177,255;--color-code-bg:#dfefff;--rgb-code-bg:223,239,255;--color-logo-gh:#6e5494;--rgb-logo-gh:110,84,148;--color-logo-tw:#1da1f2;--rgb-logo-tw:29,161,242;--color-logo-ig:#cd486b;--rgb-logo-ig:205,72,107;--color-lang-js:#ffd600;--rgb-lang-js:255,214,0;--color-lang-html:#ff8c0b;--rgb-lang-html:255,140,11;--color-lang-css:#2ea8ff;--rgb-lang-css:46,168,255;--color-lang-scss:#c69;--rgb-lang-scss:204,102,153;--color-lang-jsx:#82f3ff;--rgb-lang-jsx:130,243,255;--color-editor-red:#ff5f57;--rgb-editor-red:: 255,95,87;--color-editor-yellow:#febc2e;--rgb-editor-yellow:254,188,46;--color-editor-green:#28c840;--rgb-editor-green:40,200,64;--color-error:#f10000;--rgb-error:241,0,0}:root[data-theme=light]{--background:#fff;--foreground:#171717;--border-color:#eaeaea;--hover-color:#666;--code-background:#f5f5f5;--code-foreground:#333;--blockquote-background:#f8f8f8;--blockquote-border:#ddd;--link-color:#06c;--link-hover:#049;--color-dark:#1a1d24;--rgb-dark:26,29,36;--color-light:#fff;--rgb-light:255,255,255;--color-text:#191c22;--rgb-text:25,28,34;--color-white:#fff;--rgb-white:255,255,255;--color-header-bg:#f5f7fa;--rgb-header-bg:245,247,250;--color-bg:#f7faff;--rgb-bg:247,250,255;--color-main-bg:#fff;--rgb-main-bg:255,255,255;--color-border:#eaeaea;--rgb-border:234,234,234;--color-main:#0070f3;--rgb-main:0,112,243;--color-main-dark-01:#4a5568;--rgb-main-dark-01:74,85,104;--color-main-dark-02:#718096;--rgb-main-dark-02:113,128,150;--color-card-time:#6b7280;--rgb-card-time:107,114,128;--color-card-excerpt:#9ca3af;--rgb-card-excerpt:156,163,175;--color-nav-link:#374151;--rgb-nav-link:55,65,81;--color-header-link:#374151;--rgb-header-link:55,65,81;--color-footer-link:#374151;--rgb-footer-link:55,65,81;--color-footer-copy:#6b7280;--rgb-footer-copy:107,114,128;--color-box-default-bg:#e5e7eb;--rgb-box-default-bg:229,231,235;--color-box-success-bg:#d1fae5;--rgb-box-success-bg:209,250,229;--color-box-warning-bg:#fef3c7;--rgb-box-warning-bg:254,243,199;--color-demo-box-title:#2563eb;--rgb-demo-box-title:37,99,235;--color-editor-bg:#f3f4f6;--rgb-editor-bg:243,244,246;--color-editor-border:#e5e7eb;--rgb-editor-border:229,231,235;--color-editor-highlight:#0070f3;--rgb-editor-highlight:0,112,243;--color-code-bg:#f5f7fa;--rgb-code-bg:245,247,250;--color-logo-gh:#6e5494;--rgb-logo-gh:110,84,148;--color-logo-tw:#1da1f2;--rgb-logo-tw:29,161,242;--color-logo-ig:#cd486b;--rgb-logo-ig:205,72,107;--color-lang-js:#ffd600;--rgb-lang-js:255,214,0;--color-lang-html:#ff8c0b;--rgb-lang-html:255,140,11;--color-lang-css:#2ea8ff;--rgb-lang-css:46,168,255;--color-lang-scss:#c69;--rgb-lang-scss:204,102,153;--color-lang-jsx:#0070f3;--rgb-lang-jsx:0,112,243;--color-editor-red:#ff5f57;--rgb-editor-red:255,95,87;--color-editor-yellow:#febc2e;--rgb-editor-yellow:254,188,46;--color-editor-green:#28c840;--rgb-editor-green:40,200,64;--color-error:#f10000;--rgb-error:241,0,0}html,body{max-width:100vw;overflow-x:hidden}body{font-family:var(--font-merriweather);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--background);color:var(--foreground);font-weight:400;line-height:1.8}h1,h2,h3,h4,h5,h6{font-family:var(--font-outfit);margin-bottom:1rem;font-weight:700;line-height:1.2}a{color:var(--link-color);text-decoration:none;transition:color .2s}a:hover{color:var(--link-hover)}code,pre{font-family:var(--font-fira-code);background:var(--code-background);color:var(--code-foreground);border-radius:3px;padding:.2em .4em}pre{border:1px solid var(--border-color);border-radius:6px;padding:1em;overflow-x:auto}blockquote{background:var(--blockquote-background);border-left:4px solid var(--blockquote-border);margin:1.5em 0;padding:1em 1.5em;font-style:italic}.layout{flex-direction:column;min-height:100vh;display:flex}.header{height:var(--header-height);border-bottom:1px solid var(--border-color);flex:none;justify-content:space-between;align-items:center;padding:0 2rem;display:flex}.header nav{max-width:var(--max-width);align-items:center;gap:2rem;height:100%;margin:0 auto;display:flex}.header nav a{color:inherit;font-family:var(--font-outfit);font-weight:500;text-decoration:none}.header nav a:hover{color:var(--hover-color)}.main-content{flex-direction:column;flex:1 0 auto;justify-content:center;align-items:center;display:flex}.container{max-width:800px;margin:0 auto;padding:2rem}.footer{height:var(--footer-height);border-top:1px solid var(--border-color);background:var(--background);flex:none;justify-content:center;align-items:center;margin-top:auto;padding:1rem;display:flex}.footer-content{max-width:var(--max-width);flex-direction:column;align-items:center;gap:1rem;margin:0 auto;display:flex}.copyright{font-family:var(--font-outfit);color:var(--hover-color);font-size:.9rem}.footer-message{color:var(--hover-color);font-size:.9rem;font-family:var(--font-outfit)}
.header{text-align:center;padding:1rem 0;position:relative}.header nav{justify-content:center;gap:2rem;padding-right:4rem;display:flex}.theme-toggle{position:absolute;top:50%;right:1rem;transform:translateY(-50%)}.theme-toggle button{cursor:pointer;background:#e0e0e0;border:none;border-radius:12px;width:50px;height:24px;transition:background .3s;position:relative}.theme-toggle button:before{content:"";background:#fff;border-radius:50%;width:20px;height:20px;transition:transform .3s;position:absolute;top:2px;left:2px;box-shadow:0 2px 4px #0003}.theme-toggle button.active{background:#4a4a4a}.theme-toggle button.active:before{transform:translate(26px)}.theme-toggle button.light{background:#e0e0e0}@media (max-width:640px){.header nav{flex-wrap:wrap;justify-content:center;gap:1rem;padding-right:3.5rem}.theme-toggle{right:.5rem}}
