:root{--bg-primary: #0f0f0f;--bg-secondary: #1a1a1a;--bg-card: #222222;--bg-hover: #2c2c2c;--bg-active: #363636;--accent: #f59e0b;--accent-dark: #d97706;--accent-light: #fcd34d;--accent-muted: rgba(245,158,11,.12);--text-primary: #f9fafb;--text-secondary:#9ca3af;--text-muted: #6b7280;--border: #2a2a2a;--border-light: #383838;--success: #22c55e;--success-bg: rgba(34,197,94,.12);--danger: #ef4444;--danger-bg: rgba(239,68,68,.12);--radius-sm: 6px;--radius: 10px;--radius-lg: 16px;--header-h: 60px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;overflow:hidden}body{font-family:-apple-system,BlinkMacSystemFont,Hiragino Sans,Hiragino Kaku Gothic ProN,Noto Sans JP,sans-serif;background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;user-select:none;-webkit-user-select:none;touch-action:manipulation;font-size:15px}button{cursor:pointer;border:none;background:none;font-family:inherit;font-size:inherit;color:inherit;-webkit-tap-highlight-color:transparent}button:active{transform:scale(.96)}input,select,textarea{font-family:inherit;outline:none;user-select:text;-webkit-user-select:text}::-webkit-scrollbar{width:3px;height:3px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:2px}.app{display:flex;flex-direction:column;height:100%}.main-content{flex:1;overflow:hidden;display:flex;flex-direction:column}.header{height:var(--header-h);background:var(--bg-secondary);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 16px;gap:8px;flex-shrink:0;z-index:10}.header-logo{font-size:20px;font-weight:800;letter-spacing:-.5px;margin-right:8px}.header-logo span{color:var(--accent)}.header-nav{display:flex;gap:4px;flex:1}.header-nav-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:var(--radius);color:var(--text-secondary);font-size:14px;font-weight:500;transition:background .15s,color .15s}.header-nav-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.header-nav-btn.active{background:var(--accent-muted);color:var(--accent)}.header-right{display:flex;align-items:center;gap:8px;margin-left:auto}.header-time{font-size:13px;color:var(--text-muted);font-variant-numeric:tabular-nums}.sync-bar{display:flex;align-items:center;gap:8px;padding:6px 16px;background:var(--bg-secondary);border-bottom:1px solid var(--border);flex-shrink:0}.sync-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;box-shadow:0 0 5px currentColor;transition:background .4s}.sync-status-label{font-size:11px;color:var(--text-muted);white-space:nowrap;margin-right:4px}.sync-bar-btn{display:flex;align-items:center;gap:5px;padding:6px 14px;border-radius:var(--radius);font-size:13px;font-weight:600;transition:opacity .15s,background .15s}.sync-bar-btn:disabled{opacity:.5;cursor:not-allowed}.sync-bar-btn.push{background:var(--accent);color:#000}.sync-bar-btn.push:not(:disabled):hover{background:var(--accent-light)}.sync-bar-btn.pull{background:var(--bg-active);color:var(--text-primary);border:1px solid var(--border-light)}.sync-bar-btn.pull:not(:disabled):hover{background:var(--bg-hover)}.sync-bar-msg{font-size:12px;font-weight:600;color:var(--text-secondary);margin-left:4px;animation:fadeIn .2s ease}.role-badge{font-size:12px;font-weight:700;padding:5px 10px;border-radius:20px;white-space:nowrap;background:var(--bg-active);color:var(--text-secondary);border:1px solid var(--border-light);transition:background .15s}.role-badge:hover{background:var(--bg-hover);color:var(--text-primary)}.role-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);min-width:150px;box-shadow:0 8px 24px #00000080;z-index:200;overflow:hidden}.role-dropdown-title{font-size:10px;font-weight:700;color:var(--text-muted);padding:8px 12px 4px;text-transform:uppercase;letter-spacing:.5px}.role-dropdown-item{display:block;width:100%;text-align:left;padding:9px 12px;font-size:13px;font-weight:600;color:var(--text-primary);transition:background .15s}.role-dropdown-item:hover{background:var(--bg-hover)}.role-dropdown-item.active{color:var(--accent);background:var(--accent-muted)}.role-dropdown-divider{height:1px;background:var(--border);margin:4px 0}.role-dropdown-user{font-size:11px;color:var(--text-muted);padding:5px 12px 2px}.role-dropdown-logout{display:block;width:100%;text-align:left;padding:9px 12px;font-size:13px;font-weight:600;color:var(--danger);transition:background .15s}.role-dropdown-logout:hover{background:var(--danger-bg)}.login-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:var(--bg-primary);display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .25s ease}.login-card{background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:36px 28px;width:min(400px,100%);box-shadow:0 24px 64px #0009;display:flex;flex-direction:column;align-items:center;gap:0}.login-logo{font-size:32px;font-weight:800;letter-spacing:-1px;margin-bottom:6px}.login-logo span{color:var(--accent)}.login-subtitle{font-size:13px;color:var(--text-muted);margin-bottom:28px;font-weight:600;letter-spacing:.3px}.login-form{width:100%;display:flex;flex-direction:column;gap:14px}.login-field{display:flex;flex-direction:column;gap:6px}.login-label{font-size:12px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.login-input{width:100%;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);padding:12px 14px;font-size:16px;color:var(--text-primary);transition:border-color .15s;user-select:text;-webkit-user-select:text}.login-input:focus{border-color:var(--accent);outline:none}.login-input::placeholder{color:var(--text-muted)}.login-error{font-size:13px;font-weight:600;color:var(--danger);background:var(--danger-bg);padding:9px 12px;border-radius:var(--radius);text-align:center}.login-btn{width:100%;padding:14px;background:var(--accent);color:#000;font-size:15px;font-weight:800;border-radius:var(--radius);margin-top:4px;transition:background .15s,transform .1s}.login-btn:hover{background:var(--accent-light)}.login-btn:active{transform:scale(.98)}.login-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.login-divider{width:100%;height:1px;background:var(--border);margin:22px 0 16px}.login-link{font-size:14px;font-weight:600;color:var(--text-secondary);text-decoration:underline;text-underline-offset:3px;transition:color .15s}.login-link:hover{color:var(--accent)}.login-done-icon{font-size:48px;margin:8px 0 12px}.login-done-msg{font-size:18px;font-weight:800;color:var(--text-primary);margin-bottom:6px}.login-done-id{font-size:14px;color:var(--text-muted);background:var(--bg-card);padding:6px 16px;border-radius:var(--radius);margin-bottom:24px}.role-select-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:var(--bg-primary);display:flex;align-items:center;justify-content:center;animation:fadeIn .3s ease}.role-select-card{background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:36px 28px;width:min(420px,90vw);text-align:center;box-shadow:0 24px 64px #0009}.role-select-logo{font-size:28px;font-weight:800;margin-bottom:8px}.role-select-logo span{color:var(--accent)}.role-select-title{font-size:15px;color:var(--text-secondary);margin-bottom:24px;line-height:1.5}.role-select-list{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.role-select-btn{display:flex;align-items:center;gap:14px;padding:16px 18px;border-radius:var(--radius);background:var(--bg-card);border:1px solid var(--border-light);text-align:left;transition:border-color .15s,background .15s}.role-select-btn:hover{border-color:var(--accent);background:var(--accent-muted)}.role-select-icon{font-size:28px;flex-shrink:0}.role-select-info{flex:1}.role-select-name{font-size:15px;font-weight:700;color:var(--text-primary)}.role-select-desc{font-size:12px;color:var(--text-muted);margin-top:2px}.role-select-arrow{font-size:20px;color:var(--text-muted)}.role-select-note{font-size:11px;color:var(--text-muted)}.register-view{display:grid;grid-template-columns:1fr 380px;height:100%;overflow:hidden}.menu-panel{display:flex;flex-direction:column;overflow:hidden;border-right:1px solid var(--border)}.category-tabs{display:flex;gap:6px;padding:12px 16px;overflow-x:auto;flex-shrink:0;border-bottom:1px solid var(--border)}.category-tabs::-webkit-scrollbar{height:0}.category-tab{padding:8px 16px;border-radius:var(--radius);font-size:13px;font-weight:600;white-space:nowrap;color:var(--text-secondary);background:var(--bg-card);border:1px solid var(--border);transition:all .15s}.category-tab:hover{background:var(--bg-hover);color:var(--text-primary)}.category-tab.active{background:var(--accent);color:#000;border-color:var(--accent)}.menu-grid-wrapper{flex:1;overflow-y:auto;padding:12px 16px 16px}.menu-grid-section{margin-bottom:16px}.menu-grid-section:last-child{margin-bottom:0}.menu-grid-row-header{font-size:11px;font-weight:800;color:var(--accent);letter-spacing:.08em;padding:0 2px 6px;border-bottom:1px solid var(--border);margin-bottom:8px}.menu-grid-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:40px;color:var(--text-muted);font-size:14px}.menu-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:12px}.menu-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px 10px;display:flex;flex-direction:column;align-items:center;gap:6px;min-height:115px;justify-content:center;transition:all .15s;cursor:pointer;position:relative}.menu-card:hover{background:var(--bg-hover);border-color:var(--border-light);transform:translateY(-1px)}.menu-card:active{transform:scale(.95)}.menu-card.unavailable{opacity:.35;cursor:not-allowed}.menu-card.unavailable:active{transform:none}.menu-card-emoji{font-size:34px;line-height:1}.menu-card-name{font-size:12px;font-weight:600;text-align:center;line-height:1.3}.menu-card-price{font-size:15px;font-weight:700;color:var(--accent)}.menu-card-badge{position:absolute;top:6px;right:6px;background:var(--accent);color:#000;font-size:11px;font-weight:800;min-width:20px;height:20px;border-radius:10px;padding:0 5px;display:flex;align-items:center;justify-content:center;line-height:1}.menu-empty{grid-column:1/-1;padding:60px 20px;text-align:center;color:var(--text-muted)}.menu-empty-icon{font-size:48px;margin-bottom:12px}.receipt-side{display:flex;flex-direction:column;background:var(--bg-secondary);overflow:hidden}.receipt-tabs-bar{display:flex;align-items:center;gap:4px;padding:10px 12px;border-bottom:1px solid var(--border);overflow-x:auto;flex-shrink:0}.receipt-tabs-bar::-webkit-scrollbar{height:0}.receipt-tab{padding:6px 12px;border-radius:var(--radius);color:var(--text-secondary);background:var(--bg-card);border:1px solid var(--border);white-space:nowrap;transition:all .15s;display:flex;flex-direction:column;align-items:center;gap:1px}.receipt-tab:hover{background:var(--bg-hover);color:var(--text-primary)}.receipt-tab.active{background:var(--accent-muted);border-color:var(--accent)}.tab-label{font-size:13px;font-weight:700;color:inherit}.receipt-tab.active .tab-label{color:var(--accent)}.tab-amount{font-size:11px;font-weight:700;color:var(--text-muted)}.receipt-tab.active .tab-amount{color:var(--accent-light)}.receipt-new-btn{margin-left:auto;padding:6px 14px;border-radius:var(--radius);background:var(--accent);color:#000;font-size:13px;font-weight:800;white-space:nowrap;flex-shrink:0}.receipt-new-btn:hover{background:var(--accent-light)}.receipt-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-muted);gap:14px;padding:40px;text-align:center}.receipt-placeholder-icon{font-size:56px;opacity:.25}.receipt-panel{display:flex;flex-direction:column;height:100%;overflow:hidden}.receipt-header{padding:12px 16px 10px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.receipt-number{font-size:16px;font-weight:800}.receipt-header-right{display:flex;align-items:center;gap:8px}.receipt-time{font-size:12px;color:var(--text-muted)}.unserved-badge{display:inline-block;margin-left:8px;font-size:11px;font-weight:700;background:var(--accent-muted);color:var(--accent);padding:2px 7px;border-radius:6px}.receipt-delete-btn{font-size:16px;padding:4px 6px;border-radius:6px;color:var(--text-muted);background:transparent;transition:background .15s,color .15s;line-height:1}.receipt-delete-btn:hover{background:var(--danger-bg);color:var(--danger)}.receipt-label-row{padding:6px 12px 8px;border-bottom:1px solid var(--border)}.receipt-label-input{width:100%;background:var(--surface2);border:1.5px solid transparent;border-radius:8px;padding:6px 10px;font-size:13px;color:var(--text-primary);outline:none;box-sizing:border-box;transition:border-color .15s}.receipt-label-input::placeholder{color:var(--text-muted);font-size:12px}.receipt-label-input:focus{border-color:var(--accent)}.receipt-items{flex:1;overflow-y:auto;padding:6px 8px}.receipt-item-empty{display:flex;align-items:center;justify-content:center;height:120px;color:var(--text-muted);font-size:13px}.receipt-item{display:flex;align-items:flex-start;gap:8px;padding:9px 8px;border-radius:var(--radius);border-bottom:1px solid var(--border);transition:background .1s,opacity .2s}.receipt-item:last-child{border-bottom:none}.receipt-item:hover{background:var(--bg-hover)}.receipt-item.served{opacity:.45}.receipt-item.served .ri-name,.receipt-item.served .ri-info .ri-name{text-decoration:line-through}.served-check{width:28px;height:28px;flex-shrink:0;margin-top:1px;border-radius:6px;border:2px solid var(--border-light);background:var(--bg-card);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:800;color:var(--success);transition:all .15s}.served-check:hover{border-color:var(--success);background:var(--success-bg)}.served-check.checked{background:var(--success-bg);border-color:var(--success)}.ri-emoji{font-size:20px;flex-shrink:0}.ri-name{flex:1;font-size:13px;font-weight:600;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ri-qty{font-size:13px;font-weight:700;color:var(--accent);flex-shrink:0;min-width:28px;text-align:center}.ri-price{font-size:13px;font-weight:600;color:var(--text-secondary);flex-shrink:0;min-width:52px;text-align:right}.ri-remove{width:24px;height:24px;flex-shrink:0;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--text-muted);background:transparent;transition:all .15s}.ri-remove:hover{background:var(--danger-bg);color:var(--danger)}.receipt-footer{border-top:1px solid var(--border);padding:14px 16px;flex-shrink:0}.receipt-total-row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:12px}.receipt-total-row span:first-child{font-size:14px;color:var(--text-secondary);font-weight:600}.receipt-total-amount{font-size:26px;font-weight:800;color:var(--accent)}.complete-btn{width:100%;padding:15px;background:var(--accent);color:#000;font-size:16px;font-weight:800;border-radius:var(--radius-lg);transition:background .15s}.complete-btn:hover{background:var(--accent-light)}.complete-btn:disabled{background:var(--bg-card);color:var(--text-muted);cursor:not-allowed}.complete-btn:disabled:active{transform:none}.payment-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#000000bf;display:flex;align-items:center;justify-content:center;padding:16px;animation:fadeIn .15s ease}.payment-modal{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-light);width:100%;max-width:400px;max-height:90dvh;overflow-y:auto;display:flex;flex-direction:column;animation:slideUp .2s ease}.payment-header{padding:20px 20px 16px;border-bottom:1px solid var(--border);text-align:center}.payment-title{font-size:13px;color:var(--text-muted);font-weight:600;letter-spacing:.05em}.payment-receipt-no{font-size:14px;color:var(--text-secondary);margin-top:2px}.payment-total-amount{font-size:38px;font-weight:900;color:var(--accent);margin-top:6px;line-height:1}.payment-methods{display:flex;gap:10px;padding:16px 16px 12px}.pm-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 8px;border-radius:var(--radius);border:2px solid var(--border-light);background:var(--bg-secondary);transition:border-color .15s,background .15s,color .15s;font-weight:700}.pm-btn.active{border-color:var(--accent);background:var(--accent-muted);color:var(--accent)}.pm-btn:not(.active):hover{background:var(--bg-hover)}.pm-icon{font-size:24px;line-height:1}.pm-label{font-size:13px}.cash-calc{padding:0 16px 12px;display:flex;flex-direction:column;gap:10px}.cash-display{display:flex;align-items:center;justify-content:space-between;background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius);padding:10px 14px}.cash-display-label{font-size:13px;color:var(--text-muted);font-weight:600}.cash-display-value{font-size:26px;font-weight:800;color:var(--text-primary)}.cash-presets{display:flex;gap:6px;flex-wrap:wrap}.cash-preset{flex:1;min-width:calc(20% - 5px);padding:8px 4px;border-radius:var(--radius-sm);font-size:13px;font-weight:700;background:var(--bg-secondary);border:1px solid var(--border-light);transition:background .12s,border-color .12s,color .12s;white-space:nowrap}.cash-preset.active{background:var(--accent-muted);border-color:var(--accent);color:var(--accent)}.cash-preset:not(.active):hover{background:var(--bg-hover)}.cash-numpad{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.numpad-key{padding:14px;font-size:20px;font-weight:700;border-radius:var(--radius-sm);background:var(--bg-secondary);border:1px solid var(--border);transition:background .1s}.numpad-key:hover{background:var(--bg-hover)}.numpad-key:active{background:var(--bg-active)}.numpad-key.numpad-clear{color:var(--danger);font-size:14px;font-weight:800}.cash-change{display:flex;align-items:center;justify-content:space-between;background:var(--success-bg);border:1px solid rgba(34,197,94,.3);border-radius:var(--radius);padding:12px 14px}.cash-change.shortage{background:var(--danger-bg);border-color:#ef44444d}.cash-change-label{font-size:14px;font-weight:700;color:var(--text-secondary)}.cash-change-value{font-size:24px;font-weight:900;color:var(--success)}.cash-change.shortage .cash-change-value{color:var(--danger)}.payment-confirm-msg{margin:0 16px 12px;padding:14px 16px;background:var(--accent-muted);border:1px solid rgba(245,158,11,.3);border-radius:var(--radius);font-size:15px;font-weight:600;color:var(--text-primary);text-align:center;line-height:1.6}.payment-confirm-msg strong{color:var(--accent)}.payment-actions{display:flex;gap:10px;padding:12px 16px 20px;border-top:1px solid var(--border);flex-shrink:0}.payment-back-btn{flex:0 0 auto;padding:14px 18px;border-radius:var(--radius-lg);background:var(--bg-secondary);border:1px solid var(--border-light);font-size:15px;font-weight:700;color:var(--text-secondary);transition:background .15s}.payment-back-btn:hover{background:var(--bg-hover)}.payment-complete-btn{flex:1;padding:14px;background:var(--success);color:#000;font-size:16px;font-weight:800;border-radius:var(--radius-lg);transition:background .15s}.payment-complete-btn:hover:not(:disabled){background:#4ade80}.payment-complete-btn:disabled{background:var(--bg-active);color:var(--text-muted);cursor:not-allowed}.payment-complete-btn:disabled:active{transform:none}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes pop{0%{transform:scale(1)}40%{transform:scale(1.4)}to{transform:scale(1)}}.badge-pop{animation:pop .2s ease-out}.manager-view{display:grid;grid-template-columns:1fr 480px;height:100%;overflow:hidden}.manager-left{display:flex;flex-direction:column;overflow:hidden;border-right:1px solid var(--border)}.manager-right{display:flex;flex-direction:column;overflow:hidden;background:var(--bg-secondary)}.manager-sheet-handle,.manager-sheet-close{display:none}.panel-header{padding:14px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.panel-title{font-size:13px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.btn-add{display:flex;align-items:center;gap:6px;padding:7px 14px;background:var(--accent);color:#000;font-size:13px;font-weight:700;border-radius:var(--radius)}.btn-add:hover{background:var(--accent-light)}.btn-add-product{display:flex;align-items:center;gap:5px;padding:9px 16px;background:var(--accent);color:#000;font-size:14px;font-weight:800;border-radius:var(--radius);white-space:nowrap;flex-shrink:0;box-shadow:0 2px 8px #f59e0b4d;transition:background .15s,transform .1s}.btn-add-product:hover{background:var(--accent-light)}.btn-add-product:active{transform:scale(.95)}.manager-filter-bar{display:flex;gap:6px;padding:8px 12px;overflow-x:auto;flex-shrink:0;border-bottom:1px solid var(--border);scrollbar-width:none}.manager-filter-bar::-webkit-scrollbar{display:none}.manager-list{flex:1;overflow-y:auto;padding:8px}.row-header{font-size:11px;font-weight:800;color:var(--accent);letter-spacing:.08em;padding:10px 4px 4px;border-bottom:1px solid var(--border);margin-bottom:2px}.manager-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius);border-bottom:1px solid var(--border);transition:background .1s;cursor:pointer}.manager-item:last-child{border-bottom:none}.manager-item:hover{background:var(--bg-hover)}.manager-item.selected{background:var(--accent-muted);border-color:transparent}.manager-item-emoji{font-size:24px;flex-shrink:0}.manager-item-info{flex:1;min-width:0}.manager-item-name{font-size:14px;font-weight:600}.manager-item-meta{font-size:12px;color:var(--text-muted);margin-top:2px}.manager-item-price{font-size:14px;font-weight:700;color:var(--accent)}.unavailable-badge{font-size:10px;padding:2px 6px;background:var(--danger-bg);color:var(--danger);border-radius:4px;margin-left:6px;font-weight:600}.item-form{flex:1;overflow-y:auto;padding:12px 16px;display:flex;flex-direction:column;gap:11px}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.4px}.form-input{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);padding:10px 12px;color:var(--text-primary);font-size:15px;width:100%;transition:border-color .15s}.form-input:focus{border-color:var(--accent)}.form-select{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);padding:10px 12px;color:var(--text-primary);font-size:15px;width:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none}.form-select:focus{border-color:var(--accent)}.emoji-preview{font-size:40px;text-align:center;padding:8px}.emoji-preview-btn{background:var(--surface2);border:2px dashed var(--border-light);border-radius:12px;cursor:pointer;padding:8px 16px;transition:border-color .15s,background .15s;position:relative;display:inline-flex;align-items:center;gap:6px}.emoji-preview-btn:hover{border-color:var(--accent);background:var(--accent-muted)}.emoji-edit-hint{font-size:14px;opacity:.6}.emoji-picker{position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%);background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:12px;box-shadow:0 8px 24px #0006;z-index:100;width:260px;text-align:left}.emoji-picker-group{margin-bottom:10px}.emoji-picker-group:last-child{margin-bottom:0}.emoji-picker-label{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px}.emoji-picker-grid{display:flex;flex-wrap:wrap;gap:4px}.emoji-picker-item{font-size:22px;width:38px;height:38px;display:flex;align-items:center;justify-content:center;background:var(--surface2);border:2px solid transparent;border-radius:8px;cursor:pointer;transition:background .1s,border-color .1s,transform .1s}.emoji-picker-item:hover{background:var(--accent-muted);transform:scale(1.15)}.emoji-picker-item.selected{border-color:var(--accent);background:var(--accent-muted)}.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:4px 0}.toggle-label{font-size:14px;font-weight:500}.toggle{position:relative;width:46px;height:26px;flex-shrink:0}.toggle input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--bg-active);border-radius:13px;cursor:pointer;transition:background .2s}.toggle-slider:before{content:"";position:absolute;width:20px;height:20px;background:#fff;border-radius:50%;top:3px;left:3px;transition:transform .2s}.toggle input:checked+.toggle-slider{background:var(--accent)}.toggle input:checked+.toggle-slider:before{transform:translate(20px)}.form-actions{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--border);flex-shrink:0}.btn-save{flex:1;padding:12px;border-radius:var(--radius);background:var(--accent);color:#000;font-size:14px;font-weight:800}.btn-save:hover{background:var(--accent-light)}.btn-delete-item{padding:12px 16px;border-radius:var(--radius);background:var(--danger-bg);color:var(--danger);border:1px solid var(--danger-bg);font-size:14px;font-weight:700}.btn-delete-item:hover{background:var(--danger);color:#fff}.form-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-muted);gap:12px;padding:40px;text-align:center}.form-placeholder-icon{font-size:48px;opacity:.3}.backup-manager{border-top:1px solid var(--border);padding:12px 14px;flex-shrink:0;background:#f59e0b08}.backup-manager-title{font-size:11px;font-weight:700;color:var(--text-secondary);letter-spacing:.5px;margin-bottom:4px}.backup-manager-desc{font-size:11px;color:var(--text-muted);line-height:1.5;margin-bottom:10px}.backup-manager-btns{display:flex;gap:8px}.btn-backup,.btn-restore{flex:1;padding:9px 8px;border-radius:var(--radius);font-size:13px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:5px;white-space:nowrap}.btn-backup{background:var(--accent);color:#000}.btn-backup:active{background:var(--accent-dark)}.btn-restore{background:var(--bg-active);color:var(--text-primary);border:1px solid var(--border-light)}.btn-restore:active{background:var(--bg-hover)}.category-manager{border-top:1px solid var(--border);flex-shrink:0;max-height:160px;display:flex;flex-direction:column}.category-list{flex:1;overflow-y:auto;padding:4px 8px}.category-row{display:flex;align-items:center;gap:8px;padding:7px 8px;border-radius:var(--radius-sm)}.category-row:hover{background:var(--bg-hover)}.category-row-name{flex:1;font-size:14px;font-weight:500}.category-edit-input{flex:1;background:var(--bg-primary);border:1px solid var(--accent);border-radius:var(--radius-sm);padding:4px 8px;color:var(--text-primary);font-size:13px}.category-add-row{display:flex;gap:6px;padding:8px;border-top:1px solid var(--border)}.category-add-input{flex:1;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-sm);padding:7px 10px;color:var(--text-primary);font-size:13px}.category-add-input:focus{border-color:var(--accent)}.btn-sm{padding:7px 12px;border-radius:var(--radius-sm);font-size:12px;font-weight:700}.btn-sm-accent{background:var(--accent);color:#000}.btn-sm-accent:hover{background:var(--accent-light)}.btn-sm-ghost{background:var(--bg-card);color:var(--text-secondary);border:1px solid var(--border)}.btn-sm-ghost:hover{background:var(--bg-hover);color:var(--text-primary)}.icon-btn{width:32px;height:32px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--text-muted);background:var(--bg-card);border:1px solid var(--border)}.icon-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.icon-btn.danger:hover{background:var(--danger-bg);color:var(--danger);border-color:var(--danger)}.history-view{display:flex;flex-direction:column;height:100%;overflow:hidden}.history-toolbar{padding:12px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px;flex-shrink:0}.filter-btn{padding:7px 14px;border-radius:var(--radius);font-size:13px;font-weight:600;color:var(--text-secondary);background:var(--bg-card);border:1px solid var(--border)}.filter-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.filter-btn.active{background:var(--accent-muted);color:var(--accent);border-color:var(--accent)}.history-body{flex:1;overflow:hidden;display:grid;grid-template-columns:1fr 280px}.history-orders{overflow-y:auto;padding:12px;border-right:1px solid var(--border)}.history-summary{overflow-y:auto;padding:16px;background:var(--bg-secondary)}.summary-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:14px;margin-bottom:10px}.summary-card-label{font-size:12px;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.4px;margin-bottom:6px}.summary-card-value{font-size:24px;font-weight:800;color:var(--text-primary)}.summary-card-value.accent{color:var(--accent)}.summary-card-sub{font-size:12px;color:var(--text-muted);margin-top:4px}.order-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:8px;overflow:hidden;cursor:pointer}.order-card-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px}.order-id{font-size:13px;font-weight:700;color:var(--text-secondary)}.order-time{font-size:12px;color:var(--text-muted)}.order-total{font-size:16px;font-weight:800;color:var(--accent)}.order-card-body{padding:0 14px 10px;border-top:1px solid var(--border)}.order-card-items{margin-top:8px;display:flex;flex-direction:column;gap:4px}.order-card-item{display:flex;justify-content:space-between;font-size:12px;color:var(--text-secondary)}.history-empty{padding:60px 20px;text-align:center;color:var(--text-muted)}.history-empty-icon{font-size:48px;margin-bottom:12px}.top-items{margin-top:16px}.top-items-title{font-size:12px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.4px;margin-bottom:10px}.top-item-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}.top-item-emoji{font-size:18px;width:24px;text-align:center;flex-shrink:0}.top-item-info{flex:1;min-width:0}.top-item-name{font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.top-item-bar-wrap{background:var(--bg-primary);border-radius:2px;height:4px;margin-top:3px}.top-item-bar{background:var(--accent);height:4px;border-radius:2px;transition:width .3s}.top-item-count{font-size:11px;color:var(--text-muted);flex-shrink:0}.mobile-receipt-bar,.mobile-sheet-overlay{display:none}@media (max-width: 680px){.header{padding:0 12px;height:52px}.header-logo{font-size:18px}.header-nav-btn{padding:6px 10px;font-size:12px;gap:3px}.header-nav-btn span:first-child{font-size:14px}.header-time{display:none}.sync-bar{padding:5px 12px;gap:6px}.sync-bar-btn{font-size:12px;padding:5px 10px}.sync-bar-msg{font-size:11px}.sync-status-label{display:none}.role-badge{font-size:13px;padding:4px 8px}.role-dropdown{right:0;min-width:140px}.main-content{height:calc(100dvh - 88px)}.register-view{grid-template-columns:1fr;padding-bottom:64px}.receipt-side{display:none}.menu-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:8px}.menu-card{padding:10px 6px;border-radius:10px}.menu-card-emoji{font-size:28px}.menu-card-name{font-size:11px}.menu-card-price{font-size:12px}.menu-card-badge{width:20px;height:20px;font-size:11px;top:4px;right:4px}.category-tab{padding:6px 10px;font-size:12px}.mobile-receipt-bar{display:flex;align-items:center;gap:10px;position:fixed;bottom:0;left:0;right:0;height:64px;background:var(--bg-card);border-top:1px solid var(--border);padding:0 16px;cursor:pointer;z-index:50;box-shadow:0 -4px 16px #0000004d}.mobile-receipt-bar:active{background:var(--bg-hover)}.mobile-bar-label{font-size:14px;font-weight:700;color:var(--text-primary);flex:1}.mobile-bar-count{font-size:13px;color:var(--text-muted)}.mobile-bar-total{font-size:18px;font-weight:800;color:var(--accent)}.mobile-bar-arrow{font-size:24px;color:var(--text-muted);font-weight:300}.mobile-bar-new{margin-left:auto;background:var(--accent);color:#000;border:none;border-radius:var(--radius);padding:8px 16px;font-size:14px;font-weight:700;cursor:pointer}.mobile-sheet-overlay{display:flex;align-items:flex-end;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:200;animation:fadeIn .15s ease}.mobile-sheet{width:100%;height:88dvh;background:var(--bg-secondary);border-radius:20px 20px 0 0;display:flex;flex-direction:column;overflow:hidden;animation:slideUp .25s ease}.mobile-sheet-header{display:flex;align-items:center;gap:8px;padding:8px 12px;border-bottom:1px solid var(--border);flex-shrink:0;flex-wrap:wrap}.mobile-sheet-drag{width:40px;height:4px;background:var(--border);border-radius:2px;margin:0 auto 4px;flex-basis:100%}.mobile-sheet-tabs{display:flex;gap:6px;flex-wrap:wrap;flex:1}.mobile-sheet-close{width:32px;height:32px;border-radius:50%;background:var(--surface2);border:none;font-size:16px;color:var(--text-muted);cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center}.mobile-sheet-body{flex:1;overflow:hidden;display:flex;flex-direction:column}.mobile-sheet-body .receipt-panel{flex:1;display:flex;flex-direction:column;overflow:hidden}.manager-view{display:flex!important;flex-direction:column;position:relative}.manager-left{flex:1;height:100%;border-right:none}.manager-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:99}.manager-right{display:none}.manager-view.form-open .manager-right{display:flex;position:fixed;bottom:0;left:0;right:0;height:88dvh;background:var(--bg-secondary);border-radius:20px 20px 0 0;border-top:1px solid var(--border);z-index:100;animation:slideUp .25s ease;overflow-y:auto}.manager-sheet-handle{display:block;width:40px;height:4px;background:var(--border);border-radius:2px;margin:10px auto 0;flex-shrink:0}.manager-sheet-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;background:var(--surface2);border:none;font-size:16px;color:var(--text-muted);cursor:pointer;flex-shrink:0}.history-body{grid-template-columns:1fr}.history-orders{border-right:none;border-bottom:1px solid var(--border);max-height:55vh}.history-summary{max-height:45vh}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.kitchen-view{flex:1;padding:12px;display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:12px;overflow-y:auto;align-content:start}.kitchen-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:var(--text-muted)}.kitchen-empty-icon{font-size:52px}.kitchen-empty-text{font-size:18px;font-weight:700;color:var(--text-secondary)}.kitchen-empty-sub{font-size:13px}.kitchen-card{background:var(--bg-card);border:2px solid var(--border-light);border-radius:var(--radius-lg);padding:14px 14px 16px;display:flex;flex-direction:column;gap:8px;transition:border-color .25s,opacity .25s}.kitchen-card.all-done{border-color:var(--success);opacity:.55}.kitchen-card-head{display:flex;align-items:center;justify-content:space-between;padding-bottom:8px;border-bottom:1px solid var(--border)}.kitchen-ticket-no{font-size:13px;font-weight:800;color:var(--text-muted);letter-spacing:.3px}.kitchen-badge{font-size:12px;font-weight:700;padding:3px 9px;border-radius:6px}.kitchen-badge.pending{background:var(--accent-muted);color:var(--accent)}.kitchen-badge.done{background:var(--success-bg);color:var(--success)}.kitchen-label{font-size:22px;font-weight:800;color:var(--text-primary);line-height:1.2;padding-bottom:2px}.kitchen-items{display:flex;flex-direction:column;gap:6px}.kitchen-item{padding:10px 12px;border-radius:var(--radius);background:var(--bg-hover);cursor:pointer;transition:opacity .2s,background .15s;-webkit-tap-highlight-color:transparent}.kitchen-item:active{transform:scale(.97)}.kitchen-item.served{opacity:.35;background:transparent}.kitchen-item-row{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}.kitchen-item-name{font-size:19px;font-weight:700;color:var(--text-primary);line-height:1.35}.kitchen-item.served .kitchen-item-name{text-decoration:line-through;color:var(--text-muted)}.kitchen-item-size{font-size:13px;font-weight:700;color:var(--accent);background:var(--accent-muted);padding:1px 7px;border-radius:4px;white-space:nowrap}.kitchen-item.served .kitchen-item-size{opacity:.4}.kitchen-item-tops{font-size:13px;color:var(--text-muted);margin-top:3px;padding-left:2px}.kitchen-item.served .kitchen-item-tops{text-decoration:line-through}.kitchen-card-total{margin-top:4px;padding-top:10px;border-top:1px solid var(--border);font-size:13px;font-weight:600;color:var(--text-muted);text-align:right}.kitchen-card-total-amount{font-size:18px;font-weight:800;color:var(--accent)}@media (max-width: 600px){.kitchen-view{grid-template-columns:repeat(2,1fr);padding:10px 10px 16px;gap:10px}.kitchen-label{font-size:18px}.kitchen-item-name{font-size:16px}.kitchen-item{padding:9px 10px}}.pdf-export-btn{margin-left:auto;display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:var(--radius);background:var(--bg-card);border:1px solid var(--border-light);color:var(--text-secondary);font-size:13px;font-weight:600;transition:background .15s,color .15s,border-color .15s}.pdf-export-btn:hover{background:var(--accent-muted);color:var(--accent);border-color:var(--accent)}.pdf-export-btn:disabled{opacity:.35;pointer-events:none}.item-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:300;padding:16px;animation:fadeIn .15s ease}.item-modal{background:var(--bg-secondary);border-radius:var(--radius-lg);width:100%;max-width:480px;max-height:90dvh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 20px 60px #0009;animation:fadeIn .15s ease}.item-modal-header{display:flex;align-items:center;gap:12px;padding:16px 16px 14px;border-bottom:1px solid var(--border);flex-shrink:0}.item-modal-emoji{font-size:32px;line-height:1}.item-modal-title{flex:1}.item-modal-name{font-size:17px;font-weight:700}.item-modal-price{font-size:13px;color:var(--accent);margin-top:2px}.item-modal-close{width:32px;height:32px;border-radius:50%;background:var(--bg-hover);color:var(--text-muted);font-size:14px;display:flex;align-items:center;justify-content:center}.item-modal-section{padding:14px 16px;border-bottom:1px solid var(--border);flex-shrink:0}.item-modal-label{font-size:12px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px;display:flex;align-items:center;gap:8px}.item-modal-note{font-size:11px;font-weight:500;color:var(--text-muted);text-transform:none;letter-spacing:0;background:var(--bg-hover);padding:2px 7px;border-radius:4px}.item-modal-sizes{display:flex;gap:8px;flex-wrap:wrap}.size-btn{padding:8px 18px;border-radius:var(--radius);border:1px solid var(--border-light);background:var(--bg-card);color:var(--text-secondary);font-size:14px;font-weight:600;transition:background .12s,color .12s,border-color .12s}.size-btn.active{background:var(--accent);color:#000;border-color:var(--accent)}.size-btn:active{transform:scale(.94)}.item-modal-toppings{display:flex;flex-wrap:wrap;gap:7px;max-height:180px;overflow-y:auto}.topping-btn{padding:7px 13px;border-radius:20px;border:1px solid var(--border-light);background:var(--bg-card);color:var(--text-secondary);font-size:13px;font-weight:500;transition:background .12s,color .12s,border-color .12s;white-space:nowrap}.topping-btn.active{background:var(--accent-muted);color:var(--accent-light);border-color:var(--accent)}.topping-btn:active{transform:scale(.93)}.topping-check{font-size:11px}.item-modal-actions{display:flex;gap:10px;padding:14px 16px;flex-shrink:0}.item-modal-cancel{flex:1;padding:12px;border-radius:var(--radius);background:var(--bg-hover);color:var(--text-secondary);font-size:15px;font-weight:600}.item-modal-confirm{flex:2;padding:12px;border-radius:var(--radius);background:var(--accent);color:#000;font-size:15px;font-weight:700}.item-modal-confirm:active{transform:scale(.97)}.item-modal-confirm-note{font-size:12px;font-weight:600;opacity:.75;margin-left:4px}.ri-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.ri-info .ri-name{flex:unset}.ri-options{display:flex;flex-wrap:wrap;align-items:center;gap:4px;margin-top:1px}.ri-size-tag{font-size:10px;font-weight:700;background:var(--accent-muted);color:var(--accent);padding:1px 6px;border-radius:4px;white-space:nowrap}.ri-toppings-text{font-size:10px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.order-card-item-name{display:flex;flex-direction:column;gap:2px}@media (max-width: 600px){.item-modal-overlay{align-items:flex-end;padding:0}.item-modal{max-width:100%;border-radius:20px 20px 0 0;max-height:92dvh;animation:slideUp .25s ease}}
