:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:rgba(255,255,255,.87);background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;justify-content:center;align-items:flex-start;min-width:320px;min-height:100vh;overflow-x:hidden;width:100%;box-sizing:border-box}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.no-page-scroll{overflow:hidden}#root{max-width:1280px;width:100%;margin:0 auto;padding-top:2rem;text-align:center;overflow-x:hidden}.form-container{padding:1rem;width:100%;box-sizing:border-box}.app-container{text-align:center;padding:1rem}.app-title{font-size:1.8rem;font-weight:600;margin-bottom:1.5rem}.upc-row{display:flex;align-items:center;padding:1rem 0}.upc-row label{margin-right:.5rem;font-weight:700}.upc-row input{padding:.25rem .5rem;font-size:1rem}.scan-button{display:block;margin:.75rem auto 0;padding:.5rem 1rem;font-size:1rem;font-weight:700;cursor:pointer;border:none;background-color:#007bff;color:#fff;border-radius:4px}.scan-button:hover{background-color:#0056b3}.button-group{display:grid;grid-template-columns:repeat(3,1fr);justify-items:center;align-items:start;gap:1rem;padding:0 1rem}.icon-button{display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:#005aac;color:#fff;border:none;border-radius:16px;width:88px;height:88px;font-size:14px;cursor:pointer;transition:background-color .2s}.icon-button span{margin-top:4px;line-height:1}.icon-button:hover{background-color:#004799}.auth-form{display:flex;flex-direction:column;gap:.75rem;width:100%;max-width:300px;margin:0 auto}.app-header{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1rem 0;border-bottom:1px solid #444;margin-bottom:1rem}.app-logo{width:48px;height:48px;object-fit:contain;border-radius:4px}.app-title-text{font-size:1.8rem;font-weight:600;color:#4fc3f7}.app-header{display:flex;justify-content:space-between;align-items:center;background-color:#222;padding:1rem 2rem;color:#fff}.app-header-left,.app-header-right{display:flex;align-items:center;gap:1rem}.logout-button{padding:.5rem 1rem;background-color:#444;color:#fff;border:none;border-radius:4px;cursor:pointer}.logout-button:hover{background-color:#666}.user-welcome{font-size:.95rem;opacity:.9}@media (max-width: 480px){.app-header-right{flex-direction:column;align-items:flex-end;gap:.25rem}.user-welcome{display:none}.logout-button{width:auto;padding:.4rem .8rem;font-size:.9rem}.app-title-text{font-size:1.2rem}.app-logo{width:24px;height:24px}}.alert-icon{position:relative;margin-right:1rem;cursor:pointer}.alert-badge{position:absolute;top:-6px;right:-6px;background:red;color:#fff;font-size:12px;border-radius:50%;padding:2px 6px}.app-footer{text-align:center;font-size:.85rem;color:#888;padding:1rem 0;border-top:1px solid #333;margin-top:2rem}.sidebar{width:260px;background:#2c2c2c;color:#fff;padding:1rem;position:fixed;top:0;left:0;height:100vh;display:flex;flex-direction:column;overflow-y:auto;box-sizing:border-box}.sidebar-content{flex-grow:1;display:flex;flex-direction:column}.sidebar-footer{margin-top:auto;display:flex;flex-direction:column;gap:.5rem}.sidebar-user{display:block;margin-bottom:1.5rem;font-size:.9rem;color:#ccc}.sidebar-icon{margin-right:.5rem;flex-shrink:0}.logo{margin-bottom:2rem;color:#0d6efd;font-size:1.5rem}.nav-menu{display:flex;flex-direction:column;gap:0}.nav-item{text-align:left;text-decoration:none;color:#ccc;font-weight:500;padding:.5rem;border-radius:0;margin-bottom:1rem}.nav-item.dashboard{border-radius:4px}.nav-item:hover{background:#444;color:#fff}.nav-item.edit-button{display:inline-flex;align-items:center}.active{background:#0d6efd;color:#fff}.admin-toggle{display:flex;justify-content:space-between;align-items:center;width:100%;text-align:left;border:none;padding:.5rem;color:#ccc;font-weight:500;cursor:pointer;background:none;border-bottom-left-radius:0!important;border-bottom-right-radius:0!important;margin-bottom:0}.admin-toggle.collapsed{border-bottom-left-radius:4px!important;border-bottom-right-radius:4px!important}.admin-toggle.active{background:#0d6efd;color:#fff}.admin-toggle:hover{background:#444;color:#fff}.admin-arrow{margin-left:auto}.submenu{margin-left:0;margin-top:0;width:100%;padding:.5rem .5rem .5rem 1rem;background:#1e1e1e;display:flex;flex-direction:column;gap:.5rem;box-sizing:border-box;transition:max-height .3s ease,opacity .2s ease}.submenu{max-height:0;opacity:0;overflow:hidden;transition:max-height .7s ease,opacity .2s ease}.submenu.open{max-height:500px;opacity:1;margin-bottom:1rem}.submenu-link{color:#ccc;text-align:left;text-decoration:none;font-size:.9rem;padding:.25rem 0;display:block}.submenu-link:hover{background:none;color:#fff}.submenu-link.active{background:none;color:#ccc}.submenu-link.active:hover{background:none;color:#fff}.layout-container{display:flex;min-height:100vh}.layout-main{margin-left:220px;display:flex;flex-direction:column;flex-grow:1}.layout-content{flex-grow:1;background:#1f1f1f;color:#fff;padding:2rem;overflow:auto}.product-grid-container{padding:1rem;color:#ddd}.product-grid-container h2{font-size:1.5rem;font-weight:500;margin:0 0 .5rem;color:#ddd;text-align:left}.product-table{width:100%;border-collapse:collapse;overflow-x:auto}.product-table th,.product-table td{text-align:left;padding:10px;vertical-align:middle}.product-table thead th{background-color:#222;color:#fff;border-bottom:2px solid #444}.product-table tbody td{border-bottom:1px solid #333}.product-table tbody tr.product-row.odd{background-color:#111}.product-table tbody tr.product-row.even{background-color:#272727}.product-table img{height:60px;object-fit:contain}input[type=number]{padding:4px;border-radius:4px;border:1px solid #666;background-color:#222;color:#fff}.description-col{max-width:200px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sortable-header{cursor:pointer;user-select:none}.sortable-header.active{font-weight:700;color:#4fc3f7}.location-tags{display:flex;gap:4px;flex-wrap:wrap}.location-tag{background-color:#333;padding:2px 6px;border-radius:4px;font-size:.8rem;white-space:nowrap}.toggle-cell{text-align:center;width:28px;user-select:none;pointer-events:auto}.location-tags{display:flex;flex-wrap:wrap;gap:4px}.location-tag{background:#444;padding:2px 6px;border-radius:4px;font-size:.8rem}.location-breakdown-wrapper{padding:8px 22px 8px 8px;background:#1b1b1b;border:2px solid #007bff;border-radius:6px;overflow:hidden;box-shadow:0 2px 6px rgba(0,0,0,.2)}.inner-table{width:100%;border-collapse:collapse}.inner-table th,.inner-table td{padding:6px 10px}.inner-table tr:nth-child(odd){background-color:#333!important}.inner-table tr:nth-child(2n){background-color:#444!important}.location-breakdown-wrapper .inner-table td{border-bottom:0 solid #ffffff}.slide-container{max-height:0;overflow:hidden;opacity:0;transition:max-height .4s ease,opacity .3s ease}.slide-container.open{max-height:500px;opacity:1}.location-breakdown .slide-wrapper{max-height:0;opacity:0;overflow:hidden;transition:max-height .4s ease,opacity .3s ease}.location-breakdown.open .slide-wrapper{max-height:500px;opacity:1}.slide-wrapper-animated{overflow:hidden;height:0;opacity:0;transition:height .3s ease,opacity .3s ease}.hidden-file-input{position:absolute;width:0;height:0;opacity:0}.actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:1rem}.product-image{width:64px;height:64px;object-fit:fill;object-position:center}.product-grid-header{display:flex;flex-direction:column;gap:.25rem;border-bottom:1px solid #333;padding-bottom:.5rem;margin-bottom:1rem}.product-grid-header h2{margin-bottom:.5rem}.product-grid-controls{display:flex;align-items:center;gap:1rem}.pagination-controls{display:flex;align-items:center;padding:.5rem 0}.pagination-controls button{margin:0 .5rem}.pagination-controls .rows-per-page-filter{margin-left:auto}.dashboard-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem;margin-bottom:1.5rem}.product-search-bar{display:flex;align-items:baseline;gap:.5rem;margin:.75rem 0 1rem}.product-search-bar label{font-weight:700;font-size:1.2rem;color:#fff}.search-input{padding:.4rem .6rem;border:1px solid #555;border-radius:4px;background-color:#222;color:#f0f0f0;font-size:.95rem;width:300px}.search-input::placeholder{color:#888;font-style:italic}.product-type-filter{display:flex;align-items:baseline;gap:.5rem;margin:.75rem 0 1rem}.product-type-filter label{font-weight:700;font-size:1.2rem;color:#fff}.product-grid-controls .product-type-filter{margin-left:auto}.type-filter{padding:.4rem .6rem;border:1px solid #555;border-radius:4px;background-color:#222;color:#f0f0f0;font-size:.95rem;width:75px}.confirm-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:10000}.confirm-dialog{background:#1e1e1e;padding:1.5rem;border-radius:.5rem;width:90%;max-width:400px;box-shadow:0 2px 10px rgba(0,0,0,.7)}.confirm-title{margin-top:0;margin-bottom:1rem;color:#fff}.confirm-message{color:#ddd;margin-bottom:1.5rem}.confirm-buttons{display:flex;justify-content:flex-end;gap:.5rem;align-items:center;flex-wrap:nowrap}.confirm-buttons .edit-button{flex-shrink:0;white-space:nowrap;align-self:center;margin:0;line-height:1}.data-card{width:100%;max-width:360px;background:#1e1e1e;border:1px solid #444;border-radius:8px;padding:1rem;color:#fff;display:flex;flex-direction:column}.data-card__header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:.5rem}.data-card__title{font-size:1rem;margin:0;font-weight:400}.data-card__refresh{cursor:pointer;font-size:1.2rem}.data-card__body{margin-top:.5rem}.data-card__footer{margin-top:.75rem;text-align:left}.data-card__view-all{color:#3ea0ff;text-decoration:none;font-size:.9rem}.data-card__body{margin-top:.5rem;display:flex;flex-direction:column;gap:.25rem}.data-card__row{display:grid;grid-template-columns:160px 1fr auto;align-items:center;padding:.25rem 0;border-bottom:1px solid rgba(255,255,255,.1)}.row__cell.sku{color:#3ea0ff;font-weight:500;text-decoration:none;margin-right:.5rem;justify-self:start}.row__cell.desc{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#ccc;font-size:.9rem;padding:0 .5rem}.row__cell.qty{font-weight:700}.edit-button{background-color:#007bff;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;font-size:1rem}.location-inventory-panel{padding:2rem;max-width:600px;margin:0 auto}.location-inventory-panel h2,.location-inventory-panel h3{text-align:left;margin-bottom:1rem}.inventory-section{margin-bottom:2rem;text-align:left}.inventory-section label{display:block;margin:.5rem 0 .25rem;font-weight:700}.inventory-section input{width:100%;padding:.5rem;margin-bottom:.5rem;border:1px solid #ccc;border-radius:4px}.button-row{display:flex;justify-content:space-between;gap:1rem}.action-button{flex:1;padding:.25rem .65rem;background-color:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1rem}.action-button:hover{background-color:#0056b3}.input-with-button{display:flex;gap:.5rem}.input-with-button input,.input-with-button .action-button{height:2.5rem;font-size:1rem;padding:0 1rem;border-radius:4px;border:1px solid #ccc;box-sizing:border-box}.input-with-button .action-button{background-color:#007bff;color:#fff;border:none;cursor:pointer}.input-with-button .action-button:hover{background-color:#0056b3}.lookup-results{margin-top:2rem}.inventory-list{display:flex;flex-direction:column;gap:.5rem}.inventory-line{display:flex;flex-direction:column;padding:.5rem 0;border-bottom:1px solid #333;text-align:left;gap:.5rem}.inventory-line .product-info{flex:1 1 auto;min-width:200px;text-align:left}.inventory-line .quantity-display,.inventory-line .quantity-input{text-align:right;min-width:50px}.inventory-line .action-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.inventory-line input[type=number]{width:6ch;padding:.25rem .5rem;font-size:1rem;border-radius:4px;border:1px solid #ccc}.no-products{padding:.5rem 0;font-style:italic;color:#888;text-align:left}.inventory-top{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:nowrap}.product-info{flex:1;font-size:1rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.quantity-display input{width:4ch;font-size:1rem;padding:.25rem}.quantity-display strong{font-size:1rem}.action-buttons{display:flex;gap:.5rem}.input-with-button{display:flex;width:100%;gap:.5rem}.input-with-button input{flex:1;height:2.5rem;padding:0 1rem;font-size:1rem;border-radius:4px;border:1px solid #ccc;box-sizing:border-box}.add-location-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:10000}.add-location-dialog{background:#1e1e1e;padding:1.5rem;border-radius:.5rem;width:90%;max-width:360px;box-shadow:0 2px 10px rgba(0,0,0,.7)}.add-location-title{color:#fff;margin-top:0;margin-bottom:1rem;text-align:center}.add-location-row{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}.add-location-row label{color:#ddd;font-size:1rem;width:7ch;flex-shrink:0}.add-location-row input#new-location{flex:0 1 140px;min-width:80px;padding:.4rem;background:#2e2e2e;border:1px solid #555;color:#fff;border-radius:.25rem;outline:none}.add-location-row input#new-qty{flex:0 1 80px;min-width:40px;padding:.4rem;background:#2e2e2e;border:1px solid #555;color:#fff;border-radius:.25rem;outline:none}.add-location-row button{white-space:nowrap}.add-location-buttons{display:flex;justify-content:flex-end;gap:.5rem}.location-panel{position:relative;width:100%;height:100vh;background:#1e1e1e;z-index:0}.back-button{position:absolute;top:1rem;left:1rem;z-index:1000}.final-labels{position:absolute;top:3rem;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:.5rem;z-index:900}.location-label,.product-label,.quantity-label{background:transparent;color:#fff;font-size:1.1rem;padding:0;border-radius:0}.scanner-wrapper{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;z-index:100}.scanner-label{margin-bottom:.5rem;color:#fff;font-size:1.25rem;text-transform:uppercase;letter-spacing:.05rem}.scanner-container{width:300px;height:300px;background:#000;overflow:hidden}.manual-input{margin-top:.75rem;width:300px;padding:.5rem .75rem;font-size:1rem;border:1px solid #555;border-radius:.25rem;background:#2e2e2e;color:#fff;outline:none}.manual-input:focus{border-color:#007bff}.center-buttons{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;gap:1rem;z-index:100}.edit-button{padding:.5rem 1rem;background-color:#007bff;color:#fff;border:none;border-radius:.25rem;cursor:pointer;font-size:1rem;transition:background-color .2s ease}.quantity-input{width:7ch;padding:.25rem;font-size:1rem;border:1px solid #555;border-radius:.25rem;background:#2e2e2e;color:#fff;outline:none;text-align:right}.quantity-input:focus{border-color:#007bff}.quantity-row{display:flex;align-items:center;gap:.5rem;margin-top:.75rem}.quantity-label-text{color:#fff;font-size:1.1rem;min-width:2ch;text-align:right}.sku-label{background:transparent;color:#fff;font-size:1.1rem;padding:0;border-radius:0}.add-quantity-button{margin-top:1rem}.location-list{margin:2rem 1rem;color:#fff}.location-list h3{margin-bottom:.5rem}.location-list ul{list-style:none;padding:0}.location-list li{padding:.25rem 0;border-bottom:1px solid rgba(255,255,255,.1)}.location-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid rgba(255,255,255,.1)}.location-buttons{display:flex;gap:.5rem;align-items:center}.add-location-container{margin-top:1rem;text-align:center}.add-location-button{margin:0 auto}.form-container{text-align:left}.form-row{display:grid;grid-template-columns:140px 1fr 100px;align-items:center;gap:.5rem;margin-bottom:1rem}.form-row:not(.sku-search-row) input,.form-row:not(.sku-search-row) select{grid-column:2 / span 2}.form-row label{font-weight:500}.form-row.sku-search-row{grid-template-columns:140px 1fr auto}.form-container input,.form-container select{padding:4px 8px;font-size:14px;line-height:1.2;box-sizing:border-box;background-color:#222;border:1px solid #444;color:#fff}.form-container .edit-button{height:32px;font-size:14px;line-height:1.2;background-color:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer}.form-container .edit-button:hover{background-color:#0056b3}.location-list{list-style:none;padding-left:0;margin-left:0;margin-top:0}.sku-search-row input{width:100%}.cycle-count-card{background:#222;padding:1rem;border:1px solid #333;border-radius:6px;margin-bottom:1rem;font-size:.95rem;display:flex;flex-direction:column;gap:.5rem;text-align:left}.cycle-count-card input.counted-input{width:7ch;padding:.5rem;background:#111;border:1px solid #444;color:#fff;border-radius:4px;font-size:1rem}.cycle-description{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;display:block}.confirm-button{margin-top:.5rem;padding:.5rem 1rem;font-size:1rem;background-color:#2c82e0;color:#fff;border:none;border-radius:4px;cursor:pointer}.confirm-button:disabled{background-color:#444;cursor:not-allowed}.notes-textarea{width:100%;margin-top:.25rem;padding:.5rem;font-size:.9rem;background:#111;color:#fff;border:1px solid #444;border-radius:4px;resize:vertical}.description-line{display:flex;gap:.5rem;align-items:center}.description-line .label{font-weight:700;white-space:nowrap}.description-line .value{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.user-grid-container{padding:1rem;color:#ddd}.user-grid-header{display:flex;flex-direction:column;gap:.25rem;border-bottom:1px solid #333;padding-bottom:.5rem;margin-bottom:1rem}.user-grid-header h2{font-size:1.5rem;font-weight:500;margin:0;color:#ddd}.table-wrapper{overflow-x:auto}.user-table{width:100%;border-collapse:collapse}.user-table th,.user-table td{text-align:left;padding:10px;vertical-align:middle}.user-table thead th{background-color:#222;color:#fff;border-bottom:2px solid #444}.user-table tbody td{border-bottom:1px solid #333}.user-table tbody tr.even{background-color:#272727}.user-table tbody tr.odd{background-color:#111}.edit-button{background-color:#007bff;color:#fff;border:none;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:.9rem}.edit-button:hover{background-color:#0056b3}.row-actions{display:inline-flex;gap:4px;align-items:center}.edit-button.delete{background-color:#dc3545}.edit-button.delete:hover{background-color:#c82333}.edit-button:disabled{opacity:.5;cursor:not-allowed}.user-card-list{display:flex;flex-direction:column;gap:1rem}.user-card{background-color:#222;border-radius:8px;padding:1rem;border:1px solid #444}.card-row{display:flex;justify-content:space-between;margin-bottom:.5rem}.card-label{font-weight:700;color:#aaa}.card-value{color:#fff}.card-actions{display:flex;gap:.5rem;margin-top:.5rem}.alerts-card-list{display:flex;flex-direction:column;gap:1rem}.alert-card{background-color:#222;border-radius:8px;padding:1rem;border:1px solid #444}.alert-card.error{border-left:4px solid #e53e3e}.alert-card.warning{border-left:4px solid #ecc94b}.alert-card.info{border-left:4px solid #3182ce}.alert-type{font-weight:700;margin-bottom:.5rem;color:#fff}.alert-timestamp{font-size:.9rem;color:#aaa;margin-bottom:.5rem}.alert-message{margin-bottom:.5rem;color:#eee}.alert-actions{display:flex;justify-content:flex-end}.dialog-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:rgba(0,0,0,.5);display:flex;justify-content:center;align-items:center;z-index:999}.dialog-box{background:#1e1e1e;padding:1.5rem;border-radius:8px;width:600px;max-height:80vh;overflow-y:auto}.product-preview-list{margin:1rem 0}.preview-item{border-bottom:1px solid #ccc;margin-bottom:1rem;padding-bottom:1rem}.cancel-btn{margin-top:1rem}.add-product-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:10000}.add-product-dialog{background:#1e1e1e;padding:1.5rem;border-radius:.5rem;width:90%;max-width:360px;box-shadow:0 2px 10px rgba(0,0,0,.7)}.add-product-title{color:#fff;margin-top:0;margin-bottom:1rem;text-align:center}.add-product-row{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}.add-product-row label{color:#ddd;font-size:1rem;text-align:left;width:9ch;margin-right:.5rem;flex-shrink:0}.add-product-row input{flex:1;padding:.4rem;background:#2e2e2e;border:1px solid #555;color:#fff;border-radius:.25rem;outline:none}.add-product-row button{white-space:nowrap}.add-product-buttons{display:flex;justify-content:flex-end;gap:.5rem}.form-error{color:#f66;font-size:.875rem;margin:-.5rem 0 .5rem 9ch}
