:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,sans-serif;color:#1f2937;background:#f5f6f8}*{box-sizing:border-box}html,body,#root{margin:0;height:100%}.app{display:flex;flex-direction:column;height:100vh}.app-header{display:flex;align-items:center;gap:16px;padding:12px 16px;background:#1f2937;color:#fff;flex-wrap:wrap}.app-header h1{font-size:18px;margin:0}.file-loader{display:inline-flex;align-items:center;background:#2563eb;color:#fff;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:14px}.file-loader input{display:none}.page-controls{display:inline-flex;align-items:center;gap:8px;font-size:14px}.page-controls button{background:#374151;color:#fff;border:none;padding:4px 10px;border-radius:4px;cursor:pointer}.page-controls button:disabled{background:#4b5563;opacity:.6;cursor:not-allowed}.error-banner{background:#fee2e2;color:#b91c1c;padding:8px 16px;font-size:14px}.app-body{flex:1;display:flex;min-height:0}.viewer-area{flex:1;overflow:auto;padding:16px;background:#e5e7eb;display:flex;justify-content:center;align-items:flex-start}.placeholder{color:#6b7280;font-size:14px;text-align:center;line-height:1.7;align-self:stretch;flex:1;margin:16px;padding:48px 24px;border:2px dashed #cbd5e1;border-radius:12px;background:#f9fafb;display:flex;align-items:center;justify-content:center;transition:background .15s ease,border-color .15s ease,color .15s ease}.placeholder-active{background:#dbeafe;border-color:#2563eb;color:#1d4ed8}.viewer-stage{position:relative;display:inline-block;background:#fff;box-shadow:0 2px 6px #00000026;-webkit-user-select:none;user-select:none}.viewer-canvas{display:block;max-width:100%;height:auto}.viewer-overlay{position:absolute;top:0;right:0;bottom:0;left:0;cursor:crosshair}.selection-box{position:absolute;border:2px solid #2563eb;background:#2563eb1a;pointer-events:none}.selection-box-drag{border-style:dashed;background:#2563eb33}.quad-overlay{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none;overflow:visible}.quad-overlay polygon{fill:#10b98126;stroke:#10b981;stroke-width:2;stroke-dasharray:4 3}.quad-handle{position:absolute;width:14px;height:14px;margin-left:-7px;margin-top:-7px;border-radius:50%;background:#10b981;border:2px solid #fff;box-shadow:0 0 0 1px #10b981;cursor:grab;padding:0;pointer-events:auto}.quad-handle:active{cursor:grabbing;background:#059669}.selection-label{position:absolute;top:-20px;left:0;background:#2563eb;color:#fff;font-size:11px;padding:1px 6px;border-radius:2px;white-space:nowrap;pointer-events:none}.selection-remove{position:absolute;top:-10px;right:-10px;width:20px;height:20px;border-radius:50%;border:none;background:#ef4444;color:#fff;font-size:14px;line-height:1;cursor:pointer;pointer-events:auto}.side-panel{width:380px;border-left:1px solid #d1d5db;background:#fff;overflow-y:auto;padding:12px 16px}.side-panel h2{margin:0 0 12px;font-size:16px}.empty-hint{color:#6b7280;font-size:14px}.selection-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}.selection-item{border:1px solid #e5e7eb;border-radius:6px;padding:8px;background:#fafafa}.selection-item-header{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:6px}.selection-item-controls{display:flex;align-items:center;gap:8px;margin-bottom:6px;flex-wrap:wrap}.writing-mode-toggle{display:inline-flex;border:1px solid #d1d5db;border-radius:4px;overflow:hidden}.writing-mode-toggle button{background:#fff;color:#374151;border:none;padding:4px 10px;font-size:12px;cursor:pointer}.writing-mode-toggle button+button{border-left:1px solid #d1d5db}.writing-mode-toggle button.active{background:#2563eb;color:#fff}.selection-preprocess{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:6px;font-size:12px;color:#374151}.selection-preprocess label{display:inline-flex;align-items:center;gap:4px;cursor:pointer}.selection-preprocess input[type=checkbox]{margin:0;cursor:pointer}.preview-btn{margin-left:auto;background:#6b7280;color:#fff;border:none;border-radius:4px;padding:3px 8px;font-size:11px;cursor:pointer}.preview-btn:disabled{opacity:.5;cursor:not-allowed}.selection-preview{position:relative;margin-bottom:6px;padding:4px;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:4px;display:inline-block;max-width:100%}.selection-preview img{display:block;max-width:100%;height:auto;background:#fff}.preview-close{position:absolute;top:-8px;right:-8px;width:18px;height:18px;border-radius:50%;border:none;background:#6b7280;color:#fff;font-size:12px;line-height:1;cursor:pointer}.selection-label-input{flex:1 1 120px;min-width:0;padding:4px 6px;border:1px solid #d1d5db;border-radius:4px;font-size:13px}.selection-item-header button{border:none;border-radius:4px;padding:4px 8px;font-size:12px;cursor:pointer}.page-jump{background:#6b7280;color:#fff}.page-jump:disabled{opacity:.5;cursor:default}.run-ocr{background:#2563eb;color:#fff}.run-ocr:disabled{opacity:.6;cursor:not-allowed}.remove{background:#ef4444;color:#fff}.result{display:flex;flex-direction:column;gap:6px}.result-text{width:100%;min-height:80px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:13px;padding:6px;border:1px solid #d1d5db;border-radius:4px;resize:vertical}.copy{align-self:flex-start;background:#10b981;color:#fff;border:none;border-radius:4px;padding:4px 10px;font-size:12px;cursor:pointer}.result-empty,.result-running,.result-error{margin:0;font-size:13px}.result-empty{color:#6b7280}.result-running{color:#2563eb}.result-error{color:#b91c1c}.app-footer{background:#fff;border-top:1px solid #e5e7eb;color:#4b5563}.app-footer-details>summary{cursor:pointer;list-style:none;display:flex;align-items:center;gap:6px;padding:6px 16px;font-size:12px;color:#6b7280;-webkit-user-select:none;user-select:none;background:#f9fafb}.app-footer-details>summary:hover{background:#f3f4f6;color:#374151}.app-footer-details>summary::-webkit-details-marker{display:none}.app-footer-details>summary:before{content:"▶";font-size:9px;color:#9ca3af;transition:transform .15s ease;display:inline-block}.app-footer-details[open]>summary{border-bottom:1px solid #e5e7eb}.app-footer-details[open]>summary:before{transform:rotate(90deg)}.app-footer-inner{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1fr;gap:24px;padding:20px 16px}@media (min-width: 768px){.app-footer-inner{grid-template-columns:1fr 1fr}}.app-footer-section h3{font-size:14px;font-weight:600;color:#111827;margin:0 0 10px}.app-footer-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.app-footer-item{display:flex;align-items:flex-start;gap:10px;font-size:13px;color:#4b5563;line-height:1.5}.app-footer-item p{margin:0}.app-footer-icon{flex-shrink:0;width:22px;height:22px;background:#dbeafe;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:#2563eb;margin-top:1px}.app-footer-icon svg{width:12px;height:12px}.app-footer a{color:#2563eb;text-decoration:none}.app-footer a:hover{color:#1d4ed8;text-decoration:underline}.app-footer-licenses-title{font-weight:500;color:#374151;margin-bottom:2px}.app-footer-licenses ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:2px;font-size:12px;color:#6b7280}.app-copyright{background:#f3f4f6;padding:10px 16px;text-align:center;font-size:12px;color:#6b7280}.app-copyright p{margin:0}.app-copyright a{color:#2563eb;text-decoration:none}.app-copyright a:hover{text-decoration:underline}.app-nav{display:inline-flex;align-items:center;gap:4px;margin-right:auto}.app-nav a{color:#d1d5db;text-decoration:none;font-size:13px;padding:4px 10px;border-radius:4px}.app-nav a:hover{background:#374151;color:#fff}.app-nav a.active{background:#2563eb;color:#fff}.app-body-single{display:block;overflow-y:auto;padding:24px;background:#fff}.help-page{max-width:760px;margin:0 auto;font-size:14px;line-height:1.7;color:#1f2937}.help-page section{margin-bottom:24px}.help-callout{background:#ecfdf5;border:1px solid #a7f3d0;border-left:4px solid #10b981;border-radius:6px;padding:14px 18px;margin-bottom:28px}.help-callout h2{border:none;margin-top:0;color:#065f46}.help-callout p{margin:0 0 10px}.help-page h2{font-size:16px;margin:0 0 8px;padding-bottom:4px;border-bottom:1px solid #e5e7eb}.help-page ul,.help-page ol{margin:0;padding-left:20px}.help-page code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;background:#f3f4f6;padding:1px 4px;border-radius:3px;font-size:13px}.help-page a{color:#2563eb;text-decoration:none;word-break:break-all}.help-page a:hover{text-decoration:underline}.help-links{list-style:none;padding:0}@media (max-width: 768px){.app-header{gap:8px;padding:8px 12px}.app-header h1{font-size:15px;flex:1 1 100%}.app-nav{margin-right:0;flex-wrap:wrap}.app-nav a{font-size:12px;padding:3px 8px}.file-loader{font-size:13px;padding:6px 10px}.page-controls{font-size:13px}.app-body{flex-direction:column}.viewer-area{padding:8px;flex:1 1 auto;min-height:45vh;align-items:flex-start}.viewer-stage{max-width:100%}.side-panel{width:100%;border-left:none;border-top:1px solid #d1d5db;max-height:55vh;padding:10px 12px}.placeholder{padding:32px 16px;font-size:13px;margin:0}.quad-handle{width:22px;height:22px;margin-left:-11px;margin-top:-11px}.selection-remove{width:26px;height:26px;top:-13px;right:-13px;font-size:16px}.selection-label{font-size:10px}.app-body-single{padding:14px}.help-page{font-size:13px;line-height:1.6}.app-footer-inner{padding:16px 12px;gap:16px}.selection-item-header{gap:4px}.selection-item-header button,.selection-item-controls button{min-height:32px}.writing-mode-toggle button{min-height:32px;padding:6px 12px}.selection-preprocess{gap:10px}.selection-preprocess input[type=checkbox]{width:18px;height:18px}}
