.scan2mag-layout{--scan-utility-footer-height: 4.75rem;--scan-utility-footer-safe-height: calc(var(--scan-utility-footer-height) + env(safe-area-inset-bottom));--scan-product-actions-height: 5.5rem;--cart-actions-height: 5.5rem;--local-products-actions-height: 5.5rem;height:100%;overflow:hidden}.app-content{box-sizing:border-box;min-height:0;overflow:auto;padding-bottom:var(--scan-utility-footer-safe-height)}.app-navbar-title,.drawer-content{width:100%}.app-navbar-title{flex:1;align-items:center}.app-navbar-actions{margin-inline-start:auto;padding-inline-end:var(--vaadin-padding-s);gap:var(--vaadin-gap-xs);align-items:center}.cart-navbar-button{position:relative;min-width:2.5rem}.cart-navbar-button::part(label){padding:0}.cart-navbar-badge{position:absolute;inset-block-start:-.35rem;inset-inline-end:-.5rem;min-width:1.15rem;height:1.15rem;padding-inline:.2rem;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:var(--vaadin-text-color);color:var(--vaadin-background-color);font-size:.68rem;font-weight:700;line-height:1;pointer-events:none}.scan-view{box-sizing:border-box;min-height:calc(100dvh - 112px);display:grid;place-items:center;overflow:auto;padding:0 0 var(--scan-utility-footer-safe-height)}.scan-view--product{display:block;padding-bottom:calc(var(--scan-utility-footer-safe-height) + var(--scan-product-actions-height) + var(--vaadin-gap-l))}.scan-ready-card{width:min(348px,calc(100vw - 64px));min-height:min(432px,calc(100vh - 280px));display:grid;place-items:center;align-content:center;gap:var(--vaadin-gap-l);border-radius:32px;background:var(--vaadin-background-color)}.scan-ready-barcode{color:var(--aura-accent-color);width:44px;height:36px;display:inline-grid;grid-template-columns:3px 7px 4px 2px 8px 3px 5px;column-gap:3px;align-items:stretch;justify-content:center}.scan-ready-barcode span{width:100%;height:100%;border-radius:2px;background:currentColor}.scan-ready-text{color:var(--vaadin-text-color-secondary);font-size:.78rem;font-weight:700;letter-spacing:.28em}.scan-product-card{width:min(560px,100%);min-height:auto;gap:0}.scan-product-shell{width:min(560px,100%);min-height:0;margin:0 auto}.scan-product-scroll{overflow:visible;padding-bottom:var(--vaadin-padding-m)}.scan-product-actions{position:fixed;inset-inline-start:50%;inset-block-end:calc(var(--scan-utility-footer-safe-height) + var(--vaadin-gap-s));transform:translate(-50%);width:min(560px,calc(100vw - 32px));padding:var(--vaadin-padding-s);box-sizing:border-box;border-radius:var(--vaadin-radius-l);background:color-mix(in srgb,var(--vaadin-background-color) 96%,transparent);backdrop-filter:blur(12px);z-index:2;box-shadow:var(--aura-shadow-s)}.scan-product-stage{position:relative;width:100%;aspect-ratio:1 / 1;overflow:hidden;border-radius:24px;background:var(--vaadin-background-container)}.scan-product-image,.image-stage{width:100%;height:100%;display:grid;place-items:center;overflow:hidden;touch-action:pan-y}.scan-product-image img,.image-stage img{max-width:100%;max-height:100%;object-fit:contain}.scan-image-controls{position:absolute;inset-inline:0;inset-block-end:0;width:100%;margin:0;padding:var(--vaadin-padding-s) var(--vaadin-padding-s) calc(var(--vaadin-padding-s) + env(safe-area-inset-bottom));display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:var(--vaadin-gap-s);box-sizing:border-box;background:#ffffffa1}.scan-image-controls>:first-child,.scan-image-controls>:last-child{justify-self:center}.scan-image-controls>:nth-child(2){justify-self:center;color:var(--vaadin-text-color-secondary);font-size:.78rem}.scan-image-arrow{min-width:2.25rem;padding-inline:0;color:var(--vaadin-text-color-secondary)}.scan-image-arrow::part(label){padding:0}.scan-image-arrow vaadin-icon{width:1rem;height:1rem}.scan-product-facts,.scan-quantity-row,.manual-scan,.order-actions,.order-item,.gallery-controls,.local-product-row{width:100%;align-items:center}.scan-product-details,.order-panel,.order-items,.local-product-list,.product-preview-dialog{width:100%}.local-product-list{gap:var(--vaadin-gap-s)}.local-products-page{width:100%;box-sizing:border-box;padding-bottom:calc(var(--scan-utility-footer-safe-height) + var(--local-products-actions-height) + var(--vaadin-gap-l))}.scan-product-details h3{margin:0;text-align:center;text-wrap:wrap}.scan-meta-row{width:100%;display:flex;justify-content:space-between;align-items:center;gap:var(--vaadin-gap-s);padding-block:.35rem}.scan-meta-text{color:var(--vaadin-text-color-secondary);font-size:.75rem;font-weight:500;line-height:1.2;white-space:nowrap}.scan-stats-row{width:100%;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--vaadin-gap-s)}.scan-stat-card{display:grid;gap:.25rem;padding:var(--vaadin-padding-m);border-radius:var(--vaadin-radius-m);background:var(--vaadin-background-container);border:1px solid var(--vaadin-border-color-secondary);min-width:0;text-align:center}.scan-stat-value{color:var(--vaadin-text-color);font-size:1.2rem;font-weight:800;line-height:1}.scan-stat-unit{margin-inline-start:.25rem;font-size:.78rem;font-weight:600;color:var(--vaadin-text-color-secondary)}.scan-description{display:grid;gap:.15rem;padding-block:.35rem}.scan-description-text{color:var(--vaadin-text-color-secondary);font-size:.78rem;line-height:1.35}.scan-product-choice-list{width:min(100%,28rem)}.search-empty-state{color:var(--vaadin-text-color-secondary);font-size:.82rem}.scan-product-choice{width:100%;justify-content:flex-start;text-align:left;padding:var(--vaadin-padding-s);border-radius:var(--vaadin-radius-m);background:var(--vaadin-background-container);border:1px solid var(--vaadin-border-color-secondary);box-sizing:border-box}.scan-product-choice::part(label){width:100%;padding:0}.scan-product-choice-thumb{width:44px;height:44px;display:inline-grid;place-items:center;flex:none;overflow:hidden;border-radius:var(--vaadin-radius-s);background:color-mix(in srgb,var(--vaadin-background-color) 85%,transparent)}.scan-product-choice-thumb img{width:100%;height:100%;object-fit:contain}.scan-product-choice-thumb span{color:var(--vaadin-text-color-secondary);font-size:.68rem;text-align:center}.scan-product-choice-details{min-width:0;display:inline-grid;gap:.2rem;margin-inline-start:var(--vaadin-gap-s)}.scan-product-choice-details strong{color:var(--vaadin-text-color);font-size:.92rem;white-space:normal}.scan-product-choice-details span{color:var(--vaadin-text-color-secondary);font-size:.76rem;white-space:normal}.product-preview-stage{position:relative;width:100%;min-height:52vh;display:grid;place-items:center;padding-bottom:3.25rem;box-sizing:border-box}.product-preview-stage img{max-width:100%;max-height:52vh;object-fit:contain}.product-preview-controls{position:absolute;inset-inline:0;inset-block-end:0;width:100%;margin:0;padding:0 var(--vaadin-padding-s);display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:var(--vaadin-gap-s);box-sizing:border-box}.product-preview-controls>:first-child,.product-preview-controls>:last-child{justify-self:center}.product-preview-controls>:nth-child(2){justify-self:center;color:var(--vaadin-text-color-secondary);font-size:.78rem}.scan-quantity-row vaadin-number-field,.manual-scan vaadin-text-field{flex:1}.scan-quantity-row vaadin-number-field{min-width:0}.scan-quantity-row vaadin-number-field::part(input-field){text-align:center}.order-actions{justify-content:space-between}.cart-item-controls{align-items:center}.cart-grid{width:100%}.cart-list-mobile{display:none;width:100%;gap:var(--vaadin-gap-s)}.cart-page{width:100%;box-sizing:border-box;padding-bottom:calc(var(--scan-utility-footer-safe-height) + var(--cart-actions-height) + var(--vaadin-gap-l))}.cart-grid::part(header-cell){font-size:.74rem}.cart-grid::part(body-cell){vertical-align:middle}.cart-product-cell{width:100%;align-items:center}.cart-product-cell img{width:40px;height:40px;object-fit:contain;flex:none}.cart-items,.cart-item,.cart-item-info{width:100%}.cart-item{align-items:center;padding:var(--vaadin-padding-s);border-radius:var(--vaadin-radius-m);background:var(--vaadin-background-container);border:1px solid var(--vaadin-border-color-secondary);box-sizing:border-box}.cart-item-info{flex:1;min-width:0}.cart-item-info>span{color:var(--vaadin-text-color-secondary);font-size:.78rem}.cart-item-controls{flex-wrap:nowrap}.cart-item-controls vaadin-number-field{width:7rem;min-width:6rem}.cart-item-controls vaadin-number-field::part(input-field){text-align:center}.cart-grid-qty{width:7rem;min-width:6rem}.cart-grid-qty::part(input-field){text-align:center}.cart-money-cell{white-space:nowrap}.cart-mobile-item{display:grid;width:100%;box-sizing:border-box;gap:var(--vaadin-gap-s);padding:var(--vaadin-padding-s);border-radius:var(--vaadin-radius-m);background:var(--vaadin-background-container);border:1px solid var(--vaadin-border-color-secondary)}.cart-mobile-main{display:grid;grid-template-columns:40px minmax(0,1fr);gap:var(--vaadin-gap-s);align-items:start}.cart-mobile-main img{width:40px;height:40px;object-fit:contain}.cart-mobile-info{min-width:0;display:grid;gap:.15rem}.cart-mobile-info>span,.cart-mobile-prices>span{color:var(--vaadin-text-color-secondary);font-size:.78rem}.cart-mobile-prices{display:flex;justify-content:space-between;align-items:baseline;gap:var(--vaadin-gap-s)}.cart-mobile-actions{display:flex;justify-content:space-between;align-items:center;gap:var(--vaadin-gap-s)}.cart-empty-state{color:var(--vaadin-text-color-secondary)}.local-product-card{width:100%;display:grid;gap:var(--vaadin-gap-xs);padding:var(--vaadin-padding-s);box-sizing:border-box;border-radius:var(--vaadin-radius-m);background:var(--vaadin-background-container);border:1px solid var(--vaadin-border-color-secondary)}.local-product-card-main{width:100%;display:grid;grid-template-columns:48px minmax(0,1fr) auto;gap:var(--vaadin-gap-s);align-items:start}.local-product-card-main img,.local-product-card-main .image-thumb-placeholder{width:48px;height:48px;object-fit:contain;flex:none}.local-product-info{min-width:0;display:grid;gap:.18rem}.local-product-info strong{color:var(--vaadin-text-color);font-size:.95rem;line-height:1.2;white-space:normal;overflow-wrap:anywhere}.local-product-info>span{color:var(--vaadin-text-color-secondary);font-size:.78rem;line-height:1.25}.local-product-price{color:var(--vaadin-text-color);font-size:.92rem;line-height:1.15}.local-product-icon-actions{display:inline-grid;grid-auto-flow:row;gap:.15rem;justify-items:end}.local-product-icon-actions vaadin-button{min-width:2.25rem;min-height:2.25rem}.local-product-icon-actions vaadin-button::part(label){padding:0}.local-products-empty{color:var(--vaadin-text-color-secondary)}.local-products-action-bar{position:fixed;inset-inline-start:50%;inset-block-end:calc(var(--scan-utility-footer-safe-height) + var(--vaadin-gap-s));transform:translate(-50%);width:min(560px,calc(100vw - 32px));padding:var(--vaadin-padding-s);box-sizing:border-box;border-radius:var(--vaadin-radius-l);background:color-mix(in srgb,var(--vaadin-background-color) 96%,transparent);backdrop-filter:blur(12px);z-index:2;box-shadow:var(--aura-shadow-s)}.local-products-action-bar vaadin-text-field{width:100%}.cart-action-bar{position:fixed;inset-inline-start:50%;inset-block-end:calc(var(--scan-utility-footer-safe-height) + var(--vaadin-gap-s));transform:translate(-50%);width:min(560px,calc(100vw - 32px));padding:var(--vaadin-padding-s);display:grid;grid-template-columns:1fr 1fr;gap:var(--vaadin-gap-s);box-sizing:border-box;border-radius:var(--vaadin-radius-l);background:color-mix(in srgb,var(--vaadin-background-color) 96%,transparent);backdrop-filter:blur(12px);z-index:2;box-shadow:var(--aura-shadow-s)}.cart-action-bar>*{min-width:0}.order-item img,.local-product-row img,.image-thumb-placeholder{width:48px;height:48px;object-fit:contain;flex:none}.image-thumb-placeholder{display:inline-block}.order-item{justify-content:space-between}.order-item-quantity{color:var(--vaadin-text-color-secondary);font-size:.78rem;white-space:nowrap}.local-product-actions{margin-inline-start:auto;align-items:center}.footer-sync-button{min-width:1.6rem;min-height:1.6rem;margin-inline-start:.1rem}.footer-sync-button::part(label){padding:0}.footer-sync-button vaadin-icon{width:.82rem;height:.82rem}.scan-status-footer{position:fixed;inset-inline:0;inset-block-end:0;z-index:3;display:flex;justify-content:center;min-height:var(--scan-utility-footer-height);padding:var(--vaadin-padding-s) var(--vaadin-padding-m) calc(var(--vaadin-padding-m) + env(safe-area-inset-bottom));background:color-mix(in srgb,var(--vaadin-background-color) 92%,transparent);backdrop-filter:blur(12px);box-sizing:border-box}.scan-status-footer:before{content:"";position:absolute;inset-block-start:0;inset-inline:0;height:3px}.scan-status-footer.online:before{background:var(--aura-green)}.scan-status-footer.offline:before{background:var(--vaadin-border-color)}.scan-status-dock{width:min(340px,100%);display:grid;grid-template-columns:1fr auto;gap:0 var(--vaadin-gap-l);align-items:center;font-size:.78rem}.scan-status-line{grid-column:1;color:var(--vaadin-text-color);font-size:.8rem;font-weight:600;line-height:1.1}.scan-sync-line{grid-column:1;display:inline-flex;align-items:center;gap:var(--vaadin-gap-xs);color:var(--vaadin-text-color-secondary);font-size:.72rem}.sync-icon{width:.95rem;height:.95rem;color:var(--vaadin-text-color-secondary)}.scan-footer-actions{grid-column:2;grid-row:1 / span 2;align-self:center;display:inline-flex;align-items:center;gap:var(--vaadin-gap-m)}.footer-icon-button{min-width:2.5rem;min-height:2.5rem}.footer-icon-button::part(label){padding:0}.camera-dialog-body{width:min(100%,44rem);display:grid;gap:var(--vaadin-gap-s)}.camera-dialog-hint{color:var(--vaadin-text-color-secondary);font-size:.82rem;text-align:center}.camera-reader-shell{position:relative;width:100%}.camera-reader{width:100%;min-height:min(72dvh,42rem);overflow:hidden;border-radius:var(--vaadin-radius-l);background:#000}.camera-reader video{width:100%;height:100%;object-fit:cover}.camera-target-frame{position:absolute;inset-inline-start:50%;inset-block-start:50%;width:min(calc(100% - 40px),420px);height:clamp(96px,24%,132px);transform:translate(-50%,-50%);border:2px solid color-mix(in srgb,var(--aura-accent-color) 78%,white);border-radius:20px;box-shadow:0 0 0 1px color-mix(in srgb,var(--vaadin-background-color) 35%,transparent),0 0 0 9999px color-mix(in srgb,#000 22%,transparent);pointer-events:none}.camera-target-frame:before{content:"";position:absolute;inset-inline-start:50%;inset-block-start:50%;width:calc(100% - 28px);height:1px;transform:translate(-50%,-50%);background:color-mix(in srgb,var(--aura-accent-color) 66%,white);opacity:.75}.warehouse-shell{max-width:560px;margin:0 auto}@media(max-width:560px){.camera-dialog::part(content){padding:var(--vaadin-padding-s)}.scan-view{min-height:calc(100dvh - 116px)}.scan-view--product{padding-bottom:calc(var(--scan-utility-footer-safe-height) + var(--scan-product-actions-height) + var(--vaadin-gap-s))}.scan-ready-card{width:min(348px,calc(100vw - 48px));min-height:min(432px,calc(100vh - 300px))}.warehouse-shell{max-width:none}.cart-grid-desktop{display:none}.cart-list-mobile{display:flex}.manual-scan,.scan-quantity-row,.order-actions,.cart-item{align-items:stretch;flex-direction:column}.local-product-actions{width:100%;margin-inline-start:0;flex-direction:row;justify-content:flex-end}.local-product-card-main{grid-template-columns:48px minmax(0,1fr) auto}.camera-dialog-body{width:min(100%,calc(100vw - 24px))}.camera-reader{min-height:min(74dvh,calc(100dvh - 180px));border-radius:24px}.cart-mobile-actions .cart-grid-qty{width:100%}}
