@import"https://fonts.googleapis.com/css2?family=Sora:wght@400;500;600;700&display=swap";html,body,#root{width:100%;min-height:100%}body{min-width:320px}:root{--bg: #f4f6fb;--ink: #10223f;--subtle: #577198;--panel: #ffffff;--line: #d6ddec;--accent: #0057ff;--accent-soft: #e8efff;--danger: #d14f4f}*{box-sizing:border-box}body{margin:0;font-family:Sora,Segoe UI,sans-serif;color:var(--ink);background:radial-gradient(circle at top right,#dce8ff 0%,transparent 35%),radial-gradient(circle at bottom left,#eaf6ff 0%,transparent 25%),var(--bg)}#root{min-height:100vh}.auth-screen{min-height:100vh;display:grid;place-items:center;padding:1rem;background:radial-gradient(circle at 20% 15%,rgba(30,200,187,.24),transparent 34%),linear-gradient(150deg,#08161a,#0b2026 45%,#0f2d35)}.auth-card{width:min(92vw,560px);border-radius:1rem;border:1px solid var(--line);background:#fff;box-shadow:0 26px 65px #040c0e8c;padding:2rem;display:grid;gap:.75rem}.auth-logo{width:180px;height:auto}.auth-eyebrow{margin:0;font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:#4d6f77}.auth-card h1{margin:0;color:#0f2a32}.auth-subtitle{margin:0;color:#27515b}.auth-caption{margin:0;font-size:.82rem;color:#4e6770}.auth-error{margin:0;font-size:.85rem;color:#9f1d1d}.auth-actions{display:grid;gap:.65rem}.auth-card .auth-primary{width:100%;min-height:2.85rem;background:linear-gradient(180deg,#1c7fb3,#125f8c);color:#fff;font-weight:700;letter-spacing:.01em}.auth-card .auth-secondary{width:100%;min-height:2.75rem;border:1px solid #1c6c9f;background:#eef6ff;color:#12456f;font-weight:600}.auth-card .auth-secondary:hover{background:#e3f0ff}.auth-action-note{margin:0;font-size:.8rem;line-height:1.45;color:#3f6470}.app-shell{height:100vh;padding:1rem;display:flex;flex-direction:column;gap:1rem;overflow:hidden}.top-bar{background:linear-gradient(120deg,#0f2e56,#133d74);border-radius:1rem;color:#f4f8ff;padding:1rem 1.25rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;box-shadow:0 14px 32px #133d7442}.top-bar h1{margin:0;font-size:clamp(1.4rem,3vw,2rem)}.top-bar p{margin:.4rem 0 0;color:#d4e4ff;font-size:.88rem}button,.input-btn{border:0;border-radius:.7rem;padding:.65rem .9rem;font:inherit;cursor:pointer}button.primary{background:#fff;color:#113665;font-weight:600}button.primary:disabled{opacity:.5;cursor:not-allowed}.workspace{display:grid;grid-template-columns:230px minmax(0,1fr) 250px;gap:1rem;min-height:0;flex:1;overflow:hidden}.panel{background:var(--panel);border:1px solid var(--line);border-radius:1rem;padding:.85rem;display:flex;flex-direction:column;gap:.65rem;box-shadow:0 8px 28px #0f2e5614;min-height:0}.left-panel,.right-panel{overflow:hidden}.left-panel.compact{font-size:.84rem}.drop-zone{border:2px dashed #8ba7d8;border-radius:.9rem;padding:.75rem;text-align:center;background:#f7faff;display:flex;flex-direction:column;gap:.3rem;cursor:pointer}.drop-zone input,.input-btn input{display:none}.drop-zone strong{color:#163a6b}.drop-zone span{color:var(--subtle);font-size:.8rem}.asset-upload-row{display:grid;gap:.4rem}.input-btn{background:var(--accent-soft);color:#143862;text-align:center;font-size:.78rem;font-weight:600}.input-btn.secondary{background:#ecf7ff}.asset-list{display:grid;gap:.45rem;overflow:visible}.asset-list p{margin:0;color:var(--subtle);font-size:.86rem}.asset-card{display:grid;grid-template-columns:54px minmax(0,1fr);gap:.45rem;border:1px solid var(--line);border-radius:.8rem;padding:.45rem;background:#fff;cursor:grab}.asset-card:active{cursor:grabbing}.asset-card img{width:54px;height:34px;object-fit:contain;border-radius:.5rem;background:transparent}.asset-card strong{display:block;font-size:.72rem;line-height:1.3;overflow-wrap:anywhere}.asset-card small{color:var(--subtle);text-transform:uppercase;letter-spacing:.06em;font-size:.62rem}.text-tools{border:1px solid var(--line);border-radius:.75rem;padding:.55rem;background:#fbfdff;display:grid;gap:.45rem}.text-tools strong{font-size:.74rem;text-transform:uppercase;letter-spacing:.06em;color:#49658c}.text-tools textarea,.right-panel textarea{width:100%;border-radius:.6rem;border:1px solid #cad7ee;padding:.45rem .5rem;font:inherit;resize:vertical}.quick-row{display:grid;grid-template-columns:1fr 1fr;gap:.4rem}.mini{background:#ecf3ff;color:#21466f;font-size:.74rem;padding:.4rem .45rem}.text-chip-row{display:grid;gap:.35rem}.text-chip{border:1px dashed #91acd6;background:#f4f8ff;color:#203f63;border-radius:.58rem;padding:.35rem .45rem;font-size:.72rem;cursor:grab;-webkit-user-select:none;user-select:none;overflow-wrap:anywhere}.pdf-stage{border:1px solid var(--line);border-radius:1rem;background:linear-gradient(180deg,#f9fbff,#f2f5fc);padding:1rem;min-height:0;overflow:auto;box-shadow:inset 0 0 0 1px #eef3ff}.page-shell{position:relative;width:fit-content;margin:0 auto 1rem;background:#fff;box-shadow:0 12px 30px #071e3c1f}.page-shell:last-child{margin-bottom:0}.overlay-layer{position:absolute;inset:0}.placement{position:absolute;border:1px dashed transparent;padding:0;margin:0;background:transparent;transform-origin:center;overflow:visible}.placement img{width:100%;height:100%;object-fit:contain;pointer-events:none}.placement.selected{border-color:#0f63ff;box-shadow:0 0 0 3px #0f63ff33}.resize-handle{position:absolute;width:12px;height:12px;right:-7px;bottom:-7px;border-radius:3px;border:1px solid #0f63ff;background:#fff;cursor:nwse-resize}.text-placement{border:1px dashed transparent;background:transparent;color:#111;font-family:Helvetica,Arial,sans-serif;display:flex;align-items:flex-start;justify-content:flex-start;text-align:left;line-height:1.25;padding:2px 4px;white-space:pre;overflow:hidden}.right-panel h2{margin:0;font-size:1rem}.right-panel label{display:grid;gap:.35rem;font-size:.84rem;color:#355175}.right-panel input{width:100%;border-radius:.5rem;border:1px solid #cad7ee;padding:.35rem .45rem;font:inherit}button.danger{background:#ffe8e8;color:#7f1e1e}.status-box{margin-top:auto;border-radius:.7rem;background:#f3f6fc;border:1px solid #dde6f6;padding:.75rem;font-size:.8rem;color:#2e4b71}.empty-state{color:#587196;text-align:center;padding:2.2rem 1rem;border:2px dashed #c4d2ec;border-radius:.9rem;background:#fcfdff}@media(max-width:1200px){.workspace{grid-template-columns:220px minmax(0,1fr)}.right-panel{grid-column:span 2}}@media(max-width:860px){.app-shell{height:auto;overflow:visible;padding:.7rem}.top-bar{flex-direction:column;align-items:flex-start}.workspace{grid-template-columns:1fr}.right-panel{grid-column:auto}.page-shell canvas{width:100%!important;height:auto!important}}: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}
