:root{--bg-primary:#fbfaf7;--bg-secondary:#f4f1ea;--bg-tertiary:#ece7dd;--surface:#fff;--text-primary:#2d2a25;--text-secondary:#706b65;--text-tertiary:#9b958e;--accent:#c67b4b;--accent-hover:#b0683e;--accent-light:#fdf0e7;--info:#3b82f6;--info-light:#eff6ff;--success:#6b9b57;--success-light:#edf5e8;--danger:#d95555;--danger-light:#fef0f0;--warning:#d4a843;--warning-light:#fdf5e4;--border:#e8e3dc;--border-light:#f2eee8;--shadow-sm:0 1px 3px #0000000a;--shadow-md:0 4px 16px #0000000f;--shadow-lg:0 12px 40px #00000014;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--font-display:"Nunito", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-body:"Nunito", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}*,:before,:after{box-sizing:border-box}body{font-family:var(--font-body);color:var(--text-primary);background-color:var(--bg-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;margin:0;font-size:16px;font-weight:500;line-height:1.6}body:before{content:"";z-index:0;pointer-events:none;opacity:.035;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");background-repeat:repeat;background-size:256px 256px;position:fixed;inset:0}#root{z-index:1;position:relative}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);color:var(--text-primary);margin-top:0;font-weight:700;line-height:1.25}h1{letter-spacing:-.02em;font-size:2rem;font-weight:800}h2{letter-spacing:-.01em;font-size:1.6rem;font-weight:700}h3{font-size:1.25rem;font-weight:700}h4{font-size:1.05rem;font-family:var(--font-body);font-weight:700}p{margin:0 0 .75rem}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}.app-container{max-width:1200px;margin:0 auto;padding:1.75rem 1.5rem}.main-content-layout{grid-template-columns:1fr;gap:2rem;display:grid}@media (width>=900px){.main-content-layout.has-cart{grid-template-columns:1fr 340px}}.nav-bar{border-bottom:1px solid var(--border);flex-direction:column;align-items:stretch;margin-bottom:2rem;padding-bottom:0;display:flex}.nav-bar-container{justify-content:space-between;align-items:center;gap:1.5rem;width:100%;max-width:1200px;margin:0 auto;padding:0 1.5rem 1.25rem;display:flex}@media (width>=769px){.nav-bar{-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-light);z-index:1000;height:auto;min-height:76px;box-shadow:var(--shadow-sm);background:#fbfaf7d9;flex-direction:column;justify-content:center;margin-bottom:0;padding-bottom:0;display:flex;position:sticky;top:0;left:0;right:0}.nav-bar-container{align-items:center;height:76px;padding:0 1.5rem;display:flex}.app-container{padding:1.75rem 1.5rem}}.header-controls{flex:1;align-items:center;gap:.75rem;max-width:500px;margin:0 1.5rem;display:flex}.header-search-wrapper{flex:1;align-items:center;display:flex;position:relative}.header-search-wrapper .search-icon{color:var(--text-tertiary);pointer-events:none;z-index:5;position:absolute;left:.85rem}.header-search-wrapper .search-icon.clear-icon{pointer-events:auto}.header-search-wrapper .search-input{width:100%;height:40px;font-family:var(--font-body);background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-sm);color:var(--text-primary);outline:none;padding:0 2.5rem;font-size:.9rem;font-weight:500;transition:border-color .2s,background-color .2s,box-shadow .2s}.header-search-wrapper .search-input:focus{background:var(--surface);border-color:var(--accent);box-shadow:0 0 0 3px #c67b4b1a}.search-refresh-btn{width:24px;height:24px;color:var(--text-tertiary);cursor:pointer;z-index:5;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:0;transition:background-color .2s,color .2s;display:flex;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.search-refresh-btn:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.search-refresh-btn.parsing{color:var(--accent)}.search-refresh-btn.failed{color:var(--danger)}.spinning-icon{animation:1.5s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.order-3d-button{cursor:pointer;box-sizing:border-box;border:none;border-radius:50%;outline:none;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;padding:0;transition:transform .1s,background .2s,box-shadow .2s,border-color .2s,color .2s;display:flex;position:relative}.order-3d-inner{box-sizing:border-box;border:1px solid #ffffff40;border-radius:50%;justify-content:center;align-items:center;width:100%;height:100%;display:flex}.order-3d-button.add-to-cart{color:#fff;background:linear-gradient(135deg,#d48c5c 0%,#b56838 100%);border:1px solid #9c5227;box-shadow:0 3px #7a3d1a,0 4px 8px #b5683840,inset 0 1.5px #ffffff73}.order-3d-button.add-to-cart:active{transform:translateY(3px)!important;box-shadow:0 0 #7a3d1a,0 1px 3px #b568384d,inset 0 1.5px #ffffff73!important}.order-3d-button.ordered{color:#fff;background:linear-gradient(135deg,#7cb342 0%,#558b2f 100%);border:1px solid #4e7b26;box-shadow:0 3px #3e6a1f,0 4px 8px #6b9b5740,inset 0 1.5px #ffffff59}.order-3d-button.ordered:active{transform:translateY(3px)!important;box-shadow:0 0 #3e6a1f,0 1px 3px #6b9b574d,inset 0 1.5px #ffffff59!important}.order-3d-button.locked,.order-3d-button:disabled{color:var(--text-tertiary)!important;cursor:not-allowed!important;background:linear-gradient(135deg,#f4f1ea 0%,#ece7dd 100%)!important;border:1px solid #dfd9d0!important;transform:none!important;box-shadow:0 3px #cdc6bc,0 2px 4px #00000008,inset 0 1.5px #ffffffe6!important}.order-3d-button.locked:active,.order-3d-button:disabled:active{transform:none!important;box-shadow:0 3px #cdc6bc,0 2px 4px #00000008,inset 0 1.5px #ffffffe6!important}.order-badge-count{background:var(--danger);color:#fff;border:2px solid var(--surface);min-width:20px;height:20px;box-shadow:var(--shadow-sm);z-index:12;border-radius:50%;justify-content:center;align-items:center;padding:0 4px;font-size:.72rem;font-weight:700;display:flex;position:absolute;top:-6px;right:-6px}.garnish-3d-button{cursor:pointer;box-sizing:border-box;border:none;border-radius:50%;outline:none;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;padding:0;transition:background .2s,box-shadow .2s,border-color .2s,color .2s;display:flex;position:relative}.garnish-3d-inner{box-sizing:border-box;border:1px solid #ffffff40;border-radius:50%;justify-content:center;align-items:center;width:100%;height:100%;display:flex}.garnish-3d-button.filter-all{color:var(--text-secondary);background:linear-gradient(135deg,#fff 0%,#efece6 100%);border:1px solid #dfd9d0;box-shadow:0 3px #cdc6bc,0 4px 8px #0000000d,inset 0 1.5px #ffffffe6}.garnish-3d-button.filter-all .garnish-3d-inner{border-color:#fffc}.garnish-3d-button.filter-any{color:#fff;background:linear-gradient(135deg,#7cb342 0%,#558b2f 100%);border:1px solid #4e7b26;box-shadow:0 3px #3e6a1f,0 4px 8px #6b9b5740,inset 0 1.5px #ffffff59}.garnish-3d-button.filter-free{color:#fff;background:linear-gradient(135deg,#ffb300 0%,#ff8f00 100%);border:1px solid #e07b00;box-shadow:0 3px #a85200,0 4px 8px #ff8f0040,inset 0 1.5px #ffffff73}.garnish-3d-button:active{transform:translateY(3px)!important}.garnish-3d-button.filter-all:active{box-shadow:0 0 #cdc6bc,0 1px 3px #0000001a,inset 0 1.5px #ffffffe6}.garnish-3d-button.filter-any:active{box-shadow:0 0 #3e6a1f,0 1px 3px #6b9b574d,inset 0 1.5px #ffffff59}.garnish-3d-button.filter-free:active{box-shadow:0 0 #a85200,0 1px 3px #ff8f004d,inset 0 1.5px #ffffff73}.nav-links{gap:.25rem;display:flex}.nav-link{font-family:var(--font-body);color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;align-items:center;gap:6px;padding:.5rem 1rem;font-size:.9rem;font-weight:500;text-decoration:none;transition:color .2s,background .2s;display:flex;position:relative}.nav-link:hover{color:var(--text-primary);background:var(--bg-secondary)}.nav-link.active{color:var(--accent);background:var(--accent-light)}.panel,.glass-panel{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:2rem}.grid{grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:1.25rem;display:grid}.card{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);flex-direction:column;padding:0;transition:transform .25s,box-shadow .25s,border-color .25s;display:flex;position:relative;overflow:hidden}.card-body{flex-direction:row;width:100%;height:160px;display:flex}.card-tags-footer{border-top:1px solid var(--border-light);background:var(--bg-secondary);box-sizing:border-box;width:100%;margin-top:auto;padding:6px 12px}.card:hover{box-shadow:var(--shadow-md);border-color:var(--border);transform:translateY(-4px)}.card.unavailable{opacity:.55;background:var(--bg-secondary);pointer-events:none}.btn{font-family:var(--font-body);background:var(--accent);color:#fff;border-radius:var(--radius-sm);cursor:pointer;border:none;align-items:center;gap:.4rem;padding:.7rem 1.4rem;font-size:.9rem;font-weight:600;line-height:1.4;transition:background .2s,transform .15s,box-shadow .2s;display:inline-flex}.btn:hover{background:var(--accent-hover);box-shadow:0 2px 8px #c67b4b40}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}.btn-secondary{background:var(--bg-secondary)!important;color:var(--text-primary)!important;border:1px solid var(--border)!important}.btn-secondary:hover{background:var(--bg-tertiary)!important;box-shadow:none!important}.btn-primary{background:var(--accent)!important;color:#fff!important;border:none!important}.btn-primary:hover{background:var(--accent-hover)!important}.btn-danger{background:var(--danger-light)!important;color:var(--danger)!important;border:1px solid #d9555533!important}.btn-danger:hover{background:var(--danger)!important;color:#fff!important;border-color:var(--danger)!important}.btn-success{background:var(--success-light)!important;color:var(--success)!important;border:1px solid #6b9b5733!important}.btn-success:hover{background:var(--success)!important;color:#fff!important;border-color:var(--success)!important}.btn-sm{padding:.35rem .85rem!important;font-size:.83rem!important}.btn-place{justify-content:center;width:100%;margin-top:.25rem;padding:.7rem 1rem;font-size:.95rem;font-weight:600}.btn-icon{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:4px;transition:color .15s,background .15s;display:inline-flex}.btn-icon:hover{color:var(--text-primary);background:var(--bg-secondary)}.btn-icon-sm{padding:2px;font-size:.8rem}.btn-edit{color:var(--text-secondary);padding:2px 4px}.btn-edit:hover{color:var(--accent);background:var(--accent-light)}.btn-delete{color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px;transition:color .2s,background .2s}.btn-delete:hover{color:var(--danger);background:var(--danger-light)}.input-field{width:100%;font-family:var(--font-body);background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);box-sizing:border-box;outline:none;margin-bottom:1rem;padding:.7rem .85rem;font-size:.9rem;transition:border-color .2s,box-shadow .2s}.input-field:focus{border-color:var(--accent);box-shadow:0 0 0 3px #c67b4b1a}.input-field::placeholder{color:var(--text-tertiary)}select.input-field{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238B8580' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right .85rem center;background-repeat:no-repeat;padding-right:2.5rem}.filter-bar{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);flex-direction:column;gap:1rem;margin-bottom:1.75rem;padding:1.25rem;display:flex}.filter-search{width:100%;position:relative}.filter-search-icon{color:var(--text-tertiary);pointer-events:none;position:absolute;top:50%;left:.85rem;transform:translateY(-50%)}.filter-search-input{width:100%;font-family:var(--font-body);background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);box-sizing:border-box;outline:none;padding:.7rem .85rem .7rem 2.75rem;font-size:.92rem;font-weight:500;transition:border-color .2s,box-shadow .2s}.filter-search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #c67b4b1a}.filter-search-input::placeholder{color:var(--text-tertiary);font-weight:400}.filter-controls{flex-wrap:wrap;align-items:flex-end;gap:1.5rem;display:flex}.filter-group{flex-direction:column;gap:.35rem;display:flex}.filter-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;font-size:.75rem;font-weight:600}.filter-price{flex:2;min-width:180px}.filter-stars{flex:1;min-width:130px}.filter-toggle{flex-direction:row;flex:none;align-items:center;gap:.5rem}.price-range-row{align-items:center;gap:.5rem;display:flex}.price-input{width:90px;font-family:var(--font-body);background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);text-align:center;outline:none;padding:.5rem .6rem;font-size:.88rem;font-weight:500;transition:border-color .2s,box-shadow .2s}.price-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px #c67b4b1a}.price-input::placeholder{color:var(--text-tertiary);font-weight:400}.price-sep{color:var(--text-tertiary);font-weight:500}.toggle-switch{cursor:pointer;width:44px;height:26px;display:inline-block;position:relative}.toggle-switch input{opacity:0;width:0;height:0;position:absolute}.toggle-slider{background:var(--bg-tertiary);border-radius:26px;transition:background .25s;position:absolute;inset:0}.toggle-slider:before{content:"";background:var(--surface);border-radius:50%;width:20px;height:20px;transition:transform .25s;position:absolute;top:3px;left:3px;box-shadow:0 1px 3px #0000001f}.toggle-switch input:checked+.toggle-slider{background:var(--success)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(18px)}.toggle-switch:hover .toggle-slider{opacity:.9}.filters-container{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);margin-bottom:1.75rem;padding:1.25rem}.filters-row{flex-wrap:wrap;align-items:center;gap:1.25rem;display:flex}.filter-inputs{align-items:center;gap:.5rem;display:flex}.filter-input-small{background:var(--bg-primary);border:1px solid var(--border);width:80px;color:var(--text-primary);text-align:center;font-size:.9rem;font-family:var(--font-body);border-radius:6px;padding:.5rem}.card-badges{z-index:10;flex-direction:column;align-items:flex-start;gap:.3rem;display:flex;position:absolute;top:6px;left:6px}.card-image-wrapper{border-right:1px solid var(--border-light);box-sizing:border-box;background:#fff;border-bottom:none;flex-shrink:0;justify-content:center;align-items:center;width:140px;height:100%;margin:0;padding:8px;display:flex;position:relative;overflow:hidden}.card-image{object-fit:contain;width:100%;height:100%;transition:transform .4s cubic-bezier(.25,.8,.25,1)}.card:hover .card-image{transform:scale(1.06)}.placeholder-wrapper{background:#fff}.card-info{box-sizing:border-box;flex-direction:column;flex:1;justify-content:space-between;min-width:0;height:100%;padding:.85rem 1rem;display:flex}.card-description{-webkit-line-clamp:2;text-overflow:ellipsis;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.card-title{-webkit-line-clamp:2;text-overflow:ellipsis;white-space:normal;-webkit-box-orient:vertical;line-height:1.25;display:-webkit-box;overflow:hidden}.card-image-rating{-webkit-backdrop-filter:blur(8px);border-top:1px solid var(--border-light);box-sizing:border-box;z-index:10;background:#ffffffd9;justify-content:center;align-items:center;gap:4px;width:100%;padding:3px 6px;display:flex;position:absolute;bottom:0;left:0}.rating-stars-sticker{color:var(--warning);letter-spacing:1px;font-size:.78rem}.rating-text-sticker{color:var(--text-secondary);font-size:.72rem;font-weight:700}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.shimmer-loader{background:linear-gradient(90deg, var(--bg-secondary) 25%, var(--bg-tertiary) 50%, var(--bg-secondary) 75%);background-size:200% 100%;animation:1.6s linear infinite shimmer}.badge{letter-spacing:.01em;border-radius:6px;align-items:center;gap:4px;padding:.25rem .6rem;font-size:.73rem;font-weight:600;display:flex}.badge-unavailable{background:var(--danger-light);color:var(--danger);border:1px solid #d9555533}.badge-garnish{background:var(--success-light);color:var(--success);border:1px solid #6b9b5733}.badge-paid-garnish{background:var(--warning-light);color:#b8932e;border:1px solid #d4a84340}.badge-ordered{text-transform:uppercase;letter-spacing:.04em;background:var(--accent-light);color:var(--accent);vertical-align:middle;border-radius:4px;margin-left:6px;padding:1px 6px;font-size:.65rem;font-weight:600;display:inline-block}.rating-stars{color:var(--warning);letter-spacing:2px;font-size:.95rem}.rating-text{color:var(--text-secondary);margin-left:.25rem;font-size:.8rem}.cart-panel{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);align-self:start;max-height:calc(100vh - 8rem);padding:1.5rem;position:sticky;top:1.75rem;overflow-y:auto}.cart-item{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:flex-start;padding:.75rem 0;display:flex}.cart-item:last-child{border-bottom:none}.cart-item-info{flex-direction:column;display:flex}.cart-item-name{text-transform:capitalize;font-size:.92rem;font-weight:500}.cart-item-price{color:var(--text-secondary);margin-top:2px;font-size:.83rem}.cart-item-actions{flex-shrink:0;align-items:center;gap:4px;margin-left:8px;display:flex}.cart-item.ordered{opacity:.55}.cart-item-qty{color:var(--text-secondary);font-size:.8rem}.clickable-dish{cursor:pointer;transition:color .15s,opacity .15s}.clickable-dish:hover{color:var(--accent);text-decoration:underline;opacity:1!important}.admin-orders-panel{flex-direction:column;max-height:calc(100vh - 80px);display:flex}.admin-panel-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;margin-bottom:0;padding-bottom:.35rem;display:flex}.admin-panel-header h3{font-size:.95rem}.admin-panel-body{flex:1;min-height:0;padding:.15rem 0;overflow-y:auto}.admin-panel-footer{border-top:1px solid var(--border);flex-shrink:0;padding-top:.35rem}.admin-groups-list{flex-direction:column;gap:.35rem;display:flex}.user-group{border:1px solid var(--border-light);border-radius:var(--radius-sm);overflow:hidden}.user-group-header{background:var(--bg-primary);justify-content:space-between;align-items:center;padding:.4rem .65rem;transition:background .15s;display:flex}.user-group-header:hover{background:var(--bg-secondary)}.user-group-info{align-items:center;gap:6px;display:flex}.user-group-name{align-items:center;gap:3px;font-size:.85rem;font-weight:600;display:flex}.user-group-meta{color:var(--text-secondary);background:var(--bg-secondary);border-radius:10px;padding:1px 8px;font-size:.73rem}.user-group-total{color:var(--accent);font-size:.88rem;font-weight:700}.user-group-orders{padding:.15rem .4rem .4rem}.admin-total-row{justify-content:space-between;align-items:center;margin-bottom:.75rem;font-size:.95rem;font-weight:600;display:flex}.admin-total-price{color:var(--success);font-size:1.05rem}.pulse-target .user-group-avatar{animation:.6s cubic-bezier(.25,1,.5,1) forwards avatarFlashPulse}.pulse-target .user-group-name{animation:.8s ease-in-out .6s forwards nameColorPulse;position:relative!important;overflow:hidden!important}.pulse-target .user-group-name:after{content:"";background:linear-gradient(90deg,#0000 0%,#6b9b5773 50%,#0000 100%);width:100%;height:100%;animation:.8s ease-in-out .6s forwards nameGlarePass;position:absolute;top:0;left:-150%;transform:skew(-25deg)}.pulse-target .user-group-total{animation:.6s cubic-bezier(.25,1,.5,1) 1.4s forwards totalSumPulse}@keyframes avatarFlashPulse{0%{border-color:var(--border);transform:scale(1);box-shadow:0 0 #6b9b5700}30%{border-color:var(--success);transform:scale(1.18);box-shadow:0 0 15px #6b9b57b3}to{border-color:var(--border);transform:scale(1);box-shadow:0 0 #6b9b5700}}@keyframes nameColorPulse{0%{color:var(--text-primary)}30%{color:var(--success)}to{color:var(--text-primary)}}@keyframes nameGlarePass{0%{left:-150%}to{left:150%}}@keyframes totalSumPulse{0%{color:var(--accent);text-shadow:none;transform:scale(1)}35%{color:var(--success);text-shadow:0 0 8px #6b9b574d;transform:scale(1.18)}to{color:var(--accent);text-shadow:none;transform:scale(1)}}.fee-settings{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-sm);margin-bottom:.5rem;padding:.5rem}.place-confirm{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-sm);padding:.5rem}.admin-sidebar{flex-direction:column;align-self:start;gap:.75rem;height:calc(100vh - 76px - 3.5rem);display:flex;position:sticky;top:calc(76px + 1.75rem);overflow:hidden}.admin-sidebar>.cart-panel{box-sizing:border-box;flex:none;width:100%;padding:1rem;position:static}.admin-sidebar>.admin-orders-panel{box-sizing:border-box;background:var(--bg-secondary);border-color:var(--border);flex:auto;width:100%;min-height:0;padding:.85rem;position:static;overflow:hidden;flex-direction:column!important;display:flex!important}.batch-section{border-top:1px solid var(--border);margin-top:.75rem;padding-top:.75rem}.batch-section-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.75rem;display:flex}.batch-section-title{color:var(--text-primary);font-size:.95rem;font-weight:700}.batch-section-meta{color:var(--text-secondary);font-size:.8rem}.header-view-toggle{transition:color .2s,transform .2s}.header-view-toggle:hover{animation:.6s ease-in-out icon-pulse}.header-view-toggle.active{color:var(--accent);background:var(--accent-light)}@keyframes icon-pulse{0%{transform:scale(1)}30%{transform:scale(1.25)}60%{transform:scale(.9)}to{transform:scale(1)}}.batch-view-toggle{cursor:pointer;align-items:center;gap:6px;display:flex}.batch-toggle-label{color:var(--text-tertiary);white-space:nowrap;align-items:center;gap:4px;font-size:.78rem;font-weight:500;transition:color .2s;display:flex}.batch-toggle-label.active{color:var(--text-primary);font-weight:700}.batch-phone-view{flex-direction:column;gap:.35rem;display:flex}.phone-order-item{border-bottom:1px solid var(--border-light);align-items:baseline;gap:.4rem;padding:.2rem 0;display:flex}.phone-order-item:last-child{border-bottom:none}.phone-order-name{text-transform:capitalize;flex:1;font-size:.88rem;font-weight:500;line-height:1.3}.phone-order-qty{color:var(--text-primary);white-space:nowrap;font-size:.85rem;font-weight:700}.phone-order-price{color:var(--text-secondary);white-space:nowrap;font-size:.85rem;font-weight:600}.phone-order-footer{border-top:1px solid var(--border);flex-direction:column;gap:.25rem;margin-top:.75rem;padding-top:.5rem;display:flex}.phone-footer-row{color:var(--text-secondary);justify-content:space-between;align-items:center;font-size:.85rem;display:flex}.phone-footer-total{color:var(--text-primary);border-top:1px solid var(--border-light);margin-top:.25rem;padding-top:.25rem;font-size:.95rem;font-weight:700}.modal-overlay{-webkit-backdrop-filter:blur(4px);z-index:1000;background:#2d2a2573;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal-content{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius-lg);width:92%;max-width:500px;max-height:90vh;box-shadow:var(--shadow-lg);color:var(--text-primary);padding:2rem;animation:.25s slideUp;position:relative;overflow-y:auto}.modal-close{color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;font-size:1.4rem;line-height:1;transition:color .15s;position:absolute;top:1rem;right:1rem}.modal-close:hover{color:var(--text-primary)}.modal-header{justify-content:space-between;align-items:center;margin-bottom:1.25rem;display:flex}.modal-header h3{align-items:center;gap:8px;margin:0;font-size:1.25rem;display:flex}.modal-body{margin-bottom:1.25rem}.modal-footer{justify-content:flex-end;gap:8px;display:flex}.edit-order-modal{max-width:420px}.form-group{margin-bottom:1rem}.form-label{color:var(--text-secondary);margin-bottom:.35rem;font-size:.83rem;font-weight:600;display:block}.nutrition-grid{background:var(--bg-primary);border-radius:var(--radius-sm);border:1px solid var(--border-light);grid-template-columns:repeat(4,1fr);gap:.75rem;margin:1rem 0;padding:.85rem;display:grid}.nutrition-item{flex-direction:column;align-items:center;font-size:.85rem;display:flex}.nutrition-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em;margin-bottom:3px;font-size:.72rem;font-weight:600}.nutrition-value{color:var(--text-primary);font-weight:600}.reasons-list{flex-direction:column;gap:.5rem;margin:1rem 0;display:flex}.reason-item{color:var(--text-primary);align-items:flex-start;gap:.5rem;font-size:.88rem;line-height:1.4;display:flex}.garnish-list{flex-direction:column;gap:.6rem;margin:1.25rem 0;display:flex}.garnish-item{border:1px solid var(--border-light);border-radius:var(--radius-sm);background:var(--bg-primary);cursor:pointer;justify-content:space-between;align-items:center;padding:.85rem 1rem;transition:all .2s;display:flex}.garnish-item:hover{background:var(--surface);border-color:var(--accent);box-shadow:var(--shadow-sm)}.garnish-item.selected{background:var(--accent-light);border-color:var(--accent);box-shadow:0 0 0 3px #c67b4b1a}.toast-overlay{z-index:2000;background:0 0;justify-content:center;align-items:flex-start;padding-top:2rem;display:flex;position:fixed;inset:0}.toast-card{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius-md);min-width:320px;max-width:440px;box-shadow:var(--shadow-lg);padding:1.25rem 1.5rem;animation:.3s slideDown}.toast-card.success{border-left:4px solid var(--success)}.toast-card.error{border-left:4px solid var(--danger)}.toast-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.toast-title{color:var(--text-primary);align-items:center;gap:8px;font-size:1rem;font-weight:700;display:flex}.toast-card.success .toast-title{color:var(--success)}.toast-card.error .toast-title{color:var(--danger)}.toast-close{color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;padding:0 0 0 8px;font-size:1.3rem;line-height:1;transition:color .15s}.toast-close:hover{color:var(--text-primary)}.toast-dish{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;margin-bottom:.6rem;padding:.5rem 0;display:flex}.toast-dish-name{text-transform:capitalize;font-weight:600}.toast-dish-price{color:var(--text-primary);font-weight:600}.toast-summary{color:var(--text-secondary);font-size:.9rem;line-height:1.4}.toast-total{color:var(--accent);font-size:1rem}.toast-detail{color:var(--text-secondary);margin:0;font-size:.88rem}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.fly-chip{background:var(--surface);border:1.5px solid var(--success);font-family:var(--font-body);white-space:nowrap;border-radius:20px;align-items:center;gap:.6rem;width:fit-content;padding:.5rem 1rem;display:flex;box-shadow:0 8px 30px #0000001f}.fly-chip span{color:var(--text-primary);text-transform:capitalize;font-size:.85rem;font-weight:600}.fly-chip em{color:var(--accent);font-size:.85rem;font-style:normal;font-weight:700}.error-message{background:var(--danger-light);border-radius:var(--radius-sm);color:var(--danger);border:1px solid #d9555533;justify-content:space-between;align-items:center;gap:8px;padding:.6rem .85rem;font-size:.85rem;display:flex}.success-message{background:var(--success-light);border-radius:var(--radius-sm);color:var(--success);border:1px solid #6b9b5733;justify-content:space-between;align-items:center;gap:8px;padding:.6rem .85rem;font-size:.85rem;display:flex}.flex-between{justify-content:space-between;align-items:center;display:flex}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.spin{animation:1s linear infinite spin}@keyframes cardIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.card{animation:.4s backwards cardIn}.card:first-child{animation-delay:20ms}.card:nth-child(2){animation-delay:60ms}.card:nth-child(3){animation-delay:.1s}.card:nth-child(4){animation-delay:.14s}.card:nth-child(5){animation-delay:.18s}.card:nth-child(6){animation-delay:.22s}.card:nth-child(7){animation-delay:.26s}.card:nth-child(8){animation-delay:.3s}.card:nth-child(9){animation-delay:.34s}.card:nth-child(10){animation-delay:.38s}.card:nth-child(11){animation-delay:.42s}.card:nth-child(12){animation-delay:.46s}@media (width<=768px){.app-container{padding:1rem .75rem}.nav-bar{margin-bottom:1.5rem}.nav-bar-container{flex-direction:column;align-items:stretch;gap:1rem;padding:0}.header-controls{width:100%;max-width:100%;margin:0}.garnish-3d-button{flex-shrink:0}.grid{grid-template-columns:1fr}.filter-controls{flex-direction:column;gap:1rem}.filter-price,.filter-stars,.filter-toggle{min-width:100%}.filter-toggle{flex-direction:row;justify-content:flex-start}.price-range-row{width:100%}.price-input{flex:1}.nutrition-grid{grid-template-columns:repeat(2,1fr)}}.flying-mini-card{z-index:99999;pointer-events:none;-webkit-backdrop-filter:blur(8px);border:1.5px solid var(--accent);border-radius:var(--radius-md);font-family:var(--font-body);color:var(--text-primary);box-shadow:var(--shadow-lg), 0 0 15px #c67b4b26;transform-origin:50%;background:#ffffffd9;flex-direction:column;gap:4px;min-width:140px;max-width:220px;padding:10px 16px;display:flex;position:fixed}.flying-mini-card-title{white-space:nowrap;text-overflow:ellipsis;text-transform:capitalize;margin:0;font-size:.85rem;font-weight:700;line-height:1.2;overflow:hidden}.flying-mini-card-meta{justify-content:space-between;align-items:center;gap:8px;display:flex}.flying-mini-card-price{color:var(--accent);font-size:.9rem;font-weight:800}.flying-mini-card-stars{color:var(--warning);letter-spacing:1px;font-size:.75rem}@keyframes border-shimmer{0%{box-shadow:0 0 12px 1px #6b9b5726, var(--shadow-sm);border-color:#6b9b5773}50%{box-shadow:0 0 20px 3px #c67b4b4d, 0 0 8px 1px #6b9b5733, var(--shadow-sm);border-color:#c67b4bbf}to{box-shadow:0 0 12px 1px #6b9b5726, var(--shadow-sm);border-color:#6b9b5773}}.card.ordered{border-color:var(--success);animation:3s ease-in-out infinite border-shimmer}.card.ordered:hover{box-shadow:0 0 22px #6b9b5773, var(--shadow-md);border-color:var(--success);transform:translateY(-4px)}.batch-viewer-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:1.5rem;display:flex}.global-debts-dashboard{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:2rem;padding:1.5rem}.dashboard-title{color:var(--text-primary);align-items:center;gap:8px;margin:0 0 1rem;font-size:1.1rem;font-weight:700;display:flex}.global-debts-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem;display:grid}.user-debt-card-sticker{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-md);cursor:pointer;-webkit-user-select:none;user-select:none;flex-direction:column;gap:.75rem;padding:1rem;transition:transform .2s,box-shadow .2s,border-color .2s;display:flex}.user-debt-card-sticker:hover{box-shadow:var(--shadow-md);border-color:var(--border);transform:translateY(-2px)}.user-debt-card-sticker.is-deposit{border-left:4px solid var(--success)}.user-debt-card-sticker.is-debt{border-left:4px solid var(--danger)}.user-debt-card-header{align-items:center;gap:.75rem;display:flex}.user-debt-card-avatar{width:48px;height:48px;box-shadow:var(--shadow-sm);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex;overflow:hidden}.user-debt-card-avatar img{object-fit:cover;width:100%;height:100%}.user-debt-card-avatar span{color:#fff;text-shadow:0 1px 2px #0000001a;font-size:.95rem;font-weight:700}.user-debt-card-identity{flex-direction:column;gap:2px;min-width:0;display:flex}.user-debt-card-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:700;overflow:hidden}.badge-balance{border-radius:4px;padding:1px 6px;font-size:.78rem;font-weight:700}.badge-balance.deposit{background:var(--success-light);color:var(--success)}.badge-balance.debt{background:var(--danger-light);color:var(--danger)}.user-debt-card-breakdown{border-top:1px solid var(--border-light);grid-template-columns:repeat(3,1fr);gap:6px;padding-top:.5rem;display:grid}.breakdown-item{flex-direction:column;align-items:center;gap:1px;display:flex}.breakdown-label{color:var(--text-tertiary);text-transform:uppercase;font-size:.65rem;font-weight:600}.breakdown-val{font-size:.78rem;font-weight:700}.text-success{color:var(--success)!important}.text-danger{color:var(--danger)!important}.text-warning{color:var(--warning)!important}.user-debt-modal{width:90%!important;max-width:680px!important}.user-debt-modal-header h3{color:var(--text-primary);margin:0;font-size:1.3rem}.user-debt-cards{grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:1rem;margin:1.5rem 0;display:grid}.debt-card{background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-md);flex-direction:column;gap:4px;padding:.75rem 1rem;display:flex}.debt-card-label{color:var(--text-secondary);text-transform:uppercase;font-size:.72rem;font-weight:600}.debt-card-value{font-size:1.05rem;font-weight:700}.debt-card.highlight{border-width:1.5px}.debt-card.highlight.success{background:var(--success-light);border-color:var(--success);color:var(--success)}.debt-card.highlight.danger{background:var(--danger-light);border-color:var(--danger);color:var(--danger)}.add-adjustment-form{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);margin-bottom:1.5rem;padding:1.25rem}.add-adjustment-form h4{color:var(--text-primary);margin:0 0 1rem;font-size:.95rem}.adjustment-form-row{flex-wrap:wrap;align-items:flex-start;gap:12px;display:flex}.adjustment-form-row .form-group{flex-direction:column;flex:1;gap:6px;min-width:120px;display:flex}.adjustment-form-row .form-group.select-group{flex:1.5;min-width:180px}.adjustment-form-row label{color:var(--text-secondary);font-size:.72rem;font-weight:600}.adjustment-form-row input,.adjustment-form-row select{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);font-family:var(--font-body);color:var(--text-primary);padding:.45rem .75rem;font-size:.88rem}.adjustment-form-row input:focus,.adjustment-form-row select:focus{border-color:var(--accent);outline:none}.ledger-section h4{color:var(--text-primary);margin:0 0 .75rem;font-size:.95rem}.ledger-table-wrapper{border:1px solid var(--border-light);border-radius:var(--radius-md);max-height:220px;overflow-y:auto}.ledger-table{border-collapse:collapse;text-align:left;width:100%;font-size:.85rem}.ledger-table th,.ledger-table td{border-bottom:1px solid var(--border-light);padding:.6rem .75rem}.ledger-table th{background:var(--bg-secondary);color:var(--text-secondary);z-index:10;font-weight:700;position:sticky;top:0}.ledger-table tr.settled-row{opacity:.65;background:var(--bg-primary)}.badge-type{border-radius:4px;padding:2px 6px;font-size:.72rem;font-weight:700;display:inline-block}.badge-type.deposit{color:var(--success);background:#6b9b571a}.badge-type.loan{color:var(--danger);background:#d955551a}.badge-status{border-radius:4px;padding:1px 5px;font-size:.72rem;font-weight:600;display:inline-block}.badge-status.active{background:var(--warning-light);color:var(--warning)}.badge-status.settled{background:var(--bg-tertiary);color:var(--text-secondary)}.user-debt-modal-footer{border-top:1px solid var(--border-light);justify-content:space-between;align-items:center;margin-top:1.5rem;padding-top:1rem;display:flex}.weeks-stack{flex-direction:column;gap:2.5rem;display:flex}.week-table{padding:1.25rem;transition:border-color .25s,box-shadow .25s;overflow-x:auto}.week-table.week-completed{border:1.5px solid var(--success);box-shadow:0 4px 20px #6b9b5714}.week-table-title{align-items:center;gap:.75rem;margin-bottom:1rem;font-size:1rem;font-weight:700;display:flex}.week-table-meta{color:var(--text-secondary);background:var(--bg-secondary);border-radius:10px;padding:1px 8px;font-size:.78rem}.pivot-table-wrap{overflow-x:auto}.pivot-table{border-collapse:collapse;table-layout:fixed;width:100%}.pivot-table thead th{border-bottom:1px solid var(--border);color:var(--text-secondary);vertical-align:top;font-weight:600}.pivot-table tbody tr{border-bottom:1px solid var(--border-light);transition:background .12s}.pivot-table tbody tr:hover{background:var(--bg-primary)}.pivot-table th:nth-child(2n),.pivot-table td:nth-child(2n){background-color:#6b9b5705!important}.pivot-table th:nth-child(odd):not(.pivot-name-col),.pivot-table td:nth-child(odd):not(.pivot-name-col){background-color:#c67b4b05!important}.pivot-table td.pivot-cell:hover{background-color:var(--bg-secondary)!important}.pivot-name-col{text-align:left;white-space:nowrap;border-right:1px solid var(--border-light);width:140px;min-width:120px;padding:.6rem .75rem;font-size:.85rem;font-weight:600}.pivot-name-text{text-overflow:ellipsis;display:block;overflow:hidden}.pivot-week-total{color:var(--danger);margin-top:1px;font-size:.7rem;font-weight:700;display:block}.pivot-day-col{text-align:center;padding:.75rem .25rem;font-size:.8rem}.pivot-day-date{color:var(--text-primary);font-size:.95rem;font-weight:700;line-height:1.2}.pivot-day-label{text-transform:uppercase;color:var(--text-tertiary);letter-spacing:.05em;margin-top:2px;font-size:.65rem;font-weight:600}.pivot-day-batch-info{color:var(--text-secondary);justify-content:center;align-items:center;gap:4px;margin-top:6px;font-size:.68rem;font-weight:500;display:flex}.pivot-day-divider{color:var(--text-tertiary);opacity:.4;font-size:.6rem}.pivot-day-fee{margin-left:0}.pivot-day-action{color:var(--text-tertiary);cursor:pointer;opacity:0;pointer-events:none;background:0 0;border:none;border-radius:3px;justify-content:center;align-items:center;padding:1px 2px;transition:opacity .15s,color .15s;display:inline-flex}.pivot-day-col:hover .pivot-day-action{opacity:.6;pointer-events:auto}.pivot-day-action:hover{color:var(--text-primary);opacity:1!important}.pivot-cell{text-align:center;cursor:default;padding:.55rem .3rem;font-size:.82rem;font-weight:600;transition:background .12s}.pivot-cell.unpaid{color:var(--danger);cursor:pointer;font-weight:700}.pivot-cell.paid{color:var(--success);cursor:pointer;text-decoration:line-through}.pivot-cell.empty{color:var(--text-tertiary);cursor:pointer;font-size:.75rem;font-weight:400}.pivot-cell.empty:hover{background:var(--bg-secondary);color:var(--text-primary)}.pivot-cell.toggling{opacity:.4}.pivot-cell:not(.empty):hover{background:var(--bg-secondary)}.batch-pagination{margin-top:1.5rem;margin-bottom:2rem}.batch-detail-popup{max-width:440px}.detail-dish-row{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:.5rem 0;display:flex}.detail-dish-row:last-child{border-bottom:none}.detail-dish-name{text-transform:capitalize;font-size:.9rem;font-weight:500}.detail-dish-qty{color:var(--text-secondary);font-size:.8rem}.detail-dish-price{color:var(--text-primary);font-size:.9rem;font-weight:600}.detail-divider{background:var(--border);height:1px;margin:.75rem 0}.detail-summary{flex-direction:column;gap:.35rem;display:flex}.detail-summary-row{color:var(--text-secondary);justify-content:space-between;align-items:center;font-size:.88rem;display:flex}.detail-summary-total{color:var(--text-primary);border-top:1px solid var(--border-light);padding-top:.35rem;font-size:.95rem;font-weight:700}.cart-panel.cart-locked{background:var(--accent-light)!important;border-color:#c67b4b33!important}.cart-panel.cart-delivered{background:var(--success-light)!important;border-color:#6b9b5733!important}.create-batch-modal{max-width:440px}.create-batch-modal.redesigned{width:95%;max-width:650px}.create-batch-modal textarea.input-field{font-family:var(--font-body)}.create-batch-modal.redesigned .modal-header{flex-wrap:wrap;gap:12px}.modal-tabs{gap:6px;display:flex}.modal-tab-btn{background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;border-radius:6px;align-items:center;gap:6px;padding:6px 12px;font-size:.8rem;font-weight:600;transition:all .15s;display:inline-flex}.modal-tab-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.modal-tab-btn.active{background:var(--accent)!important;border-color:var(--accent)!important;color:var(--surface)!important}.items-tab-body{flex-direction:column;gap:1.25rem;display:flex}.modal-participants-list{flex-direction:column;gap:12px;max-height:380px;padding-right:4px;display:flex;overflow-y:auto}.no-items-placeholder{text-align:center;color:var(--text-tertiary);margin:0;padding:1.5rem 0;font-size:.85rem;font-style:italic}.participant-item-card{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-md);padding:12px;transition:border-color .15s}.participant-item-card:hover{border-color:var(--accent)}.participant-card-header{border-bottom:1px dashed var(--border);justify-content:space-between;align-items:center;margin-bottom:10px;padding-bottom:8px;display:flex}.participant-info{align-items:center;gap:8px;display:flex}.participant-avatar img{object-fit:cover;width:100%;height:100%;display:block}.participant-name{color:var(--text-primary);font-size:.9rem;font-weight:700}.participant-total{color:var(--accent);font-size:.9rem;font-weight:700}.participant-dishes{flex-direction:column;gap:6px;display:flex}.dish-row-inline{border-radius:var(--radius-sm);background:var(--surface);border:1px solid var(--border-light);align-items:center;gap:8px;padding:6px 10px;font-size:.85rem;display:flex}.dish-row-inline.inline-add-form{border:1px dashed var(--accent);background:var(--accent-light)}.dish-row-inline .input-field.input-sm{margin-bottom:0}.dish-name-lbl{color:var(--text-primary);flex:1;font-weight:500}.dish-qty-lbl{color:var(--text-tertiary);margin-left:4px;font-size:.75rem}.dish-price-lbl{color:var(--text-secondary);font-weight:600}.dish-actions-inline{align-items:center;gap:4px;display:flex}.btn-icon.btn-confirm{color:var(--success)}.btn-icon.btn-confirm:hover{background:var(--success-light);color:var(--success)}.btn-icon.btn-cancel{color:var(--danger)}.btn-icon.btn-cancel:hover{background:var(--danger-light);color:var(--danger)}.btn-add-dish-trigger{border:1px dashed var(--border);color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;background:0 0;align-items:center;gap:4px;width:fit-content;margin-top:2px;padding:5px 10px;font-size:.75rem;font-weight:600;transition:all .15s;display:inline-flex}.btn-add-dish-trigger:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}.add-participant-section{border-top:1px solid var(--border);margin-top:1rem;padding-top:1rem}.search-user-wrapper{margin-bottom:.5rem}.search-user-wrapper .search-input{margin-bottom:0;padding-left:2.25rem!important}.search-icon-inside{color:var(--text-tertiary);pointer-events:none;position:absolute;top:50%;left:.85rem;transform:translateY(-50%)}.users-autocomplete-dropdown{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);z-index:100;max-height:200px;margin-top:4px;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.dropdown-user-row{cursor:pointer;align-items:center;gap:8px;padding:8px 12px;transition:background .15s;display:flex}.dropdown-user-row:hover{background:var(--bg-secondary)}.dropdown-empty{text-align:center;color:var(--text-tertiary);padding:12px;font-size:.85rem}.add-participant-form-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);margin-top:.5rem;padding:1rem}.form-card-title{color:var(--text-secondary);justify-content:space-between;align-items:center;margin-bottom:.75rem;font-size:.85rem;display:flex}.form-card-row{align-items:center;gap:8px;display:flex}.form-card-row .input-field{margin-bottom:0}.clickable-date{cursor:pointer;border-radius:var(--radius-sm);-webkit-user-select:none;user-select:none;padding:4px 8px;transition:background-color .2s,transform .1s;display:inline-block}.clickable-date:hover{background-color:var(--bg-secondary)}.clickable-date:active{transform:scale(.95)}.clickable-label{cursor:pointer;border-radius:var(--radius-sm);-webkit-user-select:none;user-select:none;padding:2px 6px;transition:background-color .2s,color .2s,transform .1s;display:inline-block}.clickable-label:hover{background-color:var(--bg-secondary);color:var(--text-primary)!important}.clickable-label:active{transform:scale(.95)}.pivot-day-date-text{z-index:1;position:relative}.is-holiday .pivot-day-date-text:after{content:"";z-index:-1;pointer-events:none;background:#f6d3658c;border-radius:4px 6px 3px 5px;height:8px;position:absolute;bottom:-1px;left:-6px;right:-6px;transform:rotate(-1.2deg)scaleX(1.05)}.is-holiday .pivot-day-label{color:var(--danger)}.batch-parameters-inline{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:1.25rem;padding:12px 16px;display:flex}.batch-parameters-inline .inline-field{flex:140px;align-items:center;gap:8px;display:flex}.batch-parameters-inline .inline-field.notes-field{flex:2 200px}.batch-parameters-inline label{color:var(--text-secondary);white-space:nowrap;font-size:.8rem;font-weight:700}.batch-parameters-inline .input-field{border-radius:var(--radius-sm);background:var(--surface);margin-bottom:0;padding:6px 10px;font-size:.85rem}.add-participant-trigger-wrapper{align-items:center;gap:10px;margin-top:12px;display:flex;position:relative}.btn-add-participant-circle{background:var(--surface);border:2px dashed var(--accent);width:40px;height:40px;color:var(--accent);cursor:pointer;box-shadow:var(--shadow-sm);border-radius:50%;outline:none;justify-content:center;align-items:center;transition:all .2s;display:flex}.btn-add-participant-circle:hover{background:var(--accent-light);transform:scale(1.05)}.btn-add-participant-circle:active{transform:scale(.95)}.btn-add-participant-lbl{color:var(--text-secondary);font-size:.85rem;font-weight:700}.user-picker-popover{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:320px;box-shadow:var(--shadow-lg);z-index:110;flex-direction:column;gap:8px;padding:12px;display:flex;position:absolute;bottom:50px;left:0}.user-picker-header{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding-bottom:6px;display:flex}.user-picker-header h4{color:var(--text-primary);margin:0;font-size:.9rem}.user-picker-search{position:relative}.user-picker-search .search-input{height:32px;margin-bottom:0;font-size:.8rem;padding-left:2rem!important}.user-picker-grid{grid-template-columns:repeat(4,1fr);gap:10px;max-height:200px;padding:4px;display:grid;overflow-y:auto}.picker-user-option{cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;outline:none;flex-direction:column;align-items:center;gap:4px;padding:4px;transition:all .15s;display:flex}.picker-user-option:hover{background:var(--bg-secondary)}.picker-user-option:hover .picker-avatar-circle{transform:scale(1.08)}.picker-avatar-circle{color:#fff;border:1px solid var(--border);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:.75rem;font-weight:700;transition:transform .15s;display:flex;overflow:hidden}.picker-avatar-circle img{object-fit:cover;width:100%;height:100%}.picker-user-name{color:var(--text-secondary);text-align:center;white-space:nowrap;text-overflow:ellipsis;width:100%;font-size:.7rem;font-weight:600;overflow:hidden}.picker-empty{text-align:center;color:var(--text-tertiary);grid-column:span 4;padding:12px 0;font-size:.8rem}.custom-datepicker-container{width:100%;display:inline-block;position:relative}.custom-datepicker-input-wrapper{cursor:pointer;align-items:center;width:100%;display:flex;position:relative}.datepicker-display-input{border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;font-family:var(--font-body);color:var(--text-primary);cursor:pointer;text-align:left;font-size:.88rem;background:var(--surface)!important;padding:.45rem 2rem .45rem .75rem!important}.custom-datepicker-input-wrapper:hover .datepicker-display-input{border-color:var(--accent)}.datepicker-icon{color:var(--text-secondary);pointer-events:none;transition:color .15s;position:absolute;right:.75rem}.custom-datepicker-input-wrapper:hover .datepicker-icon{color:var(--accent)}.custom-datepicker-calendar{z-index:1050;background:var(--surface);border:1.5px solid var(--border-light);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);width:280px;padding:1rem;animation:.2s slideUp;position:absolute;top:calc(100% + 6px);left:0}.datepicker-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.datepicker-month-year{color:var(--text-primary);font-size:.9rem;font-weight:700}.btn-icon-nav{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:4px;transition:background .15s,color .15s;display:flex}.btn-icon-nav:hover{background:var(--bg-secondary);color:var(--accent)}.datepicker-weekdays{text-align:center;grid-template-columns:repeat(7,1fr);margin-bottom:.5rem;display:grid}.weekday-label{color:var(--text-tertiary);padding:4px 0;font-size:.75rem;font-weight:700}.datepicker-weekdays .weekday-label:nth-child(6),.datepicker-weekdays .weekday-label:nth-child(7){color:var(--danger)}.datepicker-days-grid{grid-template-columns:repeat(7,1fr);gap:4px;display:grid}.datepicker-day-btn{font-family:var(--font-body);color:var(--text-primary);cursor:pointer;aspect-ratio:1;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:6px 0;font-size:.82rem;font-weight:600;transition:background .15s,color .15s,transform .1s;display:flex}.datepicker-day-btn:hover{background:var(--accent-light);color:var(--accent);transform:scale(1.05)}.datepicker-day-btn.other-month{color:var(--text-tertiary);opacity:.5}.datepicker-day-btn.today{border:1px solid var(--accent)}.datepicker-day-btn.selected{font-weight:700;background:var(--accent)!important;color:var(--surface)!important}.datepicker-footer{border-top:1px solid var(--border-light);justify-content:flex-end;margin-top:.75rem;padding-top:.5rem;display:flex}.datepicker-footer .btn-sm{padding:.25rem .5rem;font-size:.78rem}.confirm-modal-overlay{-webkit-backdrop-filter:blur(4px);z-index:1100;background:#2d2a25a6;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.confirm-modal-content{background:var(--surface);border:1.5px solid var(--border-light);border-radius:var(--radius-lg);width:90%;max-width:440px;box-shadow:var(--shadow-lg);color:var(--text-primary);padding:1.75rem;animation:.22s cubic-bezier(.34,1.56,.64,1) scaleUp;position:relative}.confirm-modal-header h3{color:var(--text-primary);margin:0 0 1rem;font-size:1.15rem;font-weight:700}.confirm-modal-body{color:var(--text-secondary);margin-bottom:1.5rem;font-size:.92rem;line-height:1.5}.confirm-modal-body p{margin-bottom:1rem}.confirm-details-box{background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-md);flex-direction:column;gap:8px;margin-bottom:1rem;padding:.85rem 1rem;display:flex}.confirm-detail-row{justify-content:space-between;align-items:center;font-size:.85rem;display:flex}.confirm-detail-row.total-row{border-top:1px solid var(--border);margin-top:4px;padding-top:8px;font-weight:700}.confirm-warning-note{background:var(--warning-light);border-radius:var(--radius-sm);border:1px solid #d4a84333;gap:10px;margin-top:.75rem;padding:.75rem;display:flex}.confirm-warning-note p{color:#8c661b;margin:0;font-size:.8rem;line-height:1.4}.confirm-warning-note .warning-icon{font-size:1.1rem;line-height:1.2}.confirm-modal-footer{justify-content:flex-end;gap:12px;display:flex}@keyframes scaleUp{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.mobile-cart-tab{z-index:99;border:1px solid var(--border);cursor:pointer;border-right:none;border-radius:16px 0 0 16px;justify-content:center;align-items:center;width:54px;height:58px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:60%;right:0;transform:translateY(-50%);box-shadow:-4px 0 20px #0000001a}.tab-icon-wrapper{justify-content:center;align-items:center;display:flex;position:relative}.tab-badge{background:var(--danger);color:#fff;border:2px solid;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:.7rem;font-weight:800;display:flex;position:absolute;top:-8px;right:-8px;box-shadow:0 2px 6px #00000026}.mobile-cart-tab.status-empty{background:var(--surface);color:var(--text-secondary)}.mobile-cart-tab.status-pending{background:var(--warning);color:#fff;border-color:var(--warning);animation:2s infinite tabPulseWarning}.mobile-cart-tab.status-ordered{background:var(--accent);color:#fff;border-color:var(--accent);animation:2s infinite tabPulseActive}.mobile-cart-tab.status-delivered{background:var(--success);color:#fff;border-color:var(--success);animation:1.5s ease-in-out infinite alternate tabWiggleDelivered}@keyframes tabPulseWarning{0%{box-shadow:-4px 0 20px #d4a84326,0 0 #d4a84366}70%{box-shadow:-4px 0 25px #d4a8434d,0 0 0 10px #d4a84300}to{box-shadow:-4px 0 20px #d4a84326,0 0 #d4a84300}}@keyframes tabPulseActive{0%{box-shadow:-4px 0 20px #5900ff26,0 0 #5900ff66}70%{box-shadow:-4px 0 25px #5900ff4d,0 0 0 10px #5900ff00}to{box-shadow:-4px 0 20px #5900ff26,0 0 #5900ff00}}@keyframes tabWiggleDelivered{0%{transform:translateY(-50%)rotate(0)}15%{transform:translateY(-50%)rotate(-8deg)}30%{transform:translateY(-50%)rotate(6deg)}45%{transform:translateY(-50%)rotate(-4deg)}60%{transform:translateY(-50%)rotate(2deg)}75%{transform:translateY(-50%)rotate(0)}to{transform:translateY(-50%)rotate(0)}}.mobile-drawer-backdrop{-webkit-backdrop-filter:blur(4px);z-index:1000;background:#0006;position:fixed;inset:0}.mobile-drawer{background:var(--surface);border-left:1px solid var(--border);z-index:1001;flex-direction:column;width:90%;max-width:360px;display:flex;position:fixed;top:0;bottom:0;right:0;overflow:hidden;box-shadow:-10px 0 40px #00000026}.drawer-header{border-bottom:1px solid var(--border);background:#00000003;flex-direction:column;flex-shrink:0;gap:.75rem;padding:1.25rem 1.25rem .75rem;display:flex}.drawer-header-top{justify-content:space-between;align-items:center;width:100%;display:flex}.drawer-title{color:var(--text-primary);font-size:1.05rem;font-weight:800}.drawer-tabs{background:var(--bg-secondary);border-radius:var(--radius-sm);width:100%;padding:4px;display:flex}.drawer-tab-btn{color:var(--text-secondary);border-radius:calc(var(--radius-sm) - 2px);cursor:pointer;background:0 0;border:none;flex:1;justify-content:center;align-items:center;gap:6px;padding:8px 12px;font-size:.85rem;font-weight:700;transition:all .2s;display:flex}.drawer-tab-btn.active{background:var(--surface);color:var(--accent);box-shadow:var(--shadow-sm)}.drawer-close-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:4px;font-size:1.2rem;transition:color .2s;display:flex}.drawer-close-btn:hover{color:var(--danger)}.drawer-content{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.mobile-drawer .cart-panel{box-shadow:none;padding:1.25rem 1.25rem calc(1.25rem + env(safe-area-inset-bottom));background:0 0;border:none;flex:1;min-height:0;overflow-y:auto}.mobile-drawer .admin-orders-panel{box-shadow:none;padding:1.25rem 1.25rem calc(1.25rem + env(safe-area-inset-bottom));background:0 0;border:none;flex:1;min-height:0;overflow:hidden;flex-direction:column!important;display:flex!important}.mobile-drawer .admin-orders-panel .admin-panel-body{flex:1;overflow-y:auto}@media (width<=768px){.main-content-layout.has-cart{grid-template-columns:1fr!important}}.cart-indicator-container{perspective:1000px;box-sizing:content-box;width:100%;height:360px;margin:.5rem 0 1rem;padding:10px 0}.cart-indicator-card{width:100%;height:340px;transform-style:preserve-3d;border-radius:var(--radius-lg);cursor:pointer;box-shadow:var(--shadow-md);transition:transform .7s cubic-bezier(.175,.885,.32,1.2),box-shadow .6s;position:relative}.cart-indicator-card.flipped{transform:rotateY(180deg)}.cart-indicator-card.flying{box-shadow:var(--shadow-lg), 0 25px 35px #0000001a;transform:rotateY(180deg)translateY(-14px)scale(1.03)}.cart-indicator-card:not(.flipped):hover{box-shadow:var(--shadow-md), 0 8px 16px #0000000d;transform:translateY(-4px)}.cart-card-side{backface-visibility:hidden;border-radius:var(--radius-lg);box-sizing:border-box;flex-direction:column;width:100%;height:100%;padding:1.25rem 1rem;display:flex;position:absolute;overflow:hidden}.cart-card-front{text-align:center;color:#fff;background:linear-gradient(135deg,#e07a5f 0%,#c67b4b 100%);border:2px dashed #fff6;justify-content:center;align-items:center;gap:8px;transition:border-color .3s,background .3s}.cart-card-front.delivered{color:#fff;background:linear-gradient(135deg,#82c09a 0%,#4a8c66 100%);border:2px dashed #fff6;justify-content:center;gap:8px}.cart-card-front h4{margin:.25rem 0 .15rem;font-size:1.1rem;font-weight:700}.cart-card-front.delivered h4{color:#fff;margin:.5rem 0 .25rem;font-size:1.15rem}.cart-card-front p{color:#ffffffd9;margin:0;font-size:.8rem}.cart-card-front.delivered p{color:#ffffffd9}.cart-card-price-badge{color:#c67b4b;background:#fffffff2;border-radius:20px;align-items:center;gap:4px;margin-top:.4rem;padding:.25rem .75rem;font-size:.9rem;font-weight:800;display:inline-flex;box-shadow:0 4px 10px #0000001a}.qr-code-payment-btn{border-radius:var(--radius-md);background:#fff;border:2px solid #fffc;flex-shrink:0;justify-content:center;align-items:center;width:136px;height:136px;margin-top:.5rem;padding:.6rem;transition:all .25s cubic-bezier(.175,.885,.32,1.275);display:flex;position:relative;overflow:hidden;box-shadow:0 4px 6px #0000001f,inset 0 -3px #0000001a;color:var(--text-primary)!important;text-decoration:none!important}.qr-code-payment-btn:hover{border-color:#fff;transform:translateY(-2px)scale(1.03);box-shadow:0 8px 15px #0000002e,inset 0 -3px #0000001a}.qr-code-payment-btn:active{transform:translateY(1px);box-shadow:0 2px 4px #0000001a}.qr-image-wrapper{border:1px solid var(--border-light);background:#fff;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:116px;height:116px;display:flex;position:relative;overflow:hidden}.qr-code-img{object-fit:contain;width:100%;height:100%}.qr-scanner-line{z-index:2;opacity:.8;background:#2ecc71;height:2px;animation:2s linear infinite laserScan;position:absolute;left:0;right:0;box-shadow:0 0 6px #2ecc71,0 0 10px #2ecc71}@keyframes laserScan{0%{top:0}50%{top:100%}to{top:0}}.qr-btn-text{text-align:center;flex-direction:column;align-items:center;display:flex}.qr-btn-title{color:#1a1a1a;margin-bottom:1px;font-size:.7rem;font-weight:800;line-height:1.2}.qr-btn-desc{color:#666;font-size:.58rem;line-height:1.1}.flip-card-trigger{color:#ffffffd9;text-transform:uppercase;letter-spacing:.05em;background:#ffffff1f;border:1px solid #fff3;border-radius:10px;align-items:center;gap:4px;margin-top:auto;padding:.3rem .6rem;font-size:.7rem;font-weight:700;transition:all .2s;display:flex}.flip-card-trigger:hover{color:#fff;background:#ffffff38}.cart-card-back{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);flex-direction:column;padding:1.25rem 1rem;display:flex;overflow:hidden;transform:rotateY(180deg)translateZ(1px)}.cart-card-back h4{border-bottom:1px solid var(--border-light);color:var(--text-primary);margin:0 0 .5rem;padding-bottom:.5rem;font-size:.95rem}.cart-card-back-items{flex:1;margin-bottom:.5rem;overflow-y:auto}.cart-card-back-total{border-top:1px solid var(--border-light);justify-content:space-between;padding-top:.5rem;font-size:.95rem;font-weight:700;display:flex}.delivery-bike-svg{width:120px;height:68px;margin-top:-.2rem}.delivery-road{animation:.8s linear infinite roadMove}@keyframes roadMove{0%{stroke-dashoffset:0}to{stroke-dashoffset:-22px}}.bicycle-rider{animation:.5s ease-in-out infinite ride}@keyframes ride{0%,to{transform:translateY(0)}50%{transform:translateY(-2.5px)}}.back-wheel{transform-origin:50px 95px;animation:.6s linear infinite spinWheel}.front-wheel{transform-origin:150px 95px;animation:.6s linear infinite spinWheel}@keyframes spinWheel{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.backpack{transform-origin:69px 62px;animation:.4s ease-in-out infinite alternate backpackShake}@keyframes backpackShake{0%{transform:rotate(0)}to{transform:rotate(-3deg)translate(-.5px,.5px)}}.head{transform-origin:118px 30px;animation:1s ease-in-out infinite alternate headBobble}@keyframes headBobble{0%{transform:translate(0)rotate(0)}to{transform:translate(1px,-1.5px)rotate(3deg)}}.scarf{transform-origin:110px 36px;animation:.3s ease-in-out infinite alternate scarfWave}@keyframes scarfWave{0%{transform:scaleY(1)}to{transform:scaleY(1.3)skew(-4deg)}}.btn-locked{background:var(--bg-secondary)!important;color:var(--text-tertiary)!important;border:1px solid var(--border)!important;cursor:pointer!important;box-shadow:none!important;transform:none!important}.btn-locked:hover{background:var(--bg-tertiary)!important;color:var(--text-secondary)!important}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-20px)}60%{transform:translateY(-10px)}}@media (width<=480px){.card-image-wrapper{width:110px;padding:4px}}.hashtags-filter-container{scrollbar-width:none;-ms-overflow-style:none;align-items:center;gap:8px;margin-bottom:1.25rem;padding:8px 4px 14px;display:flex;position:relative;overflow-x:auto}.hashtags-filter-container::-webkit-scrollbar{display:none}.hashtag-pill{white-space:nowrap;background:var(--surface);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;box-shadow:var(--shadow-sm);border-radius:20px;align-items:center;padding:6px 12px;font-size:.8rem;font-weight:600;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}.hashtag-pill:hover{border-color:var(--accent);background:var(--accent-light);color:var(--accent);transform:translateY(-2px)}.hashtag-pill.active{background:linear-gradient(135deg, var(--accent) 0%, #7e3ff2 100%);border-color:var(--accent);transform:translateY(-1px)scale(1.02);box-shadow:0 4px 12px #5900ff33;color:#fff!important}.hashtag-count{opacity:.65;background:#0000000d;border-radius:10px;margin-left:5px;padding:1px 6px;font-size:.7rem}.hashtag-pill.active .hashtag-count{opacity:.95;background:#fff3}.btn-reset-tags{border:1px dashed var(--danger);color:var(--danger);cursor:pointer;white-space:nowrap;-webkit-user-select:none;user-select:none;background:0 0;border-radius:20px;align-items:center;gap:4px;padding:6px 12px;font-size:.8rem;font-weight:700;transition:all .2s;display:flex}.btn-reset-tags:hover{background:#dc354514;transform:scale(1.02)}.dish-card-tags{flex-wrap:wrap;gap:3px;max-height:31px;margin:0;display:flex;overflow:hidden}.dish-card-tag{background:var(--bg-secondary);border:1px solid var(--border-light);color:var(--text-secondary);cursor:pointer;border-radius:4px;align-items:center;padding:1px 4px;font-size:.62rem;font-weight:600;line-height:1.2;transition:all .15s;display:flex}.dish-card-tag:hover{background:var(--accent-light);border-color:var(--accent);color:var(--accent)}.dish-card-tag.active{background:var(--accent);border-color:var(--accent);color:#fff}.hashtags-panel{background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);flex-direction:column;gap:1.25rem;padding:1.25rem;display:flex}.hashtags-group-title{text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary);border-bottom:1px solid var(--border-light);margin-bottom:.5rem;padding-bottom:4px;font-size:.72rem;font-weight:700}.hashtags-group-list{flex-wrap:wrap;gap:8px;display:flex}.garnish-3d-button.active{border-color:var(--accent);background:var(--accent-light);color:var(--accent);box-shadow:0 0 10px #5900ff40}.header-active-tags-bar{border-top:1px solid var(--border-light);background:var(--surface);box-sizing:border-box;align-items:center;width:100%;padding:8px 1.5rem;display:flex}.header-active-tags-container{align-items:center;gap:12px;width:100%;max-width:1200px;margin:0 auto;display:flex}.active-tags-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;font-size:.72rem;font-weight:700}.active-tags-chips-wrapper{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.active-tag-chip{background:var(--accent-light);border:1px solid var(--accent);color:var(--accent);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:12px;align-items:center;padding:2px 8px;font-size:.7rem;font-weight:600;transition:all .15s;display:inline-flex}.active-tag-chip:hover{background:var(--accent);color:#fff}.active-tags-reset-btn{color:var(--danger);cursor:pointer;background:0 0;border:none;padding:2px 6px;font-size:.7rem;font-weight:700;transition:color .15s}.active-tags-reset-btn:hover{color:var(--accent-hover)}@media (width<=768px){.header-active-tags-bar{padding:8px 0}}.order-3d-button{transition:transform .2s cubic-bezier(.25,.8,.25,1.4),background .2s,box-shadow .2s,border-color .2s,color .2s!important}.order-3d-button:hover:not(:disabled):not(.locked){transform:translateY(-2px)}.order-3d-button.add-to-cart:hover:not(:disabled):not(.locked){box-shadow:0 5px #7a3d1a,0 6px 12px #b5683859,inset 0 1.5px #ffffff8c}.order-3d-button.ordered:hover:not(:disabled):not(.locked){box-shadow:0 5px #3e6a1f,0 6px 12px #6b9b5759,inset 0 1.5px #ffffff73}.order-3d-button:active:not(:disabled):not(.locked){transform:translateY(3px)!important}.order-3d-button .order-3d-inner svg{transition:transform .4s cubic-bezier(.34,1.56,.64,1)}.order-3d-button:hover:not(:disabled):not(.locked) .order-3d-inner svg{transform:rotate(90deg)}.dish-detail-modal-container{width:95%!important;max-width:520px!important;box-shadow:var(--shadow-lg), 0 20px 50px #0000001f!important;border:1px solid var(--border)!important;border-radius:20px!important;padding:0!important;overflow:hidden!important}.dish-detail-modal-container .modal-close{-webkit-backdrop-filter:blur(8px)!important;width:34px!important;height:34px!important;color:var(--text-primary)!important;z-index:100!important;background:#fffc!important;border:1px solid #fff9!important;border-radius:50%!important;justify-content:center!important;align-items:center!important;font-size:1.15rem!important;font-weight:700!important;transition:all .2s!important;display:flex!important;top:12px!important;right:12px!important;box-shadow:0 4px 12px #0000001f!important}.dish-detail-modal-container .modal-close:hover{background:#fff!important;transform:scale(1.08)!important;box-shadow:0 4px 16px #0000002e!important}.dish-detail-hero{background:var(--bg-secondary);border-bottom:1px solid var(--border-light);width:100%;height:180px;position:relative;overflow:hidden}.dish-detail-hero-img{object-fit:cover;width:100%;height:100%;display:block}.dish-detail-hero-placeholder{background:linear-gradient(135deg, var(--bg-secondary) 0%, var(--bg-tertiary) 100%);width:100%;height:100%;color:var(--text-tertiary);opacity:.8;justify-content:center;align-items:center;display:flex}.dish-detail-hero-overlay{pointer-events:none;background:linear-gradient(#0000,#0000001f);height:50px;position:absolute;bottom:0;left:0;right:0}.dish-detail-body{max-height:calc(90vh - 260px);padding:1.25rem 1.5rem .5rem;overflow-y:auto}.dish-detail-title{color:var(--text-primary);text-transform:capitalize;margin-bottom:.4rem;font-size:1.35rem;font-weight:800;line-height:1.2}.health-rating-widget{align-items:center;gap:10px;margin-bottom:1rem;display:flex}.health-score-badge{background:var(--success-light);color:var(--success);border:1px solid #6b9b5726;border-radius:8px;align-items:baseline;padding:3px 8px;font-size:.95rem;font-weight:800;display:inline-flex}.health-score-max{opacity:.7;font-size:.7rem;font-weight:600}.health-rating-info{flex-direction:column;display:flex}.health-stars-row{color:var(--warning);letter-spacing:1px;font-size:.95rem;line-height:1.1}.health-label-text{color:var(--text-secondary);font-size:.72rem;font-weight:600}.nutrition-grid-modern{grid-template-columns:repeat(4,1fr);gap:8px;margin:.75rem 0;display:grid}.nutrition-card{border-radius:var(--radius-sm);border:1px solid var(--border-light);flex-direction:column;justify-content:center;align-items:center;padding:8px 4px;transition:transform .2s,box-shadow .2s;display:flex}.nutrition-card:hover{box-shadow:var(--shadow-sm);transform:translateY(-2px)}.nutrition-card.kcal{background:#faf4ec;border-color:#b88b6326}.nutrition-card.kcal .nutrition-val-num{color:#9c6e46}.nutrition-card.prot{background:#f3f7f0;border-color:#6b9b5726}.nutrition-card.prot .nutrition-val-num{color:#527840}.nutrition-card.fat{background:#faf6ec;border-color:#b59a5a26}.nutrition-card.fat .nutrition-val-num{color:#937737}.nutrition-card.carb{background:#f0f4f7;border-color:#6d869f26}.nutrition-card.carb .nutrition-val-num{color:#4a6078}.nutrition-val-num{margin-top:2px;font-size:.95rem;font-weight:800;line-height:1.1}.macro-balance-section{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-sm);margin-bottom:1rem;padding:10px 12px}.macro-bar-container{background:var(--bg-secondary);border-radius:4px;height:8px;margin-bottom:6px;display:flex;overflow:hidden}.macro-segment{height:100%;transition:width .3s}.macro-segment.prot{background:#6b9b57}.macro-segment.fat{background:#c8a858}.macro-segment.carb{background:#6d869f}.macro-legend{color:var(--text-secondary);justify-content:space-between;font-size:.7rem;font-weight:600;display:flex}.macro-legend-item{align-items:center;gap:4px;display:flex}.macro-dot{border-radius:50%;width:5px;height:5px}.macro-dot.prot{background:#6b9b57}.macro-dot.fat{background:#c8a858}.macro-dot.carb{background:#6d869f}.analysis-list-modern{flex-direction:column;gap:6px;margin:.5rem 0 1rem;display:flex}.analysis-item-modern{border-radius:var(--radius-sm);align-items:flex-start;gap:8px;padding:6px 10px;font-size:.8rem;font-weight:600;line-height:1.4;display:flex}.analysis-item-modern.positive{color:#527840;background:#f3f7f0;border:1px solid #6b9b571f}.analysis-item-modern.warning{color:#a64b3e;background:#fdf1ee;border:1px solid #c5685b1f}.analysis-icon-wrapper{flex-shrink:0;justify-content:center;align-items:center;margin-top:2px;display:flex}.ingredients-section{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-sm);margin-bottom:1rem;padding:10px 12px}.ingredients-title{text-transform:uppercase;color:var(--text-secondary);letter-spacing:.05em;margin-bottom:4px;font-size:.72rem;font-weight:700}.ingredients-text{color:var(--text-secondary);margin:0;font-size:.8rem;line-height:1.45}.dish-detail-footer{border-top:1px solid var(--border-light);z-index:10;background:#fff;justify-content:space-between;align-items:center;padding:.85rem 1.5rem;display:flex;position:sticky;bottom:0;left:0;right:0;box-shadow:0 -4px 16px #00000005}.dish-detail-footer-info{flex-direction:column;display:flex}.dish-detail-price{color:var(--text-primary);font-size:1.3rem;font-weight:800;line-height:1.1}.dish-detail-meta{color:var(--text-secondary);margin-top:2px;font-size:.7rem;font-weight:600}.header-tags-strip-bar{background:var(--surface);border-bottom:1px solid var(--border-light);padding:.5rem 0;position:relative;overflow:hidden}.header-tags-strip-container{scrollbar-width:none;-webkit-overflow-scrolling:touch;cursor:grab;will-change:scroll-position;backface-visibility:hidden;gap:.5rem;width:100%;max-width:1200px;margin:0 auto;padding:4px 0;display:flex;overflow-x:auto}.header-tags-strip-container.grabbing{cursor:grabbing;-webkit-user-select:none;user-select:none}.header-tags-strip-container::-webkit-scrollbar{display:none}.header-tag-pill{white-space:nowrap;background:var(--bg-secondary);border:1px solid var(--border-light);color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;box-shadow:var(--shadow-sm);border-radius:20px;outline:none;flex-shrink:0;align-items:center;padding:6px 14px;font-size:.825rem;font-weight:600;transition:transform .2s cubic-bezier(.4,0,.2,1),border-color .2s cubic-bezier(.4,0,.2,1),background-color .2s cubic-bezier(.4,0,.2,1),color .2s cubic-bezier(.4,0,.2,1),box-shadow .2s cubic-bezier(.4,0,.2,1);display:inline-flex}.header-tag-pill:hover{border-color:var(--accent);background:var(--accent-light);color:var(--accent);transform:translateY(-1px)}.header-tag-pill.active{background:linear-gradient(135deg, var(--accent) 0%, #7e3ff2 100%);border-color:var(--accent);transform:translateY(-1px)scale(1.02);box-shadow:0 4px 12px #5900ff33;color:#fff!important}.header-tag-pill.pinned{background:var(--accent-light);border:1px solid var(--accent);color:var(--accent);font-weight:700}.header-tag-pill.pinned:hover{background:var(--accent);color:#fff}.pinned-tags-container{background:var(--surface);z-index:10;flex-shrink:0;align-items:center;gap:.5rem;padding-left:1.5rem;padding-right:.75rem;display:flex;position:sticky;left:0}.pinned-tags-container:after{content:"";background:linear-gradient(to right, var(--surface), transparent);pointer-events:none;width:1.5rem;position:absolute;top:0;bottom:0;right:0;transform:translate(100%)}.tags-vertical-divider{border-left:1px dashed var(--border);flex-shrink:0;width:1px;height:18px;margin:0 .25rem 0 .5rem}.scrollable-tags-list{flex-shrink:0;align-items:center;gap:.5rem;padding-right:1.5rem;display:flex}.scrollable-tags-list:first-child{padding-left:1.5rem}.header-tag-pill.hero-recommendation{color:#b27a00;background:linear-gradient(135deg,#fffbf0 0%,#fff3d1 100%);border:1px solid #ffd043;font-weight:700;animation:3s ease-in-out infinite hero-shimmer;box-shadow:0 2px 6px #ffd04326}.header-tag-pill.hero-recommendation:hover{color:#996300;background:linear-gradient(135deg,#fff3d1 0%,#ffe9a6 100%);transform:translateY(-1px)scale(1.02)}.header-tag-pill.search-matched{animation:2.2s ease-in-out infinite match-pulse;border-color:var(--danger)!important;color:var(--danger)!important;background:#ef44440d!important}.tags-fade-left{background:linear-gradient(to right, var(--surface), transparent);pointer-events:none;z-index:5;opacity:0;visibility:hidden;width:50px;position:absolute;top:0;bottom:0;left:0}.tags-fade-right{background:linear-gradient(to right, transparent, var(--surface));pointer-events:none;z-index:5;opacity:0;visibility:hidden;width:50px;position:absolute;top:0;bottom:0;right:0}@keyframes hero-shimmer{0%,to{border-color:#ffd043;box-shadow:0 2px 6px #ffd04326}50%{border-color:#ffbe00;box-shadow:0 2px 14px #ffd04359}}@keyframes match-pulse{0%,to{transform:scale(1);box-shadow:0 0 #ef444400}50%{transform:scale(1.03);box-shadow:0 0 10px #ef444440}}.admin-tags-container{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:2rem;padding:1.5rem}.admin-tags-header{justify-content:space-between;align-items:center;margin-bottom:1.25rem;display:flex}.admin-tags-legend{gap:1.5rem;font-size:.8rem;font-weight:600;display:flex}.legend-item{align-items:center;gap:6px;display:flex}.legend-color-dot{border-radius:3px;width:10px;height:10px}.legend-color-dot.site{border:1.5px solid var(--info);background:var(--info-light)}.legend-color-dot.assigned{border:1.5px solid var(--accent);background:var(--accent-light)}.admin-tags-instructions{color:var(--text-secondary);background:var(--surface);border-radius:var(--radius-sm);border-left:3px solid var(--accent);margin-bottom:1.5rem;padding:.75rem 1rem;font-size:.85rem}.admin-tags-reorder-group{flex-wrap:wrap;gap:10px;min-height:80px;margin:0;padding:0;list-style:none;display:flex}.admin-tag-reorder-item{-webkit-user-select:none;user-select:none;cursor:grab;flex-shrink:0;position:relative}.admin-tag-reorder-item:active{cursor:grabbing}.admin-tag-reorder-item:before,.admin-tag-reorder-item:after{content:"";background-color:var(--accent);opacity:0;pointer-events:none;z-index:10;border-radius:2px;width:4px;transition:opacity .15s;position:absolute;top:4px;bottom:4px}.admin-tag-reorder-item:before{left:-7px}.admin-tag-reorder-item:after{right:-7px}.admin-tag-reorder-item.drag-over-before:before,.admin-tag-reorder-item.drag-over-after:after{opacity:1}.admin-tag-pill{white-space:nowrap;box-shadow:var(--shadow-sm);border-radius:20px;align-items:center;padding:6px 14px;font-size:.825rem;font-weight:700;transition:transform .15s,box-shadow .15s;display:inline-flex}.admin-tag-pill:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.admin-tag-pill.site-tag{border:1.5px solid var(--info);background-color:var(--info-light);color:#1e40af}.admin-tag-pill.assigned-tag{border:1.5px solid var(--accent);background-color:var(--accent-light);color:var(--accent-hover)}.admin-tag-drag-handle{opacity:.5;align-items:center;margin-right:6px;font-size:.7rem;display:inline-flex}.grouping-toggle-btn,.unavailable-toggle-btn{background:var(--surface);border:1px solid var(--border-light);width:40px;height:40px;color:var(--text-secondary);cursor:pointer;box-shadow:var(--shadow-sm);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex}.grouping-toggle-btn:hover,.unavailable-toggle-btn:hover{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-medium);box-shadow:var(--shadow-md);transform:translateY(-2px)}.grouping-toggle-btn:active,.unavailable-toggle-btn:active{transform:translateY(1px)}.grouping-toggle-btn.active,.unavailable-toggle-btn.active{background:var(--accent-light);border-color:var(--accent);color:var(--accent);box-shadow:0 0 12px #c67b4b40}.grouping-toggle-btn.active:hover,.unavailable-toggle-btn.active:hover{background:var(--accent-light);color:var(--accent);box-shadow:0 0 16px #c67b4b66}.grid-group-header{background:var(--surface-glass,#ffffffbf);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-light);border-left:4px solid var(--accent);border-radius:var(--radius-md,12px);box-shadow:var(--shadow-sm);z-index:10;grid-column:1/-1;justify-content:space-between;align-items:center;margin:1.5rem 0 .5rem;padding:.75rem 1.25rem;display:flex}.grid-group-header-title{font-family:var(--font-body);color:var(--text-primary);align-items:center;gap:.6rem;font-size:1.05rem;font-weight:700;display:flex}.grid-group-header-count{color:var(--text-tertiary);background:var(--bg-tertiary);border:1px solid var(--border-light);border-radius:20px;padding:.2rem .6rem;font-size:.8rem;font-weight:600}.profile-avatar-clickable{transition:all .25s cubic-bezier(.4,0,.2,1)}.profile-avatar-clickable.admin-avatar{border:2px solid var(--accent)!important}.profile-avatar-clickable.admin-avatar:hover{transform:scale(1.08);box-shadow:0 0 8px #c67b4b66;border-color:var(--accent-hover)!important}.profile-avatar-clickable.user-avatar{border:2px solid var(--success)!important}.profile-avatar-clickable.user-avatar:hover{transform:scale(1.08);box-shadow:0 0 8px #6b9b5766;border-color:#558242!important}.profile-avatar-clickable:active{transform:scale(.95)}.profile-modal-card-container{perspective:1000px;z-index:1001;width:92%;max-width:335px;height:530px;transition:max-width .6s cubic-bezier(.175,.885,.32,1.275),height .6s cubic-bezier(.175,.885,.32,1.275);animation:.25s slideUp;position:relative}.profile-modal-card-container.details-mode{max-width:370px;height:590px}.profile-card-flipper{width:100%;height:100%;transform-style:preserve-3d;border-radius:var(--radius-lg);transition:transform .7s cubic-bezier(.175,.885,.32,1.2),box-shadow .6s;position:relative}.profile-card-flipper.flipped{transform:rotateY(180deg)}.profile-card-flipper:not(.flipped) .profile-card-front{backface-visibility:visible!important;visibility:visible!important;opacity:1!important;transition:transform .3s,border-color .3s,box-shadow .3s,opacity,visibility!important;transform:none!important}.profile-card-flipper.flipped .profile-card-back{backface-visibility:visible!important;visibility:visible!important;opacity:1!important;transition:opacity,visibility!important;transform:rotateY(180deg)!important}.profile-card-side{backface-visibility:hidden;border-radius:var(--radius-lg);box-sizing:border-box;background:var(--surface);border:1px solid var(--border-light);width:100%;height:100%;box-shadow:var(--shadow-lg);color:var(--text-primary);flex-direction:column;display:flex;position:absolute}.profile-card-front{text-align:center;cursor:pointer;visibility:visible;opacity:1;justify-content:flex-start;align-items:center;padding:2.25rem 2rem;transition:transform .3s,border-color .3s,box-shadow .3s,opacity,visibility;overflow:hidden}.profile-card-flipper.flipped .profile-card-front{visibility:hidden;opacity:0;transition:opacity 0s .35s,visibility 0s .35s}.profile-card-front:hover{box-shadow:var(--shadow-xl), 0 12px 24px #0000000d;border-color:var(--border);transform:translateY(-2px)}.profile-card-back{visibility:hidden;opacity:0;padding:1.5rem;transition:opacity 0s .35s,visibility 0s .35s;overflow-y:auto;transform:rotateY(180deg)translateZ(1px)}.profile-modal-avatar{width:80px;height:80px;box-shadow:var(--shadow-md);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-bottom:.75rem;transition:border-color .25s;display:flex;overflow:hidden}.profile-modal-avatar.admin-avatar{border:3px solid var(--accent)}.profile-modal-avatar.user-avatar{border:3px solid var(--success)}.profile-modal-avatar img{object-fit:cover;width:100%;height:100%}.profile-modal-avatar span{color:var(--text-primary);justify-content:center;align-items:center;width:100%;height:100%;font-size:2.2rem;font-weight:700;display:flex}.profile-card-side h3{color:var(--text-primary);flex-shrink:0;margin:0 0 .35rem;font-size:1.3rem;font-weight:700}.profile-debt-block{flex-direction:column;flex-shrink:0;align-items:center;gap:.75rem;width:100%;margin:.5rem 0 1rem;display:flex}.profile-debt-section{background:var(--surface);border:1px solid var(--border-light);width:100%;box-shadow:var(--shadow-sm);border-radius:12px;flex-direction:column;flex-shrink:0;align-items:center;gap:.75rem;padding:.85rem 1rem;display:flex}.profile-debt-amount-large{color:var(--danger);flex-shrink:0;margin-bottom:.15rem;font-size:1.6rem;font-weight:800;line-height:1.2}.profile-debt-badge{color:var(--text-secondary);font-size:.9rem;font-weight:500}.profile-debt-badge .debt-amount{color:var(--danger);margin-left:4px;font-size:1.2rem;font-weight:800}.profile-qr-payment-btn{border:1px solid var(--border);width:136px;box-shadow:var(--shadow-sm);background:#fff;border-radius:12px;flex-direction:column;flex-shrink:0;align-items:center;padding:8px;text-decoration:none;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex}.profile-qr-payment-btn:hover{border-color:var(--success);transform:translateY(-2px)scale(1.03);box-shadow:0 8px 24px #6b9b5726}.profile-qr-image-wrapper{background:#fff;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:118px;height:118px;display:flex;position:relative;overflow:hidden}.profile-qr-code-img{object-fit:contain;flex-shrink:0;width:100%;height:100%}.profile-qr-payment-btn .qr-scanner-line{z-index:2;opacity:.8;background:#2ecc71;height:2px;animation:2s linear infinite laserScan;position:absolute;left:0;right:0;box-shadow:0 0 6px #2ecc71,0 0 10px #2ecc71}.profile-card-flipper.flipped .qr-scanner-line{animation:none!important;display:none!important}.profile-card-flipper.flipped .profile-qr-payment-btn{display:none!important}.profile-qr-tip{color:var(--text-tertiary);text-align:center;margin-top:8px;font-size:.62rem;line-height:1.3}.profile-pay-btn{cursor:pointer;width:100%;background:var(--success)!important;color:#fff!important;border:none!important;border-radius:10px!important;padding:.75rem 1rem!important;font-size:.95rem!important;font-weight:600!important;transition:all .2s!important;box-shadow:0 4px 12px #6b9b5733!important}.profile-pay-btn:hover{transform:translateY(-1px);background:#558242!important;box-shadow:0 6px 16px #6b9b574d!important}.profile-pay-btn:active{transform:translateY(0)}.profile-no-debt-section{justify-content:center;width:100%;display:flex}.profile-balance-badge{text-align:center;border-radius:20px;width:100%;padding:.6rem 1.25rem;font-size:.95rem;font-weight:600}.profile-balance-badge.advance{background:var(--success-light);color:var(--success);border:1px solid #6b9b5733}.profile-balance-badge.advance .balance-amount{margin-left:2px;font-weight:800}.profile-balance-badge.success-clean{background:var(--success-light);color:var(--success);border:1px solid #6b9b5733;justify-content:center;align-items:center;gap:6px;display:flex}.profile-undo-section{background:var(--warning-light,#fefbf3);border:1px dashed var(--warning,#d4a843);border-radius:10px;justify-content:space-between;align-items:center;gap:8px;width:100%;margin-top:.5rem;padding:.75rem;animation:.3s fadeIn;display:flex}.profile-undo-text{color:var(--text-secondary);font-size:.8rem;font-weight:500}.profile-undo-btn{color:var(--accent)!important;cursor:pointer!important;background:0 0!important;border:none!important;padding:0!important;font-size:.8rem!important;font-weight:700!important;text-decoration:underline!important;transition:color .2s!important}.profile-undo-btn:hover{color:var(--accent-hover)!important}.profile-modal-actions{flex-shrink:0;width:100%}.profile-modal-actions .logout-btn{border:1px solid var(--border-light);background:var(--danger-light,#ef444414);width:100%;color:var(--danger,#ef4444);border-radius:10px;justify-content:center;align-items:center;gap:8px;padding:.75rem;font-weight:600;transition:all .2s;display:flex}.profile-modal-actions .logout-btn:hover{background:var(--danger);color:#fff;border-color:var(--danger);box-shadow:0 4px 12px #ef444433}@media (width<=768px){.nav-bar{z-index:1000;box-shadow:var(--shadow-sm);left:0;right:0;-webkit-backdrop-filter:blur(12px)!important;border-bottom:1px solid var(--border-light)!important;background:#fbfaf7f0!important;margin-bottom:1rem!important;position:sticky!important;top:0!important}.nav-bar-container{width:100%;display:flex;flex-direction:column!important;align-items:stretch!important;gap:.6rem!important;padding:.6rem .75rem!important}.mobile-header-line-1{justify-content:space-between;align-items:center;gap:.6rem;width:100%;display:flex}.mobile-header-line-1 .header-controls{flex:1;align-items:center;gap:.5rem;width:auto;margin:0;display:flex}.mobile-header-line-1 .header-search-wrapper{flex:1}.mobile-header-line-2-admin{border-top:1px solid var(--border-light);justify-content:flex-start;align-items:center;gap:1rem;padding:.4rem 0 .1rem;display:flex}.mobile-header-line-2-admin .nav-links{justify-content:space-around;gap:.5rem;width:100%;display:flex}.mobile-header-line-2-admin .nav-link{align-items:center;gap:4px;padding:.35rem .75rem;font-size:.85rem;display:flex}}.payment-toggle-btn{cursor:pointer;-webkit-user-select:none;user-select:none;color:#fff;background:#ffffff26;border:1.5px solid #fff6;border-radius:20px;flex-shrink:0;justify-content:center;align-items:center;gap:8px;width:75%;max-width:180px;margin-top:.25rem;padding:.45rem 1.25rem;font-size:.8rem;font-weight:700;transition:all .25s,margin-top .5s cubic-bezier(.25,.8,.25,1.1);display:inline-flex}.payment-toggle-btn:hover{background:#ffffff47;border-color:#fff9;transform:translateY(-1.5px)}.payment-toggle-btn:active{transform:translateY(.5px)}.payment-toggle-btn.paid{color:#fff;background:#2ecc71;border-color:#2ecc71;box-shadow:0 4px 10px #2ecc7159}.payment-toggle-btn.paid:hover{background:#27ae60;border-color:#27ae60;box-shadow:0 6px 14px #2ecc7173}.delivery-bike-svg{transition:transform .6s cubic-bezier(.25,.8,.25,1.25)}.cart-card-price-badge,.qr-code-payment-btn{opacity:1;max-height:160px;transition:opacity .5s cubic-bezier(.4,0,.2,1),transform .5s cubic-bezier(.4,0,.2,1),max-height .5s,margin .5s,padding .5s}.cart-card-front.paid-state{border:2px solid #ffffffd9;box-shadow:0 8px 32px #c67b4b40,inset 0 0 20px #ffffff26}.paid-state .payment-toggle-btn{margin-top:55px}.paid-state .delivery-bike-svg,.paid-state .delivered-plate-svg{transform:scale(1.65)translateY(12px)}.delivered-plate-svg{width:120px;height:68px;color:inherit;margin-top:-.2rem;transition:transform .6s cubic-bezier(.25,.8,.25,1.25)}@keyframes steamFloat{0%{stroke-dashoffset:0;opacity:0;transform:translateY(4px)}30%{opacity:.65}80%{opacity:.65}to{stroke-dashoffset:-20px;opacity:0;transform:translateY(-8px)}}.steam-line{stroke-dasharray:20;transform-origin:bottom;animation:2s ease-in-out infinite steamFloat}.steam-1{animation-delay:0s}.steam-2{animation-delay:.6s}.steam-3{animation-delay:1.2s}.delivered-greeting{color:#fff;opacity:1;margin:.1rem 0 -.2rem;font-size:1.05rem;font-weight:700;transition:opacity .5s,transform .5s}.delivered .cart-card-price-badge{color:#4a8c66;background:#fffffff2}.cart-card-front.delivered.paid-state{border:2px solid #ffffffd9!important;box-shadow:0 8px 32px #4a8c664d,inset 0 0 20px #ffffff26!important}.delivered .payment-toggle-btn.paid{color:#fff!important;background:#c67b4b!important;border-color:#c67b4b!important;box-shadow:0 4px 10px #c67b4b59!important}.delivered .payment-toggle-btn.paid:hover{background:#e07a5f!important;border-color:#e07a5f!important;box-shadow:0 6px 14px #c67b4b73!important}.paid-state .back-wheel,.paid-state .front-wheel{animation-duration:.3s}.paid-state .bicycle-rider{animation-duration:.25s}.paid-state .delivery-road{animation-duration:.4s}.paid-state .cart-card-price-badge,.paid-state .qr-code-payment-btn{opacity:0;pointer-events:none;max-height:0;overflow:hidden;transform:scale(.7);border-width:0!important;margin:0!important;padding:0!important}.profile-debt-badge-wrapper{justify-content:center;align-items:center;gap:.75rem;width:100%;margin-bottom:.75rem;display:flex}.profile-details-btn{border:1px solid var(--border-light);color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer;white-space:nowrap;background:#ffffff0d;justify-content:center;align-items:center;padding:.3rem .6rem;font-size:.75rem;font-weight:500;transition:all .25s;display:inline-flex}.profile-details-btn:hover{color:var(--accent);background:#ff6b001a;border-color:#ff6b0066}.profile-calendar-loading,.profile-calendar-error{color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:3rem 1rem;font-size:.9rem;display:flex}.calendar-view{flex-direction:column;gap:1rem;width:100%;animation:.25s fadeIn;display:flex}.calendar-nav-header{justify-content:space-between;align-items:center;width:100%;margin-bottom:.25rem;display:flex}.btn-calendar-back{color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;align-items:center;gap:.35rem;padding:.25rem .5rem;font-size:.8rem;font-weight:500;transition:all .2s;display:flex}.btn-calendar-back:hover{color:var(--text-primary);background:#ffffff0d}.calendar-month-selector{align-items:center;gap:.5rem;display:flex}.btn-month-nav{color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;transition:all .2s;display:flex}.btn-month-nav:hover{color:var(--text-primary);background:#ffffff0d}.calendar-month-title{color:var(--text-primary);text-align:center;min-width:90px;font-size:.9rem;font-weight:600}.calendar-weekdays{text-align:center;color:var(--text-tertiary);border-bottom:1px solid var(--border-light);font-size:12px;font-weight:700;font-family:var(--font-body);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;grid-template-columns:repeat(7,1fr);padding-bottom:.35rem;display:grid}.calendar-grid{grid-template-columns:repeat(7,1fr);gap:6px;padding:.25rem 0;display:grid}.calendar-cell{aspect-ratio:1;border-radius:var(--radius-sm);min-height:32px;font-size:14px;font-family:var(--font-body);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-variant-numeric:lining-nums;justify-content:center;align-items:center;display:flex;position:relative}.calendar-cell.empty{opacity:0;pointer-events:none}.calendar-cell.day-cell{color:var(--text-primary);cursor:default;background:0 0;border:1px solid #0000;transition:all .2s}.calendar-cell.day-cell.has-orders{cursor:pointer;aspect-ratio:1;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;gap:1px;width:38px;max-width:38px;height:38px;max-height:38px;margin:auto;display:flex}.calendar-cell.day-cell.paid-day{box-shadow:0 0 6px #2ecc7166;background-color:var(--success)!important;color:#fff!important}.calendar-cell.day-cell.unpaid-day{box-shadow:0 0 6px #ff6b0066;background-color:var(--accent)!important;color:#fff!important}.calendar-cell.day-cell.has-orders:hover{filter:brightness(1.15);z-index:100;transform:scale(1.1)}.day-number{font-size:14px;font-weight:700;line-height:1.1;font-family:var(--font-body);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-variant-numeric:lining-nums;margin-top:1px}.day-price-badge{opacity:.95;font-size:10px;font-weight:600;line-height:1;font-family:var(--font-body);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-variant-numeric:lining-nums}.tooltip-content{visibility:hidden;border-radius:var(--radius-md);z-index:1200;opacity:0;pointer-events:none;width:max-content;min-width:155px;max-width:235px;font-size:13px;font-family:var(--font-body);text-align:left;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;flex-direction:column;gap:.35rem;padding:.75rem .95rem;font-weight:500;line-height:1.4;transition:opacity .2s,visibility .2s;display:flex;position:absolute;bottom:130%;left:50%;transform:translate(-50%);background-color:var(--surface)!important;border:1px solid var(--border)!important;box-shadow:var(--shadow-lg)!important;color:var(--text-primary)!important;height:auto!important;max-height:none!important}.calendar-cell.day-cell.has-orders:hover .tooltip-content{visibility:visible;opacity:1}.calendar-grid>.calendar-cell:nth-child(-n+14) .tooltip-content{top:130%;bottom:auto}.calendar-grid>.calendar-cell:nth-child(7n+1) .tooltip-content,.calendar-grid>.calendar-cell:nth-child(7n+2) .tooltip-content{left:0;transform:none}.calendar-grid>.calendar-cell:nth-child(7n+6) .tooltip-content,.calendar-grid>.calendar-cell:nth-child(7n+7) .tooltip-content{left:auto;right:0;transform:none}.tooltip-total{margin-bottom:.15rem;padding-bottom:.25rem;font-weight:700;display:block;color:var(--accent)!important;border-bottom:1px solid var(--border-light)!important}.tooltip-items{flex-direction:column;gap:.25rem;width:100%;display:flex}.tooltip-item{justify-content:space-between;align-items:center;gap:.75rem;width:100%;display:flex}.tooltip-dish-name{white-space:normal;word-break:break-word;flex-grow:1;color:var(--text-secondary)!important}.tooltip-dish-price{font-weight:600;font-family:var(--font-body);white-space:nowrap;font-variant-numeric:lining-nums;color:var(--text-primary)!important}.calendar-footer{border-top:1px solid var(--border-light);text-align:left;flex-direction:column;align-items:flex-start;gap:.75rem;width:100%;margin-top:.25rem;padding-top:.75rem;display:flex}.unpaid-summary{color:var(--text-secondary);font-size:.8rem;font-weight:600}.highlight-unpaid{color:var(--accent);font-size:.9rem;font-weight:700}.adjustments-section{width:100%}.adjustments-section h4{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;margin:0 0 .35rem;font-size:.75rem;font-weight:600}.adjustments-section ul{flex-direction:column;gap:.3rem;width:100%;margin:0;padding:0;list-style:none;display:flex}.adjustment-item{border-radius:var(--radius-sm);background:#ffffff05;border:1px solid #ffffff08;justify-content:space-between;align-items:center;padding:.25rem .5rem;font-size:.75rem;display:flex}.adj-date{color:var(--text-tertiary);font-family:monospace}.adj-comment{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;flex-grow:1;max-width:140px;margin-left:.5rem;margin-right:.5rem;overflow:hidden}.adj-amount{font-weight:600}.loan-item .adj-amount{color:var(--accent)}.deposit-item .adj-amount{color:var(--success)}.back-side-header{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;margin-bottom:.75rem;padding-bottom:.75rem;display:flex}.profile-tabs-selector,.user-debt-modal-tabs{border:1px solid var(--border-light);background:#ffffff08;border-radius:20px;padding:2px;display:inline-flex}.profile-tab-selector-btn,.user-debt-tab-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:18px;padding:.35rem .85rem;font-size:.75rem;font-weight:600;transition:all .2s}.profile-tab-selector-btn.active,.user-debt-tab-btn.active{background:var(--accent);color:#fff;box-shadow:0 2px 8px #ff6b004d}.user-debt-modal-tabs{margin-left:1.5rem}.transaction-history-container{flex-direction:column;gap:.75rem;max-height:400px;padding-right:4px;display:flex;overflow-y:auto}.payment-history-card{border:1px solid var(--border-light);border-radius:var(--radius-md);cursor:pointer;background:#ffffff05;margin-bottom:.5rem;transition:all .2s;overflow:hidden}.payment-history-card:hover{background:#ffffff0a;border-color:#ff6b0033}.payment-history-card.expanded{border-color:var(--border);background:#ffffff08}.payment-history-header{justify-content:space-between;align-items:center;padding:.75rem 1rem;display:flex}.payment-header-left{flex-direction:column;align-items:flex-start;gap:2px;display:flex}.payment-date{color:var(--text-secondary);font-size:.8rem;font-weight:500}.payment-initiator-badge-wrapper{margin-top:2px;display:flex}.initiator-badge{text-transform:uppercase;letter-spacing:.02em;border-radius:4px;padding:1px 6px;font-size:.65rem;font-weight:700}.initiator-badge.admin-initiated{color:#c084fc;background:#a855f726;border:1px solid #a855f74d}.initiator-badge.user-initiated{color:#93c5fd;background:#3b82f626;border:1px solid #3b82f64d}.payment-header-right{align-items:center;gap:.75rem;display:flex}.payment-amount{color:var(--text-primary);font-size:.95rem;font-weight:700}.payment-actions{align-items:center;gap:.5rem;display:flex}.btn-cancel-payment{color:var(--danger);border-radius:var(--radius-sm);cursor:pointer;background:0 0;border:1px solid #ef44444d;justify-content:center;align-items:center;width:24px;height:24px;transition:all .2s;display:flex}.btn-cancel-payment:hover:not(:disabled){background:var(--danger);color:#fff;border-color:var(--danger);box-shadow:0 0 8px #ef44444d}.btn-cancel-payment:disabled{opacity:.5;cursor:not-allowed}.expand-chevron{color:var(--text-tertiary);align-items:center;display:flex}.payment-history-details{border-top:1px solid var(--border-light);cursor:default;background:#00000026;padding:1rem;animation:.2s ease-out slideDown}.details-section{flex-direction:column;gap:.5rem;display:flex}.details-section-title{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;align-items:center;gap:4px;margin:0;font-size:.75rem;font-weight:700;display:flex}.details-table-wrapper{border:1px solid var(--border-light);border-radius:var(--radius-sm);overflow:hidden}.details-table{border-collapse:collapse;text-align:left;width:100%;font-size:.75rem}.details-table th,.details-table td{border-bottom:1px solid var(--border-light);padding:.4rem .6rem}.details-table th{color:var(--text-tertiary);background:#ffffff03;font-weight:600}.details-table tr:last-child td{border-bottom:none}.details-table td.dish-name-cell{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;max-width:180px;overflow:hidden}.font-mono{color:var(--text-tertiary);font-family:monospace}.expanded-cancel-row{border-top:1px solid #ffffff0d;justify-content:flex-end;margin-top:1rem;padding-top:.75rem;display:flex}.btn-danger-outline{border:1px solid var(--danger);color:var(--danger);border-radius:var(--radius-sm);cursor:pointer;background:0 0;padding:.35rem .75rem;font-weight:600;transition:all .2s}.btn-danger-outline:hover:not(:disabled){background:var(--danger);color:#fff}.payments-empty-state{text-align:center;color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;padding:3rem 1rem;display:flex}.payments-empty-state p{margin:0;font-size:.9rem;font-weight:600}.user-debt-modal-tabs{margin-top:.5rem}.admin-payments-history-wrapper{padding:1.25rem}.payment-summary-box{padding:.25rem 0}.payment-summary-list{flex-direction:column;gap:.5rem;margin:0;padding:0;list-style:none;display:flex}.summary-item-text{color:var(--text-secondary);align-items:flex-start;gap:8px;font-size:.8rem;line-height:1.4;display:flex}.summary-icon{flex-shrink:0;margin-top:2px}.summary-item-content{flex-grow:1}.summary-icon.text-accent{color:var(--accent)}.summary-icon.text-success{color:var(--success)}.global-payments-feed-section{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:2rem;padding:1.5rem}.feed-header-row{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;margin-bottom:1.25rem;padding-bottom:.75rem;display:flex}.feed-filter-wrapper{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-md);color:var(--text-secondary);align-items:center;gap:8px;padding:.4rem .8rem;transition:all .2s;display:flex}.feed-filter-wrapper:focus-within{border-color:var(--accent);box-shadow:0 0 0 2px #ff6b0026}.feed-filter-wrapper .filter-icon{color:var(--text-tertiary);flex-shrink:0}.feed-filter-select{color:var(--text-primary);cursor:pointer;background:0 0;border:none;outline:none;margin-right:4px;padding:0;font-size:.85rem;font-weight:500}.feed-filter-select option{background:var(--surface);color:var(--text-primary)}.payment-feed-parties{align-items:center;gap:6px;margin-top:2px;display:flex}.party-target{color:var(--accent);background:#ff6b001a;border-radius:4px;padding:1px 6px;font-size:.75rem;font-weight:600}.party-arrow{color:var(--text-tertiary);font-size:.75rem}.global-feed-card{border-left:3px solid var(--border-light)}.global-feed-card.expanded{border-left-color:var(--accent)}
