: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(--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{-webkit-appearance:none;-moz-appearance:none;appearance:none}.annotationLayer .popupTriggerArea{height:100%;width:100%}.annotationLayer .fileAttachmentAnnotation .popupTriggerArea{position:absolute}.annotationLayer .popupWrapper{position:absolute;font-size:calc(9px * var(--scale-factor));width:100%;min-width:calc(180px * var(--scale-factor));pointer-events:none}.annotationLayer .popup{position:absolute;max-width:calc(180px * var(--scale-factor));background-color:#ff9;box-shadow:0 calc(2px * var(--scale-factor)) calc(5px * var(--scale-factor)) #888;border-radius:calc(2px * var(--scale-factor));padding:calc(6px * var(--scale-factor));margin-left:calc(5px * var(--scale-factor));cursor:pointer;font:message-box;white-space:normal;word-wrap:break-word;pointer-events:auto}.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 rgba(51,51,51,1);margin-top:calc(2px * var(--scale-factor));padding-top:calc(2px * var(--scale-factor))}.annotationLayer .richText>*{white-space:pre-wrap;font-size:calc(9px * var(--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;top:0;right:0;bottom:0;left: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;top:100%;right:0;bottom:0;left: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{--bg: #f3f2ee;--surface: #ffffff;--border: #e4e1da;--border-strong: #ccc9c0;--text: #111110;--text-2: #6e6b66;--text-3: #aaa9a3;--lime: #c8e63c;--red: #e53e3e;--radius: 6px;--radius-lg: 14px;--mono: "SF Mono", ui-monospace, "Cascadia Code", "Roboto Mono", monospace;--sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{min-height:100vh}body{font-family:var(--sans);color:var(--text);background-color:var(--bg);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='600' height='400'%3E%3Cpath d='M-100,50 C50,36 200,64 350,49 C500,34 580,58 700,44' fill='none' stroke='%23d8d5ce' stroke-width='0.8'/%3E%3Cpath d='M-100,115 C70,102 220,126 370,112 C520,98 600,120 700,108' fill='none' stroke='%23d8d5ce' stroke-width='0.8'/%3E%3Cpath d='M-100,182 C55,170 210,192 360,179 C510,166 590,186 700,175' fill='none' stroke='%23d8d5ce' stroke-width='0.8'/%3E%3Cpath d='M-100,250 C65,238 215,260 365,247 C515,234 595,253 700,242' fill='none' stroke='%23d8d5ce' stroke-width='0.8'/%3E%3Cpath d='M-100,318 C75,307 225,328 375,316 C525,304 605,322 700,312' fill='none' stroke='%23d8d5ce' stroke-width='0.8'/%3E%3Cpath d='M-100,386 C60,376 215,396 365,384 C515,372 595,390 700,380' fill='none' stroke='%23d8d5ce' stroke-width='0.8'/%3E%3C/svg%3E");background-size:600px 400px;background-repeat:repeat;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app{display:flex;flex-direction:column;min-height:100vh}.app__header{position:sticky;top:0;z-index:10;background:#f3f2eee0;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--border);padding:0 28px;height:54px;display:flex;align-items:center;gap:16px}.app__brand{display:flex;align-items:baseline;gap:7px;flex-shrink:0;text-decoration:none}.app__logo{font-family:Georgia,Times New Roman,serif;font-style:italic;font-size:18px;font-weight:400;letter-spacing:-.02em;color:var(--text)}.app__slash{color:var(--text-3);font-size:14px;font-weight:400}.app__name{font-size:13px;font-weight:500;color:var(--text);letter-spacing:-.01em}.app__meta{margin-left:auto;display:flex;align-items:center;gap:18px;flex-shrink:0}.app__version{font-family:var(--mono);font-size:10px;color:var(--text-3);letter-spacing:.07em;text-transform:uppercase}.app__privacy{font-family:var(--mono);font-size:10px;color:var(--text-2);letter-spacing:.06em;text-transform:uppercase;display:flex;align-items:center;gap:6px}.app__privacy-dot{width:6px;height:6px;border-radius:50%;background:#22c55e;flex-shrink:0;animation:blink 2.4s ease-in-out infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.app__main{flex:1;display:flex;justify-content:center;align-items:flex-start;padding:48px 24px}.upload{display:flex;flex-direction:column;align-items:center;gap:18px;padding:72px 56px;background:var(--surface);border:1px dashed var(--border-strong);border-radius:var(--radius-lg);max-width:540px;width:100%;text-align:center;transition:border-color .2s ease,box-shadow .2s ease}.upload:hover{border-color:var(--text-3);box-shadow:0 6px 28px #00000012}.upload__counter{font-family:var(--mono);font-size:10px;color:var(--text-3);letter-spacing:.1em;text-transform:uppercase}.upload__icon{width:52px;height:52px;border:1.5px solid var(--border-strong);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text-2);font-size:22px;line-height:1}.upload__title{font-size:22px;font-weight:600;letter-spacing:-.03em;color:var(--text)}.upload__sub{font-size:13px;color:var(--text-2);line-height:1.65;max-width:300px}.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 13px;border-radius:var(--radius);font-family:var(--sans);font-size:13px;font-weight:500;cursor:pointer;border:1px solid var(--border-strong);background:var(--surface);color:var(--text);transition:background .15s ease,border-color .15s ease,color .15s ease;letter-spacing:-.01em;line-height:1;white-space:nowrap;-webkit-user-select:none;user-select:none}.btn:hover{background:var(--bg);border-color:var(--text-3)}.btn--active{background:var(--text);color:#fff;border-color:var(--text)}.btn--active:hover{background:#2a2a29;border-color:#2a2a29}.btn--primary{background:var(--text);color:#fff;border-color:var(--text)}.btn--primary:hover:not(:disabled){background:#2a2a29;border-color:#2a2a29}.btn:disabled{opacity:.3;cursor:not-allowed}.btn--pill{border-radius:100px;padding:10px 26px;font-size:13px}.toolbar{display:flex;gap:6px;align-items:center}.toolbar__divider{width:1px;height:18px;background:var(--border);margin:0 2px;flex-shrink:0}.viewer{display:flex;flex-direction:column;gap:20px;align-items:center}.page-wrap{position:relative;background:#fff;box-shadow:0 2px 10px #00000014,0 0 0 1px #0000000a;border-radius:2px}.page-wrap.has-tool{cursor:crosshair;box-shadow:0 2px 10px #00000014,0 0 0 2px var(--lime)}.annotation{position:absolute;border:1.5px solid var(--text);background:#fffcc4cc;padding:2px 6px;cursor:move;pointer-events:auto;-webkit-user-select:none;user-select:none;touch-action:none;border-radius:3px;box-shadow:0 1px 4px #0000001a}.annotation:hover{box-shadow:0 0 0 3px #c8e63c59,0 1px 4px #0000001a}.annotation--text input{width:100%;height:100%;border:0;background:transparent;font-size:inherit;outline:none;padding:0;cursor:text;font-family:var(--sans);color:var(--text)}.annotation--text input::placeholder{color:var(--text-3);font-style:italic}.annotation--text input:focus{cursor:text}.annotation__delete{position:absolute;top:-9px;right:-9px;width:18px;height:18px;border-radius:50%;border:1.5px solid var(--text);background:var(--text);color:#fff;font-size:11px;line-height:15px;text-align:center;cursor:pointer;padding:0;z-index:2;transition:background .12s ease,border-color .12s ease}.annotation__delete:hover{background:var(--red);border-color:var(--red)}.annotation__resize{position:absolute;bottom:-8px;right:-8px;width:14px;height:14px;background:var(--surface);border:1.5px solid var(--text);border-radius:2px;cursor:nwse-resize;touch-action:none;z-index:2;transition:background .12s ease}.annotation__resize:hover{background:var(--lime)}.annotation--sig img{width:100%;height:100%;display:block;object-fit:contain}.annotation__date-stamp{color:var(--text-2);font-family:var(--mono);font-style:normal;letter-spacing:.04em;text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;-webkit-user-select:none;user-select:none;line-height:1.4}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000006b;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:var(--surface);border-radius:var(--radius-lg);padding:32px;display:flex;flex-direction:column;gap:22px;box-shadow:0 24px 64px #0000002e,0 0 0 1px #0000000f;min-width:540px}.modal__header{display:flex;align-items:baseline;justify-content:space-between}.modal__title{font-size:16px;font-weight:600;letter-spacing:-.02em}.modal__hint{font-family:var(--mono);font-size:10px;color:var(--text-3);letter-spacing:.07em;text-transform:uppercase}.modal__canvas-wrap{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:#fff;position:relative}.modal__canvas-guide{position:absolute;bottom:48px;left:24px;right:24px;height:1px;background:var(--border);pointer-events:none}.modal canvas{display:block;touch-action:none}.modal__check{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text-2);cursor:pointer;-webkit-user-select:none;user-select:none}.modal__check input[type=checkbox]{width:15px;height:15px;accent-color:var(--text);cursor:pointer}.modal__footer{display:flex;gap:8px;justify-content:flex-end;padding-top:6px;border-top:1px solid var(--border)}
