@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";:root{--font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--color-bg: #000000;--color-surface: #0f0f0f;--color-surface-2: #1a1a1a;--color-surface-3: #242424;--color-border: rgba(255, 255, 255, .06);--color-border-hover: rgba(255, 255, 255, .12);--color-text: #ffffff;--color-text-secondary: rgba(255, 255, 255, .7);--color-text-muted: rgba(255, 255, 255, .4);--color-primary: #ffffff;--color-primary-hover: #e0e0e0;--color-accent: #00c853;--color-accent-hover: #00b848;--color-whatsapp: #25d366;--color-whatsapp-hover: #20bd5a;--color-danger: #ff4444;--color-danger-hover: #e63e3e;--radius-sm: .5rem;--radius: .75rem;--radius-lg: 1rem;--radius-xl: 1.25rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--shadow-glow: 0 0 40px rgba(0, 200, 83, .15);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1);--color-logo-text: #ffffff}[data-theme=light]{--color-logo-text: #414040;--color-bg: #fafafa;--color-surface: #ffffff;--color-surface-2: #f5f5f5;--color-surface-3: #eeeeee;--color-border: rgba(0, 0, 0, .08);--color-border-hover: rgba(0, 0, 0, .15);--color-text: #111111;--color-text-secondary: rgba(0, 0, 0, .65);--color-text-muted: rgba(0, 0, 0, .35);--color-primary: #111111;--color-primary-hover: #333333;--color-accent: #00a844;--color-accent-hover: #009a3d;--color-whatsapp: #20a855;--color-whatsapp-hover: #1a8f47;--color-danger: #e53935;--color-danger-hover: #c62828;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .06);--shadow: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .12);--shadow-glow: 0 0 40px rgba(0, 168, 68, .1)}*{box-sizing:border-box;margin:0;padding:0}html{font-family:var(--font);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html,body,#root{background:var(--color-bg);color:var(--color-text);min-height:100vh;line-height:1.6}a{color:inherit;text-decoration:none}button{font-family:inherit}::selection{background:var(--color-accent);color:#fff}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-surface-3);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}.global-banner-container{display:flex;flex-direction:column}.global-banner{display:flex;align-items:center;gap:.75rem;padding:.625rem 1.5rem;background:var(--color-surface);border-bottom:1px solid var(--color-border)}.global-banner--neutral{background:var(--color-surface);border-bottom:1px solid var(--color-border)}.global-banner--info{background:#00c8531a;border-bottom:1px solid rgba(0,200,83,.2)}.global-banner--info .global-banner-icon{color:var(--color-accent)}.global-banner--warning{background:#ff98001a;border-bottom:1px solid rgba(255,152,0,.2)}.global-banner--warning .global-banner-icon{color:#ff9800}.global-banner--danger{background:#ff44441a;border-bottom:1px solid rgba(255,68,68,.2)}.global-banner--danger .global-banner-icon{color:#f44}.global-banner--warning .global-banner-cta{background:#ff9800}.global-banner--danger .global-banner-cta{background:#f44}.global-banner-icon{flex-shrink:0;color:var(--color-accent)}.global-banner-message{flex:1;font-size:.875rem;font-weight:500;color:var(--color-text)}.global-banner-cta{margin-left:auto;margin-right:.5rem;padding:.3rem .85rem;font-size:.8125rem;font-weight:600;color:#fff;background:var(--color-accent);border-radius:6px;text-decoration:none;white-space:nowrap;transition:opacity .2s}.global-banner-dismiss{display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--color-text-muted);padding:.25rem;border-radius:4px;flex-shrink:0;transition:color .2s,background .2s}.global-banner-dismiss:hover{color:var(--color-text);background:var(--color-surface-2)}@media(max-width:640px){.global-banner{padding:.5rem 1rem;gap:.5rem}.global-banner-cta{font-size:.75rem;padding:.2rem .5rem}}.navbar{display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;height:64px;background:var(--color-surface);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:100;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.navbar-brand{display:flex;align-items:center;gap:.5rem}.navbar-brand-logo{width:100%;height:72px;object-fit:contain}.navbar-end{display:flex;align-items:center;gap:.5rem;margin-left:auto}.navbar-links{display:flex;align-items:center;gap:.25rem}.navbar-link{font-size:.875rem;font-weight:500;color:var(--color-text-secondary);padding:.5rem .875rem;border-radius:var(--radius);transition:all var(--transition-fast)}.navbar-link:hover{color:var(--color-text);background:var(--color-surface-2)}.theme-toggle{background:none;border:none;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);cursor:pointer;color:var(--color-text-secondary);transition:all var(--transition-fast);font-size:1.1rem}.theme-toggle:hover{color:var(--color-text);background:var(--color-surface-2)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.25rem;border:none;border-radius:var(--radius);font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition);white-space:nowrap;letter-spacing:-.01em}.btn-primary{background:var(--color-text);color:var(--color-bg)}.btn-primary:hover{background:var(--color-primary-hover);transform:translateY(-1px);box-shadow:var(--shadow)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--color-surface-2);color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-surface-3);border-color:var(--color-border-hover)}.btn-danger{background:transparent;color:var(--color-danger);border:1px solid var(--color-border)}.btn-danger:hover{background:var(--color-danger);color:#fff;border-color:var(--color-danger)}.btn-accent{background:var(--color-accent);color:#fff}.btn-accent:hover{background:var(--color-accent-hover);transform:translateY(-1px);box-shadow:0 4px 16px #00c8534d}.btn-large{padding:.875rem 2rem;font-size:1rem}.btn-sm{padding:.375rem .875rem;font-size:.8125rem}.form-group{margin-bottom:1.25rem;flex:1}.form-label{display:block;font-size:.8125rem;font-weight:500;color:var(--color-text-secondary);margin-bottom:.5rem;letter-spacing:.01em}.form-input{width:100%;padding:.75rem 1rem;background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);font-size:.9375rem;font-family:inherit;transition:all var(--transition)}.form-input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #00c8531a}.form-input::placeholder{color:var(--color-text-muted)}textarea.form-input{resize:vertical}select.form-input{cursor:pointer}.form-row{display:flex;gap:1rem}.form-actions{display:flex;align-items:center;gap:1rem;margin-top:2rem}.save-success{color:var(--color-accent);font-weight:600;font-size:.875rem;display:flex;align-items:center;gap:.375rem}.landing{min-height:100vh}.hero{padding:8rem 1.5rem 6rem;text-align:center;max-width:52rem;margin:0 auto;position:relative}.hero-badge{display:inline-flex;align-items:center;gap:.5rem;font-size:.75rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--color-accent);background:#00c8531a;border:1px solid rgba(0,200,83,.2);padding:.5rem 1rem;border-radius:var(--radius-full);margin-bottom:2rem}.hero-title{font-size:clamp(2.5rem,6vw,4rem);font-weight:800;line-height:1.1;letter-spacing:-.04em;margin-bottom:1.5rem;background:linear-gradient(135deg,var(--color-text) 0%,var(--color-text-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-subtitle{font-size:1.25rem;color:var(--color-text-secondary);max-width:36rem;margin:0 auto 3rem;line-height:1.7}.hero-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.section-title{text-align:center;font-size:2rem;font-weight:800;margin-bottom:.75rem;letter-spacing:-.03em}.section-subtitle{text-align:center;color:var(--color-text-secondary);margin-bottom:3rem;font-size:1.0625rem}.features{padding:5rem 1.5rem 6rem;max-width:72rem;margin:0 auto}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(15rem,1fr));gap:1.5rem}.feature-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:2rem;transition:all var(--transition)}.feature-card:hover{border-color:var(--color-border-hover);transform:translateY(-4px);box-shadow:var(--shadow-lg)}.feature-icon{width:48px;height:48px;background:var(--color-surface-2);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin-bottom:1.25rem}.feature-title{font-size:1.0625rem;font-weight:700;margin-bottom:.625rem;letter-spacing:-.01em}.feature-desc{font-size:.9375rem;color:var(--color-text-secondary);line-height:1.6}.how-it-works{padding:5rem 1.5rem 6rem;max-width:64rem;margin:0 auto}.steps{display:flex;gap:2rem;justify-content:center;flex-wrap:wrap;margin-top:3rem}.step{text-align:center;flex:1;min-width:14rem;position:relative}.step-number{display:inline-flex;align-items:center;justify-content:center;width:3.5rem;height:3.5rem;border-radius:50%;background:var(--color-accent);color:#fff;font-size:1.25rem;font-weight:700;margin-bottom:1.25rem;box-shadow:0 4px 16px #00c8534d}.step-title{font-size:1.0625rem;font-weight:700;margin-bottom:.625rem;letter-spacing:-.01em}.step-desc{font-size:.9375rem;color:var(--color-text-secondary);line-height:1.6}.cta-section{text-align:center;padding:5rem 1.5rem;background:var(--color-surface);border-top:1px solid var(--color-border)}.cta-title{font-size:2rem;font-weight:800;margin-bottom:.75rem;letter-spacing:-.03em}.cta-desc{color:var(--color-text-secondary);margin-bottom:2rem;font-size:1.0625rem}.login-page{min-height:calc(100vh - 64px);display:grid;place-items:center;padding:2rem}.login-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:3rem;width:100%;max-width:28rem}.login-title{font-size:1.5rem;font-weight:800;margin-bottom:.375rem;text-align:center;letter-spacing:-.02em;display:flex;justify-content:center;align-items:center}.login-title img{width:80px;height:80px;object-fit:contain}.login-logo{width:28px;height:28px;object-fit:contain;margin-right:8px;vertical-align:middle}.login-subtitle{color:var(--color-text-secondary);text-align:center;margin-bottom:2.5rem;font-size:.9375rem}.login-form{display:flex;flex-direction:column;gap:0}.login-error{color:var(--color-danger);font-size:.8125rem;text-align:center;margin-bottom:1rem;padding:.75rem;background:#ff44441a;border-radius:var(--radius)}.login-success{color:var(--color-success, #22c55e);font-size:.8125rem;text-align:center;margin-bottom:1rem;padding:.75rem;background:#22c55e1a;border-radius:var(--radius)}.login-hint{color:var(--color-text-muted);font-size:.8125rem;text-align:center;margin-top:1.25rem}.link-btn{background:none;border:none;color:var(--color-accent);cursor:pointer;font-size:inherit;padding:0;text-decoration:underline}.link-btn:hover{opacity:.8}.oauth-divider{display:flex;align-items:center;gap:.75rem;margin:1.25rem 0;color:var(--color-text-muted);font-size:.8125rem}.oauth-divider:before,.oauth-divider:after{content:"";flex:1;height:1px;background:var(--color-border, #e2e8f0)}.oauth-buttons{display:flex;flex-direction:column;gap:.5rem}.btn-oauth{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.625rem 1rem;border:1px solid var(--color-border, #e2e8f0);border-radius:var(--radius);background:var(--color-bg, #fff);color:var(--color-text, #1a1a2e);font-size:.875rem;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s}.btn-oauth:hover{background:var(--color-bg-hover, #f8fafc);border-color:var(--color-text-muted)}.dashboard{min-height:calc(100vh - 64px)}.dashboard-topbar{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 2rem;border-bottom:1px solid var(--color-border);flex-wrap:wrap;gap:1rem}.topbar-name{font-size:1.375rem;font-weight:800;letter-spacing:-.02em}.topbar-actions{display:flex;gap:.75rem}.tabs{display:flex;border-bottom:1px solid var(--color-border);overflow-x:auto;padding:0 2rem;gap:.25rem}.tab{padding:1rem 1.25rem;font-size:.875rem;font-weight:600;color:var(--color-text-muted);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;white-space:nowrap;transition:all var(--transition-fast)}.tab:hover{color:var(--color-text-secondary)}.tab.active{color:var(--color-text);border-bottom-color:var(--color-accent)}.tab-content{padding:2rem;max-width:72rem}.store-form{max-width:52rem}.add-category-row{display:flex;gap:.75rem;margin-bottom:1.5rem}.add-category-row .form-input{flex:1}.category-list{display:flex;flex-direction:column;gap:.625rem}.category-item{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);gap:1rem;transition:all var(--transition)}.category-item:hover{border-color:var(--color-border-hover)}.category-name{font-weight:600;font-size:.9375rem}.category-actions{display:flex;gap:.5rem}.category-edit-input{max-width:18rem}.empty-msg{color:var(--color-text-muted);font-size:.9375rem;padding:2rem 0;text-align:center}.products-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;gap:1rem}.filter-select{max-width:16rem}.product-list{display:flex;flex-direction:column;gap:.75rem}.product-card-db{display:flex;align-items:center;gap:1.25rem;padding:1rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:all var(--transition)}.product-card-db:hover{border-color:var(--color-border-hover)}.product-thumb{width:72px;height:72px;border-radius:var(--radius);object-fit:cover;flex-shrink:0}.product-thumb-placeholder{display:grid;place-items:center;font-size:1.75rem;background:var(--color-surface-2)}.product-details{flex:1;min-width:0}.product-details h3{font-size:1rem;font-weight:700;margin-bottom:.25rem;letter-spacing:-.01em}.product-cat-price{font-size:.8125rem;color:var(--color-text-secondary)}.product-badges{display:flex;gap:.5rem;margin-top:.5rem}.badge{font-size:.6875rem;font-weight:600;padding:.25rem .625rem;border-radius:var(--radius-full);letter-spacing:.02em}.badge-featured{background:#00c8531a;color:var(--color-accent)}.badge-unavailable{background:#ff44441a;color:var(--color-danger)}.product-actions{display:flex;gap:.5rem;flex-shrink:0}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:grid;place-items:center;z-index:200;padding:1rem;animation:fadeIn var(--transition) ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:2rem;width:100%;max-width:36rem;max-height:90vh;overflow-y:auto;animation:slideUp var(--transition-slow) ease}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.modal-header h2{font-size:1.25rem;font-weight:700;letter-spacing:-.02em}.modal-close{background:var(--color-surface-2);border:none;color:var(--color-text-secondary);width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);cursor:pointer;font-size:1.25rem;transition:all var(--transition-fast)}.modal-close:hover{background:var(--color-surface-3);color:var(--color-text)}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:2rem}.checkbox-row{display:flex;gap:2rem}.checkbox-label{display:flex;align-items:center;gap:.625rem;font-size:.9375rem;cursor:pointer;font-weight:500}.checkbox-label input{width:1.25rem;height:1.25rem;accent-color:var(--color-accent)}.qr-section{text-align:center;max-width:32rem;margin:0 auto;padding:2rem 0}.qr-preview{margin-bottom:1.5rem}.qr-canvas{width:280px;height:280px;border-radius:var(--radius-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-lg)}.qr-url{font-size:.875rem;color:var(--color-text-secondary);word-break:break-all;margin-bottom:1.5rem;font-family:monospace}.qr-actions{display:flex;gap:1rem;justify-content:center;margin-bottom:1.5rem}.qr-info{font-size:.875rem;color:var(--color-text-muted);max-width:24rem;margin:0 auto}.menu-page{padding-bottom:6rem}.menu-banner{height:16rem;background-size:cover;background-position:center;background-color:var(--color-surface-2);position:relative}.menu-banner-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,#000000e6,#0006 60%,#0000001a);display:flex;flex-direction:column;justify-content:flex-end;padding:2rem}.menu-banner-title{font-size:2rem;font-weight:800;margin-bottom:.375rem;letter-spacing:-.02em;color:#fff;text-shadow:0 2px 12px rgba(0,0,0,.4)}.menu-banner-desc{font-size:.9375rem;color:#ffffffe6;text-shadow:0 1px 6px rgba(0,0,0,.3)}.menu-info{display:flex;flex-wrap:wrap;gap:.625rem 1.5rem;padding:1rem 2rem;font-size:.8125rem;color:var(--color-text-secondary);border-bottom:1px solid var(--color-border);background:var(--color-surface)}.menu-info-item{display:flex;align-items:center;gap:.375rem}.menu-info-wa{color:var(--color-whatsapp);font-weight:600}.category-nav{position:sticky;top:64px;z-index:50;background:var(--color-surface);border-bottom:1px solid var(--color-border);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.category-nav-inner{display:flex;overflow-x:auto;padding:.75rem 1.5rem;gap:.5rem;-ms-overflow-style:none;scrollbar-width:none}.category-nav-inner::-webkit-scrollbar{display:none}.category-nav-item{padding:.5rem 1.125rem;border-radius:var(--radius-full);font-size:.8125rem;font-weight:600;background:var(--color-surface-2);border:1px solid var(--color-border);color:var(--color-text-secondary);cursor:pointer;white-space:nowrap;transition:all var(--transition)}.category-nav-item:hover{color:var(--color-text);border-color:var(--color-border-hover);background:var(--color-surface-3)}.category-nav-item.active{background:var(--color-text);color:var(--color-bg);border-color:var(--color-text)}.menu-content{padding:1.5rem 1.5rem 0;max-width:72rem;margin:0 auto}.menu-section{margin-bottom:2.5rem;scroll-margin-top:8rem}.menu-section-title{font-size:1.375rem;font-weight:800;margin-bottom:1rem;padding-left:.25rem;letter-spacing:-.02em}.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(16rem,1fr));gap:1.25rem}.product-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);overflow:hidden;transition:all var(--transition)}.product-card:hover{border-color:var(--color-border-hover);transform:translateY(-2px);box-shadow:var(--shadow)}.product-card.unavailable{opacity:.5;pointer-events:none}.product-image-wrap{position:relative;aspect-ratio:16/10;overflow:hidden}.product-image{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}.product-image-fallback{object-fit:contain;padding:1.5rem;color:var(--color-text-muted);background:var(--color-surface-2)}.product-card:hover .product-image{transform:scale(1.05)}.product-image-placeholder{width:100%;height:100%;display:grid;place-items:center;font-size:3rem;background:var(--color-surface-2)}.product-badge{position:absolute;top:.75rem;left:.75rem;font-size:.6875rem;font-weight:700;padding:.3rem .75rem;border-radius:var(--radius-full);background:var(--color-accent);color:#fff;letter-spacing:.02em}.product-badge-unavailable{background:var(--color-danger)}.product-info{padding:1rem}.product-name{font-size:1rem;font-weight:700;margin-bottom:.375rem;letter-spacing:-.01em}.product-desc{font-size:.8125rem;color:var(--color-text-secondary);margin-bottom:.875rem;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.product-bottom{display:flex;align-items:center;justify-content:space-between}.product-price{font-size:1.125rem;font-weight:800;letter-spacing:-.02em}.add-to-cart-btn{padding:.5rem 1.25rem;border-radius:var(--radius-full);border:none;background:var(--color-text);color:var(--color-bg);font-size:.8125rem;font-weight:700;cursor:pointer;transition:all var(--transition);letter-spacing:-.01em}.add-to-cart-btn:hover{transform:scale(1.05);box-shadow:var(--shadow)}.cart-float{position:fixed;bottom:1.25rem;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:1rem;padding:.875rem 1.75rem;background:var(--color-text);color:var(--color-bg);border:none;border-radius:var(--radius-full);font-size:.9375rem;font-weight:700;cursor:pointer;box-shadow:var(--shadow-lg);z-index:80;transition:all var(--transition);animation:cartBounce .4s cubic-bezier(.34,1.56,.64,1)}.cart-float:hover{transform:translate(-50%) scale(1.03);box-shadow:var(--shadow-lg)}@keyframes cartBounce{0%{transform:translate(-50%) scale(.9);opacity:0}60%{transform:translate(-50%) scale(1.02)}to{transform:translate(-50%) scale(1);opacity:1}}.cart-float-count{display:inline-flex;align-items:center;justify-content:center;width:1.625rem;height:1.625rem;border-radius:50%;background:var(--color-accent);color:#fff;font-size:.75rem;font-weight:800}.cart-float-label{font-weight:700}.cart-float-total{opacity:.7;font-size:.875rem}.cart-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:150;animation:fadeIn var(--transition) ease}.cart-drawer{position:fixed;top:0;right:0;width:min(26rem,100vw);height:100vh;height:100dvh;background:var(--color-surface);border-left:1px solid var(--color-border);z-index:200;display:flex;flex-direction:column;transform:translate(100%);transition:transform var(--transition-slow) cubic-bezier(.4,0,.2,1);overflow:hidden}.cart-drawer.open{transform:translate(0)}.cart-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 1.5rem 1rem;border-bottom:1px solid var(--color-border)}.cart-header h2{font-size:1.25rem;font-weight:800;letter-spacing:-.02em}.cart-close{background:var(--color-surface-2);border:none;color:var(--color-text-secondary);width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);cursor:pointer;font-size:1.25rem;transition:all var(--transition-fast)}.cart-close:hover{background:var(--color-surface-3);color:var(--color-text)}.cart-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;color:var(--color-text-muted);text-align:center}.cart-empty p:first-child{font-size:1.125rem;font-weight:700;color:var(--color-text);margin-bottom:.5rem}.cart-items{flex:1;padding:1rem 1.5rem;overflow-y:auto;min-height:0}.cart-item{display:flex;gap:.75rem;padding:1rem 0;border-bottom:1px solid var(--color-border)}.cart-item:last-child{border-bottom:none}.cart-item-image{width:56px;height:56px;object-fit:cover;border-radius:var(--radius);flex-shrink:0}.cart-item-body{flex:1;min-width:0}.cart-item-info{display:flex;justify-content:space-between;gap:.5rem;margin-bottom:.5rem}.cart-item-name{font-weight:700;font-size:.9375rem}.cart-item-price{font-size:.9375rem;color:var(--color-accent);font-weight:700}.cart-item-controls{display:flex;align-items:center;gap:.75rem}.cart-item-controls button{width:2rem;height:2rem;border-radius:50%;border:1px solid var(--color-border);background:var(--color-surface-2);color:var(--color-text);font-size:.9375rem;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.cart-item-controls button:hover{background:var(--color-surface-3);border-color:var(--color-border-hover)}.cart-item-controls span{font-size:.9375rem;min-width:1.75rem;text-align:center;font-weight:700}.cart-item-remove{width:auto!important;border-radius:var(--radius)!important;padding:.25rem .75rem!important;font-size:.75rem!important;color:var(--color-danger)!important;border-color:transparent!important;background:none!important;margin-left:auto}.cart-item-remove:hover{color:var(--color-danger)!important;background:#ff44441a!important}.cart-summary{padding:1.25rem 1.5rem;border-top:1px solid var(--color-border)}.cart-summary-row{display:flex;justify-content:space-between;font-size:.9375rem;color:var(--color-text-secondary);margin-bottom:.5rem}.cart-summary-total{font-size:1.125rem;font-weight:800;color:var(--color-text);margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--color-border);letter-spacing:-.02em}.cart-fields{padding:0 1.5rem}.cart-field{margin-bottom:1rem}.cart-field label{display:block;font-size:.8125rem;color:var(--color-text-secondary);margin-bottom:.375rem;font-weight:500}.cart-field input,.cart-field textarea{width:100%;padding:.625rem 1rem;background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);font-size:.9375rem;font-family:inherit;transition:all var(--transition)}.cart-field input:focus,.cart-field textarea:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #00c8531a}.cart-field textarea{resize:vertical}.whatsapp-btn{display:flex;align-items:center;justify-content:center;gap:.75rem;width:calc(100% - 3rem);margin:1rem 1.5rem;padding:1rem;background:var(--color-whatsapp);color:#fff;border:none;border-radius:var(--radius-lg);font-size:1rem;font-weight:700;cursor:pointer;transition:all var(--transition);letter-spacing:-.01em}.whatsapp-btn:hover{background:var(--color-whatsapp-hover);transform:translateY(-2px);box-shadow:0 4px 20px #25d3664d}.cart-clear-btn{display:block;margin:.75rem auto 1.5rem;background:none;border:none;color:var(--color-text-muted);font-size:.8125rem;cursor:pointer;transition:color var(--transition-fast)}.cart-clear-btn:hover{color:var(--color-text-secondary)}.menu-not-found{min-height:calc(100vh - 64px);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem}.menu-not-found h1{font-size:1.5rem;font-weight:800;margin-bottom:.5rem}.menu-not-found p{color:var(--color-text-secondary)}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:1rem}.loading-spinner{width:2.5rem;height:2.5rem;border:3px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-message{font-size:.875rem;color:var(--color-text-secondary)}.order-modes-section{max-width:40rem}.order-modes-desc{color:var(--color-text-secondary);margin-bottom:1.5rem}.order-mode-toggles{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.order-mode-card{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.25rem}.order-mode-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.order-mode-desc{font-size:.8125rem;color:var(--color-text-secondary)}.delivery-settings{margin-bottom:1.5rem}.input-error{border-color:var(--color-danger)!important}.input-error:focus{box-shadow:0 0 0 2px #ff444440}.field-error{color:var(--color-danger);font-size:.75rem;margin-top:.25rem}.required{color:var(--color-danger)}.order-mode-selector{display:flex;gap:.5rem;padding:.75rem 1rem;background:var(--color-surface);border-bottom:1px solid var(--color-border)}.order-mode-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1rem;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface-2);color:var(--color-text-secondary);font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition)}.order-mode-btn:hover{border-color:var(--color-border-hover);color:var(--color-text)}.order-mode-btn.active{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.order-modes-section{max-width:480px}.order-modes-section h3{font-size:1.125rem;font-weight:700;margin-bottom:.25rem}.order-modes-description{color:var(--color-text-secondary);font-size:.875rem;margin-bottom:1.5rem}.order-modes-options{display:flex;flex-direction:column;gap:1rem}.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:1rem;background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius);cursor:pointer;transition:border-color var(--transition)}.toggle-row:hover{border-color:var(--color-border-hover)}.toggle-label{font-weight:600;font-size:.9375rem;display:block}.toggle-hint{color:var(--color-text-muted);font-size:.8125rem;display:block;margin-top:.125rem}.toggle-row input[type=checkbox]{width:1.25rem;height:1.25rem;accent-color:var(--color-accent);cursor:pointer}.global-banner{display:flex;align-items:center;justify-content:space-between;padding:.625rem 1.5rem;font-size:.875rem;font-weight:500;gap:1rem}.global-banner--info{background:#00c8531a;color:var(--color-accent);border-bottom:1px solid rgba(0,200,83,.2)}.global-banner--warning{background:#ff98001a;color:#ff9800;border-bottom:1px solid rgba(255,152,0,.2)}.global-banner--megaphone{background:#0096ff1a;color:#4dabf7;border-bottom:1px solid rgba(0,150,255,.2)}.global-banner-content{display:flex;align-items:center;gap:.5rem;flex:1;justify-content:center}.global-banner-icon{flex-shrink:0}.global-banner-message{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.global-banner-cta{display:inline-flex;align-items:center;padding:.25rem .75rem;border-radius:var(--radius-full);color:var(--color-bg);font-size:.8125rem;font-weight:700;text-decoration:none;white-space:nowrap;flex-shrink:0;transition:opacity var(--transition-fast)}.global-banner-cta:hover{opacity:.85}.global-banner-dismiss{background:none;border:none;color:inherit;opacity:.6;cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);transition:opacity var(--transition-fast);flex-shrink:0}.global-banner-dismiss:hover{opacity:1}@media(max-width:640px){.navbar{padding:0 1rem}.global-banner{padding:.5rem 1rem}.global-banner-message{white-space:normal}.form-row{flex-direction:column;gap:0}.product-grid{grid-template-columns:1fr}.hero{padding:5rem 1rem 4rem}.hero-title{font-size:2rem}.hero-subtitle{font-size:1.0625rem}.steps{flex-direction:column;gap:2rem}.product-card-db{flex-direction:column;align-items:flex-start}.product-thumb{width:100%;height:140px}.menu-banner{height:12rem}.dashboard-topbar{flex-direction:column;align-items:flex-start}.tab-content{padding:1.25rem}.features,.how-it-works{padding:3rem 1rem 4rem}.plan-section{padding:0}.plan-status-card{padding:1rem}.plan-orders-list{gap:.5rem}.plan-order-row{flex-direction:column;align-items:flex-start;gap:.25rem}.plan-order-right{align-self:flex-end}}.plan-section{max-width:640px}.plan-section h3{font-size:1.125rem;font-weight:700;margin-bottom:.25rem}.plan-description{color:var(--color-text-secondary);font-size:.875rem;margin-bottom:1.5rem}.plan-status-card{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:2rem}.plan-status-header{display:flex;gap:.5rem;margin-bottom:1rem;align-items:center}.plan-badge{display:inline-flex;align-items:center;padding:.25rem .75rem;border-radius:var(--radius-full);font-size:.8125rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.plan-badge-free{background:#ffffff14;color:var(--color-text-secondary)}.plan-badge-pro{background:#00c85326;color:var(--color-accent)}.plan-badge-past-due{background:#ff444426;color:var(--color-danger)}.plan-badge-canceled{background:#ff444414;color:var(--color-text-muted)}.plan-details{display:flex;flex-direction:column;gap:.75rem}.plan-detail-text{font-size:1rem;font-weight:500}.plan-detail-sub{font-size:.875rem;color:var(--color-text-secondary);line-height:1.5}.plan-error{color:var(--color-danger);font-size:.8125rem;margin-top:.5rem}.usage-bar-container{margin:.5rem 0}.usage-bar{width:100%;height:.5rem;background:var(--color-surface-3);border-radius:var(--radius-full);overflow:hidden}.usage-bar-fill{height:100%;background:var(--color-accent);border-radius:var(--radius-full);transition:width var(--transition-slow)}.usage-bar-warning{background:#ff9800}.usage-bar-danger{background:var(--color-danger)}.usage-bar-label{display:block;font-size:.75rem;color:var(--color-text-muted);margin-top:.375rem}.plan-success-banner{background:#00c8531f;color:var(--color-accent);border:1px solid rgba(0,200,83,.25);padding:.75rem 1rem;border-radius:var(--radius);font-size:.875rem;font-weight:600;margin-bottom:1rem;animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.plan-badge-active{background:#00c8531f;color:var(--color-accent)}.plan-payments-section{margin-bottom:1.5rem}.plan-payments-section h4{font-size:1rem;font-weight:700;margin-bottom:1rem}.plan-payments-list{display:flex;flex-direction:column;gap:.5rem}.plan-payment-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius)}.plan-payment-left{display:flex;flex-direction:column;gap:.125rem}.plan-payment-label{font-size:.875rem;font-weight:500}.plan-payment-date{font-size:.75rem;color:var(--color-text-muted)}.plan-payment-right{display:flex;align-items:center}.plan-payment-status{font-size:.75rem;font-weight:600;padding:.125rem .5rem;border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.03em}.plan-payment-active{background:#00c8531f;color:var(--color-accent)}.plan-no-payments{color:var(--color-text-muted);font-size:.875rem}.plan-orders-section{margin-top:0}.plan-orders-section h4{font-size:1rem;font-weight:700;margin-bottom:1rem}.plan-no-orders{color:var(--color-text-muted);font-size:.875rem}.plan-orders-list{display:flex;flex-direction:column;gap:.5rem}.plan-order-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius)}.plan-order-left{display:flex;align-items:center;gap:.75rem}.plan-order-type{font-size:.75rem;font-weight:600;padding:.125rem .5rem;border-radius:var(--radius-sm);background:var(--color-surface-3);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.03em}.plan-order-name{font-size:.875rem;font-weight:500}.plan-order-date{font-size:.75rem;color:var(--color-text-muted)}.plan-order-right{display:flex;align-items:center;gap:.75rem}.plan-order-total{font-size:.875rem;font-weight:600}.plan-order-items{font-size:.75rem;color:var(--color-text-muted)}.order-limit-badge{margin:0 1rem .75rem;padding:.5rem .75rem;font-size:.8125rem;font-weight:600;text-align:center;background:#ff98001f;color:#ff9800;border-radius:var(--radius)}.order-limit-exhausted{background:#ff44441f;color:var(--color-danger)}.limit-reached-message{margin:0 1rem;padding:1rem;text-align:center;background:var(--color-surface-3);border:1px solid var(--color-border);border-radius:var(--radius)}.limit-reached-message p{font-size:.875rem;color:var(--color-text-secondary);line-height:1.5}.limit-reached-message p:first-child{font-weight:600;color:var(--color-danger);margin-bottom:.25rem}.store-settings{max-width:480px}.store-settings h3{font-size:1.125rem;font-weight:700;margin-bottom:1.25rem}.color-picker-row{display:flex;align-items:center;gap:.75rem}.color-picker-input{width:40px;height:40px;padding:2px;border:1px solid var(--color-border);border-radius:var(--radius);cursor:pointer;background:var(--color-surface-2)}.color-swatch{width:32px;height:32px;border-radius:var(--radius);display:inline-block;flex-shrink:0;border:1px solid var(--color-border)}.form-hint{display:block;font-size:.75rem;color:var(--color-text-muted);margin-top:.375rem}.banner-upload-area{display:flex;flex-direction:column;gap:.5rem}.banner-preview{width:100%;height:120px;background-size:cover;background-position:center;border-radius:var(--radius);border:1px solid var(--color-border)}.menu-page .btn-accent,.menu-page .add-to-cart-btn{background:color-mix(in srgb,var(--restaurant-accent, var(--color-accent)),#000 25%);color:#fff}.menu-page .btn-accent:hover,.menu-page .add-to-cart-btn:hover{background:color-mix(in srgb,var(--restaurant-accent, var(--color-accent)),#000 15%);filter:brightness(1.05);box-shadow:0 4px 16px color-mix(in srgb,var(--restaurant-accent, var(--color-accent)) 40%,transparent)}.menu-page .category-nav-item.active{background:color-mix(in srgb,var(--restaurant-accent, var(--color-text)),#000 25%);color:#fff;border-color:color-mix(in srgb,var(--restaurant-accent, var(--color-text)),#000 25%)}.menu-page .order-mode-btn.active{background:color-mix(in srgb,var(--restaurant-accent, var(--color-accent)),#000 25%);color:#fff;border-color:color-mix(in srgb,var(--restaurant-accent, var(--color-accent)),#000 25%)}
