*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg: #f5f5f5;--color-surface: #ffffff;--color-border: #e0e0e0;--color-text: #212121;--color-text-secondary: #757575;--color-primary: #1976d2;--color-primary-hover: #1565c0;--color-secondary: #546e7a;--color-secondary-hover: #455a64;--color-danger: #d32f2f;--color-region: rgba(25, 118, 210, .35);--color-region-selected: rgba(25, 118, 210, .7);--radius: 6px;--shadow: 0 2px 8px rgba(0,0,0,.12)}body{font-family:Noto Sans JP,system-ui,-apple-system,sans-serif;background:var(--color-bg);color:var(--color-text);min-height:100vh;line-height:1.6}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;font-family:inherit;font-size:.875rem;border-radius:var(--radius);border:none;transition:background .15s,opacity .15s}button:disabled{opacity:.5;cursor:not-allowed}.app{display:flex;flex-direction:column;min-height:100vh}.main{flex:1;max-width:1400px;width:100%;margin:0 auto;padding:1.5rem 1rem}.header{background:var(--color-surface);border-bottom:1px solid var(--color-border);padding:.75rem 1.5rem;display:flex;align-items:center;justify-content:space-between;box-shadow:var(--shadow);position:sticky;top:0;z-index:100}.header-title{display:flex;align-items:center;background:none;border:none;padding:0;cursor:pointer;text-align:left;border-radius:6px;transition:opacity .15s}.header-title:hover{opacity:.75}.header-title h1{font-size:1.25rem;font-weight:700;color:var(--color-primary);margin:0}.header-subtitle{font-size:.8rem;color:var(--color-text-secondary);margin-left:.5rem}.header-actions{display:flex;gap:.5rem;align-items:center}.btn-start-ocr{font-size:.9rem;padding:.4rem 1.1rem}.btn-icon{background:none;font-size:1.25rem;padding:.25rem .5rem;border-radius:var(--radius)}.btn-icon:hover{background:var(--color-border)}.btn-lang{background:var(--color-border);color:var(--color-text);padding:.35rem .75rem;font-size:.8rem}.btn-lang:hover{background:#ccc}.btn{padding:.5rem 1.25rem;font-weight:500}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover)}.btn-secondary{background:var(--color-border);color:var(--color-text)}.btn-secondary:hover:not(:disabled){background:#ccc}.btn-danger{background:var(--color-danger);color:#fff}.btn-close{background:none;font-size:1.25rem;padding:.25rem .5rem;color:var(--color-text-secondary)}.pending-section{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem 1rem}.pending-grid{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center;max-width:960px}.pending-item{display:flex;flex-direction:column;align-items:center;gap:.4rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;padding:.5rem;width:160px}.pending-thumb{width:100%;height:120px;object-fit:contain;border-radius:4px;background:var(--color-bg)}.pending-item-name{font-size:.7rem;color:var(--color-text-secondary);text-overflow:ellipsis;overflow:hidden;white-space:nowrap;width:100%;text-align:center}.pending-hint{font-size:.85rem;color:var(--color-text-secondary)}.upload-section{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem 0}.dropzone{width:100%;max-width:640px;border:2px dashed var(--color-border);border-radius:var(--radius);padding:3rem 2rem;text-align:center;cursor:pointer;transition:border-color .15s,background .15s;background:var(--color-surface)}.dropzone:hover,.dropzone.dragging{border-color:var(--color-primary);background:#e3f2fd}.dropzone.disabled{opacity:.5;cursor:not-allowed}.dropzone-icon{font-size:2.5rem;margin-bottom:.75rem}.dropzone-text{font-size:1rem;color:var(--color-text);margin-bottom:.5rem}.dropzone-formats{font-size:.8rem;color:var(--color-text-secondary)}.upload-actions{display:flex;gap:.75rem}.processing-section{padding:2rem 0}.progress-container{max-width:640px;margin:0 auto}.progress-container.error .progress-bar-fill{background:var(--color-danger)}.progress-files{font-size:.875rem;color:var(--color-text-secondary);margin-bottom:.5rem}.progress-bar-track{background:var(--color-border);border-radius:4px;height:8px;overflow:hidden}.progress-bar-fill{height:100%;background:var(--color-primary);transition:width .3s ease}.progress-bar-fill.done{background:#388e3c}.progress-message{font-size:.8rem;color:var(--color-text-secondary);margin-top:.5rem;min-height:1.2em}.progress-title{font-size:.9rem;font-weight:600;color:var(--color-text);margin-bottom:1rem}.model-download-bars{display:flex;flex-direction:column;gap:.6rem}.model-download-row{display:flex;flex-direction:column;gap:.2rem}.model-download-label{font-size:.8rem;color:var(--color-text-secondary)}.model-download-bar-wrap{display:flex;align-items:center;gap:.5rem}.model-download-bar-wrap .progress-bar-track{flex:1}.model-download-pct{font-size:.75rem;color:var(--color-text-secondary);min-width:3ch;text-align:right}.file-loading-status{display:flex;align-items:center;gap:.75rem;max-width:640px;margin:0 auto 1.5rem}.file-loading-spinner{width:18px;height:18px;border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;flex-shrink:0;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.file-loading-message{font-size:.875rem;color:var(--color-text-secondary);word-break:break-all}.model-loading-note{font-size:.8rem;color:var(--color-text-secondary);max-width:640px;margin:1rem auto 0;padding:.75rem 1rem;background:#fff8e1;border-radius:var(--radius);border-left:3px solid #f9a825}.result-section{display:grid;grid-template-columns:160px 1fr;gap:1rem;align-items:start}.result-section:not(:has(.result-sidebar)){grid-template-columns:1fr}.result-sidebar{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);overflow-y:auto;max-height:calc(100vh - 100px);position:sticky;top:68px}.result-sidebar-item{display:flex;flex-direction:column;align-items:center;width:100%;padding:.5rem;background:none;border:none;border-bottom:1px solid var(--color-border);border-radius:0;cursor:pointer;transition:background .1s;gap:.3rem}.result-sidebar-item:last-child{border-bottom:none}.result-sidebar-item:hover{background:var(--color-bg)}.result-sidebar-item.active{background:#e3f2fd}.result-sidebar-item img{width:100%;max-width:120px;height:90px;object-fit:contain;border-radius:3px}.result-sidebar-label{font-size:.65rem;color:var(--color-text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%;text-align:center}.result-sidebar-item.active .result-sidebar-label{color:var(--color-primary)}.result-sidebar-item.sidebar-pending{opacity:.45;cursor:default}.result-sidebar-item.sidebar-pending:hover{background:transparent}.result-sidebar-thumb-wrap{position:relative;width:100%;display:flex;justify-content:center}.sidebar-item-spinner{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#fff9;border-radius:3px}.sidebar-item-spinner:after{content:"";width:20px;height:20px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.result-progress-inline{padding:.5rem 0 .25rem}.result-content{display:flex;flex-direction:column;gap:1rem;min-width:0}.result-page-nav{display:flex;align-items:center;gap:.5rem}.btn-nav{background:var(--color-surface);border:1px solid var(--color-border);padding:.35rem .75rem;font-size:1rem;border-radius:var(--radius);flex-shrink:0}.btn-nav:hover:not(:disabled){background:var(--color-bg)}.result-page-select{flex:1;font-family:inherit;font-size:.875rem;padding:.35rem .5rem;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text);cursor:pointer;min-width:0}.result-main{display:grid;grid-template-columns:1fr 400px;gap:1rem;align-items:start}@media(max-width:900px){.result-section{grid-template-columns:1fr}.result-sidebar{position:static;display:flex;flex-direction:row;overflow-x:auto;overflow-y:hidden;max-height:none}.result-sidebar-item{flex-shrink:0;width:80px;border-bottom:none;border-right:1px solid var(--color-border)}.result-sidebar-item:last-child{border-right:none}.result-sidebar-item img{height:60px}.result-main{grid-template-columns:1fr}}.result-left,.result-right{min-width:0}.new-process-section{margin-top:.5rem;text-align:center}.image-viewer{position:relative;display:inline-block;width:100%;user-select:none}.viewer-image{width:100%;display:block;border-radius:var(--radius);border:1px solid var(--color-border)}.viewer-overlay{position:absolute;top:0;left:0;pointer-events:none}.region-box{position:absolute;border:2px solid var(--color-primary);background:var(--color-region);cursor:pointer;pointer-events:all;transition:background .1s}.region-box:hover{background:#1976d280}.region-box.selected{border-color:#e65100;background:#e6510066}.drag-selection{position:absolute;border:2px dashed var(--color-primary);background:#1976d226;pointer-events:none}.result-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden}.result-panel.empty{padding:2rem;text-align:center;color:var(--color-text-secondary)}.result-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:var(--color-bg);border-bottom:1px solid var(--color-border)}.result-filename{font-size:.875rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:200px}.result-stats{font-size:.75rem;color:var(--color-text-secondary);white-space:nowrap}.result-text{padding:1rem;max-height:60vh;overflow-y:auto}.no-text{color:var(--color-text-secondary);font-style:italic}.selected-text-label{font-size:.75rem;color:var(--color-text-secondary);margin-bottom:.25rem}.selected-text{font-size:1.1rem;font-weight:500;padding:.5rem .75rem;background:#fff8e1;border-radius:var(--radius);margin-bottom:.75rem}.divider{margin:.75rem 0;border:none;border-top:1px solid var(--color-border)}.full-text{font-size:.875rem;line-height:1.8;white-space:pre-wrap;word-break:break-all}.result-actions{display:flex;flex-direction:column;gap:.5rem;padding:.75rem 1rem;background:var(--color-bg);border:1px solid var(--color-border);border-top:none;border-radius:0 0 var(--radius) var(--radius)}.result-actions-option{display:flex;align-items:center;gap:.4rem;font-size:.8rem;color:var(--color-text-secondary);cursor:pointer;user-select:none}.result-actions-option input[type=checkbox]{cursor:pointer}.result-actions-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.panel-overlay{position:fixed;inset:0;background:#0006;z-index:200;display:flex;align-items:center;justify-content:center;padding:1rem}.panel{background:var(--color-surface);border-radius:var(--radius);box-shadow:var(--shadow);width:100%;max-width:720px;max-height:80vh;display:flex;flex-direction:column}.panel-small{max-width:480px}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--color-border)}.panel-header h2{font-size:1.1rem}.panel-body{flex:1;overflow-y:auto;padding:1rem 1.25rem}.panel-footer{padding:.75rem 1.25rem;border-top:1px solid var(--color-border);display:flex;justify-content:flex-end}.history-list{list-style:none}.history-item{display:flex;gap:.75rem;padding:.75rem;border:1px solid var(--color-border);border-radius:var(--radius);margin-bottom:.5rem;cursor:pointer;transition:background .1s}.history-item:hover{background:var(--color-bg)}.history-thumb{width:48px;height:60px;object-fit:cover;border-radius:3px;flex-shrink:0}.history-info{display:flex;flex-direction:column;gap:.2rem;min-width:0}.history-filename{font-size:.875rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.history-date{font-size:.75rem;color:var(--color-text-secondary)}.history-preview{font-size:.75rem;color:var(--color-text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.empty-message{color:var(--color-text-secondary);text-align:center;padding:2rem}.settings-section{margin-bottom:1.5rem}.settings-section h3{font-size:.9rem;margin-bottom:.5rem}.settings-description{font-size:.8rem;color:var(--color-text-secondary);margin-bottom:.75rem;line-height:1.5}.footer{background:var(--color-surface);border-top:1px solid var(--color-border);padding:1rem 1.5rem}.footer-privacy{display:flex;align-items:flex-start;gap:.5rem;font-size:.8rem;color:var(--color-text-secondary);margin-bottom:.5rem}.privacy-icon{flex-shrink:0}.footer-meta{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.footer-attribution{font-size:.75rem;color:var(--color-text-secondary);margin-bottom:.4rem;line-height:1.5}.footer-attribution-text a{color:var(--color-primary)}.footer-author{font-size:.75rem;color:var(--color-text-secondary)}.footer-github{font-size:.75rem}.region-select-hint{margin:.4rem 0 0;font-size:.75rem;color:var(--color-text-secondary);text-align:center}.region-ocr-backdrop{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:200}.region-ocr-dialog{background:var(--color-surface);border-radius:10px;box-shadow:0 8px 32px #0000004d;width:min(480px,92vw);max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.region-ocr-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid var(--color-border);flex-shrink:0}.region-ocr-title{font-weight:600;font-size:.95rem}.region-ocr-close{background:none;border:none;cursor:pointer;font-size:1.25rem;color:var(--color-text-secondary);line-height:1;padding:.1rem .3rem;border-radius:4px;transition:background .15s}.region-ocr-close:hover{background:var(--color-border)}.region-ocr-preview-wrap{padding:.75rem 1rem;background:var(--color-bg);border-bottom:1px solid var(--color-border);flex-shrink:0;display:flex;justify-content:center}.region-ocr-preview{max-height:200px;max-width:100%;object-fit:contain;border-radius:4px}.region-ocr-body{padding:.75rem 1rem;flex:1;overflow:auto;min-height:80px;display:flex;align-items:flex-start}.region-ocr-processing{display:flex;align-items:center;gap:.6rem;color:var(--color-text-secondary);font-size:.9rem;padding:.5rem 0}.region-ocr-textarea{width:100%;min-height:100px;resize:vertical;padding:.5rem;border:1px solid var(--color-border);border-radius:6px;background:var(--color-bg);color:var(--color-text);font-size:.9rem;line-height:1.6;font-family:inherit}.region-ocr-empty{color:var(--color-text-secondary);font-size:.9rem;margin:0;padding:.5rem 0}.region-ocr-footer{padding:.75rem 1rem;border-top:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
