@import"https://fonts.googleapis.com/css2?family=Nunito:wght@400;500;600;700;800&display=swap";:root{--color-mint: #F0FDF9;--color-mint-dark: #D1FAE5;--color-teal: #0D9488;--color-teal-dark: #0F766E;--color-emerald: #10B981;--color-emerald-light: #6EE7B7;--color-green: #6BCB77;--color-green-light: #C7F2CC;--color-purple: #6B5B95;--color-orange: #FF914D;--color-red: #FF6B6B;--bg-primary: var(--color-mint);--bg-secondary: var(--color-mint-dark);--bg-card: #ffffff;--text-primary: var(--color-teal-dark);--text-secondary: #475569;--text-muted: #94a3b8;--border-color: var(--color-teal);--border-light: #e2e8f0;--accent-primary: var(--color-teal);--accent-safe: var(--color-green);--accent-warning: var(--color-orange);--accent-danger: var(--color-red);--accent-emerald: var(--color-emerald);--crosshatch-shadow: repeating-linear-gradient(45deg, var(--color-teal), var(--color-teal) 2px, transparent 2px, transparent 6px), repeating-linear-gradient(-45deg, var(--color-teal), var(--color-teal) 2px, transparent 2px, transparent 6px);--font-main: "Nunito", system-ui, sans-serif;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--shadow-button: 4px 4px 0 var(--color-teal);--shadow-button-hover: 2px 2px 0 var(--color-teal)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-main);font-size:15px;line-height:1.5;color:var(--text-primary);background:var(--bg-primary);min-height:100vh;-webkit-font-smoothing:antialiased}.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:12px 24px;font-family:var(--font-main);font-size:.95rem;font-weight:700;color:var(--text-primary);background:var(--bg-card);border:2px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease;transform:translate(-4px,-4px);box-shadow:var(--shadow-button)}.btn:hover{transform:translate(-2px,-2px);box-shadow:var(--shadow-button-hover)}.btn:active{transform:translate(0);box-shadow:0 0 0 var(--color-navy)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.btn-primary{background:var(--accent-yellow);color:var(--color-navy);border-color:var(--color-navy)}.btn-primary:hover{background:var(--color-yellow-dark)}.btn-success{background:var(--accent-safe);color:#fff;border-color:var(--color-navy)}.btn-success:hover{background:#5ab867}.btn-teal{background:var(--color-teal);color:#fff;border-color:var(--color-teal-dark);box-shadow:4px 4px 0 var(--color-teal-dark)}.btn-teal:hover{background:var(--color-teal-dark);box-shadow:2px 2px 0 var(--color-teal-dark)}.btn-navy{background:var(--color-teal-dark);color:#fff;border-color:var(--color-teal-dark)}.btn-navy:hover{background:#115e59}.btn-danger{background:var(--accent-danger);color:#fff;border-color:var(--color-navy)}.btn-danger:hover{background:#e55a5a}.btn-ghost{background:transparent;border-color:transparent;box-shadow:none;transform:none}.btn-ghost:hover{background:var(--bg-secondary);transform:none;box-shadow:none}.btn-lg{padding:16px 32px;font-size:1rem}.btn-sm{padding:8px 14px;font-size:.85rem;transform:translate(-2px,-2px);box-shadow:2px 2px 0 var(--color-navy)}.btn-sm:hover{transform:translate(-1px,-1px);box-shadow:1px 1px 0 var(--color-navy)}.btn-icon{padding:10px}.btn-full{width:100%}.menu-item{position:relative;background:var(--bg-card);border:2px solid var(--border-light);border-radius:var(--radius-md);padding:var(--space-md);cursor:pointer;transition:all .15s ease;box-shadow:0 1px 3px #0000000a}.menu-item:hover{border-color:var(--border-color);transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.menu-item.selected{background:#dcfce7;border-color:var(--accent-safe)}.menu-item.has-allergens{border-color:var(--accent-warning);background:#fffbeb}.menu-item.blocked{background:#fef2f2;border-color:var(--accent-danger)}.menu-item.disabled{opacity:.6;cursor:not-allowed;background:#f8f8f8;border-color:#e0e0e0}.menu-item.disabled:hover{transform:none;box-shadow:0 1px 3px #0000000a;border-color:#e0e0e0}.menu-item-name{display:flex;align-items:center;justify-content:space-between;font-weight:600;font-size:.95rem}.menu-item-desc{color:var(--text-muted);font-size:.8rem;margin-top:4px}.menu-item-price{font-weight:800;font-size:1.05rem;color:var(--color-navy);margin-top:var(--space-sm)}.allergens{display:flex;flex-wrap:wrap;gap:4px;margin-top:var(--space-sm)}.allergen-badge{padding:3px 8px;font-size:.7rem;font-weight:700;text-transform:uppercase;border-radius:6px;display:inline-flex;align-items:center;gap:4px;border:1.5px solid transparent;transition:all .15s ease}.allergen-badge.contains{background:#fef2f2;color:#dc2626;border-color:#fca5a5}.allergen-badge.may-contain{background:#fffbeb;color:#d97706;border-color:#fcd34d}.allergen-badge.traces{background:var(--bg-secondary);color:var(--text-muted);border-color:var(--border-light);cursor:pointer}.allergen-badge.traces:hover{background:var(--bg-card);border-color:var(--border-color)}.allergen-badge.safe{background:var(--bg-secondary);color:var(--text-muted);border-color:var(--border-light);cursor:pointer}.allergen-badge.safe:hover{background:#fef2f2;color:#dc2626;border-color:#fca5a5}.allergen-badge.may-contain{background:#fffbeb;color:#b45309}.allergen-badge.traces{background:var(--bg-secondary);color:var(--text-muted)}.order-panel{background:var(--bg-card);border:2px solid var(--border-color);border-radius:var(--radius-lg);display:flex;flex-direction:column;height:calc(100vh - 280px);max-height:calc(100vh - 280px);position:sticky;top:var(--space-lg);box-shadow:0 4px 20px #00000014;overflow:hidden}.order-header{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md);border-bottom:2px solid var(--border-light);font-weight:600;flex-shrink:0}.order-items{flex:1;overflow-y:auto;padding:var(--space-md);min-height:0}.order-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm) 0;border-bottom:1px solid var(--border-light)}.order-item:last-child{border-bottom:none}.order-total{padding:var(--space-lg);border-top:2px solid var(--border-color);font-size:1.3rem;font-weight:700;display:flex;justify-content:space-between;background:var(--bg-secondary);border-radius:0 0 var(--radius-lg) var(--radius-lg);flex-shrink:0}.progress-container{flex:1}.progress-info{display:flex;justify-content:space-between;margin-bottom:8px;font-size:.8rem;font-weight:600;color:var(--text-secondary)}.progress-bar-wrapper{height:8px;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:6px;overflow:hidden}.progress-bar-fill{height:100%;background:var(--color-yellow);border-radius:4px;transition:width .4s cubic-bezier(.4,0,.2,1);position:relative}.progress-bar-fill:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.3) 50%,transparent 100%);animation:shimmer 1.5s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.progress-bar-fill.complete{background:var(--color-green)}.progress-bar-fill.complete:after{animation:none;background:none}.app-container{display:flex;flex-direction:column;height:100vh;overflow:hidden}.main-content{flex:1;display:grid;grid-template-columns:1fr 360px;gap:var(--space-lg);padding:var(--space-lg);padding-bottom:100px;overflow:hidden;min-height:0}.menu-section{display:flex;flex-direction:column;min-height:0;overflow:hidden}.menu-search{display:flex;gap:var(--space-md);margin-bottom:var(--space-md)}.menu-search .input{flex:1}.menu-grid-wrapper{flex:1;overflow-y:auto;padding-right:var(--space-sm)}.menu-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:var(--space-md);align-content:start}.header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md) var(--space-xl);background:var(--bg-card);border-bottom:2px solid var(--border-color)}.header-left{display:flex;align-items:center;gap:var(--space-xl)}.logo{display:flex;align-items:center;gap:var(--space-sm);font-size:1.3rem;font-weight:800}.logo-icon{color:var(--accent-safe);font-size:1.5rem}.epos-toggle{display:flex;background:var(--bg-secondary);border-radius:var(--radius-md);padding:3px}.epos-toggle-btn{padding:8px 18px;font-size:.85rem;font-weight:600;border:none;background:transparent;border-radius:var(--radius-sm);cursor:pointer;color:var(--text-muted);transition:all .15s ease}.epos-toggle-btn.active{background:var(--bg-card);color:var(--text-primary);box-shadow:0 1px 4px #0000001a}.safety-badge{display:flex;align-items:center;gap:10px;padding:8px 14px;background:var(--bg-card);border:2px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease;transform:translate(-2px,-2px);box-shadow:2px 2px 0 var(--color-navy)}.safety-badge:hover{transform:translate(-1px,-1px);box-shadow:1px 1px 0 var(--color-navy)}.safety-badge:active{transform:translate(0);box-shadow:none}.safety-badge-content{display:flex;flex-direction:column;align-items:flex-start;line-height:1.2}.safety-badge-label{font-size:.65rem;font-weight:600;text-transform:uppercase;color:var(--text-muted);letter-spacing:.5px}.safety-badge-value{font-size:.85rem;font-weight:800}.customer-selector{display:flex;align-items:center;gap:12px;padding:8px 14px 8px 10px;background:var(--bg-card);border:2px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease;transform:translate(-2px,-2px);box-shadow:2px 2px 0 var(--color-navy);min-width:180px}.customer-selector:hover{transform:translate(-1px,-1px);box-shadow:1px 1px 0 var(--color-navy);background:var(--bg-secondary)}.customer-selector:active{transform:translate(0);box-shadow:none}.customer-selector-icon{width:36px;height:36px;background:var(--bg-secondary);border:2px solid var(--border-light);border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.customer-selector-info{flex:1;text-align:left;line-height:1.2}.customer-selector-name{font-weight:700;font-size:.9rem;color:var(--text-primary)}.customer-selector-warning{font-size:.7rem;font-weight:600;color:var(--accent-danger);display:flex;align-items:center;gap:4px;margin-top:2px}.sp-avatar{transition:transform .15s ease}.customer-badge{display:flex;align-items:center;gap:var(--space-sm);padding:8px 14px;background:var(--bg-card);border:2px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease}.customer-badge:hover{background:var(--bg-secondary)}.customer-avatar{width:36px;height:36px;background:linear-gradient(135deg,var(--accent-primary) 0%,#a855f7 100%);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700}.customer-info{text-align:left}.customer-name{font-weight:600;font-size:.9rem}.customer-allergens{font-size:.75rem;color:var(--accent-danger);display:flex;align-items:center;gap:3px}.category-tabs{display:flex;gap:var(--space-sm);padding:var(--space-md) var(--space-xl);background:var(--bg-secondary);border-bottom:2px solid var(--border-color);overflow-x:auto}.category-tab{padding:10px 18px;font-size:.9rem;font-weight:600;background:var(--bg-card);border:2px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;transition:all .15s ease}.category-tab:hover{background:var(--bg-secondary)}.category-tab.active{background:var(--color-navy);color:#fff;border-color:var(--color-navy)}.bottom-bar{position:fixed;bottom:0;left:0;right:0;display:flex;align-items:center;gap:var(--space-xl);padding:var(--space-md) var(--space-xl);background:var(--bg-card);border-top:2px solid var(--border-color);z-index:100;box-shadow:0 -4px 20px #0000001a}.bottom-action{flex-shrink:0}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:var(--bg-card);border:2px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-lg);max-width:440px;width:92%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 50px #0003}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg)}.modal-title{display:flex;align-items:center;gap:var(--space-sm);font-size:1.25rem;font-weight:700}.modal-close{background:var(--bg-secondary);border:none;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer}.modal-close:hover{background:var(--accent-danger);color:#fff}.input-group{margin-bottom:var(--space-md)}.input-label{display:block;margin-bottom:6px;font-weight:600;font-size:.85rem}.input{width:100%;padding:12px 14px;font-size:1rem;font-family:var(--font-main);border:2px solid var(--border-color);border-radius:var(--radius-md);transition:border-color .15s}.input:focus{outline:none;border-color:var(--accent-primary)}.input-error{border-color:var(--accent-danger)}.alert{display:flex;gap:var(--space-md);padding:var(--space-md);border-radius:var(--radius-md);margin-bottom:var(--space-md);border-width:2px;border-style:solid;transform:translate(-2px,-2px);box-shadow:2px 2px 0 currentColor}.alert-icon{flex-shrink:0;width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center}.alert-content{flex:1}.alert-title{font-weight:700;margin-bottom:4px;font-size:.95rem}.alert-text{font-size:.85rem;opacity:.9}.alert-danger{background:#fef2f2;border-color:#dc2626;color:#991b1b;box-shadow:2px 2px #dc2626}.alert-danger .alert-icon{background:#dc2626;color:#fff}.alert-warning{background:#fffbeb;border-color:#d97706;color:#92400e;box-shadow:2px 2px #d97706}.alert-warning .alert-icon{background:#d97706;color:#fff}.alert-success{background:#ecfdf5;border-color:var(--color-green);color:#065f46;box-shadow:2px 2px 0 var(--color-green)}.alert-success .alert-icon{background:var(--color-green);color:#fff}.alert-info{background:#eff6ff;border-color:#3b82f6;color:#1e40af;box-shadow:2px 2px #3b82f6}.alert-info .alert-icon{background:#3b82f6;color:#fff}.invoice{background:#fff;padding:var(--space-lg);border:2px dashed var(--border-color);border-radius:var(--radius-md);margin-bottom:var(--space-md)}.invoice-header{text-align:center;border-bottom:2px dashed var(--border-color);padding-bottom:var(--space-md);margin-bottom:var(--space-md)}.invoice-logo{font-size:1.2rem;font-weight:800;display:flex;align-items:center;justify-content:center;gap:var(--space-sm)}.invoice-item{display:flex;justify-content:space-between;padding:4px 0;font-size:.9rem}.invoice-divider{border:none;border-top:2px dashed var(--border-color);margin:var(--space-md) 0}.invoice-total{display:flex;justify-content:space-between;font-size:1.2rem;font-weight:700}@media print{@page{size:auto;margin:15mm}.no-print,button,.modal-close,.modal-header{display:none!important}.modal-overlay{background:transparent!important}.modal{box-shadow:none!important;border:none!important;background:#fff!important;max-width:600px!important;margin:0 auto!important}#invoice-print{width:100%;color:#000;font-size:14px}.invoice-item{display:flex;justify-content:space-between;padding:4px 0}.invoice-total{font-weight:700;font-size:16px}.invoice-header{text-align:center;margin-bottom:12px}.invoice-divider{margin:8px 0;border-top:2px dashed #000}}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-xl);color:var(--text-muted)}.spinner{width:32px;height:32px;border:3px solid var(--border-light);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.animate-spin{animation:spin 1s linear infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmerBackground{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes shimmerSlide{0%{left:-100%}to{left:200%}}.text-center{text-align:center}.text-danger{color:var(--accent-danger)}.text-warning{color:var(--accent-warning)}.text-success{color:var(--accent-safe)}.text-muted{color:var(--text-muted)}.mt-sm{margin-top:var(--space-sm)}.mt-md{margin-top:var(--space-md)}.mt-lg{margin-top:var(--space-lg)}.mb-sm{margin-bottom:var(--space-sm)}.mb-md{margin-bottom:var(--space-md)}.mb-lg{margin-bottom:var(--space-lg)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.cover-tabs{background:var(--bg-secondary);border-bottom:2px solid var(--border-color);padding:12px var(--space-xl)}.cover-tabs-scroll{display:flex;gap:10px;overflow-x:auto;padding-bottom:4px}.cover-tabs-scroll::-webkit-scrollbar{height:4px}.cover-tabs-scroll::-webkit-scrollbar-track{background:transparent}.cover-tabs-scroll::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:2px}.cover-tab{display:flex;align-items:center;gap:10px;padding:10px 16px;background:var(--bg-card);border:2px solid var(--border-light);border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease;white-space:nowrap;min-width:fit-content}.cover-tab:hover{border-color:var(--color-navy);background:#f8fafc}.cover-tab.active{background:var(--color-navy);border-color:var(--color-navy);color:#fff;transform:translate(-2px,-2px);box-shadow:2px 2px 0 var(--color-navy-light)}.cover-tab-avatar{width:28px;height:28px;border-radius:50%;background:var(--bg-secondary);border:2px solid var(--border-light);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.8rem;color:var(--text-muted);flex-shrink:0}.cover-tab.active .cover-tab-avatar{background:var(--color-yellow);border-color:var(--color-yellow);color:var(--color-navy)}.cover-tab-info{display:flex;flex-direction:column;align-items:flex-start;gap:2px}.cover-tab-name{font-weight:700;font-size:.9rem;display:flex;align-items:center;gap:4px}.cover-tab-warning{color:var(--accent-warning)}.cover-tab.active .cover-tab-warning{color:var(--color-yellow)}.cover-tab-items{font-size:.7rem;display:flex;align-items:center;gap:3px;opacity:.7}.cover-tab-allergens{display:flex;gap:4px;margin-left:auto}.cover-allergen-badge{padding:2px 6px;font-size:.6rem;font-weight:700;text-transform:uppercase;background:#fef2f2;color:#dc2626;border-radius:4px}.cover-tab.active .cover-allergen-badge{background:#fff3;color:#fff}.cover-allergen-badge.more{background:var(--bg-secondary);color:var(--text-muted)}.cover-tab.active .cover-allergen-badge.more{background:#fff3;color:#fff}.table-info-badge{display:flex;align-items:center;gap:12px;padding:8px 16px;background:var(--bg-card);border:2px solid var(--color-navy);border-radius:var(--radius-md);transform:translate(-2px,-2px);box-shadow:2px 2px 0 var(--color-navy)}.table-info-icon{width:36px;height:36px;background:var(--color-navy);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff}.table-info-content{display:flex;flex-direction:column}.table-info-name{font-weight:800;font-size:1rem;color:var(--color-navy)}.table-info-covers{font-size:.75rem;color:var(--text-muted);display:flex;align-items:center;gap:4px}.ordering-for{display:flex;align-items:center;gap:8px;padding:8px 14px;background:#eff6ff;border:2px solid #3b82f6;border-radius:var(--radius-md);font-size:.85rem;font-weight:600;color:#1e40af}.ordering-for-name{font-weight:800}.ordering-for-allergens{display:flex;gap:4px;margin-left:4px}.ordering-for-allergen{padding:2px 6px;font-size:.65rem;font-weight:700;text-transform:uppercase;background:#fef2f2;color:#dc2626;border-radius:4px}.theme-access{--color-access-primary: #0EA5E9;--color-access-dark: #0284C7;--color-access-darker: #0369A1;--color-access-light: #38BDF8;--color-access-bg: #F0F9FF;--color-access-bg-dark: #E0F2FE;--color-yellow: var(--color-access-primary);--color-yellow-dark: var(--color-access-dark);--accent-yellow: var(--color-access-primary);--bg-primary: var(--color-access-bg);--bg-secondary: var(--color-access-bg-dark)}.theme-access .btn-primary{background:var(--color-access-primary);color:#fff}.theme-access .btn-primary:hover{background:var(--color-access-dark)}.theme-access .category-tab.active,.theme-access .cover-tab.active{background:var(--color-access-primary);border-color:var(--color-access-primary)}.theme-access .cover-tab.active .cover-tab-avatar{background:var(--color-access-light);border-color:var(--color-access-light);color:var(--color-access-darker)}.theme-access .progress-bar-fill{background:var(--color-access-primary)}.theme-access .logo-icon{color:var(--color-access-primary)}.theme-access .header{border-bottom-color:var(--color-access-dark)}.theme-access .category-tabs,.theme-access .cover-tabs{background:var(--color-access-bg-dark);border-bottom-color:var(--color-access-dark)}.theme-access .bottom-bar{border-top-color:var(--color-access-dark)}.theme-access .order-panel{border-color:var(--color-access-dark)}.theme-access .order-total{background:var(--color-access-bg-dark);border-top-color:var(--color-access-dark)}.theme-access .table-info-badge{border-color:var(--color-access-dark);box-shadow:2px 2px 0 var(--color-access-dark)}.theme-access .table-info-icon{background:var(--color-access-primary)}.theme-access .table-info-name{color:var(--color-access-dark)}.theme-access .epos-toggle-btn.active{background:var(--color-access-primary);color:#fff}.theme-access .btn{box-shadow:4px 4px 0 var(--color-access-dark)}.theme-access .btn:hover,.theme-access .btn-sm{box-shadow:2px 2px 0 var(--color-access-dark)}.theme-access .btn-sm:hover{box-shadow:1px 1px 0 var(--color-access-dark)}.theme-access .customer-selector{box-shadow:2px 2px 0 var(--color-access-dark)}.theme-access .customer-selector:hover{box-shadow:1px 1px 0 var(--color-access-dark)}.theme-access .safety-badge{box-shadow:2px 2px 0 var(--color-access-dark)}.theme-access .safety-badge:hover{box-shadow:1px 1px 0 var(--color-access-dark)}.access-evo-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;background:linear-gradient(135deg,#0ea5e9,#0284c7);color:#fff;font-weight:800;font-size:.7rem;border-radius:6px;text-transform:uppercase;letter-spacing:.5px}
