section{width:100%}section h3{margin-bottom:64px}.content{align-items:center;display:flex;flex-direction:column;text-align:center}#about{position:absolute;top:15vh}#projects{margin-top:100vh}.projects{gap:54px}.footer .socials{gap:8px;margin-top:128px}.footer svg path{fill:var(--primary-color)}.skills{margin-top:32px}.skills p{color:var(--secondary-text-color)}.skills .divider{background-color:var(--secondary-text-color);height:1px;margin-bottom:24px;width:90%}.skillset{align-items:center;display:flex;flex-direction:row;flex-wrap:wrap;gap:8px;justify-content:center;width:40%}.skillset img{background-color:var(--primary-color);border-radius:14px;height:32px;opacity:20%;padding:4px;rotate:10deg;scale:1;transition:opacity .1s ease;width:32px;z-index:1}.skillset img:hover{border-radius:8px;filter:none;opacity:80%;rotate:0deg;scale:1.25;z-index:100}.skills>.flex{gap:12px;margin:32px}.btn.projects{background-color:var(--primary-color);transition:background-color .3s ease}.btn.projects *{color:var(--bg-color);transition:color .3s ease}@media only screen and (min-width:600px) and (max-width:1024px){.skillset{width:65%}}@media only screen and (max-width:600px){.skills>.flex{flex-direction:column}.skillset{width:90%}}.backdrop{background-color:rgba(var(--bg-color-rgb),.5);height:100vh;left:0;pointer-events:all;position:fixed;top:0;width:100vw}.resume-container{background-color:#fff;border-radius:6px;box-shadow:0 0 30px #00000080;height:90vh;left:50%;position:fixed;top:50%;transform:translate(-50%,-50%);transition:opacity .1s ease;width:60vw}.backdrop,.resume-container{opacity:0;z-index:-1}.backdrop.open,.resume-container.open{opacity:1;z-index:100}@media only screen and (max-width:600px){.resume-container{height:98%;width:95%}}@media only screen and (min-width:600px) and (max-width:1024px){.resume-container{height:95vh;width:90vw}}.resume-container .content{scrollbar-width:none}.resume-container .content::-webkit-scrollbar{width:none}.resume-container .header{background-color:var(--bg-color);border-bottom:1px solid var(--primary-color);justify-content:space-between;padding-bottom:8px;padding-top:8px;padding-inline:32px;width:calc(100% - 64px)}.resume-container .header .flex{gap:8px}.resume-container .header a{left:50%;position:absolute;transform:translateX(-50%)}.resume-container .content{overflow:auto;width:100%}.resume-container .btn{border:none;color:var(--primary-color);height:min-content;padding:8px;width:min-content}.loader{animation:spin 1s linear infinite;border:4px solid #999;border-radius:50%;border-top-color:#333;height:40px;margin:100px auto;width:40px}@keyframes spin{to{transform:rotate(1turn)}}: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;text-align:left;text-align:initial;z-index:2}.textLayer,.textLayer :is(span,br){position:absolute;transform-origin:0 0}.textLayer :is(span,br){color:#0000;cursor:text;margin: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(--total-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{appearance:none}.annotationLayer .popupTriggerArea{height:100%;width:100%}.annotationLayer .fileAttachmentAnnotation .popupTriggerArea{position:absolute}.annotationLayer .popupWrapper{font-size:calc(9px*var(--total-scale-factor));min-width:calc(180px*var(--total-scale-factor));pointer-events:none;position:absolute;width:100%}.annotationLayer .popup{word-wrap:break-word;background-color:#ff9;border-radius:calc(2px*var(--total-scale-factor));box-shadow:0 calc(2px*var(--total-scale-factor)) calc(5px*var(--total-scale-factor)) #888;cursor:pointer;font:message-box;margin-left:calc(5px*var(--total-scale-factor));max-width:calc(180px*var(--total-scale-factor));padding:calc(6px*var(--total-scale-factor));pointer-events:auto;position:absolute;white-space:normal}.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 #333;margin-top:calc(2px*var(--total-scale-factor));padding-top:calc(2px*var(--total-scale-factor))}.annotationLayer .richText>*{font-size:calc(9px*var(--total-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%}.head{color:var(--primary-color)}.head>*{margin:8px}.head p{color:var(--secondary-text-color);font-family:monospace;font-size:16px}nav{align-items:center;-webkit-backdrop-filter:blur(2.5px);backdrop-filter:blur(2.5px);background:rgba(var(--bg-color-rgb),.5);display:flex;flex-direction:row;gap:22px;height:64px;justify-content:center;position:sticky;top:0;transition:background-color .3s ease;z-index:100}nav a{font-family:Arial;font-size:18px;font-style:italic;font-weight:400;text-decoration:none}.nav-backdrop{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:rgba(var(--bg-color-rgb),.5);gap:24px;height:100vh;justify-content:center;left:0;opacity:0;position:fixed;top:0;transition:all .1s ease-out,var(--bg-theme-trans);width:100%;z-index:-1}.nav-backdrop>*{font-size:24px;font-weight:700}nav .btn{border:none;height:min-content;width:min-content}#menu-button{cursor:pointer;display:none}#theme-button svg{display:flex}#theme-button svg+svg,html.dark #theme-button svg{display:none}html.dark #theme-button svg+svg{display:flex}@media only screen and (max-width:600px){nav{justify-content:right}#menu-button{display:block;margin-right:24px}nav>a{display:none}.nav-backdrop.open{opacity:1;z-index:100}}.notch{gap:22px;justify-content:center;margin-top:5vh}.notch svg path{fill:var(--primary-color)}.project .details{align-items:start;color:var(--primary-color);justify-content:flex-start;padding-inline:48px;text-align:left;z-index:2}.project .details h2{font-size:36px;font-weight:700;margin-bottom:16px;margin-top:0}.project .details p{font-size:18px;font-style:normal;font-weight:400;line-height:20px;margin:16px 0 0}.project .details p:nth-of-type(2){font-size:14px;font-style:italic;font-weight:400;line-height:16px}.project{align-items:start;margin-bottom:64px;margin-top:64px;position:relative;width:100%}.project>img{box-shadow:0 0 20px var(--primary-color);width:65vw;z-index:2}.project .container-deco{height:100%;left:0;opacity:100%;padding-bottom:42px;padding-top:42px;position:absolute;top:50%;transform:translateY(-50%);width:100%}html.dark .project .container-deco{opacity:20%}.project.anchor-left>img{order:1}.project.anchor-left .details,.project.anchor-right>img{order:2}.project.anchor-right .details{order:1}.project .links{gap:8px;margin-top:16px}.project .links *{text-decoration:none}.project .links .btn{font-size:14px;justify-content:left;padding-left:16px}.project .links .btn svg{height:24px;width:24px}.project .links .github{background-color:var(--primary-color)}.project .links .github *{fill:var(--bg-color);color:var(--bg-color)}.project .links .btn img{width:32px}@media only screen and (max-width:1024px){.project{flex-direction:column}.project.anchor-right img{order:1}.project.anchor-right .details{order:2}}@media only screen and (max-width:600px){.project>img{margin-bottom:24px;width:100%}.project .details h2{font-size:24px}}@media only screen and (min-width:600px) and (max-width:1024px){.project>img{align-self:center;margin-bottom:24px;width:90%}.project .links{flex-direction:row}}.emailer{gap:16px;min-width:50%}.emailer>*{outline-color:#0000;outline-style:solid;outline-width:0;transition:outline-color .5s ease}.emailer>:focus{outline-color:var(--primary-color);outline-style:solid;outline-width:1px}.emailer input{width:calc(100% - 40px)}.emailer input,.emailer textarea{border:1px solid grey;padding:20px;text-align:center}.emailer textarea{box-sizing:border-box;font-family:inherit;font-size:1rem;height:250px;resize:vertical;width:100%}.emailer input,.emailer textarea{background-color:var(--bg-color);transition:background-color .3s ease}.emailer button{animation:none;color:#fff;padding:16px;padding-inline:36px;place-self:end;width:max-content}.emailer button:enabled{background-color:var(--primary-color);border:1px solid #0000;color:var(--bg-color);cursor:pointer;transition:background-color 1s ease}.emailer button:disabled{background-color:var(--bg-color);border:1px solid var(--secondary-text-color);color:var(--secondary-text-color);cursor:default;transition:background-color .3s ease}@keyframes loading{0%,to{opacity:1}50%{opacity:.7}}.emailer button.sending{animation:loading 1s ease-in-out infinite}@media only screen and (max-width:600px){.emailer{width:calc(100% - 96px)}}@media only screen and (min-width:600px) and (max-width:1024px){.emailer{width:60%}}
/*# sourceMappingURL=main.34a82e60.css.map*/