@font-face{font-family:crimson pro;src:url(/CrimsonPro[wght].woff2);font-weight:100 900;font-style:normal;font-display:swap}@font-face{font-family:crimson pro;src:url(/CrimsonPro-Italic[wght].woff2);font-weight:100 900;font-style:italic;font-display:swap}html{--max-text-width:40rem;--border-width:3px;--callout-gray:158, 158, 158;--callout-red:233, 49, 71;--callout-orange:236, 117, 0;--callout-green:8, 185, 78;--callout-cyan:0, 191, 188;--callout-blue:8, 109, 221;--callout-purple:120, 82, 238}body{font-size:16px;font-family:sans-serif;line-height:1.5}a:hover{color:#6495ed;text-decoration:underline}#home{max-width:var(--max-text-width);margin:0 auto}#banner{font-family:serif;font-size:2em;font-weight:700;text-align:center;text-transform:uppercase;border-bottom:1px solid #a9a9a9}#banner a{color:#000;text-decoration:none}.project-list a:hover{text-decoration:none}.project-list{width:100%;margin:0 auto;margin-bottom:6em;padding:0;list-style-type:none}.project-list li:last-child{border-bottom:1px solid #a9a9a9}.project-list li{display:block;width:100%;height:6em;border-top:1px solid #a9a9a9}.list-header{margin-top:2em;font-size:1em;text-align:center}.tbw{color:darkred!important}.block:hover{border-top:1px solid #000;border-bottom:1px solid #000;background-color:#ddd}.block:visited{color:purple}.block{color:#000;width:100%;height:100%;display:flex;flex-direction:row;border:1px solid transparent;text-decoration:none}.thumbnail-wrapper{display:flex;flex-direction:column;justify-content:center;width:4em;margin-left:1em;margin-right:1em}.thumbnail{width:100%;vertical-align:super;padding-left:0;padding-right:0}#home .heading{margin:0;padding:0;text-align:left;font-size:1em}.blurb{margin:0;padding:0}main{margin:0 auto}.single{font-family:crimson pro;font-size:20px;line-height:1.3;font-weight:300}.single>*{max-width:var(--max-text-width);margin:1rem auto;padding:0 2rem}.single .article-header,.main-section-title{font-size:30px;text-align:center;letter-spacing:1px;font-weight:700}.single .article-header::before{content:"— ";font-weight:100}.single .article-header::after{content:" —";font-weight:100}.single h2,.main-crosshead{font-size:20px;font-weight:400;text-transform:uppercase;text-align:center;letter-spacing:2px}.single h3,.heavy-crosshead{font-size:20px;font-weight:900;text-align:center}.single h1,.single h2,.single h3{max-width:var(--max-text-width);display:block;padding:0 2rem;margin:1em auto}p{text-align:justify;margin-bottom:0}video{max-width:var(--max-text-width);width:100%;height:auto}div.highlight{max-width:100%;padding:0 calc(1rem - var(--border-width));margin:1rem auto}pre{max-width:var(--max-text-width);overflow:auto;padding:1rem;margin:0 auto;background-color:#f8f8f8;border-top:var(--border-width)solid transparent;border-right:var(--border-width)solid transparent;border-bottom:var(--border-width)solid transparent;border-left:var(--border-width)solid #000;border-radius:0}pre code{display:block;width:fit-content}.single code{font-size:16px}.user-command>pre>code>span>span::before{content:"$ ";color:gray}.single ul{list-style:none}.single ul li{display:grid;grid-template-columns:2ch auto;gap:1rem;margin-left:calc(-1rem - 2ch)}.single ul li::before{content:"•";color:#000;text-align:right}.single ol{list-style:none;counter-reset:item}.single ol li{counter-increment:item;display:grid;grid-template-columns:2ch auto;gap:1rem;margin-left:calc(-1rem - 2ch)}.single ol li::before{content:counter(item);color:#000;text-align:right}.single li{text-align:justify}.single li>*{display:contents}.article-blurb{font-style:italic}.description{display:flex;flex-direction:column;justify-content:center;width:70%;padding-left:1em;font-size:.875em}.code{font-family:monospace;background-color:#ccc}.gallery{margin:1rem auto;text-align:center}.thumbnail-link{text-decoration:none}.columned{columns:2;-webkit-columns:2}#page-header-wrapper,#page-footer-wrapper{margin:2rem auto;padding:0 calc(1rem - 0px);font-family:crimson pro;font-size:20px;line-height:1.3;font-weight:300}#page-header,#page-footer{display:flex;justify-content:space-between;max-width:var(--max-text-width);padding:.5rem 1rem;margin:0 auto;border-bottom:1px solid #000}#page-footer{border-top:1px solid #000;border-bottom:none;margin-bottom:8rem}#page-header a:hover,#page-footer a:hover{color:#6495ed}#page-header a,#page-footer a{text-decoration:none}.callout-wrapper{max-width:100%;--callout-border-width:1px;padding:0 calc(1rem - var(--callout-border-width));margin:1rem auto}.callout{max-width:var(--max-text-width);padding:1rem;margin:0 auto;border:1px solid;border-radius:4px}.callout-title{display:flex;align-items:flex-start;gap:4px}.callout-icon{flex:none;display:flex;align-items:center}.callout-title-inner{font-weight:600}.callout p{color:#000}.callout-gray{color:rgb(var(--callout-gray));background-color:rgba(var(--callout-gray),.1)}.callout-red{color:rgb(var(--callout-red));background-color:rgba(var(--callout-red),.1)}.callout-orange{color:rgb(var(--callout-orange));background-color:rgba(var(--callout-orange),.1)}.callout-green{color:rgb(var(--callout-green));background-color:rgba(var(--callout-green),.1)}.callout-cyan{color:rgb(var(--callout-cyan));background-color:rgba(var(--callout-cyan),.1)}.callout-blue{color:rgb(var(--callout-blue));background-color:rgba(var(--callout-blue),.1)}.callout-purple{color:rgb(var(--callout-purple));background-color:rgba(var(--callout-purple),.1)}