:root{--primary:#2563eb;--primary-hover:#1d4ed8;--primary-light:#eff6ff;--primary-shadow:#2563eb40;--success:#16a34a;--success-light:#f0fdf4;--warning:#d97706;--warning-light:#fffbeb;--danger:#dc2626;--danger-light:#fef2f2;--info:#0891b2;--info-light:#ecfeff;--gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-200:#e2e8f0;--gray-300:#cbd5e1;--gray-400:#94a3b8;--gray-500:#64748b;--gray-600:#475569;--gray-700:#334155;--gray-800:#1e293b;--gray-900:#0f172a;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--text-inverse:#fff;--bg-page:#f1f5f9;--bg-card:#fff;--bg-input:#f8fafc;--border:#e2e8f0;--border-focus:#2563eb;--status-pending:#d97706;--status-confirmed:#2563eb;--status-preparing:#7c3aed;--status-done:#16a34a;--status-paid:#64748b;--status-available:#16a34a;--status-occupied:#dc2626;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;--radius-full:9999px;--shadow-sm:0 1px 3px #00000014;--shadow-md:0 4px 16px #00000014;--shadow-lg:0 8px 32px #0000001a;--shadow-primary:0 4px 16px var(--primary-shadow);--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs:12px;--font-size-sm:13px;--font-size-md:14px;--font-size-lg:16px;--font-size-xl:18px;--font-size-2xl:22px;--transition:all .2s ease;--sidebar-width:240px;--topbar-height:60px;--bottom-nav-height:64px;--mobile-bottom-clearance:calc(var(--bottom-nav-height) + env(safe-area-inset-bottom,0px))}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;font-size:16px}body{font-family:var(--font-sans);font-size:var(--font-size-md);color:var(--text-primary);background:var(--bg-page);-webkit-font-smoothing:antialiased;line-height:1.5}button{font-family:var(--font-sans);cursor:pointer;background:0 0;border:none}input,textarea,select{font-family:var(--font-sans);font-size:var(--font-size-md)}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}.btn{justify-content:center;align-items:center;gap:var(--space-sm);border-radius:var(--radius-md);font-size:var(--font-size-md);transition:var(--transition);white-space:nowrap;padding:8px 16px;font-weight:600;display:inline-flex}.btn-primary{background:var(--primary);color:var(--text-inverse);box-shadow:var(--shadow-primary)}.btn-primary:hover{background:var(--primary-hover)}.btn-secondary{background:var(--gray-100);color:var(--text-primary)}.btn-secondary:hover{background:var(--gray-200)}.btn-danger{background:var(--danger);color:var(--text-inverse)}.btn-danger:hover{background:#b91c1c}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover{background:var(--gray-100);color:var(--text-primary)}.btn-sm{font-size:var(--font-size-sm);border-radius:var(--radius-sm);padding:5px 12px}.btn-lg{font-size:var(--font-size-lg);padding:12px 24px}.btn:disabled{opacity:.55;cursor:not-allowed}.badge{border-radius:var(--radius-full);font-size:var(--font-size-xs);align-items:center;padding:3px 10px;font-weight:600;display:inline-flex}.badge-pending{color:var(--status-pending);background:#fef3c7}.badge-confirmed{color:var(--status-confirmed);background:#dbeafe}.badge-preparing{color:var(--status-preparing);background:#ede9fe}.badge-done{color:var(--status-done);background:#dcfce7}.badge-paid{background:var(--gray-100);color:var(--status-paid)}.badge-available{color:var(--status-available);background:#dcfce7}.badge-occupied{color:var(--status-occupied);background:#fee2e2}.card{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.input{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-input);width:100%;color:var(--text-primary);font-size:var(--font-size-md);transition:var(--transition);outline:none;padding:9px 12px}.input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px #2563eb1a}.input::placeholder{color:var(--text-muted)}.divider{background:var(--border);border:none;height:1px}.spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.dashboard-layout{background:var(--bg-page);min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--bg-card);border-right:1px solid var(--border);height:100vh;box-shadow:var(--shadow-sm);z-index:100;transition:var(--transition);flex-direction:column;display:flex;position:fixed;top:0;left:0}.sidebar-brand{align-items:center;gap:var(--space-sm);padding:var(--space-lg) var(--space-md);border-bottom:1px solid var(--border);min-height:var(--topbar-height);display:flex}.sidebar-brand-icon{background:var(--primary);border-radius:var(--radius-md);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;display:flex}.sidebar-brand-text{flex-direction:column;min-width:0;display:flex}.sidebar-brand-name{font-size:var(--font-size-md);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-weight:700;line-height:1.2;overflow:hidden}.sidebar-brand-role{font-size:var(--font-size-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-weight:500}.sidebar-nav{padding:var(--space-sm) 0;flex:1;overflow-y:auto}.sidebar-nav-section{padding:var(--space-md) var(--space-md) var(--space-xs);font-size:var(--font-size-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-weight:600}.sidebar-nav-item{align-items:center;gap:var(--space-sm);padding:10px var(--space-md);margin:2px var(--space-sm);border-radius:var(--radius-md);font-size:var(--font-size-md);color:var(--text-secondary);cursor:pointer;transition:var(--transition);width:calc(100% - var(--space-md));text-align:left;background:0 0;border:none;font-weight:500;text-decoration:none;display:flex}.sidebar-nav-item:hover{background:var(--gray-100);color:var(--text-primary)}.sidebar-nav-item.active{background:var(--primary-light);color:var(--primary);font-weight:600}.sidebar-nav-item.active .nav-icon{color:var(--primary)}.nav-icon{flex-shrink:0;align-items:center;font-size:18px;display:flex}.nav-label{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.nav-badge{background:var(--danger);color:#fff;border-radius:var(--radius-full);text-align:center;min-width:18px;padding:1px 6px;font-size:10px;font-weight:700;line-height:16px}.sidebar-footer{border-top:1px solid var(--border);padding:var(--space-md)}.sidebar-user{align-items:center;gap:var(--space-sm);margin-bottom:var(--space-sm);padding:var(--space-sm);border-radius:var(--radius-md);background:var(--gray-50);display:flex}.sidebar-user-avatar{border-radius:var(--radius-full);background:var(--primary);color:#fff;width:34px;height:34px;font-size:var(--font-size-sm);flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:flex}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{font-size:var(--font-size-sm);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-weight:600;overflow:hidden}.sidebar-user-role{font-size:var(--font-size-xs);color:var(--text-muted)}.btn-logout{justify-content:center;align-items:center;gap:var(--space-sm);width:100%;padding:8px var(--space-md);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--danger);border:1px solid var(--border);cursor:pointer;transition:var(--transition);background:0 0;font-weight:600;display:flex}.btn-logout:hover{background:var(--danger-light);border-color:var(--danger)}.dashboard-main{margin-left:var(--sidebar-width);flex-direction:column;flex:1;min-height:100vh;display:flex}.topbar{height:var(--topbar-height);background:var(--bg-card);border-bottom:1px solid var(--border);padding:0 var(--space-lg);align-items:center;gap:var(--space-md);z-index:50;display:flex;position:sticky;top:0}.topbar-title{font-size:var(--font-size-xl);color:var(--text-primary);flex:1;font-weight:700}.page-content{padding:var(--space-lg);flex:1}@media (width<=767px){.sidebar{display:none}.dashboard-main{margin-left:0}.topbar{padding:0 var(--space-md)}.page-content{padding:var(--space-md);padding-bottom:calc(var(--space-md) + var(--mobile-bottom-clearance))}.bottom-nav{display:flex}}@media (width>=768px){.bottom-nav{display:none}}.bottom-nav{height:calc(var(--bottom-nav-height) + env(safe-area-inset-bottom,0px));padding-bottom:env(safe-area-inset-bottom,0px);background:var(--bg-card);border-top:1px solid var(--border);z-index:100;justify-content:stretch;align-items:stretch;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 16px #0000000f}.bottom-nav-item{cursor:pointer;padding:var(--space-xs);color:var(--text-muted);transition:var(--transition);background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;text-decoration:none;display:flex;position:relative}.bottom-nav-item:hover{color:var(--text-secondary)}.bottom-nav-item.active{color:var(--primary)}.bottom-nav-item.active:before{content:"";background:var(--primary);border-radius:0 0 var(--radius-sm) var(--radius-sm);width:32px;height:3px;position:absolute;top:0;left:50%;transform:translate(-50%)}.bottom-nav-icon{align-items:center;font-size:20px;display:flex;position:relative}.bottom-nav-label{letter-spacing:.02em;font-size:10px;font-weight:600}.bottom-nav-badge{background:var(--danger);color:#fff;border-radius:var(--radius-full);text-align:center;min-width:16px;padding:1px 4px;font-size:9px;font-weight:700;line-height:14px;position:absolute;top:-4px;right:-8px}.login-page{background:var(--bg-page);min-height:100vh;padding:var(--space-md);background-image:radial-gradient(at 80% 10%,#2563eb14 0%,#0000 60%),radial-gradient(at 10% 90%,#2563eb0d 0%,#0000 60%);justify-content:center;align-items:center;display:flex}.login-card{background:var(--bg-card);border-radius:var(--radius-xl);border:1px solid var(--border);width:100%;max-width:400px;box-shadow:var(--shadow-lg);overflow:hidden}.login-accent-bar{background:linear-gradient(90deg, var(--primary), #60a5fa);height:4px}.login-body{padding:var(--space-xl) var(--space-xl) var(--space-xl)}.login-header{text-align:center;margin-bottom:var(--space-xl)}.login-logo{background:var(--primary);border-radius:var(--radius-lg);width:56px;height:56px;margin-bottom:var(--space-md);box-shadow:var(--shadow-primary);justify-content:center;align-items:center;font-size:26px;display:inline-flex}.login-title{font-size:var(--font-size-2xl);color:var(--text-primary);letter-spacing:-.3px;font-weight:700}.login-subtitle{font-size:var(--font-size-sm);color:var(--text-muted);margin-top:4px}.login-form{gap:var(--space-md);flex-direction:column;display:flex}.form-group{flex-direction:column;gap:6px;display:flex}.form-label{font-size:var(--font-size-xs);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.input-wrapper{align-items:center;display:flex;position:relative}.input-icon{color:var(--text-muted);pointer-events:none;align-items:center;display:flex;position:absolute;left:12px}.input-with-icon{padding-left:38px}.input-with-action{padding-right:38px}.input-action{color:var(--text-muted);border-radius:var(--radius-sm);transition:var(--transition);align-items:center;padding:4px;display:flex;position:absolute;right:10px}.input-action:hover{color:var(--text-secondary);background:var(--gray-100)}.login-error{background:var(--danger-light);border-radius:var(--radius-md);color:var(--danger);font-size:var(--font-size-sm);border:1px solid #fecaca;align-items:center;gap:8px;padding:10px 12px;display:flex}.login-submit{width:100%;margin-top:4px}@media (width<=480px){.login-body{padding:var(--space-lg)}}.home-page{min-height:100dvh;padding-bottom:calc(64px + env(safe-area-inset-bottom,0px));background:#faf7f3;flex-direction:column;display:flex}.home-header{padding:20px 18px 16px;padding-top:max(20px, env(safe-area-inset-top,20px));text-align:center;position:relative}.home-header__table-badge{top:max(16px, env(safe-area-inset-top,16px));color:#888;background:#fff;border-radius:20px;padding:5px 12px;font-size:12px;font-weight:500;position:absolute;right:16px;box-shadow:0 1px 5px #00000014}.home-header__table-badge strong{color:var(--color-primary,#e07a3a);font-weight:800}.home-header__name{color:#1a1205;letter-spacing:-.8px;margin:0 0 4px;font-family:Georgia,Times New Roman,serif;font-size:28px;font-weight:900;line-height:1.15}.home-header__sub{color:#aaa;margin:0;font-size:13px;font-weight:400}.home-banner{aspect-ratio:16/7;background:#f0ece6;border-radius:18px;flex-shrink:0;margin:4px 14px 0;position:relative;overflow:hidden;box-shadow:0 2px 12px #00000014}.home-banner__track{width:100%;height:100%;transition:transform .45s cubic-bezier(.4,0,.2,1);display:flex}.home-banner__slide{flex-shrink:0;justify-content:center;align-items:center;min-width:100%;height:100%;padding:16px 24px;display:flex}.home-banner__text{color:#1a1205;text-align:center;margin:0;font-size:15px;font-weight:700;line-height:1.45}.home-banner__dots{justify-content:center;gap:6px;display:flex;position:absolute;bottom:10px;left:0;right:0}.home-banner__dot{cursor:pointer;-webkit-tap-highlight-color:transparent;background:#1a120533;border:none;border-radius:50%;width:6px;height:6px;padding:0;transition:all .22s}.home-banner__dot--active{background:var(--color-primary,#e07a3a);border-radius:3px;width:18px}.home-section{padding:20px 14px 0}.home-section__head{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.home-section__title{color:#1a1205;letter-spacing:-.2px;margin:0;font-size:16px;font-weight:800}.home-section__more{color:var(--color-primary,#e07a3a);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;align-items:center;gap:2px;padding:4px 0;font-size:13px;font-weight:600;display:flex}.home-section__more:active{opacity:.6}.home-bestseller-grid,.home-bestseller-empty{grid-template-columns:repeat(2,1fr);gap:10px;display:grid}.home-bestseller-skeleton{aspect-ratio:3/4;background:linear-gradient(90deg,#f0ece6 25%,#e8e2da 50%,#f0ece6 75%) 0 0/200% 100%;border-radius:14px;animation:1.4s infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.home-bestseller-card{cursor:pointer;text-align:left;-webkit-tap-highlight-color:transparent;background:#fff;border:none;border-radius:14px;flex-direction:column;padding:0;transition:transform .12s;display:flex;overflow:hidden;box-shadow:0 1px 6px #00000012}.home-bestseller-card:active{transform:scale(.96)}.home-bestseller-card__img-wrap{aspect-ratio:1;background:#f5f0ea;flex-shrink:0;width:100%;overflow:hidden}.home-bestseller-card__img{object-fit:cover;width:100%;height:100%;display:block}.home-bestseller-card__img-placeholder{justify-content:center;align-items:center;width:100%;height:100%;font-size:28px;display:flex}.home-bestseller-card__name{color:#1a1205;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;padding:8px 10px 2px;font-size:13px;font-weight:700;line-height:1.3;display:-webkit-box;overflow:hidden}.home-bestseller-card__price{color:var(--color-primary,#e07a3a);margin:0;padding:2px 10px 10px;font-size:13px;font-weight:800}.home-cta{flex-direction:column;gap:10px;padding:22px 14px 0;display:flex}.home-cta__btn{letter-spacing:-.2px;cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;border-radius:16px;justify-content:center;align-items:center;gap:10px;width:100%;min-height:54px;font-size:16px;font-weight:800;transition:transform .12s,opacity .12s;display:flex}.home-cta__btn:active{opacity:.88;transform:scale(.97)}.home-cta__btn--primary{background:var(--color-primary,#e07a3a);color:#fff;box-shadow:0 4px 18px #e07a3a61}.home-cta__btn--secondary{color:#1a1205;background:#fff;border:1.5px solid #ede8e0;box-shadow:0 2px 10px #00000017}.customer-nav{z-index:100;padding-bottom:env(safe-area-inset-bottom,0px);background:#fff;border-top:1px solid #ede8e0;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -2px 12px #00000012}.customer-nav__tab{cursor:pointer;-webkit-tap-highlight-color:transparent;color:#b0a89e;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;min-height:56px;padding:6px 4px;transition:color .15s;display:flex}.customer-nav__tab--active{color:var(--color-primary,#e07a3a)}.customer-nav__tab:active{opacity:.6}.customer-nav__icon{line-height:0;position:relative}.customer-nav__dot{background:var(--color-primary,#e07a3a);color:#fff;border-radius:8px;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 3px;font-size:9px;font-weight:800;line-height:1;display:flex;position:absolute;top:-5px;right:-7px}.customer-nav__label{letter-spacing:.01em;font-size:10px;font-weight:600}.product-card{-webkit-tap-highlight-color:transparent;background:#fff;border-radius:14px;flex-direction:column;display:flex;position:relative;overflow:hidden;box-shadow:0 1px 6px #00000014}.product-card:active{transition:transform .12s;transform:scale(.97)}.product-card--adding{animation:.25s card-pop}@keyframes card-pop{0%{transform:scale(1)}50%{transform:scale(1.04)}to{transform:scale(1)}}.product-card__img-wrap{aspect-ratio:1;background:#f0ece6;flex-shrink:0;width:100%;position:relative;overflow:hidden}.product-card__img{object-fit:cover;width:100%;height:100%;display:block}.product-card__img-placeholder{color:#c4b8a8;justify-content:center;align-items:center;width:100%;height:100%;display:flex}.product-card__badge{background:var(--color-primary,#e07a3a);color:#fff;border-radius:10px;justify-content:center;align-items:center;min-width:20px;height:20px;padding:0 4px;font-size:11px;font-weight:700;animation:.18s badge-in;display:flex;position:absolute;top:6px;right:6px;box-shadow:0 2px 6px #e07a3a73}@keyframes badge-in{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}.product-card__body{flex-direction:column;flex:1;gap:2px;padding:8px 10px 10px;display:flex}.product-card__name{color:#1a1205;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:13px;font-weight:700;line-height:1.3;display:-webkit-box;overflow:hidden}.product-card__footer{flex-wrap:nowrap;justify-content:space-between;align-items:center;gap:4px;min-width:0;margin-top:6px;display:flex}.product-card__price{color:var(--color-primary,#e07a3a);letter-spacing:-.2px;white-space:nowrap;text-overflow:ellipsis;flex-shrink:1;min-width:0;font-size:13px;font-weight:800;overflow:hidden}.product-card__btn-add{background:var(--color-primary,#e07a3a);color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;transition:transform .12s;display:flex;box-shadow:0 2px 8px #e07a3a66}.product-card__btn-add:active{transform:scale(.88)}.product-card__qty-ctrl{background:#f5f0ea;border-radius:20px;flex-shrink:0;align-items:center;gap:2px;padding:3px 4px;display:flex}.product-card__qty-num{color:var(--color-primary,#e07a3a);text-align:center;min-width:16px;font-size:13px;font-weight:800}.product-card__btn-qty{color:#1a1205;cursor:pointer;-webkit-tap-highlight-color:transparent;background:#fff;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;display:flex;box-shadow:0 1px 3px #0000001a}.product-card__btn-qty--plus{background:var(--color-primary,#e07a3a);color:#fff}.product-card__btn-qty:active{transform:scale(.85)}@media (width>=480px){.product-card__img-wrap{aspect-ratio:4/3}.product-card__body{padding:10px 12px 12px}.product-card__name,.product-card__price{font-size:14px}.product-card__btn-add{width:32px;height:32px}.product-card__btn-qty{width:26px;height:26px}}.menu-page{min-height:100dvh;padding-bottom:calc(80px + env(safe-area-inset-bottom,0px));background:#faf7f3}.menu-header{z-index:100;padding-top:env(safe-area-inset-top,0px);background:#faf7f3;position:sticky;top:0;box-shadow:0 1px #00000012}.menu-header__inner{justify-content:space-between;align-items:center;padding:12px 16px 8px;display:flex}.menu-header__table{background:#fff;border-radius:20px;align-items:center;gap:5px;padding:5px 11px;display:flex;box-shadow:0 1px 4px #00000014}.menu-header__label{color:#999;font-size:11px;font-weight:500}.menu-header__table-num{color:var(--color-primary,#e07a3a);font-size:13px;font-weight:800}.menu-header__title{color:#1a1205;letter-spacing:-.4px;margin:0;font-size:18px;font-weight:900}.menu-header__spacer{min-width:70px}.menu-tabs{-webkit-overflow-scrolling:touch;scroll-behavior:smooth;scrollbar-width:none;-ms-overflow-style:none;gap:8px;padding:6px 16px 12px;display:flex;overflow-x:auto}.menu-tabs::-webkit-scrollbar{display:none}.menu-tabs__pill{color:#888;cursor:pointer;white-space:nowrap;-webkit-tap-highlight-color:transparent;background:#fff;border:1.5px solid #e5ddd3;border-radius:18px;flex-shrink:0;align-items:center;min-height:36px;padding:0 16px;font-size:13px;font-weight:600;transition:background .15s,border-color .15s,color .15s;display:flex}.menu-tabs__pill--active{background:var(--color-primary,#e07a3a);border-color:var(--color-primary,#e07a3a);color:#fff;box-shadow:0 3px 10px #e07a3a4d}.menu-tabs__pill:active{opacity:.75}.menu-main{flex-direction:column;gap:24px;padding:8px 12px 0;display:flex}.menu-section__title{color:#1a1205;letter-spacing:-.2px;align-items:center;gap:8px;margin:0 0 12px;font-size:15px;font-weight:800;display:flex}.menu-section__title:after{content:"";background:linear-gradient(90deg,#e5ddd3,#0000);border-radius:2px;flex:1;height:1.5px}.menu-grid{grid-template-columns:repeat(2,1fr);gap:10px;display:grid}@media (width>=480px){.menu-grid{grid-template-columns:repeat(3,1fr);gap:12px}}@media (width>=768px){.menu-main{padding:12px 20px 0}.menu-grid{grid-template-columns:repeat(4,1fr);gap:14px}}.menu-cart-bar{bottom:calc(12px + env(safe-area-inset-bottom,0px));z-index:200;color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent;background:#1a1205;border-radius:16px;justify-content:space-between;align-items:center;padding:13px 16px;animation:.28s cubic-bezier(.34,1.56,.64,1) cart-slide-up;display:flex;position:fixed;left:12px;right:12px;box-shadow:0 6px 24px #1a120552}.menu-cart-bar:active{transition:transform .1s;transform:scale(.975)}@keyframes cart-slide-up{0%{opacity:0;transform:translateY(100px)}to{opacity:1;transform:translateY(0)}}.menu-cart-bar__left{align-items:center;gap:10px;display:flex}.menu-cart-bar__icon{background:var(--color-primary,#e07a3a);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;display:flex;position:relative}.menu-cart-bar__count{color:var(--color-primary,#e07a3a);background:#fff;border-radius:8px;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 3px;font-size:10px;font-weight:800;display:flex;position:absolute;top:-5px;right:-5px}.menu-cart-bar__label{font-size:14px;font-weight:700}.menu-cart-bar__total{color:var(--color-primary,#e07a3a);white-space:nowrap;font-size:14px;font-weight:800}.menu-loading,.menu-error{color:#888;text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;min-height:100dvh;padding:24px;font-size:15px;display:flex}.menu-loading__spinner svg{color:var(--color-primary,#e07a3a);animation:.9s linear infinite spin}.menu-error svg{color:var(--color-primary,#e07a3a)}.menu-error button{background:var(--color-primary,#e07a3a);color:#fff;cursor:pointer;border:none;border-radius:22px;min-height:44px;margin-top:4px;padding:12px 28px;font-size:14px;font-weight:700}.ovm-modal{max-width:620px}.ovm-modal--wide{max-width:980px}.ovm-modal__header{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.ovm-content__intro{margin-bottom:1rem}.ovm-content__title{color:#111827;margin:0;font-size:1.2rem}.ovm-modal__subtitle{color:#6b7280;margin:.35rem 0 0;font-size:.92rem}.ovm-summary-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.75rem;margin-bottom:1rem;display:grid}.ovm-summary-card{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:.85rem .95rem}.ovm-summary-card__label,.ovm-order-card__total-label{color:#6b7280;font-size:.85rem;display:block}.ovm-summary-card strong,.ovm-order-card__total-value{color:#111827;font-size:1.1rem}.ovm-empty{color:#6b7280;background:#fff;border:1px dashed #d1d5db;border-radius:14px;justify-content:center;align-items:center;min-height:220px;display:flex}.ovm-order-list{gap:1rem;display:grid}.ovm-order-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:1rem;box-shadow:0 8px 26px #0f172a0d}.ovm-order-card__head,.ovm-order-card__foot,.ovm-order-item{justify-content:space-between;gap:1rem;display:flex}.ovm-order-card__head,.ovm-order-card__foot{align-items:center}.ovm-order-card__eyebrow{text-transform:uppercase;letter-spacing:.04em;color:#6b7280;font-size:.8rem}.ovm-order-card__title{color:#111827;margin:.15rem 0;font-size:1.1rem}.ovm-order-card__meta,.ovm-order-item__note{color:#6b7280;margin:0;font-size:.88rem}.ovm-order-item__meta{color:#9ca3af;text-transform:uppercase;letter-spacing:.04em;margin-bottom:.25rem;font-size:.78rem}.ovm-status{text-transform:uppercase;border-radius:999px;padding:.4rem .7rem;font-size:.8rem;font-weight:700}.ovm-status--pending{color:#92400e;background:#fef3c7}.ovm-status--confirmed{color:#1d4ed8;background:#dbeafe}.ovm-status--preparing{color:#6d28d9;background:#ede9fe}.ovm-status--done{color:#065f46;background:#d1fae5}.ovm-status--paid{color:#374151;background:#e5e7eb}.ovm-order-items{gap:.75rem;margin:1rem 0;display:grid}.ovm-order-item{border-bottom:1px solid #f3f4f6;align-items:flex-start;padding-bottom:.75rem}.ovm-order-item:last-child{border-bottom:none;padding-bottom:0}.ovm-order-item__side{white-space:nowrap;justify-items:end;gap:.2rem;font-weight:600;display:grid}.ovm-order-item__remove{color:#be123c;background:#fff1f2;border:1px solid #fecaca;border-radius:999px;margin-top:.35rem;padding:.35rem .75rem;font-size:.78rem;font-weight:700}.ovm-order-item__remove:disabled{opacity:.55;cursor:not-allowed}@media (width<=640px){.ovm-modal__header,.ovm-order-card__head,.ovm-order-card__foot,.ovm-order-item{flex-direction:column;align-items:flex-start}.ovm-order-item__side{justify-items:start}}.order-page{min-height:100dvh;padding-bottom:calc(148px + env(safe-area-inset-bottom,0px));background:#faf7f3;flex-direction:column;display:flex}.order-header{z-index:10;padding:12px 14px;padding-top:max(12px, env(safe-area-inset-top,12px));background:#faf7f3;border-bottom:1px solid #ede8e0;align-items:center;gap:10px;display:flex;position:sticky;top:0}.order-header__back-btn{cursor:pointer;color:#1a1205;-webkit-tap-highlight-color:transparent;background:#fff;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;display:flex;box-shadow:0 1px 5px #0000001a}.order-header__back-btn:active{transform:scale(.88)}.order-header__text{flex:1;min-width:0}.order-header__title{color:#1a1205;letter-spacing:-.3px;margin:0;font-size:17px;font-weight:900;line-height:1.2}.order-header__sub{color:#999;margin:2px 0 0;font-size:12px;font-weight:500}.order-header__table{color:var(--color-primary,#e07a3a);font-weight:700}.order-header__clear-btn{color:#f87171;cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;flex-shrink:0;align-items:center;gap:4px;padding:8px 4px;font-size:12px;font-weight:600;display:flex}.order-header__clear-btn:active{opacity:.6}.order-empty{color:#bbb;text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;padding:32px 24px;font-size:14px;font-weight:500;line-height:1.6;display:flex}.order-empty__btn{background:var(--color-primary,#e07a3a);color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;border-radius:14px;min-height:48px;margin-top:8px;padding:13px 28px;font-size:14px;font-weight:700;box-shadow:0 4px 14px #e07a3a66}.order-empty__btn:active{transform:scale(.96)}.order-main{flex-direction:column;gap:8px;padding:12px 12px 0;display:flex}.order-orders-view{padding:12px}.order-main__meta{color:#aaa;text-transform:uppercase;letter-spacing:.05em;padding:0 2px 4px;font-size:11px;font-weight:600}.order-item{background:#fff;border-radius:16px;animation:.28s both fade-up;overflow:hidden;box-shadow:0 1px 5px #0000000f}@keyframes fade-up{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.order-item__row{flex-wrap:nowrap;align-items:center;gap:8px;min-width:0;padding:12px 12px 8px;display:flex}.order-item__info{flex:1;min-width:0}.order-item__name{color:#1a1205;white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:13px;font-weight:700;overflow:hidden}.order-item__unit-price{color:var(--color-primary,#e07a3a);white-space:nowrap;margin:3px 0 0;font-size:12px;font-weight:600}.order-item__per{color:#bbb;font-weight:400}.order-item__qty-ctrl{background:#f5f0ea;border-radius:20px;flex-shrink:0;align-items:center;gap:4px;padding:4px 6px;display:flex}.order-item__qty-num{color:var(--color-primary,#e07a3a);text-align:center;min-width:18px;font-size:14px;font-weight:800}.order-item__qty-btn{color:#1a1205;cursor:pointer;-webkit-tap-highlight-color:transparent;background:#fff;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;display:flex;box-shadow:0 1px 3px #0000001a}.order-item__qty-btn--plus{background:var(--color-primary,#e07a3a);color:#fff}.order-item__qty-btn:active{transform:scale(.85)}.order-item__subtotal{color:#1a1205;text-align:right;white-space:nowrap;flex-shrink:0;margin:0;font-size:13px;font-weight:900}.order-item__note-wrap{padding:0 12px 10px}.order-item__note-toggle{color:#aaa;cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;align-items:center;gap:5px;min-height:32px;padding:4px 0;font-size:12px;font-weight:500;display:flex}.order-item__note-toggle:active{opacity:.6}.order-item__note-value{color:var(--color-primary,#e07a3a);white-space:nowrap;text-overflow:ellipsis;max-width:200px;overflow:hidden}.order-item__note-input{color:#1a1205;box-sizing:border-box;-webkit-text-size-adjust:100%;background:#faf7f3;border:1.5px solid #e5ddd3;border-radius:10px;outline:none;width:100%;margin-top:6px;padding:10px 12px;font-size:14px;display:block}@supports (-webkit-touch-callout:none){.order-item__note-input{font-size:16px}}.order-item__note-input::placeholder{color:#ccc}.order-item__note-input:focus{border-color:var(--color-primary,#e07a3a)}.order-bar{z-index:20;padding:12px 14px;padding-bottom:calc(14px + env(safe-area-inset-bottom,0px));background:#fff;border-top:1px solid #ede8e0;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 20px #00000014}.order-bar__summary{justify-content:space-between;align-items:flex-end;margin-bottom:10px;display:flex}.order-bar__label{color:#aaa;margin:0 0 2px;font-size:11px;font-weight:500}.order-bar__total{color:#1a1205;letter-spacing:-.5px;margin:0;font-size:22px;font-weight:900;line-height:1}.order-bar__qty{color:#aaa;margin:0;padding-bottom:2px;font-size:12px}.order-bar__submit-btn{background:var(--color-primary,#e07a3a);color:#fff;letter-spacing:-.2px;cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;border-radius:14px;justify-content:center;align-items:center;width:100%;min-height:50px;font-size:16px;font-weight:800;display:flex;box-shadow:0 4px 16px #e07a3a66}.order-bar__submit-btn:active:not(:disabled){opacity:.9;transform:scale(.97)}.order-bar__submit-btn:disabled{opacity:.6;cursor:not-allowed}.order-bar__spinner{border:2.5px solid #ffffff59;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.75s linear infinite spin}.order-feedback{min-height:100dvh;padding:32px 24px;padding-bottom:calc(32px + env(safe-area-inset-bottom,0px));text-align:center;background:#faf7f3;flex-direction:column;justify-content:center;align-items:center;display:flex}.order-feedback__icon{border-radius:50%;justify-content:center;align-items:center;width:76px;height:76px;margin-bottom:18px;animation:.45s cubic-bezier(.34,1.56,.64,1) both icon-pop;display:flex}@keyframes icon-pop{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}.order-feedback__icon--success{color:#10b981;background:#d1fae5}.order-feedback__icon--error{color:#f87171;background:#fee2e2}.order-feedback__title{color:#1a1205;letter-spacing:-.4px;margin:0 0 8px;font-size:21px;font-weight:900}.order-feedback__sub{color:#666;max-width:280px;margin:0 0 6px;font-size:14px;line-height:1.5}.order-feedback__sub strong{color:var(--color-primary,#e07a3a)}.order-feedback__hint{color:#aaa;margin:0 0 32px;font-size:12px}.order-feedback__actions{gap:10px;display:flex}.order-feedback__btn{cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;border-radius:14px;align-items:center;min-height:48px;padding:0 22px;font-size:14px;font-weight:700;display:flex}.order-feedback__btn:active{transform:scale(.95)}.order-feedback__btn--dark{color:#fff;background:#1a1205;box-shadow:0 4px 16px #1a120538}.order-feedback__btn--primary{background:var(--color-primary,#e07a3a);color:#fff;box-shadow:0 4px 14px #e07a3a61}.order-feedback__btn--outline{color:#1a1205;background:0 0;border:2px solid #1a1205!important}.amp-page{max-width:1100px;margin:0 auto;padding:1rem}.amp-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:1.25rem;display:flex}.amp-title{color:#1a1a2e;margin:0;font-size:1.4rem;font-weight:700}.amp-toolbar{flex-wrap:wrap;gap:.5rem;display:flex}.amp-feedback{border-radius:8px;margin-bottom:1rem;padding:.75rem 1rem;font-size:.9rem;font-weight:500}.amp-feedback--error{color:#991b1b;background:#fee2e2;border-left:4px solid #ef4444}.amp-feedback--success{color:#065f46;background:#d1fae5;border-left:4px solid #10b981}.amp-modal-backdrop{z-index:130;padding:0 0 calc(var(--mobile-bottom-clearance) + 12px);background:#00000073;justify-content:center;align-items:flex-end;animation:.18s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.amp-modal{width:100%;max-width:520px;max-height:calc(100vh - var(--mobile-bottom-clearance) - 24px);background:#fff;border-radius:18px 18px 0 0;padding:1.5rem 1.25rem;animation:.22s slideUp;overflow-y:auto}@keyframes slideUp{0%{opacity:0;transform:translateY(60px)}to{opacity:1;transform:translateY(0)}}.amp-modal__title{color:#1a1a2e;margin:0 0 1.1rem;font-size:1.15rem;font-weight:700}.amp-form{flex-direction:column;gap:.85rem;display:flex}.amp-label{color:#374151;flex-direction:column;gap:.3rem;font-size:.88rem;font-weight:600;display:flex}.amp-input,.amp-select{color:#1a1a2e;background:#fff;border:1.5px solid #d1d5db;border-radius:8px;outline:none;min-height:44px;padding:.6rem .8rem;font-size:.95rem;transition:border-color .15s}.amp-input:focus,.amp-select:focus{border-color:#4f46e5}.amp-toggle-row{justify-content:space-between;align-items:center;padding:.5rem 0;display:flex}.amp-toggle-label{color:#374151;font-size:.9rem;font-weight:600}.amp-toggle{width:46px;height:26px;display:inline-block;position:relative}.amp-toggle input{opacity:0;width:0;height:0}.amp-toggle-slider{cursor:pointer;background:#d1d5db;border-radius:13px;transition:background .2s;position:absolute;inset:0}.amp-toggle-slider:before{content:"";background:#fff;border-radius:50%;width:20px;height:20px;transition:transform .2s;position:absolute;top:3px;left:3px;box-shadow:0 1px 3px #0003}.amp-toggle input:checked+.amp-toggle-slider{background:#4f46e5}.amp-toggle input:checked+.amp-toggle-slider:before{transform:translate(20px)}.amp-modal__actions{flex-wrap:wrap;gap:.5rem;margin-top:.5rem;display:flex}.amp-confirm{background:#fff7ed;border:1.5px solid #fb923c;border-radius:12px;flex-direction:column;gap:.75rem;padding:1rem;display:flex}.amp-confirm p{color:#92400e;margin:0;font-size:.95rem}.amp-confirm__actions{gap:.5rem;display:flex}@media (width>=640px){.amp-page{padding:1.5rem}.amp-title{font-size:1.6rem}.amp-modal{border-radius:16px;align-self:center;max-height:90vh;margin:auto}.amp-modal-backdrop{align-items:center;padding:16px}}.atp-page{max-width:900px;margin:0 auto;padding:1rem}.atp-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:1.25rem;display:flex}.atp-title{color:var(--color-text,#1a1a2e);margin:0;font-size:1.4rem;font-weight:700}.atp-toolbar{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.btn{cursor:pointer;white-space:nowrap;border:none;border-radius:8px;align-items:center;gap:.35rem;min-height:44px;padding:.6rem 1rem;font-size:.9rem;font-weight:600;line-height:1;transition:opacity .15s,transform .1s;display:inline-flex}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-primary{color:#fff;background:#4f46e5}.btn-primary:hover:not(:disabled){background:#4338ca}.btn-ghost{color:#4f46e5;background:0 0;border:1.5px solid #4f46e5}.btn-ghost:hover:not(:disabled){background:#eef2ff}.btn-sm{min-height:38px;padding:.45rem .75rem;font-size:.82rem}.btn-danger{color:#b91c1c;background:#fee2e2}.btn-danger:hover:not(:disabled){background:#fecaca}.btn-warning{color:#92400e;background:#fef3c7}.btn-warning:hover:not(:disabled){background:#fde68a}.btn-success{color:#065f46;background:#d1fae5}.btn-success:hover:not(:disabled){background:#a7f3d0}.atp-create-bar{flex-wrap:wrap;gap:.5rem;margin-bottom:1.25rem;display:flex}.atp-input{color:#1a1a2e;background:#fff;border:1.5px solid #d1d5db;border-radius:8px;outline:none;flex:180px;min-height:44px;padding:.6rem .85rem;font-size:.95rem;transition:border-color .15s}.atp-input:focus{border-color:#4f46e5}.atp-input::placeholder{color:#9ca3af}.atp-feedback{border-radius:8px;margin-bottom:1rem;padding:.75rem 1rem;font-size:.9rem;font-weight:500}.atp-feedback--error{color:#991b1b;background:#fee2e2;border-left:4px solid #ef4444}.atp-feedback--success{color:#065f46;background:#d1fae5;border-left:4px solid #10b981}.atp-loading{color:#6b7280;justify-content:center;align-items:center;gap:.6rem;padding:2rem;font-size:.95rem;display:flex}.spinner{border:3px solid #e5e7eb;border-top-color:#4f46e5;border-radius:50%;flex-shrink:0;width:22px;height:22px;animation:.7s linear infinite spin}.atp-empty{text-align:center;color:#6b7280;padding:3rem 1rem}.atp-empty-icon{margin-bottom:.5rem;font-size:2.5rem}.atp-empty p{margin:.25rem 0 0;font-size:.95rem}.atp-grid{grid-template-columns:1fr;gap:.85rem;display:grid}@media (width>=640px){.atp-page{padding:1.5rem}.atp-title{font-size:1.6rem}.atp-grid{grid-template-columns:repeat(2,1fr)}}@media (width>=900px){.atp-grid{grid-template-columns:repeat(3,1fr)}}.sp-page{max-width:1200px;margin:0 auto;padding:1rem}.sp-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem;display:flex}.sp-title{color:#1a1a2e;margin:0;font-size:1.5rem}.sp-subtitle{color:#6b7280;margin:.35rem 0 0;font-size:.92rem}.sp-empty{color:#6b7280;background:#fff;border:1px dashed #d1d5db;border-radius:14px;justify-content:center;align-items:center;min-height:220px;display:flex}@media (width<=640px){.sp-page{padding:.85rem}}.sp-order-card__total-label{color:#6b7280;font-size:.85rem;display:block}.sp-order-card__total-value{color:#111827;font-size:1.05rem}.sp-order-card__actions{flex-wrap:wrap;gap:.5rem;display:flex}@media (width<=640px){.sp-order-card__head,.sp-order-card__foot,.sp-order-item{flex-direction:column;align-items:flex-start}.sp-order-item__side{justify-items:start;margin-left:0}}.ssp-list{gap:.85rem;display:grid}.ssp-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;grid-template-columns:64px 1fr;align-items:stretch;gap:1rem;padding:1rem;display:grid;box-shadow:0 8px 26px #0f172a0d}.ssp-card__queue{color:#0f766e;background:linear-gradient(135deg,#ecfeff,#cffafe);border-radius:14px;justify-content:center;align-items:center;font-size:1.1rem;font-weight:800;display:flex}.ssp-card__main{flex-direction:column;gap:.75rem;display:flex}.ssp-card__top{justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.ssp-card__eyebrow{text-transform:uppercase;letter-spacing:.04em;color:#6b7280;font-size:.8rem}.ssp-card__title{color:#111827;margin:.15rem 0;font-size:1.15rem}.ssp-card__meta{color:#6b7280;margin:0;font-size:.88rem}.ssp-card__details{color:#374151;flex-wrap:wrap;gap:1rem;font-size:.92rem;display:flex}.ssp-card__actions{flex-wrap:wrap;gap:.5rem;display:flex}.ssp-badge{text-transform:uppercase;color:#166534;background:#dcfce7;border-radius:999px;padding:.4rem .7rem;font-size:.8rem;font-weight:700}@media (width<=640px){.ssp-card{grid-template-columns:1fr}.ssp-card__queue{min-height:48px}.ssp-card__top{flex-direction:column;align-items:flex-start}}.mic{background:#fff;border:1.5px solid #e5e7eb;border-radius:14px;flex-direction:column;transition:box-shadow .18s,transform .15s;display:flex;position:relative;overflow:hidden}.mic:hover{box-shadow:0 6px 20px #0000001a}.mic--unavailable{opacity:.55}.mic--unavailable:after{content:"Hết món";color:#fff;text-transform:uppercase;letter-spacing:.05em;background:#ef4444;border-radius:20px;padding:.2rem .55rem;font-size:.7rem;font-weight:700;position:absolute;top:10px;right:10px}.mic__img-wrap{background:linear-gradient(135deg,#f3f4f6 0%,#e5e7eb 100%);flex-shrink:0;justify-content:center;align-items:center;height:130px;font-size:2.6rem;display:flex;overflow:hidden}.mic__img{object-fit:cover;width:100%;height:100%;display:block}.mic__img-fallback{justify-content:center;align-items:center;width:100%;height:100%;display:flex}.mic__body{flex-direction:column;flex:1;gap:.25rem;padding:.75rem;display:flex}.mic__name{color:#1a1a2e;word-break:break-word;margin:0;font-size:.95rem;font-weight:700;line-height:1.3}.mic__category{color:#9ca3af;text-transform:uppercase;letter-spacing:.05em;font-size:.72rem;font-weight:600}.mic__price{color:#f97316;margin-top:auto;padding-top:.35rem;font-size:1rem;font-weight:800}.mic__footer{border-top:1px solid #f3f4f6;flex-wrap:wrap;gap:.4rem;padding:.6rem .75rem;display:flex}.mic__qty{align-items:center;gap:.4rem;width:100%;display:flex}.mic__qty-btn{color:#4f46e5;cursor:pointer;background:#fff;border:1.5px solid #4f46e5;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.1rem;font-weight:700;transition:background .12s;display:flex}.mic__qty-btn:hover{background:#eef2ff}.mic__qty-btn:active{transform:scale(.93)}.mic__qty-num{color:#1a1a2e;text-align:center;min-width:24px;font-size:1rem;font-weight:700}.mic__qty-label{color:#6b7280;margin-left:auto;font-size:.8rem}.mic--in-cart{border-color:#4f46e5;box-shadow:0 0 0 2px #c7d2fe}.mic-btn{cursor:pointer;white-space:nowrap;border:none;border-radius:7px;align-items:center;gap:.3rem;min-height:36px;padding:.4rem .7rem;font-size:.8rem;font-weight:600;transition:opacity .15s;display:inline-flex}.mic-btn:disabled{opacity:.45;cursor:not-allowed}.mic-btn--ghost{color:#374151;background:#f3f4f6}.mic-btn--ghost:hover:not(:disabled){background:#e5e7eb}.mic-btn--danger{color:#b91c1c;background:#fee2e2}.mic-btn--danger:hover:not(:disabled){background:#fecaca}.mic-btn--toggle-on{color:#065f46;background:#d1fae5}.mic-btn--toggle-off{color:#6b7280;background:#f3f4f6}.mig{flex-direction:column;gap:1rem;display:flex}.mig__bar{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.mig__search{border:1.5px solid #d1d5db;border-radius:8px;outline:none;flex:180px;min-height:42px;padding:.55rem .8rem;font-size:.9rem;transition:border-color .15s}.mig__search:focus{border-color:#4f46e5}.mig__cats{flex-wrap:wrap;gap:.35rem;display:flex}.mig__cat{color:#6b7280;cursor:pointer;white-space:nowrap;background:#fff;border:1.5px solid #d1d5db;border-radius:20px;min-height:36px;padding:.4rem .85rem;font-size:.82rem;font-weight:600;transition:background .12s,color .12s,border-color .12s}.mig__cat:hover{color:#4f46e5;border-color:#4f46e5}.mig__cat--active{color:#fff;background:#4f46e5;border-color:#4f46e5}.mig__count{color:#9ca3af;font-size:.82rem}.mig__grid{grid-template-columns:repeat(2,1fr);gap:.75rem;display:grid}.mig__empty{text-align:center;color:#9ca3af;padding:3rem 1rem}.mig__empty-icon{margin-bottom:.5rem;font-size:2.5rem}@media (width>=640px){.mig__grid{grid-template-columns:repeat(3,1fr)}}@media (width>=900px){.mig__grid{grid-template-columns:repeat(4,1fr)}}.table-card{background:#fff;border:1.5px solid #e5e7eb;border-radius:12px;padding:1rem;transition:box-shadow .15s;box-shadow:0 1px 4px #0000000f}.table-card:hover{box-shadow:0 4px 12px #0000001a}.table-card__header{align-items:flex-start;gap:.5rem;margin-bottom:.6rem;display:flex}.table-card__name{color:#1a1a2e;word-break:break-word;flex:1;margin:0;font-size:1rem;font-weight:700}.table-card__badge{text-transform:uppercase;letter-spacing:.04em;border-radius:20px;flex-shrink:0;padding:.2rem .55rem;font-size:.72rem;font-weight:700;display:inline-block}.table-card__badge--available{color:#065f46;background:#d1fae5}.table-card__badge--occupied{color:#991b1b;background:#fee2e2}.table-card__badge--inactive{color:#6b7280;background:#f3f4f6}.table-card__badge--default{color:#3730a3;background:#e0e7ff}.table-card__token{color:#9ca3af;word-break:break-all;margin:0 0 .85rem;font-family:monospace;font-size:.78rem}.table-card__feedback{border-radius:8px;margin-bottom:.85rem;padding:.75rem 1rem;font-size:.9rem;font-weight:500}.table-card__feedback--error{color:#991b1b;background:#fee2e2;border-left:4px solid #ef4444}.table-card__actions,.table-card__rename,.table-card__confirm-actions{flex-wrap:wrap;gap:.4rem;display:flex}.table-card__rename{margin-top:.5rem}.table-card__input{color:#1a1a2e;background:#fff;border:1.5px solid #d1d5db;border-radius:8px;outline:none;flex:180px;min-height:44px;padding:.6rem .85rem;font-size:.95rem;transition:border-color .15s}.table-card__input:focus{border-color:#4f46e5}.table-card__btn{cursor:pointer;white-space:nowrap;border:none;border-radius:8px;justify-content:center;align-items:center;gap:.35rem;min-height:38px;padding:.45rem .75rem;font-size:.82rem;font-weight:600;line-height:1;transition:opacity .15s,transform .1s;display:inline-flex}.table-card__btn:active{transform:scale(.97)}.table-card__btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.table-card__btn--primary{color:#fff;background:#4f46e5}.table-card__btn--ghost{color:#4f46e5;background:0 0;border:1.5px solid #4f46e5}.table-card__btn--warning{color:#92400e;background:#fef3c7}.table-card__btn--danger{color:#b91c1c;background:#fee2e2}.table-card__confirm{background:#fff7ed;border:1.5px solid #fb923c;border-radius:8px;flex-direction:column;gap:.5rem;margin-top:.6rem;padding:.75rem;display:flex}.table-card__confirm-text{color:#92400e;margin:0;font-size:.88rem;font-weight:500}.table-card__modal-overlay{z-index:1000;background:#0f172a8c;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.table-card__modal{text-align:center;background:#fff;border-radius:16px;width:min(100%,380px);padding:20px 16px 16px;position:relative;box-shadow:0 20px 60px #0003}.table-card__modal-close{cursor:pointer;background:#f3f4f6;border:none;border-radius:999px;width:36px;height:36px;font-size:20px;position:absolute;top:10px;right:10px}.table-card__modal-title{margin:0 0 14px;font-size:1.1rem;font-weight:700}.table-card__modal-qr{justify-content:center;margin-bottom:12px;display:flex}.table-card__modal-text{color:#6b7280;margin:0 0 10px;font-size:.95rem}.table-card__modal-link{word-break:break-all;color:#4f46e5;font-size:.82rem;text-decoration:none;display:block}.sp-table-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem;display:grid}.sp-modal{max-width:620px}.sp-modal--wide{max-width:980px}.sp-modal__header,.sp-modal__footer{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.sp-modal__footer{margin-top:1rem}.sp-summary-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.75rem;margin-bottom:1rem;display:grid}.sp-summary-card{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:.85rem .95rem}.sp-summary-card__label,.sp-order-card__total-label{color:#6b7280;font-size:.85rem;display:block}.sp-summary-card strong,.sp-order-card__total-value{color:#111827;font-size:1.1rem}.sp-inline-orders{gap:.5rem;margin-bottom:1rem;display:grid}.sp-inline-orders__item{background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;justify-content:space-between;gap:1rem;padding:.65rem .8rem;font-size:.9rem;display:flex}.sp-order-list{gap:1rem;display:grid}.sp-order-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:1rem;box-shadow:0 8px 26px #0f172a0d}.sp-order-card__head,.sp-order-card__foot,.sp-order-item{justify-content:space-between;gap:1rem;display:flex}.sp-order-card__head,.sp-order-card__foot{align-items:center}.sp-order-card__eyebrow{text-transform:uppercase;letter-spacing:.04em;color:#6b7280;font-size:.8rem}.sp-order-card__title{color:#111827;margin:.15rem 0;font-size:1.1rem}.sp-order-card__meta,.sp-order-item__note{color:#6b7280;margin:0;font-size:.88rem}.sp-status{text-transform:uppercase;border-radius:999px;padding:.4rem .7rem;font-size:.8rem;font-weight:700}.sp-status--pending{color:#92400e;background:#fef3c7}.sp-status--confirmed{color:#1d4ed8;background:#dbeafe}.sp-status--preparing{color:#6d28d9;background:#ede9fe}.sp-status--done{color:#065f46;background:#d1fae5}.sp-status--paid{color:#374151;background:#e5e7eb}.sp-order-items{gap:.75rem;margin:1rem 0;display:grid}.sp-order-item{border-bottom:1px solid #f3f4f6;align-items:flex-start;padding-bottom:.75rem}.sp-order-item:last-child{border-bottom:none;padding-bottom:0}.sp-order-item__side{white-space:nowrap;justify-items:end;gap:.2rem;font-weight:600;display:grid}@media (width<=640px){.sp-modal__header,.sp-modal__footer,.sp-order-card__head,.sp-order-card__foot,.sp-order-item,.sp-inline-orders__item{flex-direction:column;align-items:flex-start}.sp-order-item__side{justify-items:start}}.kp-page{max-width:1100px;margin:0 auto;padding:1rem}.kp-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem;display:flex}.kp-title{color:#1a1a2e;margin:0;font-size:1.5rem}.kp-subtitle{color:#6b7280;margin:.35rem 0 0;font-size:.92rem}.kp-summary{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.75rem;margin-bottom:1rem;display:grid}.kp-summary__card{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:.9rem 1rem}.kp-summary__card span{color:#6b7280;font-size:.85rem;display:block}.kp-summary__card strong{color:#111827;font-size:1.2rem}.kp-empty{color:#6b7280;background:#fff;border:1px dashed #d1d5db;border-radius:14px;justify-content:center;align-items:center;min-height:220px;display:flex}.kp-list{gap:.85rem;display:grid}.kp-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;grid-template-columns:64px 1fr;align-items:stretch;gap:1rem;padding:1rem;display:grid;box-shadow:0 8px 26px #0f172a0d}.kp-card__queue{color:#c2410c;background:linear-gradient(135deg,#fff7ed,#ffedd5);border-radius:14px;justify-content:center;align-items:center;font-size:1.1rem;font-weight:800;display:flex}.kp-card__main{flex-direction:column;gap:.75rem;display:flex}.kp-card__top{justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.kp-card__eyebrow{text-transform:uppercase;letter-spacing:.04em;color:#6b7280;font-size:.8rem}.kp-card__title{color:#111827;margin:.15rem 0;font-size:1.15rem}.kp-card__meta{color:#6b7280;margin:0;font-size:.88rem}.kp-card__details{color:#374151;flex-wrap:wrap;gap:1rem;font-size:.92rem;display:flex}.kp-card__actions{flex-wrap:wrap;gap:.5rem;display:flex}.kp-status{text-transform:uppercase;border-radius:999px;padding:.4rem .7rem;font-size:.8rem;font-weight:700}.kp-status--confirmed{color:#1d4ed8;background:#dbeafe}.kp-status--preparing{color:#6d28d9;background:#ede9fe}@media (width<=640px){.kp-page{padding:.85rem}.kp-card{grid-template-columns:1fr}.kp-card__queue{min-height:48px}.kp-card__top{flex-direction:column;align-items:flex-start}}.aup-meta{color:#6b7280;margin:.2rem 0 0;font-size:.84rem}.aup-badge--kitchen{color:#92400e;background:#fef3c7}html,body,#root{min-height:100%}body{background:#f5f5f5;margin:0;font-family:Arial,sans-serif}
