:root{--brand-h: 199;--brand-s: 89%;--brand-l: 48%;--brand: hsl(var(--brand-h) var(--brand-s) var(--brand-l));--brand-strong: hsl(var(--brand-h) var(--brand-s) calc(var(--brand-l) - 8%));--brand-soft: hsl(var(--brand-h) var(--brand-s) var(--brand-l) / .12);--brand-soft-strong: hsl(var(--brand-h) var(--brand-s) var(--brand-l) / .22);--brand-contrast: #ffffff;--ok: #16a34a;--ok-soft: rgba(22, 163, 74, .12);--warn: #d97706;--warn-soft: rgba(217, 119, 6, .12);--danger: #dc2626;--danger-soft: rgba(220, 38, 38, .12);--r-sm: 8px;--r-md: 12px;--r-lg: 16px;--r-xl: 22px;--r-full: 999px;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .06), 0 1px 3px rgba(15, 23, 42, .08);--shadow-md: 0 4px 12px rgba(15, 23, 42, .08), 0 2px 4px rgba(15, 23, 42, .06);--shadow-lg: 0 18px 40px rgba(15, 23, 42, .14);--shadow-pop: 0 12px 28px rgba(15, 23, 42, .18);--ease: cubic-bezier(.4, 0, .2, 1);--sidebar-w: 264px;--topbar-h: 64px;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;font-feature-settings:"cv11","ss01"}:root,[data-theme=light]{color-scheme:light;--bg: #f4f6fb;--bg-grad: radial-gradient(1200px 600px at 100% -10%, hsl(var(--brand-h) 80% 95%), transparent 55%), #f4f6fb;--surface: #ffffff;--surface-2: #f8fafc;--surface-3: #f1f5f9;--surface-hover: #f1f5f9;--border: #e6eaf1;--border-strong: #d4dae6;--text: #0f172a;--text-2: #475569;--text-3: #94a3b8;--overlay: rgba(15, 23, 42, .45)}[data-theme=dark]{color-scheme:dark;--bg: #0a0e1a;--bg-grad: radial-gradient(1200px 600px at 100% -10%, hsl(var(--brand-h) 60% 14%), transparent 55%), #0a0e1a;--surface: #121829;--surface-2: #161d31;--surface-3: #1c2540;--surface-hover: #1c2540;--border: #232c45;--border-strong: #2f3a5c;--text: #eef2ff;--text-2: #a9b4d0;--text-3: #6b768f;--overlay: rgba(2, 6, 16, .6);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .4);--shadow-md: 0 6px 18px rgba(0, 0, 0, .45);--shadow-lg: 0 22px 48px rgba(0, 0, 0, .55);--shadow-pop: 0 16px 36px rgba(0, 0, 0, .6)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg-grad);background-attachment:fixed;color:var(--text);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;transition:background-color .3s var(--ease),color .3s var(--ease)}::selection{background:var(--brand-soft-strong)}*{scrollbar-width:thin;scrollbar-color:var(--border-strong) transparent}*::-webkit-scrollbar{width:10px;height:10px}*::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:var(--r-full);border:2px solid transparent;background-clip:content-box}*::-webkit-scrollbar-thumb:hover{background:var(--text-3);background-clip:content-box}h1,h2,h3,h4{margin:0;font-weight:700;letter-spacing:-.02em}a{color:inherit;text-decoration:none}button{font-family:inherit}:focus-visible{outline:2px solid var(--brand);outline-offset:2px;border-radius:var(--r-sm)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:40px;padding:0 16px;border-radius:var(--r-md);border:1px solid transparent;background:var(--surface-3);color:var(--text);font-size:14px;font-weight:600;cursor:pointer;white-space:nowrap;transition:transform .08s var(--ease),background .15s var(--ease),box-shadow .15s var(--ease),border-color .15s var(--ease),opacity .15s;-webkit-user-select:none;user-select:none}.btn:active{transform:translateY(1px) scale(.99)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn svg{width:18px;height:18px}.btn-primary{background:linear-gradient(180deg,var(--brand),var(--brand-strong));color:var(--brand-contrast);box-shadow:0 4px 14px var(--brand-soft-strong)}.btn-primary:hover:not(:disabled){box-shadow:0 6px 20px var(--brand-soft-strong);filter:brightness(1.04)}.btn-ghost{background:transparent;color:var(--text-2)}.btn-ghost:hover:not(:disabled){background:var(--surface-hover);color:var(--text)}.btn-outline{background:var(--surface);border-color:var(--border-strong)}.btn-outline:hover:not(:disabled){border-color:var(--brand);color:var(--brand)}.btn-danger{background:var(--danger-soft);color:var(--danger)}.btn-danger:hover:not(:disabled){background:var(--danger);color:#fff}.btn-lg{height:48px;padding:0 22px;font-size:15px;border-radius:var(--r-lg)}.btn-sm{height:32px;padding:0 12px;font-size:13px;gap:6px}.btn-icon{width:40px;padding:0}.btn-icon.btn-sm{width:32px}.btn-block{width:100%}.field{display:flex;flex-direction:column;gap:6px}.field-label{font-size:12.5px;font-weight:600;color:var(--text-2)}.input,.select,.textarea{width:100%;height:42px;padding:0 14px;border-radius:var(--r-md);border:1px solid var(--border-strong);background:var(--surface);color:var(--text);font-size:14px;transition:border-color .15s var(--ease),box-shadow .15s var(--ease)}.textarea{height:auto;padding:10px 14px;min-height:84px;resize:vertical}.input::placeholder{color:var(--text-3)}.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 4px var(--brand-soft)}.select{-moz-appearance:none;appearance:none;-webkit-appearance:none;padding-right:34px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpath d='M4 6l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;text-overflow:ellipsis}.input-group{position:relative;display:flex;align-items:center}.input-group>svg{position:absolute;left:12px;width:18px;height:18px;color:var(--text-3);pointer-events:none}.input-group .input{padding-left:40px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm)}.card-pad{padding:20px}.badge{display:inline-flex;align-items:center;gap:5px;height:24px;padding:0 10px;border-radius:var(--r-full);font-size:12px;font-weight:600;background:var(--surface-3);color:var(--text-2)}.badge-ok{background:var(--ok-soft);color:var(--ok)}.badge-warn{background:var(--warn-soft);color:var(--warn)}.badge-danger{background:var(--danger-soft);color:var(--danger)}.badge-brand{background:var(--brand-soft);color:var(--brand-strong)}.table-wrap{overflow-x:auto;border-radius:var(--r-lg);border:1px solid var(--border);background:var(--surface)}.table{width:100%;border-collapse:collapse;font-size:14px}.table th{text-align:left;padding:13px 16px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-3);background:var(--surface-2);border-bottom:1px solid var(--border);position:sticky;top:0}.table td{padding:13px 16px;border-bottom:1px solid var(--border);color:var(--text)}.table tbody tr:last-child td{border-bottom:none}.table tbody tr{transition:background .12s var(--ease)}.table tbody tr:hover{background:var(--surface-2)}.table .num{text-align:right;font-variant-numeric:tabular-nums}.divider{height:1px;background:var(--border);border:none;margin:0}.muted{color:var(--text-2)}.dim{color:var(--text-3)}.mono{font-variant-numeric:tabular-nums}.link{color:var(--brand)}.table.table-sm th,.table.table-sm td{padding:7px 10px;font-size:13px}.spinner{width:18px;height:18px;border:2.5px solid var(--brand-soft-strong);border-top-color:var(--brand);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.skeleton{background:linear-gradient(90deg,var(--surface-2) 25%,var(--surface-3) 37%,var(--surface-2) 63%);background-size:400% 100%;animation:shimmer 1.4s ease infinite;border-radius:var(--r-sm)}@keyframes shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}.switch{position:relative;width:44px;height:26px;border-radius:var(--r-full);background:var(--border-strong);border:none;cursor:pointer;transition:background .2s var(--ease);flex-shrink:0}.switch:after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:var(--shadow-sm);transition:transform .2s var(--ease)}.switch[data-on=true]{background:var(--brand)}.switch[data-on=true]:after{transform:translate(18px)}@keyframes fadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.animate-in{animation:fadeUp .35s var(--ease) both}.menu-pop{position:absolute;top:calc(100% + 8px);right:0;min-width:180px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-pop);padding:6px;z-index:50;animation:fadeUp .16s var(--ease) both}.menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:9px 10px;border:none;background:transparent;color:var(--text);font-size:14px;border-radius:var(--r-sm);cursor:pointer;text-align:left}.menu-item:hover{background:var(--surface-hover)}.menu-item.active{background:var(--brand-soft);color:var(--brand-strong);font-weight:600}.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:10px;padding:13px 20px;background:var(--ok);color:#fff;border-radius:var(--r-full);font-weight:600;font-size:14px;box-shadow:var(--shadow-lg);z-index:200;animation:toastIn .3s var(--ease) both}@keyframes toastIn{0%{opacity:0;transform:translate(-50%,16px)}to{opacity:1;transform:translate(-50%)}}.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:56px 20px;text-align:center;color:var(--text-3)}.empty svg{width:44px;height:44px;opacity:.5}.fab-wrap{position:fixed;right:22px;bottom:22px;z-index:60;display:flex;flex-direction:column;align-items:flex-end;gap:12px}.fab-btn{width:56px;height:56px;border-radius:50%;border:none;cursor:pointer;background:var(--brand);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px #00000038;position:relative;transition:transform .15s,box-shadow .15s}.fab-btn:hover{transform:translateY(-2px);box-shadow:0 12px 28px #00000047}.fab-btn.open{background:var(--surface-3, #334155)}.fab-badge{position:absolute;top:-3px;right:-3px;min-width:20px;height:20px;padding:0 5px;border-radius:10px;background:var(--danger);color:#fff;font-size:11.5px;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid var(--surface)}.fab-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:59;background:transparent}.fab-panel{width:320px;max-width:calc(100vw - 44px);background:var(--surface);border:1px solid var(--border);border-radius:16px;box-shadow:0 16px 44px #0000003d;overflow:hidden;animation:fabIn .14s ease-out}@keyframes fabIn{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:none}}.fab-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border)}.fab-section{padding:12px 16px}.fab-section+.fab-section{border-top:1px solid var(--border)}.fab-label{font-size:11.5px;text-transform:uppercase;letter-spacing:.04em;color:var(--text-3);margin-bottom:8px}.fab-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px}.fab-action{display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:10px;border:1px solid var(--border);background:var(--surface-2);color:var(--text);cursor:pointer;font-size:13px;font-weight:600;text-align:left;transition:background .12s,border-color .12s}.fab-action:hover{background:var(--brand-soft, var(--surface-3));border-color:var(--brand)}.fab-notes{display:flex;flex-direction:column;gap:6px}.fab-note{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;font-size:13px;width:100%;transition:background .12s}.fab-note:hover{background:var(--surface-2)}.fab-note.warn{border-left:3px solid var(--warn, #b45309)}.fab-note.danger{border-left:3px solid var(--danger)}.fab-note.info{border-left:3px solid var(--brand)}.fab-empty{display:flex;align-items:center;gap:8px;color:var(--text-3);font-size:13px;padding:6px 2px}.app-shell{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh}.sidebar{grid-row:1 / -1;display:flex;flex-direction:column;background:var(--surface);border-right:1px solid var(--border);position:sticky;top:0;height:100vh;z-index:40}.sidebar-brand{display:flex;align-items:center;gap:12px;height:var(--topbar-h);padding:0 20px;border-bottom:1px solid var(--border);flex-shrink:0}.sidebar-logo{width:38px;height:38px;border-radius:var(--r-md);background:linear-gradient(135deg,var(--brand),var(--brand-strong));display:grid;place-items:center;color:var(--brand-contrast);box-shadow:0 4px 12px var(--brand-soft-strong);flex-shrink:0}.sidebar-logo svg{width:22px;height:22px}.sidebar-brand-text{display:flex;flex-direction:column;min-width:0}.sidebar-brand-text b{font-size:15px;letter-spacing:-.02em}.sidebar-brand-text span{font-size:12px;color:var(--text-3)}.sidebar-nav{flex:1;overflow-y:auto;padding:14px 12px;display:flex;flex-direction:column;gap:4px}.nav-group-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);padding:14px 12px 6px}.nav-group-label:first-child{padding-top:4px}.nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--r-md);color:var(--text-2);font-size:14px;font-weight:500;cursor:pointer;transition:background .14s var(--ease),color .14s var(--ease);position:relative}.nav-item svg{width:19px;height:19px;flex-shrink:0}.nav-item:hover{background:var(--surface-hover);color:var(--text)}.nav-item.active{background:var(--brand-soft);color:var(--brand-strong);font-weight:600}.nav-item.active:before{content:"";position:absolute;left:-12px;top:50%;transform:translateY(-50%);width:4px;height:22px;border-radius:0 4px 4px 0;background:var(--brand)}.nav-badge{margin-left:auto;font-size:11px;font-weight:700;background:var(--brand);color:var(--brand-contrast);border-radius:var(--r-full);padding:1px 7px}.sidebar-footer{padding:12px;border-top:1px solid var(--border);flex-shrink:0}.user-card{display:flex;align-items:center;gap:10px;padding:8px;border-radius:var(--r-md)}.avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--brand),var(--brand-strong));color:var(--brand-contrast);display:grid;place-items:center;font-weight:700;font-size:14px;flex-shrink:0}.user-card-info{min-width:0;flex:1}.user-card-info b{display:block;font-size:13.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-card-info span{font-size:12px;color:var(--text-3)}.main-col{display:flex;flex-direction:column;min-width:0}.topbar{height:var(--topbar-h);display:flex;align-items:center;gap:12px;padding:0 24px;background:color-mix(in srgb,var(--surface) 80%,transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:30}.topbar h1{font-size:19px}.topbar-spacer{flex:1}.topbar-actions{display:flex;align-items:center;gap:8px}.icon-btn{width:40px;height:40px;border-radius:var(--r-md);border:1px solid var(--border);background:var(--surface);color:var(--text-2);display:grid;place-items:center;cursor:pointer;transition:all .14s var(--ease)}.icon-btn svg{width:19px;height:19px}.icon-btn:hover{color:var(--brand);border-color:var(--brand);background:var(--brand-soft)}.page{padding:24px;max-width:1440px;width:100%;margin:0 auto}.page-header{display:flex;align-items:center;flex-wrap:wrap;gap:12px;margin-bottom:20px}.page-header h2{font-size:22px}.page-header .muted{font-size:14px}.hamburger,.scrim{display:none}@media(max-width:1024px){.app-shell{grid-template-columns:1fr}.sidebar{position:fixed;left:0;top:0;width:var(--sidebar-w);transform:translate(-100%);transition:transform .28s var(--ease);box-shadow:var(--shadow-lg)}.sidebar.open{transform:translate(0)}.hamburger{display:grid}.scrim.show{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:var(--overlay);z-index:39;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}}@media(max-width:640px){.page{padding:16px}.topbar{padding:0 16px}.topbar h1{font-size:17px}}.grid{display:grid;gap:16px}.row{display:flex;gap:12px;align-items:center}.row-wrap{flex-wrap:wrap}.between{justify-content:space-between}.gap-sm{gap:8px}.flex-1{flex:1}.stack{display:flex;flex-direction:column;gap:16px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.stat-card{display:flex;align-items:center;gap:16px;padding:20px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);transition:transform .18s var(--ease),box-shadow .18s var(--ease)}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-icon{width:52px;height:52px;border-radius:var(--r-md);display:grid;place-items:center;flex-shrink:0}.stat-icon svg{width:26px;height:26px}.tone-brand{background:var(--brand-soft);color:var(--brand-strong)}.tone-ok{background:var(--ok-soft);color:var(--ok)}.tone-warn{background:var(--warn-soft);color:var(--warn)}.tone-danger{background:var(--danger-soft);color:var(--danger)}.stat-label{font-size:13px;color:var(--text-3);font-weight:500}.stat-value{font-size:24px;font-weight:700;letter-spacing:-.02em;margin-top:2px}.stat-sub{font-size:12px;color:var(--text-3);margin-top:2px}.section-title{font-size:16px;font-weight:700;margin-bottom:14px;display:flex;align-items:center;gap:8px}.dash-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:16px}@media(max-width:900px){.dash-grid{grid-template-columns:1fr}}.list-row{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--border)}.list-row:last-child{border-bottom:none}.list-row .rank{width:28px;height:28px;border-radius:var(--r-sm);display:grid;place-items:center;font-weight:700;font-size:13px;background:var(--brand-soft);color:var(--brand-strong);flex-shrink:0}.modal-scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--overlay);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:grid;place-items:start center;padding:clamp(16px,4vh,48px) 16px;overflow-y:auto;z-index:100;animation:fadeUp .18s var(--ease) both}.modal{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);max-height:calc(100vh - 96px);overflow:hidden;display:flex;flex-direction:column}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--border)}.modal-head h3{font-size:17px}.modal-body{padding:20px;overflow-y:auto;min-height:0;flex:1 1 auto}.modal-foot{display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap;padding:16px 20px;border-top:1px solid var(--border)}.login-wrap{min-height:100vh;display:grid;grid-template-columns:1fr 1fr}.login-aside{position:relative;overflow:hidden;background:linear-gradient(150deg,var(--brand-strong),var(--brand));color:#fff;padding:56px;display:flex;flex-direction:column;justify-content:space-between}.login-aside:before{content:"";position:absolute;width:480px;height:480px;border-radius:50%;background:#ffffff1f;top:-160px;right:-120px}.login-aside:after{content:"";position:absolute;width:320px;height:320px;border-radius:50%;background:#ffffff14;bottom:-100px;left:-60px}.login-aside .la-brand{display:flex;align-items:center;gap:14px;position:relative;z-index:1}.login-aside .la-logo{width:52px;height:52px;border-radius:var(--r-md);background:#ffffff2e;display:grid;place-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.login-aside .la-logo svg{width:28px;height:28px}.login-aside h1{font-size:38px;line-height:1.1;position:relative;z-index:1;max-width:460px}.login-aside p{font-size:16px;opacity:.9;position:relative;z-index:1;max-width:420px}.login-features{display:flex;flex-direction:column;gap:14px;position:relative;z-index:1}.login-feature{display:flex;align-items:center;gap:12px;font-size:15px}.login-feature .lf-dot{width:34px;height:34px;border-radius:var(--r-sm);background:#ffffff29;display:grid;place-items:center}.login-feature svg{width:18px;height:18px}.login-main{display:grid;place-items:center;padding:32px;position:relative}.login-card{width:100%;max-width:400px}.login-card h2{font-size:26px;margin-bottom:6px}.login-card .sub{color:var(--text-2);margin-bottom:28px}.login-tabs{display:flex;gap:4px;padding:4px;background:var(--surface-3);border-radius:var(--r-md);margin-bottom:22px}.login-tab{flex:1;height:38px;border:none;background:transparent;color:var(--text-2);font-weight:600;font-size:14px;border-radius:var(--r-sm);cursor:pointer;transition:all .15s var(--ease)}.login-tab.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.login-corner{position:absolute;top:20px;right:24px;display:flex;gap:8px}.login-error{background:var(--danger-soft);color:var(--danger);padding:11px 14px;border-radius:var(--r-md);font-size:13.5px;margin-bottom:16px;font-weight:500}@media(max-width:900px){.login-aside{display:none}.login-wrap{grid-template-columns:1fr}}.pin-display{display:flex;gap:12px;justify-content:center;margin:8px 0 22px}.pin-dot{width:16px;height:16px;border-radius:50%;border:2px solid var(--border-strong);transition:all .15s var(--ease)}.pin-dot.filled{background:var(--brand);border-color:var(--brand);transform:scale(1.1)}.pin-pad{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.pin-key{height:60px;border-radius:var(--r-md);border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:22px;font-weight:600;cursor:pointer;transition:all .12s var(--ease)}.pin-key:hover{background:var(--surface-hover)}.pin-key:active{transform:scale(.95);background:var(--brand-soft)}.pos-layout{display:grid;grid-template-columns:1fr 400px;gap:0;height:calc(100vh - var(--topbar-h));overflow:hidden}.pos-products{padding:20px;overflow-y:auto}.pos-toolbar{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap}.cat-chips{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.cat-chip{height:34px;padding:0 14px;border-radius:var(--r-full);border:1px solid var(--border-strong);background:var(--surface);color:var(--text-2);font-size:13px;font-weight:600;cursor:pointer;transition:all .14s var(--ease)}.cat-chip:hover{border-color:var(--brand);color:var(--brand)}.cat-chip.active{background:var(--brand);border-color:var(--brand);color:var(--brand-contrast)}.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px}.product-card{text-align:left;border:1px solid var(--border);background:var(--surface);border-radius:var(--r-lg);padding:14px;cursor:pointer;transition:all .16s var(--ease);display:flex;flex-direction:column;gap:8px;position:relative;overflow:hidden}.product-card:hover{border-color:var(--brand);transform:translateY(-3px);box-shadow:var(--shadow-md)}.product-card:active{transform:translateY(0) scale(.98)}.product-thumb{height:64px;border-radius:var(--r-md);background:linear-gradient(135deg,var(--brand-soft),var(--surface-3));display:grid;place-items:center;color:var(--brand-strong)}.product-thumb svg{width:28px;height:28px}.product-name{font-size:13.5px;font-weight:600;line-height:1.3;min-height:35px}.product-meta{display:flex;align-items:center;justify-content:space-between}.product-price{font-size:15px;font-weight:700;color:var(--brand-strong)}.product-stock{font-size:11.5px;color:var(--text-3)}.product-stock.low{color:var(--warn)}.product-stock.out{color:var(--danger)}.cart{background:var(--surface);border-left:1px solid var(--border);display:flex;flex-direction:column;height:100%}.cart-head{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.cart-head h3{font-size:16px;display:flex;align-items:center;gap:8px}.cart-customer{padding:12px 16px;border-bottom:1px solid var(--border)}.cart-items{flex:1;overflow-y:auto;padding:8px 16px}.cart-item{display:flex;flex-direction:column;gap:8px;padding:12px 0;border-bottom:1px solid var(--border)}.cart-item:last-child{border-bottom:none}.cart-item-top{display:flex;justify-content:space-between;gap:8px;align-items:start}.cart-item-name{font-size:13.5px;font-weight:600;line-height:1.3}.cart-item-sub{font-size:12px;color:var(--text-3)}.cart-item-controls{display:flex;align-items:center;gap:8px}.qty-stepper{display:flex;align-items:center;border:1px solid var(--border-strong);border-radius:var(--r-md);overflow:hidden}.qty-stepper button{width:30px;height:32px;border:none;background:var(--surface);color:var(--text);cursor:pointer;font-size:16px;display:grid;place-items:center}.qty-stepper button:hover{background:var(--surface-hover)}.qty-stepper input{width:58px;height:32px;border:none;border-left:1px solid var(--border);border-right:1px solid var(--border);text-align:center;background:var(--surface);color:var(--text);font-size:13px;font-weight:600}.cart-item-total{font-weight:700;font-size:14px}.cart-item-remove{color:var(--text-3);background:none;border:none;cursor:pointer;padding:2px}.cart-item-remove:hover{color:var(--danger)}.cart-foot{border-top:1px solid var(--border);padding:16px 20px}.cart-line{display:flex;justify-content:space-between;align-items:center;padding:5px 0;font-size:14px}.cart-line.total{font-size:20px;font-weight:800;padding-top:10px;margin-top:6px;border-top:1px dashed var(--border-strong)}.pay-methods{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:12px 0}.pay-method{height:56px;border-radius:var(--r-md);border:1.5px solid var(--border);background:var(--surface);cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;font-size:12px;font-weight:600;color:var(--text-2);transition:all .14s var(--ease)}.pay-method svg{width:18px;height:18px}.pay-method:hover{border-color:var(--brand)}.pay-method.active{border-color:var(--brand);background:var(--brand-soft);color:var(--brand-strong)}.adjust-row{display:flex;align-items:center;gap:8px;padding:8px 0}.pay-grid{display:grid;grid-template-columns:1fr 252px;gap:18px;align-items:start}.pay-summary{background:linear-gradient(160deg,var(--brand-soft),var(--surface-2));border:1px solid var(--border);border-radius:var(--r-lg);padding:16px 18px}.pay-summary .cart-line{padding:5px 0;font-size:13.5px}.pay-summary .cart-line.total{font-size:18px;border-top:1px dashed var(--border-strong);margin-top:6px}.cat-chip.sm{height:30px;padding:0 11px;font-size:12.5px}.cat-chip.ghost{background:var(--surface-2);border-style:dashed;color:var(--text-2);font-weight:600}.cat-chip.ghost:hover{border-color:var(--brand);color:var(--brand)}@media(max-width:640px){.pay-grid{grid-template-columns:1fr}}.drawer-scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--overlay);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:110;animation:fadeUp .15s var(--ease) both}.held-drawer{position:absolute;top:0;right:0;bottom:0;width:380px;max-width:92vw;background:var(--surface);border-left:1px solid var(--border);box-shadow:-16px 0 48px #0f172a2e;display:flex;flex-direction:column;animation:heldIn .22s var(--ease) both}@keyframes heldIn{0%{transform:translate(40px);opacity:.3}to{transform:none;opacity:1}}.held-drawer-head{padding:16px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;font-size:15px}.held-drawer-body{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:9px}.held-drawer-foot{padding:11px 16px;border-top:1px solid var(--border);font-size:12px}.held-card{display:flex;align-items:center;gap:11px;padding:11px 12px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface)}.held-card:hover{border-color:var(--brand)}.held-ava{width:38px;height:38px;border-radius:var(--r-md);background:var(--brand-soft);color:var(--brand-strong);display:grid;place-items:center;font-weight:700;font-size:13px;flex-shrink:0}.held-meta{flex:1;min-width:0}.held-meta b{font-size:13.5px;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.held-meta .sub{font-size:12px;color:var(--text-2)}.held-tot{font-weight:700;font-size:13.5px}.cash-tiles{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin-bottom:20px}.cash-tile{border:1px solid var(--border);border-radius:var(--r-lg);padding:15px 16px;background:var(--surface);cursor:pointer;transition:all .14s var(--ease)}.cash-tile:first-child{background:linear-gradient(160deg,var(--brand-soft),var(--surface))}.cash-tile:hover{border-color:var(--brand)}.cash-tile.active{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}.cash-tile-val{font-size:21px;font-weight:800;letter-spacing:-.01em;margin-top:4px}.cash-filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px;align-items:center}.rcpt-grid{display:grid;grid-template-columns:1fr 300px;gap:28px;align-items:start}.rcpt-upload{width:100%;border:1.5px dashed var(--border);border-radius:var(--r-md);background:var(--surface-2);color:var(--text-2);font-size:13px;padding:18px;cursor:not-allowed}.rcpt{width:260px;background:#fff;color:#16181d;font-family:Courier New,monospace;font-size:11.5px;line-height:1.55;padding:16px 14px;border-radius:4px;box-shadow:var(--shadow-lg)}.rcpt.narrow{width:200px;font-size:10.5px}.rcpt-c{text-align:center}.rcpt-big{font-size:13.5px;font-weight:700}.rcpt-hr{border-top:1px dashed #9aa1ad;margin:7px 0}.rcpt-ri{display:flex;justify-content:space-between;gap:8px}.rcpt-sub{color:#444}.rcpt-logo{width:40px;height:40px;border-radius:9px;background:var(--brand);color:#fff;display:grid;place-items:center;font-weight:800;font-size:18px;margin:0 auto 7px}.rcpt-qr{width:70px;height:70px;margin:8px auto 0;border-radius:5px;background:conic-gradient(#16181d 0,#16181d 25%,#fff 0,#fff 50%,#16181d 0,#16181d 75%,#fff 0) 0 0 / 15px 15px}@media(max-width:720px){.rcpt-grid{grid-template-columns:1fr}}.seg{display:inline-flex;padding:3px;gap:2px;background:var(--surface-3);border-radius:var(--r-md)}.seg button{border:none;background:transparent;color:var(--text-2);font-size:12.5px;font-weight:600;padding:5px 10px;border-radius:var(--r-sm);cursor:pointer;transition:all .14s var(--ease);white-space:nowrap}.seg button.on{background:var(--surface);color:var(--brand-strong);box-shadow:var(--shadow-sm)}.st-pill{display:inline-flex;align-items:center;gap:5px;height:24px;padding:0 10px;border-radius:999px;font-size:12px;font-weight:700;white-space:nowrap}.st-pill:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}.st-pill.draft{background:var(--surface-3);color:var(--text-3)}.st-pill.ordered{background:var(--brand-soft);color:var(--brand-strong)}.st-pill.transit{background:var(--warn-soft);color:var(--warn)}.st-pill.received{background:var(--ok-soft);color:var(--ok)}.st-pill.cancelled{background:var(--danger-soft);color:var(--danger)}.status-chip.active{color:var(--brand-contrast)}.status-chip.draft.active{background:var(--text-3);border-color:var(--text-3)}.status-chip.ordered.active{background:var(--brand-strong);border-color:var(--brand-strong)}.status-chip.transit.active{background:var(--warn);border-color:var(--warn)}.status-chip.received.active{background:var(--ok);border-color:var(--ok)}.form-grid-3{display:grid;grid-template-columns:2fr 1fr 1fr;gap:10px}.gap-xs{gap:6px}.gap-md{gap:16px}.select-sm{height:30px;padding:0 8px;font-size:12.5px}.btn.danger{color:var(--danger)}.btn.danger:hover:not(:disabled){background:var(--danger-soft)}@media(max-width:720px){.form-grid-3{grid-template-columns:1fr}}.purch-table{width:100%;border-collapse:collapse;font-size:12.5px}.purch-table th{text-align:left;font-size:11px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.02em;padding:4px 6px;border-bottom:1px solid var(--border)}.purch-table th.num,.purch-table td.num{text-align:right}.purch-table td{padding:5px 6px;border-bottom:1px solid var(--border);vertical-align:middle}.cell-input{height:30px;padding:0 8px;border:1px solid var(--border-strong);border-radius:var(--r-sm);background:var(--surface);color:var(--text);font-size:12.5px;outline:none}.cell-input[type=number],.input[type=number]{-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}.cell-input[type=number]::-webkit-outer-spin-button,.cell-input[type=number]::-webkit-inner-spin-button,.input[type=number]::-webkit-outer-spin-button,.input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.cell-input:focus{border-color:var(--brand)}.cell-input.num{text-align:right}.purch-table .cell-input{width:100%}select.cell-input{-moz-appearance:none;appearance:none;-webkit-appearance:none;padding-right:22px;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpath d='M3 5l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 6px center}.purch-prodname{background:none;border:none;padding:0;font:inherit;font-weight:700;color:var(--brand-strong);cursor:pointer;text-align:left}.purch-prodname:hover{text-decoration:underline}.th-unit{text-transform:none;font-weight:400;color:var(--text-3);margin-left:3px}.markup-pos{color:var(--ok);font-weight:700}.markup-neg{color:var(--danger);font-weight:700}.price-history{position:absolute;z-index:60;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-lg);padding:10px 12px;min-width:240px;font-size:12px}.price-history table{width:100%;border-collapse:collapse}.price-history td{padding:3px 4px;border-bottom:1px solid var(--border)}.expense-row{display:flex;align-items:center;gap:8px;padding:5px 0}.purch-layout{display:grid;grid-template-columns:1fr 340px;gap:18px;align-items:start}.purch-col{display:flex;flex-direction:column;gap:13px;min-width:0}.purch-summary{position:sticky;top:0;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px;display:flex;flex-direction:column;gap:2px}.purch-sline{display:flex;justify-content:space-between;align-items:baseline;gap:8px;padding:4px 0;font-size:13px}.purch-sline .k{color:var(--text-2)}.purch-sline.big{font-size:16px;font-weight:800;padding-top:8px;border-top:1px solid var(--border);margin-top:4px}.exp-card{border:1px solid var(--border);border-radius:var(--r-md);padding:8px 9px;margin-bottom:7px;background:var(--surface)}.pos-card{display:flex;align-items:center;gap:12px;border:1px solid var(--border);border-radius:var(--r-lg);padding:11px 14px;background:var(--surface)}.pos-card:hover{border-color:var(--border-strong)}.pos-main{flex:1;min-width:0}.pos-name{font-weight:700;font-size:14px}.pos-formula{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-top:7px;font-size:12.5px;color:var(--text-2)}.pos-side{text-align:right;flex-shrink:0}.pos-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:26px;color:var(--text-3);border:1px dashed var(--border);border-radius:var(--r-lg)}.purch-block{border:1px solid var(--border);border-radius:var(--r-lg);padding:12px 14px;display:flex;flex-direction:column;gap:10px;background:var(--surface)}.exp-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.exp-row .cell-input{height:32px}.purch-footer{display:flex;align-items:center;gap:10px;width:100%}.purch-foot-totals{flex:1}.pft-inner{display:inline-flex;flex-direction:column;gap:2px;min-width:240px}.pft-row{display:flex;justify-content:space-between;gap:20px;font-size:12.5px;color:var(--text-2)}.pft-row b{color:var(--text)}.pft-row.total{font-size:14px;font-weight:800;color:var(--text);border-top:1px solid var(--border);margin-top:3px;padding-top:3px}.pft-row.total b{font-size:14px}@media(max-width:900px){.purch-layout{grid-template-columns:1fr}.purch-summary{position:static}}@media(max-width:720px){.purch-table{display:block;overflow-x:auto;white-space:nowrap}}@media(max-width:1024px){.pos-layout{grid-template-columns:1fr;height:auto;overflow:visible}.cart{border-left:none;border-top:1px solid var(--border)}}.settings-grid{display:grid;grid-template-columns:240px 1fr;gap:24px;align-items:start}.settings-nav{display:flex;flex-direction:column;gap:4px;position:sticky;top:calc(var(--topbar-h) + 24px)}.settings-nav button{display:flex;align-items:center;gap:10px;padding:11px 14px;border:none;background:transparent;color:var(--text-2);border-radius:var(--r-md);font-size:14px;font-weight:500;cursor:pointer;text-align:left;width:100%}.settings-nav button svg{width:18px;height:18px}.settings-nav button:hover{background:var(--surface-hover);color:var(--text)}.settings-nav button.active{background:var(--brand-soft);color:var(--brand-strong);font-weight:600}.setting-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 0;border-bottom:1px solid var(--border)}.setting-row:last-child{border-bottom:none}.setting-row .sr-info b{display:block;font-size:14.5px}.setting-row .sr-info span{font-size:13px;color:var(--text-3)}.color-swatches{display:flex;gap:10px;flex-wrap:wrap}.color-swatch{width:38px;height:38px;border-radius:var(--r-md);cursor:pointer;border:2px solid transparent;transition:transform .12s var(--ease);position:relative}.color-swatch:hover{transform:scale(1.08)}.color-swatch.active{border-color:var(--text);box-shadow:0 0 0 2px var(--surface),0 0 0 4px var(--text)}@media(max-width:760px){.settings-grid{grid-template-columns:1fr}.settings-nav{flex-direction:row;overflow-x:auto;position:static}}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form-grid .full{grid-column:1 / -1}@media(max-width:540px){.form-grid{grid-template-columns:1fr}}.tree{font-size:14px}.tree-row{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--r-md);transition:background .12s var(--ease)}.tree-row:hover{background:var(--surface-2)}.tree-row .tw-toggle{width:20px;display:grid;place-items:center;color:var(--text-3);cursor:pointer}.tree-row .tw-icon{width:30px;height:30px;border-radius:var(--r-sm);display:grid;place-items:center;background:var(--brand-soft);color:var(--brand-strong);flex-shrink:0}.tree-row .tw-label{font-weight:600}.tree-row .tw-count{font-size:12px;color:var(--text-3)}.tree-row .tw-add{margin-left:auto;opacity:0;transition:opacity .12s}.tree-row:hover .tw-add{opacity:1}.tree-children{margin-left:22px;padding-left:12px;border-left:1px dashed var(--border-strong)}.chip-row{display:flex;flex-wrap:wrap;gap:8px;padding:6px 0 6px 42px}.org-chip{display:inline-flex;align-items:center;gap:7px;height:32px;padding:0 10px 0 8px;border-radius:var(--r-full);border:1px solid var(--border);background:var(--surface);cursor:pointer;font-size:13px;font-weight:600;transition:all .14s var(--ease)}.org-chip:hover{border-color:var(--brand)}.org-chip .dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.org-chip .dot.on{background:var(--ok)}.org-chip .dot.off{background:var(--text-3)}.org-chip.muted-chip{opacity:.6}.org-chip.locked{cursor:default;border-style:dashed}.bar{height:8px;border-radius:var(--r-full);background:var(--surface-3);overflow:hidden}.bar>span{display:block;height:100%;border-radius:var(--r-full);background:var(--brand)}.weigh-board{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:14px}.weigh-tk{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:14px 15px 13px;position:relative;overflow:hidden}.weigh-tk:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--border)}.weigh-tk.s-info:before{background:var(--info, #2563eb)}.weigh-tk.s-warn:before{background:var(--warn)}.weigh-tk.s-ok:before{background:var(--ok)}.weigh-tk.s-muted{opacity:.72}.wtk-top{display:flex;align-items:flex-start;gap:10px;margin-bottom:11px}.wplate{font-size:17px;font-weight:800;letter-spacing:.02em;font-variant-numeric:tabular-nums;background:var(--surface-3);border:1px solid var(--border);border-radius:var(--r-sm);padding:3px 9px;white-space:nowrap}.wcp{font-size:13.5px;font-weight:700}.wdir{font-size:10px;font-weight:700;padding:3px 8px;border-radius:99px;text-transform:uppercase;letter-spacing:.03em;white-space:nowrap}.wdir.out{background:var(--brand-soft);color:var(--brand-strong)}.wdir.in{background:var(--info-soft, rgba(37,99,235,.12));color:var(--info, #2563eb)}.wgrid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;margin-bottom:11px}.wgrid .wc{background:var(--surface-2);padding:8px 6px;text-align:center}.wgrid .wc .k{font-size:10px;color:var(--text-3);font-weight:600;text-transform:uppercase;letter-spacing:.03em}.wgrid .wc .v{font-size:15px;font-weight:800;font-variant-numeric:tabular-nums;margin-top:2px}.wgrid .wc .v.muted{color:#cbd5e1}.wgrid .wc.net{background:var(--brand-soft)}.wgrid .wc.net .v{color:var(--brand-strong)}.wstage{display:flex;align-items:center;gap:3px;margin-bottom:12px;font-size:10px;color:var(--text-3);flex-wrap:wrap}.wst{display:inline-flex;align-items:center;gap:4px;font-weight:600}.wst .b{width:15px;height:15px;border-radius:50%;border:1.5px solid var(--border);display:grid;place-items:center;font-size:8.5px}.wst.done{color:var(--ok)}.wst.done .b{background:var(--ok);border-color:var(--ok);color:#fff}.wst.now{color:var(--brand-strong)}.wst.now .b{border-color:var(--brand);color:var(--brand)}.wst:not(:last-child):after{content:"·";margin-left:3px;color:var(--border)}.wtk-foot{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.wgl{display:grid;grid-template-columns:1.3fr .8fr 1.15fr 1.1fr .7fr 34px;gap:10px;padding:9px 12px;align-items:center;border-bottom:1px solid var(--border)}.wgl:last-of-type{border-bottom:none}.wgl-h{background:var(--surface-3);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:var(--text-3)}.wgl .r{text-align:right}.wgl .input,.wgl .select{height:38px}.wgl .num{text-align:right;font-variant-numeric:tabular-nums}
