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;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}: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%}.blog-list-container{margin:0 auto;max-width:var(--content-max-width);padding:2rem 1rem}.blog-list-item{margin-bottom:2.5rem}.blog-list-item h2{margin:0}.blog-meta{color:#666;color:var(--text-secondary,#666);font-size:.9rem;margin:.25rem 0 1rem}.blog-post-container{margin:0 auto;max-width:var(--content-max-width);padding:2rem 1rem}.blog-markdown{line-height:1.7}.blog-markdown img{height:auto;max-width:100%}.blog-markdown b,.blog-markdown strong{font-weight:500}.back-link{color:inherit;display:inline-block;margin-bottom:1rem;text-decoration:none}@keyframes fadeInUp{0%{opacity:0;transform:translate3d(0,15px,0)}to{opacity:1;transform:translateZ(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInFromLeft{0%{opacity:0;transform:translate3d(-20px,0,0)}to{opacity:1;transform:translateZ(0)}}@keyframes scaleIn{0%{opacity:0;transform:translateZ(0) scale(.95)}to{opacity:1;transform:translateZ(0) scale(1)}}.App,body{animation:fadeIn .5s ease-out;background-color:#fff;color:#212529;margin:0 auto;max-width:800px;max-width:var(--content-max-width);padding:0 1rem;text-align:left;will-change:opacity}:root{--content-max-width:800px;font-feature-settings:"liga" 1,"calt" 1;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;font-weight:200}@supports (font-variation-settings:normal){:root{font-family:Helvetica Neue,Helvetica,Arial,sans-serif;font-weight:200}}*{box-sizing:border-box}.App.dark,body.dark{background-color:#121212;color:#fff}.App.light,body.light{background-color:#f8f9fa;color:#212529}.dark{background-color:#121212;color:#fff}.light{background-color:#f8f9fa;color:#212529}a,a:visited{border-radius:6px;transition:all .2s ease-in-out}.sequences-link,a,a:visited{color:inherit;text-decoration:none}.sequences-link{font-weight:400}.sequences-link:hover{text-decoration:underline}h2{font-size:2rem}h2,h3{color:inherit}h3{font-size:1.2rem;margin-bottom:.5rem;margin-top:1rem}nav{align-items:flex-start;animation:fadeInUp .6s ease-out .1s both;display:flex;flex-direction:column;margin-top:3rem;width:100%;will-change:transform,opacity}.nav-left{text-align:left;width:100%}.nav-left h1,.nav-left p{color:inherit}.nav-left h1{font-size:3rem;margin-bottom:.5rem}.nav-left h2{margin-bottom:.25rem}.nav-left p{font-size:1.2rem;margin-top:0}.nav-left h2+p{margin-top:.25rem}.date-display{animation:fadeIn .5s ease-out .6s both;color:inherit;font-size:.9rem;font-weight:300;letter-spacing:.5px;opacity:.7;text-align:left;will-change:opacity}.nav-right ul{color:inherit;display:flex;justify-content:center;list-style-type:none;margin-top:10px;padding:0}.nav-right ul li{margin:0 10px}.nav-right ul li a{color:#212529;font-size:1rem;text-decoration:underline}.social-icons{margin-top:20px}.profile-pic{animation:scaleIn .5s ease-out .05s both;border-radius:50%;height:120px;margin-bottom:1rem;object-fit:cover;width:120px;will-change:transform,opacity}.social-icon{opacity:1;transition:transform .2s ease-in-out,opacity .2s ease-in-out;will-change:transform}.social-icon:hover{opacity:.7;transform:translate3d(0,-2px,0)}.footer{background-color:inherit;height:60px;padding:0 20px;position:relative}.footer,.footer-nav{align-items:center;color:inherit;display:flex;width:100%}.footer-nav{height:100%;justify-content:space-between}.footer-nav ul{display:flex;gap:15px;list-style-type:none;margin:0;padding:0}.footer-nav ul li a{color:inherit;font-size:1rem;position:relative;text-decoration:none;transition:color .2s ease-in-out}.footer-nav ul li a:after{background-color:#212529;bottom:-4px;content:"";height:2px;left:0;position:absolute;transform:scaleX(0);transform-origin:center;transition:transform .3s ease-in-out;width:100%}.footer-nav ul li a:hover:after{transform:scaleX(1)}body.light .footer-nav ul li a:after{background-color:#212529}.footer-icons{align-items:center;display:flex;margin-right:20px}.footer-icons a{color:inherit;margin-left:10px;text-decoration:none}.footer-right{align-items:center;display:flex;font-weight:700;gap:20px;justify-content:flex-end}.footer-right ul{display:flex;gap:15px;margin:0;padding:0}.theme-toggle{background-color:initial;border:none;color:inherit;cursor:pointer}.theme-toggle:hover{opacity:.8}.theme-toggle svg{font-size:1rem}.projects-section{align-items:center;color:inherit;display:flex;flex-direction:column;justify-content:center;margin-bottom:1rem;margin-top:2rem;padding:0 1rem}.project-item-link{margin-bottom:1rem;max-width:800px;text-align:left;width:100%}.projects-section h2{color:inherit;font-size:1.5rem;margin:.5rem 0}.projects-section p{color:inherit;font-size:1rem;margin:.5rem 0}.project-item{border-radius:8px;padding:1rem;transition:all .3s ease}.project-item:hover{background-color:#ffffff0d;box-shadow:0 4px 12px #0000004d;transform:translateY(-2px)}.works-section{animation:fadeInUp .6s ease-out .2s both;color:inherit}.work-item,.works-section{will-change:transform,opacity}.work-item{animation:slideInFromLeft .4s ease-out both;border-bottom:1px solid #80808033;padding:.8rem 0;transition:all .2s ease-in-out}.work-item:first-child{animation-delay:.25s}.work-item:nth-child(2){animation-delay:.3s}.work-item:nth-child(3){animation-delay:.35s}.work-item:nth-child(4){animation-delay:.4s}.work-item:nth-child(5){animation-delay:.45s}.work-item:nth-child(6){animation-delay:.5s}.work-item:last-child{border-bottom:none}.work-header{align-items:center;display:flex;gap:0;justify-content:flex-start;margin-bottom:.3rem;width:100%}.work-title{display:flex;flex-direction:column;gap:.1rem;width:100%}.company-name{color:inherit;font-size:1.1rem;font-weight:700;margin:0}.project-name-link{color:inherit;text-decoration:none;transition:opacity .2s ease-in-out}.project-name-link:hover{opacity:.7}.job-title-row{align-items:center;display:flex;justify-content:space-between;width:100%}.job-title,.work-dates{color:inherit;font-size:1rem;font-weight:400;margin:0;opacity:.8}.work-period{font-size:.8rem;font-weight:400}.work-description{color:inherit;font-size:1rem;line-height:1.5;margin-top:.3rem;opacity:.7}.work-role{color:inherit;font-size:1rem;text-align:right}.company-logo{height:30px;margin-right:1rem;object-fit:contain;width:30px}.resume-section.dark{background-color:#121212;color:#fff}.resume-section.light{background-color:#f8f9fa;color:#212529}.resume-container{align-items:center;background:inherit;display:flex;flex-direction:column;padding:10px}.resume-navigation{display:flex;gap:10px;justify-content:center;margin-top:10px}.resume-navigation button{background-color:#ffffff1a;border:none;border-radius:4px;color:inherit;cursor:pointer;padding:5px 10px;transition:background-color .2s ease-in-out}.resume-navigation button:hover{background-color:#fff3}.resume-navigation button:disabled{cursor:not-allowed;opacity:.5}.react-pdf__Page{background-color:#fff!important;box-shadow:0 2px 8px #0003}.react-pdf__Page__textLayer{color:#000!important}.pictures-container{color:inherit;margin:0 auto;max-width:1200px;padding:2rem 1rem}.pictures-header{margin-bottom:3rem;text-align:center}.pictures-container h1{color:inherit;font-size:2.5rem;font-weight:300;letter-spacing:.5px;margin-bottom:.5rem}.pictures-subtitle{color:inherit;font-size:1.1rem;font-weight:300;margin:0;opacity:.7}.pictures-grid{column-count:3;column-gap:1.5rem;margin-top:2rem}.picture-item{aspect-ratio:3/4;background-color:#8080801a;border-radius:8px;break-inside:avoid;display:inline-block;margin-bottom:1.5rem;overflow:hidden;page-break-inside:avoid;position:relative;width:100%}.picture-item img,.picture-item video{cursor:pointer;display:block;height:100%;object-fit:cover;transition:transform .3s ease-in-out;width:100%}.picture-item:hover img{transform:scale(1.02)}.chicago-grid,.hanoi-grid,.sf-grid{column-count:auto;display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:center}.chicago-grid .picture-item,.hanoi-grid .picture-item,.sf-grid .picture-item{flex-basis:calc(33.33333% - 1rem);flex-grow:0;flex-shrink:1;margin-bottom:0;max-width:calc(33.33333% - 1rem);width:calc(33.33333% - 1rem)}.hanoi-grid .picture-item video{border-radius:8px;cursor:pointer;transition:transform .3s ease-in-out}.hanoi-grid .picture-item:hover video{transform:scale(1.02)}@media (max-width:768px){.pictures-grid{column-count:2;column-gap:1rem}.chicago-grid .picture-item,.hanoi-grid .picture-item,.sf-grid .picture-item{flex-basis:calc(50% - 0.5rem);flex-grow:0;flex-shrink:1;max-width:calc(50% - .5rem);width:calc(50% - .5rem)}.picture-item{margin-bottom:1rem}.pictures-container{padding:1.5rem 1rem}.pictures-container h1{font-size:2rem}.pictures-subtitle{font-size:1rem}}@media (max-width:480px){.pictures-grid{column-count:1;column-gap:0}.chicago-grid .picture-item,.hanoi-grid .picture-item,.sf-grid .picture-item{flex:0 1 100%;max-width:100%;width:100%}.picture-item{margin-bottom:1rem}.pictures-container{padding:1rem .5rem}}.top-nav{align-items:flex-end;animation:fadeIn .5s ease-out;display:flex;flex-direction:column;gap:.5rem;margin-top:0!important;position:fixed;right:2rem;top:2rem;width:auto!important;will-change:opacity;z-index:1000}.nav-link{color:inherit;font-size:1rem;font-weight:400;letter-spacing:1px;opacity:.7;padding:.25rem 0;text-align:left;text-decoration:none;transition:all .2s ease-in-out}.nav-link:hover{opacity:1;transform:translateX(-2px)}.nav-link.active{font-weight:500;opacity:1}@media (max-width:768px){.top-nav{gap:.4rem;right:1.5rem;top:1.5rem}.nav-link{font-size:.9rem;padding:.2rem 0}}@media (max-width:480px){.top-nav{gap:.3rem;right:1rem;top:1rem}.nav-link{font-size:.8rem;letter-spacing:.5px;padding:.15rem 0}}
/*# sourceMappingURL=main.699224e5.css.map*/