:root{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;color:#1f2937;background:linear-gradient(120deg,#f4f6fb,#eef3ff 45%,#f8fbff);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-width:320px;height:100vh;overflow:hidden}#app{height:100vh}.app-shell{display:grid;grid-template-columns:360px 1fr;height:100vh;overflow:hidden}.panel{border-right:1px solid #dce3f1;padding:16px;background:#ffffffe0;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);overflow-y:auto;height:100vh}.panel h1{margin:0;font-size:1.5rem}.subtle{color:#5f6473;font-size:.9rem}.error-text{color:#b42318;font-size:.9rem;margin:8px 0 0}.block{margin-top:14px;border:1px solid #e2e8f7;border-radius:10px;padding:10px;background:#fff}.label{display:block;margin-bottom:8px;font-weight:700}.row{display:flex;gap:10px}input,select,textarea,button{width:100%;margin-top:6px;border:1px solid #cfd7ea;border-radius:8px;padding:8px 9px;font:inherit}button{cursor:pointer;background:#0f295f;color:#fff;border:1px solid #0f295f;font-weight:600}button:disabled{background:#c5ccd9;border-color:#c5ccd9;cursor:not-allowed}.thumb{width:100%;max-height:100px;object-fit:contain;margin-top:8px;background:#f5f7fc;border-radius:8px;border:1px solid #dce2f2}.signature-pad{width:100%;height:auto;border:2px dashed #a9b5d2;border-radius:8px;background:#fff;touch-action:none}.viewer{overflow:auto;padding:22px;height:100vh}.viewer.drag-over{outline:3px dashed #2066df;outline-offset:-12px;background:#2066df14}.empty-state{background:#fff;border:1px dashed #c5cee3;border-radius:12px;padding:30px;text-align:center}.page-section{margin-bottom:28px}.page-title{margin-bottom:8px;font-weight:700}.page-canvas{position:relative;width:fit-content;border:1px solid #c4cfeb;background:#fff;box-shadow:0 8px 26px #1a2c5129}.page-canvas>img{display:block}.overlay{position:absolute;top:0;left:0;cursor:move;border:1px dashed transparent;overflow:visible;background:#ffffff1a}.overlay.selected{border-color:#2066df}.overlay img{display:block;object-fit:contain}.resize-handle{position:absolute;width:12px;height:12px;border:1px solid #0f295f;background:#fff;border-radius:999px;z-index:3;padding:0}.resize-handle-nw{top:-6px;left:-6px;cursor:nwse-resize}.resize-handle-n{top:-6px;left:calc(50% - 6px);cursor:ns-resize}.resize-handle-ne{top:-6px;right:-6px;cursor:nesw-resize}.resize-handle-e{top:calc(50% - 6px);right:-6px;cursor:ew-resize}.resize-handle-se{bottom:-6px;right:-6px;cursor:nwse-resize}.resize-handle-s{bottom:-6px;left:calc(50% - 6px);cursor:ns-resize}.resize-handle-sw{bottom:-6px;left:-6px;cursor:nesw-resize}.resize-handle-w{top:calc(50% - 6px);left:-6px;cursor:ew-resize}.check-row{display:flex;align-items:center;gap:8px;margin-top:8px;font-size:.9rem}.check-row input[type=checkbox]{width:auto;margin:0}.toggle-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:6px}.toggle-row .check-row{margin-top:0}.overlay-editor{position:absolute;top:0;left:0;width:340px;min-height:220px;background:#fffffff5;border:1px solid #2066df;padding:6px;overflow:auto;z-index:5;box-shadow:0 8px 20px #192c523d}.overlay.editing{overflow:visible;z-index:6}.overlay-editor textarea,.overlay-editor input,.overlay-editor select,.overlay-editor button{margin-top:4px}@media(max-width:980px){.app-shell{grid-template-columns:1fr}.panel{border-right:0;border-bottom:1px solid #dce3f1;height:46vh}.viewer{height:54vh}}
