*{margin:0;padding:0;box-sizing:border-box}:root{--primary-color: #2563eb;--primary-hover: #1d4ed8;--secondary-color: #6b7280;--danger-color: #dc2626;--success-color: #16a34a;--warning-color: #f59e0b;--bg-color: #f3f4f6;--card-bg: #ffffff;--text-color: #1f2937;--text-muted: #6b7280;--border-color: #e5e7eb;--shadow: 0 1px 3px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--capture-bg: #ffffff;--capture-border: #ffffff}[data-theme=dark]{--primary-color: #3b82f6;--primary-hover: #2563eb;--secondary-color: #4b5563;--bg-color: #111827;--card-bg: #1f2937;--text-color: #f9fafb;--text-muted: #9ca3af;--border-color: #374151;--shadow: 0 1px 3px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .3);--capture-bg: #1f2937;--capture-border: #374151}html,body{height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-color);color:var(--text-color);min-height:100vh;-webkit-tap-highlight-color:transparent}.container{max-width:600px;margin:0 auto;padding:12px;min-height:100vh;display:flex;flex-direction:column}header{text-align:center;padding:16px 0}.header-row{display:flex;align-items:center;justify-content:center;gap:12px}header h1{font-size:1.5rem;color:var(--primary-color);margin-bottom:4px}.btn-theme{width:36px;height:36px;border:none;background:var(--card-bg);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow)}.theme-icon{width:20px;height:20px;stroke:var(--text-color)}.theme-icon-dark,[data-theme=dark] .theme-icon-light{display:none}[data-theme=dark] .theme-icon-dark{display:block}.subtitle{color:var(--text-muted);font-size:.9rem}main{flex:1;display:flex;flex-direction:column}.tabs{display:flex;background:var(--card-bg);border-radius:12px;padding:4px;margin-bottom:16px;box-shadow:var(--shadow)}.tab{flex:1;padding:10px 8px;border:none;background:transparent;border-radius:8px;font-size:.8rem;font-weight:500;color:var(--text-muted);cursor:pointer;transition:all .2s;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px}.tab-icon{width:20px;height:20px;stroke:currentColor}.tab.active{background:var(--primary-color);color:#fff}.tab .badge{background:var(--danger-color);color:#fff;font-size:.65rem;padding:2px 5px;border-radius:10px;min-width:16px;position:absolute;top:4px;right:4px}.tab{position:relative}.tab.active .badge{background:#fff;color:var(--primary-color)}.tab-content{display:none;flex:1}.tab-content.active{display:block}.camera-wrapper{display:flex;flex-direction:column;gap:12px}.camera-container{position:relative;background:#000;border-radius:16px;overflow:hidden;aspect-ratio:4/3;width:100%}#cameraVideo{width:100%;height:100%;object-fit:cover}.camera-placeholder{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#1a1a2e;color:#fff;cursor:pointer}.camera-placeholder.hidden{display:none}.placeholder-icon{width:64px;height:64px;stroke:#fff;margin-bottom:12px}.camera-hint{font-size:.85rem;color:#ffffffb3;margin-top:8px;text-align:center;padding:0 16px}.camera-overlay{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none}.scan-region{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:70%;height:70%;border:2px solid rgba(37,99,235,.8);border-radius:12px;box-shadow:0 0 0 9999px #0000004d}.scan-region:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--primary-color);animation:scan 2s ease-in-out infinite}@keyframes scan{0%,to{top:0}50%{top:calc(100% - 2px)}}.camera-controls{display:flex;align-items:center;justify-content:center;gap:24px;padding:8px}.btn-icon{width:48px;height:48px;border-radius:50%;background:var(--card-bg);border:none;cursor:pointer;box-shadow:var(--shadow);display:flex;align-items:center;justify-content:center;color:var(--text-color);transition:all .2s}.btn-icon:hover{background:var(--bg-color)}.btn-icon:active{transform:scale(.95)}.btn-round{width:52px;height:52px;padding:0;border-radius:50%}.btn-round .btn-icon-svg{width:24px;height:24px}.btn-capture{width:68px;height:68px;padding:0;border-radius:50%;background:transparent;border:4px solid var(--capture-border);cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0003}.capture-inner{width:54px;height:54px;background:var(--capture-bg);border-radius:50%;display:block;transition:transform .1s ease}.btn-capture:active .capture-inner{transform:scale(.9)}.btn-round.flash-on{background:var(--warning-color)}.camera-status{text-align:center;font-size:.85rem;color:var(--text-muted);min-height:20px}.camera-status.success{color:var(--success-color)}.camera-status.error{color:var(--danger-color)}.auto-scan-toggle{display:flex;align-items:center;justify-content:center;gap:12px;padding:12px;background:var(--card-bg);border-radius:12px;font-size:.9rem}.switch{position:relative;width:48px;height:28px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:var(--border-color);border-radius:28px;transition:.3s}.slider:before{content:"";position:absolute;height:22px;width:22px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.3s}input:checked+.slider{background:var(--primary-color)}input:checked+.slider:before{transform:translate(20px)}.upload-area{background:var(--card-bg);border:2px dashed var(--border-color);border-radius:16px;padding:40px 20px;text-align:center;cursor:pointer;transition:all .3s ease}.upload-area:hover,.upload-area.dragover{border-color:var(--primary-color);background:#2563eb0d}.upload-icon{width:64px;height:64px;margin:0 auto 12px;stroke:var(--text-muted)}.upload-hint{color:var(--text-muted);font-size:.85rem;margin-top:8px}.upload-actions{display:flex;gap:12px;margin-top:16px}.upload-actions .btn{flex:1}.btn{padding:14px 24px;border:none;border-radius:12px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn:disabled{opacity:.5;cursor:not-allowed}.btn:active:not(:disabled){transform:scale(.98)}.btn-icon-svg{width:18px;height:18px;flex-shrink:0;stroke:currentColor}.btn-primary{background:var(--primary-color);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-secondary{background:var(--secondary-color);color:#fff}.btn-secondary:hover:not(:disabled){background:#4b5563}.btn-danger{background:var(--danger-color);color:#fff}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-sm{padding:8px 12px;font-size:.85rem;border-radius:8px}.btn-sm .btn-icon-svg{width:14px;height:14px}.results-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;flex-wrap:wrap;gap:8px}.results-header h2{font-size:1.1rem}.results-actions{display:flex;gap:8px}#resultsCount{color:var(--text-muted);font-size:.85rem;font-weight:400}.results-list{display:flex;flex-direction:column;gap:12px}.no-results{color:var(--text-muted);text-align:center;padding:40px;background:var(--card-bg);border-radius:12px}.result-item{background:var(--card-bg);border-radius:12px;padding:16px;box-shadow:var(--shadow)}.result-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.result-thumbnail{width:48px;height:48px;object-fit:cover;border-radius:8px;flex-shrink:0}.result-meta{flex:1;min-width:0}.result-filename{font-size:.8rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.result-format{display:inline-block;padding:2px 8px;background:var(--primary-color);color:#fff;border-radius:4px;font-size:.7rem;font-weight:600;margin-top:4px}.result-text{font-family:SF Mono,Consolas,monospace;background:var(--bg-color);padding:12px;border-radius:8px;word-break:break-all;font-size:.9rem;line-height:1.4}.result-error{color:var(--danger-color);font-size:.9rem}.result-actions{display:flex;gap:8px;margin-top:12px}.toast-container{position:fixed;bottom:80px;left:50%;transform:translate(-50%);z-index:1001;display:flex;flex-direction:column;gap:8px}.toast{background:var(--text-color);color:#fff;padding:12px 20px;border-radius:8px;font-size:.9rem;animation:slideUp .3s ease;white-space:nowrap}.toast.success{background:var(--success-color)}.toast.error{background:var(--danger-color)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:none;align-items:center;justify-content:center;flex-direction:column;z-index:1000}.loading-overlay.active{display:flex}.spinner{width:48px;height:48px;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-overlay p{color:#fff;margin-top:16px;font-size:1rem}footer{text-align:center;padding:16px;color:var(--text-muted);font-size:.8rem}@media (min-width: 768px){.container{max-width:800px;padding:20px}header h1{font-size:2rem}.tabs{max-width:400px;margin:0 auto 24px}.tab{flex-direction:row;gap:8px;font-size:.9rem;padding:12px 16px}.camera-container{max-width:500px;margin:0 auto}.upload-area{padding:60px 40px}.results-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}}@media (hover: none){.btn:active{opacity:.8}}@supports (padding: max(0px)){.container{padding-left:max(12px,env(safe-area-inset-left));padding-right:max(12px,env(safe-area-inset-right));padding-bottom:max(12px,env(safe-area-inset-bottom))}}
