:root{--bg: #f5f6f8;--card: #ffffff;--border: #e3e6ea;--text: #1f2430;--muted: #6b7280;--primary: #f5811f;--primary-dark: #c25e0f;--warn: #b91c1c}*{box-sizing:border-box}body{margin:0;font-family:-apple-system,Segoe UI,Noto Sans TC,system-ui,sans-serif;background:var(--bg);color:var(--text)}.center{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}.muted{color:var(--muted)}.warn{color:var(--warn)}.card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:20px;margin-bottom:16px}.login-card{width:320px}.login-card h1{margin-top:0;font-size:20px}.login-card label{display:block;margin:12px 0;font-size:14px}.login-card input{width:100%;padding:10px;border:1px solid var(--border);border-radius:8px;margin-top:4px}button{background:var(--primary);color:#fff;border:none;border-radius:8px;padding:10px 16px;cursor:pointer;font-size:14px}button:disabled{opacity:.5;cursor:not-allowed}.btn-link{background:none;color:var(--primary);padding:4px 8px;text-decoration:none}.app-shell{min-height:100vh;display:flex;flex-direction:column}.topbar{height:56px;background:var(--card);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 16px}.brand{font-weight:700;display:flex;align-items:center;gap:8px}.brand-logo{height:32px;width:auto;display:block}.brand-sub{font-size:13px;color:var(--muted);font-weight:600}.login-logo{width:200px;max-width:70%;display:block;margin:0 auto 8px}.topbar-right{display:flex;align-items:center;gap:12px;font-size:14px}.merchant-select{padding:6px 8px;border:1px solid var(--border);border-radius:8px}.badge{background:#fef3c7;color:#92400e;border-radius:6px;padding:2px 8px;font-size:12px;margin-left:8px}.app-body{flex:1;display:flex}.sidebar{width:200px;background:var(--card);border-right:1px solid var(--border);padding:12px}.sidebar-title{font-size:12px;color:var(--muted);padding:8px}.nav-link{display:block;padding:10px 12px;border-radius:8px;color:var(--text);text-decoration:none;font-size:14px}.nav-link:hover{background:var(--bg)}.nav-link.active{background:#fff3e8;color:var(--primary);font-weight:600}.nav-group{margin-top:10px}.nav-group-title{font-size:11px;color:var(--muted);padding:4px 12px;letter-spacing:.05em}.content{flex:1;padding:24px}.content h1{font-size:22px;margin-top:0}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}.tile{text-decoration:none;color:var(--text);text-align:center;padding:28px 12px}.tile:hover{border-color:var(--primary)}.page-head{display:flex;align-items:center;justify-content:space-between}.table{width:100%;border-collapse:collapse;font-size:14px}.table th,.table td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--border)}.table th{color:var(--muted);font-weight:600}.form{max-width:460px}.form label{display:block;margin:14px 0;font-size:14px}.form input,.form select{width:100%;padding:10px;border:1px solid var(--border);border-radius:8px;margin-top:4px}.form small{display:block;margin-top:4px}.form-actions{display:flex;gap:12px;align-items:center;justify-content:flex-end;margin-top:8px}.tag{font-size:11px;background:#fff3e8;color:#b5651d;border-radius:5px;padding:1px 6px;margin-left:6px}.tag-warn{background:#fee2e2;color:#991b1b}.feature-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:6px 16px}.feature-item{display:flex;align-items:center;gap:8px;font-size:14px;padding:4px 0}.feature-item code,.perm-item code{font-size:11px;margin-left:auto}.two-col{display:grid;grid-template-columns:220px 1fr;gap:16px;align-items:start}.role-list{display:flex;flex-direction:column;gap:4px}.role-btn{background:none;color:var(--text);text-align:left;padding:10px 12px;border-radius:8px}.role-btn:hover{background:var(--bg)}.role-btn.active{background:#fff3e8;color:var(--primary);font-weight:600}.perm-cat{margin-bottom:14px}.perm-cat-title{font-size:12px;color:var(--muted);border-bottom:1px solid var(--border);padding-bottom:4px;margin-bottom:6px}.perm-item{display:flex;align-items:center;gap:8px;font-size:14px;padding:3px 0}.branch-add{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}.branch-add input{flex:1;min-width:120px;padding:8px;border:1px solid var(--border);border-radius:8px}@media (max-width: 640px){.two-col{grid-template-columns:1fr}}.cell-input{width:100%;padding:6px 8px;border:1px solid var(--border);border-radius:6px}.small{font-size:12px}.opt-editor{border-top:1px dashed var(--border);margin-top:8px;padding-top:8px}.opt-group{border:1px solid var(--border);border-radius:8px;padding:8px;margin:8px 0}.opt-group-head{display:flex;justify-content:space-between;align-items:center}.opt-row{display:flex;gap:8px;align-items:center;font-size:14px;padding:2px 0}.pe{padding:4px 0 6px}.pe-tabs{display:flex;gap:2px;border-bottom:1px solid var(--border);margin-bottom:12px}.pe-tabs button{background:none;border:none;padding:8px 16px;cursor:pointer;color:#8b8f98;border-bottom:2px solid transparent;font-weight:600;font-size:14px}.pe-tabs button.active{color:var(--primary);border-bottom-color:var(--primary)}.oe-quick{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin-bottom:12px}.og-card{border:1px solid var(--border);border-radius:10px;padding:10px 12px;margin-bottom:8px;background:var(--card, #fff)}.og-head{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:10px}.og-name{width:110px;font-weight:700}.og-head label{display:flex;align-items:center;gap:4px}.og-del{margin-left:auto}.og-chips{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.chip{display:inline-flex;align-items:center;gap:5px;background:#eef1f5;border-radius:16px;padding:5px 12px;font-size:13px;color:var(--text)}.chip button{border:none;background:none;cursor:pointer;color:#98a;font-size:15px;line-height:1;padding:0}.chip-add-btn{border:1px dashed var(--primary);background:none;color:var(--primary);cursor:pointer;font-size:13px}.chip-add{display:inline-flex;align-items:center;gap:4px}.chip-add input{width:86px;padding:5px 10px;border:1px solid var(--border);border-radius:14px;font-size:13px}.chip-add input[type=number]{width:58px}.chip-add button{width:28px;height:28px;border-radius:50%;border:none;background:var(--primary);color:#fff;cursor:pointer;font-size:16px;line-height:1}.order-actions{display:flex;gap:8px;flex-wrap:wrap}.order-detail{background:var(--bg);font-size:13px;padding:8px 12px}.ord-extras{font-size:13px;color:#555;margin:6px 0 2px;line-height:1.7}.ord-note{color:#b45309;font-weight:600}.appdl-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}.appdl-grid .card{text-align:center}.appdl-grid h3{text-align:left}.appdl-steps{text-align:left;font-size:14px;line-height:1.7;color:#374151;padding-left:20px;margin:8px 0 12px}.appdl-qr{width:200px;height:200px;border:1px solid var(--border);border-radius:12px;padding:6px}.appdl-btn{display:block;max-width:220px;margin:12px auto 8px;text-decoration:none}.appdl-url{display:flex;gap:6px;max-width:320px;margin:0 auto}.appdl-url input{flex:1;min-width:0;padding:8px;border:1px solid var(--border);border-radius:8px;font-size:12px}.pos-layout{display:grid;grid-template-columns:140px 1fr 300px;gap:12px;align-items:start}.pos-cats{display:flex;flex-direction:column;gap:4px}.pos-products{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px}.pos-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:8px;cursor:pointer;text-align:center;color:var(--text);display:flex;flex-direction:column;gap:4px;align-items:center}.pos-card:hover{border-color:var(--primary)}.pos-card:active{transform:scale(.97)}.pos-card-img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:8px}.pos-card-ph{display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;color:#fff;background:var(--primary)}.pos-card-name{font-weight:600;font-size:14px;line-height:1.2}.pos-card-price{color:var(--primary);font-weight:700}.pos-card.sold-out,.order-item.sold-out{opacity:.45;cursor:not-allowed}.pos-cart{position:sticky;top:12px}.pos-cart label{display:block;font-size:13px;margin-bottom:8px}.pos-cart select,.pos-cart .cell-input{margin-top:4px;margin-bottom:8px}.cart-lines{max-height:320px;overflow:auto;margin:8px 0}.cart-line{display:flex;justify-content:space-between;gap:8px;font-size:14px;padding:6px 0;border-bottom:1px solid var(--border)}.qty{display:flex;align-items:center;gap:6px}.qty button{padding:2px 8px}.cart-total{font-weight:700;margin:8px 0;text-align:right}.modal-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;padding:16px;z-index:50}.modal{background:var(--card);border-radius:12px;padding:20px;width:360px;max-height:80vh;overflow:auto}.opt-pick{display:inline-block;margin:4px 6px 0 0;background:var(--bg);color:var(--text);border:1px solid var(--border)}.opt-pick.active{background:#fff3e8;color:var(--primary);border-color:var(--primary)}.order-shell{max-width:480px;margin:0 auto;min-height:100vh;background:var(--card);padding-bottom:180px}.order-head{position:sticky;top:0;background:var(--primary);color:#fff;padding:16px;font-size:18px;font-weight:700;z-index:10}.order-menu{padding:8px 16px}.order-cat h3{margin:16px 0 4px}.order-item{width:100%;display:flex;justify-content:space-between;align-items:center;gap:12px;background:none;color:var(--text);border:none;border-bottom:1px solid var(--border);padding:14px 0;text-align:left;cursor:pointer}.order-cart{position:fixed;bottom:0;left:0;right:0;max-width:480px;margin:0 auto;background:var(--card);border-top:1px solid var(--border);padding:12px 16px;box-shadow:0 -4px 12px #0000000f}.order-cart-lines{max-height:120px;overflow:auto}.order-fields{display:flex;gap:6px;margin:8px 0}.order-fields select,.order-fields input{flex:1;min-width:0;padding:8px;border:1px solid var(--border);border-radius:8px}.order-submit{width:100%;padding:14px;font-size:16px}.qr-card{max-width:420px;text-align:center}.qr-img{width:280px;height:280px}.qr-url{display:flex;gap:8px;margin:12px 0}.qr-url input{flex:1;padding:8px;border:1px solid var(--border);border-radius:8px;font-size:12px}.qr-actions{display:flex;gap:8px;justify-content:center}.qr-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}.qr-tile{border:1px solid var(--border);border-radius:10px;padding:10px;text-align:center}.qr-tile-title{font-weight:600}.qr-tile-img{width:100%;max-width:160px;height:auto;aspect-ratio:1;margin:6px 0}.qr-tile-actions{display:flex;flex-wrap:wrap;gap:4px;justify-content:center}.btn-secondary{background:var(--card);color:var(--primary);border:1px solid var(--primary)}.qr-mode{display:flex;gap:6px}.qr-mode-btn{background:var(--bg);color:#555;border:1.5px solid var(--border);border-radius:8px;padding:6px 14px;font-size:13px;cursor:pointer}.qr-mode-btn.active{background:#fff3e8;color:var(--primary);border-color:var(--primary);font-weight:700}.qr-mode-btn:disabled{opacity:.45;cursor:not-allowed}.kds-live{font-size:12px;color:#16a34a;vertical-align:middle}.kds-board{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.kds-col{background:var(--bg);border-radius:10px;padding:8px;min-height:200px}.kds-col-head{font-weight:700;padding:6px 8px}.kds-card{background:var(--card);border:1px solid var(--border);border-left:4px solid var(--border);border-radius:8px;padding:10px;margin-bottom:8px}.kds-card.kds-warn{border-left-color:#f59e0b}.kds-card.kds-late{border-left-color:#dc2626}.kds-card-head{display:flex;justify-content:space-between;align-items:center}.kds-time{font-size:12px;color:var(--muted)}.kds-time.kds-warn{color:#b45309;font-weight:600}.kds-time.kds-late{color:#dc2626;font-weight:700}.kds-meta{display:flex;flex-wrap:wrap;gap:6px;font-size:12px;color:var(--muted);margin:4px 0 6px}.kds-table{background:#fff3e8;color:#b5651d;border-radius:4px;padding:0 6px}.kds-paid{background:#dcfce7;color:#166534;border-radius:4px;padding:0 6px}.kds-unpaid{background:#fee2e2;color:#991b1b;border-radius:4px;padding:0 6px}.kds-items{margin:6px 0;padding:0;list-style:none;font-size:14px}.kds-items li{padding:4px 0;border-bottom:1px dashed var(--border)}.kds-item-line{font-weight:600}.kds-qty{color:var(--primary)}.kds-opts{font-size:13px;color:#555;margin-left:4px}.kds-note{font-size:12px;color:#b45309;margin-left:4px}.kds-pickup{background:#eef2ff;color:#4f46e5;border-radius:4px;padding:0 6px;font-weight:600}.kds-xtag{background:#f1f3f5;color:#555;border-radius:4px;padding:0 6px}.kds-onote{background:#fff7ed;color:#b45309;border:1px solid #fed7aa;border-radius:6px;padding:5px 8px;font-size:13px;font-weight:600;margin:4px 0 6px}.kds-btn{width:100%;margin-top:6px}.kds-empty{text-align:center;padding:16px}@media (max-width: 640px){.kds-board{grid-template-columns:1fr}}.row-low{background:#fff7ed}.hub-tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:16px}.hub-tab{background:none;color:var(--muted);border:none;border-bottom:2px solid transparent;border-radius:0;padding:10px 16px;font-size:15px}.hub-tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.range-tabs{display:flex;gap:4px}.stat{text-align:center}.stat-num{font-size:26px;font-weight:700}.prod-extra{margin-bottom:10px}.prod-thumb{width:44px;height:44px;border-radius:8px;object-fit:cover}.o-shell{max-width:480px;margin:0 auto;min-height:100vh;background:#fff;padding-bottom:84px}.o-center{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:#f5f6f8}.o-muted{color:#8b8f98}.o-sm{font-size:12px}.o-xs{font-size:11px;line-height:1;padding:0 2px}.o-pad{padding:16px}.o-warn{color:#b91c1c;padding:8px 16px}.o-top{position:sticky;top:0;z-index:20;background:#fff;box-shadow:0 1px #0000000d}.o-header{background:linear-gradient(135deg,#f5811f,#c25e0f);color:#fff;padding:14px 16px}.o-header-name{font-size:19px;font-weight:800}.o-header-sub{font-size:12px;opacity:.85;margin-top:2px}.o-tabs{display:flex;gap:8px;overflow-x:auto;padding:10px 12px;-webkit-overflow-scrolling:touch}.o-tabs::-webkit-scrollbar{display:none}.o-tab{flex:0 0 auto;background:#fff;color:#555;border:1px solid #e5e7eb;border-radius:999px;padding:8px 18px;font-size:15px;font-weight:500;cursor:pointer}.o-tab.active{background:#f5811f;color:#fff;border-color:#f5811f;font-weight:700}.o-search{padding:2px 14px 12px;display:flex;align-items:center;gap:8px;border-bottom:1px solid #f0f0f0}.o-search-icon{color:#9ca3af;font-size:15px}.o-search-input{flex:1;min-width:0;padding:8px 2px;border:none;border-bottom:1px solid #e5e7eb;font-size:15px;background:none}.o-search-input:focus{outline:none;border-color:#f5811f}.o-search-clear{flex:0 0 auto;width:28px;height:28px;border-radius:50%;border:none;background:#f1f3f5;color:#888;font-size:13px;cursor:pointer}.o-menu{padding:0 14px}.o-section{scroll-margin-top:8px;padding-top:6px}.o-cat-title{font-size:19px;font-weight:700;text-align:center;margin:22px 0 14px;color:#1f2430}.o-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px 12px}.o-card{display:flex;flex-direction:column;align-items:stretch;text-align:center;background:#fff;border:1px solid #f0f0f0;border-radius:14px;padding:8px 8px 12px;cursor:pointer}.o-card:active{background:#fafafa}.o-card.sold{opacity:.55}.o-card-imgwrap{position:relative;width:100%;margin-bottom:8px}.o-card-img{width:100%;aspect-ratio:1;border-radius:12px;object-fit:cover;background:#f1f3f5;display:block}.o-card-img-ph{display:flex;align-items:center;justify-content:center;font-size:42px;color:#c2c7cf;font-weight:700}.o-card-sold{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#0009;color:#fff;font-size:13px;border-radius:6px;padding:3px 10px}.o-card-name{font-size:15px;font-weight:600;color:#1f2430;line-height:1.35}.o-card-desc{font-size:12px;color:#9ca3af;line-height:1.4;margin:5px 0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.o-card-price{font-size:16px;color:#1f2430;margin-top:auto;padding-top:4px}.o-pickup{background:#fff7ef;border:2px solid #ffd9a8;border-radius:16px;padding:12px 18px;text-align:center}.o-pickup-label{font-size:13px;color:#b06a16;font-weight:600}.o-pickup-no{font-size:56px;font-weight:800;color:#e8590c;line-height:1.1}.o-pickup-sub{font-size:12px;color:#9ca3af}.si-body{padding:16px;max-width:520px;margin:0 auto}.si-row{display:flex;gap:12px;align-items:flex-start;background:#fff;border:1px solid #f0f0f0;border-radius:12px;padding:14px;margin-bottom:10px;text-decoration:none;color:#1f2430}.si-link:active{background:#fafafa}.si-ic{font-size:22px;line-height:1.3}.si-label{font-size:12px;color:#9ca3af;margin-bottom:2px}.si-val{font-size:15px;line-height:1.5}.si-cta{display:block;text-align:center;text-decoration:none;margin-top:6px}.si-status{font-size:12px;font-weight:700;border-radius:6px;padding:1px 8px;margin-left:8px}.si-open{background:#e7f8ef;color:#1f9d55}.si-closed{background:#fee2e2;color:#b91c1c}.si-status-sub{font-size:12px;color:#9ca3af;margin-top:2px}.snd-opts{display:flex;flex-wrap:wrap;gap:8px;margin:10px 0}.snd-opt{background:var(--bg);color:var(--text);border:1.5px solid var(--border);border-radius:999px;padding:8px 16px;font-size:14px;cursor:pointer}.snd-opt.active{background:#fff3e8;color:var(--primary);border-color:var(--primary);font-weight:700}.snd-row{display:flex;align-items:center;gap:10px}.snd-row select{padding:8px 10px;border:1px solid var(--border);border-radius:8px}.snd-test{margin-left:auto}.mo-body{padding:16px;max-width:520px;margin:0 auto}.mo-card{display:flex;gap:12px;align-items:center;background:#fff;border:1px solid #f0f0f0;border-radius:14px;padding:12px;margin-bottom:10px;text-decoration:none;color:#1f2430}.mo-card:active{background:#fafafa}.mo-pickup{flex:0 0 auto;width:74px;text-align:center;border-right:1px dashed #eee;padding-right:10px}.mo-pickup-label{font-size:11px;color:#b06a16}.mo-pickup-no{font-size:32px;font-weight:800;color:#e8590c;line-height:1.1}.mo-info{flex:1;min-width:0}.mo-top{display:flex;justify-content:space-between;align-items:center;gap:8px}.mo-no{font-size:13px;color:#6b7280}.mo-st{font-size:12px;font-weight:700;border-radius:10px;padding:2px 8px;white-space:nowrap}.st-new{background:#eef2ff;color:#4f46e5}.st-go{background:#fff4e5;color:#d9810a}.st-done{background:#e7f8ef;color:#1f9d55}.st-cancel{background:#f3f4f6;color:#9ca3af}.mo-items{margin:4px 0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mo-bottom{display:flex;justify-content:space-between;align-items:center}.o-announce-card{background:#fff7ef;border:1px solid #ffe0c2;border-radius:12px;padding:14px 16px;font-size:14px;line-height:1.6;color:#7c4a12}.o-reorder-list{display:flex;flex-direction:column;gap:10px}.o-reorder-card{display:flex;justify-content:space-between;gap:12px;border:1px solid #f0f0f0;border-radius:12px;padding:12px 14px}.o-reorder-meta{min-width:0}.o-reorder-no{font-weight:700;font-size:15px}.o-reorder-items{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:190px}.o-reorder-actions{flex:0 0 auto;display:flex;flex-direction:column;gap:6px;align-items:stretch;justify-content:center}.o-reorder-link{text-align:center;font-size:12px;color:#6b7280;text-decoration:none;border:1px solid #e5e7eb;border-radius:8px;padding:4px 10px}.o-reorder-btn{background:#f5811f;color:#fff;border:none;border-radius:8px;padding:7px 14px;font-size:13px;font-weight:700;cursor:pointer;white-space:nowrap}.o-bottombar{position:fixed;left:50%;transform:translate(-50%);bottom:0;width:100%;max-width:480px;background:#fff;border-top:1px solid #eee;padding:10px 16px calc(10px + env(safe-area-inset-bottom));display:flex;align-items:center;justify-content:space-between;gap:12px;z-index:30}.o-subtotal{font-size:15px;color:#6b7280}.o-subtotal b{font-size:20px;color:#9ca3af;margin-left:4px}.o-subtotal b.on{color:#f5811f}.o-confirm{background:#f5811f;color:#fff;border:none;border-radius:999px;padding:12px 32px;font-size:16px;font-weight:700;cursor:pointer}.o-confirm:disabled{background:#ddd2c4;cursor:default}.o-fab{position:fixed;right:16px;bottom:72px;width:54px;height:54px;border-radius:50%;background:#3a3a3a;color:#fff;border:none;font-size:22px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #0000004d;z-index:31;cursor:pointer}.o-fab-badge{position:absolute;top:-4px;right:-4px;background:#ef4444;color:#fff;border-radius:999px;min-width:22px;height:22px;line-height:22px;font-size:12px;font-weight:700;padding:0 5px}.o-sheet-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:40;display:flex;align-items:flex-end;justify-content:center}.o-sheet{background:#fff;width:100%;max-width:480px;border-radius:16px 16px 0 0;max-height:85vh;display:flex;flex-direction:column;animation:o-slideup .22s ease}@keyframes o-slideup{0%{transform:translateY(100%)}to{transform:translateY(0)}}.o-sheet-head{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid #eee;font-weight:700}.o-sheet-close{background:none;border:none;font-size:18px;color:#888}.o-sheet-body{padding:16px 16px calc(16px + env(safe-area-inset-bottom));overflow-y:auto;flex:1 1 auto;min-height:0;-webkit-overflow-scrolling:touch}.o-optgroup{margin-bottom:16px}.o-optgroup-title{font-size:14px;font-weight:600;margin-bottom:8px}.o-req{background:#fee2e2;color:#991b1b;font-size:11px;border-radius:5px;padding:1px 6px}.o-optchips{display:flex;flex-wrap:wrap;gap:8px}.o-chip{background:#f1f3f5;color:#444;border:1.5px solid transparent;border-radius:10px;padding:8px 14px;font-size:14px}.o-chip.active{background:#fff3e8;color:#f5811f;border-color:#f5811f;font-weight:600}.o-cart-lines{margin-bottom:12px}.o-cart-line{display:flex;justify-content:space-between;gap:10px;padding:10px 0;border-bottom:1px solid #f0f0f0;font-size:14px}.o-qty{display:flex;align-items:center;gap:8px}.o-qty button{width:28px;height:28px;border-radius:8px;background:#f1f3f5;border:none;font-size:16px}.o-del{width:auto!important;padding:0 8px;color:#b91c1c;background:none!important;font-size:12px!important}.o-fields{display:flex;gap:8px;margin-bottom:12px}.o-fields select,.o-fields input{flex:1;min-width:0;padding:10px;border:1px solid #ddd;border-radius:10px;font-size:14px}.o-pick{display:flex;gap:8px;margin-bottom:8px}.o-seg{flex:1;background:#f1f3f5;color:#555;border:1.5px solid transparent;border-radius:10px;padding:11px;font-size:15px;font-weight:600;cursor:pointer}.o-seg.active{background:#fff3e8;color:#f5811f;border-color:#f5811f}.o-datetime{width:100%;padding:11px;border:1px solid #ddd;border-radius:10px;font-size:15px;margin-bottom:10px}.o-toggle{display:flex;align-items:center;justify-content:space-between;padding:11px 12px;background:#f8f9fa;border-radius:10px;margin-bottom:8px;font-size:15px}.o-toggle input{width:20px;height:20px;accent-color:#f5811f}.o-note{width:100%;padding:11px;border:1px solid #ddd;border-radius:10px;font-size:14px;resize:vertical;margin-bottom:12px;font-family:inherit}.o-btn{background:#f5811f;color:#fff;border:none;border-radius:12px;padding:14px;font-size:16px;font-weight:600;width:100%;cursor:pointer}.o-btn:disabled{opacity:.5}.o-submit{margin-top:4px}.o-modal-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:40;display:flex;align-items:center;justify-content:center;padding:24px 20px}.o-modal{position:relative;background:#fff;width:100%;max-width:360px;max-height:88vh;border-radius:18px;display:flex;flex-direction:column;animation:o-pop .18s ease}@keyframes o-pop{0%{transform:scale(.94);opacity:0}to{transform:scale(1);opacity:1}}.o-modal-close{position:absolute;top:-14px;right:-14px;width:40px;height:40px;border-radius:50%;background:#fff;border:none;font-size:17px;color:#555;box-shadow:0 2px 8px #0003;cursor:pointer;z-index:1}.o-modal-body{padding:22px 20px 6px;overflow-y:auto;flex:1 1 auto;min-height:0;-webkit-overflow-scrolling:touch}.o-modal-img{width:100%;aspect-ratio:1;max-height:240px;object-fit:cover;border-radius:12px;display:block}.o-modal-img-ph{display:flex;align-items:center;justify-content:center;font-size:56px;color:#c2c7cf;font-weight:700;background:#f1f3f5}.o-modal-name{font-size:18px;font-weight:700;margin-top:16px;color:#1f2430}.o-modal-price{font-size:18px;font-weight:700;color:#1f2430;margin-top:4px}.o-modal-hr{border:none;border-top:1px solid #eee;margin:14px 0}.o-modal-desc{font-size:14px;color:#6b7280;line-height:1.6;margin:0 0 14px}.o-modal-qty{display:flex;align-items:center;justify-content:center;gap:18px;margin:18px 0 8px}.o-stepper{width:44px;height:44px;border-radius:50%;background:#ededed;border:none;font-size:20px;color:#444;cursor:pointer}.o-stepper-n{min-width:72px;text-align:center;font-size:18px;font-weight:700;border:1px solid #e5e7eb;border-radius:999px;padding:8px 0}.o-modal-foot{display:flex;gap:10px;padding:8px 20px calc(20px + env(safe-area-inset-bottom));flex:0 0 auto}.o-modal-back{flex:1;background:#9ca3af;color:#fff;border:none;border-radius:999px;padding:13px;font-size:16px;font-weight:700;cursor:pointer}.o-modal-ok{flex:1.5;background:#f5811f;color:#fff;border:none;border-radius:999px;padding:13px;font-size:16px;font-weight:700;cursor:pointer}.o-modal-ok:disabled{background:#ddd2c4;font-size:14px}.ost-body{padding:20px 16px}.ost-steps{display:flex;justify-content:space-between;position:relative;margin:20px 0}.ost-steps:before{content:"";position:absolute;top:16px;left:12%;right:12%;height:2px;background:#e5e7eb;z-index:0}.ost-step{display:flex;flex-direction:column;align-items:center;gap:6px;z-index:1;flex:1}.ost-dot{width:34px;height:34px;border-radius:50%;background:#e5e7eb;color:#9ca3af;display:flex;align-items:center;justify-content:center;font-weight:700}.ost-step.done .ost-dot{background:#16a34a;color:#fff}.ost-step.current .ost-dot{background:#f5811f;color:#fff;box-shadow:0 0 0 4px #f5811f33}.ost-label{font-size:13px;color:#6b7280}.ost-step.done .ost-label,.ost-step.current .ost-label{color:#1f2430;font-weight:600}.ost-ready{background:#dcfce7;color:#166534;text-align:center;padding:14px;border-radius:12px;font-weight:700;margin:8px 0}.ost-cancelled{background:#fee2e2;color:#991b1b;text-align:center;padding:14px;border-radius:12px;font-weight:700}.ost-meta{display:flex;gap:10px;font-size:13px;color:#6b7280;margin-bottom:8px}.o-done{background:#fff;border-radius:16px;padding:32px 24px;text-align:center;max-width:320px}.o-done-emoji{font-size:48px}.o-done-no{font-size:22px;font-weight:800;margin:4px 0}.bell-btn{background:none;border:1px solid var(--border);border-radius:8px;padding:5px 9px;font-size:16px;line-height:1}.bell-btn.on{border-color:var(--primary);background:#fff3e8}.alert-cta{display:block;width:100%;background:#fff7ed;color:#b45309;border:none;border-bottom:1px solid #fde6c8;border-radius:0;padding:9px 16px;font-size:13px;font-weight:600;text-align:center;cursor:pointer}.no-toast{position:fixed;top:12px;left:50%;transform:translate(-50%);width:calc(100% - 24px);max-width:440px;display:flex;align-items:center;gap:10px;background:#1f2430;color:#fff;border-radius:12px;padding:12px 14px;box-shadow:0 8px 24px #00000040;z-index:100;animation:no-drop .22s ease}@keyframes no-drop{0%{transform:translate(-50%,-16px);opacity:0}to{transform:translate(-50%);opacity:1}}.no-toast-ic{font-size:22px}.no-toast-body{flex:1;min-width:0}.no-toast-title{font-weight:700;font-size:15px}.no-toast-sub{font-size:12px;opacity:.8}.no-toast-link{flex:0 0 auto;background:var(--primary);color:#fff;text-decoration:none;border-radius:8px;padding:7px 14px;font-size:13px;font-weight:700}.no-toast-close{flex:0 0 auto;background:none;color:#aab;font-size:14px;padding:4px 6px}.topbar-title,.tabbar{display:none}.tabbar-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:7px 2px 5px;background:none;border:none;color:#98a0ab;text-decoration:none;cursor:pointer}.tabbar-item.active{color:var(--primary)}.tabbar-item span{font-size:11px;line-height:1}.tabbar-item:active{background:#faf7f3}.ms-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:60;display:flex;align-items:flex-end}.ms-sheet{background:#fff;width:100%;max-height:88vh;border-radius:18px 18px 0 0;display:flex;flex-direction:column;animation:o-slideup .24s ease}.ms-grab{width:40px;height:4px;border-radius:2px;background:#e0e3e8;margin:8px auto 4px;flex:0 0 auto}.ms-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;padding:6px 18px 12px;border-bottom:1px solid var(--border)}.ms-title{font-size:17px;font-weight:800}.ms-sub{font-size:12px;color:var(--muted);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ms-close{background:#f1f3f5;border:none;border-radius:50%;width:34px;height:34px;display:flex;align-items:center;justify-content:center;color:#555;flex:0 0 auto}.ms-scroll{overflow-y:auto;padding:12px 16px calc(20px + env(safe-area-inset-bottom))}.ms-group{margin-bottom:16px}.ms-group-title{font-size:12px;color:var(--muted);letter-spacing:.05em;margin-bottom:8px}.ms-select{width:100%;padding:12px;border:1px solid var(--border);border-radius:10px;font-size:15px}.ms-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.ms-item{display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center;text-decoration:none;color:var(--text);background:var(--bg);border-radius:12px;padding:14px 6px;font-size:12px;line-height:1.3}.ms-item:active{background:#fff3e8}.ms-item-ic{color:var(--primary)}.ms-footer{display:flex;flex-direction:column;gap:8px;margin-top:4px}.ms-foot-btn{display:flex;align-items:center;justify-content:center;gap:6px;padding:13px;border-radius:10px;border:1px solid var(--border);background:#fff;color:var(--text);text-decoration:none;font-size:14px}.ms-logout{color:var(--warn);border-color:#f3c8c8}.ord-cards{display:flex;flex-direction:column;gap:10px}.ord-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:14px;box-shadow:0 1px 3px #0000000a}.ord-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.ord-card-no{font-size:22px;font-weight:800;color:#1f2430;line-height:1.1}.ord-card-pills{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}.ord-card-meta{display:flex;flex-wrap:wrap;align-items:center;gap:6px;color:var(--muted);font-size:13px;margin:8px 0}.ord-card-amt{margin-left:auto;color:var(--text);font-weight:700;font-size:15px}.ord-card-items-btn{background:none;border:none;color:var(--primary);font-size:13px;padding:4px 0;cursor:pointer}.ord-card-items{background:var(--bg);border-radius:8px;padding:8px 10px;font-size:13px;margin:2px 0 8px;line-height:1.6}.ord-card-actions{gap:6px;flex-wrap:wrap;border-top:1px solid var(--border);padding-top:10px;margin-top:6px}.ord-card-actions .btn-link{background:var(--bg);border-radius:8px;padding:9px 14px;font-size:14px}.ord-card-actions .btn-link.danger{background:#fef2f2}.pos-mcats{display:flex;gap:8px;overflow-x:auto;padding:2px 0 12px;-webkit-overflow-scrolling:touch;position:sticky;top:0;background:var(--bg);z-index:5}.pos-mcats::-webkit-scrollbar{display:none}.pos-mcat{flex:0 0 auto;background:#fff;border:1px solid var(--border);border-radius:999px;padding:8px 16px;font-size:14px;color:#555}.pos-mcat.active{background:var(--primary);color:#fff;border-color:var(--primary);font-weight:700}.pos-mproducts{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding-bottom:80px}.pos-mbar{position:fixed;left:0;right:0;bottom:calc(56px + env(safe-area-inset-bottom));display:flex;align-items:center;gap:12px;background:#fff;border-top:1px solid var(--border);padding:10px 14px;z-index:44;box-shadow:0 -2px 10px #0000000f}.pos-mbar-info{display:flex;flex-direction:column;line-height:1.2;flex:0 0 auto}.pos-mbar-count{font-size:12px;color:var(--muted)}.pos-mbar-total{font-size:20px;font-weight:800;color:var(--primary)}.pos-mbar-btn{flex:1;background:var(--primary);color:#fff;border:none;border-radius:12px;padding:14px;font-size:16px;font-weight:700}.pos-mbar-btn:disabled{background:#ddd2c4}.pos-sheet-bg{z-index:60}.pos-sheet-body label{display:block;font-size:13px;margin-bottom:8px}.pos-sheet-body select,.pos-sheet-body .cell-input{width:100%;margin-top:4px;margin-bottom:10px;padding:10px;border:1px solid var(--border);border-radius:8px}.pos-sheet-body .cart-total{margin:12px 0}.pos-sheet-body>button{width:100%;padding:14px;font-size:16px}.skel-list{display:flex;flex-direction:column;gap:12px}.skel-row{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:16px;display:flex;flex-direction:column;gap:10px}.skel-line{height:14px;border-radius:6px;background:linear-gradient(90deg,#eef0f2 25%,#e1e5ea 37%,#eef0f2 63%);background-size:400% 100%;animation:skel-shimmer 1.4s ease infinite}.skel-line-sm{height:11px}@keyframes skel-shimmer{0%{background-position:100% 50%}to{background-position:0 50%}}.inv-mlist{display:flex;flex-direction:column;gap:8px}.inv-mrow{display:flex;align-items:center;gap:12px;background:var(--card);border:1px solid var(--border);border-radius:12px;padding:12px}.inv-mrow.inv-low{border-left:3px solid var(--warn)}.inv-mstock{flex:0 0 auto;min-width:42px;text-align:center}.inv-mstock b{font-size:22px}.inv-mmain{flex:1;min-width:0}.inv-mname{font-weight:600;display:flex;align-items:center;gap:6px}.inv-mmeta{display:flex;flex-wrap:wrap;align-items:center;gap:10px;font-size:13px;margin-top:4px}.inv-mtrack{display:inline-flex;align-items:center;gap:4px}.inv-msafe{width:56px;padding:4px 6px}.inv-madjust{flex:0 0 auto;padding:8px 12px}@media (max-width: 768px){.topbar{height:auto;min-height:52px;gap:8px;padding:max(env(safe-area-inset-top),8px) 12px 8px}.brand-logo{display:none}.topbar-title{display:block;font-size:17px;font-weight:700;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.topbar-right{gap:8px}.merchant-select,.topbar-merchant,.topbar-email,.topbar-platform,.topbar-logout,.badge,.sidebar{display:none}.tabbar{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:45;background:#fff;border-top:1px solid var(--border);padding-bottom:env(safe-area-inset-bottom);box-shadow:0 -2px 10px #0000000d}.content{padding:14px 12px calc(74px + env(safe-area-inset-bottom))}.content h1{font-size:20px}.page-head{flex-wrap:wrap;gap:8px}.no-toast{top:max(env(safe-area-inset-top),12px)}table.table{display:block;overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch}.hub-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap}.hub-tab{flex:0 0 auto}.pos-layout{grid-template-columns:1fr}.pos-cats{flex-direction:row;flex-wrap:wrap}.pos-cart{position:static}.pos-products{grid-template-columns:repeat(auto-fill,minmax(96px,1fr))}.two-col{grid-template-columns:1fr}.modal{width:100%}}.bill-plan-row{display:flex;flex-wrap:wrap;align-items:center;gap:10px 14px}.bill-plan-code{font-family:monospace;font-size:13px;background:#f1f3f5;border-radius:6px;padding:3px 8px;color:#555}.bill-inline{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:#6b7280}.bill-inline input{padding:6px 8px;border:1px solid #ddd;border-radius:8px;font-size:14px}.bill-check{display:inline-flex;align-items:center;gap:4px;font-size:14px}.bill-feat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:6px 16px;margin-top:14px;padding-top:14px;border-top:1px solid #eee;max-height:360px;overflow-y:auto}.bill-feat{display:flex;align-items:center;gap:8px;font-size:13px}.bill-feat small{font-size:11px}.bill-status-btns{display:flex;flex-wrap:wrap;align-items:center;gap:12px;margin-top:12px}.bill-add{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}.bill-add input{padding:8px 10px;border:1px solid #ddd;border-radius:8px;font-size:14px}.btn-link.danger{color:#b91c1c}.export-btns{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}.legal-wrap{min-height:100vh;background:#f5f6f8;padding:24px 16px}.legal-card{max-width:720px;margin:0 auto;background:#fff;border-radius:14px;padding:28px 26px;line-height:1.7}.legal-card h1{margin:0 0 4px}.legal-card h3{margin:20px 0 4px;font-size:16px}.legal-card p{color:#374151;margin:4px 0}.legal-foot{margin-top:24px;font-size:12px}.login-legal{text-align:center;font-size:12px;margin-top:14px}.login-legal a,.o-consent a{color:#f5811f;text-decoration:none}.o-consent{text-align:center;font-size:12px;color:#9ca3af;margin:10px 0 2px}.line-status{margin:4px 0 0;padding-left:0;list-style:none;line-height:1.9}.line-check{display:flex;align-items:center;gap:8px}.analytics-range{display:flex;flex-wrap:wrap;align-items:center;gap:12px}.analytics-range input{padding:7px 10px;border:1px solid #ddd;border-radius:8px}.kpi-row{display:flex;flex-wrap:wrap;gap:12px;margin:12px 0}.kpi-card{flex:1;min-width:120px;background:#fff;border:1px solid #eee;border-radius:12px;padding:16px;text-align:center}.kpi-val{font-size:24px;font-weight:800;color:#1f2430}.kpi-label{font-size:13px;color:#8b8f98;margin-top:4px}.insight-list{line-height:1.9;margin:6px 0 12px;padding-left:20px}.ai-btn{background:linear-gradient(135deg,#a855f7,#6366f1);color:#fff;border:none;border-radius:10px;padding:10px 18px;font-weight:600;cursor:not-allowed;opacity:.7}.pill{display:inline-block;font-size:12px;font-weight:700;border-radius:999px;padding:3px 10px;white-space:nowrap}.pill-new{background:#eef2ff;color:#4f46e5}.pill-go{background:#fff4e5;color:#d9810a}.pill-done{background:#e7f8ef;color:#1f9d55}.pill-cancel{background:#f3f4f6;color:#9ca3af}.pill-warn{background:#fee2e2;color:#b91c1c}.nav-link{display:flex;align-items:center;gap:10px}.nav-ic{flex:0 0 auto;opacity:.8}.nav-link.active .nav-ic{opacity:1}.dash-greet{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:16px;flex-wrap:wrap}.dash-greet h1{margin:0 0 2px}.dash-pending{display:inline-flex;align-items:center;gap:8px;background:#fff4e5;color:#d9810a;text-decoration:none;border:1px solid #ffe0bf;border-radius:12px;padding:8px 14px;font-weight:700}.dash-pending-n{font-size:22px;line-height:1}.dash-pending span{display:inline-flex;align-items:center;gap:4px}.kpi-hot{color:#d9810a}.dash-alert{display:flex;align-items:center;gap:10px;background:#fff7ed;border:1px solid #fed7aa;color:#b45309;border-radius:12px;padding:12px 16px;margin-bottom:16px;text-decoration:none;font-size:14px}.dash-alert b{font-size:16px}.dash-alert .muted{margin-left:6px}.dash-alert-arrow{margin-left:auto;flex:0 0 auto}.dash-h2{font-size:16px;margin:18px 0 10px;color:#374151}.dash-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}.dash-tile{display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center;text-decoration:none;color:var(--text);background:var(--card);border:1px solid var(--border);border-radius:14px;padding:22px 12px;transition:border-color .15s,box-shadow .15s,transform .05s}.dash-tile:hover{border-color:var(--primary);box-shadow:0 4px 14px #f5811f1a}.dash-tile:active{transform:scale(.98)}.dash-tile-ic{color:var(--primary)}.setup-card{border:1px solid #ffe0bf;background:#fff9f3}.setup-title{font-size:17px;font-weight:700;margin-bottom:12px}.setup-list{display:flex;flex-direction:column;gap:8px}.setup-item{display:flex;align-items:center;gap:10px;padding:12px 14px;border:1px solid var(--border);border-radius:10px;background:#fff;text-decoration:none;color:var(--text);font-weight:600}.setup-item.done{color:var(--muted);font-weight:400;background:#fafbfc}.setup-item:hover{border-color:var(--primary)}.setup-ic{color:#c7ccd3;flex:0 0 auto}.setup-ic-done{color:#16a34a;flex:0 0 auto}
