*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;overflow:hidden}#root{height:100%}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.app{flex-direction:column;width:100vw;height:100vh;display:flex;overflow:hidden}.toolbar{z-index:10;background-color:#fafafa;border-bottom:1px solid #e0e0e0;justify-content:space-between;align-items:center;padding:.75rem 1.5rem;display:flex}.toolbar-title{color:#333;white-space:nowrap;font-size:1.1rem;font-weight:600}.toolbar-controls{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:.5rem;display:flex}.toolbar-group{flex-wrap:wrap;align-items:center;gap:4px;display:flex}.toolbar-divider{background-color:#ddd;width:1px;height:24px;margin:0 8px}.toolbar-controls button{cursor:pointer;color:#555;background-color:#fff;border:1px solid #ddd;border-radius:4px;padding:6px 12px;font-size:.85rem;transition:all .15s}.toolbar-controls button:hover:not(:disabled){background-color:#f0f0f0;border-color:#ccc}.toolbar-controls button:disabled{opacity:.4;cursor:not-allowed}.toolbar-controls button.active{background-color:#e8e8e8;border-color:#bbb}.toolbar-field{flex-direction:column;gap:.25rem;min-width:108px;display:flex}.toolbar-field-label{color:#667085;font-size:.72rem;font-weight:600}.toolbar-select{color:#344054;background:#fff;border:1px solid #d0d7de;border-radius:8px;min-width:108px;padding:.45rem .75rem;font-size:.88rem}.toolbar-color-select-wrap{align-items:center;display:flex;position:relative}.toolbar-color-indicator{pointer-events:none;border:1px solid #00000014;border-radius:999px;width:14px;height:14px;position:absolute;left:.75rem}.toolbar-select-color{padding-left:2rem}.clear-btn{color:#dc3545!important;border-color:#dc3545!important}.clear-btn:hover:not(:disabled){color:#fff!important;background-color:#dc3545!important}.canvas-container{background-color:#fff;flex:1;position:relative;overflow:hidden}.canvas-container canvas{cursor:crosshair;position:absolute;top:0;left:0}.recognize-button{color:#fff;cursor:pointer;z-index:20;background-color:#007bff;border:none;border-radius:8px;align-items:center;gap:8px;padding:.875rem 1.75rem;font-size:1rem;font-weight:600;transition:all .2s;display:flex;position:fixed;bottom:2rem;right:2rem;box-shadow:0 4px 12px #007bff4d}.recognize-button:hover:not(:disabled){background-color:#0056b3;transform:translateY(-2px);box-shadow:0 6px 16px #007bff66}.recognize-button:active:not(:disabled){transform:translateY(0)}.recognize-button:disabled{cursor:not-allowed;box-shadow:none;background-color:#6c757d;transform:none}.recognize-button.loading{background-color:#6c757d}.recognize-button.success{background-color:#28a745;box-shadow:0 4px 12px #28a7454d}.recognize-button.error{background-color:#dc3545;box-shadow:0 4px 12px #dc35454d}.ocr-preview-backdrop{z-index:40;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#12161d9e;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.ocr-preview-modal{background:#fffdf9;border-radius:20px;width:min(720px,100%);max-height:min(88vh,920px);padding:1.25rem;overflow:auto;box-shadow:0 20px 60px #00000047}.ocr-preview-copy{margin-bottom:1rem}.ocr-preview-eyebrow{letter-spacing:.08em;text-transform:uppercase;color:#8f6a2a;margin-bottom:.35rem;font-size:.75rem;font-weight:700}.ocr-preview-title{color:#1f2933;margin-bottom:.35rem;font-size:1.4rem}.ocr-preview-description{color:#52606d;font-size:.95rem}.ocr-preview-image-frame{background:linear-gradient(135deg,#fff7e6e6,#fffffff2);border:1px solid #d6c2a1cc;border-radius:16px;justify-content:center;align-items:center;min-height:240px;padding:1rem;display:flex}.ocr-preview-image{object-fit:contain;background:#fff;border-radius:10px;max-width:100%;max-height:52vh;box-shadow:0 12px 28px #0f172a1f}.ocr-preview-actions{justify-content:flex-end;gap:.75rem;margin-top:1rem;display:flex}.ocr-preview-btn{cursor:pointer;border:1px solid #0000;border-radius:10px;padding:.75rem 1rem;font-size:.95rem;font-weight:600;transition:transform .15s,background-color .15s}.ocr-preview-btn:hover{transform:translateY(-1px)}.ocr-preview-btn-secondary{color:#52606d;background:#f4f1ea;border-color:#e2dacd}.ocr-preview-btn-primary{color:#fff;background:#0f7b6c}.spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:.6s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.toast{z-index:30;background:#fff;border-left:4px solid #28a745;border-radius:8px;min-width:280px;max-width:400px;padding:1rem 1.25rem;animation:.2s ease-out slideUp;position:fixed;bottom:6rem;right:2rem;box-shadow:0 8px 32px #00000026}.toast-error{border-left-color:#dc3545}.toast-success{border-left-color:#28a745}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.toast-content{margin-bottom:.75rem}.toast-label{color:#888;margin-bottom:4px;font-size:.8rem}.toast-text{color:#333;word-break:break-all;font-size:1.25rem}.toast-message{color:#dc3545;font-size:.9rem}.toast-actions{justify-content:flex-end;gap:8px;display:flex}.toast-btn{cursor:pointer;background:#fff;border:1px solid #ddd;border-radius:4px;padding:4px 12px;font-size:.85rem;transition:background-color .15s}.toast-btn:hover{background-color:#f0f0f0}.toast-btn-close{color:#888}@media (width<=768px){.toolbar{flex-direction:column;gap:.5rem;padding:.5rem 1rem}.toolbar-title{font-size:.95rem}.toolbar-controls{flex-wrap:wrap;justify-content:center}.recognize-button{padding:.75rem 1.25rem;font-size:.9rem;bottom:1rem;right:1rem}.toast{min-width:auto;bottom:5rem;left:1rem;right:1rem}.ocr-preview-backdrop{padding:1rem}.ocr-preview-modal{border-radius:16px;padding:1rem}.ocr-preview-image{max-height:42vh}.ocr-preview-actions{flex-direction:column-reverse}.ocr-preview-btn{width:100%}}
