*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{background:#0f0f1a;color:#e0e0e0;height:100vh;overflow:hidden}#root{height:100vh;display:flex;flex-direction:column}button{cursor:pointer;border:none;outline:none;font-family:inherit}input,select,textarea{font-family:inherit}.app{display:flex;flex-direction:column;height:100vh;background:#111119}.header{display:flex;align-items:center;gap:0;padding:0;background:#1b1b2f;border-bottom:1px solid rgba(255,255,255,.06);flex-shrink:0;height:48px}.header-logo{font-size:15px;font-weight:800;padding:0 18px;color:#fff;letter-spacing:-.3px;white-space:nowrap;display:flex;align-items:center;gap:6px;height:100%;background:linear-gradient(135deg,#6c5ce7,#e94560);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.header-divider{width:1px;height:100%;background:rgba(255,255,255,.06)}.toolbar{display:flex;align-items:center;gap:2px;flex:1;padding:0 6px;height:100%}.tool-sep{width:1px;height:24px;background:rgba(255,255,255,.08);margin:0 4px;flex-shrink:0}.tool-btn{position:relative;display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:8px;background:transparent;color:#888;font-size:13px;transition:all .12s ease;flex-shrink:0}.tool-btn:hover{background:rgba(255,255,255,.08);color:#ddd}.tool-btn.active{background:#6c5ce7;color:#fff;box-shadow:0 2px 8px #6c5ce74d}.tool-btn:disabled{opacity:.25;pointer-events:none}.tool-btn svg{width:18px;height:18px}.tool-btn-wide{display:flex;align-items:center;gap:5px;padding:0 12px;height:32px;border-radius:7px;background:transparent;color:#999;font-size:12px;font-weight:500;transition:all .12s;white-space:nowrap}.tool-btn-wide:hover{background:rgba(255,255,255,.07);color:#ddd}.tool-btn-wide svg{width:15px;height:15px;flex-shrink:0}.tool-btn-wide.primary{background:#6c5ce7;color:#fff}.tool-btn-wide.primary:hover{background:#5a4bd6}.tool-btn[data-tip]:after{content:attr(data-tip);position:absolute;bottom:-28px;left:50%;transform:translate(-50%) scale(.9);transform-origin:top;background:#222;color:#ccc;font-size:11px;font-weight:500;padding:3px 8px;border-radius:5px;white-space:nowrap;pointer-events:none;opacity:0;transition:all .12s;z-index:100}.tool-btn[data-tip]:hover:after{opacity:1;transform:translate(-50%) scale(1)}.pick-group{display:flex;align-items:center;gap:6px;padding:0 8px;height:32px}.pick-group input[type=color]{width:22px;height:22px;border:2px solid rgba(255,255,255,.1);border-radius:50%;padding:0;cursor:pointer;background:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.pick-group input[type=color]::-webkit-color-swatch-wrapper{padding:0}.pick-group input[type=color]::-webkit-color-swatch{border:none;border-radius:50%}.pick-group input[type=range]{width:60px;accent-color:#6c5ce7;height:3px}.pick-group .pick-label{font-size:10px;color:#555;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.zoom-group{display:flex;align-items:center;gap:0;margin-left:auto;padding:0 8px}.zoom-group button{width:28px;height:28px;border-radius:6px;background:transparent;color:#888;font-size:16px;font-weight:700;display:flex;align-items:center;justify-content:center;transition:all .12s}.zoom-group button:hover{background:rgba(255,255,255,.08);color:#ddd}.zoom-group .zoom-val{font-size:11px;color:#666;font-weight:600;min-width:38px;text-align:center;cursor:pointer}.zoom-group .zoom-val:hover{color:#aaa}.main{display:flex;flex:1;overflow:hidden}.sidebar{width:180px;background:#16162a;border-right:1px solid rgba(255,255,255,.05);display:flex;flex-direction:column;flex-shrink:0}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-bottom:1px solid rgba(255,255,255,.05)}.sidebar-header h3{font-size:10px;font-weight:700;color:#555;text-transform:uppercase;letter-spacing:1px}.sidebar-header span{font-size:10px;color:#444;font-weight:600}.page-thumb-list{display:flex;flex-direction:column;gap:4px;padding:8px;overflow-y:auto;flex:1}.page-thumb-list::-webkit-scrollbar{width:4px}.page-thumb-list::-webkit-scrollbar-thumb{background:#333;border-radius:2px}.page-thumb{border-radius:6px;overflow:hidden;cursor:pointer;border:2px solid transparent;background:#111;transition:all .12s;position:relative}.page-thumb:hover{border-color:#6c5ce766}.page-thumb.selected{border-color:#6c5ce7;box-shadow:0 0 0 1px #6c5ce74d}.page-thumb img{width:100%;display:block}.page-thumb .thumb-label{position:absolute;bottom:0;left:0;right:0;text-align:center;font-size:9px;font-weight:700;color:#fff;background:rgba(0,0,0,.6);padding:2px 0}.thumb-loading{color:#333;font-size:10px;text-align:center;padding:10px;font-weight:500}.canvas-area{flex:1;overflow:auto;display:flex;flex-direction:column;align-items:center;padding:32px;gap:20px;background:#111119;position:relative}.canvas-area::-webkit-scrollbar{width:7px}.canvas-area::-webkit-scrollbar-track{background:transparent}.canvas-area::-webkit-scrollbar-thumb{background:#2a2a40;border-radius:4px}.page-container{position:relative;box-shadow:0 4px 24px #00000080,0 0 0 1px #ffffff08;border-radius:3px;overflow:hidden;background:#fff}.page-container canvas.pdf-render{display:block}.page-container canvas.draw-layer{position:absolute;top:0;left:0;cursor:crosshair;z-index:10}.page-container canvas.draw-layer.cursor-text{cursor:text}.page-container canvas.draw-layer.cursor-default{cursor:default}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;flex:1;width:100%}.drop-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;width:420px;max-width:90%;padding:48px 32px;border:2px dashed #2a2a40;border-radius:16px;background:rgba(108,92,231,.03);transition:all .2s;cursor:pointer}.drop-zone:hover,.drop-zone.drag-over{border-color:#6c5ce7;background:rgba(108,92,231,.08)}.drop-zone.drag-over{transform:scale(1.02)}.drop-zone svg{color:#444}.drop-zone h2{font-size:18px;font-weight:700;color:#666;text-align:center}.drop-zone p{font-size:13px;color:#444;text-align:center}.drop-zone .or{font-size:11px;color:#333;font-weight:600;text-transform:uppercase;letter-spacing:1px}.drop-zone .browse-btn{padding:10px 28px;background:#6c5ce7;color:#fff;border-radius:10px;font-size:14px;font-weight:600;transition:background .15s;border:none}.drop-zone .browse-btn:hover{background:#5a4bd6}.page-nav-float{position:sticky;bottom:16px;display:flex;align-items:center;gap:4px;padding:6px 10px;background:rgba(27,27,47,.95);border-radius:10px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.08);box-shadow:0 4px 16px #0006}.page-nav-float button{width:30px;height:28px;border-radius:6px;background:transparent;color:#888;font-size:14px;display:flex;align-items:center;justify-content:center;transition:all .12s}.page-nav-float button:hover{background:rgba(255,255,255,.08);color:#ddd}.page-nav-float button:disabled{opacity:.2;pointer-events:none}.page-nav-float .page-input{width:36px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);border-radius:5px;color:#ddd;font-size:12px;font-weight:600;text-align:center;padding:3px 0;outline:none}.page-nav-float .page-input:focus{border-color:#6c5ce7}.page-nav-float .page-of{font-size:11px;color:#555;font-weight:500;padding:0 2px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.7);display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{background:#1b1b2f;border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:28px;min-width:400px;max-width:90vw;max-height:80vh;overflow-y:auto;box-shadow:0 20px 60px #00000080}.modal h2{font-size:17px;font-weight:700;color:#eee;margin-bottom:6px}.modal .modal-desc{font-size:13px;color:#666;margin-bottom:16px}.modal .modal-actions{display:flex;gap:10px;margin-top:20px;justify-content:flex-end}.modal .modal-actions button{padding:8px 20px;border-radius:8px;font-size:13px;font-weight:600}.modal .btn-primary{background:#6c5ce7;color:#fff}.modal .btn-primary:hover{background:#5a4bd6}.modal .btn-primary:disabled{opacity:.4}.modal .btn-secondary{background:rgba(255,255,255,.06);color:#999}.modal .btn-secondary:hover{background:rgba(255,255,255,.1);color:#ccc}.file-list{display:flex;flex-direction:column;gap:6px;margin:12px 0}.file-item{display:flex;align-items:center;gap:10px;padding:8px 12px;background:rgba(255,255,255,.04);border-radius:8px;font-size:13px;color:#aaa}.file-item span{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-item button{width:24px;height:24px;border-radius:6px;background:rgba(233,69,96,.15);color:#e94560;font-size:12px;display:flex;align-items:center;justify-content:center;transition:background .12s}.file-item button:hover{background:#e94560;color:#fff}.split-inputs{display:flex;flex-direction:column;gap:10px;margin:12px 0}.split-inputs label{font-size:12px;color:#666;display:flex;flex-direction:column;gap:5px}.split-inputs input{padding:8px 10px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:8px;color:#ddd;font-size:14px}.split-inputs input:focus{outline:none;border-color:#6c5ce7}.status-bar{display:flex;align-items:center;gap:16px;padding:3px 16px;background:#1b1b2f;border-top:1px solid rgba(255,255,255,.04);font-size:10px;color:#444;flex-shrink:0}.text-input-popup{position:fixed;z-index:500;background:#1b1b2f;border:1px solid #6c5ce7;border-radius:10px;padding:12px;box-shadow:0 8px 32px #00000080;display:flex;flex-direction:column;gap:8px}.text-input-popup textarea{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:7px;color:#ddd;padding:8px;font-size:13px;resize:both;min-height:60px;min-width:200px}.text-input-popup textarea:focus{outline:none;border-color:#6c5ce7}.text-input-popup .popup-actions{display:flex;gap:6px;justify-content:flex-end}.text-input-popup .popup-actions button{padding:5px 14px;border-radius:6px;font-size:12px;font-weight:600}.text-input-popup .popup-actions .confirm-btn{background:#6c5ce7;color:#fff}.text-input-popup .popup-actions .cancel-btn{background:rgba(255,255,255,.06);color:#999}.toast{position:fixed;bottom:60px;left:50%;transform:translate(-50%);background:rgba(27,27,47,.95);color:#ccc;padding:10px 20px;border-radius:10px;font-size:13px;font-weight:500;z-index:2000;pointer-events:none;border:1px solid rgba(255,255,255,.08);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:toastIn .2s,toastOut .3s 1.7s forwards}@keyframes toastIn{0%{opacity:0;transform:translate(-50%,8px)}to{opacity:1;transform:translate(-50%)}}@keyframes toastOut{to{opacity:0}}.text-edit-layer{z-index:20}.text-hit-area{box-sizing:border-box;transition:all .1s;border-radius:2px}.text-hit-area:hover{background:rgba(108,92,231,.12);box-shadow:0 0 0 1px #6c5ce74d}.text-hit-area.text-edited{background:rgba(233,69,96,.06);box-shadow:0 0 0 1px #e945604d}.text-hit-area.text-ocr:hover{background:rgba(46,204,113,.12);box-shadow:0 0 0 1px #2ecc7166}.text-edit-input{min-height:1em;box-sizing:border-box}.ocr-loading-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.4);border-radius:3px;pointer-events:all;z-index:30}.ocr-loading-box{display:flex;flex-direction:column;align-items:center;gap:10px;background:rgba(27,27,47,.95);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:24px 32px;color:#ccc;font-size:14px;font-weight:500;box-shadow:0 8px 32px #0006}.ocr-loading-box .ocr-sub{font-size:11px;color:#666}.ocr-spinner{width:28px;height:28px;border:3px solid rgba(108,92,231,.2);border-top-color:#6c5ce7;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.file-btn{display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;border-radius:7px;background:rgba(255,255,255,.05);color:#999;font-size:12px;font-weight:500;margin-bottom:4px;transition:all .12s}.file-btn:hover{background:#6c5ce7;color:#fff}
