:root{--bg: #0f1419;--surface: #1a2332;--surface-2: #243044;--border: #2d3f56;--text: #e8eef5;--muted: #8fa3bc;--primary: #3b82f6;--primary-hover: #2563eb;--accent: #10b981;--warn: #f59e0b;--danger: #ef4444;--radius: 12px;--shadow: 0 8px 32px rgba(0, 0, 0, .35);font-family:DM Sans,system-ui,sans-serif;color:var(--text);background:var(--bg);line-height:1.5}*{box-sizing:border-box}body{margin:0;min-height:100vh}h1,h2,h3,p{margin:0}a{color:inherit;text-decoration:none}code{font-size:.9em;background:var(--surface-2);padding:.15rem .4rem;border-radius:6px}.app-shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh}.sidebar{background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:1.25rem;gap:1.5rem}.brand{display:flex;gap:.75rem;align-items:center}.brand.center{flex-direction:column;text-align:center;margin-bottom:.5rem}.brand-mark{width:42px;height:42px;border-radius:10px;background:linear-gradient(135deg,var(--primary),#6366f1);display:grid;place-items:center;font-weight:700;font-size:.85rem}.brand-mark.lg{width:56px;height:56px;font-size:1rem}.brand small,.brand p{color:var(--muted);font-size:.85rem}.sidebar nav{display:flex;flex-direction:column;gap:.35rem;flex:1}.sidebar nav a{padding:.65rem .85rem;border-radius:8px;color:var(--muted);font-weight:500}.sidebar nav a.active,.sidebar nav a:hover{background:var(--surface-2);color:var(--text)}.sidebar-footer{border-top:1px solid var(--border);padding-top:1rem;display:grid;gap:.75rem}.user-chip{display:grid;gap:.15rem;font-size:.9rem}.user-chip span{color:var(--muted)}.user-chip small{color:var(--muted);font-size:.8rem}.main{padding:1.75rem 2rem;overflow:auto;min-width:0}.page{display:grid;gap:1.25rem;max-width:1400px;width:100%;min-width:0}.page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap}.page-header p{color:var(--muted);margin-top:.35rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;box-shadow:var(--shadow)}.card h2{font-size:1.05rem;margin-bottom:1rem}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.15rem;display:grid;gap:.35rem}.stat-card span{color:var(--muted);font-size:.85rem}.stat-card strong{font-size:1.75rem}.stat-card.accent strong{color:var(--accent)}.stat-card.warn strong{color:var(--warn)}.stat-card-btn{text-align:left;cursor:pointer;font:inherit;color:inherit;transition:border-color .15s,box-shadow .15s}.stat-card-btn:hover{border-color:var(--primary)}.stat-card-btn.active{border-color:var(--primary);box-shadow:0 0 0 1px #3b82f659}.stat-card-btn.warn.active{border-color:var(--warn);box-shadow:0 0 0 1px #f59e0b59}.stat-card-btn.accent.active{border-color:var(--accent);box-shadow:0 0 0 1px #10b98159}.section-header-row{display:flex;justify-content:space-between;align-items:center;gap:.75rem;flex-wrap:wrap;margin-bottom:1rem}.section-header-row h2{margin-bottom:0}.filter-badge{font-size:.85rem}.sort-header{background:none;border:none;color:inherit;font:inherit;font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.04em;cursor:pointer;padding:0;display:inline-flex;align-items:center;gap:.15rem}.sort-header:hover{color:var(--text)}.sort-header.active{color:var(--primary)}.sort-indicator{font-size:.75rem;opacity:.85}.link-btn{background:none;border:none;color:var(--primary);font:inherit;font-weight:600;cursor:pointer;padding:0;text-decoration:underline}.low-stock-qty{color:var(--warn);font-weight:600}.grid-2{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,.8fr);gap:1.25rem;align-items:start}.grid-2>*{min-width:0}.catalog-layout{display:grid;grid-template-columns:minmax(200px,220px) minmax(0,1fr);gap:1rem;align-items:start}.catalog-layout .add-product-card .form-stack{gap:.65rem}.catalog-layout .add-product-card label{font-size:.82rem;gap:.25rem}.catalog-layout .add-product-card input{padding:.45rem .55rem;font-size:.88rem}.catalog-layout .add-product-card h2{font-size:1rem;margin-bottom:.75rem}.catalog-table-card{min-width:0}.sort-header{background:none;border:none;color:inherit;font:inherit;font-weight:600;font-size:.78rem;letter-spacing:.04em;text-transform:uppercase;padding:0;cursor:pointer;text-align:left;white-space:nowrap;display:inline-flex;align-items:center;gap:.25rem}.sort-header:hover,.sort-header.active{color:var(--accent)}.sort-header .sort-icon{opacity:.45;font-size:.7rem}.sort-header.active .sort-icon{opacity:1}.num-cell{text-align:right;font-variant-numeric:tabular-nums}.stack{display:grid;gap:1.25rem}@media(max-width:960px){.app-shell{grid-template-columns:1fr}.sidebar{position:fixed;inset:0 auto 0 0;z-index:40;width:260px;transform:translate(-100%);transition:transform .2s ease}.sidebar.open{transform:translate(0)}.sidebar-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:30;border:none;background:#00000080;cursor:pointer}.mobile-topbar{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.menu-btn{flex-shrink:0}.grid-2,.catalog-layout{grid-template-columns:1fr}}@media(min-width:961px){.mobile-topbar,.sidebar-backdrop{display:none}}.welcome-card{background:linear-gradient(135deg,#3b82f61f,#10b98114)}.steps{margin:0;padding-left:1.25rem;display:grid;gap:.5rem;color:var(--muted)}.steps a{color:var(--primary);font-weight:600}.steps a:hover{text-decoration:underline}.table-wrap{overflow:auto;max-width:100%}table{width:100%;border-collapse:collapse;font-size:.92rem}.stock-table{table-layout:fixed}.stock-table th:nth-child(1),.stock-table td:nth-child(1){width:7rem}.stock-table th:nth-child(3),.stock-table td:nth-child(3),.stock-table th:nth-child(4),.stock-table td:nth-child(4),.stock-table th:nth-child(5),.stock-table td:nth-child(5),.stock-table th:nth-child(6),.stock-table td:nth-child(6){width:5rem;text-align:right;white-space:nowrap}.stock-table .product-name-cell{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}th,td{text-align:left;padding:.65rem .5rem;border-bottom:1px solid var(--border)}th{color:var(--muted);font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.04em}.muted{color:var(--muted)}.badge{display:inline-block;padding:.2rem .55rem;border-radius:999px;background:var(--surface-2);font-size:.78rem;font-weight:600}.badge.ok{background:#10b98133;color:var(--accent)}.badge.warn{background:#f59e0b33;color:var(--warn)}.review-list{display:grid;gap:.75rem}.review-item{border:1px solid var(--border);border-radius:10px;overflow:hidden}.review-item-header{width:100%;text-align:left;background:var(--surface-2);border:none;color:inherit;font:inherit;padding:.85rem 1rem;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}.review-item-header:hover{background:#3b82f614}.review-meta{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.review-item-body{padding:1rem;border-top:1px solid var(--border)}.review-actions{margin-top:1rem;display:grid;gap:.75rem}.http-auth-details summary{cursor:pointer;font-weight:600;color:var(--muted)}.http-auth-details[open] summary{color:var(--text);margin-bottom:.25rem}.actions{display:flex;gap:.35rem;flex-wrap:wrap}.btn{border:none;border-radius:8px;padding:.6rem 1rem;font:inherit;font-weight:600;cursor:pointer;transition:background .15s,opacity .15s}.btn:disabled{opacity:.6;cursor:not-allowed}.btn.primary{background:var(--primary);color:#fff}.btn.primary:hover:not(:disabled){background:var(--primary-hover)}.btn.secondary{background:var(--surface-2);color:var(--text);border:1px solid var(--border)}.btn.ghost{background:transparent;color:var(--muted);border:1px solid var(--border)}.btn.small{padding:.35rem .65rem;font-size:.82rem}.btn.full{width:100%}label{display:grid;gap:.35rem;font-size:.9rem;font-weight:500}input,select,textarea{background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:.6rem .75rem;font:inherit}input:focus,select:focus{outline:2px solid rgba(59,130,246,.45);border-color:var(--primary)}.form-stack{display:grid;gap:.85rem}.inline-fields{display:flex;gap:.5rem;align-items:center}.inline-fields input,.inline-fields select{flex:1}.inline-filter-row,.receivables-filters{display:flex;flex-wrap:wrap;gap:.75rem;align-items:flex-end}.inline-filter-row label,.receivables-filters label{display:grid;gap:.35rem;font-size:.85rem;color:var(--muted)}.checkbox-inline{display:flex!important;align-items:center;gap:.45rem;font-size:.9rem;color:var(--text);padding-bottom:.35rem}.receipt-balance-panel{display:flex;flex-wrap:wrap;gap:1rem 1.5rem;align-items:center;margin:1rem 0;padding:.85rem 1rem;border-radius:8px;background:var(--surface-2);border:1px solid var(--border)}.badge.warn{background:#f59e0b2e;border-color:#f59e0b59;color:var(--warn)}.badge.ok{background:#10b98126;border-color:#10b98159;color:var(--accent)}.tab-group{display:flex;gap:.35rem}.tab{background:var(--surface-2);border:1px solid var(--border);color:var(--muted);padding:.5rem 1rem;border-radius:8px;cursor:pointer;font:inherit;font-weight:600}.tab.active{background:var(--primary);border-color:var(--primary);color:#fff}.alert{padding:.75rem 1rem;border-radius:8px;font-size:.92rem}.action-row{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}.block-help{margin-bottom:1rem;font-size:.92rem}.info-box{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:.75rem 1rem;display:grid;gap:.35rem;margin-bottom:.75rem}.info-box code{word-break:break-all}.ok-text{color:var(--accent);margin-top:.75rem}.warn-text{color:var(--warn);margin-top:.75rem}.alert.error{background:#ef444426;border:1px solid rgba(239,68,68,.35)}.alert.info{background:#3b82f61f;border:1px solid rgba(59,130,246,.3)}.login-page{min-height:100vh;display:grid;place-items:center;padding:1.5rem;background:radial-gradient(circle at top,#1e3a5f 0%,var(--bg) 55%)}.login-card{width:min(420px,100%);background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:2rem;display:grid;gap:1rem;box-shadow:var(--shadow)}.center-page{min-height:100vh;display:grid;place-items:center;color:var(--muted)}.search-bar-row{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.search-sort-row{display:flex;flex-wrap:wrap;align-items:flex-end;gap:.75rem 1.25rem;margin-bottom:1rem}.search-sort-row .search-bar-row{margin-bottom:0;flex:1;min-width:min(100%,280px)}.list-sort-controls{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem .75rem}.list-sort-field{display:flex;align-items:center;gap:.45rem;font-size:.88rem;font-weight:500}.list-sort-label{color:var(--muted);white-space:nowrap}.list-sort-field select{padding:.45rem .55rem;font-size:.88rem;min-width:7.5rem}.list-sort-dir .tab{padding:.4rem .7rem;font-size:.82rem}.search-input{flex:1;max-width:420px;padding:.55rem .85rem;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--text);font:inherit}.search-count{font-size:.88rem;white-space:nowrap}.warn-qty{color:var(--warn)}.row-selected{background:#3b82f614}.vendor-radio-group{display:flex;flex-direction:column;gap:.35rem;min-width:160px}.vendor-radio{display:flex;align-items:center;gap:.45rem;font-size:.9rem;cursor:pointer}.vendor-radio input{accent-color:var(--primary)}.invoice-create-panel{margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid var(--border);display:grid;gap:.85rem}.invoice-meta-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.75rem;margin-bottom:1rem}.invoice-meta-grid>div{display:grid;gap:.2rem}.nav-section{display:grid;gap:.25rem;margin-bottom:.85rem}.nav-section-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);padding:0 .85rem;margin-bottom:.15rem}.stat-grid.compact{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));margin-bottom:1rem}.cost-input{width:100px;padding:.35rem .5rem;border-radius:6px;border:1px solid var(--border);background:var(--bg);color:var(--text)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:grid;place-items:center;z-index:100;padding:1rem}.modal-card{width:min(480px,100%);background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:1.25rem;box-shadow:var(--shadow)}.scan-card .form-stack{margin-top:.75rem}.scan-mode-row{display:flex;gap:.5rem;margin-bottom:.85rem}.scan-hint{margin-top:.75rem;font-size:.92rem}.scan-error-row{background:#ef444414}.camera-wrap{margin-top:1rem;display:grid;gap:.5rem}.camera-video,.camera-preview{width:100%;max-height:280px;border-radius:10px;background:#000;object-fit:cover}.scan-panel{margin:1rem 0;padding:1rem;border-radius:10px;border:1px solid var(--border);background:#3b82f60a}.scan-panel h3,.scan-panel h4{margin:0 0 .5rem}.scan-controls{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.scan-controls input[type=text],.scan-controls input:not([type]){flex:1;min-width:180px;padding:.55rem .75rem;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--text)}.qty-input{width:72px;padding:.45rem .5rem;border-radius:6px;border:1px solid var(--border)}.assign-target-panel{border-color:var(--primary);background:#3b82f61a}.unknown-product-panel{margin-top:1rem;padding:1rem;border-radius:10px;border:1px dashed var(--warn);background:#f59e0b0f}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.btn.small{padding:.3rem .65rem;font-size:.85rem}
