*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body{margin:0;padding:0;background:#1a1a1a;color:#fff;font-family:Noto Sans SC,Inter,Segoe UI,system-ui,sans-serif;font-size:14px;line-height:1.4;-webkit-font-smoothing:antialiased}#app{min-height:100vh;background:#1a1a1a}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}img{display:block}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-thumb{background:#333;border-radius:4px}.nm-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;background:#c41e1e;color:#fff;font-weight:700;border-radius:24px;padding:12px 22px;box-shadow:0 2px 12px #c41e1e66;transition:background .15s ease}.nm-btn:active{background:#8b1515}.nm-btn:disabled{opacity:.4;box-shadow:none}.nm-btn-ghost{display:inline-flex;align-items:center;justify-content:center;gap:6px;background:transparent;color:#d4a017;font-weight:700;border:2px solid #d4a017;border-radius:24px;padding:10px 18px}.nm-btn-dark{display:inline-flex;align-items:center;justify-content:center;gap:6px;background:#2d2d2d;color:#ccc;border:1px solid #333333;border-radius:24px;padding:10px 16px;font-weight:600}.nm-price{color:#d4a017;font-weight:700;font-variant-numeric:tabular-nums;font-family:Inter,Noto Sans SC,system-ui,sans-serif}.nm-tag{display:inline-block;font-size:10px;font-weight:700;color:#fff;padding:2px 8px;border-radius:10px;background:#c41e1e}.nm-qty-btn{width:32px;height:32px;border-radius:50%;background:#3d3d3d;color:#fff;font-size:20px;font-weight:700;display:inline-flex;align-items:center;justify-content:center}.nm-qty-btn.is-add{background:#c41e1e}:root{--nm-red: #c41e1e;--nm-red-hover: #a31818;--nm-red-active: #8b1515;--nm-gold: #d4a017;--nm-green: #5dbb63;--nm-dark: #1a1a1a;--nm-card: #2d2d2d;--nm-border: #333333;--nm-input: #3d3d3d;--nm-text: #ffffff;--nm-text-secondary: #cccccc;--nm-text-muted: #999999;--nm-font-base: Noto Sans SC, Inter, Segoe UI, system-ui, sans-serif;--nm-font-latin: Inter, Noto Sans SC, system-ui, sans-serif}.pos-shell{height:100vh;overflow:hidden;display:flex;flex-direction:column;background:#1a1a1a;color:#fff}.pos-topbar{display:flex;align-items:center;gap:16px;padding:10px 18px;background:linear-gradient(180deg,#1a1a1a,#2d2d2d);border-bottom:1px solid rgba(212,160,23,.5);flex-shrink:0;z-index:20}.pos-brand{display:flex;align-items:center;gap:10px}.pos-brand svg{width:34px;height:34px}.pos-brand-name{font-family:Inter,Noto Sans SC,system-ui,sans-serif;font-weight:800;letter-spacing:3px;font-size:18px}.pos-brand-name .b{color:#fff}.pos-brand-name .g{color:#d4a017}.pos-topbar-spacer{flex:1}.pos-cashier-badge{display:inline-flex;align-items:center;gap:6px;background:#0000004d;border:1px solid #333333;border-radius:999px;padding:5px 12px;font-size:13px;color:#ccc}.pos-cashier-badge .dot{width:7px;height:7px;border-radius:50%;background:#5dbb63}.pos-tabs{display:inline-flex;gap:6px}.pos-tab{padding:8px 20px;border-radius:20px;font-weight:700;font-size:15px;color:#999;transition:all .15s ease}.pos-tab.active{background:#c41e1e;color:#fff}.pos-body{flex:1;display:flex;min-height:0}.pos-panel{background:#2d2d2d;border:1px solid #333333;border-radius:12px}.pos-section-title{font-weight:700;font-size:16px;color:#fff;margin:0 0 12px}.pos-muted{color:#999}.pos-input{width:100%;background:#3d3d3d;border:1px solid #333333;border-radius:8px;color:#fff;font-family:inherit;font-size:16px;padding:12px 14px;outline:none}.pos-input::placeholder{color:#999}.pos-input:focus{border-color:#d4a017;box-shadow:0 0 0 2px #d4a01733}.pos-label{display:block;font-size:13px;color:#ccc;margin-bottom:6px;font-weight:600}.pos-pay-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}.pos-pay-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:18px 12px;background:#3d3d3d;border:1.5px solid #333333;border-radius:14px;color:#fff;font-weight:700;font-size:16px;transition:all .12s ease}.pos-pay-btn.active{border-color:#c41e1e;background:#c41e1e24}.pos-pay-btn .ico{font-size:26px}.pos-line{display:flex;align-items:flex-start;gap:10px;padding:12px 0;border-bottom:1px dashed rgba(212,160,23,.22)}.pos-line:last-child{border-bottom:none}.pos-line-name{flex:1;font-weight:600}.pos-line-opts{font-size:12px;color:#999;margin-top:3px}.pos-order-card{cursor:pointer;padding:14px 16px;display:flex;align-items:center;gap:14px;transition:border-color .12s ease}.pos-order-card:hover,.pos-order-card.active{border-color:#d4a017}.pos-pickup-badge{min-width:56px;height:56px;border-radius:12px;background:#3d3d3d;border:1px solid rgba(212,160,23,.4);display:flex;flex-direction:column;align-items:center;justify-content:center}.pos-pickup-badge .n{font-family:Inter,Noto Sans SC,system-ui,sans-serif;font-weight:800;font-size:22px;color:#d4a017;line-height:1}.pos-pickup-badge .l{font-size:9px;color:#999;text-transform:uppercase;letter-spacing:1px}.pos-prod-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}.pos-prod-card{cursor:pointer;overflow:hidden;display:flex;flex-direction:column;transition:border-color .12s ease}.pos-prod-card:hover{border-color:#d4a017}.pos-prod-card .img{width:100%;aspect-ratio:1.3;object-fit:cover;background:#3d3d3d}.pos-prod-card .img-ph{width:100%;aspect-ratio:1.3;background:#3d3d3d;display:flex;align-items:center;justify-content:center;font-size:32px}.pos-prod-card .body{padding:10px;display:flex;flex-direction:column;gap:6px;flex:1}.pos-prod-card .nm{font-weight:600;font-size:14px;line-height:1.3}.pos-prod-card .row{margin-top:auto;display:flex;align-items:center;justify-content:space-between}.pos-cat-tabs{display:flex;gap:8px;overflow-x:auto;padding-bottom:8px;border-bottom:1.5px dashed rgba(212,160,23,.45);margin-bottom:14px}.pos-cat-tab{white-space:nowrap;padding:7px 16px;border-radius:20px;font-weight:700;color:#ccc;background:transparent}.pos-cat-tab.active{background:#c41e1e;color:#fff}.pos-mask{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:50;padding:20px}.pos-modal{background:#2d2d2d;border:1px solid #333333;border-radius:12px;width:100%;max-width:560px;max-height:88vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 8px 40px #00000080}.pos-modal-head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid #333333}.pos-modal-title{font-weight:700;font-size:17px}.pos-modal-body{padding:18px;overflow-y:auto}.pos-modal-foot{padding:14px 18px;border-top:1px solid #333333;display:flex;gap:12px;align-items:center}.pos-close-x{width:32px;height:32px;border-radius:50%;background:#3d3d3d;color:#ccc;font-size:18px;display:flex;align-items:center;justify-content:center}.pos-opt-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.pos-opt-card{cursor:pointer;text-align:center;padding:12px 8px;background:#2d2d2d;border:1.5px solid #333333;border-radius:14px;transition:all .12s ease}.pos-opt-card.active{border-color:#c41e1e;background:#c41e1e1f}.pos-opt-card .emoji{font-size:26px}.pos-opt-card .nm{font-size:13px;margin-top:4px}.pos-cart{width:360px;flex-shrink:0;border-left:1px solid #333333;background:#2d2d2d;display:flex;flex-direction:column}.pos-cart-head{padding:14px 16px;border-bottom:1px solid #333333;font-weight:700;font-size:16px}.pos-cart-list{flex:1;overflow-y:auto;padding:0 16px}.pos-cart-foot{padding:14px 16px;border-top:1px solid rgba(212,160,23,.4)}.pos-amount-big{font-family:Inter,Noto Sans SC,system-ui,sans-serif;font-weight:800;font-size:30px;color:#d4a017;font-variant-numeric:tabular-nums}.pos-receipt{background:#fffdf8;color:#1a1a1a;border-radius:8px;padding:18px 16px;font-family:Inter,monospace;max-width:320px;margin:0 auto}.pos-receipt .r-store{text-align:center;font-weight:800;letter-spacing:2px;margin-bottom:2px}.pos-receipt .r-pickup{text-align:center;font-size:40px;font-weight:800;margin:8px 0}.pos-receipt .r-line{display:flex;justify-content:space-between;font-size:13px;padding:3px 0}.pos-receipt .r-opt{font-size:11px;color:#666;padding-left:8px}.pos-receipt .r-sep{border-top:1px dashed #999;margin:8px 0}.pos-receipt .r-total{display:flex;justify-content:space-between;font-weight:800;font-size:16px}.pos-receipt .r-thanks{text-align:center;margin-top:10px;font-size:12px;color:#666}.pos-toast{position:fixed;left:50%;bottom:30px;transform:translate(-50%);background:#2d2d2d;border:1px solid #d4a017;color:#fff;padding:12px 22px;border-radius:999px;z-index:100;box-shadow:0 4px 20px #0006;font-weight:600}.pos-err{color:#ff6b6b;font-size:13px}.pos-state{display:inline-block;font-size:11px;font-weight:700;padding:2px 8px;border-radius:8px;background:#3d3d3d;color:#ccc}@media print{body *{visibility:hidden}.pos-receipt,.pos-receipt *{visibility:visible}.pos-receipt{position:absolute;left:0;top:0}}
