:root{--primary: #e85d3a;--primary-light: #fff0ec;--primary-dark: #c44528;--success: #22c55e;--warning: #f59e0b;--bg: #f8f6f3;--card: #ffffff;--text: #2d2d2d;--text-secondary: #888;--border: #eee;--shadow: 0 2px 12px rgba(0, 0, 0, .06);--radius: 12px;--radius-sm: 8px;--header-h: 56px;--cart-h: 60px;--sidebar-w: 80px}*{margin:0;padding:0;box-sizing:border-box}html,body{font-family:Noto Sans,Noto Sans Thai,Noto Sans SC,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent;overscroll-behavior:none;height:100%;overflow:hidden}#root{height:100%}.app{display:flex;flex-direction:column;height:100%;max-width:480px;margin:0 auto;background:var(--bg);position:relative;overflow:hidden}.header{height:var(--header-h);padding:0 16px;background:var(--card);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;z-index:100}.header-left{display:flex;flex-direction:column;gap:1px}.header-brand{font-size:16px;font-weight:700;color:var(--text);display:flex;align-items:center;gap:6px}.header-icon{flex-shrink:0;color:var(--primary)}.header-info{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-secondary)}.header-divider{color:#ddd}.header-order-no{color:var(--primary);font-weight:600}.header-auto-login{font-size:11px;color:var(--success);background:#f0fdf4;padding:4px 10px;border-radius:20px;white-space:nowrap;border:none;font-family:inherit;cursor:pointer;transition:all .15s}.header-auto-login:active{background:#dcfce7;transform:scale(.95)}.lang-switcher{position:fixed;top:10px;right:16px;z-index:200;background:#fffffff2;border:1px solid var(--border);border-radius:20px;padding:4px 10px;font-size:12px;cursor:pointer;font-family:inherit;color:var(--text-secondary);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .2s}.lang-switcher:active{background:var(--primary-light)}.search-bar{display:flex;align-items:center;margin:8px 12px;padding:8px 14px;background:var(--card);border-radius:var(--radius);border:1.5px solid var(--border);gap:8px;flex-shrink:0}.search-icon{font-size:16px;opacity:.5}.search-input{flex:1;border:none;outline:none;font-size:14px;font-family:inherit;background:transparent;color:var(--text)}.search-input::placeholder{color:#bbb}.search-clear{background:none;border:none;font-size:14px;color:#ccc;cursor:pointer;padding:2px 6px}.menu-layout{display:flex;flex:1;overflow:hidden;min-height:0}.menu-layout.compact{flex:none;height:400px;border-top:1px solid var(--border)}.category-sidebar{width:var(--sidebar-w);background:var(--card);overflow-y:auto;overflow-x:hidden;flex-shrink:0;border-right:1px solid var(--border);-webkit-overflow-scrolling:touch;scrollbar-width:none}.category-sidebar::-webkit-scrollbar{display:none}.cat-item{display:flex;flex-direction:column;align-items:center;gap:2px;width:100%;padding:12px 4px;border:none;background:transparent;cursor:pointer;font-family:inherit;position:relative;transition:background .15s;border-left:3px solid transparent}.cat-item.active{background:var(--primary-light);border-left-color:var(--primary)}.cat-item:active{background:#fdf2f0}.cat-icon{font-size:18px}.cat-name{font-size:10px;font-weight:500;color:var(--text);text-align:center;line-height:1.3;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cat-item.active .cat-name{color:var(--primary);font-weight:700}.cat-count{font-size:10px;color:var(--text-secondary);background:#f5f5f5;padding:1px 6px;border-radius:10px;min-width:20px;text-align:center}.cat-item.active .cat-count{background:var(--primary);color:#fff}.menu-grid{flex:1;overflow-y:auto;overflow-x:hidden;padding:8px 10px;-webkit-overflow-scrolling:touch;scroll-behavior:smooth}.cat-section-header{font-size:15px;font-weight:700;padding:10px 4px 6px;color:var(--text);display:flex;align-items:center;gap:4px}.cat-section-count{font-size:12px;color:var(--text-secondary);font-weight:400}.menu-items{display:grid;grid-template-columns:1fr 1fr;gap:10px}.menu-grid-bottom{height:80px}.menu-card{background:var(--card);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);cursor:pointer;transition:transform .15s,box-shadow .15s;display:flex;flex-direction:column}.menu-card:active{transform:scale(.97);box-shadow:0 1px 6px #00000014}.menu-card-img{width:100%;aspect-ratio:4/3;background:linear-gradient(135deg,#fff5f0,#fff0ec);display:flex;align-items:center;justify-content:center;overflow:hidden}.menu-card-emoji{font-size:48px;transition:transform .2s}.menu-card:active .menu-card-emoji{transform:scale(1.1)}.menu-card-body{padding:8px 10px 10px;flex:1;display:flex;flex-direction:column}.menu-card-name{font-size:13px;font-weight:600;color:var(--text);margin-bottom:2px;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.menu-card-desc{font-size:11px;color:var(--text-secondary);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:6px}.menu-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto}.menu-card-price{font-size:15px;font-weight:700;color:var(--primary)}.menu-card-btn{width:32px;height:32px;border-radius:50%;border:2px solid var(--primary);background:var(--primary);color:#fff;font-size:18px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}.menu-card-btn.has-item{background:#fff;color:var(--primary);border:2px solid var(--primary)}.menu-card-btn:active{transform:scale(.9)}.btn-in-cart{font-size:12px;font-weight:700}.btn-add{font-size:20px;line-height:1}.cart-float{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;padding:8px 12px;padding-bottom:max(8px,env(safe-area-inset-bottom));z-index:150;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translate(-50%) translateY(100%);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.cart-float-btn{width:100%;display:flex;align-items:center;justify-content:space-between;padding:14px 18px;background:var(--primary);color:#fff;border:none;border-radius:var(--radius);font-size:15px;font-weight:700;font-family:inherit;cursor:pointer;box-shadow:0 4px 20px #e85d3a59;transition:all .15s}.cart-float-btn:active{background:var(--primary-dark);transform:scale(.98)}.cart-float-left{display:flex;align-items:center;gap:8px}.cart-float-left svg{opacity:.9}.cart-float-count{background:#ffffff40;padding:2px 8px;border-radius:12px;font-size:13px;min-width:24px;text-align:center}.cart-float-label{font-size:12px;opacity:.9}.cart-float-right{display:flex;align-items:center;gap:6px}.cart-float-total{font-size:16px}.cart-float-arrow{font-size:18px}.spec-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:300;display:flex;align-items:flex-end;justify-content:center;animation:fadeIn .2s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.spec-dialog{background:#fff;width:100%;max-width:480px;border-radius:20px 20px 0 0;padding:20px 16px 24px;padding-bottom:max(24px,env(safe-area-inset-bottom));animation:slideUpDialog .3s ease-out;max-height:80vh;overflow-y:auto}@keyframes slideUpDialog{0%{transform:translateY(100%)}to{transform:translateY(0)}}.spec-header{display:flex;align-items:center;gap:10px;margin-bottom:16px}.spec-emoji{font-size:28px}.spec-header h3{flex:1;font-size:18px;font-weight:700}.spec-price{font-size:18px;font-weight:700;color:var(--primary)}.spec-section{margin-bottom:16px}.spec-label{display:block;font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:8px}.spec-spice-options{display:flex;gap:8px}.spice-btn{flex:1;padding:10px 4px;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:#fff;font-size:13px;font-family:inherit;cursor:pointer;transition:all .15s;text-align:center}.spice-btn.active{background:var(--primary-light);border-color:var(--primary);color:var(--primary);font-weight:600}.spec-addons{display:flex;flex-direction:column;gap:6px}.addon-btn{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:#fff;font-size:14px;font-family:inherit;cursor:pointer;transition:all .15s}.addon-btn.active{background:#f0fdf4;border-color:var(--success)}.addon-price{font-size:13px;color:var(--primary);font-weight:600}.spec-remark{width:100%;padding:10px 14px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:14px;font-family:inherit;outline:none;transition:border-color .15s}.spec-remark:focus{border-color:var(--primary)}.spec-footer{display:flex;gap:10px;margin-top:20px}.btn-cancel{flex:1;padding:14px;border:1.5px solid var(--border);border-radius:var(--radius);background:#fff;font-size:15px;font-family:inherit;cursor:pointer;font-weight:500}.btn-confirm{flex:2;padding:14px;border:none;border-radius:var(--radius);background:var(--primary);color:#fff;font-size:15px;font-weight:700;font-family:inherit;cursor:pointer;transition:all .15s}.btn-confirm:active{background:var(--primary-dark)}.order-confirm-page{flex:1;overflow-y:auto;padding:0 12px 80px}.order-confirm-header{display:flex;align-items:center;gap:12px;padding:12px 0}.order-confirm-header h2{font-size:18px;font-weight:700}.btn-back{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:6px 12px;font-size:14px;font-family:inherit;cursor:pointer;color:var(--text-secondary)}.order-items{display:flex;flex-direction:column;gap:4px}.order-item{display:flex;flex-wrap:wrap;align-items:baseline;gap:8px;padding:10px 12px;background:var(--card);border-radius:var(--radius-sm)}.order-item-left{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.order-item-name{font-size:14px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.order-item-qty{font-size:12px;color:var(--text-secondary);font-weight:600}.order-item-price{font-size:14px;font-weight:700;color:var(--text);white-space:nowrap}.order-item-details{width:100%;display:flex;flex-wrap:wrap;gap:4px;padding-left:4px}.order-item-tag{font-size:11px;padding:2px 8px;border-radius:4px;background:#f5f5f5;color:var(--text-secondary)}.spice-tag{background:#fff5f0;color:var(--primary)}.addon-tag{background:#f0fdf4;color:var(--success)}.remark-tag{background:#fefce8;color:#a16207}.order-item.is-new{border-left:2px solid var(--border);background:#fafafa}.batch-group{margin-top:6px}.batch-separator{display:flex;align-items:center;gap:10px;padding:8px 4px 4px}.batch-sep-line{flex:1;height:1px;background:#e5e5e5}.batch-sep-text{font-size:11px;font-weight:500;color:#aaa;white-space:nowrap;letter-spacing:.3px}.order-total-line{display:flex;justify-content:space-between;align-items:center;padding:12px;margin-top:8px;font-size:16px;font-weight:600}.order-total-price{font-size:20px;color:var(--primary);font-weight:700}.order-form{margin-top:12px;display:flex;flex-direction:column;gap:8px}.order-label{font-size:13px;font-weight:600;color:var(--text-secondary)}.order-optional{font-size:11px;font-weight:400;color:#aaa}.order-input{width:100%;padding:12px 14px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:15px;font-family:inherit;outline:none}.order-input:focus{border-color:var(--primary)}.order-confirm-footer{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;padding:12px;padding-bottom:max(12px,env(safe-area-inset-bottom));z-index:150;background:linear-gradient(transparent,var(--bg) 30%)}.btn-confirm-order{width:100%;padding:16px;background:var(--primary);color:#fff;border:none;border-radius:var(--radius);font-size:16px;font-weight:700;font-family:inherit;cursor:pointer;transition:all .15s;box-shadow:0 4px 20px #e85d3a59}.btn-confirm-order:disabled{background:#ddd;color:#999;cursor:not-allowed;box-shadow:none}.btn-confirm-order:not(:disabled):active{background:var(--primary-dark);transform:scale(.98)}.tracking-page{flex:1;display:flex;flex-direction:column;overflow-y:auto;padding-bottom:80px;min-height:0}.tracking-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:40px}.tracking-empty-icon{font-size:64px}.tracking-empty p{font-size:15px;color:var(--text-secondary)}.btn-primary{padding:12px 32px;background:var(--primary);color:#fff;border:none;border-radius:var(--radius);font-size:16px;font-weight:600;font-family:inherit;cursor:pointer}.tracking-card{margin:12px;padding:20px 16px;background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow)}.tracking-status-bar{display:flex;align-items:flex-start;justify-content:space-between}.status-step{display:flex;flex-direction:column;align-items:center;gap:6px;position:relative;flex:1}.status-dot{width:36px;height:36px;border-radius:50%;background:#f0f0f0;display:flex;align-items:center;justify-content:center;font-size:16px;z-index:1;transition:all .3s}.status-step.done .status-dot{background:var(--success);color:#fff}.status-step.current .status-dot{background:var(--primary);color:#fff;animation:pulse 1.5s infinite}@keyframes pulse{0%,to{box-shadow:0 0 #e85d3a66}50%{box-shadow:0 0 0 8px #e85d3a00}}.status-label{font-size:11px;color:var(--text-secondary);text-align:center;white-space:nowrap}.status-step.current .status-label{color:var(--primary);font-weight:700}.status-line{position:absolute;top:18px;left:calc(50% + 18px);width:calc(100% - 36px);height:3px;background:#f0f0f0;z-index:0}.status-line.done{background:var(--success)}.tracking-wait{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:16px;padding-top:12px;border-top:1px solid var(--border);font-size:14px;font-weight:500;color:var(--text-secondary)}.wait-dot-pulse{width:8px;height:8px;background:var(--warning);border-radius:50%;animation:blink 1s infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.tracking-section{margin:0 12px 8px;padding:12px;background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow)}.tracking-continue{padding:0 12px;margin:8px 0}.btn-continue-order{width:100%;padding:16px;background:linear-gradient(135deg,var(--primary),#ff7b52);color:#fff;border:none;border-radius:var(--radius);font-size:16px;font-weight:700;font-family:inherit;cursor:pointer;box-shadow:0 4px 16px #e85d3a4d;transition:all .15s}.btn-continue-order:active{transform:scale(.97);box-shadow:0 2px 8px #e85d3a33}.tracking-search-bar{display:flex;align-items:center;margin:8px 12px;padding:8px 14px;background:var(--card);border-radius:var(--radius);border:1.5px solid var(--border);gap:8px}.tracking-menu{height:calc(100vh - 340px);min-height:300px;border-top:1px solid var(--border)}.new-items-bar{display:flex;align-items:center;justify-content:space-between;margin:0 12px 8px;padding:12px 16px;background:var(--primary-light);border:1.5px solid var(--primary);border-radius:var(--radius);font-size:14px;font-weight:500;color:var(--primary)}.btn-confirm-add{padding:8px 20px;background:var(--primary);color:#fff;border:none;border-radius:20px;font-size:14px;font-weight:700;font-family:inherit;cursor:pointer;transition:all .15s}.btn-confirm-add:active{background:var(--primary-dark)}.tracking-section h3{font-size:14px;font-weight:700;margin-bottom:8px;color:var(--text)}.new-items-section{border:2px dashed var(--primary);background:var(--primary-light)}.btn-add-order{width:100%;margin-top:8px;padding:12px;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:600;font-family:inherit;cursor:pointer}.add-more-banner{margin:12px;padding:14px 16px;background:#fffbeb;border:1px dashed var(--warning);border-radius:var(--radius);display:flex;align-items:center;gap:8px;font-size:14px;cursor:pointer;transition:all .15s}.add-more-banner:active{background:#fef3c7}.add-more-arrow{margin-left:auto;color:var(--warning)}.bind-section{margin:0 12px 8px}.bind-label{display:block;font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.bind-phone-input{flex:1;min-width:0;padding:10px 12px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:14px;font-family:inherit;outline:none;transition:border-color .15s}.bind-phone-input:focus{border-color:var(--primary)}.bind-phone-input::placeholder{color:#ccc;font-size:13px}.tracking-actions{margin:12px;display:flex;gap:10px}.btn-reorder{flex:1;padding:14px;background:var(--card);border:2px solid var(--primary);border-radius:var(--radius);color:var(--primary);font-size:15px;font-weight:600;font-family:inherit;cursor:pointer}.empty-search{text-align:center;padding:40px;color:var(--text-secondary);font-size:15px}.main-content,.menu-page{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}.adding-banner{display:flex;align-items:center;justify-content:space-between;margin:6px 12px 0;padding:8px 14px;background:var(--primary-light);border-radius:var(--radius-sm);font-size:13px;color:var(--primary)}.adding-banner strong{font-weight:700}.adding-banner-cancel{background:none;border:none;font-size:16px;cursor:pointer;color:var(--primary);padding:2px 6px}.cart-float-btn.adding-btn{background:linear-gradient(135deg,#22c55e,#16a34a);box-shadow:0 4px 20px #22c55e59}.cart-float-btn.adding-btn:active{background:#16a34a}.profile-page{flex:1;overflow-y:auto;padding:0 20px 40px}.profile-header{display:flex;align-items:center;gap:10px;padding:14px 0 24px}.profile-header h2{font-size:17px;font-weight:700}.profile-info-card{background:#fafafa;border:1px solid #eee;border-radius:var(--radius-sm);padding:12px 16px;margin-bottom:12px}.profile-info-title{font-size:11px;font-weight:600;color:#999;text-transform:uppercase;letter-spacing:1px;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid #eee}.profile-info-row{display:flex;align-items:center;padding:6px 0;gap:12px;border-bottom:1px solid #f0f0f0}.profile-info-row:last-child{border-bottom:none}.profile-info-label{font-size:11px;font-weight:500;color:#aaa;text-transform:uppercase;letter-spacing:.5px;min-width:60px}.profile-info-value{font-size:13px;color:var(--text);font-weight:500}.profile-info-value.mono{font-family:SF Mono,Menlo,Courier New,monospace;font-size:12px;letter-spacing:.5px}.profile-section-hint{font-size:12px;color:#999;margin-bottom:18px;line-height:1.5}.profile-field{margin-bottom:18px}.profile-label{display:block;font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.profile-input{width:100%;padding:13px 16px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:15px;font-family:inherit;outline:none;background:var(--card);transition:border-color .15s}.profile-input:focus{border-color:var(--text)}.profile-input::placeholder{color:#ccc}.btn-profile-save{width:100%;padding:14px;background:var(--text);color:#fff;border:none;border-radius:var(--radius-sm);font-size:15px;font-weight:600;font-family:inherit;cursor:pointer;margin-top:6px;letter-spacing:.2px;transition:all .15s}.btn-profile-save:active{opacity:.85;transform:scale(.99)}.btn-profile-save.saved{background:var(--success)}.profile-section{margin-top:28px;padding-top:20px;border-top:1px solid #eee}.profile-section-title{font-size:13px;font-weight:600;margin-bottom:12px;color:var(--text);text-transform:uppercase;letter-spacing:.5px}.profile-empty-text{font-size:14px;color:#bbb;text-align:center;padding:20px 0}.payment-section{margin:0 12px 8px;padding:16px;background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow)}.payment-header{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--text);margin-bottom:12px}.payment-dot{width:8px;height:8px;background:var(--warning);border-radius:50%;animation:blink 1s infinite}.payment-dot.done{background:var(--success);animation:none}.payment-section.paid{opacity:.7}.payment-methods{display:flex;flex-direction:column;gap:6px}.payment-method-btn{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:#fafafa;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:inherit;font-size:14px;cursor:pointer;transition:all .15s}.payment-method-btn:active{background:#f5f5f5}.payment-method-label{font-weight:600;color:var(--text)}.payment-method-hint{font-size:12px;color:var(--text-secondary);margin-left:8px}.payment-method-arrow{color:#ccc;margin-left:auto}.payment-qr,.payment-cash-confirm{display:flex;flex-direction:column;align-items:center;gap:12px;padding:8px 0}.qr-box{width:180px;height:180px;background:#1a1a1a;border-radius:var(--radius);display:flex;align-items:center;justify-content:center}.qr-inner{display:flex;flex-direction:column;align-items:center;gap:2px;color:#fff;font-size:11px;font-weight:600;letter-spacing:3px}.qr-code{font-size:14px;letter-spacing:4px;opacity:.8}.qr-amount{font-size:22px;font-weight:700;color:var(--text)}.cash-confirm-text{font-size:28px;font-weight:700;color:var(--text);padding:16px 0}.btn-payment-done{width:100%;padding:13px;background:var(--text);color:#fff;border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;letter-spacing:.3px}.btn-payment-done:active{opacity:.85}.btn-payment-back{width:100%;padding:11px;background:none;border:none;font-size:13px;color:var(--text-secondary);font-family:inherit;cursor:pointer}.admin-app{display:flex;height:100vh;max-width:100%;background:#f5f5f5;overflow:hidden}.admin-login{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f5f5f5}.admin-login-form{width:320px;padding:40px 32px;background:#fff;border-radius:8px;text-align:center;box-shadow:0 1px 3px #0000000f}.admin-login-logo{margin-bottom:16px;color:#333}.admin-login-form h2{font-size:18px;font-weight:700;margin-bottom:24px;color:#111}.admin-input{width:100%;padding:11px 14px;border:1.5px solid #e5e5e5;border-radius:6px;font-size:14px;font-family:inherit;outline:none;margin-bottom:10px;background:#fff}.admin-input:focus{border-color:#333}.admin-btn{width:100%;padding:12px;background:#111;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;margin-top:4px}.admin-btn-sm{padding:8px 18px;background:#111;color:#fff;border:none;border-radius:5px;font-size:13px;font-weight:500;font-family:inherit;cursor:pointer}.admin-btn-sm.primary{background:#111}.admin-btn-sm.saved{background:var(--success)}.admin-error{color:#e53e3e;font-size:13px;margin-bottom:4px}.admin-login-hint{font-size:11px;color:#aaa;margin-top:12px}.admin-sidebar{width:180px;background:#1a1a1a;color:#fff;display:flex;flex-direction:column;justify-content:space-between;flex-shrink:0;padding:20px 0}.admin-sidebar-logo{padding:0 20px 20px;border-bottom:1px solid #333;margin-bottom:8px}.admin-nav{display:flex;flex-direction:column;gap:2px;padding:0 8px}.admin-nav-item{display:flex;align-items:center;gap:10px;padding:11px 12px;background:none;border:none;color:#888;font-size:14px;font-family:inherit;cursor:pointer;border-radius:6px;transition:all .15s}.admin-nav-item:hover{color:#ddd;background:#2a2a2a}.admin-nav-item.active{color:#fff;background:#333}.admin-nav-icon{width:22px;height:22px;border:1.5px solid currentColor;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}.admin-nav-badge{margin-left:auto;background:#e53e3e;color:#fff;font-size:11px;font-weight:600;padding:1px 7px;border-radius:10px;min-width:20px;text-align:center}.admin-nav-badge.cash{background:#f59e0b}.admin-logout-btn{margin:0 20px;padding:10px;background:none;border:1px solid #444;color:#888;font-size:13px;font-family:inherit;cursor:pointer;border-radius:6px}.admin-main{flex:1;overflow-y:auto;padding:24px;background:#f5f5f5}.admin-main h2{font-size:20px;font-weight:700;margin-bottom:16px}.admin-kitchen-header{display:flex;align-items:center;gap:16px;margin-bottom:16px}.kitchen-total{font-size:13px;color:#888}.btn-ding-test{padding:4px 12px;background:#f0f0f0;border:none;border-radius:4px;font-size:12px;cursor:pointer;font-family:inherit;margin-left:auto}.kitchen-columns{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;min-height:calc(100vh - 140px)}.kitchen-column{background:#fff;border-radius:6px;display:flex;flex-direction:column;overflow:hidden}.kitchen-column.highlight{border-top:3px solid #e53e3e}.kitchen-column-header{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;font-size:13px;font-weight:600;border-bottom:1px solid #f0f0f0;background:#fafafa}.kitchen-column-count{background:#e5e5e5;padding:1px 8px;border-radius:10px;font-size:12px}.kitchen-column-body{flex:1;overflow-y:auto;padding:8px}.kitchen-order-card{background:#fafafa;border:1px solid #eee;border-radius:6px;padding:10px;margin-bottom:8px;font-size:13px}.ko-top{display:flex;gap:8px;margin-bottom:6px}.ko-id{font-weight:700}.ko-table{color:#888}.ko-total{font-weight:600;margin-left:auto}.ko-tag{font-size:10px;font-weight:600;padding:1px 6px;border-radius:3px;display:inline-block;margin-bottom:4px}.cash-tag{background:#fefce8;color:#a16207}.paid-tag{background:#f0fdf4;color:#16a34a}.ko-items{margin:4px 0}.ko-item{display:flex;justify-content:space-between;padding:2px 0}.ko-item-qty{color:#888;font-size:12px}.ko-item-new{font-size:10px;background:#f0f0f0;padding:0 5px;border-radius:3px;color:#888}.ko-time{font-size:11px;color:#bbb;margin:4px 0}.ko-action-btn{width:100%;padding:7px;background:#111;color:#fff;border:none;border-radius:4px;font-size:12px;font-family:inherit;cursor:pointer;margin-top:4px}.kitchen-empty{text-align:center;color:#ddd;font-size:20px;padding:20px}.cashier-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px}.cashier-stat{background:#fff;padding:16px;border-radius:6px;text-align:center}.cashier-stat-label{display:block;font-size:11px;color:#888;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.cashier-stat-value{font-size:20px;font-weight:700}.cashier-section{background:#fff;border-radius:6px;padding:12px 16px;margin-bottom:12px}.cashier-section h3{font-size:14px;font-weight:600;margin-bottom:8px;display:flex;align-items:center;gap:8px}.cashier-badge{background:#e53e3e;color:#fff;font-size:11px;padding:1px 7px;border-radius:10px}.cashier-badge.done{background:#16a34a}.cashier-empty{font-size:13px;color:#bbb;text-align:center;padding:12px}.cashier-order{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid #f5f5f5}.cashier-order-left{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.cashier-order-id{font-weight:600;font-size:13px}.cashier-order-table{font-size:13px;color:#888}.cashier-order-items{font-size:12px;color:#aaa;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cashier-order-method{font-size:11px;background:#f0fdf4;color:#16a34a;padding:1px 8px;border-radius:4px}.cashier-order-right{display:flex;align-items:center;gap:12px;flex-shrink:0}.cashier-order-total{font-weight:700;font-size:14px}.cashier-confirm-btn{padding:6px 14px;background:#111;color:#fff;border:none;border-radius:4px;font-size:12px;font-family:inherit;cursor:pointer}.admin-menu-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.menu-cat-group{background:#fff;border-radius:6px;padding:12px 16px;margin-bottom:12px}.menu-cat-title{font-size:14px;font-weight:600;margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid #f0f0f0}.menu-dish-list{display:flex;flex-direction:column;gap:4px}.menu-dish-row{display:flex;align-items:center;gap:12px;padding:8px 0;border-bottom:1px solid #fafafa;font-size:13px}.menu-dish-name{flex:1;font-weight:500}.menu-dish-price{font-weight:600}.menu-dish-tag{font-size:10px;background:#fefce8;color:#a16207;padding:1px 6px;border-radius:3px}.menu-dish-edit{background:none;border:1px solid #ddd;padding:3px 10px;border-radius:4px;font-size:12px;cursor:pointer;font-family:inherit}.menu-dish-del{background:none;border:none;color:#ccc;font-size:16px;cursor:pointer;padding:2px 6px}.admin-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;z-index:400;display:flex;align-items:center;justify-content:center}.admin-modal{background:#fff;padding:24px;border-radius:8px;width:380px;max-height:80vh;overflow-y:auto}.admin-modal h3{font-size:16px;font-weight:700;margin-bottom:16px}.admin-modal label{display:block;font-size:12px;font-weight:500;color:#888;margin-bottom:4px;margin-top:8px}.admin-modal .admin-input{margin-bottom:6px}.admin-modal select.admin-input{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.checkbox-label{display:flex;align-items:center;gap:8px;font-size:13px!important;color:#333!important;padding:4px 0}.admin-modal-actions{display:flex;gap:8px;margin-top:16px;justify-content:flex-end}.table-add-form{background:#fff;padding:16px;border-radius:6px;margin-bottom:16px}.table-add-row{display:flex;gap:10px;margin-bottom:12px}.table-add-field{flex:1}.table-add-field label{display:block;font-size:11px;color:#888;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.table-zone-group{margin-bottom:16px}.table-zone-title{font-size:14px;font-weight:600;margin-bottom:10px}.table-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}.table-card{background:#fff;border-radius:6px;padding:12px;text-align:center}.table-card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.table-card-num{font-size:16px;font-weight:700}.table-card-seats{font-size:11px;color:#888}.table-card-qr{margin:8px 0}.table-qr-mini{width:60px;height:60px;background:#1a1a1a;border-radius:4px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:10px;font-weight:600;margin:0 auto}.table-card-actions{display:flex;gap:6px;justify-content:center}.table-card-btn{padding:4px 10px;border:1px solid #ddd;background:#fff;border-radius:4px;font-size:11px;cursor:pointer;font-family:inherit}.table-card-btn.del{color:#e53e3e;border-color:#fee}.qr-preview{text-align:center}.qr-big-box{width:160px;height:160px;background:#1a1a1a;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:600;margin:16px auto}.qr-url{font-size:12px;color:#888;word-break:break-all;margin:8px 0}.qr-hint{font-size:12px;color:#bbb;margin-bottom:12px}.admin-settings{max-width:500px}.settings-desc{font-size:13px;color:#888;margin-bottom:16px}.settings-list{display:flex;flex-direction:column;gap:8px}.settings-item{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;background:#fff;border-radius:6px;cursor:pointer}.settings-item-left{display:flex;flex-direction:column;gap:2px}.settings-item-label{font-size:14px;font-weight:600}.settings-item-desc{font-size:12px;color:#888}.settings-toggle{width:44px;height:24px;accent-color:#111;cursor:pointer}.desk-order-layout{display:flex;flex:1;min-height:0;overflow:hidden}.desk-menu-area{flex:1;display:flex;flex-direction:column;min-width:0;min-height:0;overflow:hidden}.desk-order-page{flex:1;display:flex;flex-direction:column;height:calc(100vh - 48px);overflow:hidden;position:relative}.desk-table-selector-page{position:relative}.desk-tsel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.desk-tsel-header h2{font-size:20px;font-weight:700;margin:0}.desk-tsel-top-stats{display:flex;gap:6px}.desk-stat-pill{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;border-radius:16px;font-size:12px;font-weight:600;cursor:default;white-space:nowrap}.desk-stat-pill.unpaid{background:#fef2f2;color:#e53e3e;border:1px solid #fecaca;cursor:pointer}.desk-stat-pill.unpaid:hover{background:#fee2e2}.desk-stat-pill.settled{background:#f0fdf4;color:#16a34a;border:1px solid #bbf7d0}.desk-stat-dot{width:7px;height:7px;border-radius:50%;background:currentColor}.desk-stat-dot.red{animation:blink 1s infinite}.desk-tsel-bottom-bar{display:flex;gap:20px;padding:14px 2px;border-top:1px solid #eee;margin-top:auto;flex-shrink:0}.desk-bottom-count{display:flex;align-items:center;gap:6px;font-size:13px;color:#888}.desk-bottom-count strong{font-size:18px;font-weight:700;color:#111}.desk-bottom-count.idle .desk-bottom-dot{width:10px;height:10px;background:#22c55e;border-radius:50%}.desk-bottom-count.dining .desk-bottom-dot{width:10px;height:10px;background:var(--primary);border-radius:50%}.desk-order-page h2{font-size:20px;font-weight:700;margin-bottom:8px}.desk-sidebar-right{width:300px;flex-shrink:0;background:#fff;border-left:1px solid #e5e5e5;display:flex;flex-direction:column;overflow-y:auto}.desk-side-section{padding:16px;border-bottom:1px solid #f0f0f0}.desk-side-section:last-child{border-bottom:none}.desk-side-title{font-size:13px;font-weight:700;color:#111;text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px;display:flex;align-items:center;gap:6px}.unpaid-title .desk-pulse-dot{width:8px;height:8px;background:#e53e3e;border-radius:50%;animation:blink 1s infinite;flex-shrink:0}.desk-cart-hint{font-size:13px;color:#bbb;text-align:center;padding:20px 0}.desk-side-cart-list{max-height:240px;overflow-y:auto;margin-bottom:10px}.desk-side-row{display:flex;align-items:center;gap:6px;padding:7px 6px;border-bottom:1px solid #f5f5f5;cursor:pointer;transition:background .1s;font-size:12px}.desk-side-row:hover{background:#fafafa}.desk-side-qty{font-weight:700;color:var(--primary);min-width:18px}.desk-side-name{flex:1;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.desk-side-price{font-weight:600;white-space:nowrap}.desk-side-total-line{display:flex;justify-content:space-between;align-items:center;padding:8px 4px;font-size:14px;font-weight:600;border-top:1.5px solid #eee;margin-bottom:8px}.desk-place-btn{width:100%;padding:12px 16px;background:#111;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .15s}.desk-place-btn:active{background:#333;transform:scale(.98)}.desk-unpaid-section{background:#fefce8}.desk-unpaid-group{margin-top:8px}.desk-unpaid-group-label{font-size:11px;font-weight:600;color:#888;text-transform:uppercase;letter-spacing:.3px;margin-bottom:6px;padding-bottom:4px;border-bottom:1px dashed #eee}.desk-unpaid-card{background:#fff;border:1px solid #eee;border-radius:6px;padding:10px 12px;margin-bottom:6px;font-size:12px}.desk-unpaid-card.current-table{border-color:#f59e0b;border-width:1.5px;background:#fffbeb}.desk-unpaid-top{display:flex;justify-content:space-between;font-weight:700;margin-bottom:4px}.desk-unpaid-items{color:#666;font-size:11px;line-height:1.4;margin-bottom:6px}.desk-unpaid-actions{display:flex;align-items:center;gap:8px}.desk-unpaid-time{color:#aaa;font-size:11px;flex:1}.desk-unpaid-bar{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:#fefce8;border:1px solid #f59e0b;border-radius:6px;font-size:13px;font-weight:500;color:#a16207;margin-bottom:12px}.desk-unpaid-badge{background:#e53e3e;color:#fff;font-size:11px;font-weight:700;padding:1px 7px;border-radius:10px;min-width:18px;text-align:center}.desk-table-unpaid-tag{font-size:9px;background:#e53e3e;color:#fff;padding:2px 6px;border-radius:4px;position:absolute;top:6px;right:6px}.desk-table-card{position:relative!important}.desk-select-hint{font-size:13px;color:#888;margin-bottom:20px}.desk-zone-tabs{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}.desk-zone-tab{padding:8px 16px;background:#fff;border:1px solid #e5e5e5;border-radius:6px;font-size:13px;font-family:inherit;cursor:pointer;color:#666;transition:all .15s}.desk-zone-tab.active{background:#111;color:#fff;border-color:#111}.desk-zone-tab:active{transform:scale(.97)}.desk-table-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px;overflow-y:auto}.desk-table-card{position:relative;display:flex;flex-direction:column;align-items:center;gap:6px;padding:18px 12px 14px;background:#fff;border:2px solid #e5e5e5;border-radius:10px;font-family:inherit;cursor:pointer;transition:all .15s}.desk-table-header{display:flex;align-items:center;justify-content:center;gap:6px}.desk-table-status-dot{display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0}.desk-table-card.status-idle .desk-table-status-dot{background:#22c55e}.desk-table-card.status-dining .desk-table-status-dot{background:var(--primary)}.desk-table-card.status-settled .desk-table-status-dot{background:#d1d5db}.desk-table-card.status-idle:hover{box-shadow:0 2px 12px #22c55e26}.desk-table-card.status-dining:hover{box-shadow:0 2px 12px #e85d3a26}.desk-table-card.status-settled{opacity:.6}.desk-table-card.status-settled:hover{opacity:.85}.desk-table-card:hover{border-color:#111;box-shadow:0 2px 8px #0000000f}.desk-table-card:active{background:#fafafa;transform:scale(.97)}.desk-table-num{font-size:22px;font-weight:700;color:#111}.desk-table-seats{font-size:12px;color:#888}.desk-table-zone{font-size:10px;color:#bbb;background:#f5f5f5;padding:2px 8px;border-radius:4px}.desk-top-bar{display:flex;align-items:center;gap:12px;margin-bottom:8px}.desk-back-btn{display:flex;align-items:center;gap:4px;padding:6px 12px;background:#fff;border:1px solid #e5e5e5;border-radius:6px;font-size:13px;font-family:inherit;cursor:pointer;color:#666;transition:all .15s}.desk-back-btn:active{background:#f5f5f5}.desk-table-badge{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:600;color:#111}.desk-table-badge svg{color:#888}.desk-search-bar{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#fff;border:1.5px solid #e5e5e5;border-radius:8px;margin-bottom:10px;flex-shrink:0}.desk-search-input{flex:1;border:none;outline:none;font-size:13px;font-family:inherit;background:transparent;color:#111}.desk-search-input::placeholder{color:#bbb}.desk-search-clear{background:none;border:none;cursor:pointer;color:#ccc;padding:2px}.desk-menu-layout{display:flex;flex:1;overflow:hidden;min-height:0}.desk-cat-list{width:72px;background:#fff;overflow-y:auto;flex-shrink:0;border-right:1px solid #f0f0f0;scrollbar-width:none;min-height:0}.desk-cat-list::-webkit-scrollbar{display:none}.desk-cat-item{display:flex;flex-direction:column;align-items:center;gap:4px;width:100%;padding:10px 4px;border:none;background:transparent;cursor:pointer;font-family:inherit;border-left:3px solid transparent;transition:all .15s}.desk-cat-item.active{background:#f5f5f5;border-left-color:#111}.desk-cat-item:active{background:#f0f0f0}.desk-cat-icon{font-size:18px}.desk-cat-name{font-size:10px;color:#888;text-align:center;line-height:1.2}.desk-cat-item.active .desk-cat-name{color:#111;font-weight:600}.desk-dish-grid{flex:1;overflow-y:auto;padding:8px 10px;display:grid;grid-template-columns:repeat(2,1fr);gap:10px;align-content:start;min-height:0}.desk-empty{grid-column:1 / -1;text-align:center;color:#ccc;font-size:14px;padding:40px 0}.desk-dish-card{background:#fff;border-radius:8px;overflow:hidden;border:none;cursor:pointer;font-family:inherit;text-align:left;transition:all .15s;box-shadow:0 1px 4px #0000000a}.desk-dish-card:active{transform:scale(.97)}.desk-dish-img{width:100%;aspect-ratio:4/3;background:linear-gradient(135deg,#fafafa,#f0f0f0);display:flex;align-items:center;justify-content:center}.desk-dish-emoji{font-size:36px}.desk-dish-emoji.hidden{display:none}.desk-dish-body{padding:6px 8px 8px}.desk-dish-name{font-size:12px;font-weight:600;color:#111;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:4px}.desk-dish-footer{display:flex;align-items:center;justify-content:space-between}.desk-dish-price{font-size:14px;font-weight:700;color:var(--primary)}.desk-dish-add{width:26px;height:26px;border-radius:50%;background:#111;color:#fff;font-size:14px;font-weight:700;display:flex;align-items:center;justify-content:center}.desk-dish-add.has{background:#fff;border:2px solid #111;color:#111;font-size:11px}.desk-dish-real-img{width:100%;height:100%;object-fit:cover}.desk-dish-img{width:100%;aspect-ratio:4/3;background:linear-gradient(135deg,#fafafa,#f0f0f0);display:flex;align-items:center;justify-content:center;position:relative}.desk-cart-tag{font-size:10px;padding:2px 6px;border-radius:3px;white-space:nowrap}.desk-cart-tag.spice{background:#fff0ec;color:var(--primary)}.desk-cart-tag.addon{background:#f0fdf4;color:#16a34a}.desk-cart-price{font-size:13px;font-weight:600;white-space:nowrap}.desk-cart-del{background:none;border:none;cursor:pointer;color:#ccc;padding:2px;flex-shrink:0}.desk-cart-del:hover{color:#e53e3e}.desk-place-btn{display:flex;align-items:center;justify-content:space-between;width:calc(100% - 16px);margin:8px;padding:14px 16px;background:#111;color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .15s}.desk-place-btn:active{background:#333;transform:scale(.99)}.desk-place-total{font-size:13px;font-weight:400;opacity:.8}.desk-spec-dialog{background:#fff;border-radius:12px 12px 0 0;width:100%;max-width:480px;padding:20px 16px 24px;max-height:70vh;overflow-y:auto}.desk-spec-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.desk-spec-header h3{font-size:17px;font-weight:700}.desk-spec-price{font-size:17px;font-weight:700;color:var(--primary)}.desk-spec-section{margin-bottom:14px}.desk-spec-label{display:block;font-size:12px;font-weight:600;color:#888;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.desk-spec-options{display:flex;gap:8px}.desk-spec-opt{flex:1;padding:10px 8px;border:1.5px solid #e5e5e5;border-radius:6px;background:#fff;font-size:12px;font-family:inherit;cursor:pointer;text-align:center;transition:all .15s}.desk-spec-opt.active{background:#f5f5f5;border-color:#111;font-weight:600}.desk-spec-opt.addon{display:flex;justify-content:space-between;align-items:center}.desk-spec-addons{display:flex;flex-direction:column;gap:6px}.desk-spec-addon-price{color:var(--primary);font-weight:600}.desk-spec-remark{width:100%;padding:10px 12px;border:1.5px solid #e5e5e5;border-radius:6px;font-size:13px;font-family:inherit;outline:none}.desk-spec-remark:focus{border-color:#111}.desk-spec-remark::placeholder{color:#ccc}.desk-spec-footer{display:flex;gap:10px;margin-top:20px}.desk-spec-btn{padding:12px;border-radius:8px;font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .15s}.desk-spec-btn.cancel{flex:1;background:#fff;border:1.5px solid #e5e5e5;color:#666}.desk-spec-btn.confirm{flex:2;background:#111;border:none;color:#fff}.desk-spec-btn:active{transform:scale(.98)}.desk-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:500;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s}.desk-modal{background:#fff;border-radius:12px;padding:28px 24px 20px;width:380px;max-height:80vh;overflow-y:auto;text-align:center}.desk-modal-icon{margin-bottom:8px}.desk-modal h3{font-size:18px;font-weight:700;margin-bottom:4px}.desk-modal-sub{font-size:13px;color:#888;margin-bottom:20px}.desk-modal-qr-section{margin-bottom:16px}.desk-modal-qr-hint{font-size:12px;color:#888;margin-bottom:10px;text-transform:uppercase;letter-spacing:.5px}.desk-qr-box{width:160px;height:160px;background:#1a1a1a;border-radius:8px;margin:0 auto 8px;display:flex;align-items:center;justify-content:center}.desk-qr-inner{display:flex;align-items:center;justify-content:center}.desk-qr-url{font-size:11px;color:#aaa;word-break:break-all;display:block;max-width:280px;margin:0 auto}.desk-modal-items{text-align:left;margin-bottom:12px}.desk-modal-item{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid #f5f5f5;font-size:13px}.desk-modal-item-qty{color:#888;min-width:24px}.desk-modal-item-name{flex:1;font-weight:500}.desk-modal-item-price{font-weight:600;white-space:nowrap}.desk-modal-total{display:flex;justify-content:space-between;align-items:center;padding-top:10px;margin-top:6px;border-top:1.5px solid #eee;font-size:14px;font-weight:600}.desk-modal-total-price{font-size:18px;font-weight:700;color:var(--primary)}.desk-modal-actions{display:flex;gap:10px;margin-top:16px}.desk-modal-btn{flex:1;padding:11px;border-radius:8px;font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .15s}.desk-modal-btn.secondary{background:#fff;border:1.5px solid #e5e5e5;color:#666}.desk-modal-btn.primary{background:#111;border:none;color:#fff}.admin-cat-manage-section{margin-bottom:20px}.admin-subtitle{font-size:15px;font-weight:600;margin-bottom:10px;color:#111}.admin-cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:8px}.admin-cat-card{background:#fff;border:1px solid #e5e5e5;border-radius:6px;padding:12px;display:flex;align-items:center;gap:8px}.admin-cat-card-icon{font-size:22px;flex-shrink:0}.admin-cat-card-name{font-weight:600;font-size:13px;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-cat-card-en{font-size:11px;color:#aaa;flex-shrink:0}.admin-cat-card-count{font-size:11px;background:#f0f0f0;padding:2px 7px;border-radius:10px;color:#888;font-weight:500;flex-shrink:0}.admin-cat-card-actions{display:flex;gap:4px;margin-left:4px}.menu-dish-thumb{width:28px;height:28px;object-fit:cover;border-radius:4px;flex-shrink:0}.dish-upload-area{border:2px dashed #ddd;border-radius:8px;cursor:pointer;transition:all .15s;text-align:center;overflow:hidden}.dish-upload-area:hover{border-color:#999;background:#fafafa}.diah-upload-placeholder{display:flex;flex-direction:column;align-items:center;gap:6px;padding:24px 16px;color:#bbb;font-size:13px}.diah-upload-placeholder svg{margin-bottom:2px}.dish-upload-preview{width:100%;max-height:160px;object-fit:cover}.admin-modal-sm{width:320px}@media (min-width: 768px){.app,.cart-float,.order-confirm-footer{max-width:600px}.category-sidebar{width:90px}.menu-items{grid-template-columns:1fr 1fr 1fr}}@media (min-width: 900px){.desk-dish-grid{grid-template-columns:repeat(3,1fr)}}@media (min-width: 1400px){.desk-dish-grid{grid-template-columns:repeat(4,1fr)}}@media (min-width: 1800px){.desk-dish-grid{grid-template-columns:repeat(5,1fr)}}
