@import"https://fonts.googleapis.com/css2?family=Roboto+Mono:wght@400&display=swap";*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:-apple-system,BlinkMacSystemFont,Helvetica Neue,Roboto,Arial,Noto Sans,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:Menlo,Roboto Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}:root{--font-color: #495057;--heading-color: #343a40;--background: white;--dark-font-color: #1b1d25;--medium-font-color: #60656c;--light-font-color: #858b93;--light-background: #f6f8fb;--lighter-background: #e6e8eb;--border: #d6d9de;--link-color: #5c7cfa;--link-color-darker: #364fc7;--navbar-color: #1b1d25;--blockquote: #edf2ff;--transparent-text: rgba(0, 0, 0, .7);--transparent-bg: rgba(0, 0, 0, .05);--light-transparent-bg: rgba(255, 255, 255, .1);--code-font-family: Menlo, "Roboto Mono", Courier New, monospace}.dark{--font-color: #b3b9c5;--heading-color: #ffd479;--dark-font-color: #ced4da;--background: #282828;--medium-font-color: #dee2e6;--light-font-color: #868e96;--light-background: #383838;--lighter-background: #404040;--border: #404040;--link-color: #6ab0f3;--link-color-darker: #4a72a5;--link-hover-color: #e1a6f2;--navbar-color: #1d1d1d;--blockquote: #2a4661;--transparent-text: rgba(255, 255, 255, .7);--transparent-bg: rgba(0, 0, 0, .2);--light-transparent-bg: rgba(255, 255, 255, .05)}*,*:before,*:after{box-sizing:border-box}html{font-family:-apple-system,BlinkMacSystemFont,Helvetica Neue,Roboto,Roboto,Arial,Noto Sans,sans-serif,"Apple Color Emoji",Segoe UI,"Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";color:var(--font-color);font-weight:400;font-size:1rem;line-height:1.5}body{background:var(--background);margin:0;padding:0}h1,h2,h3,h4,h5{margin:0 0 1.5rem;font-weight:700;line-height:1.2;color:var(--heading-color);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1>a,h2>a,h3>a,h4>a,h5>a,h6>a{color:inherit;text-decoration:none}h1:not(:first-child),h2:not(:first-child),h3:not(:first-child),h4:not(:first-child){margin-top:3rem}h1{font-size:2.5rem;line-height:1.1}h2{font-size:1.75rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}h2 code{font-size:1.75rem!important}h3{font-size:1.5rem;color:var(--font-color);font-weight:600;margin-bottom:1rem}h3 code{font-size:1.4rem!important}h4{font-size:1.3rem;color:var(--font-color);font-weight:500;margin-bottom:1rem;border-bottom:1px solid var(--border);padding-bottom:.25rem}h5{font-size:1.2rem;margin-bottom:1rem}@media screen and (min-width:800px){h1{font-size:3rem}h2{font-size:1.8rem}h2 code{font-size:1.8rem!important}h3{font-size:1.6rem;color:var(--font-color);font-weight:600}h3 code{font-size:1.6rem!important}}p,ol,ul,dl,table,blockquote{font-size:1.05rem;margin:0 0 1.5rem}ul{padding:0 1rem}@media screen and (min-width:800px){p,ol,ul,dl,table,blockquote{font-size:1.1rem}ul{padding:0 2rem}}ul li p{margin:0}ul li ul{padding-left:1rem;margin:0}ul li ul li{margin:0}ol li ol{margin-bottom:0}blockquote{margin:2rem 0;padding:1rem;background:var(--blockquote);border-radius:.35rem;font-weight:400;border-left:3px solid var(--link-color)}blockquote *:last-child{margin:0}blockquote a{padding:1px 4px}blockquote :not(pre)>code[class*=language-]{background:#0000001a!important}blockquote a:hover{border-radius:.35rem;border-bottom:1px solid var(--link-color-darker);background:var(--link-color-darker);color:#fff}img{display:inline-block;max-width:100%;height:auto}a{color:var(--link-color);text-decoration:none;font-weight:700}a:hover{color:var(--link-color-darker)}a code[class*=language-]{color:var(--link-color)!important}a code[class*=language-]:hover{background:var(--link-color)!important;color:#fff!important}table{display:block;border-collapse:separate;border-spacing:0;width:100%;max-width:100%;overflow-x:auto;border-radius:.35rem}thead,tbody{white-space:nowrap}th{border-bottom:2px solid var(--border)}tfoot th{border-top:1px solid var(--border)}td{border-bottom:1px solid var(--border)}th,td{text-align:left;padding:.75rem!important;hyphens:auto;word-break:break-word}tbody tr:nth-child(2n){background-color:var(--light-background)}@media screen and (min-width:800px){table{display:table;border:1px solid var(--border)}}::-moz-selection{background:#3b5bdb;color:#fff}::selection{background:#3b5bdb;color:#fff}.dark h1{color:#fff}.dark h3,.dark h4{color:var(--medium-font-color)}.dark a{color:var(--link-color)}.dark a:hover{color:var(--link-hover-color)}.dark a.button{border:2px solid transparent;color:#fff;background:#4263eb}.dark a.button:hover{border:2px solid transparent;background:#748ffc}.dark a.button.secondary{border-color:var(--lighter-background);background:var(--lighter-background);color:#fff}.dark .navbar a{color:var(--transparent-text)}.dark .navbar a:hover,.dark .navbar a[aria-current=page],.dark .navbar a.brand{color:#fff}.dark .filename{background:linear-gradient(to bottom,#303030,#202020)!important;box-shadow:0 1px #64646480 inset,0 1px #515151;border:1px solid #202020!important;color:var(--dark-font-color)!important;text-shadow:none!important}.dark pre.language-terminal{background:var(--navbar-color);border:1px solid #111}.dark pre.language-terminal:before{border-bottom:1px solid #111;background:linear-gradient(to bottom,#303030,#202020)!important;color:inherit}.dark pre.language-terminal:after{text-shadow:none;color:var(--light-font-color)}.dark code.language-terminal{color:var(--dark-font-color)}.dark [type=search]{border:1px solid var(--light-background);background:var(--light-background);color:var(--dark-font-color);border:2px solid transparent}.dark [type=search]:focus{outline:none;border:2px solid var(--link-color)}.dark header u{background:linear-gradient(transparent 85%,#111 0)}.dark table,.dark td,.dark th{border-color:#111}.dark tbody tr:nth-child(odd){background-color:#222}.dark blockquote{color:#ffffffe6}.dark .new-post{background:#37b24d;color:#fff}.dark .guide h2{color:var(--medium-font-color)}.dark .guide-thumbnails a:hover{color:#fff}.container{width:100%}@media(min-width:640px){.container{max-width:640px}}@media(min-width:768px){.container{max-width:768px}}@media(min-width:1024px){.container{max-width:1024px}}@media(min-width:1280px){.container{max-width:1280px}}@media(min-width:1536px){.container{max-width:1536px}}.search-header{margin-bottom:20px}.search-title{font-size:24px;font-weight:700;margin-bottom:10px;margin-right:20px}.search-input{width:100%;padding:10px;border:1px solid #ccc;border-radius:5px;font-size:16px;box-sizing:border-box}.search-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 5px #007bff80}section{margin:2rem 0}section:first-of-type{margin-top:0}section>h2{display:flex;align-items:center;font-size:1.6rem;margin-top:0;margin-bottom:.5rem}@media screen and (min-width:800px){section>h2{margin-bottom:2rem}}.index h2,section>h2{border-bottom-width:0}@media screen and (min-width:800px){.index h2,section>h2{border-bottom-width:1px}}.section-button{font-weight:500;background:var(--light-background);color:var(--dark-font-color);padding:.4rem .6rem;font-size:.8rem;border-radius:3rem;border-bottom:0;white-space:nowrap;line-height:1;margin-left:2rem;margin-top:.5rem}.section-button:hover{background:#868e96;color:#fff}@media screen and (min-width:800px){section{margin:3.5rem 0}section>h2{font-size:2rem;margin:0 0 1rem}}.container{max-width:825px;padding:0 1.5rem;margin-left:auto;margin-right:auto}.container.page p{max-width:600px}@media screen and (min-width:800px){.container{padding:0 2rem}}.avatar{display:none;max-width:100px;margin-right:1rem}.blurb{padding:1.25rem 0;background:#fff;font-family:VT323,monospace}.blurb-subtitle{color:#bbb!important;padding-left:1rem;font-size:20px!important;line-height:1.25!important;margin-top:-.25rem!important;margin-bottom:.75rem!important;opacity:.8}.blurb-buttons{display:flex!important;flex-direction:row!important;flex-wrap:wrap;gap:.65rem;margin-top:.5rem}.blurb-compact{display:flex;flex-direction:column;gap:.5rem;align-items:flex-start;width:100%}@media screen and (min-width:600px){.blurb-compact{flex-direction:row;align-items:center;justify-content:flex-start}}.blurb-compact p{margin:0 auto 0 0;color:#bbb;font-size:22px;line-height:1;text-align:left}.blurb-compact p a{color:#fff;background:transparent}.blurb-compact p a:hover{color:#04a1a1;background:transparent}.blurb-socials{display:flex;align-items:center;gap:.85rem}.blurb-socials a{display:inline-flex;align-items:center;color:#bbb;background:transparent;padding:0;line-height:0}.blurb-socials a:hover{color:#fff;background:transparent}.blurb-buttons a.button{margin-top:0;margin-right:0;width:auto;flex:0 0 auto}.blurb .container{max-width:90%;background-color:#000;border:.875px solid #000000;border-left-width:2px;border-right-width:2px;padding:6.125px 11.5px 7px 10.5px;box-shadow:-3.5px -7px #bbb,2.5px 6.125px #bbb,-3.5px 6.125px #bbb,2.5px -7px #bbb;filter:drop-shadow(7px 8px 0 black);margin:7px auto 10px}.blurb p{color:#000;font-size:24px;line-height:1;font-weight:400}.blurb p:last-of-type{margin-bottom:.5rem}.blurb h3{color:#bbb;padding-left:1rem;font-size:32px;font-weight:400;line-height:1}.blurb a{color:#bbb;background:#000;font-weight:400}.blurb a:hover{color:#fff;background:#04a1a1;font-weight:400}.blurb a.button{border-color:#04a1a1;background:#04a1a1;color:#fff;border-radius:0;font-size:24px;padding:.25rem .75rem;filter:drop-shadow(7px 8px 0 black);margin-top:.25rem}.blurb a.button:hover{border-color:#fff;background:#fff;color:#000}@media screen and (min-width:800px){.blurb{padding:2.25rem 0}.blurb .container{display:flex;max-width:calc(825px - 4rem)}.avatar{display:block;max-width:130px}.blurb p{font-size:32px}.blurb-subtitle{font-size:24px!important}.blurb h3{font-size:40px}.blurb a.button{font-size:28px}}a.link{display:block;padding:.25rem 0;margin:.25rem 0;border-radius:.35rem;font-weight:600;color:var(--dark-font-color)}a.link:hover{color:var(--link-color)}a.button{display:inline-block;border:2px solid var(--link-color);padding:.3rem .6rem;margin-right:.75rem;font-weight:500;background:var(--link-color);color:#fff;border-radius:.35rem;font-size:.9rem}a.button.large{padding:.8rem 1rem;font-size:1.05rem}a.button.secondary{border:2px solid #edf2ff;background:#edf2ff;color:#3b5bdb}a.button:hover,a.button.secondary:hover{border:2px solid var(--link-color-darker);background:var(--link-color-darker);color:#fff}@media screen and (min-width:800px){a.button{font-size:.9rem}a.button.large{padding:1rem 1.5rem;font-size:1.1rem}}p.subtitle{color:var(--medium-font-color);font-size:1.3rem;font-weight:300;margin-bottom:0}@media screen and (min-width:800px){p.subtitle{font-size:1.5rem}}main{margin-top:50px}@media screen and (min-width:800px){main{margin-top:0}}.emoji{margin:0 .4rem 0 .1rem}.navbar{width:100%;position:fixed;top:0;left:0;background:var(--navbar-color);box-shadow:0 3px 13px #646e8c1a,0 2px 4px #646e8c26;z-index:2;padding:.5rem}.navbar .flex{justify-content:space-between}.navbar a{border-radius:.35rem;margin:0 .05rem;color:#bbb;font-weight:400;font-size:.85rem;border:1px solid transparent;padding:0 .3rem;background:transparent}.navbar button{font-size:1rem;margin-right:-1rem}.navbar a .emoji{display:none}.navbar a:first-of-type{margin-left:-1rem}.navbar a.brand{font-weight:500;color:#fff;white-space:nowrap;border:none;display:flex;align-items:center;line-height:1;background:transparent}.navbar a.brand .emoji{display:inline-block!important}.navbar a.brand img{height:22px;width:22px}@media screen and (min-width:500px){.navbar a{font-size:.95rem;padding:.5rem}}@media screen and (min-width:800px){.emoji{margin:0 .5rem 0 .1rem}.navbar{position:static;padding:1.5rem 0;background:transparent;box-shadow:none}.navbar>.container{max-width:min(1180px,calc(100vw - 4rem))}.navbar .flex{justify-content:space-between}.navbar a{padding:.75rem 1.25rem;margin:0 .25rem;font-size:1.1rem;color:var(--font-color)}.navbar a.brand{font-size:1.3rem;margin-right:3rem;border:none;background:transparent!important;color:var(--dark-font-color)}.navbar a.brand img{height:26px;width:26px;margin-right:.25rem}.navbar a:first-of-type{margin-left:-1.5rem}.navbar a:hover,.navbar a[aria-current=page]{background:var(--transparent-bg);color:var(--dark-font-color)}.navbar a.brand:hover{background:var(--transparent-bg)!important}#dark-mode-button:hover{background:var(--transparent-bg)}}@media print{.navbar{display:none}}#dark-mode-button{display:flex;border:none;padding:.2rem .7rem .2rem .5rem;border-radius:.35rem;box-sizing:content-box;cursor:pointer;font-size:1.1rem;background:transparent}#dark-mode-button:focus{outline:none}@media screen and (min-width:800px){#dark-mode-button{padding:.75rem;font-size:1.2rem}}.footer{padding:2rem 0}.footer>.flex{flex-direction:column;align-items:center;justify-content:center}.footer-links{display:flex;align-items:center;justify-content:center;flex-wrap:wrap}.flex nav{padding:1rem 0}.footer a{border-radius:.35rem;margin:0 .05rem;font-weight:400;font-size:1rem;border:1px solid transparent;padding:.5rem;margin:0 .5rem;color:var(--light-font-color)}.footer a:hover{color:var(--heading-color);background:var(--transparent-bg)}.footer a.img{display:flex;align-items:center;padding:0;margin:0 .75rem;background:none}.footer img{height:30px;width:30px}@media screen and (min-width:800px){.footer>.flex{align-items:flex-start;margin-left:-1.5rem;margin-right:-1.5rem}.footer a{padding:.75rem}.footer a.img{padding:0 .5rem;margin:0 1rem}}@media print{.footer{display:none}}.flex{display:flex;align-items:center}.new-post,.popular-post{display:inline-block;color:#111;padding:.3rem .4rem;border-radius:.3rem;font-size:.85rem;margin-left:1rem}.new-post{background:#d3f9d8}.popular-post{background:#4263eb;color:#fff}@media screen and (min-width:800px){.new-post,.popular-post{margin-bottom:0}}header{padding:1.5rem 0}header h1{font-size:2rem;display:inline-block;font-weight:600;margin-top:1rem}header u{display:inline-block;text-decoration:none;padding:.4rem 0}.article-header{padding-top:2rem;margin-bottom:3rem}.article-header .container{padding-left:0;padding-right:0}@media screen and (min-width:1100px){.article-header>.container{max-width:min(1180px,calc(100vw - 4rem));padding-left:2rem;padding-right:calc(5rem + 240px)}.post-footer{max-width:min(1180px,calc(100vw - 4rem));margin-left:auto;margin-right:auto;padding-left:2rem;padding-right:calc(5rem + 240px)}.post-footer .container{max-width:100%;padding-left:0;padding-right:0}.post-footer .blurb .container{max-width:100%;padding-left:1.25rem;padding-right:1.25rem}}.now-updated{display:flex;width:-moz-fit-content;width:fit-content;align-items:center;gap:.5rem;margin:.75rem 0 1rem;padding:.4rem .85rem;border-radius:999px;background:var(--light-background);border:1px solid var(--border);color:var(--medium-font-color);font-size:.9rem;font-weight:500}.now-updated-dot{width:8px;height:8px;border-radius:50%;background:#51cf66;box-shadow:0 0 0 3px #51cf662e;flex:0 0 auto}.now-updated-relative{color:var(--light-font-color);font-weight:400}.now-updated.is-stale{color:var(--light-font-color);font-style:italic}.now-updated.is-stale .now-updated-dot{background:#adb5bd;box-shadow:0 0 0 3px #adb5bd2e}.article-header .thumb{display:flex;flex-direction:column;gap:1rem}.article-header .thumb-text{min-width:0;flex:1}.article-header h1{font-weight:700;font-size:1.8rem;margin:0;line-height:1.2}.article-header .description{font-size:1.2rem;color:var(--medium-font-color);font-weight:300;margin-top:1.5rem;margin-bottom:0}.article-post img{display:block;max-width:100%;height:auto;margin:1.5rem auto;border-radius:6px}.post-hero{display:flex;justify-content:center;align-items:center;background:#f3efe7;padding:3.5rem 2rem;margin:.5rem auto 2.5rem;border-radius:8px;border:1px solid rgba(0,0,0,.06)}.home-grid{display:grid;grid-template-columns:1fr;gap:3rem;margin-bottom:3rem}.home-grid>section{display:flex;flex-direction:column;margin:0}.home-grid>section>:last-child{flex:1}@media screen and (min-width:800px){.home-grid{grid-template-columns:minmax(0,4fr) minmax(0,5fr);-moz-column-gap:6rem;column-gap:6rem;row-gap:3rem;align-items:stretch;position:relative;width:min(1200px,calc(100vw - 3rem));margin-left:50%;margin-bottom:8rem;transform:translate(-50%)}}.post-hero img{display:block;max-width:520px;width:100%;height:auto;margin:0;border-radius:4px;box-shadow:0 8px 28px #0000001a,0 2px 6px #0000000f;border:1px solid rgba(0,0,0,.08)}.context-checklist{background:#fbf9f5;border:1px solid rgba(122,109,84,.2);border-left:3px solid #1a1a1a;padding:1.25rem 1.5rem;margin:1.75rem 0 2.25rem;border-radius:0 6px 6px 0}.context-checklist .checklist-label{display:block;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.7rem;letter-spacing:.2em;color:#7a6d54;text-transform:uppercase;margin:0 0 .85rem}.context-checklist ul{list-style:none;padding:0;margin:0}.context-checklist ul li{padding:.55rem 0 .55rem 1.75rem;position:relative;font-size:.98rem;line-height:1.55}.context-checklist ul li+li{border-top:1px dashed rgba(0,0,0,.08)}.context-checklist ul li:before{content:"?";position:absolute;left:0;top:.55rem;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.95rem;font-weight:700;color:#1a1a1a}.context-checklist.context-loaded ul li:before{content:"✓";font-family:inherit;font-size:1rem}.post-meta{color:var(--light-font-color);font-size:.85rem;line-height:1.3;display:flex;flex-direction:column;gap:.4rem}.post-meta a{color:var(--font-color)}.post-meta a:hover{text-decoration:underline}.post-meta time{margin-top:0rem;font-size:.85rem}.post-meta .tags{margin-top:0rem}.post-meta .\!tags{margin-top:0rem!important}.post-meta .tags a{text-decoration:none}.post-meta .\!tags a{text-decoration:none!important}.article-with-aside{display:block}.article-aside{display:none}@media screen and (min-width:1100px){.container.article-with-aside{max-width:min(1180px,calc(100vw - 4rem))}.article-with-aside{display:grid;grid-template-columns:minmax(0,1fr) 240px;-moz-column-gap:3rem;column-gap:3rem;align-items:start}.article-aside{display:block;position:sticky;top:6rem;align-self:start}}.article-aside-inner{display:flex;flex-direction:column;gap:1.5rem}.article-share{display:flex;flex-wrap:nowrap;gap:.4rem}.article-share-inline{flex-wrap:wrap;margin-top:.85rem}.article-header.article-header-narrow>.container{padding-left:1.5rem;padding-right:1.5rem}@media screen and (min-width:800px){.article-header.article-header-narrow>.container{padding-left:2rem;padding-right:2rem}}@media screen and (min-width:1100px){.article-header.article-header-narrow>.container{max-width:825px}.post-footer.post-footer-narrow{max-width:825px;padding-left:2rem;padding-right:2rem}}.article-share a,.article-share button.share-copy{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;flex:0 0 32px;border-radius:8px;background:var(--light-background);color:var(--medium-font-color);border:1px solid var(--border);padding:0;cursor:pointer;line-height:0;position:relative}.article-share a:hover,.article-share button.share-copy:hover{color:var(--font-color);background:var(--lighter-background);text-decoration:none}.share-copied{position:absolute;bottom:-1.4rem;right:0;font-size:.75rem;line-height:1;color:var(--font-color);white-space:nowrap}.article-toc{border:1px solid var(--border);border-radius:10px;background:var(--light-background);padding:1rem 1.1rem}.article-toc-title{display:flex;align-items:center;gap:.5rem;font-weight:600;color:var(--font-color);padding-bottom:.65rem;margin-bottom:.5rem;border-bottom:1px solid var(--border)}.article-toc ul{list-style:none;padding:0;margin:0;font-size:.9rem}.article-toc li{margin:0}.article-toc li.toc-depth-3{padding-left:.85rem}.article-toc a{display:block;color:var(--medium-font-color);font-weight:400;line-height:1.35;border-left:2px solid transparent;padding:.3rem 0 .3rem .6rem;margin-left:-.6rem;transition:color .15s ease,border-color .15s ease}.article-toc a:hover{color:var(--font-color);text-decoration:none}.article-toc a.is-active{color:var(--link-color);border-left-color:var(--link-color);font-weight:600}.anchor.before{stroke:var(--link-color);stroke-width:1px;fill:var(--link-color);font-weight:700;left:-.25rem}.article-post .anchor.before{top:1rem}@media screen and (min-width:800px){.post-meta{margin-top:.2rem;padding:0rem 0}header h1{font-size:3rem;margin-top:2rem}header u{background:linear-gradient(transparent 85%,#bac8ff 0)}.article-header{padding-top:2rem}.article-header h1{padding-bottom:0;font-size:3rem}.article-header .thumb{flex-direction:row;align-items:flex-start;gap:1.75rem}.article-header .description{font-size:1.5rem}}@media screen and (min-width:1100px){.article-header h1{font-size:2.5rem}}.post-thumbnail{flex-shrink:0;width:140px;height:140px}.post-thumbnail img{display:block;width:100%;height:100%;-o-object-fit:cover;object-fit:cover;border-radius:8px}@media screen and (min-width:800px){.post-thumbnail{width:200px;height:200px}}.search-form{display:flex}[type=search]{padding:.8rem 1rem;border:1px solid var(--border);width:100%;max-width:400px;border-radius:.35rem;font-size:1rem;-webkit-appearance:none;margin-left:auto;margin-right:auto;margin-bottom:3rem}.search-form [type=search]{border-right:none;border-top-right-radius:0;border-bottom-right-radius:0}::placeholder,::-webkit-input-placeholder,::-moz-placeholder,:-moz-placeholder,:-ms-input-placeholder{color:var(--light-font-color)}.suggested{flex-direction:column;align-items:stretch;margin-left:-1rem;margin-right:-1rem;padding:0}.suggested span{font-weight:400;display:block;font-size:.9rem;color:var(--transparent-text)}.suggested a{background:none;margin:.5rem 1rem;border-bottom:none;transition:all .2s ease;padding:1.5rem;border-radius:.35rem;background:var(--light-background);border:1px solid var(--border);color:var(--heading-color)}.suggested a:hover{transform:translate3D(0,-1px,0);background:var(--lighter-background)}@media screen and (min-width:800px){.suggested{flex-direction:row}.suggested a{flex:0 0 calc(50% - 2rem)}.suggested a:first-of-type{text-align:right}}.small{max-width:600px}time,.meta{color:var(--light-font-color);font-size:.85rem;white-space:nowrap;font-weight:400}.meta{color:var(--medium-font-color);font-size:1rem}.count{font-weight:700;color:var(--link-color)}.\!tags{display:flex!important;flex-wrap:wrap!important;align-items:center!important;margin-left:-.5rem!important;margin-right:-.5rem!important}.tags{display:flex!important;flex-wrap:wrap;align-items:center;margin-left:-.5rem;margin-right:-.5rem}.\!tags>a{display:block!important;font-weight:500!important;background:var(--light-background)!important;color:var(--font-color)!important;margin:.2rem!important;padding:.5rem .6rem!important;font-size:.8rem!important;border-radius:.3rem!important;border-bottom:0!important;white-space:nowrap!important;line-height:1!important}.tags>a{display:block;font-weight:500;background:var(--light-background);color:var(--font-color);margin:.2rem;padding:.5rem .6rem;font-size:.8rem;border-radius:.3rem;border-bottom:0;white-space:nowrap;line-height:1}.\!tags>a:hover{background:var(--lighter-background)!important;color:var(--heading-color)!important}.tags>a:hover{background:var(--lighter-background);color:var(--heading-color)}mark{background:#ffec99}kbd{background-color:#f7f7f7;border:2px solid rgba(0,0,0,.3);border-radius:3px;box-shadow:0 1px #0003,inset 0 0 0 2px #fff;color:#333;display:inline-block;font-family:Helvetica Neue,Inter,-apple-system,BlinkMacSystemFont,Helvetica,Arial,sans-serif;line-height:1.4;margin:0 .1em;padding:.1em .6em;text-shadow:0 1px 0 #fff;font-size:14px}#comments{margin-top:3rem}#comments h2{margin:0}@media print{.comments,#comments{display:none}}.post-row{display:flex;align-items:center;width:100%}.post-row time{display:block;flex:0 0 65px}.post-row h3{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.post a{display:flex;align-items:center;justify-content:stretch;padding:.75rem 0;border-bottom:1px solid var(--border)}.posts .post:last-of-type a{border-bottom-width:0}.post a:hover{border-radius:.3rem}.post a:hover h3{text-decoration:underline}.post h3{margin-top:.1rem;margin-bottom:0;font-size:1.1rem;font-weight:600}@media screen and (min-width:800px){.post h3{font-size:1.2rem}.post a{padding:.6rem 0;border-bottom-color:transparent}.post-row time{flex:0 0 80px}}.projects .project:last-of-type{border-bottom-width:0}.project{display:flex;align-items:center;justify-content:space-between;padding:1rem 0;border-bottom:1px solid var(--border)}.project .icon{font-size:1.5rem;width:40px}.project a{display:flex;align-items:center;margin-bottom:.25rem}.project a:hover h3{text-decoration:underline}.project h3{font-size:1.2rem;margin:0}.project .description{font-size:1.1rem;color:var(--light-font-color)}.project a.button{margin-left:1.5rem}@media screen and (min-width:800px){.project{border-bottom-width:0}.project h3{font-size:1.3rem}.project .description{font-size:1rem}}.guides .gatsby-image-wrapper{height:50px!important;width:50px!important;min-width:50px;margin-right:1rem}.guides.front-page .guide h2{margin-bottom:0}.guides.front-page img{height:50px!important;width:50px!important;min-width:50px;margin-right:1rem}.guides .guide:last-of-type{border-bottom-color:transparent}.guide{display:flex;padding:1.5rem 0;border-bottom:1px solid var(--border)}.guide h2{font-size:1.2rem;font-weight:600;padding-bottom:.5rem;margin:0 0 .5rem;border-bottom:none}.guide a h2:hover{text-decoration:underline}.guide p{font-weight:400;margin:0;line-height:1.5;color:var(--light-font-color);font-size:1rem}@media screen and (min-width:800px){.guides.front-page img{margin-right:1.5rem}.guides.front-page .guide{border-bottom:none}.guides .gatsby-image-wrapper{height:100px!important;width:100px!important;min-width:100px;margin-right:2rem}.guide{padding:2rem 0}.guides.front-page .guide{padding:1.5rem 0}}.stack-mobile{display:flex;flex-direction:column}@media screen and (min-width:800px){.stack-mobile{display:block}}.article-post h1>a,.article-post h2>a,.article-post h3>a,.article-post h4>a,.article-post h5>a,.article-post h6>a{color:inherit;font-weight:inherit;text-decoration:none}.article-post h1>a:hover,.article-post h2>a:hover,.article-post h3>a:hover,.article-post h4>a:hover,.article-post h5>a:hover,.article-post h6>a:hover{color:var(--link-color)}a.guide{display:flex;padding:1.5rem 0;border-bottom:1px solid var(--border);color:var(--heading-color)}a.guide:hover h3,a.guide:hover h2{text-decoration:underline}.guide-thumb{width:50px;height:50px;flex-shrink:0;overflow:hidden;aspect-ratio:1;margin-right:1rem}.guide-thumb img{width:100%!important;height:100%!important;-o-object-fit:cover;object-fit:cover}.guide-content h3{font-size:1.2rem;font-weight:600;padding-bottom:0;margin:0 0 .25rem;border-bottom:none;color:var(--heading-color)}.guide-content p{font-weight:400;margin:0;line-height:1.5;color:var(--light-font-color);font-size:1rem}@media screen and (min-width:800px){.guides.front-page .guide-thumb{margin-right:1.5rem}.guides.front-page a.guide{border-bottom:none;padding:1.5rem 0}a.guide{padding:2rem 0}}.visible{visibility:visible}.invisible{visibility:hidden}.collapse{visibility:collapse}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.block{display:block}.inline{display:inline}.flex{display:flex}.table{display:table}.grid{display:grid}.contents{display:contents}.hidden{display:none}.flex-shrink{flex-shrink:1}.grow{flex-grow:1}.border-collapse{border-collapse:collapse}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.flex-wrap{flex-wrap:wrap}.justify-center{justify-content:center}.border{border-width:1px}.uppercase{text-transform:uppercase}.italic{font-style:italic}.underline{text-decoration-line:underline}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.outline{outline-style:solid}.ring{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.blur{--tw-blur: blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.grayscale{--tw-grayscale: grayscale(100%);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-filter{backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.ease-in{transition-timing-function:cubic-bezier(.4,0,1,1)}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.var-highlight{color:#569cd6}.const-highlight{color:#4fc1ff}.white-highlight{color:#dfd4ff}.bracket-highlight{color:#ffe600}.array-highlight{color:#be3cdf}.string-highlight{color:#fa7629cc}.key-highlight{color:#9cdcfe}#typewriter{font-size:1em;margin:0;font-weight:700;font-family:Fira Code}#typewriter_cursor{color:"#bbbbbb"}#typewriter_cursor:after{content:" ";display:inline-block;margin-left:2px;background-color:#fff;animation-name:blink;animation-duration:.5s;animation-iteration-count:infinite}.fancy-link{display:inline-flex;align-items:baseline;color:#17717a;font-weight:700;-webkit-text-decoration-skip:ink;text-decoration-skip-ink:auto}.fancy-link:hover,.fancy-link:focus{text-decoration:none}.fancy-link__icon{font-size:1em}.icon{width:1em;height:1em}pre#typewriter:after{height:1em;width:.5em}@keyframes blink{0%{opacity:1}49%{opacity:1}50%{opacity:0}to{opacity:0}}:root{--code-font-family: Menlo, "Roboto Mono", Courier New, monospace;--code-font-color: #b3b9c5;--code-background-color: #353535;--string: #92d192;--variable: #f2777a;--property: #abb2bf;--number: #fca369;--operator: #ac8d58;--punctuation: #d5d8df;--comment: #848991;--function: #62cfcf;--keyword: #ffeead;--attribute: #ffd479;--class: #e1a6f2;--tag: #6ab0f3;--error: #f2777a}code[class*=language-],pre[class*=language-]{-webkit-font-smoothing:subpixel-antialiased;color:var(--code-font-color);font-family:var(--code-font-family);font-size:.9rem;text-align:left;white-space:pre-wrap;word-spacing:normal;word-break:normal;word-wrap:normal;font-weight:400;line-height:1.7;-moz-tab-size:2;-o-tab-size:2;tab-size:2;hyphens:none}pre[class*=language-]{padding:1.5rem;margin:.6rem -1.5rem 2rem;overflow:auto;box-shadow:0 0 1px #0000001a,0 0 1px #0000000f,0 2px 2px #0000000f,0 4px 4px #0000000f,0 8px 8px #0000000f,0 16px 16px #0000000f}@media screen and (min-width:800px){code[class*=language-],pre[class*=language-]{font-size:.9rem}pre[class*=language-]{padding:1.5rem;margin-left:auto;margin-right:auto;border-radius:.35rem}}:not(pre)>code[class*=language-],pre[class*=language-]{background-color:var(--code-background-color)}:not(pre)>code[class*=language-]{padding:.1rem .3rem;border-radius:.35rem}pre.language-text,code.language-text{background:var(--light-background)!important;color:var(--dark-font-color)!important;border:1px solid var(--border);box-shadow:none}pre.language-text code.language-text{border:none}code.language-shell:before{content:"$ ";color:var(--comment)}pre.language-terminal{position:relative;background:#fff;color:#595c62;padding-top:3rem;margin:2rem 0;border-radius:.35rem;border:1px solid #c7c9ca;box-shadow:0 .5rem 1rem #3333,0 .5rem 2rem #3333}code.language-terminal{color:#595c62}pre.language-terminal:before{content:"•••";position:absolute;top:0;left:0;background:linear-gradient(to bottom,#eaeaea,#d2d2d2);color:#b9bcbd;width:100%;font-size:2.5rem;margin:0;line-height:0;padding:15px 0 12px;text-indent:6px;letter-spacing:-18px;border-bottom:1px solid #a6a9aa}pre.language-terminal:after{content:"Output";line-height:1;font-family:Myriad Pro,sans-serif;text-shadow:0px 1px 0px rgba(255,255,255,.5);font-size:.9rem;position:absolute;top:6px;right:.5rem}.gatsby-highlight-code-line{background-color:#191919;display:block;margin-right:-1rem;margin-left:-1rem;padding-right:1rem;padding-left:.75rem;border-left:.25rem solid #748ffc}.token.comment,.token.prolog,.token.doctype,.token.cdata,.token.important{color:var(--comment)}.token.punctuation{color:var(--punctuation)}.token.namespace{opacity:.7}.token.property{color:var(--property)}.token.tag,.token.constant,.token.symbol,.token.deleted{color:var(--tag)}.token.number{color:var(--number)}.token.char,.token.builtin,.token.url,.token.inserted{color:var(--code-font-color)}.token.attr-name,.token.selector{color:var(--attribute)}.token.attr-value,.token.string{color:var(--string)}.token.operator{color:var(--operator)}.token.atrule,.token.keyword{color:var(--keyword)}.token.function{color:var(--function)}.language-css,.token.boolean,.token.class-name{color:var(--class)!important}.token.regex{color:var(--keyword)}.token.variable{color:var(--variable)}.token.bold{font-weight:700}.token.italic{font-style:italic}.token.entity{cursor:help}.filename{font-size:.9rem;margin-bottom:-.8rem;padding:.3rem 1.5rem;line-height:1;font-family:Myriad Pro,sans-serif;background:linear-gradient(to bottom,#eaeaea,#d2d2d2);border:1px solid #b9bcbd;color:#4d494d;z-index:2;margin-left:-1.5rem;margin-right:-1.5rem;text-shadow:0px 1px 0px rgba(255,255,255,.5);box-shadow:0 1px #ffffff80 inset,0 1px #515151;text-align:center}@media screen and (min-width:800px){.filename{padding:.3rem 1rem .5rem;border-top-left-radius:.3rem;border-top-right-radius:.3rem;margin-left:auto;margin-right:auto}}pre::-moz-selection,code::-moz-selection{text-shadow:none;color:inherit;background:#9696964d!important}pre::selection,code::selection{text-shadow:none;color:inherit;background:#9696964d!important}pre[class*=language-]::-moz-selection,code[class*=language-] ::-moz-selection{text-shadow:none;color:inherit;background:#9696964d!important}pre[class*=language-]::selection,code[class*=language-] ::selection{text-shadow:none;color:inherit;background:#9696964d!important}.Image__Small img,.Image__Medium img{display:block;max-width:100%;height:auto;border:1px solid #ccc;border-radius:5px}.Image__Small{max-width:400px;margin:1rem 0}.Image__Medium{max-width:600px;margin:1rem 0}.collage-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px}.collage-item{text-align:center}.collage-item img{height:200px;width:auto;border:1px solid #ccc;border-radius:5px}.collage-caption{margin-top:5px;font-size:14px;color:#555}.card{background-color:#f0f8ff;border:1px solid #dce3e8;border-radius:10px;padding:25px;box-shadow:0 4px 12px #0000000d;width:calc(100% - 40px);max-width:800px;margin:30px auto}.card h2{margin:0 0 20px;color:#2a3f54;font-weight:700;font-size:1.5rem;border-bottom:2px solid #dce3e8;padding-bottom:10px}.card ol{margin:0;padding-left:20px;color:#4a4a4a;font-size:1rem}.card ol li{margin:12px 0;line-height:1.6}.card ol li strong{color:#007acc}.dark .card{background-color:#2a2a2a;border-color:#404040}.dark .card h2{color:#ffd479;border-bottom-color:#404040}.dark .card ol{color:#b3b9c5}.dark .card ol li strong{color:#6ab0f3}.dark .collage-caption{color:#999}.dark .collage-item img{border-color:#555}
