*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f5f5;color:#333}#root{min-height:100vh}h1,h2,h3,h4,h5,h6{margin:0;font-weight:600}p{margin:0}button{font-family:inherit}.btn-primary,.btn-secondary{padding:14px 24px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s}@media(max-width:768px){body{font-size:14px}}html,body{overflow-x:hidden;position:relative}.bottom-nav{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:space-around;background:#fff;border-top:1px solid #e0e0e0;padding:8px 0;box-shadow:0 -2px 10px #0000001a;z-index:1000}.nav-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 12px;background:none;border:none;cursor:pointer;color:#666;transition:all .3s ease;flex:1;max-width:100px}.nav-item:hover{background:#f5f5f5;border-radius:8px}.nav-item.active{color:#2196f3}.nav-icon{font-size:24px}.nav-label{font-size:12px;font-weight:500}@media(max-width:480px){.nav-label{font-size:10px}.nav-icon{font-size:20px}.nav-item{padding:6px 8px}}.page-manager{background:#fff;border-radius:12px;padding:20px;margin-bottom:20px;box-shadow:0 2px 8px #0000001a}.page-manager-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.page-manager-header h3{font-size:18px;color:#333;margin:0}.btn-add-page{padding:10px 20px;background:#2196f3;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:background .3s}.btn-add-page:hover{background:#1976d2}.pages-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:16px;margin-bottom:16px}.page-thumbnail{position:relative;background:#f9f9f9;border:2px solid #e0e0e0;border-radius:12px;padding:8px;cursor:move;transition:all .3s}.page-thumbnail:hover{border-color:#2196f3;transform:translateY(-4px);box-shadow:0 4px 12px #2196f333}.page-thumbnail.dragging{opacity:.5;transform:scale(.95)}.page-number{position:absolute;top:12px;left:12px;background:#000000b3;color:#fff;font-size:12px;font-weight:600;padding:4px 8px;border-radius:4px;z-index:2}.thumbnail-image{width:100%;height:180px;object-fit:cover;border-radius:8px;display:block;margin-bottom:8px}.page-controls{display:flex;gap:4px;justify-content:center}.btn-icon{padding:6px 10px;background:#f5f5f5;border:1px solid #e0e0e0;border-radius:6px;font-size:14px;cursor:pointer;transition:all .2s;flex:1}.btn-icon:hover:not(:disabled){background:#e0e0e0;border-color:#ccc}.btn-icon:disabled{opacity:.3;cursor:not-allowed}.btn-icon.btn-delete{background:#ffebee;border-color:#ffcdd2}.btn-icon.btn-delete:hover{background:#ef5350;border-color:#e53935}.drag-handle{position:absolute;top:12px;right:12px;font-size:20px;color:#0000004d;cursor:move;-webkit-user-select:none;user-select:none;letter-spacing:-4px}.page-manager-hint{text-align:center;font-size:13px;color:#999;margin-top:12px}@media(max-width:768px){.pages-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px}.thumbnail-image{height:150px}.page-manager-header{flex-direction:column;gap:12px;align-items:stretch}.btn-add-page{width:100%}}@media(max-width:480px){.pages-grid{grid-template-columns:repeat(2,1fr)}}.image-editor{position:fixed;inset:0;background:#000000f2;z-index:3000;display:flex;flex-direction:column;overflow:hidden}.editor-header{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;background:#1a1a1a;border-bottom:1px solid #333;gap:16px}.editor-header h3{color:#fff;font-size:18px;margin:0;flex:1}.zoom-controls{display:flex;align-items:center;gap:8px;background:#2a2a2a;padding:6px 12px;border-radius:8px;border:1px solid #444}.zoom-btn{background:#3a3a3a;border:1px solid #555;color:#fff;padding:6px 10px;border-radius:4px;font-size:13px;cursor:pointer;transition:all .2s;min-width:32px}.zoom-btn:hover{background:#4a4a4a;border-color:#2196f3}.zoom-btn.active{background:#2196f3;border-color:#2196f3}.zoom-level{color:#2196f3;font-size:13px;font-weight:600;min-width:45px;text-align:center}.btn-close{background:transparent;border:none;color:#fff;font-size:24px;cursor:pointer;padding:4px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s}.btn-close:hover{background:#ffffff1a}.editor-toolbar{display:flex;gap:8px;padding:12px 24px;background:#2a2a2a;border-bottom:1px solid #333;overflow-x:auto}.tool-btn{display:flex;align-items:center;gap:6px;padding:10px 16px;background:#3a3a3a;color:#fff;border:1px solid #444;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.tool-btn:hover{background:#4a4a4a;border-color:#2196f3}.tool-btn.active{background:#2196f3;border-color:#2196f3;color:#fff}.smart-crop-btn{background:#4caf50;border-color:#4caf50;animation:pulse 2s infinite}.smart-crop-btn:hover{background:#45a049;border-color:#45a049}@keyframes pulse{0%,to{box-shadow:0 0 #4caf50b3}50%{box-shadow:0 0 0 6px #4caf5000}}.brush-size-panel{display:flex;align-items:center;gap:16px;padding:12px 24px;background:#1a1a1a;border-bottom:1px solid #333}.brush-size-panel label{color:#ccc;font-size:14px;font-weight:500;min-width:130px}.brush-slider{flex:1;max-width:300px;height:6px;background:#3a3a3a;border-radius:3px;outline:none;-webkit-appearance:none}.brush-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;background:#2196f3;border-radius:50%;cursor:pointer;transition:all .2s}.brush-slider::-webkit-slider-thumb:hover{background:#1976d2;transform:scale(1.2)}.brush-slider::-moz-range-thumb{width:18px;height:18px;background:#2196f3;border-radius:50%;cursor:pointer;border:none;transition:all .2s}.brush-slider::-moz-range-thumb:hover{background:#1976d2;transform:scale(1.2)}.crop-mode-panel{display:flex;gap:12px;padding:12px 24px;background:#1a1a1a;border-bottom:1px solid #333;overflow-x:auto;align-items:center}.panel-label{color:#999;font-size:13px;font-weight:600;white-space:nowrap}.mode-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 14px;background:#2a2a2a;border:2px solid #3a3a3a;border-radius:8px;cursor:pointer;transition:all .2s;min-width:70px}.mode-btn:hover{background:#3a3a3a;border-color:#2196f3}.mode-btn.active{background:#2196f3;border-color:#2196f3}.mode-icon{font-size:20px}.mode-name{font-size:11px;color:#ccc;font-weight:500}.mode-btn.active .mode-name{color:#fff}.btn-reset-polygon{padding:8px 16px;background:#f44336;color:#fff;border:none;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;transition:background .2s}.btn-reset-polygon:hover{background:#d32f2f}.filters-panel{display:flex;gap:12px;padding:16px 24px;background:#1a1a1a;border-bottom:1px solid #333;overflow-x:auto}.filter-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 16px;background:#2a2a2a;border:2px solid #3a3a3a;border-radius:8px;cursor:pointer;transition:all .2s;min-width:80px}.filter-btn:hover{background:#3a3a3a;border-color:#2196f3}.filter-btn.active{background:#2196f3;border-color:#2196f3}.filter-icon{font-size:24px}.filter-name{font-size:12px;color:#ccc;font-weight:500}.filter-btn.active .filter-name{color:#fff}.signature-panel{background:#1a1a1a;padding:20px 24px;border-bottom:1px solid #333}.signature-panel h4{color:#fff;font-size:14px;margin:0 0 12px}.signature-canvas{display:block;width:100%;max-width:400px;height:150px;background:#fff;border-radius:8px;cursor:crosshair;margin-bottom:12px}.signature-controls{display:flex;gap:8px}.btn-small{padding:8px 16px;font-size:13px}.editor-canvas-container{flex:1;display:flex;align-items:center;justify-content:center;padding:24px;overflow:auto;position:relative;background:#0a0a0a}.editor-canvas{max-width:100%;max-height:100%;background:#fff;box-shadow:0 4px 20px #00000080;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.btn-apply-crop{position:absolute;bottom:40px;right:40px;padding:14px 28px;background:#4caf50;color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;box-shadow:0 4px 12px #4caf5066;transition:all .2s;z-index:10}.btn-apply-crop:hover{background:#45a049;transform:translateY(-2px);box-shadow:0 6px 16px #4caf5080}.editor-footer{display:flex;gap:12px;padding:16px 24px;background:#1a1a1a;border-top:1px solid #333}.editor-footer button{flex:1;padding:14px;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s}.btn-secondary{background:#3a3a3a;color:#fff}.btn-secondary:hover{background:#4a4a4a}@media(max-width:768px){.editor-header{flex-wrap:wrap;padding:12px 16px}.zoom-controls{order:3;width:100%;justify-content:center;margin-top:8px}.editor-toolbar{padding:8px 12px}.tool-btn{padding:8px 12px;font-size:13px}.brush-size-panel{flex-direction:column;align-items:stretch;padding:10px 16px}.brush-size-panel label{min-width:auto}.brush-slider{max-width:100%}.crop-mode-panel{padding:10px 12px}.mode-btn{min-width:65px;padding:8px 10px}.mode-icon{font-size:18px}.mode-name{font-size:10px}.filters-panel{padding:12px}.filter-btn{min-width:70px;padding:10px 12px}.signature-panel{padding:16px 12px}.editor-canvas-container{padding:12px}.btn-apply-crop{bottom:20px;right:20px;padding:12px 24px;font-size:14px}.editor-footer{padding:12px}.editor-footer button{padding:12px;font-size:14px}}@media(hover:none){.signature-canvas,.editor-canvas{touch-action:none}}.crop-mode-panel[data-mode=pen]:after{content:"Click to add points • Drag to move • Backspace to delete • Double-click to close";display:block;position:absolute;bottom:-30px;left:50%;transform:translate(-50%);background:#2196f3f2;color:#fff;padding:6px 12px;border-radius:4px;font-size:12px;white-space:nowrap;z-index:100}.crop-mode-panel[data-mode=polygon]:after{content:"Click to add points • Min 3 points";display:block;position:absolute;bottom:-30px;left:50%;transform:translate(-50%);background:#2196f3e6;color:#fff;padding:6px 12px;border-radius:4px;font-size:12px;white-space:nowrap}.crop-mode-panel[data-mode=freeform]:after{content:"Click and drag to draw a path";display:block;position:absolute;bottom:-30px;left:50%;transform:translate(-50%);background:#2196f3e6;color:#fff;padding:6px 12px;border-radius:4px;font-size:12px;white-space:nowrap}.crop-mode-panel[data-mode=circle]:after{content:"Click center • Drag to set radius";display:block;position:absolute;bottom:-30px;left:50%;transform:translate(-50%);background:#2196f3e6;color:#fff;padding:6px 12px;border-radius:4px;font-size:12px;white-space:nowrap}.crop-mode-panel[data-mode=perspective]:after{content:"Drag corners to adjust • Use Smart Crop for auto-detect";display:block;position:absolute;bottom:-30px;left:50%;transform:translate(-50%);background:#4caf50e6;color:#fff;padding:6px 12px;border-radius:4px;font-size:12px;white-space:nowrap}.scan-page{padding:20px 20px 80px;max-width:1200px;margin:0 auto}.scan-header{text-align:center;margin-bottom:30px}.scan-header h1{font-size:24px;margin-bottom:8px;color:#333}.scan-header p{color:#666;font-size:14px}.scan-modes{margin-bottom:30px}.scan-modes h3{font-size:18px;color:#333;margin-bottom:16px;text-align:center}.mode-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}.mode-btn{display:flex;flex-direction:column;align-items:center;padding:20px 16px;background:#fff;border:2px solid #e0e0e0;border-radius:12px;cursor:pointer;transition:all .3s;text-align:center}.mode-btn:hover{border-color:#2196f3;transform:translateY(-2px);box-shadow:0 4px 12px #2196f326}.mode-btn.active{background:#e3f2fd;border-color:#2196f3;box-shadow:0 4px 12px #2196f333}.mode-icon{font-size:48px;margin-bottom:12px}.mode-name{font-size:16px;font-weight:600;color:#333;margin-bottom:8px}.mode-desc{font-size:13px;color:#666;line-height:1.4}.scan-content{background:#f9f9f9;border-radius:12px;overflow:hidden;min-height:400px;display:flex;align-items:center;justify-content:center}.scan-placeholder{text-align:center;padding:40px}.scan-placeholder h3{font-size:20px;color:#333;margin-bottom:8px}.scan-placeholder p{color:#666;font-size:14px;margin-bottom:24px}.processing-view{width:100%;padding:20px;background:#fff;position:relative}.processing-overlay{position:absolute;inset:0;background:#fffffff2;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:10;border-radius:12px}.spinner{width:50px;height:50px;border:4px solid #f3f3f3;border-top:4px solid #2196F3;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px}.processing-overlay p{color:#333;font-size:16px;margin-bottom:8px}.processing-note{font-size:14px;color:#666}.preview-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;margin-bottom:20px}.preview-section{display:flex;flex-direction:column;gap:12px}.preview-section h4{font-size:16px;color:#333;font-weight:600}.preview-section img{width:100%;border-radius:8px;border:1px solid #e0e0e0;display:block}.opencv-badge{display:inline-block;font-size:11px;font-weight:600;color:#ff6b6b;background:#fff0f0;padding:4px 8px;border-radius:4px;margin-left:8px;text-transform:uppercase;vertical-align:middle}.processing-badge{display:inline-block;font-size:13px;color:#4caf50;background:#e8f5e9;padding:8px 12px;border-radius:6px;margin-top:12px;font-weight:500}.qr-result{padding:16px;background:#e8f5e9;border:2px solid #4caf50;border-radius:12px;margin-top:12px}.qr-result.qr-not-found{background:#fff3e0;border-color:#ff9800}.qr-header{display:flex;align-items:center;gap:8px;margin-bottom:12px}.qr-icon{font-size:24px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:50%}.qr-label{font-size:14px;font-weight:600;color:#2e7d32;margin:0}.qr-not-found .qr-label{color:#e65100}.qr-content{display:flex;flex-direction:column;gap:12px}.qr-data{font-size:14px;color:#1b5e20;word-break:break-all;font-family:monospace;background:#fff;padding:12px;border-radius:8px;line-height:1.6;margin:0}.qr-meta{font-size:12px;color:#66bb6a;margin:0}.qr-hint{font-size:13px;color:#f57c00;margin:0;line-height:1.5}.btn-copy-qr{padding:10px 16px;background:#4caf50;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:background .3s;align-self:flex-start}.btn-copy-qr:hover{background:#45a049}.processing-options{display:flex;align-items:center;gap:20px;padding:16px;background:#f9f9f9;border-radius:8px;margin-bottom:20px;flex-wrap:wrap}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.checkbox-label span{font-size:14px;color:#333}.btn-small{padding:8px 16px;font-size:14px;margin-left:auto}.preview-controls{display:flex;gap:12px}.preview-controls .btn-primary,.preview-controls .btn-secondary{flex:1;padding:14px 24px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s}.btn-primary{background:#2196f3;color:#fff}.btn-primary:hover{background:#1976d2}.btn-secondary{background:#f5f5f5;color:#333}.btn-secondary:hover{background:#e0e0e0}@media(max-width:768px){.mode-grid{grid-template-columns:repeat(2,1fr)}.mode-icon{font-size:36px}.mode-name{font-size:14px}.mode-desc{font-size:12px}.preview-container{grid-template-columns:1fr}.processing-options{flex-direction:column;align-items:flex-start}.btn-small{margin-left:0;width:100%}}@media(max-width:480px){.scan-page{padding:15px}.scan-header h1{font-size:20px}.placeholder-icon{font-size:60px}.mode-grid{grid-template-columns:1fr}}.ocr-results{margin-top:20px;background:#fff;border-radius:12px;padding:24px;box-shadow:0 4px 16px #0000001f}.btn-small{padding:10px 16px;font-size:13px;font-weight:600;border-radius:6px;transition:all .2s}.btn-danger{background:#fff;color:#f44336;border:1px solid #f44336}.btn-danger:hover{background:#f44336;color:#fff}@media(max-width:768px){.ocr-text-area-large{min-height:300px;font-size:14px}.ocr-stats{gap:12px}.stat-item{font-size:12px}.ocr-actions-extended{flex-direction:column;align-items:stretch}.ocr-actions-left{width:100%}.ocr-actions-left button{flex:1}}.documents-page{padding:20px 20px 80px;max-width:1400px;margin:0 auto}.documents-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.documents-header h1{font-size:24px;color:#333}.btn-new-folder{padding:10px 20px;background:#2196f3;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:background .3s}.btn-new-folder:hover{background:#1976d2}.documents-layout{display:grid;grid-template-columns:250px 1fr;gap:24px}.folders-sidebar{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000001a;height:fit-content}.folders-sidebar h3{font-size:16px;color:#333;margin-bottom:16px}.folders-list{display:flex;flex-direction:column;gap:4px}.folder-item{display:flex;align-items:center;gap:4px}.folder-button{flex:1;display:flex;align-items:center;gap:12px;padding:12px;background:transparent;border:none;border-radius:8px;cursor:pointer;transition:background .2s;text-align:left}.folder-button:hover{background:#f5f5f5}.folder-item.active .folder-button{background:#e3f2fd;color:#2196f3}.folder-icon{font-size:20px}.folder-name{flex:1;font-size:14px;font-weight:500}.folder-count{font-size:12px;color:#999;background:#f5f5f5;padding:2px 8px;border-radius:12px}.folder-item.active .folder-count{background:#2196f3;color:#fff}.folder-delete{padding:6px;background:transparent;border:none;border-radius:4px;cursor:pointer;font-size:14px;opacity:0;transition:opacity .2s,background .2s}.folder-item:hover .folder-delete{opacity:1}.folder-delete:hover{background:#ffebee}.documents-content{min-height:400px}.empty-state{text-align:center;padding:80px 20px}.empty-icon{font-size:80px;margin-bottom:20px;opacity:.5}.empty-state h3{font-size:20px;color:#333;margin-bottom:8px}.empty-state p{color:#666;font-size:14px}.documents-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px}.document-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000001a;cursor:pointer;transition:transform .2s,box-shadow .2s}.document-card:hover{transform:translateY(-4px);box-shadow:0 4px 12px #00000026}.doc-thumbnail{position:relative;width:100%;height:220px;background:#f9f9f9;overflow:hidden}.doc-thumbnail img{width:100%;height:100%;object-fit:cover}.no-preview{display:flex;align-items:center;justify-content:center;height:100%;color:#999;font-size:14px}.page-count-badge{position:absolute;top:12px;right:12px;background:#2196f3e6;color:#fff;font-size:12px;font-weight:600;padding:4px 10px;border-radius:12px}.document-info{padding:12px}.document-info h4{font-size:14px;margin-bottom:4px;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.document-info p{font-size:12px;color:#999}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px}.modal-dialog{background:#fff;border-radius:12px;padding:24px;max-width:400px;width:100%}.modal-dialog h3{font-size:20px;color:#333;margin-bottom:16px}.folder-name-input{width:100%;padding:12px;border:1px solid #e0e0e0;border-radius:8px;font-size:14px;margin-bottom:16px}.folder-name-input:focus{outline:none;border-color:#2196f3}.modal-actions{display:flex;gap:12px}.modal-actions button{flex:1;padding:12px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:background .3s}.document-modal{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px}.modal-content{background:#fff;border-radius:12px;max-width:900px;width:100%;max-height:90vh;display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e0e0e0}.modal-header h3{font-size:18px;color:#333}.close-btn{background:none;border:none;font-size:24px;cursor:pointer;color:#666;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s}.close-btn:hover{background:#f5f5f5}.modal-body{flex:1;overflow:auto;padding:20px;display:flex;flex-direction:column;align-items:center}.modal-body img{max-width:100%;border-radius:8px;margin-bottom:20px}.page-navigation{display:flex;align-items:center;gap:16px;padding:16px;background:#f9f9f9;border-radius:8px}.nav-btn{padding:8px 16px;background:#fff;border:1px solid #e0e0e0;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.nav-btn:hover:not(:disabled){background:#2196f3;color:#fff;border-color:#2196f3}.nav-btn:disabled{opacity:.3;cursor:not-allowed}.page-indicator{font-size:14px;color:#666;font-weight:500}.modal-footer{display:flex;gap:12px;padding:20px;border-top:1px solid #e0e0e0}.folder-select{flex:1;padding:12px;border:1px solid #e0e0e0;border-radius:8px;font-size:14px;cursor:pointer}.folder-select:focus{outline:none;border-color:#2196f3}.btn-danger{padding:12px 24px;background:#f44336;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:background .3s}.btn-danger:hover{background:#d32f2f}@media(max-width:768px){.documents-layout{grid-template-columns:1fr}.folders-sidebar{position:sticky;top:0;z-index:10}.folders-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:8px}.folder-delete{opacity:1}.documents-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.modal-footer{flex-direction:column}}.ocr-modal{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:3000;padding:20px}.ocr-modal-content{background:#fff;border-radius:12px;max-width:900px;width:100%;max-height:90vh;display:flex;flex-direction:column;padding:24px;overflow:auto}.ocr-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:2px solid #f0f0f0}.ocr-header h4{font-size:18px;color:#333;margin:0;font-weight:600}.btn-close-ocr{background:transparent;border:none;font-size:20px;color:#666;cursor:pointer;padding:4px;border-radius:4px;transition:background .2s}.btn-close-ocr:hover{background:#f5f5f5}.ocr-loading{text-align:center;padding:60px 40px}.ocr-loading p{color:#666;margin-top:16px;font-size:15px}.ocr-editor{margin-bottom:20px}.ocr-text-area-large{width:100%;min-height:400px;max-height:600px;padding:16px;border:2px solid #e0e0e0;border-radius:8px;font-size:15px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.7;resize:vertical;margin-bottom:12px;transition:border-color .3s}.ocr-text-area-large:focus{outline:none;border-color:#2196f3;box-shadow:0 0 0 3px #2196f31a}.ocr-stats{display:flex;gap:20px;padding:12px 16px;background:#f8f9fa;border-radius:6px;flex-wrap:wrap}.stat-item{font-size:13px;color:#666;font-weight:500}.ocr-actions-extended{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}.ocr-actions-left{display:flex;gap:8px;flex-wrap:wrap}.spinner{border:3px solid #f3f3f3;border-top:3px solid #2196F3;border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite;margin:0 auto}.ocr-progress-container{display:flex;align-items:center;gap:16px;margin-bottom:20px}.ocr-progress-bar{flex:1;height:12px;background:#e0e0e0;border-radius:6px;overflow:hidden}.ocr-progress-fill{height:100%;background:linear-gradient(90deg,#2196f3,#1976d2);border-radius:6px;transition:width .3s ease}.ocr-progress-text{font-size:14px;font-weight:600;color:#2196f3;min-width:45px;text-align:right}.ocr-processing-note{font-size:12px!important;color:#999!important;margin-top:8px!important}.ocr-options-bar{display:flex;align-items:center;gap:16px;padding:12px 16px;background:#f8f9fa;border-radius:8px;margin-bottom:16px;flex-wrap:wrap}.ocr-lang-selector{display:flex;align-items:center;gap:8px}.ocr-lang-selector label{font-size:14px;font-weight:500;color:#333}.ocr-lang-selector select{padding:8px 12px;border:1px solid #e0e0e0;border-radius:6px;font-size:14px;background:#fff;cursor:pointer}.ocr-lang-selector select:focus{outline:none;border-color:#2196f3}.ocr-confidence-badge{padding:6px 14px;background:linear-gradient(135deg,#4caf50,#45a049);color:#fff;border-radius:16px;font-size:12px;font-weight:600}.pdf-progress-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:4000;padding:20px}.pdf-progress-modal{background:#fff;border-radius:16px;padding:32px 40px;max-width:450px;width:100%;text-align:center}.pdf-progress-modal h4{font-size:18px;color:#333;margin-bottom:24px}.pdf-progress-container{display:flex;align-items:center;gap:16px;margin-bottom:16px}.pdf-progress-bar{flex:1;height:12px;background:#e0e0e0;border-radius:6px;overflow:hidden}.pdf-progress-fill{height:100%;background:linear-gradient(90deg,#2196f3,#1976d2);border-radius:6px;transition:width .3s ease}.pdf-progress-text{font-size:14px;font-weight:600;color:#2196f3;min-width:45px;text-align:right}.pdf-status-text{color:#666;font-size:14px;margin-bottom:8px}.pdf-processing-note{font-size:12px;color:#999}.analysis-error .error-icon{font-size:24px}.analysis-actions{display:flex;gap:8px;flex-wrap:wrap}@media(max-width:480px){.doc-assistant-actions{flex-direction:column}.doc-assistant-actions button{width:100%}.key-fields-grid{grid-template-columns:1fr}.analysis-header{flex-direction:column;align-items:flex-start}.analysis-actions{width:100%}.analysis-actions button{flex:1}}.ocr-page{padding:20px 20px 80px;max-width:800px;margin:0 auto}.ocr-header{text-align:center;margin-bottom:30px}.ocr-header h1{font-size:24px;margin-bottom:8px;color:#333}.ocr-header p{color:#666;font-size:14px;margin-bottom:12px}.free-badge{display:inline-block;padding:6px 14px;background:linear-gradient(135deg,#4caf50,#45a049);color:#fff;border-radius:20px;font-size:12px;font-weight:600}.ocr-content{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000001a}.upload-section{min-height:300px;display:flex;align-items:center;justify-content:center}.image-preview{position:relative;margin-bottom:20px}.image-preview img{width:100%;border-radius:8px;display:block}.btn-clear{position:absolute;top:12px;right:12px;width:36px;height:36px;border-radius:50%;border:none;background:#000000b3;color:#fff;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.btn-clear:hover{background:#000000e6}.ocr-controls{margin-bottom:20px}.lang-selector{display:flex;align-items:center;gap:12px;margin-bottom:16px}.lang-selector label{font-size:14px;font-weight:500;color:#333}.lang-selector select{flex:1;padding:10px 14px;border:1px solid #e0e0e0;border-radius:6px;font-size:14px;background:#fff;cursor:pointer}.lang-selector select:focus{outline:none;border-color:#2196f3}.btn-extract{width:100%}.progress-container{display:flex;align-items:center;gap:16px;margin-bottom:20px}.progress-bar{flex:1;height:12px;background:#e0e0e0;border-radius:6px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#2196f3,#1976d2);border-radius:6px;transition:width .3s ease}.progress-text{font-size:14px;font-weight:600;color:#2196f3;min-width:45px;text-align:right}.processing-note{margin-top:8px;font-size:12px;color:#999}.error-message{display:flex;align-items:center;gap:12px;padding:16px;background:#fff3f3;border:1px solid #ffcccc;border-radius:8px;margin-bottom:20px}.error-icon{font-size:24px}.error-message p{color:#d32f2f;font-size:14px;margin:0}.text-result{margin-top:20px}.result-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;flex-wrap:wrap;gap:12px}.result-header h3{font-size:18px;color:#333;margin:0}.confidence-badge{padding:4px 12px;background:#e8f5e9;color:#4caf50;border-radius:12px;font-size:12px;font-weight:600}.result-actions-top{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap}.result-actions{display:flex;gap:8px}.btn-small{padding:8px 16px;font-size:14px}.result-footer{margin-top:12px;display:flex;justify-content:flex-end}.char-count{font-size:12px;color:#999}.text-output{width:100%;padding:16px;border:1px solid #e0e0e0;border-radius:8px;font-size:14px;line-height:1.6;resize:vertical;font-family:inherit;min-height:200px}.text-output:focus{outline:none;border-color:#2196f3}.doc-assistant-section{margin-top:32px;padding-top:24px;border-top:2px solid #e0e0e0}.doc-assistant-title{font-size:18px;color:#333;margin-bottom:16px;font-weight:600}.doc-assistant-actions{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap}.analysis-loading{text-align:center;padding:30px}.analysis-loading .spinner{width:40px;height:40px;border:3px solid #f3f3f3;border-top:3px solid #2196F3;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 16px}.analysis-loading p{color:#666;font-size:14px}.analysis-error{display:flex;align-items:center;gap:12px;padding:16px;background:#fff3f3;border:1px solid #ffcccc;border-radius:8px;margin-bottom:16px}.analysis-error p{color:#d32f2f;font-size:14px;margin:0}.analysis-result{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;padding:20px}.analysis-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:12px}.doc-type-badge{display:inline-block;padding:4px 12px;background:#2196f3;color:#fff;border-radius:12px;font-size:12px;font-weight:600;margin-right:8px}.confidence-badge-small{display:inline-block;padding:4px 12px;background:#e8f5e9;color:#4caf50;border-radius:12px;font-size:12px;font-weight:600}.analysis-actions{display:flex;gap:8px}.analysis-section{margin-bottom:20px}.analysis-section:last-child{margin-bottom:0}.analysis-section h4{font-size:15px;color:#333;margin-bottom:12px;font-weight:600}.bullet-list{list-style:none;padding:0;margin:0}.bullet-list li{padding:8px 0 8px 20px;position:relative;color:#555;font-size:14px;line-height:1.5}.bullet-list li:before{content:"•";position:absolute;left:0;color:#2196f3;font-weight:700}.key-fields-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:12px}.key-field{background:#fff;padding:12px;border-radius:6px;border:1px solid #e0e0e0}.key-field strong{display:block;font-size:12px;color:#666;margin-bottom:4px;text-transform:uppercase;font-weight:600}.key-field span{font-size:14px;color:#333;word-break:break-word}.organize-suggestions{display:flex;flex-direction:column;gap:12px}.suggestion-item{background:#fff;padding:12px;border-radius:6px;border:1px solid #e0e0e0}.suggestion-item strong{display:block;font-size:12px;color:#666;margin-bottom:6px;text-transform:uppercase;font-weight:600}.suggestion-item span{font-size:14px;color:#333}.tag-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}.tag-chip{display:inline-block;padding:4px 12px;background:#e3f2fd;color:#1976d2;border-radius:12px;font-size:12px;font-weight:500}@media(max-width:480px){.ocr-page{padding:15px}.upload-placeholder{padding:20px}.placeholder-icon{font-size:60px}.lang-selector{flex-direction:column;align-items:stretch}.result-actions-top{width:100%}.result-actions-top button{flex:1}.doc-assistant-actions{flex-direction:column}.doc-assistant-actions button{width:100%}.key-fields-grid{grid-template-columns:1fr}.analysis-header{flex-direction:column;align-items:flex-start}.analysis-actions{width:100%}.analysis-actions button{flex:1}}.convert-page{padding:20px 20px 80px;max-width:800px;margin:0 auto}.convert-header{text-align:center;margin-bottom:30px}.convert-header h1{font-size:24px;margin-bottom:8px;color:#333}.convert-header p{color:#666;font-size:14px}.convert-content{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000001a;min-height:400px}.upload-section{min-height:400px;display:flex;align-items:center;justify-content:center}.upload-placeholder{text-align:center;padding:40px}.placeholder-icon{font-size:80px;margin-bottom:20px}.upload-placeholder h3{font-size:20px;color:#333;margin-bottom:8px}.upload-placeholder p{color:#666;font-size:14px;margin-bottom:24px}.file-upload-btn{display:inline-block;padding:14px 32px;background:#2196f3;color:#fff;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:background .3s}.file-upload-btn:hover{background:#1976d2}.supported-formats{margin-top:24px;padding-top:24px;border-top:1px solid #e0e0e0}.formats-label{font-size:12px;font-weight:600;color:#999;text-transform:uppercase;margin-bottom:8px}.formats-list{font-size:13px;color:#666;line-height:1.5}.btn-clear{width:32px;height:32px;border-radius:50%;border:none;background:#f5f5f5;color:#666;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.btn-clear:hover{background:#e0e0e0}.processing{text-align:center;padding:40px}.spinner{width:50px;height:50px;border:4px solid #f3f3f3;border-top:4px solid #2196F3;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 20px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.processing p{color:#666;font-size:14px}.conversion-section{display:flex;flex-direction:column;gap:24px}.file-info{display:flex;align-items:center;gap:16px;padding:20px;background:#f9f9f9;border-radius:8px;position:relative}.file-icon{font-size:40px}.file-details{flex:1}.file-details h4{font-size:16px;color:#333;margin-bottom:4px;word-break:break-all}.file-details p{font-size:14px;color:#999}.format-selector h3{font-size:18px;color:#333;margin-bottom:16px}.format-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px}.format-btn{display:flex;flex-direction:column;align-items:center;gap:8px;padding:20px;background:#f9f9f9;border:2px solid transparent;border-radius:8px;cursor:pointer;transition:all .3s}.format-btn:hover{background:#f0f0f0}.format-btn.active{background:#e3f2fd;border-color:#2196f3}.format-icon{font-size:32px}.format-label{font-size:14px;font-weight:600;color:#333}.btn-convert{width:100%;padding:16px;font-size:16px}@media(max-width:480px){.convert-page{padding:15px}.format-grid{grid-template-columns:repeat(2,1fr)}.file-icon{font-size:32px}}.input-mode-selector{display:flex;gap:12px;justify-content:center;margin-bottom:24px}.mode-tab{padding:12px 24px;background:#fff;border:2px solid #e0e0e0;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s}.mode-tab:hover{border-color:#2196f3;background:#f5f5f5}.mode-tab.active{background:#2196f3;border-color:#2196f3;color:#fff}.text-input-section,.website-input-section{padding:20px}.text-input-section h3,.website-input-section h3{font-size:18px;color:#333;margin-bottom:12px}.text-input-area{width:100%;min-height:300px;padding:16px;border:2px solid #e0e0e0;border-radius:8px;font-size:14px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;resize:vertical;margin-bottom:20px}.text-input-area:focus{outline:none;border-color:#2196f3}.website-url-input{width:100%;padding:14px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:15px;margin-bottom:8px}.website-url-input:focus{outline:none;border-color:#2196f3}.url-hint{font-size:13px;color:#999;margin-bottom:20px}.format-note{font-size:13px;color:#666;margin-top:8px;text-align:center}.convert-progress-container{display:flex;align-items:center;gap:16px;margin-bottom:16px;max-width:400px;margin-left:auto;margin-right:auto}.convert-progress-bar{flex:1;height:12px;background:#e0e0e0;border-radius:6px;overflow:hidden}.convert-progress-fill{height:100%;background:linear-gradient(90deg,#2196f3,#1976d2);border-radius:6px;transition:width .3s ease}.convert-progress-text{font-size:14px;font-weight:600;color:#2196f3;min-width:45px;text-align:right}.settings-page{padding:20px 20px 80px;max-width:800px;margin:0 auto}.settings-header{margin-bottom:30px}.settings-header h1{font-size:24px;margin-bottom:8px;color:#333}.settings-header p{color:#666;font-size:14px}.settings-content{display:flex;flex-direction:column;gap:24px}.settings-section{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000001a}.settings-section h3{font-size:18px;color:#333;margin-bottom:16px}.api-key-section{display:flex;flex-direction:column;gap:16px}.api-description{color:#666;font-size:14px;line-height:1.5}.api-key-input-group{display:flex;gap:8px}.api-key-input{flex:1;padding:12px 16px;border:1px solid #e0e0e0;border-radius:8px;font-size:14px;font-family:monospace}.api-key-input:focus{outline:none;border-color:#2196f3}.btn-toggle-visibility{padding:12px 16px;background:#f5f5f5;border:none;border-radius:8px;font-size:18px;cursor:pointer;transition:background .3s}.btn-toggle-visibility:hover{background:#e0e0e0}.api-key-actions{display:flex;gap:12px}.api-key-actions .btn-primary,.api-key-actions .btn-secondary{flex:1}.api-note{color:#999;font-size:13px}.api-note a{color:#2196f3;text-decoration:none}.api-note a:hover{text-decoration:underline}.setting-item{display:flex;justify-content:space-between;align-items:center;padding:16px 0;border-bottom:1px solid #f0f0f0}.setting-item:last-child{border-bottom:none}.setting-info h4{font-size:16px;color:#333;margin-bottom:4px}.setting-info p{font-size:14px;color:#999}.toggle-switch{position:relative;display:inline-block;width:52px;height:28px}.toggle-switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background-color:#ccc;transition:.4s;border-radius:28px}.slider:before{position:absolute;content:"";height:20px;width:20px;left:4px;bottom:4px;background-color:#fff;transition:.4s;border-radius:50%}input:checked+.slider{background-color:#2196f3}input:checked+.slider:before{transform:translate(24px)}input:disabled+.slider{opacity:.5;cursor:not-allowed}.quality-options{display:flex;gap:12px}.quality-btn{flex:1;padding:12px;background:#f9f9f9;border:2px solid transparent;border-radius:8px;font-size:14px;font-weight:600;color:#333;cursor:pointer;transition:all .3s}.quality-btn:hover{background:#f0f0f0}.quality-btn.active{background:#e3f2fd;border-color:#2196f3;color:#2196f3}.storage-info{display:flex;flex-direction:column;gap:16px}.storage-info p{color:#666;font-size:14px}.about-info{display:flex;flex-direction:column;gap:12px}.about-item{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid #f0f0f0;color:#666;font-size:14px}.about-item:last-child{border-bottom:none}.api-status-section{display:flex;flex-direction:column;gap:16px}.status-display{padding:16px;background:#f9f9f9;border-radius:8px}.status-indicator{display:flex;align-items:center;gap:12px;padding:12px;border-radius:6px;font-size:14px;font-weight:500}.status-success{background:#e8f5e9;color:#2e7d32;border:1px solid #c8e6c9}.status-warning{background:#fff3e0;color:#e65100;border:1px solid #ffe0b2}.status-icon{font-size:18px}.api-note code{background:#f5f5f5;padding:2px 6px;border-radius:3px;font-family:Courier New,monospace;font-size:13px;color:#d32f2f}@media(max-width:480px){.settings-page{padding:15px}.quality-options{flex-direction:column}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}.auth-card{width:100%;max-width:420px;background:#fff;border-radius:16px;padding:20px;box-shadow:0 12px 30px #00000014}.auth-header{text-align:center;margin-bottom:16px}.auth-header h1{font-size:28px;margin-bottom:6px}.auth-header p{color:#666}.auth-tabs{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:14px 0 12px;background:#f5f5f5;padding:6px;border-radius:12px}.auth-tab{border:none;background:transparent;padding:10px 12px;border-radius:10px;font-weight:700;cursor:pointer}.auth-tab.active{background:#fff;box-shadow:0 8px 18px #0000000f}.auth-banner{margin:10px 0;padding:10px 12px;border-radius:10px;font-size:14px;line-height:1.3}.auth-banner-error{background:#ffebee;color:#b71c1c}.auth-banner-info{background:#e3f2fd;color:#0d47a1}.auth-google{width:100%}.auth-divider{display:flex;align-items:center;gap:12px;margin:14px 0;color:#777;font-size:14px}.auth-divider:before,.auth-divider:after{content:"";height:1px;background:#e5e5e5;flex:1}.auth-form{display:flex;flex-direction:column;gap:12px}.auth-label{display:flex;flex-direction:column;gap:6px;font-size:14px;font-weight:600}.auth-input{padding:12px 14px;border:1px solid #ddd;border-radius:10px;outline:none;font-size:16px}.auth-input:focus{border-color:#2196f3;box-shadow:0 0 0 3px #2196f326}.auth-link{background:transparent;border:none;padding:0;margin-top:-6px;text-align:left;color:#1976d2;font-weight:600;cursor:pointer}.auth-link:disabled{opacity:.6;cursor:not-allowed}.auth-submit{width:100%}.app{min-height:100vh;background:#f5f5f5}.main-content{min-height:100vh;padding-bottom:70px}@media(max-width:480px){.main-content{padding-bottom:65px}}
