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}body::-webkit-scrollbar,html::-webkit-scrollbar{display:none}body,html{-ms-overflow-style:none;scroll-behavior:smooth;scrollbar-width:none}#cursor .primary,#cursor .secondary{background-color:#2c2b28;border-radius:50%;left:50%;pointer-events:none;position:fixed;top:50%;transform:translate(-50%,-50%);z-index:9999}#cursor .primary{height:8px;width:8px}#cursor .secondary{height:64px;opacity:.2;width:64px}body.dark #cursor .primary,body.dark #cursor .secondary{background-color:#fff}.header-blur{backdrop-filter:blur(18px) saturate(160%) contrast(1.08);-webkit-backdrop-filter:blur(18px) saturate(160%) contrast(1.08);background:#ffffff21;border-bottom:1.5px solid #ffffff2e;border-radius:0 0 22px 22px;box-shadow:none;left:0;min-height:72px;overflow:visible;position:fixed;right:0;top:0;transition:background .3s,border .3s,border-radius .4s cubic-bezier(.68,-.55,.27,1.55);z-index:100}.header-blur:before{border-bottom:1.5px solid #ffffff38;opacity:.5;z-index:2}.header-blur:after,.header-blur:before{border-radius:0 0 22px 22px;content:"";inset:0;pointer-events:none;position:absolute}.header-blur:after{background:linear-gradient(90deg,#ff005012,#00ffff0d),linear-gradient(0deg,#ffffff0a,#fff0 60%);filter:blur(.3px);mix-blend-mode:lighten;opacity:.55;z-index:3}.header-blur:active,.header-blur:focus-within{border-radius:0 0 32px 32px;transition:border-radius .25s cubic-bezier(.68,-.55,.27,1.55)}body.dark .header-blur{background:#2c2b2826;border-bottom:1.5px solid #ffffff14}body.dark .header-blur:before{border-bottom:1.5px solid #ffffff21}body.dark .header-blur:after{background:linear-gradient(90deg,#ff00500a,#00ffff08),linear-gradient(0deg,#ffffff05,#fff0 60%);opacity:.38}.header-inner{align-items:center;display:flex;height:72px;justify-content:space-between;margin:0 auto;max-width:1400px;padding:0 48px}.logo-type,h1,h2,h3{color:#232323;display:flex;font-family:Plus Jakarta Sans,sans-serif;font-size:1.35rem;font-weight:700;gap:0;letter-spacing:.01em;-webkit-user-select:none;user-select:none}body.dark .logo-type{color:#fff}.logo-char{display:inline-block;transition:transform .18s cubic-bezier(.68,-.55,.27,1.55)}.logo-char.bounce{animation:bounceUp .32s cubic-bezier(.68,-.55,.27,1.55)}@keyframes bounceUp{0%{transform:translateY(0)}40%{transform:translateY(-12px)}70%{transform:translateY(2px)}to{transform:translateY(0)}}.header-menu{align-items:center;display:flex;gap:32px}.menu-link{color:#232323;font-weight:500;margin:0 12px;padding:4px 0;position:relative;text-decoration:none;transition:color .2s}.menu-link:hover{color:#ffd600}body.dark .menu-link{color:#fff}body.dark .menu-link:hover{color:#ffd600}.menu-link.active{color:#232323}.menu-link.active:after{background:#ffd600;border-radius:2px;content:"";display:block;height:2.5px;margin:2px auto 0;transition:width .2s;width:80%}.mode-switch-toggle{align-items:center;background:#cbcbcb;border:none;border-radius:16px;cursor:pointer;display:flex;height:28px;padding:0;position:relative;transition:background .2s;width:48px}body.dark .mode-switch-toggle{background:#50493d}.toggle-track{height:100%;position:relative;width:100%}.toggle-thumb,.toggle-track{align-items:center;display:flex}.toggle-thumb{background:#0000;border-radius:50%;box-shadow:none;height:22px;justify-content:center;left:3px;position:absolute;top:3px;transition:left .25s cubic-bezier(.68,-.55,.27,1.55),background .2s;width:22px}.mode-switch-toggle.dark .toggle-thumb{background:#0000;left:23px}.toggle-thumb svg{transition:all .3s cubic-bezier(.68,-.55,.27,1.55)}.ham{-webkit-tap-highlight-color:transparent;background:none;border:none;cursor:pointer;display:none;margin-left:18px;padding:0;transition:transform .4s;-webkit-user-select:none;user-select:none}.hamRotate.active{transform:rotate(45deg)}.line{fill:none;stroke:#232323;stroke-width:5.5;stroke-linecap:round;transition:stroke-dasharray .4s,stroke-dashoffset .4s}body.dark .line{stroke:#fff}.ham1 .top{stroke-dasharray:40 139}.ham1 .bottom{stroke-dasharray:40 180}.ham1.active .top{stroke-dashoffset:-98px}.ham1.active .bottom{stroke-dashoffset:-138px}@media (max-width:900px){.mobile-only{display:block}.desktop-menu{display:none!important}.ham{display:block}.mobile-menu{background:#fffffff7;border-radius:0 0 0 16px;box-shadow:0 8px 32px #00000014;display:flex;flex-direction:column;gap:28px;min-width:180px;opacity:0;padding:24px 32px 24px 24px;pointer-events:none;position:absolute;right:0;top:72px;transform:translateY(-16px) scale(.98);transition:opacity .25s,transform .25s;z-index:200}.mobile-menu.open{opacity:1;pointer-events:auto;transform:translateY(0) scale(1)}.mobile-menu.dark{background:#2c2b28f7}.mobile-menu .menu-link{color:#232323;display:block;font-size:1.1rem;margin:0;padding-bottom:20px;text-align:left;width:100%}.mobile-menu .menu-link:last-child{padding-bottom:0}.mobile-menu.dark .menu-link{color:#fff}.mobile-menu .mode-switch-toggle{align-self:flex-start;background:#cbcbcb;display:flex;height:28px;margin:0;width:48px}.mobile-menu.dark .mode-switch-toggle{background:#50493d;color:#fff}}@media (max-width:700px){.header-inner{padding:0 16px}.profile-summary{align-items:center;flex-direction:column;gap:16px;text-align:center}.projects-section{flex-direction:column;gap:28px}}.mobile-only{display:none}@media (max-width:900px){.mobile-only{display:block}.desktop-menu{display:none!important}}body{background:#fff;font-family:Plus Jakarta Sans,Arial,Helvetica,sans-serif}body.dark{background:#2c2b28}.resume-page{color:#232323;font-family:Plus Jakarta Sans,Arial,Helvetica,sans-serif;margin:0 auto;max-width:820px;padding:110px 48px 32px;position:static}@media (max-width:700px){.resume-page{padding:48px 16px 80px}}body.dark .resume-page{color:#fff}.resume-page-outer{align-items:flex-start;display:flex;flex-direction:column;margin-top:0}@media (max-width:700px){.resume-page-outer{margin-top:100px}}@media (max-width:899px) and (min-width:701px){.resume-page-outer{margin-top:60px}}.profile-summary{align-items:flex-start;display:flex;gap:32px;margin-bottom:44px}.profile-img{aspect-ratio:1/1;background:#eee;border-radius:50%;display:block;height:100px;margin-top:8px;object-fit:cover;width:100px}.profile-summary h1{color:#232323;font-size:1.6rem;font-weight:700;margin-bottom:10px}.summary-desc{color:#444;font-size:1.08rem;line-height:1.6;margin-bottom:16px}body.dark .summary-desc{color:#b0b3c6}body.dark .profile-summary h1{color:#fff}.resume-links{display:flex;flex-wrap:wrap;gap:18px;margin-bottom:8px}.resume-links a{color:#232323;font-size:1.01rem;font-weight:500;text-decoration:underline;transition:color .2s}body.dark .resume-links a{color:#fff}.resume-links a:hover{color:#50493d}.projects-section{display:flex;flex-wrap:wrap;gap:48px;justify-content:center;margin-top:36px}.project-col{flex:1 1;min-width:220px}.project-col h2{color:#888;font-size:1.08rem;font-weight:600;letter-spacing:.01em;margin-bottom:12px}.project-list{display:flex;flex-direction:column;gap:18px}.project-list strong{color:#232323;font-size:1.08rem;font-weight:600}body.dark .project-list strong{color:#fff}.project-desc{color:#888;font-size:.98rem;margin-top:2px}body.dark .project-desc{color:#b0b3c6}.floating-back-btn{align-items:center;background:none;border:none;cursor:pointer;display:flex;left:19px;outline:none;padding:0;position:fixed;top:0;z-index:120}@media (max-width:700px){.floating-back-btn{left:-30px;top:0}}@media (max-width:950px) and (min-width:701px){.floating-back-btn{left:0;top:0}}.floating-back-btn .back-btn-bg{align-items:center;background:#fff;border-radius:22px;box-shadow:0 2px 8px 0 #00000014;display:flex;height:44px;max-width:90vw;min-width:44px;overflow:hidden;padding:0 18px;transition:background .2s,width .2s;width:auto}@media (max-width:950px) and (min-width:701px){.pdf-viewer-outer{padding-top:120px!important}}@media (max-width:700px){.pdf-viewer-outer{padding-top:140px!important}}.homepage-section{box-sizing:border-box;margin:0 auto;max-width:1200px;padding-left:48px;padding-right:48px;padding-top:120px;width:100%}@media (max-width:900px){.homepage-section{padding-left:24px;padding-right:24px;padding-top:100px}}@media (max-width:700px){.homepage-section{padding-left:16px!important;padding-right:16px!important;padding-top:80px!important}.homepage-row{align-items:flex-start!important;flex-direction:column!important;gap:18px!important;width:100%!important}}.homepage-section img,.homepage-section svg{height:auto;max-width:100%}: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%}: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}