*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f1f5f9;color:#0f172a;overflow-x:hidden}#root{min-height:100vh}:root{--primary: #4f46e5;--primary-dark: #4338ca;--primary-light: #eef2ff;--success: #16a34a;--success-light: #dcfce7;--warning: #d97706;--warning-light: #fef3c7;--danger: #dc2626;--danger-light: #fee2e2;--bg: #f1f5f9;--surface: #ffffff;--border: #e2e8f0;--border-strong: #cbd5e1;--text: #0f172a;--text-secondary: #475569;--text-muted: #94a3b8;--shadow-sm: 0 1px 2px rgba(0,0,0,.05);--shadow: 0 1px 3px rgba(0,0,0,.1), 0 1px 2px rgba(0,0,0,.06);--shadow-md: 0 4px 6px rgba(0,0,0,.07), 0 2px 4px rgba(0,0,0,.06);--shadow-lg: 0 10px 15px rgba(0,0,0,.1), 0 4px 6px rgba(0,0,0,.05);--radius: 8px;--radius-sm: 5px;--radius-lg: 12px}.sdv-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.6);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;z-index:1100;padding:1.5rem}.sdv-modal{background:var(--surface);border-radius:var(--radius-lg);box-shadow:0 30px 70px #0006;width:100%;max-width:880px;max-height:92vh;overflow-y:auto;display:flex;flex-direction:column}.sdv-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border);flex-shrink:0}.sdv-title{display:flex;align-items:baseline;gap:.75rem}.sdv-shelf-name{font-size:1.1rem;font-weight:700;color:var(--text)}.sdv-dims{font-size:.82rem;color:var(--text-muted)}.sdv-close{width:32px;height:32px;border:none;background:var(--bg);border-radius:var(--radius);cursor:pointer;font-size:1.2rem;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;transition:background .12s ease,color .12s ease}.sdv-close:hover{background:var(--danger-light);color:var(--danger)}.sdv-perspective-wrap{padding:2.25rem 1.75rem 2rem;background:#1a1f2c;display:flex;justify-content:center;perspective:900px;overflow-x:auto}.sdv-shelf-3d{transform:rotateX(6deg);transform-origin:center bottom;display:flex;flex-direction:column;width:100%;max-width:760px;border-left:18px solid #c8cdd4;border-right:18px solid #c8cdd4;border-radius:2px;box-shadow:-8px 0 20px #00000080,8px 0 20px #00000080,0 12px 44px #000000a6}.sdv-level{display:flex;flex-direction:column}.sdv-board{flex-shrink:0;background:linear-gradient(180deg,#ffffff 0%,#f2f3f5 30%,#e2e5e9 65%,#d4d8dd 100%);box-shadow:inset 0 1px 2px #fff,inset 0 -1px 1px #00000014,0 4px 10px #0006;position:relative;z-index:2}.sdv-board:not(.sdv-bottom-board){min-height:36px;display:flex;align-items:center}.sdv-level-bar{display:flex;align-items:center;justify-content:space-between;width:100%;padding:0 .75rem}.sdv-level-label{font-size:.68rem;font-weight:700;color:#6b7280;text-transform:uppercase;letter-spacing:.07em;white-space:nowrap}.sdv-sections-control{display:flex;align-items:center;gap:.3rem}.sdv-sec-btn{width:20px;height:20px;border-radius:4px;border:1.5px solid #9ca3af;background:#f9fafb;color:#374151;font-size:.9rem;font-weight:700;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .1s ease,border-color .1s ease;padding:0}.sdv-sec-btn:hover:not(:disabled){background:var(--primary);border-color:var(--primary);color:#fff}.sdv-sec-btn:disabled{opacity:.35;cursor:not-allowed}.sdv-sec-count{font-size:.75rem;font-weight:700;color:#374151;min-width:16px;text-align:center}.sdv-sec-unit{font-size:.65rem;color:#9ca3af;white-space:nowrap}.sdv-bottom-board{height:16px;border-bottom-left-radius:3px;border-bottom-right-radius:3px}.sdv-cells{display:grid;background:#0f1420;min-height:115px;gap:2px;padding:2px}.sdv-cell{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);border-radius:3px;display:flex;align-items:center;justify-content:center;min-height:105px;position:relative;overflow:hidden;transition:background .12s ease}.sdv-cell.empty{border:1.5px dashed rgba(255,255,255,.13)}.sdv-cell.empty:hover{background:rgba(255,255,255,.05)}.sdv-cell.occupied{border-color:#ffffff26;background:rgba(255,255,255,.05)}.sdv-add-cell-btn{width:34px;height:34px;border-radius:50%;border:2px dashed rgba(255,255,255,.22);background:transparent;color:#ffffff4d;font-size:1.25rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .12s ease,color .12s ease,background .12s ease}.sdv-add-cell-btn:hover{border-color:var(--primary);color:var(--primary);background:rgba(79,70,229,.18)}.sdv-item{display:flex;flex-direction:column;align-items:center;gap:.2rem;padding:.5rem .3rem .3rem;width:100%;height:100%;position:relative}.sdv-item-img{width:58px;height:58px;object-fit:cover;border-radius:4px;flex-shrink:0;box-shadow:0 2px 6px #00000073}.sdv-item-icon{font-size:2.2rem;line-height:1}.sdv-item-name{font-size:.62rem;color:#ffffffbf;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%;max-width:84px}.sdv-item-qty{font-size:.6rem;font-weight:700;color:#ffffff73;background:rgba(0,0,0,.35);padding:1px 6px;border-radius:3px}.sdv-remove-item{position:absolute;top:3px;right:3px;width:16px;height:16px;background:rgba(220,38,38,.75);color:#fff;border:none;border-radius:3px;cursor:pointer;font-size:.7rem;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .12s ease;padding:0;line-height:1}.sdv-cell:hover .sdv-remove-item{opacity:1}.sdv-add-form{display:flex;flex-direction:column;gap:.28rem;padding:.4rem;width:100%}.sdv-add-form select,.sdv-add-form input{font-size:.7rem;border:1px solid rgba(255,255,255,.2);border-radius:4px;padding:3px 5px;background:rgba(255,255,255,.1);color:#fff;outline:none;width:100%;min-width:0}.sdv-add-form select option{background:#1a1f2e;color:#fff}.sdv-add-form input::placeholder{color:#ffffff59}.sdv-add-actions{display:flex;gap:.2rem}.sdv-confirm-btn{flex:1;font-size:.68rem;font-weight:700;background:var(--primary);color:#fff;border:none;border-radius:4px;padding:4px 0;cursor:pointer;transition:background .12s ease}.sdv-confirm-btn:hover{background:var(--primary-dark)}.sdv-cancel-btn{width:24px;font-size:.9rem;background:rgba(255,255,255,.1);color:#ffffff8c;border:none;border-radius:4px;cursor:pointer;transition:background .12s ease}.sdv-cancel-btn:hover{background:rgba(255,255,255,.2)}.sdv-unpositioned{padding:1rem 1.25rem;border-top:1px solid var(--border)}.sdv-unpositioned-title{font-size:.75rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.5rem}.sdv-unpositioned-list{display:flex;flex-wrap:wrap;gap:.5rem}.sdv-unpositioned-item{display:flex;align-items:center;gap:.4rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:.3rem .65rem;font-size:.8rem;color:var(--text)}.sdv-upos-thumb{width:24px;height:24px;object-fit:cover;border-radius:3px}.sdv-upos-qty{color:var(--text-muted);font-size:.75rem}.orm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.55);z-index:200;display:flex;align-items:center;justify-content:center;padding:1.5rem}.orm-modal{background:white;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:860px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.orm-toolbar{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.25rem;border-bottom:1px solid var(--border);flex-shrink:0;background:var(--surface)}.orm-toolbar-title{font-size:.9rem;font-weight:700;color:var(--text)}.orm-toolbar-actions{display:flex;gap:.5rem;align-items:center}.orm-print-btn{padding:.4rem 1rem;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.82rem;font-weight:600;cursor:pointer;transition:background .15s ease}.orm-print-btn:hover{background:var(--primary-dark)}.orm-close-btn{width:30px;height:30px;border:none;background:var(--bg);border-radius:var(--radius-sm);font-size:1.1rem;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .12s ease,color .12s ease}.orm-close-btn:hover{background:var(--danger-light);color:var(--danger)}.orm-content{flex:1;overflow-y:auto;padding:1.75rem 2rem;display:flex;flex-direction:column;gap:1.5rem}.orm-report-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding-bottom:1.25rem;border-bottom:2px solid var(--text)}.orm-report-title h1{font-size:1.4rem;font-weight:800;color:var(--text);letter-spacing:-.03em;margin-bottom:.2rem}.orm-report-subtitle{font-size:.82rem;color:var(--text-secondary)}.orm-report-meta{display:flex;flex-direction:column;gap:.2rem;text-align:right}.orm-meta-row{display:flex;gap:.75rem;align-items:baseline;font-size:.82rem}.orm-meta-row span{color:var(--text-muted)}.orm-meta-row strong{color:var(--text);font-weight:600}.orm-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.orm-summary-chip{border-radius:var(--radius);padding:.875rem 1rem;display:flex;flex-direction:column;gap:.3rem}.chip-label{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.chip-value{font-size:1.75rem;font-weight:800;letter-spacing:-.03em;line-height:1}.chip-needed{background:var(--danger-light)}.chip-needed .chip-label,.chip-needed .chip-value{color:var(--danger)}.chip-brought{background:var(--success-light)}.chip-brought .chip-label,.chip-brought .chip-value{color:var(--success)}.chip-order{background:#eef2ff;border:1.5px solid #c7d2fe}.chip-order .chip-label,.chip-order .chip-value{color:var(--primary)}.orm-table{width:100%;border-collapse:collapse;font-size:.85rem}.orm-table thead th{text-align:left;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);padding:.5rem .75rem;border-bottom:1.5px solid var(--border);white-space:nowrap}.orm-table thead th.col-needed,.orm-table thead th.col-brought,.orm-table thead th.col-short,.orm-table thead th.col-order{text-align:center}.orm-table tbody tr{border-bottom:1px solid var(--border);transition:background .1s ease}.orm-table tbody tr:last-child{border-bottom:none}.orm-table tbody tr:hover{background:#f8fafc}.orm-table td{padding:.6rem .75rem;vertical-align:middle}.orm-product-cell{display:flex;align-items:center;gap:.6rem}.orm-thumb{width:36px;height:36px;object-fit:cover;border-radius:var(--radius-sm);flex-shrink:0}.orm-thumb-placeholder{width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;background:var(--bg);border-radius:var(--radius-sm);flex-shrink:0}.orm-product-name{font-weight:600;color:var(--text)}.orm-shelf-list{display:flex;flex-wrap:wrap;gap:.25rem}.orm-shelf-tag{font-size:.68rem;background:var(--bg);border:1px solid var(--border);border-radius:99px;padding:.1rem .45rem;color:var(--text-secondary);white-space:nowrap}.num{text-align:center;font-variant-numeric:tabular-nums}.val-short{color:var(--danger);font-weight:700}.val-ok{color:var(--success);font-weight:700}.order-qty{font-weight:800;color:var(--primary);font-size:.95rem}.row-met{opacity:.75}.orm-total-row{border-top:2px solid var(--text);font-weight:700}.orm-total-row td{padding:.6rem .75rem}.orm-footnote{font-size:.75rem;color:var(--text-muted);border-top:1px solid var(--border);padding-top:.75rem;line-height:1.6}@media print{.orm-overlay{position:static;background:none;padding:0;display:block}.orm-modal{box-shadow:none;border-radius:0;max-width:none;max-height:none;width:100%}.no-print{display:none!important}.orm-content{overflow:visible;padding:1.5cm 2cm}.orm-report-header{border-bottom:2px solid black}.orm-total-row{border-top:2px solid black}.orm-table thead th{border-bottom:1.5px solid #666}.orm-table tbody tr{border-bottom:1px solid #ddd}.orm-summary-chip{border:1px solid #ccc!important}}.floor-plan-view{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.fv-header{display:flex;align-items:center;justify-content:space-between;padding:.875rem 1.25rem;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0}.fv-header-left{display:flex;align-items:center;gap:.75rem}.fv-header h2{font-size:1.1rem;font-weight:700;color:var(--text);margin:0}.fv-badge{font-size:.73rem;font-weight:600;padding:.22rem .6rem;border-radius:99px}.fv-badge-ok{background:var(--success-light);color:var(--success)}.fv-badge-warn{background:var(--warning-light);color:var(--warning)}.fv-edit-btn{padding:.4rem .9rem;font-size:.8rem;font-weight:600;background:var(--surface);color:var(--text-secondary);border:1.5px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:border-color .12s ease,color .12s ease}.fv-edit-btn:hover{border-color:var(--primary);color:var(--primary)}.fv-body{display:flex;flex:1;overflow:hidden}.fv-main{display:flex;flex-direction:column;flex:1;overflow-y:auto;min-width:0}.fv-grid-wrap{padding:1.25rem;overflow-x:auto;background:var(--bg);flex-shrink:0}.fv-grid{display:grid;width:fit-content;background:#f8f9fb;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.fv-grid-cell{width:40px;height:40px;border:1px solid #eaecf0;box-sizing:border-box}.fv-tile{border-radius:3px;border:1.5px solid var(--shelf-accent, var(--primary));background:white;display:flex;flex-direction:column;gap:2px;padding:3px 4px 2px;overflow:hidden;cursor:pointer;transition:box-shadow .12s ease,transform .1s ease;z-index:1;position:relative}.fv-tile:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;border-radius:2px 0 0 2px}.fv-tile.fv-status-ok:before{background:var(--success)}.fv-tile.fv-status-low:before{background:var(--warning)}.fv-tile.fv-status-critical:before{background:var(--danger)}.fv-tile.fv-status-unknown:before{background:var(--border)}.fv-tile:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.fv-tile.selected{box-shadow:0 0 0 3px var(--primary),var(--shadow-md);transform:translateY(-1px)}.fv-tile-label{font-size:.48rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1}.fv-tile-thumbs{display:flex;gap:1px;align-items:center;overflow:hidden;flex:1}.fv-tile-thumb{width:14px;height:14px;object-fit:cover;border-radius:2px;flex-shrink:0}.fv-tile-thumb-placeholder{width:14px;height:14px;font-size:.5rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--bg);border-radius:2px}.fv-tile-more{font-size:.42rem;color:var(--text-muted);white-space:nowrap}.fv-tile-bar{height:3px;background:var(--border);border-radius:99px;overflow:hidden;flex-shrink:0}.fv-tile-fill{height:100%;border-radius:99px;transition:width .3s ease}.fv-tile-fill.fv-status-ok{background:var(--success)}.fv-tile-fill.fv-status-low{background:var(--warning)}.fv-tile-fill.fv-status-critical{background:var(--danger)}.fv-queue{border-top:1.5px solid var(--border);background:var(--surface);padding:.875rem 0 .5rem}.fv-queue-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem;padding:0 1.25rem}.fv-queue-header h3{font-size:.82rem;font-weight:700;color:var(--text);margin:0}.fv-queue-header-right{display:flex;align-items:center;gap:.75rem}.fv-queue-totals{display:flex;align-items:center;gap:.4rem}.fv-order-report-btn{padding:.3rem .75rem;font-size:.75rem;font-weight:600;color:var(--primary);background:var(--primary-light);border:1.5px solid #c7d2fe;border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;transition:background .12s ease,border-color .12s ease}.fv-order-report-btn:hover{background:#dde4fe;border-color:var(--primary)}.fv-queue-total-needed{font-size:.73rem;font-weight:700;color:var(--danger);background:var(--danger-light);padding:.18rem .55rem;border-radius:99px}.fv-queue-total-brought{font-size:.73rem;font-weight:700;color:var(--success);background:var(--success-light);padding:.18rem .55rem;border-radius:99px}.fv-qt-head,.fv-qt-row{display:grid;grid-template-columns:1fr 120px 150px;align-items:center}.fv-qt-head{padding:.3rem 1.25rem;border-bottom:1.5px solid var(--border)}.fv-qt-head>div{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.fv-qt-col-needed,.fv-qt-col-brought{text-align:center}.fv-qt-row{border-bottom:1px solid var(--border);min-height:44px;transition:background .1s ease}.fv-qt-row:last-child{border-bottom:none}.fv-qt-row:hover{background:var(--bg)}.fv-qt-row.fv-status-low{border-left:3px solid var(--warning)}.fv-qt-row.fv-status-critical{border-left:3px solid var(--danger)}.fv-qt-item-cell{display:flex;align-items:center;gap:.6rem;padding:.45rem .75rem .45rem 1.25rem;cursor:pointer;min-width:0}.fv-qt-row.fv-status-low .fv-qt-item-cell,.fv-qt-row.fv-status-critical .fv-qt-item-cell{padding-left:1rem}.fv-qi-thumb{width:32px;height:32px;object-fit:cover;border-radius:var(--radius-sm);flex-shrink:0}.fv-qi-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:1rem;background:var(--border);border-radius:var(--radius-sm);flex-shrink:0}.fv-qi-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.fv-qi-name{font-size:.82rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fv-qi-shelf{font-size:.68rem;color:var(--text-muted)}.fv-qt-needed-cell{display:flex;flex-direction:column;align-items:center;gap:1px;padding:.4rem .5rem}.fv-qt-needed-val{font-size:1.1rem;font-weight:800;line-height:1}.fv-qt-needed-val.fv-status-low{color:var(--warning)}.fv-qt-needed-val.fv-status-critical{color:var(--danger)}.fv-qt-brought-cell{display:flex;flex-direction:column;align-items:center;gap:2px;padding:.4rem 1rem .4rem .5rem}.fv-qt-brought-input{width:72px;font-size:1.1rem;font-weight:800;color:var(--text);border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);text-align:center;padding:.2rem .3rem;outline:none;-moz-appearance:textfield;transition:border-color .15s ease}.fv-qt-brought-input::-webkit-inner-spin-button,.fv-qt-brought-input::-webkit-outer-spin-button{-webkit-appearance:none}.fv-qt-brought-input:focus{border-color:var(--primary);background:white}.fv-qt-brought-hint{font-size:.65rem;font-weight:700;white-space:nowrap}.hint-ok{color:var(--success)}.hint-short{color:var(--warning)}.fv-panel{width:300px;min-width:300px;border-left:1.5px solid var(--border);background:var(--surface);display:flex;flex-direction:column;overflow-y:auto}.fv-panel-header{display:flex;align-items:flex-start;justify-content:space-between;padding:1rem 1rem .875rem;border-bottom:1px solid var(--border);flex-shrink:0}.fv-panel-title{display:flex;flex-direction:column;gap:.2rem}.fv-panel-name{font-size:1rem;font-weight:700;color:var(--text)}.fv-panel-subtitle{font-size:.72rem;color:var(--text-muted)}.fv-panel-close{width:28px;height:28px;border:none;background:var(--bg);border-radius:var(--radius-sm);cursor:pointer;font-size:1.1rem;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;transition:background .12s ease,color .12s ease;flex-shrink:0}.fv-panel-close:hover{background:var(--danger-light);color:var(--danger)}.fv-panel-items{flex:1;overflow-y:auto;padding:.25rem 0}.fv-panel-empty{padding:1rem 1.25rem;font-size:.82rem;color:var(--text-muted);line-height:1.6}.fv-item-row{padding:.75rem 1rem;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:.55rem}.fv-item-row:last-child{border-bottom:none}.fv-item-row-top{display:flex;align-items:center;gap:.6rem}.fv-item-row-img{width:40px;height:40px;object-fit:cover;border-radius:var(--radius-sm);flex-shrink:0}.fv-item-row-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;background:var(--bg);border-radius:var(--radius-sm);flex-shrink:0}.fv-item-row-info{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.fv-item-row-name{font-size:.86rem;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fv-item-row-sku{font-size:.68rem;color:var(--text-muted);font-family:monospace}.fv-item-row-count{display:flex;flex-direction:column;gap:.35rem}.fv-item-count-label{font-size:.67rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.fv-item-count-controls{display:flex;align-items:center;gap:.5rem}.fv-count-btn{width:36px;height:36px;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--bg);color:var(--text);font-size:1.2rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .12s ease,background .12s ease;flex-shrink:0}.fv-count-btn:hover{border-color:var(--primary);background:var(--primary-light);color:var(--primary)}.fv-count-input{flex:1;font-size:1.5rem;font-weight:800;color:var(--text);border:none;border-bottom:2.5px solid var(--border);background:transparent;text-align:center;outline:none;padding:0 4px;-moz-appearance:textfield;transition:border-color .15s ease;min-width:0}.fv-count-input::-webkit-inner-spin-button,.fv-count-input::-webkit-outer-spin-button{-webkit-appearance:none}.fv-count-input:focus{border-bottom-color:var(--primary)}.fv-item-needed{font-size:.78rem;font-weight:700}.fv-item-needed.fv-status-low{color:var(--warning)}.fv-item-needed.fv-status-critical{color:var(--danger)}.fv-item-ok{font-size:.78rem;font-weight:700;color:var(--success)}.fv-panel-footer{padding:.75rem 1rem;border-top:1px solid var(--border);flex-shrink:0}.fv-panel-detail-btn{width:100%;font-size:.8rem;font-weight:600;color:var(--primary);background:var(--primary-light);border:none;border-radius:var(--radius);padding:.5rem;cursor:pointer;transition:background .12s ease}.fv-panel-detail-btn:hover{background:#dde4fe}.fv-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:.75rem;padding:3rem;text-align:center}.fv-empty-icon{font-size:3rem;line-height:1}.fv-empty h3{font-size:1.1rem;font-weight:700;color:var(--text);margin:0}.fv-empty p{font-size:.9rem;color:var(--text-secondary);margin:0}.fv-empty-btn{margin-top:.5rem;padding:.6rem 1.25rem;background:var(--primary);color:#fff;border:none;border-radius:var(--radius);font-size:.9rem;font-weight:600;cursor:pointer;transition:background .12s ease}.fv-empty-btn:hover{background:var(--primary-dark)}.shelf{background:color-mix(in srgb,var(--shelf-color, var(--primary)) 8%,white);border:2px solid var(--success);border-radius:var(--radius);padding:.5rem .6rem;cursor:grab;transition:box-shadow .15s ease,opacity .15s ease;display:flex;flex-direction:column;gap:.4rem;overflow:hidden;-webkit-user-select:none;user-select:none}.shelf.dragging{opacity:.45;cursor:grabbing;box-shadow:0 8px 24px #0000002e}.shelf:hover{box-shadow:var(--shadow-md)}.shelf-header{display:flex;justify-content:space-between;align-items:center;gap:.25rem}.shelf-label{font-size:.78rem;font-weight:700;color:var(--text);cursor:pointer;padding:1px 4px;border-radius:3px;transition:background .12s ease;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.shelf-label:hover{background:rgba(0,0,0,.07)}.label-edit-input{flex:1;min-width:0;font-size:.78rem;font-weight:700;color:var(--text);border:1.5px solid var(--primary);border-radius:3px;padding:1px 4px;background:white;outline:none}.view-btn{width:18px;height:18px;min-width:18px;border:none;background:transparent;color:var(--text-muted);border-radius:3px;cursor:pointer;font-size:.8rem;line-height:1;display:flex;align-items:center;justify-content:center;transition:background .12s ease,color .12s ease;padding:0}.view-btn:hover{background:var(--primary-light);color:var(--primary)}.remove-btn{width:18px;height:18px;min-width:18px;border:none;background:transparent;color:var(--text-muted);border-radius:3px;cursor:pointer;font-size:1rem;line-height:1;display:flex;align-items:center;justify-content:center;transition:background .12s ease,color .12s ease;padding:0}.remove-btn:hover{background:var(--danger-light);color:var(--danger)}.shelf-content{display:flex;flex-direction:column;gap:.25rem}.shelf-meta-row{display:flex;align-items:center;justify-content:space-between;gap:.25rem}.stock-info{display:flex;align-items:baseline;gap:.2rem}.levels-badge{font-size:.68rem;font-weight:700;color:#fff;background:rgba(0,0,0,.28);padding:1px 5px;border-radius:3px;cursor:pointer;transition:background .12s ease;flex-shrink:0;letter-spacing:.02em}.levels-badge:hover{background:rgba(0,0,0,.45)}.levels-edit-input{width:36px;font-size:.72rem;font-weight:700;color:var(--text);border:1.5px solid var(--primary);border-radius:3px;padding:1px 3px;background:white;outline:none;flex-shrink:0}.stock-count{font-weight:800;font-size:1rem;line-height:1}.stock-max{font-size:.72rem;color:var(--text-muted)}.stock-bar{height:5px;background:var(--border);border-radius:99px;overflow:hidden}.stock-fill{height:100%;border-radius:99px;transition:width .3s ease}.shelf-items{display:flex;flex-wrap:wrap;gap:.2rem}.mini-item{background:rgba(0,0,0,.06);padding:1px 5px;border-radius:3px;font-size:.65rem;color:var(--text-secondary);max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.more-items{background:rgba(0,0,0,.04);padding:1px 5px;border-radius:3px;font-size:.65rem;color:var(--text-muted)}.floor-plan-grid{background:var(--surface);border-radius:var(--radius-lg);padding:1.25rem;box-shadow:var(--shadow);overflow:auto}.grid-container{display:grid;gap:2px;background:var(--border);padding:2px;border-radius:var(--radius-sm);min-width:fit-content}.grid-cell{width:60px;height:60px;background:#f8fafc;border-radius:2px;transition:background .12s ease}.grid-cell.highlight{background:var(--primary-light)}.grid-drop-preview{border-radius:4px;pointer-events:none;z-index:10}.preview-valid{background:rgba(79,70,229,.12);border:2px dashed var(--primary);box-shadow:inset 0 0 0 1px #4f46e540}.preview-invalid{background:rgba(220,38,38,.08);border:2px dashed var(--danger);box-shadow:inset 0 0 0 1px #dc262633}.shelf-palette{background:var(--surface);border-radius:var(--radius-lg);padding:1.25rem;box-shadow:var(--shadow);position:sticky;top:1rem;display:flex;flex-direction:column;gap:1rem}.shelf-palette h3{font-size:.8rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.07em;margin-bottom:-.5rem}.palette-hint{font-size:.78rem;color:var(--text-muted)}.palette-preview-wrap{display:flex;justify-content:center;align-items:center;background:var(--bg);border:1.5px dashed var(--border-strong);border-radius:var(--radius);padding:1rem;min-height:100px}.palette-shelf-preview{width:100%;max-width:160px;max-height:140px;min-width:48px;min-height:48px;border-radius:var(--radius-sm);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.2rem;cursor:grab;color:#fff;box-shadow:var(--shadow-md);transition:transform .15s ease,box-shadow .15s ease,opacity .15s ease;-webkit-user-select:none;user-select:none}.palette-shelf-preview:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.palette-shelf-preview.dragging{opacity:.35;cursor:grabbing}.palette-shelf-dim{font-size:.85rem;font-weight:800;letter-spacing:-.01em;text-shadow:0 1px 2px rgba(0,0,0,.3)}.palette-shelf-cap{font-size:.65rem;font-weight:500;opacity:.85}.palette-form{display:flex;flex-direction:column;gap:.75rem}.dim-row{display:flex;align-items:flex-end;gap:.5rem}.dim-field{flex:1;display:flex;flex-direction:column;gap:.3rem}.dim-field label,.palette-field label{font-size:.72rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em}.dim-field input,.palette-field input{padding:.5rem .6rem;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:.9rem;font-weight:600;color:var(--text);background:var(--bg);width:100%;transition:border-color .15s ease,box-shadow .15s ease}.dim-field input:focus,.palette-field input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light);background:white}.dim-sep{font-size:1.1rem;font-weight:700;color:var(--text-muted);padding-bottom:.4rem;flex-shrink:0}.palette-field{display:flex;flex-direction:column;gap:.3rem}.color-dots{display:flex;gap:6px;flex-wrap:wrap}.color-dot{width:26px;height:26px;border-radius:50%;border:2.5px solid transparent;cursor:pointer;transition:transform .12s ease,border-color .12s ease;outline:none}.color-dot:hover{transform:scale(1.15)}.color-dot.active{border-color:var(--text);transform:scale(1.15);box-shadow:0 0 0 2px #fff inset}.palette-footer{display:flex;justify-content:space-between;align-items:center;padding-top:.75rem;border-top:1px solid var(--border)}.shelf-count{font-size:.8rem;font-weight:600;color:var(--text-secondary)}.clear-btn{padding:.35rem .75rem;background:transparent;color:var(--danger);border:1.5px solid var(--danger);border-radius:var(--radius-sm);font-size:.78rem;font-weight:600;cursor:pointer;transition:all .15s ease}.clear-btn:hover:not(:disabled){background:var(--danger-light)}.clear-btn:disabled{opacity:.4;cursor:not-allowed}.floor-plan-creator{flex:1;min-height:0;display:flex;flex-direction:column;padding:1.25rem 1.5rem;overflow-y:auto}.config-panel{background:var(--surface);border-radius:var(--radius-lg);padding:2rem;box-shadow:var(--shadow-md);max-width:480px;margin:2rem auto}.config-panel h2{font-size:1.25rem;font-weight:700;color:var(--text);letter-spacing:-.02em;margin-bottom:1.75rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.config-section{margin-bottom:1.5rem}.config-section h3{font-size:.8rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.07em;margin-bottom:.875rem}.section-description{color:var(--text-muted);font-size:.82rem;margin-bottom:.875rem}.dimension-inputs{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.dimension-inputs>div{display:flex;flex-direction:column;gap:.4rem}.dimension-inputs label{font-size:.82rem;font-weight:500;color:var(--text-secondary)}.dimension-inputs input{padding:.6rem .75rem;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:.9rem;color:var(--text);transition:border-color .15s ease,box-shadow .15s ease;background:#fafafa}.dimension-inputs input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light);background:white}.shelf-types-list{display:flex;flex-direction:column;gap:.4rem;margin-bottom:.875rem}.shelf-type-item{display:flex;justify-content:space-between;align-items:center;padding:.65rem .875rem;background:var(--bg);border-radius:var(--radius-sm);border:1px solid var(--border)}.shelf-type-info{display:flex;flex-direction:column;gap:.15rem}.shelf-type-name{font-weight:600;color:var(--text);font-size:.875rem}.shelf-type-dimensions{font-size:.75rem;color:var(--text-muted);font-family:monospace}.shelf-type-color{width:24px;height:24px;border-radius:4px;border:1.5px solid rgba(0,0,0,.1)}.manage-shelves-btn{width:100%;padding:.6rem;background:var(--bg);color:var(--primary);border:1.5px solid var(--primary);border-radius:var(--radius-sm);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .15s ease}.manage-shelves-btn:hover{background:var(--primary-light)}.config-note{font-size:.82rem;color:var(--text-secondary);background:var(--primary-light);border:1px solid rgba(79,70,229,.2);border-radius:var(--radius-sm);padding:.7rem .875rem;margin-bottom:1rem;line-height:1.5}.create-btn{width:100%;padding:.875rem;background:var(--primary);color:#fff;border:none;border-radius:var(--radius);font-size:.95rem;font-weight:600;cursor:pointer;transition:background .15s ease,transform .15s ease;margin-top:.5rem}.create-btn:hover{background:var(--primary-dark);transform:translateY(-1px)}.creator-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem;background:var(--surface);padding:.875rem 1.25rem;border-radius:var(--radius-lg);box-shadow:var(--shadow);gap:1rem}.creator-header-left{display:flex;align-items:center;gap:1rem;flex-shrink:0}.creator-header h2{color:var(--text);font-size:1.1rem;font-weight:700;letter-spacing:-.02em;white-space:nowrap}.floor-dim-editor{display:flex;align-items:center;gap:.35rem;background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:.3rem .6rem}.dim-input{width:42px;font-size:.88rem;font-weight:700;color:var(--text);border:none;background:transparent;text-align:center;outline:none;-moz-appearance:textfield;padding:0}.dim-input::-webkit-inner-spin-button,.dim-input::-webkit-outer-spin-button{-webkit-appearance:none}.dim-input:focus{color:var(--primary)}.dim-x{font-size:.8rem;color:var(--text-muted);font-weight:600}.dim-label{font-size:.72rem;color:var(--text-muted);white-space:nowrap}.creator-header-actions{display:flex;align-items:center;gap:.75rem}.undo-redo-group{display:flex;gap:2px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:2px}.undo-btn,.redo-btn{padding:.35rem .75rem;background:transparent;border:none;border-radius:calc(var(--radius-sm) - 1px);font-size:.8rem;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all .15s ease;white-space:nowrap}.undo-btn:hover:not(:disabled),.redo-btn:hover:not(:disabled){background:var(--surface);color:var(--primary)}.undo-btn:disabled,.redo-btn:disabled{color:var(--text-muted);cursor:not-allowed}.reset-btn{padding:.4rem 1rem;background:transparent;color:var(--danger);border:1.5px solid var(--danger);border-radius:var(--radius-sm);font-size:.8rem;font-weight:600;cursor:pointer;transition:all .15s ease}.reset-btn:hover{background:var(--danger-light)}.save-view-btn{padding:.4rem 1rem;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.82rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .15s ease}.save-view-btn:hover{background:var(--primary-dark)}.creator-content{display:grid;grid-template-columns:220px 1fr;gap:1.25rem;align-items:start;flex:1;min-height:0}@media (max-width: 900px){.creator-content{grid-template-columns:1fr}}.stock-scanner{max-width:1100px;margin:0 auto;display:flex;flex-direction:column;gap:1.25rem}.scanner-header{background:var(--surface);padding:1.25rem 1.5rem;border-radius:var(--radius-lg);box-shadow:var(--shadow)}.scanner-header h2{font-size:1.2rem;font-weight:700;color:var(--text);letter-spacing:-.02em;margin-bottom:.2rem}.scanner-header p{color:var(--text-secondary);font-size:.875rem}.no-floor-plan{background:var(--surface);border-radius:var(--radius-lg);padding:4rem 2rem;text-align:center;box-shadow:var(--shadow)}.no-floor-plan-icon{color:var(--text-muted);margin-bottom:1rem}.no-floor-plan h2{font-size:1.15rem;font-weight:700;color:var(--text);margin-bottom:.4rem}.no-floor-plan p{color:var(--text-secondary);font-size:.9rem}.scanner-content{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;align-items:start}@media (max-width: 768px){.scanner-content{grid-template-columns:1fr}}.mode-toggle{display:flex;gap:2px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:3px;margin-bottom:1rem}.mode-toggle button{flex:1;padding:.5rem;border:none;background:transparent;color:var(--text-secondary);border-radius:calc(var(--radius) - 2px);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s ease}.mode-toggle button.active{background:var(--primary);color:#fff;font-weight:600}.mode-toggle button:hover:not(.active){background:var(--surface)}.camera-section{background:var(--surface);border-radius:var(--radius-lg);padding:1.25rem;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:1rem}.camera-btn{width:100%;padding:1.75rem 1rem;background:var(--primary-light);color:var(--primary);border:2px dashed var(--primary);border-radius:var(--radius-lg);font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.6rem;transition:all .15s ease}.camera-btn:hover{background:var(--primary);color:#fff;border-style:solid}.camera-view{position:relative;border-radius:var(--radius-lg);overflow:hidden;background:#000}.camera-feed{width:100%;display:block;border-radius:var(--radius-lg)}.scan-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none}.scan-frame{width:60%;aspect-ratio:1.6;border:2.5px solid rgba(255,255,255,.8);border-radius:10px;box-shadow:0 0 0 9999px #00000073}.scan-label{margin-top:1rem;color:#fff;font-size:.85rem;font-weight:500;display:flex;align-items:center;gap:.4rem;background:rgba(0,0,0,.55);padding:.35rem .75rem;border-radius:99px}.stop-scan-btn{position:absolute;top:.75rem;right:.75rem;display:flex;align-items:center;gap:.3rem;padding:.35rem .75rem;background:rgba(0,0,0,.6);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.8rem;font-weight:600;cursor:pointer;transition:background .15s ease}.stop-scan-btn:hover{background:rgba(220,38,38,.8)}@keyframes spin{to{transform:rotate(360deg)}}.spin{animation:spin 1s linear infinite}.manual-input-section{background:var(--bg);padding:1.25rem;border-radius:var(--radius-lg);border:1px solid var(--border)}.manual-input-section h3{font-size:.875rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.75rem}.barcode-input-group{display:flex;gap:.5rem;margin-bottom:.5rem}.barcode-input{flex:1;padding:.65rem .875rem;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:.9rem;color:var(--text);background:white;transition:border-color .15s ease,box-shadow .15s ease}.barcode-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.lookup-btn{padding:.65rem 1.1rem;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.875rem;font-weight:600;cursor:pointer;transition:background .15s ease;white-space:nowrap}.lookup-btn:hover{background:var(--primary-dark)}.manual-hint{color:var(--text-muted);font-size:.8rem}.scan-feedback{display:flex;align-items:center;gap:.5rem;padding:.6rem .875rem;border-radius:var(--radius-sm);font-size:.875rem;font-weight:500}.scan-feedback.notfound{background:var(--danger-light);color:var(--danger)}.scanned-item{padding:1rem;background:var(--success-light);border-radius:var(--radius-lg);border:1.5px solid var(--success)}.item-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;font-size:.875rem;font-weight:700;color:var(--success)}.check-icon{color:var(--success)}.clear-scan-btn{margin-left:auto;background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:2px;display:flex;border-radius:3px;transition:color .12s ease}.clear-scan-btn:hover{color:var(--danger)}.item-details{display:flex;flex-direction:column;gap:.4rem;margin-bottom:.875rem}.item-field{display:flex;align-items:center;gap:.5rem;font-size:.875rem}.item-field-label{color:var(--text-muted);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;min-width:48px}.item-field code{font-family:monospace;font-size:.82rem;background:rgba(0,0,0,.06);padding:1px 5px;border-radius:3px;color:var(--text)}.quantity-input{display:flex;align-items:center;gap:.75rem}.quantity-input label{font-size:.82rem;font-weight:600;color:var(--text-secondary)}.quantity-input input{width:72px;padding:.45rem .6rem;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:.9rem;background:white}.quantity-input input:focus{outline:none;border-color:var(--primary)}.shelf-selection{background:var(--surface);border-radius:var(--radius-lg);padding:1.25rem;box-shadow:var(--shadow);max-height:640px;overflow-y:auto}.shelf-selection h3{font-size:.8rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.07em;margin-bottom:.875rem}.shelf-list{display:flex;flex-direction:column;gap:.5rem}.no-shelves{color:var(--text-muted);font-size:.875rem;text-align:center;padding:2rem}.shelf-item{border:1.5px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease;position:relative;padding:.875rem 1rem .875rem 1.1rem}.shelf-item:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;border-radius:var(--radius) 0 0 var(--radius)}.shelf-item.low:before{background:var(--danger)}.shelf-item.medium:before{background:var(--warning)}.shelf-item.good:before{background:var(--success)}.shelf-item:hover{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.shelf-item.selected{border-color:var(--primary);background:var(--primary-light);box-shadow:0 0 0 3px #4f46e526}.shelf-item-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.35rem}.shelf-name{font-weight:700;color:var(--text);font-size:.9rem;flex:1}.stock-badge{font-size:.75rem;font-weight:700;padding:2px 7px;border-radius:99px}.stock-badge.low{background:var(--danger-light);color:var(--danger)}.stock-badge.medium{background:var(--warning-light);color:var(--warning)}.stock-badge.good{background:var(--success-light);color:var(--success)}.alert-icon{color:var(--danger);flex-shrink:0}.backroom-message{font-size:.78rem;color:var(--text-muted);margin-top:.25rem}.shelf-items-preview{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.6rem}.item-tag{background:var(--bg);border:1px solid var(--border);padding:2px 8px;border-radius:99px;font-size:.75rem;color:var(--text-secondary)}.action-bar{position:fixed;bottom:2rem;left:50%;transform:translate(-50%);z-index:200}.add-stock-btn{padding:.875rem 2rem;background:var(--primary);color:#fff;border:none;border-radius:99px;font-size:1rem;font-weight:700;cursor:pointer;display:flex;align-items:center;gap:.6rem;box-shadow:0 8px 24px #4f46e566;transition:all .15s ease;white-space:nowrap}.add-stock-btn:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 12px 28px #4f46e573}.item-manager-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.45);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.item-manager{background:var(--surface);border-radius:var(--radius-lg);max-width:860px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.manager-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--surface);z-index:10;gap:1rem}.manager-header h2{font-size:1.1rem;font-weight:700;color:var(--text);letter-spacing:-.02em}.manager-header-actions{display:flex;align-items:center;gap:.75rem}.csv-actions{display:flex;gap:4px}.csv-btn{padding:.35rem .8rem;border-radius:var(--radius-sm);font-size:.8rem;font-weight:600;cursor:pointer;transition:all .15s ease;white-space:nowrap}.csv-btn.export{background:transparent;color:var(--success);border:1.5px solid var(--success)}.csv-btn.export:hover{background:var(--success-light)}.csv-btn.import{background:transparent;color:var(--primary);border:1.5px solid var(--primary)}.csv-btn.import:hover{background:var(--primary-light)}.hidden-file-input{display:none}.close-btn{width:32px;height:32px;border:1px solid var(--border);background:var(--bg);border-radius:var(--radius-sm);font-size:1.25rem;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all .15s ease;line-height:1}.close-btn:hover{background:var(--danger-light);color:var(--danger);border-color:var(--danger)}.manager-content{padding:1.5rem;display:flex;flex-direction:column;gap:2rem}.add-item{background:var(--bg);padding:1.25rem;border-radius:var(--radius-lg);border:1px solid var(--border)}.add-item h3{font-size:.8rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.07em;margin-bottom:1rem}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.875rem;margin-bottom:.875rem}.form-group{display:flex;flex-direction:column;gap:.35rem}.form-group label{font-size:.78rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.form-group input[type=text],.form-group input[type=number],.form-group select{padding:.6rem .75rem;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:.875rem;color:var(--text);background:var(--surface);transition:border-color .15s ease,box-shadow .15s ease}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.add-btn{width:100%;padding:.7rem;background:var(--primary);color:#fff;border:none;border-radius:var(--radius);font-size:.9rem;font-weight:600;cursor:pointer;transition:background .15s ease,transform .15s ease;margin-top:.25rem}.add-btn:hover{background:var(--primary-dark);transform:translateY(-1px)}.existing-items h3{font-size:.9rem;font-weight:700;color:var(--text);margin-bottom:.875rem}.item-count{color:var(--text-muted);font-weight:500}.no-items{color:var(--text-muted);font-size:.875rem;text-align:center;padding:2.5rem;border:1.5px dashed var(--border);border-radius:var(--radius-lg)}.items-list{display:flex;flex-direction:column;gap:.75rem}.item-card{display:flex;gap:1rem;padding:1rem;border:1.5px solid var(--border);border-radius:var(--radius-lg);transition:border-color .15s ease,box-shadow .15s ease}.item-card:hover{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.item-details{flex:1;display:flex;flex-direction:column;gap:.6rem}.item-name-input{padding:.5rem .65rem;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:.95rem;font-weight:600;color:var(--text);width:100%;transition:border-color .15s ease}.item-name-input:focus{outline:none;border-color:var(--primary)}.item-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:.6rem}.meta-field{display:flex;flex-direction:column;gap:.2rem}.meta-field label{font-size:.7rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.meta-input,.meta-select{padding:.4rem .5rem;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:.82rem;color:var(--text);background:var(--surface)}.meta-input.small{width:70px}.meta-input:focus,.meta-select:focus{outline:none;border-color:var(--primary)}.delete-btn{padding:.4rem .875rem;background:transparent;color:var(--danger);border:1.5px solid var(--danger);border-radius:var(--radius-sm);font-size:.8rem;font-weight:600;cursor:pointer;transition:all .15s ease;align-self:flex-start;white-space:nowrap}.delete-btn:hover{background:var(--danger-light)}.snapshot-group{margin-top:.25rem}.snapshot-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.snapshot-thumb{width:52px;height:52px;object-fit:cover;border-radius:var(--radius-sm);border:1.5px solid var(--border)}.snapshot-placeholder{width:52px;height:52px;border:1.5px dashed var(--border);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:.65rem;color:var(--text-muted);text-align:center}.snapshot-btn{padding:.3rem .7rem;font-size:.78rem;font-weight:600;background:var(--primary-light);color:var(--primary);border:1.5px solid var(--primary);border-radius:var(--radius-sm);cursor:pointer;transition:background .12s ease}.snapshot-btn:hover{background:var(--primary);color:#fff}.snapshot-remove-btn{padding:.3rem .6rem;font-size:.78rem;background:transparent;color:var(--danger);border:1.5px solid var(--danger);border-radius:var(--radius-sm);cursor:pointer;transition:background .12s ease}.snapshot-remove-btn:hover{background:var(--danger-light)}.item-snapshot-col{flex-shrink:0;display:flex;align-items:flex-start}.snapshot-upload-label{cursor:pointer;display:block;position:relative}.snapshot-thumb-lg{width:64px;height:64px;object-fit:cover;border-radius:var(--radius-sm);border:1.5px solid var(--border);transition:opacity .12s ease;display:block}.snapshot-thumb-lg:hover{opacity:.75}.snapshot-placeholder-lg{width:64px;height:64px;border:1.5px dashed var(--border);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1.4rem;background:var(--bg);transition:border-color .12s ease}.snapshot-upload-label:hover .snapshot-placeholder-lg{border-color:var(--primary)}.barcode-field-row{display:flex;gap:.5rem;align-items:stretch}.barcode-field-row input{flex:1;min-width:0}.scan-barcode-btn{padding:0 .875rem;font-size:.82rem;font-weight:600;background:var(--primary-light);color:var(--primary);border:1.5px solid var(--primary);border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;transition:background .12s ease,color .12s ease;flex-shrink:0}.scan-barcode-btn:hover{background:var(--primary);color:#fff}.scan-confirm-card{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.875rem 1.25rem;border-radius:var(--radius);border:2px solid transparent;margin-bottom:.5rem;flex-wrap:wrap}.scan-confirm-card.found{background:var(--success-light);border-color:var(--success)}.scan-confirm-card.unknown{background:var(--warning-light);border-color:var(--warning)}.scan-confirm-card.already-exists{background:var(--primary-light);border-color:var(--primary)}.scan-confirm-left{display:flex;align-items:center;gap:.75rem;flex:1;min-width:0}.scan-confirm-img{width:52px;height:52px;object-fit:cover;border-radius:var(--radius-sm);flex-shrink:0}.scan-confirm-icon{width:52px;height:52px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;background:white;border-radius:var(--radius-sm);flex-shrink:0}.scan-confirm-info{display:flex;flex-direction:column;gap:2px;min-width:0}.scan-confirm-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary)}.scan-confirm-label.already{color:var(--primary)}.scan-confirm-name{font-size:.95rem;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.scan-confirm-barcode{font-size:.72rem;color:var(--text-muted);font-family:monospace}.scan-confirm-actions{display:flex;gap:.5rem;flex-shrink:0}.scan-add-btn{padding:.5rem 1.1rem;background:var(--success);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.88rem;font-weight:700;cursor:pointer;transition:background .12s ease;white-space:nowrap}.scan-add-btn:hover:not(:disabled){background:#15803d}.scan-add-btn:disabled{opacity:.6;cursor:default}.scan-edit-btn{padding:.5rem .875rem;background:transparent;color:var(--text-secondary);border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:.82rem;font-weight:600;cursor:pointer;transition:border-color .12s ease,color .12s ease;white-space:nowrap}.scan-edit-btn:hover{border-color:var(--primary);color:var(--primary)}.scan-discard-btn{padding:.5rem .875rem;background:transparent;color:var(--text-muted);border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:.82rem;font-weight:600;cursor:pointer}.lookup-hint{font-size:.75rem;font-weight:600;margin-top:.35rem}.lookup-loading{color:var(--text-muted)}.lookup-found{color:var(--success)}.lookup-notfound{color:var(--warning)}.lookup-error{color:var(--danger)}.im-camera-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.82);z-index:2000;display:flex;align-items:center;justify-content:center;padding:1.25rem}.im-camera-modal{background:#000;border-radius:var(--radius-lg);overflow:hidden;width:100%;max-width:500px;box-shadow:0 25px 60px #000000b3}.im-camera-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:rgba(255,255,255,.07);color:#f1f5f9;font-size:.88rem;font-weight:600}.im-camera-close{width:30px;height:30px;border:none;background:rgba(255,255,255,.12);color:#f1f5f9;border-radius:var(--radius-sm);font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .12s ease}.im-camera-close:hover{background:var(--danger)}.im-camera-body{position:relative;aspect-ratio:16 / 9;background:#111;overflow:hidden}.im-camera-feed{width:100%;height:100%;object-fit:cover;display:block}.im-scan-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;pointer-events:none}.im-scan-box{position:relative;width:75%;height:40%;box-shadow:0 0 0 9999px #0000007a;border-radius:4px}.im-corner{position:absolute;width:20px;height:20px;border-color:#fff;border-style:solid}.im-corner.tl{top:-2px;left:-2px;border-width:3px 0 0 3px;border-radius:3px 0 0}.im-corner.tr{top:-2px;right:-2px;border-width:3px 3px 0 0;border-radius:0 3px 0 0}.im-corner.bl{bottom:-2px;left:-2px;border-width:0 0 3px 3px;border-radius:0 0 0 3px}.im-corner.br{bottom:-2px;right:-2px;border-width:0 3px 3px 0;border-radius:0 0 3px}.im-scan-line{position:absolute;left:4px;right:4px;height:2px;background:linear-gradient(90deg,transparent 0%,#ef4444 30%,#ef4444 70%,transparent 100%);box-shadow:0 0 8px 2px #ef444499;animation:im-sweep 2s ease-in-out infinite}@keyframes im-sweep{0%{top:4px;opacity:.6}50%{top:calc(100% - 6px);opacity:1}to{top:4px;opacity:.6}}.im-scan-hint{color:#ffffffd1;font-size:.78rem;font-weight:500;text-shadow:0 1px 3px rgba(0,0,0,.8);text-align:center}.im-capture-fallback{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:2rem;color:#ffffffbf;font-size:.88rem;text-align:center;line-height:1.6}.im-photo-btn{padding:.6rem 1.5rem;background:var(--primary);color:#fff;border:none;border-radius:var(--radius);font-size:.9rem;font-weight:600;cursor:pointer;transition:background .15s ease}.im-photo-btn:hover{background:var(--primary-dark)}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background:#0f172a;color:#fff;padding:0 1.5rem;height:58px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;box-shadow:0 1px #ffffff0f}.app-header h1{font-size:1.05rem;font-weight:700;letter-spacing:-.01em;color:#f8fafc}.nav-buttons{display:flex;gap:2px;background:rgba(255,255,255,.06);border-radius:var(--radius);padding:3px}.nav-buttons button{background:transparent;border:none;color:#94a3b8;padding:.45rem 1rem;border-radius:calc(var(--radius) - 2px);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s ease;white-space:nowrap}.nav-buttons button:hover{background:rgba(255,255,255,.08);color:#f1f5f9}.nav-buttons button.active{background:var(--primary);color:#fff;font-weight:600}.app-main{flex:1;padding:1.5rem;overflow-y:auto}.app-main--full{padding:0;overflow:hidden;display:flex;flex-direction:column}.items-view{max-width:1100px;margin:0 auto;display:flex;flex-direction:column;gap:1.25rem}.items-header{background:var(--surface);padding:1.5rem;border-radius:var(--radius-lg);box-shadow:var(--shadow);display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;flex-wrap:wrap}.items-header-text h2{color:var(--text);font-size:1.25rem;font-weight:700;letter-spacing:-.02em;margin-bottom:.25rem}.items-header-text p{color:var(--text-secondary);font-size:.875rem}.manage-items-btn{padding:.55rem 1.25rem;background:var(--primary);color:#fff;border:none;border-radius:var(--radius);font-size:.875rem;font-weight:600;cursor:pointer;transition:background .15s ease,transform .15s ease;white-space:nowrap}.manage-items-btn:hover{background:var(--primary-dark);transform:translateY(-1px)}.items-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem}.summary-card{background:var(--surface);padding:1.25rem 1.5rem;border-radius:var(--radius-lg);box-shadow:var(--shadow);border-left:3px solid var(--primary)}.summary-label{color:var(--text-secondary);font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;display:block;margin-bottom:.5rem}.summary-value{color:var(--text);font-size:2rem;font-weight:800;letter-spacing:-.03em;line-height:1}.items-preview{background:var(--surface);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow)}.items-preview-title{font-size:.875rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:1rem}.item-preview-card{padding:.875rem 1rem;border:1px solid var(--border);border-radius:var(--radius);margin-bottom:.5rem;transition:border-color .15s ease,box-shadow .15s ease;display:flex;align-items:center;gap:1rem}.item-preview-card:hover{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.item-preview-thumb{width:40px;height:40px;object-fit:cover;border-radius:var(--radius-sm);flex-shrink:0}.item-preview-info{display:flex;align-items:center;gap:.75rem;flex:1;min-width:0}.item-preview-name{font-weight:600;color:var(--text);font-size:.9rem}.item-preview-sku{color:var(--text-muted);font-size:.8rem;font-family:monospace;margin-left:auto}.item-preview-barcode{color:var(--primary);font-size:.78rem;font-weight:500}.more-items{text-align:center;color:var(--text-muted);font-size:.85rem;padding:.75rem;border:1px dashed var(--border);border-radius:var(--radius)}
