*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
    --bg:#07070d;--bg2:#0d0d16;--card:rgba(255,255,255,0.025);--card2:rgba(255,255,255,0.04);
    --accent:#6c5ce7;--accent-g:rgba(108,92,231,0.3);--accent-l:#a29bfe;
    --txt:#f0f0f5;--txt2:#6e6e85;--txt3:#3e3e52;
    --border:rgba(255,255,255,0.05);--border2:rgba(255,255,255,0.1);
    --teal:#00cec9;--red:#ff6b6b;
}

body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--txt);min-height:100vh;min-height:100dvh;overflow-x:hidden}
body::-webkit-scrollbar{width:6px}
body::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}

.glow{position:fixed;inset:0;pointer-events:none;z-index:0;
    background:radial-gradient(ellipse 70% 50% at 50% -10%,rgba(108,92,231,0.1),transparent)}

.wrap{max-width:900px;margin:0 auto;padding:clamp(24px,5vw,48px) clamp(16px,4vw,24px);position:relative;z-index:1}

/* Brand */
.brand{display:block;text-align:center;margin-bottom:clamp(24px,4vw,40px);font-size:12px;font-weight:600;letter-spacing:5px;text-transform:uppercase;color:var(--txt3);text-decoration:none}
.brand b{color:var(--accent-l);font-weight:700}

/* Footer */
footer{text-align:center;padding:clamp(24px,5vw,40px) 0 16px;color:var(--txt3);font-size:10px;letter-spacing:.5px}
footer b{color:var(--txt2)}
footer span{display:inline-block;margin-top:4px;font-size:9px;color:var(--txt3);opacity:.6}

/* Notification */
.notif{position:fixed;top:20px;right:20px;padding:12px 18px;background:rgba(13,13,22,.95);border:1px solid var(--accent);border-radius:10px;color:var(--txt);font-size:12px;font-weight:500;z-index:100;transform:translateX(120%);transition:transform .4s cubic-bezier(.16,1,.3,1);backdrop-filter:blur(20px);box-shadow:0 8px 28px rgba(0,0,0,.5)}
.notif.on{transform:translateX(0)}
.notif svg{display:inline-block;width:13px;height:13px;margin-right:5px;vertical-align:-2px;color:var(--teal)}

/* ===== LANDING PAGE ===== */
.landing-header{text-align:center;margin-bottom:clamp(28px,5vw,44px)}
.landing-header h1{font-size:clamp(20px,4vw,28px);font-weight:700;margin-bottom:8px;color:var(--txt)}
.landing-header p{font-size:clamp(12px,2.5vw,14px);color:var(--txt2);max-width:500px;margin:0 auto;line-height:1.6}

.tool-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;margin-bottom:24px}

.tool-card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:clamp(18px,3vw,24px);cursor:pointer;transition:all .3s;text-decoration:none;display:flex;flex-direction:column;gap:10px;backdrop-filter:blur(40px)}
.tool-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 8px 28px rgba(108,92,231,.08)}
.tool-card-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:rgba(108,92,231,.1);border-radius:10px;color:var(--accent-l)}
.tool-card-icon svg{width:20px;height:20px}
.tool-card-name{font-size:14px;font-weight:600;color:var(--txt)}
.tool-card-desc{font-size:11px;color:var(--txt2);line-height:1.5}

/* Landing SEO */
.landing-seo{margin-top:clamp(32px,6vw,56px);padding-top:clamp(24px,4vw,40px);border-top:1px solid var(--border)}
.landing-seo h2{font-size:clamp(16px,3vw,20px);font-weight:700;text-align:center;margin-bottom:clamp(16px,3vw,28px);color:var(--txt)}
.seo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}
.seo-item{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:clamp(14px,2.5vw,20px)}
.seo-item strong{font-size:13px;font-weight:600;color:var(--accent-l);display:block;margin-bottom:6px}
.seo-item p{font-size:11px;color:var(--txt2);line-height:1.6;margin:0}

/* ===== TOOL PAGE ===== */
.tool-header{display:flex;align-items:center;gap:12px;margin-bottom:clamp(20px,4vw,32px)}
.back-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--card);border:1px solid var(--border);border-radius:10px;color:var(--txt2);cursor:pointer;transition:all .2s;text-decoration:none;flex-shrink:0}
.back-btn:hover{border-color:var(--accent);color:var(--accent-l)}
.back-btn svg{width:18px;height:18px}
.tool-title{font-size:clamp(18px,4vw,24px);font-weight:700;color:var(--txt)}
.tool-desc{font-size:12px;color:var(--txt2);margin-top:2px}

/* ===== UPLOAD ZONE ===== */
.upload-zone{background:var(--card);border:2px dashed var(--border2);border-radius:18px;padding:clamp(32px,6vw,56px) clamp(20px,4vw,32px);text-align:center;cursor:pointer;transition:all .3s;backdrop-filter:blur(40px);margin-bottom:20px}
.upload-zone:hover,.upload-zone.drag{border-color:var(--accent);background:rgba(108,92,231,.03)}
.upload-zone.drag{transform:scale(1.01)}
.upload-icon{width:48px;height:48px;margin:0 auto 16px;color:var(--txt3);opacity:.5}
.upload-icon svg{width:100%;height:100%}
.upload-text{font-size:14px;font-weight:500;color:var(--txt2);margin-bottom:6px}
.upload-hint{font-size:11px;color:var(--txt3)}
.upload-zone input[type="file"]{display:none}

.file-info{display:flex;align-items:center;gap:12px;background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:12px 16px;margin-bottom:20px}
.file-info-icon{width:32px;height:32px;flex-shrink:0;color:var(--accent-l)}
.file-info-icon svg{width:100%;height:100%}
.file-info-details{flex:1;min-width:0}
.file-info-name{font-size:13px;font-weight:600;color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.file-info-meta{font-size:11px;color:var(--txt3);font-family:'JetBrains Mono',monospace;margin-top:2px}
.file-info-remove{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border);border-radius:7px;color:var(--txt3);cursor:pointer;transition:all .2s;flex-shrink:0}
.file-info-remove:hover{border-color:var(--red);color:var(--red)}
.file-info-remove svg{width:14px;height:14px}

/* ===== THUMBNAIL GRID ===== */
.thumb-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:12px;margin-bottom:20px}

.thumb-item{position:relative;background:var(--bg2);border:2px solid var(--border);border-radius:10px;overflow:hidden;cursor:pointer;transition:all .2s;aspect-ratio:210/297}
.thumb-item:hover{border-color:var(--border2)}
.thumb-item.selected{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-g)}
.thumb-item canvas{width:100%;height:100%;object-fit:contain;display:block}
.thumb-num{position:absolute;bottom:0;left:0;right:0;text-align:center;font-size:10px;font-weight:600;color:var(--txt2);background:rgba(7,7,13,.85);padding:4px 0;font-family:'JetBrains Mono',monospace}
.thumb-check{position:absolute;top:6px;right:6px;width:22px;height:22px;border-radius:50%;background:rgba(7,7,13,.7);border:2px solid var(--border2);display:flex;align-items:center;justify-content:center;transition:all .2s}
.thumb-item.selected .thumb-check{background:var(--accent);border-color:var(--accent)}
.thumb-check svg{width:12px;height:12px;color:#fff;opacity:0}
.thumb-item.selected .thumb-check svg{opacity:1}

/* Selection toolbar */
.sel-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:8px 14px;margin-bottom:16px;flex-wrap:wrap}
.sel-bar-left{display:flex;align-items:center;gap:8px}
.sel-count{font-size:12px;font-weight:500;color:var(--txt2);font-family:'JetBrains Mono',monospace}
.sel-btn{padding:6px 14px;background:rgba(255,255,255,0.04);border:1px solid var(--border2);border-radius:7px;color:var(--txt);font-family:'Inter',sans-serif;font-size:11px;font-weight:600;cursor:pointer;transition:all .2s;text-transform:uppercase;letter-spacing:1px}
.sel-btn:hover{border-color:var(--accent);color:var(--accent-l);background:var(--accent-g)}

/* ===== ACTION BAR ===== */
.action-bar{position:sticky;bottom:16px;z-index:10;display:flex;gap:10px;justify-content:center;flex-wrap:wrap;background:linear-gradient(transparent,var(--bg) 30%);padding:20px 0 4px;margin-top:8px}
.action-btn{padding:12px clamp(24px,5vw,36px);background:var(--accent);border:none;border-radius:12px;color:#fff;font-family:'Inter',sans-serif;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s;letter-spacing:.5px;display:flex;align-items:center;gap:8px;backdrop-filter:blur(20px);box-shadow:0 8px 28px rgba(108,92,231,.3)}
.action-btn:hover{transform:translateY(-2px);background:#7c6ef0;box-shadow:0 12px 36px rgba(108,92,231,.4)}
.action-btn:active{transform:translateY(0)}
.action-btn:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}
.action-btn svg{width:18px;height:18px}

.action-btn.secondary{background:transparent;border:1px solid var(--border2);color:var(--txt2);box-shadow:none}
.action-btn.secondary:hover{border-color:var(--accent);color:var(--accent-l);box-shadow:none}

/* ===== TOOL OPTIONS ===== */
.options-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:clamp(16px,3vw,22px);margin-bottom:20px;backdrop-filter:blur(40px)}
.options-card:hover{border-color:var(--border2)}
.opt-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:2px;color:var(--txt3);margin-bottom:10px;display:block}
.opt-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}

.opt-select{height:38px;background:var(--bg2);border:1px solid var(--border);border-radius:9px;color:var(--txt);font-family:'Inter',sans-serif;font-size:12px;padding:0 12px;cursor:pointer;appearance:none;-webkit-appearance:none;transition:all .3s;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%233e3e52' viewBox='0 0 16 16'%3E%3Cpath d='M4 6l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:28px}
.opt-select option{background:#0d0d16;color:var(--txt)}
.opt-select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-g)}

.opt-input{height:38px;background:var(--bg2);border:1px solid var(--border);border-radius:9px;color:var(--txt);font-family:'Inter',sans-serif;font-size:12px;padding:0 12px;transition:all .3s}
.opt-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-g)}

.opt-slider{width:100%;height:3px;-webkit-appearance:none;appearance:none;background:rgba(255,255,255,0.05);border-radius:2px;outline:none;cursor:pointer}
.opt-slider::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;background:var(--accent);border-radius:50%;cursor:pointer;box-shadow:0 0 10px var(--accent-g)}
.opt-slider::-moz-range-thumb{width:14px;height:14px;background:var(--accent);border-radius:50%;cursor:pointer;border:none}

.tab-bar{display:flex;gap:4px;margin-bottom:16px}
.tab{flex:1;padding:8px;background:transparent;border:1px solid var(--border);border-radius:8px;color:var(--txt3);font-family:'Inter',sans-serif;font-size:10px;font-weight:600;cursor:pointer;text-transform:uppercase;letter-spacing:1.5px;transition:all .2s;text-align:center}
.tab.on{background:rgba(108,92,231,.1);border-color:var(--accent);color:var(--accent-l)}

/* ===== PROGRESS ===== */
.progress-wrap{margin:16px 0}
.progress-bar{width:100%;height:4px;background:rgba(255,255,255,.05);border-radius:2px;overflow:hidden}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--teal));border-radius:2px;transition:width .3s ease;width:0%}
.progress-text{font-size:11px;font-family:'JetBrains Mono',monospace;color:var(--txt3);margin-top:6px;text-align:center}

/* ===== METADATA TABLE ===== */
.meta-table{width:100%;border-collapse:collapse;margin-bottom:16px}
.meta-table td{padding:10px 12px;border-bottom:1px solid var(--border);font-size:12px;vertical-align:top}
.meta-table td:first-child{font-weight:600;color:var(--txt3);text-transform:uppercase;letter-spacing:1px;font-size:10px;width:120px;white-space:nowrap}
.meta-table td:last-child{color:var(--txt);word-break:break-word;font-family:'JetBrains Mono',monospace;font-size:11px}

/* ===== MERGE FILE LIST ===== */
.merge-list{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}
.merge-item{display:flex;align-items:center;gap:12px;background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:10px 14px;transition:all .2s;cursor:grab}
.merge-item:active{cursor:grabbing}
.merge-item.drag-over{border-color:var(--accent);background:rgba(108,92,231,.03)}
.merge-handle{color:var(--txt3);flex-shrink:0;cursor:grab}
.merge-handle svg{width:16px;height:16px}
.merge-info{flex:1;min-width:0}
.merge-name{font-size:12px;font-weight:600;color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.merge-pages{font-size:10px;color:var(--txt3);font-family:'JetBrains Mono',monospace;margin-top:2px}
.merge-remove{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border);border-radius:7px;color:var(--txt3);cursor:pointer;transition:all .2s;flex-shrink:0}
.merge-remove:hover{border-color:var(--red);color:var(--red)}
.merge-remove svg{width:14px;height:14px}

/* ===== CROP ===== */
.crop-container{position:relative;margin:0 auto 20px;display:inline-block;max-width:100%}
.crop-container canvas{display:block;max-width:100%;border-radius:8px}
.crop-overlay{position:absolute;top:0;left:0;right:0;bottom:0;cursor:crosshair}
.crop-rect{position:absolute;border:2px solid var(--accent);background:rgba(108,92,231,.1);cursor:move}
.crop-handle{position:absolute;width:10px;height:10px;background:var(--accent);border-radius:2px}

/* ===== ROTATE INDICATORS ===== */
.thumb-rotate-badge{position:absolute;top:6px;left:6px;padding:2px 6px;background:rgba(108,92,231,.85);border-radius:4px;font-size:9px;font-weight:700;color:#fff;font-family:'JetBrains Mono',monospace;display:none}
.thumb-item[data-rotation] .thumb-rotate-badge{display:block}

/* ===== IMAGE UPLOAD GRID ===== */
.img-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:12px;margin-bottom:20px}
.img-item{position:relative;background:var(--bg2);border:2px solid var(--border);border-radius:10px;overflow:hidden;cursor:grab;transition:all .2s;aspect-ratio:210/297}
.img-item:hover{border-color:var(--border2)}
.img-item.drag-over{border-color:var(--accent)}
.img-item img{width:100%;height:100%;object-fit:cover;display:block}
.img-item-num{position:absolute;bottom:0;left:0;right:0;text-align:center;font-size:10px;font-weight:600;color:var(--txt2);background:rgba(7,7,13,.85);padding:4px 0;font-family:'JetBrains Mono',monospace}
.img-item-remove{position:absolute;top:4px;right:4px;width:22px;height:22px;border-radius:50%;background:rgba(255,107,107,.85);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}
.img-item:hover .img-item-remove{opacity:1}
.img-item-remove svg{width:12px;height:12px}

/* ===== RESPONSIVE ===== */
@media(max-width:768px){
    .tool-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}
    .thumb-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}
}
@media(max-width:480px){
    .tool-grid{grid-template-columns:1fr 1fr}
    .thumb-grid{grid-template-columns:repeat(3,1fr)}
    .sel-bar{flex-direction:column;text-align:center}
    .action-bar{flex-direction:column;position:relative;bottom:auto}
    .action-btn{width:100%;justify-content:center}
    .opt-row:not(.opt-row-inline){flex-direction:column}
    .opt-select,.opt-input{width:100%}
    .compare-uploads{flex-direction:column}
}

/* ===== EDITOR LAYOUT ===== */
.editor-layout{position:fixed;inset:0;z-index:50;display:flex;background:var(--bg)}
.editor-sidebar{width:140px;background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0}
.sidebar-header{padding:10px 12px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;color:var(--txt3);border-bottom:1px solid var(--border)}
.sidebar-pages{flex:1;overflow-y:auto;padding:8px;display:flex;flex-direction:column;gap:8px}
.sidebar-pages::-webkit-scrollbar{width:4px}
.sidebar-pages::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}
.sidebar-thumb{position:relative;border:2px solid var(--border);border-radius:6px;cursor:pointer;overflow:hidden;transition:all .2s;flex-shrink:0}
.sidebar-thumb:hover{border-color:var(--border2)}
.sidebar-thumb.active{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-g)}
.sidebar-thumb canvas{width:100%;display:block}
.sidebar-thumb-num{position:absolute;bottom:0;left:0;right:0;text-align:center;font-size:9px;font-weight:600;color:var(--txt2);background:rgba(7,7,13,.85);padding:2px 0;font-family:'JetBrains Mono',monospace}
.editor-main{flex:1;display:flex;flex-direction:column;min-width:0}
.editor-topbar{display:flex;align-items:center;justify-content:space-between;padding:6px 12px;border-bottom:1px solid var(--border);background:var(--bg2);flex-shrink:0;gap:8px}
.editor-topbar-left{display:flex;align-items:center;gap:4px;flex-wrap:wrap}
.editor-topbar-right{display:flex;align-items:center;gap:8px}
.editor-filename{font-size:11px;color:var(--txt2);font-family:'JetBrains Mono',monospace;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.editor-save-btn{background:var(--accent)!important;color:#fff!important;border-color:var(--accent)!important}
.editor-save-btn:hover{background:#7c6ef0!important}
.editor-close-btn{color:var(--txt3)!important;font-size:16px!important;padding:4px 8px!important}
.editor-close-btn:hover{color:var(--red)!important;border-color:var(--red)!important}
.editor-canvas-wrap{flex:1;overflow:auto;display:flex;justify-content:center;align-items:flex-start;padding:24px;background:#111120;position:relative}
.editor-status{text-align:center;font-size:11px;color:var(--accent-l);padding:4px 12px;border-top:1px solid var(--border);background:var(--bg2);flex-shrink:0}
.editor-bottombar{display:flex;align-items:center;justify-content:center;gap:10px;padding:6px 12px;border-top:1px solid var(--border);background:var(--bg2);flex-shrink:0}
.editor-pagenum{font-size:11px;font-family:'JetBrains Mono',monospace;color:var(--txt2);min-width:50px;text-align:center}
.editor-nav-btn{padding:4px 10px!important;font-size:10px!important}
.editor-float-panel{position:absolute;bottom:20px;right:20px;z-index:20;background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:16px;backdrop-filter:blur(20px);box-shadow:0 8px 32px rgba(0,0,0,.4);max-width:300px}
.highlight-placement{border:none;transition:outline .15s;pointer-events:auto}
.highlight-placement:hover{outline:1.5px dashed rgba(255,235,59,0.6)}
.highlight-drag-preview{position:absolute;background:rgba(255,235,59,0.3);border:1.5px dashed rgba(255,200,0,0.6);pointer-events:none;z-index:8;display:none}
@media(max-width:768px){.editor-sidebar{width:100px}.editor-topbar-left .mode-btn{font-size:9px!important;padding:4px 8px!important}}
@media(max-width:480px){.editor-sidebar{display:none}}

.sig-pad{width:100%;height:100px;background:#fff;border:1px solid var(--border);border-radius:8px;cursor:crosshair;touch-action:none}
.sign-preview{position:relative;display:inline-block;cursor:default}
.sign-preview canvas{display:block;border-radius:4px;box-shadow:0 4px 24px rgba(0,0,0,.4)}
.sign-preview.placing{cursor:crosshair}
.sign-overlay{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:3}
.text-layer{position:absolute;top:0;left:0;width:100%;height:100%;z-index:2}
.mode-edit .text-layer{z-index:10}
.mode-edit .sign-overlay,.mode-edit .sign-overlay *{pointer-events:none!important}
.text-item{position:absolute;background:transparent;color:transparent;white-space:nowrap;line-height:1.1;cursor:default;border:none;padding:0 1px;box-sizing:border-box;transform-origin:left top;overflow:visible}
.mode-edit .text-item:hover{background:rgba(108,92,231,0.08);cursor:text;z-index:5}
.mode-erase .text-item:hover{background:rgba(255,107,107,0.12);cursor:pointer;z-index:5}
.mode-erase{cursor:crosshair}
.whiteout-preview{position:absolute;background:rgba(255,255,255,0.4);border:1.5px dashed rgba(255,107,107,0.6);pointer-events:none;z-index:8;display:none}
.mode-addtext{cursor:text}
.mode-select .text-item.edited{cursor:grab;outline:1px dashed var(--teal)}
.text-item.edited{background:#fff;color:#000;z-index:3}
.text-item.erased{pointer-events:none;background:transparent;color:transparent}
.para-block{position:absolute;background:transparent;color:transparent;cursor:default;border:none;box-sizing:border-box;overflow:hidden;transition:background .15s}
.mode-edit .para-block:hover{background:rgba(108,92,231,0.08);cursor:text}
.mode-erase .para-block:hover{background:rgba(255,107,107,0.12);cursor:pointer}
.para-block.edited{background:transparent;color:#000;z-index:3;overflow:visible;white-space:pre-wrap}
.para-block.erased{pointer-events:none;background:transparent;color:transparent}
.mode-select .para-block.edited{cursor:grab;outline:1px dashed var(--teal)}
.para-edit{position:absolute;z-index:10;background:transparent;color:#000;border:1.5px dashed rgba(108,92,231,0.4);border-radius:0;outline:none;box-sizing:border-box;word-wrap:break-word;min-width:50px;font-family:serif;cursor:text}
.para-edit:focus{border-color:rgba(108,92,231,0.6)}
.image-overlay{pointer-events:none;transition:border .15s,box-shadow .15s}
.image-overlay-active{pointer-events:auto;border:1.5px dashed rgba(108,92,231,0.25)!important}
.image-overlay-active:hover{border-color:rgba(108,92,231,0.6)!important;box-shadow:0 0 0 2px rgba(108,92,231,0.15)}
.image-overlay-active .sign-remove{display:none}
.image-overlay-active:hover .sign-remove{display:flex}
.text-edit-input{position:absolute;z-index:10;background:#fff;border:1.5px solid var(--accent);border-radius:2px;color:#000;font-family:inherit;padding:1px 3px;outline:none;box-sizing:border-box}
.mode-btn.active{background:var(--accent) !important;color:#fff !important;border-color:var(--accent) !important}
.edit-toolbar .opt-row{justify-content:center}
.sign-placement{position:absolute;pointer-events:auto;cursor:grab;user-select:none}
.sign-placement.dragging{cursor:grabbing;opacity:0.8}
.sign-text{color:#1a1a2e;font-size:14px;font-family:'Inter',sans-serif;white-space:nowrap}
.sign-remove{position:absolute;top:-10px;right:-10px;background:var(--red);color:#fff;border:none;border-radius:50%;width:22px;height:22px;cursor:pointer;font-size:14px;line-height:22px;padding:0;display:block;opacity:0;transition:opacity .2s}
.sign-placement:hover .sign-remove{opacity:1}
.resize-handle{position:absolute;width:10px;height:10px;background:var(--accent);border:1px solid rgba(255,255,255,.8);border-radius:2px;z-index:10;pointer-events:auto;box-sizing:border-box}
.resize-nw{top:-5px;left:-5px;cursor:nw-resize}
.resize-ne{top:-5px;right:-5px;cursor:ne-resize}
.resize-sw{bottom:-5px;left:-5px;cursor:sw-resize}
.resize-se{bottom:-5px;right:-5px;cursor:se-resize}
.sign-placement .resize-handle{opacity:0.6;transition:opacity .15s}
.sign-placement:hover .resize-handle{opacity:1}
.field-resize-handle{opacity:0;transition:opacity .15s}
.form-field-input:hover~.field-resize-handle,.field-resize-handle:hover{opacity:1}
.form-field-drag-handle{cursor:grab;background:rgba(108,92,231,0.15);border-left:2px solid var(--accent);z-index:11;transition:background .15s;box-sizing:border-box}
.form-field-drag-handle:hover{background:rgba(108,92,231,0.35)}
.form-field-drag-handle:active{cursor:grabbing}
.form-field-remove{width:16px;height:16px;border-radius:50%;background:var(--red);color:#fff;border:none;font-size:11px;line-height:16px;cursor:pointer;opacity:0;transition:opacity .15s;z-index:12;padding:0;text-align:center}
.form-field-input:hover~.form-field-remove,.form-field-remove:hover{opacity:1}
.form-field-manual{border:1.5px dashed rgba(37,99,235,0.4)!important;border-bottom:1.5px dashed rgba(37,99,235,0.4)!important}
.form-field-draw-preview{position:absolute;background:rgba(37,99,235,0.1);border:1.5px dashed rgba(37,99,235,0.5);pointer-events:none;z-index:8;display:none}
.highlight-drag-preview{position:absolute;background:rgba(255,235,59,0.3);border:1.5px dashed rgba(255,235,59,0.7);pointer-events:none;z-index:8;display:none}
.highlight-colors{display:flex;gap:6px;align-items:center;justify-content:center;padding:6px 0}
.hl-swatch{width:22px;height:22px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:border-color .15s,transform .15s}
.hl-swatch:hover{transform:scale(1.15)}
.hl-swatch.active{border-color:var(--txt);transform:scale(1.15)}
.undo-redo-bar{display:flex;gap:6px;align-items:center;margin-right:10px}
.undo-redo-bar button{background:rgba(108,92,231,0.18);border:1px solid rgba(108,92,231,0.4);border-radius:8px;color:var(--accent-l);cursor:pointer;display:flex;align-items:center;gap:4px;padding:5px 10px;font-size:11px;font-weight:600;font-family:inherit;letter-spacing:.3px;transition:all .2s}
.undo-redo-bar button:hover:not(:disabled){background:rgba(108,92,231,0.35);border-color:var(--accent);color:#fff}
.undo-redo-bar button:disabled{opacity:0.3;cursor:default;background:var(--card2);border-color:var(--border);color:var(--txt3)}
.undo-redo-bar button svg{width:14px;height:14px;flex-shrink:0}
.sign-placement.whiteout-placement{border:none;transition:outline .15s}
.sign-placement.whiteout-placement:hover{outline:1.5px dashed rgba(0,0,0,0.25)}
.sign-status{text-align:center;font-size:12px;color:var(--accent-l);min-height:20px;margin:8px 0}
.form-fields-grid{display:flex;flex-direction:column;gap:10px;max-height:400px;overflow-y:auto;padding:4px 0}
.form-field-row{display:flex;flex-direction:column;gap:4px}
.form-field-label{font-size:11px;color:var(--txt2);font-weight:500;text-transform:uppercase;letter-spacing:0.5px}

.ocr-output{width:100%;min-height:200px;max-height:400px;background:var(--card2);border:1px solid var(--border);border-radius:8px;color:var(--txt);font-family:'JetBrains Mono',monospace;font-size:12px;padding:12px;resize:vertical;line-height:1.6}

.compare-uploads{display:flex;gap:12px;margin-bottom:8px}
.compare-upload-box{flex:1}
.upload-zone-sm{padding:20px 12px;min-height:auto}
.upload-zone-sm .upload-icon{width:28px;height:28px;margin-bottom:6px}
.upload-zone-sm .upload-text{font-size:12px}
.diff-wrap{margin-top:8px}
.diff-page{}
.diff-header{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--txt3);margin-bottom:6px;text-transform:uppercase;letter-spacing:1px}
.diff-content{background:var(--card2);border:1px solid var(--border);border-radius:8px;padding:14px;font-size:13px;line-height:1.8;color:var(--txt);word-wrap:break-word;max-height:500px;overflow-y:auto}
.diff-add{background:rgba(46,213,115,0.2);color:#2ed573;border-radius:2px}
.diff-del{background:rgba(255,71,87,0.2);color:#ff4757;text-decoration:line-through;border-radius:2px}
