:root{--white:#f6f6f6;--light-grey:#a1a1a1;--dark-grey:#222;--orange:#FF5A33;--yellow:#FFEC5C;--green1:#B4CF66;--green2:#44803F;--green3:#146152;--body-background-color:#212529;--body-font:system-ui,-apple-system,"Segoe UI",roboto,"Helvetica Neue","Noto Sans","Liberation Sans",arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji"}body{color:var(--white);position:relative;margin:0;font-family:var(--body-font);font-weight:400;line-height:1.5;text-align:start;background:var(--body-background-color);text-size-adjust:100%;-webkit-tap-highlight-color:transparent;overflow:hidden}body::before{content:'';position:absolute;width:100%;height:100%;top:0;background-color:#000;z-index:0;opacity:.7}body::after{content:'';position:fixed;top:0;left:0;height:100%;width:.5rem;z-index:99;background:linear-gradient(0deg,rgba(255 90 51 / 100%) 0,rgba(255 90 51 / 100%) 20%,rgba(255 236 92 / 100%) 20%,rgba(255 236 92 / 100%) 40%,rgba(180 207 102 / 100%) 40%,rgba(180 207 102 / 100%) 60%,rgba(68 128 63 / 100%) 60%,rgba(68 128 63 / 100%) 80%,rgba(20 97 82 / 100%) 80%,rgba(20 97 82 / 100%) 100%)}.screen{height:100vh;width:100vw;overflow-y:scroll}@media print{.screen{height:auto}}footer{position:relative;z-index:2}main{padding:2rem 0 12rem;position:relative;z-index:1}@media (width >= 768px){.page{max-width:720px}}@media (width >= 576px){.page{max-width:540px}}.page{width:1120px;max-width:94%;padding:0;padding-left:1rem;margin:0 auto}.page-small{width:700px}.post-title+.post-date{font-size:1.25rem}.lead{margin:3rem 0 1rem;font-size:1.25rem;font-weight:300}.color-bands{position:fixed;left:0;height:100%;width:.5rem;z-index:99}.color-bands div{height:20%}.color-bands div:first-of-type{background:var(--green3)}.color-bands div:nth-of-type(2){background:var(--green2)}.color-bands div:nth-of-type(3){background:var(--green1)}.color-bands div:nth-of-type(4){background:var(--yellow)}.color-bands div:nth-of-type(5){background:var(--orange)}.btn-primary{background:var(--green3);border-color:var(--green3)}.btn-primary:hover{background:var(--green2);border-color:var(--green2)}li{counter-increment:li}ul:not(.navbar-nav) li{list-style-type:none}li::before{content:counter(li) ". ";color:var(--green2);display:inline-block;width:1.5rem;margin-left:-1.5rem}ul:not(.navbar-nav) li::before{content:"\2D54";color:var(--green2);font-weight:700;display:inline-block;width:1.5rem;margin-left:-1.5rem}ol{list-style:none;counter-reset:li}.blockquote{padding:1rem;background-color:var(--dark-grey);border-radius:.25rem;margin:0 0 1rem}.blockquote-wrapper{display:flex;gap:1.5rem;margin-bottom:0}.blockquote-quote{color:var(--green1);width:85px;margin:.5rem 0 auto}@media (width >= 768px){.blockquote-quote{width:45px}}.blockquote-quote::before{content:"\f6b0";display:inline-block}.blockquote-body{font-size:1.25rem;margin:0}.blockquote-text{margin:0}.blockquote-text+.blockquote-text{margin-top:1rem}.blockquote-attribution{color:var(--light-grey);font-size:1.1rem}.blockquote-attribution::before{content:"—";margin-right:.5rem}.code{padding:1rem;background-color:var(--dark-grey);border-radius:.25rem;display:block;margin-top:0;margin-bottom:1rem;overflow:auto;font-family:Monaco,monospace;font-size:.875rem}.list-item .code{margin-top:1rem}.code::before{counter-reset:listing}.code .code-line{counter-increment:listing;font:inherit;color:inherit;word-break:normal;white-space:pre}.code .code-line::before{display:inline-block;width:36px;content:counter(listing) " ";color:#6c757d}.unformatted{padding:1rem;background-color:var(--dark-grey);border-radius:.25rem;display:block;margin-top:0;margin-bottom:1rem;overflow:auto;font-family:Monaco,monospace;font-size:.875rem;white-space:pre-wrap}*,::after,::before{box-sizing:border-box}h1,h2,h3,h4,h5,h6{margin-top:0;margin-bottom:.5rem;font-weight:500;line-height:1.2;font-family:"Roboto Slab",var(--body-font);color:rgb(246 246 246)}h1{color:var(--green1);font-size:calc(1.375rem + 1.5vw)}h2{font-size:calc(1.325rem + .9vw);margin-top:2rem}h3{font-size:calc(1rem + .3vw);margin-top:2rem;margin-bottom:1.5rem}@media (width >= 1200px){h1{font-size:2.5rem}h2{font-size:2rem}}.blog-title-keyword{font-weight:500}.blog-title-argument{font-weight:300}.external-link,.internal-link{color:var(--green1);transition:all .5s;text-decoration:underline}.external-link:hover,.internal-link:hover{cursor:pointer;color:var(--green2)}.brand{color:var(--green1);font-family:"Roboto Slab",var(--body-font)}.see-all-posts-link{display:flex;align-items:center;gap:.5rem;margin-top:1rem}.banner{position:relative}.banner::before{content:'';position:absolute;width:100%;height:100%;top:0;background-color:#000;z-index:0;opacity:.7}.banner-background{width:100%;vertical-align:middle}.banner-content{position:absolute;left:50%;top:50%;width:1120px;max-width:94%;padding:3rem 0 0 1rem;text-align:center;transform:translate(-50%,-50%)}@media (width >= 768px){.banner-content{padding-top:0}}.banner-subtitle{font-family:var(--body-font);font-size:calc(1.3rem + .6vw);font-weight:300}@media (width >= 1200px){.banner-subtitle{font-size:1.75rem}}.banner-see-posts-button{display:inline-block;background-color:var(--green3);border:1px solid var(--green3);color:#fff;margin-top:.5rem;padding:.5rem 1rem;font-size:1.25rem;border-radius:.5rem;text-decoration:none;line-height:1.5;transition:color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out}.banner-see-posts-button:hover{background-color:var(--green2);border-color:var(--green2)}.post-list{display:flex;flex-direction:column;gap:1.5rem}.post-in-list{display:flex;flex-direction:column;justify-content:space-between;padding-bottom:1.5rem;border-bottom:1px solid rgb(73 80 87)}.post-link{text-underline-offset:0.125em;font-size:1.25rem}.post-date{color:var(--light-grey);white-space:nowrap}.project .filtered-posts .post-in-list{padding-bottom:0;border-bottom:none}@media (width >= 768px){.post-in-list{flex-direction:row;align-items:center}}.projects-title,.recent-posts-title{font-size:calc(1.325rem + .9vw);margin-top:.5rem;margin-bottom:1.5rem}@media (width >= 768px){.projects-title,.recent-posts-title{margin-top:0}}@media (width >= 1200px){.projects-title,.recent-posts-title{font-size:2rem}}.tags{display:flex;flex-flow:wrap;flex-direction:row;gap:.5rem;margin-top:1rem;margin-bottom:3rem}@media (width >= 576px){.tags{gap:1rem}}.tag{display:inline-block;padding:4px 8px;background-color:#f8f9fa;border:1px solid #f8f9fa;border-radius:4px;color:#000;font-size:.875rem;font-weight:400;transition:color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out;pointer-events:none}.tag-active{background:var(--green3);border-color:var(--green3);color:#fff}.filtering-tags .tag{pointer-events:auto}.filtering-tags .tag:hover{cursor:pointer;color:#000;background-color:#d3d4d5;border-color:#c6c7c8}.filtering-tags .tag-active:hover{background:var(--green2);border-color:var(--green2);color:#fff}.list{margin:0 0 1rem;padding:0 0 0 2rem}.table{width:100%;margin-bottom:1rem;color:#adb5bd;vertical-align:top;border-color:#495057;caption-side:bottom;border-collapse:collapse}.table caption{padding-top:.5rem;padding-bottom:.5rem;color:rgba(173 181 189 / 75%);text-align:left}.table tbody,.table td,.table tfoot,.table th,.table thead,.table tr{border-color:inherit;border-style:solid;border-width:0}.table>thead{vertical-align:bottom}.table>tbody{vertical-align:inherit}.table>:not(caption)>*>*{padding:.5rem;background-color:transparent;border-bottom-width:1px;box-shadow:inset 0 0 0 9999px transparent}.table th{text-align:inherit;text-align:-webkit-match-parent}.table td{color:var(--white)}.column-number{text-align:right}.text{margin:0 0 1rem}.about{margin-top:6rem}.about-title{font-size:calc(1.3rem + .6vw)}@media (width >= 1200px){.about-title{font-size:1.75rem}}.about-text{margin:0 0 1rem}.nav-bar{position:relative;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;padding:.5rem 0;background-color:rgba(43 48 53 / 100%)}.nav-bar>.page{display:flex;flex-wrap:inherit;align-items:center;justify-content:space-between}.nav-bar-balloon{margin-right:.8rem;width:24px}.nav-bar-item{display:flex;padding:5px 0;margin-right:16px;font-size:1.25rem;color:#fff;text-decoration:none;white-space:nowrap;font-family:"Roboto Slab",var(--body-font)}.nav-bar-item-title:hover{color:#fff}.nav-bar-item-close{margin-right:0;display:flex;align-items:center}.nav-bar-item-close svg{width:20px;height:20px}.inset{padding-left:1.5rem;border-left:4px solid #495057;margin-top:0;margin-bottom:1rem}.image,.slideshare,.video,.youtube{display:flex;flex-direction:column;margin-bottom:1rem}.image-caption,.slideshare-caption,.video-caption,.youtube-caption{color:var(--light-grey);font-weight:500}.list-item+.image{margin-top:1rem}.centered-image .image-caption,.centered-image img{margin:0 auto}.centered-image img{width:60%}.slideshare iframe{border:1px solid #fff;aspect-ratio:597/466}.youtube iframe{border:1px solid #fff;aspect-ratio:560/315}.divider{border:0;border-color:inherit;border-top:1px solid;opacity:.25;margin:3rem 0}.footer{background-color:rgba(43 48 53 / 100%);padding:1.5rem 0}.footer-content{display:flex;justify-content:space-between}.footer-left,.footer-right{display:flex;flex-direction:column;gap:1rem}.rss{width:24px;fill:#FF5A33}.footer-blog-link{color:var(--light-grey);text-decoration:none}.footer-blog-link .brand,.footer-blog-link .copyright{display:inline-block}.footer-blog-link .copyright+.brand{margin-left:10px}.footer-attribution{color:var(--light-grey);font-weight:300}.footer-attribution *{font-size:.875em;color:var(--light-grey)}.reference{color:var(--yellow)}.underline{text-decoration:underline}.projects{margin-top:6rem}.project-buttons{position:relative;display:flex;gap:2rem;flex-wrap:wrap}.project-button{width:9rem;background-color:var(--green3);border:1px solid var(--green3);color:#fff;padding:.5rem 1rem;font-size:1.25rem;border-radius:.5rem;text-decoration:none;line-height:1.5;transition:color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out}.project-name{display:flex;justify-content:center}.project-button img{width:100%}.project-button:hover{background-color:var(--green2);border-color:var(--green2)}