:root{--brand-500: hsl(189, 90%, 35%);--brand-600: hsl(189, 95%, 25%);--brand-900: hsl(189, 100%, 8%);--primary: var(--brand-500);--primary-hover: var(--brand-600);--primary-fg: #ffffff;--primary-subtle: hsl(189, 100%, 98%);--primary-soft: hsl(189, 50%, 94%);--primary-ring: hsl(189, 90%, 35% / .28);--bg: hsl(0, 0%, 100%);--bg-muted: hsl(189, 22%, 98%);--bg-subtle: hsl(189, 18%, 96%);--bg-app: hsl(189, 14%, 97%);--card: #ffffff;--border: hsl(189, 18%, 90%);--border-strong:hsl(189, 16%, 82%);--border-soft: hsl(189, 18%, 94%);--fg: hsl(189, 32%, 12%);--fg-strong: hsl(189, 40%, 8%);--fg-muted: hsl(189, 10%, 38%);--fg-subtle: hsl(189, 8%, 54%);--success: hsl(142, 65%, 36%);--success-bg: hsl(142, 55%, 96%);--warning: hsl(38, 92%, 45%);--warning-bg: hsl(38, 92%, 96%);--danger: hsl(0, 70%, 48%);--danger-bg: hsl(0, 80%, 97%);--info: hsl(212, 80%, 48%);--info-bg: hsl(212, 90%, 97%);--radius-xs: .25rem;--radius-sm: .375rem;--radius: .5rem;--radius-lg: .625rem;--radius-xl: .875rem;--shadow-xs: 0 1px 0 0 rgb(0 35 41 / .04);--shadow-sm: 0 1px 2px 0 rgb(0 35 41 / .06);--shadow-md: 0 2px 6px -2px rgb(0 35 41 / .1), 0 1px 2px 0 rgb(0 35 41 / .04);--shadow-lg: 0 8px 20px -8px rgb(0 35 41 / .18), 0 2px 6px -2px rgb(0 35 41 / .06);--shadow-xl: 0 16px 40px -12px rgb(0 35 41 / .22);--h-control: 36px;--h-control-lg: 40px;--topbar-h: 56px;--subbar-h: 44px;--bottombar-h: 44px;--cart-w: 380px;--font-sans: "Inter", "Poppins", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, "SFMono-Regular", Menlo, Consolas, monospace;--ease: cubic-bezier(.22, 1, .36, 1);--t-fast: .12s;--t: .18s}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:Poppins,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-size:13px;font-weight:400;color:var(--fg);background:var(--bg-app);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow:hidden;font-feature-settings:"cv11","ss01"}button{font-family:inherit;cursor:pointer}input,select,textarea{font-family:inherit;color:inherit}.mono{font-family:var(--font-mono);font-feature-settings:"ss01"}.num{font-variant-numeric:tabular-nums}.pos{display:grid;grid-template-columns:1fr var(--cart-w);grid-template-rows:var(--topbar-h) var(--subbar-h) 1fr var(--bottombar-h);grid-template-areas:"topbar    cart" "sessbar   cart" "main      cart" "bottom    cart";height:100vh;background:var(--bg-app)}.topbar{grid-area:topbar;display:flex;align-items:center;gap:12px;padding:0 16px;background:var(--bg);border-bottom:1px solid var(--border);z-index:5}.brand{display:flex;align-items:center;gap:10px;padding-right:14px;border-right:1px solid var(--border);height:100%}.brand-mark{width:60px;height:60px;display:grid;place-items:center;position:relative;flex-shrink:0}.brand-mark img{width:100%;height:100%;-o-object-fit:contain;object-fit:contain;display:block}.brand-text{line-height:1.15}.brand-text strong{display:block;font-weight:600;font-size:13px;color:var(--fg-strong);letter-spacing:-.01em}.brand-text small{font-size:10.5px;color:var(--fg-muted);font-family:var(--font-mono)}.search{flex:1;max-width:540px;position:relative}.search input{width:100%;height:36px;padding:0 80px 0 36px;border-radius:var(--radius-sm);border:1px solid var(--border-strong);background:var(--bg);font-size:13px;color:var(--fg);transition:border-color var(--t),box-shadow var(--t)}.search input::-moz-placeholder{color:var(--fg-subtle)}.search input::placeholder{color:var(--fg-subtle)}.search input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-ring)}.search-icon,.search-scan,.search-kbd{position:absolute;top:50%;transform:translateY(-50%);display:flex;align-items:center}.search-icon{left:11px;color:var(--fg-subtle);pointer-events:none}.search-kbd{right:66px;font-family:var(--font-mono);font-size:10px;color:var(--fg-subtle);background:var(--bg-muted);padding:2px 5px;border-radius:var(--radius-xs);border:1px solid var(--border);pointer-events:none}.search-scan{right:4px;width:28px;height:28px;border:none;border-radius:var(--radius-xs);background:transparent;color:var(--primary);display:grid;place-items:center;transition:background var(--t)}.search-scan:hover{background:var(--primary-soft)}.topbar-right{display:flex;align-items:center;gap:8px;margin-left:auto;height:100%}.kbd{font-family:var(--font-mono);font-size:10.5px;font-weight:600;color:var(--fg-muted);background:var(--bg);padding:2px 6px;border-radius:var(--radius-xs);border:1px solid var(--border-strong);border-bottom-width:2px;line-height:1}.icon-btn{width:32px;height:32px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg);color:var(--fg-muted);display:grid;place-items:center;transition:all var(--t);position:relative}.icon-btn:hover{color:var(--primary);border-color:var(--primary);background:var(--primary-subtle)}.icon-btn:active{transform:scale(.96)}.icon-btn .badge{position:absolute;top:-4px;right:-4px;min-width:16px;height:16px;padding:0 4px;border-radius:999px;background:var(--danger);color:#fff;font-size:9.5px;font-weight:600;display:grid;place-items:center;line-height:1;border:1.5px solid var(--bg)}.user-chip{display:flex;align-items:center;gap:8px;padding:2px 8px 2px 2px;border-radius:var(--radius-sm);background:transparent;border:1px solid var(--border);cursor:pointer;transition:background var(--t);height:32px}.user-chip:hover{background:var(--bg-muted)}.avatar{width:26px;height:26px;border-radius:var(--radius-xs);background:linear-gradient(135deg,var(--primary),var(--brand-900));color:#fff;display:grid;place-items:center;font-weight:600;font-size:11px;letter-spacing:-.02em}.avatar.lg{width:40px;height:40px;border-radius:var(--radius-sm);font-size:14px}.user-chip .meta{line-height:1.15;text-align:left}.user-chip .meta strong{display:block;font-size:12px;font-weight:600;color:var(--fg)}.user-chip .meta small{font-size:10px;color:var(--fg-muted)}.sessbar{grid-area:sessbar;display:flex;align-items:center;gap:10px;padding:0 16px;background:var(--bg);border-bottom:1px solid var(--border)}.crumbs{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--fg-muted)}.crumbs .sep{color:var(--fg-subtle)}.crumbs .cur{color:var(--fg-strong);font-weight:500}.sess-stats{margin-left:auto;display:flex;align-items:center;gap:4px;height:100%}.sess-stat{display:flex;align-items:center;gap:8px;padding:0 12px;height:100%;border-left:1px solid var(--border);font-size:12px}.sess-stat:last-child{border-right:1px solid var(--border)}.sess-stat .lbl{color:var(--fg-muted);font-size:10.5px;text-transform:uppercase;letter-spacing:.05em;font-weight:600}.sess-stat .val{font-weight:600;color:var(--fg-strong);font-variant-numeric:tabular-nums}.sess-stat.live .val{color:var(--success)}.sess-stat.live .lbl:before{content:"";display:inline-block;width:5px;height:5px;border-radius:50%;background:var(--success);margin-right:5px;animation:pulse 1.6s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.catbar{display:flex;gap:4px;padding:8px 16px;background:var(--bg);border-bottom:1px solid var(--border);overflow-x:auto;scrollbar-width:thin;scrollbar-color:var(--border-strong) transparent}.catbar::-webkit-scrollbar{height:4px}.catbar::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:999px}.cat-pill{display:inline-flex;align-items:center;gap:6px;height:30px;padding:0 10px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg);color:var(--fg-muted);font-size:12px;font-weight:500;white-space:nowrap;transition:all var(--t-fast)}.cat-pill:hover{border-color:var(--border-strong);color:var(--fg);background:var(--bg-muted)}.cat-pill.active{background:var(--brand-900);color:#fff;border-color:var(--brand-900)}.cat-pill .count{display:inline-grid;place-items:center;min-width:18px;height:16px;padding:0 4px;border-radius:var(--radius-xs);background:var(--bg-subtle);color:var(--fg-muted);font-size:10px;font-weight:600;font-variant-numeric:tabular-nums}.cat-pill.active .count{background:#ffffff26;color:#fff}.main{grid-area:main;overflow:hidden;display:flex;flex-direction:column;min-width:0}.main-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px 4px;gap:12px}.main-header h2{margin:0;font-size:14px;font-weight:600;color:var(--fg-strong);letter-spacing:-.01em;display:flex;align-items:center;gap:8px}.main-header h2 .count{font-size:11px;font-weight:500;color:var(--fg-muted);background:var(--bg-muted);border:1px solid var(--border);padding:2px 7px;border-radius:999px;font-variant-numeric:tabular-nums}.main-header .right{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--fg-muted)}.main-header .sort{display:inline-flex;align-items:center;gap:6px;height:28px;padding:0 10px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:12px;color:var(--fg)}.grid{flex:1;overflow-y:auto;padding:6px 16px 16px;display:grid;gap:10px;grid-template-columns:repeat(var(--cols, 5),minmax(0,1fr));align-content:start}.grid::-webkit-scrollbar{width:8px}.grid::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:999px}.grid::-webkit-scrollbar-track{background:transparent}.card{position:relative;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:8px;display:flex;flex-direction:column;cursor:pointer;transition:border-color var(--t-fast),box-shadow var(--t-fast),transform var(--t-fast)}.card:hover{border-color:var(--primary);box-shadow:var(--shadow-sm)}.card:active{transform:scale(.995)}.card-img{position:relative;aspect-ratio:4 / 3;border-radius:var(--radius-sm);margin-bottom:8px;display:grid;place-items:center;overflow:hidden;border:1px solid var(--border-soft)}.card-img.placeholder{background:repeating-linear-gradient(135deg,#f3f6f7 0,#f3f6f7 6px,#edf2f2 6px,#edf2f2 12px);color:var(--fg-subtle)}.card-img .ph-sku{font-family:var(--font-mono);font-size:10px;font-weight:600;color:var(--fg-muted);background:#fff;padding:2px 8px;border-radius:var(--radius-xs);border:1px solid var(--border);letter-spacing:.02em}.card-img img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.stock-pill{position:absolute;top:6px;left:6px;display:inline-flex;align-items:center;gap:4px;padding:2px 6px;border-radius:var(--radius-xs);background:#fff;border:1px solid var(--border);font-family:var(--font-mono);font-size:9.5px;font-weight:600;letter-spacing:.02em;color:var(--fg-muted)}.stock-pill .dot{width:5px;height:5px;border-radius:50%;background:var(--success)}.stock-pill.ok{color:#1c5431}.stock-pill.low{color:#794415}.stock-pill.low .dot{background:var(--warning)}.stock-pill.out{color:#932525;background:var(--danger-bg);border-color:#f7d4d4}.stock-pill.out .dot{background:var(--danger)}.card-brand{font-size:10px;font-weight:600;color:var(--fg-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:2px}.card-name{font-size:12.5px;font-weight:500;color:var(--fg);line-height:1.35;margin:0 0 4px;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;min-height:2.7em;letter-spacing:-.005em}.card-meta-row{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-size:10.5px;color:var(--fg-subtle);font-family:var(--font-mono)}.card-meta-row .sep{color:var(--border-strong)}.card-foot{display:flex;align-items:center;justify-content:space-between;margin-top:auto;gap:8px}.card-price{display:flex;flex-direction:column;line-height:1.05}.card-price .now{font-size:14px;font-weight:700;color:var(--fg-strong);letter-spacing:-.02em;font-variant-numeric:tabular-nums}.card-price .now small{font-size:10px;font-weight:500;color:var(--fg-muted);margin-right:1px}.card-price .was{font-size:10px;color:var(--fg-subtle);text-decoration:line-through;margin-top:1px}.qty-add{width:28px;height:28px;border-radius:var(--radius-sm);border:1px solid var(--border-strong);background:var(--bg);color:var(--fg);display:grid;place-items:center;transition:all var(--t-fast)}.card:hover .qty-add{background:var(--primary);color:#fff;border-color:var(--primary)}.card.in-cart .qty-add{background:var(--brand-900);color:#fff;border-color:var(--brand-900)}.card.in-cart{border-color:var(--primary);background:linear-gradient(0deg,var(--primary-subtle),white)}.card .in-cart-badge{position:absolute;top:-6px;right:-6px;min-width:18px;height:18px;padding:0 5px;border-radius:var(--radius-xs);background:var(--primary);color:#fff;font-size:10px;font-weight:700;display:grid;place-items:center;font-variant-numeric:tabular-nums}.card.out{opacity:.6}.card.out .qty-add{background:var(--bg-muted);color:var(--fg-subtle);border-color:var(--border);pointer-events:none}.bottom{grid-area:bottom;display:flex;align-items:center;gap:4px;padding:0 12px;background:var(--bg);border-top:1px solid var(--border)}.bottom-btn{display:inline-flex;align-items:center;gap:6px;height:30px;padding:0 10px;border-radius:var(--radius-sm);border:1px solid transparent;background:transparent;color:var(--fg-muted);font-size:12px;font-weight:500;transition:all var(--t-fast)}.bottom-btn:hover{color:var(--primary);background:var(--primary-subtle)}.bottom-btn.danger:hover{color:var(--danger);background:var(--danger-bg)}.bottom-btn .num{min-width:16px;height:16px;padding:0 4px;border-radius:var(--radius-xs);background:var(--bg-subtle);color:var(--fg-muted);font-size:10px;font-weight:700;display:inline-grid;place-items:center;font-variant-numeric:tabular-nums}.bottom-divider{width:1px;height:16px;background:var(--border);margin:0 4px}.bottom-right{margin-left:auto;display:flex;align-items:center;gap:6px;font-size:11px;color:var(--fg-subtle);font-family:var(--font-mono)}.cart{grid-area:cart;display:flex;flex-direction:column;background:var(--bg);border-left:1px solid var(--border);min-height:0}.cart-header{padding:12px 14px 10px;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:8px}.cart-header-row{display:flex;align-items:center;justify-content:space-between}.cart-header h3{margin:0;font-size:13px;font-weight:600;color:var(--fg-strong);letter-spacing:-.005em}.cart-header h3 .badge{display:inline-flex;align-items:center;height:16px;padding:0 6px;background:var(--bg-muted);border:1px solid var(--border);border-radius:var(--radius-xs);margin-left:6px;font-size:10px;font-weight:500;color:var(--fg-muted);font-family:var(--font-mono);vertical-align:1px}.cart-order-meta{font-size:11px;color:var(--fg-muted);font-family:var(--font-mono)}.cart-tabs{display:flex;gap:0;border-radius:var(--radius-sm);background:var(--bg-muted);border:1px solid var(--border);padding:2px}.cart-tabs button{flex:1;height:24px;background:transparent;border:none;border-radius:var(--radius-xs);font-size:11px;font-weight:500;color:var(--fg-muted);transition:all var(--t-fast)}.cart-tabs button.active{background:#fff;color:var(--fg-strong);box-shadow:var(--shadow-xs)}.cust-row{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--bg-muted);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--t-fast);color:var(--fg-muted);font-size:12px;width:100%;text-align:left}.cust-row:hover{border-color:var(--primary);background:var(--primary-subtle);color:var(--primary)}.cust-row.set{background:var(--primary-subtle);border-color:var(--primary);color:var(--fg)}.cust-row .av{width:24px;height:24px;border-radius:50%;background:var(--primary);color:#fff;display:grid;place-items:center;font-size:10px;font-weight:600}.cust-row .body{flex:1;min-width:0;line-height:1.25}.cust-row .body strong{display:block;font-size:12px;font-weight:600;color:var(--fg-strong);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cust-row .body small{font-size:10.5px;color:var(--fg-muted);font-family:var(--font-mono)}.cust-row .pts{display:inline-flex;align-items:center;gap:4px;padding:2px 6px;background:#fff;border:1px solid var(--border);border-radius:var(--radius-xs);color:var(--warning);font-size:10px;font-weight:600;font-family:var(--font-mono)}.cart-items{flex:1;overflow-y:auto;padding:4px 0}.cart-items::-webkit-scrollbar{width:6px}.cart-items::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:999px}.cart-empty{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:var(--fg-subtle);padding:24px;gap:10px}.cart-empty .icon-wrap{width:48px;height:48px;border-radius:var(--radius);background:var(--bg-muted);border:1px solid var(--border);color:var(--fg-muted);display:grid;place-items:center}.cart-empty h4{margin:0;font-size:13px;color:var(--fg-strong);font-weight:600}.cart-empty p{margin:0;font-size:11.5px;max-width:220px;line-height:1.5}.cart-empty .hint{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:var(--fg-muted);background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-xs);padding:4px 8px;margin-top:4px}.cart-item{display:grid;grid-template-columns:36px 1fr auto;gap:10px;padding:8px 14px;align-items:center;transition:background var(--t-fast);animation:slideIn .22s var(--ease);border-bottom:1px solid var(--border-soft)}.cart-item:hover{background:var(--bg-muted)}@keyframes slideIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.ci-thumb{width:36px;height:36px;border-radius:var(--radius-xs);background:repeating-linear-gradient(135deg,#f3f6f7 0,#f3f6f7 5px,#e7edee 5px,#e7edee 10px);border:1px solid var(--border-soft);display:grid;place-items:center;font-family:var(--font-mono);font-size:8.5px;font-weight:600;color:var(--fg-muted);flex-shrink:0;overflow:hidden}.ci-thumb img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.ci-body{min-width:0;line-height:1.3}.ci-name{font-size:12.5px;font-weight:500;color:var(--fg);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ci-sub{display:flex;align-items:center;gap:6px;margin-top:2px;font-size:10.5px;color:var(--fg-muted);font-family:var(--font-mono)}.ci-sub .pricex{color:var(--fg-muted)}.ci-right{display:flex;flex-direction:column;align-items:flex-end;gap:6px}.qty-stepper{display:inline-flex;align-items:center;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);height:24px;overflow:hidden}.qty-stepper button{width:22px;height:100%;border:none;background:transparent;color:var(--fg-muted);display:grid;place-items:center;transition:all var(--t-fast)}.qty-stepper button:hover{background:var(--primary-soft);color:var(--primary)}.qty-stepper .qty{min-width:24px;text-align:center;font-size:12px;font-weight:600;color:var(--fg);font-variant-numeric:tabular-nums;border-left:1px solid var(--border);border-right:1px solid var(--border);height:100%;display:grid;place-items:center}.ci-subtotal{font-size:12.5px;font-weight:600;color:var(--fg-strong);font-variant-numeric:tabular-nums}.ci-remove{width:18px;height:18px;border-radius:var(--radius-xs);border:none;background:transparent;color:var(--fg-subtle);display:grid;place-items:center;transition:all var(--t-fast)}.ci-remove:hover{background:var(--danger-bg);color:var(--danger)}.cart-totals{border-top:1px solid var(--border);padding:10px 14px 6px;background:var(--bg)}.tot-row{display:flex;justify-content:space-between;align-items:center;padding:3px 0;font-size:12px;color:var(--fg-muted);font-variant-numeric:tabular-nums}.tot-row .lbl{display:flex;align-items:center;gap:5px}.tot-row .lbl-link{display:flex;align-items:center;gap:5px;background:none;border:none;color:var(--primary);font-size:12px;font-weight:500;padding:2px 0;cursor:pointer}.tot-row .lbl-link:hover{text-decoration:underline}.tot-row.disc .lbl{color:var(--success)}.tot-row.disc .val{color:var(--success);font-weight:500}.tot-row.grand{margin-top:4px;padding-top:8px;border-top:1px solid var(--border);font-size:13px;color:var(--fg-strong);font-weight:600}.tot-row.grand .val{color:var(--brand-900);font-size:20px;letter-spacing:-.02em;font-weight:700}.cart-actions{display:grid;gap:6px;padding:8px 14px 14px;background:var(--bg);border-top:1px solid var(--border)}.cart-actions .row{display:grid;grid-template-columns:1fr 1fr;gap:6px}.btn{height:36px;border:1px solid transparent;border-radius:var(--radius-sm);font-size:12.5px;font-weight:600;display:inline-flex;align-items:center;justify-content:center;gap:6px;transition:all var(--t-fast);letter-spacing:0;padding:0 14px}.btn:active{transform:scale(.985)}.btn:disabled{opacity:.5;pointer-events:none}.btn-primary{background:var(--primary);color:var(--primary-fg);border-color:var(--primary)}.btn-primary:hover{background:var(--primary-hover);border-color:var(--primary-hover)}.btn-dark{background:var(--brand-900);color:#fff;border-color:var(--brand-900)}.btn-dark:hover{background:#003d47}.btn-pay{height:46px;font-size:13px;display:grid;grid-template-columns:auto 1fr auto;align-items:center;padding:0 16px;gap:12px}.btn-pay .label{text-align:left;font-weight:600}.btn-pay .amt{font-size:16px;font-weight:700;letter-spacing:-.01em;text-align:right;font-variant-numeric:tabular-nums}.btn-pay .kbd-light{background:#ffffff26;border-color:#ffffff40;color:#fff}.btn-secondary{background:var(--bg);border:1px solid var(--border-strong);color:var(--fg)}.btn-secondary:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-subtle)}.btn-outline{background:var(--bg);border:1px solid var(--border);color:var(--fg-muted)}.btn-outline:hover{color:var(--fg);border-color:var(--border-strong);background:var(--bg-muted)}.btn-ghost{background:transparent;color:var(--fg-muted);height:28px;font-size:11.5px;font-weight:500;border:none}.btn-ghost:hover{color:var(--danger)}.btn-sm{height:28px;font-size:11.5px;padding:0 10px}.btn-lg{height:44px;font-size:13.5px;padding:0 18px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00232980;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);z-index:100;display:grid;place-items:center;padding:24px;animation:fadeIn .16s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);border:1px solid var(--border);width:100%;max-width:520px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:pop .2s var(--ease)}@keyframes pop{0%{opacity:0;transform:scale(.97) translateY(6px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal.wide{max-width:680px}.modal.xl{max-width:880px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border)}.modal-header h3{margin:0;font-size:14px;font-weight:600;color:var(--fg-strong);letter-spacing:-.005em;display:flex;align-items:center;gap:8px}.modal-header h3 .id{font-family:var(--font-mono);font-size:11px;font-weight:500;color:var(--fg-muted);background:var(--bg-muted);padding:2px 6px;border-radius:var(--radius-xs)}.modal-header p{margin:3px 0 0;font-size:12px;color:var(--fg-muted)}.modal-close{width:26px;height:26px;border-radius:var(--radius-sm);border:none;background:transparent;color:var(--fg-muted);display:grid;place-items:center;transition:all var(--t-fast)}.modal-close:hover{background:var(--bg-muted);color:var(--fg)}.modal-body{padding:16px 18px;overflow-y:auto}.modal-foot{display:flex;gap:8px;justify-content:flex-end;align-items:center;padding:12px 18px;border-top:1px solid var(--border);background:var(--bg-muted)}.modal-foot .left{margin-right:auto;font-size:11px;color:var(--fg-muted);display:flex;align-items:center;gap:6px}.field{display:grid;gap:4px;margin-bottom:12px}.field>label,.label{font-size:11px;font-weight:600;color:var(--fg-muted);text-transform:uppercase;letter-spacing:.04em}.field input,.field select,.field textarea{height:36px;padding:0 10px;border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--bg);font-size:13px;transition:all var(--t-fast)}.field textarea{padding:8px 10px;height:auto;min-height:70px;resize:vertical}.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-ring)}.field .hint{font-size:11px;color:var(--fg-subtle)}.seg{display:inline-flex;padding:2px;border-radius:var(--radius-sm);background:var(--bg-muted);border:1px solid var(--border);gap:1px}.seg button{padding:6px 12px;border:none;background:transparent;border-radius:var(--radius-xs);font-size:12px;font-weight:500;color:var(--fg-muted);transition:all var(--t-fast)}.seg button.active{background:var(--bg);color:var(--fg-strong);box-shadow:var(--shadow-xs)}.chip{display:inline-flex;align-items:center;gap:4px;padding:2px 7px;border-radius:var(--radius-xs);font-size:10.5px;font-weight:600;border:1px solid;letter-spacing:.02em}.chip .dot{width:5px;height:5px;border-radius:50%}.chip.success{background:var(--success-bg);border-color:#c6ecd4;color:#1c5431}.chip.success .dot{background:var(--success)}.chip.warn{background:var(--warning-bg);border-color:#f7e1ba;color:#794415}.chip.warn .dot{background:var(--warning)}.chip.danger{background:var(--danger-bg);border-color:#f7d4d4;color:#932525}.chip.danger .dot{background:var(--danger)}.chip.info{background:var(--info-bg);border-color:#cbdff6;color:#224a77}.chip.info .dot{background:var(--info)}.chip.neutral{background:var(--bg-muted);border-color:var(--border);color:var(--fg-muted)}.chip.neutral .dot{background:var(--fg-subtle)}.chip.brand{background:var(--primary-subtle);border-color:#c6e6ec;color:var(--brand-900)}.chip.brand .dot{background:var(--primary)}.dt{width:100%;border-collapse:separate;border-spacing:0;font-size:12px}.dt th,.dt td{padding:8px 10px;text-align:left;border-bottom:1px solid var(--border)}.dt thead th{background:var(--bg-muted);font-size:10.5px;font-weight:600;color:var(--fg-muted);text-transform:uppercase;letter-spacing:.04em;border-top:1px solid var(--border);position:sticky;top:0}.dt thead th:first-child{border-top-left-radius:var(--radius-sm)}.dt thead th:last-child{border-top-right-radius:var(--radius-sm)}.dt tbody tr:hover{background:var(--bg-muted)}.dt .num,.dt td.num{font-variant-numeric:tabular-nums}.dt .sku{font-family:var(--font-mono);font-size:11px;color:var(--fg-muted)}.dt .check{width:14px;height:14px;border:1px solid var(--border-strong);border-radius:var(--radius-xs);display:inline-grid;place-items:center;background:var(--bg);transition:all var(--t-fast)}.dt .check.on{background:var(--primary);border-color:var(--primary);color:#fff}.dt tr.sel td{background:var(--primary-subtle)}.dt tr.sel:hover td{background:var(--primary-soft)}.pay-methods{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:14px}.pay-method{padding:12px 10px;border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--bg);text-align:center;cursor:pointer;transition:all var(--t-fast);display:flex;flex-direction:column;align-items:center;gap:6px;position:relative}.pay-method:hover,.pay-method.active{border-color:var(--primary);background:var(--primary-subtle)}.pay-method.active:before{content:"";position:absolute;top:-1px;right:-1px;bottom:-1px;left:-1px;border-radius:var(--radius-sm);border:1px solid var(--primary);pointer-events:none}.pay-method .icon{width:32px;height:32px;border-radius:var(--radius-xs);background:var(--bg-muted);color:var(--fg-muted);display:grid;place-items:center}.pay-method.active .icon{background:var(--primary);color:#fff}.pay-method .label{font-size:12px;font-weight:500;color:var(--fg)}.pay-method .kbd-mini{position:absolute;top:6px;right:6px;font-family:var(--font-mono);font-size:9px;color:var(--fg-subtle);background:var(--bg);padding:1px 4px;border-radius:var(--radius-xs);border:1px solid var(--border)}.pay-amount-display{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;border-radius:var(--radius-sm);background:var(--brand-900);color:#fff;margin-bottom:14px}.pay-amount-display .label{font-size:11px;opacity:.7;text-transform:uppercase;letter-spacing:.06em;font-weight:600}.pay-amount-display .value{font-size:26px;font-weight:700;letter-spacing:-.02em;font-variant-numeric:tabular-nums}.cash-input{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}.cash-input .field{margin-bottom:0}.cash-input .change{padding:10px 12px;border-radius:var(--radius-sm);background:var(--success-bg);border:1px solid hsl(142,60%,85%)}.cash-input .change .label{font-size:10px;color:#246b3e;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.cash-input .change .value{font-size:20px;font-weight:700;color:#1f5c35;margin-top:2px;font-variant-numeric:tabular-nums;letter-spacing:-.02em}.cash-input .change.neg{background:var(--danger-bg);border-color:#f6cbcb}.cash-input .change.neg .label{color:#932525}.cash-input .change.neg .value{color:var(--danger)}.denoms{display:grid;grid-template-columns:repeat(6,1fr);gap:6px}.denom{padding:8px 0;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);font-size:12px;font-weight:600;color:var(--fg);font-variant-numeric:tabular-nums;transition:all var(--t-fast)}.denom:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-subtle)}.qr-box{width:180px;height:180px;margin:0 auto 12px;border-radius:var(--radius-sm);background:var(--brand-900);padding:10px;display:grid;place-items:center}.qr-box svg{width:100%;height:100%}.split-list{margin-top:10px;display:grid;gap:6px}.split-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg)}.split-item .method{font-weight:600;font-size:11.5px;flex:1}.split-item .amt{font-variant-numeric:tabular-nums;font-weight:600}.toasts{position:fixed;top:16px;right:16px;z-index:200;display:grid;gap:6px;pointer-events:none}.toast{pointer-events:auto;display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:var(--radius-sm);background:var(--bg);border:1px solid var(--border);box-shadow:var(--shadow-lg);font-size:12.5px;font-weight:500;min-width:240px;animation:toastIn .2s var(--ease)}@keyframes toastIn{0%{opacity:0;transform:translate(12px)}to{opacity:1;transform:translate(0)}}.toast.success{border-left:3px solid var(--success)}.toast.success .icon{color:var(--success)}.toast.error{border-left:3px solid var(--danger)}.toast.error .icon{color:var(--danger)}.toast.info{border-left:3px solid var(--info)}.toast.info .icon{color:var(--info)}.toast .text{color:var(--fg-strong)}.toast .sub{color:var(--fg-muted);font-size:11px}.popover{position:absolute;top:calc(var(--topbar-h) - 4px);right:12px;z-index:90;width:240px;background:var(--bg);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-lg);overflow:hidden;animation:pop .16s var(--ease)}.popover-item{display:flex;align-items:center;gap:10px;padding:9px 12px;font-size:12.5px;color:var(--fg);cursor:pointer;transition:background var(--t-fast);border:none;background:transparent;width:100%;text-align:left}.popover-item .kbd{margin-left:auto}.popover-item:hover{background:var(--bg-muted)}.popover-item:hover .icon{color:var(--primary)}.popover-item .icon{color:var(--fg-muted);display:inline-grid}.popover-divider{height:1px;background:var(--border)}.popover-label{padding:8px 12px 3px;font-size:9.5px;font-weight:700;color:var(--fg-subtle);text-transform:uppercase;letter-spacing:.08em}.parked-list{display:grid;gap:6px}.parked-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);transition:all var(--t-fast)}.parked-item:hover{border-color:var(--primary);background:var(--primary-subtle)}.parked-item .pi-icon{width:30px;height:30px;border-radius:var(--radius-xs);background:var(--bg-muted);border:1px solid var(--border);color:var(--primary);display:grid;place-items:center}.parked-item .pi-body{flex:1;line-height:1.3}.parked-item .pi-name{font-size:12.5px;font-weight:600;color:var(--fg-strong)}.parked-item .pi-meta{font-size:10.5px;color:var(--fg-muted);margin-top:2px;font-family:var(--font-mono)}.parked-item .pi-amt{font-size:13px;font-weight:700;color:var(--brand-900);font-variant-numeric:tabular-nums}.receipt{background:#fff;font-family:var(--font-mono);font-size:11px;color:var(--fg);padding:18px;border-radius:var(--radius);border:1px dashed var(--border-strong);max-width:300px;margin:0 auto;line-height:1.5}.receipt h4{text-align:center;margin:0 0 4px;font-family:Poppins,sans-serif;font-size:14px;font-weight:600}.receipt .center{text-align:center}.receipt .muted{color:var(--fg-muted)}.receipt hr{border:none;border-top:1px dashed var(--border-strong);margin:8px 0}.receipt .line{display:flex;justify-content:space-between}.receipt .grand{font-weight:700;font-size:13px;font-family:Poppins,sans-serif}.receipt .thanks{text-align:center;margin-top:10px;font-family:Poppins,sans-serif;font-weight:500;color:var(--fg-strong)}.spinner{width:14px;height:14px;border:2px solid var(--primary-soft);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.check-ring{width:52px;height:52px;border-radius:50%;background:var(--success-bg);color:var(--success);display:grid;place-items:center;margin:0 auto 12px;animation:checkPop .36s var(--ease);border:2px solid hsl(142,60%,80%)}@keyframes checkPop{0%{transform:scale(.4);opacity:0}60%{transform:scale(1.08);opacity:1}to{transform:scale(1)}}.cart-fab{display:none;position:fixed;bottom:14px;right:14px;z-index:50;height:46px;padding:0 16px;border:none;border-radius:var(--radius);background:var(--brand-900);color:#fff;font-weight:600;font-size:13px;box-shadow:var(--shadow-lg);align-items:center;gap:10px}.cart-fab .count{background:var(--primary);color:#fff;border-radius:var(--radius-xs);min-width:22px;height:22px;padding:0 6px;display:grid;place-items:center;font-size:11px;font-weight:700}.login{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;grid-template-columns:1.05fr 1fr;background:var(--bg);z-index:1000;font-family:Poppins,sans-serif}.login-brand{position:relative;background:var(--brand-900);color:#fff;padding:36px 40px;display:flex;flex-direction:column;overflow:hidden}.login-brand:before{content:"";position:absolute;inset:auto -30% -50% -10%;height:70%;background:radial-gradient(ellipse at center,var(--brand-500) 0%,transparent 60%);opacity:.45;pointer-events:none}.login-brand:after{content:"";position:absolute;top:-10%;right:-20%;width:360px;height:360px;border-radius:50%;background:var(--brand-500);opacity:.18;filter:blur(40px);pointer-events:none}.lb-top{display:flex;align-items:center;gap:12px;position:relative;z-index:2}.lb-top .brand-mark{width:36px;height:36px;font-size:16px}.lb-top strong{font-size:16px;font-weight:600;letter-spacing:-.01em}.lb-top small{font-size:11px;opacity:.6;font-family:var(--font-mono);display:block;margin-top:1px}.lb-mid{margin-top:auto;margin-bottom:24px;position:relative;z-index:2}.lb-mid h1{margin:0 0 16px;font-size:36px;font-weight:600;letter-spacing:-.025em;line-height:1.1}.lb-mid p{margin:0;font-size:14px;color:#accdd2;max-width:380px;line-height:1.5}.lb-features{display:grid;gap:10px;margin-top:28px;max-width:380px;position:relative;z-index:2}.lb-features .ft{display:flex;align-items:center;gap:10px;font-size:12.5px;color:#bdd7db}.lb-features .ft .ck{width:18px;height:18px;border-radius:var(--radius-xs);background:#ffffff14;color:var(--brand-500);display:grid;place-items:center;flex-shrink:0}.lb-bottom{display:flex;align-items:center;justify-content:space-between;font-size:11px;color:#759ca3;position:relative;z-index:2;font-family:var(--font-mono)}.lb-bottom .sys-dots{display:flex;align-items:center;gap:6px}.lb-bottom .sys-dots .dot{width:6px;height:6px;border-radius:50%;background:var(--success)}.login-form-wrap{display:grid;grid-template-rows:auto 1fr auto;justify-items:center;padding:32px 48px;overflow-y:auto}.login-form-top{width:100%;max-width:420px;display:flex;align-items:center;justify-content:space-between;font-size:11px;color:var(--fg-muted);margin-bottom:28px}.login-form-top .reg{font-family:var(--font-mono);background:var(--bg-muted);border:1px solid var(--border);padding:4px 8px;border-radius:var(--radius-xs);color:var(--fg-strong)}.login-form{align-self:center;max-width:420px;width:100%}.login-form h2{margin:0 0 4px;font-size:22px;font-weight:600;letter-spacing:-.02em;color:var(--fg-strong)}.login-form .sub{font-size:13px;color:var(--fg-muted);margin-bottom:24px}.login-form .field input{height:42px;font-size:14px;padding:0 14px}.pin-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;margin-bottom:4px}.pin-cell{height:48px;border:1.5px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--bg);display:grid;place-items:center;font-size:18px;font-weight:600;color:var(--fg-strong);font-family:var(--font-mono);transition:all var(--t-fast)}.pin-cell.filled{border-color:var(--primary);background:var(--primary-subtle)}.pin-cell.active{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-ring)}.pin-cell.error{border-color:var(--danger);animation:shake .4s var(--ease)}@keyframes shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-6px)}40%,80%{transform:translate(6px)}}.pin-dot{width:10px;height:10px;border-radius:50%;background:var(--fg-strong)}.pin-keypad{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:18px}.pin-key{height:52px;border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--bg);font-size:18px;font-weight:600;color:var(--fg-strong);font-family:var(--font-mono);cursor:pointer;transition:all var(--t-fast);display:grid;place-items:center}.pin-key:hover{background:var(--bg-muted);border-color:var(--primary)}.pin-key:active{transform:scale(.96);background:var(--primary-subtle)}.pin-key.action{font-family:Poppins,sans-serif;font-size:13px;color:var(--fg-muted)}.pin-key.action.signin{background:var(--primary);color:#fff;border-color:var(--primary);font-size:13px;font-weight:600}.pin-key.action.signin:hover{background:var(--primary-hover)}.pin-key.action.signin:disabled{opacity:.4;pointer-events:none}.login-form .err-msg{display:flex;align-items:center;gap:6px;margin-top:12px;padding:8px 12px;border-radius:var(--radius-sm);background:var(--danger-bg);color:var(--danger);font-size:12px;font-weight:500;border:1px solid hsl(0,70%,90%)}.login-form-bottom{width:100%;max-width:420px;padding-top:24px;display:flex;align-items:center;justify-content:space-between;font-size:11px;color:var(--fg-subtle)}.login-form-bottom a,.login-form-bottom button{background:none;border:none;color:var(--primary);font-size:11px;font-weight:500;cursor:pointer;font-family:inherit}.login-form-bottom a:hover,.login-form-bottom button:hover{text-decoration:underline}.cashier-list{display:grid;gap:6px;margin-bottom:14px}.cashier-row{display:flex;align-items:center;gap:10px;padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);cursor:pointer;transition:all var(--t-fast)}.cashier-row:hover{border-color:var(--primary);background:var(--primary-subtle)}.cashier-row.sel{border-color:var(--primary);background:var(--primary-subtle);box-shadow:0 0 0 2px var(--primary-ring)}.cashier-row .body{flex:1;line-height:1.25}.cashier-row .body strong{display:block;font-size:12.5px;font-weight:600;color:var(--fg-strong)}.cashier-row .body small{font-size:10.5px;color:var(--fg-muted);font-family:var(--font-mono)}.cashier-row .role{font-size:10px;font-weight:600;padding:2px 6px;border-radius:var(--radius-xs);background:var(--primary-subtle);color:var(--primary);text-transform:uppercase;letter-spacing:.04em}.cash-cnt-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px;margin-bottom:12px}.cash-cnt-row{display:grid;grid-template-columns:1fr 70px 80px;gap:6px;align-items:center;padding:6px 8px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg)}.cash-cnt-row .denom-lbl{font-size:12px;font-weight:600;color:var(--fg);font-variant-numeric:tabular-nums}.cash-cnt-row input{width:100%;height:28px;text-align:right;border:1px solid var(--border);border-radius:var(--radius-xs);font-size:12px;padding:0 6px;font-variant-numeric:tabular-nums}.cash-cnt-row .total{text-align:right;font-variant-numeric:tabular-nums;font-size:11.5px;color:var(--fg-muted)}.cust-search-input{position:relative;margin-bottom:12px}.cust-search-input input{width:100%;height:40px;padding:0 14px 0 36px;border:1px solid var(--border-strong);border-radius:var(--radius-sm);font-size:13px}.cust-search-input input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-ring)}.cust-search-input .icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--fg-subtle)}.cust-result{display:flex;align-items:center;gap:12px;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);cursor:pointer;transition:all var(--t-fast)}.cust-result:hover{border-color:var(--primary);background:var(--primary-subtle)}.cust-result+.cust-result{margin-top:6px}.cust-result .av{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--brand-900));color:#fff;display:grid;place-items:center;font-weight:600;font-size:13px}.cust-result .body{flex:1;line-height:1.3}.cust-result .body strong{display:block;font-size:13px;font-weight:600;color:var(--fg-strong)}.cust-result .body small{font-size:11px;color:var(--fg-muted);font-family:var(--font-mono)}.cust-result .tier{display:inline-flex;align-items:center;gap:4px;padding:2px 7px;border-radius:var(--radius-xs);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.cust-result .tier.bronze{background:#faf2eb;color:#7a491f;border:1px solid hsl(28,50%,88%)}.cust-result .tier.silver{background:#f0f2f4;color:#4c5567;border:1px solid hsl(220,15%,85%)}.cust-result .tier.gold{background:#fcf5e8;color:#824917;border:1px solid hsl(38,80%,80%)}.cust-result .tier.plat{background:var(--primary-subtle);color:var(--brand-900);border:1px solid hsl(189,50%,80%)}.cust-result .points{font-family:var(--font-mono);font-size:11px;color:var(--fg-muted);margin-top:3px}.summary-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:16px}.summary-card{padding:12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg)}.summary-card .lbl{font-size:10.5px;color:var(--fg-muted);font-weight:600;text-transform:uppercase;letter-spacing:.04em}.summary-card .val{margin-top:4px;font-size:18px;font-weight:700;color:var(--fg-strong);letter-spacing:-.01em;font-variant-numeric:tabular-nums}.summary-card .delta{margin-top:2px;font-size:11px;font-family:var(--font-mono);color:var(--fg-muted)}.summary-card .delta.up{color:var(--success)}.summary-card .delta.down{color:var(--danger)}.bar-row{display:flex;align-items:center;gap:10px;padding:6px 0;font-size:12px}.bar-row .lbl{width:90px;color:var(--fg)}.bar-row .bar-track{flex:1;height:10px;background:var(--bg-muted);border-radius:999px;overflow:hidden;border:1px solid var(--border)}.bar-row .bar-fill{height:100%;background:var(--primary);border-radius:999px;transition:width .6s var(--ease)}.bar-row .val{width:90px;text-align:right;font-variant-numeric:tabular-nums;font-weight:600;color:var(--fg-strong)}.pin-input{width:100%;height:56px;padding:0 56px 0 16px;border:1.5px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--bg);font-family:var(--font-mono);font-size:22px;font-weight:600;letter-spacing:.4em;text-align:center;color:var(--fg-strong);transition:all var(--t-fast);-webkit-text-security:disc}.pin-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-ring)}.input-wrap{position:relative}.input-kbd-btn{position:absolute;right:6px;top:50%;transform:translateY(-50%);width:36px;height:36px;border-radius:var(--radius-xs);border:1px solid var(--border);background:var(--bg-muted);color:var(--fg-muted);display:grid;place-items:center;transition:all var(--t-fast);cursor:pointer}.input-kbd-btn:hover{color:var(--primary);border-color:var(--primary);background:var(--primary-subtle)}.input-kbd-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.vkb{margin-top:14px;padding:10px;background:var(--bg-muted);border:1px solid var(--border);border-radius:var(--radius);animation:kbdPop .18s var(--ease)}@keyframes kbdPop{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.vkb-head{display:flex;align-items:center;justify-content:space-between;font-size:10.5px;font-weight:600;color:var(--fg-muted);text-transform:uppercase;letter-spacing:.06em;padding:0 2px 8px}.vkb-head .target{font-family:var(--font-mono);background:var(--bg);border:1px solid var(--border);padding:2px 6px;border-radius:var(--radius-xs);color:var(--fg-strong);text-transform:none;letter-spacing:0}.vkb-head .close{border:none;background:none;color:var(--fg-muted);cursor:pointer;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:4px 8px;border-radius:var(--radius-xs);display:inline-flex;align-items:center;gap:4px}.vkb-head .close:hover{background:var(--bg);color:var(--fg)}.vkb-row{display:flex;gap:4px;margin-bottom:4px}.vkb-row:last-child{margin-bottom:0}.vkb-key{flex:1;min-width:0;height:38px;border:1px solid var(--border-strong);border-radius:var(--radius-xs);background:var(--bg);font-family:var(--font-mono);font-size:13px;font-weight:600;color:var(--fg-strong);cursor:pointer;transition:all var(--t-fast);display:grid;place-items:center;padding:0}.vkb-key:hover{background:var(--bg-muted);border-color:var(--primary)}.vkb-key:active{transform:scale(.94);background:var(--primary-subtle)}.vkb-key.action{font-family:Poppins,sans-serif;font-size:11.5px;font-weight:600;color:var(--fg-muted);background:var(--bg-muted);flex:1.2}.vkb-key.action.shift.on{background:var(--brand-900);color:#fff;border-color:var(--brand-900)}.vkb-key.space{flex:4}.vkb-num{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.vkb-num .vkb-key{height:48px;font-size:16px}.gvkb-fab{position:fixed;bottom:14px;left:14px;z-index:210;height:44px;padding:0 14px;display:inline-flex;align-items:center;gap:8px;background:var(--brand-900);color:#fff;border:none;border-radius:999px;box-shadow:var(--shadow-lg);font-size:12px;font-weight:600;cursor:pointer;transition:transform var(--t-fast),background var(--t-fast)}.gvkb-fab:hover{background:#003d47;transform:scale(1.04)}.gvkb-fab.active{background:var(--primary)}.gvkb-fab .target{font-family:var(--font-mono);font-size:10.5px;font-weight:600;background:#ffffff2e;padding:2px 6px;border-radius:var(--radius-xs);max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gvkb-panel{position:fixed;bottom:14px;left:14px;right:14px;z-index:215;margin:0 auto;max-width:720px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);padding:10px;animation:kbdPop .18s var(--ease)}.gvkb-panel .vkb-head{padding:2px 6px 8px}.gvkb-panel.num{max-width:280px}.gvkb-panel.num .vkb-num .vkb-key{height:56px;font-size:18px}.gvkb-panel .gvkb-mode{display:inline-flex;background:var(--bg-muted);border:1px solid var(--border);border-radius:var(--radius-xs);padding:1px;gap:1px;margin-right:8px}.gvkb-panel .gvkb-mode button{border:none;background:transparent;padding:3px 8px;font-size:10.5px;font-weight:600;font-family:Poppins,sans-serif;color:var(--fg-muted);letter-spacing:.04em;text-transform:uppercase;border-radius:3px;cursor:pointer}.gvkb-panel .gvkb-mode button.on{background:#fff;color:var(--fg-strong);box-shadow:var(--shadow-xs)}@media (max-width: 1280px){:root{--cart-w: 360px}}@media (max-width: 1100px){:root{--cart-w: 340px}.login{grid-template-columns:1fr}.login-brand{display:none}}@media (max-width: 980px){.pos{grid-template-columns:1fr;grid-template-areas:"topbar" "sessbar" "main" "bottom"}.cart{position:fixed;top:0;right:0;bottom:0;width:380px;z-index:80;transform:translate(100%);transition:transform .22s var(--ease);box-shadow:var(--shadow-xl)}.cart.open{transform:translate(0)}.cart-fab{display:inline-flex}}@media (max-width: 640px){.topbar{flex-wrap:wrap}.search{order:3;flex-basis:100%;max-width:none}.cart{width:100%}.summary-grid{grid-template-columns:repeat(2,1fr)}.pay-methods{grid-template-columns:1fr}}.prefs{display:grid;grid-template-columns:200px 1fr;min-height:460px;margin:-20px -24px}.prefs-nav{display:flex;flex-direction:column;gap:2px;padding:14px 10px;background:var(--bg-muted);border-right:1px solid var(--border)}.prefs-nav-item{display:flex;align-items:center;gap:9px;padding:8px 10px;background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);font-size:12.5px;font-weight:500;color:var(--fg-muted);text-align:left;cursor:pointer;transition:all var(--t-fast)}.prefs-nav-item:hover{background:var(--bg);color:var(--fg-strong)}.prefs-nav-item.active{background:var(--bg);color:var(--fg-strong);border-color:var(--border);box-shadow:var(--shadow-xs)}.prefs-nav-item.active svg{color:var(--primary)}.prefs-pane{padding:18px 24px;overflow-y:auto;max-height:60vh}.prefs-row{display:grid;grid-template-columns:1fr auto;gap:24px;align-items:center;padding:14px 0;border-bottom:1px solid var(--border)}.prefs-row:last-child{border-bottom:none}.prefs-row-text{min-width:0}.prefs-row-label{font-size:13px;font-weight:500;color:var(--fg-strong)}.prefs-row-hint{font-size:11.5px;color:var(--fg-muted);margin-top:3px;line-height:1.4}.prefs-row-ctl{display:flex;align-items:center;justify-content:flex-end}.prefs-input,.prefs-select{height:32px;padding:0 10px;border:1px solid var(--border-strong);background:var(--bg);border-radius:var(--radius-sm);font-size:12.5px;color:var(--fg);min-width:220px}.prefs-input:focus,.prefs-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-ring)}.prefs-stepper{display:inline-flex;align-items:center;border:1px solid var(--border-strong);border-radius:var(--radius-sm);overflow:hidden;background:var(--bg)}.prefs-stepper button{width:28px;height:30px;border:none;background:transparent;font-size:14px;font-weight:600;color:var(--fg-muted);cursor:pointer}.prefs-stepper button:hover{background:var(--bg-muted);color:var(--fg-strong)}.prefs-stepper span{min-width:32px;text-align:center;font-size:12.5px;font-weight:500;color:var(--fg-strong);font-variant-numeric:tabular-nums}.prefs-slider{display:inline-flex;align-items:center;gap:12px;min-width:260px}.prefs-slider input[type=range]{flex:1;accent-color:var(--primary)}.prefs-slider .num{font-size:12px;font-weight:500;color:var(--fg-muted);font-variant-numeric:tabular-nums;min-width:36px;text-align:right}.prefs-switch{width:36px;height:20px;border:1px solid var(--border-strong);background:var(--bg-muted);border-radius:999px;position:relative;cursor:pointer;transition:all var(--t-fast);padding:0}.prefs-switch .thumb{position:absolute;top:1px;left:1px;width:16px;height:16px;background:#fff;border-radius:50%;box-shadow:var(--shadow-xs);transition:transform var(--t-fast)}.prefs-switch.on{background:var(--primary);border-color:var(--primary)}.prefs-switch.on .thumb{transform:translate(16px)}.prefs-status{margin-top:18px;padding:12px 14px;background:var(--bg-muted);border:1px solid var(--border);border-radius:var(--radius-sm);display:grid;gap:8px;font-size:12px;color:var(--fg)}.prefs-status>div{display:flex;align-items:center;gap:10px}.prefs-status .chip{min-width:130px;justify-content:flex-start}.prefs-about-head{display:flex;align-items:center;gap:14px;padding-bottom:14px;border-bottom:1px solid var(--border);margin-bottom:14px}.prefs-about-head img{height:36px;width:auto}.prefs-about-head strong{display:block;font-size:14px;color:var(--fg-strong);font-weight:600}.prefs-about-head div div{font-size:11.5px;color:var(--fg-muted);font-family:var(--font-mono);margin-top:3px}.prefs-meta{display:grid;grid-template-columns:1fr 1fr;gap:10px 24px;margin:0}.prefs-meta>div{display:grid;gap:2px}.prefs-meta dt{font-size:10.5px;font-weight:600;color:var(--fg-subtle);text-transform:uppercase;letter-spacing:.04em;margin:0}.prefs-meta dd{font-size:12.5px;color:var(--fg-strong);margin:0;font-weight:500}.prefs-links{display:flex;gap:8px;margin-top:18px;padding-top:14px;border-top:1px solid var(--border)}.modal.xl{max-width:820px;width:92vw}
