@import url(https://fonts.googleapis.com/css2?family=Figtree:wght@400;500;600;700;800;900&family=IBM+Plex+Mono:wght@400;500;600&display=swap);:root{--ds-navy:#0f172a;--ds-navy-mid:#1e293b;--ds-navy-light:#334155;--ds-green:#16a34a;--ds-green-dark:#15803d;--ds-green-deeper:#14532d;--ds-green-tint:#f0fdf4;--ds-green-light:#dcfce7;--ds-gold:#d97706;--ds-gold-dark:#b45309;--ds-gold-tint:#fffbeb;--ds-gold-light:#fef3c7;--ds-bg:#f1f5f9;--ds-surface:#fff;--ds-surface-raised:#f8fafc;--ds-surface-sunken:#e8eef4;--ds-border:#e2e8f0;--ds-border-mid:#cbd5e1;--ds-border-strong:#94a3b8;--ds-text:#0f172a;--ds-text-mid:#334155;--ds-text-sub:#475569;--ds-text-muted:#94a3b8;--ds-text-inverse:#fff;--ds-text-link:#16a34a;--ds-success:#16a34a;--ds-success-bg:#f0fdf4;--ds-success-border:#86efac;--ds-warning:#d97706;--ds-warning-bg:#fffbeb;--ds-warning-border:#fcd34d;--ds-danger:#dc2626;--ds-danger-bg:#fef2f2;--ds-danger-border:#fca5a5;--ds-info:#2563eb;--ds-info-bg:#eff6ff;--ds-info-border:#93c5fd;--ds-neutral:#64748b;--ds-neutral-bg:#f8fafc;--ds-neutral-border:#e2e8f0;--ds-font-ui:"Inter","Figtree","Segoe UI",system-ui,sans-serif;--ds-font-mono:"IBM Plex Mono","Consolas","Courier New",monospace;--ds-text-xs:11px;--ds-text-sm:12px;--ds-text-base:14px;--ds-text-md:15px;--ds-text-lg:16px;--ds-text-xl:20px;--ds-text-2xl:24px;--ds-text-3xl:30px;--ds-sp-1:4px;--ds-sp-2:8px;--ds-sp-3:12px;--ds-sp-4:16px;--ds-sp-5:20px;--ds-sp-6:24px;--ds-sp-8:32px;--ds-sp-10:40px;--ds-sp-12:48px;--ds-r-xs:2px;--ds-r-sm:4px;--ds-r-md:8px;--ds-r-lg:12px;--ds-r-xl:16px;--ds-r-pill:999px;--ds-shadow-xs:0 1px 2px #0f172a0a;--ds-shadow-sm:0 1px 3px #0f172a14;--ds-shadow-md:0 4px 12px #0f172a1a;--ds-shadow-lg:0 8px 24px #0f172a1f;--ds-shadow-card:0 1px 3px #0f172a0f,0 1px 2px #0f172a0a;--ds-t-fast:0.1s ease;--ds-t-base:0.15s ease;--ds-t-slow:0.25s ease}body{background:#f1f5f9;background:var(--ds-bg);color:#0f172a;color:var(--ds-text);font-family:Inter,Figtree,Segoe UI,system-ui,sans-serif!important;font-family:var(--ds-font-ui)!important;line-height:1.5}.ds-table,body{font-size:14px;font-size:var(--ds-text-base)}.ds-table{border-collapse:collapse;font-family:Inter,Figtree,Segoe UI,system-ui,sans-serif;font-family:var(--ds-font-ui);width:100%}.ds-table thead th{background:#0f172a!important;background:var(--ds-navy)!important;border:none!important;color:#fff!important;color:var(--ds-text-inverse)!important;font-size:11px!important;font-size:var(--ds-text-xs)!important;font-weight:700!important;letter-spacing:.07em!important;padding:10px 14px!important;text-align:left!important;text-transform:uppercase!important;white-space:nowrap!important}.ds-table thead th.num{text-align:right!important}.ds-table tbody tr{border-bottom:1px solid #e2e8f0!important;border-bottom:1px solid var(--ds-border)!important;transition:background .1s ease!important;transition:background var(--ds-t-fast)!important}.ds-table tbody tr:nth-child(2n){background:#f8fafc!important;background:var(--ds-surface-raised)!important}.ds-table tbody tr:hover{background:#f0fdf4!important;background:var(--ds-green-tint)!important}.ds-table td{border-bottom:1px solid #e2e8f0!important;border-bottom:1px solid var(--ds-border)!important;color:#0f172a!important;color:var(--ds-text)!important;font-size:14px!important;font-size:var(--ds-text-base)!important;padding:9px 14px!important;vertical-align:middle!important}.ds-table td.num{letter-spacing:-.02em!important;text-align:right!important}.ds-table td.code,.ds-table td.num{font-family:IBM Plex Mono,Consolas,Courier New,monospace!important;font-family:var(--ds-font-mono)!important;font-size:12px!important;font-size:var(--ds-text-sm)!important}.ds-table td.code{color:#2563eb!important;color:var(--ds-info)!important;font-weight:500!important}.ds-page-header{align-items:center;background:#fff;background:var(--ds-surface);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--ds-border);display:flex;flex-wrap:wrap;gap:16px;gap:var(--ds-sp-4);justify-content:space-between;padding:16px 24px;padding:var(--ds-sp-4) var(--ds-sp-6)}.ds-page-title{color:#0f172a;color:var(--ds-text);font-size:20px;font-size:var(--ds-text-xl);font-weight:800;letter-spacing:-.4px;line-height:1.2}.ds-page-sub{color:#94a3b8;color:var(--ds-text-muted);font-size:12px;font-size:var(--ds-text-sm);font-weight:400;margin-top:2px}.ds-stats-row{grid-gap:16px;grid-gap:var(--ds-sp-4);display:grid;gap:16px;gap:var(--ds-sp-4);grid-template-columns:repeat(auto-fit,minmax(140px,1fr));margin-bottom:20px;margin-bottom:var(--ds-sp-5)}.ds-stat-card{background:#fff;background:var(--ds-surface);border:1px solid #e2e8f0;border:1px solid var(--ds-border);border-radius:8px;border-radius:var(--ds-r-md);box-shadow:0 1px 3px #0f172a0f,0 1px 2px #0f172a0a;box-shadow:var(--ds-shadow-card);overflow:hidden;padding:16px 20px;padding:var(--ds-sp-4) var(--ds-sp-5);position:relative}.ds-stat-card:before{background:#0f172a;background:var(--ds-navy);content:"";height:3px;left:0;position:absolute;right:0;top:0}.ds-stat-card.green:before{background:#16a34a;background:var(--ds-green)}.ds-stat-card.gold:before{background:#d97706;background:var(--ds-gold)}.ds-stat-card.danger:before{background:#dc2626;background:var(--ds-danger)}.ds-stat-card.blue:before{background:#2563eb;background:var(--ds-info)}.ds-stat-label{color:#94a3b8;color:var(--ds-text-muted);font-size:11px;font-size:var(--ds-text-xs);font-weight:700;letter-spacing:.07em;margin-bottom:8px;margin-bottom:var(--ds-sp-2);text-transform:uppercase}.ds-stat-value{color:#0f172a;color:var(--ds-text);font-family:IBM Plex Mono,Consolas,Courier New,monospace;font-family:var(--ds-font-mono);font-size:24px;font-size:var(--ds-text-2xl);font-weight:800;letter-spacing:-.03em;line-height:1.1}.ds-stat-sub{color:#475569;color:var(--ds-text-sub);font-size:12px;font-size:var(--ds-text-sm);margin-top:4px;margin-top:var(--ds-sp-1)}.ds-card{background:#fff;background:var(--ds-surface);border:1px solid #e2e8f0;border:1px solid var(--ds-border);border-radius:8px;border-radius:var(--ds-r-md);box-shadow:0 1px 3px #0f172a0f,0 1px 2px #0f172a0a;box-shadow:var(--ds-shadow-card);overflow:hidden}.ds-card-header{align-items:center;background:#f8fafc;background:var(--ds-surface-raised);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--ds-border);display:flex;justify-content:space-between;padding:16px 20px;padding:var(--ds-sp-4) var(--ds-sp-5)}.ds-card-title{color:#0f172a;color:var(--ds-text);font-size:15px;font-size:var(--ds-text-md);font-weight:700}.ds-card-body{padding:20px;padding:var(--ds-sp-5)}.ds-btn{align-items:center;border:1px solid #0000;border-radius:4px;border-radius:var(--ds-r-sm);cursor:pointer;display:inline-flex;font-family:Inter,Figtree,Segoe UI,system-ui,sans-serif;font-family:var(--ds-font-ui);font-size:12px;font-size:var(--ds-text-sm);font-weight:600;gap:8px;gap:var(--ds-sp-2);line-height:1;padding:7px 14px;text-decoration:none;transition:all .15s ease;transition:all var(--ds-t-base);white-space:nowrap}.ds-btn:disabled{cursor:not-allowed;opacity:.45}.ds-btn-primary{background:#16a34a;background:var(--ds-green);border-color:#16a34a;border-color:var(--ds-green);color:#fff}.ds-btn-primary:hover:not(:disabled){background:#15803d;background:var(--ds-green-dark);border-color:#15803d;border-color:var(--ds-green-dark)}.ds-btn-secondary{background:#fff;background:var(--ds-surface);border-color:#cbd5e1;border-color:var(--ds-border-mid);color:#475569;color:var(--ds-text-sub)}.ds-btn-secondary:hover:not(:disabled){background:#f8fafc;background:var(--ds-surface-raised);border-color:#94a3b8;border-color:var(--ds-border-strong);color:#0f172a;color:var(--ds-text)}.ds-btn-danger{background:#fff;background:var(--ds-surface);border-color:#fca5a5;border-color:var(--ds-danger-border);color:#dc2626;color:var(--ds-danger)}.ds-btn-danger:hover:not(:disabled){background:#fef2f2;background:var(--ds-danger-bg);border-color:#dc2626;border-color:var(--ds-danger)}.ds-btn-ghost{background:#0000;border-color:#0000;color:#475569;color:var(--ds-text-sub)}.ds-btn-ghost:hover:not(:disabled){background:#f8fafc;background:var(--ds-surface-raised);color:#0f172a;color:var(--ds-text)}.ds-btn-sm{font-size:11px;font-size:var(--ds-text-xs);padding:5px 10px}.ds-btn-lg{font-size:15px;font-size:var(--ds-text-md);padding:10px 20px}.ds-badge{border:1px solid #0000;border-radius:4px;border-radius:var(--ds-r-sm);display:inline-block;font-family:Inter,Figtree,Segoe UI,system-ui,sans-serif;font-family:var(--ds-font-ui);font-size:11px;font-size:var(--ds-text-xs);font-weight:700;letter-spacing:.05em;padding:2px 7px;text-transform:uppercase;white-space:nowrap}.ds-badge-green{background:#dcfce7;background:var(--ds-green-light);border-color:#86efac;border-color:var(--ds-success-border);color:#14532d;color:var(--ds-green-deeper)}.ds-badge-gold{background:#fef3c7;background:var(--ds-gold-light);border-color:#fcd34d;border-color:var(--ds-warning-border);color:#b45309;color:var(--ds-gold-dark)}.ds-badge-red{background:#fef2f2;background:var(--ds-danger-bg);border-color:#fca5a5;border-color:var(--ds-danger-border);color:#dc2626;color:var(--ds-danger)}.ds-badge-blue{background:#eff6ff;background:var(--ds-info-bg);border-color:#93c5fd;border-color:var(--ds-info-border);color:#2563eb;color:var(--ds-info)}.ds-badge-gray{background:#f8fafc;background:var(--ds-neutral-bg);border-color:#e2e8f0;border-color:var(--ds-neutral-border);color:#64748b;color:var(--ds-neutral)}.ds-badge-navy{background:#0f172a;background:var(--ds-navy);border-color:#0f172a;border-color:var(--ds-navy);color:#fff}.ds-label{color:#475569;color:var(--ds-text-sub);display:block;font-size:11px;font-size:var(--ds-text-xs);font-weight:700;letter-spacing:.06em;margin-bottom:4px;margin-bottom:var(--ds-sp-1);text-transform:uppercase}.ds-input{background:#fff;background:var(--ds-surface);border:1px solid #cbd5e1;border:1px solid var(--ds-border-mid);border-radius:4px;border-radius:var(--ds-r-sm);color:#0f172a;color:var(--ds-text);font-family:Inter,Figtree,Segoe UI,system-ui,sans-serif;font-family:var(--ds-font-ui);font-size:14px;font-size:var(--ds-text-base);outline:none;padding:8px 12px;transition:border-color .15s ease,box-shadow .15s ease;transition:border-color var(--ds-t-base),box-shadow var(--ds-t-base);width:100%}.ds-input:focus{border-color:#16a34a;border-color:var(--ds-green);box-shadow:0 0 0 3px #16a34a1f}.ds-alert{align-items:flex-start;border-left:3px solid;border-radius:4px;border-radius:var(--ds-r-sm);display:flex;font-size:12px;font-size:var(--ds-text-sm);font-weight:500;gap:12px;gap:var(--ds-sp-3);margin-bottom:16px;margin-bottom:var(--ds-sp-4);padding:10px 14px}.ds-alert-success{background:#f0fdf4;background:var(--ds-success-bg);border-color:#16a34a;border-color:var(--ds-green);color:#14532d;color:var(--ds-green-deeper)}.ds-alert-error{background:#fef2f2;background:var(--ds-danger-bg);border-color:#dc2626;border-color:var(--ds-danger);color:#7f1d1d}.ds-alert-warning{background:#fffbeb;background:var(--ds-warning-bg);border-color:#d97706;border-color:var(--ds-gold);color:#78350f}.ds-alert-info{background:#eff6ff;background:var(--ds-info-bg);border-color:#2563eb;border-color:var(--ds-info);color:#1e3a8a}.ds-filter-bar{background:#f8fafc;background:var(--ds-surface-raised);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--ds-border);flex-wrap:wrap;padding:16px 20px;padding:var(--ds-sp-4) var(--ds-sp-5)}.ds-filter-bar,.ds-loading{align-items:center;display:flex;gap:12px;gap:var(--ds-sp-3)}.ds-loading{font-size:14px;font-size:var(--ds-text-base);justify-content:center;padding:48px;padding:var(--ds-sp-12)}.ds-empty,.ds-loading{color:#94a3b8;color:var(--ds-text-muted)}.ds-empty{padding:48px 24px;padding:var(--ds-sp-12) var(--ds-sp-6);text-align:center}.ds-empty-title{color:#475569;color:var(--ds-text-sub);font-size:16px;font-size:var(--ds-text-lg);font-weight:700;margin-bottom:8px;margin-bottom:var(--ds-sp-2)}.ds-code,.ds-mono{font-family:IBM Plex Mono,Consolas,Courier New,monospace!important;font-family:var(--ds-font-mono)!important;font-size:12px!important;font-size:var(--ds-text-sm)!important}.ds-code{color:#2563eb!important;color:var(--ds-info)!important;font-weight:500!important}.ds-num{font-family:IBM Plex Mono,Consolas,Courier New,monospace!important;font-family:var(--ds-font-mono)!important;font-size:12px!important;font-size:var(--ds-text-sm)!important;text-align:right!important}.ds-positive{color:#16a34a!important;color:var(--ds-green)!important;font-weight:600!important}.ds-negative{color:#dc2626!important;color:var(--ds-danger)!important;font-weight:600!important}.ds-muted{color:#94a3b8!important;color:var(--ds-text-muted)!important}.ds-bold{font-weight:700!important}.ds-divider{background:#e2e8f0;background:var(--ds-border);border:none;height:1px;margin:20px 0;margin:var(--ds-sp-5) 0}.ds-section-title{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--ds-border);color:#94a3b8;color:var(--ds-text-muted);font-size:12px;font-size:var(--ds-text-sm);font-weight:700;letter-spacing:.07em;margin-bottom:16px;margin-bottom:var(--ds-sp-4);padding-bottom:8px;padding-bottom:var(--ds-sp-2);text-transform:uppercase}.code{color:#2563eb!important;color:var(--ds-info)!important;font-weight:500!important;letter-spacing:-.01em!important}.code,.value{font-family:IBM Plex Mono,Consolas,Courier New,monospace!important;font-family:var(--ds-font-mono)!important;font-size:12px!important;font-size:var(--ds-text-sm)!important}.value{color:#15803d!important;color:var(--ds-green-dark)!important;font-weight:600!important;text-align:right!important}.positive{color:#16a34a!important;color:var(--ds-green)!important}.negative,.positive{font-family:IBM Plex Mono,Consolas,Courier New,monospace!important;font-family:var(--ds-font-mono)!important;font-weight:600!important}.negative{color:#dc2626!important;color:var(--ds-danger)!important}.data-table thead th{background:#0f172a!important;background:var(--ds-navy)!important;font-size:13px!important;letter-spacing:.07em!important}.data-table td,.data-table thead th{font-family:Inter,Figtree,Segoe UI,system-ui,sans-serif!important;font-family:var(--ds-font-ui)!important;padding:12px 18px!important}.data-table td{font-size:14px!important;font-size:var(--ds-text-base)!important}.data-table tbody tr:hover{background:#f0fdf4!important;background:var(--ds-green-tint)!important}.status-pill{border-radius:4px!important;border-radius:var(--ds-r-sm)!important;font-size:11px!important;font-size:var(--ds-text-xs)!important;font-weight:700!important;letter-spacing:.05em!important;padding:3px 8px!important;text-transform:uppercase!important}.page-header h1,.status-pill{font-family:Inter,Figtree,Segoe UI,system-ui,sans-serif!important;font-family:var(--ds-font-ui)!important}.page-header h1{font-weight:800!important;letter-spacing:-.4px!important}.form-group label{color:#475569!important;color:var(--ds-text-sub)!important;font-size:11px!important;font-size:var(--ds-text-xs)!important;font-weight:700!important;letter-spacing:.06em!important}.filter-select,.form-group input,.form-group label,.form-group select,.form-group textarea,.search-input{font-family:Inter,Figtree,Segoe UI,system-ui,sans-serif!important;font-family:var(--ds-font-ui)!important}.filter-select,.form-group input,.form-group select,.form-group textarea,.search-input{border-color:#cbd5e1!important;border-color:var(--ds-border-mid)!important;border-radius:4px!important;border-radius:var(--ds-r-sm)!important;color:#0f172a!important;color:var(--ds-text)!important;font-size:var(--ds-text-base)!important}.filter-select:focus,.form-group input:focus,.form-group select:focus,.form-group textarea:focus,.search-input:focus{border-color:#16a34a!important;border-color:var(--ds-green)!important;box-shadow:0 0 0 3px #16a34a1f!important;outline:none!important}.action-btn.primary{background:#16a34a!important;background:var(--ds-green)!important;border-color:#16a34a!important;border-color:var(--ds-green)!important;border-radius:4px!important;border-radius:var(--ds-r-sm)!important;font-family:Inter,Figtree,Segoe UI,system-ui,sans-serif!important;font-family:var(--ds-font-ui)!important;font-weight:600!important;transition:background .15s ease!important;transition:background var(--ds-t-base)!important}.action-btn.primary:hover{background:#15803d!important;background:var(--ds-green-dark)!important;border-color:#15803d!important;border-color:var(--ds-green-dark)!important}.action-btn{font-weight:600!important}.action-btn,.submit-btn{border-radius:4px!important;border-radius:var(--ds-r-sm)!important;font-family:Inter,Figtree,Segoe UI,system-ui,sans-serif!important;font-family:var(--ds-font-ui)!important}.submit-btn{background:#16a34a!important;background:var(--ds-green)!important;font-weight:700!important;letter-spacing:.02em!important;transition:background .15s ease!important;transition:background var(--ds-t-base)!important}.submit-btn:hover:not(:disabled){background:#15803d!important;background:var(--ds-green-dark)!important}.header-icon{align-items:center!important;border-radius:8px!important;border-radius:var(--ds-r-md)!important;box-shadow:none!important;display:flex!important;flex-shrink:0!important;height:48px!important;justify-content:center!important;width:48px!important}.loading-state,.no-data{color:#94a3b8!important;color:var(--ds-text-muted)!important;font-family:Inter,Figtree,Segoe UI,system-ui,sans-serif!important;font-family:var(--ds-font-ui)!important;font-size:14px!important;font-size:var(--ds-text-base)!important}.no-data{padding:32px!important;padding:var(--ds-sp-8)!important;text-align:center!important}.back-btn{background:#f8fafc!important;background:var(--ds-surface-raised)!important;border:1px solid #cbd5e1!important;border:1px solid var(--ds-border-mid)!important;border-radius:4px!important;border-radius:var(--ds-r-sm)!important;color:#475569!important;color:var(--ds-text-sub)!important;font-family:Inter,Figtree,Segoe UI,system-ui,sans-serif!important;font-family:var(--ds-font-ui)!important;font-size:12px!important;font-size:var(--ds-text-sm)!important;font-weight:600!important}.back-btn:hover{background:#e8eef4!important;background:var(--ds-surface-sunken)!important;color:#0f172a!important;color:var(--ds-text)!important}.message.success{background:#f0fdf4!important;background:var(--ds-success-bg)!important;border-left-color:#16a34a!important;border-left-color:var(--ds-green)!important;border-radius:4px!important;border-radius:var(--ds-r-sm)!important;color:#14532d!important;color:var(--ds-green-deeper)!important}.message.error,.message.success{font-family:Inter,Figtree,Segoe UI,system-ui,sans-serif!important;font-family:var(--ds-font-ui)!important}.message.error{background:#fef2f2!important;background:var(--ds-danger-bg)!important;border-left-color:#dc2626!important;border-left-color:var(--ds-danger)!important;border-radius:4px!important;border-radius:var(--ds-r-sm)!important;color:#7f1d1d!important}.css-dropdown-menu button,.dropdown-menu button{font-family:Inter,Figtree,Segoe UI,system-ui,sans-serif!important;font-family:var(--ds-font-ui)!important}.admin-container,.purchasing-container,.sales-container,.stock-levels-container,.warehouse-container{background:#f1f5f9!important;background:var(--ds-bg)!important}@media (max-width:768px){.admin-container,.purchasing-container,.sales-container,.warehouse-container{padding:12px!important;padding:var(--ds-sp-3)!important}.page-header{align-items:flex-start!important;flex-direction:column!important;gap:12px!important;gap:var(--ds-sp-3)!important}.filter-bar{flex-wrap:wrap!important}.kpi-grid{grid-template-columns:repeat(2,1fr)!important}.ds-stats-row{grid-template-columns:repeat(2,1fr)}.action-btn{font-size:11px!important;font-size:var(--ds-text-xs)!important;padding:7px 12px!important}}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0}.visible{visibility:visible}.collapse{visibility:collapse}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.border-collapse{border-collapse:collapse}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.resize{resize:both}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.break-all{word-break:break-all}.border{border-width:1px}.uppercase{text-transform:uppercase}.lowercase{text-transform:lowercase}.capitalize{text-transform:capitalize}.italic{font-style:italic}.underline{text-decoration-line:underline}.outline{outline-style:solid}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-duration:.15s;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1)}.wms-kpi-row{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:16px}.wms-kpi-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;flex:1 1;min-width:140px;padding:14px 16px}.wms-kpi-label{color:#64748b;font-size:11px;letter-spacing:.5px;margin-bottom:4px;text-transform:uppercase}.wms-kpi-value{color:#1e293b;font-size:22px;font-weight:700}.wms-kpi-value.green{color:#16a34a}.wms-kpi-value.red{color:#dc2626}.wms-kpi-value.blue{color:#2563eb}.wms-kpi-value.amber{color:#d97706}.wms-btn-import{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:6px;color:#15803d;cursor:pointer;font-size:13px;font-weight:600;padding:8px 14px;transition:background .15s}.wms-btn-import:hover{background:#dcfce7}.wms-import-message{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:6px;color:#15803d;font-size:13px;margin:8px 0;padding:10px 14px}.wms-btn-action{border:none;border-radius:4px;cursor:pointer;font-size:11px;font-weight:600;padding:4px 8px;transition:opacity .15s}.wms-btn-action:hover{opacity:.85}.wms-btn-action.notify{background:#dcfce7;color:#15803d}.wms-btn-action.remind{background:#fef3c7;color:#92400e}.wms-btn-action.xml{background:#1a2332;color:#fff}.wms-btn-action.walkin{background:#6c757d;color:#fff}.wms-btn-action.whatsapp{background:#25d366;color:#fff}.wms-btn-action.email{background:#2563eb;color:#fff}.wms-badge{border-radius:4px;display:inline-block;font-size:11px;font-weight:700;padding:2px 8px;text-transform:uppercase}.wms-badge.paid{background:#dcfce7;color:#15803d}.wms-badge.partial{background:#fef3c7;color:#92400e}.wms-badge.unpaid{background:#fee2e2;color:#dc2626}.wms-badge.active{background:#dbeafe;color:#1d4ed8}.wms-badge.inactive{background:#f1f5f9;color:#64748b}.wms-badge.overdue{background:#fee2e2;color:#dc2626}.wms-badge.pending{background:#fef3c7;color:#92400e}.wms-badge.completed{background:#dcfce7;color:#15803d}.wms-badge.cancelled{background:#f1f5f9;color:#64748b}.wms-stock-badge{border-radius:4px;color:#fff;font-size:11px;font-weight:700;padding:1px 6px}.wms-stock-badge.out{background:#dc2626}.wms-stock-badge.low{background:#f59e0b}.wms-stock-badge.ok{background:#16a34a}.wms-btn-edit{background:#3498db;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;font-weight:600;padding:6px 12px}.wms-btn-edit:hover{background:#2980b9}.wms-btn-delete{background:#e74c3c;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;font-weight:600;padding:6px 12px}.wms-btn-delete:hover{background:#c0392b}.wms-flex-row{align-items:center;display:flex;gap:8px}.wms-flex-between{align-items:center;display:flex;justify-content:space-between}.wms-modal-section{border-top:1px solid #e2e8f0;margin-top:12px;padding-top:12px}.wms-input-discount{width:70px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.wms-shimmer{animation:shimmer 1.5s infinite;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);background-size:200% 100%;border-radius:4px}.admin-container,.analytics-container,.dashboard,.expiry-container,.inventory-dashboard-container,.page-content,.product-list-container,.purchasing-container,.sales-container,.stock-levels-container{animation:fadeIn .15s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.page-title{color:#1a2332;font-size:26px;font-weight:700;line-height:1.2;margin:0}.page-subtitle{color:#64748b;font-size:14px;font-weight:400;margin:2px 0 0}:root{--table-row-hover:#f0f7ff}.data-table tbody tr,.expiry-table tbody tr,.items-table tbody tr{transition:background .1s ease}.data-table tbody tr:hover,.expiry-table tbody tr:hover,.items-table tbody tr:hover{background:#f0f7ff!important;background:var(--table-row-hover)!important}.modal-overlay{animation:overlayIn .15s ease}.modal-card{animation:modalIn .2s ease}@keyframes overlayIn{0%{opacity:0}to{opacity:1}}@keyframes modalIn{0%{opacity:0;transform:scale(.96) translateY(-8px)}to{opacity:1;transform:scale(1) translateY(0)}}.admin-container,.analytics-container,.dashboard,.expiry-container,.inventory-dashboard-container,.product-list-container,.purchasing-container,.sales-container,.stock-levels-container{box-sizing:border-box;max-width:none;padding:24px 32px;width:100%}.wms-kpi-value{font-size:28px}.kpi-value{font-size:36px!important}.btn-primary,.submit-btn{font-size:14px!important;padding:9px 22px!important}.filter-select,.form-group input,.form-group select,.form-group textarea,.search-input{font-size:14px!important;padding:10px 14px!important}@media print{.btn-danger,.btn-primary,.btn-secondary,.modal-overlay,.nav-sidebar,.navigation,.no-print,.page-header-actions,.sidebar,.toast-container,.top-bar,button:not(.print-only),nav{display:none!important}body{background:#fff!important;font-family:Arial,sans-serif!important;font-size:11pt!important;margin:0!important;padding:0!important}.content-area,.dashboard-container,.main-content,.page-content,[class*=content-wrapper],[class*=main-content]{margin-left:0!important;max-width:100%!important;padding-left:12px!important;padding-right:12px!important;width:100%!important}h1,h2,h3{color:#000!important;page-break-after:avoid}.card,[class*=card],[class*=kpi]{background:#fff!important;border:1px solid #ccc!important;box-shadow:none!important;break-inside:avoid;page-break-inside:avoid}.kpi-grid,[class*=kpi-grid],[class*=stats-grid]{grid-gap:8px!important;display:grid!important;gap:8px!important;grid-template-columns:repeat(4,1fr)!important}table{border-collapse:collapse!important;font-size:9pt!important;width:100%!important}td,th{word-wrap:break-word!important;border:1px solid #ccc!important;overflow-wrap:break-word!important;padding:4px 8px!important;white-space:normal!important}th{background:#1a3a5c!important;color:#fff!important;-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}canvas{height:auto!important;max-width:100%!important}[class*=chart]{break-inside:avoid;page-break-inside:avoid}*{max-width:100%!important;overflow:visible!important;text-overflow:clip!important;white-space:normal!important}.page-break{break-before:always;page-break-before:always}@page{size:A4;margin:15mm 12mm 15mm 12mm}}:root{--warehouse-navy:var(--ds-navy);--warehouse-blue:var(--ds-navy-mid);--warehouse-green:var(--ds-green);--warehouse-gold:var(--ds-gold)}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--ds-bg);font-family:var(--ds-font-ui)}.App{display:flex;flex-direction:column;min-height:100vh}.app-content{flex:1 1;padding:0}.app-main{flex:1 1;padding:20px}.analytics-container{background:var(--ds-bg);color:var(--ds-text);font-family:var(--ds-font-ui);min-height:100vh}.analytics-container,.analytics-container *{box-sizing:border-box}.brand-header{background:var(--ds-navy);overflow:hidden;padding:18px 28px;position:relative}.brand-header:before{background:#ffffff0a;border-radius:50%;content:"";height:200px;pointer-events:none;position:absolute;right:-60px;top:-40px;width:200px}.brand-header-inner{flex-wrap:wrap;justify-content:space-between;position:relative;z-index:1}.brand-header-inner,.brand-logo-area{align-items:center;display:flex;gap:14px}.brand-icon{align-items:center;background:#ffffff1a;border-radius:var(--ds-r-md);display:flex;font-size:1.8rem;height:44px;justify-content:center;width:44px}.brand-title{color:#fff;font-size:var(--ds-text-xl);font-weight:800;letter-spacing:-.4px;margin:0}.brand-tagline{color:#fff9;font-size:var(--ds-text-xs);font-weight:400}.brand-header-actions{align-items:center;display:flex;gap:var(--ds-sp-2)}.export-btn{align-items:center;background:#ffffff1a;border:1px solid #ffffff40;border-radius:var(--ds-r-sm);color:#fff;cursor:pointer;display:flex;font-family:var(--ds-font-ui);font-size:var(--ds-text-xs);font-weight:600;gap:5px;padding:6px 12px;transition:background var(--ds-t-fast),border-color var(--ds-t-fast)}.export-btn:hover{background:#fff3;border-color:#fff6}.refresh-btn{align-items:center;background:#ffffff1a;border:1px solid #ffffff40;border-radius:var(--ds-r-sm);color:#fff;cursor:pointer;display:flex;font-size:var(--ds-text-base);height:34px;justify-content:center;transition:background var(--ds-t-fast);width:34px}.refresh-btn:hover{background:#ffffff38}.refresh-btn.spinning{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.alerts-panel{border:1px solid var(--ds-warning-border);border-radius:var(--ds-r-md);box-shadow:var(--ds-shadow-sm);margin:14px 28px 0;overflow:hidden}.alerts-header{align-items:center;background:var(--ds-warning-bg);border:none;cursor:pointer;display:flex;font-family:var(--ds-font-ui);justify-content:space-between;padding:10px 18px;text-align:left;transition:background var(--ds-t-fast);width:100%}.alerts-header:hover{background:#fef3c7}.alerts-header-left{align-items:center;display:flex;flex-wrap:wrap;gap:var(--ds-sp-3)}.alerts-bell{font-size:1.1rem}.alerts-title{color:var(--ds-text);font-size:var(--ds-text-sm);font-weight:700}.alerts-badge{border-radius:var(--ds-r-pill);font-size:var(--ds-text-xs);font-weight:700;padding:2px 9px;white-space:nowrap}.alerts-badge.critical{background:var(--ds-danger-bg);color:var(--ds-danger)}.alerts-badge.warning{background:var(--ds-warning-bg);border:1px solid var(--ds-warning-border);color:var(--ds-gold-dark)}.alerts-badge.info{background:var(--ds-info-bg);color:var(--ds-info)}.alerts-toggle{color:var(--ds-text-muted);font-size:var(--ds-text-xs)}.alerts-list{background:var(--ds-surface);border-top:1px solid var(--ds-warning-border);max-height:240px;overflow-y:auto}.alert-item{align-items:center;border-bottom:1px solid var(--ds-border);display:flex;font-size:var(--ds-text-sm);gap:var(--ds-sp-3);padding:9px 18px;transition:background var(--ds-t-fast)}.alert-item:last-child{border-bottom:none}.alert-item:hover{background:var(--ds-surface-raised)}.alert-item.critical{border-left:3px solid var(--ds-danger)}.alert-item.warning{border-left:3px solid var(--ds-gold)}.alert-item.info{border-left:3px solid var(--ds-info)}.alert-type-badge{border-radius:var(--ds-r-pill);flex-shrink:0;font-size:var(--ds-text-xs);font-weight:700;letter-spacing:.05em;padding:2px 8px;text-transform:uppercase;white-space:nowrap}.alert-type-badge.out_of_stock{background:var(--ds-danger-bg);color:var(--ds-danger)}.alert-type-badge.low_stock{background:var(--ds-warning-bg);color:var(--ds-gold-dark)}.alert-type-badge.dead_stock{background:var(--ds-info-bg);color:var(--ds-info)}.alert-type-badge.overdue{background:var(--ds-danger-bg);color:var(--ds-danger)}.alert-message{color:var(--ds-text-sub);flex:1 1;font-size:var(--ds-text-sm)}.alert-amount{color:var(--ds-text);font-family:var(--ds-font-mono);font-size:var(--ds-text-sm);font-weight:600;white-space:nowrap}.filter-bar{align-items:flex-end;background:var(--ds-surface);border:1px solid var(--ds-border);border-radius:var(--ds-r-md);box-shadow:var(--ds-shadow-sm);gap:var(--ds-sp-4);margin:14px 28px 0;padding:var(--ds-sp-4) var(--ds-sp-5)}.filter-group{flex-direction:column;gap:var(--ds-sp-1)}.filter-label{color:var(--ds-text-muted);font-size:var(--ds-text-xs);font-weight:700;letter-spacing:.06em;text-transform:uppercase}.filter-select{appearance:none;-webkit-appearance:none;background:var(--ds-surface-raised) url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='m0 0 5 6 5-6z' fill='%2394a3b8'/%3E%3C/svg%3E") no-repeat right 12px center;cursor:pointer;outline:none;padding:7px 34px 7px 12px;transition:border-color var(--ds-t-fast),box-shadow var(--ds-t-fast)}.filter-clear-btn{align-self:flex-end;background:var(--ds-surface);border:1px solid var(--ds-border-mid);border-radius:var(--ds-r-sm);color:var(--ds-text-sub);cursor:pointer;font-family:var(--ds-font-ui);font-size:var(--ds-text-sm);font-weight:500;padding:7px 12px;transition:all var(--ds-t-fast)}.filter-clear-btn:hover{background:var(--ds-danger-bg);border-color:var(--ds-danger);color:var(--ds-danger)}.filter-active-tag{align-self:flex-end;color:var(--ds-green);font-family:var(--ds-font-ui);font-size:var(--ds-text-xs);font-weight:600;padding-bottom:2px}.kpi-section{padding:18px 28px 0}.kpi-grid{grid-template-columns:repeat(4,1fr)}@media (max-width:1100px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:580px){.kpi-grid{grid-template-columns:1fr}}.kpi-card{overflow:hidden;position:relative;transition:box-shadow var(--ds-t-base)}.kpi-card:hover{box-shadow:var(--ds-shadow-md)}.kpi-card:before{background:var(--ds-green);border-radius:var(--ds-r-md) var(--ds-r-md) 0 0;content:"";height:3px;left:0;position:absolute;right:0;top:0}.kpi-card[data-accent=gold]:before{background:var(--ds-gold)}.kpi-card[data-accent=green]:before{background:var(--ds-green)}.kpi-card[data-accent=blue]:before{background:var(--ds-info)}.kpi-card[data-accent=red]:before{background:var(--ds-danger)}.kpi-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--ds-sp-3)}.kpi-card-title{color:var(--ds-text-muted);font-family:var(--ds-font-ui);font-size:var(--ds-text-xs);font-weight:700;letter-spacing:.07em;line-height:1.3;text-transform:uppercase}.kpi-card-icon{font-size:1.3rem;opacity:.8}.kpi-card-value-row{align-items:baseline;display:flex;gap:5px}.kpi-card-value{color:var(--ds-text);font-family:var(--ds-font-mono);font-size:1.8rem;font-weight:800;letter-spacing:-.04em;line-height:1.1}.kpi-card-unit{color:var(--ds-text-muted);font-family:var(--ds-font-ui);font-size:var(--ds-text-sm);font-weight:500}.kpi-card-trend{align-items:center;display:flex;gap:5px;margin-top:var(--ds-sp-2)}.trend-up{color:var(--ds-green)}.trend-down,.trend-up{font-size:var(--ds-text-xs);font-weight:600}.trend-down{color:var(--ds-danger)}.trend-neutral{color:var(--ds-text-muted);font-size:var(--ds-text-xs);font-weight:600}.charts-section{padding:18px 28px 0}.charts-grid{grid-gap:var(--ds-sp-4);display:grid;gap:var(--ds-sp-4);grid-template-columns:repeat(2,1fr)}@media (max-width:860px){.charts-grid{grid-template-columns:1fr}}.chart-card{background:var(--ds-surface);border:1px solid var(--ds-border);border-radius:var(--ds-r-md);box-shadow:var(--ds-shadow-card);padding:var(--ds-sp-5)}.chart-header{align-items:baseline;display:flex;flex-wrap:wrap;gap:var(--ds-sp-2);justify-content:space-between;margin-bottom:var(--ds-sp-4)}.chart-title{color:var(--ds-text);font-size:var(--ds-text-md);font-weight:700;margin:0}.chart-subtitle,.chart-title{font-family:var(--ds-font-ui)}.chart-subtitle{color:var(--ds-text-muted);font-size:var(--ds-text-xs);font-weight:500}.chart-empty{align-items:center;color:var(--ds-text-muted);display:flex;font-size:var(--ds-text-sm);height:200px;justify-content:center}.chart-legend{margin-top:var(--ds-sp-4)}.chart-legend-item{align-items:center;display:flex;font-size:var(--ds-text-sm);justify-content:space-between;padding:5px 0}.chart-legend-left{align-items:center;display:flex;gap:var(--ds-sp-3)}.chart-legend-color{border-radius:var(--ds-r-pill);flex-shrink:0;height:10px;width:10px}.chart-legend-name{color:var(--ds-text-sub);font-weight:500}.chart-legend-value{color:var(--ds-text);font-family:var(--ds-font-mono);font-size:var(--ds-text-sm);font-weight:700}.chart-tooltip{background:var(--ds-surface);border:1px solid var(--ds-border-mid);border-radius:var(--ds-r-sm);box-shadow:var(--ds-shadow-lg);padding:9px 13px}.chart-tooltip-name{color:var(--ds-text);font-family:var(--ds-font-ui);font-size:var(--ds-text-sm);font-weight:600}.chart-tooltip-value{color:var(--ds-text-muted);font-family:var(--ds-font-mono);font-size:var(--ds-text-xs);margin-top:2px}.error-container,.loading-container{align-items:center;background:var(--ds-bg);display:flex;font-family:var(--ds-font-ui);justify-content:center;min-height:100vh}.error-content,.loading-content{max-width:400px;text-align:center}.spinner{animation:spin .7s linear infinite;border:3px solid var(--ds-border-mid);border-radius:var(--ds-r-pill);border-top-color:var(--ds-green);height:40px;margin:0 auto 14px;width:40px}.loading-text{color:var(--ds-text-muted);font-size:var(--ds-text-sm)}.error-icon{font-size:2.5rem;margin-bottom:var(--ds-sp-3)}.error-title{color:var(--ds-text);font-size:var(--ds-text-md);font-weight:700;margin:0 0 var(--ds-sp-2)}.error-message{color:var(--ds-text-muted);line-height:1.5;margin:0 0 var(--ds-sp-5)}.error-message,.retry-btn{font-size:var(--ds-text-sm)}.retry-btn{background:var(--ds-green);border:none;border-radius:var(--ds-r-sm);color:#fff;cursor:pointer;font-family:var(--ds-font-ui);font-weight:600;padding:9px var(--ds-sp-6);transition:background var(--ds-t-fast)}.retry-btn:hover{background:var(--ds-green-dark)}.dashboard-footer{align-items:center;border-top:1px solid var(--ds-border);display:flex;flex-wrap:wrap;gap:var(--ds-sp-2);justify-content:space-between;margin:var(--ds-sp-6) 28px 0;padding:var(--ds-sp-4) 0 var(--ds-sp-5)}.footer-brand,.footer-updated{color:var(--ds-text-muted);font-family:var(--ds-font-ui);font-size:var(--ds-text-xs)}.footer-brand{font-weight:600;letter-spacing:.4px}@media print{.no-print{display:none!important}.analytics-container{background:#fff}.brand-header{background:var(--ds-navy)!important;padding:14px 22px;-webkit-print-color-adjust:exact;print-color-adjust:exact}.brand-header-actions{display:none!important}.alerts-panel{margin:10px 22px 0}.alerts-list{max-height:none}.filter-bar{display:none}.charts-section,.kpi-section{padding-left:22px;padding-right:22px}.chart-card,.kpi-card{border:1px solid var(--ds-border)!important;break-inside:avoid;page-break-inside:avoid}.chart-card,.kpi-card,.kpi-card:hover{box-shadow:none!important}.dashboard-footer{padding-top:12px}}@media (max-width:680px){.brand-header{padding:14px 18px}.charts-section,.dashboard-footer,.filter-bar,.kpi-section,.widget-section{margin-left:18px;margin-right:18px}}.widget-section{margin-top:16px;padding:0 28px}.widget-grid-3{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(3,1fr)}.widget-grid-2{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(2,1fr)}.widget-card{background:#fff;background:var(--ds-surface,#fff);border:1px solid #e5e7eb;border:1px solid var(--ds-border,#e5e7eb);border-radius:10px;border-radius:var(--ds-r-md,10px);box-shadow:0 1px 4px #00000014;box-shadow:var(--ds-shadow-card,0 1px 4px #00000014);padding:20px}.widget-card-title{color:#6b7280;color:var(--ds-text-muted,#6b7280);font-family:Figtree,sans-serif;font-family:var(--ds-font-ui,"Figtree",sans-serif);font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.widget-big-number{color:#111827;color:var(--ds-text,#111827);font-family:JetBrains Mono,monospace;font-family:var(--ds-font-mono,"JetBrains Mono",monospace);font-size:1.5rem;font-weight:800;margin:6px 0}.widget-subtitle{color:#6b7280;color:var(--ds-text-muted,#6b7280);font-size:12px}.progress-bar-bg{background:#e5e7eb;background:var(--ds-border,#e5e7eb);border-radius:100px;height:6px;margin:8px 0}.progress-bar-fill{background:#16a34a;border-radius:100px;height:100%;transition:width .4s ease}.widget-create-btn{background:#16a34a;border:none;border-radius:6px;color:#fff;cursor:pointer;display:inline-block;font-family:Figtree,sans-serif;font-family:var(--ds-font-ui,"Figtree",sans-serif);font-size:12px;font-weight:600;margin-top:12px;padding:6px 14px;transition:opacity .15s}.widget-create-btn:hover{opacity:.85}.widget-create-link{color:#3b82f6;cursor:pointer;font-size:12px;font-weight:600}.widget-create-link:hover{text-decoration:underline}.widget-divider{border:none;border-top:1px solid #e5e7eb;border-top:1px solid var(--ds-border,#e5e7eb);margin:0}.overdue-count-badge{align-items:center;background:#fef2f2;border-radius:100px;color:#dc2626;display:inline-flex;font-family:monospace;font-family:var(--ds-font-mono,monospace);font-size:12px;font-weight:700;height:24px;justify-content:center;min-width:24px;padding:0 8px}.widget-table{border-collapse:collapse;font-family:Figtree,sans-serif;font-family:var(--ds-font-ui,"Figtree",sans-serif);font-size:12px;width:100%}.widget-table th{color:#6b7280;color:var(--ds-text-muted,#6b7280);font-size:10px;font-weight:700;letter-spacing:.05em;padding:6px 8px;text-align:left;text-transform:uppercase}.widget-table td,.widget-table th{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--ds-border,#e5e7eb)}.widget-table td{color:#374151;padding:8px}.widget-table tr:last-child td{border-bottom:none}.widget-table tr:hover td{background:#f8fafc}.overdue-badge{background:#fef2f2;border-radius:100px;color:#dc2626;display:inline-block;font-size:10px;font-weight:700;padding:2px 8px}.view-all-link{color:#3b82f6;cursor:pointer;display:block;font-size:12px;font-weight:600;margin-top:12px;text-align:center}.view-all-link:hover{text-decoration:underline}.bank-row{align-items:center;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--ds-border,#e5e7eb);display:flex;justify-content:space-between;padding:10px 0}.bank-row:last-child{border-bottom:none}.bank-name{color:#111827;font-size:13px;font-weight:600}.bank-type-badge{background:#f3f4f6;border-radius:100px;color:#6b7280;font-size:10px;font-weight:600;margin-left:8px;padding:2px 8px;text-transform:capitalize}.bank-balance{color:#111827;font-family:JetBrains Mono,monospace;font-family:var(--ds-font-mono,"JetBrains Mono",monospace);font-size:14px;font-weight:700}.expiry-bell{align-items:center;background:#ffffff1a;border:1px solid #ffffff40;border-radius:6px;color:#fff;cursor:pointer;display:flex;height:34px;justify-content:center;position:relative;transition:background .15s;width:34px}.expiry-bell:hover{background:#ffffff38}.expiry-badge{align-items:center;background:#dc2626;border-radius:100px;color:#fff;display:flex;font-size:10px;font-weight:700;height:16px;justify-content:center;min-width:16px;padding:0 4px;position:absolute;right:-5px;top:-5px}@media (max-width:1100px){.widget-grid-2,.widget-grid-3{grid-template-columns:1fr}}@media print{.expiry-bell,.view-all-link,.widget-create-btn,.widget-create-link{display:none!important}.widget-card{border:1px solid #e5e7eb!important;border:1px solid var(--ds-border,#e5e7eb)!important;box-shadow:none!important;break-inside:avoid;page-break-inside:avoid}}.product-list-container{margin:0 auto;max-width:1400px;padding:var(--ds-sp-6)}.product-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--ds-sp-5)}.product-header h2{color:var(--ds-text);font-size:var(--ds-text-2xl);font-weight:800;letter-spacing:-.4px;margin:0}.product-form-container{background:var(--ds-surface);border:1px solid var(--ds-border);border-radius:var(--ds-r-md);box-shadow:var(--ds-shadow-card);margin-bottom:var(--ds-sp-6);padding:var(--ds-sp-6)}.product-form-container h3{color:var(--ds-text);font-size:var(--ds-text-md);font-weight:700;margin:0 0 var(--ds-sp-5) 0}.product-form{display:flex;flex-direction:column;gap:var(--ds-sp-4)}.form-row{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.form-group input:disabled{background:var(--ds-surface-sunken);color:var(--ds-text-muted);cursor:not-allowed}.form-checkboxes{display:flex;gap:var(--ds-sp-5)}.checkbox-label{align-items:center;color:var(--ds-text-sub);cursor:pointer;display:flex;font-family:var(--ds-font-ui);font-size:var(--ds-text-sm);gap:var(--ds-sp-2)}.checkbox-label input[type=checkbox]{accent-color:var(--ds-green);cursor:pointer;height:16px;width:16px}.form-buttons{display:flex;gap:var(--ds-sp-3);margin-top:var(--ds-sp-2)}.btn-primary{background:var(--ds-green);border:none;border-radius:var(--ds-r-sm);color:#fff;cursor:pointer;font-family:var(--ds-font-ui);font-size:var(--ds-text-sm);font-weight:700;letter-spacing:.02em;padding:10px var(--ds-sp-6);transition:background var(--ds-t-base)}.btn-primary:hover{background:var(--ds-green-dark)}.btn-secondary{background:var(--ds-surface-raised);border:1px solid var(--ds-border-mid);border-radius:var(--ds-r-sm);color:var(--ds-text-sub);cursor:pointer;font-family:var(--ds-font-ui);font-size:var(--ds-text-sm);font-weight:600;padding:10px var(--ds-sp-6);transition:all var(--ds-t-base)}.btn-secondary:hover{background:var(--ds-surface-sunken);color:var(--ds-text)}.filters{display:flex;flex-wrap:wrap;gap:var(--ds-sp-3);margin-bottom:var(--ds-sp-5)}.search-input{border:1px solid var(--ds-border-mid);border-radius:var(--ds-r-sm);color:var(--ds-text);flex:1 1;font-family:var(--ds-font-ui);font-size:var(--ds-text-base);min-width:200px;padding:8px 12px}.search-input:focus{border-color:var(--ds-green);box-shadow:0 0 0 3px #16a34a1f;outline:none}.filter-select{border:1px solid var(--ds-border-mid);border-radius:var(--ds-r-sm);color:var(--ds-text);font-family:var(--ds-font-ui);font-size:var(--ds-text-base);min-width:180px;padding:8px 12px}.filter-select:focus{border-color:var(--ds-green);box-shadow:0 0 0 3px #16a34a1f;outline:none}.products-grid{grid-gap:var(--ds-sp-4);display:grid;gap:var(--ds-sp-4);grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.product-card{background:var(--ds-surface);border:1px solid var(--ds-border);border-radius:var(--ds-r-md);box-shadow:var(--ds-shadow-card);padding:var(--ds-sp-5);transition:box-shadow var(--ds-t-base),border-color var(--ds-t-base)}.product-card:hover{border-color:var(--ds-border-mid);box-shadow:var(--ds-shadow-md)}.product-header-card{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:var(--ds-sp-3)}.product-header-card h3{color:var(--ds-text);font-size:var(--ds-text-md);font-weight:700;margin:0}.badge-inactive{background:var(--ds-warning-bg);border:1px solid var(--ds-warning-border);border-radius:var(--ds-r-sm);color:var(--ds-gold-dark);font-family:var(--ds-font-ui);font-size:var(--ds-text-xs);font-weight:700;padding:2px 8px;text-transform:uppercase}.product-details{margin-bottom:var(--ds-sp-4)}.product-details p{color:var(--ds-text-sub);font-size:var(--ds-text-sm);margin:4px 0}.product-details .description{color:var(--ds-text-muted);font-size:var(--ds-text-xs);font-style:italic;margin-top:var(--ds-sp-2)}.product-actions{display:flex;gap:var(--ds-sp-2)}.btn-delete,.btn-edit{border:1px solid;border-radius:var(--ds-r-sm);cursor:pointer;flex:1 1;font-family:var(--ds-font-ui);font-size:var(--ds-text-sm);font-weight:600;padding:7px var(--ds-sp-3);transition:opacity var(--ds-t-base)}.btn-edit{background:var(--ds-green-tint);border-color:var(--ds-success-border);color:var(--ds-green-dark)}.btn-delete{background:var(--ds-danger-bg);border-color:var(--ds-danger-border);color:var(--ds-danger)}.btn-delete:hover,.btn-edit:hover{opacity:.8}.no-products{padding:var(--ds-sp-12) var(--ds-sp-5)}.error,.loading,.no-products{color:var(--ds-text-muted);font-size:var(--ds-text-md);text-align:center}.error,.loading{padding:var(--ds-sp-10)}.error{color:var(--ds-danger)}@media (max-width:768px){.product-list-container{padding:var(--ds-sp-3)}.product-header{align-items:flex-start;gap:var(--ds-sp-3)}.filters,.product-header{flex-direction:column}.filter-select,.search-input{min-width:0;min-width:auto;width:100%}.form-row,.products-grid{grid-template-columns:1fr}}.stock-receipt-container{background:var(--ds-bg);min-height:100vh;padding:var(--ds-sp-6)}.header-icon{background:var(--ds-navy)}.mode-toggle{background:var(--ds-surface);border:1px solid var(--ds-border);border-radius:var(--ds-r-md);display:flex;gap:3px;padding:3px}.toggle-btn{background:#0000;border:none;border-radius:var(--ds-r-sm);color:var(--ds-text-sub);cursor:pointer;font-family:var(--ds-font-ui);font-size:var(--ds-text-sm);font-weight:600;padding:7px var(--ds-sp-4);transition:all var(--ds-t-base)}.toggle-btn.active{background:var(--ds-navy);color:#fff}.toggle-btn:hover:not(.active){background:var(--ds-surface-raised);color:var(--ds-text)}.receipt-content{grid-gap:var(--ds-sp-5);display:grid;gap:var(--ds-sp-5);grid-template-columns:2fr 1fr}.receipt-form-section{background:var(--ds-surface);border:1px solid var(--ds-border);border-radius:var(--ds-r-md);box-shadow:var(--ds-shadow-card);padding:var(--ds-sp-6)}.section-badge{background:var(--ds-success-bg);border:1px solid var(--ds-success-border);border-radius:var(--ds-r-sm);color:var(--ds-green-deeper);display:inline-block;font-family:var(--ds-font-ui);font-size:var(--ds-text-xs);font-weight:700;letter-spacing:.05em;margin-bottom:var(--ds-sp-4);padding:3px 10px;text-transform:uppercase}.batch-header-fields{background:var(--ds-surface-raised);border:1px solid var(--ds-border-mid);border-radius:var(--ds-r-md);margin-bottom:var(--ds-sp-4);padding:var(--ds-sp-4)}.form-row{grid-gap:var(--ds-sp-4);display:grid;gap:var(--ds-sp-4);grid-template-columns:1fr 1fr;margin-bottom:var(--ds-sp-3)}.form-row:has(.form-group:only-child){grid-template-columns:1fr}.form-group.full-width{grid-column:1/-1}.message{margin:var(--ds-sp-3) 0}.submit-btn.add-btn{background:var(--ds-info)}.submit-btn.add-btn:hover:not(:disabled){background:#1d4ed8}.batch-items-list{margin-top:var(--ds-sp-5)}.batch-items-list h3{color:var(--ds-text);font-size:var(--ds-text-md);font-weight:700;margin-bottom:var(--ds-sp-3)}.batch-table{border-collapse:collapse;width:100%}.batch-table th{background:var(--ds-surface-sunken);color:var(--ds-text-muted);font-family:var(--ds-font-ui);font-size:var(--ds-text-xs);letter-spacing:.06em;padding:7px 12px;text-align:left;text-transform:uppercase}.batch-table td{border-bottom:1px solid var(--ds-border);font-size:var(--ds-text-sm);padding:7px 12px}.batch-summary{align-items:center;border-top:1px solid var(--ds-border-mid);display:flex;justify-content:space-between;margin-top:var(--ds-sp-4);padding-top:var(--ds-sp-3)}.batch-summary span{color:var(--ds-text);font-family:var(--ds-font-ui);font-size:var(--ds-text-md);font-weight:700}.batch-summary .submit-btn{padding:10px var(--ds-sp-6);width:auto}.recent-receipts-sidebar{background:var(--ds-surface);border:1px solid var(--ds-border);border-radius:var(--ds-r-md);box-shadow:var(--ds-shadow-card);height:fit-content;padding:var(--ds-sp-5)}.recent-receipts-sidebar h3{color:var(--ds-text);font-size:var(--ds-text-md);font-weight:700;margin-bottom:var(--ds-sp-4)}.receipt-item{border-bottom:1px solid var(--ds-border);padding:var(--ds-sp-3)}.receipt-header{display:flex;justify-content:space-between}.receipt-product{color:var(--ds-text);font-family:var(--ds-font-ui);font-size:var(--ds-text-sm);font-weight:600}.receipt-qty{color:var(--ds-green);font-family:var(--ds-font-mono);font-size:var(--ds-text-sm);font-weight:700}.receipt-details{color:var(--ds-text-muted);display:flex;font-size:var(--ds-text-xs);justify-content:space-between;margin-top:var(--ds-sp-1)}.no-data{padding:var(--ds-sp-5)}@media (max-width:768px){.stock-receipt-container{padding:12px!important}.batch-header-fields .form-row,.form-row,.receipt-content{grid-template-columns:1fr}.form-group input,.form-group select,.form-group textarea{font-size:16px!important;min-height:44px;padding:12px!important}.form-group label{font-size:13px;margin-bottom:6px}.submit-btn{font-size:16px!important;min-height:52px;padding:14px!important}.toggle-btn{font-size:14px;min-height:44px;padding:10px 16px}.page-header{align-items:flex-start;flex-direction:column}.mode-toggle{width:100%}.mode-toggle .toggle-btn{flex:1 1}.recent-receipts-sidebar{margin-top:16px}.batch-table thead{display:none}.batch-table tbody tr{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;display:block;margin-bottom:8px;padding:12px}.batch-table tbody td{border:none;display:flex;font-size:14px;justify-content:space-between;padding:3px 0}.batch-summary{flex-direction:column;gap:10px}.batch-summary .submit-btn{width:100%!important}}.stock-levels-container{background:var(--ds-bg);min-height:100vh;padding:var(--ds-sp-6)}.page-header{margin-bottom:var(--ds-sp-5)}.header-icon.levels{align-items:center;background:var(--ds-green);border-radius:var(--ds-r-md);box-shadow:none;color:#fff;display:flex;font-size:24px;height:44px;justify-content:center;width:44px}.header-actions{display:flex;gap:var(--ds-sp-2)}.action-btn.refresh{border-color:var(--ds-green);color:var(--ds-green)}.action-btn.refresh:hover{background:var(--ds-green-tint)}.summary-stats{display:flex;flex-wrap:wrap;gap:var(--ds-sp-3);margin-bottom:var(--ds-sp-5)}.stat-card{flex:1 1;min-width:130px;overflow:hidden;padding:var(--ds-sp-4);position:relative;text-align:center}.stat-card:before{background:var(--ds-green);content:"";height:3px;left:0;position:absolute;right:0;top:0}.stat-card.gold:before{background:var(--ds-gold)}.stat-card.alert:before{background:#ea580c}.stat-card.danger:before{background:var(--ds-danger)}.stat-value{font-size:26px;letter-spacing:-.03em}.stat-label{margin-top:var(--ds-sp-1)}.filters-section{background:var(--ds-surface);border:1px solid var(--ds-border);border-radius:var(--ds-r-md);flex-wrap:wrap;gap:var(--ds-sp-4);margin-bottom:var(--ds-sp-4);padding:var(--ds-sp-3) var(--ds-sp-4)}.filter-group,.filters-section{align-items:center;display:flex}.filter-group{gap:var(--ds-sp-2)}.filter-group label{color:var(--ds-text-sub);font-family:var(--ds-font-ui);font-size:var(--ds-text-sm);font-weight:600}.filter-group input,.filter-group select{border:1px solid var(--ds-border-mid);border-radius:var(--ds-r-sm);color:var(--ds-text);font-family:var(--ds-font-ui);font-size:var(--ds-text-base);padding:7px 10px}.filter-group input:focus,.filter-group select:focus{border-color:var(--ds-green);box-shadow:0 0 0 3px #16a34a1f;outline:none}.filter-checkbox label{align-items:center;color:var(--ds-text-sub);cursor:pointer;display:flex;font-family:var(--ds-font-ui);font-size:var(--ds-text-sm);gap:var(--ds-sp-2)}.stock-table-container{background:var(--ds-surface);border:1px solid var(--ds-border);border-radius:var(--ds-r-md);box-shadow:var(--ds-shadow-card);overflow:hidden}.stock-table{border-collapse:collapse;width:100%}.stock-table th{background:var(--ds-navy);color:#fff;font-family:var(--ds-font-ui);font-size:var(--ds-text-xs);font-weight:700;letter-spacing:.07em;padding:10px 14px;text-align:left;text-transform:uppercase}.stock-table td{border-bottom:1px solid var(--ds-border);font-size:var(--ds-text-base);padding:9px 14px}.stock-row.in-stock:hover{background:var(--ds-green-tint)}.stock-row.low-stock{background:var(--ds-warning-bg)}.stock-row.out-of-stock{background:var(--ds-danger-bg)}.product-name{color:var(--ds-text);font-weight:600}.sku{color:var(--ds-text-muted);font-size:var(--ds-text-xs)}.quantity,.sku{font-family:var(--ds-font-mono)}.quantity{color:var(--ds-text);font-size:var(--ds-text-md);font-weight:700}.status-badge{border-radius:var(--ds-r-sm);font-family:var(--ds-font-ui);font-size:var(--ds-text-xs);font-weight:700;padding:3px 8px}.status-badge.in-stock{background:var(--ds-success-bg);border:1px solid var(--ds-success-border);color:var(--ds-green-deeper)}.status-badge.low-stock{background:var(--ds-warning-bg);border:1px solid var(--ds-warning-border);color:#92400e}.status-badge.out-of-stock{background:var(--ds-danger-bg);border:1px solid var(--ds-danger-border);color:#7f1d1d}@media (max-width:768px){.stock-levels-container{padding:var(--ds-sp-3)}.page-header{align-items:flex-start;flex-direction:column}.stock-table-container{overflow-x:auto}.stock-table td,.stock-table th{font-size:var(--ds-text-xs);padding:8px}.filters-section{align-items:stretch;flex-direction:column}.filters-section,.summary-stats{gap:var(--ds-sp-2)}.stat-card{flex:1 1 calc(50% - var(--ds-sp-2));min-width:0;min-width:auto}}.stocktake-container{background:var(--ds-bg);min-height:100vh;padding:var(--ds-sp-6)}.stocktake-controls{align-items:center;display:flex;flex-wrap:wrap;gap:var(--ds-sp-6);margin:var(--ds-sp-5) 0}.stocktake-controls .form-group{min-width:250px}.stocktake-controls select{border:1px solid var(--ds-border-mid);border-radius:var(--ds-r-sm);color:var(--ds-text);font-family:var(--ds-font-ui);font-size:var(--ds-text-base);padding:8px 12px;width:100%}.stocktake-controls select:focus{border-color:var(--ds-green);box-shadow:0 0 0 3px #16a34a1f;outline:none}.count-summary{color:var(--ds-text-sub);display:flex;font-family:var(--ds-font-ui);font-size:var(--ds-text-sm);font-weight:600;gap:var(--ds-sp-4)}.count-summary .has-diff{color:#ea580c}.stocktake-table-container{background:var(--ds-surface);border:1px solid var(--ds-border);border-radius:var(--ds-r-md);box-shadow:var(--ds-shadow-card);overflow-x:auto}.stocktake-table{border-collapse:collapse;width:100%}.stocktake-table th{background:var(--ds-navy);color:#fff;font-family:var(--ds-font-ui);font-size:var(--ds-text-xs);font-weight:700;letter-spacing:.07em;padding:10px var(--ds-sp-4);text-align:left;text-transform:uppercase}.stocktake-table td{border-bottom:1px solid var(--ds-border);font-size:var(--ds-text-base);padding:9px var(--ds-sp-4)}.stocktake-table tr.has-difference{background:var(--ds-warning-bg)}.count-input{border:1px solid var(--ds-border-mid);border-radius:var(--ds-r-sm);color:var(--ds-text);font-family:var(--ds-font-mono);font-size:var(--ds-text-md);font-weight:700;padding:7px 10px;text-align:center;width:100px}.count-input:focus{border-color:var(--ds-green);box-shadow:0 0 0 3px #16a34a1f;outline:none}.sys-qty{color:var(--ds-text-sub);font-weight:600}.diff,.sys-qty{font-family:var(--ds-font-mono)}.diff{font-weight:700}.diff.positive{color:var(--ds-green)}.diff.negative{color:var(--ds-danger)}.stocktake-actions{margin:var(--ds-sp-5) 0;text-align:center}.stocktake-results{background:var(--ds-surface);border:1px solid var(--ds-border);border-radius:var(--ds-r-md);box-shadow:var(--ds-shadow-card);margin-top:var(--ds-sp-5);padding:var(--ds-sp-6)}.result-stats{color:var(--ds-text-sub);display:flex;font-family:var(--ds-font-ui);font-size:var(--ds-text-md);gap:var(--ds-sp-6);margin:var(--ds-sp-4) 0}.result-stats strong{color:var(--ds-green);font-family:var(--ds-font-mono)}.result-table{border-collapse:collapse;margin-top:var(--ds-sp-4);width:100%}.result-table th{background:var(--ds-surface-sunken);color:var(--ds-text-muted);font-family:var(--ds-font-ui);font-size:var(--ds-text-xs);letter-spacing:.07em;padding:9px 14px;text-align:left;text-transform:uppercase}.result-table td{border-bottom:1px solid var(--ds-border);font-size:var(--ds-text-base);padding:9px 14px}.result-table tr.adjusted{background:var(--ds-warning-bg)}.result-table tr.match{background:var(--ds-green-tint)}@media (max-width:768px){.stocktake-container{padding:var(--ds-sp-3)}.stocktake-controls{gap:var(--ds-sp-3)}.stocktake-controls .form-group{min-width:0;min-width:auto;width:100%}.count-summary{flex-direction:column;gap:var(--ds-sp-1)}.result-stats{flex-direction:column;gap:var(--ds-sp-2)}}.stock-issue-container{background:var(--ds-bg);min-height:100vh;padding:var(--ds-sp-6)}.header-icon.issue{background:#ea580c;color:#fff}.section-badge.issue{background:#fff7ed;border-color:#fed7aa;color:#9a3412}.issue-content{grid-gap:var(--ds-sp-5);display:grid;gap:var(--ds-sp-5);grid-template-columns:2fr 1fr}.issue-form-section{background:var(--ds-surface);border:1px solid var(--ds-border);border-radius:var(--ds-r-md);box-shadow:var(--ds-shadow-card);padding:var(--ds-sp-6)}.stock-indicator{align-items:center;border:1px solid;border-radius:var(--ds-r-sm);display:flex;font-weight:600;gap:var(--ds-sp-3);margin-bottom:var(--ds-sp-3);padding:10px var(--ds-sp-4)}.stock-indicator.ok{background:var(--ds-success-bg);border-color:var(--ds-success-border)}.stock-indicator.warning{background:var(--ds-warning-bg);border-color:var(--ds-warning-border)}.stock-indicator.danger{background:var(--ds-danger-bg);border-color:var(--ds-danger-border)}.stock-label{color:var(--ds-text-sub);font-family:var(--ds-font-ui);font-size:var(--ds-text-sm)}.stock-value{color:var(--ds-text);font-family:var(--ds-font-mono);font-size:20px;font-weight:800;letter-spacing:-.03em}.submit-btn.issue{background:#ea580c}.submit-btn.issue:hover:not(:disabled){background:#c2410c}.recent-issues-sidebar{background:var(--ds-surface);border:1px solid var(--ds-border);border-radius:var(--ds-r-md);box-shadow:var(--ds-shadow-card);height:fit-content;padding:var(--ds-sp-5)}.recent-issues-sidebar h3{color:var(--ds-text);font-size:var(--ds-text-md);font-weight:700;margin-bottom:var(--ds-sp-4)}.issue-item{border-bottom:1px solid var(--ds-border);padding:var(--ds-sp-3)}.issue-header{display:flex;justify-content:space-between}.issue-product{color:var(--ds-text);font-family:var(--ds-font-ui);font-weight:600}.issue-product,.issue-qty{font-size:var(--ds-text-sm)}.issue-qty{color:var(--ds-danger);font-family:var(--ds-font-mono);font-weight:700}.issue-details{color:var(--ds-text-muted);display:flex;font-size:var(--ds-text-xs);justify-content:space-between;margin-top:var(--ds-sp-1)}@media (max-width:768px){.issue-content{grid-template-columns:1fr}}.expiry-container{background:var(--ds-bg);min-height:100vh;padding:var(--ds-sp-6)}.expiry-summary-cards{display:flex;flex-wrap:wrap;gap:var(--ds-sp-3);margin:var(--ds-sp-5) 0}.exp-card{border:1px solid;border-radius:var(--ds-r-md);cursor:pointer;flex:1 1;min-width:120px;padding:var(--ds-sp-4);text-align:center;transition:box-shadow var(--ds-t-base)}.exp-card:hover{box-shadow:var(--ds-shadow-md)}.exp-card.expired{background:var(--ds-danger-bg);border-color:var(--ds-danger-border)}.exp-card.critical{background:#fff7ed;border-color:#fdba74}.exp-card.warning{background:var(--ds-warning-bg);border-color:var(--ds-warning-border)}.exp-card.info{background:var(--ds-info-bg);border-color:var(--ds-info-border)}.exp-card.all{background:var(--ds-surface);border-color:var(--ds-border-mid)}.exp-num{color:var(--ds-text);font-family:var(--ds-font-mono);font-size:30px;font-weight:800;letter-spacing:-.03em}.exp-label{color:var(--ds-text-muted);font-family:var(--ds-font-ui);font-size:var(--ds-text-xs);letter-spacing:.07em;margin-top:var(--ds-sp-1);text-transform:uppercase}.expiry-controls{align-items:center;display:flex;flex-wrap:wrap;gap:var(--ds-sp-5);margin:var(--ds-sp-4) 0}.expiry-controls select{border:1px solid var(--ds-border-mid);border-radius:var(--ds-r-sm);color:var(--ds-text);font-family:var(--ds-font-ui);font-size:var(--ds-text-base);padding:7px 10px}.expiry-controls select:focus{border-color:var(--ds-green);box-shadow:0 0 0 3px #16a34a1f;outline:none}.filter-label{color:var(--ds-text-sub);font-family:var(--ds-font-ui);font-size:var(--ds-text-sm);font-weight:600}.expiry-table-container{background:var(--ds-surface);border:1px solid var(--ds-border);border-radius:var(--ds-r-md);box-shadow:var(--ds-shadow-card);overflow-x:auto}.expiry-table{border-collapse:collapse;width:100%}.expiry-table th{background:var(--ds-navy);color:#fff;font-family:var(--ds-font-ui);font-size:var(--ds-text-xs);font-weight:700;letter-spacing:.07em;padding:10px 14px;text-align:left;text-transform:uppercase}.expiry-table td{border-bottom:1px solid var(--ds-border);font-size:var(--ds-text-base);padding:9px 14px}.no-data-message{color:var(--ds-text-muted);font-size:var(--ds-text-base);padding:var(--ds-sp-10);text-align:center}@media (max-width:768px){.expiry-container{padding:var(--ds-sp-3)}.expiry-summary-cards{gap:var(--ds-sp-2)}.exp-card{flex:1 1 calc(50% - var(--ds-sp-2));min-width:0;min-width:auto}.expiry-controls{gap:var(--ds-sp-2)}}.inventory-dashboard-container{background:var(--ds-bg);min-height:100vh;padding:var(--ds-sp-6)}.dashboard-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--ds-sp-8)}.dashboard-header h1{color:var(--ds-text);font-size:var(--ds-text-3xl);font-weight:800;letter-spacing:-.5px;margin:0}.dashboard-header p{color:var(--ds-text-muted);font-size:var(--ds-text-sm);margin:5px 0 0}.stats-grid{grid-gap:var(--ds-sp-4);display:grid;gap:var(--ds-sp-4);grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-bottom:var(--ds-sp-8)}.stat-card{align-items:center;background:var(--ds-surface);border:1px solid var(--ds-border);border-radius:var(--ds-r-md);border-top:3px solid var(--ds-navy);box-shadow:var(--ds-shadow-card);display:flex;gap:var(--ds-sp-4);padding:var(--ds-sp-5) var(--ds-sp-6);transition:box-shadow var(--ds-t-base)}.stat-card:hover{box-shadow:var(--ds-shadow-md)}.stat-card.primary{border-top-color:var(--ds-info)}.stat-card.success{border-top-color:var(--ds-green)}.stat-card.warning{border-top-color:var(--ds-gold)}.stat-card.danger{border-top-color:var(--ds-danger)}.stat-icon{flex-shrink:0;font-size:36px;opacity:.85}.stat-value{color:var(--ds-text);font-family:var(--ds-font-mono);font-size:var(--ds-text-3xl);font-weight:800;letter-spacing:-.04em;margin-bottom:2px}.stat-label{color:var(--ds-text-muted);font-family:var(--ds-font-ui);font-size:var(--ds-text-xs);font-weight:700;letter-spacing:.07em;text-transform:uppercase}.dashboard-section{background:var(--ds-surface);border:1px solid var(--ds-border);border-radius:var(--ds-r-md);box-shadow:var(--ds-shadow-card);margin-bottom:var(--ds-sp-5);padding:var(--ds-sp-6)}.dashboard-section h2{color:var(--ds-text);font-size:var(--ds-text-xl);font-weight:800;letter-spacing:-.3px;margin:0 0 var(--ds-sp-6) 0}.warehouse-grid{grid-gap:var(--ds-sp-4);display:grid;gap:var(--ds-sp-4);grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.warehouse-card{background:var(--ds-surface-raised);border:1px solid var(--ds-border);border-left:3px solid var(--ds-navy-mid);border-radius:var(--ds-r-md);padding:var(--ds-sp-4) var(--ds-sp-5)}.warehouse-name{color:var(--ds-text);font-family:var(--ds-font-ui);font-size:var(--ds-text-md);font-weight:700;margin-bottom:var(--ds-sp-4)}.warehouse-stats{display:flex;flex-direction:column;gap:var(--ds-sp-2)}.wh-stat{align-items:center;display:flex;justify-content:space-between}.wh-label{color:var(--ds-text-muted);font-family:var(--ds-font-ui)}.wh-label,.wh-value{font-size:var(--ds-text-sm)}.wh-value{color:var(--ds-text);font-family:var(--ds-font-mono);font-weight:700}.alerts-container{display:flex;flex-direction:column;gap:var(--ds-sp-3)}.alert-item{border-left:3px solid;border-radius:var(--ds-r-sm);padding:var(--ds-sp-4)}.alert-item.warning{background:var(--ds-warning-bg);border-left-color:var(--ds-gold)}.alert-item.critical{background:var(--ds-danger-bg);border-left-color:var(--ds-danger)}.alert-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--ds-sp-2)}.alert-product{color:var(--ds-text)}.alert-product,.urgency-badge{font-family:var(--ds-font-ui);font-weight:700}.urgency-badge{border-radius:var(--ds-r-sm);font-size:var(--ds-text-xs);letter-spacing:.05em;padding:3px 8px;text-transform:uppercase}.urgency-badge.warning{background:var(--ds-gold);color:#fff}.urgency-badge.critical{background:var(--ds-danger);color:#fff}.alert-details{color:var(--ds-text-muted);display:flex;font-size:var(--ds-text-sm);gap:var(--ds-sp-4)}.movements-list{display:flex;flex-direction:column;gap:var(--ds-sp-3)}.movement-item{grid-gap:var(--ds-sp-4);align-items:center;background:var(--ds-surface-raised);border:1px solid var(--ds-border);border-radius:var(--ds-r-sm);display:grid;gap:var(--ds-sp-4);grid-template-columns:44px 1fr 100px 120px;padding:var(--ds-sp-3) var(--ds-sp-4);transition:background var(--ds-t-base)}.movement-item:hover{background:var(--ds-green-tint)}.movement-type{font-size:var(--ds-text-xl);text-align:center}.movement-product{color:var(--ds-text);font-family:var(--ds-font-ui);font-size:var(--ds-text-sm);font-weight:700}.movement-details{color:var(--ds-text-muted);font-family:var(--ds-font-ui);font-size:var(--ds-text-xs);margin-top:2px}.movement-quantity{font-family:var(--ds-font-mono);font-size:var(--ds-text-lg);font-weight:800;letter-spacing:-.03em;text-align:right}.movement-date{color:var(--ds-text-muted);font-family:var(--ds-font-ui);font-size:var(--ds-text-xs);text-align:right}@media (max-width:768px){.inventory-dashboard-container{padding:var(--ds-sp-3)}.dashboard-header{align-items:flex-start;flex-direction:column;gap:var(--ds-sp-3)}.stats-grid{grid-template-columns:1fr 1fr}.movement-item{grid-template-columns:44px 1fr;grid-template-rows:auto auto}.movement-date,.movement-quantity{grid-column:2;text-align:left}.alert-details{flex-direction:column;gap:var(--ds-sp-1)}}@media (max-width:480px){.stats-grid{grid-template-columns:1fr}.movement-item{grid-template-columns:36px 1fr}}.barcode-container{background:var(--ds-bg);min-height:100vh;padding:var(--ds-sp-6)}.scan-section{margin:var(--ds-sp-5) 0}.scan-input-wrapper{align-items:center;background:var(--ds-surface);border:1px solid var(--ds-border-mid);border-radius:var(--ds-r-md);box-shadow:var(--ds-shadow-card);display:flex;gap:var(--ds-sp-2);padding:var(--ds-sp-3) var(--ds-sp-5)}.scan-icon{font-size:var(--ds-text-xl)}.scan-input{background:#0000;border:none;color:var(--ds-text);flex:1 1;font-family:var(--ds-font-mono);font-size:var(--ds-text-lg);font-weight:600;outline:none;padding:8px}.scan-input::placeholder{color:var(--ds-text-muted);font-family:var(--ds-font-ui);font-weight:400}.scan-btn{background:var(--ds-green);border:none;border-radius:var(--ds-r-sm);color:#fff;cursor:pointer;font-family:var(--ds-font-ui);font-size:var(--ds-text-sm);font-weight:700;padding:9px var(--ds-sp-6);transition:background var(--ds-t-base)}.scan-btn:hover:not(:disabled){background:var(--ds-green-dark)}.scan-btn:disabled{opacity:.45}.scan-hint{color:var(--ds-text-muted);font-family:var(--ds-font-ui);font-size:var(--ds-text-xs);margin-top:var(--ds-sp-2)}.product-result{margin-top:var(--ds-sp-5)}.result-grid{grid-gap:var(--ds-sp-4);display:grid;gap:var(--ds-sp-4);grid-template-columns:1.5fr 1fr}.product-info-card,.stock-info-card{background:var(--ds-surface);border:1px solid var(--ds-border);border-radius:var(--ds-r-md);box-shadow:var(--ds-shadow-card);padding:var(--ds-sp-6)}.product-info-card h2{color:var(--ds-text);font-size:var(--ds-text-xl);font-weight:800;letter-spacing:-.3px;margin-bottom:var(--ds-sp-4)}.product-details-grid{grid-gap:var(--ds-sp-3);display:grid;gap:var(--ds-sp-3);grid-template-columns:1fr 1fr}.detail .label{color:var(--ds-text-muted);display:block;font-family:var(--ds-font-ui);font-size:var(--ds-text-xs);letter-spacing:.06em;margin-bottom:2px;text-transform:uppercase}.detail .value{color:var(--ds-text);font-family:var(--ds-font-ui);font-size:var(--ds-text-md);font-weight:600}.total-stock{border:1px solid;border-radius:var(--ds-r-sm);margin-bottom:var(--ds-sp-4);padding:var(--ds-sp-5);text-align:center}.total-stock.ok{background:var(--ds-success-bg);border-color:var(--ds-success-border)}.total-stock.warning{background:var(--ds-warning-bg);border-color:var(--ds-warning-border)}.total-stock.danger{background:var(--ds-danger-bg);border-color:var(--ds-danger-border)}.big-number{color:var(--ds-text);font-family:var(--ds-font-mono);font-size:48px;font-weight:800;letter-spacing:-.04em;line-height:1}.big-label{color:var(--ds-text-muted);font-family:var(--ds-font-ui);font-size:var(--ds-text-xs);letter-spacing:.07em;margin-top:var(--ds-sp-1);text-transform:uppercase}.location-row{align-items:center;border-bottom:1px solid var(--ds-border);display:flex;font-size:var(--ds-text-sm);justify-content:space-between;padding:7px 0}.location-row .qty{color:var(--ds-green-dark);font-family:var(--ds-font-mono);font-weight:700}.history-section{background:var(--ds-surface);border:1px solid var(--ds-border);border-radius:var(--ds-r-md);box-shadow:var(--ds-shadow-card);margin-top:var(--ds-sp-5);padding:var(--ds-sp-5)}.history-section h3{color:var(--ds-text);font-size:var(--ds-text-md);font-weight:700;margin-bottom:var(--ds-sp-3)}.history-table{border-collapse:collapse;width:100%}.history-table th{background:var(--ds-surface-sunken);color:var(--ds-text-muted);font-family:var(--ds-font-ui);font-size:var(--ds-text-xs);letter-spacing:.07em;padding:8px 12px;text-align:left;text-transform:uppercase}.history-table td{border-bottom:1px solid var(--ds-border);font-size:var(--ds-text-sm);padding:8px 12px}.type-badge{font-family:var(--ds-font-ui);font-weight:700;text-transform:uppercase}.type-badge.RECEIPT{background:var(--ds-success-bg);border:1px solid var(--ds-success-border);color:var(--ds-green-deeper)}.type-badge.ISSUE{background:var(--ds-danger-bg);border:1px solid var(--ds-danger-border);color:#7f1d1d}.negative,.positive{font-weight:700}.scan-history{background:var(--ds-surface);border:1px solid var(--ds-border);border-radius:var(--ds-r-md);box-shadow:var(--ds-shadow-card);margin-top:var(--ds-sp-6);padding:var(--ds-sp-5)}.scan-history h3{color:var(--ds-text);font-size:var(--ds-text-md);font-weight:700;margin-bottom:var(--ds-sp-3)}.scan-entry{border-bottom:1px solid var(--ds-border);display:flex;font-size:var(--ds-text-sm);gap:var(--ds-sp-4);padding:7px 0}.scan-time{color:var(--ds-text-muted);font-family:var(--ds-font-mono);font-size:var(--ds-text-xs);width:80px}.scan-product{color:var(--ds-text);flex:1 1;font-weight:600}.scan-code{color:var(--ds-text-muted);font-family:var(--ds-font-mono);font-size:var(--ds-text-xs)}@media (max-width:768px){.result-grid{grid-template-columns:1fr}}.warehouse-manager-container{background:var(--ds-bg);min-height:100vh;padding:var(--ds-sp-6)}.wh-form-card{background:var(--ds-surface);border:1px solid var(--ds-border);border-radius:var(--ds-r-md);box-shadow:var(--ds-shadow-card);margin:var(--ds-sp-5) 0;padding:var(--ds-sp-6)}.warehouse-layout{grid-gap:var(--ds-sp-5);display:grid;gap:var(--ds-sp-5);grid-template-columns:1fr 1fr;margin-top:var(--ds-sp-5)}.warehouse-tree{display:flex;flex-direction:column;gap:var(--ds-sp-3)}.wh-node{background:var(--ds-surface);border:1px solid var(--ds-border);border-radius:var(--ds-r-md);box-shadow:var(--ds-shadow-card);overflow:hidden}.wh-node.selected{border-color:var(--ds-green);border-width:2px}.wh-node-header{align-items:center;cursor:pointer;display:flex;gap:var(--ds-sp-3);padding:var(--ds-sp-4);transition:background var(--ds-t-base)}.wh-node-header:hover{background:var(--ds-surface-raised)}.wh-icon{font-size:var(--ds-text-xl)}.wh-info{flex:1 1}.wh-name{color:var(--ds-text);font-family:var(--ds-font-ui);font-size:var(--ds-text-md);font-weight:700}.wh-code{font-family:var(--ds-font-mono);letter-spacing:-.01em}.wh-code,.wh-stats{color:var(--ds-text-muted);font-size:var(--ds-text-xs)}.wh-stats{align-items:flex-end;font-family:var(--ds-font-ui);gap:2px}.wh-children,.wh-stats{display:flex;flex-direction:column}.wh-children{gap:var(--ds-sp-2);padding:0 var(--ds-sp-4) var(--ds-sp-3) var(--ds-sp-10)}.warehouse-detail,.wh-children .wh-node{border:1px solid var(--ds-border)}.warehouse-detail{background:var(--ds-surface);border-radius:var(--ds-r-md);box-shadow:var(--ds-shadow-card);padding:var(--ds-sp-6)}.warehouse-detail h3{color:var(--ds-text);font-size:var(--ds-text-lg);font-weight:800;margin-bottom:var(--ds-sp-1)}.detail-code{color:var(--ds-text-muted);font-family:var(--ds-font-mono);font-size:var(--ds-text-sm);margin-bottom:var(--ds-sp-4)}.detail-table{border-collapse:collapse;width:100%}.detail-table th{background:var(--ds-surface-sunken);color:var(--ds-text-muted);font-family:var(--ds-font-ui);font-size:var(--ds-text-xs);letter-spacing:.07em;padding:9px 12px;text-align:left;text-transform:uppercase}.detail-table td{border-bottom:1px solid var(--ds-border);font-size:var(--ds-text-base);padding:9px 12px}@media (max-width:768px){.warehouse-layout{grid-template-columns:1fr}}.purchasing-container{background:var(--ds-bg);min-height:100vh;padding:var(--ds-sp-6)}.header-icon.supplier{background:var(--ds-info);color:#fff}.header-icon.po{background:var(--ds-navy);color:#fff}.header-icon.invoice{background:#7c3aed;color:#fff}.send-btn{background:var(--ds-info-bg);border:1px solid var(--ds-info-border);border-radius:var(--ds-r-sm);color:var(--ds-info);cursor:pointer;font-size:var(--ds-text-xs);font-weight:700;padding:4px 10px}.data-table tr.completed{background:var(--ds-green-tint)}.data-table tr.partial{background:var(--ds-warning-bg)}.add-cost-row,.add-item-row{align-items:center;display:flex;flex-wrap:wrap;gap:var(--ds-sp-2);margin-bottom:var(--ds-sp-3)}.add-cost-row input,.add-cost-row select,.add-item-row input,.add-item-row select{border:1px solid var(--ds-border-mid);border-radius:var(--ds-r-sm);font-family:var(--ds-font-ui);font-size:var(--ds-text-base);padding:7px 10px}.add-cost-row select,.add-item-row select{min-width:200px}.add-item-btn{white-space:nowrap}.po-summary-cards{display:flex;flex-wrap:wrap;gap:var(--ds-sp-3);margin-bottom:var(--ds-sp-5)}.tab-content h4:first-child{margin-top:0}.inline-input{border:1px solid var(--ds-border-mid);border-radius:var(--ds-r-sm);font-family:var(--ds-font-ui);font-size:var(--ds-text-sm);min-width:80px;padding:6px 10px;width:100%}.inline-input:focus{border-color:var(--ds-green);box-shadow:0 0 0 3px #16a34a1f;outline:none}.existing-invoices,.receipts-list{margin-top:var(--ds-sp-4)}.receipt-tag{background:var(--ds-green-tint);border:1px solid var(--ds-success-border);border-radius:var(--ds-r-sm);color:var(--ds-green-dark)}.invoice-tag,.receipt-tag{display:inline-block;font-family:var(--ds-font-ui);font-size:var(--ds-text-sm);font-weight:600;margin:3px;padding:7px var(--ds-sp-4)}.invoice-tag{background:#f5f3ff;border:1px solid #c4b5fd;border-radius:var(--ds-r-sm);color:#6d28d9}.landed-existing{border-bottom:1px solid var(--ds-border);margin-bottom:var(--ds-sp-5);padding-bottom:var(--ds-sp-4)}.modal-actions .cancel-btn{flex:0 0 auto}@media (max-width:768px){.form-row-2,.form-row-3{grid-template-columns:1fr}.add-cost-row,.add-item-row{flex-wrap:wrap}.aging-cards,.po-summary-cards{flex-direction:column}.table-container{overflow-x:auto}}.sales-container{background:var(--ds-bg);min-height:100vh;padding:var(--ds-sp-6)}.header-icon.customer{background:var(--ds-green);color:#fff}.header-icon.so{background:var(--ds-navy);color:#fff}.header-icon.delivery{background:var(--ds-gold);color:#fff}.header-icon.sinvoice{background:#7c3aed;color:#fff}.header-icon.pricing{background:var(--ds-danger);color:#fff}.header-icon.returns{background:#ea580c;color:#fff}.back-btn{background:var(--ds-surface-raised);border:1px solid var(--ds-border-mid);border-radius:var(--ds-r-sm);color:var(--ds-text-sub);cursor:pointer;font-family:var(--ds-font-ui);font-size:var(--ds-text-sm);font-weight:600;padding:7px var(--ds-sp-4)}.back-btn:hover{color:var(--ds-text)}.back-btn:hover,.edit-btn:hover{background:var(--ds-surface-sunken)}.view-btn{background:var(--ds-info-bg);border:1px solid var(--ds-info-border);border-radius:var(--ds-r-sm);color:var(--ds-info);font-size:var(--ds-text-sm);font-weight:600}.pay-btn,.view-btn{cursor:pointer;padding:4px 10px}.pay-btn{background:var(--ds-green-tint);border:1px solid var(--ds-success-border);border-radius:var(--ds-r-sm);color:var(--ds-green);font-size:var(--ds-text-xs);font-weight:700}.remove-btn{background:var(--ds-danger-bg);border:none;color:var(--ds-danger);cursor:pointer;font-weight:700;padding:4px var(--ds-sp-2)}.info-message,.remove-btn{border-radius:var(--ds-r-sm)}.info-message{background:var(--ds-info-bg);border-left:3px solid var(--ds-info);color:var(--ds-info);padding:var(--ds-sp-5);text-align:center}.form-card{background:var(--ds-surface);border:1px solid var(--ds-border);border-radius:var(--ds-r-md);box-shadow:var(--ds-shadow-card);margin-bottom:var(--ds-sp-5);padding:var(--ds-sp-6)}.form-group input,.form-group select,.form-group textarea{transition:border-color var(--ds-t-base),box-shadow var(--ds-t-base)}.filter-select,.search-input{border:1px solid var(--ds-border-mid);border-radius:var(--ds-r-sm);color:var(--ds-text);font-family:var(--ds-font-ui);font-size:var(--ds-text-base);min-width:200px;padding:8px 12px}.filter-select:focus,.search-input:focus{border-color:var(--ds-green);box-shadow:0 0 0 3px #16a34a1f;outline:none}.table-container{overflow:hidden}.data-table tr.stock-warning{background:var(--ds-warning-bg)}.data-table tr.has-discount{background:var(--ds-green-tint)}.code{letter-spacing:-.01em}.highlight-value{color:var(--ds-gold);font-family:var(--ds-font-mono);font-weight:800}.loading-state,.no-data{font-size:var(--ds-text-base)}.area-badge,.type-badge{padding:2px 8px}.line-items-section{background:var(--ds-surface-raised);border:1px solid var(--ds-border-mid);border-radius:var(--ds-r-md);margin:var(--ds-sp-4) 0;padding:var(--ds-sp-4)}.line-items-section.sales{background:var(--ds-surface-raised);border-color:var(--ds-navy-light)}.line-items-section h4{color:var(--ds-text);font-size:var(--ds-text-md);font-weight:700;margin:0 0 var(--ds-sp-3)}.add-item-row{align-items:center;display:flex;flex-wrap:wrap;gap:var(--ds-sp-2);margin-bottom:var(--ds-sp-3)}.add-item-row input,.add-item-row select{border:1px solid var(--ds-border-mid);border-radius:var(--ds-r-sm);font-family:var(--ds-font-ui);font-size:var(--ds-text-base);padding:7px 10px}.add-item-row select{min-width:240px}.add-item-btn{background:var(--ds-info);border:none;border-radius:var(--ds-r-sm);color:#fff;cursor:pointer;font-family:var(--ds-font-ui);font-weight:700;padding:7px var(--ds-sp-4)}.items-table{border-collapse:collapse;width:100%}.items-table th{background:var(--ds-surface-sunken);color:var(--ds-text-muted);font-family:var(--ds-font-ui);font-size:var(--ds-text-xs);letter-spacing:.06em;padding:7px 12px;text-align:left;text-transform:uppercase}.items-table td{border-bottom:1px solid var(--ds-border);font-size:var(--ds-text-sm);padding:7px 12px}.totals-row{background:var(--ds-surface-raised);font-weight:700}.totals-row.grand{background:var(--ds-navy);color:#fff}.totals-row.grand td{color:#fff;font-family:var(--ds-font-mono)}.so-summary-cards{display:flex;flex-wrap:wrap;gap:var(--ds-sp-3);margin-bottom:var(--ds-sp-5)}.summary-card{background:var(--ds-surface);border:1px solid var(--ds-border);border-radius:var(--ds-r-md);box-shadow:var(--ds-shadow-card);flex:1 1;min-width:120px;padding:var(--ds-sp-4);text-align:center}.summary-card.highlight{background:var(--ds-navy);border-color:var(--ds-navy)}.summary-card.highlight .sc-label,.summary-card.highlight .sc-value{color:#fff}.sc-label{color:var(--ds-text-muted);font-family:var(--ds-font-ui);font-size:var(--ds-text-xs);letter-spacing:.07em;margin-bottom:var(--ds-sp-1);text-transform:uppercase}.sc-value{color:var(--ds-text);font-family:var(--ds-font-mono);font-size:20px;font-weight:800;letter-spacing:-.03em}.so-totals{margin-left:auto;margin-top:var(--ds-sp-4);max-width:350px}.total-line{display:flex;font-family:var(--ds-font-ui);font-size:var(--ds-text-sm);justify-content:space-between;padding:7px var(--ds-sp-4)}.total-line .amount{font-family:var(--ds-font-mono)}.total-line.discount{color:var(--ds-danger)}.total-line.grand{background:var(--ds-navy);border-radius:var(--ds-r-sm);color:#fff;font-size:var(--ds-text-md);font-weight:800;padding:10px var(--ds-sp-4)}.workflow-bar{background:var(--ds-surface);border:1px solid var(--ds-border);border-radius:var(--ds-r-md);box-shadow:var(--ds-shadow-card);gap:0;justify-content:center;margin-bottom:var(--ds-sp-5);padding:var(--ds-sp-5)}.workflow-bar,.workflow-step{align-items:center;display:flex}.workflow-step{flex-direction:column;min-width:80px;position:relative}.step-icon{align-items:center;background:var(--ds-surface-sunken);border-radius:50%;display:flex;font-size:26px;height:48px;justify-content:center;margin-bottom:var(--ds-sp-2);width:48px}.workflow-step.completed .step-icon{background:var(--ds-green-light)}.workflow-step.current .step-icon{background:var(--ds-green);box-shadow:0 0 0 4px #16a34a33}.step-label{color:var(--ds-text-muted);font-family:var(--ds-font-ui);font-size:var(--ds-text-xs);font-weight:700;letter-spacing:.05em;text-transform:uppercase}.workflow-step.current .step-label{color:var(--ds-green)}.step-line{background:var(--ds-border-mid);height:2px;position:absolute;right:-20px;top:24px;width:40px}.step-line.done{background:var(--ds-green)}.action-bar{display:flex;flex-wrap:wrap;gap:var(--ds-sp-3);margin-bottom:var(--ds-sp-5)}.workflow-btn{border:none;border-radius:var(--ds-r-sm);color:#fff;cursor:pointer;font-family:var(--ds-font-ui);font-size:var(--ds-text-sm);font-weight:700;padding:10px var(--ds-sp-6);transition:opacity var(--ds-t-base)}.workflow-btn:disabled{opacity:.45}.workflow-btn.confirm{background:var(--ds-info)}.workflow-btn.ship{background:var(--ds-gold)}.workflow-btn.deliver{background:var(--ds-green)}.workflow-btn.invoice{background:#7c3aed}.info-card{background:var(--ds-surface);border:1px solid var(--ds-border);border-radius:var(--ds-r-md);box-shadow:var(--ds-shadow-card);margin-top:var(--ds-sp-4);padding:var(--ds-sp-5)}.info-card h4{color:var(--ds-text);font-size:var(--ds-text-md);font-weight:700;margin:0 0 var(--ds-sp-3)}.info-grid{grid-gap:var(--ds-sp-3);display:grid;gap:var(--ds-sp-3);grid-template-columns:1fr 1fr}.info-grid .label{color:var(--ds-text-muted);font-size:var(--ds-text-xs);letter-spacing:.05em;text-transform:uppercase}.area-group{margin-bottom:var(--ds-sp-6)}.area-header{align-items:center;background:var(--ds-green-tint);border:1px solid var(--ds-success-border);border-radius:var(--ds-r-sm);display:flex;justify-content:space-between;margin-bottom:var(--ds-sp-3);padding:10px var(--ds-sp-4)}.area-name{color:var(--ds-green);font-family:var(--ds-font-ui);font-size:var(--ds-text-md);font-weight:800}.area-count{background:var(--ds-green);border-radius:var(--ds-r-pill);color:#fff;font-size:var(--ds-text-xs);font-weight:700;padding:2px 10px}.delivery-cards{grid-gap:var(--ds-sp-3);display:grid;gap:var(--ds-sp-3);grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.delivery-card{background:var(--ds-surface);border:1px solid var(--ds-border-mid);border-radius:var(--ds-r-md);padding:var(--ds-sp-4);transition:border-color var(--ds-t-base),box-shadow var(--ds-t-base)}.delivery-card:hover{box-shadow:var(--ds-shadow-md)}.delivery-card.delivered{background:var(--ds-green-tint);border-color:var(--ds-success-border)}.delivery-card.in_transit{background:var(--ds-warning-bg);border-color:var(--ds-warning-border)}.dc-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--ds-sp-2)}.dc-order{color:var(--ds-info);font-family:var(--ds-font-mono);font-size:var(--ds-text-sm);font-weight:600}.dc-customer{color:var(--ds-text);font-family:var(--ds-font-ui);font-size:var(--ds-text-md);font-weight:700}.dc-address{color:var(--ds-text-sub)}.dc-address,.dc-footer{font-size:var(--ds-text-sm);margin-bottom:var(--ds-sp-3)}.dc-footer{display:flex;justify-content:space-between}.dc-driver{color:var(--ds-text-sub)}.dc-total{color:var(--ds-green-dark);font-family:var(--ds-font-mono);font-weight:800}.complete-btn{background:var(--ds-green);border:none;border-radius:var(--ds-r-sm);color:#fff;cursor:pointer;font-family:var(--ds-font-ui);font-size:var(--ds-text-sm);font-weight:700;padding:9px;transition:background var(--ds-t-base);width:100%}.complete-btn:hover{background:var(--ds-green-dark)}.complete-btn.small{font-size:var(--ds-text-xs);padding:4px 10px;width:auto}.today-header h3{color:var(--ds-text);font-size:var(--ds-text-lg);font-weight:700;margin-bottom:var(--ds-sp-4)}.aging-card{min-width:110px;padding:var(--ds-sp-4)}.aging-value{font-size:22px}.overdue-alert{background:var(--ds-danger-bg);border:1px solid var(--ds-danger-border);border-radius:var(--ds-r-md);margin-bottom:var(--ds-sp-5);padding:var(--ds-sp-4)}.overdue-header{color:var(--ds-danger);font-family:var(--ds-font-ui);font-size:var(--ds-text-md);font-weight:800;margin-bottom:var(--ds-sp-3)}.overdue-list{display:flex;flex-direction:column;gap:var(--ds-sp-2)}.overdue-item{align-items:center;background:var(--ds-surface);border:1px solid var(--ds-border);border-radius:var(--ds-r-sm);display:flex;gap:var(--ds-sp-4);padding:7px 12px}.oi-inv,.overdue-item{font-size:var(--ds-text-sm)}.oi-inv{color:var(--ds-info);font-family:var(--ds-font-mono);font-weight:600;width:120px}.oi-cust{flex:1 1;font-weight:600}.oi-phone{color:var(--ds-text-sub);width:120px}.oi-balance{width:100px}.oi-balance,.oi-days{font-family:var(--ds-font-mono);font-weight:700;text-align:right}.oi-days{color:var(--ds-danger);width:90px}.modal-card{width:500px}.modal-card h3{margin:0 0 var(--ds-sp-2)}.modal-card p{color:var(--ds-text-sub);font-size:var(--ds-text-sm);margin:0 0 var(--ds-sp-4)}.status-pending{color:var(--ds-gold)}.status-partial{color:var(--ds-info)}.status-paid{color:var(--ds-green)}.price-preview{margin-bottom:var(--ds-sp-5)}@media (max-width:768px){.form-row-2,.form-row-3{grid-template-columns:1fr}.add-item-row{flex-wrap:wrap}.aging-cards,.so-summary-cards{flex-direction:column}.table-container{overflow-x:auto}.workflow-bar{flex-wrap:wrap}.delivery-cards{grid-template-columns:1fr}.overdue-item{flex-wrap:wrap}.info-grid{grid-template-columns:1fr}}.admin-container{background:var(--ds-bg);min-height:100vh;padding:var(--ds-sp-6)}.page-header{flex-wrap:wrap;gap:var(--ds-sp-3);justify-content:space-between;margin-bottom:var(--ds-sp-6)}.header-content,.page-header{align-items:center;display:flex}.header-content{gap:var(--ds-sp-4)}.header-icon{align-items:center;border-radius:var(--ds-r-md);box-shadow:none;color:#fff;display:flex;font-size:24px;height:44px;justify-content:center;width:44px}.header-icon.finance{background:var(--ds-green)}.header-icon.reports{background:#7c3aed}.header-icon.users{background:var(--ds-info)}.header-icon.settings{background:var(--ds-neutral)}.header-icon.notifications{background:#d97706}.header-icon.route{background:#0891b2}.header-icon.fifo{background:#7c3aed}.page-header h1{color:var(--ds-text);font-size:var(--ds-text-2xl);font-weight:800;letter-spacing:-.4px;margin:0}.page-header p{color:var(--ds-text-muted);margin:2px 0 0}.action-btn,.page-header p{font-size:var(--ds-text-sm)}.action-btn{background:var(--ds-surface);border:1px solid var(--ds-border-mid);border-radius:var(--ds-r-sm);cursor:pointer;font-family:var(--ds-font-ui);font-weight:600;padding:7px var(--ds-sp-4);transition:all var(--ds-t-base)}.action-btn:hover{background:var(--ds-surface-raised);border-color:var(--ds-border-strong)}.action-btn.primary{background:var(--ds-green);border-color:var(--ds-green);color:#fff}.action-btn.primary:hover{background:var(--ds-green-dark);border-color:var(--ds-green-dark)}.submit-btn{background:var(--ds-green);border:none;border-radius:var(--ds-r-sm);color:#fff;cursor:pointer;font-family:var(--ds-font-ui);font-size:var(--ds-text-md);font-weight:700;letter-spacing:.02em;margin-top:var(--ds-sp-2);padding:12px;transition:background var(--ds-t-base);width:100%}.submit-btn:hover:not(:disabled){background:var(--ds-green-dark)}.submit-btn:disabled{cursor:not-allowed;opacity:.45}.cancel-btn{background:var(--ds-surface-raised);border:1px solid var(--ds-border-mid);border-radius:var(--ds-r-sm);color:var(--ds-text-sub);cursor:pointer;font-family:var(--ds-font-ui);font-weight:600;padding:10px var(--ds-sp-6)}.edit-btn{background:none;border:none;border-radius:var(--ds-r-sm);cursor:pointer;font-size:var(--ds-text-md);padding:4px var(--ds-sp-2);transition:background var(--ds-t-base)}.edit-btn:hover{background:var(--ds-surface-raised)}.message{border-left:3px solid;border-radius:var(--ds-r-sm);font-family:var(--ds-font-ui);font-size:var(--ds-text-sm);font-weight:600;margin-bottom:var(--ds-sp-4);padding:10px var(--ds-sp-4)}.message.success{background:var(--ds-success-bg);border-left-color:var(--ds-green);color:var(--ds-green-deeper)}.message.error{background:var(--ds-danger-bg);border-left-color:var(--ds-danger);color:#7f1d1d}.loading-state{padding:var(--ds-sp-10)}.loading-state,.no-data{color:var(--ds-text-muted);text-align:center}.no-data{font-style:italic;padding:var(--ds-sp-8)}.form-card,.settings-form{background:var(--ds-surface);border:1px solid var(--ds-border);border-radius:var(--ds-r-md);box-shadow:var(--ds-shadow-card);margin-bottom:var(--ds-sp-5);padding:var(--ds-sp-6)}.form-card h3{color:var(--ds-text);font-size:var(--ds-text-md);font-weight:700;margin:0 0 var(--ds-sp-4)}.form-row-2{grid-gap:var(--ds-sp-4);grid-template-columns:1fr 1fr}.form-row-2,.form-row-3{display:grid;gap:var(--ds-sp-4);margin-bottom:var(--ds-sp-3)}.form-row-3{grid-gap:var(--ds-sp-4);grid-template-columns:1fr 1fr 1fr}.form-group{display:flex;flex-direction:column;gap:var(--ds-sp-1)}.form-group label{color:var(--ds-text-sub);font-family:var(--ds-font-ui);font-size:var(--ds-text-xs);font-weight:700;letter-spacing:.06em;text-transform:uppercase}.form-group input,.form-group select,.form-group textarea{border:1px solid var(--ds-border-mid);border-radius:var(--ds-r-sm);color:var(--ds-text);font-family:var(--ds-font-ui);font-size:var(--ds-text-base);padding:8px 12px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--ds-green);box-shadow:0 0 0 3px #16a34a1f;outline:none}.filter-bar{align-items:center;display:flex;flex-wrap:wrap;gap:var(--ds-sp-3);margin-bottom:var(--ds-sp-4)}.filter-bar label{color:var(--ds-text-sub);font-family:var(--ds-font-ui);font-size:var(--ds-text-sm);font-weight:600}.filter-input,.filter-select{border:1px solid var(--ds-border-mid);border-radius:var(--ds-r-sm);color:var(--ds-text);font-family:var(--ds-font-ui);font-size:var(--ds-text-base);padding:7px 10px}.filter-input:focus,.filter-select:focus{border-color:var(--ds-green);box-shadow:0 0 0 3px #16a34a1f;outline:none}.table-container{background:var(--ds-surface);border:1px solid var(--ds-border);border-radius:var(--ds-r-md);box-shadow:var(--ds-shadow-card);overflow-x:auto}.data-table{border-collapse:collapse;width:100%}.data-table th{background:var(--ds-navy);color:#fff;font-family:var(--ds-font-ui);font-size:var(--ds-text-xs);font-weight:700;letter-spacing:.07em;padding:10px 14px;text-align:left;text-transform:uppercase;white-space:nowrap}.data-table td{border-bottom:1px solid var(--ds-border);color:var(--ds-text);font-family:var(--ds-font-ui);font-size:var(--ds-text-base);padding:9px 14px}.data-table tr:hover{background:var(--ds-green-tint)}.data-table tr.inactive{opacity:.5}.data-table tr.overdue-row{background:var(--ds-danger-bg)}.data-table.compact td{font-size:var(--ds-text-sm);padding:7px 12px}.data-table.compact th{padding:7px 12px}.code{color:var(--ds-info);font-family:var(--ds-font-mono);font-size:var(--ds-text-sm);font-weight:500}.name{font-weight:600}.value{color:var(--ds-green-dark);font-size:var(--ds-text-sm)}.positive,.value{font-family:var(--ds-font-mono);font-weight:600}.positive{color:var(--ds-green)}.negative{color:var(--ds-danger);font-family:var(--ds-font-mono);font-weight:600}.center{text-align:center}.action-cell{display:flex;gap:var(--ds-sp-1)}.status-pill{border-radius:var(--ds-r-sm);color:#fff;display:inline-block;font-family:var(--ds-font-ui);font-size:var(--ds-text-xs);font-weight:700;letter-spacing:.05em;padding:3px 8px;text-transform:uppercase;white-space:nowrap}.area-badge{background:var(--ds-green-tint);border:1px solid var(--ds-success-border);border-radius:var(--ds-r-sm);color:var(--ds-green)}.area-badge,.type-badge{display:inline-block;font-size:var(--ds-text-xs);font-weight:600;padding:2px 7px}.type-badge{background:var(--ds-info-bg);border:1px solid var(--ds-info-border);border-radius:var(--ds-r-sm);color:var(--ds-info)}.action-badge{background:var(--ds-surface-raised);border:1px solid var(--ds-border-mid);border-radius:var(--ds-r-sm);color:var(--ds-text-sub);display:inline-block;font-size:var(--ds-text-xs);font-weight:600;padding:2px 7px}.rank{color:var(--ds-gold);font-family:var(--ds-font-mono);font-weight:800;margin-right:var(--ds-sp-2)}.margin-badge{border-radius:var(--ds-r-sm);display:inline-block;font-size:var(--ds-text-xs);font-weight:700;padding:2px 7px}.margin-badge.high{background:var(--ds-green-light);color:var(--ds-green-deeper)}.margin-badge.med{background:var(--ds-gold-light);color:var(--ds-gold-dark)}.margin-badge.low{background:var(--ds-danger-bg);color:var(--ds-danger)}.tab-bar{background:var(--ds-surface);border:1px solid var(--ds-border);border-radius:var(--ds-r-md);display:flex;flex-wrap:wrap;gap:3px;margin-bottom:var(--ds-sp-4);padding:3px}.tab-btn{background:#0000;border:none;border-radius:var(--ds-r-sm);color:var(--ds-text-sub);cursor:pointer;font-family:var(--ds-font-ui);font-size:var(--ds-text-sm);font-weight:600;padding:8px var(--ds-sp-5);transition:all var(--ds-t-base)}.tab-btn.active{background:var(--ds-navy);color:#fff}.tab-btn:hover:not(.active){background:var(--ds-surface-raised);color:var(--ds-text)}.tab-content{background:var(--ds-surface);border:1px solid var(--ds-border);border-radius:var(--ds-r-md);box-shadow:var(--ds-shadow-card);padding:var(--ds-sp-6)}.tab-content h3{margin:0 0 var(--ds-sp-4)}.tab-content h3,.tab-content h4{color:var(--ds-text);font-size:var(--ds-text-md);font-weight:700}.tab-content h4{margin:var(--ds-sp-4) 0 var(--ds-sp-3)}.modal-overlay{align-items:center;background:#0f172a8c;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:500}.modal-card{background:var(--ds-surface);border:1px solid var(--ds-border);border-radius:var(--ds-r-xl);box-shadow:var(--ds-shadow-lg);max-width:90vw;padding:var(--ds-sp-8);width:450px}.modal-card h3{color:var(--ds-text);font-size:var(--ds-text-lg);font-weight:800;margin:0 0 var(--ds-sp-4)}.modal-actions{display:flex;gap:var(--ds-sp-3);margin-top:var(--ds-sp-4)}.modal-actions .submit-btn{flex:1 1}.kpi-grid{grid-gap:var(--ds-sp-4);display:grid;gap:var(--ds-sp-4);grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-bottom:var(--ds-sp-6)}.kpi-card{align-items:center;background:var(--ds-surface);border:1px solid var(--ds-border);border-left:4px solid var(--ds-border-mid);border-radius:var(--ds-r-md);box-shadow:var(--ds-shadow-card);display:flex;gap:var(--ds-sp-4);padding:var(--ds-sp-5)}.kpi-card.receivable{border-left-color:var(--ds-info)}.kpi-card.payable{border-left-color:var(--ds-danger)}.kpi-card.net{border-left-color:#7c3aed}.kpi-card.sales{border-left-color:var(--ds-green)}.kpi-card.profit{border-left-color:var(--ds-gold)}.kpi-card.stock{border-left-color:var(--ds-neutral)}.kpi-icon{flex-shrink:0;font-size:28px}.kpi-body{flex:1 1}.kpi-label{color:var(--ds-text-muted);font-family:var(--ds-font-ui);font-size:var(--ds-text-xs);font-weight:700;letter-spacing:.07em;text-transform:uppercase}.kpi-value{color:var(--ds-text);font-family:var(--ds-font-mono);font-size:var(--ds-text-2xl);font-weight:800;letter-spacing:-.03em}.kpi-sub{color:var(--ds-text-muted);font-family:var(--ds-font-ui);font-size:var(--ds-text-xs)}.section-row{grid-gap:var(--ds-sp-5);display:grid;gap:var(--ds-sp-5);grid-template-columns:1fr 1fr;margin-bottom:var(--ds-sp-5)}.section-card{background:var(--ds-surface);border:1px solid var(--ds-border);border-radius:var(--ds-r-md);box-shadow:var(--ds-shadow-card);padding:var(--ds-sp-6)}.section-card h3{color:var(--ds-text);font-size:var(--ds-text-md);font-weight:700;margin:0 0 var(--ds-sp-4)}.cash-flow-bar{flex-direction:column}.cash-flow-bar,.cf-row{display:flex;gap:var(--ds-sp-3)}.cf-row{align-items:center}.cf-label{color:var(--ds-text-sub);font-family:var(--ds-font-ui);font-size:var(--ds-text-sm);font-weight:600;min-width:150px}.cf-bar-wrap{align-items:center;display:flex;flex:1 1;gap:var(--ds-sp-3)}.cf-bar{border-radius:var(--ds-r-sm);height:24px;min-width:4px;transition:width .4s ease}.cf-bar.in{background:var(--ds-green)}.cf-bar.out{background:var(--ds-danger)}.cf-amount{color:var(--ds-text);font-family:var(--ds-font-mono);font-size:var(--ds-text-sm);font-weight:800}.cf-net{border-top:1px solid var(--ds-border-mid);color:var(--ds-text);font-family:var(--ds-font-ui);font-size:var(--ds-text-md);font-weight:700;margin-top:var(--ds-sp-2);padding:var(--ds-sp-3) 0}.cf-net,.pnl-header{display:flex;justify-content:space-between}.pnl-header{align-items:center;margin-bottom:var(--ds-sp-4)}.period-tabs{display:flex;gap:var(--ds-sp-1)}.period-btn{background:var(--ds-surface);border:1px solid var(--ds-border-mid);border-radius:var(--ds-r-sm);color:var(--ds-text-sub);cursor:pointer;font-family:var(--ds-font-ui);font-size:var(--ds-text-xs);font-weight:600;padding:5px 12px;transition:all var(--ds-t-base)}.period-btn.active{background:var(--ds-navy);border-color:var(--ds-navy);color:#fff}.pnl-body{display:flex;flex-direction:column;gap:var(--ds-sp-1)}.pnl-line{display:flex;font-family:var(--ds-font-ui);font-size:var(--ds-text-sm);justify-content:space-between;padding:7px 0}.pnl-line.sub{color:var(--ds-text-muted);font-size:var(--ds-text-xs);padding-left:var(--ds-sp-5)}.pnl-line.bold{border-top:1px solid var(--ds-border-mid);font-weight:700;padding-top:9px}.pnl-line.grand{background:var(--ds-navy);border-radius:0 0 var(--ds-r-md) var(--ds-r-md);color:#fff;font-size:var(--ds-text-md);font-weight:800;margin:var(--ds-sp-2) calc(var(--ds-sp-6)*-1) calc(var(--ds-sp-6)*-1);padding:var(--ds-sp-4) var(--ds-sp-6)}.pnl-line.grand .val{color:#fff}.val{font-family:var(--ds-font-mono);font-weight:700}.pnl-margin{color:var(--ds-text-muted);font-family:var(--ds-font-ui);font-size:var(--ds-text-xs);padding:var(--ds-sp-3) 0 0;text-align:center}.trend-chart{align-items:flex-end;display:flex;gap:var(--ds-sp-2);height:180px;padding:var(--ds-sp-5) 0}.trend-month{align-items:center;display:flex;flex:1 1;flex-direction:column}.trend-bars{align-items:flex-end;display:flex;gap:3px;height:140px}.trend-bar{border-radius:var(--ds-r-sm) var(--ds-r-sm) 0 0;min-height:2px;transition:height .4s;width:14px}.trend-bar.sales{background:var(--ds-green)}.trend-bar.purchases{background:var(--ds-danger)}.trend-label{color:var(--ds-text-muted)}.trend-label,.trend-legend{font-family:var(--ds-font-ui);font-size:var(--ds-text-xs);margin-top:var(--ds-sp-2)}.trend-legend{color:var(--ds-text-sub);display:flex;gap:var(--ds-sp-4);justify-content:center}.legend-dot{border-radius:var(--ds-r-xs);display:inline-block;height:10px;margin-right:4px;vertical-align:middle;width:10px}.legend-dot.sales{background:var(--ds-green)}.legend-dot.purchases{background:var(--ds-danger)}.report-grid{grid-gap:var(--ds-sp-3);display:grid;gap:var(--ds-sp-3);grid-template-columns:repeat(auto-fill,minmax(200px,1fr));margin-bottom:var(--ds-sp-6)}.report-card{align-items:center;background:var(--ds-surface);border:1px solid var(--ds-border);border-radius:var(--ds-r-md);box-shadow:var(--ds-shadow-card);cursor:pointer;display:flex;gap:var(--ds-sp-4);padding:var(--ds-sp-4);transition:border-color var(--ds-t-base),box-shadow var(--ds-t-base)}.report-card:hover{border-color:var(--ds-green);box-shadow:var(--ds-shadow-md)}.report-card.active{background:var(--ds-green-tint);border-color:var(--ds-green)}.rc-icon{font-size:26px}.rc-name{color:var(--ds-text);font-size:var(--ds-text-sm);font-weight:700}.rc-desc,.rc-name{font-family:var(--ds-font-ui)}.rc-desc{color:var(--ds-text-muted);font-size:var(--ds-text-xs)}.report-output{background:var(--ds-surface);border:1px solid var(--ds-border);border-radius:var(--ds-r-md);box-shadow:var(--ds-shadow-card);padding:var(--ds-sp-6)}.report-output h3{color:var(--ds-text);font-size:var(--ds-text-md);font-weight:700;margin:0 0 var(--ds-sp-4)}.report-summary{background:var(--ds-green-tint);border:1px solid var(--ds-success-border);border-radius:var(--ds-r-sm);font-family:var(--ds-font-ui);font-size:var(--ds-text-sm);margin-bottom:var(--ds-sp-4);padding:var(--ds-sp-3) var(--ds-sp-4)}.report-summary strong{color:var(--ds-green)}.report-summary .positive{color:var(--ds-green);font-family:var(--ds-font-mono)}.report-summary .negative{color:var(--ds-danger);font-family:var(--ds-font-mono)}.aging-cards{display:flex;flex-wrap:wrap;gap:var(--ds-sp-3);margin-bottom:var(--ds-sp-5)}.aging-card{border:1px solid;border-radius:var(--ds-r-md);flex:1 1;min-width:100px;padding:var(--ds-sp-3);text-align:center}.aging-card.current{background:var(--ds-success-bg);border-color:var(--ds-success-border)}.aging-card.d30{background:var(--ds-warning-bg);border-color:var(--ds-warning-border)}.aging-card.d60{background:#fff7ed;border-color:#fdba74}.aging-card.d90{background:var(--ds-danger-bg);border-color:var(--ds-danger-border)}.aging-card.over90{background:var(--ds-danger-bg);border-color:#f87171}.aging-card.total{background:var(--ds-navy);border-color:var(--ds-navy)}.aging-card.total .aging-label,.aging-card.total .aging-value{color:#fff}.aging-label{color:var(--ds-text-muted);font-family:var(--ds-font-ui);font-size:var(--ds-text-xs);font-weight:700;letter-spacing:.05em;margin-bottom:var(--ds-sp-1);text-transform:uppercase}.aging-value{color:var(--ds-text);font-family:var(--ds-font-mono);font-size:20px;font-weight:800;letter-spacing:-.03em}.perf-bar{background:var(--ds-surface-sunken);border:1px solid var(--ds-border);border-radius:var(--ds-r-sm);height:22px;overflow:hidden;position:relative}.perf-fill{background:var(--ds-green);border-radius:var(--ds-r-sm);height:100%;transition:width .4s}.perf-bar span{color:var(--ds-text);font-family:var(--ds-font-mono);font-size:var(--ds-text-xs);font-weight:700;position:absolute;right:var(--ds-sp-2);top:4px}.role-legend{background:var(--ds-surface);border:1px solid var(--ds-border);border-radius:var(--ds-r-md);box-shadow:var(--ds-shadow-card);margin-top:var(--ds-sp-6);padding:var(--ds-sp-5)}.role-legend h4{color:var(--ds-text);font-size:var(--ds-text-md);font-weight:700;margin:0 0 var(--ds-sp-3)}.role-grid{grid-gap:var(--ds-sp-2);display:grid;gap:var(--ds-sp-2);grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.role-item{align-items:center;display:flex;font-family:var(--ds-font-ui);gap:var(--ds-sp-3);padding:var(--ds-sp-2)}.backup-section p,.role-item{color:var(--ds-text-sub);font-size:var(--ds-text-sm)}.backup-section p{margin-bottom:var(--ds-sp-4)}.backup-section code{background:var(--ds-surface-raised);border:1px solid var(--ds-border);border-radius:var(--ds-r-sm);color:var(--ds-text);font-family:var(--ds-font-mono);font-size:var(--ds-text-xs);padding:2px var(--ds-sp-2)}.backup-action{align-items:center;background:var(--ds-info-bg);border:1px solid var(--ds-info-border);border-radius:var(--ds-r-md);display:flex;flex-wrap:wrap;gap:var(--ds-sp-3);justify-content:space-between;padding:var(--ds-sp-4)}.export-grid{grid-gap:var(--ds-sp-3);display:grid;gap:var(--ds-sp-3);grid-template-columns:repeat(auto-fill,minmax(150px,1fr));margin-top:var(--ds-sp-4)}.export-card{background:var(--ds-surface);border:1px solid var(--ds-border);border-radius:var(--ds-r-md);cursor:pointer;padding:var(--ds-sp-4);text-align:center;transition:border-color var(--ds-t-base),box-shadow var(--ds-t-base)}.export-card:hover{background:var(--ds-green-tint);border-color:var(--ds-green);box-shadow:var(--ds-shadow-sm)}.ec-name{color:var(--ds-text);font-size:var(--ds-text-sm);font-weight:700;margin-bottom:var(--ds-sp-1)}.ec-name,.ec-rows{font-family:var(--ds-font-ui)}.ec-rows{color:var(--ds-text-muted);font-size:var(--ds-text-xs)}@media (max-width:768px){.form-row-2,.form-row-3,.section-row{grid-template-columns:1fr}.kpi-grid{grid-template-columns:1fr 1fr}.report-grid{grid-template-columns:1fr}.aging-cards{flex-direction:column}.trend-chart{overflow-x:auto}.pnl-header{flex-direction:column;gap:var(--ds-sp-2)}}.pdf-toolbar{background:#1a1a2e;display:flex;gap:10px;padding:12px 20px;position:sticky;top:0;z-index:100}.btn-print{background:#0d7a3e;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:8px 20px}.btn-print:hover{background:#0a5c2e}.btn-close-pdf{background:#666;border:none;border-radius:6px;color:#fff;cursor:pointer;padding:8px 16px}.btn-close-pdf:hover{background:#555}.delivery-note-wrapper,.delivery-sheet-wrapper,.invoice-pdf-wrapper,.statement-wrapper{background:#e0e0e0;min-height:100vh}.dn-page,.invoice-page,.stmt-page{max-width:210mm;padding:30px 40px}.delivery-sheet-page,.dn-page,.invoice-page,.stmt-page{background:#fff;box-shadow:0 2px 12px #00000026;color:#222;font-family:Segoe UI,Arial,sans-serif;font-size:12px;line-height:1.5;margin:0 auto}.delivery-sheet-page{max-width:297mm;padding:20px 30px}.dn-header,.inv-header,.stmt-header{align-items:flex-start;border-bottom:3px solid #0d7a3e;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:16px}.dn-company-name,.inv-company-name,.stmt-company-name{color:#0d7a3e;font-size:22px;font-weight:700;margin:0 0 4px}.dn-company p,.inv-company p,.stmt-company p{color:#555;font-size:11px;margin:1px 0}.dn-title,.inv-title,.stmt-title{color:#0d7a3e;font-size:20px;font-weight:700;letter-spacing:1px;margin:0 0 8px;text-align:right}.dn-meta,.inv-meta,.stmt-meta{border-collapse:collapse;font-size:11px}.dn-meta td,.inv-meta td,.stmt-meta td{padding:2px 0}.meta-label{color:#777;padding-right:8px;text-align:right;white-space:nowrap}.meta-value{color:#222;font-weight:600}.dn-info-row,.inv-addresses{display:flex;gap:40px;margin-bottom:20px}.dn-info-row>div,.inv-addresses>div{flex:1 1}.dn-customer-info h3,.dn-driver-info h3,.inv-bill-to h3,.inv-ship-to h3,.stmt-customer h3{color:#0d7a3e;font-size:11px;font-weight:700;letter-spacing:.5px;margin:0 0 6px;text-transform:uppercase}.dn-cust-name,.inv-cust-name,.stmt-cust-name{font-size:14px;font-weight:700;margin:0 0 3px}.dn-customer-info p,.dn-driver-info p,.inv-bill-to p,.inv-ship-to p,.stmt-customer p{font-size:11px;margin:1px 0}.dn-instructions{background:#f0f7f4;border-left:3px solid #0d7a3e;font-size:11px;margin-bottom:16px;padding:8px 12px}.dn-items-table,.inv-items-table{border-collapse:collapse;font-size:11px;margin-bottom:20px;width:100%}.dn-items-table thead,.inv-items-table thead{background:#0d7a3e;color:#fff}.dn-items-table th,.inv-items-table th{font-size:10px;font-weight:600;letter-spacing:.3px;padding:8px 6px;text-align:left;text-transform:uppercase}.dn-items-table td,.inv-items-table td{border-bottom:1px solid #e5e5e5;padding:7px 6px}.dn-items-table tbody tr:nth-child(2n),.inv-items-table tbody tr:nth-child(2n){background:#f9f9f9}.col-no{text-align:center;width:30px}.col-sku{width:70px}.col-barcode,.col-sku{font-family:monospace;font-size:10px}.col-barcode{width:90px}.col-desc{min-width:120px}.col-uom{text-align:center;width:45px}.col-qty,.col-shipped{font-weight:600;text-align:center;width:55px}.col-price,.col-total{font-family:monospace;text-align:right;width:75px}.col-disc{font-size:10px;text-align:center;width:50px}.col-check{font-size:14px;text-align:center;width:30px}.col-amount{font-family:monospace;text-align:right}.inv-totals-section{display:flex;justify-content:space-between;margin-bottom:30px}.inv-notes{color:#555;flex:1 1;font-size:11px;padding-right:40px}.inv-totals{border-collapse:collapse;min-width:220px}.inv-totals td{font-size:12px;padding:4px 0}.inv-totals td:first-child{color:#555;padding-right:12px;text-align:right}.inv-totals td:last-child{font-family:monospace;font-size:12px;text-align:right}.inv-grand-total td{color:#0d7a3e;font-size:14px!important}.dn-totals-row td,.inv-grand-total td{border-top:2px solid #0d7a3e;padding-top:8px}.dn-signatures,.inv-footer{display:flex;justify-content:space-between;margin-top:40px;padding-top:10px}.dn-sig-block,.inv-sig-block{min-width:160px;text-align:center}.dn-sig-line,.inv-sig-line{border-bottom:1px solid #333;height:40px;margin-bottom:4px}.dn-sig-block p,.inv-sig-block p{color:#555;font-size:10px;margin:2px 0}.dn-sig-detail{color:#888!important;font-size:9px!important}.dn-footer-note,.inv-terms,.stmt-footer{border-top:1px solid #ddd;color:#888;font-size:10px;margin-top:20px;padding-top:10px;text-align:center}.stmt-footer p{margin:2px 0}.stmt-customer,.stmt-table{margin-bottom:20px}.stmt-table{border-collapse:collapse;font-size:11px;width:100%}.stmt-table thead{background:#0d7a3e;color:#fff}.stmt-table th{font-size:10px;font-weight:600;letter-spacing:.3px;padding:8px;text-align:left;text-transform:uppercase}.stmt-table td{border-bottom:1px solid #e5e5e5;padding:6px 8px}.stmt-table tbody tr:nth-child(2n){background:#f9f9f9}.stmt-ref{font-family:monospace;font-size:11px;font-weight:600}.stmt-opening td{background:#f0f7f4!important;border-bottom:2px solid #0d7a3e}.stmt-totals-row td{background:#f0f7f4!important;border-top:2px solid #0d7a3e;padding-top:8px}.stmt-closing{display:flex;justify-content:flex-end;margin-bottom:30px}.stmt-balance-box{align-items:center;background:#0d7a3e;border-radius:8px;color:#fff;display:flex;font-size:14px;gap:16px;padding:14px 24px}.stmt-balance-amount{font-family:monospace;font-size:22px;font-weight:700}.access-denied{align-items:center;color:#666;display:flex;flex-direction:column;justify-content:center;min-height:60vh;text-align:center}.access-denied-icon{font-size:64px;margin-bottom:16px}.access-denied h2{color:#c0392b;margin-bottom:8px}.access-denied p{font-size:14px;margin:4px 0}@media print{.nav-container,.navigation,.no-print,.pdf-toolbar{display:none!important}body,html{background:#fff!important;margin:0!important;padding:0!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.delivery-note-wrapper,.delivery-sheet-wrapper,.invoice-pdf-wrapper,.statement-wrapper{background:#fff!important;left:0;position:absolute;top:0;width:100%}.delivery-sheet-page{box-shadow:none!important;margin:0!important;max-width:none!important;padding:10mm!important}.dds-table thead{background:#0d7a3e!important;display:table-header-group;-webkit-print-color-adjust:exact;print-color-adjust:exact}.dds-table th{color:#fff!important}.dds-table tr{page-break-inside:avoid}.dn-page,.invoice-page,.stmt-page{box-shadow:none!important;margin:0!important;max-width:none!important;padding:15mm!important}.dn-header,.inv-header,.stmt-header{border-bottom-color:#0d7a3e!important}.dn-items-table thead,.inv-items-table thead,.stmt-table thead{background:#0d7a3e!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.dn-items-table th,.inv-items-table th,.stmt-table th{color:#fff!important}.dn-items-table tbody tr:nth-child(2n),.inv-items-table tbody tr:nth-child(2n),.stmt-table tbody tr:nth-child(2n){background:#f5f5f5!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.stmt-balance-box{background:#0d7a3e!important;color:#fff!important}.stmt-balance-box,.stmt-opening td,.stmt-totals-row td{-webkit-print-color-adjust:exact;print-color-adjust:exact}.stmt-opening td,.stmt-totals-row td{background:#f0f7f4!important}@page{size:A4;margin:0}.inv-items-table{page-break-inside:auto}.inv-items-table tr{page-break-after:auto;page-break-inside:avoid}.inv-items-table thead{display:table-header-group}.inv-bank-details,.inv-footer,.inv-totals-section{page-break-inside:avoid}.main-content{margin-left:0!important;margin-right:0!important}}.invoice-page[dir=rtl]{font-family:Noto Sans Arabic,Segoe UI,Tahoma,sans-serif}.invoice-page[dir=rtl] .inv-header{flex-direction:row-reverse}.invoice-page[dir=rtl] .inv-title{text-align:left}.invoice-page[dir=rtl] .inv-company{text-align:right}.invoice-page[dir=rtl] .meta-label{padding-left:8px;padding-right:0;text-align:left}.invoice-page[dir=rtl] .inv-addresses{flex-direction:row-reverse}.invoice-page[dir=rtl] .inv-items-table th{text-align:right}.invoice-page[dir=rtl] .col-disc,.invoice-page[dir=rtl] .col-no,.invoice-page[dir=rtl] .col-uom{text-align:center}.invoice-page[dir=rtl] .col-price,.invoice-page[dir=rtl] .col-total{direction:ltr;text-align:left}.invoice-page[dir=rtl] .col-qty{direction:ltr}.invoice-page[dir=rtl] .inv-totals td:first-child{padding-left:12px;padding-right:0;text-align:left}.invoice-page[dir=rtl] .inv-totals td:last-child{direction:ltr;text-align:left}.invoice-page[dir=rtl] .inv-totals-section{flex-direction:row-reverse}.invoice-page[dir=rtl] .inv-notes{padding-left:40px;padding-right:0}.invoice-page[dir=rtl] .inv-footer{flex-direction:row-reverse}@media (max-width:768px){input,select,textarea{box-sizing:border-box;font-size:16px!important;min-height:44px;width:100%!important}.action-btn,.btn,.complete-btn,.submit-btn,.tab-btn,.toggle-btn,button{font-size:14px;min-height:44px;min-width:44px}.batch-table thead,.data-table thead{display:none}.batch-table tbody tr,.data-table tbody tr{background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 1px 3px #0000000f;display:block;margin-bottom:10px;padding:12px 14px}.batch-table tbody td,.data-table tbody td{align-items:center;border:none;display:flex;font-size:14px;justify-content:space-between;padding:4px 0}.batch-table tbody td:before,.data-table tbody td:before{color:#6b7280;content:attr(data-label);flex-shrink:0;font-size:12px;font-weight:600;margin-right:8px;text-transform:uppercase}.modal-overlay>div,[style*="min-width: 400"],[style*="minWidth: 400"]{border-radius:0!important;height:100vh!important;margin:0!important;max-height:100vh!important;max-width:100%!important;min-width:0!important;min-width:auto!important;width:100%!important}.batch-header-fields .form-row,.form-row,.form-row-2,.form-row-3{grid-template-columns:1fr!important}.sales-container,.stock-receipt-container,[style*="padding: 24px 32px"]{padding:12px!important}.wms-kpi-card{min-width:0!important;min-width:auto!important}.table-container{-webkit-overflow-scrolling:touch;overflow-x:auto}}@media (max-width:480px){.page-header{align-items:flex-start;flex-direction:column;gap:8px}.page-header h1{font-size:18px!important}.mode-toggle{width:100%}.mode-toggle .toggle-btn{flex:1 1}.tab-bar{-webkit-overflow-scrolling:touch;flex-wrap:nowrap!important;gap:4px;overflow-x:auto}.tab-btn{flex-shrink:0;white-space:nowrap}}[dir=rtl]{font-family:Noto Sans Arabic,Segoe UI,Tahoma,sans-serif}[dir=rtl] .data-table td,[dir=rtl] .data-table th{text-align:right}[dir=rtl] .data-table td.code,[dir=rtl] .data-table td.value{text-align:left}[dir=rtl] .driver-list-item{border-left:none;border-right:4px solid #e67e22}[dir=rtl] button[style*="padding-left: 36px"],[dir=rtl] button[style*="padding: 7px 12px 7px 36px"]{padding:7px 36px 7px 12px}[dir=rtl] input[type=search],[dir=rtl] input[type=text],[dir=rtl] label,[dir=rtl] textarea{text-align:right}[dir=rtl] .driver-stat-num,[dir=rtl] .receipt-qty,[dir=rtl] .value,[dir=rtl] input[type=date],[dir=rtl] input[type=number],[dir=rtl] input[type=tel]{direction:ltr;text-align:right}[dir=rtl] svg[style*="rotate(90deg)"]{transform:rotate(-90deg)}[dir=rtl] .dc-footer,[dir=rtl] .dc-header,[dir=rtl] .driver-item-row,[dir=rtl] .receipt-details,[dir=rtl] .receipt-header{flex-direction:row-reverse}[dir=rtl] .status-pill{direction:ltr}.sig-container{margin-bottom:16px}.sig-label{color:#333;display:block;font-size:13px;font-weight:600;margin-bottom:6px}.sig-canvas-wrapper{background:#fff;border:2px solid #ccc;border-radius:8px;overflow:hidden;position:relative;touch-action:none}.sig-canvas{cursor:crosshair;display:block;height:auto;width:100%}.sig-placeholder{color:#ccc;font-size:18px;left:50%;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);-webkit-user-select:none;user-select:none}.sig-buttons{display:flex;gap:8px;margin-top:8px}.sig-clear-btn{background:#eee;color:#555}.sig-clear-btn,.sig-save-btn{border:none;border-radius:6px;cursor:pointer;font-size:12px;font-weight:600;padding:7px 16px}.sig-save-btn{background:#0d7a3e;color:#fff}.sig-save-btn:disabled{cursor:not-allowed;opacity:.5}@media (max-width:480px){.sig-canvas-wrapper{max-height:180px}}.driver-app{background:#f5f5f5;font-family:-apple-system,system-ui,sans-serif;margin:0 auto;max-width:480px;min-height:100vh}.driver-header{align-items:flex-start;background:#0d7a3e;color:#fff;display:flex;justify-content:space-between;padding:16px 16px 12px;position:sticky;top:0;z-index:10}.driver-header-title{font-size:20px;font-weight:700}.driver-header-sub{font-size:12px;margin-top:2px;opacity:.8}.driver-refresh-btn{font-size:18px;padding:8px 12px}.driver-back-btn,.driver-refresh-btn{background:#fff3;border:none;border-radius:8px;color:#fff;cursor:pointer}.driver-back-btn{font-size:14px;padding:6px 14px}.driver-stats{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(4,1fr);padding:12px 16px}.driver-stat-box{background:#fff;border-bottom:3px solid #0d7a3e;border-radius:10px;box-shadow:0 1px 3px #0000000f;padding:10px 0;text-align:center}.driver-stat-num{color:#0d7a3e;font-size:22px;font-weight:700}.driver-stat-label{color:#888;font-size:10px;letter-spacing:.5px;text-transform:uppercase}.driver-list{padding:0 12px 16px}.driver-list-item{align-items:center;background:#fff;border-left:4px solid #e67e22;border-radius:12px;box-shadow:0 1px 4px #0000000f;cursor:pointer;display:flex;gap:12px;margin-bottom:10px;padding:14px}.driver-list-seq{color:#888;font-size:11px;font-weight:700;min-width:24px}.driver-list-content{flex:1 1}.driver-list-name{font-size:15px;font-weight:700;margin-bottom:2px}.driver-list-area{color:#666;font-size:12px}.driver-list-meta{color:#999;font-size:11px;margin-top:3px}.driver-status-badge{align-items:center;border-radius:8px;display:flex;flex-direction:column;font-size:14px;gap:2px;padding:6px 10px}.driver-card{background:#fff;border-radius:12px;box-shadow:0 1px 4px #0000000f;margin:12px 16px;padding:16px}.driver-card-label{color:#888;font-size:11px;font-weight:700;letter-spacing:.5px;margin-bottom:6px;text-transform:uppercase}.driver-card-title{font-size:18px;font-weight:700;margin-bottom:4px}.driver-phone-link{color:#0d7a3e;display:inline-block;font-size:14px;font-weight:600;margin-bottom:4px;text-decoration:none}.driver-address{color:#555;font-size:13px}.driver-meta{color:#888;font-size:12px}.driver-item-row{border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;padding:8px 0}.driver-item-name{font-size:14px;font-weight:500}.driver-item-qty{color:#0d7a3e;font-size:14px;font-weight:700}.driver-label{color:#444;display:block;font-size:12px;font-weight:600;margin-bottom:4px}.driver-textarea{border:1px solid #ddd;border-radius:8px;box-sizing:border-box;font-size:14px;padding:10px;resize:vertical;width:100%}.driver-gps-btn{background:#3498db;border:none;border-radius:8px;color:#fff;cursor:pointer;flex:1 1;font-size:13px;font-weight:600;padding:10px 16px}.driver-complete-btn{background:#0d7a3e;border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:16px;font-weight:700;padding:14px;width:100%}.driver-complete-btn:disabled{cursor:not-allowed;opacity:.5}.driver-close-btn{background:#666;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;padding:12px;width:100%}.driver-msg-error{background:#fce4e4;color:#c0392b}.driver-msg-error,.driver-msg-success{border-radius:8px;font-size:13px;margin:8px 16px;padding:10px 16px}.driver-msg-success{background:#e8f8e8;color:#0d7a3e}.driver-center{color:#888;padding:40px;text-align:center}@media (max-width:480px){.driver-stats{grid-template-columns:repeat(2,1fr)}.driver-stat-num{font-size:18px}}@media (max-width:768px){.driver-app{max-width:100%}.driver-complete-btn{border-radius:12px;font-size:18px;min-height:80px;padding:18px}.driver-back-btn{font-size:16px;min-height:44px;padding:12px 20px}.driver-gps-btn{font-size:15px;min-height:56px;padding:14px 18px}.driver-close-btn{font-size:16px;min-height:56px;padding:16px}.driver-refresh-btn{font-size:22px;min-height:44px;min-width:44px;padding:12px 16px}.driver-header-title{font-size:22px}.driver-header-sub{font-size:14px}.driver-card-title{font-size:20px}.driver-card-label{font-size:12px}.driver-address{font-size:15px}.driver-phone-link{display:block;font-size:16px;padding:8px 0}.driver-item-name,.driver-item-qty{font-size:16px}.driver-item-row{padding:12px 0}.driver-label{font-size:14px}.driver-textarea{font-size:16px;min-height:44px;padding:12px}.driver-meta{font-size:14px}.driver-msg-error,.driver-msg-success{font-size:15px;padding:12px 16px}.driver-list-item{margin-bottom:12px;min-height:80px;padding:16px}.driver-list-name{font-size:17px}.driver-list-area{font-size:14px}.driver-list-meta,.driver-list-seq{font-size:13px}.driver-status-badge{padding:8px 12px}.driver-status-badge span{font-size:12px}}.blp-container{margin:0 auto;max-width:900px;padding:20px 24px}.blp-title{color:#0d7a3e;margin-bottom:4px}.blp-subtitle{color:#666;font-size:13px;margin-bottom:20px}.blp-controls{align-items:center;display:flex;flex-wrap:wrap;gap:10px;margin-bottom:16px}.blp-input{min-width:200px;padding:8px 14px}.blp-input,.blp-select{border:1px solid #ddd;border-radius:8px;font-size:13px}.blp-select{padding:8px 12px}.blp-btn{border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:13px;font-weight:600;padding:8px 16px}.blp-btn-select-all{background:#3498db}.blp-btn-clear{background:#888}.blp-btn-generate{background:#0d7a3e;margin-left:auto}.blp-btn-generate:disabled{cursor:not-allowed;opacity:.5}.blp-product-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.blp-product-card{background:#fff;border:1px solid #e5e5e5;border-radius:8px;cursor:pointer;padding:10px 12px;transition:all .15s}.blp-product-card.selected{background:#f0f8f4;border:2px solid #0d7a3e}.blp-product-header{align-items:center;display:flex;justify-content:space-between}.blp-product-name{font-size:14px;font-weight:600}.blp-product-check{font-size:18px}.blp-product-sku{color:#888;font-size:11px;margin-top:2px}.blp-product-price{color:#0d7a3e;font-size:12px;font-weight:700;margin-top:2px}.blp-empty{color:#888;padding:30px;text-align:center}.blp-toolbar{background:#1a1a2e;display:flex;gap:10px;padding:12px 20px;position:sticky;top:0;z-index:10}.blp-toolbar-info{align-self:center;color:#aaa;font-size:13px}.blp-btn-print{background:#0d7a3e;font-size:14px;font-weight:600;padding:8px 20px}.blp-btn-back,.blp-btn-print{border:none;border-radius:6px;color:#fff;cursor:pointer}.blp-btn-back{background:#666;padding:8px 16px}.blp-label-grid{gap:12px;margin:0 auto;max-width:210mm;padding:20px}.blp-label-card{background:#fff;border:1px dashed #ccc;border-radius:8px;padding:12px;page-break-inside:avoid;text-align:center}.blp-label-name{font-size:11px;font-weight:700;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.blp-label-footer{color:#666;display:flex;font-size:10px;justify-content:space-between;margin-top:4px}.blp-label-price{font-weight:700}@media (max-width:768px){.blp-container{padding:16px}.blp-controls{align-items:stretch;flex-direction:column}.blp-input{min-width:0;min-width:auto;width:100%}.blp-btn-generate{margin-left:0}.blp-product-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}}
/*# sourceMappingURL=main.e990a951.css.map*/