:root{--font-weight:400;--background:255,255,255;--text:17,17,17;--header:106,0,186;--header-text:255,255,255;--padding:6rem;--link:106,0,186;--link-visited:17,17,17;--button-shadow:170,170,170;--button-hover:255,255,255;--content-width:90rem;--list-indent:0;--inline-code-back:rgba(17,17,17,0.05)}@media(prefers-color-scheme:dark){:root{--font-weight:300;--background:17,17,17;--text:226,218,247;--link:203,153,243;--link-visited:255,255,255;--button-shadow:17,17,17;--button-hover:var(--header);--inline-code-back:rgba(255,255,255,0.05)}}@media(max-width:50em){:root{--padding:2.4rem;--list-indent:1.2em}}@font-face{font-family:roboto;font-style:normal;font-weight:300;src:local(''),url(/fonts/roboto-v20-latin-300.woff2)format('woff2'),url(/fonts/roboto-v20-latin-300.woff)format('woff')}@font-face{font-family:roboto;font-style:italic;font-weight:300;src:local(''),url(/fonts/roboto-v20-latin-300italic.woff2)format('woff2'),url(/fonts/roboto-v20-latin-300italic.woff)format('woff')}@font-face{font-family:roboto;font-style:normal;font-weight:400;src:local(''),url(/fonts/roboto-v20-latin-regular.woff2)format('woff2'),url(/fonts/roboto-v20-latin-regular.woff)format('woff')}@font-face{font-family:roboto;font-style:italic;font-weight:400;src:local(''),url(/fonts/roboto-v20-latin-italic.woff2)format('woff2'),url(/fonts/roboto-v20-latin-italic.woff)format('woff')}@font-face{font-family:roboto;font-style:normal;font-weight:700;src:local(''),url(/fonts/roboto-v20-latin-700.woff2)format('woff2'),url(/fonts/roboto-v20-latin-700.woff)format('woff')}@font-face{font-family:roboto;font-style:italic;font-weight:700;src:local(''),url(/fonts/roboto-v20-latin-700italic.woff2)format('woff2'),url(/fonts/roboto-v20-latin-700italic.woff)format('woff')}@font-face{font-family:roboto;font-style:normal;font-weight:900;src:local(''),url(/fonts/roboto-v20-latin-900.woff2)format('woff2'),url(/fonts/roboto-v20-latin-900.woff)format('woff')}@font-face{font-family:roboto;font-style:italic;font-weight:900;src:local(''),url(/fonts/roboto-v20-latin-900italic.woff2)format('woff2'),url(/fonts/roboto-v20-latin-900italic.woff)format('woff')}@font-face{font-family:petrona;font-style:normal;font-weight:300;src:local(''),url(/fonts/petrona-v12-latin-300.woff2)format('woff2'),url(/fonts/petrona-v12-latin-300.woff)format('woff')}@font-face{font-family:petrona;font-style:normal;font-weight:400;src:local(''),url(/fonts/petrona-v12-latin-regular.woff2)format('woff2'),url(/fonts/petrona-v12-latin-regular.woff)format('woff')}@font-face{font-family:petrona;font-style:normal;font-weight:700;src:local(''),url(/fonts/petrona-v12-latin-700.woff2)format('woff2'),url(/fonts/petrona-v12-latin-700.woff)format('woff')}@font-face{font-family:petrona;font-style:italic;font-weight:300;src:local(''),url(/fonts/petrona-v12-latin-300italic.woff2)format('woff2'),url(/fonts/petrona-v12-latin-300italic.woff)format('woff')}@font-face{font-family:petrona;font-style:italic;font-weight:400;src:local(''),url(/fonts/petrona-v12-latin-italic.woff2)format('woff2'),url(/fonts/petrona-v12-latin-italic.woff)format('woff')}@font-face{font-family:petrona;font-style:italic;font-weight:700;src:local(''),url(/fonts/petrona-v12-latin-700italic.woff2)format('woff2'),url(/fonts/petrona-v12-latin-700italic.woff)format('woff')}html{box-sizing:border-box}*,*:before,*:after{box-sizing:inherit}img{display:block;max-width:100%;height:auto}body,h1,h2,h3,h4,h5,h6,p,ul,ol{font-size:1em;font-style:normal;font-weight:var(--font-weight);margin:0;padding:0}ul,ol{list-style-type:none}figure{margin:0;padding:0}strong{font-weight:700}html{font-size:62.5%}body{background:rgb(var(--background));background-size:auto 10px;color:rgb(var(--text));font-family:roboto,Helvetica,Arial,sans-serif;font-family:petrona,sans-serif;font-size:2.2rem;line-height:1.5;padding-bottom:calc(var(--padding)/2)}.page-title{font-size:calc( 3.2rem + (7.2 - 3.2) * (100vw - 40rem)/(130 - 40) );font-weight:900;margin:4rem auto 0;max-width:var(--content-width)}.header[style] .page-title{text-shadow:0 0 5rem #111,0 0 2.5rem rgba(17,17,17,.25)}@media(min-width:81.5em){.page-title{font-size:7.2rem}}@media(max-width:45em){.page-title{margin-top:2rem}}.sub-title{margin:0 auto;max-width:var(--content-width);text-align:right}.header,.footer,h1,h2,h3,h4,h5,h6{font-family:roboto,Helvetica,Arial,sans-serif}h2,h3,h4,h5,h6{margin-bottom:3rem}h2,h3{margin-top:5rem}h2{font-size:3.2rem;font-weight:700}h2 br{display:none}h3{font-size:2.4rem;font-weight:700}h2:first-child,h3:first-child,h4:first-child,h5:first-child,h6:first-child{margin-top:0}h2+h3,h3+h4{margin-top:0}p:not([class]),ul:not([class]),ol:not([class]){margin-bottom:3rem}ul:not([class]),ol:not([class]){margin-left:var(--list-indent)}ul:not([class]){list-style-type:disc}ol:not([class]){list-style-type:decimal}p:not([class]):last-child,ul:not([class]):last-child,ol:not([class]):last-child{margin-bottom:0}ul ul{padding-left:3rem}figcaption,figcaption *{font-size:1.6rem}p code{background:var(--inline-code-back);padding:.2rem .3rem}.read-count{font-size:2rem}.header{background:linear-gradient(195deg,rgba(0,149,221,0) 25%,rgba(0,149,221,.5) 100%),linear-gradient(120deg,#6a00ba 0%,#cd1677 50%,#ff8d00 100%);background-size:cover!important;color:rgb(var(--header-text));padding:var(--padding);position:relative}.header:after{background:url(/nav/square-light.svg)repeat-x;content:'';display:block;height:10px;left:0;position:absolute;bottom:0;width:100%}@media(prefers-color-scheme:dark){.header:after{background:url(/nav/square-dark.svg)repeat-x}}.header a.logo{color:rgb(var(--header-text));display:inline-block;font-size:2.8rem;font-weight:700;text-decoration:none;text-transform:uppercase}.logo__di{display:block;font-size:13rem;line-height:.75;margin:0 0 -.3rem -.75rem}.header a.logo:hover{text-decoration:none}.header a.logo:after{content:'';display:block;height:.8rem;width:100%;margin-top:.8rem}.header a.logo:hover:after{background:rgb(var(--header-text))}.header__menu{position:absolute;right:var(--padding);top:0}@media(max-width:45em){.header a.logo{font-size:1.4rem}.logo__di{font-size:6.5rem;margin:0 0 -.1rem -.45rem}}.header a{color:rgb(var(--header-text));text-decoration:none}.header a:hover,.header a:focus{text-decoration:underline;text-underline-offset:2.4rem;text-decoration-skip:objects;text-decoration-thickness:.8rem}@media(max-width:45em){.header a:hover,.header a:focus{text-underline-offset:.8rem;text-decoration-thickness:.8rem}}.menu{display:flex}.menu li{margin-left:2.4rem}.menu a{display:block;padding-top:1.6rem;position:relative}.menu a:hover,.menu a:focus{text-decoration:none}.menu a:hover:after,.menu a:focus:after{content:'';display:block;height:.8rem;width:100%;background:rgb(var(--header-text));margin-top:.8rem}.menu .active:before{background:rgb(var(--header-text));content:'';height:.8rem;position:absolute;top:0;width:100%}.page{margin:calc(var(--padding) + 10px)auto 0;max-width:calc(var(--content-width) + (var(--padding) * 2));padding:0 var(--padding);position:relative}.page__sidebar{font-size:1.8rem;font-weight:500;padding:.5rem 0;padding-left:calc(var(--padding)/2);position:absolute;right:var(--padding);top:0;width:22rem}.page__sidebar:before{background:url(/nav/square-dark.svg)repeat-y;background-size:10px 10px;bottom:0;content:" ";left:0;opacity:.2;position:absolute;top:0;width:10px}@media(prefers-color-scheme:dark){.page__sidebar:before{background:url(/nav/square-light.svg)repeat-y;background-size:10px 10px}}article .page__content{overflow:hidden}article h2,.page__content>*{padding-right:26rem}.page__content .pullout,.page__content>img,.page__content .highlight{margin:4rem 0;padding-left:0;padding-right:0;position:relative}.post-listing{position:relative;background:#fc0}.post-listing+.post-listing{margin-top:var(--padding)}.featured-image{float:right;margin:.8rem 26rem 1rem 4rem;padding-right:0;width:16rem}@media(max-width:45em){.page__sidebar{position:static;position:relative;margin-bottom:var(--padding);right:auto;width:auto}article h2,.page__content>*{padding-right:0}.featured-image{margin-right:0}}.pagination{margin-top:var(--padding);text-align:center}.footer{font-size:1.6rem;margin:calc(var(--padding) * 1.5)auto calc(var(--padding)/2);max-width:calc(var(--content-width) + (var(--padding) * 2));opacity:.75;padding:0 var(--padding);position:relative}.page a:not([class]){color:rgb(var(--link));padding:.2rem}.page a:not([class]):hover,.page a:not([class]):focus{background:rgb(var(--header));color:rgb(var(--header-text))}.page a[href^=http]{margin-right:-.4rem}.page a[href^=http]:after{content:'\1f852';display:inline-block;font-size:1.2rem;transform:rotate(-45deg);vertical-align:top}.button{background:rgb(var(--header));box-shadow:0 2px 2px rgba(var(--button-shadow),.5);color:rgb(var(--header-text));display:inline-block;padding:.6rem 1.2rem;text-decoration:none}.button:hover,.button:focus{background:rgb(var(--text));box-shadow:none;color:rgb(var(--button-hover))}.button+.button{margin-left:.8rem}pre{overflow:auto;padding:.6rem 1.2rem}table pre{margin:.6rem 0;padding:0}