:root{color-scheme:light;font-family:Inter,Segoe UI,Arial,sans-serif;background:#f5f7fb;color:#111827}body{margin:0}.page{max-width:1100px;margin:0 auto;padding:32px 20px 60px}.nav{display:flex;gap:12px;margin-bottom:24px}.nav a{text-decoration:none;color:#374151;background:#fff;border:1px solid #e5e7eb;padding:8px 14px;border-radius:999px;font-weight:600}.nav a.active{color:#111827;border-color:#111827}header h1{margin:0 0 8px}header p{margin:0 0 24px;color:#4b5563}.info-panel{margin-top:12px;padding:12px 14px;border-radius:12px;background:#f8fafc;border:1px solid #e5e7eb;color:#374151}.info-panel summary{font-weight:600;cursor:pointer}.info-panel div{margin-top:8px;font-size:.95rem;color:#4b5563}.controls{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.control-group{display:flex;flex-direction:column;gap:6px;flex:1;min-width:0}.control-row{display:flex;gap:40px;align-items:flex-start}.select{display:inline-flex;align-items:center;gap:12px;padding:10px 14px;border:1px solid #d1d5db;border-radius:10px;background:#fff;width:100%;justify-content:space-between}.select select{border:none;background:transparent;font-size:.95rem;min-width:0;flex:1}.select input{border:none;background:transparent;font-size:.95rem;flex:1;text-align:right}.select.checkbox{gap:8px}.select.checkbox input{width:16px;height:16px}.file{display:inline-flex;align-items:center;gap:12px;padding:10px 14px;border:1px solid #d1d5db;border-radius:10px;background:#fff;cursor:pointer}.file input{cursor:pointer}.status{font-size:.95rem;color:#4b5563}.model-help{font-size:.9rem;color:#6b7280;min-height:1.2em}.file{width:100%;justify-content:space-between}.primary{border:none;border-radius:10px;padding:10px 18px;background:#2563eb;color:#fff;font-weight:600;cursor:pointer;min-width:160px}.primary:disabled{opacity:.6;cursor:not-allowed}.secondary{border:1px solid #d1d5db;border-radius:10px;padding:10px 18px;background:#fff;color:#374151;font-weight:600;cursor:pointer}.secondary:hover{border-color:#9ca3af}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}.grid h2{margin-bottom:8px}img{width:100%;max-height:420px;object-fit:contain;background:#f3f4f6;border-radius:12px;border:1px solid #e5e7eb}.placeholder{height:320px;display:grid;place-items:center;background:#f3f4f6;border-radius:12px;border:1px dashed #d1d5db;color:#9ca3af}.placeholder-page .placeholder{height:420px}.loading-bar{width:70%;height:10px;border-radius:999px;background:linear-gradient(90deg,#dbeafe,#60a5fa,#dbeafe);background-size:200% 100%;animation:loadingBar 1.2s ease-in-out infinite}@keyframes loadingBar{0%{background-position:0% 0%}to{background-position:200% 0%}}.batch{margin-top:32px}.batch-header-row{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:12px}.batch-download{border:none;border-radius:999px;padding:8px 16px;background:#111827;color:#fff;cursor:pointer}.batch-download:disabled{opacity:.6;cursor:not-allowed}.batch-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}.batch-card{border:1px solid #e5e7eb;border-radius:12px;padding:12px;background:#fff}.batch-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;gap:8px}.batch-name{font-size:.9rem;font-weight:600;color:#111827;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.badge{font-size:.75rem;padding:2px 8px;border-radius:999px;text-transform:capitalize}.badge-pending{background:#e5e7eb;color:#374151}.badge-uploading{background:#dbeafe;color:#1d4ed8}.badge-done{background:#dcfce7;color:#166534}.badge-error{background:#fee2e2;color:#991b1b}.batch-images{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:8px}.placeholder.small{height:140px}.recognition .control-row{gap:24px;align-items:center}.results{margin-top:24px}.results-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}.candidate-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:8px}.result-card{border:1px solid #e5e7eb;border-radius:12px;padding:12px;background:#fff}.result-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-weight:600}.result-meta{color:#4b5563;font-size:.9rem}.match{color:#166534}.no-match{color:#991b1b}.error{margin-top:8px;color:#b91c1c;font-size:.9rem}.helper{margin:0;color:#6b7280;font-size:.9rem;line-height:1.4}.progress-row{display:flex;align-items:center;gap:12px;margin-top:8px}.progress-bar{flex:1;height:8px;background:#e5e7eb;border-radius:999px;overflow:hidden}.progress-bar-fill{height:100%;background:#2563eb;border-radius:999px;transition:width .2s ease}.progress-text{font-size:.85rem;color:#4b5563;min-width:52px;text-align:right}.emphasis{font-weight:600;color:#111827}.batch-error{font-size:.8rem;color:#b91c1c;margin-bottom:8px}.download{display:inline-flex;margin-top:12px;text-decoration:none;background:#2563eb;color:#fff;padding:8px 14px;border-radius:8px}.download.disabled{pointer-events:none;opacity:.5}.api{margin-top:32px;padding:16px;border-radius:12px;background:#eef2ff;color:#3730a3}.api-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;margin-top:12px}.api-card h3{margin:0 0 8px}.code-block{margin-top:12px;background:#111827;color:#e5e7eb;padding:12px;border-radius:10px;font-size:.85rem;overflow-x:auto}.api-preview{margin-top:16px}.api-preview h3{margin:0 0 8px}
