.header{align-items:flex-end;background-color:#333;background-position:50%;background-size:cover;border-bottom:#000;box-shadow:inset;box-shadow:0 2px 5px var(--shadow-color);color:#fff;display:flex;height:30vh;justify-content:center;margin-bottom:1vh;overflow:hidden;padding:1.25rem 0;text-align:center;transition:all 1s ease-in-out}.shortHeader{cursor:pointer;max-height:.5vh}footer{align-items:center;background-color:var(--footer-bg);border-radius:var(--border-radius) var(--border-radius) 0 0;bottom:0;color:var(--text-color);display:flex;height:var(--footer-height);justify-content:center;left:0;position:fixed;width:100%;z-index:10}.social-media{display:flex;gap:var(--spacing-md);margin:0}.social-media a{color:var(--text-color);transition:color .3s ease}.social-media a:hover{color:var(--text-hover)}.credits{margin-right:var(--spacing-md)}.attributions{bottom:var(--spacing-sm);font-size:var(--font-size-sm);position:absolute;right:var(--spacing-sm)}.attributions a{text-decoration:none;transition:color .3s ease}.attributions a,.attributions a:visited{color:var(--text-hover)}@media (max-width:520px){.attributions{bottom:0;position:relative;right:0;text-align:center}footer{flex-direction:row;gap:var(--spacing-sm);height:auto;padding:.5rem}}.intro{color:var(--text-primary);margin-left:40vw;margin-right:40vw;margin-top:-10vh;z-index:2}.intro,.intro-content{align-items:flex-start;display:flex;flex-direction:column}.intro-content{margin-bottom:1vh;padding:var(--spacing-md) 0}.intro-image{border-radius:var(--border-radius);box-shadow:0 0 2px var(--shadow-color);height:clamp(8rem,15vw,10rem);object-fit:cover;transition:transform .3s ease;width:clamp(8rem,15vw,10rem)}.intro-content:hover{transform:scale(1.05);transition:transform 1s}.intro-short:hover{color:var(--text-hover);transition:1s ease}.intro-short{font-size:clamp(1rem,2.5vw,1.5rem);font-weight:700;letter-spacing:.05rem;line-height:1.6;margin-top:var(--spacing-sm);text-shadow:-1px 0 var(--midnight-black),0 1px var(--midnight-black),1px 0 var(--midnight-black),0 -1px var(--midnight-black);text-transform:uppercase;z-index:10}.intro-rest{display:inline-block;opacity:0;pointer-events:none;transform:translateY(20px) scale(.8) rotateX(-90deg);transform-origin:center bottom;transition:opacity .8s cubic-bezier(.23,1,.32,1),transform .8s cubic-bezier(.23,1,.32,1);will-change:opacity,transform}.intro-short:hover .intro-rest{opacity:1;pointer-events:auto;transform:translateY(0) scale(1) rotateX(0deg)}.intro-name{align-self:center;margin-top:-2.3vh}@media only screen and (max-width:1920px){.intro{margin-left:30vw;margin-right:30vw}}@media only screen and (max-width:1200px){.intro{margin-left:25vw;margin-right:25vw;margin-top:-8vh}}@media only screen and (max-width:1000px){.intro{margin-left:20vw;margin-right:20vw;margin-top:-7vh}.intro-name{margin-top:-2.1vh}.intro-image{height:clamp(6rem,12vw,8rem);width:clamp(6rem,12vw,8rem)}.intro-title{font-size:clamp(.9rem,2vw,1rem)}}@media only screen and (max-width:768px){.intro{margin-left:15vw;margin-right:15vw;margin-top:-6vh}.intro-name{margin-top:-1.7vh}}@media only screen and (max-width:480px){.intro{margin-left:10vw;margin-right:10vw;margin-top:-5.5vh}.intro-image{height:clamp(4rem,10vw,5rem);width:clamp(4rem,10vw,5rem)}.intro-title{font-size:clamp(.7rem,1.8vw,.8rem)}}@media only screen and (max-width:320px){.intro{margin-left:3vw;margin-right:3vw;margin-top:-6vh}}.project-card{background:var(--gradient-bg);box-shadow:0 4px 12px var(--shadow-color);margin-bottom:.8rem}.project-card:hover{background:linear-gradient(135deg,#4b4b5f,#2a2a3a)}a{text-decoration:none}@media (max-width:520px){.project-card{border-radius:8px;margin-bottom:.75rem}.card-body{align-items:flex-start;flex-direction:column;padding:16px}.project-icon{height:48px;width:48px}.card-title{font-size:1.1rem}}.project-card{backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:var(--gradient-card);background-color:var(--gradient-card);border-radius:12px;box-shadow:0 0 2px var(--shadow-color);overflow:hidden;transition:transform .3s ease,box-shadow .3s ease,background .3s ease}.project-card:hover{background:var(--gradient-card-hover);background-color:var(--gradient-card-hover);box-shadow:0 8px 20px #00000040;transform:translateY(-5px)}.project-card:focus-within{outline:2px solid var(--text-hover);outline-offset:2px}.card-body{align-items:center;background:#0000;border:none;display:flex;flex-direction:row;gap:16px;justify-content:space-between;padding:24px}.project-icon{border-radius:8px;height:64px;object-fit:cover;transition:transform .3s ease;width:64px}.project-icon:hover{transform:scale(1.1)}.card-title{color:var(--text-primary);font-size:1.25rem;font-weight:600;transition:color .3s ease}.card-title:hover{color:var(--text-hover)}.titleContainer{align-items:center;border-bottom:2px solid var(--accent-color);box-shadow:0 4px 2px -2px var(--shadow-color);color:var(--text-primary);display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm)}.titleContainer h2{font-size:clamp(.8rem,1vw,1.2rem);font-weight:700;letter-spacing:.05em;margin:0;text-shadow:0 0 8px rgba(var(--text-primary),.5)}.backIcon{background-color:initial;color:var(--text-primary);cursor:pointer;flex-shrink:0;font-size:clamp(1rem,2.5vw,1.5rem);transition:color .2s ease-in-out}.backIcon:hover{color:var(--text-hover)}.link-button{border:1px solid var(--lemon-blaze);border-radius:var(--border-radius);box-shadow:0 0 8px rgba(var(--lemon-blaze),.6);color:var(--golden-zest);cursor:pointer;display:inline-block;font-weight:700;letter-spacing:.04em;margin-top:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);text-decoration:none;text-transform:uppercase;transition:all .3s ease-in-out}.link-button:hover{background-color:var(--lemon-blaze);box-shadow:0 0 15px rgba(var(--lemon-blaze),.9),0 0 30px rgba(var(--lemon-blaze),.5);color:var(--midnight-black);transform:translateY(-2px)}.link-button:active{box-shadow:0 0 5px rgba(var(--lemon-blaze),.7);transform:translateY(0)}.silverhand-gif{margin-right:30vh;right:0}.jackie-gif,.silverhand-gif{bottom:0;box-shadow:0 0 2px var(--shadow-color);margin-bottom:20vh;position:absolute;scale:1.5}.jackie-gif{left:0;margin-left:20vh}.cv{align-items:center;color:#fff;display:flex;flex-direction:column;margin-top:1em;overflow:hidden!important;width:100%}.react-pdf__Page__annotations,.react-pdf__Page__canvas{height:100%!important;width:100%!important}: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)}.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%}[data-rmiz]{position:relative}[data-rmiz-ghost]{pointer-events:none;position:absolute}[data-rmiz-btn-unzoom],[data-rmiz-btn-zoom]{-webkit-appearance:none;appearance:none;background-color:#000000b3;border:none;border-radius:50%;box-shadow:0 0 1px #ffffff80;color:#fff;height:40px;margin:0;outline-offset:2px;padding:9px;touch-action:manipulation;width:40px}[data-rmiz-btn-zoom]:not(:focus):not(:active){clip:rect(0 0 0 0);-webkit-clip-path:inset(50%);clip-path:inset(50%);height:1px;overflow:hidden;pointer-events:none;position:absolute;white-space:nowrap;width:1px}[data-rmiz-btn-zoom]{cursor:zoom-in;inset:10px 10px auto auto;position:absolute}[data-rmiz-btn-unzoom]{cursor:zoom-out;inset:20px 20px auto auto;position:absolute;z-index:1}[data-rmiz-content=found] [data-zoom],[data-rmiz-content=found] [role=img],[data-rmiz-content=found] img,[data-rmiz-content=found] svg{cursor:zoom-in}[data-rmiz-modal]::backdrop{display:none}[data-rmiz-modal][open]{background:#0000;border:0;height:100vh;height:100dvh;margin:0;max-height:none;max-width:none;overflow:hidden;padding:0;position:fixed;width:100vw;width:100dvw}[data-rmiz-modal-overlay]{inset:0;position:absolute;transition:background-color .3s}[data-rmiz-modal-overlay=hidden]{background-color:#fff0}[data-rmiz-modal-overlay=visible]{background-color:#fff}[data-rmiz-modal-content]{height:100%;position:relative;width:100%}[data-rmiz-modal-img]{cursor:zoom-out;image-rendering:high-quality;position:absolute;transform-origin:top left;transition:transform .3s}@media (prefers-reduced-motion:reduce){[data-rmiz-modal-img],[data-rmiz-modal-overlay]{transition-duration:.01ms!important}}.image-list{display:inline-flex;flex-wrap:wrap;gap:.75rem;justify-content:center;list-style:none;margin-top:.5rem;padding:0}.image-list img{border-radius:.5rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;height:100px;object-fit:cover;width:100px}.image-list img:hover{transform:scale(1.05);transition:transform .2s ease-in-out}.buttons-group{display:flex;gap:.5rem}:root{--midnight-black:#000;--burgundy-shadow:#880425;--crimson-flame:#c5003c;--golden-zest:#f3e600;--lemon-blaze:#fee801;--aqua-breeze:#55ead4;--teal-tide:#39c4b6;--sky-sapphire:#54c1e6;--olive-glow:#9a9f17;--abyssal-navy:#00060e;--nean-pink:#d600ff;--cyberpunk-purple:#bd00ff;--footer-bg:var(--abyssal-navy);--text-primary:#f5f5f5;--text-hover:var(--lemon-blaze);--accent-color:var(--crimson-flame);--shadow-color:var(--cyberpunk-purple);--border-color:#ffffff14;--gradient-bg:linear-gradient(135deg,var(--burgundy-shadow) -50%,var(--midnight-black) 100%);--gradient-card:linear-gradient(135deg,var(--teal-tide) -100%,var(--abyssal-navy) 100%);--gradient-card-hover:linear-gradient(135deg,var(--sky-sapphire) 0%,var(--abyssal-navy) 100%);--border-radius:0.625rem;--spacing-sm:0.5rem;--spacing-md:1rem;--spacing-lg:2rem;--footer-height:2rem;--font-size-sm:clamp(0.65rem,1.5vw,0.7rem)}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{overflow-x:hidden;scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#880425 -50%,#000);background:var(--gradient-bg);background-color:linear-gradient(135deg,#880425 -50%,#000);background-color:var(--gradient-bg);color:#f5f5f5;color:var(--text-primary);display:flex;flex-direction:column;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;min-height:100vh;overflow-y:auto;padding-bottom:2rem;padding-bottom:var(--footer-height)}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.container{flex-grow:1;margin-bottom:1rem;margin-bottom:var(--spacing-md);margin-left:40vw;margin-right:40vw;padding-bottom:2rem;padding-bottom:var(--footer-height)}[data-rmiz-modal-overlay=visible]{background:linear-gradient(135deg,#880425 -50%,#000)!important;background:var(--gradient-bg)!important;background-color:linear-gradient(135deg,#880425 -50%,#000)!important;background-color:var(--gradient-bg)!important;opacity:.95!important}@media only screen and (max-width:1920px){.container{margin-left:30vw;margin-right:30vw}}@media only screen and (max-width:1200px){.container{margin-left:25vw;margin-right:25vw}}@media only screen and (max-width:1000px){.container{margin-left:20vw;margin-right:20vw}}@media only screen and (max-width:768px){.container{margin-left:15vw;margin-right:15vw}}@media only screen and (max-width:480px){.container{margin-left:10vw;margin-right:10vw}}@media only screen and (max-width:320px){.container{margin-left:3vw;margin-right:3vw}}@media only screen and (max-height:1000px){.container,body{padding-bottom:3rem;padding-bottom:calc(var(--footer-height) + var(--spacing-md))}}
/*# sourceMappingURL=main.20fc5b79.css.map*/