*,*:before,*:after{box-sizing:border-box}input{border-radius:.5rem;border:1px solid #d1d5db;padding:.4rem .6rem;font:inherit;color:inherit;background-color:#fff}input[readonly]{background-color:#f3f4f6}html{font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;line-height:1.5;-webkit-text-size-adjust:100%}body{margin:0;min-height:100vh;background-color:#f8fafc}#root{min-height:100vh}.auth-init-loading{min-height:100vh;display:flex;align-items:center;justify-content:center;font-size:1rem;color:#64748b}.auth-init-error{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;color:#b91c1c;background-color:#fef2f2;border-bottom:1px solid #fecaca}.auth-init-retry{padding:.25rem .75rem;font-size:.8125rem;font-weight:600;color:#b91c1c;background:#fff;border:1px solid #fecaca;border-radius:.375rem;cursor:pointer}.auth-init-retry:hover{background:#fef2f2}.placeholder-page{min-height:100vh;display:flex;flex-direction:column;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}.placeholder-main{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.5rem;text-align:center}.placeholder-title{margin:0 0 .75rem;font-size:clamp(1.5rem,5vw,2rem);font-weight:700;color:#0f172a}.placeholder-meta{margin:0 0 1rem;font-size:.9375rem;color:#475569}.placeholder-meta strong{color:#0f172a}.placeholder-coming{margin:0;font-size:.875rem;color:#94a3b8}.customer-layout{height:100vh;max-height:100vh;min-height:0;display:flex;flex-direction:column;overflow:hidden;padding-bottom:env(safe-area-inset-bottom)}.customer-layout-main{flex:1;min-height:0;height:0;display:flex;flex-direction:column;overflow:hidden;padding-bottom:calc(44px + 1rem + env(safe-area-inset-bottom))}.place-branding{flex-shrink:0;display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;padding-top:calc(.75rem + env(safe-area-inset-top));background-color:#fff;border-bottom:1px solid #e2e8f0}.place-branding-logo{width:40px;height:40px;flex-shrink:0;background-color:#e2e8f0;border-radius:.5rem;display:flex;align-items:center;justify-content:center;font-size:.75rem;color:#64748b}.place-branding-name{margin:0;font-size:1.125rem;font-weight:700;color:#0f172a;min-width:0}.bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:100;display:flex;align-items:stretch;justify-content:space-around;min-height:44px;padding:.5rem 0;padding-bottom:calc(.5rem + env(safe-area-inset-bottom));background-color:#fff;border-top:1px solid #e2e8f0}.bottom-nav-item{flex:1;display:flex;align-items:center;justify-content:center;font:inherit;font-weight:500;color:#64748b;text-decoration:none;padding:.5rem 1rem;min-height:44px;border:none;background:none;cursor:pointer}.bottom-nav-item--active,.bottom-nav-item:hover{color:#0f172a}.bottom-nav-item--active{font-weight:600}.menu-page{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden;background-color:#e2e8f0}.menu-page-main{flex:1;min-height:0;display:flex;overflow:hidden;position:relative}.menu-page-loading,.menu-page-empty{margin:auto;padding:1.5rem;color:#64748b;font-size:.9375rem}.menu-page-categories{flex-shrink:0;width:7.5rem;min-width:7.5rem;display:flex;flex-direction:column;min-height:0;overflow:hidden;background-color:#fff;border-right:2px solid #cbd5e1;box-shadow:1px 0 #0000000a}.menu-page-categories-title{flex-shrink:0;margin:0;padding:.75rem .5rem;font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#64748b;background-color:#f8fafc;border-bottom:1px solid #e2e8f0}.menu-categories{flex:1;min-height:0;overflow-y:auto;padding:.5rem 0;display:flex;flex-direction:column;gap:0}.menu-category-tab{padding:.5rem .4rem;font:inherit;font-size:.8125rem;text-align:center;color:#475569;background:none;border:none;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-height:44px;display:flex;align-items:center;justify-content:center}.menu-category-tab:hover{color:#0f172a;background-color:#f1f5f9}.menu-category-tab--active{font-weight:600;color:#0f172a;background-color:#e2e8f0}.menu-page-items{flex:1;min-width:0;min-height:0;display:flex;flex-direction:column;overflow:hidden;background-color:#fff;border-left:1px solid #e2e8f0;box-shadow:-1px 0 #00000005}.menu-page-items-title{flex-shrink:0;margin:0;padding:.75rem 1rem;font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#64748b;background-color:#f8fafc;border-bottom:1px solid #e2e8f0}.menu-page-content{flex:1;min-height:0;overflow-y:auto;padding:.75rem 1rem;-webkit-overflow-scrolling:touch}.menu-item-list{display:flex;flex-direction:column;gap:0}.menu-category-section{scroll-margin-top:0}.menu-category-section-header{margin:0;padding:.5rem 0 .375rem;font-size:.8125rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:#64748b;border-bottom:1px solid #e2e8f0}.menu-category-section:not(:first-child) .menu-category-section-header{padding-top:1rem}.menu-item-list-in-section{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.75rem}.menu-item-row{display:flex;gap:.75rem;align-items:flex-start;background-color:#fff;border-radius:.5rem;padding:.75rem;border:1px solid #e2e8f0}.menu-item-image-wrap{flex-shrink:0;width:80px;height:80px;border-radius:.375rem;overflow:hidden;background-color:#f1f5f9}.menu-item-image{width:100%;height:100%;object-fit:cover}.menu-item-image-placeholder{width:100%;height:100%;background-color:#e2e8f0}.menu-item-details{min-width:0;flex:1;display:flex;flex-direction:column;gap:.25rem}.menu-item-name{font-weight:600;color:#0f172a;font-size:1rem}.menu-item-description{font-size:.875rem;color:#64748b;line-height:1.4}.menu-item-price{font-size:.9375rem;font-weight:600;color:#0f172a}.menu-item-actions{margin-top:auto;display:flex;align-items:center;justify-content:flex-end;gap:.5rem}.menu-item-quantity-bubble{display:inline-flex;align-items:center;justify-content:center;min-width:1.5rem;height:1.5rem;padding:0 .35rem;font-size:.8125rem;font-weight:600;color:#0f172a;background-color:#e2e8f0;border-radius:9999px}.menu-item-add-button{flex-shrink:0;width:2.25rem;height:2.25rem;display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:600;line-height:1;color:#fff;background-color:#0f172a;border:none;border-radius:.5rem;cursor:pointer}.menu-item-add-button:hover{background-color:#1e293b}.orders-page{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.orders-page-scroll{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:1.5rem 1rem 1rem;display:flex;flex-direction:column;gap:1rem}.orders-page-footer{flex-shrink:0;padding:.75rem 1rem;border-top:1px solid #e5e7eb;background-color:#fff}.orders-page-title{margin:0;font-size:1.25rem;font-weight:700;color:#0f172a}.orders-page-empty{margin:0;font-size:.9375rem;color:#64748b}.orders-page-empty a{color:#0f172a;font-weight:600;text-decoration:underline}.orders-page-success{margin:0;padding:.75rem 1rem;font-size:.9375rem;color:#166534;background-color:#dcfce7;border-radius:.5rem}.orders-page-error{margin:0;padding:.75rem 1rem;font-size:.9375rem;color:#b91c1c;background-color:#fef2f2;border-radius:.5rem}.orders-cart-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.75rem}.orders-cart-item{padding:.75rem 1rem;background-color:#fff;border:1px solid #e2e8f0;border-radius:.5rem}.orders-cart-item-main{display:flex;align-items:baseline;justify-content:space-between;gap:.5rem}.orders-cart-item-name{font-weight:600;color:#0f172a;font-size:1rem}.orders-cart-item-qty{font-size:.9375rem;color:#64748b}.orders-cart-item-contributors{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.5rem}.orders-total{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background-color:#f8fafc;border-radius:.5rem;font-weight:700;font-size:1.125rem;color:#0f172a}.orders-total-label{font-weight:600}.orders-place-button{width:100%;padding:.875rem 1.5rem;font-size:1rem;font-weight:600;color:#fff;background-color:#0f172a;border:none;border-radius:.625rem;cursor:pointer}.orders-place-button:hover:not(:disabled){background-color:#1e293b}.orders-place-button:disabled{opacity:.7;cursor:not-allowed}.device-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.2rem .5rem;font-size:.75rem;font-weight:500;color:#0f172a;background-color:#f1f5f9;border-radius:9999px}.device-badge-dot{width:.5rem;height:.5rem;border-radius:50%}.device-badge--user-a .device-badge-dot{background-color:#3b82f6}.device-badge--user-b .device-badge-dot{background-color:#22c55e}.device-badge--user-c .device-badge-dot{background-color:#f59e0b}.device-badge--user-d .device-badge-dot{background-color:#ec4899}.device-badge--user-e .device-badge-dot{background-color:#8b5cf6}.device-badge--user-f .device-badge-dot{background-color:#06b6d4}.order-items{list-style:none;padding:0;margin:0 0 1rem;display:flex;flex-direction:column;gap:.75rem}.order-item{padding:.75rem .75rem .5rem;border-radius:.75rem;background-color:#fff;border:1px solid #e5e7eb}.order-item-main{display:flex;justify-content:space-between;gap:1rem;align-items:flex-start}.order-item-info{flex:1;min-width:0}.order-item-name{font-weight:600}.order-item-tags{margin-top:.25rem;display:flex;flex-wrap:wrap;gap:.25rem}.order-item-actions{display:flex;gap:.5rem;align-items:center;flex-shrink:0}.order-item-actions input[type=number]{width:4rem;margin-left:.25rem}.order-item-line-total{font-weight:600;margin-right:.5rem}.order-item-qty-badge{font-size:.9rem;font-weight:600;color:#374151;background-color:#f3f4f6;border-radius:999px;padding:.15rem .5rem}.order-item-options--readonly{margin-top:.35rem}.order-item-options--readonly .order-item-option-group{gap:.25rem}.option-pill--selected{background-color:#ecfdf5;border-color:#a7f3d0;color:#065f46}.menu-card-inner{display:flex;align-items:flex-start;gap:.75rem}.menu-card-thumb{flex-shrink:0;width:72px;height:72px;border-radius:.5rem;overflow:hidden;background-color:#f3f4f6;display:flex;align-items:center;justify-content:center}.menu-card-thumb-img{display:block;width:100%;height:100%;object-fit:cover}.menu-card-thumb-placeholder{font-size:.7rem;color:#9ca3af;text-align:center;padding:.25rem}.menu-card-body{flex:1;min-width:0}.menu-card-body--unified{display:flex;flex-direction:column;min-height:0}.menu-card-body--unified .menu-card-description{-webkit-line-clamp:3;line-clamp:3}.menu-card-header{display:flex;justify-content:space-between;align-items:baseline;gap:.5rem;min-width:0}.menu-card-name{font-weight:600;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.menu-card-price{font-weight:600;color:#059669;font-size:.95rem;flex-shrink:0}.menu-card-description{margin:.35rem 0 0;font-size:.85rem;color:#6b7280;line-height:1.3;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;line-clamp:2}.menu-card-ingredients{margin-top:.3rem;font-size:.8rem;color:#6b7280;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.menu-card-footer{display:flex;justify-content:space-between;align-items:center;gap:.75rem;margin-top:auto;padding-top:.75rem}.menu-card-footer-price .menu-card-price{font-size:1rem;font-weight:600}.menu-card-footer-actions{display:flex;align-items:center;gap:.35rem;flex-shrink:0}.menu-card-add-btn{width:40px;height:40px;border-radius:50%;border:none;background-color:#059669;color:#fff;font-size:1.5rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:background-color .15s ease,transform .15s ease;box-shadow:0 2px 6px #05966959}.menu-card-add-btn:hover{background-color:#047857;transform:scale(1.05)}.menu-card-add-btn:active{transform:scale(.98)}.btn-primary,.btn-ghost{border-radius:999px;padding:.45rem 1.1rem;font:inherit;cursor:pointer;border:1px solid transparent;display:inline-flex;align-items:center;justify-content:center;gap:.25rem;white-space:nowrap}.btn-primary{background-color:#0f172a;color:#fff;border-color:#1e293b}.btn-primary:hover{background-color:#1e293b}.btn-primary:disabled{opacity:.6;cursor:default}.btn-ghost{background-color:transparent;color:#374151;border-color:#d1d5db}.modal-backdrop{position:fixed;inset:0;background-color:#0006;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background-color:#fff;border-radius:.75rem;box-shadow:0 20px 40px #00000026;max-width:420px;width:100%;max-height:90vh;display:flex;flex-direction:column}.modal-content--order-detail{max-width:400px}.modal-header{display:flex;align-items:flex-start;gap:.5rem;padding:1rem 1.25rem;border-bottom:1px solid #e5e7eb;flex-wrap:wrap}.modal-title{margin:0;font-size:1.25rem;font-weight:700;flex:1}.modal-close{border:none;background:none;font-size:1.5rem;line-height:1;cursor:pointer;color:#6b7280;padding:.25rem}.modal-close:hover{color:#111827}.modal-body{padding:1rem 1.25rem;overflow-y:auto;flex:1;min-height:0}.modal-footer{padding:1rem 1.25rem;border-top:1px solid #e5e7eb;display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.order-detail-actions .btn-primary{margin-left:auto}.order-item-options{margin-top:.5rem;display:flex;flex-direction:column;gap:.5rem}.order-item-option-group{display:flex;flex-wrap:wrap;align-items:center;gap:.35rem}.order-item-option-label{font-size:.8rem;font-weight:600;color:#374151;margin-right:.25rem;width:100%}.order-item-option-text{flex:1;min-width:120px;font-size:.85rem;padding:.3rem .5rem;border:1px solid #d1d5db;border-radius:.375rem}.option-pill{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;border-radius:999px;border:1px solid #e5e7eb;background-color:#f9fafb;font-size:.8rem;cursor:pointer}.option-pill input{cursor:pointer}.option-pill-extra{font-size:.85em;opacity:.9}.item-options-description{margin:0 0 1rem;font-size:.9rem;color:#6b7280;line-height:1.4}.item-options-qty-row{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.item-options-qty-label{font-size:.9rem;font-weight:600;color:#374151}.item-options-qty-input{width:5rem;padding:.35rem .5rem;font-size:.95rem;border:1px solid #d1d5db;border-radius:.375rem}.device-badge-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.order-item-qty-stepper{display:flex;align-items:center;border:1px solid #d1d5db;border-radius:.375rem;overflow:hidden}.order-item-qty-stepper-btn{display:flex;align-items:center;justify-content:center;width:1.75rem;height:1.75rem;background:transparent;border:none;cursor:pointer;font-size:1rem;font-weight:600;color:#374151;line-height:1}.order-item-qty-stepper-btn:not(:disabled):hover{background-color:#f3f4f6}.order-item-qty-stepper-btn:disabled{color:#9ca3af;cursor:default}.order-item-qty-stepper-val{min-width:1.5rem;text-align:center;font-size:.9rem;font-weight:600;padding:0 .25rem;border-left:1px solid #d1d5db;border-right:1px solid #d1d5db}.btn-ghost--sm{padding:.2rem .6rem;font-size:.8rem}.confirm-order-list{list-style:none;padding:0;margin:0 0 1rem;display:flex;flex-direction:column;gap:.5rem}.confirm-order-item{padding:.6rem .75rem;background-color:#f8fafc;border-radius:.5rem;border:1px solid #e5e7eb}.confirm-order-item-main{display:flex;align-items:baseline;justify-content:space-between;gap:.5rem}.confirm-order-item-name{font-weight:600;flex:1;min-width:0}.confirm-order-item-right{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.confirm-order-item-price{font-weight:600;color:#374151}.confirm-order-item-qty{font-size:.85rem;color:#6b7280}.confirm-order-item-options{margin:.25rem 0 0;font-size:.8rem;color:#6b7280}.confirm-order-total{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-top:1px solid #e5e7eb;font-weight:600;font-size:1rem;margin-bottom:1rem}.confirm-order-total-amount{font-size:1.1rem}.confirm-order-warning{display:flex;align-items:flex-start;gap:.5rem;padding:.75rem 1rem;background-color:#fffbeb;border:1px solid #fcd34d;border-radius:.5rem;font-size:.875rem;color:#92400e;line-height:1.4}.confirm-order-warning-icon{flex-shrink:0;font-size:1rem}.confirm-order-btn{flex:1}.cart-bar{flex-shrink:0;display:flex;align-items:center;gap:0;padding:.625rem .75rem;background-color:#0f172a;border-top:1px solid rgba(255,255,255,.08);box-shadow:0 -4px 16px #0000002e;animation:cart-bar-slide-up .2s ease-out}@keyframes cart-bar-slide-up{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.cart-bar-info{flex:1;display:flex;align-items:center;gap:.5rem;background:none;border:none;padding:.25rem .5rem .25rem 0;cursor:pointer;text-align:left;min-height:44px}.cart-bar-icon{font-size:1.25rem;line-height:1}.cart-bar-badge{display:inline-flex;align-items:center;justify-content:center;min-width:1.375rem;height:1.375rem;padding:0 .3rem;font-size:.75rem;font-weight:700;color:#fff;background-color:#ef4444;border-radius:9999px;line-height:1}.cart-bar-total{font-size:.9375rem;font-weight:600;color:#fff}.cart-bar-checkout{flex-shrink:0;display:inline-flex;align-items:center;gap:.375rem;padding:.5rem 1.125rem;font:inherit;font-size:.9375rem;font-weight:600;color:#0f172a;background-color:#fff;border:none;border-radius:.5rem;cursor:pointer;min-height:44px;transition:background-color .12s ease}.cart-bar-checkout:hover{background-color:#f1f5f9}.cart-bar-checkout-arrow{font-size:1rem}.cart-modal-backdrop{position:absolute;inset:0;background-color:#00000073;z-index:200;display:flex;flex-direction:column;justify-content:flex-end}.cart-modal-sheet{background-color:#fff;border-radius:1rem 1rem 0 0;max-height:82vh;display:flex;flex-direction:column;animation:cart-sheet-up .22s cubic-bezier(.32,.72,0,1);padding-bottom:env(safe-area-inset-bottom)}.cart-modal-sheet--closing{animation:cart-sheet-down .22s cubic-bezier(.32,.72,0,1) forwards}@keyframes cart-sheet-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes cart-sheet-down{0%{transform:translateY(0)}to{transform:translateY(100%)}}.cart-modal-sheet:before{content:"";display:block;width:2.5rem;height:.25rem;background-color:#d1d5db;border-radius:9999px;margin:.625rem auto 0;flex-shrink:0}.cart-modal-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.25rem .625rem;border-bottom:1px solid #f1f5f9;flex-shrink:0}.cart-modal-select-all{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.9375rem}.cart-modal-select-all input[type=checkbox]{width:1.125rem;height:1.125rem;cursor:pointer;accent-color:#0f172a}.cart-modal-item-count{font-weight:600;color:#0f172a}.cart-modal-trash-btn{display:flex;align-items:center;justify-content:center;width:2.25rem;height:2.25rem;font-size:1.125rem;background:none;border:1px solid #e5e7eb;border-radius:.5rem;cursor:pointer;color:#6b7280;transition:background-color .1s ease,color .1s ease}.cart-modal-trash-btn:hover{background-color:#fef2f2;border-color:#fca5a5;color:#dc2626}.cart-modal-trash-btn:disabled{opacity:.5;cursor:default}.cart-modal-clear-confirm{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.625rem 1.25rem;background-color:#fef2f2;border-bottom:1px solid #fecaca;font-size:.875rem;color:#b91c1c;flex-shrink:0}.cart-modal-clear-confirm-actions{display:flex;align-items:center;gap:.5rem}.cart-modal-clear-btn{padding:.3rem .8rem;font:inherit;font-size:.8125rem;font-weight:600;color:#fff;background-color:#dc2626;border:none;border-radius:.375rem;cursor:pointer}.cart-modal-clear-btn:disabled{opacity:.6;cursor:default}.cart-modal-list{list-style:none;margin:0;padding:0;overflow-y:auto;-webkit-overflow-scrolling:touch;max-height:308px;flex:1;min-height:0}.cart-modal-item{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem 1.25rem;border-bottom:1px solid #f1f5f9;transition:background-color .1s ease}.cart-modal-item--selected{background-color:#f0f9ff}.cart-modal-item-check{display:flex;align-items:center;padding-top:.15rem;flex-shrink:0;cursor:pointer}.cart-modal-item-check input[type=checkbox]{width:1.125rem;height:1.125rem;cursor:pointer;accent-color:#0f172a}.cart-modal-item-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:.25rem}.cart-modal-item-main{display:flex;justify-content:space-between;align-items:baseline;gap:.5rem}.cart-modal-item-name{font-weight:600;font-size:.9375rem;color:#0f172a;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cart-modal-item-price{font-weight:600;font-size:.9375rem;color:#374151;flex-shrink:0}.cart-modal-item-options{margin:0;font-size:.8rem;color:#6b7280;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cart-modal-item-footer{display:flex;align-items:center;justify-content:space-between;gap:.5rem;flex-wrap:wrap;margin-top:.125rem}.cart-modal-item-contributors{display:flex;flex-wrap:wrap;gap:.25rem}.cart-modal-item-qty{display:flex;align-items:center;border:1px solid #d1d5db;border-radius:.375rem;overflow:hidden;height:1.875rem}.cart-modal-qty-btn{display:flex;align-items:center;justify-content:center;width:1.875rem;height:100%;background:none;border:none;font-size:1rem;font-weight:600;color:#374151;cursor:pointer;line-height:1}.cart-modal-qty-btn:hover:not(:disabled){background-color:#f3f4f6}.cart-modal-qty-btn:disabled{color:#9ca3af;cursor:default}.cart-modal-qty-val{min-width:1.75rem;text-align:center;font-size:.875rem;font-weight:600;padding:0 .2rem;border-left:1px solid #d1d5db;border-right:1px solid #d1d5db}.cart-modal-footer{flex-shrink:0;padding:.75rem 1.25rem;border-top:1px solid #e5e7eb}.cart-modal-checkout-btn{width:100%;padding:.875rem;font:inherit;font-size:1rem;font-weight:600;color:#fff;background-color:#0f172a;border:none;border-radius:.625rem;cursor:pointer;transition:background-color .12s ease}.cart-modal-checkout-btn:hover{background-color:#1e293b}.order-track-page{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden;background-color:#f8fafc}.order-track-scroll{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:1.25rem 1rem 1rem;display:flex;flex-direction:column;gap:1rem}.order-track-page-title{margin:0;font-size:1.25rem;font-weight:700;color:#0f172a}.order-track-empty{margin:2rem auto;font-size:.9375rem;color:#64748b;text-align:center}.order-track-empty a{color:#0f172a;font-weight:600;text-decoration:underline}.order-track-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:1rem}.pipeline-bar{flex-shrink:0;display:grid;grid-template-columns:repeat(3,1fr);background-color:#fff;border-bottom:1px solid #e2e8f0;padding:.875rem .75rem .75rem;gap:0;position:relative}.pipeline-bar--complete{grid-template-columns:1fr;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1rem;background-color:#f0fdf4;border-bottom-color:#bbf7d0}.pipeline-complete-icon{font-size:1.125rem;line-height:1}.pipeline-complete-label{font-size:.9375rem;font-weight:600;color:#166534}.pipeline-step-wrapper{display:flex;flex-direction:column;align-items:center;position:relative}.pipeline-step-wrapper:not(:last-child):after{content:"";position:absolute;top:1.0625rem;right:-.375rem;width:calc(100% - 2.5rem);height:2px;background-color:#e2e8f0;z-index:0}.pipeline-step-wrapper:not(:last-child).pipeline-step-wrapper--connector-done:after{background-color:#059669}.pipeline-step{display:flex;flex-direction:column;align-items:center;gap:.25rem;z-index:1}.pipeline-step-icon{display:flex;align-items:center;justify-content:center;width:2.125rem;height:2.125rem;border-radius:50%;font-size:1rem;border:2px solid #e2e8f0;background-color:#f8fafc;color:#94a3b8;transition:background-color .2s ease,border-color .2s ease,box-shadow .2s ease}.pipeline-step-label{font-size:.6875rem;font-weight:500;color:#94a3b8;text-align:center;white-space:nowrap}.pipeline-step--done .pipeline-step-icon{background-color:#059669;border-color:#059669;color:#fff;font-size:.8125rem;font-weight:700}.pipeline-step--done .pipeline-step-label{color:#059669;font-weight:600}.pipeline-step--active .pipeline-step-icon{background-color:#0f172a;border-color:#0f172a;color:#fff;box-shadow:0 0 0 3px #0f172a1f}.pipeline-step--active .pipeline-step-label{color:#0f172a;font-weight:700}.pipeline-step-pills{display:flex;flex-wrap:wrap;justify-content:center;gap:.25rem;margin-top:.375rem;z-index:1}.pipeline-pill{display:inline-flex;align-items:center;padding:.15rem .45rem;font-size:.6875rem;font-weight:600;border-radius:9999px;border:1px solid #e2e8f0;background-color:#f1f5f9;color:#475569;white-space:nowrap;line-height:1.4}.pipeline-pill--active{background-color:#0f172a;border-color:#0f172a;color:#fff}.pipeline-pill--done{background-color:#dcfce7;border-color:#86efac;color:#166534}.order-track-card{background-color:#fff;border:1px solid #e2e8f0;border-radius:.875rem;overflow:hidden;box-shadow:0 1px 3px #0000000f}.order-track-card--cancelled{opacity:.65;border-left:3px solid #fca5a5}.order-track-card-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.875rem 1rem .625rem;border-bottom:1px solid #f1f5f9}.order-track-card-header-left{display:flex;flex-direction:column;gap:.125rem;min-width:0}.order-track-order-number{font-size:1rem;font-weight:700;color:#0f172a}.order-track-order-time{font-size:.75rem;color:#94a3b8}.order-track-badge{flex-shrink:0;display:inline-flex;align-items:center;padding:.25rem .625rem;font-size:.75rem;font-weight:600;border-radius:9999px;white-space:nowrap}.order-track-badge--sent{background-color:#eff6ff;color:#1d4ed8}.order-track-badge--preparing{background-color:#fffbeb;color:#b45309}.order-track-badge--ready{background-color:#f0fdf4;color:#166534}.order-track-badge--cancelled{background-color:#fef2f2;color:#b91c1c}.order-track-items{list-style:none;margin:0;padding:.625rem 1rem;display:flex;flex-direction:column;gap:.375rem}.order-track-item{display:flex;justify-content:space-between;align-items:baseline;gap:.5rem;font-size:.9rem}.order-track-item-name{color:#374151;flex:1;min-width:0}.order-track-item-qty{color:#6b7280;font-size:.85em}.order-track-item-price{color:#374151;font-weight:600;flex-shrink:0}.order-track-total{display:flex;justify-content:space-between;align-items:center;padding:.625rem 1rem;border-top:1px solid #f1f5f9;font-size:.9375rem;font-weight:600;color:#0f172a}.order-track-total-amount{font-size:1rem}
