:root,[data-theme=light]{--primary: #667eea;--primary-hover: #5a6fd6;--primary-light: #f0f3ff;--bg-main: #f5f5f5;--bg-card: #ffffff;--bg-elevated: #ffffff;--bg-input: #ffffff;--bg-hover: #f0f0f0;--bg-active: #e8e8e8;--text-primary: #1a1a2e;--text-secondary: #666666;--text-muted: #999999;--text-inverse: #ffffff;--border-color: #e5e5e5;--border-light: #f0f0f0;--success: #10b981;--success-bg: #ecfdf5;--warning: #f59e0b;--warning-bg: #fffbeb;--error: #ef4444;--error-bg: #fef2f2;--info: #3b82f6;--info-bg: #eff6ff;--shadow-sm: 0 1px 2px rgba(0,0,0,.05);--shadow-md: 0 4px 6px rgba(0,0,0,.07);--shadow-lg: 0 10px 25px rgba(0,0,0,.1);--header-bg: #ffffff;--header-border: #e5e5e5}[data-theme=dark]{--primary: #818cf8;--primary-hover: #6366f1;--primary-light: #1e1b4b;--bg-main: #0f0f1a;--bg-card: #1a1a2e;--bg-elevated: #252542;--bg-input: #252542;--bg-hover: #2a2a4a;--bg-active: #353560;--text-primary: #f1f1f1;--text-secondary: #a0a0a0;--text-muted: #6b6b6b;--text-inverse: #1a1a2e;--border-color: #2a2a4a;--border-light: #1f1f3a;--success: #34d399;--success-bg: #064e3b;--warning: #fbbf24;--warning-bg: #78350f;--error: #f87171;--error-bg: #7f1d1d;--info: #60a5fa;--info-bg: #1e3a5f;--shadow-sm: 0 1px 2px rgba(0,0,0,.3);--shadow-md: 0 4px 6px rgba(0,0,0,.4);--shadow-lg: 0 10px 25px rgba(0,0,0,.5);--header-bg: #1a1a2e;--header-border: #2a2a4a}[data-theme=pos]{--primary: #22c55e;--primary-hover: #16a34a;--primary-light: #dcfce7;--bg-main: #e8f5e9;--bg-card: #ffffff;--bg-elevated: #ffffff;--bg-input: #ffffff;--bg-hover: #f0fdf4;--bg-active: #dcfce7;--bg-sidebar: #ffffff;--bg-panel: #ffffff;--text-primary: #1f2937;--text-secondary: #6b7280;--text-muted: #9ca3af;--text-inverse: #ffffff;--border-color: #e5e7eb;--border-light: #f3f4f6;--border-active: #22c55e;--success: #22c55e;--success-bg: #dcfce7;--warning: #f59e0b;--warning-bg: #fef3c7;--error: #ef4444;--error-bg: #fee2e2;--info: #3b82f6;--info-bg: #dbeafe;--badge-discount-bg: #fef3c7;--badge-discount-text: #92400e;--badge-veg: #dcfce7;--badge-veg-text: #166534;--badge-nonveg: #fee2e2;--badge-nonveg-text: #991b1b;--table-available: #22c55e;--table-occupied: #3b82f6;--table-dirty: #f59e0b;--table-reserved: #8b5cf6;--table-out: #6b7280;--shadow-sm: 0 1px 2px rgba(0,0,0,.05);--shadow-md: 0 4px 6px rgba(0,0,0,.07);--shadow-lg: 0 10px 15px rgba(0,0,0,.1);--header-bg: #ffffff;--header-border: #e5e7eb}*{transition:background-color .2s ease,border-color .2s ease,color .2s ease}html{scroll-behavior:smooth}body{background:var(--bg-main);color:var(--text-primary)}.toast-container{position:fixed;top:1rem;right:1rem;z-index:9999;display:flex;flex-direction:column;gap:.75rem;max-width:380px}.toast{display:flex;align-items:flex-start;gap:.75rem;padding:1rem 1.25rem;border-radius:12px;color:#fff;animation:slideIn .3s ease;position:relative;overflow:hidden;box-shadow:0 4px 20px #0003}.toast:before{content:"";position:absolute;top:-20px;right:-20px;width:80px;height:80px;border-radius:50%;background:#ffffff1a}.toast:after{content:"";position:absolute;bottom:-30px;right:40px;width:60px;height:60px;border-radius:50%;background:#ffffff14}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-success{background:linear-gradient(135deg,#2ecc71,#27ae60)}.toast-error{background:linear-gradient(135deg,#e74c3c,#c0392b)}.toast-warning{background:linear-gradient(135deg,#f39c12,#e67e22)}.toast-info{background:linear-gradient(135deg,#3498db,#2980b9)}.toast-icon{width:32px;height:32px;border-radius:50%;background:#fff3;display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:700;flex-shrink:0;position:relative;top:-8px;left:-8px;margin-right:-8px}.toast-content{flex:1;z-index:1}.toast-title{display:block;font-size:1.1rem;margin-bottom:.25rem}.toast-message{margin:0;font-size:.9rem;opacity:.9}.toast-close{background:none;border:none;color:#fff;font-size:1.5rem;cursor:pointer;opacity:.7;padding:0;line-height:1;z-index:1}.toast-close:hover{opacity:1}@media(max-width:480px){.toast-container{left:1rem;right:1rem;max-width:none}}.pwa-install-banner{position:fixed;bottom:0;left:0;right:0;background:#1a1a1a!important;border-top:1px solid #333;padding:1rem 1.25rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;z-index:1000;box-shadow:0 -8px 32px #0006;animation:slideUp .3s cubic-bezier(.34,1.56,.64,1)}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.pwa-install-content{display:flex;align-items:center;gap:.875rem}.pwa-icon-wrapper{width:44px;height:44px;background:linear-gradient(135deg,#22c55e,#16a34a);border-radius:12px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #22c55e4d;flex-shrink:0}.pwa-icon-wrapper svg{width:24px;height:24px;color:#fff}.pwa-text{display:flex;flex-direction:column;gap:2px}.pwa-text strong{color:#fff!important;font-size:.95rem;font-weight:600}.pwa-text span{color:#888!important;font-size:.8rem}.pwa-actions{display:flex;gap:.5rem;flex-shrink:0}.pwa-dismiss{padding:.6rem 1rem;background:transparent;border:1px solid #444;border-radius:10px;color:#888!important;font-size:.85rem;cursor:pointer;transition:all .2s}.pwa-dismiss:hover{background:#2a2a2a;color:#fff!important;border-color:#555}.pwa-install{padding:.6rem 1.25rem;background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff!important;border:none;border-radius:10px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #22c55e4d}.pwa-install:hover{transform:translateY(-2px);box-shadow:0 6px 16px #22c55e66}.connection-status{position:fixed;top:0;left:0;right:0;padding:.75rem 1rem;display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:.85rem;font-weight:500;z-index:1001;animation:slideDown .3s cubic-bezier(.34,1.56,.64,1)}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.connection-status .status-icon{width:18px;height:18px;display:flex;align-items:center;justify-content:center}.connection-status .status-icon svg{width:100%;height:100%}.connection-status.offline{background:#1a1a1a!important;color:#ff7a00!important;border-bottom:2px solid #FF7A00}.connection-status.offline .status-icon{color:#ff7a00}.connection-status.online{background:#1a1a1a!important;color:#22c55e!important;border-bottom:2px solid #22c55e}.connection-status.online .status-icon{color:#22c55e}@media(max-width:480px){.pwa-install-banner{flex-direction:column;padding:1.25rem;gap:1rem}.pwa-install-content{width:100%}.pwa-actions{width:100%;display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.pwa-dismiss,.pwa-install{width:100%;padding:.75rem;text-align:center}}.customer-auth-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:200;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:1rem}.customer-auth-modal{background:#1a1a1a;border-radius:20px;padding:2rem;width:100%;max-width:400px;position:relative;border:1px solid #333;box-shadow:0 25px 50px #00000080;animation:authModalIn .3s cubic-bezier(.34,1.56,.64,1)}@keyframes authModalIn{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.customer-auth-modal .close-btn{position:absolute;top:1rem;right:1rem;width:32px;height:32px;background:#2a2a2a;border:1px solid #444;border-radius:50%;font-size:1.2rem;cursor:pointer;color:#888;display:flex;align-items:center;justify-content:center;transition:all .2s}.customer-auth-modal .close-btn:hover{background:#ef4444;border-color:#ef4444;color:#fff}.auth-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;background:#0d0d0d;padding:4px;border-radius:12px}.auth-tabs button{flex:1;padding:.75rem;border:none;background:transparent;border-radius:10px;cursor:pointer;font-weight:500;color:#888;transition:all .2s}.auth-tabs button:hover{color:#fff}.auth-tabs button.active{background:#22c55e;color:#fff;box-shadow:0 4px 12px #22c55e4d}.customer-auth-modal .form-group{margin-bottom:.75rem}.customer-auth-modal label{display:none}.customer-auth-modal .input-wrapper{position:relative;display:flex;align-items:center;background:#0d0d0d!important;border-radius:12px;border:1px solid #333;transition:all .2s}.customer-auth-modal .input-wrapper:focus-within{border-color:#ff7a00;box-shadow:0 0 0 3px #ff7a001a}.customer-auth-modal .input-icon{position:absolute;left:14px;width:20px;height:20px;color:#ff7a00;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:1}.customer-auth-modal .input-icon svg{width:100%;height:100%}.customer-auth-modal input{width:100%!important;padding:.875rem 1rem .875rem 2.75rem!important;border:none!important;border-radius:12px!important;font-size:.95rem!important;background:transparent!important;color:#fff!important;transition:all .2s}.customer-auth-modal input::placeholder{color:#666!important}.customer-auth-modal input:focus{outline:none!important;box-shadow:none!important}.customer-auth-modal .submit-btn{width:100%;padding:1rem;background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;margin-top:.75rem;transition:all .2s;box-shadow:0 4px 15px #22c55e4d}.customer-auth-modal .submit-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #22c55e66}.customer-auth-modal .submit-btn:disabled{background:#333;color:#666;cursor:not-allowed;box-shadow:none;transform:none}.customer-auth-modal.profile-view{text-align:center}.profile-header{margin-bottom:1.5rem}.profile-avatar{width:80px;height:80px;background:linear-gradient(135deg,#22c55e,#16a34a);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700;color:#fff;margin:0 auto 1rem;box-shadow:0 8px 24px #22c55e4d}.profile-header h2{margin:0 0 .25rem;font-size:1.5rem;color:#fff}.profile-email{color:#888;font-size:.9rem}.profile-info{background:#0d0d0d;border-radius:12px;padding:1rem;margin-bottom:1.5rem}.profile-row{display:flex;align-items:center;gap:12px;padding:.75rem 0;border-bottom:1px solid #222;color:#ccc;font-size:.95rem}.profile-row:last-child{border-bottom:none}.profile-icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px;color:#ff7a00}.profile-icon svg{width:100%;height:100%}.profile-actions{display:flex;flex-direction:column;gap:.75rem}.logout-btn{width:100%;padding:1rem;background:#ef4444;color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.5rem}.logout-btn svg{width:20px;height:20px}.logout-btn:hover{background:#dc2626;transform:translateY(-2px)}:root{--hub-bg: #0a0a0a;--hub-surface: #141414;--hub-surface-2: #1e1e1e;--hub-border: #2a2a2a;--hub-text: #ffffff;--hub-text-muted: #888888;--hub-accent: #FF7A00;--hub-accent-light: #ffaa4d;--hub-accent-dark: #cc6200;--hub-green: #2ECC71;--hub-red: #ef4444;--hub-gradient: linear-gradient(135deg, #FF7A00 0%, #ff5722 100%)}.hub-home{min-height:100vh;background:var(--hub-bg);color:var(--hub-text);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;overflow-x:hidden}.hub-nav{position:fixed;top:0;left:0;right:0;z-index:100;background:#0a0a0ad9;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--hub-border)}.hub-nav-inner{max-width:1400px;margin:0 auto;padding:1rem 2rem;display:flex;align-items:center;justify-content:space-between}.hub-logo{display:flex;align-items:center;gap:.35rem;text-decoration:none}.logo-img{height:30px;width:auto;object-fit:contain}.logo-text{font-size:1.25rem;font-weight:700;color:var(--hub-text)}.logo-accent{color:var(--hub-accent)}.hub-nav-links{display:flex;gap:2rem}.nav-link{color:var(--hub-text-muted);text-decoration:none;font-size:.95rem;font-weight:500;transition:color .2s;position:relative}.nav-link:hover,.nav-link.active{color:var(--hub-accent)}.nav-link.active:after{content:"";position:absolute;bottom:-4px;left:0;right:0;height:2px;background:var(--hub-accent);border-radius:1px}.hub-nav-actions{display:flex;align-items:center;gap:.75rem}.nav-btn{display:flex;align-items:center;gap:.5rem;padding:.6rem 1.25rem;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;text-decoration:none;border:none}.nav-btn svg{width:18px;height:18px}.nav-btn-ghost{background:transparent;color:var(--hub-text-muted)}.nav-btn-ghost:hover{color:var(--hub-text)}.nav-btn-primary{background:var(--hub-gradient);color:#000}.nav-btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 20px #f6a3124d}.nav-btn-order-status{position:relative;background:#2ecc7126;border:1px solid var(--hub-green);color:var(--hub-green);padding:.5rem;border-radius:50%;animation:pulse-order 2s ease-in-out infinite}.nav-btn-order-status svg{width:20px;height:20px}.order-badge{position:absolute;top:-4px;right:-4px;background:var(--hub-green);color:#000;font-size:.7rem;font-weight:700;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center}@keyframes pulse-order{0%,to{box-shadow:0 0 #2ecc7166}50%{box-shadow:0 0 0 8px #2ecc7100}}.hub-hero{padding:8rem 2rem 4rem;position:relative;overflow:hidden}.hero-bg-elements{position:absolute;inset:0;pointer-events:none}.hero-glow{position:absolute;border-radius:50%;filter:blur(100px)}.hero-glow-1{width:600px;height:600px;background:var(--hub-accent);top:-200px;right:-100px;opacity:.12}.hero-glow-2{width:400px;height:400px;background:#ff6b35;bottom:0;left:20%;opacity:.08}.hero-content{max-width:1400px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;position:relative;z-index:1}.hero-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#f6a31226;border:1px solid rgba(246,163,18,.3);border-radius:20px;color:var(--hub-accent);font-size:.85rem;font-weight:500;margin-bottom:1.5rem}.hero-badge svg{width:16px;height:16px}.hero-text h1{font-size:3.5rem;font-weight:700;line-height:1.1;margin:0 0 1.5rem}.text-gradient{background:var(--hub-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-description{font-size:1.1rem;color:var(--hub-text-muted);line-height:1.7;margin-bottom:2rem;max-width:500px}.hero-cta{margin-bottom:3rem}.btn-primary,.btn-secondary,.btn-ghost{display:inline-flex;align-items:center;gap:.5rem;padding:1rem 2rem;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);text-decoration:none;border:none}.btn-primary{background:var(--hub-gradient);color:#000;box-shadow:0 4px 15px #f6a3124d}.btn-primary:hover{transform:translateY(-3px);box-shadow:0 8px 25px #f6a31266}.btn-primary svg{width:18px;height:18px}.btn-ghost{background:var(--hub-surface);color:var(--hub-text);border:1px solid var(--hub-border)}.btn-ghost:hover{background:var(--hub-surface-2);border-color:var(--hub-accent)}.hero-stats{display:flex;align-items:center;gap:2rem}.stat{text-align:center}.stat-value{display:block;font-size:1.75rem;font-weight:700;color:var(--hub-accent)}.stat-label{font-size:.85rem;color:var(--hub-text-muted)}.stat-divider{width:1px;height:40px;background:var(--hub-border)}.hero-visual{position:relative}.hero-plate{border-radius:50%;overflow:hidden;box-shadow:0 25px 50px #00000080}.hero-plate img{width:100%;height:100%;object-fit:cover}.hero-plate-main{width:400px;height:400px;border:4px solid var(--hub-accent);animation:float 6s ease-in-out infinite}.hero-plate-secondary{position:absolute;width:180px;height:180px;bottom:-20px;right:-40px;border:3px solid var(--hub-accent-light);animation:float 6s ease-in-out infinite 1s}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-15px)}}.hero-floating-card{position:absolute;top:50%;left:-60px;background:var(--hub-surface);border:1px solid var(--hub-border);border-radius:12px;padding:1rem;display:flex;align-items:center;gap:.75rem;animation:slideIn .5s ease .5s both;box-shadow:0 10px 30px #0000004d}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.floating-card-icon{width:40px;height:40px;background:var(--hub-gradient);border-radius:10px;display:flex;align-items:center;justify-content:center}.floating-card-icon svg{width:20px;height:20px;color:#000}.floating-card-title{display:block;font-weight:600;font-size:.9rem}.floating-card-text{font-size:.8rem;color:var(--hub-text-muted)}.promo-banner{max-width:1000px;margin:4rem auto 0;background:var(--hub-surface);border:1px solid var(--hub-border);border-radius:20px;padding:2rem;position:relative;overflow:hidden}.promo-banner:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--hub-gradient)}.promo-content{display:flex;justify-content:space-between;align-items:center}.promo-text h3{font-size:1.25rem;margin:0 0 .5rem}.promo-rating{display:flex;gap:.25rem}.promo-star svg{width:18px;height:18px;color:var(--hub-accent)}.promo-offer{text-align:center;padding:1rem 2rem;background:#f6a3121a;border-radius:12px}.promo-label{display:block;font-size:.85rem;color:var(--hub-text-muted)}.promo-value{display:block;font-size:3rem;font-weight:800;color:var(--hub-accent);line-height:1}.tipo-negocio-section{max-width:1400px;margin:0 auto;padding:2rem}.tipo-negocio-tabs{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}.tipo-tab{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--hub-surface);border:1px solid var(--hub-border);border-radius:25px;color:var(--hub-text-muted);font-size:.95rem;font-weight:500;cursor:pointer;transition:all .3s}.tipo-tab:hover{border-color:var(--hub-accent);color:var(--hub-text)}.tipo-tab.active{background:var(--hub-gradient);border-color:transparent;color:#000}.tipo-icon{display:flex;align-items:center;justify-content:center}.tipo-icon svg{width:20px;height:20px}.section-header{max-width:1400px;margin:0 auto;padding:3rem 2rem 2rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.section-title{font-size:1.75rem;font-weight:600;display:flex;align-items:center;gap:.75rem;margin:0;text-align:center;width:100%;justify-content:center}.section-title-sm{font-size:1.5rem;font-weight:600;display:flex;align-items:center;gap:.5rem;margin:0}.title-decoration{color:var(--hub-accent);font-size:1rem}.destacados-section{max-width:1400px;margin:0 auto;padding:0 2rem 4rem}.destacados-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.destacado-card{position:relative;background:var(--hub-surface);border:1px solid var(--hub-border);border-radius:16px;overflow:hidden;text-decoration:none;color:inherit;transition:all .4s cubic-bezier(.4,0,.2,1)}.destacado-card:hover{transform:translateY(-10px);box-shadow:0 25px 50px #0006;border-color:var(--hub-accent)}.destacado-featured{grid-column:span 2;grid-row:span 2}.destacado-image{position:relative;aspect-ratio:4/3;overflow:hidden}.destacado-featured .destacado-image{aspect-ratio:16/10}.destacado-image img{width:100%;height:100%;object-fit:cover;transition:transform .5s}.destacado-card:hover .destacado-image img{transform:scale(1.08)}.destacado-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.8) 0%,transparent 60%)}.destacado-badges{position:absolute;top:1rem;left:1rem;display:flex;gap:.5rem}.badge{display:flex;align-items:center;gap:.25rem;padding:.4rem .75rem;border-radius:20px;font-size:.8rem;font-weight:600;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.badge svg{width:14px;height:14px}.badge-hot{background:#ef4444e6;color:#fff}.badge-rating{background:#000000b3;color:var(--hub-accent)}.btn-favorite,.card-favorite{position:absolute;top:1rem;right:1rem;width:40px;height:40px;background:#00000080;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;z-index:5}.btn-favorite svg,.card-favorite svg{width:20px;height:20px;color:#fff;transition:all .3s}.btn-favorite:hover,.card-favorite:hover{background:#ef4444cc;transform:scale(1.1)}.btn-favorite.active,.card-favorite.active{background:var(--hub-red)}.btn-favorite.active svg,.card-favorite.active svg{color:#fff;animation:heartPop .4s ease}@keyframes heartPop{0%{transform:scale(1)}50%{transform:scale(1.3)}to{transform:scale(1)}}.destacado-content{padding:1rem}.destacado-tipo{display:inline-block;font-size:.8rem;color:var(--hub-accent);font-style:italic;margin-bottom:.5rem}.destacado-content h3{font-size:1rem;font-weight:700;margin:0 0 .35rem}.destacado-featured .destacado-content h3{font-size:1.15rem}.destacado-content p{font-size:.8rem;color:var(--hub-text-muted);margin:0 0 .75rem;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.destacado-meta{display:flex;gap:1rem;margin-bottom:.75rem}.meta-item{display:flex;align-items:center;gap:.25rem;font-size:.75rem;color:var(--hub-text-muted)}.meta-item svg{width:16px;height:16px}.destacado-footer{display:flex;justify-content:space-between;align-items:center}.destacado-precio{font-size:.95rem;font-weight:700;color:var(--hub-accent)}.btn-ver-menu{display:flex;align-items:center;gap:.3rem;font-size:.8rem;font-weight:600;color:var(--hub-accent);transition:gap .3s}.btn-ver-menu svg{width:16px;height:16px}.destacado-card:hover .btn-ver-menu{gap:.6rem}.categorias-section{max-width:1400px;margin:0 auto;padding:0 2rem 2rem;overflow-x:auto;scrollbar-width:thin;scrollbar-color:var(--hub-border) transparent}.categorias-section::-webkit-scrollbar{height:4px}.categorias-section::-webkit-scrollbar-track{background:transparent}.categorias-section::-webkit-scrollbar-thumb{background:var(--hub-border);border-radius:4px}.categorias-section::-webkit-scrollbar-thumb:hover{background:var(--hub-accent)}.categorias-scroll{display:flex;gap:.75rem;padding-bottom:.75rem}.categoria-chip{display:flex;align-items:center;gap:.5rem;padding:.6rem 1.25rem;background:var(--hub-surface);border:1px solid var(--hub-border);border-radius:20px;color:var(--hub-text-muted);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.categoria-chip:hover{border-color:var(--hub-accent);color:var(--hub-text)}.categoria-chip.active{background:var(--hub-accent);border-color:var(--hub-accent);color:#000}.categoria-icon{display:flex;align-items:center;justify-content:center}.categoria-icon svg{width:18px;height:18px}.explorar-section{max-width:1400px;margin:0 auto;padding:2rem}.explorar-controls{display:flex;gap:1rem;align-items:center}.search-box{position:relative;width:320px}.search-box input{width:100%;padding:.85rem 1rem .85rem 3rem;background:var(--hub-surface);border:1px solid var(--hub-border);border-radius:12px;color:var(--hub-text);font-size:.95rem;transition:all .2s}.search-box input::placeholder{color:var(--hub-text-muted)}.search-box input:focus{outline:none;border-color:var(--hub-accent)}.search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:var(--hub-text-muted)}.search-icon svg{width:18px;height:18px}.restaurants-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;margin-top:2rem}.restaurant-card{background:var(--hub-surface);border:1px solid var(--hub-border);border-radius:20px;overflow:hidden;text-decoration:none;color:inherit;transition:all .4s cubic-bezier(.4,0,.2,1)}.restaurant-card:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 20px 40px #f6a31226;border-color:var(--hub-accent)}.card-image{position:relative;aspect-ratio:16/10;overflow:hidden}.card-image img{width:100%;height:100%;object-fit:cover;transition:transform .5s}.restaurant-card:hover .card-image img{transform:scale(1.1)}.card-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--hub-surface-2) 0%,var(--hub-surface) 100%);font-size:3.5rem}.card-offer{position:absolute;top:1rem;left:1rem;display:flex;align-items:center;gap:.35rem;padding:.4rem .85rem;background:var(--hub-green);border-radius:20px;font-size:.8rem;font-weight:700;color:#fff;animation:pulse 2s ease-in-out infinite}.card-offer svg{width:14px;height:14px}@keyframes pulse{0%,to{box-shadow:0 0 #22c55e66}50%{box-shadow:0 0 0 8px #22c55e00}}.card-rating{position:absolute;bottom:1rem;left:1rem;display:flex;align-items:center;gap:.35rem;padding:.5rem .85rem;background:#000000bf;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:10px;font-size:.95rem;font-weight:700}.card-rating svg{width:16px;height:16px;color:var(--hub-accent)}.card-body{padding:1.25rem}.card-body h3{font-size:1.15rem;font-weight:700;margin:0 0 .5rem;transition:color .2s}.restaurant-card:hover .card-body h3{color:var(--hub-accent)}.card-description{font-size:.9rem;color:var(--hub-text-muted);margin:0 0 1rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.card-stats{display:flex;gap:1rem;flex-wrap:wrap}.card-stat{display:flex;align-items:center;gap:.35rem;font-size:.85rem;color:var(--hub-text-muted);padding:.35rem .65rem;background:var(--hub-surface-2);border-radius:8px}.card-stat svg{width:14px;height:14px}.card-stat.delivery{color:var(--hub-green);background:#22c55e1a}.restaurant-skeleton{background:var(--hub-surface);border:1px solid var(--hub-border);border-radius:20px;overflow:hidden}.skeleton-image{aspect-ratio:16/10;background:linear-gradient(90deg,var(--hub-surface-2) 25%,var(--hub-border) 50%,var(--hub-surface-2) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}.skeleton-content{padding:1.25rem}.skeleton-line{height:16px;background:var(--hub-surface-2);border-radius:4px;margin-bottom:.75rem}.skeleton-line.short{width:60%}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.empty-state{grid-column:1 / -1;text-align:center;padding:4rem 2rem;color:var(--hub-text-muted)}.opiniones-section{max-width:1400px;margin:0 auto;padding:2rem}.opiniones-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem}.opinion-card{background:var(--hub-surface);border:1px solid var(--hub-border);border-radius:20px;padding:1.5rem;transition:all .3s}.opinion-card:hover{transform:translateY(-5px);border-color:var(--hub-accent)}.opinion-rating{display:flex;gap:.25rem;margin-bottom:1rem}.opinion-rating svg{width:18px;height:18px;color:var(--hub-accent)}.opinion-texto{font-size:1rem;line-height:1.7;color:var(--hub-text-muted);margin:0 0 1.5rem;font-style:italic}.opinion-autor{display:flex;align-items:center;gap:1rem}.autor-avatar{width:48px;height:48px;background:var(--hub-gradient);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem;color:#000}.autor-info{flex:1}.autor-nombre{display:block;font-weight:600}.autor-rol{font-size:.85rem;color:var(--hub-text-muted)}.cta-section{max-width:1200px;margin:4rem auto;padding:0 2rem}.cta-content{background:var(--hub-surface);border:1px solid var(--hub-border);border-radius:24px;padding:3rem;display:flex;justify-content:space-between;align-items:center;gap:2rem;position:relative;overflow:hidden}.cta-content:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--hub-gradient)}.cta-text h2{font-size:1.75rem;margin:0 0 .5rem}.cta-text p{color:var(--hub-text-muted);margin:0}.cta-buttons{display:flex;gap:1rem;flex-shrink:0}.cta-buttons svg{width:18px;height:18px}.hub-footer{background:var(--hub-surface);border-top:1px solid var(--hub-border);padding:4rem 2rem 2rem;margin-top:4rem}.footer-content{max-width:1400px;margin:0 auto;display:flex;justify-content:space-between;gap:4rem;flex-wrap:wrap}.footer-brand{max-width:350px;display:flex;flex-direction:column;align-items:flex-start;gap:.75rem}.footer-brand .footer-logo-img{height:56px;width:auto;object-fit:contain;filter:drop-shadow(0 4px 12px rgba(255,122,0,.2))}.footer-brand .logo-text{font-size:1.75rem;font-weight:700;letter-spacing:-.5px}.footer-brand p{color:var(--hub-text-muted);font-size:1rem;line-height:1.6;margin-top:.5rem}.footer-links{display:flex;gap:4rem}.footer-col h4{font-size:1rem;margin:0 0 1rem;color:var(--hub-accent)}.footer-col a{display:block;color:var(--hub-text-muted);text-decoration:none;padding:.4rem 0;transition:color .2s}.footer-col a:hover{color:var(--hub-text)}.footer-bottom{max-width:1400px;margin:3rem auto 0;padding-top:2rem;border-top:1px solid var(--hub-border);text-align:center;color:var(--hub-text-muted);font-size:.9rem}@media(max-width:1024px){.hero-content{grid-template-columns:1fr;text-align:center}.hero-text h1{font-size:2.75rem}.hero-description{margin:0 auto 2rem}.hero-stats{justify-content:center}.hero-visual{display:none}.destacados-grid{grid-template-columns:repeat(3,1fr)}.destacado-featured{grid-column:span 2;grid-row:span 1}.cta-content{flex-direction:column;text-align:center}}@media(max-width:768px){.hub-nav-inner{padding:1rem}.hub-nav-links{display:none}.hub-hero{padding:6rem 1rem 2rem}.hero-text h1{font-size:2rem}.promo-content{flex-direction:column;gap:1.5rem;text-align:center}.section-header{flex-direction:column;align-items:flex-start}.search-box{width:100%}.destacados-grid{grid-template-columns:repeat(2,1fr)}.destacado-featured{grid-column:span 2}.restaurants-grid{grid-template-columns:1fr}.cta-buttons{flex-direction:column;width:100%}.cta-buttons .btn-primary,.cta-buttons .btn-ghost{width:100%;justify-content:center}.footer-content,.footer-links{flex-direction:column;gap:2rem}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.hub-hero{animation:fadeInUp .8s ease}.destacado-card{animation:fadeInUp .6s ease both}.destacado-card:nth-child(2){animation-delay:.1s}.destacado-card:nth-child(3){animation-delay:.2s}.restaurant-card{animation:fadeInUp .5s ease both}.restaurant-card:nth-child(1){animation-delay:.05s}.restaurant-card:nth-child(2){animation-delay:.1s}.restaurant-card:nth-child(3){animation-delay:.15s}.restaurant-card:nth-child(4){animation-delay:.2s}.cart-overlay{position:fixed;inset:0;background:#000000b3;z-index:100;display:flex;justify-content:flex-end;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.cart-panel{width:100%;max-width:420px;background:#141414;height:100%;display:flex;flex-direction:column;animation:cartSlideIn .3s cubic-bezier(.4,0,.2,1);border-left:1px solid #2a2a2a}@keyframes cartSlideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.cart-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid #2a2a2a;background:#1a1a1a}.cart-header h2{margin:0;color:#fff;font-size:1.25rem;font-weight:600}.cart-panel .close-btn{width:36px;height:36px;background:#2a2a2a;border:1px solid #333;border-radius:50%;font-size:1.2rem;cursor:pointer;color:#888;display:flex;align-items:center;justify-content:center;transition:all .2s}.cart-panel .close-btn:hover{background:#ef4444;border-color:#ef4444;color:#fff}.cart-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#666;gap:12px}.cart-empty p{font-size:1.1rem}.cart-items{flex:1;overflow-y:auto;padding:1rem 1.5rem}.cart-item{display:flex;justify-content:space-between;align-items:center;padding:1rem 0;border-bottom:1px solid #2a2a2a;gap:12px}.item-info{flex:1;min-width:0}.item-info h4{margin:0 0 .25rem;font-size:.95rem;color:#fff;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.item-info .variant{display:block;font-size:.8rem;color:#22c55e;margin-bottom:4px}.item-price{font-weight:600;color:#888;font-size:.9rem}.item-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.item-actions button{width:32px;height:32px;border:1px solid #333;background:#1a1a1a;border-radius:8px;cursor:pointer;font-size:1rem;color:#fff;display:flex;align-items:center;justify-content:center;transition:all .2s}.item-actions button:hover{background:#22c55e;border-color:#22c55e}.item-actions span{min-width:28px;text-align:center;color:#fff;font-weight:600}.item-actions .remove-btn{border:none!important;background:transparent!important;color:#ef4444!important;font-size:1.1rem}.item-actions .remove-btn:hover{background:#ef444426!important;transform:scale(1.1)}.order-type{display:flex;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid #2a2a2a;background:#1a1a1a}.order-type label{flex:1;padding:.875rem;border:2px solid #333;border-radius:12px;text-align:center;cursor:pointer;transition:all .2s;color:#888;background:#0d0d0d;font-weight:500}.order-type label:hover{border-color:#444;color:#fff}.order-type label.active{border-color:#22c55e;background:#22c55e1a;color:#22c55e}.order-type input{display:none}.cart-summary{padding:1rem 1.5rem;background:#0d0d0d;border-top:1px solid #2a2a2a}.summary-row{display:flex;justify-content:space-between;margin-bottom:.5rem;color:#888;font-size:.95rem}.summary-row.total{font-size:1.25rem;font-weight:700;padding-top:.75rem;border-top:1px solid #333;margin-top:.75rem;color:#fff}.cart-actions{display:flex;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid #2a2a2a;background:#141414}.clear-btn{padding:.875rem 1.25rem;background:#1a1a1a;border:1px solid #333;border-radius:10px;cursor:pointer;color:#888;font-weight:500;transition:all .2s}.clear-btn:hover{background:#ef4444;border-color:#ef4444;color:#fff}.checkout-btn{flex:1;padding:.875rem 1.25rem;background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;border:none;border-radius:10px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 15px #22c55e4d}.checkout-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #22c55e66}.item-image{width:56px;height:56px;border-radius:10px;overflow:hidden;flex-shrink:0}.item-image img{width:100%;height:100%;object-fit:cover}.cart-empty-icon{font-size:3rem;opacity:.5}.cart-empty-hint{font-size:.85rem;color:#555}.menu-dark{display:flex;min-height:100vh;background:#0d0d0d;color:#fff;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif}.menu-dark-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:#0d0d0d;color:#888;gap:16px}.menu-dark-spinner{width:40px;height:40px;border:3px solid #333;border-top-color:#22c55e;border-radius:50%;animation:spin 1s linear infinite}.menu-dark-error{display:flex;align-items:center;justify-content:center;min-height:100vh;background:#0d0d0d;color:#ef4444;font-size:18px}.menu-dark-sidebar{width:100px;background:#141414;border-right:1px solid #222;padding:20px 0;display:flex;flex-direction:column;gap:8px;overflow-y:auto;flex-shrink:0}.menu-dark-category{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 8px;cursor:pointer;transition:all .2s;border-left:3px solid transparent}.menu-dark-category:hover{background:#22c55e1a}.menu-dark-category.active{background:#22c55e26;border-left-color:#22c55e}.menu-dark-category-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#1a1a1a;border-radius:12px;transition:all .2s}.menu-dark-category.active .menu-dark-category-icon{background:#22c55e}.menu-dark-category-icon svg{width:22px;height:22px;color:#888}.menu-dark-category.active .menu-dark-category-icon svg{color:#fff}.menu-dark-category span{font-size:11px;color:#888;text-align:center;line-height:1.2}.menu-dark-category.active span{color:#22c55e;font-weight:500}.menu-dark-main{flex:1;display:flex;flex-direction:column;overflow:hidden}.menu-dark-header{display:flex;align-items:center;gap:24px;padding:16px 24px;background:#0d0d0d;border-bottom:1px solid #1a1a1a;flex-shrink:0}.menu-dark-brand h1{font-size:20px;font-weight:400;margin:0;display:flex;gap:8px}.brand-name{font-weight:700;color:#fff}.brand-accent{font-weight:300;color:#888}.menu-dark-search{flex:1;max-width:400px;position:relative}.menu-dark-search svg{position:absolute;left:16px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:#666}.menu-dark-search input{width:100%;padding:12px 16px 12px 48px;background:#1a1a1a;border:1px solid #333;border-radius:25px;color:#fff;font-size:14px;outline:none;transition:all .2s}.menu-dark-search input::placeholder{color:#666}.menu-dark-search input:focus{border-color:#22c55e;box-shadow:0 0 0 3px #22c55e1a}.menu-dark-actions{display:flex;align-items:center;gap:12px}.menu-dark-rating{display:flex;align-items:center;gap:6px;padding:8px 16px;background:#1a1a1a;border:1px solid #333;border-radius:20px;color:#fff;font-size:14px;cursor:pointer;transition:all .2s}.menu-dark-rating:hover{background:#222;border-color:#fbbf24}.rating-star{font-size:16px}.rating-value{font-weight:600}.menu-dark-cart-btn{padding:12px 24px;background:#ef4444;border:none;border-radius:25px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.menu-dark-cart-btn:hover{background:#dc2626;transform:scale(1.02)}.menu-dark-account{cursor:pointer}.account-avatar{width:40px;height:40px;background:linear-gradient(135deg,#22c55e,#16a34a);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#fff;transition:all .2s}.account-avatar:hover{transform:scale(1.1);box-shadow:0 0 20px #22c55e66}.menu-dark-login{width:40px;height:40px;background:#1a1a1a;border:1px solid #333;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.menu-dark-login svg{width:20px;height:20px;color:#888}.menu-dark-login:hover{background:#22c55e;border-color:#22c55e}.menu-dark-login:hover svg{color:#fff}.menu-dark-back{width:40px;height:40px;background:#1a1a1a;border:1px solid #333;border-radius:50%;display:flex;align-items:center;justify-content:center;text-decoration:none;transition:all .2s}.menu-dark-back svg{width:20px;height:20px;color:#888}.menu-dark-back:hover{background:#22c55e;border-color:#22c55e}.menu-dark-back:hover svg{color:#fff}.menu-dark-grid{flex:1;overflow-y:auto;padding:24px;display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;align-content:start}.menu-dark-card{position:relative;border-radius:16px;overflow:hidden;background:#1a1a1a;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);aspect-ratio:16/10}.menu-dark-card:hover{transform:translateY(-4px);box-shadow:0 20px 40px #0006}.menu-dark-card-image{position:absolute;inset:0}.menu-dark-card-image img{width:100%;height:100%;object-fit:cover}.menu-dark-card-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:48px;background:linear-gradient(135deg,#1a1a1a,#0d0d0d)}.menu-dark-card:before{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,#0000001a,#0000004d,#000c);z-index:1;pointer-events:none}.menu-dark-card-info{position:absolute;bottom:0;left:0;right:0;padding:16px;z-index:2}.menu-dark-card-info h3{font-size:16px;font-weight:600;color:#fff;margin:0 0 4px;text-shadow:0 2px 4px rgba(0,0,0,.5)}.menu-dark-card-price{font-size:15px;font-weight:500;color:#ffffffe6;text-shadow:0 2px 4px rgba(0,0,0,.5)}.menu-dark-card-rating{position:absolute;top:12px;right:12px;background:#0009;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:4px 10px;border-radius:12px;font-size:12px;font-weight:600;color:#fff;z-index:2}.menu-dark-card:after{content:"+";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.8);width:56px;height:56px;background:#22c55e;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:300;z-index:3;opacity:0;transition:all .3s cubic-bezier(.34,1.56,.64,1);box-shadow:0 8px 24px #22c55e66}.menu-dark-card:hover:after{transform:translate(-50%,-50%) scale(1);opacity:1}.menu-dark-modal-overlay{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:150;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:20px}.menu-dark-modal{background:#1a1a1a;border-radius:20px;width:100%;max-width:480px;max-height:90vh;overflow:hidden;position:relative;border:1px solid #333;box-shadow:0 25px 60px #0009;animation:modalIn .3s cubic-bezier(.34,1.56,.64,1)}@keyframes modalIn{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.menu-dark-modal-close{position:absolute;top:16px;right:16px;width:36px;height:36px;background:#0009;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:50%;font-size:1.5rem;cursor:pointer;color:#fff;display:flex;align-items:center;justify-content:center;z-index:10;transition:all .2s}.menu-dark-modal-close:hover{background:#ef4444;border-color:#ef4444;transform:scale(1.1)}.menu-dark-modal-image{width:100%;height:240px;object-fit:cover}.menu-dark-modal-content{padding:24px}.menu-dark-modal-content h2{margin:0 0 8px;font-size:1.5rem;font-weight:700;color:#fff}.menu-dark-modal-content p{color:#888;font-size:.95rem;line-height:1.5;margin:0 0 20px}.menu-dark-variants h4{color:#aaa;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px;margin:0 0 12px;font-weight:500}.menu-dark-variant-btn{width:100%;display:flex;justify-content:space-between;align-items:center;padding:14px 16px;background:#0d0d0d;border:2px solid #333;border-radius:12px;color:#fff;font-size:.95rem;cursor:pointer;margin-bottom:10px;transition:all .2s}.menu-dark-variant-btn:hover{border-color:#22c55e;background:#22c55e1a}.menu-dark-variant-btn span:last-child{font-weight:600;color:#22c55e}.menu-dark-reviews-modal{max-width:520px}.menu-dark-reviews-header{padding:24px 24px 0}.menu-dark-reviews-header h2{margin:0 0 20px;font-size:1.5rem;font-weight:700;color:#fff}.menu-dark-reviews-summary{padding-bottom:20px;border-bottom:1px solid #333}.reviews-big-rating{display:flex;flex-direction:column;align-items:center;gap:8px}.reviews-big-rating .big-number{font-size:3rem;font-weight:700;color:#fff;line-height:1}.reviews-stars{display:flex;gap:4px;font-size:1.5rem}.reviews-stars span{color:#333}.reviews-stars span.filled{color:#fbbf24}.reviews-count{color:#888;font-size:.9rem}.menu-dark-reviews-list{padding:20px 24px;max-height:400px;overflow-y:auto}.no-reviews{text-align:center;color:#666;padding:40px 0}.menu-dark-review{padding:16px 0;border-bottom:1px solid #2a2a2a}.menu-dark-review:last-child{border-bottom:none}.review-header{display:flex;align-items:center;gap:12px;margin-bottom:10px}.review-avatar{width:40px;height:40px;background:linear-gradient(135deg,#22c55e,#16a34a);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#fff;flex-shrink:0}.review-info{flex:1}.review-name{display:block;font-weight:600;color:#fff;font-size:.95rem;margin-bottom:2px}.review-stars{display:flex;gap:2px;font-size:.9rem}.review-stars span{color:#333}.review-stars span.filled{color:#fbbf24}.review-date{color:#666;font-size:.8rem}.review-comment{color:#aaa;font-size:.9rem;line-height:1.5;margin:0;font-style:italic}@media(max-width:768px){.menu-dark-sidebar{width:70px}.menu-dark-category span{font-size:9px}.menu-dark-header{flex-wrap:wrap;gap:12px;padding:12px 16px}.menu-dark-search{order:3;max-width:100%;flex-basis:100%}.menu-dark-grid{padding:16px;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}.menu-dark-modal{max-width:100%;margin:10px;max-height:95vh}.menu-dark-modal-image{height:180px}}@media(max-width:480px){.menu-dark-sidebar{display:none}.menu-dark-brand h1{font-size:16px}.menu-dark-cart-btn{padding:10px 16px;font-size:12px}}.cart-fab{position:fixed;bottom:24px;right:24px;width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#22c55e,#16a34a);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px #22c55e66,0 4px 8px #0003;z-index:90;transition:all .3s cubic-bezier(.34,1.56,.64,1);overflow:visible}.cart-fab:hover{transform:scale(1.1);box-shadow:0 12px 32px #22c55e80,0 6px 12px #00000040}.cart-fab:active{transform:scale(.95)}.cart-fab-icon{display:flex;align-items:center;justify-content:center;transition:transform .3s ease}.cart-fab-icon svg{width:28px;height:28px;color:#fff}.cart-fab:hover .cart-fab-icon{transform:translateY(-2px)}.cart-fab-badge{position:absolute;top:-4px;right:-4px;min-width:24px;height:24px;background:#ef4444;color:#fff;border-radius:12px;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 6px;box-shadow:0 2px 8px #ef444466;animation:badgePop .3s cubic-bezier(.34,1.56,.64,1);border:2px solid #0d0d0d}@keyframes badgePop{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.cart-fab-pulse{position:absolute;inset:0;border-radius:50%;background:inherit;opacity:0;z-index:-1}.cart-fab.has-items .cart-fab-pulse{animation:fabPulse 2s ease-out infinite}@keyframes fabPulse{0%{transform:scale(1);opacity:.5}to{transform:scale(1.8);opacity:0}}.cart-fab.has-items{animation:fabWiggle .5s ease}@keyframes fabWiggle{0%,to{transform:rotate(0)}25%{transform:rotate(-10deg)}75%{transform:rotate(10deg)}}.cart-fab:before{content:"Ver carrito";position:absolute;right:72px;background:#1a1a1a;color:#fff;padding:8px 14px;border-radius:8px;font-size:13px;font-weight:500;white-space:nowrap;opacity:0;transform:translate(10px);transition:all .3s ease;pointer-events:none;box-shadow:0 4px 12px #0000004d}.cart-fab:after{content:"";position:absolute;right:68px;border:6px solid transparent;border-left-color:#1a1a1a;opacity:0;transform:translate(10px);transition:all .3s ease;pointer-events:none}.cart-fab:hover:before,.cart-fab:hover:after{opacity:1;transform:translate(0)}@media(max-width:768px){.cart-fab{bottom:20px;right:20px;width:56px;height:56px}.cart-fab-icon svg{width:24px;height:24px}.cart-fab:before,.cart-fab:after{display:none}}.checkout-page{min-height:100vh;background:#0d0d0d;padding:2rem 1rem 1rem;display:flex;align-items:flex-start;justify-content:center}.checkout-container{max-width:480px;width:100%;background:#1a1a1a;border-radius:20px;padding:1.5rem;border:1px solid #2a2a2a;box-shadow:0 25px 50px #0006}.checkout-container.empty-cart{text-align:center;padding:3rem 1.5rem}.empty-cart-icon{margin-bottom:1rem}.empty-cart-icon svg{width:64px;height:64px;color:#444}.empty-cart h2{margin:0 0 .5rem;color:#fff}.empty-cart p{color:#888;margin-bottom:1.5rem}.checkout-header{display:flex;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #2a2a2a;position:relative}.checkout-header h1{flex:1;margin:0;font-size:1.25rem;font-weight:600;color:#fff;text-align:center}.back-link{position:absolute;left:0;display:inline-flex;align-items:center;gap:6px;background:transparent;border:none;color:#888;cursor:pointer;font-size:.9rem;font-weight:500;padding:.5rem;border-radius:8px;transition:all .2s ease}.back-link svg{width:20px;height:20px;color:#888;transition:all .2s}.back-link:hover{color:#22c55e}.back-link:hover svg{color:#22c55e;transform:translate(-3px)}.checkout-steps{display:flex;align-items:center;justify-content:center;margin-bottom:2.5rem;padding:1.5rem 1rem;background:linear-gradient(180deg,rgba(34,197,94,.05) 0%,transparent 100%);border-radius:16px;position:relative}.step{display:flex;flex-direction:column;align-items:center;gap:8px;position:relative;z-index:2}.step-num{width:44px;height:44px;border-radius:50%;background:#2a2a2a;color:#555;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;transition:all .4s cubic-bezier(.34,1.56,.64,1);border:3px solid #333;position:relative}.step.active .step-num{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;border-color:#22c55e;box-shadow:0 0 20px #22c55e80,0 0 40px #22c55e33;transform:scale(1.1);animation:stepPulse 2s ease-in-out infinite}@keyframes stepPulse{0%,to{box-shadow:0 0 20px #22c55e80,0 0 40px #22c55e33}50%{box-shadow:0 0 30px #22c55eb3,0 0 60px #22c55e4d}}.step.completed .step-num{background:linear-gradient(135deg,#16a34a,#15803d);color:#fff;border-color:#16a34a;box-shadow:0 4px 12px #16a34a4d}.step.completed .step-num span{display:none}.step.completed .step-num:after{content:"✓";font-size:1.3rem;font-weight:700;animation:checkPop .3s ease}@keyframes checkPop{0%{transform:scale(0)}50%{transform:scale(1.3)}to{transform:scale(1)}}.step-label{font-size:.8rem;color:#555;font-weight:500;text-transform:uppercase;letter-spacing:.5px;transition:all .3s}.step.active .step-label{color:#22c55e;font-weight:600}.step.completed .step-label{color:#16a34a}.step-line{flex:1;height:4px;background:#2a2a2a;margin:0 8px 28px;border-radius:2px;position:relative;overflow:hidden;max-width:80px}.step-line:after{content:"";position:absolute;top:0;left:0;height:100%;width:0;background:linear-gradient(90deg,#22c55e,#16a34a);border-radius:2px;transition:width .5s ease}.step.completed+.step-line:after,.step-line.filled:after{width:100%;animation:lineFill .5s ease forwards}@keyframes lineFill{0%{width:0}to{width:100%}}.checkout-step h2{margin:0 0 1.5rem;font-size:1.2rem;color:#fff}.login-prompt{display:flex;align-items:center;gap:1rem;background:#22c55e14;border:1px solid rgba(34,197,94,.3);border-radius:12px;padding:1rem;margin-bottom:1.5rem}.login-prompt-icon{width:44px;height:44px;background:#22c55e26;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.login-prompt-icon svg{width:22px;height:22px;color:#22c55e}.login-prompt p{margin:0;font-size:.9rem;color:#fff}.login-prompt button{background:none;border:none;color:#22c55e;font-weight:600;cursor:pointer;padding:0;text-decoration:underline}.user-badge{display:flex;align-items:center;gap:.5rem;background:#22c55e1a;color:#22c55e;padding:.75rem 1rem;border-radius:8px;margin-bottom:1.5rem;font-size:.9rem;border:1px solid rgba(34,197,94,.2)}.user-badge-icon svg{width:18px;height:18px}.checkout-step .form-group{margin-bottom:1.25rem}.checkout-step .form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#888;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px}.checkout-step .form-group input,.checkout-step .form-group textarea,.checkout-step input[type=text],.checkout-step input[type=tel],.checkout-step input[type=email],.checkout-step textarea{width:100%;padding:.875rem 1rem;border:2px solid #333!important;border-radius:10px;font-size:1rem;background:#0d0d0d!important;color:#fff!important;transition:all .2s;-webkit-appearance:none;appearance:none}.checkout-step .form-group input::placeholder,.checkout-step .form-group textarea::placeholder,.checkout-step input::placeholder,.checkout-step textarea::placeholder{color:#555!important}.checkout-step .form-group input:focus,.checkout-step .form-group textarea:focus,.checkout-step input:focus,.checkout-step textarea:focus{outline:none;border-color:#22c55e!important;box-shadow:0 0 0 3px #22c55e26}.checkout-step .form-group textarea{min-height:80px;resize:vertical}.order-summary-mini{background:#0d0d0d;border-radius:10px;padding:1rem;margin:1.5rem 0;border:1px solid #2a2a2a}.order-summary-mini .summary-row{display:flex;justify-content:space-between;padding:.35rem 0;font-size:.95rem;color:#888}.order-summary-mini .summary-row.total{border-top:1px solid #333;margin-top:.5rem;padding-top:.75rem;font-weight:600;font-size:1.1rem;color:#fff}.payment-info{margin-bottom:1.5rem}.total-box{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;padding:1.25rem;border-radius:12px;display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;box-shadow:0 4px 15px #22c55e4d}.total-box span{font-size:.95rem;opacity:.9}.total-box strong{font-size:1.5rem}.bank-details{background:#0d0d0d;padding:1rem;border-radius:10px;border:1px solid #2a2a2a}.bank-details h4{margin:0 0 .75rem;font-size:.9rem;color:#888}.bank-details p{margin:.4rem 0;font-size:.95rem;display:flex;justify-content:space-between;color:#fff}.bank-details p span{color:#888}.file-upload{position:relative}.file-upload input[type=file]{position:absolute;opacity:0;width:100%;height:100%;cursor:pointer}.file-label{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1.5rem;border:2px dashed #333;border-radius:10px;text-align:center;cursor:pointer;color:#888;transition:all .2s;background:#0d0d0d}.file-icon{display:flex}.file-icon svg{width:32px;height:32px}.file-upload:hover .file-label,.file-upload.has-file .file-label{border-color:#22c55e;background:#22c55e1a;color:#22c55e}.next-btn,.submit-btn,.home-btn{width:100%;padding:1rem;background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;text-decoration:none;display:flex;align-items:center;justify-content:center;gap:.5rem;box-shadow:0 4px 15px #22c55e4d}.btn-icon{display:flex}.btn-icon svg{width:20px;height:20px}.btn-icon.spinning svg{animation:spin 1s linear infinite}.next-btn:hover,.submit-btn:hover,.home-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #22c55e66}.next-btn:disabled,.submit-btn:disabled{background:#333;color:#555;cursor:not-allowed;box-shadow:none;transform:none}.checkout-step.success{text-align:center;padding:2rem 0}.success-icon{width:80px;height:80px;margin:0 auto 1.5rem;background:linear-gradient(135deg,#22c55e,#16a34a);border-radius:50%;display:flex;align-items:center;justify-content:center;animation:successBounce .6s ease;box-shadow:0 8px 24px #22c55e66}.success-icon svg{width:40px;height:40px;color:#fff}@keyframes successBounce{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.success h2{margin-bottom:.5rem;color:#fff}.success p{color:#888;margin:.25rem 0}.success .small{font-size:.85rem;margin-bottom:1.5rem}.geo-status{display:flex;align-items:center;gap:.5rem;margin-top:.5rem;padding:.5rem .75rem;border-radius:8px;font-size:.85rem;background:#0d0d0d;border:1px solid #2a2a2a}.geo-icon{display:flex;align-items:center}.geo-icon svg{width:16px;height:16px}.geo-icon.spinning svg{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.geo-status.loading{color:#888}.geo-status.success{background:#22c55e1a;border-color:#22c55e4d;color:#22c55e}.geo-status.manual{background:#3b82f61a;border-color:#3b82f64d;color:#3b82f6}.geo-status.error{background:#f59e0b1a;border-color:#f59e0b4d;color:#f59e0b}.adjust-location-btn{display:flex;align-items:center;gap:.25rem;background:none;border:none;color:inherit;font-weight:600;cursor:pointer;padding:.25rem .5rem;border-radius:4px;font-size:.8rem;transition:background .2s;margin-left:auto}.adjust-icon svg{width:14px;height:14px}.adjust-location-btn:hover{background:#ffffff1a}.map-modal-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.map-modal{background:#1a1a1a;border-radius:16px;width:100%;max-width:500px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;border:1px solid #333}.map-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid #2a2a2a}.map-modal-header h3{margin:0;font-size:1.1rem;color:#fff;display:flex;align-items:center;gap:.5rem}.modal-title-icon svg{width:20px;height:20px;color:#22c55e}.map-modal-close{width:32px;height:32px;background:#2a2a2a;border:1px solid #444;border-radius:50%;font-size:1.2rem;cursor:pointer;color:#888;display:flex;align-items:center;justify-content:center;transition:all .2s}.map-modal-close:hover{background:#ef4444;border-color:#ef4444;color:#fff}.map-modal-hint{margin:0;padding:.75rem 1.25rem;font-size:.85rem;color:#888;background:#0d0d0d}.checkout-map{height:300px;width:100%}.map-modal-actions{padding:1rem 1.25rem;border-top:1px solid #2a2a2a}.map-confirm-btn{width:100%;padding:.875rem;background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;box-shadow:0 4px 15px #22c55e4d;display:flex;align-items:center;justify-content:center;gap:.5rem}.map-confirm-btn svg{width:20px;height:20px}.map-confirm-btn:hover{transform:translateY(-2px)}@media(max-width:480px){.checkout-page{padding:1rem .5rem .5rem}.checkout-container{border-radius:16px;padding:1.25rem}.checkout-steps{padding:1rem .5rem}.step-num{width:38px;height:38px;font-size:.9rem}.step-label{font-size:.7rem}}.my-orders-page{--ff-bg: #0a0a0a;--ff-surface: #141414;--ff-surface-2: #1e1e1e;--ff-border: #2a2a2a;--ff-text: #ffffff;--ff-text-muted: #888888;--ff-accent: #FF7A00;--ff-green: #2ECC71;--bg-main: #0a0a0a;--bg-card: #141414;--bg-elevated: #1e1e1e;--bg-input: #1e1e1e;--bg-hover: #2a2a2a;--text-primary: #ffffff;--text-secondary: #888888;--border-color: #2a2a2a;--primary: #FF7A00;min-height:100vh;background:#0a0a0a!important;color:#fff!important;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif}.my-orders-page *,.my-orders-page *:before,.my-orders-page *:after{box-sizing:border-box}.my-orders-header{background:#141414f2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding:1rem 1.5rem;display:flex;align-items:center;gap:1rem;border-bottom:1px solid #2a2a2a;position:sticky;top:0;z-index:50}.my-orders-header .back-btn{color:#ff7a00;text-decoration:none;font-weight:500;transition:opacity .2s}.my-orders-header .back-btn:hover{opacity:.8}.my-orders-header h1{flex:1;margin:0;font-size:1.25rem;font-weight:600;color:#fff}.my-orders-header .user-info{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:#888;background:#1e1e1e;padding:.5rem 1rem;border-radius:20px;border:1px solid #2a2a2a}.my-orders-content{max-width:1200px;margin:0 auto;padding:2rem}.loading-state,.empty-state{text-align:center;padding:4rem 2rem}.spinner{width:48px;height:48px;border:3px solid #2a2a2a;border-top-color:#ff7a00;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 1.5rem}.empty-icon{font-size:4rem;display:block;margin-bottom:1.5rem}.empty-state h2{margin:0 0 .5rem;color:#fff;font-size:1.5rem}.empty-state p{color:#888;margin-bottom:2rem;font-size:1rem}.browse-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.875rem 2rem;background:linear-gradient(135deg,#ff7a00,#ff5722);color:#000;text-decoration:none;border-radius:10px;font-weight:600;transition:all .3s;box-shadow:0 4px 15px #ff7a004d}.browse-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px #ff7a0066}.orders-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1.25rem}.order-card{background:#141414!important;border-radius:20px;padding:1.5rem;border:1px solid #2a2a2a!important;cursor:pointer;transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.order-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#ff7a00,#ff5722);opacity:0;transition:opacity .3s}.order-card:hover{transform:translateY(-6px);box-shadow:0 20px 40px #ff7a0026;border-color:#ff7a00!important}.order-card:hover:before{opacity:1}.order-card.active{border-color:#2ecc71!important;background:linear-gradient(135deg,#2ecc7114,#141414)!important}.order-card.active:before{background:linear-gradient(90deg,#2ecc71,#27ae60);opacity:1}.order-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.25rem}.order-info{display:flex;flex-direction:column;gap:.35rem}.order-id{font-weight:700;color:#ff7a00;font-size:1.1rem;letter-spacing:-.5px}.order-date{font-size:.8rem;color:#666}.status-badge{padding:.5rem 1rem;border-radius:25px;font-size:.8rem;font-weight:600;color:#fff;display:flex;align-items:center;gap:.4rem;box-shadow:0 4px 12px #0000004d}.status-badge.large{padding:.6rem 1.5rem;font-size:1rem}.progress-bar{height:5px;background:#1e1e1e;border-radius:3px;margin-bottom:1.25rem;overflow:hidden}.progress-fill{height:100%;border-radius:3px;transition:width .6s cubic-bezier(.4,0,.2,1);background:linear-gradient(90deg,#ff7a00,#2ecc71);box-shadow:0 0 10px #ff7a0080}.order-card-body{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem;padding:1rem;background:#1a1a1a;border-radius:12px}.restaurant-info{display:flex;align-items:center;gap:.875rem}.restaurant-logo{width:48px;height:48px;border-radius:12px;object-fit:cover;border:2px solid #2a2a2a;box-shadow:0 4px 12px #0000004d}.restaurant-name{font-weight:600;color:#fff;font-size:1rem}.order-summary{text-align:right}.items-count{display:block;font-size:.8rem;color:#666;margin-bottom:.25rem}.order-total{font-weight:700;font-size:1.25rem;color:#fff;background:linear-gradient(135deg,#fff,#ccc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.order-card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:1rem;border-top:1px solid #2a2a2a;font-size:.85rem}.order-type{color:#888;display:flex;align-items:center;gap:.4rem;background:#1e1e1e;padding:.5rem .875rem;border-radius:8px;font-size:.8rem}.view-details{color:#ff7a00;font-weight:600;transition:all .3s;display:flex;align-items:center;gap:.3rem;padding:.5rem 1rem;background:#ff7a001a;border-radius:8px}.order-card:hover .view-details{gap:.6rem;background:#ff7a0033}.modal-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.order-detail-modal{background:#141414!important;border:1px solid #2a2a2a!important;border-radius:20px;width:100%;max-width:480px;max-height:85vh;overflow-y:auto;position:relative;scrollbar-width:thin;scrollbar-color:#2a2a2a transparent;color:#fff!important}.order-detail-modal *{color:inherit}.order-detail-modal::-webkit-scrollbar{width:6px}.order-detail-modal::-webkit-scrollbar-track{background:transparent}.order-detail-modal::-webkit-scrollbar-thumb{background:#2a2a2a;border-radius:3px}.modal-close{position:absolute;top:1rem;right:1rem;background:#1e1e1e!important;border:1px solid #2a2a2a!important;width:36px;height:36px;border-radius:50%;font-size:1.25rem;cursor:pointer;color:#888!important;z-index:10;transition:all .2s;display:flex;align-items:center;justify-content:center}.modal-close:hover{background:#2a2a2a!important;color:#fff!important}.detail-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;background:linear-gradient(135deg,#1e1e1e,#141414)!important;border-radius:20px 20px 0 0;border-bottom:1px solid #2a2a2a}.detail-label{display:block;font-size:.75rem;color:#888;text-transform:uppercase;letter-spacing:.5px}.detail-id{font-size:1.75rem;font-weight:700;color:#ff7a00}.status-tracker{display:flex;justify-content:space-between;padding:1.5rem;background:#1e1e1e!important;position:relative}.tracker-step{display:flex;flex-direction:column;align-items:center;gap:.5rem;position:relative;z-index:1;flex:1}.step-icon{width:40px;height:40px;border-radius:50%;border:2px solid #2a2a2a;display:flex;align-items:center;justify-content:center;font-size:1rem;background:#141414!important;color:#888;transition:all .3s}.tracker-step.completed .step-icon,.tracker-step.current .step-icon{color:#fff;border-color:transparent}.tracker-step.current .step-icon{animation:pulse-tracker 1.5s infinite;box-shadow:0 0 20px #ff7a0066}@keyframes pulse-tracker{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.step-label{font-size:.7rem;color:#888;text-align:center}.tracker-step.current .step-label{font-weight:600;color:#fff}.step-line{position:absolute;top:20px;left:60%;width:80%;height:2px;background:#2a2a2a;z-index:0}.step-line.completed{background:linear-gradient(90deg,#ff7a00,#2ecc71)}.detail-section{padding:1.25rem 1.5rem;border-bottom:1px solid #2a2a2a;background:#141414!important}.detail-section h3{margin:0 0 1rem;font-size:1rem;color:#fff!important;font-weight:600}.detail-section p{margin:.5rem 0;font-size:.9rem;color:#888!important}.detail-section p strong{color:#fff!important}.items-list{background:#1e1e1e!important;border-radius:12px;padding:.5rem;margin-bottom:1rem}.item-row{display:flex;align-items:center;padding:.75rem;border-bottom:1px solid #2a2a2a}.item-row:last-child{border-bottom:none}.item-qty{background:linear-gradient(135deg,#ff7a00,#ff5722);color:#000;padding:.2rem .5rem;border-radius:6px;font-size:.8rem;font-weight:700;margin-right:.75rem;min-width:28px;text-align:center}.item-name{flex:1;color:#fff!important;font-weight:500}.item-price{color:#888!important;font-weight:600}.totals{padding-top:.75rem}.total-row{display:flex;justify-content:space-between;padding:.4rem 0;font-size:.9rem;color:#888!important}.total-row.final{border-top:2px solid #2a2a2a;margin-top:.75rem;padding-top:1rem;font-weight:700;font-size:1.15rem;color:#fff!important}.total-row.final span:last-child{color:#ff7a00}.contact-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;margin:1.25rem 1.5rem;padding:1rem;background:linear-gradient(135deg,#25d366,#128c7e);color:#fff;text-align:center;text-decoration:none;border-radius:12px;font-weight:600;transition:all .3s;box-shadow:0 4px 15px #25d3664d}.contact-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px #25d36666}.link-orders-hint{background:#ff7a001a;border:1px solid rgba(255,122,0,.3);border-radius:12px;padding:1.25rem;margin-bottom:1.5rem;text-align:center}.link-orders-hint p{margin:0 0 .75rem;color:#fff;font-size:.9rem}.link-btn{background:linear-gradient(135deg,#ff7a00,#ff5722);color:#000;border:none;padding:.6rem 1.25rem;border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s}.link-btn:hover{transform:translateY(-2px);box-shadow:0 4px 15px #ff7a004d}.link-modal{background:#141414;border:1px solid #2a2a2a;border-radius:20px;padding:2rem;width:90%;max-width:400px;text-align:center;position:relative}.link-modal h2{margin:0 0 .75rem;color:#fff;font-size:1.25rem}.link-modal p{color:#888;margin-bottom:1.5rem;font-size:.9rem}.link-input{width:100%;padding:1rem;border:2px solid #2a2a2a;border-radius:12px;font-size:1rem;margin-bottom:1rem;background:#1e1e1e;color:#fff;transition:border-color .2s}.link-input:focus{outline:none;border-color:#ff7a00}.link-input::placeholder{color:#888}.link-submit{width:100%;padding:1rem;background:linear-gradient(135deg,#ff7a00,#ff5722);color:#000;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s}.link-submit:disabled{background:#2a2a2a;color:#888;cursor:not-allowed}.link-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #ff7a0066}.review-section{margin-top:1.5rem;padding:1.25rem;background:#1e1e1e;border-radius:16px;border:1px solid #2a2a2a}.review-section h3{margin:0 0 .75rem;font-size:1rem;color:#fff}.review-section.prompt{text-align:center;background:linear-gradient(135deg,#fbbf241a,#1e1e1e);border-color:#fbbf244d}.review-section.prompt p{color:#888;margin:0 0 1rem;font-size:.9rem}.review-btn{padding:.875rem 2rem;background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#000;border:none;border-radius:10px;font-weight:600;cursor:pointer;font-size:.95rem;transition:all .3s;box-shadow:0 4px 15px #fbbf244d}.review-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px #fbbf2466}.star-rating{display:flex;gap:.25rem}.star-rating.large{gap:.5rem}.star-rating .star{background:none;border:none;font-size:1.5rem;color:#2a2a2a;cursor:pointer;padding:0;transition:color .15s,transform .15s}.star-rating.large .star{font-size:2.25rem}.star-rating .star.filled{color:#fbbf24}.star-rating .star:hover{transform:scale(1.15);color:#fbbf24}.star-rating .star:disabled{cursor:default}.star-rating .star:disabled:hover{transform:none}.review-section.form{background:#141414}.rating-group{margin-bottom:1rem}.rating-group label{display:block;margin-bottom:.5rem;font-size:.9rem;color:#888}.rating-group.main{text-align:center;padding-bottom:1rem;border-bottom:1px solid #2a2a2a;margin-bottom:1rem}.rating-group.main label{font-weight:600;color:#fff}.rating-group.main .star-rating{justify-content:center}.rating-details{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.comment-group{margin-bottom:1rem}.comment-group label{display:block;margin-bottom:.5rem;font-size:.9rem;color:#888}.comment-group textarea{width:100%;padding:.875rem;border:2px solid #2a2a2a;border-radius:12px;font-size:.95rem;resize:vertical;background:#1e1e1e;color:#fff;min-height:100px;transition:border-color .2s}.comment-group textarea:focus{outline:none;border-color:#ff7a00}.comment-group textarea::placeholder{color:#888}.review-actions{display:flex;gap:.75rem}.review-actions .cancel-btn{flex:1;padding:.875rem;background:#1e1e1e;color:#fff;border:1px solid #2a2a2a;border-radius:10px;cursor:pointer;font-size:.95rem;transition:all .2s}.review-actions .cancel-btn:hover{background:#2a2a2a}.review-actions .submit-btn{flex:2;padding:.875rem;background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#000;border:none;border-radius:10px;font-weight:600;cursor:pointer;font-size:.95rem;transition:all .3s}.review-actions .submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #fbbf2466}.review-actions .submit-btn:disabled{opacity:.5;cursor:not-allowed}.review-section.existing{text-align:center;background:linear-gradient(135deg,#fbbf240d,#1e1e1e)}.review-section.existing .star-rating{justify-content:center;margin-bottom:.75rem}.review-comment{color:#888;font-style:italic;margin:0 0 .5rem}.review-date{font-size:.8rem;color:#666}.dishes-review .step-hint{font-size:.85rem;color:#888;margin:-.5rem 0 1rem}.dishes-rating-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.dish-rating-item{background:#1e1e1e;border-radius:12px;padding:1rem;border:1px solid #2a2a2a}.dish-rating-header{display:flex;justify-content:space-between;align-items:center;gap:.5rem}.dish-rating-header .dish-name{flex:1;font-weight:600;color:#fff;font-size:.9rem}.dish-rating-header .star-rating{flex-shrink:0}.dish-rating-header .star-rating .star{font-size:1.25rem}.dish-comment-input{width:100%;margin-top:.75rem;padding:.6rem;border:1px solid #2a2a2a;border-radius:8px;font-size:.85rem;background:#141414;color:#fff;transition:border-color .2s}.dish-comment-input:focus{outline:none;border-color:#ff7a00}.dish-comment-input::placeholder{color:#888}@media(max-width:768px){.my-orders-content{padding:1rem}.orders-list{grid-template-columns:1fr;gap:1rem}}@media(max-width:480px){.my-orders-header{padding:1rem}.my-orders-header .user-info{display:none}.order-card{padding:1.25rem;border-radius:16px}.order-card-body{padding:.75rem}.restaurant-logo{width:40px;height:40px}.status-tracker{padding:1rem}.step-icon{width:32px;height:32px;font-size:.85rem}.step-label{font-size:.6rem}.rating-details{grid-template-columns:1fr}}.join-team-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:1rem}.join-team-container{background:var(--bg-card);border-radius:20px;padding:2.5rem;width:100%;max-width:420px;box-shadow:0 20px 60px #0000004d}.join-team-header{text-align:center;margin-bottom:2rem}.join-icon{font-size:3rem;display:block;margin-bottom:1rem}.join-team-header h1{margin:0 0 .5rem;font-size:1.75rem;color:var(--text-primary)}.join-team-header p{margin:0;color:var(--text-secondary)}.invitation-info{display:flex;flex-direction:column;align-items:center;gap:.5rem;margin-top:1rem;padding:.75rem;background:var(--bg-hover);border-radius:10px}.role-badge{padding:.25rem .75rem;background:var(--primary);color:#fff;border-radius:20px;font-size:.85rem;font-weight:500}.restaurant-name{font-weight:600;color:var(--text-primary)}.join-team-form{display:flex;flex-direction:column;gap:1.25rem}.join-team-form .form-group{margin:0}.join-team-form label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-primary);font-size:.9rem}.join-team-form input{width:100%;padding:.875rem 1rem;border:2px solid var(--border-color);border-radius:10px;font-size:1rem;background:var(--bg-input);color:var(--text-primary);transition:border-color .2s}.join-team-form input:focus{outline:none;border-color:var(--primary)}.join-team-form select{width:100%;padding:.875rem 1rem;border:2px solid var(--border-color);border-radius:10px;font-size:1rem;background:var(--bg-input);color:var(--text-primary);cursor:pointer;transition:border-color .2s}.join-team-form select:focus{outline:none;border-color:var(--primary)}.join-btn{width:100%;padding:1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;margin-top:.5rem;transition:opacity .2s,transform .2s}.join-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.join-btn:disabled{opacity:.6;cursor:not-allowed}.join-footer{text-align:center;margin-top:1.5rem;color:var(--text-secondary);font-size:.9rem}.join-footer a{color:var(--primary);text-decoration:none;font-weight:500}.join-footer a:hover{text-decoration:underline}.admin-login{min-height:100vh;background:#0a0a0a;display:flex;align-items:center;justify-content:center;padding:1rem;position:relative;overflow:hidden}.admin-login:before{content:"";position:absolute;width:600px;height:600px;background:#ff7a00;border-radius:50%;filter:blur(150px);opacity:.15;top:-200px;right:-100px}.admin-login:after{content:"";position:absolute;width:400px;height:400px;background:#ff5722;border-radius:50%;filter:blur(120px);opacity:.1;bottom:-100px;left:-100px}.login-container{width:100%;max-width:420px;background:#141414!important;border-radius:24px;padding:2.5rem;box-shadow:0 25px 50px #00000080;border:1px solid #2a2a2a!important;position:relative;z-index:1;color:#fff!important}.admin-login .back-link{display:inline-flex;align-items:center;gap:.5rem;color:#ff7a00!important;text-decoration:none;margin-bottom:1.5rem;font-size:.9rem;font-weight:500;transition:opacity .2s;background:transparent!important}.admin-login .back-link:hover{opacity:.8}.login-header{text-align:center;margin-bottom:2rem}.login-logo{width:80px;height:auto;margin-bottom:1rem;filter:drop-shadow(0 4px 12px rgba(255,122,0,.3))}.login-header h1{margin:0;font-size:1.75rem;color:#fff!important;font-weight:700}.login-header h1 .accent{color:#ff7a00!important}.login-header p{color:#888!important;margin:.75rem 0 0;font-size:.95rem}.login-form .form-group{margin-bottom:1.5rem}.login-form label{display:block;margin-bottom:.5rem;font-weight:500;color:#888!important;font-size:.9rem;background:transparent!important}.login-form input{width:100%;padding:1rem 1.25rem;border:2px solid #2a2a2a!important;border-radius:12px;font-size:1rem;background:#1e1e1e!important;color:#fff!important;transition:border-color .2s,box-shadow .2s}.login-form input::placeholder{color:#666!important}.login-form input:focus{outline:none;border-color:#ff7a00!important;box-shadow:0 0 0 4px #ff7a001a}.error-message{background:#ef44441a;color:#ef4444;padding:1rem;border-radius:12px;margin-bottom:1.5rem;font-size:.9rem;border:1px solid rgba(239,68,68,.3)}.login-form .submit-btn{width:100%;padding:1rem;background:linear-gradient(135deg,#ff7a00,#ff5722);color:#000;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s;box-shadow:0 4px 15px #ff7a004d}.login-form .submit-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px #ff7a0066}.login-form .submit-btn:disabled{background:#2a2a2a;color:#666;cursor:not-allowed;transform:none;box-shadow:none}.toggle-mode{text-align:center;margin-top:2rem;color:#888!important;font-size:.9rem}.toggle-mode button{background:transparent!important;border:none;color:#ff7a00!important;font-weight:600;cursor:pointer;margin-left:.5rem;transition:opacity .2s}.toggle-mode button:hover{opacity:.8}.login-footer-links{margin-top:2rem;padding-top:1.5rem;border-top:1px solid #2a2a2a!important;text-align:center}.login-footer-links a{color:#888!important;text-decoration:none;background:transparent!important;font-size:.9rem;transition:color .2s;display:inline-flex;align-items:center;gap:.5rem}.login-footer-links a:hover{color:#ff7a00!important}.admin-dashboard{min-height:100vh;background:var(--bg-main)}.admin-header{background:var(--header-bg);padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--header-border);position:sticky;top:0;z-index:50}.admin-header h1{margin:0;font-size:1.25rem;color:var(--text-primary)}.header-nav{display:flex;gap:.5rem;align-items:center}.nav-link{padding:.5rem .75rem;background:var(--bg-hover);border-radius:8px;text-decoration:none;color:var(--text-primary);border:none;cursor:pointer;font-size:.9rem}.nav-link:hover{background:var(--bg-active)}.logout-btn{padding:.5rem .75rem;background:var(--error);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:.9rem}.logout-btn:hover{opacity:.9}.theme-toggle{padding:.5rem;background:var(--bg-hover);border:none;border-radius:8px;cursor:pointer;font-size:1.1rem;display:flex;align-items:center;justify-content:center}.theme-toggle:hover{background:var(--bg-active)}.stats-bar{display:flex;gap:1rem;padding:1rem 2rem;background:var(--header-bg);border-bottom:1px solid var(--border-color)}.stat-card{background:var(--bg-hover);padding:1rem 1.5rem;border-radius:12px;text-align:center;min-width:120px}.stat-value{display:block;font-size:1.5rem;font-weight:700;color:var(--primary)}.stat-label{font-size:.85rem;color:var(--text-secondary)}.orders-board{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;padding:1.5rem;min-height:calc(100vh - 180px)}@media(max-width:1200px){.orders-board{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.orders-board{grid-template-columns:1fr}.stats-bar{padding:1rem;overflow-x:auto}.stat-card{min-width:100px;padding:.75rem 1rem}.stat-value{font-size:1.2rem}.admin-header{padding:1rem}.admin-header h1{font-size:1rem}}.order-column{background:var(--bg-card);border-radius:12px;padding:1rem;box-shadow:var(--shadow-sm);border:1px solid var(--border-color)}.order-column h2{margin:0 0 1rem;font-size:.95rem;padding-bottom:.75rem;border-bottom:3px solid;display:flex;justify-content:space-between;align-items:center;color:var(--text-primary)}.order-column .count{background:var(--bg-hover);padding:.25rem .6rem;border-radius:12px;font-size:.85rem;color:var(--text-secondary)}.orders-list{display:flex;flex-direction:column;gap:.75rem;max-height:calc(100vh - 320px);overflow-y:auto}.order-card{background:var(--bg-elevated);border-radius:10px;padding:1rem;border:1px solid var(--border-color)}.order-header{display:flex;justify-content:space-between;margin-bottom:.5rem}.order-id{font-weight:700;color:var(--primary);font-size:.9rem}.order-customer{margin-bottom:.75rem}.order-customer strong{display:block;color:var(--text-primary)}.order-customer span{font-size:.85rem;color:var(--text-secondary)}.order-items{background:var(--bg-hover);padding:.5rem .75rem;border-radius:6px;margin-bottom:.75rem}.order-item{font-size:.9rem;padding:.25rem 0;color:var(--text-primary)}.order-total{font-weight:700;margin-bottom:.75rem;color:var(--text-primary)}.order-actions button{width:100%;padding:.6rem;background:var(--primary);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500}.order-actions button:hover{background:var(--primary-hover)}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.qr-modal{background:var(--bg-card);border-radius:16px;padding:2rem;text-align:center;max-width:350px;border:1px solid var(--border-color)}.qr-modal h2{margin:0 0 1.5rem;color:var(--text-primary)}.qr-container{background:#fff;padding:1rem;border-radius:12px;display:inline-block;margin-bottom:1rem}.qr-url{font-size:.8rem;color:var(--text-secondary);word-break:break-all;margin-bottom:1.5rem;padding:.5rem;background:var(--bg-hover);border-radius:6px}.qr-actions{display:flex;gap:.5rem}.qr-actions button{flex:1;padding:.75rem;border:none;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:500}.qr-actions button:first-child{background:var(--primary);color:#fff}.qr-actions button:first-child:hover{background:var(--primary-hover)}.qr-actions button:last-child{background:var(--bg-hover);color:var(--text-primary)}.qr-actions button:last-child:hover{background:var(--bg-active)}.order-card{cursor:grab;-webkit-user-select:none;user-select:none;transition:transform .15s ease,box-shadow .15s ease,opacity .15s ease}.order-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.order-card:active{cursor:grabbing}.order-card.dragging{opacity:.5;transform:rotate(3deg) scale(1.02);box-shadow:var(--shadow-lg)}.order-column{transition:background .2s ease,border-color .2s ease}.order-column.drag-over{background:var(--primary-light);border-color:var(--primary);border-style:dashed}.order-column.drag-over .orders-list{min-height:100px}.order-column.drag-over:after{content:"Soltar aquí";display:block;text-align:center;padding:1rem;color:var(--primary);font-weight:500;font-size:.9rem;opacity:.8}@keyframes cardEnter{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.order-card{animation:cardEnter .2s ease}.orders-list{min-height:50px;padding-bottom:1rem}.order-column h2{-webkit-user-select:none;user-select:none}.order-detail-modal{background:var(--bg-card);border-radius:16px;padding:0;width:95%;max-width:500px;max-height:90vh;overflow-y:auto;position:relative;border:1px solid var(--border-color)}.modal-close{position:absolute;top:1rem;right:1rem;background:var(--bg-hover);border:none;width:32px;height:32px;border-radius:50%;font-size:1.5rem;cursor:pointer;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;line-height:1;z-index:10}.modal-close:hover{background:var(--error);color:#fff}.order-detail-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--border-color);background:var(--bg-hover)}.order-detail-id .label{display:block;font-size:.8rem;color:var(--text-secondary);text-transform:uppercase}.order-detail-id .value{font-size:1.5rem;font-weight:700;color:var(--primary)}.order-status-badge{padding:.5rem 1rem;border-radius:20px;font-size:.85rem;font-weight:600}.order-status-badge.pending_confirmation{background:#fff3e0;color:#e65100}.order-status-badge.confirmed{background:#e3f2fd;color:#1565c0}.order-status-badge.preparing{background:#f3e5f5;color:#7b1fa2}.order-status-badge.ready{background:#e8f5e9;color:#2e7d32}.order-detail-section{padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color)}.order-detail-section:last-of-type{border-bottom:none}.order-detail-section h3{margin:0 0 1rem;font-size:.95rem;color:var(--text-primary)}.detail-row{display:flex;justify-content:space-between;padding:.4rem 0;font-size:.95rem}.detail-row .label{color:var(--text-secondary)}.detail-row .value{color:var(--text-primary);font-weight:500}.phone-link{color:var(--primary);text-decoration:none;font-weight:500}.phone-link:hover{text-decoration:underline}.order-items-list{background:var(--bg-hover);border-radius:10px;padding:.75rem;margin-bottom:1rem}.order-item-detail{display:flex;align-items:center;padding:.5rem 0;border-bottom:1px solid var(--border-color)}.order-item-detail:last-child{border-bottom:none}.order-item-detail .qty{background:var(--primary);color:#fff;padding:.2rem .5rem;border-radius:4px;font-size:.85rem;font-weight:600;margin-right:.75rem}.order-item-detail .name{flex:1;color:var(--text-primary)}.order-item-detail .price{color:var(--text-secondary);font-weight:500}.order-totals{padding-top:.5rem}.total-row{display:flex;justify-content:space-between;padding:.35rem 0;font-size:.95rem;color:var(--text-secondary)}.total-row.final{border-top:2px solid var(--border-color);margin-top:.5rem;padding-top:.75rem;font-size:1.1rem;font-weight:700;color:var(--text-primary)}.payment-proof-container{text-align:center}.payment-proof-img{max-width:100%;max-height:300px;border-radius:10px;cursor:pointer;border:2px solid var(--border-color);transition:transform .2s,border-color .2s}.payment-proof-img:hover{transform:scale(1.02);border-color:var(--primary)}.proof-hint{font-size:.8rem;color:var(--text-muted);margin-top:.5rem}.order-detail-actions{padding:1.25rem 1.5rem;background:var(--bg-hover)}.action-btn{width:100%;padding:1rem;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:opacity .2s}.action-btn:hover{opacity:.9}.action-btn.confirm{background:#ff9800;color:#fff}.action-btn.prepare{background:#3b82f6;color:#fff}.action-btn.ready{background:#8b5cf6;color:#fff}.action-btn.complete{background:#10b981;color:#fff}.ocr-validation{margin-top:1rem;padding-top:1rem;border-top:1px dashed var(--border-color)}.ocr-btn{width:100%;padding:.75rem 1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:opacity .2s,transform .2s}.ocr-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.ocr-btn:disabled{opacity:.7;cursor:not-allowed}.ocr-result{padding:1rem;border-radius:10px;text-align:center}.ocr-result.valid{background:#10b9811a;border:2px solid #10b981}.ocr-result.invalid{background:#f59e0b1a;border:2px solid #f59e0b}.ocr-status{font-size:1.1rem;font-weight:600;margin-bottom:.5rem}.ocr-result.valid .ocr-status{color:#10b981}.ocr-result.invalid .ocr-status{color:#f59e0b}.ocr-amount{font-size:.95rem;color:var(--text-secondary)}.ocr-amount strong{color:var(--text-primary)}.ocr-diff{display:block;font-size:.85rem;color:#ef4444;margin-top:.25rem}.bulk-ocr-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:.85rem;font-weight:500;cursor:pointer;transition:opacity .2s}.bulk-ocr-btn:hover:not(:disabled){opacity:.9}.bulk-ocr-btn:disabled{opacity:.6;cursor:not-allowed}.action-btn.whatsapp{background:#25d366;color:#fff;margin-top:.5rem}.action-btn.whatsapp:hover{background:#128c7e}.notifications-section{background:var(--bg-hover);border-radius:10px;margin:0 1.5rem 1rem;padding:1rem!important;border:none!important}.notifications-section h3{margin-bottom:.75rem!important;font-size:.9rem!important}.notification-buttons{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}.notification-buttons .action-btn{padding:.75rem;font-size:.85rem;border-radius:8px}.action-btn.whatsapp-auto{background:#25d366;color:#fff}.action-btn.whatsapp-auto:hover{background:#128c7e}.action-btn.whatsapp-manual{background:var(--bg-elevated);color:#25d366;border:2px solid #25D366}.action-btn.whatsapp-manual:hover{background:#25d3661a}.action-btn.email{background:#3b82f6;color:#fff}.action-btn.email:hover{background:#2563eb}.action-btn.send-all{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.action-btn.send-all:hover{opacity:.9}@media(max-width:480px){.notification-buttons{grid-template-columns:1fr}}.menu-editor{min-height:100vh;background:var(--bg-main)}.menu-editor.loading{display:flex;align-items:center;justify-content:center;color:var(--text-secondary)}.editor-header{background:var(--header-bg);padding:1rem 2rem;display:flex;align-items:center;gap:1rem;border-bottom:1px solid var(--header-border);position:sticky;top:0;z-index:50}.editor-header .back-btn{color:var(--primary);text-decoration:none;font-weight:500}.editor-header h1{margin:0;font-size:1.25rem;color:var(--text-primary)}.editor-content{max-width:800px;margin:0 auto;padding:2rem}.category-block{background:var(--bg-card);border-radius:12px;margin-bottom:1.5rem;overflow:hidden;border:1px solid var(--border-color)}.category-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:var(--bg-elevated);border-bottom:1px solid var(--border-color)}.category-header h2{margin:0;font-size:1.1rem;cursor:pointer;color:var(--text-primary)}.category-header h2:hover{color:var(--primary)}.category-header input{font-size:1.1rem;font-weight:700;padding:.25rem .5rem;border:2px solid var(--primary);border-radius:4px;background:var(--bg-input);color:var(--text-primary)}.category-actions{display:flex;gap:.5rem}.category-actions button{padding:.5rem 1rem;background:var(--primary);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.85rem}.category-actions button.delete{background:var(--error)}.dishes-list{padding:.5rem}.dish-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem;border-radius:8px;transition:background .2s}.dish-row:hover{background:var(--bg-hover)}.dish-row.unavailable{opacity:.5}.dish-main{display:flex;gap:1rem;align-items:center}.dish-name{font-weight:500;color:var(--text-primary)}.dish-price{color:var(--primary);font-weight:700}.dish-actions{display:flex;gap:.5rem;align-items:center}.dish-actions button{padding:.25rem .5rem;background:var(--bg-hover);border:none;border-radius:4px;cursor:pointer}.dish-actions button:hover{background:var(--bg-active)}.dish-actions button.delete{color:var(--error)}.toggle{position:relative;display:inline-block;width:44px;height:24px}.toggle input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background:var(--text-muted);border-radius:24px;transition:.3s}.slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.3s}.toggle input:checked+.slider{background:var(--success)}.toggle input:checked+.slider:before{transform:translate(20px)}.new-category-form{display:flex;gap:.5rem;padding:1rem;background:var(--bg-card);border-radius:12px;border:1px solid var(--border-color)}.new-category-form input{flex:1;padding:.75rem;border:2px solid var(--border-color);border-radius:8px;background:var(--bg-input);color:var(--text-primary)}.new-category-form input:focus{outline:none;border-color:var(--primary)}.new-category-form button{padding:.75rem 1.5rem;background:var(--primary);color:#fff;border:none;border-radius:8px;cursor:pointer}.new-category-form button.cancel{background:var(--bg-hover);color:var(--text-primary)}.add-category-btn{width:100%;padding:1rem;background:var(--bg-card);border:2px dashed var(--border-color);border-radius:12px;font-size:1rem;color:var(--text-secondary);cursor:pointer;transition:all .2s}.add-category-btn:hover{border-color:var(--primary);color:var(--primary)}.modal-content{background:var(--bg-card);border-radius:16px;padding:2rem;width:100%;max-width:450px;max-height:90vh;overflow-y:auto;border:1px solid var(--border-color)}.modal-content h2{margin:0 0 1.5rem;color:var(--text-primary)}.modal-content .form-group{margin-bottom:1.25rem}.modal-content label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-secondary)}.modal-content input,.modal-content textarea{width:100%;padding:.75rem;border:2px solid var(--border-color);border-radius:8px;font-size:1rem;background:var(--bg-input);color:var(--text-primary)}.modal-content input:focus,.modal-content textarea:focus{outline:none;border-color:var(--primary)}.modal-content textarea{min-height:80px;resize:vertical}.modal-actions{display:flex;gap:1rem;margin-top:1.5rem}.modal-actions button{flex:1;padding:.75rem;border:none;border-radius:8px;font-size:1rem;cursor:pointer}.modal-actions button.cancel{background:var(--bg-hover);color:var(--text-primary)}.modal-actions button:not(.cancel){background:var(--primary);color:#fff}.image-upload{display:flex;flex-direction:column;gap:.75rem}.image-preview{width:100%;max-width:200px;height:120px;object-fit:cover;border-radius:8px;border:2px solid var(--border-color)}.image-upload input[type=file]{padding:.5rem;border:2px dashed var(--border-color);border-radius:8px;cursor:pointer;color:var(--text-secondary)}.image-upload input[type=file]:hover{border-color:var(--primary)}.uploading{color:var(--primary);font-size:.9rem}.drag-handle{cursor:grab;color:var(--text-muted);font-size:1.2rem;padding:0 .5rem;-webkit-user-select:none;user-select:none}.drag-handle:active{cursor:grabbing}.category-block{transition:transform .2s,box-shadow .2s,border-color .2s}.category-block[draggable=true]{cursor:grab}.category-block[draggable=true]:active{cursor:grabbing}.category-block.drag-over{border-color:var(--primary);border-style:dashed;background:var(--primary-light)}.category-header{gap:.5rem}.dish-row{transition:transform .15s,background .2s,box-shadow .15s}.dish-row[draggable=true]{cursor:grab}.dish-row[draggable=true]:active{cursor:grabbing;transform:scale(1.02);box-shadow:var(--shadow-md);background:var(--bg-card);z-index:10}.dishes-list.drag-over{background:var(--primary-light);border-radius:8px;min-height:60px}.empty-dishes{padding:1.5rem;text-align:center;color:var(--text-muted);font-size:.9rem;border:2px dashed var(--border-color);border-radius:8px;margin:.5rem}.dish-main{flex:1}.dish-modal{max-width:500px}.modal-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:2px solid var(--border-color);padding-bottom:.5rem}.modal-tabs .tab{padding:.5rem 1rem;background:transparent;border:none;border-radius:6px 6px 0 0;cursor:pointer;font-size:.9rem;color:var(--text-secondary);transition:all .2s}.modal-tabs .tab:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary)}.modal-tabs .tab.active{background:var(--primary);color:#fff}.modal-tabs .tab:disabled{opacity:.5;cursor:not-allowed}.variants-section{min-height:200px}.variants-help{font-size:.85rem;color:var(--text-secondary);margin-bottom:1rem;padding:.75rem;background:var(--bg-hover);border-radius:8px;line-height:1.5}.variants-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.variant-row{display:flex;gap:.5rem;align-items:center;padding:.5rem;background:var(--bg-hover);border-radius:8px}.variant-name{flex:1;padding:.5rem!important;font-size:.9rem!important}.variant-price{display:flex;align-items:center;gap:.25rem;width:100px}.variant-price .price-label{color:var(--text-secondary);font-size:.9rem}.variant-price input{width:70px!important;padding:.5rem!important;font-size:.9rem!important;text-align:right}.remove-variant{width:28px;height:28px;padding:0!important;background:var(--error)!important;color:#fff!important;border:none;border-radius:50%;cursor:pointer;font-size:.8rem;display:flex;align-items:center;justify-content:center}.remove-variant:hover{opacity:.9}.add-variant-btn{width:100%;padding:.75rem;background:transparent;border:2px dashed var(--border-color);border-radius:8px;color:var(--text-secondary);cursor:pointer;font-size:.9rem;transition:all .2s}.add-variant-btn:hover{border-color:var(--primary);color:var(--primary)}.variants-preview{margin-top:1rem;padding:1rem;background:var(--bg-elevated);border-radius:8px;border:1px solid var(--border-color)}.variants-preview h4{margin:0 0 .5rem;font-size:.85rem;color:var(--text-secondary)}.variants-preview ul{list-style:none;padding:0;margin:0}.variants-preview li{padding:.35rem 0;font-size:.9rem;color:var(--text-primary);display:flex;justify-content:space-between}.variants-preview li strong{color:var(--primary)}.loading-text{text-align:center;color:var(--text-muted);padding:2rem}.dish-row .dish-variants-badge{font-size:.75rem;background:var(--primary-light);color:var(--primary);padding:.15rem .5rem;border-radius:10px;margin-left:.5rem}.pricing-calculator{min-height:200px}.pricing-modes{display:flex;gap:.5rem;margin-bottom:1.25rem}.mode-btn{flex:1;padding:.6rem;background:var(--bg-hover);border:2px solid var(--border-color);border-radius:8px;cursor:pointer;font-size:.9rem;color:var(--text-secondary);transition:all .2s}.mode-btn:hover{background:var(--bg-active)}.mode-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.manual-pricing .price-input-wrapper{display:flex;align-items:center;gap:.5rem}.price-input-wrapper .currency{font-size:1.25rem;color:var(--text-secondary);font-weight:600}.price-input-wrapper input{flex:1;font-size:1.5rem!important;font-weight:600;text-align:right}.pricing-tip{margin-top:1rem;padding:.75rem;background:var(--bg-hover);border-radius:8px;font-size:.85rem;color:var(--text-secondary)}.cost-inputs{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.cost-inputs .price-input-wrapper input{font-size:1rem!important}.margin-sliders{margin-bottom:1.25rem}.slider-group{margin-bottom:1rem}.slider-group label{display:flex;justify-content:space-between;margin-bottom:.5rem;font-size:.85rem;color:var(--text-secondary)}.slider-group label strong{color:var(--primary)}.slider-group input[type=range]{width:100%;height:6px;border-radius:3px;background:var(--border-color);appearance:none;cursor:pointer}.slider-group input[type=range]::-webkit-slider-thumb{appearance:none;width:18px;height:18px;border-radius:50%;background:var(--primary);cursor:pointer}.price-suggestion{background:linear-gradient(135deg,#10b981,#059669);border-radius:10px;padding:1rem;margin-bottom:1rem;text-align:center;color:#fff}.suggestion-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.suggested-price{font-size:1.75rem}.apply-price-btn{width:100%;padding:.6rem;background:#fff3;border:2px solid rgba(255,255,255,.5);border-radius:8px;color:#fff;font-weight:600;cursor:pointer;transition:background .2s}.apply-price-btn:hover{background:#ffffff4d}.cost-breakdown{background:var(--bg-hover);border-radius:10px;padding:1rem;margin-bottom:1rem}.cost-breakdown h4{margin:0 0 .75rem;font-size:.9rem;color:var(--text-primary)}.breakdown-row{display:flex;justify-content:space-between;padding:.4rem 0;font-size:.85rem;color:var(--text-secondary)}.breakdown-row.total{border-top:2px solid var(--border-color);margin-top:.5rem;padding-top:.75rem;font-weight:600;color:var(--text-primary)}.price-analysis{background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:10px;padding:1rem}.price-analysis h4{margin:0 0 .75rem;font-size:.9rem;color:var(--text-primary)}.analysis-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.analysis-item{text-align:center;padding:.5rem;background:var(--bg-hover);border-radius:8px}.analysis-item .label{display:block;font-size:.75rem;color:var(--text-secondary);margin-bottom:.25rem}.analysis-item .value{font-size:1.1rem;font-weight:600;color:var(--text-primary)}.analysis-item .value.positive{color:#10b981}.analysis-item .value.negative{color:#ef4444}.analysis-item .value.warning{color:#f59e0b}.margin-warning{margin-top:.75rem;padding:.5rem;background:#f59e0b1a;border:1px solid #f59e0b;border-radius:6px;font-size:.8rem;color:#b45309}@media(max-width:480px){.cost-inputs{grid-template-columns:1fr}.analysis-grid{grid-template-columns:1fr 1fr}}.settings-page{min-height:100vh;background:var(--bg-main)}.settings-content{max-width:600px;margin:0 auto;padding:2rem}.settings-form{background:var(--bg-card);border-radius:12px;padding:2rem;border:1px solid var(--border-color)}.form-section{margin-bottom:2rem}.form-section h2{font-size:1.1rem;margin:0 0 1rem;padding-bottom:.5rem;border-bottom:2px solid var(--primary);color:var(--text-primary)}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-secondary)}.form-group input,.form-group textarea{width:100%;padding:.75rem;border:2px solid var(--border-color);border-radius:8px;font-size:1rem;background:var(--bg-input);color:var(--text-primary)}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--primary)}.form-group textarea{min-height:80px;resize:vertical}.form-group input[type=color]{width:60px;height:40px;padding:0;cursor:pointer;border-radius:8px}.form-row{display:flex;gap:1rem}.form-row .form-group{flex:1}.logo-upload{display:flex;flex-direction:column;gap:1rem;align-items:flex-start}.logo-preview{width:120px;height:120px;object-fit:cover;border-radius:12px;border:2px solid var(--border-color)}.logo-upload input[type=file]{color:var(--text-secondary)}.save-btn{width:100%;padding:1rem;background:var(--primary);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer}.save-btn:hover{background:var(--primary-hover)}.save-btn:disabled{background:var(--text-muted);cursor:not-allowed}.notifications-config{margin-top:1.5rem}.section-desc{color:var(--text-secondary);font-size:.9rem;margin:-.5rem 0 1rem}.notif-channels{display:flex;flex-direction:column;gap:1rem}.notif-channel{background:var(--bg-hover);border-radius:10px;padding:1rem;border:1px solid var(--border-color)}.channel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.channel-info{display:flex;align-items:center;gap:.75rem}.channel-icon{font-size:1.5rem}.channel-info strong{display:block;color:var(--text-primary)}.channel-desc{font-size:.8rem;color:var(--text-secondary)}.toggle-switch{position:relative;display:inline-block;width:50px;height:28px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:var(--text-muted);transition:.3s;border-radius:28px}.toggle-slider:before{position:absolute;content:"";height:22px;width:22px;left:3px;bottom:3px;background-color:#fff;transition:.3s;border-radius:50%}.toggle-switch input:checked+.toggle-slider{background-color:var(--primary)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(22px)}.test-btn{width:100%;padding:.6rem;background:var(--primary);color:#fff;border:none;border-radius:6px;font-size:.85rem;cursor:pointer;transition:opacity .2s}.test-btn:hover:not(:disabled){opacity:.9}.test-btn:disabled{opacity:.6;cursor:not-allowed}.test-btn.whatsapp{background:#25d366}.notif-events{display:flex;flex-direction:column;gap:.5rem}.notif-event{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--bg-hover);border-radius:8px;cursor:pointer;transition:background .2s;border:1px solid transparent}.notif-event:hover{background:var(--bg-active)}.notif-event input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary);cursor:pointer}.event-icon{font-size:1.25rem}.event-info{flex:1}.event-info strong{display:block;color:var(--text-primary);font-size:.95rem}.event-info span{font-size:.8rem;color:var(--text-secondary)}.info-section{background:var(--bg-hover);border-radius:10px;padding:1rem!important;margin-top:1rem}.info-section h3{margin:0 0 .75rem;font-size:.95rem;color:var(--text-primary)}.info-list{list-style:none;padding:0;margin:0}.info-list li{padding:.4rem 0;font-size:.85rem;color:var(--text-secondary)}.info-list li strong{color:var(--text-primary)}@media(max-width:600px){.settings-content{padding:1rem}.settings-form{padding:1.25rem}.form-row{flex-direction:column;gap:0}}.finance-page{min-height:100vh;background:var(--bg-primary)}.finance-page .back-btn{color:var(--text-secondary);text-decoration:none;font-size:.9rem;margin-right:1rem}.finance-page .back-btn:hover{color:var(--primary)}.finance-controls{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:var(--bg-card);border-bottom:1px solid var(--border-color)}.period-selector{display:flex;gap:.5rem;background:var(--bg-hover);padding:.25rem;border-radius:10px}.period-btn{padding:.5rem 1.25rem;border:none;background:transparent;color:var(--text-secondary);border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s}.period-btn.active{background:var(--primary);color:#fff}.period-btn:hover:not(.active){background:var(--bg-card)}.cash-close-btn{padding:.6rem 1.25rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;font-weight:600;cursor:pointer;transition:opacity .2s}.cash-close-btn:hover{opacity:.9}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;color:var(--text-secondary)}.loading-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.comparison-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem;padding:1.5rem}.comparison-card{background:var(--bg-card);border-radius:16px;padding:1.5rem;box-shadow:var(--shadow-sm)}.comparison-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.comparison-label{color:var(--text-secondary);font-size:.9rem;font-weight:500}.comparison-growth{font-size:.85rem;font-weight:600;padding:.25rem .5rem;border-radius:6px}.comparison-growth.positive{background:#10b9811a;color:#10b981}.comparison-growth.negative{background:#ef44441a;color:#ef4444}.comparison-value{font-size:2rem;font-weight:700;color:var(--text-primary);margin-bottom:.25rem}.comparison-orders{color:var(--text-secondary);font-size:.9rem}.comparison-vs{color:var(--text-muted);font-size:.8rem;margin-top:.5rem}.finance-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;padding:0 1.5rem 1.5rem}.finance-stats .stat-card{background:var(--bg-card);border-radius:12px;padding:1.25rem;display:flex;align-items:center;gap:1rem;box-shadow:var(--shadow-sm)}.finance-stats .stat-card.large{grid-column:span 2;background:linear-gradient(135deg,#667eea,#764ba2)}.finance-stats .stat-card.large .stat-value,.finance-stats .stat-card.large .stat-label{color:#fff}.stat-icon{font-size:2rem}.stat-content{display:flex;flex-direction:column}.finance-stats .stat-value{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.finance-stats .stat-label{font-size:.8rem;color:var(--text-secondary)}.finance-charts{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:1.5rem;padding:0 1.5rem 1.5rem}.chart-card{background:var(--bg-card);border-radius:16px;padding:1.5rem;box-shadow:var(--shadow-sm)}.chart-card h3{margin:0 0 1.25rem;font-size:1rem;color:var(--text-primary)}.bar-chart{display:flex;align-items:flex-end;gap:.5rem;height:200px;padding-top:1rem}.bar-item{flex:1;display:flex;flex-direction:column;align-items:center;height:100%}.bar{width:100%;max-width:40px;background:linear-gradient(180deg,var(--primary) 0%,#764ba2 100%);border-radius:6px 6px 0 0;min-height:4px;position:relative;transition:height .3s ease}.bar:hover{opacity:.8}.bar-value{position:absolute;top:-20px;left:50%;transform:translate(-50%);font-size:.7rem;color:var(--text-secondary);white-space:nowrap}.bar-label{margin-top:.5rem;font-size:.75rem;color:var(--text-muted)}.top-products{display:flex;flex-direction:column;gap:.75rem}.product-row{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--bg-hover);border-radius:10px}.product-rank{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--primary);color:#fff;border-radius:50%;font-size:.75rem;font-weight:600}.product-name{flex:1;color:var(--text-primary);font-weight:500}.product-qty{color:var(--text-secondary);font-size:.85rem}.product-revenue{color:#10b981;font-weight:600}.recent-orders-section{padding:0 1.5rem 1.5rem}.recent-orders-section h3{margin:0 0 1rem;color:var(--text-primary)}.orders-table{background:var(--bg-card);border-radius:12px;overflow:hidden;box-shadow:var(--shadow-sm)}.table-header,.table-row{display:grid;grid-template-columns:80px 1fr 60px 60px 100px 80px;padding:.75rem 1rem;gap:.5rem;align-items:center}.table-header{background:var(--bg-hover);font-weight:600;font-size:.8rem;color:var(--text-secondary);text-transform:uppercase}.table-row{border-bottom:1px solid var(--border-color);font-size:.9rem;color:var(--text-primary)}.table-row:last-child{border-bottom:none}.table-row:hover{background:var(--bg-hover)}.status-badge{font-size:1.1rem}.cash-close-modal{background:var(--bg-card);border-radius:20px;width:90%;max-width:500px;max-height:85vh;overflow-y:auto;position:relative}.cash-close-modal h2{padding:1.5rem;margin:0;border-bottom:1px solid var(--border-color);color:var(--text-primary)}.cash-close-date{display:flex;gap:.5rem;padding:1rem 1.5rem;background:var(--bg-hover)}.cash-close-date input{flex:1;padding:.5rem;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-input);color:var(--text-primary)}.cash-close-date button{padding:.5rem 1rem;background:var(--primary);color:#fff;border:none;border-radius:8px;cursor:pointer}.cash-close-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;padding:1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.cash-close-summary .summary-item{text-align:center}.cash-close-summary .value{display:block;font-size:1.5rem;font-weight:700}.cash-close-summary .label{font-size:.75rem;opacity:.9}.cash-close-products{padding:1.5rem}.cash-close-products h4{margin:0 0 1rem;color:var(--text-primary)}.product-line{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px dashed var(--border-color);color:var(--text-primary)}.product-line:last-child{border-bottom:none}.cash-close-actions{padding:1.5rem;border-top:1px solid var(--border-color)}.export-btn{width:100%;padding:1rem;background:#10b981;color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:opacity .2s}.export-btn:hover{opacity:.9}@media(max-width:768px){.finance-controls{flex-direction:column;gap:1rem}.finance-stats .stat-card.large{grid-column:span 1}.table-header,.table-row{grid-template-columns:60px 1fr 50px 80px}.table-header span:nth-child(3),.table-row span:nth-child(3),.table-header span:nth-child(6),.table-row span:nth-child(6){display:none}}.no-data{text-align:center;color:var(--text-muted);padding:1rem;font-style:italic}.include-all-toggle{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-secondary);cursor:pointer}.include-all-toggle input{width:16px;height:16px;cursor:pointer}.cash-close-info{display:flex;flex-wrap:wrap;gap:1rem;padding:.75rem 1.5rem;background:var(--bg-hover);font-size:.85rem;color:var(--text-secondary)}.cash-close-info span{display:flex;align-items:center;gap:.25rem}.team-page{padding:1.5rem;max-width:1200px;margin:0 auto}.team-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem}.team-header h1{margin:0 0 .25rem;font-size:1.75rem;color:var(--text-primary)}.team-header p{margin:0;color:var(--text-secondary)}.invite-btn{padding:.75rem 1.5rem;background:var(--primary);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:opacity .2s}.invite-btn:hover{opacity:.9}.team-section{margin-bottom:2rem}.team-section h2{font-size:1.1rem;color:var(--text-primary);margin:0 0 1rem;padding-bottom:.5rem;border-bottom:2px solid var(--border-color)}.members-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.member-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:1.25rem;display:flex;gap:1rem;position:relative}.member-avatar{width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}.member-info{flex:1;min-width:0}.member-info h3{margin:0 0 .25rem;font-size:1rem;color:var(--text-primary)}.member-email{margin:0 0 .5rem;font-size:.85rem;color:var(--text-secondary);word-break:break-all}.role-badge{display:inline-block;padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;color:#fff}.role-badge.small{padding:.15rem .5rem;font-size:.7rem}.member-phone{margin:.5rem 0 0;font-size:.8rem;color:var(--text-secondary)}.member-activity{margin:.25rem 0 0;font-size:.75rem;color:var(--text-muted)}.member-actions{display:flex;flex-direction:column;gap:.5rem;align-items:flex-end}.role-select{padding:.35rem .5rem;border:1px solid var(--border-color);border-radius:6px;font-size:.8rem;background:var(--bg-input);color:var(--text-primary);cursor:pointer}.remove-btn{background:none;border:none;font-size:1rem;cursor:pointer;opacity:.6;transition:opacity .2s}.remove-btn:hover{opacity:1}.invitations-list{display:flex;flex-direction:column;gap:.75rem}.invitation-card{background:var(--bg-card);border:1px dashed var(--border-color);border-radius:8px;padding:1rem;display:flex;justify-content:space-between;align-items:center}.invitation-info{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.invitation-email{font-weight:500;color:var(--text-primary)}.invitation-expires{font-size:.8rem;color:var(--text-muted)}.cancel-invitation-btn{padding:.35rem .75rem;background:var(--bg-hover);border:1px solid var(--border-color);border-radius:6px;font-size:.8rem;color:var(--text-secondary);cursor:pointer}.cancel-invitation-btn:hover{background:#fee2e2;border-color:#fca5a5;color:#dc2626}.roles-info{background:var(--bg-hover);border-radius:12px;padding:1.5rem}.roles-info h2{border-bottom:none;padding-bottom:0}.roles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}.role-info-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;padding:1rem}.role-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.role-icon{font-size:1.25rem}.role-name{font-weight:600}.role-info-card p{margin:0;font-size:.85rem;color:var(--text-secondary);line-height:1.4}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.invite-modal{background:var(--bg-card);border-radius:16px;padding:2rem;width:100%;max-width:450px;position:relative}.invite-modal h2{margin:0 0 1.5rem;font-size:1.25rem;color:var(--text-primary)}.form-group{margin-bottom:1.25rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-primary)}.form-group input,.form-group select{width:100%;padding:.75rem 1rem;border:2px solid var(--border-color);border-radius:8px;font-size:1rem;background:var(--bg-input);color:var(--text-primary)}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--primary)}.role-description{margin:.5rem 0 0;font-size:.8rem;color:var(--text-secondary);line-height:1.4}.form-actions{display:flex;gap:.75rem;margin-top:1.5rem}.form-actions button{flex:1;padding:.75rem;border-radius:8px;font-size:1rem;cursor:pointer;transition:all .2s}.form-actions button:first-child{background:var(--bg-hover);border:1px solid var(--border-color);color:var(--text-primary)}.form-actions button.primary{background:var(--primary);border:none;color:#fff;font-weight:600}.form-actions button.primary:disabled{opacity:.5;cursor:not-allowed}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem}.spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:1rem}@media(max-width:600px){.team-header{flex-direction:column;gap:1rem}.invite-btn{width:100%}.member-card{flex-direction:column;text-align:center}.member-avatar{margin:0 auto}.member-actions{flex-direction:row;justify-content:center;width:100%;margin-top:.5rem}.invitation-card{flex-direction:column;gap:.75rem}.invitation-info{justify-content:center}}.delivery-map-page{min-height:100vh;display:flex;flex-direction:column;background:var(--bg-main)}.delivery-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:var(--bg-card);border-bottom:1px solid var(--border-color)}.header-left{display:flex;align-items:center;gap:1rem}.back-link{color:var(--primary);text-decoration:none;font-weight:500}.delivery-header h1{margin:0;font-size:1.5rem;color:var(--text-primary)}.header-actions{display:flex;gap:.5rem}.geocode-btn{padding:.5rem 1rem;background:#f59e0b;color:#fff;border:none;border-radius:8px;font-size:.85rem;font-weight:500;cursor:pointer;transition:opacity .2s}.geocode-btn:hover:not(:disabled){opacity:.9}.geocode-btn:disabled{opacity:.6;cursor:not-allowed}.header-stats{display:flex;gap:2rem}.header-stats .stat{text-align:center}.header-stats .stat-value{display:block;font-size:1.5rem;font-weight:700;color:var(--primary)}.header-stats .stat-label{font-size:.8rem;color:var(--text-secondary)}.delivery-content{flex:1;display:flex;overflow:hidden}.delivery-sidebar{width:320px;background:var(--bg-card);border-right:1px solid var(--border-color);overflow-y:auto;flex-shrink:0}.sidebar-section{padding:1rem;border-bottom:1px solid var(--border-color)}.sidebar-section h3{margin:0 0 1rem;font-size:.95rem;color:var(--text-primary)}.loading-text,.empty-text{color:var(--text-secondary);font-size:.9rem;text-align:center;padding:1rem}.orders-list{display:flex;flex-direction:column;gap:.5rem}.order-item{background:var(--bg-hover);border-radius:8px;padding:.75rem;cursor:pointer;transition:all .2s;border:2px solid transparent}.order-item:hover{background:var(--bg-main)}.order-item.selected{border-color:var(--primary);background:var(--bg-main)}.order-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.order-id{font-weight:700;color:var(--primary)}.order-badges{display:flex;align-items:center;gap:.35rem}.order-type-badge{font-size:.9rem}.order-status{padding:.2rem .5rem;border-radius:12px;font-size:.7rem;font-weight:600;color:#fff}.order-item-body{display:flex;flex-direction:column;gap:.25rem}.customer-name{font-weight:500;color:var(--text-primary);font-size:.9rem}.customer-address{font-size:.8rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.order-rider{margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--border-color);font-size:.8rem;color:var(--text-secondary)}.riders-list{display:flex;flex-direction:column;gap:.5rem}.rider-item{display:flex;align-items:center;gap:.75rem;padding:.5rem;background:var(--bg-hover);border-radius:8px}.rider-avatar{font-size:1.5rem}.rider-name{font-weight:500;color:var(--text-primary);font-size:.9rem}.rider-status{font-size:.75rem}.rider-status.available{color:#10b981}.rider-status.busy{color:#ef4444}.rider-status.offline{color:#6b7280}.rider-item.offline{opacity:.6}.map-container{flex:1;position:relative}.leaflet-map{width:100%;height:100%;min-height:400px}.custom-marker{background:none;border:none}.marker-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;background:#fff;border-radius:50%;box-shadow:0 2px 10px #0003}.restaurant-marker .marker-icon{background:#667eea;font-size:1.25rem}.order-marker .marker-icon{border-radius:50% 50% 50% 0;transform:rotate(-45deg)}.order-marker .marker-icon:after{transform:rotate(45deg)}.map-legend{position:absolute;bottom:1rem;left:1rem;background:var(--bg-card);padding:.75rem 1rem;border-radius:8px;box-shadow:0 2px 10px #0000001a;z-index:1000}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:var(--text-secondary);margin:.25rem 0}.legend-icon{font-size:1rem}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:2000;padding:1rem}.assign-modal{background:var(--bg-card);border-radius:16px;padding:1.5rem;width:100%;max-width:400px;position:relative}.modal-close{position:absolute;top:1rem;right:1rem;background:var(--bg-hover);border:none;width:32px;height:32px;border-radius:50%;font-size:1.25rem;cursor:pointer;color:var(--text-secondary)}.assign-modal h2{margin:0 0 1rem;font-size:1.25rem;color:var(--text-primary)}.order-details{background:var(--bg-hover);padding:1rem;border-radius:8px;margin-bottom:1rem}.order-details p{margin:.25rem 0;font-size:.9rem;color:var(--text-secondary)}.order-details strong{color:var(--text-primary)}.no-riders{text-align:center;color:var(--text-secondary);padding:1rem}.rider-options h4{margin:0 0 .75rem;font-size:.9rem;color:var(--text-secondary)}.rider-option{width:100%;display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--bg-hover);border:2px solid var(--border-color);border-radius:8px;cursor:pointer;margin-bottom:.5rem;transition:all .2s}.rider-option:hover{border-color:var(--primary);background:var(--bg-main)}.rider-option-icon{font-size:1.5rem}.rider-option-name{flex:1;font-weight:500;color:var(--text-primary);text-align:left}.rider-option-phone{font-size:.8rem;color:var(--text-secondary)}@media(max-width:768px){.delivery-content{flex-direction:column}.delivery-sidebar{width:100%;max-height:40vh;border-right:none;border-bottom:1px solid var(--border-color)}.map-container{min-height:50vh}.header-stats{display:none}}:root{--rider-primary: #10b981;--rider-secondary: #3b82f6;--rider-danger: #ef4444;--rider-warning: #f59e0b;--rider-bg: #0f172a;--rider-card: #1e293b;--rider-border: #334155;--rider-text: #f1f5f9;--rider-text-secondary: #94a3b8}.rider-login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--rider-bg) 0%,#1e3a5f 100%);padding:1rem}.rider-login-card{background:var(--rider-card);border-radius:20px;padding:2rem;width:100%;max-width:400px;box-shadow:0 20px 60px #0000004d}.rider-login-header{text-align:center;margin-bottom:2rem}.rider-icon{font-size:4rem;display:block;margin-bottom:1rem}.rider-login-header h1{color:var(--rider-text);margin:0 0 .5rem;font-size:1.75rem}.rider-login-header p{color:var(--rider-text-secondary);margin:0}.rider-login-form .form-group{margin-bottom:1.25rem}.rider-login-form label{display:block;color:var(--rider-text-secondary);font-size:.85rem;margin-bottom:.5rem}.rider-login-form input{width:100%;padding:.875rem 1rem;background:var(--rider-bg);border:2px solid var(--rider-border);border-radius:12px;color:var(--rider-text);font-size:1rem;transition:border-color .2s}.rider-login-form input:focus{outline:none;border-color:var(--rider-primary)}.rider-login-btn{width:100%;padding:1rem;background:linear-gradient(135deg,var(--rider-primary),#059669);border:none;border-radius:12px;color:#fff;font-size:1.1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.rider-login-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 30px #10b9814d}.rider-login-btn:disabled{opacity:.7;cursor:not-allowed}.rider-login-help{text-align:center;color:var(--rider-text-secondary);font-size:.85rem;margin-top:1.5rem}.rider-dashboard{min-height:100vh;background:var(--rider-bg);color:var(--rider-text);display:flex;flex-direction:column}.rider-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:var(--rider-card);border-bottom:1px solid var(--rider-border)}.rider-profile{display:flex;align-items:center;gap:.75rem}.rider-avatar{font-size:2rem}.rider-info{display:flex;flex-direction:column}.rider-name{font-weight:600;font-size:1rem}.rider-restaurant{font-size:.8rem;color:var(--rider-text-secondary)}.rider-header .logout-btn{padding:.5rem 1rem;background:transparent;border:1px solid var(--rider-border);border-radius:8px;color:var(--rider-text-secondary);cursor:pointer}.rider-status-bar{display:flex;gap:.75rem;padding:1rem;background:var(--rider-card)}.status-toggle{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s}.status-toggle.offline{background:var(--rider-border);color:var(--rider-text-secondary)}.status-toggle.online{background:linear-gradient(135deg,var(--rider-primary),#059669);color:#fff}.status-indicator{width:12px;height:12px;border-radius:50%;background:currentColor;animation:pulse 2s infinite}.status-toggle.online .status-indicator{background:#fff}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.availability-toggle{padding:1rem 1.5rem;border:none;border-radius:12px;font-size:.9rem;font-weight:500;cursor:pointer;background:var(--rider-bg);color:var(--rider-text)}.rider-stats{display:grid;grid-template-columns:1fr 1fr;gap:1rem;padding:1rem}.rider-stats .stat-card{background:var(--rider-card);border-radius:12px;padding:1rem;text-align:center}.rider-stats .stat-value{display:block;font-size:1.75rem;font-weight:700;color:var(--rider-primary)}.rider-stats .stat-label{font-size:.8rem;color:var(--rider-text-secondary)}.rider-map-container{position:relative;height:200px;margin:0 1rem;border-radius:12px;overflow:hidden}.rider-map{width:100%;height:100%}.location-badge{position:absolute;top:.5rem;right:.5rem;background:var(--rider-primary);color:#fff;padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:500;z-index:1000}.active-order-card{margin:1rem;background:var(--rider-card);border-radius:16px;padding:1.25rem;border:2px solid var(--rider-primary)}.active-order-card .order-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.active-order-card .order-id{font-weight:700;font-size:1.1rem}.active-order-card .order-status{padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;background:var(--rider-warning);color:#fff}.active-order-card .order-status.out_for_delivery{background:var(--rider-secondary)}.order-customer{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.phone-link{color:var(--rider-secondary);text-decoration:none}.order-address{display:flex;align-items:flex-start;gap:.5rem;padding:.75rem;background:var(--rider-bg);border-radius:8px;margin-bottom:.75rem}.address-icon{font-size:1.25rem}.order-items{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem}.order-item{background:var(--rider-bg);padding:.25rem .5rem;border-radius:4px;font-size:.8rem;color:var(--rider-text-secondary)}.order-total{text-align:right;font-size:1.1rem;margin-bottom:1rem}.order-actions{display:flex;gap:.75rem}.order-actions .action-btn{flex:1;padding:.875rem;border:none;border-radius:10px;font-size:.9rem;font-weight:600;cursor:pointer;text-decoration:none;text-align:center}.action-btn.pickup{background:var(--rider-warning);color:#fff}.action-btn.navigate{background:var(--rider-secondary);color:#fff}.action-btn.complete{background:var(--rider-primary);color:#fff}.pending-orders{flex:1;padding:1rem}.pending-orders h3{margin:0 0 1rem;font-size:1rem;color:var(--rider-text-secondary)}.orders-list{display:flex;flex-direction:column;gap:.75rem}.order-card-mini{background:var(--rider-card);border-radius:12px;padding:1rem}.order-mini-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.order-mini-info{display:flex;flex-direction:column;gap:.25rem}.order-address-mini{font-size:.8rem;color:var(--rider-text-secondary)}.loading-text,.empty-text{text-align:center;color:var(--rider-text-secondary);padding:2rem}.modal-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:flex-end;justify-content:center;z-index:2000}.order-detail-modal{background:var(--rider-card);border-radius:20px 20px 0 0;padding:1.5rem;width:100%;max-width:500px;max-height:80vh;overflow-y:auto;position:relative}.modal-close{position:absolute;top:1rem;right:1rem;background:var(--rider-bg);border:none;width:36px;height:36px;border-radius:50%;font-size:1.5rem;cursor:pointer;color:var(--rider-text)}@media(min-width:768px){.rider-dashboard{max-width:500px;margin:0 auto}}[data-theme=pos]{--primary: #2D8B4E;--primary-hover: #246B3E;--primary-light: #E8F5EC;--bg-main: #E8F5EC;--bg-card: #FFFFFF;--bg-panel: #FFFFFF;--bg-sidebar: #FFFFFF;--bg-hover: #F5F5F5;--bg-input: #FFFFFF;--text-primary: #1A1A1A;--text-secondary: #666666;--text-muted: #999999;--border-color: #E5E5E5;--border-light: #F0F0F0;--shadow-sm: 0 1px 3px rgba(0,0,0,.08);--shadow-md: 0 4px 12px rgba(0,0,0,.1);--success: #2D8B4E;--success-bg: #E8F5EC;--warning: #F59E0B;--warning-bg: #FEF3C7;--error: #EF4444;--error-bg: #FEE2E2;--info: #3B82F6;--info-bg: #DBEAFE}.pos-container{display:flex;height:100vh;background:var(--bg-main);overflow:hidden}.pos-sidebar{width:200px;background:var(--bg-sidebar);border-right:1px solid var(--border-color);display:flex;flex-direction:column;flex-shrink:0;transition:width .3s ease}.pos-sidebar.collapsed{width:70px}.pos-logo{padding:20px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border-light)}.pos-logo-icon{width:44px;height:44px;background:var(--primary);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px}.pos-logo-text{font-weight:700;font-size:16px;color:var(--text-primary)}.pos-logo-text span{color:var(--primary)}.pos-nav{flex:1;padding:16px 12px;display:flex;flex-direction:column;gap:4px}.pos-nav-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:10px;color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer}.pos-nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.pos-nav-item.active{background:var(--primary);color:#fff}.pos-nav-item .icon{width:20px;height:20px;flex-shrink:0}.pos-sidebar-footer{padding:16px;border-top:1px solid var(--border-light)}.pos-user-list{margin-bottom:12px}.pos-user-item{display:flex;align-items:center;gap:10px;padding:8px;border-radius:8px;background:var(--bg-hover)}.pos-user-avatar{width:32px;height:32px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600}.pos-user-name{font-size:13px;color:var(--text-primary);font-weight:500}.pos-logout{display:flex;align-items:center;gap:10px;padding:10px 16px;color:var(--text-secondary);cursor:pointer;border-radius:8px;font-size:14px}.pos-logout:hover{background:var(--error-bg);color:var(--error)}.pos-main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}.pos-topbar{background:transparent;padding:16px 24px;display:flex;align-items:center;gap:16px}.pos-toggle-btn{width:40px;height:40px;border:none;background:var(--bg-card);cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:10px;color:var(--text-secondary);box-shadow:var(--shadow-sm)}.pos-search{flex:1;max-width:400px;position:relative}.pos-search input{width:100%;padding:12px 16px 12px 44px;border:none;border-radius:12px;font-size:14px;background:var(--bg-card);color:var(--text-primary);box-shadow:var(--shadow-sm)}.pos-search input:focus{outline:none;box-shadow:0 0 0 2px var(--primary-light)}.pos-search-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:var(--text-muted)}.pos-categories-bar{display:flex;gap:12px;padding-bottom:16px;overflow-x:auto;flex-shrink:0}.pos-category{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 20px;border-radius:12px;cursor:pointer;min-width:90px;background:var(--bg-card);border:2px solid transparent;color:var(--text-secondary);box-shadow:var(--shadow-sm);transition:all .2s}.pos-category:hover{border-color:var(--primary-light)}.pos-category.active{border-color:var(--primary);background:var(--primary-light);color:var(--primary)}.pos-category-icon-wrapper{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--bg-hover);border-radius:10px}.pos-category.active .pos-category-icon-wrapper{background:#fff}.pos-category-icon{font-size:22px}.pos-category-name{font-size:12px;font-weight:600;white-space:nowrap}.pos-category-count{font-size:10px;color:var(--text-muted)}.pos-category.active .pos-category-count{color:var(--primary)}.pos-content-wrapper{flex:1;display:flex;overflow:hidden;padding:0 10px 10px;gap:24px;min-height:0}.pos-left-panel{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}.pos-left-panel .pos-products{flex:1;overflow-y:auto;min-height:0}.pos-products{flex:1;overflow-y:auto;padding-right:8px;min-height:0}.pos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;padding:1rem}.pos-product-card{position:relative;border-radius:16px;overflow:hidden;aspect-ratio:4/3;cursor:pointer;transition:transform .2s,box-shadow .2s}.pos-product-card:hover{transform:scale(1.02);box-shadow:0 8px 24px #0000004d}.pos-product-card.selected{box-shadow:0 0 0 2px #2d8b4e80,0 4px 12px #0003}.pos-product-card.active{box-shadow:0 0 0 3px var(--primary),0 0 25px #2d8b4e80,0 8px 24px #0000004d;transform:scale(1.02)}.pos-product-image{position:absolute;inset:0;background:#1a1a1a}.pos-product-image img{width:100%;height:100%;object-fit:cover}.pos-product-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:48px;background:linear-gradient(135deg,#2a2a2a,#1a1a1a)}.pos-product-card:before{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,#0000001a,#0000004d,#000000b3);z-index:1;pointer-events:none}.pos-product-info{position:absolute;bottom:0;left:0;right:0;padding:12px;z-index:2;color:#fff}.pos-product-name{font-size:14px;font-weight:600;color:#fff;margin-bottom:2px;line-height:1.2;text-shadow:0 1px 3px rgba(0,0,0,.5)}.pos-product-price{font-size:14px;font-weight:600;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.5)}.pos-product-desc,.pos-product-footer,.pos-product-tag,.pos-product-actions{display:none}.pos-product-qty{display:none;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:4;align-items:center;gap:0;background:#fffffff2;border-radius:30px;padding:4px;box-shadow:0 4px 20px #0000004d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.pos-product-card.active .pos-product-qty{display:flex}.pos-product-qty-badge{position:absolute;top:10px;right:10px;z-index:4;min-width:28px;height:28px;background:var(--primary);color:#fff;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;box-shadow:0 2px 8px #2d8b4e66;padding:0 8px}.pos-product-qty .pos-qty-btn{width:36px;height:36px;border:none;background:var(--primary);color:#fff;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:500;transition:all .15s ease}.pos-product-qty .pos-qty-btn:hover{background:var(--primary-hover);transform:scale(1.1)}.pos-product-qty .pos-qty-btn:active{transform:scale(.95)}.pos-product-qty .pos-qty-value{min-width:40px;height:36px;line-height:36px;text-align:center;font-weight:700;color:var(--text-primary);font-size:18px;background:#fff}.pos-product-card:not(.selected):after{content:"+";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.8);width:56px;height:56px;background:var(--primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:300;z-index:3;opacity:0;transition:all .25s cubic-bezier(.34,1.56,.64,1);box-shadow:0 4px 20px #2d8b4e80}.pos-product-badge{position:absolute;top:10px;left:10px;background:linear-gradient(135deg,#ff6b6b,#ee5a5a);color:#fff;padding:4px 10px;border-radius:8px;font-size:11px;font-weight:700;z-index:2;box-shadow:0 2px 8px #ee5a5a66;text-transform:uppercase;letter-spacing:.5px}.pos-product-card:not(.selected):hover:after{transform:translate(-50%,-50%) scale(1);opacity:1}.pos-qty-selector,.pos-add-btn{display:none!important}.pos-add-btn:hover{background:var(--primary-hover)}.pos-qty-selector{display:flex;align-items:center;gap:0;border:2px solid var(--primary);border-radius:8px;overflow:hidden}.pos-qty-btn{width:36px;height:36px;border:none;background:var(--primary);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center}.pos-qty-btn.minus,.pos-qty-btn.plus{background:var(--primary)}.pos-qty-value{min-width:40px;text-align:center;font-weight:600;color:var(--text-primary);background:#fff;height:36px;line-height:36px}.pos-order-panel{width:340px;background:var(--bg-panel);border-radius:16px;display:flex;flex-direction:column;flex-shrink:0;box-shadow:var(--shadow-sm);overflow:hidden}.pos-order-header{padding:20px;border-bottom:1px solid var(--border-light)}.pos-table-info{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.pos-table-number{font-size:22px;font-weight:700;color:var(--text-primary)}.pos-table-customer{font-size:13px;color:var(--text-secondary)}.pos-edit-btn{width:36px;height:36px;border:1px solid var(--border-color);background:transparent;border-radius:8px;cursor:pointer;color:var(--text-secondary);display:flex;align-items:center;justify-content:center}.pos-service-tabs{display:flex;gap:8px}.pos-service-tab{flex:1;padding:10px 8px;border:1px solid var(--border-color);background:transparent;border-radius:8px;font-size:12px;font-weight:500;cursor:pointer;color:var(--text-secondary);transition:all .2s}.pos-service-tab.active{background:var(--primary);border-color:var(--primary);color:#fff}.pos-order-items{flex:1;overflow-y:auto;padding:16px 20px;min-height:0}.pos-empty-cart{text-align:center;color:var(--text-muted);padding:40px 0;font-size:14px}.pos-cart-header{display:flex;justify-content:space-between;align-items:center;padding:8px 0 12px;border-bottom:1px solid var(--border-color);margin-bottom:8px}.pos-cart-header span{font-size:13px;font-weight:600;color:var(--text-primary)}.pos-clear-cart{display:flex;align-items:center;gap:4px;padding:6px 12px;border:none;background:var(--error-bg);color:var(--error);border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s}.pos-clear-cart:hover{background:var(--error);color:#fff}.pos-clear-cart svg{width:14px;height:14px}.pos-existing-orders-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;padding:8px 0;border-bottom:1px dashed var(--border-color);margin-bottom:8px}.pos-cart-item{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--border-light)}.pos-cart-item:last-child{border-bottom:none}.pos-cart-item.existing{opacity:.7}.pos-cart-item-remove{width:28px;height:28px;border:none;background:transparent;color:var(--text-muted);border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s;margin-left:8px}.pos-cart-item-remove:hover{background:var(--error-bg);color:var(--error)}.pos-cart-item-remove svg{width:16px;height:16px}.pos-cart-item-image{width:50px;height:50px;border-radius:10px;background:var(--bg-hover);overflow:hidden;display:flex;align-items:center;justify-content:center;flex-shrink:0}.pos-cart-item-image img{width:100%;height:100%;object-fit:cover}.pos-cart-item-image span{font-size:24px}.pos-cart-item-details{flex:1;min-width:0}.pos-cart-item-name{font-size:13px;font-weight:600;color:var(--text-primary);margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pos-cart-item-meta{display:flex;align-items:center;gap:8px}.pos-cart-item-price{font-size:13px;color:var(--primary);font-weight:500}.pos-cart-item-qty{font-size:12px;color:var(--text-muted)}.pos-cart-item-total{font-size:14px;font-weight:600;color:var(--text-primary)}.pos-order-summary{padding:20px;border-top:1px solid var(--border-color)}.pos-summary-row{display:flex;justify-content:space-between;margin-bottom:8px;font-size:14px;color:var(--text-secondary)}.pos-summary-row.total{font-size:18px;font-weight:700;color:var(--text-primary);margin-top:12px;padding-top:12px;border-top:1px solid var(--border-color)}.pos-payment-methods{display:flex;gap:10px;margin:16px 0}.pos-payment-btn{flex:1;padding:12px 8px;border:1px solid var(--border-color);background:transparent;border-radius:10px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:6px;color:var(--text-secondary);font-size:10px;transition:all .2s}.pos-payment-btn:hover{border-color:var(--primary)}.pos-payment-btn.active{border-color:var(--primary);background:var(--primary-light);color:var(--primary)}.pos-payment-btn svg{width:20px;height:20px}.pos-place-order{width:100%;padding:16px;background:var(--primary);color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:background .2s}.pos-place-order:hover{background:var(--primary-hover)}.pos-place-order:disabled{background:var(--text-muted);cursor:not-allowed}.pos-close-table{width:100%;padding:12px;margin-top:10px;background:transparent;border:2px solid var(--error);color:var(--error);border-radius:12px;font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px}.pos-close-table:hover{background:var(--error-bg)}.pos-table-tabs{display:flex;gap:12px;padding:12px 0;overflow-x:auto;flex-shrink:0}.pos-table-tab{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg-card);border:2px solid transparent;border-radius:12px;cursor:pointer;min-width:150px;box-shadow:var(--shadow-sm);transition:all .2s}.pos-table-tab:hover{border-color:var(--primary-light)}.pos-table-tab.active{border-color:var(--primary);background:var(--primary-light)}.pos-tab-number{width:40px;height:40px;background:var(--primary);color:#fff;border-radius:10px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px}.pos-tab-info{flex:1}.pos-tab-customer{font-size:13px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pos-tab-meta{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--text-muted)}.pos-tab-status{padding:2px 8px;border-radius:4px;font-size:10px;font-weight:600}.pos-tab-status.active{background:var(--info-bg);color:var(--info)}.pos-tab-status.billing{background:var(--warning-bg);color:var(--warning)}.pos-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.pos-modal{background:var(--bg-card);border-radius:16px;width:100%;max-width:500px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.pos-modal-large{max-width:600px}.pos-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border-color)}.pos-modal-header h2{font-size:18px;font-weight:600;color:var(--text-primary)}.pos-modal-close{width:32px;height:32px;border:none;background:transparent;cursor:pointer;border-radius:8px;color:var(--text-secondary);display:flex;align-items:center;justify-content:center}.pos-modal-body{padding:24px;overflow-y:auto}.pos-modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:20px 24px;border-top:1px solid var(--border-color)}.pos-modal-footer-multi{flex-wrap:wrap}.pos-modal-actions{display:flex;gap:8px}.pos-btn-cancel,.pos-btn-primary,.pos-btn-secondary{padding:12px 24px;border-radius:10px;font-size:14px;font-weight:500;cursor:pointer;border:none;display:flex;align-items:center;gap:8px}.pos-btn-cancel{background:var(--bg-hover);color:var(--text-secondary)}.pos-btn-primary{background:var(--primary);color:#fff}.pos-btn-primary:disabled{background:var(--text-muted);cursor:not-allowed}.pos-btn-secondary{background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-primary)}.pos-table-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px}.pos-table-option{padding:16px;border:2px solid var(--border-color);border-radius:12px;text-align:center;cursor:pointer;transition:all .2s}.pos-table-option:hover,.pos-table-option.selected{border-color:var(--primary);background:var(--primary-light)}.pos-table-option-number{font-size:16px;font-weight:600;color:var(--text-primary)}.pos-table-option-info{font-size:12px;color:var(--text-muted);margin-top:4px}.pos-open-form{border-top:1px solid var(--border-color);padding-top:20px}.pos-form-group{margin-bottom:16px}.pos-form-group label{display:block;font-size:14px;font-weight:500;color:var(--text-primary);margin-bottom:8px}.pos-form-group input{width:100%;padding:12px 16px;border:1px solid var(--border-color);border-radius:10px;font-size:14px;background:var(--bg-input);color:var(--text-primary)}.pos-receipt{background:var(--bg-main);border-radius:12px;padding:24px}.pos-receipt-header{text-align:center;padding-bottom:16px;border-bottom:1px dashed var(--border-color);margin-bottom:16px}.pos-receipt-header h3{font-size:18px;font-weight:700;margin-bottom:8px}.pos-receipt-header p{font-size:13px;color:var(--text-secondary);margin:4px 0}.pos-receipt-orders{margin-bottom:16px}.pos-receipt-order{background:var(--bg-card);border-radius:8px;padding:12px;margin-bottom:12px}.pos-receipt-order-header{display:flex;justify-content:space-between;font-size:13px;font-weight:600;padding-bottom:8px;border-bottom:1px dashed var(--border-color);margin-bottom:8px}.pos-receipt-item{display:flex;align-items:center;padding:6px 0;font-size:13px}.pos-receipt-item-qty{width:30px;color:var(--text-muted)}.pos-receipt-item-name{flex:1}.pos-receipt-item-price{font-weight:500}.pos-receipt-summary{border-top:2px solid var(--text-primary);padding-top:16px}.pos-receipt-row{display:flex;justify-content:space-between;padding:6px 0;font-size:14px}.pos-receipt-row.pos-receipt-total{font-size:18px;font-weight:700;padding-top:12px;margin-top:8px;border-top:1px solid var(--border-color)}.pos-receipt-qr{text-align:center;padding-top:16px;margin-top:16px;border-top:1px dashed var(--border-color)}.pos-receipt-qr p{font-size:12px;color:var(--text-muted);margin-bottom:12px}.pos-receipt-qr img{width:120px;height:120px}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton-box,.skeleton-text,.skeleton-icon{background:linear-gradient(90deg,var(--bg-hover) 25%,var(--border-light) 50%,var(--bg-hover) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:8px}.skeleton-text{height:14px}.skeleton-icon{width:40px;height:40px}.pos-product-card.skeleton .pos-product-image{background:linear-gradient(90deg,var(--bg-hover) 25%,var(--border-light) 50%,var(--bg-hover) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}.pos-category.skeleton{pointer-events:none}.btn-spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@media(max-width:1200px){.pos-order-panel{width:300px}.pos-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}}@media(max-width:992px){.pos-sidebar{position:fixed;left:-200px;top:0;height:100vh;z-index:100;transition:left .3s}.pos-sidebar.open{left:0}}@media print{body *{visibility:hidden}.pos-modal-overlay,.pos-modal-overlay *{visibility:visible}.pos-modal-overlay{position:absolute;left:0;top:0;width:100%;background:#fff!important}.pos-modal{max-width:80mm;margin:0 auto;box-shadow:none}.pos-modal-footer{display:none!important}.pos-receipt{background:#fff!important;font-size:11px}}.bill-container{min-height:100vh;background:linear-gradient(135deg,#e8f5e9,#c8e6c9);padding:20px;display:flex;justify-content:center;align-items:flex-start}.bill-card{background:#fff;border-radius:20px;box-shadow:0 10px 40px #0000001a;max-width:420px;width:100%;overflow:hidden}.bill-header{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;padding:24px;text-align:center}.bill-header h1{font-size:24px;font-weight:700;margin-bottom:4px}.bill-address{font-size:13px;opacity:.9;margin-bottom:16px}.bill-table-info{display:flex;justify-content:center;align-items:center;gap:12px;margin-bottom:8px}.bill-table-badge{background:#fff3;padding:6px 16px;border-radius:20px;font-weight:600;font-size:14px}.bill-customer{font-size:14px;opacity:.9}.bill-date{font-size:12px;opacity:.8}.bill-status{padding:16px 24px;border-bottom:1px solid #e5e7eb}.bill-status-badge{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;border-radius:12px;font-weight:600;font-size:14px}.bill-status-badge.active{background:#dbeafe;color:#1d4ed8}.bill-status-badge.billing{background:#fef3c7;color:#b45309}.bill-status-badge.closed{background:#dcfce7;color:#166534}.bill-orders{padding:16px 24px}.bill-order{background:#f9fafb;border-radius:12px;padding:16px;margin-bottom:12px}.bill-order:last-child{margin-bottom:0}.bill-order-header{display:flex;justify-content:space-between;align-items:center;font-size:13px;font-weight:600;color:#374151;padding-bottom:12px;border-bottom:1px dashed #d1d5db;margin-bottom:12px}.bill-order-time{color:#6b7280;font-weight:400}.bill-order-items{display:flex;flex-direction:column;gap:8px}.bill-item{display:flex;justify-content:space-between;align-items:center;font-size:14px}.bill-item-info{display:flex;align-items:center;gap:8px}.bill-item-qty{color:#6b7280;font-size:13px;min-width:28px}.bill-item-name{color:#1f2937}.bill-item-price{font-weight:500;color:#1f2937}.bill-empty{text-align:center;padding:40px 20px;color:#9ca3af}.bill-empty span{font-size:48px;display:block;margin-bottom:12px}.bill-empty p{font-size:14px}.bill-summary{padding:20px 24px;background:#f9fafb;border-top:1px solid #e5e7eb}.bill-row{display:flex;justify-content:space-between;padding:8px 0;font-size:14px;color:#6b7280}.bill-row.bill-total{font-size:20px;font-weight:700;color:#1f2937;padding-top:16px;margin-top:8px;border-top:2px solid #22c55e}.bill-row.bill-total span:last-child{color:#22c55e}.bill-footer{padding:20px 24px;text-align:center;border-top:1px solid #e5e7eb}.bill-footer p{font-size:13px;color:#6b7280;margin-bottom:4px}.bill-footer-small{font-size:11px!important;color:#9ca3af!important}.bill-loading{text-align:center;padding:60px 20px}.bill-spinner{width:40px;height:40px;border:3px solid #e5e7eb;border-top-color:#22c55e;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 16px}@keyframes spin{to{transform:rotate(360deg)}}.bill-loading p{color:#6b7280;font-size:14px}.bill-error{text-align:center;padding:60px 20px;background:#fff;border-radius:20px;max-width:400px}.bill-error-icon{font-size:48px;display:block;margin-bottom:16px}.bill-error h2{font-size:18px;color:#1f2937;margin-bottom:8px}.bill-error p{font-size:14px;color:#6b7280}@media(max-width:480px){.bill-container{padding:0}.bill-card{border-radius:0;min-height:100vh}}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f5f5}input,button,textarea,select{font-family:inherit}a{color:inherit}img{max-width:100%;height:auto}
