:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}#root{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}}.video-scanner{position:relative;width:100%;height:100vh;background:#000;display:flex;flex-direction:column;justify-content:center;align-items:center}.video-feed{width:100%;height:100%;object-fit:cover}.scanner-overlay{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;display:flex;justify-content:center;align-items:center}.scan-area{display:none}.scanner-info{position:absolute;bottom:60px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:12px}.frame-counter{background:#000000b3;color:#fff;padding:12px 20px;border-radius:25px;display:flex;align-items:center;gap:8px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);font-size:14px;font-weight:600}.counter-label{opacity:.8}.counter-value{background:#0f0;color:#000;padding:4px 12px;border-radius:15px;font-weight:700;min-width:30px;text-align:center}.scanner-mode{background:#007bffe6;color:#fff;padding:8px 16px;border-radius:15px;font-size:12px;font-weight:600;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.qr-detected{background:#28a745e6;color:#fff;padding:6px 12px;border-radius:12px;font-size:11px;font-weight:600;animation:flash .5s ease-in-out}@keyframes flash{0%{background:#28a745e6}50%{background:#28a745;transform:scale(1.05)}to{background:#28a745e6}}.scanning-indicator{background:#007bffe6;color:#fff;padding:12px 20px;border-radius:25px;display:flex;align-items:center;gap:8px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);font-size:14px;font-weight:600;animation:scanPulse 2s infinite}.scanning-indicator.waiting-api{background:#ffc107e6;color:#000;animation:waitingPulse 1.5s infinite}.scanning-indicator.qr-loading-border{border:2px solid #ffc107}.scanning-indicator.qr-active-border{border:2px solid #00ff00}.scanning-indicator.qr-error-border{border:2px solid #dc3545;background:#dc3545e6}.qr-error-details{background:#dc3545e6;color:#fff;padding:12px 16px;border-radius:12px;font-size:12px;font-weight:500;max-width:300px;text-align:left}.qr-error-details .error-message{margin-bottom:12px;opacity:.9}.qr-error-details .error-troubleshooting{font-size:11px;opacity:.8}.qr-error-details .error-troubleshooting strong{display:block;margin-bottom:4px}.qr-error-details .error-troubleshooting ul{margin:0;padding-left:16px;list-style-type:disc}.qr-error-details .error-troubleshooting li{margin-bottom:2px}@keyframes scanPulse{0%{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.02)}to{opacity:1;transform:scale(1)}}@keyframes waitingPulse{0%{opacity:1}50%{opacity:.7}to{opacity:1}}.scanning-dot{width:12px;height:12px;border-radius:50%;background:#0f0;display:inline-block;animation:scanDot 2s infinite}.scanning-dot.waiting-api{background:#ff6b35;animation:waitingDot 1.5s infinite}@keyframes scanDot{0%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}to{opacity:1;transform:scale(1)}}@keyframes waitingDot{0%{opacity:1;transform:scale(1)}25%{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1.1)}75%{opacity:.3;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.video-scanner.error{background:#f8f9fa;color:#333}.error-message{text-align:center;padding:40px}.error-message h3{color:#dc3545;margin-bottom:16px}.error-help{font-size:14px;color:#888;margin-top:16px}.video-scanner.permission{background:#f8f9fa;color:#333}.permission-prompt{text-align:center;padding:40px;max-width:400px}.permission-help{font-size:14px;color:#888;margin-top:16px;max-width:300px;line-height:1.4}.video-scanner.loading{background:#f8f9fa;color:#333}.loading-spinner{text-align:center;padding:40px}@media (max-width: 768px){.scan-area{width:240px;height:240px}.scanner-info{bottom:40px}.frame-counter{padding:10px 16px;font-size:13px}.scanner-mode{padding:6px 12px;font-size:11px}.qr-error-details,.qr-detected{font-size:10px;padding:5px 10px}}.product-result{position:fixed;top:0;left:0;width:100%;height:100vh;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);display:flex;justify-content:center;align-items:center;padding:20px;box-sizing:border-box;overflow-y:auto}.product-content{background:#fff;border-radius:16px;padding:32px;max-width:500px;width:100%;text-align:center;box-shadow:0 20px 40px #0000001a;max-height:90vh;overflow-y:auto}.product-image-container{margin-bottom:32px}.product-image{max-width:100%;max-height:300px;width:auto;height:auto;border-radius:12px;box-shadow:0 8px 24px #00000026}.product-details{margin-bottom:32px;text-align:left}.product-title{font-size:28px;font-weight:700;color:#333;margin:0 0 16px;line-height:1.3;text-align:center}.product-subtitle{font-size:18px;color:#666;margin:0 0 24px;line-height:1.5;text-align:center}.additional-info{border-top:1px solid #e0e0e0;padding-top:24px;margin-top:24px}.info-item{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid #f5f5f5}.info-item:last-child{border-bottom:none}.info-label{font-weight:600;color:#555;text-transform:capitalize;flex:1;text-align:left}.info-value{color:#333;flex:1;text-align:right;word-break:break-word}.result-actions{display:flex;flex-direction:column;gap:12px;margin-top:24px}.scan-another-button{padding:16px 32px;background:#007bff;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease}.scan-another-button:hover{background:#0056b3;transform:translateY(-2px);box-shadow:0 4px 12px #007bff4d}.scan-another-button:active{transform:translateY(0)}@media (max-width: 768px){.product-result{padding:40px 16px 16px;align-items:flex-start}.product-content{padding:24px;max-height:85vh}.product-title{font-size:24px}.product-subtitle{font-size:16px}.info-item{flex-direction:column;align-items:flex-start;gap:4px}.info-label,.info-value{text-align:left}.result-actions{gap:16px;margin-top:32px}}@media (max-height: 600px){.product-content{max-height:95vh;padding:20px}.product-image{max-height:200px}.product-image-container{margin-bottom:20px}}.timeout-screen{position:fixed;top:0;left:0;width:100%;height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;align-items:center;z-index:1000}.timeout-content{background:#fff;padding:48px 32px;border-radius:16px;text-align:center;max-width:400px;margin:20px;box-shadow:0 20px 40px #0000001a}.timeout-icon{font-size:64px;margin-bottom:24px;display:block}.timeout-screen h2{color:#333;margin:0 0 16px;font-size:28px;font-weight:600}.timeout-screen p{color:#666;margin:0 0 16px;font-size:16px;line-height:1.5}.timeout-subtitle{font-size:14px;color:#888;margin-bottom:32px!important}.timeout-actions{display:flex;flex-direction:column;gap:12px}.retry-button{padding:16px 32px;background:#28a745;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease}.retry-button:hover{background:#218838;transform:translateY(-2px);box-shadow:0 4px 12px #28a7454d}.retry-button:active{transform:translateY(0)}.back-button{padding:12px 24px;background:transparent;color:#666;border:2px solid #e0e0e0;border-radius:8px;font-size:14px;cursor:pointer;transition:all .2s ease}.back-button:hover{border-color:#666;color:#333}@media (max-width: 768px){.timeout-content{margin:20px;padding:40px 24px}.timeout-icon{font-size:56px}.timeout-screen h2{font-size:24px}.timeout-actions{gap:16px}}.app{position:relative;width:100%;height:100vh;overflow:hidden}.qr-detected-indicator{position:absolute;top:20px;left:20px;right:20px;background:#28a745e6;color:#fff;padding:12px 16px;border-radius:8px;font-size:14px;font-weight:600;text-align:center;z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:slideDown .3s ease-out}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}html,body,#root{height:100%;width:100%;margin:0;padding:0}
