:root{--color-bg:#0e141b;--color-bg-offset:#252526;--color-text:#fff;--color-text-offset:#818a91;--color-border:#2d2d2d;--color-primary:#ff5277;--color-primary-offset:#ff2957;--color-secondary:#43a9a3}*{box-sizing:border-box;margin:0;padding:0}body{background:#0e141b;background:var(--color-bg);color:#fff;color:var(--color-text);font-family:Roboto,sans-serif}a{text-decoration:none}::-webkit-scrollbar{height:7px;width:7px}::-webkit-scrollbar-thumb{background:#ff5277;background:var(--color-primary);border-radius:8px}.App{margin:auto;width:90%}@media screen and (max-width:770px){.App{margin:0;width:100%}.content{padding:20px 80px}}@media screen and (max-width:500px){.content{padding:20px 30px}}nav{align-items:center;background:var(--color-bg);box-shadow:0 5px 15px #0000000f;display:flex;height:100px;justify-content:space-between}.navbar-logo{height:65px;width:65px}.navbar-logo img{border-radius:100%;height:100%;width:100%}#navbar{align-items:center;display:flex;justify-content:center}#navbar li{list-style:none;padding:0 20px;position:relative}#navbar li a{color:var(--color-text);font-size:1.3rem;font-weight:600;transition:.3s ease-in-out}#navbar li a:active,#navbar li a:hover{color:#ffffffb3}#navbar li a:hover:after{background:var(--color-primary);bottom:-4px;content:"";height:2px;left:20px;position:absolute;width:30%}#mobile{display:none}#mobile i{align-items:center;color:var(--color-text)}.navbar-icons{position:relative;right:5px;top:4px}@media screen and (max-width:820px){.navbar-icons{display:none}}@media screen and (max-width:770px){nav{padding:20px 80px}#mobile{display:block;z-index:1}#mobile i{cursor:pointer;font-size:24px}#navbar{background:var(--color-bg);box-shadow:0 40px 60px #0000001a;display:flex;flex:1 0 auto;flex-direction:column;height:100vh;padding:40px 0 0 10px;position:fixed;right:-780px;top:0;transition:.3s ease-in-out;width:100%;z-index:1}#navbar.active{right:0}#navbar li a{font-size:2.3rem;font-weight:600}#navbar li{margin-bottom:25px}.navbar-icons{position:relative;right:7px}.navbar-logo{height:60px;width:60px}}@media screen and (max-width:500px){nav{padding:20px 30px}}footer{border-top:1px solid var(--color-border);display:flex;flex-wrap:wrap;margin-top:100px;padding:2rem 0;width:100%}footer div{flex:0 0 auto;text-align:center;width:33.33%}.footer-icons{padding:0}.footer-icons-img{color:var(--color-text);height:25px;transition:transform .3s ease;width:25px}.footer-icons-img:hover{transform:scale(1.5)}.footer-icons li{display:inline-block;padding-left:15px;padding-right:15px}@media screen and (max-width:770px){footer div{flex:0 0 auto;width:100%}footer div:nth-child(-n+2){margin-bottom:25px}}@media screen and (max-width:500px){footer{margin-top:0}}.home-presentation h1{color:var(--color-primary);font-size:19px;font-weight:700;letter-spacing:1px;line-height:30px;margin-block-end:1em;margin-block-start:1em;text-transform:uppercase}.home-presentation h2{font-size:56px;line-height:56px;margin-block-end:.67em;margin-block-start:.67em}.home-presentation p{color:var(--color-text-offset);font-size:32px;line-height:44px;margin-block-end:1em;margin-block-start:1em}.home-presentation p a{color:var(--color-secondary);text-decoration:underline;transition:.3s ease-in-out}.home-presentation p a:hover{color:#ffffffb3}.parallax-title{font-size:55px;line-height:55px;text-align:center}.home-find-me{display:flex;flex-wrap:wrap;margin-bottom:50px;margin-top:50px}.home-find-me-col{flex-basis:50%}.home-find-me-col:first-child{text-align:center}.home-find-me-col:first-child h4{color:var(--color-primary);font-size:40px;line-height:48px;text-transform:uppercase}.home-find-me-col:first-child p{color:var(--color-text-offset);font-size:18px;line-height:24px;margin-top:25px}.home-find-me-col:first-child div{margin-top:30px}.home-icons-img{color:var(--color-text);height:60px;transition:transform .3s ease;width:60px}.home-icons-img:hover{transform:scale(1.5)}.home-icons li{display:inline-block;padding-left:15px;padding-right:15px}@media screen and (max-width:1200px){.home-find-me-col{flex-basis:100%}.home-find-me-col:nth-child(2){margin-top:50px}}@media screen and (max-width:650px){.home-presentation h1{font-size:19px;line-height:30px}.home-presentation h2{font-size:40px;line-height:40px}.home-presentation p{font-size:24px;line-height:33px}.parallax-title{font-size:30px;line-height:30px}}.flex-center,.image-content{align-items:center;display:flex;justify-content:center}.dark-overlay:before,.fill-absolute,.image-content{bottom:0;left:0;position:absolute;right:0;top:0}.dark-overlay:before{background-color:#00000080;content:""}.image-box{overflow:hidden;padding:0}.image-bg,.image-box{height:100vh;position:relative;width:100%}.image-bg{background-attachment:fixed;background-position:50%;background-repeat:no-repeat;background-size:cover}.image-behind{height:auto;margin:0;padding:0;position:relative;width:100%}.tilt-box-wrap{height:300px;margin:auto;perspective:1000px;position:relative;transition:all .6s ease-out;width:80%}.tilt-box-wrap:hover{transform:scale(1.1);transition:all .3s linear}.tilt-box{background:#04527b;color:var(--color-text);font-size:15px;font-weight:700;height:100%;perspective:1000px;text-align:center;text-transform:uppercase;transform:rotateX(0deg) rotateY(0deg);transform-style:preserve-3d;transition:all .6s ease-out;width:100%}.tilt-box div{animation:logos 20s infinite;background-position:50%;background-repeat:no-repeat;background-size:contain;height:60%;margin:auto;position:relative;top:40px;width:80%}@keyframes logos{0%,16.66%{background-image:url(/portfolio/static/media/ruby-logo.2dadaf85f2f2ec3bc660.png)}16.67%,33.33%{background-image:url(data:image/png;base64,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)}33.34%,50%{background-image:url(/portfolio/static/media/postgresql-logo.6a0753e482c35a76d61a.png)}50.01%,66.66%{background-image:url(/portfolio/static/media/rspec-logo.fac606b2010d47f9578b.png)}66.67%,83.33%{background-image:url(/portfolio/static/media/linux-logo.55bd3b8d3529be7174e3.webp)}83.34%,to{background-image:url(/portfolio/static/media/docker-logo.7c458e84c4fe68d40608.png)}}.tilt-box h5{font-size:24px;position:relative;top:25px;transform:translateZ(40px)}.t_over{height:33.333%;position:absolute;width:33.333%;z-index:1}.t_over:first-child{left:0;top:0}.t_over:nth-child(2){left:33.333%;top:0}.t_over:nth-child(3){left:66.666%;top:0}.t_over:nth-child(4){left:0;top:33.333%}.t_over:nth-child(5){left:33.333%;top:33.333%}.t_over:nth-child(6){left:66.666%;top:33.333%}.t_over:nth-child(7){left:0;top:66.666%}.t_over:nth-child(8){left:33.333%;top:66.666%}.t_over:nth-child(9){left:66.666%;top:66.666%}.t_over:first-child:hover~.tilt-box{transform:rotateX(-20deg) rotateY(20deg)}.t_over:nth-child(2):hover~.tilt-box{transform:rotateX(-20deg) rotateY(0deg)}.t_over:nth-child(3):hover~.tilt-box{transform:rotateX(-20deg) rotateY(-20deg)}.t_over:nth-child(4):hover~.tilt-box{transform:rotateX(0deg) rotateY(20deg)}.t_over:nth-child(5):hover~.tilt-box{transform:rotateX(0deg) rotateY(0deg)}.t_over:nth-child(6):hover~.tilt-box{transform:rotateX(0deg) rotateY(-20deg)}.t_over:nth-child(7):hover~.tilt-box{transform:rotateX(20deg) rotateY(20deg)}.t_over:nth-child(8):hover~.tilt-box{transform:rotateX(20deg) rotateY(0deg)}.t_over:nth-child(9):hover~.tilt-box{transform:rotateX(20deg) rotateY(-20deg)}@media screen and (max-width:650px){.tilt-box-wrap{height:300px;width:100%}.tilt-box{font-size:10px;font-weight:700}}.about-presentation h1{font-size:112px;font-weight:700;line-height:134px;text-align:center}.about-presentation-row{align-items:center;display:flex;flex-wrap:wrap;justify-content:center;margin-bottom:50px;margin-top:50px}.about-presentation-col{flex-basis:50%;padding:25px}.about-presentation-col img{height:100%;width:100%}.about-presentation-col p{font-size:25px;line-height:35px;text-align:justify}.technologie-cards{margin-bottom:35px;margin-top:15px}.technologie-cards p{font-size:3em;font-weight:500;text-align:center}.technologie-cards-row{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(4,1fr)}@media screen and (max-width:1200px){.about-presentation h1{font-size:3.5rem;line-height:normal}.about-presentation-col{flex-basis:100%;padding:0}.about-presentation-col:nth-child(2){margin-top:50px}.about-presentation-col p{font-size:22px}.technologie-cards-row{grid-template-columns:repeat(2,1fr)}}@media screen and (max-width:600px){.technologie-cards-row{gap:15px;grid-template-columns:1fr;grid-template-rows:1fr}}.skillset-card-container{border:1.7px solid #43a9a3;border-radius:5px;box-shadow:2px 2.5px 2px 1.5px #43a9a380;margin-top:25px;padding:15px;.skillset-card{align-items:center;color:var(--color-text);display:flex;font-size:90px;justify-content:center;transition:all .4s ease 0s}.skillset-card:hover{transform:scale(1.05)}@media screen and (max-width:600px){.skillset-card{padding:15px}}.skillset-card-title{p{color:var(--color-text);font-size:20px;margin:15px 0 0;text-align:center}}}.project{padding:0 20px;width:100%}.project h1,.project h2{animation:fadeInDown .6s ease;font-size:2.5rem;font-weight:600;letter-spacing:-.5px;margin-bottom:10px;text-align:center}.project h2{font-size:2.2rem;margin-top:60px}.project p a{color:var(--color-secondary);font-weight:500;position:relative;text-decoration:none;transition:all .3s cubic-bezier(.25,.46,.45,.94)}.project p a:after{background:var(--color-secondary);bottom:-2px;content:"";height:2px;left:0;position:absolute;transform:scaleX(0);transform-origin:right;transition:transform .3s cubic-bezier(.25,.46,.45,.94);width:100%}.project a:hover:after{transform:scaleX(1);transform-origin:left}.project a:hover{color:#ffffffe6}.project p{animation:fadeInUp .6s ease .2s both;color:#ffffffbf;font-size:1.05rem;line-height:1.6;margin-bottom:40px;margin-top:15px;text-align:center}.project-cards{grid-gap:28px;animation:fadeInUp .8s ease .3s both;display:grid;gap:28px;grid-template-columns:repeat(4,1fr);margin-bottom:50px;margin-top:50px}@media screen and (max-width:1400px){.project h1,.project h2{font-size:2.2rem}.project-cards{gap:25px}}@media screen and (max-width:1200px){.project h1,.project h2{font-size:2rem}.project p{font-size:1rem}.project-cards{gap:22px;grid-template-columns:repeat(2,1fr)}}@media screen and (max-width:900px){.project h1,.project h2{font-size:1.8rem}.project-cards{gap:20px}}@media screen and (max-width:768px){.project{padding:0 15px}.project h1,.project h2{font-size:1.6rem}.project p{font-size:.95rem}.project-cards{gap:18px;grid-template-columns:1fr}}@media screen and (max-width:500px){.project{padding:0 12px}.project h1,.project h2{font-size:1.4rem;margin-bottom:8px}.project p{font-size:.9rem;margin-bottom:30px}.project-cards{gap:16px;margin-bottom:40px;margin-top:40px}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.project-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#1e1e1ee6,#323232e6);border:1.5px solid #43a9a366;border-radius:12px;box-shadow:0 10px 30px #0000004d;display:flex;flex-direction:column;height:100%;overflow:hidden;transition:all .4s cubic-bezier(.25,.46,.45,.94)}.project-card:hover{border-color:#43a9a3cc;box-shadow:0 20px 50px #43a9a333;transform:translateY(-8px)}.card-image-wrapper{flex-shrink:0;overflow:hidden;position:relative;width:100%}.card-image-wrapper:before{background:linear-gradient(135deg,#43a9a326,#0000);bottom:0;content:"";left:0;opacity:0;pointer-events:none;position:absolute;right:0;top:0;transition:opacity .4s ease;z-index:1}.project-card:hover .card-image-wrapper:before{opacity:1}.card-image-wrapper img{background:linear-gradient(135deg,#43a9a31a,#6464641a);display:block;height:280px;object-fit:cover;object-position:center;transition:transform .5s cubic-bezier(.25,.46,.45,.94);width:100%}.project-card:hover .card-image-wrapper img{transform:scale(1.08)}.image-overlay{background:#43a9a30d;bottom:0;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .4s ease}.project-card:hover .image-overlay{opacity:1}.card-content{display:flex;flex-direction:column;flex-grow:1;padding:28px 24px}.project-card h2{color:var(--color-primary);font-size:1.35rem;font-weight:600;line-height:1.3;margin:0 0 16px;transition:color .3s ease}.project-card:hover h2{color:#ffb3cc}.project-card p{color:#fffc;flex-grow:1;font-size:.95rem;line-height:1.6;margin:0 0 20px;text-align:justify;transition:color .3s ease;white-space:pre-wrap;word-break:break-word}.project-card:hover p{color:#fffffff2}.link-container{display:flex;flex-wrap:wrap;gap:12px;margin-top:auto}.card-link,.link-container{align-items:center;justify-content:center}.card-link{background:#0000;border:1.5px solid var(--color-primary);border-radius:8px;color:var(--color-primary);display:inline-flex;font-size:.95rem;font-weight:500;gap:6px;overflow:hidden;padding:10px 18px;position:relative;text-decoration:none;transition:all .3s cubic-bezier(.25,.46,.45,.94)}.card-link:before{background:var(--color-primary);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .3s cubic-bezier(.25,.46,.45,.94);width:100%;z-index:-1}.card-link:hover{border-color:var(--color-primary);box-shadow:0 8px 20px #43a9a34d;color:var(--color-background)}.card-link:hover:before{left:0}@media screen and (max-width:1200px){.card-image-wrapper img{height:240px}.card-content{padding:24px 20px}.project-card h2{font-size:1.2rem}.project-card p{font-size:.9rem;text-align:center}}@media screen and (max-width:768px){.card-image-wrapper img{height:220px}.card-content{padding:20px 18px}.project-card h2{font-size:1.1rem;margin-bottom:12px}.project-card p{font-size:.85rem;line-height:1.5;margin-bottom:16px}.link-container{gap:8px}.card-link{font-size:.85rem;padding:8px 14px}.card-link svg{height:16px!important;width:16px!important}}@media screen and (max-width:500px){.card-image-wrapper img{height:200px}.card-content{padding:18px 16px}.project-card h2{font-size:1rem;margin-bottom:10px}.project-card p{font-size:.82rem;line-height:1.4;margin-bottom:14px}.link-container{gap:6px}.card-link{font-size:.8rem;padding:8px 12px}.card-link span{display:none}.card-link svg{height:18px!important;width:18px!important}}.resume h1{color:var(--color-primary);font-size:50px;text-align:center}.resume-button{display:flex;justify-content:center;margin-top:25px}.resume-button button{background:#0000;background-image:linear-gradient(45deg,var(--color-primary) 50%,#0000 50%);background-position:100%;background-size:400%;border:2.5px solid var(--color-primary);border-radius:10rem;color:var(--color-text);cursor:pointer;height:50px;text-transform:uppercase;transition:background .4s ease-in-out;width:200px}.resume-button button:hover{background-position:0;color:var(--color-text)}.resume-button button span{bottom:4px;position:relative}.resume-container{display:flex;flex-wrap:wrap;justify-content:center;margin-left:calc(var(--bs-gutter-x)*-.5);margin-right:calc(var(--bs-gutter-x)*-.5);margin-top:calc(var(--bs-gutter-y)*-1);padding-bottom:50px;padding-top:50px}.resume-pdf{height:100%;overflow-y:hidden}@media screen and (max-width:650px){.resume h1{font-size:38px}}: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{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%}
/*# sourceMappingURL=main.7ddd2278.css.map*/