*,: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:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";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}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}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,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}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}::-webkit-search-decoration{-webkit-appearance:none}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}*,: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: }.visible{visibility:visible}.my-10{margin-top:2.5rem;margin-bottom:2.5rem}.mb-16{margin-bottom:4rem}.mb-20{margin-bottom:5rem}.mb-4{margin-bottom:1rem}.mb-5{margin-bottom:1.25rem}.mb-8{margin-bottom:2rem}.ml-5{margin-left:1.25rem}.mr-2{margin-right:.5rem}.mr-4{margin-right:1rem}.mr-5{margin-right:1.25rem}.mt-10{margin-top:2.5rem}.mt-16{margin-top:4rem}.mt-20{margin-top:5rem}.mt-4{margin-top:1rem}.flex{display:flex}.hidden{display:none}.h-full{height:100%}.w-full{width:100%}.items-center{align-items:center}.justify-center{justify-content:center}.rounded-lg{border-radius:.5rem}.bg-green-50{--tw-bg-opacity: 1;background-color:rgb(240 253 244 / var(--tw-bg-opacity))}.bg-red-50{--tw-bg-opacity: 1;background-color:rgb(254 242 242 / var(--tw-bg-opacity))}.p-10{padding:2.5rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-red-800{--tw-text-opacity: 1;color:rgb(153 27 27 / var(--tw-text-opacity))}.opacity-50{opacity:.5}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}@font-face{font-family:IBMPlexMono;font-weight:400;src:url(/jhavrick/assets/IBMPlexMono-Regular-BCvwfN5l.ttf)}@font-face{font-family:IBMPlexMono;font-weight:light;src:url(/jhavrick/assets/IBMPlexMono-Light-C5FdNFFb.ttf)}@font-face{font-family:IBMPlexMono;font-weight:700;src:url(/jhavrick/assets/IBMPlexMono-Bold-DYbenGlc.ttf)}html{line-height:1.3}body{font-family:IBMPlexMono;background-color:#fff;color:var(--font-color)}#root{width:100vw;height:100vh;overflow-x:hidden;--font-color: rgb(26, 26, 26);--border-color: #d1d1d1;--accent-color: #07d;--offset-color: rgba(0,0,0,.5) }::-moz-selection{background:#a1d3ff;opacity:.25}::selection{background:#a1d3ff;opacity:.25}a{color:inherit;text-decoration:none;border-bottom:1px solid var(--accent-color)}a.icon-link{text-decoration:none;border-bottom:none}hr{border:none;border-top:1px solid var(--border-color);margin:1em 0}p{margin:25px 0;line-height:1.6}.accent-color{color:var(--accent-color)}.accent-bg{background-color:var(--accent-color)}.accent-bg-text{color:#fff;background:#000;border-bottom:3px solid var(--accent-color);padding:5px}h1.header-text{font-size:32px;font-weight:400;line-height:1.3;letter-spacing:-2px}button,a.button{display:inline-flex;color:#fff;background:var(--accent-color);padding:10px 15px;cursor:pointer;transition:.15s}button:hover,a.button:hover{filter:brightness(1.05);transition:.15s}button:disabled,a.button:disabled{opacity:.5;cursor:not-allowed;transition:.15s}input,textarea,select{border-radius:0;border:1px solid var(--border-color);padding:10px;width:100%}input:focus,textarea:focus,select:focus{outline:2px solid var(--accent-color)}input:disabled,textarea:disabled,select:disabled{opacity:.5;cursor:not-allowed}textarea{height:200px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:5px;font-weight:700}.spinner{display:inline-block;width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin 1s ease-in-out infinite;-webkit-animation:spin 1s ease-in-out infinite}@keyframes spin{to{-webkit-transform:rotate(360deg)}}@media (prefers-color-scheme: dark){.dark\:bg-gray-800{--tw-bg-opacity: 1;background-color:rgb(31 41 55 / var(--tw-bg-opacity))}.dark\:text-green-300{--tw-text-opacity: 1;color:rgb(134 239 172 / var(--tw-text-opacity))}.dark\:text-red-400{--tw-text-opacity: 1;color:rgb(248 113 113 / var(--tw-text-opacity))}}.portrait{display:inline-block;position:relative;width:110px;height:110px}.portrait__backdrop{background-color:var(--accent-color);position:absolute;left:12px;top:4px;width:100%;height:100%;z-index:-1;border-radius:100%}.portrait__img{border-radius:100%;filter:grayscale(100%)}.page-layout{display:flex;flex-direction:row;justify-content:flex-start;position:relative;width:100%;height:100%}.page-layout__sidebar{display:flex;flex-direction:row;justify-content:space-between;top:0;left:0;width:100vh;height:45px;transform:rotate(90deg) translate(-45px);transform-origin:bottom left;position:fixed;z-index:4;background:#00000080;color:#fff;font-size:16px;letter-spacing:1px}.page-layout__title{color:#fff;background:#000;display:flex;justify-content:center;align-items:center;text-align:center;padding:0 25px;text-transform:uppercase;letter-spacing:1.5px;color:inherit;text-decoration:none;border-bottom:none;border-bottom:2px solid var(--accent-color);transition:background .15s}.page-layout__title:hover{background:#141414;transition:background .15s}.title-collapsed{display:none}.page-layout__hero-desc{display:flex;justify-content:center;align-items:center;margin:0;padding:0 15px;font-size:14px}.hero-desc-sm{display:none}.page-layout__hero-desc span{margin-right:10px}.page-layout__hero-cam-icon{transform:rotate(-90deg);font-size:20px}.page-layout__hero-desc span:after{content:"|";margin-left:10px}.page-layout__hero-desc span:last-child:after{content:"";margin-left:0}.page-layout__hero,.page-layout__body{flex:1}.page-layout__hero{position:relative;overflow:hidden}.page-layout__hero-overlay{position:absolute;width:100%;height:100%;z-index:1;background-color:var(--accent-color);opacity:.2;pointer-events:none}.page-layout__hero img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;filter:grayscale(100%)}.page-layout__body{overflow-y:auto}.page-layout__nav{display:flex;width:100%;border-bottom:1px solid var(--border-color);font-size:14px;background-color:#fff}.page-layout__nav a{color:inherit;text-decoration:none;border-bottom:none}.page-layout__nav .current-link{font-weight:700;color:var(--accent-color);border-bottom:1px solid var(--accent-color)}.page-layout__nav-list{display:flex;flex-direction:row;justify-content:space-evenly;list-style-type:none;width:50%;min-width:400px;margin:auto;padding:20px}.page-layout__nav .page-layout__title{color:#fff;border-bottom:none}.page-layout__main{display:flex;flex-direction:column;justify-content:flex-start;align-items:center}.page-layout__content{width:70%}@media screen and (max-width: 1400px){.page-layout__nav-list{width:100%}.page-layout__content{width:90%}}@media screen and (max-width: 1000px){.title-collapsed{display:flex}.page-layout{flex-direction:column;height:auto}.page-layout__sidebar{width:100%;height:45px;transform:none;z-index:2;font-size:12px}.page-layout__nav{position:fixed;top:0;left:0;z-index:4}.hero-desc-sm{display:flex;z-index:1;position:absolute;bottom:0;background:#00000080;width:100%;color:#fff;height:50px;font-size:12px}.page-layout__hero-cam-icon{transform:rotate(0);font-size:16px;margin-top:0}.hero-desc-lg{display:none}}@media screen and (max-width: 512px){.page-layout__nav{flex-direction:column}.page-layout__title{padding:15px}.page-layout__nav-list{min-width:auto;padding:20px 0}.hero-desc-sm{font-size:10px;height:30px}.page-layout__hero{padding-top:50px}.page-layout__hero-cam-icon{display:none}}.link-list-container{display:flex;justify-content:space-between;align-items:flex-start;flex-direction:row;font-family:IBMPlexMono,monospace}.link-list__header{display:flex;justify-content:flex-start;align-items:center;text-transform:uppercase;letter-spacing:4px;margin-bottom:20px;font-size:12px}.link-list__items{list-style:none;margin:0;padding:0;font-size:14px}.link-list__item{padding-bottom:10px;display:flex;justify-content:flex-start;align-items:center}@media screen and (max-width: 512px){.link-list-container{flex-direction:column}.link-list{margin-bottom:30px}.link-list:last-child{margin-bottom:0}}.project-item{display:flex;justify-content:flex-start;align-items:stretch;max-height:200px;font-size:14px;margin:30px 0}.project-item p{margin:0}.project-item__content{display:flex;flex-direction:column;justify-content:space-between;align-items:flex-start;flex-grow:1}.project-item__preview{position:relative;height:200px;margin-right:25px;background-color:var(--accent-color);-o-object-fit:cover;object-fit:cover;overflow:visible;aspect-ratio:.8}.project-item__img{width:100%;height:100%;aspect-ratio:.8;-o-object-fit:cover;object-fit:cover;margin-right:20px;-o-object-position:left;object-position:left}.project-item__img.img-bordered{border:1px solid var(--border-color)}.project-item__preview:after{position:absolute;content:"";display:block;width:100%;height:100%;background-color:var(--accent-color);left:5px;top:5px;z-index:-1}.project-item__title.title-sm{display:none}.project-item__title{font-size:18px;font-weight:700;margin-bottom:10px}.project-item__content{padding:10px 0}@media screen and (max-width: 768px){.project-item{flex-direction:column;max-height:100%}.project-item__preview{height:150px;margin-right:0;margin-bottom:20px}.project-item__img{margin-right:0;-o-object-position:top;object-position:top}.project-item__title{display:none}.project-item__title.title-sm{display:block;margin-bottom:20px}.project-item__content{padding:0}.project-item__content p{margin-bottom:15px}}/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */html{line-height:1.15;-webkit-text-size-adjust:100%}body{margin:0}main{display:block}h1{font-size:2em;margin:.67em 0}hr{box-sizing:content-box;height:0;overflow:visible}pre{font-family:monospace,monospace;font-size:1em}a{background-color:transparent}abbr[title]{border-bottom:none;text-decoration:underline;-webkit-text-decoration:underline dotted;text-decoration:underline dotted}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace,monospace;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}img{border-style:none}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0}button,input{overflow:visible}button,select{text-transform:none}button,[type=button],[type=reset],[type=submit]{-webkit-appearance:button}button::-moz-focus-inner,[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner{border-style:none;padding:0}button:-moz-focusring,[type=button]:-moz-focusring,[type=reset]:-moz-focusring,[type=submit]:-moz-focusring{outline:1px dotted ButtonText}fieldset{padding:.35em .75em .625em}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal}progress{vertical-align:baseline}textarea{overflow:auto}[type=checkbox],[type=radio]{box-sizing:border-box;padding:0}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}details{display:block}summary{display:list-item}template{display:none}[hidden]{display:none}
