@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--bg-primary: #f9fafb;--bg-secondary: #ffffff;--bg-tertiary: #f3f4f6;--bg-glass: rgba(255, 255, 255, .7);--bg-glass-hover: rgba(255, 255, 255, .8);--bg-overlay: rgba(0, 0, 0, .5);--text-primary: #111827;--text-secondary: #374151;--text-tertiary: #6b7280;--text-muted: #9ca3af;--border-color: #e5e7eb;--border-light: #f3f4f6;--card-bg: #ffffff;--card-shadow: 0 1px 3px rgba(0, 0, 0, .1);--card-shadow-hover: 0 4px 12px rgba(0, 0, 0, .15);--glass-bg: rgba(255, 255, 255, .6);--glass-border: rgba(255, 255, 255, .4);--glass-shadow: 0 8px 24px rgba(0, 0, 0, .08);--tab-bg: #f3f4f6;--tab-active-bg: #ffffff;--tab-text: #6b7280;--tab-active-text: #111827;--input-bg: #f3f4f6;--input-border: #e5e7eb;--input-text: #111827;--input-placeholder: #9ca3af;--success: #10b981;--error: #ef4444;--warning: #f59e0b;--whatsapp: #25D366;--scrollbar-track: #f1f1f1;--scrollbar-thumb: #c1c1c1;--scrollbar-hover: #a8a8a8}:root.dark{--bg-primary: #0f0f0f;--bg-secondary: #1a1a1a;--bg-tertiary: #262626;--bg-glass: rgba(26, 26, 26, .8);--bg-glass-hover: rgba(38, 38, 38, .9);--bg-overlay: rgba(0, 0, 0, .7);--text-primary: #f9fafb;--text-secondary: #e5e7eb;--text-tertiary: #9ca3af;--text-muted: #6b7280;--border-color: #374151;--border-light: #262626;--card-bg: #1a1a1a;--card-shadow: 0 1px 3px rgba(0, 0, 0, .3);--card-shadow-hover: 0 4px 12px rgba(0, 0, 0, .4);--glass-bg: rgba(38, 38, 38, .7);--glass-border: rgba(55, 65, 81, .5);--glass-shadow: 0 8px 24px rgba(0, 0, 0, .2);--tab-bg: #262626;--tab-active-bg: #374151;--tab-text: #9ca3af;--tab-active-text: #f9fafb;--input-bg: #262626;--input-border: #374151;--input-text: #f9fafb;--input-placeholder: #6b7280;--success: #10b981;--error: #ef4444;--warning: #f59e0b;--whatsapp: #25D366;--scrollbar-track: #1a1a1a;--scrollbar-thumb: #374151;--scrollbar-hover: #4b5563}body{margin:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-primary);color:var(--text-primary);transition:background-color .3s ease,color .3s ease}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}a{text-decoration:none;color:inherit}button,input,textarea{font-family:inherit}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--scrollbar-track)}::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-hover)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .3s ease-in}.slide-up{animation:slideUp .4s ease-out}.search-bar{position:relative;width:100%;max-width:600px;margin:0 auto}.search-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);width:20px;height:20px;color:var(--text-muted);pointer-events:none}.search-input{width:100%;padding:14px 48px;border:none;border-radius:28px;font-size:16px;background:var(--card-bg);color:var(--text-primary);box-shadow:var(--card-shadow);transition:all .3s ease}.search-input:focus{outline:none;box-shadow:var(--card-shadow-hover)}.search-input::placeholder{color:var(--input-placeholder)}.clear-button{position:absolute;right:16px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:color .2s}.clear-button:hover{color:var(--text-tertiary)}.clear-button svg{width:18px;height:18px}.restaurant-card{background:var(--card-bg);border-radius:28px;overflow:visible;box-shadow:var(--card-shadow);cursor:pointer;transition:all .3s ease;display:flex;flex-direction:column;padding:20px;position:relative;min-height:180px;border:1px solid var(--border-color)}.restaurant-card:hover{box-shadow:var(--card-shadow-hover);transform:translateY(-4px)}.restaurant-card-image-float{position:absolute;top:-15px;right:-15px;width:120px;height:120px;background:var(--card-bg);border-radius:50%;overflow:hidden;box-shadow:var(--card-shadow-hover);border:4px solid var(--card-bg);z-index:10}.restaurant-logo{width:100%;height:100%;object-fit:cover}.restaurant-logo-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);color:var(--text-muted)}.restaurant-logo-placeholder svg{width:56px;height:56px}.restaurant-inactive-badge{position:absolute;top:2px;right:2px;padding:3px 8px;background:#dc2626f2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;border-radius:10px;font-size:9px;font-weight:700;box-shadow:0 2px 8px #dc26264d;z-index:20}.restaurant-card-content{padding:0;display:flex;flex-direction:column;gap:10px;flex:1;justify-content:space-between}.restaurant-name{margin:auto 0 0;font-size:14px;font-weight:700;color:var(--text-primary);line-height:1.4;width:100%;padding-right:0;display:block;word-wrap:break-word;overflow-wrap:break-word}.restaurant-actions-row{display:flex;gap:8px;justify-content:flex-start;margin-top:0;padding-right:110px}.action-icon-btn{width:40px;height:40px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;box-shadow:0 4px 12px #00000026}.action-icon-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #00000026}.whatsapp-btn{background:linear-gradient(135deg,#25d366,#20ba5a)}.whatsapp-btn svg{width:22px;height:22px;color:#fff}.location-btn{background:linear-gradient(135deg,#3b82f6,#2563eb)}.location-btn svg{width:22px;height:22px;color:#fff}@media(max-width:768px){.restaurant-card{padding:16px;min-height:160px;border-radius:24px}.restaurant-card-image-float{width:100px;height:100px;top:-12px;right:-12px;border-width:3px}.restaurant-logo-placeholder svg{width:40px;height:40px}.restaurant-name{font-size:13px}.restaurant-actions-row{padding-right:90px}.action-icon-btn{width:36px;height:36px}.whatsapp-btn svg,.location-btn svg{width:20px;height:20px}}@media(max-width:640px){.restaurant-card{padding:14px;min-height:150px;border-radius:22px}.restaurant-card-image-float{width:90px;height:90px;top:-10px;right:-10px;border-width:3px}.restaurant-logo-placeholder svg{width:36px;height:36px}.restaurant-name{font-size:12px}.restaurant-actions-row{padding-right:80px}.action-icon-btn{width:34px;height:34px}.whatsapp-btn svg,.location-btn svg{width:18px;height:18px}}.nav-overlay{position:fixed;inset:0;background:var(--bg-overlay);z-index:1099;animation:fadeIn .2s ease}.nav-info-menu{position:fixed;bottom:110px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;gap:12px;z-index:1100;opacity:0;visibility:hidden;transform:translate(-50%) translateY(20px);transition:all .3s ease;width:max-content}.nav-info-menu.open{opacity:1;visibility:visible;transform:translate(-50%) translateY(0)}.nav-info-menu-item{display:flex;align-items:center;gap:12px;padding:14px 20px;background:var(--card-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:16px;box-shadow:var(--card-shadow);cursor:pointer;color:#000000a6;font-size:14px;font-weight:500;white-space:nowrap;transition:all .2s ease}.nav-info-menu-item:hover{transform:translateY(-2px);box-shadow:var(--card-shadow-hover)}.nav-info-menu-item svg{width:20px;height:20px;flex-shrink:0}.nav-info-menu-item.whatsapp{background:#25d366;color:#fff;border-color:#25d366}.nav-info-menu-item.whatsapp:hover{background:#22c55e;border-color:#22c55e}.bottom-navigation{position:fixed;bottom:20px;left:50%;transform:translate(-50%);min-width:280px;max-width:90vw;background:#ffffffb3;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid rgba(255,255,255,.3);border-radius:30px;padding:10px 14px;display:flex;justify-content:space-between;align-items:center;gap:10px;z-index:1098;box-shadow:0 4px 16px #00000014}.nav-item{position:relative;display:flex;align-items:center;justify-content:center;background:transparent;border:none;cursor:pointer;padding:10px 20px;min-width:52px;height:52px;border-radius:20px;transition:all .2s;color:#00000080;flex:0 0 auto}.nav-item.active{background:#fffffff2;box-shadow:0 2px 8px #0000001a;color:#000000b3}.nav-item:hover{background:#0000000d;color:#000000b3}.nav-item svg{width:24px;height:24px}.nav-item span{font-size:12px;font-weight:600}.nav-badge{position:absolute;top:4px;right:4px;background:#ef4444;color:#fff;border-radius:10px;padding:2px 6px;font-size:10px;font-weight:700;min-width:18px;text-align:center}@media(max-width:768px){.bottom-navigation{bottom:16px;padding:8px 12px;border-radius:24px;min-width:260px}.nav-item{padding:8px 16px;min-width:48px;height:48px;border-radius:16px}.nav-item svg{width:22px;height:22px}.nav-info-menu{bottom:95px}}.quantity-add-btn{display:flex;align-items:center;justify-content:center;background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);color:var(--text-secondary);border:none;border-radius:50%;cursor:pointer;transition:all .2s ease}.quantity-add-btn:hover{background:var(--bg-glass-hover);transform:scale(1.05)}.quantity-add-btn svg{width:60%;height:60%}.quantity-selector{display:flex;align-items:center;gap:8px;background:var(--bg-tertiary);border-radius:100px;padding:4px}.quantity-btn{display:flex;align-items:center;justify-content:center;background:var(--card-bg);color:var(--text-primary);border:none;border-radius:50%;cursor:pointer;transition:all .2s ease;box-shadow:var(--card-shadow)}.quantity-btn:hover{background:var(--bg-tertiary)}.quantity-btn svg{width:60%;height:60%}.quantity-value{font-weight:600;color:var(--text-primary);min-width:20px;text-align:center}.quantity-small .quantity-add-btn,.quantity-small.quantity-add-btn{width:28px;height:28px}.quantity-small .quantity-btn{width:24px;height:24px}.quantity-small .quantity-value{font-size:13px}.quantity-medium .quantity-add-btn,.quantity-medium.quantity-add-btn{width:32px;height:32px}.quantity-medium .quantity-btn{width:28px;height:28px}.quantity-medium .quantity-value{font-size:14px}.quantity-large .quantity-add-btn,.quantity-large.quantity-add-btn{width:40px;height:40px}.quantity-large .quantity-btn{width:36px;height:36px}.quantity-large .quantity-value{font-size:16px;min-width:28px}.cart-modal-overlay{position:fixed;inset:0;background:var(--bg-overlay);z-index:1200;display:flex;align-items:flex-end;justify-content:center;animation:fadeIn .2s ease}.cart-modal{background:var(--card-bg);border-radius:24px 24px 0 0;width:100%;max-width:500px;max-height:85vh;display:flex;flex-direction:column;animation:slideUp .3s ease}.cart-modal-handle{display:flex;justify-content:center;padding:12px;cursor:grab;user-select:none;-webkit-user-select:none}.cart-modal-handle:active{cursor:grabbing}.cart-modal-handle .handle-bar{width:40px;height:4px;background:var(--border-color);border-radius:2px}.cart-modal-header{display:flex;align-items:center;justify-content:space-between;padding:0 20px 12px;border-bottom:1px solid var(--border-light)}.cart-modal-header h2{font-size:20px;font-weight:700;color:var(--text-primary);margin:0}.cart-clear-btn{background:none;border:none;color:#ef4444;font-size:14px;font-weight:500;cursor:pointer;padding:4px 8px}.cart-restaurant-name{font-size:14px;color:var(--text-tertiary);margin:12px 20px 0}.cart-modal-content{flex:1;overflow-y:auto;padding:16px 20px}.cart-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center}.cart-empty svg{width:64px;height:64px;color:var(--border-color);margin-bottom:16px}.cart-empty p{font-size:16px;font-weight:600;color:var(--text-secondary);margin:0 0 4px}.cart-empty span{font-size:14px;color:var(--text-muted);margin-bottom:20px}.cart-explore-btn{display:flex;align-items:center;gap:8px;padding:12px 24px;background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:none;border-radius:100px;color:var(--text-secondary);font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease}.cart-explore-btn svg{width:18px;height:18px;color:var(--text-secondary);margin:0}.cart-explore-btn:hover{background:var(--bg-glass-hover);transform:scale(1.02)}.cart-items{display:flex;flex-direction:column;gap:16px}.cart-item{display:flex;gap:12px;padding-bottom:16px;border-bottom:1px solid var(--border-light)}.cart-item:last-child{border-bottom:none;padding-bottom:0}.cart-item-image{width:64px;height:64px;border-radius:12px;overflow:hidden;flex-shrink:0}.cart-item-image img{width:100%;height:100%;object-fit:cover}.cart-item-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary)}.cart-item-placeholder svg{width:24px;height:24px;color:var(--text-muted)}.cart-item-info{flex:1;min-width:0}.cart-item-info h4{font-size:14px;font-weight:600;color:var(--text-primary);margin:0 0 4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cart-item-price{font-size:13px;color:var(--text-tertiary);margin:0}.cart-item-actions{display:flex;flex-direction:column;align-items:flex-end;gap:8px}.cart-item-subtotal{font-size:14px;font-weight:600;color:var(--text-primary);margin:0}.cart-modal-footer{padding:16px 20px 32px;border-top:1px solid var(--border-light);background:var(--card-bg)}.cart-total{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.cart-total span{font-size:16px;color:var(--text-tertiary)}.cart-total-price{font-size:20px!important;font-weight:700!important;color:var(--text-primary)!important}.cart-checkout-btn{width:100%;padding:16px;background:var(--text-primary);color:var(--bg-primary);border:none;border-radius:16px;font-size:16px;font-weight:600;cursor:pointer;transition:background .2s ease}.cart-checkout-btn:hover{background:var(--text-secondary)}.cart-whatsapp-btn{width:100%;padding:16px;background:#25d366;color:#fff;border:none;border-radius:16px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:10px}.cart-whatsapp-btn svg{width:22px;height:22px}.cart-whatsapp-btn:hover{background:#20bd5c;transform:scale(1.02)}@media(max-width:640px){.cart-modal{max-height:90vh}.cart-item-image{width:56px;height:56px}}.home-page{min-height:100vh;background:var(--bg-primary);padding-bottom:100px}.home-header{background:transparent;padding:20px;position:sticky;top:0;z-index:100}.home-search-section{max-width:1200px;margin:0 auto}.home-content{max-width:1200px;margin:0 auto;padding:30px 20px}.restaurants-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(280px,100%),1fr));gap:24px}.loading-state,.error-state,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;color:var(--text-tertiary)}.loading-state svg,.error-state svg,.empty-state svg{width:64px;height:64px;margin-bottom:16px;color:var(--text-muted)}.loading-state p,.error-state p,.empty-state p{margin:0;font-size:16px}.retry-button{margin-top:16px;padding:10px 24px;background:#3b82f6;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.retry-button:hover{background:#2563eb}@media(max-width:768px){.home-header{padding:16px}.home-content{padding:24px 16px}.restaurants-grid{grid-template-columns:repeat(2,1fr);gap:16px}}@media(max-width:640px){.home-content{padding:20px 16px}}.category-tabs-container{width:100%;background:transparent;position:sticky;top:0;z-index:10;padding:24px 0;transition:all .3s ease}.category-tabs-container.scrolled{background:var(--bg-glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.category-tabs{display:flex;gap:12px;overflow-x:auto;padding:8px 20px;scrollbar-width:none;-ms-overflow-style:none}.category-tabs::-webkit-scrollbar{display:none}.category-tab{flex-shrink:0;padding:10px 18px;border:none;border-radius:100px;background:var(--tab-bg);color:var(--tab-text);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap;position:relative;display:flex;flex-direction:row;align-items:center;gap:8px}.category-tabs-container.scrolled .category-tab{background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.category-tab:hover{background:var(--border-color);color:var(--text-secondary)}.category-tabs-container.scrolled .category-tab:hover{background:var(--bg-glass-hover)}.category-tab.active{background:var(--tab-active-bg);color:var(--tab-active-text);font-weight:600;box-shadow:var(--card-shadow)}.category-tabs-container.scrolled .category-tab.active{background:var(--card-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:var(--card-shadow)}@media(max-width:640px){.category-tabs-container{padding:16px 0}.category-tabs{padding:8px 16px;gap:10px}.category-tab{padding:10px 16px;font-size:13px;border-radius:16px;line-height:1.2}}.restaurant-detail{min-height:100vh;background:var(--bg-primary);color:var(--text-primary);padding-bottom:80px}.restaurant-info-section{padding:20px;max-width:1200px;margin:0 auto}.restaurant-info-header{display:flex;align-items:flex-start;gap:16px}.restaurant-logo-float{width:100px;height:100px;border-radius:50%;overflow:hidden;border:4px solid var(--card-bg);box-shadow:var(--card-shadow-hover);flex-shrink:0;background:var(--bg-tertiary)}.restaurant-logo-float img{width:100%;height:100%;object-fit:cover}.restaurant-logo-float .logo-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary)}.restaurant-logo-float .logo-placeholder svg{width:40px;height:40px;color:var(--text-muted)}.restaurant-social-icons{display:flex;gap:8px;padding-top:10px}.social-icon-button{width:40px;height:40px;border-radius:50%;background:var(--bg-tertiary);border:1px solid var(--border-color);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;text-decoration:none}.social-icon-button:hover{background:var(--border-color);transform:scale(1.05)}.social-icon-button svg{width:18px;height:18px;fill:var(--text-secondary)}.restaurant-name-section{margin-top:16px}.restaurant-detail-name{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0}.restaurant-description{font-size:.9rem;color:var(--text-tertiary);margin:4px 0 0}.restaurant-search-container{margin-top:20px}.products-section{max-width:1200px;margin:0 auto;padding:24px 20px}.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(300px,100%),1fr));gap:20px}.empty-products,.empty-categories{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;color:var(--text-tertiary)}.empty-products svg,.empty-categories svg{width:64px;height:64px;margin-bottom:16px;color:var(--text-muted)}.empty-products p,.empty-categories p{margin:0;font-size:16px}.restaurant-detail-loading,.restaurant-detail-error{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center;color:var(--text-tertiary)}.restaurant-detail-loading svg,.restaurant-detail-error svg{width:64px;height:64px;margin-bottom:16px;color:var(--text-muted)}.restaurant-detail-loading p,.restaurant-detail-error p{margin:0 0 16px;font-size:16px}.spinner{width:48px;height:48px;border:4px solid var(--border-color);border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}@keyframes spin{to{transform:rotate(360deg)}}.back-home-button{padding:10px 24px;background:#3b82f6;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.back-home-button:hover{background:#2563eb}@media(max-width:768px){.restaurant-logo-float{width:80px;height:80px}.social-icon-button{width:36px;height:36px}.social-icon-button svg{width:16px;height:16px}.restaurant-detail-name{font-size:1.25rem}.products-section{padding:20px 16px}.products-grid{grid-template-columns:1fr;gap:16px}}@media(max-width:640px){.restaurant-info-section{padding:16px}.restaurant-info-header{gap:12px}.restaurant-logo-float{width:70px;height:70px;border-width:3px}.restaurant-social-icons{padding-top:8px;gap:6px}.social-icon-button{width:32px;height:32px}.social-icon-button svg{width:14px;height:14px}.restaurant-detail-name{font-size:1.1rem}.restaurant-description{font-size:.85rem}}.product-card{display:flex;background:var(--card-bg);border-radius:24px;padding:16px;cursor:pointer;transition:all .2s ease;box-shadow:var(--card-shadow);min-height:180px}.product-card:hover{box-shadow:var(--card-shadow-hover)}.product-card.unavailable{opacity:.6;cursor:not-allowed}.product-image{width:180px;height:160px;flex-shrink:0;position:relative;overflow:hidden;border-radius:24px}.product-image img{width:100%;height:100%;object-fit:cover}.product-image-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary)}.product-image-placeholder svg{width:32px;height:32px;color:var(--text-muted)}.product-unavailable-badge{position:absolute;bottom:0;left:0;right:0;background:#000000b3;color:#fff;font-size:10px;text-align:center;padding:4px}.product-content{flex:1;padding:0 0 0 14px;display:flex;flex-direction:column;justify-content:center;position:relative;min-width:0}.product-add-container{position:absolute;top:0;right:0}.product-name{font-size:15px;font-weight:600;color:var(--text-primary);margin:0 0 8px;padding-right:40px;line-height:1.3}.product-name.no-actions{padding-right:0}.product-description{font-size:13px;color:var(--text-tertiary);margin:0 0 8px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.product-price{font-size:15px;font-weight:700;color:var(--text-primary);margin:8px 0 0;align-self:flex-end}.bottom-sheet-overlay{position:fixed;inset:0;background:#00000080;z-index:1000;display:flex;align-items:flex-end;justify-content:center;animation:fadeIn .2s ease}.bottom-sheet{background:var(--card-bg);border-radius:24px 24px 0 0;width:100%;max-width:500px;max-height:85vh;overflow-y:auto;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.bottom-sheet-handle{display:flex;justify-content:center;padding:12px;cursor:grab;user-select:none;-webkit-user-select:none}.bottom-sheet-handle:active{cursor:grabbing}.handle-bar{width:40px;height:4px;background:var(--border-color);border-radius:2px}.bottom-sheet-gallery{padding:0 20px}.gallery-main{width:100%;aspect-ratio:1;border-radius:16px;overflow:hidden;background:var(--bg-tertiary)}.gallery-main img{width:100%;height:100%;object-fit:cover}.gallery-placeholder{width:100%;aspect-ratio:1;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border-radius:16px}.gallery-placeholder svg{width:64px;height:64px;color:var(--text-muted)}.gallery-thumbnails{display:flex;gap:8px;margin-top:12px;overflow-x:auto;padding-bottom:4px}.gallery-thumb{width:60px;height:60px;border-radius:12px;overflow:hidden;border:2px solid transparent;cursor:pointer;flex-shrink:0;padding:0;background:none;transition:border-color .2s ease}.gallery-thumb.active{border-color:var(--text-primary)}.gallery-thumb img{width:100%;height:100%;object-fit:cover}.bottom-sheet-info{padding:20px}.bottom-sheet-name{font-size:22px;font-weight:700;color:var(--text-primary);margin:0 0 8px}.bottom-sheet-description{font-size:15px;color:var(--text-tertiary);line-height:1.5;margin:0 0 16px}.bottom-sheet-price{font-size:20px;font-weight:700;color:var(--text-primary);margin:0}.bottom-sheet-actions{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 32px;border-top:1px solid var(--border-light);gap:16px}.bottom-sheet-total{font-size:16px;font-weight:600;color:var(--text-primary)}@media(max-width:640px){.product-card{padding:14px;min-height:150px;border-radius:20px}.product-image{width:140px;height:130px;border-radius:20px}.product-content{padding:0 0 0 12px}.product-name{font-size:14px;padding-right:36px}.product-description{font-size:12px;-webkit-line-clamp:2;line-clamp:2}.product-price{font-size:14px}.bottom-sheet{max-height:90vh}.gallery-main{border-radius:12px}.bottom-sheet-name{font-size:20px}}body.bottom-sheet-open{overflow:hidden}body.bottom-sheet-open .bottom-navigation{display:none}.restaurant-change-overlay{position:fixed;inset:0;background:var(--bg-overlay);z-index:1100;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.restaurant-change-modal{background:var(--card-bg);border-radius:24px;padding:32px 24px 24px;width:100%;max-width:340px;text-align:center;animation:scaleIn .2s ease}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.restaurant-change-icon{width:64px;height:64px;margin:0 auto 16px;background:#fef3c7;border-radius:50%;display:flex;align-items:center;justify-content:center}.restaurant-change-icon svg{width:32px;height:32px;color:#f59e0b}.restaurant-change-modal h3{font-size:18px;font-weight:700;color:var(--text-primary);margin:0 0 12px}.restaurant-change-modal p{font-size:14px;color:var(--text-tertiary);line-height:1.5;margin:0 0 24px}.restaurant-change-modal p strong{color:var(--text-secondary)}.restaurant-change-actions{display:flex;gap:12px}.restaurant-change-cancel,.restaurant-change-confirm{flex:1;padding:14px 16px;border-radius:16px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease}.restaurant-change-cancel{background:var(--bg-tertiary);border:none;color:var(--text-secondary)}.restaurant-change-cancel:hover{background:var(--border-color)}.restaurant-change-confirm{background:var(--text-primary);border:none;color:var(--bg-primary)}.restaurant-change-confirm:hover{background:var(--text-secondary)}*{margin:0;padding:0;box-sizing:border-box}#root{width:100%;min-height:100vh}
