@import"https://fonts.googleapis.com/css2?family=JetBrains+Mono:ital,wght@0,100..800;1,100..800&display=swap";: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}: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}*{box-sizing:border-box}html{overflow-x:hidden}:root{--color-primary: #304C89;--color-secondary: #648de5;--color-tertiary: #9eb7e5;--color-light: #e8e5da;--color-accent: #cdc392;--bg-primary: var(--color-primary);--bg-secondary: var(--color-secondary);--text-primary: var(--color-light);--text-secondary: var(--color-tertiary);--text-muted: var(--color-accent);--border-color: var(--color-secondary);--hover-color: var(--color-tertiary);--accent-color: var(--color-accent);font-family:JetBrains Mono,Courier New,Consolas,Monaco,monospace;line-height:1.5;font-weight:400;color-scheme:dark;color:var(--text-primary);background-color:var(--bg-primary);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:color .2s ease,background-color .2s ease}a{font-weight:500;color:var(--color-secondary);text-decoration:inherit}a:hover{color:var(--hover-color)}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh;background-color:inherit;color:inherit;transition:all .2s ease}#app{max-width:1280px;margin:0 auto;padding:2rem;text-align:center;width:100%;min-height:100vh;display:flex;align-items:center;justify-content:center}.app{width:100%;display:block;text-align:center;min-height:0}h1{font-size:3.2em;line-height:1.1;margin-bottom:1rem}.drop-zone{margin-top:2rem;padding:2rem;border:2px dashed var(--border-color);border-radius:12px;min-height:400px;display:flex;align-items:center;justify-content:center;background-color:#648de51a;transition:all .3s ease;cursor:pointer;position:relative}.drop-zone:hover,.drop-zone.drag-over{border-color:var(--hover-color);background-color:#9eb7e526;transform:translateY(-2px);box-shadow:0 8px 25px #9eb7e54d}.drop-zone.pdf-loaded{cursor:default}.drop-zone.pdf-loaded:hover,.drop-zone.pdf-loaded.drag-over{border-color:var(--border-color);background-color:#648de51a;transform:none;box-shadow:none}.drop-message{text-align:center;color:var(--text-secondary)}.upload-icon{width:64px;height:64px;margin:0 auto 1rem;opacity:.6}.file-hint{font-size:.9em;opacity:.7;margin-top:.5rem}.pdf-container{width:100%}.pdf-controls{display:flex;justify-content:center;align-items:center;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.pdf-controls button{background:var(--color-secondary);color:var(--text-primary);border:none;padding:.6rem 1.2rem;border-radius:6px;cursor:pointer;font-size:.9em;transition:all .2s ease}.pdf-controls button:hover:not(:disabled){background:var(--hover-color);transform:translateY(-1px)}.pdf-controls button:disabled{background:var(--color-primary);cursor:not-allowed;opacity:.6}.close-btn{background:var(--color-primary)!important}.close-btn:hover{background:var(--color-secondary)!important}.page-info{font-weight:500;color:var(--text-primary);min-width:120px}.pdf-viewer{display:flex;justify-content:center;margin-top:1rem}.loading{display:flex;justify-content:center;align-items:center;height:200px;color:var(--text-secondary);font-size:1.1em}.error-message{text-align:center;color:var(--accent-color);padding:2rem}.error-message button{background:var(--color-secondary);color:var(--text-primary);border:none;padding:.6rem 1.2rem;border-radius:6px;cursor:pointer;margin-top:1rem}.error-message button:hover{background:var(--hover-color)}.react-pdf__Page{margin:0 auto;box-shadow:0 4px 20px #304c8966;border-radius:8px;overflow:hidden}.react-pdf__Page__canvas{max-width:100%;height:auto!important}.pdf-metadata{background:#648de51a;border:1px solid var(--border-color);border-radius:8px;padding:1.5rem;margin:1rem 0;text-align:left;max-width:800px;margin-left:auto;margin-right:auto}.pdf-metadata h3{color:var(--text-primary);margin:0 0 1rem;font-size:1.2em;text-align:center;border-bottom:1px solid var(--border-color);padding-bottom:.5rem}.metadata-grid{display:grid;grid-template-columns:1fr;gap:.75rem}.metadata-item{display:flex;justify-content:space-between;align-items:flex-start;padding:.5rem 0;border-bottom:1px solid rgba(100,141,229,.2)}.metadata-item:last-child{border-bottom:none}.metadata-label{color:var(--text-secondary);font-weight:500;min-width:120px;flex-shrink:0}.metadata-value{color:var(--text-primary);text-align:right;word-break:break-word;flex:1;margin-left:1rem}.image-viewer{display:flex;justify-content:center;align-items:center;margin:1rem 0}.image-viewer img{max-width:100%;max-height:600px;object-fit:contain;border-radius:8px;box-shadow:0 4px 20px #304c8966}.stored-files-section{margin:1.5rem 0;background:#ffffff0d;border-radius:12px;padding:1rem;border:1px solid var(--border-color)}.stored-files-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.stored-files-header h3{margin:0;color:var(--text-primary);font-size:1.1em}.stored-files-controls{display:flex;gap:.5rem}.toggle-stored-files-btn,.clear-all-btn{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color);padding:.5rem 1rem;border-radius:8px;cursor:pointer;font-size:.9em;transition:all .2s ease}.toggle-stored-files-btn:hover,.clear-all-btn:hover{background:var(--hover-color);transform:translateY(-2px)}.clear-all-btn{background:#d32f2f;border-color:#f44336}.clear-all-btn:hover{background:#f44336}.stored-files-list{display:flex;flex-direction:column;gap:.75rem;max-height:300px;overflow-y:auto;padding-right:.5rem}.stored-files-list::-webkit-scrollbar{width:6px}.stored-files-list::-webkit-scrollbar-track{background:#ffffff1a;border-radius:3px}.stored-files-list::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.stored-files-list::-webkit-scrollbar-thumb:hover{background:var(--hover-color)}.stored-file-item{display:flex;justify-content:space-between;align-items:center;background:#ffffff14;padding:.75rem;border-radius:8px;border:1px solid rgba(255,255,255,.1);transition:all .2s ease}.stored-file-item:hover{background:#ffffff1f;border-color:var(--border-color);transform:translateY(-1px)}.file-info{display:flex;align-items:center;gap:.75rem;flex:1;min-width:0}.file-icon{font-size:1.5em;flex-shrink:0}.file-details{flex:1;min-width:0}.file-name{font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:300px}.file-meta{display:flex;flex-direction:column;gap:.25rem;font-size:.8em;color:var(--text-secondary);margin-top:.25rem}.file-size{font-weight:500}.file-date{color:var(--text-muted)}.file-actions{display:flex;gap:.5rem;flex-shrink:0}.load-file-btn,.delete-file-btn{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color);padding:.5rem .75rem;border-radius:6px;cursor:pointer;font-size:.85em;transition:all .2s ease;white-space:nowrap}.load-file-btn:hover{background:var(--hover-color);transform:translateY(-1px)}.delete-file-btn{background:#d32f2f;border-color:#f44336;padding:.5rem}.delete-file-btn:hover{background:#f44336;transform:translateY(-1px)}@media (max-width: 768px){.pdf-metadata{padding:1rem;margin:.5rem 0}.metadata-item{flex-direction:column;align-items:flex-start;gap:.25rem}.metadata-label{min-width:auto}.metadata-value{text-align:left;margin-left:0}.image-viewer img{max-height:400px}.stored-files-header{flex-direction:column;gap:.75rem;align-items:stretch}.stored-files-controls{justify-content:space-between}.stored-file-item{flex-direction:column;gap:.75rem;align-items:stretch}.file-info{justify-content:flex-start}.file-name{max-width:none}.file-meta{flex-direction:row;gap:1rem}.file-actions{justify-content:space-between}}@media (prefers-color-scheme: light){:root{--bg-primary: var(--color-primary);--bg-secondary: var(--color-secondary);--text-primary: var(--color-light);--text-secondary: var(--color-tertiary);color:var(--text-primary);background-color:var(--bg-primary)}.drop-zone{background-color:#648de51a}.drop-zone:hover,.drop-zone.drag-over{background-color:#9eb7e526}.drop-message{color:var(--text-secondary)}.page-info{color:var(--text-primary)}.loading{color:var(--text-secondary)}.react-pdf__Page{box-shadow:0 4px 20px #304c8966}}.public-files-section{margin:2rem 0;background:#ffffff0d;border-radius:12px;padding:1.5rem;border:1px solid var(--border-color)}.public-files-section h3{margin:0 0 1.5rem;color:var(--text-primary);font-size:1.2em;text-align:center}.public-files-table{width:100%;border-collapse:collapse;background:#ffffff05;border-radius:8px;overflow:hidden}.public-files-table th{background:var(--bg-secondary);color:var(--text-primary);padding:1rem;text-align:left;font-weight:600;border-bottom:2px solid var(--border-color)}.public-files-table td{padding:1rem;border-bottom:1px solid rgba(255,255,255,.1);color:var(--text-primary)}.public-files-table tr:hover{background:#ffffff0d}.public-files-table .file-name{font-weight:500;max-width:300px;word-break:break-word}.public-files-table .file-type{color:var(--text-secondary);font-size:.9em;text-transform:uppercase;font-weight:500}.public-files-table .file-actions{display:flex;gap:.5rem;justify-content:center}.action-btn{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary);padding:.5rem;border-radius:6px;cursor:pointer;font-size:1.2em;transition:all .2s ease;min-width:40px;height:40px;display:flex;align-items:center;justify-content:center}.action-btn:hover{background:var(--hover-color);transform:translateY(-2px);box-shadow:0 4px 12px #9eb7e54d}.download-btn:hover{background:#4caf50;border-color:#66bb6a}.preview-btn:hover{background:#2196f3;border-color:#42a5f5}@media (max-width: 768px){#app{padding:1rem}h1{font-size:2.5em}.drop-zone{padding:1.5rem;min-height:300px}.pdf-controls{gap:.5rem}.pdf-controls button{padding:.5rem 1rem;font-size:.8em}.public-files-section{padding:1rem}.public-files-table th,.public-files-table td{padding:.75rem .5rem}.public-files-table .file-name{max-width:200px}.action-btn{min-width:35px;height:35px;font-size:1em}}
