body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}@font-face{font-family:lato;font-style:normal;font-weight:200;src:url(/static/media/Lato-Thin.5a60dde25d817751d590.ttf)}@font-face{font-family:lato;font-style:normal;font-weight:400;src:url(/static/media/Lato-Regular.9d883d540ee2b4de8024.ttf)}@font-face{font-family:lato;font-style:normal;font-weight:700;src:url(/static/media/Lato-Bold.636be8de934918e38ed9.ttf)}@font-face{font-family:lato;font-style:normal;font-weight:900;src:url(/static/media/Lato-Black.57dee8aface5572f9101.ttf)}html{overflow-x:hidden;overflow-y:scroll}h1{font-weight:900}*,html{scroll-behavior:smooth}body{background-color:var(--bg);flex-direction:column;font-family:lato,sans-serif;justify-content:center}.app,body{border:0;display:flex;margin:0;padding:0}.app{flex-direction:row;height:100vh;justify-content:left;width:100vw}p{font-size:20px}a:not(.special){color:var(--link);position:relative;text-decoration:none;transition:color .2s ease;white-space:nowrap}a:not(.special):before{background-color:var(--link);bottom:0;content:"";height:.1vmax;left:0;position:absolute;transition:height .2s ease;width:100%;z-index:-1}a:not(.special):hover:before{bottom:0;height:100%}a:not(.special):hover{color:#fff}#resume a:before{content:none}.tie{filter:drop-shadow(.3vmax .4vmax .5vmax black);flex-direction:row;margin-left:2vmax;margin-right:2vmax;transition:translate .5s ease}.tie,.tie .content{display:flex;position:fixed;width:18vmax}.tie .content{color:var(--tie-text);flex-direction:column;padding-left:.5vmax;padding-right:.5vmax;z-index:10}.tie .content .header h1{font-size:2.55vmax;margin:.5vmax 0;text-shadow:.1vmax .1vmax var(--tie-text-inverted)}.tie .content .header div{background:linear-gradient(135deg,#999 5%,#fff 10%,#ccc 30%,#ddd 50%,#ccc 70%,#fff 80%,#999 95%);border-radius:0 .5vmax .5vmax 0;box-shadow:inset .1vmax .1vmax .1vmax 0 #ffffff80,inset -.1vmax -.1vmax .1vmax 0 #00000080;font-size:1vmax;margin:1.5vmax 0 1.5vmax -1vmax;padding:.5vmax .5vmax .5vmax 1vmax;width:85%}.tie .content .navigation{background:radial-gradient(#0000 0,#0000 .5vmax,var(--tie-inset) .5vmax,var(--tie-inset));background-position:-2.32vmax -2.32vmax;background-size:1.6vmax 1.6vmax;height:11.3vmax;margin:.5vmax;width:16vmax}.tie .content .navigation .box{background-color:var(--tie-inset);content:"";height:10.3vmax;margin:.5vmax .5vmax -10.3vmax;width:15vmax}.tie .content .navigation .text{align-items:center;display:flex;flex-direction:column;justify-content:center;margin:-20px .5vmax .5vmax;width:15vmax}.tie .content .navigation .text h2{color:var(--tie-inset-text);cursor:pointer;font-size:2.5vmax;margin:.25vmax 0;padding-top:0;text-shadow:.5vmax .5vmax 1vmax var(--tie-inset-text-inverted);-webkit-user-select:none;user-select:none;z-index:1}.tie .content .navigation .text h2 a{color:inherit;text-decoration:none}.tie .content .navigation .text h2:after,.tie .content .navigation .text h2:before{content:"-";margin-left:.5vmax;margin-right:.5vmax;opacity:0;transition:opacity .2s ease}.tie .content .navigation .text h2:hover:after,.tie .content .navigation .text h2:hover:before{opacity:100%}.tie .bar{--tie1-semi:color-mix(in srgb,var(--tie1) 50%,#0000);--tie2-semi:color-mix(in srgb,var(--tie2) 50%,#0000);--tie3-semi:color-mix(in srgb,var(--tie3) 50%,#0000);background-color:var(--tie0);background-image:repeating-linear-gradient(45deg,var(--tie1-semi) 1vmax,var(--tie1-semi) 5vmax,var(--tie2-semi) 5vmax,var(--tie2-semi) 5.5vmax,var(--tie1-semi) 5.5vmax,var(--tie1-semi) 7vmax,#0000 7vmax,#0000 8vmax,var(--tie3-semi) 8vmax,var(--tie3-semi) 8.5vmax,#0000 8.5vmax,#0000 9vmax,var(--tie3-semi) 9vmax,var(--tie3-semi) 9.5vmax,#0000 9.5vmax,#0000 10vmax,var(--tie1-semi) 10vmax,var(--tie1-semi) 10.5vmax,#0000 10.5vmax,#0000 12vmax,var(--tie1-semi) 12vmax,var(--tie1-semi) 13.5vmax,#0000 13.5vmax,#0000 14vmax,var(--tie2-semi) 14vmax,var(--tie2-semi) 15.5vmax,#0000 15.5vmax,#0000 16vmax),repeating-linear-gradient(135deg,var(--tie1-semi) 1vmax,var(--tie1-semi) 5vmax,var(--tie2-semi) 5vmax,var(--tie2-semi) 5.5vmax,var(--tie1-semi) 5.5vmax,var(--tie1-semi) 7vmax,#0000 7vmax,#0000 8vmax,var(--tie3-semi) 8vmax,var(--tie3-semi) 8.5vmax,#0000 8.5vmax,#0000 9vmax,var(--tie3-semi) 9vmax,var(--tie3-semi) 9.5vmax,#0000 9.5vmax,#0000 10vmax,var(--tie1-semi) 10vmax,var(--tie1-semi) 10.5vmax,#0000 10.5vmax,#0000 12vmax,var(--tie1-semi) 12vmax,var(--tie1-semi) 13.5vmax,#0000 13.5vmax,#0000 14vmax,var(--tie2-semi) 14vmax,var(--tie2-semi) 15.5vmax,#0000 15.5vmax,#0000 16vmax);-webkit-clip-path:polygon(0 0,0 75vh,9vmax calc(75vh + 9vmax),18vmax 75vh,18vmax 0);clip-path:polygon(0 0,0 75vh,9vmax calc(75vh + 9vmax),18vmax 75vh,18vmax 0);filter:var(--tie-filter);float:left}.sidebar,.tie .bar{height:100vh;position:fixed;width:18vmax}.sidebar{display:flex;filter:drop-shadow(.3vmax .4vmax .5vmax black);flex-direction:column;margin:0 2vmax;right:0}.photo{background-color:#fff;margin-right:2vmax;margin-top:2vmax;transition:transform .5s ease;width:18vmax}.photo img{margin:1vmax;width:16vmax}.photo:hover{transform:rotate(3deg)}.clips{bottom:2vmax;position:fixed;right:-3vmax;width:20vmax}.clips div{background:linear-gradient(135deg,#999 5%,#fff 10%,#ccc 30%,#ddd 50%,#ccc 70%,#fff 80%,#999 95%);border-radius:.5vmax 0 0 .5vmax;box-shadow:inset .1vmax .1vmax .1vmax 0 #ffffff80,inset -.1vmax -.1vmax .1vmax 0 #00000080;cursor:pointer;font-size:1vmax;margin-top:1vmax;padding:.5vmax .5vmax .5vmax 1vmax;transition:transform .5s ease;-webkit-user-select:none;user-select:none}.clips div:hover{transform:translateX(.5vmax)}.main{align-items:flex-start;display:flex;filter:drop-shadow(.3vmax .4vmax .5vmax black);flex-direction:column;justify-content:flex-start;margin-left:22vmax;transition:opacity .5s ease;width:100%}.footer{background-color:#0000;height:0;min-height:.01vmax;width:100%}.card{background-color:#fff;display:flex;margin-bottom:2vmax;margin-right:2vmax;width:56vmax}.card h1{margin:0}.inner{margin:1vmax;min-width:0;outline:.2vmax solid #000;padding:1vmax;width:100%}.card *{pointer-events:auto;z-index:100}:root{--bg:#333;--portfolio-overlay:#ffffffaa;--tie-text:#000;--tie-text-inverted:#fff;--tie-inset:var(--bg);--tie-inset-text:#fff;--tie-inset-text-inverted:#000}.theme-sage,:root{--tie0:#d1b7a8;--tie1:#546c6c;--tie2:#2e3a3a;--tie3:#14100f;--tie-filter:brightness(150%);--link:var(--tie1)}.theme-crayon{--tie0:#ffa300;--tie1:#ff004d;--tie2:#29adff;--tie3:#00e436;--tie-filter:sepia(30%);--link:var(--tie1)}.tabs{display:flex;flex-direction:row;width:56vmax}.tabs .tab{align-items:center;background-color:#ddd;-webkit-clip-path:polygon(15% 0,85% 0,100% 100%,0 100%);clip-path:polygon(15% 0,85% 0,100% 100%,0 100%);cursor:pointer;display:flex;font-size:.9vmax;height:2vmax;justify-content:center;margin-right:-2vmax;text-align:center;transform:translateY(.1px);-webkit-user-select:none;user-select:none;width:12vmax}.tabs .selected{background-color:#fff}.portfolio{background-color:#fff;display:flex;margin-bottom:2vmax;margin-right:2vmax;width:56vmax}.portfolio .inner{justify-content:left;margin:1vmax;min-width:0;outline:.2vmax solid #000;padding:1vmax;width:56vmax;width:100%}.portfolio .inner,.portfolio .inner>div{align-items:center;display:flex;flex-direction:row}.portfolio .inner>div{gap:1vmax;margin:0;opacity:0;padding:0;position:absolute;width:52vmax}.portfolio .inner>div:first-child{opacity:1}.portfolio .inner>div:first-child *{z-index:10}.inner{pointer-events:none}.portfolio .inner .overlaid{display:flex;flex-direction:row}.portfolio .inner .overlaid img,.portfolio .inner .overlaid video{margin-left:1vmax;margin-right:-100%;width:100%;z-index:-1}.portfolio .inner .overlaid div{align-items:center;display:flex;justify-content:center;padding:1.5vmax;width:100%}.portfolio .inner .overlaid div div{background-color:#ffffffaa;background-color:var(--portfolio-overlay);width:80%;z-index:-1}.portfolio .inner .overlaid div div p{margin:0;padding:0}.portfolio .inner .overlaid div div *{pointer-events:auto}.portfolio .inner .overlaid h3{margin-bottom:1vmax;margin-top:1vmax}.portfolio .inner .overlaid h3:first-child{margin-top:0}.portfolio .inner .carousel-container{pointer-events:auto}.contact{background-color:#fff;flex-direction:row;margin-bottom:2vmax;margin-right:2vmax;margin-top:2vmax;width:56vmax}.contact,.contact div{align-items:center;display:flex;justify-content:center}.contact div{width:100%}.contact p{display:flex;flex-direction:row;font-size:1.2vmax;margin:0;padding-left:1vmax;padding-right:1vmax;z-index:2}.contact hr{border:.11vmax solid #000;margin:1vmax 0;padding:0;width:4vmax}.carousel-container{margin:0 auto;overflow:hidden;position:relative;width:100%}.carousel-image{display:block;height:600px;object-fit:cover;transition:all .5s ease-in-out;width:100%}.carousel-caption{background:#0009;bottom:0;color:#fff;font-size:1rem;padding:.75em;position:absolute;text-align:center;width:100%}.carousel-arrow{background:#00000080;border:none;border-radius:50%;color:#fff;cursor:pointer;padding:.5em;position:absolute;top:50%;transform:translateY(-50%);transition:background .3s}.carousel-arrow:hover{background:#000000b3}.carousel-arrow svg{display:block}.carousel-arrow-left{left:16px}.carousel-arrow-right{right:16px}:root{--react-pdf-text-layer:1;--highlight-bg-color:#b400aa;--highlight-selected-bg-color:#006400}@media screen and (forced-colors:active){:root{--highlight-bg-color:Highlight;--highlight-selected-bg-color:ButtonText}}[data-main-rotation="90"]{transform:rotate(90deg) translateY(-100%)}[data-main-rotation="180"]{transform:rotate(180deg) translate(-100%,-100%)}[data-main-rotation="270"]{transform:rotate(270deg) translateX(-100%)}.textLayer{-webkit-text-size-adjust:none;-moz-text-size-adjust:none;text-size-adjust:none;forced-color-adjust:none;inset:0;line-height:1;overflow:hidden;position:absolute;text-align:left;text-align:initial;transform-origin:0 0;z-index:2}.textLayer :is(span,br){color:#0000;cursor:text;margin:0;position:absolute;transform-origin:0 0;white-space:pre}.textLayer span.markedContent{height:0;top:0}.textLayer .highlight{background-color:#b400aa;background-color:var(--highlight-bg-color);border-radius:4px;margin:-1px;padding:1px}.textLayer .highlight.appended{position:static}.textLayer .highlight.begin{border-radius:4px 0 0 4px}.textLayer .highlight.end{border-radius:0 4px 4px 0}.textLayer .highlight.middle{border-radius:0}.textLayer .highlight.selected{background-color:#006400;background-color:var(--highlight-selected-bg-color)}.textLayer br::selection{background:#0000}.textLayer .endOfContent{cursor:default;display:block;inset:100% 0 0;position:absolute;-webkit-user-select:none;user-select:none;z-index:-1}.textLayer.selecting .endOfContent{top:0}.hiddenCanvasElement{display:none;height:0;left:0;position:absolute;top:0;width:0}:root{--react-pdf-annotation-layer:1;--annotation-unfocused-field-background:url('data:image/svg+xml;charset=utf-8,<svg width="1" height="1" xmlns="http://www.w3.org/2000/svg"><rect width="100%" height="100%" style="fill:rgba(0,54,255,.13)"/></svg>');--input-focus-border-color:Highlight;--input-focus-outline:1px solid Canvas;--input-unfocused-border-color:#0000;--input-disabled-border-color:#0000;--input-hover-border-color:#000;--link-outline:none}@media screen and (forced-colors:active){:root{--input-focus-border-color:CanvasText;--input-unfocused-border-color:ActiveText;--input-disabled-border-color:GrayText;--input-hover-border-color:Highlight;--link-outline:1.5px solid LinkText}.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input:required,.annotationLayer .choiceWidgetAnnotation select:required,.annotationLayer .textWidgetAnnotation :is(input,textarea):required{outline:1.5px solid selectedItem}.annotationLayer .linkAnnotation:hover{-webkit-backdrop-filter:invert(100%);backdrop-filter:invert(100%)}}.annotationLayer{left:0;pointer-events:none;position:absolute;top:0;transform-origin:0 0;z-index:3}.annotationLayer[data-main-rotation="90"] .norotate{transform:rotate(270deg) translateX(-100%)}.annotationLayer[data-main-rotation="180"] .norotate{transform:rotate(180deg) translate(-100%,-100%)}.annotationLayer[data-main-rotation="270"] .norotate{transform:rotate(90deg) translateY(-100%)}.annotationLayer canvas{height:100%;position:absolute;width:100%}.annotationLayer section{box-sizing:border-box;margin:0;pointer-events:auto;position:absolute;text-align:left;text-align:initial;transform-origin:0 0}.annotationLayer .linkAnnotation{outline:none;outline:var(--link-outline)}.textLayer.selecting~.annotationLayer section{pointer-events:none}.annotationLayer :is(.linkAnnotation,.buttonWidgetAnnotation.pushButton)>a{font-size:1em;height:100%;left:0;position:absolute;top:0;width:100%}.annotationLayer :is(.linkAnnotation,.buttonWidgetAnnotation.pushButton)>a:hover{background:#ff0;box-shadow:0 2px 10px #ff0;opacity:.2}.annotationLayer .textAnnotation img{cursor:pointer;height:100%;left:0;position:absolute;top:0;width:100%}.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input,.annotationLayer .choiceWidgetAnnotation select,.annotationLayer .textWidgetAnnotation :is(input,textarea){background-image:url('data:image/svg+xml;charset=utf-8,<svg width="1" height="1" xmlns="http://www.w3.org/2000/svg"><rect width="100%" height="100%" style="fill:rgba(0,54,255,.13)"/></svg>');background-image:var(--annotation-unfocused-field-background);border:2px solid #0000;border:2px solid var(--input-unfocused-border-color);box-sizing:border-box;font:calc(9px*var(--scale-factor)) sans-serif;height:100%;margin:0;vertical-align:top;width:100%}.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input:required,.annotationLayer .choiceWidgetAnnotation select:required,.annotationLayer .textWidgetAnnotation :is(input,textarea):required{outline:1.5px solid red}.annotationLayer .choiceWidgetAnnotation select option{padding:0}.annotationLayer .buttonWidgetAnnotation.radioButton input{border-radius:50%}.annotationLayer .textWidgetAnnotation textarea{resize:none}.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input[disabled],.annotationLayer .choiceWidgetAnnotation select[disabled],.annotationLayer .textWidgetAnnotation :is(input,textarea)[disabled]{background:none;border:2px solid #0000;border:2px solid var(--input-disabled-border-color);cursor:not-allowed}.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input:hover,.annotationLayer .choiceWidgetAnnotation select:hover,.annotationLayer .textWidgetAnnotation :is(input,textarea):hover{border:2px solid #000;border:2px solid var(--input-hover-border-color)}.annotationLayer .buttonWidgetAnnotation.checkBox input:hover,.annotationLayer .choiceWidgetAnnotation select:hover,.annotationLayer .textWidgetAnnotation :is(input,textarea):hover{border-radius:2px}.annotationLayer .choiceWidgetAnnotation select:focus,.annotationLayer .textWidgetAnnotation :is(input,textarea):focus{background:none;border:2px solid Highlight;border:2px solid var(--input-focus-border-color);border-radius:2px;outline:1px solid Canvas;outline:var(--input-focus-outline)}.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) :focus{background-color:initial;background-image:none}.annotationLayer .buttonWidgetAnnotation.checkBox :focus{border:2px solid Highlight;border:2px solid var(--input-focus-border-color);border-radius:2px;outline:1px solid Canvas;outline:var(--input-focus-outline)}.annotationLayer .buttonWidgetAnnotation.radioButton :focus{border:2px solid Highlight;border:2px solid var(--input-focus-border-color);outline:1px solid Canvas;outline:var(--input-focus-outline)}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:after,.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:before,.annotationLayer .buttonWidgetAnnotation.radioButton input:checked:before{background-color:CanvasText;content:"";display:block;position:absolute}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:after,.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:before{height:80%;left:45%;width:1px}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:before{transform:rotate(45deg)}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:after{transform:rotate(-45deg)}.annotationLayer .buttonWidgetAnnotation.radioButton input:checked:before{border-radius:50%;height:50%;left:30%;top:20%;width:50%}.annotationLayer .textWidgetAnnotation input.comb{font-family:monospace;padding-left:2px;padding-right:0}.annotationLayer .textWidgetAnnotation input.comb:focus{width:103%}.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input{-webkit-appearance:none;appearance:none}.annotationLayer .popupTriggerArea{height:100%;width:100%}.annotationLayer .fileAttachmentAnnotation .popupTriggerArea{position:absolute}.annotationLayer .popupWrapper{font-size:calc(9px*var(--scale-factor));min-width:calc(180px*var(--scale-factor));pointer-events:none;position:absolute;width:100%}.annotationLayer .popup{word-wrap:break-word;background-color:#ff9;border-radius:calc(2px*var(--scale-factor));box-shadow:0 calc(2px*var(--scale-factor)) calc(5px*var(--scale-factor)) #888;cursor:pointer;font:message-box;margin-left:calc(5px*var(--scale-factor));max-width:calc(180px*var(--scale-factor));padding:calc(6px*var(--scale-factor));pointer-events:auto;position:absolute;white-space:normal}.annotationLayer .popup>*{font-size:calc(9px*var(--scale-factor))}.annotationLayer .popup h1{display:inline-block}.annotationLayer .popupDate{display:inline-block;margin-left:calc(5px*var(--scale-factor))}.annotationLayer .popupContent{border-top:1px solid #333;margin-top:calc(2px*var(--scale-factor));padding-top:calc(2px*var(--scale-factor))}.annotationLayer .richText>*{font-size:calc(9px*var(--scale-factor));white-space:pre-wrap}.annotationLayer .caretAnnotation,.annotationLayer .circleAnnotation svg ellipse,.annotationLayer .fileAttachmentAnnotation,.annotationLayer .freeTextAnnotation,.annotationLayer .highlightAnnotation,.annotationLayer .inkAnnotation svg polyline,.annotationLayer .lineAnnotation svg line,.annotationLayer .polygonAnnotation svg polygon,.annotationLayer .polylineAnnotation svg polyline,.annotationLayer .squareAnnotation svg rect,.annotationLayer .squigglyAnnotation,.annotationLayer .stampAnnotation,.annotationLayer .strikeoutAnnotation,.annotationLayer .underlineAnnotation{cursor:pointer}.annotationLayer section svg{height:100%;left:0;position:absolute;top:0;width:100%}.annotationLayer .annotationTextContent{color:#0000;height:100%;opacity:0;pointer-events:none;position:absolute;-webkit-user-select:none;user-select:none;width:100%}.annotationLayer .annotationTextContent span{display:inline-block;width:100%}
/*# sourceMappingURL=main.e7e2be73.css.map*/