body,html{margin:0;padding:0;width:100%;height:100%}.fade-in{animation:fadeIn 1s ease forwards;opacity:0}button{transition:border-color .25s ease-out;font-size:1.5rem;background-color:transparent;border:.25rem solid white;cursor:pointer;padding:1rem;margin-top:1rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}*{font-family:JetBrains Mono;color:#fff;box-sizing:border-box}@keyframes kf-zoom-in{0%{opacity:0;transform:translateY(0) scale(0)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes kf-zoom-out{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(0) scale(0)}}.zoom-in{animation:kf-zoom-in 1.2s cubic-bezier(.15,.67,.22,1) forwards;animation-delay:1.3s}.zoom-out{animation:kf-zoom-out .3s ease-in}.unselectable-text{user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.page-container:before,.page-container:after{content:"";display:block;height:10vh;flex-shrink:0}.page-container{display:grid;align-items:start;justify-content:center;height:100vh;width:100vw;overflow-y:auto;position:absolute}.header-container{width:100%;display:flex;flex-direction:column;justify-content:space-between;align-items:start}.tags-text{color:#bbbb;font-size:2rem;vertical-align:top;height:100%}.date-text{color:#8888;font-size:2rem;vertical-align:top;height:100%}h1,h2,h3,h4,p{margin:0}h1{font-size:4rem}.info-container>p{font-size:2rem}.info-container{position:relative;isolation:isolate;inset:0;z-index:10;display:flex;flex-direction:column;align-content:center;padding:3rem;color:#fff;opacity:0;min-width:25vw;max-width:50vw;gap:2vh;margin:auto}.info-container:before{content:"";position:absolute;inset:0;z-index:-1;width:100%;background-image:var(--bg-image);background-size:contain;background-position:center;filter:blur(8px) brightness(.3);transform:scale(1)}.info-container:after{content:"";position:absolute;inset:0;border:.5rem solid var(--border-color);z-index:2;pointer-events:none}.hline{width:100}.button-container{width:100%;display:flex;justify-content:space-between;align-items:end;gap:.5rem}.links-container{gap:.5rem;display:flex}.links-container p:after{content:" ↗"}button{transition:border-color .25s ease-out;font-size:1.5rem;background-color:transparent;border:.25rem solid var(--border-color);cursor:pointer;padding:1rem;margin-top:1rem}button:hover{border-color:#7d7d7d}.info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-top:1.5rem}.info-card{padding:1.2rem;border:.25rem solid rgba(255,255,255,.5);background:#00000040}.info-card h3{margin:0 0 .5rem}.info-card p{margin:0}@media(max-width:800px){.info-grid{grid-template-columns:1fr}}: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}: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}body,html{--button-gap: 1rem;margin:0;padding:0}._homePageContainer_k2s3l_8{width:66vw;margin:0 auto;min-height:100vh}._homePageContent_k2s3l_15{padding:var(--button-gap) 0;gap:var(--button-gap);display:flex;flex-direction:column}._homeButtonContainer_k2s3l_22{display:flex;gap:var(--button-gap);position:sticky;top:2rem;margin-bottom:var(--button-gap);z-index:15}._homeButtonContainer_k2s3l_22 a{flex:1;text-decoration:none}._homeButtonContainer_k2s3l_22{padding:0 var(--button-gap)}._homeButton_k2s3l_22{width:100%;height:100%;padding:1rem;border:.25rem solid white;padding:clamp(.5rem,2vw,1rem);-webkit-backdrop-filter:blur(8px) brightness(.8);backdrop-filter:blur(8px) brightness(.8);margin:0;box-sizing:border-box;cursor:pointer}._homeButton_k2s3l_22:hover{border:.25rem solid rgba(255,255,255,.471)}._homeInfoBox_k2s3l_67{border:.25rem solid white;padding:clamp(1rem,3vw,3rem);-webkit-backdrop-filter:blur(24px) brightness(.8);backdrop-filter:blur(24px) brightness(.8)}li::marker{content:"> ";font-size:clamp(1.5rem,3.5vw,3rem)}p,li{font-size:2rem}b{color:#35dada}._contentFadeOut_k2s3l_103{opacity:0;transition:opacity .2s ease-out}._contentFadeIn_k2s3l_108{opacity:1;transition:opacity .2s ease-in}._contactContainer_8fw0n_1{display:flex;flex-direction:column;justify-items:center;justify-content:center;align-items:center;gap:1rem;font-size:clamp(1rem,4vw,3rem)}._contactContainer_8fw0n_1 button{margin:0;font-size:2.5rem}._contactContainer_8fw0n_1 h2{font-size:clamp(1rem,4vw,3rem)}._linkButton_8fw0n_20{border:.25rem solid white}._linkButton_8fw0n_20:after{content:""}._link_8fw0n_20{text-wrap-mode:nowrap;overflow-x:hidden}._link_8fw0n_20:hover{color:#fff}._link_8fw0n_20>a{transition:color .2s ease-out}._link_8fw0n_20>a:hover{color:#09e5e9}._link_8fw0n_20:after{content:" ]"}._link_8fw0n_20:hover:after{content:" ]>"}._link_8fw0n_20:before{content:"[ "}._link_8fw0n_20:hover:before{content:"<[ "}._topText_ibg91_3{position:absolute;left:50%;transform:translate(-50%);z-index:5;pointer-events:all;display:flex;flex-direction:column;align-items:center}._projectInfo_ibg91_14{border:.25rem solid white;border-top:0;-webkit-backdrop-filter:blur(6px) brightness(.8);backdrop-filter:blur(6px) brightness(.8);overflow:hidden;padding:.5rem}._title_ibg91_22{margin:0;padding:.25rem .5rem;text-align:center;font-size:2.5rem}._subtitle_ibg91_29{margin:0;padding:0 .5rem;text-align:center;font-size:1.75rem}._tags_ibg91_37{margin:0;font-size:1.5rem;text-align:center;padding:.5rem;font-style:italic;color:#fff9}._seeMoreButton_ibg91_47,._backButton_ibg91_48{font-size:1.5rem;padding:1rem;margin:0;cursor:pointer;border:.25rem solid white;-webkit-backdrop-filter:blur(6px) brightness(.8);backdrop-filter:blur(6px) brightness(.8);background:transparent;color:inherit;text-decoration:none;pointer-events:all;transition:border-color .25s ease-out,background-color .15s ease-out}._seeMoreButton_ibg91_47:hover,._backButton_ibg91_48:hover{background-color:#0009;border-color:#a8a8a8}._seeMoreButton_ibg91_47{border-top:0}._backButton_ibg91_48{position:absolute;bottom:1rem;left:1rem}
