.header{padding:3rem;border-bottom:1px solid var(--border-color);width:100%;transition:border-color .3s ease;display:flex;justify-content:space-between;align-items:center}.header-left{display:flex;align-items:center}.header-name{font-size:1.5rem;font-weight:400;color:var(--text-primary);text-decoration:none;transition:color .2s ease}.header-name:hover{color:var(--link-hover)}.header-right{display:flex;align-items:center;gap:2rem}.nav-link{color:var(--text-primary);text-decoration:none;font-weight:400;transition:color .2s ease;position:relative}.nav-link:hover,.nav-link.active{color:var(--link-hover)}@media (max-width: 768px){.header{padding:2rem;flex-direction:column;align-items:flex-start;gap:1.5rem}.header-right{width:100%;justify-content:flex-start;gap:1.5rem}.header-name{font-size:1.25rem}}.personal-projects-page{flex:1;background-color:var(--bg-primary);color:var(--text-primary);padding:4rem 3rem 3rem;width:100%;max-width:100%;box-sizing:border-box;overflow-x:hidden}.personal-projects-container{max-width:1200px;margin:0 auto}.personal-projects-title{font-size:3rem;font-weight:300;letter-spacing:-.02em;margin-bottom:3rem;color:var(--text-primary)}.projects-list{display:flex;flex-direction:column;gap:4rem;margin-top:3rem}.project-card{display:flex;flex-direction:column;gap:2rem;padding-bottom:4rem;border-bottom:1px solid var(--border-color)}.project-card:last-child{border-bottom:none}.project-header{display:flex;flex-direction:column;gap:1.5rem}.project-name{font-size:2rem;font-weight:400;letter-spacing:-.01em;color:var(--text-primary);margin:0}.carousel-container{width:100%;position:relative;min-height:300px;overflow:hidden;border-radius:8px;background-color:#000;border:2px solid var(--border-color);box-shadow:inset 0 1px #ffffff1a,0 2px 4px #0003,0 4px 8px #0000001a}[data-theme=dark] .carousel-container{box-shadow:inset 0 1px #ffffff0d,0 2px 4px #0006,0 4px 8px #0000004d}.carousel-wrapper{position:relative;width:100%;min-height:300px}.carousel-image{width:100%;height:auto;object-fit:contain;opacity:0;transition:opacity .6s ease-in-out;user-select:none;-webkit-user-select:none;display:block;position:absolute;top:0;left:0}.carousel-image.active{position:relative;opacity:1}.placeholder-image{background-color:var(--bg-secondary);border:2px dashed var(--border-color)}.placeholder-overlay{color:var(--text-secondary);font-size:1rem;text-align:center}.carousel-indicators{position:absolute;bottom:1rem;left:50%;transform:translate(-50%);display:flex;gap:.5rem;z-index:10}.indicator{width:8px;height:8px;border-radius:50%;border:none;background-color:#fff6;cursor:pointer;transition:background-color .3s ease,transform .3s ease;padding:0}.indicator:hover{background-color:#fff9;transform:scale(1.2)}.indicator.active{background-color:#ffffffe6;transform:scale(1.3)}[data-theme=dark] .indicator{background-color:#ffffff4d}[data-theme=dark] .indicator:hover{background-color:#ffffff80}[data-theme=dark] .indicator.active{background-color:#fffc}.project-content{display:flex;flex-direction:column;gap:1.5rem}.project-description{display:flex;flex-direction:column;gap:1rem}.project-description p{font-size:1rem;line-height:1.7;color:var(--text-primary);margin:0;text-align:left}.markdown-content{font-size:1rem;line-height:1.7;color:var(--text-primary)}.markdown-content p{margin:0 0 1rem}.markdown-content p:last-child{margin-bottom:0}.markdown-content ul{margin:0 0 1rem;padding-left:1.5rem;list-style-type:disc}.markdown-content ul:last-child{margin-bottom:0}.markdown-content li{margin-bottom:.5rem;color:var(--text-primary)}.markdown-content li:last-child{margin-bottom:0}.markdown-content strong{font-weight:600;color:var(--text-primary)}.markdown-content em{font-style:italic;color:var(--text-primary)}.markdown-content a{color:var(--link-hover);text-decoration:underline;transition:color .3s ease}.markdown-content a:hover{color:var(--link-hover);opacity:.8}.project-links{display:flex;gap:1rem;flex-wrap:wrap;align-items:center;justify-content:center}.project-link{color:var(--text-primary);text-decoration:none;font-weight:500;padding:.5rem 1rem;border:1px solid var(--border-color);border-radius:4px;transition:all .3s ease;background-color:var(--bg-secondary)}.project-link:hover{color:var(--link-hover);border-color:var(--link-hover);background-color:var(--bg-primary)}@media (max-width: 768px){.personal-projects-page{padding:3rem 2rem 2rem}.personal-projects-title{font-size:2.5rem;margin-bottom:2rem}.projects-list{margin-top:1.5rem;gap:3rem}.project-card{gap:1.5rem;padding-bottom:3rem}.project-name{font-size:1.75rem}.carousel-container,.carousel-wrapper{min-height:250px}}@media (max-width: 480px){.personal-projects-page{padding:2rem 1.5rem 1.5rem}.personal-projects-title{font-size:2rem}.project-name{font-size:1.5rem}.carousel-container,.carousel-wrapper{min-height:200px}.project-description p{font-size:.95rem}}:root{--react-pdf-annotation-layer: 1;--annotation-unfocused-field-background: url("data:image/svg+xml;charset=UTF-8,<svg width='1px' height='1px' xmlns='http://www.w3.org/2000/svg'><rect width='100%' height='100%' style='fill:rgba(0, 54, 255, 0.13);'/></svg>");--input-focus-border-color: Highlight;--input-focus-outline: 1px solid Canvas;--input-unfocused-border-color: transparent;--input-disabled-border-color: transparent;--input-hover-border-color: black;--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 .textWidgetAnnotation :is(input,textarea):required,.annotationLayer .choiceWidgetAnnotation select:required,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input:required{outline:1.5px solid selectedItem}.annotationLayer .linkAnnotation:hover{-webkit-backdrop-filter:invert(100%);backdrop-filter:invert(100%)}}.annotationLayer{position:absolute;top:0;left:0;pointer-events:none;transform-origin:0 0;z-index:3}.annotationLayer[data-main-rotation="90"] .norotate{transform:rotate(270deg) translate(-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{position:absolute;width:100%;height:100%}.annotationLayer section{position:absolute;text-align:initial;pointer-events:auto;box-sizing:border-box;margin:0;transform-origin:0 0}.annotationLayer .linkAnnotation{outline:var(--link-outline)}.textLayer.selecting~.annotationLayer section{pointer-events:none}.annotationLayer :is(.linkAnnotation,.buttonWidgetAnnotation.pushButton)>a{position:absolute;font-size:1em;top:0;left:0;width:100%;height:100%}.annotationLayer :is(.linkAnnotation,.buttonWidgetAnnotation.pushButton)>a:hover{opacity:.2;background:#ff0;box-shadow:0 2px 10px #ff0}.annotationLayer .textAnnotation img{position:absolute;cursor:pointer;width:100%;height:100%;top:0;left:0}.annotationLayer .textWidgetAnnotation :is(input,textarea),.annotationLayer .choiceWidgetAnnotation select,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input{background-image:var(--annotation-unfocused-field-background);border:2px solid var(--input-unfocused-border-color);box-sizing:border-box;font:calc(9px * var(--total-scale-factor)) sans-serif;height:100%;margin:0;vertical-align:top;width:100%}.annotationLayer .textWidgetAnnotation :is(input,textarea):required,.annotationLayer .choiceWidgetAnnotation select:required,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input: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 .textWidgetAnnotation :is(input,textarea)[disabled],.annotationLayer .choiceWidgetAnnotation select[disabled],.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input[disabled]{background:none;border:2px solid var(--input-disabled-border-color);cursor:not-allowed}.annotationLayer .textWidgetAnnotation :is(input,textarea):hover,.annotationLayer .choiceWidgetAnnotation select:hover,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input:hover{border:2px solid var(--input-hover-border-color)}.annotationLayer .textWidgetAnnotation :is(input,textarea):hover,.annotationLayer .choiceWidgetAnnotation select:hover,.annotationLayer .buttonWidgetAnnotation.checkBox input:hover{border-radius:2px}.annotationLayer .textWidgetAnnotation :is(input,textarea):focus,.annotationLayer .choiceWidgetAnnotation select:focus{background:none;border:2px solid var(--input-focus-border-color);border-radius:2px;outline:var(--input-focus-outline)}.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) :focus{background-image:none;background-color:transparent}.annotationLayer .buttonWidgetAnnotation.checkBox :focus{border:2px solid var(--input-focus-border-color);border-radius:2px;outline:var(--input-focus-outline)}.annotationLayer .buttonWidgetAnnotation.radioButton :focus{border:2px solid var(--input-focus-border-color);outline:var(--input-focus-outline)}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:before,.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:after,.annotationLayer .buttonWidgetAnnotation.radioButton input:checked:before{background-color:CanvasText;content:"";display:block;position:absolute}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:before,.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:after{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{appearance:none}.annotationLayer .popupTriggerArea{height:100%;width:100%}.annotationLayer .fileAttachmentAnnotation .popupTriggerArea{position:absolute}.annotationLayer .popupWrapper{position:absolute;font-size:calc(9px * var(--total-scale-factor));width:100%;min-width:calc(180px * var(--total-scale-factor));pointer-events:none}.annotationLayer .popup{position:absolute;max-width:calc(180px * var(--total-scale-factor));background-color:#ff9;box-shadow:0 calc(2px * var(--total-scale-factor)) calc(5px * var(--total-scale-factor)) #888;border-radius:calc(2px * var(--total-scale-factor));padding:calc(6px * var(--total-scale-factor));margin-left:calc(5px * var(--total-scale-factor));cursor:pointer;font:message-box;white-space:normal;word-wrap:break-word;pointer-events:auto}.annotationLayer .popup>*{font-size:calc(9px * var(--total-scale-factor))}.annotationLayer .popup h1{display:inline-block}.annotationLayer .popupDate{display:inline-block;margin-left:calc(5px * var(--total-scale-factor))}.annotationLayer .popupContent{border-top:1px solid rgba(51,51,51,1);margin-top:calc(2px * var(--total-scale-factor));padding-top:calc(2px * var(--total-scale-factor))}.annotationLayer .richText>*{white-space:pre-wrap;font-size:calc(9px * var(--total-scale-factor))}.annotationLayer .highlightAnnotation,.annotationLayer .underlineAnnotation,.annotationLayer .squigglyAnnotation,.annotationLayer .strikeoutAnnotation,.annotationLayer .freeTextAnnotation,.annotationLayer .lineAnnotation svg line,.annotationLayer .squareAnnotation svg rect,.annotationLayer .circleAnnotation svg ellipse,.annotationLayer .polylineAnnotation svg polyline,.annotationLayer .polygonAnnotation svg polygon,.annotationLayer .caretAnnotation,.annotationLayer .inkAnnotation svg polyline,.annotationLayer .stampAnnotation,.annotationLayer .fileAttachmentAnnotation{cursor:pointer}.annotationLayer section svg{position:absolute;width:100%;height:100%;top:0;left:0}.annotationLayer .annotationTextContent{position:absolute;width:100%;height:100%;opacity:0;color:transparent;-webkit-user-select:none;user-select:none;pointer-events:none}.annotationLayer .annotationTextContent span{width:100%;display:inline-block}:root{--react-pdf-text-layer: 1;--highlight-bg-color: rgba(180, 0, 170, 1);--highlight-selected-bg-color: rgba(0, 100, 0, 1)}@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) translate(-100%)}.textLayer{position:absolute;text-align:initial;inset:0;overflow:hidden;line-height:1;text-size-adjust:none;forced-color-adjust:none;transform-origin:0 0;z-index:2}.textLayer :is(span,br){color:transparent;position:absolute;white-space:pre;cursor:text;margin:0;transform-origin:0 0}.textLayer span.markedContent{top:0;height:0}.textLayer .highlight{margin:-1px;padding:1px;background-color:var(--highlight-bg-color);border-radius:4px}.textLayer .highlight.appended{position:initial}.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:var(--highlight-selected-bg-color)}.textLayer br::selection{background:transparent}.textLayer .endOfContent{display:block;position:absolute;inset:100% 0 0;z-index:-1;cursor:default;-webkit-user-select:none;user-select:none}.textLayer.selecting .endOfContent{top:0}.hiddenCanvasElement{position:absolute;top:0;left:0;width:0;height:0;display:none}.resume-page{flex:0 1 auto;align-self:flex-start;background-color:var(--bg-primary);color:var(--text-primary);padding:4rem 3rem 3rem;width:100%;max-width:100%;box-sizing:border-box;overflow-x:hidden}.resume-container{max-width:1200px;margin:0 auto}.resume-title{font-size:3rem;font-weight:300;letter-spacing:-.02em;margin-bottom:3rem;color:var(--text-primary)}.resume-pdf-wrapper{width:100%;display:flex;flex-direction:column;align-items:center;gap:1.5rem}.resume-document{display:flex;flex-direction:column;align-items:center;width:100%}.resume-page-canvas{box-shadow:0 2px 4px #0000001a,0 4px 8px #0000000d;margin:0 auto}[data-theme=dark] .resume-page-canvas{box-shadow:0 2px 4px #0000004d,0 4px 8px #0003}.resume-loading,.resume-error{padding:2rem;text-align:center;color:var(--text-primary)}.resume-error{display:flex;flex-direction:column;gap:1rem;align-items:center}.resume-pagination{display:flex;align-items:center;gap:1rem;justify-content:center}.resume-page-button{padding:.5rem 1rem;background-color:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--text-secondary);border-radius:4px;cursor:pointer;font-size:.9rem;transition:background-color .2s}.resume-page-button:hover:not(:disabled){background-color:var(--text-secondary);color:var(--bg-primary)}.resume-page-button:disabled{opacity:.5;cursor:not-allowed}.resume-page-info{color:var(--text-primary);font-size:.9rem}.resume-download-section{margin-top:1rem}.resume-download-link{display:inline-block;padding:.75rem 1.5rem;background-color:var(--bg-secondary);color:var(--text-primary);text-decoration:none;border:1px solid var(--text-secondary);border-radius:4px;font-size:.9rem;transition:background-color .2s}.resume-download-link:hover{background-color:var(--text-secondary);color:var(--bg-primary)}@media (max-width: 768px){.resume-page{padding:3rem 2rem 2rem}.resume-title{font-size:2.5rem;margin-bottom:2rem}.resume-pdf-wrapper{gap:1rem}.resume-page-canvas{max-width:100%}}@media (max-width: 480px){.resume-page{padding:2rem 1.5rem 1.5rem}.resume-title{font-size:2rem}.resume-pdf-wrapper{gap:.75rem}.resume-pagination{flex-wrap:wrap;gap:.5rem}.resume-page-button{padding:.4rem .8rem;font-size:.85rem}.resume-download-link{padding:.6rem 1.2rem;font-size:.85rem}}.not-found-page{min-height:100vh;background-color:var(--bg-primary);color:var(--text-primary);display:flex;align-items:center;justify-content:center;padding:3rem}.not-found-container{text-align:center;max-width:600px}.not-found-title{font-size:6rem;font-weight:300;letter-spacing:-.02em;margin-bottom:1rem;color:var(--text-primary);line-height:1}.not-found-message{font-size:1.5rem;font-weight:400;margin-bottom:1rem;color:var(--text-primary)}.not-found-description{font-size:1rem;color:var(--text-secondary);margin-bottom:2rem;line-height:1.6}.not-found-link{display:inline-block;color:var(--text-primary);text-decoration:none;font-weight:500;padding:.75rem 1.5rem;border:1px solid var(--border-color);border-radius:4px;transition:all .3s ease;background-color:var(--bg-secondary)}.not-found-link:hover{color:var(--link-hover);border-color:var(--link-hover);background-color:var(--bg-primary)}@media (max-width: 768px){.not-found-page{padding:2rem}.not-found-title{font-size:4rem}.not-found-message{font-size:1.25rem}}@media (max-width: 480px){.not-found-title{font-size:3rem}.not-found-message{font-size:1.125rem}.not-found-description{font-size:.95rem}}:root{--bg-primary: #ffffff;--bg-secondary: #f0f0f0;--text-primary: #000000;--text-secondary: #666666;--border-color: #f0f0f0;--link-hover: #0077b5}[data-theme=dark]{--bg-primary: #1a1a1a;--bg-secondary: #2d2d2d;--text-primary: #ffffff;--text-secondary: #b0b0b0;--border-color: #404040;--link-hover: #4da6ff}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Helvetica Neue,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6;transition:background-color .3s ease,color .3s ease}#root{width:100%}.app-wrapper{min-height:100vh;display:flex;flex-direction:column}.routes-wrapper{flex:1;display:flex;flex-direction:column;min-height:0}.app-wrapper:has(.home-page){min-height:0!important;height:calc(var(--vh) * 100)!important;max-height:calc(var(--vh) * 100)!important;overflow:hidden}.app-wrapper:has(.home-page) .app{min-height:0!important;height:100%}.app-wrapper:has(.home-page) .routes-wrapper{min-height:0!important;flex:1 1 0;overflow:hidden}.app-wrapper:has(.home-page) .home-page{min-height:0!important;height:100%}.app-wrapper:has(.home-page) .header{padding-bottom:1.5rem}.app-wrapper:has(.home-page) .footer{padding-bottom:1.5rem}body.home-page-active{overflow:hidden!important;height:calc(var(--vh) * 100)!important;min-height:0!important;max-height:calc(var(--vh) * 100)!important;display:block!important;place-items:unset!important}html.home-page-active{overflow:hidden!important;height:calc(var(--vh) * 100)!important}body.home-page-active #root{height:100%;display:flex;flex-direction:column}.app{display:flex;flex-direction:column}.main-content{flex:1;display:flex;align-items:flex-start;justify-content:left;padding:4rem 3rem 3rem;width:100%}.home-page{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden}.home-page .main-content{flex:1;min-height:0;overflow:hidden}.hello-container{text-align:left;cursor:pointer;position:relative}.hello-text{font-size:4rem;font-weight:300;letter-spacing:-.02em;margin-bottom:0;opacity:1;transition:opacity .3s ease}.language-name{font-size:1rem;font-weight:400;color:var(--text-secondary);opacity:0;transition:opacity .3s ease,color .3s ease;position:absolute;top:100%;left:0;white-space:nowrap}.theme-toggle{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary);padding:.5rem;border-radius:50%;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;width:2rem;height:2rem}.theme-toggle:hover{background:var(--border-color);transform:scale(1.1)}.theme-toggle svg{width:1rem;height:1rem}@media (max-width: 768px){.hello-text{font-size:3rem}.main-content{padding:2rem 1.5rem 1.5rem}.home-page .main-content{padding:.75rem 2rem .5rem}.home-page .hello-text{font-size:2.5rem}.app-wrapper:has(.home-page) .header{padding-bottom:1rem}.app-wrapper:has(.home-page) .footer{padding-bottom:1rem}.theme-toggle{width:1.75rem;height:1.75rem}.theme-toggle svg{width:.875rem;height:.875rem}}@media (max-width: 480px){.hello-text{font-size:2.5rem}}.footer{padding:3rem;text-align:right;border-top:1px solid var(--border-color);width:100%;transition:border-color .3s ease;display:flex;justify-content:space-between;align-items:center}.footer-left{display:flex;align-items:center}.footer-right{display:flex;align-items:center;gap:1rem}.github-link,.linkedin-link{display:inline-block;color:var(--text-primary);transition:color .2s ease}.github-link:hover,.linkedin-link:hover{color:var(--link-hover)}.github-icon,.linkedin-icon{padding-top:8px}@media (max-width: 768px){.footer{padding:2rem}}:root{font-family:Helvetica Neue,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:var(--text-primary, #000000);background-color:var(--bg-primary, #ffffff);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}[data-theme=dark]{color-scheme:dark}a{font-weight:500;color:var(--text-primary, #646cff);text-decoration:inherit}a:hover{color:var(--link-hover, #535bf2)}html{overflow-x:hidden;width:100%;max-width:100%}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh;transition:background-color .3s ease,color .3s ease;overflow-x:hidden;width:100%;max-width:100%}#root{max-width:100%;width:100%;margin:0;padding:0;overflow-x:hidden}*{box-sizing:border-box}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:var(--bg-secondary, #1a1a1a);color:var(--text-primary, #ffffff);cursor:pointer;transition:border-color .25s,background-color .3s ease,color .3s ease}button:hover{border-color:var(--link-hover, #646cff)}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}
