:root{--primary:#E0962E;--bg:#FAF7F2;--text:#2B2B2E;--muted:#948F8A;--surface:#FFFFFF;--border:#E8E3DC;--radius:12px;--bar-h:72px}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}ul{list-style:none}button{cursor:pointer;border:none;background:none}button,input{font:inherit}a{color:inherit;text-decoration:none}.page{max-width:640px;margin:0 auto;padding:24px 16px calc(24px + var(--bar-h))}.hero{border-bottom:4px solid var(--primary);padding-bottom:16px;margin-bottom:24px}.hero h1{color:var(--primary);margin:0 0 4px}.muted,.tag{color:var(--muted);font-size:14px}.error{background:#fde8e8;color:#9b1c1c;padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:14px}.menu-root{max-width:480px;margin:0 auto;min-height:100dvh;padding-bottom:calc(var(--bar-h) + 16px)}.menu-pad{padding:0 16px}.menu-header{padding:20px 16px 16px;border-bottom:3px solid var(--primary);background:var(--bg)}.menu-title{font-size:24px;font-weight:800;color:var(--primary);letter-spacing:-.5px}.cat-nav{display:flex;gap:8px;padding:12px 16px;overflow-x:auto;white-space:nowrap;background:var(--bg);position:-webkit-sticky;position:sticky;top:0;z-index:10;scrollbar-width:none;border-bottom:1px solid var(--border)}.cat-nav::-webkit-scrollbar{display:none}.cat-nav-link{display:inline-block;padding:6px 14px;border-radius:20px;font-size:13px;font-weight:600;color:var(--text);background:var(--surface);border:1px solid var(--border);transition:background .15s,color .15s;flex-shrink:0}.cat-nav-link:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.menu-body{padding:0 0 8px}.cat-section{padding:24px 16px 8px}.cat-section+.cat-section{border-top:1px solid var(--border)}.cat-heading{font-size:18px;font-weight:700;margin-bottom:4px}.cat-desc{font-size:13px;color:var(--muted);margin-bottom:12px;line-height:1.4}.cat-section--content .cat-content-body{font-size:14px;color:var(--muted);line-height:1.6;margin-top:8px}.item-list{display:flex;flex-direction:column;gap:1px}.item-card{display:flex;align-items:center;gap:12px;padding:14px 0;border-bottom:1px solid var(--border)}.item-card:last-child{border-bottom:none}.item-card--unavailable{opacity:.5}.item-body{flex:1 1;min-width:0}.item-name{display:block;font-size:15px;font-weight:600;line-height:1.3}.item-desc{display:block;font-size:13px;color:var(--muted);margin-top:2px;line-height:1.4}.sold-badge{display:inline-block;font-size:11px;font-weight:700;color:#9b1c1c;background:#fde8e8;border-radius:4px;padding:2px 6px;margin-top:4px;text-transform:uppercase;letter-spacing:.5px}.item-aside{display:flex;flex-direction:column;align-items:flex-end;gap:6px;flex-shrink:0}.item-price{font-size:15px;font-weight:700;color:var(--text)}.add-btn{width:32px;height:32px;border-radius:50%;background:var(--primary);color:#fff;font-size:22px;font-weight:400;display:flex;align-items:center;justify-content:center;line-height:1;transition:transform .1s,opacity .1s;flex-shrink:0}.add-btn:active{transform:scale(.9)}.cart-bar{position:fixed;bottom:16px;left:50%;transform:translateX(-50%);width:calc(100% - 32px);max-width:448px;height:56px;background:var(--primary);color:#fff;border-radius:16px;display:flex;align-items:center;padding:0 16px;gap:8px;font-size:15px;font-weight:700;box-shadow:0 4px 16px rgba(0,0,0,.25);z-index:20;transition:transform .2s}.cart-bar:active{transform:translateX(-50%) scale(.98)}.cart-bar-badge{background:rgba(255,255,255,.3);border-radius:20px;padding:2px 10px;font-size:14px;font-weight:800}.cart-bar-label{flex:1 1;text-align:center}.cart-bar-total{font-size:15px}.sheet-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:30;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.sheet{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:480px;max-height:85dvh;background:var(--surface);border-radius:20px 20px 0 0;z-index:40;display:flex;flex-direction:column;animation:slideUp .25s ease;overflow:hidden}.sheet--tall{max-height:92dvh}@keyframes slideUp{0%{transform:translateX(-50%) translateY(100%)}to{transform:translateX(-50%) translateY(0)}}.sheet-handle{width:40px;height:4px;background:var(--border);border-radius:2px;margin:10px auto 0;flex-shrink:0}.sheet-inner{display:flex;flex-direction:column;flex:1 1;overflow:hidden}.sheet-top{display:flex;align-items:center;justify-content:space-between;padding:12px 16px 8px;flex-shrink:0}.sheet-title{font-size:18px;font-weight:700}.sheet-close-btn{width:32px;height:32px;border-radius:50%;background:var(--bg);display:flex;align-items:center;justify-content:center;flex-shrink:0}.sheet-close-btn,.sheet-desc{font-size:14px;color:var(--muted)}.sheet-desc{padding:0 16px 4px;line-height:1.4}.sheet-body{flex:1 1;overflow-y:auto;padding:8px 0;overscroll-behavior:contain}.sheet-footer{border-top:1px solid var(--border);display:flex;flex-direction:column;gap:8px;flex-shrink:0;background:var(--surface)}.opt-section,.sheet-footer{padding:12px 16px}.opt-section+.opt-section{border-top:1px solid var(--border)}.opt-section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.opt-section-label{font-size:15px;font-weight:700}.req-badge{font-size:11px;font-weight:700;padding:3px 8px;border-radius:20px;background:#fde8e8;color:#9b1c1c;text-transform:uppercase;letter-spacing:.3px}.req-badge.req-done{background:#d1fae5;color:#065f46}.opt-list{display:flex;flex-direction:column;gap:2px}.opt-row{display:flex;align-items:center;gap:10px;width:100%;padding:11px 12px;border-radius:10px;background:var(--bg);text-align:left;transition:background .1s}.opt-row--checked{background:#fff3e0}.opt-row:active{background:#ede9e1}.opt-indicator{font-size:18px;color:var(--muted);flex-shrink:0;line-height:1}.opt-row--checked .opt-indicator{color:var(--primary)}.opt-name{flex:1 1;font-size:15px}.opt-delta{font-size:14px;font-weight:600;color:var(--muted)}.special-instructions-input{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:10px;font-size:15px;font-family:inherit;background:var(--bg);color:var(--text);resize:vertical;box-sizing:border-box}.special-instructions-input:focus{outline:2px solid var(--primary);outline-offset:1px}.btn-primary{width:100%;padding:15px;background:var(--primary);color:#fff;font-size:16px;font-weight:700;border-radius:14px;transition:opacity .15s}.btn-primary:disabled{opacity:.4;cursor:not-allowed}.btn-secondary{width:100%;padding:12px;background:var(--bg);color:var(--text);font-size:14px;font-weight:600;border-radius:12px;border:1px solid var(--border)}.basket-line{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid var(--border)}.basket-line:last-child{border-bottom:none}.bl-info{flex:1 1;min-width:0}.bl-name{display:block;font-size:15px;font-weight:600}.bl-mods{display:block;font-size:13px;color:var(--muted);margin-top:2px}.bl-note{font-style:italic}.bl-right{gap:12px;flex-shrink:0}.bl-right,.qty-ctrl{display:flex;align-items:center}.qty-ctrl{gap:8px}.qty-btn{width:28px;height:28px;border-radius:50%;background:var(--bg);border:1px solid var(--border);font-size:18px;display:flex;align-items:center;justify-content:center;line-height:1;color:var(--text)}.qty-val{min-width:20px;text-align:center}.bl-price,.qty-val{font-size:15px;font-weight:700}.bl-price{min-width:48px;text-align:right}.subtotal-row{display:flex;justify-content:space-between;font-size:15px;font-weight:600;padding:4px 0}.order-summary{margin:0 16px 20px;padding:12px;background:var(--bg);border-radius:var(--radius)}.summary-line{font-size:14px;padding:4px 0;color:var(--muted)}.summary-line,.summary-total{display:flex;justify-content:space-between}.summary-total{font-size:15px;font-weight:700;padding-top:8px;margin-top:8px;border-top:1px solid var(--border)}.guest-form{padding:0 16px;gap:12px}.form-field,.guest-form{display:flex;flex-direction:column}.form-field{gap:6px}.form-field span{font-size:13px;font-weight:600;color:var(--muted)}.form-field input{padding:12px 14px;border:1.5px solid var(--border);border-radius:10px;font-size:16px;background:var(--bg);color:var(--text);outline:none;transition:border-color .15s}.form-field input:focus{border-color:var(--primary)}.form-error{margin:8px 16px 0;font-size:14px;color:#9b1c1c;background:#fde8e8;padding:10px 12px;border-radius:8px}.checkout-note{text-align:center;font-size:12px;color:var(--muted);margin-top:12px;padding:0 16px}.receipt-card{background:var(--surface);border-radius:var(--radius);padding:20px;box-shadow:0 1px 6px rgba(0,0,0,.08)}.receipt-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:16px}.receipt-ref{font-size:20px;font-weight:800;color:var(--primary)}.receipt-time{font-size:13px;color:var(--muted)}.receipt-lines{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.receipt-line{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;font-size:14px}.rl-left{display:flex;gap:8px;flex:1 1;min-width:0}.rl-qty{font-weight:700;color:var(--muted);flex-shrink:0}.rl-name{font-weight:600;display:block}.rl-mods{font-size:13px;color:var(--muted);display:block;margin-top:2px}.rl-price{font-weight:700;flex-shrink:0}.receipt-total{display:flex;justify-content:space-between;font-size:16px;font-weight:700;padding-top:12px;border-top:2px solid var(--border);margin-bottom:16px}.receipt-guest{font-size:14px;color:var(--muted);border-top:1px solid var(--border);padding-top:12px}.receipt-guest p+p{margin-top:2px}.staff-page{max-width:800px}.staff-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.staff-actions{display:flex;gap:8px;flex-shrink:0}.staff-link{font-size:13px;font-weight:600;color:var(--primary);padding:6px 12px;border:1px solid var(--border);border-radius:20px;background:var(--surface)}.staff-login{display:flex;flex-direction:column;gap:14px}.enable-sound-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px 16px;margin-bottom:14px;background:#fffbeb;color:#b45309;border:1.5px dashed #fcd34d;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s}.enable-sound-btn:hover{background:#fef3c7}.status-tabs{display:flex;gap:6px;overflow-x:auto;padding-bottom:12px;scrollbar-width:none}.status-tabs::-webkit-scrollbar{display:none}.status-tab{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:20px;font-size:13px;font-weight:600;color:var(--muted);background:var(--surface);border:1px solid var(--border);cursor:pointer;white-space:nowrap;flex-shrink:0;transition:background .15s,color .15s,border-color .15s}.status-tab:hover{border-color:var(--primary);color:var(--text)}.status-tab--active{background:var(--primary);color:#fff;border-color:var(--primary)}.status-tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:9px;font-size:11px;font-weight:700;background:rgba(0,0,0,.12)}.status-tab--active .status-tab-count{background:rgba(255,255,255,.3)}.refresh-indicator{font-size:11px;color:var(--muted);text-align:right;margin-bottom:10px}.new-orders-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;background:var(--primary);color:#fff;border-radius:10px;margin-bottom:14px;font-size:14px;font-weight:600;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.new-orders-banner-dismiss{background:rgba(255,255,255,.25);color:#fff;border:none;border-radius:6px;padding:3px 10px;font-size:12px;font-weight:700;cursor:pointer;flex-shrink:0}.status-badge{display:inline-flex;align-items:center;padding:2px 9px;border-radius:20px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;flex-shrink:0}.status-badge--received{background:#fef2f2;color:#dc2626}.status-badge--accepted{background:#fffbeb;color:#b45309}.status-badge--in_progress{background:#eff6ff;color:#1d4ed8}.status-badge--complete{background:#ecfdf5;color:#065f46}.status-badge--cancelled,.status-badge--rejected{background:#f3f4f6;color:#6b7280}.order-board{display:flex;flex-direction:column;gap:14px}.order-card{background:var(--surface);border-left:1px solid var(--border);border:1px solid var(--border);border-left-width:4px;border-radius:var(--radius);padding:14px 16px;box-shadow:0 1px 4px rgba(0,0,0,.05);transition:box-shadow .2s}.order-card--received{border-left-color:#dc2626}.order-card--accepted{border-left-color:#d97706}.order-card--in_progress{border-left-color:#2563eb}.order-card--complete{border-left-color:#059669;opacity:.8}.order-card--cancelled,.order-card--rejected{border-left-color:#d1d5db;opacity:.65}.order-card--new{animation:newOrderPulse 1.5s ease 0s 3}@keyframes newOrderPulse{0%,to{box-shadow:0 1px 4px rgba(0,0,0,.05)}50%{box-shadow:0 0 0 3px rgba(224,150,46,.35),0 1px 8px rgba(0,0,0,.1)}}.order-card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;gap:8px;flex-wrap:wrap}.order-ref{font-size:17px;font-weight:800;color:var(--primary)}.order-when{font-size:12px;color:var(--muted)}.order-guest{display:flex;justify-content:space-between;align-items:baseline;gap:8px;font-size:14px;padding-bottom:10px;border-bottom:1px solid var(--border)}.order-phone{color:var(--primary);font-weight:600}.order-lines{display:flex;flex-direction:column;gap:6px;padding:10px 0}.order-line{display:flex;gap:8px;align-items:flex-start;font-size:14px}.ol-qty{font-weight:700;color:var(--muted);flex-shrink:0}.ol-name{flex:1 1;min-width:0;font-weight:600}.ol-mods{display:block;font-size:12px;font-weight:400;color:var(--muted);margin-top:1px}.ol-note{font-style:italic}.ol-price{font-weight:700;flex-shrink:0}.order-foot{display:flex;justify-content:space-between;align-items:baseline;padding-top:10px;border-top:1px solid var(--border)}.order-eta{font-size:12px;color:var(--muted)}.order-total{font-size:16px}.notif-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:100;display:flex;align-items:center;justify-content:center;padding:16px;animation:fadeIn .15s ease}.notif-modal{background:var(--surface);border-radius:20px;width:100%;max-width:420px;box-shadow:0 24px 64px rgba(0,0,0,.4);overflow:hidden;animation:scaleIn .2s ease}@keyframes scaleIn{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}.notif-header{display:flex;align-items:center;gap:12px;background:var(--primary);color:#fff;padding:16px 20px}.notif-bell{font-size:28px;flex-shrink:0;animation:ringBell .6s ease .1s 3;display:inline-block;transform-origin:top center}@keyframes ringBell{0%,to{transform:rotate(0deg)}20%{transform:rotate(20deg)}40%{transform:rotate(-18deg)}60%{transform:rotate(14deg)}80%{transform:rotate(-10deg)}}.notif-title{font-size:18px;font-weight:800;line-height:1.2}.notif-subtitle{font-size:12px;opacity:.85;margin-top:2px}.notif-queue-badge{margin-left:auto;background:rgba(255,255,255,.25);border-radius:20px;padding:3px 10px;font-size:12px;font-weight:700;flex-shrink:0}.notif-ref{font-size:22px;font-weight:800;color:var(--primary);padding:14px 20px 4px}.notif-guest{display:flex;justify-content:space-between;align-items:baseline;gap:8px;font-size:14px;padding:0 20px 12px;border-bottom:1px solid var(--border)}.notif-lines{list-style:none;padding:10px 20px;display:flex;flex-direction:column;gap:6px}.notif-line{display:flex;gap:8px;align-items:flex-start;font-size:14px}.notif-line-qty{font-weight:700;color:var(--muted);flex-shrink:0}.notif-line-name{flex:1 1;min-width:0;font-weight:600}.notif-line-mods{display:block;font-size:12px;font-weight:400;color:var(--muted);margin-top:1px}.notif-line-price{font-weight:700;flex-shrink:0}.notif-total{display:flex;justify-content:space-between;font-size:15px;font-weight:700;padding:10px 20px 14px;border-top:1px solid var(--border)}.notif-actions{display:flex;gap:10px;padding:0 20px 12px}.notif-btn{flex:1 1;padding:14px;border-radius:12px;font-size:15px;font-weight:800;border:none;cursor:pointer;transition:opacity .15s,transform .1s}.notif-btn:active{transform:scale(.97)}.notif-btn:disabled{opacity:.45;cursor:not-allowed;transform:none}.notif-btn--accept{background:#059669;color:#fff}.notif-btn--reject{background:#fef2f2;color:#dc2626;border:1.5px solid #fecaca}.notif-later{display:block;width:100%;padding:12px;text-align:center;font-size:13px;color:var(--muted);background:none;border:none;border-top:1px solid var(--border);cursor:pointer;transition:color .15s}.notif-later:hover{color:var(--text)}.order-actions{display:flex;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}.order-action-btn{flex:1 1;padding:10px 12px;border-radius:10px;font-size:13px;font-weight:700;border:none;cursor:pointer;transition:opacity .15s,transform .1s}.order-action-btn:active{transform:scale(.97)}.order-action-btn:disabled{opacity:.45;cursor:not-allowed;transform:none}.order-action-btn--accept{background:#059669;color:#fff}.order-action-btn--reject{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.order-action-btn--advance{background:var(--primary);color:#fff}.order-action-btn--cancel{background:#f3f4f6;color:#6b7280;border:1px solid #e5e7eb}