*{box-sizing:border-box;margin:0;padding:0}html,body{color:#111;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-tap-highlight-color:transparent;background:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:16px;line-height:1.5}#root{flex-direction:column;min-height:100dvh;display:flex}a{color:inherit}:root{--color-primary:#f97316;--color-primary-dark:#ea580c;--color-primary-light:#fff7ed;--color-primary-50:#fff7ed;--color-primary-100:#ffedd5;--color-primary-500:#f97316;--color-primary-600:#ea580c;--color-primary-700:#c2410c;--color-primary-300:#fdba74;--color-bg:#faf9f7;--color-surface:#fff;--color-surface-hover:#f7f5f3;--color-surface-elevated:#fff;--color-text:#1a1814;--color-text-secondary:#6b6560;--color-text-tertiary:#a39e98;--color-text-inverse:#fff;--color-border:#e8e5e1;--color-border-light:#f2f0ed;--color-divider:#f2f0ed;--color-success:#16a34a;--color-success-bg:#dcfce7;--color-warning:#d97706;--color-warning-bg:#fef3c7;--color-error:#dc2626;--color-error-bg:#fef2f2;--color-info:#0284c7;--color-info-bg:#e0f2fe;--shadow-sm:0 1px 3px #1c18140a, 0 1px 2px #1c181405;--shadow-md:0 4px 12px #1c18140f, 0 1px 3px #1c18140a;--shadow-lg:0 12px 24px -4px #1c181414, 0 4px 8px #1c181408;--shadow-xl:0 20px 40px -8px #1c18141f, 0 8px 16px #1c18140a;--shadow-float:0 8px 32px #1c181424;--shadow-glow:0 4px 24px #f973164d;--radius-xs:6px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--radius-2xl:24px;--radius-full:9999px;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-size-xs:12px;--font-size-sm:13px;--font-size-base:15px;--font-size-md:16px;--font-size-lg:18px;--font-size-xl:22px;--font-size-2xl:28px;--font-size-3xl:34px;--transition-fast:.15s ease;--transition-base:.2s cubic-bezier(.25, .46, .45, .94);--transition-slow:.35s cubic-bezier(.25, .46, .45, .94);--transition-spring:.4s cubic-bezier(.34, 1.56, .64, 1);--space-xs:4px;--space-sm:8px;--space-md:12px;--space-lg:16px;--space-xl:20px;--space-2xl:24px;--space-3xl:32px;--space-4xl:40px;--bottom-nav-h:calc(80px + env(safe-area-inset-bottom,20px))}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-tap-highlight-color:transparent;scroll-behavior:smooth}body{font-family:var(--font-sans);background:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-variant-numeric:tabular-nums;line-height:1.55;overflow-x:hidden}img{max-width:100%;display:block}button{font-family:inherit}.app-header{z-index:100;-webkit-backdrop-filter:blur(20px)saturate(1.8);background:#faf9f7e0;border-bottom:1px solid #0000000f;justify-content:center;align-items:center;padding:12px 16px;display:flex;position:sticky;top:0}.logo{font-size:var(--font-size-lg);color:var(--color-primary);letter-spacing:-.5px;font-weight:800;text-decoration:none;transition:opacity .15s}.header-restaurant-name{font-size:var(--font-size-base);letter-spacing:-.3px;color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;max-width:70%;font-weight:700;animation:.3s cubic-bezier(.22,1,.36,1) headerTitleIn;position:absolute;left:50%;overflow:hidden;transform:translate(-50%)}:is(.header-restaurant-name+.logo,.app-header:has(.header-restaurant-name) .logo){opacity:0;pointer-events:none;transition:opacity .25s}@keyframes headerTitleIn{0%{opacity:0;transform:translate(-50%)translateY(4px)scale(.97)}to{opacity:1;transform:translate(-50%)translateY(0)scale(1)}}.app-main{padding-bottom:calc(var(--bottom-nav-h) + 24px);flex:1}.page{padding:var(--space-xl) var(--space-lg);max-width:600px;margin:0 auto;animation:.35s cubic-bezier(.25,.46,.45,.94) pageIn}.page h1{font-size:var(--font-size-2xl);letter-spacing:-.7px;color:var(--color-text);margin-bottom:8px;font-weight:800;line-height:1.15}.page-sub{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-bottom:var(--space-xl);line-height:1.4}.loading{text-align:center;padding:56px var(--space-lg);color:var(--color-text-tertiary)}.empty{text-align:center;color:var(--color-text-tertiary);padding:var(--space-3xl) 0}.card-grid{gap:var(--space-lg);margin-top:var(--space-xl);flex-direction:column;display:flex}.card{color:inherit;background:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);transition:box-shadow var(--transition-base), transform var(--transition-base);border:none;text-decoration:none;display:block;position:relative;overflow:hidden}.card:active{box-shadow:var(--shadow-lg);transform:scale(.975)}.card-img{object-fit:cover;background:linear-gradient(145deg, var(--color-surface-hover) 0%, var(--color-border-light) 100%);width:100%;height:180px;animation:.4s imgFadeIn}@keyframes imgFadeIn{0%{opacity:0}to{opacity:1}}.card-body{padding:var(--space-xl)}.card-body h2{font-size:var(--font-size-lg);letter-spacing:-.2px;margin:0 0 4px;font-weight:700}.card-sub{font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin:0}.card-desc{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:6px 0 0;line-height:1.45}.category-tabs{gap:var(--space-xs);-webkit-overflow-scrolling:touch;scrollbar-width:none;flex:1;min-width:0;padding:0 4px;display:flex;overflow-x:auto}.category-tabs::-webkit-scrollbar{display:none}.tab{white-space:nowrap;border-radius:var(--radius-full);background:var(--color-surface);font-size:var(--font-size-xs);cursor:pointer;color:var(--color-text-secondary);transition:all var(--transition-spring);box-shadow:var(--shadow-sm);-webkit-tap-highlight-color:transparent;border:none;flex-shrink:0;padding:7px 14px;font-weight:500}.tab:active{transform:scale(.93)}.tab.active{background:var(--color-text);color:var(--color-text-inverse);box-shadow:var(--shadow-md);font-weight:600;animation:.35s cubic-bezier(.34,1.56,.64,1) tabPop}@keyframes tabPop{0%{transform:scale(.88)}60%{transform:scale(1.04)}to{transform:scale(1)}}.menu-page{padding:0}.menu-header{padding:var(--space-xl) var(--space-lg) var(--space-md)}.menu-header-top{justify-content:space-between;align-items:baseline;gap:var(--space-md);display:flex;position:relative}.menu-header h1{font-size:var(--font-size-2xl);letter-spacing:-.5px;margin:0;font-weight:800;line-height:1.15}.menu-section{padding:0 var(--space-lg)}.section-title{font-size:var(--font-size-lg);margin:var(--space-2xl) 0 var(--space-md);color:var(--color-text);letter-spacing:-.2px;font-weight:700}.menu-grid{gap:var(--space-md);grid-template-columns:1fr 1fr;align-items:start;display:grid}.menu-card{color:inherit;background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);transition:transform var(--transition-spring), border-color var(--transition-fast);text-decoration:none;position:relative;overflow:hidden}.menu-card:active{border-color:var(--color-border);transform:scale(.97)}.menu-card-img{aspect-ratio:4/3;object-fit:cover;background:linear-gradient(145deg, var(--color-surface-hover) 0%, var(--color-border-light) 100%);width:100%;animation:.4s imgFadeIn;display:block}.menu-card-body{padding:var(--space-sm) var(--space-md) var(--space-md)}.menu-card-body h3{font-size:var(--font-size-sm);letter-spacing:-.1px;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-weight:600;line-height:1.3;display:-webkit-box;overflow:hidden}.menu-card-desc{font-size:var(--font-size-xs);color:var(--color-text-tertiary);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0 0 8px;line-height:1.35;display:-webkit-box;overflow:hidden}.menu-card-price{font-size:var(--font-size-md);color:var(--color-text);letter-spacing:-.3px;font-weight:800}.item-page{padding:0 0 80px}.item-hero{object-fit:cover;background:linear-gradient(145deg, var(--color-surface-hover) 0%, var(--color-border-light) 100%);width:100%;height:280px;animation:.4s imgFadeIn}.item-info{padding:var(--space-xl) var(--space-lg) var(--space-lg)}.item-info h1{font-size:var(--font-size-xl);letter-spacing:-.4px;margin:0 0 8px;font-weight:800}.item-desc{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin:0 0 var(--space-lg);line-height:1.55}.item-price{color:var(--color-text);letter-spacing:-.5px;font-size:26px;font-weight:800}.modifier-group{padding:0 var(--space-lg) var(--space-lg)}.modifier-group.required-group{margin:0 var(--space-sm) var(--space-md);padding:var(--space-lg);border-radius:var(--radius-lg);background:linear-gradient(135deg,#f9731608,#f973160f);border:1px solid #f973161a}.modifier-group h3{font-size:var(--font-size-md);margin:0 0 10px;font-weight:600}.modifier-group .required{color:var(--color-error)}.required{color:var(--color-error);font-weight:600}.modifier-group .hint{color:var(--color-text-tertiary);font-size:var(--font-size-xs);font-weight:400}.modifier-options{gap:var(--space-sm);flex-wrap:wrap;display:flex}.modifier-opt{border:1.5px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);cursor:pointer;min-height:48px;transition:all var(--transition-fast);-webkit-tap-highlight-color:transparent;align-items:center;gap:8px;padding:12px 16px;font-size:14px;display:flex}.modifier-opt.selected{background:var(--color-text);color:var(--color-text-inverse);border-color:var(--color-text);box-shadow:var(--shadow-md);transform:scale(1.02)}.mod-indicator{border:2px solid var(--color-border);width:20px;height:20px;transition:all var(--transition-fast);color:var(--color-border);flex-shrink:0;justify-content:center;align-items:center;font-size:11px;display:flex}.mod-indicator.checked{color:var(--color-text-inverse)}.mod-radio{border-radius:50%}.mod-check{border-radius:4px}.modifier-opt.selected .mod-indicator{border-color:var(--color-text-inverse);color:var(--color-text-inverse)}.opt-price{font-size:var(--font-size-xs);opacity:.7;margin-left:auto}.item-actions{bottom:var(--bottom-nav-h);-webkit-backdrop-filter:blur(20px)saturate(1.8);padding:14px var(--space-lg);gap:var(--space-md);z-index:20;background:#faf9f7eb;border-top:1px solid #0000000f;align-items:center;max-width:600px;margin:0 auto;display:flex;position:fixed;left:0;right:0}.qty-control{border:1.5px solid var(--color-border);border-radius:var(--radius-full);background:var(--color-bg);align-items:center;gap:0;display:flex;overflow:hidden}.qty-control button{cursor:pointer;width:36px;height:36px;color:var(--color-text);transition:background var(--transition-fast);-webkit-tap-highlight-color:transparent;background:0 0;border:none;font-size:17px;line-height:1}.qty-control button:active{background:var(--color-surface-hover)}.qty-control span{text-align:center;width:28px;font-size:var(--font-size-sm);font-variant-numeric:tabular-nums;font-weight:700}.btn-add{border-radius:var(--radius-md);background:var(--color-text);color:var(--color-text-inverse);font-size:var(--font-size-md);cursor:pointer;transition:transform var(--transition-spring), opacity var(--transition-fast);letter-spacing:-.1px;border:none;flex:1;padding:15px;font-weight:700}.btn-add:active{opacity:.85;transform:scale(.97)}.btn-add:disabled{opacity:.3;cursor:not-allowed}.cart-page{padding-bottom:100px}.cart-items{margin-top:var(--space-md)}.cart-item-wrapper{background:var(--color-error);position:relative;overflow:hidden}.cart-item-wrapper.swipe-full .cart-item-delete-btn{background:#c0392b}.cart-item-wrapper.swipe-full .cart-item-delete-btn:after{content:"Отпустите";color:#ffffffb3;font-size:11px;font-weight:600;position:absolute;bottom:6px}.cart-item-wrapper+.cart-item-wrapper{border-top:1px solid var(--color-border-light)}.cart-item-wrapper.removing{transition:transform var(--transition-base), opacity var(--transition-base);opacity:0;transform:translate(-100%)}.cart-item-swipeable{touch-action:pan-y;will-change:transform;display:flex}.cart-item-content{padding:var(--space-md) 0;background:var(--color-bg);flex:0 0 100%}.cart-item-tap{align-items:flex-start;gap:var(--space-md);cursor:pointer;-webkit-tap-highlight-color:transparent;display:flex}.cart-item-delete-icon{display:none}.cart-item-delete-btn{background:var(--color-error);color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;flex-direction:column;flex:0 0 72px;justify-content:center;align-items:center;gap:4px;font-size:12px;font-weight:600;display:flex}.cart-item-delete-btn svg{width:18px;height:18px}.cart-item-img{border-radius:var(--radius-lg);object-fit:cover;flex-shrink:0;width:72px;height:72px}.cart-item-img-placeholder{border-radius:var(--radius-lg);background:linear-gradient(135deg, var(--color-surface-hover), var(--color-border-light));flex-shrink:0;justify-content:center;align-items:center;width:72px;height:72px;font-size:24px;display:flex}.cart-item-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.cart-item-info h3{font-size:var(--font-size-base);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-weight:600;line-height:1.3;display:-webkit-box;overflow:hidden}.cart-item-mods{font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin:0;line-height:1.4}.cart-item-bottom{justify-content:space-between;align-items:center;margin-top:4px;display:flex}.cart-item-price{font-size:var(--font-size-md);color:var(--color-text);margin:0;font-weight:800}.btn-remove{color:var(--color-text-tertiary);cursor:pointer;border-radius:var(--radius-sm);width:44px;height:44px;transition:color var(--transition-fast), background var(--transition-fast);-webkit-tap-highlight-color:transparent;background:0 0;border:none;justify-content:center;align-items:center;padding:0;font-size:16px;display:flex}.btn-remove:active{color:var(--color-error);background:var(--color-error-bg)}.cart-footer{margin-top:var(--space-2xl);padding-top:var(--space-xl);border-top:2px solid var(--color-text)}.cart-footer-sticky{bottom:var(--bottom-nav-h);-webkit-backdrop-filter:blur(20px)saturate(1.8);padding:var(--space-md) var(--space-xl);border-top:1px solid var(--color-border-light);z-index:20;gap:var(--space-sm);background:#faf9f7f7;flex-direction:column;max-width:600px;margin:0 auto;display:flex;position:fixed;left:0;right:0}.cart-add-more{text-align:center;font-size:var(--font-size-sm);color:var(--color-primary);transition:opacity var(--transition-fast);padding:6px 0;font-weight:600;text-decoration:none;display:block}.cart-add-more:active{opacity:.7}.cart-checkout-btn{letter-spacing:-.2px;font-size:var(--font-size-md)!important;padding:16px!important}.checkout-summary{background:var(--color-surface);padding:var(--space-xl);border-radius:var(--radius-xl);margin:var(--space-lg) 0;font-size:var(--font-size-base);color:var(--color-text-secondary);box-shadow:var(--shadow-md)}.checkout-form{gap:var(--space-xl);flex-direction:column;display:flex}.checkout-form label{flex-direction:column;gap:6px;display:flex}.checkout-form label span{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:600}.checkout-form input,.checkout-form textarea{border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-md);background:var(--color-surface);color:var(--color-text);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);padding:15px 16px;font-family:inherit}.checkout-form input:focus,.checkout-form textarea:focus{border-color:var(--color-text);outline:none;box-shadow:0 0 0 3px #1a18140f}.checkout-form input::placeholder,.checkout-form textarea::placeholder{color:var(--color-text-secondary)}.checkout-form{padding-bottom:calc(var(--bottom-nav-h) + 80px)}.checkout-sticky-footer{bottom:var(--bottom-nav-h);-webkit-backdrop-filter:blur(16px);margin:0 calc(-1 * var(--space-xl));padding:var(--space-md) var(--space-xl);padding-bottom:max(var(--space-md), env(safe-area-inset-bottom,var(--space-md)));border-top:1px solid var(--color-border);z-index:10;background:#faf9f7f2;position:sticky}.checkout-otp-resend{justify-content:space-between;align-items:center;margin-top:6px;display:flex}.otp-status{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:6px;display:block}.otp-success{color:var(--color-success);font-weight:600}.form-error{color:var(--color-error);font-size:var(--font-size-sm);margin:0;font-weight:500}.phone-hint{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:4px;font-weight:400;display:block}.btn-primary{border-radius:var(--radius-md);background:var(--color-text);width:100%;color:var(--color-text-inverse);font-size:var(--font-size-md);cursor:pointer;text-align:center;transition:transform var(--transition-spring), opacity var(--transition-fast);letter-spacing:-.1px;border:none;padding:16px;font-weight:700;text-decoration:none;display:block}.btn-primary:active{opacity:.85;transform:scale(.97)}.btn-primary:disabled{opacity:.3;cursor:not-allowed}.btn-secondary{border:1.5px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);width:100%;color:var(--color-text);font-size:var(--font-size-md);cursor:pointer;text-align:center;transition:background var(--transition-fast), transform var(--transition-spring);padding:15px;font-weight:600;text-decoration:none;display:block}.btn-secondary:active{background:var(--color-surface-hover);transform:scale(.97)}.btn-block{width:100%}.order-header{justify-content:space-between;align-items:center;gap:var(--space-md);flex-wrap:wrap;display:flex}.order-status-badge{border-radius:var(--radius-full);font-size:var(--font-size-sm);white-space:nowrap;letter-spacing:.1px;padding:7px 18px;font-weight:700}.status-grey{background:var(--color-surface-hover);color:var(--color-text-secondary)}.status-yellow{background:var(--color-warning-bg);color:#92400e}.status-blue{background:var(--color-info-bg);color:var(--color-info)}.status-orange{color:#e65100;background:#fff3e0}.status-green{background:var(--color-success-bg);color:var(--color-success)}.status-red{background:var(--color-error-bg);color:var(--color-error)}.order-ready-banner{background:var(--color-success-bg);color:var(--color-success);padding:var(--space-xl);border-radius:var(--radius-xl);text-align:center;font-size:var(--font-size-lg);margin:var(--space-xl) 0;flex-wrap:wrap;justify-content:center;align-items:center;gap:8px;font-weight:700;animation:2.5s ease-in-out infinite readyPulse;display:flex}.order-ready-banner svg{flex-shrink:0;width:24px;height:24px}@keyframes readyPulse{0%,to{box-shadow:0 0 #16a34a1f}50%{box-shadow:0 0 0 16px #16a34a00}}.order-items{margin-top:var(--space-2xl)}.order-items h2{font-size:var(--font-size-md);margin:0 0 var(--space-md);font-weight:700}.order-item{border-bottom:1px solid var(--color-divider);justify-content:space-between;align-items:center;padding:12px 0;display:flex}.order-item-name{font-size:14px;font-weight:500}.order-item-mods{font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin-top:2px;display:block}.order-item-price{white-space:nowrap;font-size:14px;font-weight:700}.order-total{font-size:var(--font-size-xl);padding:var(--space-lg) 0;border-top:2px solid var(--color-text);margin-top:var(--space-sm);letter-spacing:-.3px;justify-content:space-between;font-weight:800;display:flex}.order-meta{margin-top:var(--space-xl);padding:var(--space-xl);border-radius:var(--radius-xl);background:var(--color-surface);color:var(--color-text-secondary);box-shadow:var(--shadow-sm);font-size:14px;line-height:1.6}.order-meta p{margin:4px 0}.board-page{z-index:1000;color:#e2e8f0;font-family:var(--font-sans);background:#0c0f1a;flex-direction:column;display:flex;position:fixed;inset:0}.board-header{background:#141829;border-bottom:1px solid #ffffff0f;flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 28px;display:flex}.board-title{color:#fff;letter-spacing:-.3px;font-size:1.5rem;font-weight:800}.board-header-right{align-items:center;gap:14px;display:flex}.board-error{color:#fca5a5;font-size:.85rem}.board-fs-btn{color:#e2e8f0;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast);background:#ffffff0f;border:1px solid #ffffff1a;padding:10px 14px;font-size:1.2rem}.board-fs-btn:hover{background:#ffffff1f}.board-columns{flex:1;display:flex;overflow:hidden}.board-col{flex-direction:column;flex:1;display:flex;overflow-y:auto}.board-col-prep{border-right:1px solid #ffffff0f}.board-col-label{z-index:2;letter-spacing:-.2px;text-transform:uppercase;letter-spacing:1.5px;align-items:center;gap:8px;padding:18px 28px;font-size:.85rem;font-weight:800;display:flex;position:sticky;top:0}.board-col-label svg{width:16px;height:16px}.board-col-label-prep{color:#64748b;background:#141829}.board-col-label-ready{color:#4ade80;background:#0a1a0e}.board-numbers{flex-wrap:wrap;align-content:flex-start;gap:16px;padding:24px;display:flex}.board-num{border-radius:var(--radius-xl);text-align:center;letter-spacing:1px;flex-direction:column;align-items:center;gap:6px;min-width:150px;padding:20px 32px;font-size:3rem;font-weight:800;display:flex}.board-num-id{font-size:inherit}.board-customer{color:#64748b;letter-spacing:0;font-size:.85rem;font-weight:500}.board-items{color:#475569;letter-spacing:0;flex-direction:column;gap:2px;max-width:200px;font-size:.75rem;font-weight:400;display:flex}.board-item{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.board-num-prep{color:#64748b;background:#1a1f35;border:1px solid #ffffff0f}.board-num-ready{color:#4ade80;background:#0d3320;border:2px solid #22c55e;font-size:3.5rem}.board-num-pulse{animation:2.5s ease-in-out infinite boardPulse}@keyframes boardPulse{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}.board-empty{color:#334155;text-align:center;letter-spacing:0;width:100%;padding:48px;font-size:1.5rem}@media (width>=1200px){.board-num{min-width:200px;padding:24px 40px;font-size:4rem}.board-num-ready{font-size:4.5rem}.board-col-label{padding:22px 36px}}.spinner-wrap{padding:72px var(--space-lg);justify-content:center;align-items:center;gap:var(--space-lg);color:var(--color-text-tertiary);flex-direction:column;display:flex}.spinner{border:2.5px solid var(--color-border);border-top-color:var(--color-text);border-radius:50%;width:32px;height:32px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.error-state{text-align:center;padding:56px var(--space-lg)}.error-state-icon{margin-bottom:var(--space-md);font-size:48px}.error-state-msg{color:var(--color-error);font-size:var(--font-size-base);margin-bottom:var(--space-xl);font-weight:500}.btn-retry{border:1.5px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);font-size:var(--font-size-base);cursor:pointer;color:var(--color-text);transition:all var(--transition-fast);-webkit-tap-highlight-color:transparent;padding:13px 28px;font-weight:600}.btn-retry:active{background:var(--color-surface-hover);transform:scale(.97)}.toast-container{bottom:calc(var(--bottom-nav-h) + 80px);z-index:200;pointer-events:none;position:fixed;left:50%;transform:translate(-50%)}.toast{background:var(--color-text);color:var(--color-text-inverse);border-radius:var(--radius-full);box-shadow:var(--shadow-float);white-space:nowrap;letter-spacing:-.1px;pointer-events:auto;align-items:center;gap:12px;padding:14px 24px;font-size:14px;font-weight:600;animation:.35s cubic-bezier(.34,1.56,.64,1) toastIn;display:flex}.toast-msg{flex:1}.toast-action{color:var(--color-primary-300);cursor:pointer;text-transform:uppercase;letter-spacing:.3px;background:0 0;border:none;padding:0;font-size:14px;font-weight:700}.toast-action:hover{text-decoration:underline}@keyframes toastIn{0%{opacity:0;transform:translateY(16px)scale(.9)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes toastOut{0%{opacity:1;transform:translateY(0)scale(1)}to{opacity:0;transform:translateY(-8px)scale(.95)}}.order-progress{margin:var(--space-2xl) 0;align-items:center;gap:0;padding:0 4px;display:flex}.progress-step{flex-direction:column;flex:1;align-items:center;display:flex;position:relative}.progress-dot{background:var(--color-surface);border:2.5px solid var(--color-border);z-index:1;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:14px;transition:all .35s cubic-bezier(.25,.46,.45,.94);display:flex}.progress-dot svg{width:16px;height:16px}.progress-step.done .progress-dot{background:var(--color-text);border-color:var(--color-text);color:var(--color-text-inverse)}.progress-step.active .progress-dot{background:var(--color-surface);border-color:var(--color-text);border-width:2.5px;animation:2.5s ease-in-out infinite progressPulse;box-shadow:0 0 0 5px #1a181414}.progress-step.active.ready .progress-dot{border-color:var(--color-success);box-shadow:0 0 0 5px #16a34a1a}@keyframes progressPulse{0%,to{box-shadow:0 0 0 5px #1a181414}50%{box-shadow:0 0 0 10px #1a181405}}.progress-label{color:var(--color-text-tertiary);text-align:center;max-width:72px;margin-top:8px;font-size:11px;font-weight:500;line-height:1.2}.progress-step.done .progress-label,.progress-step.active .progress-label{color:var(--color-text);font-weight:700}.progress-line{background:var(--color-border);border-radius:2px;flex:1;align-self:flex-start;height:3px;margin-top:17px;transition:background .35s}.progress-line.filled{background:var(--color-text)}.confirm-overlay{z-index:300;-webkit-backdrop-filter:blur(8px);background:#0006;justify-content:center;align-items:center;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.confirm-dialog{background:var(--color-surface);border-radius:var(--radius-2xl);padding:var(--space-3xl);text-align:center;width:90%;max-width:320px;box-shadow:var(--shadow-xl);animation:.3s cubic-bezier(.34,1.56,.64,1) 50ms both dialogSlideUp}@keyframes dialogSlideUp{0%{opacity:0;transform:translateY(24px)scale(.92)}to{opacity:1;transform:translateY(0)scale(1)}}.confirm-dialog h3{margin-bottom:var(--space-sm);letter-spacing:-.2px;font-size:17px;font-weight:700}.confirm-dialog p{color:var(--color-text-secondary);margin-bottom:var(--space-2xl);font-size:14px;line-height:1.5}.confirm-actions{gap:var(--space-sm);display:flex}.confirm-actions button{border-radius:var(--radius-md);font-size:var(--font-size-base);cursor:pointer;transition:transform var(--transition-spring);-webkit-tap-highlight-color:transparent;border:none;flex:1;padding:14px;font-weight:700}.confirm-actions button:active{transform:scale(.95)}.confirm-cancel{background:var(--color-surface-hover);color:var(--color-text)}.confirm-ok{background:var(--color-text);color:var(--color-text-inverse)}@keyframes pageIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.empty-state{text-align:center;padding:64px var(--space-lg)}.empty-state-icon{margin-bottom:var(--space-xl);filter:grayscale(.1);opacity:.6;font-size:56px}.empty-state-icon svg{width:56px;height:56px}.empty-state-text{color:var(--color-text-secondary);font-size:var(--font-size-lg);margin-bottom:6px;font-weight:700}.empty-state-sub{color:var(--color-text-tertiary);font-size:var(--font-size-sm);max-width:260px;margin-inline:auto;line-height:1.45}.skeleton{background:linear-gradient(90deg, var(--color-surface-hover) 25%, var(--color-border-light) 50%, var(--color-surface-hover) 75%);border-radius:var(--radius-sm);background-size:200% 100%;animation:2s ease-in-out infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-card{border-radius:var(--radius-lg);height:120px;margin-bottom:var(--space-md)}.skeleton-text{width:60%;height:14px;margin-bottom:var(--space-sm)}.skeleton-text-sm{width:40%;height:12px}.skeleton-card-wrap{pointer-events:none;overflow:hidden}.skeleton-card-wrap .card-body,.skeleton-card-wrap .menu-card-body{gap:var(--space-sm);padding:var(--space-md);flex-direction:column;display:flex}.img-placeholder{background:linear-gradient(145deg, var(--color-surface-hover) 0%, var(--color-border) 100%);width:100%;color:var(--color-text-tertiary);justify-content:center;align-items:center;font-size:36px;display:flex}.card-img-placeholder{height:180px}.menu-card-img-placeholder{aspect-ratio:4/3;font-size:30px}.item-hero-placeholder{background:linear-gradient(145deg, var(--color-primary-50) 0%, var(--color-primary-100) 100%);height:280px;font-size:56px}.menu-card-badge{background:var(--color-text);color:var(--color-text-inverse);width:26px;height:26px;font-size:var(--font-size-xs);box-shadow:var(--shadow-md);z-index:2;border-radius:50%;justify-content:center;align-items:center;font-weight:800;animation:.3s cubic-bezier(.34,1.56,.64,1) badgePop;display:flex;position:absolute;top:10px;right:10px}@keyframes badgePop{0%{transform:scale(0)}to{transform:scale(1)}}.menu-search{padding:var(--space-sm) var(--space-lg) var(--space-xs)}.search-input-wrap{position:relative}.search-icon{color:var(--color-text-tertiary);pointer-events:none;align-items:center;font-size:14px;display:flex;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.search-icon svg{width:16px;height:16px}.search-input{border:1.5px solid var(--color-border);border-radius:var(--radius-md);width:100%;font-size:var(--font-size-base);background:var(--color-surface);color:var(--color-text);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);padding:12px 14px 12px 38px;font-family:inherit}.search-input:focus{border-color:var(--color-text);outline:none;box-shadow:0 0 0 3px #1a18140f}.search-input::placeholder{color:var(--color-text-secondary)}.search-clear{background:var(--color-text-tertiary);cursor:pointer;width:22px;height:22px;color:var(--color-text-inverse);transition:background var(--transition-fast), transform var(--transition-fast), opacity var(--transition-fast);-webkit-tap-highlight-color:transparent;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:11px;animation:.15s fadeIn;display:flex;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.search-clear svg{width:12px;height:12px}.search-clear:active{background:var(--color-text-secondary)}.recent-orders{margin-top:var(--space-3xl)}.recent-orders h2{font-size:var(--font-size-md);margin-bottom:var(--space-md);color:var(--color-text);font-weight:700}.recent-order-card{padding:var(--space-lg) var(--space-xl);background:var(--color-surface);border-radius:var(--radius-lg);margin-bottom:var(--space-sm);color:inherit;box-shadow:var(--shadow-sm);transition:transform var(--transition-spring), box-shadow var(--transition-base);border:none;justify-content:space-between;align-items:center;text-decoration:none;display:flex}.recent-order-card:active{box-shadow:var(--shadow-md);transform:scale(.975)}.recent-order-info{flex-direction:column;gap:2px;display:flex}.recent-order-num{font-weight:700;font-size:var(--font-size-base)}.recent-order-meta{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.recent-order-status{border-radius:var(--radius-full);font-size:var(--font-size-xs);white-space:nowrap;background:var(--color-surface-hover);color:var(--color-text-secondary);padding:5px 14px;font-weight:700}.recent-order-right{align-items:center;gap:var(--space-sm);flex-shrink:0;display:flex}.recent-order-chevron{color:var(--color-text-tertiary);transition:transform var(--transition-fast);font-size:20px;line-height:1}.recent-order-card:active .recent-order-chevron{transform:translate(3px)}.pwa-install-banner{bottom:var(--bottom-nav-h);background:var(--color-surface);padding:var(--space-lg);z-index:150;border-top:1px solid #0000000f;justify-content:space-between;align-items:center;animation:.35s cubic-bezier(.34,1.56,.64,1) dialogSlideUp;display:flex;position:fixed;left:0;right:0;box-shadow:0 -4px 24px #0000000f}.pwa-install-text{flex:1}.pwa-install-text strong{margin-bottom:2px;font-size:14px;display:block}.pwa-install-text span{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.pwa-install-btn{background:var(--color-text);color:var(--color-text-inverse);border-radius:var(--radius-md);cursor:pointer;white-space:nowrap;transition:transform var(--transition-spring);border:none;padding:10px 22px;font-size:14px;font-weight:700}.pwa-install-btn:active{transform:scale(.95)}.pwa-install-close{color:var(--color-text-tertiary);cursor:pointer;background:0 0;border:none;margin-left:8px;padding:4px 8px;font-size:20px}.pwa-ios-share{vertical-align:middle;color:var(--color-primary-600);display:inline-flex}.pwa-ios-share svg{width:16px;height:16px}body:has(.pwa-install-banner) .item-actions{bottom:calc(var(--bottom-nav-h) + 72px)}body:has(.pwa-install-banner) .cart-footer-sticky{bottom:calc(var(--bottom-nav-h) + 72px)}body:has(.pwa-install-banner) .checkout-sticky-footer{bottom:calc(var(--bottom-nav-h) + 72px)}body:has(.pwa-install-banner) .scroll-top-btn{bottom:calc(var(--bottom-nav-h) + 96px)}body:has(.pwa-install-banner) .toast-container{bottom:calc(var(--bottom-nav-h) + 152px)}body:has(.pwa-install-banner) .item-page{padding-bottom:152px}body:has(.pwa-install-banner) .cart-page{padding-bottom:172px}body:has(.pwa-install-banner) .profile-page{padding-bottom:80px}.scroll-top-btn{bottom:calc(var(--bottom-nav-h) + 24px);background:var(--color-surface);width:44px;height:44px;box-shadow:var(--shadow-md);cursor:pointer;z-index:50;transition:opacity var(--transition-base), transform var(--transition-spring);-webkit-tap-highlight-color:transparent;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:18px;animation:.2s ease-out fadeIn;display:flex;position:fixed;right:16px}.scroll-top-btn:active{transform:scale(.88)}.phone-input-wrap{position:relative}.phone-prefix{color:var(--color-text-secondary);font-size:var(--font-size-md);pointer-events:none;position:absolute;top:50%;left:16px;transform:translateY(-50%)}.phone-input-wrap input{padding-left:40px!important}.empty-state-action{margin-top:var(--space-xl);text-decoration:none;display:inline-block}.error-boundary{padding:var(--space-4xl) var(--space-xl);text-align:center;max-width:400px;margin:0 auto}.error-boundary h2{font-size:var(--font-size-xl);margin-bottom:var(--space-sm)}.error-boundary p{color:var(--color-text-secondary);margin-bottom:var(--space-2xl);line-height:1.5}.checkout-restaurant{color:var(--color-text);margin:0 0 var(--space-md);font-weight:600;font-size:var(--font-size-md)}.checkout-items-list{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.checkout-items-list li{font-size:var(--font-size-sm);color:var(--color-text-secondary);justify-content:space-between;align-items:baseline;display:flex}.checkout-items-list li span:last-child{font-variant-numeric:tabular-nums;white-space:nowrap;margin-left:var(--space-md)}.checkout-total{margin:var(--space-md) 0 0;padding-top:var(--space-md);border-top:1px solid var(--color-border);font-weight:700;font-size:var(--font-size-md);color:var(--color-text);text-align:right}.form-error-centered{text-align:center;padding:var(--space-md) var(--space-lg);background:var(--color-error-bg);border-radius:var(--radius-md);color:var(--color-error);font-size:var(--font-size-sm);margin:var(--space-md) 0;font-weight:500;line-height:1.45}.order-new-link{text-align:center;text-decoration:none;display:block}.lookup-form{margin-top:var(--space-lg)}.card-img,.menu-card-img,.cart-item-img,.item-hero{animation:.35s ease-out both imgFadeIn}.category-tabs-wrap{position:relative}.category-tabs-wrap:before,.category-tabs-wrap:after{content:"";z-index:10;pointer-events:none;opacity:0;width:32px;transition:opacity var(--transition-fast);position:absolute;top:0;bottom:0}.category-tabs-wrap:before{background:linear-gradient(90deg,#faf9f7f2,#0000);left:0}.category-tabs-wrap:after{background:linear-gradient(270deg,#faf9f7f2,#0000);right:0}.category-tabs-wrap.fade-left:before,.category-tabs-wrap.fade-right:after{opacity:1}.progress-step-group{display:contents}.skel-w70{width:70%}.skel-w80{width:80%}.skel-w50{width:50%}.skel-w35{width:35%}.skel-w30{width:30%}.skel-h24{height:24px}.skel-mt8{margin-top:8px}.skel-mt6{margin-top:6px}.skel-mt16{margin-top:16px}.skel-tab{border-radius:9999px;width:72px;height:34px}@media (hover:hover){.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.menu-card:hover{border-color:var(--color-border);transform:translateY(-2px)}.btn-primary:hover:not(:disabled){opacity:.88}.btn-secondary:hover,.tab:hover:not(.active){background:var(--color-surface-hover)}.modifier-opt:hover:not(.selected){border-color:var(--color-text-tertiary)}.qty-control button:hover:not(:disabled){background:var(--color-surface-hover)}.recent-order-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.recent-order-card:hover .recent-order-chevron{color:var(--color-primary);transform:translate(3px)}.menu-card-quick-add:hover{opacity:.9;transform:scale(1.1)}}:focus-visible,button:focus-visible,a:focus-visible,input:focus-visible,textarea:focus-visible{outline:2px solid var(--color-text);outline-offset:2px}input:focus-visible,textarea:focus-visible{outline:none}.tab:focus-visible{outline-offset:-2px}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}.item-hero-wrap:after{content:"";pointer-events:none;background:linear-gradient(#0000,#faf9f799);height:80px;position:absolute;bottom:0;left:0;right:0}.empty-state-icon{animation:3s ease-in-out infinite emptyFloat}@keyframes emptyFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.recent-order-status.status-green{background:var(--color-success-bg);color:var(--color-success)}.recent-order-status.status-red{background:var(--color-error-bg);color:var(--color-error)}.recent-order-status.status-orange{color:#e65100;background:#fff3e0}.recent-order-status.status-yellow{background:var(--color-warning-bg);color:#b45309}.recent-order-status.status-blue{background:var(--color-info-bg);color:var(--color-info)}.recent-order-status.status-grey{background:var(--color-surface-hover);color:var(--color-text-tertiary)}.order-actions-row{gap:var(--space-sm);margin-top:var(--space-xl);display:flex}.order-actions-row .btn-secondary{flex:1}.order-share-btn{cursor:pointer;-webkit-tap-highlight-color:transparent;align-items:center;gap:6px;display:inline-flex}.order-share-btn svg{width:16px;height:16px}.order-reorder-link{margin-top:var(--space-2xl);text-align:center;justify-content:center;align-items:center;gap:6px;text-decoration:none;display:flex}.order-reorder-link svg{width:18px;height:18px}.checkout-form textarea{resize:none;min-height:56px;overflow:hidden}.qty-control button:disabled:active{background:0 0}.copy-btn{cursor:pointer;vertical-align:middle;margin-left:var(--space-sm);border-radius:var(--radius-sm);transition:background var(--transition-fast);-webkit-tap-highlight-color:transparent;background:0 0;border:none;align-items:center;padding:4px 8px;font-size:18px;display:inline-flex}.copy-btn svg{width:16px;height:16px}.copy-btn:active{background:var(--color-surface-hover)}.nutrition-info{gap:var(--space-md);margin-top:var(--space-md);padding:var(--space-md) 0;border-top:1px solid var(--color-border-light);display:flex}.nutrition-item{flex-direction:column;align-items:center;min-width:48px;display:flex}.nutrition-val{font-size:var(--font-size-sm);color:var(--color-text);font-weight:700}.nutrition-label{color:var(--color-text-tertiary);text-transform:lowercase;font-size:10px}.hidden{display:none!important}.tag-chip{border-radius:var(--radius-full);background:var(--color-primary-50);color:var(--color-primary-700);letter-spacing:.2px;padding:2px 8px;font-size:10px;font-weight:600;display:inline-block}.menu-card-tags{flex-wrap:wrap;gap:4px;margin:6px 0 0;display:flex}.item-tags{margin-bottom:var(--space-lg);flex-wrap:wrap;gap:6px;display:flex}.item-tags .tag-chip{font-size:var(--font-size-xs);padding:4px 12px}.item-hero-wrap{position:relative}.btn-loading{justify-content:center;align-items:center;gap:8px;display:inline-flex}.btn-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;flex-shrink:0;width:16px;height:16px;animation:.7s linear infinite spin}@media (width<=380px){.menu-grid{grid-template-columns:1fr}.checkout-summary{padding:var(--space-md)}.order-progress{margin:var(--space-lg) 0}.progress-label{max-width:52px;font-size:9px}}@media (width<=600px){.page{padding:var(--space-lg) var(--space-md)}.card-grid{grid-template-columns:1fr}.cart-item-tap{gap:10px}.cart-item-bottom{padding-left:70px}.cart-item-img,.cart-item-img-placeholder{width:60px;height:60px}}.offline-banner{z-index:999;background:var(--color-error);color:#fff;text-align:center;padding:6px var(--space-md);animation:slideDown .3s var(--transition-spring);font-size:.85rem;font-weight:600;position:sticky;top:56px}@keyframes slideDown{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.4)}}.cart-title-row{justify-content:space-between;align-items:center;gap:var(--space-md);display:flex}.btn-clear-cart{color:var(--color-error);cursor:pointer;border-radius:var(--radius-sm);transition:background var(--transition-fast);background:0 0;border:none;padding:4px 8px;font-size:.85rem;font-weight:500}.btn-clear-cart:hover,.btn-clear-cart:focus-visible{background:#ef44441a}.restaurant-desc{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-top:4px;line-height:1.4}.search-results-count{color:var(--color-text-tertiary);font-size:var(--font-size-xs);margin:4px 0 0;padding-left:2px}.menu-card-footer{justify-content:space-between;align-items:center;margin-top:auto;display:flex}.menu-card-quick-add{background:var(--color-primary);width:36px;height:36px;color:var(--color-text-inverse);cursor:pointer;transition:transform var(--transition-spring), opacity var(--transition-fast);-webkit-tap-highlight-color:transparent;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:18px;font-weight:700;display:flex}.menu-card-quick-add svg{width:16px;height:16px}.menu-card-quick-add:active{opacity:.85;transform:scale(.85)}.phone-field{position:relative}.phone-field input{width:100%}.phone-field .input-valid{border-color:var(--color-success)}.phone-field .input-valid:focus{border-color:var(--color-success);box-shadow:0 0 0 3px #16a34a1a}.input-check{color:var(--color-success);pointer-events:none;align-items:center;font-size:16px;font-weight:700;animation:.3s cubic-bezier(.34,1.56,.64,1) checkPop;display:flex;position:absolute;top:50%;right:14px;transform:translateY(-50%)}.input-check svg,.input-x svg{width:16px;height:16px}@keyframes checkPop{0%{transform:translateY(-50%)scale(0)}to{transform:translateY(-50%)scale(1)}}.order-auto-refresh{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-top:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);border-left:3px solid var(--color-success);background:#16a34a0d;align-items:center;gap:8px;display:flex}.order-auto-refresh:before{content:"";background:var(--color-success);border-radius:50%;flex-shrink:0;width:6px;height:6px;animation:2s ease-in-out infinite pulse-dot}.empty-cart-recent{text-align:center;margin-top:var(--space-lg);color:var(--color-primary);font-size:var(--font-size-sm);transition:opacity var(--transition-fast);font-weight:600;text-decoration:none;display:block}.empty-cart-recent:active{opacity:.7}.confetti-burst{cursor:pointer;pointer-events:none;z-index:1000;animation:3s ease-out forwards confettiFadeOut;position:fixed;inset:0}.confetti-burst:before,.confetti-burst:after{content:"";border-radius:2px;width:8px;height:8px;animation:2.5s ease-in forwards confettiRain;position:absolute;top:-10%;left:0}.confetti-burst:before{box-shadow:10px 0 #ff6b6b,40px 12px #4ecdc4,70px 4px #ffe66d,100px 18px #a8e6cf,140px 2px #ff8a5c,170px 14px #6c5ce7,210px 8px #ff6b6b,250px 16px #4ecdc4,280px 0 #ffe66d,310px 10px #a8e6cf,340px 6px #ff8a5c,370px 14px #6c5ce7}.confetti-burst:after{top:-6%;left:20px;box-shadow:25px 6px #6c5ce7,55px 0 #ffe66d,85px 16px #ff6b6b,115px 10px #4ecdc4,155px 4px #a8e6cf,185px 14px #ff8a5c,225px 2px #ffe66d,265px 12px #6c5ce7,295px 8px #ff6b6b,325px 0 #4ecdc4,355px 18px #a8e6cf,385px 6px #ff8a5c}@keyframes confettiRain{0%{opacity:1;transform:translateY(0)rotate(0)}50%{opacity:1}to{opacity:0;transform:translateY(110vh)rotate(720deg)}}@keyframes confettiFadeOut{0%,75%{opacity:1}to{opacity:0}}.menu-card,.menu-card-body{flex-direction:column;display:flex}.menu-card-footer{padding-top:var(--space-sm);margin-top:auto}.tab-count{opacity:.5;margin-left:3px;font-size:11px;font-weight:400}.tab.active .tab-count{opacity:.7}.order-terminal-banner{text-align:center;padding:var(--space-lg) var(--space-md);border-radius:var(--radius-lg);margin-top:var(--space-md)}.order-terminal-banner.cancelled,.order-terminal-banner.error{background:#ef44440f}.order-terminal-banner.expired{background:#6b72800f}.order-terminal-icon{margin-bottom:var(--space-sm);justify-content:center;align-items:center;font-size:48px;display:flex}.order-terminal-icon svg{width:48px;height:48px}.order-terminal-title{font-size:var(--font-size-md);margin:0 0 4px;font-weight:700}.order-terminal-sub{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.qty-control span{transition:transform .15s cubic-bezier(.34,1.56,.64,1)}.qty-control button:active+span{transform:scale(1.2)}.qty-control span:has(+button:active){transform:scale(1.2)}@media (prefers-reduced-motion:reduce){.confetti-burst,.confetti-burst:before,.confetti-burst:after{animation:none;display:none}}.menu-card-quick-add.just-added{background:var(--color-success);animation:.35s cubic-bezier(.34,1.56,.64,1) quickAddPop}@keyframes quickAddPop{0%{transform:scale(.7)}50%{transform:scale(1.15)}to{transform:scale(1)}}.menu-card-qty-control{background:var(--color-primary);border-radius:var(--radius-full);align-items:center;display:flex;overflow:hidden}.menu-card-qty-control button{width:28px;height:28px;color:var(--color-text-inverse);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;padding:0;font-size:16px;font-weight:700;display:flex}.menu-card-qty-control button svg{width:14px;height:14px}.menu-card-qty-control button:active{background:#ffffff38}.menu-card-qty-control button.just-added{background:var(--color-success)}.menu-card-qty-control span{color:var(--color-text-inverse);text-align:center;min-width:18px;font-size:13px;font-weight:700;line-height:1}.checkout-items-list li{gap:var(--space-sm)}.checkout-item-thumb{border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0;width:36px;height:36px}.checkout-item-thumb-placeholder{border-radius:var(--radius-sm);background:var(--color-surface-hover);flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;display:flex}.checkout-item-name{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.ready-since{font-size:var(--font-size-sm);opacity:.75;margin-top:4px;font-weight:500;transition:opacity .3s;animation:.4s readySinceFade;display:block}@keyframes readySinceFade{0%{opacity:0;transform:translateY(2px)}to{opacity:.75;transform:translateY(0)}}.item-in-cart-badge{background:var(--color-success-bg);color:var(--color-success);font-size:var(--font-size-xs);border-radius:var(--radius-full);white-space:nowrap;padding:4px 12px;font-weight:700;text-decoration:none;animation:.3s cubic-bezier(.34,1.56,.64,1) badgePop;position:absolute;top:-36px;right:0}.order-items-toggle{width:100%;padding:0 0 var(--space-sm);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;justify-content:space-between;align-items:center;display:flex}.order-items-toggle h2{font-size:var(--font-size-md);margin:0}.toggle-chevron{font-size:var(--font-size-sm);color:var(--color-text-tertiary);transition:transform .25s}.toggle-chevron.open{transform:rotate(180deg)}.order-items-list{animation:.3s itemsReveal}.order-items-list.collapsed{display:none}@keyframes itemsReveal{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.order-items-show-all{border:1px dashed var(--color-border);border-radius:var(--radius-md);width:100%;padding:var(--space-sm);margin-top:var(--space-xs);font-size:var(--font-size-sm);color:var(--color-primary);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;transition:background .2s;display:block}.order-items-show-all:hover{background:var(--color-bg-secondary)}@media (width>=601px) and (width<=1024px){.page{max-width:720px;margin:0 auto}.menu-grid{grid-template-columns:repeat(3,1fr)}.card-grid{grid-template-columns:repeat(2,1fr)}.checkout-form{max-width:500px}.orders-layout{gap:var(--space-lg);grid-template-columns:1fr 1fr;display:grid}}@media (width>=1025px){.page{max-width:960px;margin:0 auto}.menu-grid{grid-template-columns:repeat(4,1fr)}.card-grid{grid-template-columns:repeat(3,1fr)}.checkout-form{max-width:480px}}.bottom-nav{z-index:100;height:var(--bottom-nav-h);padding-top:10px;padding-bottom:calc(env(safe-area-inset-bottom,20px) + 14px);-webkit-backdrop-filter:blur(20px)saturate(1.8);background:#fffffff2;border-top:1px solid #0000000f;justify-content:space-around;align-items:flex-start;display:flex;position:fixed;bottom:0;left:0;right:0}.bnav-tab{color:var(--color-text-tertiary);border-radius:var(--radius-md);-webkit-tap-highlight-color:transparent;cursor:pointer;background:0 0;border:none;flex-direction:column;align-items:center;gap:2px;padding:4px 20px;font-family:inherit;font-size:10px;text-decoration:none;transition:color .15s;display:flex;position:relative}.bnav-tab.active{color:var(--color-primary)}.bnav-tab.active .bnav-icon{background:var(--color-primary-bg,#ff6b001a);border-radius:var(--radius-full)}@keyframes bnav-bounce{0%{transform:scale(.75)translateY(2px)}50%{transform:scale(1.15)translateY(-2px)}to{transform:scale(1)translateY(0)}}.bnav-icon{border-radius:var(--radius-full);justify-content:center;align-items:center;width:48px;height:28px;font-size:22px;line-height:1;transition:background .2s;display:flex;position:relative}.bnav-label{letter-spacing:.1px;font-weight:600}.bnav-badge{background:var(--color-primary);color:#fff;min-width:18px;height:18px;font-size:10px;font-weight:800;font-family:var(--font-sans);border-radius:9px;justify-content:center;align-items:center;padding:0 4px;animation:.3s cubic-bezier(.34,1.56,.64,1) badgePop;display:flex;position:absolute;top:-4px;right:-12px}.bnav-dot{background:var(--color-success);border-radius:50%;width:8px;height:8px;animation:2s ease-in-out infinite pulse-dot;position:absolute;top:0;right:-8px}.card-grid>*,.menu-grid>*{animation:.45s cubic-bezier(.25,.46,.45,.94) backwards cardStagger}.card-grid>:first-child{animation-delay:50ms}.card-grid>:nth-child(2){animation-delay:.12s}.card-grid>:nth-child(3){animation-delay:.19s}.card-grid>:nth-child(4){animation-delay:.26s}.card-grid>:nth-child(5){animation-delay:.33s}.card-grid>:nth-child(n+6){animation-delay:.38s}.menu-grid>:first-child{animation-delay:30ms}.menu-grid>:nth-child(2){animation-delay:70ms}.menu-grid>:nth-child(3){animation-delay:.11s}.menu-grid>:nth-child(4){animation-delay:.15s}.menu-grid>:nth-child(5){animation-delay:.19s}.menu-grid>:nth-child(6){animation-delay:.23s}.menu-grid>:nth-child(7){animation-delay:.27s}.menu-grid>:nth-child(8){animation-delay:.31s}.menu-grid>:nth-child(n+9){animation-delay:.34s}@keyframes cardStagger{0%{opacity:0;transform:translateY(16px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.card:before{content:"";background:linear-gradient(to bottom, transparent, var(--color-surface));z-index:1;pointer-events:none;height:40px;position:absolute;top:140px;left:0;right:0}.menu-card:before{content:"";background:linear-gradient(to bottom, transparent, var(--color-surface));z-index:1;pointer-events:none;height:40px;position:absolute;top:88px;left:0;right:0}@media (hover:hover){.bnav-tab:hover{color:var(--color-primary-600)}}.card-body-row{align-items:center;gap:var(--space-md);display:flex}.card-body-text{flex:1;min-width:0}.card-body-text h2{font-size:var(--font-size-lg);letter-spacing:-.2px;margin:0 0 4px;font-weight:700}.card-chevron{color:var(--color-text-tertiary);transition:transform var(--transition-fast);flex-shrink:0;font-size:24px;line-height:1}.card:active .card-chevron{transform:translate(3px)}@media (hover:hover){.card:hover .card-chevron{color:var(--color-primary);transform:translate(3px)}}.item-breadcrumb{font-size:var(--font-size-sm);color:var(--color-primary);margin-bottom:var(--space-md);transition:opacity var(--transition-fast);align-items:center;gap:4px;padding:4px 0;font-weight:600;text-decoration:none;display:inline-flex}.item-breadcrumb:active{opacity:.6}.order-meta{margin-top:var(--space-xl);border-radius:var(--radius-lg);background:var(--color-surface);color:var(--color-text);box-shadow:var(--shadow-sm);padding:0;font-size:14px;overflow:hidden}.order-meta-item{align-items:flex-start;gap:var(--space-md);padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-divider);display:flex}.order-meta-item:last-child{border-bottom:none}.order-meta-icon{flex-shrink:0;align-items:center;margin-top:2px;font-size:18px;display:flex}.order-meta-icon svg{width:18px;height:18px}.order-meta-label{font-size:var(--font-size-xs);color:var(--color-text-tertiary);font-weight:500}.checkout-summary-header{margin-bottom:var(--space-md);justify-content:space-between;align-items:center;display:flex}.checkout-item-count{background:var(--color-text);color:var(--color-text-inverse);width:28px;height:28px;font-size:var(--font-size-sm);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-weight:800;display:flex}.checkout-total-row{margin-top:var(--space-lg);padding-top:var(--space-lg);border-top:1.5px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.checkout-total-price{font-size:var(--font-size-xl);color:var(--color-text);letter-spacing:-.3px;font-weight:800}.checkout-total-row>span:first-child{font-size:var(--font-size-md);color:var(--color-text-secondary);font-weight:600}.lookup-hero{text-align:center;margin-bottom:var(--space-xl)}.lookup-hero-icon{margin-bottom:var(--space-sm);justify-content:center;align-items:center;font-size:48px;display:flex}.lookup-hero-icon svg{width:48px;height:48px}.lookup-hero h1{margin-bottom:0}.ptr-indicator{opacity:0;height:0;margin:0 calc(-1 * var(--space-lg));justify-content:center;align-items:center;display:flex;overflow:hidden}.ptr-spinner{border:2.5px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:24px;height:24px;display:block}.ptr-refreshing .ptr-spinner{animation:.7s linear infinite spin}.cart-item-unit-price{color:var(--color-text-tertiary);white-space:nowrap;margin-left:6px;font-size:11px;font-weight:400}.empty-cart-cta{width:100%;max-width:280px;margin:var(--space-2xl) auto 0;text-align:center;display:block}.order-status-badge.status-orange,.order-status-badge.status-blue{position:relative;overflow:hidden}.order-status-badge.status-orange:after,.order-status-badge.status-blue:after{content:"";background:linear-gradient(90deg,#0000,#ffffff59,#0000);width:100%;height:100%;animation:2.5s ease-in-out infinite statusShimmer;position:absolute;top:0;left:-100%}@keyframes statusShimmer{0%{left:-100%}50%,to{left:100%}}.checkout-form-divider{background:var(--color-divider);height:1px;margin:var(--space-xs) 0}.card-desc{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.order-ready-banner{font-size:var(--font-size-md);line-height:1.5}.order-payment-banner{text-align:center;padding:var(--space-xl) var(--space-lg);border-radius:var(--radius-lg);margin-top:var(--space-md);background:#f973160f;border:1px solid #f9731626}.order-payment-icon{margin-bottom:var(--space-sm);color:var(--color-primary);justify-content:center;align-items:center;font-size:40px;display:flex}.order-payment-icon svg{width:40px;height:40px}.order-payment-title{font-size:var(--font-size-md);color:var(--color-text);margin:0 0 4px;font-weight:700}.order-payment-sub{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0;line-height:1.45}.empty-state+.btn-secondary.empty-state-action{max-width:280px;margin:var(--space-xl) auto 0;display:block}.order-item:nth-child(2n){margin:0 calc(-1 * var(--space-md));padding-left:var(--space-md);padding-right:var(--space-md);border-radius:var(--radius-sm);background:#00000004}.item-actions{padding-bottom:max(14px, env(safe-area-inset-bottom,14px))}.cart-footer-sticky{padding-bottom:max(var(--space-lg), env(safe-area-inset-bottom,var(--space-lg)))}.lookup-form{max-width:360px;margin-left:auto;margin-right:auto}.section-title{align-items:center;gap:var(--space-md);display:flex}.section-title:after{content:"";background:var(--color-divider);flex:1;height:1px}.checkout-steps{margin-bottom:var(--space-xl);padding:0 var(--space-xl);justify-content:center;align-items:center;gap:0;display:flex}.cstep{color:inherit;flex-direction:column;flex-shrink:0;align-items:center;gap:6px;text-decoration:none;display:flex}.cstep-dot{width:32px;height:32px;font-size:var(--font-size-sm);border:2px solid var(--color-border);background:var(--color-surface);color:var(--color-text-tertiary);transition:all var(--transition-fast);border-radius:50%;justify-content:center;align-items:center;font-weight:800;display:flex}.cstep-dot svg{width:14px;height:14px}.cstep.active .cstep-dot{border-color:var(--color-text);background:var(--color-text);color:var(--color-text-inverse);box-shadow:0 0 0 4px #1a18140f}.cstep.done .cstep-dot{border-color:var(--color-success);background:var(--color-success);color:#fff}.cstep-label{font-size:var(--font-size-xs);color:var(--color-text-tertiary);font-weight:600}.cstep.active .cstep-label{color:var(--color-text)}.cstep.done .cstep-label{color:var(--color-success)}.cstep-line{background:var(--color-border);min-width:40px;max-width:80px;height:2px;margin:0 var(--space-sm);transition:background var(--transition-fast);flex:1;margin-bottom:22px}.cstep-line.done{background:var(--color-success)}.cstep-line.active{background:linear-gradient(to right, var(--color-text), var(--color-border))}@keyframes shake{0%,to{transform:translate(0)}10%,50%,90%{transform:translate(-4px)}30%,70%{transform:translate(4px)}}.modifier-group.shake{animation:.5s ease-in-out shake}.modifier-group.required-group.shake{border-color:var(--color-error);box-shadow:0 0 0 3px #dc26261a}.modifier-group.required-group.highlight{border-color:var(--color-error);transition:border-color .3s,box-shadow .3s;box-shadow:0 0 0 4px #dc26261f}.online-banner{z-index:999;background:var(--color-success);color:#fff;text-align:center;padding:6px var(--space-md);animation:slideDown .3s var(--transition-spring), fadeOut .4s ease 2s forwards;font-size:.85rem;font-weight:600;position:sticky;top:56px}@keyframes fadeOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-100%)}}.empty-search-clear{max-width:200px;margin:var(--space-lg) auto 0}.phone-field .input-invalid{border-color:var(--color-error)}.phone-field .input-invalid:focus{border-color:var(--color-error);box-shadow:0 0 0 3px #dc262614}.input-x{color:var(--color-error);pointer-events:none;opacity:.5;align-items:center;font-size:14px;font-weight:600;display:flex;position:absolute;top:50%;right:14px;transform:translateY(-50%)}.order-header-top{justify-content:space-between;align-items:center;gap:var(--space-md);flex-wrap:wrap;display:flex}.menu-card-body h3{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.qty-control button:disabled{opacity:.55;cursor:not-allowed}.cart-item-info h3{white-space:normal;-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}.menu-card-select-btn{border-radius:var(--radius-full);border:1.5px solid var(--color-primary);color:var(--color-primary);font-size:var(--font-size-xs);cursor:pointer;white-space:nowrap;transition:all var(--transition-fast);-webkit-tap-highlight-color:transparent;background:0 0;flex-shrink:0;padding:6px 14px;font-weight:700}.menu-card-select-btn:active{background:var(--color-primary);color:#fff;transform:scale(.93)}@media (hover:hover){.menu-card-select-btn:hover{background:var(--color-primary);color:#fff}}.swipe-hint{padding:var(--space-xs) var(--space-md);margin-bottom:var(--space-xs);color:var(--color-text-tertiary);font-size:var(--font-size-xs);cursor:pointer;justify-content:center;align-items:center;gap:6px;font-weight:500;animation:2s ease-in-out infinite swipeHintAnim;display:flex}.swipe-hint svg{width:16px;height:16px;animation:1.5s ease-in-out infinite swipeArrow}@keyframes swipeArrow{0%,to{opacity:.5;transform:translate(0)}50%{opacity:1;transform:translate(-6px)}}@keyframes swipeHintAnim{0%,to{opacity:.6}50%{opacity:1}}.empty-cart-last-order{padding:var(--space-lg) var(--space-xl);margin-top:var(--space-xl);background:var(--color-surface);border-radius:var(--radius-lg);color:inherit;box-shadow:var(--shadow-sm);transition:transform var(--transition-spring), box-shadow var(--transition-base);justify-content:space-between;align-items:center;text-decoration:none;display:flex}.empty-cart-last-order:active{box-shadow:var(--shadow-md);transform:scale(.975)}.empty-cart-last-order-info{flex-direction:column;gap:2px;min-width:0;display:flex}.empty-cart-last-order-label{font-size:var(--font-size-xs);color:var(--color-text-tertiary);font-weight:500}.empty-cart-last-order-name{font-weight:700;font-size:var(--font-size-base);color:var(--color-text)}.empty-cart-last-order-meta{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.empty-cart-last-order-right{align-items:center;gap:var(--space-sm);flex-shrink:0;display:flex}@media (hover:hover){.empty-cart-last-order:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}}.checkout-form input,.checkout-form textarea{transition:border-color var(--transition-base), box-shadow var(--transition-base), background var(--transition-fast)}.checkout-form input:hover:not(:focus),.checkout-form textarea:hover:not(:focus){border-color:var(--color-text-tertiary)}.search-results-count{padding:2px var(--space-lg);animation:.2s fadeIn}.menu-card-desc{line-height:1.4}.cart-item-delete-btn{transition:opacity var(--transition-fast);border-radius:0}.cart-item-delete-btn:active{opacity:.85}.menu-bottom-bar{bottom:var(--bottom-nav-h);z-index:50;-webkit-backdrop-filter:blur(20px)saturate(1.8);background:#fffffff2;border-top:1px solid #0000000f;flex-direction:column;gap:6px;max-width:600px;margin:0 auto;padding:8px 12px;display:flex;position:fixed;left:0;right:0}.menu-search-btn{border-radius:var(--radius-full);border:1.5px solid var(--color-border);background:var(--color-surface);width:36px;height:36px;color:var(--color-text-secondary);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:border-color var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;display:flex}.menu-search-btn svg{width:16px;height:16px}.menu-search-btn:active{border-color:var(--color-text)}.menu-bottom-bar>.category-tabs-wrap{flex:1;min-width:0}.menu-bottom-bar>.menu-bottom-search{flex:1}.menu-bottom-bar>.menu-bottom-search .search-input{font-size:var(--font-size-sm);padding:8px 14px 8px 38px}.menu-bottom-bar>:first-child.menu-search-btn{z-index:2;position:absolute;top:8px;left:12px}.menu-bottom-bar:has(.menu-search-btn)>.category-tabs-wrap{padding-left:40px}.menu-bottom-bar .tag-filter-bar{padding:0}.menu-page{padding-bottom:calc(var(--bottom-nav-h) + 80px)!important}.restaurant-schedule{background:var(--color-surface);border-radius:var(--radius-full);border:1px solid var(--color-border-light);cursor:pointer;-webkit-tap-highlight-color:transparent;white-space:nowrap;flex-shrink:0;align-items:center;gap:5px;padding:5px 10px;transition:border-radius .2s,padding .2s;display:inline-flex}.restaurant-schedule.open{border-radius:var(--radius-lg);cursor:default;right:var(--space-lg);z-index:20;box-shadow:var(--shadow-md);background:var(--color-surface);align-items:flex-start;margin-top:4px;padding:8px 12px;position:absolute;top:100%}.restaurant-schedule>svg{width:15px;height:15px;color:var(--color-primary);flex-shrink:0;margin-top:1px}.schedule-summary{font-size:var(--font-size-xs);color:var(--color-text-secondary);align-items:center;gap:4px;font-weight:500;display:flex}.schedule-summary svg{color:var(--color-text-tertiary)}.restaurant-schedule-rows{flex-direction:column;gap:2px;display:flex}.restaurant-schedule-item{font-size:var(--font-size-xs);align-items:center;gap:8px;line-height:1.4;display:flex}.schedule-day{color:var(--color-text-secondary);min-width:56px;font-weight:600}.schedule-time{color:var(--color-text);font-variant-numeric:tabular-nums;font-weight:500}.cart-continue{font-size:var(--font-size-sm);color:var(--color-primary);border-radius:var(--radius-full);transition:background var(--transition-fast);margin-bottom:var(--space-sm);background:#f9731614;align-items:center;gap:4px;padding:8px 14px;font-weight:600;text-decoration:none;display:inline-flex}.cart-continue:active{background:#f9731626}.qty-control button:active:not(:disabled){transform:scale(.9)}.progress-label{font-weight:500}.tag-chip{background:var(--color-primary-100);color:var(--color-primary-700);letter-spacing:0}.tag-filter-bar{padding:6px var(--space-md);-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:8px;display:flex;overflow-x:auto}.tag-filter-bar::-webkit-scrollbar{display:none}.tag-filter-chip{border-radius:var(--radius-full);border:1.5px solid var(--color-primary-200);background:var(--color-surface);color:var(--color-text-secondary);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;-webkit-tap-highlight-color:transparent;flex-shrink:0;padding:6px 14px;font-weight:500}.tag-filter-chip:active{transform:scale(.93)}.tag-filter-chip.active{background:var(--color-primary-500);color:#fff;border-color:var(--color-primary-500);order:-1;box-shadow:0 2px 8px #f9731640}.qr-error-actions{gap:var(--space-md);margin-top:var(--space-2xl);flex-direction:column;max-width:280px;margin-inline:auto;display:flex}.btn-secondary{border-radius:var(--radius-md);color:var(--color-text-secondary);background:var(--color-surface);border:1px solid var(--color-border);transition:background var(--transition-base);justify-content:center;align-items:center;padding:14px 24px;font-size:15px;font-weight:600;text-decoration:none;display:inline-flex}.btn-secondary:active{background:var(--color-border-light)}.lookup-manual{margin-top:var(--space-2xl);border-top:1px solid var(--color-border-light);padding-top:var(--space-md)}.lookup-manual summary{cursor:pointer;font-size:var(--font-size-sm);color:var(--color-text-tertiary);text-align:center;padding:var(--space-sm) 0;font-weight:500;list-style:none}.lookup-manual summary::marker{display:none}.lookup-manual summary::-webkit-details-marker{display:none}.lookup-manual summary:before{content:"▶︎";transition:transform var(--transition-base);margin-right:4px;font-size:10px;display:inline-block}.lookup-manual[open] summary:before{transform:rotate(90deg)}.lookup-manual .lookup-form{margin-top:var(--space-md)}.sw-update-banner{bottom:calc(var(--bottom-nav-h) + 16px);z-index:250;background:var(--color-text);color:var(--color-text-inverse);border-radius:var(--radius-full);box-shadow:var(--shadow-float);align-items:center;gap:12px;padding:12px 20px;font-size:14px;font-weight:600;animation:.35s cubic-bezier(.34,1.56,.64,1) toastIn;display:flex;position:fixed;left:50%;transform:translate(-50%)}.sw-update-banner button{background:var(--color-primary);color:#fff;border-radius:var(--radius-sm);cursor:pointer;border:none;padding:6px 14px;font-size:13px;font-weight:700}.cart-items{padding-bottom:calc(var(--bottom-nav-h) + 80px)}@media (hover:hover) and (pointer:fine){.cart-item-delete-icon{background:var(--color-surface);border:1px solid var(--color-border-light,var(--color-border));cursor:pointer;opacity:0;width:28px;height:28px;transition:opacity var(--transition-fast), background var(--transition-fast), color var(--transition-fast);z-index:2;color:var(--color-text-tertiary);border-radius:50%;justify-content:center;align-items:center;padding:0;display:flex;position:absolute;top:8px;right:8px}.cart-item-delete-icon svg{width:14px;height:14px}.cart-item-delete-icon:hover{background:var(--color-error-bg);color:var(--color-error);border-color:var(--color-error)}.cart-item-wrapper:hover .cart-item-delete-icon{opacity:1}}.btn-link{color:var(--color-primary);font:inherit;font-size:var(--font-size-sm);cursor:pointer;background:0 0;border:none;padding:0;font-weight:600;text-decoration:none}.btn-link:disabled{opacity:.4;cursor:not-allowed}.btn-sm{font-size:var(--font-size-sm);padding:8px 14px}.login-page{max-width:400px;margin:0 auto}.login-page h1{text-align:center}.login-subtitle{text-align:center;color:var(--color-text-secondary);font-size:var(--font-size-md);margin-bottom:var(--space-xl);line-height:1.5}.login-form{gap:var(--space-lg);flex-direction:column;display:flex}.login-form label{gap:var(--space-xs);font-size:var(--font-size-sm);color:var(--color-text-secondary);flex-direction:column;font-weight:500;display:flex}.login-form input{border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-md);background:var(--color-surface);color:var(--color-text);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);padding:15px 16px;font-family:inherit}.login-form input:focus{border-color:var(--color-text);outline:none;box-shadow:0 0 0 3px #1a18140f}.login-form input::placeholder{color:var(--color-text-secondary)}.otp-input{letter-spacing:.3em;text-align:center;font-variant-numeric:tabular-nums;font-size:24px!important}.login-resend{text-align:center}.login-countdown{font-size:var(--font-size-sm);color:var(--color-text-tertiary)}.profile-page{max-width:600px;margin:0 auto}.profile-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-lg);gap:var(--space-md);margin-bottom:var(--space-2xl);flex-direction:column;display:flex}.profile-row{align-items:center;gap:var(--space-sm);font-size:var(--font-size-md);min-height:32px;display:flex}.profile-icon{color:var(--color-text-tertiary);flex-shrink:0;align-items:center;display:flex}.profile-icon svg{width:18px;height:18px}.profile-since{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.profile-edit-form{align-items:center;gap:var(--space-sm);flex:1;display:flex}.profile-edit-form input{border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-md);background:var(--color-surface);color:var(--color-text);flex:1;padding:8px 12px;font-family:inherit}.profile-edit-form input:focus{border-color:var(--color-text);outline:none}.profile-orders{margin-bottom:var(--space-2xl)}.profile-orders h2{font-size:var(--font-size-lg);margin-bottom:var(--space-md);font-weight:700}.profile-orders-list{gap:var(--space-sm);flex-direction:column;margin:0;padding:0;list-style:none;display:flex}.profile-order-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-md) var(--space-lg);color:inherit;transition:box-shadow var(--transition-fast), transform var(--transition-spring);text-decoration:none;display:block}.profile-order-card:active{transform:scale(.98)}.profile-order-top{margin-bottom:var(--space-xs);justify-content:space-between;align-items:center;display:flex}.profile-order-num{font-weight:700;font-size:var(--font-size-md)}.profile-order-restaurant{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--space-xs)}.profile-order-bottom{margin-bottom:var(--space-xs);justify-content:space-between;align-items:center;display:flex}.profile-order-total{font-weight:600}.profile-order-date{font-size:var(--font-size-sm);color:var(--color-text-tertiary)}.profile-order-items{gap:var(--space-xs);flex-wrap:wrap;display:flex}.profile-order-item{font-size:var(--font-size-xs);color:var(--color-text-secondary);background:var(--color-bg);border-radius:var(--radius-sm);padding:2px 8px}.profile-order-item.more{font-style:italic}.profile-logout{margin-top:var(--space-lg)}.bottom-sheet-overlay{z-index:1000;background:#00000073;justify-content:center;align-items:flex-end;animation:.25s ease-out bsOverlayIn;display:flex;position:fixed;inset:0}@keyframes bsOverlayIn{0%{opacity:0}to{opacity:1}}.bottom-sheet{background:var(--color-bg);-webkit-overflow-scrolling:touch;will-change:transform;border-radius:16px 16px 0 0;width:100%;max-width:600px;max-height:85vh;animation:.3s cubic-bezier(.25,.46,.45,.94) bsSlideUp;overflow-y:auto}@keyframes bsSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.bottom-sheet-handle{background:var(--color-border-light);border-radius:2px;flex-shrink:0;width:36px;height:4px;margin:10px auto 0}.bottom-sheet-img{aspect-ratio:16/9;object-fit:cover;width:100%;margin-top:8px;display:block}.bottom-sheet-body{padding:var(--space-lg) var(--space-xl) var(--space-xl)}.bottom-sheet-title{margin:0;font-size:20px;font-weight:700;line-height:1.3}.bottom-sheet-desc{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:8px 0 0;line-height:1.5}.bottom-sheet-tags{flex-wrap:wrap;gap:6px;margin-top:10px;display:flex}.bottom-sheet-mods{flex-wrap:wrap;gap:6px;margin-top:12px;display:flex}.bottom-sheet-mod-chip{font-size:var(--font-size-xs);background:var(--color-surface);color:var(--color-text-secondary);border-radius:var(--radius-full);border:1px solid var(--color-border-light);padding:4px 10px;display:inline-block}.bottom-sheet-footer{align-items:baseline;gap:6px;margin-top:16px;display:flex}.bottom-sheet-price{color:var(--color-text);font-size:22px;font-weight:800}.bottom-sheet-qty{font-size:var(--font-size-sm);color:var(--color-text-tertiary)}.bottom-sheet-cta{text-align:center;margin-top:16px;text-decoration:none}
