.barcode-scanner-overlay{z-index:9999;background-color:#000c;flex-direction:column;justify-content:center;align-items:center;width:100vw;height:100vh;padding:20px;display:none;position:fixed;inset:0}.barcode-scanner-container{width:100%;height:0;box-shadow:none;background-color:#000;border-radius:8px;margin-bottom:1rem;padding-bottom:75%;transition:all .3s;position:relative;overflow:hidden}.barcode-scanner-overlay .barcode-scanner-container{aspect-ratio:4/3;width:100%;max-width:800px;height:auto;max-height:70vh;margin-bottom:0;padding-bottom:0}.barcode-scanner-video{object-fit:cover;width:100%;height:100%;position:absolute;top:0;left:0}.barcode-scanner-canvas{display:none}.barcode-scanner-close{color:#333;cursor:pointer;z-index:10;appearance:none;background-color:#ffffffe6;border:none;outline:none;justify-content:center;align-items:center;width:80px;height:80px;margin-top:40px;padding:0;font-size:48px;line-height:1;transition:background-color .3s;display:flex;border-radius:50%!important}.barcode-scanner-close:hover{background-color:#fff}.barcode-scanner-line{z-index:5;background-color:#ff3b30;width:100%;height:3px;animation:2s linear infinite barcode-scanner-line;position:absolute;top:0;left:0}@keyframes barcode-scanner-line{0%{top:0}50%{top:calc(100% - 3px)}to{top:0}}.barcode-scanner-fullscreen{z-index:9999;border-radius:0;width:100vw;height:100vh;padding-bottom:0;position:fixed;top:0;left:0}body.barcode-scanner-active{overflow:hidden}.barcode-scanner-controls{gap:.5rem;margin-bottom:1rem;display:flex}.barcode-scanner-button{cursor:pointer;border:none;border-radius:4px;flex:1;padding:.75rem .5rem;font-size:.9rem;transition:background-color .3s}.barcode-scanner-button:disabled{opacity:.6;cursor:not-allowed}.barcode-scanner-start{color:#fff;background-color:#4a6cf7}.barcode-scanner-start:hover:not(:disabled){background-color:#3a5ce6}.barcode-scanner-stop{color:#fff;background-color:#f44336}.barcode-scanner-stop:hover:not(:disabled){background-color:#d32f2f}.barcode-scanner-switch{color:#fff;background-color:#4caf50}.barcode-scanner-switch:hover:not(:disabled){background-color:#388e3c}.barcode-scanner-result-container{background-color:#fff;border-radius:8px;margin-top:1rem;padding:1rem;box-shadow:0 2px 8px #0000001a}.barcode-scanner-result-title{margin-top:0;margin-bottom:.5rem;font-size:1.25rem}.barcode-scanner-result{word-break:break-all;background-color:#f0f0f0;border-radius:4px;min-height:3rem;padding:.75rem;font-family:monospace}@media (width>=768px){.barcode-scanner-container{max-height:400px;padding-bottom:56.25%}.barcode-scanner-fullscreen{max-height:none;padding-bottom:0}.barcode-scanner-overlay .barcode-scanner-container{padding-bottom:0}}@media screen and (width<=768px){.barcode-scanner-close{width:70px;height:70px;margin-top:30px;padding:0;font-size:40px;border-radius:50%!important}}