:root{--color-primary: #2E7D32;--color-primary-light: #4CAF50;--color-primary-dark: #1B5E20;--color-bg-primary: #F8FAF9;--color-bg-secondary: #EEF2F0;--color-bg-card: #FFFFFF;--color-bg-elevated: #E4EBE7;--color-text-primary: #0D1912;--color-text-secondary: #2E4840;--color-text-muted: #5C7269;--color-accent: #2E7D32;--color-accent-hover: #1B5E20;--color-accent-glow: rgba(46, 125, 50, .12);--color-danger: #D32F2F;--color-danger-glow: rgba(211, 47, 47, .1);--color-success: #16A34A;--color-success-glow: rgba(22, 163, 74, .12);--color-info: #1976D2;--color-warning: #E67E22;--color-highlight: #F59E0B;--gradient-primary: linear-gradient(135deg, #4CAF50 0%, #2E7D32 100%);--gradient-dark: linear-gradient(180deg, #F8FAF9 0%, #EEF2F0 100%);--gradient-card: linear-gradient(145deg, #FFFFFF 0%, #F8FAF9 100%);--shadow-sm: 0 2px 8px rgba(26, 46, 38, .06);--shadow-md: 0 8px 16px rgba(26, 46, 38, .08);--shadow-lg: 0 16px 32px rgba(26, 46, 38, .12);--shadow-glow: 0 0 15px var(--color-accent-glow);--color-border: rgba(26, 46, 38, .2);--radius-sm: .5rem;--radius-md: .75rem;--radius-lg: 1rem;--radius-xl: 1.25rem;--radius-2xl: 1.5rem;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-normal: .25s cubic-bezier(.4, 0, .2, 1)}html.dark,.dark{--color-bg-primary: #121212;--color-bg-secondary: #1A1A1A;--color-bg-card: #1E1E1E;--color-bg-elevated: #2A2A2A;--color-text-primary: #F5F5F5;--color-text-secondary: #9E9E9E;--color-text-muted: #757575;--color-accent: #4CAF50;--color-accent-hover: #2E7D32;--color-accent-glow: rgba(76, 175, 80, .15);--color-danger: #EF5350;--color-danger-glow: rgba(239, 83, 80, .15);--color-success: #22C55E;--color-success-glow: rgba(34, 197, 94, .15);--color-info: #2196F3;--color-warning: #F97316;--color-highlight: #F59E0B;--gradient-primary: linear-gradient(135deg, #4CAF50 0%, #2E7D32 100%);--gradient-dark: linear-gradient(180deg, #1A1A1A 0%, #121212 100%);--gradient-card: linear-gradient(145deg, rgba(30, 30, 30, .9) 0%, rgba(26, 26, 26, .95) 100%);--shadow-sm: 0 2px 4px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .5);--shadow-glow: 0 0 25px var(--color-accent-glow);--color-border: rgba(255, 255, 255, .14)}*{box-sizing:border-box;margin:0;padding:0}html{font-size:14px}html,body{height:100%}body{font-family:Tajawal,Geist,Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;direction:inherit;background:var(--color-bg-primary);color:var(--color-text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow:hidden;-webkit-user-select:none;user-select:none;line-height:1.6}#root{height:100%}button{cursor:pointer;border:none;font-family:inherit;transition:all var(--transition-fast);outline:none}button:focus-visible{box-shadow:0 0 0 2px var(--color-accent)}input{font-family:inherit;outline:none}@media(max-width:1024px){body{overflow:hidden auto}#root{height:100dvh}.app-container{padding-bottom:64px;overflow:hidden}.main-content{overflow-y:auto;-webkit-overflow-scrolling:touch}.main-content--kds{overflow:hidden;padding:0}.reports-panel,.settings-panel,.incoming-panel,.kds-container,.table-selector{padding-bottom:1rem}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#4caf504d;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#4caf5080}.glass{background:var(--color-bg-card);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--color-border)}.dark .glass{background:#1e1e1e99;border-color:#4caf5014}.glass-dark{background:#0000001a;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--color-border)}.dark .glass-dark{background:#121212b3;border-color:#4caf500d}.gradient-text{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.animate-pulse{animation:pulse 2s ease-in-out infinite}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.animate-slide-in-right{animation:slideInRight .3s ease forwards}.animate-slide-in-up{animation:slideInUp .3s ease forwards}.animate-scale-in{animation:scaleIn .2s ease forwards}.animate-fade-in{animation:fadeIn .2s ease forwards}.badge{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .75rem;border-radius:100px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.badge-success{background:var(--color-success-glow);color:var(--color-success)}.badge-warning{background:#f59e0b26;color:var(--color-warning)}.badge-danger{background:var(--color-danger-glow);color:var(--color-danger)}.badge-info{background:#3b82f626;color:var(--color-info)}.btn-primary{background:var(--gradient-primary);color:#000;font-weight:700;padding:.875rem 1.5rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-md),var(--shadow-glow);transition:all var(--transition-fast)}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg),0 0 40px var(--color-accent-glow)}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}.btn-secondary{background:var(--color-bg-elevated);color:var(--color-text-primary);font-weight:600;padding:.75rem 1.25rem;border-radius:var(--radius-md);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-bg-card);border-color:var(--color-accent)}.btn-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:transparent;color:var(--color-text-secondary);border-radius:var(--radius-md)}.btn-icon:hover{background:var(--color-bg-elevated);color:var(--color-text-primary)}.input{width:100%;padding:.875rem 1rem;background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:1rem;transition:all var(--transition-fast)}.input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-glow)}.input::placeholder{color:var(--color-text-muted)}.card{background:var(--gradient-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.card:hover{border-color:var(--color-accent)}.card-elevated{box-shadow:var(--shadow-lg)}@media(max-height:820px){html{font-size:13px}}@media(max-height:700px){html{font-size:13px}}.sidebar{height:100%;background:var(--color-bg-secondary);display:flex;flex-direction:column;align-items:center;padding:1.25rem 0;border-left:1px solid var(--color-border);position:relative;min-height:0;overflow:hidden}.sidebar:after{content:"";position:absolute;left:0;top:0;bottom:0;width:1px;background:linear-gradient(180deg,transparent 0%,var(--color-border) 50%,transparent 100%);opacity:.3}.logo-container{margin-bottom:2rem;display:flex;justify-content:center;width:100%;flex-shrink:0}.logo-circle{width:44px;height:44px;background:var(--color-accent-glow);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;border:1px solid var(--color-border)}.nav-menu{flex:1 1 auto;display:flex;flex-direction:column;gap:.5rem;width:100%;padding:0 .5rem;min-height:0;overflow-y:auto}.nav-menu::-webkit-scrollbar{width:0;height:0}.nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:.875rem .5rem;border-radius:var(--radius-lg);color:var(--color-text-muted);background:transparent;transition:all var(--transition-normal);width:100%;position:relative;overflow:hidden}.nav-item:before{content:"";position:absolute;right:0;top:50%;transform:translateY(-50%);width:3px;height:0;background:var(--color-accent);border-radius:2px 0 0 2px;transition:height var(--transition-fast)}.nav-item:hover{background:var(--color-bg-elevated);color:var(--color-text-primary)}.nav-item.active{background:var(--color-primary);color:#fff;box-shadow:0 4px 12px var(--color-accent-glow)}.nav-item.active:before{display:none}.nav-item svg{transition:transform var(--transition-fast)}.nav-item:hover svg,.nav-item.active svg{transform:scale(1.1)}.nav-label{font-size:.65rem;margin-top:.4rem;font-weight:600;letter-spacing:.3px;text-transform:uppercase;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center}.nav-badge{position:absolute;top:6px;left:6px;min-width:18px;height:18px;background:var(--color-danger);color:#fff;font-size:.65rem;font-weight:700;border-radius:100px;display:flex;align-items:center;justify-content:center;padding:0 4px;animation:pulse 2s ease-in-out infinite}.nav-divider{height:1px;width:60%;background:var(--color-border);margin:.75rem 0}.sidebar-terminal-chip{font-size:.625rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--color-text-muted);background:var(--color-surface-raised, rgba(255,255,255,.06));border:1px solid var(--color-border, rgba(255,255,255,.08));border-radius:.375rem;padding:.25rem .375rem;text-align:center;max-width:48px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:.25rem;cursor:default;-webkit-user-select:none;user-select:none}.logout-btn{margin-top:.5rem;padding:.875rem;color:var(--color-text-muted);background:transparent;border-radius:var(--radius-lg);transition:all var(--transition-fast);flex-shrink:0}.logout-btn:hover{background:var(--color-danger-glow);color:var(--color-danger)}.sidebar-time{margin-top:auto;padding:.5rem .75rem;text-align:center;flex-shrink:0}.sidebar-time-value{font-size:1.05rem;font-weight:700;color:var(--color-text-primary);font-variant-numeric:tabular-nums}.sidebar-time-date{font-size:.78rem;color:var(--color-text-muted);margin-top:.25rem}.restaurant-switcher{width:100%;padding:0 8px 6px;flex-shrink:0;box-sizing:border-box}.restaurant-pill{width:100%;display:flex;align-items:center;gap:5px;padding:6px 8px;background:var(--color-accent-glow);border:1px solid var(--color-primary-light);border-radius:8px;color:var(--color-primary);font-size:11px;font-weight:600;cursor:default;overflow:hidden;box-sizing:border-box}.restaurant-pill--switchable{cursor:pointer}.restaurant-pill--switchable:hover{background:var(--color-primary-light);color:#fff}.restaurant-pill__icon{flex-shrink:0}.restaurant-pill__name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:left}.switcher-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9998}.switcher-dropdown{position:fixed;bottom:72px;left:12px;width:220px;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:12px;overflow:hidden;box-shadow:var(--shadow-lg);z-index:9999}.switcher-option{width:100%;display:flex;align-items:center;gap:10px;padding:12px 16px;background:transparent;border:none;border-bottom:1px solid var(--color-border);color:var(--color-text-primary);font-size:13px;cursor:pointer;text-align:left}.switcher-option:last-child{border-bottom:none}.switcher-option:hover{background:var(--color-accent-glow);color:var(--color-primary)}.lang-toggle-btn{display:flex;align-items:center;justify-content:center;gap:.35rem;padding:.5rem .75rem;margin:.5rem 0;color:var(--color-text-secondary);background:var(--color-bg-elevated);border-radius:var(--radius-md);font-size:.75rem;font-weight:700;transition:all var(--transition-fast);border:1px solid var(--color-border)}.lang-toggle-btn:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.network-status-dot{width:8px;height:8px;border-radius:50%;position:absolute;bottom:2px;right:calc(50% - 26px);border:1.5px solid var(--color-bg-secondary)}.network-status-dot.online{background:#22c55e}.network-status-dot.offline{background:#ef4444;animation:pulse 2s ease-in-out infinite}.network-status-dot.syncing{background:#eab308;animation:pulse 1s ease-in-out infinite}@media(max-width:1024px){.sidebar{height:64px;width:100%;flex-direction:row;align-items:center;padding:0 .5rem;border-left:none;border-top:1px solid var(--color-border);position:fixed;bottom:0;left:0;right:0;z-index:50}.sidebar:after{display:none}.logo-container,.sidebar-time,.lang-toggle-btn,.nav-divider,.restaurant-switcher,.staff-chip{display:none}.nav-menu{flex-direction:row;flex:1;gap:0;padding:0;height:100%}.nav-item{flex:1;flex-direction:column;padding:.375rem .25rem;border-radius:0;height:100%;min-width:0}.nav-item:before{display:none}.nav-item.active{background:transparent;color:var(--color-accent);box-shadow:none}.nav-item.active svg{color:var(--color-accent)}.nav-item:hover{background:var(--color-bg-elevated)}.nav-label{font-size:.6rem;margin-top:.25rem}.nav-badge{top:4px;left:50%;transform:translate(6px)}.logout-btn{flex-shrink:0;padding:.75rem;margin-top:0}.network-status-dot{bottom:auto;top:6px;right:calc(50% - 20px);position:absolute}}.staff-chip{display:flex;align-items:center;gap:8px;margin:0 8px 6px;padding:8px 10px;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:10px;cursor:pointer;text-align:left;width:calc(100% - 16px);box-sizing:border-box;transition:border-color .15s,background .15s}.staff-chip:hover{border-color:var(--color-primary);background:var(--color-bg-primary)}.staff-chip__icon{color:var(--color-primary);flex-shrink:0}.staff-chip__info{display:flex;flex-direction:column;gap:1px;flex:1;min-width:0}.staff-chip__name{font-size:12px;font-weight:700;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.staff-chip__role{font-size:10px;color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.staff-chip__switch-icon{color:var(--color-text-muted);flex-shrink:0}@media(min-width:1025px)and (max-height:820px){.sidebar{padding:.5rem 0}.logo-container{margin-bottom:.75rem}.nav-menu{gap:.35rem}.nav-item{padding:.6rem .5rem}.sidebar-time{padding:.35rem .5rem}.sidebar-time-date:last-child{display:none}.nav-divider{margin:.35rem 0}.logout-btn{padding:.5rem;margin-top:.25rem}}.staff-chip:hover .staff-chip__switch-icon{color:var(--color-primary)}.product-card{background:var(--color-bg-card);border-radius:var(--radius-lg);overflow:hidden;position:relative;cursor:pointer;border:1px solid var(--color-border);display:flex;flex-direction:column;height:240px;transition:all var(--transition-normal);animation:scaleIn .3s ease backwards}.product-card:hover{transform:translateY(-6px);border-color:var(--color-accent);box-shadow:var(--shadow-lg),0 0 20px var(--color-accent-glow)}.product-card:active{transform:scale(.98)}.product-image-container{height:140px;width:100%;overflow:hidden;position:relative;background:var(--color-bg-primary)}.product-image{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}.product-card:hover .product-image{transform:scale(1.1)}.product-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition-fast)}.product-card:hover .product-overlay{opacity:1}.add-icon{width:56px;height:56px;background:var(--gradient-primary);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#000;transform:scale(.8);transition:transform var(--transition-fast);box-shadow:var(--shadow-glow)}.product-card:hover .add-icon{transform:scale(1)}.product-category-badge{position:absolute;top:.75rem;left:.75rem;padding:.25rem .6rem;background:var(--color-bg-card);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:var(--radius-sm);font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-secondary);border:1px solid var(--color-border)}.dark .product-category-badge{background:#0009;color:#fffc}.product-info{padding:1rem;flex:1;display:flex;flex-direction:column;justify-content:space-between}.product-name{font-size:.95rem;font-weight:600;color:var(--color-text-primary);line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.product-footer{display:flex;justify-content:space-between;align-items:center;margin-top:auto}.product-price{font-size:1.25rem;font-weight:800;color:var(--color-accent)}.quick-add-btn{width:32px;height:32px;background:var(--color-bg-elevated);border-radius:var(--radius-sm);color:var(--color-text-secondary);display:flex;align-items:center;justify-content:center;opacity:0;transition:all var(--transition-fast)}.product-card:hover .quick-add-btn{opacity:1}.quick-add-btn:hover{background:var(--color-accent);color:#000}@media(max-width:1024px){.product-card{height:200px}.product-image-container{height:110px}.product-overlay{opacity:0;background:#00000059}.product-card:active .product-overlay{opacity:1}.quick-add-btn{opacity:1;width:36px;height:36px;background:var(--color-accent);color:#000;border-radius:var(--radius-md)}.product-card:hover{transform:none}.product-card:active{transform:scale(.97)}.product-info{padding:.625rem .75rem}.product-name{font-size:.85rem}.product-price{font-size:1.05rem}}@media(max-width:767px){.product-card{height:185px}.product-image-container{height:100px}}.customizer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:flex-end;justify-content:center;animation:ic-fade-in .2s ease}@media(min-width:640px){.customizer-overlay{align-items:center}}@keyframes ic-fade-in{0%{opacity:0}to{opacity:1}}.customizer-sheet{background:var(--color-bg-card);width:100%;max-width:520px;max-height:90vh;border-radius:1.5rem 1.5rem 0 0;display:flex;flex-direction:column;box-shadow:0 -4px 40px #0000002e;animation:ic-slide-up .28s cubic-bezier(.32,.72,0,1);overflow:hidden}@media(min-width:640px){.customizer-sheet{border-radius:1.5rem;animation:ic-pop-in .22s cubic-bezier(.32,.72,0,1)}}@keyframes ic-slide-up{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes ic-pop-in{0%{transform:scale(.95) translateY(8px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.customizer-handle{display:flex;justify-content:center;padding:.75rem 0 0;flex-shrink:0}.customizer-handle-bar{width:40px;height:4px;background:var(--color-border);border-radius:99px;opacity:.6}@media(min-width:640px){.customizer-handle{display:none}}.customizer-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding:1rem 1.25rem .9rem}.customizer-title{display:flex;flex-direction:column;gap:.2rem}.customizer-title h3{margin:0;font-size:1.2rem;font-weight:700;color:var(--color-text-primary);line-height:1.3;letter-spacing:-.01em}.customizer-base-price{font-size:.9rem;color:var(--color-text-secondary);font-weight:500}.customizer-close{flex-shrink:0;width:32px;height:32px;background:var(--color-bg-elevated);border:none;color:var(--color-text-secondary);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);margin-top:2px}.customizer-close:hover{background:var(--color-border);color:var(--color-text-primary)}.customizer-divider{height:1px;background:var(--color-border);margin:0 1.25rem;opacity:.7}.customizer-body{padding:1rem 1.25rem 1.25rem;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:1.5rem}.customizer-group{display:flex;flex-direction:column;gap:.75rem}.customizer-group-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.customizer-group-name{font-weight:700;color:var(--color-text-primary);font-size:.9rem;text-transform:uppercase;letter-spacing:.06em}.customizer-group-rule{font-size:.7rem;font-weight:600;color:var(--color-text-secondary);background:var(--color-bg-elevated);padding:.2rem .55rem;border-radius:99px;text-transform:uppercase;letter-spacing:.04em}.customizer-group-rule.is-required{color:#ef4444;background:#ef44441a}.customizer-chips{display:flex;flex-wrap:wrap;gap:.5rem}.customizer-chip{display:flex;align-items:center;gap:.45rem;padding:.6rem 1rem;background:var(--color-bg-primary);border:1.5px solid var(--color-border);border-radius:99px;cursor:pointer;font-size:.9rem;font-weight:500;color:var(--color-text-primary);transition:all var(--transition-fast);white-space:nowrap;line-height:1}.customizer-chip:hover{border-color:var(--color-accent);background:var(--color-accent-glow)}.customizer-chip.is-checked{border-color:var(--color-accent);background:var(--color-accent);color:#fff;box-shadow:0 2px 8px var(--color-accent-glow)}.customizer-chip-price{font-size:.78rem;font-weight:600;opacity:.85}.customizer-chip.is-checked .customizer-chip-price{opacity:.9}.customizer-options{display:flex;flex-direction:column;gap:.35rem}.customizer-option{display:flex;align-items:center;gap:.75rem;padding:.8rem 1rem;background:var(--color-bg-primary);border:1.5px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);font-size:.93rem;color:var(--color-text-primary);text-align:start}.customizer-option:hover,.customizer-option.is-checked{border-color:var(--color-accent);background:var(--color-accent-glow)}.customizer-marker{width:20px;height:20px;flex-shrink:0;border:2px solid var(--color-border);display:flex;align-items:center;justify-content:center;color:#fff;background:transparent;transition:all var(--transition-fast)}.customizer-marker.is-radio{border-radius:50%}.customizer-marker.is-checkbox{border-radius:5px}.customizer-option.is-checked .customizer-marker{background:var(--color-accent);border-color:var(--color-accent)}.customizer-option-name{flex:1}.customizer-option-price{font-weight:600;color:var(--color-accent);font-size:.88rem;margin-inline-start:auto}.customizer-inclusion-chips{display:flex;flex-wrap:wrap;gap:.45rem}.customizer-inclusion-chip{display:flex;align-items:center;gap:.35rem;padding:.5rem .9rem;border-radius:99px;border:1.5px solid var(--color-border);background:var(--color-bg-primary);font-size:.88rem;font-weight:500;color:var(--color-text-primary);cursor:pointer;transition:all var(--transition-fast);-webkit-user-select:none;user-select:none}.customizer-inclusion-chip.is-included{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.customizer-inclusion-chip.is-included:hover{background:var(--color-accent-hover);border-color:var(--color-accent-hover)}.customizer-inclusion-chip.is-removed{background:#ef44441f;border-color:#ef4444;color:#ef4444;font-weight:600}.customizer-inclusion-chip.is-removed:hover{background:#ef444433}.customizer-inclusion-chip-icon{font-size:.8rem;font-style:normal;font-weight:700;line-height:1}.customizer-note-wrapper{position:relative}.customizer-note{width:100%;padding:.8rem 1rem;background:var(--color-bg-primary);border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-size:.92rem;color:var(--color-text-primary);font-family:inherit;box-sizing:border-box;transition:border-color var(--transition-fast)}.customizer-note::placeholder{color:var(--color-text-secondary);opacity:.6}.customizer-note:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-glow)}.customizer-footer{display:flex;align-items:center;gap:.75rem;padding:.9rem 1.25rem calc(.9rem + env(safe-area-inset-bottom,0px));border-top:1px solid var(--color-border);background:var(--color-bg-card);flex-shrink:0}.customizer-qty{display:flex;align-items:center;background:var(--color-bg-elevated);border-radius:var(--radius-md);overflow:hidden;border:1.5px solid var(--color-border)}.customizer-qty-btn{width:40px;height:44px;border:none;background:transparent;color:var(--color-text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast);font-size:1.1rem}.customizer-qty-btn:hover:not(:disabled){background:var(--color-border)}.customizer-qty-btn:disabled{opacity:.3;cursor:not-allowed}.customizer-qty-value{min-width:36px;text-align:center;font-weight:700;font-size:1rem;color:var(--color-text-primary)}.customizer-confirm{flex:1;padding:0 1.25rem;height:48px;background:var(--color-accent);color:#fff;border:none;border-radius:var(--radius-md);font-size:.97rem;font-weight:700;cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:space-between;letter-spacing:.01em}.customizer-confirm:hover:not(:disabled){background:var(--color-accent-hover);transform:translateY(-1px);box-shadow:0 4px 16px var(--color-accent-glow)}.customizer-confirm:active:not(:disabled){transform:translateY(0)}.customizer-confirm:disabled{background:var(--color-bg-elevated);color:var(--color-text-secondary);cursor:not-allowed;box-shadow:none}.customizer-confirm-label{font-weight:700}.customizer-confirm-price{font-weight:700;opacity:.92;font-size:1rem}.cart-container{background:var(--color-bg-secondary);height:100%;display:flex;flex-direction:column;border-right:1px solid var(--color-border);position:relative}.cart-container:before{content:"";position:absolute;right:0;top:0;bottom:0;width:1px;background:linear-gradient(180deg,transparent 0%,var(--color-accent-glow) 50%,transparent 100%);opacity:.5}.cart-header{padding:1rem 1.25rem;border-bottom:1px solid var(--color-border);flex-shrink:0}.cart-header-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem}.cart-title-section{display:flex;flex-direction:column}.cart-title{font-size:1.25rem;font-weight:700;color:var(--color-text-primary)}.cart-item-count{font-size:.8rem;color:var(--color-text-muted);margin-top:.15rem}.clear-cart-btn{background:transparent;color:var(--color-text-muted);padding:.5rem;border-radius:var(--radius-sm);opacity:.6;transition:all var(--transition-fast)}.clear-cart-btn:hover{background:var(--color-danger-glow);color:var(--color-danger);opacity:1}.table-badge{display:inline-flex;align-items:center;gap:.35rem;padding:.4rem .85rem;background:linear-gradient(135deg,#f59e0b26,#d977061a);color:var(--color-accent);border-radius:100px;font-size:.85rem;font-weight:600;border:1px solid rgba(245,158,11,.2)}.no-table-hint{font-size:.8rem;color:var(--color-text-muted)}.cart-items{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.75rem}.cart-section-header{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);padding:4px 6px;border-bottom:1px solid var(--color-border);margin-top:4px}.cart-section-header:first-child{margin-top:0}.cart-item--locked{opacity:.65;background:var(--color-bg-elevated);border:1px dashed var(--color-border);cursor:default;pointer-events:none}.cart-item--locked .item-qty-locked{font-size:.85rem;font-weight:600;color:var(--color-text-muted);padding:4px 10px}.cart-item{display:flex;justify-content:space-between;align-items:center;background:var(--color-bg-card);padding:.65rem .75rem .65rem 2.25rem;border-radius:var(--radius-lg);border:1px solid var(--color-border);position:relative;animation:slideInRight .3s ease backwards}.cart-item:hover{border-color:var(--color-accent)}.cart-item-left{display:flex;align-items:center;gap:.5rem;min-width:0;flex:1}.cart-item-image{width:36px;height:36px;border-radius:var(--radius-md);object-fit:cover;flex-shrink:0}.item-info{display:flex;flex-direction:column;min-width:0}.item-name{font-weight:600;font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.item-unit-price{color:var(--color-text-muted);font-size:.7rem}.cart-item-right{display:flex;flex-direction:column;align-items:flex-start;gap:.5rem}.item-actions{display:flex;align-items:center;gap:.35rem}.qty-btn{width:28px;height:28px;border-radius:var(--radius-sm);background:var(--color-bg-primary);color:var(--color-text-secondary);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.qty-btn:hover{background:var(--color-bg-elevated);color:#fff}.qty-btn.qty-btn-plus:hover{background:var(--color-accent);color:#000}.item-qty{font-weight:700;min-width:24px;text-align:center;font-size:.9rem}.item-total{font-weight:700;color:var(--color-accent);font-size:.95rem;font-variant-numeric:tabular-nums}.cart-footer{padding:1rem;background:var(--color-bg-card);border-top:1px solid var(--color-border);flex-shrink:0}.discount-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem;background:var(--color-bg-elevated);border:1px dashed var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);font-weight:600;font-size:.85rem;margin-bottom:1rem;transition:all var(--transition-fast)}.discount-btn:hover{border-color:var(--color-accent);color:var(--color-accent);background:#f59e0b0d}.totals-section{margin-bottom:1rem}.total-row{display:flex;justify-content:space-between;margin-bottom:.5rem;color:var(--color-text-secondary);font-size:.9rem;font-weight:500;font-variant-numeric:tabular-nums}.total-row.discount-row{color:var(--color-success)}.grand-total{display:flex;justify-content:space-between;font-size:1.4rem;font-weight:800;color:var(--color-text-primary);padding-top:.5rem;border-top:2px solid var(--color-border);font-variant-numeric:tabular-nums}.checkout-btn{width:100%;background:var(--gradient-primary);color:#fff;padding:1rem 1.5rem;border-radius:var(--radius-lg);font-weight:700;font-size:1rem;display:flex;justify-content:space-between;align-items:center;box-shadow:var(--shadow-md),var(--shadow-glow);transition:all var(--transition-fast)}.checkout-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-lg),0 0 40px var(--color-accent-glow)}.checkout-btn:active:not(:disabled){transform:translateY(0)}.checkout-btn:disabled{opacity:.3;cursor:not-allowed;box-shadow:none}.checkout-label{display:inline-flex;align-items:center;gap:.5rem}.checkout-amount{background:#00000026;padding:.35rem .75rem;border-radius:var(--radius-md);font-variant-numeric:tabular-nums;font-weight:800}.empty-cart{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;padding:2rem}.empty-cart-icon{width:80px;height:80px;background:var(--color-bg-card);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:1rem;color:var(--color-text-muted);opacity:.5}.empty-cart-title{font-weight:700;font-size:1.1rem;color:var(--color-text-secondary);margin-bottom:.25rem}.empty-cart-hint{font-size:.85rem;color:var(--color-text-muted)}.item-note-display{font-size:.7rem;color:var(--color-accent);background:#f59e0b0d;padding:2px 6px;border-radius:4px;margin-top:2px;display:inline-block}.item-modifiers{font-size:.7rem;color:var(--color-text-secondary);margin-top:2px;display:block}.item-removed{font-size:.7rem;color:#ef4444;margin-top:2px;display:block;font-weight:500}.item-note-btn{position:absolute;top:4px;left:4px;background:var(--color-bg-elevated);color:var(--color-text-muted);padding:4px;border-radius:6px;border:1px solid var(--color-border);display:flex;align-items:center;justify-content:center;transition:all .15s;z-index:1}.item-note-btn:hover,.item-note-btn.has-note{background:var(--color-accent-glow);border-color:var(--color-accent);color:var(--color-accent)}.order-note-section{margin-bottom:1rem;padding:.75rem;background:#00000008;border-radius:var(--radius-md);border:1px solid var(--color-border)}.note-label{display:block;font-size:.75rem;font-weight:600;color:var(--color-text-muted);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.025em}.order-note-input{width:100%;background:transparent;border:none;resize:none;color:var(--color-text-secondary);font-size:.85rem;height:48px;outline:none}.order-note-input::placeholder{color:var(--color-text-muted)}.note-modal-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem;animation:fadeIn .2s ease}.note-modal{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.5rem;width:100%;max-width:320px;box-shadow:var(--shadow-lg);animation:scaleIn .2s ease backwards;display:flex;flex-direction:column;gap:1rem}.note-modal h3{margin:0;font-size:1.1rem;color:var(--color-text-primary)}.note-modal input{width:100%;padding:.75rem 1rem;background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:.95rem;outline:none;transition:all var(--transition-fast)}.note-modal input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-glow)}.note-modal-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:.5rem}.note-modal-cancel{padding:.5rem 1rem;background:transparent;border:1px solid var(--color-border);color:var(--color-text-secondary);border-radius:var(--radius-md);font-size:.9rem;font-weight:600}.note-modal-cancel:hover{background:var(--color-bg-elevated);color:var(--color-text-primary)}.note-modal-save{padding:.5rem 1rem;background:var(--color-accent);color:#fff;border:none;border-radius:var(--radius-md);font-size:.9rem;font-weight:600;box-shadow:0 2px 8px var(--color-accent-glow)}.note-modal-save:hover{background:var(--color-accent-hover);transform:translateY(-1px)}@media(max-height:820px){.cart-header{padding:.625rem 1rem}.cart-items{padding:.625rem;gap:.5rem}.cart-footer{padding:.75rem 1rem}.discount-btn{padding:.5rem;margin-bottom:.5rem}.checkout-btn{padding:.75rem 1rem;font-size:.9rem}.totals-section{margin-bottom:.5rem}}.split-bill-modal{max-width:440px}.split-mode-toggle{display:flex;gap:.5rem;margin-bottom:1rem;padding:.25rem;background:var(--color-bg-elevated);border-radius:.5rem;border:1px solid var(--color-border)}.split-mode-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.5rem .75rem;border:none;background:transparent;color:var(--color-text-muted);border-radius:.4rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s}.split-mode-btn:hover{color:var(--color-text)}.split-mode-btn.active{background:var(--color-bg);color:var(--color-primary);box-shadow:0 1px 2px #00000014}.split-amount-input{width:100px;padding:.35rem .5rem;border:1px solid var(--color-border);border-radius:.4rem;background:var(--color-bg);color:var(--color-text);font-size:.9rem;text-align:end;font-variant-numeric:tabular-nums}.split-amount-input:focus{outline:none;border-color:var(--color-primary)}.split-summary{display:flex;align-items:center;justify-content:space-between;background:var(--color-bg-elevated);padding:1.5rem;border-radius:1rem;margin-bottom:1.5rem;border:1px solid var(--color-border)}.summary-item{display:flex;flex-direction:column;gap:.25rem}.summary-item .label{font-size:.75rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.summary-item .value{font-size:1.25rem;font-weight:700;color:var(--color-text-primary)}.summary-item.highlight .value{color:var(--color-accent);font-size:1.5rem}.summary-divider{color:var(--color-text-muted);opacity:.3}.split-counter{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding:0 .5rem}.split-counter label{font-weight:600;color:var(--color-text-secondary)}.counter-controls{display:flex;align-items:center;gap:1.5rem;background:var(--color-bg-primary);padding:.5rem 1rem;border-radius:100px;border:1px solid var(--color-border)}.counter-controls button{background:transparent;color:var(--color-text-primary);font-size:1.5rem;font-weight:300;width:24px;height:24px;display:flex;align-items:center;justify-content:center;transition:color .2s}.counter-controls button:hover{color:var(--color-accent)}.counter-controls span{font-size:1.25rem;font-weight:700;min-width:20px;text-align:center;color:var(--color-text-primary)}.splits-list{max-height:240px;overflow-y:auto;margin-bottom:1.5rem;display:flex;flex-direction:column;gap:.5rem;padding-right:.5rem}.split-item{display:flex;align-items:center;justify-content:space-between;padding:.875rem 1.25rem;background:var(--color-bg-card);border-radius:.75rem;border:1px solid var(--color-border)}.split-index{font-size:.875rem;color:var(--color-text-muted);flex:1}.split-value{font-weight:600;margin-right:1.5rem;color:var(--color-text-primary)}.split-method{padding:.35rem .75rem;border-radius:6px;font-size:.7rem;font-weight:700;min-width:64px;transition:all .2s}.split-method.card{background:#6366f126;color:#6366f1;border:1px solid rgba(99,102,241,.3)}.split-method.cash{background:var(--color-success-glow);color:var(--color-success);border:1px solid var(--color-success)}.confirm-split-btn{width:100%;background:var(--gradient-primary);color:#fff;padding:1rem;border-radius:var(--radius-lg);font-weight:700;display:flex;align-items:center;justify-content:center;gap:.75rem;margin-top:auto;box-shadow:var(--shadow-glow)}.confirm-split-btn:hover{transform:translateY(-2px);box-shadow:0 0 30px var(--color-accent-glow)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.dark .modal-overlay{background:#000000d9}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--color-bg-card);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-radius:var(--radius-xl);padding:1.5rem;width:90%;max-width:480px;max-height:90vh;overflow-y:auto;animation:slideUp .4s cubic-bezier(.16,1,.3,1);border:1px solid var(--color-border);box-shadow:var(--shadow-lg)}.dark .modal-content{background:#1a1a1ad9}@keyframes slideUp{0%{opacity:0;transform:translateY(30px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}.modal-title{font-size:1.75rem;font-weight:800;color:var(--color-text-primary)}.close-btn{background:var(--color-bg-elevated);color:var(--color-text-secondary);width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.close-btn:hover{background:var(--color-danger-glow);color:var(--color-danger);transform:rotate(90deg)}.payment-amount{text-align:center;padding:1.25rem;background:#00000008;border-radius:var(--radius-lg);margin-bottom:1.25rem;border:1px solid var(--color-border)}.amount-label{color:var(--color-text-secondary);font-size:.9rem;font-weight:500;margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.05em}.amount-value{font-size:2.25rem;font-weight:800;color:var(--color-text-primary);letter-spacing:-1px}.payment-methods{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.25rem}.payment-method-btn{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.75rem;background:var(--color-bg-card);border-radius:var(--radius-lg);color:var(--color-text-secondary);border:2px solid transparent;transition:all .3s cubic-bezier(.4,0,.2,1)}.payment-method-btn:hover{background:var(--color-bg-elevated);border-color:var(--color-accent);color:var(--color-text-primary);transform:translateY(-2px)}.payment-method-btn.selected{border-color:var(--color-accent);background:var(--color-accent-glow);color:var(--color-accent);box-shadow:0 8px 24px #4caf501a}.payment-method-btn span{font-weight:700;font-size:1rem}.cash-input-section{margin-bottom:1.25rem}.cash-label{display:block;color:var(--color-text-secondary);margin-bottom:.75rem;font-size:.9rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em}.cash-input{width:100%;padding:1.25rem;background:#0000000d;border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text-primary);font-size:1.5rem;font-weight:700;text-align:center;transition:all .2s}.cash-input:focus{outline:none;border-color:var(--color-accent)}.change-display{display:flex;justify-content:space-between;padding:1rem;background:var(--color-success);border-radius:var(--radius-md);margin-bottom:1.5rem;color:#fff;font-weight:600}.change-display.error{background:var(--color-danger)}.quick-cash-btns{display:flex;gap:.5rem;margin-top:.75rem;flex-wrap:wrap}.quick-cash-btn{padding:.5rem 1rem;background:var(--color-bg-primary);border-radius:var(--radius-sm);color:var(--color-text-secondary);font-size:.9rem}.quick-cash-btn:hover{background:var(--color-accent);color:#fff}.confirm-payment-btn{width:100%;padding:1rem;background:var(--color-accent);color:#fff;font-size:1.1rem;font-weight:700;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;gap:.5rem}.confirm-payment-btn:hover{background:var(--color-accent-hover)}.confirm-payment-btn:disabled{opacity:.5;cursor:not-allowed}.payment-modal-footer{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--color-border)}.split-btn{width:100%;background:var(--color-bg-secondary);color:var(--color-text-secondary);padding:.75rem;border-radius:var(--radius-md);font-weight:600;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all .2s;border:1px solid var(--color-border)}.split-btn:hover{background:var(--color-bg-elevated);border-color:var(--color-text-muted);color:var(--color-text-primary)}.table-selector{padding:1.5rem}.section-title{font-size:1.25rem;font-weight:700;margin-bottom:1.5rem;display:flex;align-items:center;gap:.5rem}.tables-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:1rem}.table-btn{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;background:var(--color-bg-card);border-radius:var(--radius-lg);color:var(--color-text-secondary);border:2px solid transparent;transition:all .2s ease;position:relative}.table-btn:hover{border-color:var(--color-accent);transform:scale(1.05)}.table-btn.selected{border-color:var(--color-accent);background:var(--color-accent-glow);color:var(--color-accent)}.table-btn.occupied{background:#ef44441a;border-color:var(--color-danger);color:var(--color-danger)}.table-number{font-size:1.5rem;font-weight:800}.table-status{font-size:.7rem;text-transform:uppercase;letter-spacing:.5px}.table-order-badge{position:absolute;top:-8px;right:-8px;background:var(--color-danger);color:#fff;font-size:.7rem;font-weight:700;padding:.25rem .5rem;border-radius:100px}.table-btn.transfer-source{border:2px solid var(--color-accent);box-shadow:0 0 0 4px var(--color-accent-glow);color:var(--color-accent)}.table-btn.transfer-target{border-color:var(--color-accent);animation:transferPulse 1.4s ease-in-out infinite}.table-btn.transfer-target:hover{background:var(--color-accent-glow);transform:scale(1.05)}.table-btn.dimmed{opacity:.35;pointer-events:none}@keyframes transferPulse{0%,to{box-shadow:0 0 0 0 var(--color-accent-glow)}50%{box-shadow:0 0 0 8px transparent}}.transfer-banner{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1rem;margin-bottom:1.25rem;background:var(--color-accent-glow);border:1px solid var(--color-accent);border-radius:var(--radius-md);color:var(--color-accent);font-weight:600;font-size:.9rem}.incoming-panel{padding:1.5rem;height:100%;overflow-y:auto}.incoming-header{margin-bottom:1.5rem}.incoming-title-row{display:flex;align-items:center;gap:.5rem;color:var(--color-text-primary)}.incoming-title{font-size:1.25rem;font-weight:700;color:var(--color-text-primary)}.incoming-count{background:var(--color-primary);color:#fff;font-size:.75rem;font-weight:700;min-width:22px;height:22px;border-radius:100px;display:flex;align-items:center;justify-content:center;padding:0 6px}.incoming-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:60%;color:var(--color-text-muted);gap:1rem;opacity:.5}.incoming-empty p{font-size:.95rem}.incoming-list{display:flex;flex-direction:column;gap:1rem}.incoming-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1rem;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.incoming-card-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.incoming-card-id{display:flex;align-items:center;gap:.25rem;font-weight:700;font-size:.85rem;color:var(--color-text-primary);font-variant-numeric:tabular-nums}.incoming-source-badge{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .6rem;border-radius:var(--radius-sm);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.3px}.incoming-source-badge.website{background:#3b82f626;color:#60a5fa}.incoming-source-badge.delivery{background:#f59e0b26;color:#fbbf24}.incoming-card-time{display:flex;align-items:center;gap:.25rem;font-size:.75rem;color:var(--color-text-muted);margin-inline-start:auto}.incoming-info{display:flex;align-items:center;gap:.4rem;font-size:.8rem;color:var(--color-text-secondary);margin-bottom:.35rem}.incoming-delivery-info{margin-bottom:.5rem;padding:.5rem;background:var(--color-bg-elevated);border-radius:var(--radius-sm)}.incoming-delivery-info .incoming-info:last-child{margin-bottom:0}.incoming-items{border-top:1px solid var(--color-border);padding-top:.5rem;margin-bottom:.5rem}.incoming-item{display:flex;align-items:center;gap:.5rem;padding:.3rem 0;font-size:.85rem}.incoming-item-qty{font-weight:700;color:var(--color-primary);min-width:28px}.incoming-item-detail{flex:1;display:flex;flex-direction:column;gap:1px}.incoming-item-name{color:var(--color-text-primary)}.incoming-item-mods{font-size:.72rem;color:var(--color-text-secondary)}.incoming-item-removal{font-size:.72rem;color:#ef4444;font-weight:600}.incoming-item-price{color:var(--color-text-muted);font-variant-numeric:tabular-nums}.incoming-note{font-size:.8rem;color:var(--color-text-muted);font-style:italic;padding:.4rem .6rem;background:var(--color-bg-elevated);border-radius:var(--radius-sm);margin-bottom:.5rem}.incoming-card-footer{display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--color-border);padding-top:.75rem}.incoming-total{font-size:1.1rem;font-weight:800;color:var(--color-text-primary)}.incoming-actions{display:flex;gap:.5rem}.incoming-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.5rem 1rem;border-radius:var(--radius-md);font-size:.8rem;font-weight:700;transition:all var(--transition-fast);cursor:pointer}.incoming-btn.accept{background:var(--color-success);color:#fff}.incoming-btn.accept:hover{filter:brightness(1.1);transform:translateY(-1px)}.incoming-btn.reject{background:transparent;color:var(--color-danger);border:1px solid var(--color-danger)}.incoming-btn.reject:hover{background:var(--color-danger);color:#fff}.waste-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.waste-modal{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:16px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column;isolation:isolate}.waste-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--color-border);flex-shrink:0}.waste-modal-title{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:600;color:#f87171}.waste-modal-close{background:none;border:none;color:var(--color-text-secondary);cursor:pointer;padding:6px;border-radius:6px;display:flex;align-items:center;transition:color .15s;flex-shrink:0}.waste-modal-close:hover{color:var(--color-text-primary)}.waste-modal-body{display:flex;flex-direction:column;gap:16px;padding:20px;overflow-y:auto}.waste-field{display:flex;flex-direction:column;gap:6px}.waste-field label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted)}.waste-select,.waste-input,.waste-textarea{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:8px;color:var(--color-text-primary);font-size:14px;padding:10px 12px;width:100%;outline:none;transition:border-color .15s;box-sizing:border-box}.waste-select:focus,.waste-input:focus,.waste-textarea:focus{border-color:#f87171}.waste-select option{background:var(--color-bg-card);color:var(--color-text-primary)}.waste-quantity-row{display:flex;align-items:center;gap:8px}.waste-quantity-row .waste-input{flex:1}.waste-unit{font-size:13px;color:var(--color-text-muted);min-width:36px}.waste-reasons{display:flex;flex-wrap:wrap;gap:8px}.waste-reason-btn{padding:8px 14px;border-radius:20px;border:1px solid var(--color-border);background:transparent;color:var(--color-text-secondary);font-size:13px;cursor:pointer;transition:all .15s;touch-action:manipulation}.waste-reason-btn:hover{border-color:#f87171;color:#f87171}.waste-reason-btn.selected{background:#f8717126;border-color:#f87171;color:#f87171;font-weight:600}.waste-textarea{resize:none;font-family:inherit}.waste-cost-preview{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#f8717114;border:1px solid rgba(248,113,113,.25);border-radius:10px}.waste-cost-preview span:first-child{font-size:13px;color:var(--color-text-secondary)}.waste-cost-value{font-size:20px;font-weight:700;color:#f87171}.waste-modal-footer{display:flex;gap:10px;justify-content:flex-end;padding-top:4px}.waste-btn-cancel{padding:10px 20px;border-radius:8px;border:1px solid var(--color-border);background:transparent;color:var(--color-text-secondary);font-size:14px;cursor:pointer;transition:all .15s;touch-action:manipulation}.waste-btn-cancel:hover:not(:disabled){border-color:var(--color-text-secondary);color:var(--color-text-primary)}.waste-btn-submit{display:flex;align-items:center;gap:6px;padding:10px 20px;border-radius:8px;border:none;background:#f87171;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s;touch-action:manipulation}.waste-btn-submit:hover:not(:disabled){background:#ef4444}.waste-btn-submit:disabled,.waste-btn-cancel:disabled{opacity:.5;cursor:not-allowed}.waste-loading{display:flex;justify-content:center;padding:16px 0}.waste-empty{font-size:13px;color:var(--color-text-muted);padding:8px 0}.waste-spinner{animation:waste-spin .8s linear infinite}@keyframes waste-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:768px){.waste-modal-overlay{padding:12px;align-items:flex-end}.waste-modal{max-width:100%;max-height:85vh;border-radius:20px 20px 0 0}.waste-modal-header{padding:14px 16px}.waste-modal-body{padding:16px;gap:14px}.waste-reason-btn{padding:10px 14px;font-size:13px}}@media(max-width:480px){.waste-modal-overlay{padding:0;align-items:flex-end}.waste-modal{max-height:92vh;border-radius:20px 20px 0 0}.waste-modal-header{padding:14px 16px}.waste-modal-title{font-size:15px}.waste-modal-body{padding:14px 16px;gap:12px}.waste-select,.waste-input,.waste-textarea{font-size:16px;padding:12px}.waste-reasons{gap:6px}.waste-reason-btn{padding:10px 12px;font-size:13px;flex:1 1 calc(50% - 6px);text-align:center;border-radius:10px}.waste-cost-preview{padding:10px 14px}.waste-cost-value{font-size:18px}.waste-modal-footer{flex-direction:column-reverse;gap:8px}.waste-btn-cancel,.waste-btn-submit{width:100%;justify-content:center;padding:13px;font-size:15px}}.kds-container{height:100%;width:100%;display:flex;flex-direction:column;overflow:hidden;padding:1.5rem;flex:1;min-height:0}.kds-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem;flex-shrink:0}.kds-header-left{display:flex;align-items:center;gap:.75rem}.kds-header-left h1{font-size:1.5rem;font-weight:800;color:var(--color-text-primary);letter-spacing:-.5px}.kds-live-badge{display:inline-flex;align-items:center;gap:6px;padding:.35rem .75rem;border-radius:100px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;background:var(--color-bg-elevated);color:var(--color-text-secondary);border:1px solid var(--color-border)}.kds-live-dot{width:7px;height:7px;background:var(--color-primary);border-radius:50%;animation:pulse 2s ease-in-out infinite}.kds-header-stats{display:flex;gap:.75rem}.kds-stat-pill{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--color-bg-card);border-radius:var(--radius-md);border:1px solid var(--color-border);font-size:.85rem;color:var(--color-text-secondary)}.kds-stat-pill .pill-val{font-weight:800;font-size:1.1rem;font-variant-numeric:tabular-nums;color:var(--color-text-primary)}.kds-header-actions{display:flex;gap:.5rem}.kds-waste-btn{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:#f871711a;border:1px solid rgba(248,113,113,.3);color:#f87171;border-radius:var(--radius-md);font-size:.85rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.kds-waste-btn:hover{background:#f8717133;border-color:#f87171}.kds-fullscreen-btn{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:var(--color-bg-elevated);border:1px solid var(--color-border);color:var(--color-text-secondary);border-radius:var(--radius-md);font-size:.85rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.kds-fullscreen-btn:hover{background:var(--color-bg-card);border-color:var(--color-accent);color:var(--color-text-primary)}.kds-board{flex:1;display:grid;grid-template-columns:1fr 1.4fr .8fr;gap:1rem;overflow:hidden;min-height:0}.kds-lane{display:flex;flex-direction:column;overflow:hidden;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);min-height:0;min-width:0}.lane-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;flex-shrink:0;border-bottom:1px solid var(--color-border)}.lane-header-left{display:flex;align-items:center;gap:.5rem}.lane-header h2{margin:0;font-size:.9rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-primary)}.lane-count{font-size:.75rem;font-weight:700;padding:2px 10px;border-radius:100px;min-width:24px;text-align:center}.kds-lane.lane-new .lane-header{background:transparent;border-bottom:1px solid var(--color-border)}.kds-lane.lane-new .lane-header svg{color:var(--color-text-secondary)}.kds-lane.lane-new .lane-count{background:var(--color-bg-elevated);color:var(--color-text-primary);border:1px solid var(--color-border)}.kds-lane.lane-preparing .lane-header{background:transparent;border-bottom:1px solid var(--color-border)}.kds-lane.lane-preparing .lane-header svg{color:var(--color-text-secondary)}.kds-lane.lane-preparing .lane-count{background:var(--color-bg-elevated);color:var(--color-text-primary);border:1px solid var(--color-border)}.kds-lane.lane-ready .lane-header{background:transparent;border-bottom:1px solid var(--color-border)}.kds-lane.lane-ready .lane-header svg{color:var(--color-text-secondary)}.kds-lane.lane-ready .lane-count{background:var(--color-bg-elevated);color:var(--color-text-primary);border:1px solid var(--color-border)}.kds-lane.lane-delivery .lane-header{background:transparent;border-bottom:1px solid var(--color-border)}.kds-lane.lane-delivery .lane-header svg{color:var(--color-text-secondary)}.kds-lane.lane-delivery .lane-count{background:var(--color-bg-elevated);color:var(--color-text-primary);border:1px solid var(--color-border)}.lane-body{flex:1;overflow-y:auto;overflow-x:hidden;padding:.75rem;display:flex;flex-direction:column;gap:.625rem;min-height:0}.kds-ticket{background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;transition:all var(--transition-fast);animation:slideInUp .3s ease backwards;flex-shrink:0}.kds-ticket:hover{border-color:var(--color-accent);box-shadow:var(--shadow-md);transform:translateY(-2px)}.ticket-urgency-bar{height:3px;width:100%;background:var(--color-bg-elevated);overflow:hidden}.ticket-urgency-fill{height:100%;transition:width 1s linear,background-color 1s}.urgency-ok .ticket-urgency-fill{background:transparent}.urgency-warn .ticket-urgency-fill{background:var(--color-text-muted);opacity:.5}.urgency-critical .ticket-urgency-fill,.urgency-rush .ticket-urgency-fill{background:var(--color-text-muted)}.ticket-head{display:flex;align-items:center;justify-content:space-between;padding:.6rem .85rem}.ticket-id{display:flex;align-items:baseline;gap:.5rem}.ticket-number{font-size:1.25rem;font-weight:800;color:var(--color-text-primary);font-variant-numeric:tabular-nums}.ticket-table{font-size:.75rem;font-weight:700;color:var(--color-text-primary);background:var(--color-bg-elevated);padding:2px 8px;border-radius:var(--radius-sm);border:1px solid var(--color-border)}.ticket-meta{display:flex;align-items:center;gap:.6rem}.ticket-timer{font-size:.95rem;font-weight:700;display:flex;align-items:center;gap:4px;color:var(--color-text-muted);font-variant-numeric:tabular-nums}.urgency-warn .ticket-timer,.urgency-critical .ticket-timer,.urgency-rush .ticket-timer{color:var(--color-text-primary)}.ticket-rush-tag{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:.35rem .75rem;border-radius:100px;background:var(--color-bg-elevated);color:var(--color-text-primary);border:1px solid var(--color-border)}.ticket-items{padding:0 .85rem .5rem}.ticket-item{display:flex;align-items:flex-start;gap:.5rem;padding:.4rem 0;border-bottom:1px solid var(--color-border)}.ticket-item:last-child{border-bottom:none}.item-qty{font-size:1.05rem;font-weight:800;color:var(--color-text-primary);min-width:30px;flex-shrink:0}.item-info{flex:1;min-width:0}.item-name{font-size:.9rem;font-weight:600;color:var(--color-text-primary);line-height:1.3}.item-note{display:inline-block;font-size:.75rem;font-weight:600;color:var(--color-text-secondary);background:var(--color-bg-elevated);border:1px solid var(--color-border);padding:2px 8px;border-radius:var(--radius-sm);margin-top:3px}.item-mod-tags{display:block;font-size:.72rem;color:var(--color-text-secondary);margin-top:2px}.item-removal-tag{display:block;font-size:.8rem;font-weight:700;color:#ef4444;margin-top:2px;letter-spacing:.01em}.ticket-order-note{margin:0 .85rem .5rem;padding:.5rem .65rem;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.8rem;font-weight:700;color:var(--color-text-secondary);display:flex;align-items:center;gap:6px}.ticket-bump{display:flex;border-top:1px solid var(--color-border)}.bump-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:.65rem;border:none;font-size:.85rem;font-weight:700;cursor:pointer;transition:all var(--transition-fast);background:var(--color-bg-elevated);color:var(--color-text-primary);border-top:1px solid var(--color-border)}.bump-btn.bump-start,.bump-btn.bump-done,.bump-btn.bump-serve{background:var(--color-bg-elevated);color:var(--color-text-secondary)}.bump-btn:hover{background:var(--color-primary);color:#fff}.bump-btn.bump-cancel{color:#ef4444}.bump-btn.bump-cancel:hover{background:#ef4444;color:#fff}.kds-ticket.ticket-ready{border-color:var(--color-primary)}.kds-ticket.ticket-ready .ticket-number{color:var(--color-primary)}.kds-ticket.ticket-active{border-color:var(--color-text-muted)}.lane-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;color:var(--color-text-muted);padding:2rem}.lane-empty svg{opacity:.3}.lane-empty p{font-size:.85rem;font-weight:600;margin:0}.kds-summary-drawer{border-top:1px solid var(--color-border);padding:.75rem;background:var(--color-bg-elevated);max-height:35%;overflow-y:auto}.summary-title{display:flex;align-items:center;gap:6px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);margin-bottom:.5rem}.summary-row{display:flex;align-items:center;padding:.35rem .5rem;border-radius:var(--radius-sm)}.summary-row:nth-child(2n){background:var(--color-bg-card)}.summary-row-qty{font-size:.9rem;font-weight:800;color:var(--color-text-primary);min-width:32px}.summary-row-name{flex:1;font-size:.85rem;font-weight:600;color:var(--color-text-secondary)}.kds-lane-tabs{display:none}@media(max-width:1100px){.kds-container{padding:1rem}.kds-board{grid-template-columns:1fr 1fr}.kds-board{grid-template-columns:repeat(3,1fr);gap:.625rem}.kds-header-stats{display:none}.bump-btn{min-height:48px;font-size:.9rem}}@media(max-width:768px){.kds-header-left h1{font-size:1.1rem}.kds-live-badge,.kds-fullscreen-btn span{display:none}.kds-fullscreen-btn{padding:.5rem .625rem}.lane-header h2{font-size:.75rem}.ticket-number{font-size:1rem}}@media(max-width:600px){.kds-container{padding:.75rem}.kds-header{margin-bottom:.625rem}.kds-lane-tabs{display:flex;gap:.375rem;margin-bottom:.75rem;flex-shrink:0;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.25rem}.kds-lane-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:.35rem;padding:.6rem .25rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:700;color:var(--color-text-secondary);background:transparent;border:none;cursor:pointer;position:relative;transition:all var(--transition-fast)}.kds-lane-tab.active{background:var(--color-primary);color:#fff}.kds-lane-tab-badge{position:absolute;top:2px;right:2px;min-width:16px;height:16px;background:var(--color-danger);color:#fff;font-size:.6rem;font-weight:800;border-radius:100px;display:flex;align-items:center;justify-content:center;padding:0 3px}.kds-board{grid-template-columns:1fr}.kds-lane{display:none}.kds-lane.lane-active{display:flex}.bump-btn{min-height:52px;font-size:.95rem}}.receipt-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease;padding:2rem}.dark .receipt-modal-overlay{background:#000000d9}.receipt-modal{background:var(--color-bg-secondary);border-radius:var(--radius-xl);width:100%;max-width:420px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;animation:scaleIn .3s ease}.receipt-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--color-border)}.receipt-modal-title{font-size:1.25rem;font-weight:700}.receipt-modal-close{background:transparent;color:var(--color-text-secondary);padding:.5rem;border-radius:var(--radius-sm)}.receipt-modal-close:hover{background:var(--color-bg-elevated);color:var(--color-text-primary)}.receipt-container{flex:1;overflow-y:auto;padding:1.5rem}.receipt-paper-canvas-wrapper{background:#fff;padding:0;border-radius:4px;box-shadow:0 4px 20px #00000026;max-width:384px;margin:0 auto;overflow:hidden}.receipt-canvas-preview{width:100%;height:auto;image-rendering:pixelated}.receipt-footer{text-align:center;font-size:.75rem;color:#666;margin-top:1rem}.receipt-barcode{text-align:center;margin:1rem 0}.barcode-placeholder{display:inline-block;background:repeating-linear-gradient(90deg,#000,#000 2px,#fff 2px,#fff 4px);height:40px;width:150px}.receipt-modal-actions{display:flex;gap:1rem;padding:1.25rem 1.5rem;border-top:1px solid var(--color-border)}.receipt-btn{flex:1;padding:.875rem;border-radius:var(--radius-lg);font-weight:600;display:flex;align-items:center;justify-content:center;gap:.5rem}.receipt-btn-print{background:var(--gradient-primary);color:#000}.receipt-btn-print:hover{transform:translateY(-2px);box-shadow:var(--shadow-glow)}.receipt-btn-email{background:var(--color-bg-card);color:var(--color-text-primary);border:1px solid var(--color-border)}.receipt-btn-email:hover{border-color:var(--color-accent)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-pulse{animation:pulse 1.5s cubic-bezier(.4,0,.6,1) infinite}.receipt-btn-print.loading{opacity:.8;background:var(--color-bg-elevated);color:var(--color-text-secondary);cursor:wait}.receipt-print-error{color:var(--color-danger);font-size:.8rem;margin-top:.5rem;text-align:center}.discount-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.dark .discount-modal-overlay{background:#000000d9}.discount-modal{background:var(--color-bg-card);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-radius:var(--radius-xl);width:100%;max-width:400px;animation:scaleIn .3s cubic-bezier(.16,1,.3,1);border:1px solid var(--color-border);box-shadow:var(--shadow-lg)}.dark .discount-modal{background:#1a1a1acc}.discount-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 1.75rem;border-bottom:1px solid var(--color-border)}.discount-modal-title{font-size:1.5rem;font-weight:800;color:var(--color-text-primary)}.discount-modal-close{background:var(--color-bg-elevated);color:var(--color-text-secondary);width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.discount-modal-close:hover{background:var(--color-danger-glow);color:var(--color-danger)}.discount-modal-body{padding:2rem}.discount-type-toggle{display:flex;background:var(--color-bg-secondary);border-radius:var(--radius-lg);padding:.4rem;margin-bottom:2rem;border:1px solid var(--color-border)}.discount-type-btn{flex:1;padding:.875rem;background:transparent;color:var(--color-text-secondary);border-radius:var(--radius-md);font-weight:700;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all .2s}.discount-type-btn.active{background:var(--color-primary);color:#fff;box-shadow:0 4px 12px var(--color-accent-glow)}.discount-input-group{margin-bottom:2rem}.discount-input-label{display:block;color:var(--color-text-secondary);font-size:.9rem;font-weight:600;margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.05em}.discount-input-wrapper{position:relative}.discount-input{width:100%;padding:1.25rem 3.5rem 1.25rem 1.25rem;background:#0000000d;border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text-primary);font-size:2rem;font-weight:800;text-align:center;transition:all .2s}.discount-input:focus{background:#0000004d;border-color:var(--color-accent);box-shadow:0 0 0 4px var(--color-accent-glow)}.discount-input-symbol{position:absolute;right:1.25rem;top:50%;transform:translateY(-50%);color:var(--color-accent);font-size:1.5rem;font-weight:800}.quick-discount-btns{display:flex;gap:.625rem;flex-wrap:wrap;margin-bottom:2rem}.quick-discount-btn{padding:.625rem 1.125rem;background:var(--color-bg-card);border-radius:var(--radius-md);color:var(--color-text-secondary);font-weight:700;border:1px solid var(--color-border);transition:all .2s}.quick-discount-btn:hover{background:var(--color-bg-elevated);border-color:var(--color-accent);color:var(--color-accent);transform:translateY(-2px)}.discount-preview{background:#00000008;border-radius:var(--radius-lg);padding:1.25rem;margin-bottom:2rem;border:1px solid var(--color-border)}.discount-preview-row{display:flex;justify-content:space-between;margin-bottom:.625rem;color:var(--color-text-secondary);font-weight:500}.discount-preview-row.total{color:var(--color-text-primary);font-weight:800;font-size:1.25rem;margin-top:1rem;padding-top:1rem;border-top:1px dashed var(--color-border)}.discount-preview-row.savings{color:var(--color-success);font-weight:700}.discount-apply-btn{width:100%;padding:1.125rem;background:var(--gradient-primary);color:#000;border-radius:var(--radius-lg);font-weight:800;font-size:1.1rem;display:flex;align-items:center;justify-content:center;gap:.75rem;box-shadow:var(--shadow-md),var(--shadow-glow);transition:all .2s cubic-bezier(.4,0,.2,1)}.discount-apply-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-lg),0 0 30px var(--color-accent-glow)}.discount-apply-btn:disabled{opacity:.3;cursor:not-allowed;transform:none;box-shadow:none}.sp-loading{display:flex;justify-content:center;padding:32px;color:var(--color-text-muted)}.sp-error{display:flex;flex-direction:column;align-items:center;gap:12px;padding:24px;color:var(--color-danger);font-size:13px}.sp-spin{animation:sp-spin .8s linear infinite}@keyframes sp-spin{to{transform:rotate(360deg)}}.sp-root{display:flex;flex-direction:column;gap:14px}.sp-banner{display:flex;align-items:center;gap:7px;padding:9px 12px;background:#f0f6ff;border:1px solid #c7deff;border-radius:8px;font-size:12px;color:#2563eb;line-height:1.4}.sp-banner strong{font-weight:600}.sp-header{display:flex;align-items:center;justify-content:space-between}.sp-count{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--color-text-muted)}.sp-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;border:none;transition:background .15s}.sp-btn--primary{background:var(--color-primary);color:#fff}.sp-btn--primary:hover:not(:disabled){background:var(--color-primary-dark)}.sp-btn--primary:disabled{opacity:.45;cursor:not-allowed}.sp-btn--secondary{background:var(--color-bg-elevated);border:1px solid var(--color-border);color:var(--color-text-primary)}.sp-btn--secondary:hover{border-color:var(--color-primary);color:var(--color-primary)}.sp-btn--sm{padding:5px 12px;font-size:12px}.sp-form{display:flex;flex-direction:column;gap:10px;padding:16px;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:12px}.sp-form-title{margin:0 0 2px;font-size:13px;font-weight:700;color:var(--color-text-primary)}.sp-form-row{display:flex;gap:10px;flex-wrap:wrap}.sp-field{display:flex;flex-direction:column;gap:5px;min-width:0}.sp-field--grow{flex:1;min-width:140px}.sp-field label{font-size:12px;font-weight:600;color:var(--color-text-secondary)}.sp-required{color:var(--color-danger)}.sp-optional{font-weight:400;color:var(--color-text-muted)}.sp-input{width:100%;padding:9px 12px;background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:8px;color:var(--color-text-primary);font-size:14px;box-sizing:border-box;transition:border-color .15s}.sp-input:focus{outline:none;border-color:var(--color-primary)}.sp-input--pin{letter-spacing:.3em;text-align:center}.sp-input--sm{padding:6px 10px;font-size:13px;width:auto;flex:1;min-width:80px}.sp-form-error{margin:0;font-size:12px;color:var(--color-danger);padding:6px 10px;background:var(--color-danger-glow);border-radius:6px}.sp-form-actions{display:flex;gap:8px;justify-content:flex-end;padding-top:4px;border-top:1px solid var(--color-border);margin-top:2px}.sp-empty{display:flex;flex-direction:column;align-items:center;gap:10px;padding:32px 16px;color:var(--color-text-muted);text-align:center}.sp-empty p{margin:0;font-size:13px;line-height:1.6}.sp-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.sp-item{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:12px;padding:12px 14px;display:flex;flex-direction:column;gap:10px;transition:opacity .2s}.sp-item--inactive{opacity:.5}.sp-item-main{display:flex;align-items:center;gap:12px}.sp-avatar{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0}.role--waiter{background:#edf0f4;color:#4a5568;border:1.5px solid #d2d8e2}.role--cashier{background:#edf3f0;color:#3a5247;border:1.5px solid #c8d9d3}.role--kitchen{background:#f4f0ec;color:#5c4a38;border:1.5px solid #ddd3c8}.role--manager{background:#efecf4;color:#443a5c;border:1.5px solid #d0c8de}.sp-item-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.sp-item-name{font-size:14px;font-weight:600;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sp-item-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.sp-item-email{font-size:11px;color:var(--color-text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:160px}.sp-badge{font-size:10px;font-weight:700;padding:2px 7px;border-radius:20px;text-transform:uppercase;letter-spacing:.05em;border:1px solid transparent}.sp-badge.role--waiter{color:#4a5568;border-color:#d2d8e2;background:#edf0f4}.sp-badge.role--cashier{color:#3a5247;border-color:#c8d9d3;background:#edf3f0}.sp-badge.role--kitchen{color:#5c4a38;border-color:#ddd3c8;background:#f4f0ec}.sp-badge.role--manager{color:#443a5c;border-color:#d0c8de;background:#efecf4}.sp-badge--inactive{color:var(--color-text-muted);border-color:var(--color-border);background:var(--color-bg-primary)}.sp-item-actions{display:flex;gap:6px;flex-shrink:0}.sp-icon-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:8px;color:var(--color-text-secondary);cursor:pointer;transition:border-color .15s,color .15s}.sp-icon-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.sp-icon-btn--danger:hover{border-color:var(--color-danger);color:var(--color-danger)}.sp-icon-btn--success:hover{border-color:var(--color-primary);color:var(--color-primary)}.sp-item-details{display:flex;flex-wrap:wrap;gap:12px;padding:8px 10px;background:var(--color-bg-primary);border-radius:8px;font-size:12px;color:var(--color-text-secondary)}.sp-pin-reset{display:flex;flex-direction:column;gap:8px;padding:10px 12px;background:var(--color-bg-primary);border-radius:8px;border:1px solid var(--color-border)}.sp-pin-label{font-size:12px;font-weight:600;color:var(--color-text-secondary)}.sp-pin-row{display:flex;gap:8px;align-items:center}.settings-panel{padding:2rem;height:100%;overflow-y:auto;background:var(--color-bg-primary)}.settings-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2.5rem;padding-bottom:1rem;border-bottom:1px solid var(--color-border)}.settings-title{display:flex;align-items:center;gap:1rem}.settings-title h2{font-size:1.75rem;font-weight:800;color:var(--color-text-primary);margin:0;letter-spacing:-.5px}.settings-title svg{color:var(--color-primary)}.settings-actions{display:flex;gap:1rem}.settings-btn{display:flex;align-items:center;gap:.625rem;padding:.75rem 1.25rem;border-radius:var(--radius-lg);font-size:.9rem;font-weight:700;cursor:pointer;transition:all var(--transition-fast);border:none}.settings-btn.primary{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-md)}.settings-btn.primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg),var(--shadow-glow)}.settings-btn.secondary{background:var(--color-bg-elevated);color:var(--color-text-secondary);border:1px solid var(--color-border)}.settings-btn.secondary:hover{background:var(--color-bg-card);color:var(--color-text-primary);border-color:var(--color-text-muted)}.settings-content{display:flex;flex-direction:column;gap:2rem;max-width:900px}.settings-section{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:2rem;box-shadow:var(--shadow-sm)}.section-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px dashed var(--color-border)}.section-header h3{font-size:1.1rem;font-weight:700;color:var(--color-text-primary);margin:0}.section-header svg{color:var(--color-primary)}.settings-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.setting-item{display:flex;flex-direction:column;gap:.75rem}.setting-item.full-width{grid-column:span 2}.setting-item label{font-size:.85rem;font-weight:700;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.setting-item input,.setting-item select{padding:.875rem 1.25rem;background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text-primary);font-size:.95rem;font-weight:500;transition:all var(--transition-fast)}.setting-item input:focus,.setting-item select:focus{outline:none;border-color:var(--color-primary);background:var(--color-bg-card);box-shadow:0 0 0 4px var(--color-accent-glow)}.setting-item input::placeholder{color:var(--color-text-muted)}.setting-item select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23a0aec0' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:left 1rem center;background-size:1.25rem;padding-left:3rem}[dir=ltr] .setting-item select{background-position:right 1rem center;padding-left:1.25rem;padding-right:3rem}.setting-item select option{background:var(--color-bg-card);color:var(--color-text-primary)}.setting-item.toggle-item{flex-direction:row;justify-content:space-between;align-items:center;padding:1.25rem;background:var(--color-bg-secondary);border-radius:var(--radius-lg);grid-column:span 2;border:1px solid var(--color-border)}.toggle-info{display:flex;flex-direction:column;gap:.25rem}.toggle-info label{color:var(--color-text-primary);font-weight:700;text-transform:none;letter-spacing:normal}.toggle-description{font-size:.8rem;color:var(--color-text-muted)}.toggle-switch{position:relative;width:52px;height:28px;cursor:pointer}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--color-bg-elevated);border-radius:28px;transition:all .3s;border:1px solid var(--color-border)}.toggle-slider:before{content:"";position:absolute;height:20px;width:20px;left:3px;top:50%;transform:translateY(-50%);background:#fff;border-radius:50%;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-sm)}.toggle-switch input:checked+.toggle-slider{background:var(--color-primary);border-color:var(--color-primary-dark)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(24px,-50%)}.help-section{background:var(--color-accent-glow);border:1px solid var(--color-primary-light);border-style:dashed}.help-content p{color:var(--color-text-secondary);font-size:.95rem;margin:0 0 1.5rem}.help-links{display:flex;gap:1rem}.help-link{padding:.625rem 1.25rem;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:.85rem;font-weight:700;cursor:pointer;transition:all var(--transition-fast)}.help-link:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary);transform:translateY(-2px)}.printer-selection{display:flex;gap:1rem}.printer-selection select{flex:1}.test-btn{padding:.75rem 1.5rem;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-primary);font-size:.9rem;font-weight:700;cursor:pointer;transition:all .2s;white-space:nowrap}.test-btn:hover:not(:disabled){background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.test-btn:disabled{opacity:.5;cursor:not-allowed}.settings-action-btn{display:flex;align-items:center;justify-content:center;gap:.75rem;width:100%;padding:1rem;background:#f59e0b0d;border:1px solid rgba(245,158,11,.2);border-radius:var(--radius-lg);color:var(--color-highlight);font-size:.95rem;font-weight:700;cursor:pointer;transition:all .2s}.settings-action-btn:hover{background:#f59e0b1a;transform:translateY(-1px)}.settings-action-btn.secondary{background:var(--color-bg-secondary);border-color:var(--color-border);color:var(--color-text-primary)}.settings-action-btn.secondary:hover{background:var(--color-bg-elevated)}@media(max-width:768px){.settings-grid{grid-template-columns:1fr}.setting-item.full-width,.setting-item.toggle-item{grid-column:span 1}.settings-header{flex-direction:column;gap:1.5rem;align-items:flex-start}.settings-tabs{margin-left:0;width:100%;overflow-x:auto;padding-bottom:.5rem}}.settings-tabs{display:flex;gap:.5rem;margin-right:auto;margin-left:2rem}.settings-tab-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:transparent;border:none;border-radius:var(--radius-lg);color:var(--color-text-secondary);font-weight:600;cursor:pointer;transition:all .2s}.settings-tab-btn:hover{background:var(--color-bg-elevated);color:var(--color-text-primary)}.settings-tab-btn.active{background:var(--color-bg-elevated);color:var(--color-primary);box-shadow:0 1px 2px #0000000d}.menu-management{width:100%;max-width:900px}.menu-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.menu-management h3,.menu-header h3{font-size:1.25rem;font-weight:700;color:var(--color-text-primary);margin:0}.menu-list{display:flex;flex-direction:column;gap:1rem}.menu-item-row{display:flex;align-items:center;gap:1.5rem;padding:1rem;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:all .2s}.menu-item-row:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm);border-color:var(--color-text-muted)}.item-thumb{width:60px;height:60px;object-fit:cover;border-radius:var(--radius-md);background:var(--color-bg-secondary)}.item-info{flex:1}.item-name{font-weight:700;color:var(--color-text-primary);font-size:1.1rem;margin-bottom:.25rem}.item-meta{color:var(--color-text-secondary);font-size:.9rem}.item-actions{display:flex;gap:.5rem}.icon-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-bg-elevated);color:var(--color-text-secondary);cursor:pointer;transition:all .2s}.icon-btn:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.icon-btn.danger:hover{background:var(--color-danger);border-color:var(--color-danger)}.edit-form.card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:2rem;margin-bottom:2rem;box-shadow:var(--shadow-md);animation:fadeIn .3s ease}.edit-form.card h4{margin:0 0 1.5rem;color:var(--color-text-primary);font-size:1.1rem;font-weight:700}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-top:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.85rem;font-weight:700;color:var(--color-text-secondary);text-transform:uppercase}.form-group input,.form-group select{padding:.875rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-primary);color:var(--color-text-primary);font-size:.95rem}.form-group select{cursor:pointer;-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%232E4840' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-size:1.25rem;background-position:left .75rem center;padding-left:2.5rem;padding-right:.875rem;text-align:right}[dir=ltr] .form-group select{background-position:right .75rem center;padding-right:2.5rem;padding-left:.875rem;text-align:left}.dark .form-group select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23E0E0E0' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E")}.category-icon-fix{padding-right:2.5rem!important}.form-actions{grid-column:span 2;display:flex;justify-content:flex-end;gap:1rem;margin-top:1rem}.lang-switch-group{display:flex;gap:.5rem;flex-shrink:0}.lang-switch-btn{padding:.5rem 1rem;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-bg-elevated);color:var(--color-text-secondary);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s}.lang-switch-btn:hover{background:var(--color-bg-card);color:var(--color-text-primary);border-color:var(--color-text-muted)}.lang-switch-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}@media(max-width:1024px){.settings-panel{padding:1rem}.settings-header{flex-direction:column;align-items:flex-start;gap:.75rem;margin-bottom:1.5rem}.settings-title h2{font-size:1.35rem}.settings-actions{width:100%}.settings-btn{flex:1;justify-content:center}}@media(max-width:767px){.settings-panel{padding:.75rem}.settings-title h2{font-size:1.1rem}}.bt-error-msg{margin-top:.5rem;padding:.5rem .75rem;border-radius:8px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444;font-size:.8rem;line-height:1.4;word-break:break-word}.bt-printer-row{display:flex;align-items:center;gap:.75rem}.bt-status{flex:1;display:flex;align-items:center;gap:.4rem;font-size:.875rem;color:var(--color-text-secondary);padding:.5rem .75rem;background:var(--color-bg-tertiary);border-radius:var(--radius-sm);border:1px solid var(--color-border)}.bt-status.connected{color:#16a34a;border-color:#16a34a44;background:#16a34a11}.net-printer-row{display:flex;gap:.5rem;align-items:center}.net-printer-ip{flex:1;min-width:0}.net-printer-port{width:80px}.printer-width-group{display:flex;gap:.5rem}.printer-width-btn{flex:1;padding:.5rem .75rem;font-size:.875rem;font-weight:500;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-bg-tertiary);color:var(--color-text-secondary);cursor:pointer;transition:all .15s ease}.printer-width-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.printer-width-btn:not(.active):hover{border-color:var(--color-primary);color:var(--color-primary)}.terminals-list{display:flex;flex-direction:column;gap:.5rem}.terminals-empty{font-size:.875rem;color:var(--color-text-secondary);margin:0}.terminal-status-row{display:flex;align-items:center;gap:.75rem;padding:.625rem .875rem;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md)}.terminal-status-row--self{border-color:var(--color-accent, #3b82f6);background:color-mix(in srgb,var(--color-accent, #3b82f6) 8%,var(--color-bg-card))}.terminal-self-badge{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:.15rem .5rem;border-radius:999px;background:var(--color-accent, #3b82f6);color:#fff;white-space:nowrap}.terminal-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.terminal-dot.online{background:#22c55e;box-shadow:0 0 0 3px #22c55e33}.terminal-dot.offline{background:var(--color-text-secondary);opacity:.5}.terminal-status-name{font-size:.9rem;font-weight:600;color:var(--color-text-primary);flex:1}.terminal-status-time{font-size:.775rem;color:var(--color-text-secondary);white-space:nowrap}.terminal-rename-input{flex:1;min-width:0;padding:.4rem .6rem;font-size:.9rem;font-weight:600;background:var(--color-bg-body);color:var(--color-text-primary);border:1px solid var(--color-border);border-radius:var(--radius-sm);outline:none;font-family:inherit}.terminal-rename-input:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f633}.terminal-rename-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:1px solid var(--color-border);background:var(--color-bg-card);color:var(--color-text-secondary);border-radius:var(--radius-sm);cursor:pointer;flex-shrink:0;transition:color .15s,background .15s}.terminal-rename-btn:hover:not(:disabled){color:var(--color-text-primary);background:var(--color-bg-body)}.terminal-rename-btn.save:not(:disabled){color:#22c55e}.terminal-rename-btn.cancel:not(:disabled){color:#ef4444}.terminal-rename-btn:disabled{opacity:.5;cursor:not-allowed}.terminal-rename-error{font-size:.8rem;color:#ef4444;margin:-.25rem 0 .25rem 1.5rem}.settings-btn--danger-outline{background:transparent;color:#ef4444;border:1px solid rgba(239,68,68,.4);border-radius:var(--radius-lg);padding:.625rem 1rem;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s}.settings-btn--danger-outline:hover{background:#ef444414;border-color:#ef4444b3}.pin-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:9999}.pin-box{background:var(--color-bg-card, #1a1a2e);border:1px solid var(--color-border, #333);border-radius:20px;padding:2rem 1.5rem 1.5rem;width:300px;max-height:90vh;overflow-y:auto;text-align:center;box-shadow:0 24px 64px #000000a6;animation:pin-pop .18s cubic-bezier(.34,1.56,.64,1)}@keyframes pin-pop{0%{transform:scale(.88);opacity:0}to{transform:scale(1);opacity:1}}.pin-title{font-size:1.2rem;font-weight:800;color:var(--color-text-primary, #fff);margin:0 0 .3rem}.pin-subtitle{font-size:.8rem;color:var(--color-text-muted, #888);margin:0 0 1.5rem}.pin-dots{display:flex;justify-content:center;gap:14px;margin-bottom:.4rem}.pin-dots.pin-dots-shake{animation:shake .4s ease-in-out}.pin-dot{width:16px;height:16px;border-radius:50%;border:2px solid var(--color-border, #555);background:transparent;transition:background .15s,border-color .15s,transform .15s}.pin-dot.filled{background:var(--color-primary, #6c5ce7);border-color:var(--color-primary, #6c5ce7);transform:scale(1.15)}.pin-dot.filled.error{background:#e74c3c;border-color:#e74c3c}.pin-dot.locked{border-color:#e74c3c;background:#e74c3c26}.pin-err{color:#e74c3c;font-size:.78rem;margin:.35rem 0 .9rem}.pin-lockout{display:flex;flex-direction:column;align-items:center;gap:.3rem;padding:.6rem 0 .8rem}.pin-lockout-icon{width:28px;height:28px;color:#e74c3c;margin-bottom:.15rem}.pin-lockout-msg{font-size:.8rem;color:var(--color-text-muted, #888);margin:0}.pin-lockout-countdown{font-size:.9rem;color:#e74c3c;margin:0}.pin-lockout-countdown strong{font-variant-numeric:tabular-nums}.pin-pad-locked .pin-key{opacity:.25;cursor:not-allowed;pointer-events:none}.pin-pad{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:1.2rem auto 0;max-width:240px}.pin-key{height:58px;border-radius:12px;font-size:1.35rem;font-weight:700;color:var(--color-text-primary, #fff);background:var(--color-bg-elevated, #252525);border:1px solid var(--color-border, #333);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .1s,transform .08s;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.pin-key:active{transform:scale(.9);background:var(--color-primary, #6c5ce7);border-color:var(--color-primary, #6c5ce7);color:#fff}.pin-key-del{font-size:1.2rem;background:transparent;border-color:transparent;color:var(--color-text-muted, #888)}.pin-key-del:active{background:var(--color-bg-elevated, #252525);border-color:var(--color-border, #333);color:var(--color-text-primary, #fff);transform:scale(.9)}.pin-dismiss{margin-top:1.2rem;width:100%;padding:.65rem;border-radius:10px;font-size:.88rem;font-weight:700;background:transparent;border:1px solid var(--color-border, #444);color:var(--color-text-muted, #888);cursor:pointer;transition:background .15s,color .15s;touch-action:manipulation}.pin-dismiss:hover{background:var(--color-bg-elevated, #222);color:var(--color-text-primary, #fff)}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-7px)}40%{transform:translate(7px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.ebt-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:99999;animation:ebt-fade .15s ease}@keyframes ebt-fade{0%{opacity:0}to{opacity:1}}.ebt-box{background:var(--color-bg-card, #1a1a2e);border:1px solid var(--color-border, #333);border-radius:16px;width:340px;box-shadow:0 24px 64px #0009;overflow:hidden;animation:ebt-pop .18s cubic-bezier(.34,1.56,.64,1)}@keyframes ebt-pop{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.ebt-header{display:flex;align-items:center;gap:.6rem;padding:1rem 1.2rem;border-bottom:1px solid var(--color-border, #333);color:var(--color-text-primary, #fff);font-weight:700;font-size:.95rem}.ebt-header span{flex:1}.ebt-close{background:transparent;border:none;color:var(--color-text-muted, #888);cursor:pointer;padding:4px;border-radius:6px;display:flex;align-items:center;transition:color .1s,background .1s}.ebt-close:hover{color:var(--color-text-primary, #fff);background:var(--color-bg-elevated, #252525)}.ebt-list{padding:.5rem;max-height:280px;overflow-y:auto;min-height:80px;display:flex;flex-direction:column;gap:4px}.ebt-scanning{display:flex;align-items:center;gap:.6rem;color:var(--color-text-muted, #888);font-size:.88rem;padding:1.2rem;justify-content:center}.ebt-device{display:flex;align-items:center;gap:.7rem;padding:.75rem 1rem;border-radius:10px;background:transparent;border:1px solid transparent;color:var(--color-text-primary, #fff);font-size:.9rem;cursor:pointer;text-align:left;transition:background .12s,border-color .12s;width:100%}.ebt-device:hover:not(:disabled){background:var(--color-bg-elevated, #252525);border-color:var(--color-border, #333)}.ebt-device.selecting{background:#6c5ce726;border-color:var(--color-primary, #6c5ce7);color:var(--color-primary, #6c5ce7)}.ebt-device span{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ebt-device:disabled{opacity:.6;cursor:default}.ebt-footer{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.2rem;border-top:1px solid var(--color-border, #333)}.ebt-hint{font-size:.75rem;color:var(--color-text-muted, #888)}.ebt-cancel{background:transparent;border:1px solid var(--color-border, #444);border-radius:8px;color:var(--color-text-muted, #888);font-size:.82rem;font-weight:600;padding:.4rem .9rem;cursor:pointer;transition:background .12s,color .12s}.ebt-cancel:hover{background:var(--color-bg-elevated, #222);color:var(--color-text-primary, #fff)}.ebt-spin{animation:ebt-rotate .8s linear infinite;flex-shrink:0}@keyframes ebt-rotate{to{transform:rotate(360deg)}}.login-container{height:100vh;display:flex;align-items:center;justify-content:center;background:#121212}.login-card{display:flex;flex-direction:column;gap:1.5rem;padding:3rem 3.5rem;background:#141420;border:1px solid #1e1e2e;border-radius:20px;width:100%;max-width:480px;box-shadow:0 16px 48px #00000080}.login-logo{display:flex;justify-content:center;color:#4caf50;margin-bottom:.5rem}.login-title{text-align:center;font-size:1.65rem;font-weight:700;color:#f0f0f0;margin:0}.login-error{background:#ef44441f;color:#ef4444;padding:.75rem 1rem;border-radius:10px;font-size:.9rem;text-align:center}.login-card input{padding:1rem 1.25rem;background:#121212;border:1px solid #2a2a3a;border-radius:10px;color:#f0f0f0;font-size:1.05rem;outline:none;transition:border-color .2s;text-align:left;direction:ltr}.password-wrapper{position:relative;display:flex;align-items:center}.password-wrapper input{width:100%;padding-right:3rem}.password-wrapper input::-ms-reveal,.password-wrapper input::-ms-clear{display:none}.password-wrapper input::-webkit-credentials-auto-fill-button,.password-wrapper input::-webkit-password-auto-fill-button{display:none}.password-toggle{position:absolute;right:1rem;background:none;border:none;cursor:pointer;color:#aaa;display:flex;align-items:center;padding:0;margin:0;transition:color .2s}.password-toggle:hover{color:#f0f0f0}.login-card input::placeholder{color:#666}.login-card input:-webkit-autofill,.login-card input:-webkit-autofill:hover,.login-card input:-webkit-autofill:focus{-webkit-box-shadow:0 0 0px 1000px #121212 inset;-webkit-text-fill-color:#f0f0f0;border-color:#2a2a3a;transition:background-color 5000s ease-in-out 0s}.login-card input:focus{border-color:#4caf50}.login-card button[type=submit]{padding:1rem;background:#4caf50;color:#fff;border:none;border-radius:10px;font-size:1.05rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:background .2s;margin-top:.5rem}.login-card button[type=submit]:hover{background:#2e7d32}.login-card button[type=submit]:disabled{opacity:.6;cursor:not-allowed}.spin{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:767px){.login-card{padding:2rem 1.5rem;border-radius:16px;margin:0 1rem}.login-title{font-size:1.35rem}}.sss-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--color-bg-primary);display:flex;align-items:center;justify-content:center;z-index:9000;padding:24px}.sss-card{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:24px;padding:32px 28px 24px;position:relative;width:100%;max-width:540px;display:flex;flex-direction:column;gap:24px;box-shadow:var(--shadow-lg)}.sss-header{text-align:center}.sss-restaurant{margin:0 0 6px;font-size:11px;font-weight:700;color:var(--color-primary);text-transform:uppercase;letter-spacing:.08em}.sss-title{margin:0 0 6px;font-size:22px;font-weight:800;color:var(--color-text-primary)}.sss-sub{margin:0;font-size:13px;color:var(--color-text-muted)}.sss-loading{display:flex;justify-content:center;padding:16px;color:var(--color-text-muted)}.sss-spin{animation:sss-spin .8s linear infinite}@keyframes sss-spin{to{transform:rotate(360deg)}}.sss-empty{text-align:center;color:var(--color-text-muted);font-size:13px;line-height:1.7;margin:0}.sss-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:12px}.sss-avatar-btn{display:flex;flex-direction:column;align-items:center;gap:8px;padding:18px 8px 14px;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:16px;cursor:pointer;transition:border-color .15s,transform .1s;-webkit-tap-highlight-color:transparent}.sss-avatar-btn:hover{border-color:var(--color-primary)}.sss-avatar-btn:active{transform:scale(.96)}.sss-avatar{width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:800;color:#fff;flex-shrink:0}.sss-name{font-size:13px;font-weight:700;color:var(--color-text-primary);text-align:center;line-height:1.2}.sss-role{font-size:11px;color:var(--color-text-muted)}.sss-owner-btn{display:flex;align-items:center;justify-content:center;gap:7px;padding:11px;background:none;border:1px solid var(--color-border);border-radius:12px;color:var(--color-text-muted);font-size:13px;font-weight:600;cursor:pointer;transition:border-color .15s,color .15s}.sss-owner-btn:hover{border-color:var(--color-text-secondary);color:var(--color-text-primary)}.shift-loading{display:flex;justify-content:center;align-items:center;padding:48px;color:var(--color-text-muted)}.shift-spin{animation:shift-spin .8s linear infinite}@keyframes shift-spin{to{transform:rotate(360deg)}}.shift-root{display:flex;flex-direction:column;gap:16px;padding:20px;width:100%;max-width:520px;height:100%;overflow-y:auto;box-sizing:border-box}.shift-page-title{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:700;color:var(--color-text-primary)}.shift-card{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:16px;padding:20px;display:flex;flex-direction:column;gap:14px}.shift-badge{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em}.shift-badge--open{color:var(--color-primary)}.shift-badge--closed{color:var(--color-text-muted)}.shift-meta{display:flex;flex-wrap:wrap;gap:6px 16px;font-size:13px;color:var(--color-text-secondary)}.shift-meta strong{color:var(--color-text-primary)}.shift-stat-row{display:flex;gap:12px}.shift-stat{display:flex;flex-direction:column;gap:2px}.shift-stat-label{font-size:11px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.shift-stat-value{font-size:20px;font-weight:700;color:var(--color-text-primary)}.shift-form{display:flex;flex-direction:column;gap:8px}.shift-label{font-size:12px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.shift-input{width:100%;padding:10px 12px;background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:8px;color:var(--color-text-primary);font-size:14px;box-sizing:border-box;font-family:inherit;transition:border-color .15s}.shift-input:focus{outline:none;border-color:var(--color-primary)}.shift-diff{font-size:13px;font-weight:600;padding:6px 10px;border-radius:8px}.shift-diff--pos{color:var(--color-primary);background:var(--color-primary-glow, rgba(46, 125, 50, .12))}.shift-diff--neg{color:var(--color-danger);background:var(--color-danger-glow)}.shift-error{margin:0;font-size:12px;color:var(--color-danger)}.shift-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:11px;border-radius:10px;font-size:14px;font-weight:700;cursor:pointer;border:none;margin-top:4px;transition:opacity .15s}.shift-btn:disabled{opacity:.5;cursor:not-allowed}.shift-btn--open{background:var(--color-primary);color:#fff}.shift-btn--close{background:var(--color-danger);color:#fff}.shift-history{display:flex;flex-direction:column;gap:4px}.shift-history-title{margin:0 0 8px;font-size:12px;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.shift-history-row{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:10px}.shift-history-left{display:flex;flex-direction:column;gap:2px}.shift-history-by{font-size:13px;font-weight:600;color:var(--color-text-primary)}.shift-history-date{font-size:11px;color:var(--color-text-muted)}.shift-history-right{display:flex;gap:8px;font-size:13px;font-weight:600;color:var(--color-text-secondary);align-items:center}.shift-warning{margin:0;font-size:12px;color:var(--color-warning, #f59e0b);font-weight:600}.shift-btn-paidout{display:flex;align-items:center;gap:6px;margin-left:auto;padding:6px 12px;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:8px;color:var(--color-text-secondary);font-size:13px;font-weight:600;cursor:pointer;transition:border-color .15s}.shift-btn-paidout:hover{border-color:var(--color-primary);color:var(--color-primary)}.shift-btn--reprint{background:transparent;border:1px dashed var(--color-border);color:var(--color-text-muted);font-size:12px}.shift-btn--reprint:hover{border-color:var(--color-text-secondary);color:var(--color-text-secondary)}.shift-offline-notice{display:flex;align-items:center;gap:6px;padding:8px 12px;border-radius:8px;background:#fef3c7;color:#92400e;font-size:12px;font-weight:500;margin-bottom:4px}.shift-pending-notice{font-size:11px;color:#b45309;background:#fffbeb;border:1px solid #fde68a;border-radius:6px;padding:4px 8px;margin-bottom:8px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:900}.paidout-modal{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:20px;width:100%;max-width:420px;max-height:90vh;overflow-y:auto;box-shadow:0 24px 64px #00000080}.paidout-header{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 0}.paidout-title-row{display:flex;align-items:center;gap:8px;color:var(--color-text-primary)}.paidout-title{margin:0;font-size:16px;font-weight:700}.paidout-close{background:none;border:none;cursor:pointer;color:var(--color-text-muted);padding:4px;border-radius:6px}.paidout-close:hover{color:var(--color-text-primary)}.paidout-body{display:flex;flex-direction:column;gap:8px;padding:16px 20px 20px}.zreport-modal{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:20px;width:100%;max-width:440px;max-height:90vh;overflow-y:auto;box-shadow:0 24px 64px #00000080}.zreport-header{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 0;position:sticky;top:0;background:var(--color-bg-secondary);z-index:1}.zreport-title-row{display:flex;align-items:center;gap:8px;color:var(--color-text-primary)}.zreport-title{margin:0;font-size:16px;font-weight:700}.zreport-actions{display:flex;align-items:center;gap:8px}.zreport-body{padding:16px 20px 24px;font-family:Courier New,monospace;font-size:13px}.zreport-restaurant{font-size:15px;font-weight:700;text-align:center;color:var(--color-text-primary);margin-bottom:2px}.zreport-caisse{font-size:12px;text-align:center;color:var(--color-text-muted);margin-bottom:8px}.zreport-line{border-top:1px dashed var(--color-border);margin:10px 0}.zreport-row{display:flex;justify-content:space-between;align-items:center;padding:3px 0;color:var(--color-text-secondary);font-size:13px}.zreport-amount{font-weight:700;color:var(--color-text-primary)}.zreport-section-title{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);margin-bottom:4px}.zreport-paidout{padding-left:8px}.zreport-variance{font-weight:700}.zreport-pos .zreport-amount{color:var(--color-primary)}.zreport-neg .zreport-amount{color:var(--color-danger)}.zreport-reason{font-size:12px;color:var(--color-text-muted);font-style:italic;margin-top:4px}.zreport-signature{text-align:center;color:var(--color-text-muted);margin-top:8px;font-size:12px}.com-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:9999;padding:16px}.com-disposition{margin-top:14px;padding-top:14px;border-top:1px solid var(--color-border)}.com-disposition-list{display:flex;flex-direction:column;gap:6px;margin-top:8px}.com-disposition-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--color-border);border-radius:8px;cursor:pointer;font-size:.875rem;color:var(--color-text);transition:all .15s}.com-disposition-item:hover{border-color:var(--color-primary);background:var(--color-bg-elevated)}.com-disposition-item--active{border-color:var(--color-primary);background:var(--color-primary-bg, rgba(59,130,246,.08));color:var(--color-primary);font-weight:500}.com-disposition-item input[type=radio]{accent-color:var(--color-primary);cursor:pointer}.com-modal{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:16px;width:100%;max-width:420px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:0;overflow:hidden}.com-header{display:flex;align-items:flex-start;gap:12px;padding:20px 20px 16px;border-bottom:1px solid var(--color-border)}.com-icon{width:40px;height:40px;border-radius:10px;background:var(--color-danger-glow);display:flex;align-items:center;justify-content:center;color:var(--color-danger);flex-shrink:0}.com-title{margin:0;font-size:15px;font-weight:700;color:var(--color-text-primary)}.com-sub{margin:3px 0 0;font-size:13px;color:var(--color-text-muted)}.com-close{margin-left:auto;background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:0;flex-shrink:0}.com-close:hover{color:var(--color-danger)}.com-body{padding:16px 20px;display:flex;flex-direction:column;gap:10px}.com-label{margin:0;font-size:12px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.com-required{color:var(--color-danger)}.com-quick-reasons{display:flex;flex-wrap:wrap;gap:6px}.com-quick-btn{padding:5px 12px;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:20px;font-size:12px;color:var(--color-text-secondary);cursor:pointer;transition:all .15s}.com-quick-btn:hover{border-color:var(--color-danger);color:var(--color-danger)}.com-quick-btn--active{background:var(--color-danger-glow);border-color:var(--color-danger);color:var(--color-danger);font-weight:600}.com-textarea{width:100%;padding:10px 12px;background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:8px;color:var(--color-text-primary);font-size:13px;resize:none;box-sizing:border-box;font-family:inherit;transition:border-color .15s}.com-textarea:focus{outline:none;border-color:var(--color-primary)}.com-actions{display:flex;gap:10px;padding:14px 20px;border-top:1px solid var(--color-border);background:var(--color-bg-elevated)}.com-btn{flex:1;padding:10px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;border:none;transition:background .15s}.com-btn--secondary{background:var(--color-bg-primary);border:1px solid var(--color-border);color:var(--color-text-primary)}.com-btn--secondary:hover{border-color:var(--color-text-muted)}.com-btn--danger{background:var(--color-danger);color:#fff}.com-btn--danger:hover:not(:disabled){background:#b71c1c}.com-btn--danger:disabled{opacity:.4;cursor:not-allowed}.offline-banner{width:100%;flex-shrink:0;display:flex;align-items:center;justify-content:center;gap:8px;font-size:12px;font-weight:600;height:36px;padding:0 16px;box-sizing:border-box}.offline-banner--offline{background:#fbc02d;color:#000}.offline-banner--syncing{background:#2563eb;color:#fff}.offline-banner__actions{margin-left:auto;display:flex;align-items:center;gap:6px;flex-shrink:0}.offline-banner__action{display:flex;align-items:center;justify-content:center;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:4px;color:#fff;width:20px;height:20px;padding:0;cursor:pointer;flex-shrink:0;transition:background .15s}.offline-banner__action:hover{background:#fff3}.offline-spin{animation:offline-spin 1s linear infinite}@keyframes offline-spin{to{transform:rotate(360deg)}}.tps-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:9999;padding:16px}.tps-card{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:20px;padding:28px 24px;width:100%;max-width:420px;display:flex;flex-direction:column;gap:24px}.tps-header{text-align:center;display:flex;flex-direction:column;gap:4px}.tps-staff{margin:0;font-size:12px;font-weight:600;color:var(--color-primary);text-transform:uppercase;letter-spacing:.08em}.tps-title{margin:0;font-size:20px;font-weight:700;color:var(--color-text-primary)}.tps-sub{margin:0;font-size:13px;color:var(--color-text-muted)}.tps-grid{display:flex;flex-direction:column;gap:10px}.tps-item{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:12px;cursor:pointer;text-align:left;transition:border-color .15s,background .15s}.tps-item:hover,.tps-item--last{border-color:var(--color-primary);background:var(--color-accent-glow)}.tps-icon{width:40px;height:40px;border-radius:10px;background:var(--color-bg-elevated);border:1px solid var(--color-border);display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);flex-shrink:0}.tps-icon--online{background:#2e7d321a;border-color:#2e7d324d;color:#2e7d32}.tps-item-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.tps-name{font-size:15px;font-weight:600;color:var(--color-text-primary)}.tps-last-label{font-size:11px;color:var(--color-primary);font-weight:500}.tps-status{font-size:11px;font-weight:600;color:var(--color-text-muted);padding:2px 8px;border-radius:20px;background:var(--color-bg-elevated);border:1px solid var(--color-border)}.tps-status--online{color:#2e7d32;background:#2e7d321a;border-color:#2e7d324d}.app-shell{display:flex;flex-direction:column;height:100vh;width:100vw;background:var(--color-bg-primary);overflow:hidden}.app-container{display:grid;grid-template-columns:64px 1fr 310px;grid-template-rows:minmax(0,1fr);flex:1;min-height:0;width:100%;background:var(--color-bg-primary);overflow:hidden}.main-content{display:flex;flex-direction:column;height:100%;overflow:hidden;padding:1rem 1.5rem;position:relative}.header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;flex-shrink:0}.header-left{display:flex;flex-direction:column}.header-greeting{font-size:.8rem;color:var(--color-text-muted);margin-bottom:.15rem}.header-title{font-size:1.75rem;font-weight:700;letter-spacing:-.5px;color:var(--color-text-primary)}.dark .header-title{background:linear-gradient(135deg,#fff,#ccc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-right{display:flex;gap:1rem}.header-stat{display:flex;flex-direction:column;align-items:flex-start;padding:.875rem 1.25rem;background:var(--color-bg-card);border-radius:var(--radius-lg);border:1px solid var(--color-border)}.header-stat.highlight{background:var(--color-accent-glow);border-color:var(--color-accent)}.header-stat-value{font-size:1.5rem;font-weight:700;color:var(--color-text-primary);font-variant-numeric:tabular-nums}.header-stat.highlight .header-stat-value{color:var(--color-accent)}.header-stat-label{font-size:.7rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;margin-top:.15rem}.category-tabs{display:flex;gap:.625rem;margin-bottom:1.5rem;overflow-x:auto;padding-bottom:.5rem;flex-shrink:0}.category-tab{padding:.625rem 1.25rem;border-radius:var(--radius-md);background:var(--color-bg-card);color:var(--color-text-secondary);font-weight:600;font-size:.875rem;border:1px solid var(--color-border);white-space:nowrap;transition:all var(--transition-fast)}.category-tab.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary);box-shadow:0 4px 12px var(--color-accent-glow)}.category-tab:hover:not(.active){background:var(--color-bg-elevated);border-color:var(--color-text-muted)}.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.75rem;overflow-y:auto;padding-bottom:1rem;padding-left:.5rem;flex:1;min-height:0;align-content:start}.settings-placeholder,.reports-placeholder{padding:2rem}.settings-placeholder h2,.reports-placeholder h2{font-size:1.5rem;font-weight:800;margin-bottom:.5rem}.placeholder-text{color:var(--color-text-secondary);margin-bottom:2rem}.quick-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.quick-stat-card{background:var(--color-bg-card);border-radius:var(--radius-lg);padding:1.5rem;display:flex;flex-direction:column;align-items:center;border:1px solid var(--color-border)}.quick-stat-value{font-size:2rem;font-weight:800;color:var(--color-accent);margin-bottom:.5rem}.quick-stat-label{font-size:.8rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px}@media(max-width:1280px){.app-container{grid-template-columns:72px 1fr 360px}}@media(min-width:1025px){.app-container{grid-template-columns:64px 1fr 320px}.app-container.app-container--no-cart{grid-template-columns:64px 1fr}.header-title{font-size:1.5rem}.product-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.cart-fab,.cart-mobile-handle,.cart-overlay-backdrop{display:none!important}}@media(max-width:1024px){.app-container{grid-template-columns:1fr;grid-template-rows:1fr 64px}.main-content{padding:1rem;padding-bottom:0}.app-container>.cart-container{display:none}.cart-fab{display:flex;position:fixed;bottom:80px;right:1rem;z-index:100;width:56px;height:56px;border-radius:50%;background:var(--gradient-primary);color:#fff;align-items:center;justify-content:center;box-shadow:0 4px 20px var(--color-accent-glow),var(--shadow-lg);transition:transform .2s ease;border:none;cursor:pointer}.cart-fab:active{transform:scale(.93)}.cart-fab-badge{position:absolute;top:-4px;right:-4px;min-width:20px;height:20px;background:var(--color-danger);color:#fff;font-size:.7rem;font-weight:700;border-radius:100px;display:flex;align-items:center;justify-content:center;padding:0 4px;border:2px solid var(--color-bg-primary)}.cart-overlay-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:flex;align-items:flex-end;background:#0000008c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeInOverlay .2s ease}.cart-overlay-backdrop .cart-container{display:flex!important;width:100%;max-width:480px;margin:0 auto;height:85dvh;border-radius:20px 20px 0 0;border:1px solid var(--color-border);border-bottom:none;animation:slideUpCart .3s cubic-bezier(.34,1.56,.64,1)}.cart-mobile-handle{display:block;width:40px;height:4px;background:var(--color-border);border-radius:2px;margin:.625rem auto 0;flex-shrink:0;cursor:pointer}.header-title{font-size:1.25rem}.product-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.625rem}}@media(max-width:767px){.main-content{padding:.75rem;padding-bottom:0}.header{flex-direction:column;gap:.625rem;margin-bottom:.75rem}.header-right{width:100%;gap:.5rem}.header-stat{flex:1;padding:.5rem .75rem}.header-stat-value{font-size:1rem}.header-title{font-size:1.05rem}.header-greeting{font-size:.7rem}.category-tabs{gap:.375rem;margin-bottom:.625rem}.category-tab{padding:.5rem .875rem;font-size:.8rem}.product-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:.5rem}}@keyframes slideUpCart{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes fadeInOverlay{0%{opacity:0}to{opacity:1}}.pin-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:9999}.pin-modal{background:var(--color-bg-card, #1a1a2e);border:1px solid var(--color-border, #333);border-radius:16px;padding:2.5rem 2rem;width:340px;text-align:center;box-shadow:0 20px 60px #00000080}.pin-modal h3{font-size:1.4rem;font-weight:800;color:var(--color-text-primary, #fff);margin-bottom:.5rem}.pin-modal>p{font-size:.85rem;color:var(--color-text-muted, #888);margin-bottom:1.5rem}.pin-input-row{display:flex;justify-content:center;margin-bottom:1rem}.pin-input{width:140px;text-align:center;font-size:2rem;letter-spacing:12px;padding:.75rem 1rem;border-radius:12px;border:2px solid var(--color-border, #444);background:var(--color-bg-primary, #0a0a0f);color:var(--color-text-primary, #fff);outline:none;transition:border-color .2s}.pin-input:focus{border-color:var(--color-primary, #6c5ce7)}.pin-input::-ms-reveal,.pin-input::-ms-clear,.pin-input::-webkit-contacts-auto-fill-button,.pin-input::-webkit-credentials-auto-fill-button,.pin-input::-webkit-reveal{display:none!important}.pin-input.pin-error{border-color:#e74c3c;animation:shake .4s ease-in-out}.pin-error-text{color:#e74c3c;font-size:.8rem;margin-bottom:1rem}.pin-actions{display:flex;gap:.75rem;justify-content:center;margin-top:.5rem}.pin-cancel,.pin-confirm{padding:.6rem 1.5rem;border-radius:10px;font-weight:700;font-size:.9rem;cursor:pointer;border:none;transition:all .2s}.pin-cancel{background:var(--color-bg-elevated, #222);color:var(--color-text-secondary, #aaa)}.pin-cancel:hover{background:var(--color-bg-card, #333)}.pin-confirm{background:var(--color-primary, #6c5ce7);color:#fff}.pin-confirm:hover:not(:disabled){filter:brightness(1.15)}.pin-confirm:disabled{opacity:.4;cursor:not-allowed}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-8px)}50%{transform:translate(8px)}75%{transform:translate(-4px)}}.table-action-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:500;animation:fadeInOverlay .15s ease}.table-action-sheet{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.5rem;width:100%;max-width:300px;display:flex;flex-direction:column;gap:.75rem;box-shadow:var(--shadow-lg);animation:scaleIn .18s ease backwards}.table-action-title{font-size:1.15rem;font-weight:700;color:var(--color-text-primary);text-align:center;margin-bottom:.25rem}.table-action-btn{width:100%;padding:.8rem 1rem;border-radius:var(--radius-md);font-weight:600;font-size:.95rem;cursor:pointer;border:none;transition:all var(--transition-fast);display:inline-flex;align-items:center;justify-content:center;gap:.6rem}.table-action-btn--primary{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-md)}.table-action-btn--primary:hover{filter:brightness(1.1)}.table-action-btn--secondary{background:var(--color-bg-elevated);border:1px solid var(--color-border);color:var(--color-text-primary)}.table-action-btn--secondary:hover{border-color:var(--color-accent);color:var(--color-accent)}.table-action-btn--cancel{background:transparent;color:var(--color-text-muted);font-size:.85rem}.table-action-btn--cancel:hover{color:var(--color-text-secondary)}.append-mode-banner{display:flex;align-items:center;gap:8px;padding:10px 14px;margin-bottom:8px;background:#3b82f61a;border:1px solid rgba(59,130,246,.3);border-radius:8px;color:var(--color-primary, #3b82f6);font-size:.875rem;font-weight:500}.append-mode-banner span{flex:1}.append-mode-cancel{background:transparent;border:none;cursor:pointer;color:inherit;padding:4px;display:flex;align-items:center;border-radius:4px;opacity:.7;transition:opacity .15s}.append-mode-cancel:hover{opacity:1;background:#3b82f626}.transfer-cancel-fab{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:300;background:var(--color-danger);color:#fff;border:none;border-radius:100px;padding:.625rem 1.5rem;font-weight:700;font-size:.9rem;cursor:pointer;box-shadow:0 4px 20px #00000059;transition:all var(--transition-fast);display:inline-flex;align-items:center;gap:.5rem}.transfer-cancel-fab:hover{filter:brightness(1.1);transform:translate(-50%) translateY(-2px)}@media(max-height:820px){.header{margin-bottom:.5rem}.header-title{font-size:1.25rem}.header-stat{padding:.5rem .75rem}.header-stat-value{font-size:1.1rem}.category-tabs{margin-bottom:.75rem}}
