:root{--primary: #f97316;--primary-dark: #ea580c;--primary-light: #fdba74;--secondary: #1e293b;--accent: #0ea5e9;--success: #22c55e;--warning: #f59e0b;--danger: #ef4444;--bg: #f8fafc;--bg-white: #ffffff;--bg-card: #ffffff;--text: #1e293b;--text-light: #64748b;--text-lighter: #94a3b8;--border: #e2e8f0;--border-light: #f1f5f9;--shadow: 0 1px 3px rgba(0, 0, 0, .08), 0 1px 2px rgba(0, 0, 0, .06);--shadow-md: 0 4px 6px rgba(0, 0, 0, .07), 0 2px 4px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1), 0 4px 6px rgba(0, 0, 0, .05);--radius: 12px;--radius-sm: 8px;--radius-lg: 16px;--max-width: 1200px;--transition: .2s ease}[data-theme=vendor]{--primary: #15803d;--primary-dark: #166534;--primary-light: #86efac;--accent: #22c55e;--bg: #f8fafc;--bg-card: #ffffff;--border-light: #e2e8f0;--navbar-bg-start: #f0fdf4;--navbar-bg-end: #dcfce7}[data-theme=vendor] .navbar{background:#14532d;border-bottom:1px solid #166534;box-shadow:0 1px 8px #0000001f}[data-theme=vendor] .tab-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}[data-theme=admin]{--primary: #7c3aed;--primary-dark: #6d28d9;--primary-light: #c4b5fd;--accent: #ec4899;--bg: #f5f3ff;--bg-card: #ffffff;--border-light: #ede9fe;--navbar-bg-start: #3b0764;--navbar-bg-end: #581c87}[data-theme=admin] .navbar{background:linear-gradient(135deg,var(--navbar-bg-start) 0%,var(--navbar-bg-end) 100%);border-bottom:none;box-shadow:0 2px 12px #3b076466}[data-theme=admin] .tab-btn.active{background:#7c3aed;color:#fff;border-color:#7c3aed}[data-theme=admin] .admin-stat-card.revenue-card{border-color:#c4b5fd;background:#faf5ff}[data-theme=vendor] .navbar-logo{color:var(--primary)}[data-theme=vendor] .nav-link{color:#bbf7d0}[data-theme=vendor] .nav-link:hover{color:#86efac;background:#ffffff14}[data-theme=vendor] .nav-user-name{color:#f0fdf4}[data-theme=vendor] .navbar .btn-outline{border-color:#4ade80;color:#bbf7d0}[data-theme=vendor] .navbar .btn-outline:hover{background:#ffffff1a;border-color:#86efac;color:#fff}[data-theme=vendor] .notification-bell-btn{color:#bbf7d0}[data-theme=vendor] .notification-bell-btn:hover{background:#ffffff1a}[data-theme=vendor] .nav-link.active{color:#fff;background:#ffffff1f}[data-theme=vendor] .navbar-logo{color:#4ade80}[data-theme=vendor] .logo-text{color:#f0fdf4}[data-theme=vendor] .nav-user-trigger{color:#f0fdf4}[data-theme=vendor] .nav-user-trigger:hover{background:#ffffff1a}[data-theme=vendor] .nav-user-chevron{color:#86efac}[data-theme=admin] .navbar-logo{color:#fff}[data-theme=admin] .nav-link{color:#ffffffbf}[data-theme=admin] .nav-link:hover{color:#fff;background:#ffffff26}[data-theme=admin] .nav-user-name{color:#fff}[data-theme=admin] .navbar .btn-outline{border-color:#ffffff80;color:#fff}[data-theme=admin] .navbar .btn-outline:hover{background:#ffffff26;border-color:#fff}[data-theme=admin] .notification-bell-btn:hover{background:#ffffff26}[data-theme=admin] .nav-link.active{color:#fff;background:#ffffff2e}[data-theme=admin] .role-badge,.role-badge{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.4);padding:.18rem .6rem;border-radius:999px;font-size:.68rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase}[data-theme=vendor] .role-badge{background:#4ade8033;color:#86efac;border:1px solid rgba(74,222,128,.35)}[data-theme=customer] .role-badge{background:#f9731633;color:#fdba74;border:1px solid rgba(249,115,22,.35)}[data-theme=customer] .navbar{background:#1e293b;border-bottom:1px solid #334155;box-shadow:0 1px 8px #0000001f}[data-theme=customer] .navbar-logo,:not([data-theme]) .navbar-logo{color:#f97316}[data-theme=customer] .navbar-flat{font-weight:700;text-transform:uppercase;color:#cbd5e1}[data-theme=customer] .logo-text{color:#f1f5f9}[data-theme=customer] .nav-link{color:#cbd5e1}[data-theme=customer] .nav-link:hover{color:#f97316}[data-theme=customer] .nav-user-name{color:#f1f5f9}[data-theme=customer] .notification-bell-btn{color:#cbd5e1}[data-theme=customer] .notification-bell-btn:hover{background:#ffffff1a}[data-theme=customer] .nav-user-trigger{color:#f1f5f9}[data-theme=customer] .nav-user-trigger:hover{background:#ffffff1a}[data-theme=customer] .nav-user-chevron{color:#94a3b8}[data-theme=customer] .navbar .btn-outline{color:#cbd5e1;border-color:#475569}[data-theme=customer] .navbar .btn-outline:hover{background:#ffffff1a;color:#fff}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background-color:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased}a{text-decoration:none;color:inherit}img{max-width:100%;height:auto;display:block}ul{list-style:none}button{cursor:pointer;font-family:inherit}input,textarea,select{font-family:inherit;font-size:1rem}.app-layout{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1}.page-container{max-width:var(--max-width);margin:0 auto;padding:2rem 1.5rem}.page-subtitle{color:var(--text-light);margin-bottom:1.5rem;font-size:1.05rem}.profile-card{background:var(--bg-card);border-radius:var(--radius);padding:2rem;box-shadow:var(--shadow);max-width:480px}.profile-info{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-light)}.profile-info p{margin-bottom:.5rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-weight:600;border:2px solid transparent;border-radius:var(--radius-sm);padding:.65rem 1.5rem;font-size:.95rem;transition:all var(--transition);white-space:nowrap}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-primary:hover{background:var(--primary-dark);border-color:var(--primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-outline{background:transparent;color:var(--text);border-color:var(--border)}.btn-outline:hover{border-color:var(--primary);color:var(--primary)}.btn-danger{background:var(--danger);color:#fff;border-color:var(--danger)}.btn-danger:hover{background:#dc2626}.btn-sm{padding:.4rem 1rem;font-size:.85rem}.btn-lg{padding:.85rem 2rem;font-size:1.1rem}.btn-full{width:100%}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.navbar{background:var(--bg-white);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;box-shadow:var(--shadow)}.navbar-container{max-width:var(--max-width);margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem}.navbar-logo{display:flex;align-items:center;gap:.5rem;font-size:1.4rem;font-weight:800;color:var(--primary);position:relative;z-index:1}.logo-icon{font-size:1.6rem}.logo-icon{font-size:1.6rem;line-height:1;flex-shrink:0}.navbar-links{display:flex;align-items:center;gap:1rem}.nav-link{color:var(--text-light);font-weight:500;padding:.4rem .75rem;border-radius:var(--radius-sm);transition:all var(--transition);font-size:.95rem}.nav-link:hover{color:var(--primary);background:#0000000d}.cart-link{position:relative}.cart-badge{position:absolute;top:-4px;right:-8px;background:var(--primary);color:#fff;font-size:.7rem;font-weight:700;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center}.nav-user-wrap{position:relative}.nav-user-trigger{display:flex;align-items:center;gap:.35rem;padding:.35rem .75rem;border-radius:var(--radius-sm);background:none;border:1px solid var(--border);cursor:pointer;font-size:.95rem;transition:background var(--transition)}.nav-user-trigger:hover{background:#0000000d}.nav-user-name{font-weight:600;color:var(--text);font-size:.95rem}.nav-user-chevron{font-size:.6rem;color:var(--text-light)}.nav-user-dropdown{position:absolute;top:calc(100% + .5rem);right:0;min-width:140px;background:var(--bg-card);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);border:1px solid var(--border);overflow:hidden;z-index:100}.nav-user-dropdown-item{display:block;width:100%;padding:.65rem 1rem;text-align:left;border:none;background:none;color:var(--text);font-size:.9rem;text-decoration:none;cursor:pointer;transition:background var(--transition)}.nav-user-dropdown-item:hover{background:var(--border-light)}.nav-user-dropdown-logout{color:var(--danger);font-weight:500}[data-theme=vendor] .nav-user-trigger{border-color:var(--border);color:var(--text)}[data-theme=vendor] .nav-user-trigger:hover{background:#15803d14}[data-theme=vendor] .nav-user-chevron{color:var(--text-light)}[data-theme=admin] .nav-user-trigger{border-color:#ffffff80;color:#fff}[data-theme=admin] .nav-user-trigger:hover{background:#ffffff26}[data-theme=admin] .nav-user-chevron{color:#fffc}.navbar-flat{font-size:.75rem;color:var(--text-light);min-width:0;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-auth{display:flex;gap:.5rem}.footer{background:var(--secondary);color:#cbd5e1;margin-top:auto}.footer-container{max-width:var(--max-width);margin:0 auto;padding:3rem 1.5rem;display:grid;grid-template-columns:2fr 1fr 1fr;gap:2rem}.footer-section h3,.footer-section h4{color:#fff;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.footer-section h3 .logo-icon{font-size:1.5rem}.footer-section p{line-height:1.7;font-size:.95rem}.footer-section ul li{margin-bottom:.5rem;font-size:.9rem}.footer-section ul li a:hover{color:var(--primary-light)}.footer-bottom{border-top:1px solid #334155;text-align:center;padding:1.5rem;font-size:.85rem;color:#94a3b8}.hero{background:linear-gradient(135deg,#1e293b,#334155);padding:5rem 1.5rem;text-align:center}.hero-content{max-width:700px;margin:0 auto}.hero h1{font-size:3rem;font-weight:800;color:#fff;line-height:1.2;margin-bottom:1rem}.hero p{font-size:1.2rem;color:#94a3b8;margin-bottom:2rem;line-height:1.7}.hero-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.hero-actions .btn-outline{color:#fff;border-color:#ffffff4d}.hero-actions .btn-outline:hover{border-color:#fff;color:#fff}.section{max-width:var(--max-width);margin:0 auto;padding:3rem 1.5rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.section-header h2{font-size:1.75rem;font-weight:700}.view-all-link{color:var(--primary);font-weight:600;transition:color var(--transition)}.view-all-link:hover{color:var(--primary-dark)}.home-page{max-width:var(--max-width);margin:0 auto;padding:1.25rem 1.5rem 2rem}.home-header{margin-bottom:1rem}.home-header h2{font-size:1.4rem;font-weight:700;margin:0}.home-subtitle{font-size:.88rem;color:var(--text-light);margin:.2rem 0 0}.home-search-bar{margin-bottom:.75rem}.how-it-works{background:#fff;padding:4rem 1.5rem;text-align:center}.how-it-works h2{font-size:1.75rem;margin-bottom:2rem}.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;max-width:var(--max-width);margin:0 auto}.step-card{padding:2rem}.step-icon{font-size:3rem;margin-bottom:1rem}.step-card h3{font-size:1.2rem;margin-bottom:.5rem}.step-card p{color:var(--text-light)}.vendor-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1.5rem}.vendor-card{background:var(--bg-card);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:all var(--transition);display:block}.vendor-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.vendor-card-image{position:relative;height:200px;overflow:hidden}.vendor-card-image img,.vendor-card-image .image-placeholder{width:100%;height:100%;object-fit:cover}.image-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--border-light);color:var(--text-lighter);gap:.5rem}.image-placeholder.vendor-placeholder{min-height:200px}.image-placeholder.menu-item-placeholder{min-height:100%;min-width:100%}.image-placeholder .placeholder-text{font-size:.75rem;font-weight:500}.image-placeholder span:first-child{font-size:2rem}.vendor-detail-image.image-placeholder{width:400px;height:280px;min-height:280px}.menu-list-image.image-placeholder{width:70px;height:70px;min-width:70px;min-height:70px}.admin-vendor-thumb.image-placeholder{width:36px;height:36px;min-width:36px;min-height:36px}.vendor-approval-img.image-placeholder,.cart-item-image.image-placeholder{width:80px;height:80px;min-width:80px;min-height:80px}.vendor-closed-badge{position:absolute;top:12px;right:12px;background:#ef4444e6;color:#fff;padding:.25rem .75rem;border-radius:999px;font-size:.8rem;font-weight:600}.vendor-card-info{padding:1.25rem}.vendor-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem}.vendor-card-header h3{font-size:1.15rem;font-weight:700}.vendor-rating{font-size:.9rem;font-weight:600;color:var(--warning)}.vendor-cuisine{color:var(--primary);font-weight:600;font-size:.85rem;margin-bottom:.5rem}.vendor-description{color:var(--text-light);font-size:.9rem;line-height:1.5;margin-bottom:.75rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.vendor-card-meta{display:flex;gap:1rem;font-size:.85rem;color:var(--text-light)}.vendor-detail-header{display:flex;gap:2rem;margin-bottom:2rem;background:#fff;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow)}.vendor-detail-image{width:400px;height:280px;object-fit:cover;flex-shrink:0}.vendor-detail-info{padding:2rem;display:flex;flex-direction:column;justify-content:center}.vendor-detail-info h1{font-size:2rem;margin-bottom:.5rem}.vendor-cuisine-tag{display:inline-block;background:#fff7ed;color:var(--primary);padding:.25rem .75rem;border-radius:999px;font-weight:600;font-size:.85rem;margin-bottom:.75rem}.vendor-meta{display:flex;gap:1.5rem;margin-top:1rem;font-size:.95rem;color:var(--text-light)}.menu-section h2{font-size:1.5rem;margin-bottom:1rem}.category-filters{display:flex;gap:.5rem;margin-bottom:1.5rem;flex-wrap:wrap}.category-btn{padding:.4rem 1rem;border:2px solid var(--border);border-radius:999px;background:#fff;font-size:.85rem;font-weight:500;color:var(--text-light);cursor:pointer;transition:all var(--transition)}.category-btn:hover{border-color:var(--primary);color:var(--primary)}.category-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.menu-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:.75rem}.mic{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);display:flex;transition:box-shadow .2s}.mic:hover{box-shadow:var(--shadow-md)}.mic-disabled{opacity:.55;pointer-events:none}.mic-img{width:110px;min-height:110px;flex-shrink:0;position:relative;overflow:hidden}.mic-img img{width:100%;height:100%;object-fit:cover}.mic-preorder-flag{position:absolute;top:6px;left:0;font-size:.62rem;font-weight:700;color:#92400e;background:#fef3c7;padding:1px 8px 1px 6px;border-radius:0 999px 999px 0;box-shadow:0 1px 3px #0000001f}.mic-body{padding:.65rem .75rem;display:flex;flex-direction:column;flex:1;min-width:0;gap:.3rem}.mic-top{display:flex;justify-content:space-between;align-items:baseline;gap:.5rem}.mic-name{font-size:.92rem;font-weight:700;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mic-price{font-weight:800;color:var(--primary);font-size:.95rem;white-space:nowrap}.mic-desc{color:var(--text-light);font-size:.78rem;line-height:1.3;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.mic-tags{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.mic-category{font-size:.65rem;font-weight:600;color:var(--text-light);background:var(--border-light);padding:1px 7px;border-radius:4px}.mic-stock{font-size:.65rem;font-weight:600;color:var(--text-light)}.mic-stock-low{color:#ea580c}.mic-stock-out{color:var(--danger);font-weight:700}.mic-preorder-eta{font-size:.68rem;font-weight:600;color:#059669;background:#ecfdf5;border-radius:6px;padding:3px 8px;width:fit-content}.mic-footer{margin-top:auto;padding-top:.25rem}.mic-add-btn{display:inline-block;padding:.35rem 1rem;font-size:.78rem;font-weight:700;color:#fff;background:var(--primary);border:none;border-radius:var(--radius-sm);cursor:pointer;transition:background .15s,transform .1s}.mic-add-btn:hover{background:var(--primary-dark)}.mic-add-btn:active{transform:scale(.97)}.mic-add-btn:disabled{background:var(--border-light);color:var(--text-light);cursor:not-allowed}.mic-notice{font-size:.75rem;font-weight:600;color:var(--danger)}@media (max-width: 480px){.menu-grid{grid-template-columns:1fr;gap:.5rem}.mic-img{width:90px;min-height:90px}.mic-body{padding:.5rem .6rem}.mic-name{font-size:.85rem}.mic-price{font-size:.88rem}}border: 1.5px solid var(--border-light); border-radius: var(--radius); padding: 1rem; background: #fefce8; } .preorder-toggle-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-weight:600;font-size:.92rem}.preorder-checkbox{width:1.1rem;height:1.1rem;accent-color:#f59e0b;cursor:pointer}.preorder-hours-input{margin-top:.75rem;padding-top:.75rem;border-top:1px solid #fde68a}.preorder-hours-input label{display:block;font-size:.82rem;font-weight:600;margin-bottom:.3rem;color:var(--text)}.preorder-hours-input input{width:100px;padding:.4rem .6rem;border:1px solid #fbbf24;border-radius:var(--radius-sm);font-size:.88rem}.preorder-hours-hint{display:block;font-size:.75rem;color:#a16207;margin-top:.3rem}.vml-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.vml-disabled{opacity:.5}.vml-top{display:flex;gap:.75rem;padding:.75rem}.vml-img{width:56px;height:56px;border-radius:8px;object-fit:cover;flex-shrink:0}.vml-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.2rem}.vml-name-row{display:flex;justify-content:space-between;align-items:baseline;gap:.5rem}.vml-name-row h4{font-size:.9rem;font-weight:700;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.vml-price{font-weight:800;color:var(--primary);font-size:.9rem;white-space:nowrap}.vml-desc{font-size:.75rem;color:var(--text-light);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.vml-tags{display:flex;align-items:center;gap:.35rem;flex-wrap:wrap;margin-top:.15rem}.vml-category{font-size:.62rem;font-weight:600;color:var(--text-light);background:var(--border-light);padding:1px 6px;border-radius:4px}.vml-stock{font-size:.62rem;font-weight:600;color:var(--text-light)}.vml-stock-low{color:#ea580c}.vml-stock-out{color:var(--danger)}.vml-preorder{font-size:.6rem;font-weight:700;color:#92400e;background:#fef3c7;padding:1px 6px;border-radius:4px}.vml-status{font-size:.6rem;font-weight:700}.vml-active{color:#059669}.vml-inactive{color:#9ca3af}.vml-actions{display:flex;border-top:1px solid var(--border-light)}.vml-btn{flex:1;padding:.45rem 0;font-size:.72rem;font-weight:600;border:none;background:none;cursor:pointer;transition:background .15s;color:var(--text-light)}.vml-btn:not(:last-child){border-right:1px solid var(--border-light)}.vml-btn:hover{background:var(--border-light)}.vml-btn-enable{color:var(--primary)}.vml-btn-disable{color:#9ca3af}.vml-btn-edit{color:var(--text)}.vml-btn-delete{color:var(--danger)}.floating-cart{position:fixed;bottom:2rem;left:50%;transform:translate(-50%);z-index:50;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.browse-filters{margin-bottom:1.5rem}.search-input{width:100%;padding:.85rem 1.25rem;border:2px solid var(--border);border-radius:var(--radius);font-size:1rem;background:#fff;margin-bottom:1rem;transition:border-color var(--transition)}.search-input:focus{outline:none;border-color:var(--primary)}.cuisine-filters{display:flex;gap:.5rem;flex-wrap:wrap}.results-count{color:var(--text-light);margin-bottom:1.5rem;font-size:.9rem}.auth-page{display:flex;justify-content:center;padding:3rem 1.5rem}.auth-container{width:100%;max-width:440px;background:#fff;padding:2.5rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.auth-container h1{font-size:1.75rem;margin-bottom:.25rem}.auth-subtitle{color:var(--text-light);margin-bottom:1.5rem}.auth-form{display:flex;flex-direction:column;gap:1rem}.auth-form .btn-full{margin-top:.75rem}.auth-switch{text-align:center;color:var(--text-light);font-size:.9rem}.auth-switch a{color:var(--primary);font-weight:600}.demo-credentials{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:var(--radius-sm);padding:1rem;font-size:.8rem;color:#15803d;margin-top:.5rem}.demo-credentials p{margin-bottom:.25rem}.form-group{display:flex;flex-direction:column;gap:.35rem}.form-group label{font-weight:600;font-size:.9rem;color:var(--text)}.form-group input,.form-group textarea,.form-group select{padding:.7rem 1rem;border:2px solid var(--border);border-radius:var(--radius-sm);font-size:.95rem;transition:border-color var(--transition);background:#fff}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--primary)}.form-group input:disabled{background:var(--border-light);color:var(--text-light)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-actions{display:flex;gap:.75rem;margin-top:.5rem}.role-selector,.toggle-group{display:flex;gap:.5rem}.role-btn{flex:1;padding:.65rem;border:2px solid var(--border);border-radius:var(--radius-sm);background:#fff;font-size:.9rem;font-weight:500;cursor:pointer;transition:all var(--transition)}.role-btn.active{border-color:var(--primary);background:#fff7ed;color:var(--primary)}.status-toggle-switch{display:inline-flex;align-items:center;gap:.75rem;cursor:pointer;font-size:.9rem;font-weight:600}.status-toggle-switch .switch-label{color:var(--text-light);transition:color .2s ease}.status-toggle-switch.is-open .switch-open{color:#059669}.status-toggle-switch.is-closed .switch-closed{color:#dc2626}.switch-track{position:relative;width:48px;height:26px;border-radius:13px;background:#d1d5db;transition:background .2s ease}.status-toggle-switch.is-open .switch-track{background:#10b981}.status-toggle-switch.is-closed .switch-track{background:#ef4444}.switch-thumb{position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #0003;transition:transform .2s ease}.status-toggle-switch.is-open .switch-thumb{transform:translate(22px)}.status-toggle-switch.is-closed .switch-thumb{transform:translate(0)}.phone-input-wrapper{display:flex;align-items:center;border:2px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;transition:border-color var(--transition)}.phone-input-wrapper:focus-within{border-color:var(--primary)}.phone-prefix{padding:.7rem .75rem;background:var(--border-light);color:var(--text-light);font-size:.95rem;font-weight:600;border-right:2px solid var(--border);white-space:nowrap}.phone-input-wrapper input{flex:1;border:none!important;border-radius:0!important;padding:.7rem 1rem;font-size:.95rem;outline:none;background:#fff}.otp-input{letter-spacing:.4em;font-size:1.4rem!important;font-weight:700;text-align:center;padding:.8rem 1rem!important}.otp-info{display:flex;align-items:center;justify-content:space-between;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:var(--radius-sm);padding:.75rem 1rem;font-size:.9rem;color:#15803d}.resend-otp{text-align:center;margin-top:.25rem}.resend-timer{font-size:.85rem;color:var(--text-light)}.btn-link{background:none;border:none;color:var(--primary);font-weight:600;font-size:.85rem;cursor:pointer;padding:0;text-decoration:underline}.btn-link:hover{opacity:.8}.alert{padding:.75rem 1rem;border-radius:var(--radius-sm);font-size:.9rem;font-weight:500}.alert-error{background:#fef2f2;color:var(--danger);border:1px solid #fecaca}.alert-success{background:#f0fdf4;color:#15803d}.alert-warning{background:#fffbeb;color:#b45309;border:1px solid #fde68a}.cart-layout{display:grid;grid-template-columns:1fr 360px;gap:2rem;align-items:start}.cart-vendor-name{font-weight:600;font-size:1.05rem;margin-bottom:1rem;color:var(--text)}.cart-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:.75rem}.cart-item-image{width:80px;height:80px;border-radius:var(--radius-sm);object-fit:cover}.cart-item-info{flex:1}.cart-item-info h4{font-size:1rem;margin-bottom:.15rem}.cart-item-vendor{color:var(--text-light);font-size:.8rem}.cart-item-price{color:var(--text-light);font-size:.85rem}.cart-item-controls{display:flex;flex-direction:column;align-items:flex-end;gap:.5rem}.quantity-control{display:flex;align-items:center;gap:.5rem;background:var(--border-light);border-radius:var(--radius-sm);padding:.25rem}.qty-btn{width:32px;height:32px;border:none;border-radius:6px;background:#fff;font-size:1.1rem;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow);transition:all var(--transition)}.qty-btn:hover{background:var(--primary);color:#fff}.qty-value{font-weight:700;min-width:24px;text-align:center}.cart-item-subtotal{font-weight:700;color:var(--primary)}.clear-cart-btn{margin-top:.5rem}.cart-summary,.checkout-summary{background:#fff;border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow);position:sticky;top:80px}.cart-summary h3,.checkout-summary h3{font-size:1.2rem;margin-bottom:1rem}.summary-items{display:flex;flex-direction:column;gap:.5rem}.summary-row{display:flex;justify-content:space-between;font-size:.9rem;color:var(--text-light)}.summary-divider{height:1px;background:var(--border);margin:1rem 0}.summary-total{font-size:1.1rem;font-weight:700;color:var(--text);margin-bottom:1rem}.checkout-layout{display:grid;grid-template-columns:1fr minmax(0,380px);gap:2rem;align-items:start}.checkout-section-card{background:#fff;border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow);margin-bottom:1.5rem}.checkout-section-card h3{margin-bottom:1rem}.oh-page{max-width:var(--max-width);margin:0 auto;padding:1rem 1.5rem 2rem}.oh-tabs{display:flex;gap:0;margin-bottom:1.25rem;background:var(--border-light);border-radius:var(--radius);padding:3px}.oh-tab{flex:1;padding:.6rem 1rem;border:none;background:transparent;font-size:.9rem;font-weight:600;color:var(--text-light);cursor:pointer;border-radius:calc(var(--radius) - 2px);transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.4rem}.oh-tab-active{background:#fff;color:var(--text);box-shadow:0 1px 3px #0000001a}.oh-tab-badge{background:var(--primary);color:#fff;font-size:.7rem;padding:.1rem .45rem;border-radius:999px;font-weight:700}.oh-list{display:flex;flex-direction:column;gap:.75rem}.oc-card{background:#fff;border-radius:var(--radius);padding:1rem 1.15rem;box-shadow:var(--shadow);border-left:3px solid var(--border);transition:box-shadow .2s}.oc-card.oc-active{border-left-color:var(--primary);background:#fafbff}.oc-card.oc-cancelled{border-left-color:#ef4444;opacity:.75}.oc-top-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.4rem}.oc-order-num{font-size:1rem;font-weight:800;color:var(--text)}.oc-info-strip{display:flex;flex-wrap:wrap;align-items:center;gap:.3rem .75rem;padding:.5rem .65rem;margin-bottom:.6rem;background:#f0f4ff;border-radius:var(--radius-sm);border-left:3px solid var(--primary);font-size:.85rem}.oc-info-item{color:var(--text);font-weight:500}.oc-phone-link{color:var(--primary);text-decoration:none;font-weight:600}.oc-phone-link:active{opacity:.7}.oc-date{font-size:.78rem;color:var(--text-light)}.oc-items{display:flex;flex-direction:column;gap:.2rem;padding:.55rem .65rem;background:var(--border-light);border-radius:var(--radius-sm);margin-bottom:.6rem}.oc-item-row{display:flex;align-items:center;gap:.4rem;font-size:.85rem}.oc-item-qty{font-weight:700;color:var(--primary);min-width:1.8rem}.oc-item-name{flex:1;color:var(--text)}.oc-item-price{color:var(--text-light);font-weight:500}.oc-bottom-row{display:flex;align-items:center;justify-content:space-between}.oc-total{font-size:1.05rem;font-weight:800;color:var(--text)}.oc-address{font-size:.8rem;color:var(--text-light)}.oc-progress-bar{display:flex;gap:4px;margin-top:.65rem}.oc-progress-step{flex:1;height:4px;border-radius:2px;background:var(--border);transition:background .3s}.oc-progress-step.done{background:var(--primary)}.orders-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:1rem}.order-card,.order-card-vendor{background:#fff;border-radius:var(--radius);padding:1.25rem;box-shadow:var(--shadow)}.order-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.order-card-header strong{font-size:.95rem}.order-date{display:block;font-size:.8rem;color:var(--text-light);font-weight:400;margin-top:.15rem}.order-customer{font-weight:400;color:var(--text-light);font-size:.9rem}.order-status{display:inline-block;padding:.2rem .75rem;border-radius:999px;font-size:.75rem;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.5px}.status-pending{background:#f59e0b}.status-confirmed{background:#3b82f6}.status-preparing{background:#8b5cf6}.status-ready{background:#10b981}.status-delivered{background:#22c55e}.status-cancelled{background:#ef4444}.order-vendor-name{font-weight:600;color:var(--text);margin-bottom:.75rem;font-size:.95rem}.order-items-list{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.75rem;padding:.75rem;background:var(--border-light);border-radius:var(--radius-sm)}.order-item-row{display:flex;justify-content:space-between;font-size:.9rem}.order-card-footer{display:flex;flex-direction:column;gap:.5rem}.order-address{font-size:.85rem;color:var(--text-light)}.order-actions{display:flex;gap:.5rem;flex-wrap:wrap}.ocv-top-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.6rem}.ocv-order-num{font-size:1.05rem;font-weight:800;color:var(--text)}.ocv-time{margin-left:auto;font-size:.78rem;color:var(--text-light)}.ocv-customer-strip{display:flex;flex-wrap:wrap;align-items:center;gap:.35rem .75rem;padding:.5rem .65rem;margin-bottom:.6rem;background:#f0f4ff;border-radius:var(--radius-sm);border-left:3px solid var(--primary);font-size:.85rem}.ocv-customer-strip.ocv-strip-muted{background:var(--border-light);border-left-color:var(--text-light)}.ocv-customer-name{font-weight:600;color:var(--text)}.ocv-customer-phone{color:var(--primary);text-decoration:none;font-weight:500}.ocv-customer-phone:active{opacity:.7}.ocv-customer-flat{color:var(--text-light);font-weight:500}.ocv-footer{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem;margin-top:.25rem}.ocv-footer-left{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.ocv-total{font-size:1rem;font-weight:700;color:var(--text)}.dashboard{max-width:var(--max-width);margin:0 auto;padding:1rem 1.5rem}.vd-upi-banner{display:flex;align-items:center;justify-content:space-between;padding:.875rem 1.25rem;background:linear-gradient(135deg,#fef3c7,#fde68a);border:1.5px solid #f59e0b;border-radius:var(--radius);margin-bottom:.75rem;cursor:pointer;transition:transform .15s,box-shadow .15s}.vd-upi-banner:active{transform:scale(.98)}.vd-upi-banner-content{display:flex;align-items:center;gap:.75rem}.vd-upi-banner-icon{font-size:1.5rem}.vd-upi-banner-text{display:flex;flex-direction:column;gap:.15rem}.vd-upi-banner-text strong{font-size:.9rem;color:#92400e}.vd-upi-banner-text span{font-size:.78rem;color:#a16207}.vd-upi-banner-arrow{font-size:1.25rem;color:#92400e;font-weight:700}.vd-status-bar{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-radius:var(--radius);margin-bottom:1rem;transition:background .3s,box-shadow .3s}.vd-status-bar.vd-open{background:linear-gradient(135deg,#ecfdf5,#d1fae5);border:1.5px solid #6ee7b7}.vd-status-bar.vd-closed{background:linear-gradient(135deg,#fef2f2,#fecaca);border:1.5px solid #fca5a5}.vd-status-bar-left{display:flex;flex-direction:column;gap:.15rem}.vd-shop-name{font-size:1.3rem;font-weight:800;color:var(--text);margin:0}.vd-status-bar-right{display:flex;align-items:center;gap:.75rem}.vd-status-label{font-size:.82rem;font-weight:600;color:var(--text-light)}.vd-toggle-btn{display:flex;align-items:center;gap:.5rem;padding:.4rem .75rem;border:none;border-radius:999px;font-weight:800;font-size:.75rem;cursor:pointer;transition:all .3s;letter-spacing:.5px}.vd-toggle-btn.vd-toggle-open{background:#16a34a;color:#fff}.vd-toggle-btn.vd-toggle-closed{background:#dc2626;color:#fff}.vd-toggle-btn:disabled{opacity:.6;cursor:wait}.vd-toggle-track{width:36px;height:20px;border-radius:999px;background:#ffffff59;position:relative;transition:background .3s}.vd-toggle-thumb{position:absolute;top:2px;width:16px;height:16px;border-radius:50%;background:#fff;transition:left .3s;box-shadow:0 1px 3px #0003}.vd-toggle-open .vd-toggle-thumb{left:18px}.vd-toggle-closed .vd-toggle-thumb{left:2px}.vd-toggle-text{min-width:48px;text-align:center}.vd-alert-banner{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:linear-gradient(135deg,#fffbeb,#fef3c7);border:1.5px solid #fbbf24;border-radius:var(--radius);margin-bottom:1rem;cursor:pointer;transition:transform .15s;font-size:.9rem}.vd-alert-banner:hover{transform:translateY(-1px)}.vd-alert-icon{font-size:1.3rem;animation:vd-pulse 1.5s infinite}@keyframes vd-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.vd-alert-action{margin-left:auto;font-weight:700;color:#b45309;font-size:.85rem}.vd-stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:.6rem;margin-bottom:1rem}.vd-stat{background:#fff;border-radius:var(--radius);padding:.75rem .5rem;text-align:center;box-shadow:var(--shadow);cursor:pointer;transition:transform .15s,box-shadow .15s}.vd-stat:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.vd-stat-num{display:block;font-size:1.5rem;font-weight:800;color:var(--primary)}.vd-stat-label{color:var(--text-light);font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.tab-badge{display:inline-flex;align-items:center;justify-content:center;background:#dc2626;color:#fff;font-size:.65rem;font-weight:700;min-width:18px;height:18px;border-radius:999px;margin-left:.35rem;padding:0 4px}.vd-order-section{margin-bottom:1.5rem}.vd-order-section-title{font-size:.95rem;font-weight:700;padding:.5rem .75rem;border-radius:var(--radius-sm);margin-bottom:.75rem}.vd-section-new{background:#fef3c7;color:#92400e}.vd-section-active{background:#dbeafe;color:#1e40af}.vd-section-done{background:#f3f4f6;color:#6b7280}.vd-order-highlight{border-left:4px solid #f59e0b!important;animation:vd-fadeIn .3s ease}.vd-order-done{opacity:.7}.vd-order-cancelled{opacity:.5}@keyframes vd-fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.btn-success{background:#16a34a;color:#fff;border:none}.btn-success:hover{background:#15803d}.vd-settings{display:flex;flex-direction:column;gap:1rem}.vd-settings-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.vd-settings-card-header{display:flex;align-items:center;gap:.6rem;padding:.85rem 1.25rem;background:#f9fafb;border-bottom:1px solid var(--border)}.vd-settings-card-header h3{font-size:.95rem;font-weight:700;margin:0}.vd-settings-card-icon{font-size:1.2rem}.vd-settings-card-body{padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.85rem}.btn-full{width:100%;padding:.85rem;font-size:1rem;font-weight:700}.dashboard-header{margin-bottom:1.5rem}.dashboard-header h1{font-size:1.75rem}.dashboard-subtitle{color:var(--text-light);font-size:1rem}.dashboard-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:2rem}.stat-card{background:#fff;border-radius:var(--radius);padding:1.5rem;text-align:center;box-shadow:var(--shadow)}.stat-number{display:block;font-size:2rem;font-weight:800;color:var(--primary)}.stat-label{color:var(--text-light);font-size:.85rem;font-weight:500}.dashboard-tabs{display:flex;gap:.25rem;margin-bottom:1.5rem;border-bottom:2px solid var(--border)}.tab-btn{padding:.75rem 1.5rem;border:none;background:none;font-size:.95rem;font-weight:600;color:var(--text-light);cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-2px;transition:all var(--transition)}.tab-btn:hover{color:var(--primary)}.tab-btn.active{color:var(--primary);border-bottom-color:var(--primary)}.dashboard-content{min-height:300px}.content-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.item-form,.settings-form{background:#fff;padding:1.5rem;border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:1.5rem;display:flex;flex-direction:column;gap:1rem}.item-form h3{margin-bottom:.5rem}.menu-list{display:flex;flex-direction:column;gap:.75rem}.menu-list-item{display:none}.menu-list-item.unavailable{opacity:.6}.menu-list-image{width:70px;height:70px;border-radius:var(--radius-sm);object-fit:cover}.menu-list-info{flex:1}.menu-list-info h4{font-size:1rem;margin-bottom:.2rem}.menu-list-info p{color:var(--text-light);font-size:.85rem}.menu-list-price{font-weight:700;color:var(--primary);font-size:1.1rem;min-width:60px;text-align:right}.menu-list-actions{display:flex;gap:.5rem;flex-wrap:wrap;margin-left:auto}@media (max-width: 768px){.menu-list-item{flex-direction:row;align-items:center;flex-wrap:wrap;gap:.5rem;padding:.6rem}.menu-list-image{width:44px;height:44px;border-radius:6px}.menu-list-info{flex:1;min-width:0}.menu-list-info h4{font-size:.85rem;margin-bottom:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.menu-list-info p{display:none}.menu-list-info .menu-item-category{font-size:.65rem;padding:1px 5px}.menu-list-price{font-size:.85rem;font-weight:700;min-width:auto}.menu-list-stock{font-size:.75rem}.menu-list-actions{width:100%;margin-left:0;display:flex;gap:.35rem}.menu-list-actions .btn{flex:1;font-size:.7rem;padding:.3rem .4rem;min-height:30px}.menu-list{gap:.4rem}.order-card,.order-card-vendor{padding:.7rem}.order-card-header{margin-bottom:.4rem}.order-card-header strong{font-size:.82rem}.order-customer{font-size:.78rem}.order-status{font-size:.7rem;padding:2px 6px}.order-items-list{padding:.4rem .5rem;margin-bottom:.4rem;gap:.2rem;font-size:.8rem}.order-card-footer{gap:.3rem;font-size:.82rem}.order-actions{gap:.3rem;flex-wrap:wrap}.order-actions .btn{font-size:.7rem;padding:.25rem .5rem;min-height:28px}.order-address{font-size:.78rem}.utr-display{font-size:.75rem}.payment-badge{font-size:.72rem;padding:2px 6px}.orders-list{gap:.5rem}.dashboard-header{margin-bottom:.75rem}.dashboard-header h1{font-size:1.15rem}.dashboard-subtitle{font-size:.82rem}.vd-status-bar{flex-direction:column;align-items:flex-start;gap:.75rem;padding:.75rem 1rem}.vd-status-bar-right{width:100%;justify-content:space-between}.vd-shop-name{font-size:1.1rem}.vd-stats-row{grid-template-columns:repeat(4,1fr);gap:.35rem}.vd-stat{padding:.5rem .25rem}.vd-stat-num{font-size:1.05rem}.vd-stat-label{font-size:.6rem}.vd-alert-banner{font-size:.82rem;padding:.6rem .75rem}.vd-order-section-title{font-size:.85rem;padding:.4rem .6rem}}.orders-list{display:flex;flex-direction:column;gap:1rem}.empty-state{text-align:center;padding:4rem 2rem}.empty-icon{font-size:4rem;margin-bottom:1rem}.empty-state h2{font-size:1.5rem;margin-bottom:.5rem}.empty-state p{color:var(--text-light);margin-bottom:1.5rem}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;color:var(--text-light)}.spinner{width:40px;height:40px;border:4px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:1rem}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 768px){.page-container{padding:1rem .75rem}.hero h1{font-size:2rem}.steps-grid{grid-template-columns:1fr}.vendor-grid{grid-template-columns:1fr;gap:.75rem}.vendor-card{display:flex;flex-direction:row}.vendor-card-image{width:100px;height:100px;flex-shrink:0}.vendor-card-info{padding:.6rem .75rem}.vendor-card-info h3{font-size:.95rem;margin-bottom:.15rem}.vendor-card-info .vendor-description{display:none}.vendor-card-meta{font-size:.75rem;gap:.5rem}.vendor-rating,.vendor-cuisine{font-size:.8rem}.vendor-closed-badge{font-size:.7rem;padding:2px 6px;top:6px;right:6px}.vendor-detail-header{flex-direction:column}.vendor-detail-image{width:100%;height:140px}.vendor-detail-info{padding:.75rem 1rem}.vendor-detail-info h1{font-size:1.3rem}.vendor-meta{flex-wrap:wrap;gap:.4rem;font-size:.8rem}.menu-grid{grid-template-columns:1fr;gap:.6rem}.menu-item-card{min-height:auto}.menu-item-image{width:85px;height:85px}.menu-item-info{padding:.5rem .6rem}.menu-item-header h4{font-size:.9rem}.menu-item-description{font-size:.78rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.menu-item-meta{font-size:.75rem;gap:.3rem}.add-to-cart-btn{padding:.3rem .6rem;font-size:.8rem}.cart-layout,.checkout-layout{grid-template-columns:1fr}.dashboard{padding:1rem .75rem}.dashboard-stats{grid-template-columns:repeat(4,1fr);gap:.35rem;margin-bottom:1rem}.stat-card{padding:.5rem .25rem}.stat-number{font-size:1rem}.stat-label{font-size:.6rem}.dashboard-tabs{gap:0;margin-bottom:.75rem}.tab-btn{font-size:.78rem;padding:.5rem .6rem}.content-header h2{font-size:1.05rem}.form-row,.footer-container{grid-template-columns:1fr}.navbar-container{flex-wrap:nowrap;gap:.5rem}.navbar-logo{flex-shrink:1;min-width:0}.navbar-logo .logo-icon{flex-shrink:0}.navbar-logo .community-badge{font-size:.7rem;padding:2px 6px;max-width:8em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.navbar-logo .role-badge{display:none}.navbar-flat{font-size:.7rem;max-width:12em}.navbar-links{flex-wrap:nowrap;flex-shrink:0;gap:.5rem}.orders-grid{grid-template-columns:1fr}.section-header h2{font-size:1.1rem}.category-filters{gap:.4rem}.category-btn{padding:.3rem .7rem;font-size:.8rem}.floating-cart{bottom:75px}.floating-cart .btn{font-size:.9rem;padding:.6rem 1.2rem}}@media all and (display-mode: standalone){body{padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}.navbar{padding-top:env(safe-area-inset-top)}.footer{padding-bottom:calc(1.5rem + env(safe-area-inset-bottom))}}.toast-container{position:fixed;top:5rem;right:1.5rem;z-index:10000;display:flex;flex-direction:column;gap:.75rem;max-width:400px;width:calc(100% - 3rem);pointer-events:none}.toast{pointer-events:auto;display:flex;align-items:flex-start;gap:.75rem;padding:1rem 1.25rem;border-radius:12px;background:#fff;box-shadow:0 8px 32px #00000026,0 2px 8px #0000001a;animation:toastSlideIn .4s cubic-bezier(.16,1,.3,1);border-left:4px solid #666;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.toast-success{border-left-color:#22c55e}.toast-info{border-left-color:#3b82f6}.toast-warning{border-left-color:#f97316}.toast-error{border-left-color:#ef4444}@keyframes toastSlideIn{0%{opacity:0;transform:translate(100%) scale(.95)}to{opacity:1;transform:translate(0) scale(1)}}.toast-content{flex:1;min-width:0}.toast-title{font-weight:600;font-size:.9rem;color:#1a1a2e;margin-bottom:.2rem}.toast-message{font-size:.82rem;color:#666;line-height:1.4;word-break:break-word}.toast-close{background:none;border:none;color:#999;font-size:1rem;cursor:pointer;padding:.2rem;line-height:1;flex-shrink:0;border-radius:50%;transition:all .2s}.toast-close:hover{color:#333;background:#0000000f}.notification-bell-wrapper{position:relative;display:flex;align-items:center}.notification-bell-btn{background:none;border:none;cursor:pointer;position:relative;padding:.4rem;font-size:1.3rem;line-height:1;border-radius:50%;transition:background .2s}.notification-bell-btn:hover{background:#0000000f}.bell-icon{display:inline-block;transition:transform .3s}.notification-bell-btn:hover .bell-icon{animation:bellShake .5s ease-in-out}@keyframes bellShake{0%,to{transform:rotate(0)}20%{transform:rotate(15deg)}40%{transform:rotate(-15deg)}60%{transform:rotate(10deg)}80%{transform:rotate(-10deg)}}.notification-badge{position:absolute;top:0;right:0;background:#ef4444;color:#fff;font-size:.65rem;font-weight:700;min-width:18px;height:18px;border-radius:10px;display:flex;align-items:center;justify-content:center;padding:0 4px;border:2px solid white;line-height:1;animation:badgePop .3s cubic-bezier(.16,1,.3,1)}@keyframes badgePop{0%{transform:scale(0)}to{transform:scale(1)}}.notification-panel{position:absolute;top:calc(100% + .5rem);right:0;width:380px;max-height:480px;background:#fff;border-radius:16px;box-shadow:0 12px 48px #0000002e,0 2px 12px #00000014;z-index:9999;overflow:hidden;animation:panelDropdown .25s cubic-bezier(.16,1,.3,1)}@keyframes panelDropdown{0%{opacity:0;transform:translateY(-10px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.notification-panel-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid #f0f0f0}.notification-panel-header h3{margin:0;font-size:1rem;font-weight:700;color:#1a1a2e}.mark-all-read-btn{background:none;border:none;color:var(--primary);font-size:.82rem;cursor:pointer;font-weight:500;padding:.3rem .6rem;border-radius:6px;transition:background .2s}.mark-all-read-btn:hover{background:#f9731614}.notification-panel-body{overflow-y:auto;max-height:400px}.notification-empty{text-align:center;padding:3rem 1.5rem;color:#aaa}.notification-empty-icon{font-size:2.5rem;display:block;margin-bottom:.75rem}.notification-empty p{margin:0;font-size:.9rem}.notification-item{display:flex;align-items:flex-start;gap:.75rem;padding:.9rem 1.25rem;cursor:pointer;transition:background .15s;border-bottom:1px solid #f5f5f5;position:relative}.notification-item:hover{background:#fafafa}.notification-item.unread{background:#fff7ed}.notification-item.unread:hover{background:#ffedd5}.notification-item-icon{font-size:1.5rem;flex-shrink:0;margin-top:.1rem}.notification-item-content{flex:1;min-width:0}.notification-item-title{font-weight:600;font-size:.85rem;color:#1a1a2e;margin-bottom:.15rem}.notification-item-message{font-size:.8rem;color:#666;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.notification-item-time{font-size:.72rem;color:#aaa;margin-top:.3rem}.notification-item-delete{background:none;border:none;color:#ccc;font-size:.85rem;cursor:pointer;padding:.3rem;border-radius:50%;opacity:0;transition:all .2s;flex-shrink:0}.notification-item:hover .notification-item-delete{opacity:1}.notification-item-delete:hover{color:#ef4444;background:#ef444414}.install-prompt-overlay{position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%);z-index:9999;width:calc(100% - 2rem);max-width:420px;animation:slideUpFade .4s ease}.install-prompt{background:var(--bg-white);border-radius:var(--radius-lg);box-shadow:0 8px 30px #00000026,0 2px 8px #0000001a;padding:1.25rem;display:flex;flex-direction:column;gap:.75rem;border:1px solid var(--border)}.install-prompt-icon{font-size:2.5rem;text-align:center}.install-prompt-content h3{font-size:1.1rem;font-weight:700;color:var(--text);margin-bottom:.25rem;text-align:center}.install-prompt-content p{font-size:.85rem;color:var(--text-light);text-align:center;line-height:1.4}.install-prompt-actions{display:flex;gap:.75rem;justify-content:center}.install-prompt-actions .btn{flex:1;max-width:160px}.ios-install-guide{display:flex;flex-direction:column;gap:.5rem}.ios-step{display:flex;align-items:center;gap:.75rem;padding:.5rem;background:var(--border-light);border-radius:var(--radius-sm);font-size:.85rem}.ios-step-num{background:var(--primary);color:#fff;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0}@keyframes slideUpFade{0%{opacity:0;transform:translate(-50%) translateY(30px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.mobile-bottom-nav{display:none}@media (max-width: 768px){.mobile-bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;background:var(--bg-white);border-top:1px solid var(--border);padding:.4rem 0;padding-bottom:calc(.4rem + env(safe-area-inset-bottom));z-index:100;justify-content:space-around;box-shadow:0 -2px 10px #0000000d}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;gap:.15rem;text-decoration:none;color:var(--text-light);font-size:.65rem;font-weight:500;padding:.25rem .75rem;border-radius:var(--radius-sm);transition:color var(--transition);position:relative;-webkit-tap-highlight-color:transparent}.bottom-nav-item.active{color:var(--primary)}.bottom-nav-icon{font-size:1.4rem;line-height:1}.bottom-nav-badge{position:absolute;top:-2px;right:4px;background:var(--danger);color:#fff;font-size:.6rem;font-weight:700;min-width:16px;height:16px;border-radius:10px;display:flex;align-items:center;justify-content:center;padding:0 3px}.mobile-bottom-nav.menu-open{z-index:1001}.bottom-nav-item-wrap{position:relative;display:flex;flex-direction:column;align-items:center}.bottom-nav-item-wrap .bottom-nav-item{background:none;border:none;cursor:pointer}.bottom-nav-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#0000004d}.bottom-nav-menu{position:absolute;bottom:100%;right:0;margin-bottom:8px;background:var(--card-bg, #fff);border:1px solid var(--border, #e5e7eb);border-radius:10px;box-shadow:0 -4px 20px #00000026;min-width:160px;z-index:1000;overflow:hidden}.bottom-nav-menu-user{padding:.75rem 1rem;font-weight:600;font-size:.9rem;border-bottom:1px solid var(--border, #e5e7eb);color:var(--text)}.bottom-nav-menu-item{display:block;width:100%;padding:.75rem 1rem;border:none;background:none;text-align:left;font-size:.9rem;cursor:pointer;color:var(--text)}.bottom-nav-menu-item:hover{background:var(--bg-light, #f3f4f6)}.bottom-nav-menu-item.logout{color:var(--danger, #ef4444);font-weight:600}a.bottom-nav-menu-item{color:inherit;text-decoration:none;text-align:left;cursor:pointer}.main-content{padding-bottom:70px}.footer{padding-bottom:calc(70px + 1rem)}.navbar-links .nav-link,.navbar-links .nav-auth,.navbar-links .nav-user-wrap{display:none}.floating-cart,.install-prompt-overlay{bottom:5rem}}@media (hover: none) and (pointer: coarse){.btn{min-height:44px;min-width:44px}.btn-sm{min-height:36px}.qty-btn{min-width:36px;min-height:36px}.category-btn{min-height:40px;padding:.5rem 1rem}.nav-link{min-height:44px;display:flex;align-items:center}.vendor-card:hover,.menu-item-card:hover{transform:none}*{-webkit-overflow-scrolling:touch}.btn,.qty-btn,.category-btn,.bottom-nav-item,.tab-btn{-webkit-user-select:none;user-select:none}}.cp-steps{display:flex;align-items:center;justify-content:center;gap:0;margin-bottom:1.25rem}.cp-step{display:flex;align-items:center;gap:.35rem;opacity:.4}.cp-step-active{opacity:1}.cp-step-done{opacity:.7}.cp-step-num{width:26px;height:26px;border-radius:50%;background:var(--border);color:var(--text-light);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700}.cp-step-active .cp-step-num{background:var(--primary);color:#fff}.cp-step-done .cp-step-num{background:#d1fae5;color:#065f46}.cp-step-label{font-size:.8rem;font-weight:600;color:var(--text-light)}.cp-step-active .cp-step-label{color:var(--text)}.cp-step-line{width:40px;height:2px;background:var(--border);margin:0 .5rem}.cp-summary{background:#f9fafb;border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:.75rem;overflow:hidden}.cp-summary-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;padding:.65rem .75rem;background:none;border:none;font-size:.85rem;font-weight:600;color:var(--text);cursor:pointer}.cp-summary-total{color:var(--primary);font-weight:700;white-space:nowrap}.cp-summary-items{padding:.5rem .75rem .65rem;display:flex;flex-direction:column;gap:.25rem;border-top:1px solid var(--border)}.cp-summary-row{display:flex;justify-content:space-between;font-size:.8rem;color:var(--text-light)}.cp-upi-pay-btn{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:linear-gradient(135deg,#5f2b8e,#7c3aed);color:#fff;border:none;border-radius:.75rem;text-decoration:none;cursor:pointer;box-shadow:0 4px 14px #7c3aed4d;transition:transform .15s,box-shadow .15s;margin-bottom:.75rem}.cp-upi-pay-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px #7c3aed66}.cp-upi-pay-btn:active{transform:scale(.97)}.cp-upi-pay-icon{font-size:1.5rem;flex-shrink:0}.cp-upi-pay-text{display:flex;flex-direction:column;gap:.15rem}.cp-upi-pay-text strong{font-size:1rem}.cp-upi-pay-text small{font-size:.75rem;opacity:.85}.cp-upi-pay-arrow{margin-left:auto;font-size:1.25rem;opacity:.7}.qr-divider-text{text-align:center;font-size:.8rem;color:var(--text-light);margin:.25rem 0 .5rem;position:relative}.cp-paid-section{margin-top:1.25rem}.cp-paid-divider{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.cp-paid-divider:before,.cp-paid-divider:after{content:"";flex:1;height:1px;background:var(--border)}.cp-paid-divider span{font-size:.78rem;color:#94a3b8;white-space:nowrap;text-transform:uppercase;letter-spacing:.04em;font-weight:600}.cp-paid-btn{display:flex;align-items:center;gap:.75rem;width:100%;padding:1rem 1.25rem;background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;border:none;border-radius:.75rem;cursor:pointer;box-shadow:0 4px 14px #22c55e4d;transition:all .2s ease;text-align:left}.cp-paid-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px #22c55e66}.cp-paid-btn:active{transform:scale(.98)}.cp-paid-btn-icon{font-size:1.5rem;flex-shrink:0}.cp-paid-btn-text{display:flex;flex-direction:column;gap:.15rem;flex:1}.cp-paid-btn-text strong{font-size:1rem}.cp-paid-btn-text small{font-size:.75rem;opacity:.85}.cp-paid-btn-arrow{font-size:1.25rem;opacity:.7;flex-shrink:0}.cp-confirm-section{display:flex;flex-direction:column;gap:1rem}.cp-confirm-check{display:flex;align-items:flex-start;gap:.75rem;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:.75rem;padding:1rem}.cp-confirm-icon{font-size:1.5rem;flex-shrink:0}.cp-confirm-check strong{font-size:1rem;color:#15803d}.cp-confirm-check p{font-size:.85rem;color:#475569;margin-top:.2rem}.cp-place-order-btn{font-size:1.05rem!important;padding:1rem!important;border-radius:.75rem!important}.cp-utr-optional{border-top:1px solid var(--border);padding-top:.75rem}.cp-utr-toggle{background:none;border:none;color:var(--text-light);font-size:.82rem;cursor:pointer;padding:.25rem 0;text-align:left;display:block;width:100%}.cp-utr-toggle:hover{color:var(--primary)}.cp-utr-toggle-hint{font-size:.75rem;color:#94a3b8}.cp-utr-field{animation:fadeIn .2s ease}.cp-utr-field label{display:block;font-size:.82rem;font-weight:600;color:var(--text-light);margin-bottom:.4rem}.cp-optional-tag{font-weight:400;color:#94a3b8;font-size:.75rem}.cp-utr-input-row{display:flex;gap:.5rem;align-items:stretch}.cp-utr-input{flex:1;padding:.6rem .75rem;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:1rem;letter-spacing:.1em;font-family:monospace}.cp-utr-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #f973161a}.cp-paste-btn{padding:.5rem .75rem;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-alt);font-size:.82rem;cursor:pointer;white-space:nowrap;transition:all .15s}.cp-paste-btn:hover{border-color:var(--primary)}.cp-utr-hint{display:block;font-size:.75rem;color:#94a3b8;margin-top:.35rem}.cp-back-to-pay{background:none;border:none;color:var(--text-light);font-size:.82rem;cursor:pointer;padding:.25rem 0;text-align:left}.cp-back-to-pay:hover{color:var(--primary)}.checkout-summary-desktop{display:block}.payment-layout{display:grid;grid-template-columns:1fr minmax(0,340px);gap:2rem;align-items:start}.payment-card{background:#fff;border-radius:var(--radius);border:2px solid var(--border);padding:2rem;display:flex;flex-direction:column;gap:1.5rem}.payment-header{text-align:center;padding-bottom:1rem;border-bottom:2px dashed var(--border)}.payment-amount{font-size:2.5rem;font-weight:800;color:var(--primary)}.payment-order-ref{font-size:.85rem;color:var(--text-light);margin-top:.25rem}.payment-instructions{text-align:center;color:var(--text-light);font-size:.95rem}.upi-qr-wrapper{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.5rem;background:#f9fafb;border-radius:var(--radius-sm);border:1px solid var(--border)}.qr-hint{font-size:.8rem;color:var(--text-light);text-align:center}.upi-id-box{display:flex;align-items:center;gap:.75rem;background:#fff7ed;border:1.5px solid var(--primary);border-radius:var(--radius-sm);padding:.75rem 1rem}.upi-id-label{font-size:.75rem;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.upi-id-value{flex:1;font-weight:600;font-size:1rem;color:var(--text);word-break:break-all}.utr-form{display:flex;flex-direction:column;gap:.75rem}.utr-instructions{font-size:.9rem;color:var(--text-light)}.skip-payment{text-align:center;display:block;font-size:.85rem;color:var(--text-light);margin-top:-.5rem}.payment-badge{display:inline-block;padding:.2rem .65rem;border-radius:999px;font-size:.75rem;font-weight:600;margin-top:.35rem}.payment-paid{background:#d1fae5;color:#065f46}.payment-pending{background:#fef3c7;color:#92400e}.utr-display{font-size:.78rem;color:var(--text-light);font-family:monospace;margin-top:.15rem}@media (max-width: 768px){.checkout-page{overflow-x:hidden;max-width:100vw}.checkout-layout,.payment-layout{grid-template-columns:minmax(0,1fr);gap:1rem;margin-top:0;min-width:0}.payment-card,.checkout-form-section,.checkout-summary{min-width:0;max-width:100%}.checkout-summary-desktop{display:none}.upi-id-box,.upi-id-value{min-width:0}.summary-row span:first-child{min-width:0;overflow:hidden;text-overflow:ellipsis}.payment-instructions p,.utr-instructions{overflow-wrap:break-word}.btn-full{white-space:normal;text-align:center}.checkout-page .form-group input,.checkout-page .form-group textarea{max-width:100%;box-sizing:border-box}.checkout-page h1{font-size:1.2rem;margin-bottom:.75rem}.payment-card{padding:1rem;gap:.75rem}.payment-header{padding-bottom:.5rem}.payment-amount{font-size:1.75rem}.payment-order-ref{font-size:.78rem}.payment-instructions{font-size:.82rem;margin-bottom:0}.upi-qr-wrapper{padding:.75rem;gap:.4rem}.upi-qr-wrapper .payment-qr-img,.upi-qr-wrapper img,.upi-qr-wrapper svg{width:140px!important;height:140px!important;max-width:140px;max-height:140px;object-fit:contain;border-radius:8px}.qr-hint{font-size:.72rem}.upi-id-box{padding:.5rem .75rem;gap:.5rem}.upi-id-value{font-size:.88rem}.utr-form{gap:.5rem}.utr-instructions{font-size:.82rem}.utr-form .btn-lg{padding:.65rem 1rem;font-size:.9rem}.checkout-summary{padding:1rem}.checkout-summary h3{font-size:1rem;margin-bottom:.5rem}.summary-items,.summary-row{font-size:.88rem}.summary-total{font-size:1rem}.checkout-page.page-container{padding:.75rem .5rem}.cp-utr-input-row{flex-direction:column}.cp-utr-input{width:100%}.cp-place-order-btn{font-size:.95rem!important;padding:.85rem!important}.cp-upi-pay-btn{padding:.85rem 1rem}.cp-confirm-check{padding:.75rem}}.adm{max-width:var(--max-width);margin:0 auto;padding:0 0 2rem}.adm-topbar{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;position:sticky;top:0;background:#fff;z-index:5;border-bottom:1px solid var(--border)}.adm-title{font-size:1.1rem;font-weight:800}.adm-refresh{background:none;border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:.3rem .6rem;font-size:1rem;cursor:pointer}.adm-tabs-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:.5rem .75rem;background:#fff;border-bottom:1px solid var(--border);position:sticky;top:3rem;z-index:4}.adm-tabs-wrap::-webkit-scrollbar{display:none}.adm-tabs{display:flex;gap:.4rem;width:max-content}.adm-tab{display:flex;align-items:center;gap:.25rem;padding:.45rem .75rem;border:1.5px solid var(--border);border-radius:999px;background:#fff;font-size:.8rem;font-weight:600;color:var(--text-light);cursor:pointer;white-space:nowrap;transition:all .15s}.adm-tab-on{background:var(--primary);color:#fff;border-color:var(--primary)}.adm-tab-badge{background:#ef4444;color:#fff;font-size:.65rem;padding:.05rem .35rem;border-radius:999px;font-weight:700}.adm-tab-on .adm-tab-badge{background:#ffffff4d}.adm-section{padding:1rem}.adm-section h3{font-size:1rem;font-weight:700;margin-bottom:.75rem}.adm-section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.adm-section-head h3{margin-bottom:0}.adm-list{display:flex;flex-direction:column;gap:.65rem}.adm-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem;margin-bottom:.75rem}.adm-stat{background:#fff;border:1.5px solid var(--border);border-radius:var(--radius);padding:.75rem;text-align:center}.adm-stat-num{display:block;font-size:1.5rem;font-weight:800;color:var(--text);line-height:1.2}.adm-stat-lbl{font-size:.75rem;color:var(--text-light)}.adm-stat-warn{border-color:#fbbf24;background:#fffbeb}.adm-stat-ok{border-color:#34d399;background:#f0fdf4}.adm-stat-rev{border-color:#818cf8;background:#eef2ff}.adm-alert{display:flex;align-items:center;gap:.5rem;width:100%;padding:.7rem 1rem;background:#fef3c7;border:1.5px solid #fbbf24;border-radius:var(--radius-sm);font-size:.88rem;cursor:pointer;text-align:left}.adm-comm-card{display:flex;flex-direction:column;gap:.5rem;background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:.75rem 1rem}.adm-comm-info{display:flex;flex-direction:column;gap:.15rem;min-width:0}.adm-comm-info strong{font-size:.95rem}.adm-comm-meta{font-size:.78rem;color:var(--text-light)}.adm-comm-slug{font-size:.72rem;color:var(--primary);font-family:monospace}.adm-comm-toggle{display:flex;align-items:center;justify-content:space-between;cursor:pointer;padding:.35rem 0;border-top:1px solid var(--border)}.adm-comm-toggle-label{font-size:.8rem;color:var(--text-light);font-weight:500}.adm-toggle{width:40px;height:22px;border-radius:11px;background:#d1d5db;position:relative;transition:background .2s;flex-shrink:0}.adm-toggle-on{background:var(--primary)}.adm-toggle-knob{width:18px;height:18px;border-radius:50%;background:#fff;position:absolute;top:2px;left:2px;transition:transform .2s;box-shadow:0 1px 3px #00000026}.adm-toggle-on .adm-toggle-knob{transform:translate(18px)}.adm-comm-acts{display:flex;gap:.35rem;flex-shrink:0}.adm-form{background:#fff;border:1.5px solid var(--border);border-radius:var(--radius);padding:1rem;margin-bottom:1rem;display:flex;flex-direction:column;gap:.5rem}.adm-form h4{font-size:.95rem;margin-bottom:.25rem}.adm-form input,.adm-form textarea{width:100%;padding:.55rem .75rem;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:.88rem}.adm-hint{font-size:.75rem;color:var(--text-light);margin-top:-.25rem}.adm-form-btns{display:flex;gap:.4rem;margin-top:.25rem}.adm-pending-card{background:#fff;border:2px solid #fbbf24;border-radius:var(--radius);padding:.85rem}.adm-pending-top{display:flex;gap:.75rem;align-items:flex-start;margin-bottom:.5rem}.adm-pending-img{width:56px;height:56px;object-fit:cover;border-radius:var(--radius-sm);flex-shrink:0}.adm-pending-info{display:flex;flex-direction:column;gap:.1rem;font-size:.82rem;color:var(--text-light);min-width:0}.adm-pending-info strong{font-size:.95rem;color:var(--text)}.adm-pending-desc{font-size:.8rem;color:var(--text-light);margin-bottom:.5rem}.adm-pending-acts{display:flex;gap:.4rem}.adm-reject-form{display:flex;flex-direction:column;gap:.4rem;margin-top:.5rem}.adm-reject-form textarea{padding:.5rem;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:.85rem;resize:none}.adm-vendor-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:.85rem}.adm-vendor-top{display:flex;gap:.65rem;align-items:flex-start;margin-bottom:.4rem}.adm-vendor-img{width:44px;height:44px;object-fit:cover;border-radius:var(--radius-sm);flex-shrink:0}.adm-vendor-info{flex:1;min-width:0;display:flex;flex-direction:column}.adm-vendor-info strong{font-size:.92rem}.adm-vendor-meta{font-size:.78rem;color:var(--text-light)}.adm-vendor-stats{display:flex;gap:1rem;font-size:.8rem;color:var(--text-light);margin-bottom:.5rem}.adm-vendor-acts{display:flex;gap:.35rem}.adm-order-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:.85rem}.adm-order-top{display:flex;align-items:center;gap:.4rem;margin-bottom:.35rem;flex-wrap:wrap}.adm-order-num{font-size:.95rem;font-weight:800}.adm-order-parties{display:flex;align-items:center;gap:.35rem;font-size:.82rem;color:var(--text);margin-bottom:.4rem;flex-wrap:wrap}.adm-order-items{display:flex;flex-wrap:wrap;gap:.25rem .75rem;font-size:.8rem;color:var(--text-light);padding:.4rem .6rem;background:var(--border-light);border-radius:var(--radius-sm);margin-bottom:.4rem}.adm-order-bottom{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;font-size:.85rem}.adm-order-time{font-size:.75rem;color:var(--text-light);margin-left:auto}.vendor-status-badge{padding:.15rem .5rem;border-radius:999px;font-size:.72rem;font-weight:600;white-space:nowrap}.vendor-status-badge.status-pending{background:#fef3c7;color:#92400e}.vendor-status-badge.status-approved{background:#d1fae5;color:#065f46}.vendor-status-badge.status-rejected{background:#fee2e2;color:#991b1b}.vendor-status-screen{max-width:520px;margin:4rem auto;text-align:center;background:#fff;border-radius:var(--radius-lg);padding:3rem 2.5rem;border:2px solid #fbbf24;box-shadow:var(--shadow-md)}.vendor-status-screen.rejected{border-color:var(--danger)}.vendor-status-icon{font-size:3.5rem;margin-bottom:1rem}.vendor-status-screen h2{margin-bottom:.75rem}.vendor-status-screen p{color:var(--text-light);margin-bottom:.75rem}.vendor-status-note{font-size:.85rem;background:var(--border-light);border-radius:var(--radius-sm);padding:.75rem 1rem;color:var(--text-light)!important}.vendor-status-details{margin-top:1.25rem;font-size:.85rem;color:var(--text-light)}.vendor-whatsapp-btn{display:inline-flex;align-items:center;gap:.5rem;margin-top:1.25rem;padding:.75rem 1.5rem;background:#25d366;color:#fff;font-size:.95rem;font-weight:600;border-radius:var(--radius-md);text-decoration:none;transition:background .2s,transform .15s;box-shadow:0 2px 8px #25d3664d}.vendor-whatsapp-btn:hover{background:#1ebe57;transform:translateY(-1px)}.vendor-whatsapp-btn:active{transform:translateY(0)}.vendor-whatsapp-icon{font-size:1.2rem}.rejection-reason{background:#fee2e2;border-radius:var(--radius-sm);padding:.75rem 1rem;font-size:.88rem;color:#991b1b;margin:.75rem 0}@media (min-width: 769px){.adm-stats{grid-template-columns:repeat(4,1fr)}.adm-topbar{padding:.75rem 1.5rem}.adm-section{padding:1.25rem 1.5rem}}html{overscroll-behavior-y:contain}@media (max-width: 768px){.toast-container{top:auto;bottom:5rem;right:.75rem;left:.75rem;max-width:100%;width:auto}.notification-panel{position:fixed;top:3.5rem;right:.5rem;left:.5rem;width:auto;max-height:calc(100vh - 10rem);border-radius:12px}.notification-item-delete{opacity:1}}.community-select-page{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.community-hero{text-align:center;padding:4rem 1.5rem 2rem;color:#fff}.community-hero h1{font-size:2.5rem;font-weight:800;margin-bottom:.5rem}.community-hero p{font-size:1.1rem;opacity:.9}.community-list-section{max-width:900px;margin:0 auto;padding:0 1.5rem 3rem}.community-list-section h2{color:#fff;font-size:1.3rem;margin-bottom:1.5rem;text-align:center}.community-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.25rem}.community-card{background:#fff;border-radius:16px;padding:2rem 1.5rem;text-decoration:none;color:var(--text-dark);transition:transform .2s,box-shadow .2s;text-align:center;box-shadow:0 4px 15px #0000001a}.community-card:hover{transform:translateY(-4px);box-shadow:0 8px 25px #00000026}.community-card-icon{font-size:2.5rem;margin-bottom:.75rem}.community-card h3{font-size:1.2rem;font-weight:700;margin-bottom:.25rem}.community-city{color:var(--text-light);font-size:.9rem}.community-address{color:var(--text-light);font-size:.8rem;margin-top:.25rem}.community-badge{display:inline-block;background:#00000014;color:var(--text);font-size:.65rem;font-weight:600;padding:2px 8px;border-radius:10px;margin-left:.5rem;vertical-align:middle}[data-theme=vendor] .community-badge{background:#15803d1f;color:var(--primary);border:1px solid rgba(21,128,61,.25)}[data-theme=vendor] .navbar-flat{color:#bbf7d0}[data-theme=admin] .community-badge{background:#ffffff40;color:#fff;border:1px solid rgba(255,255,255,.4)}[data-theme=admin] .navbar-flat{color:#ffffffe6}.loading-spinner-container{display:flex;justify-content:center;padding:3rem}.file-input{padding:.5rem;border:2px dashed var(--border);border-radius:8px;cursor:pointer;width:100%;background:var(--background)}.file-input:hover{border-color:var(--primary)}.image-preview{margin-top:.5rem;display:flex;align-items:center;gap:.75rem}.image-preview img{width:80px;height:60px;object-fit:cover;border-radius:6px;border:1px solid var(--border)}.payment-settings-section{background:var(--bg, #f9fafb);border:2px solid var(--border, #e5e7eb);border-radius:10px;padding:1.25rem;margin-top:.5rem}.payment-settings-section h3{margin:0 0 1rem;font-size:1.05rem}.content-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;flex-wrap:wrap;gap:.5rem}.content-header h2{margin:0}.community-admin-list{display:flex;flex-direction:column;gap:.75rem}.community-admin-card{display:flex;align-items:center;justify-content:space-between;background:var(--card-bg, #fff);border:1px solid var(--border, #e5e7eb);border-radius:10px;padding:1rem 1.25rem;gap:1rem;flex-wrap:wrap}.community-admin-info h3{margin:0 0 .25rem;font-size:1.05rem}.community-admin-meta{font-size:.88rem;color:var(--text-light, #6b7280)}.community-admin-slug{margin-top:.25rem;font-size:.82rem;font-family:monospace;color:var(--primary, #3b82f6)}.community-admin-actions{display:flex;gap:.5rem;flex-shrink:0}@media (max-width: 600px){.community-admin-card{flex-direction:column;align-items:flex-start}.community-admin-actions{width:100%}.community-admin-actions .btn{flex:1}}.feedback-page{max-width:600px;margin:0 auto;padding:1rem}.feedback-header{text-align:center;margin-bottom:1.5rem}.feedback-header h2{font-size:1.5rem;margin-bottom:.25rem}.feedback-header p{color:#64748b;font-size:.9rem}.feedback-toggle{display:flex;gap:.5rem;margin-bottom:1.5rem;background:#f1f5f9;border-radius:.5rem;padding:.25rem}.feedback-toggle-btn{flex:1;padding:.6rem .75rem;border:none;background:transparent;border-radius:.375rem;font-size:.85rem;font-weight:500;color:#64748b;cursor:pointer;transition:all .2s}.feedback-toggle-btn.active{background:#fff;color:#f97316;box-shadow:0 1px 3px #0000001a}.feedback-form{display:flex;flex-direction:column;gap:1.25rem}.fb-field{display:flex;flex-direction:column;gap:.5rem}.fb-field label{font-weight:600;font-size:.85rem;color:#334155}.fb-field input,.fb-field textarea{border:1px solid #e2e8f0;border-radius:.5rem;padding:.65rem .75rem;font-size:.9rem;transition:border-color .2s}.fb-field input:focus,.fb-field textarea:focus{outline:none;border-color:#f97316;box-shadow:0 0 0 3px #f973161a}.fb-char-count{font-size:.75rem;color:#94a3b8;text-align:right}.fb-categories{display:flex;flex-wrap:wrap;gap:.5rem}.fb-cat-btn{display:flex;align-items:center;gap:.3rem;padding:.4rem .75rem;border:1px solid #e2e8f0;border-radius:2rem;background:#fff;font-size:.8rem;cursor:pointer;transition:all .2s}.fb-cat-btn.active{border-color:#f97316;background:#fff7ed;color:#f97316;font-weight:600}.fb-stars{display:flex;align-items:center;gap:.25rem}.fb-star{font-size:1.75rem;background:none;border:none;cursor:pointer;color:#e2e8f0;transition:color .15s,transform .15s;padding:0;line-height:1}.fb-star.active{color:#f59e0b}.fb-star:hover{transform:scale(1.15)}.fb-rating-text{font-size:.85rem;color:#64748b;margin-left:.5rem}.fb-list{display:flex;flex-direction:column;gap:.75rem}.fb-card{background:#fff;border:1px solid #e2e8f0;border-radius:.75rem;padding:1rem}.fb-card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.fb-card-cat{font-size:.8rem;color:#64748b;text-transform:capitalize}.fb-status{font-size:.7rem;font-weight:600;padding:.2rem .5rem;border-radius:1rem;text-transform:uppercase;letter-spacing:.02em}.fb-status-new{background:#dbeafe;color:#2563eb}.fb-status-reviewed{background:#fef3c7;color:#d97706}.fb-status-resolved{background:#dcfce7;color:#16a34a}.fb-card-subject{font-size:.95rem;font-weight:600;margin-bottom:.35rem}.fb-card-msg{font-size:.85rem;color:#475569;line-height:1.5;margin-bottom:.5rem}.fb-card-bottom{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.fb-card-stars{color:#f59e0b;font-size:.9rem;letter-spacing:.05em}.fb-card-date{font-size:.75rem;color:#94a3b8}.fb-admin-reply{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:.5rem;padding:.6rem .75rem;margin-top:.5rem;font-size:.85rem}.fb-admin-reply strong{color:#16a34a;font-size:.8rem}.fb-admin-reply p{margin-top:.25rem;color:#334155}.fb-admin-filters{display:flex;gap:.5rem;margin-bottom:1rem;overflow-x:auto;padding-bottom:.25rem}.fb-filter-btn{display:flex;align-items:center;gap:.3rem;padding:.4rem .7rem;border:1px solid #e2e8f0;border-radius:2rem;background:#fff;font-size:.8rem;cursor:pointer;white-space:nowrap;transition:all .2s}.fb-filter-btn.active{border-color:#f97316;background:#fff7ed;color:#f97316;font-weight:600}.fb-filter-count{background:#e2e8f0;color:#475569;padding:.1rem .4rem;border-radius:1rem;font-size:.7rem;font-weight:600}.fb-filter-btn.active .fb-filter-count{background:#fed7aa;color:#c2410c}.fb-admin-card{background:#fff;border:1px solid #e2e8f0;border-radius:.75rem;padding:1rem}.fb-admin-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.fb-admin-user{display:flex;align-items:center;gap:.4rem;font-size:.9rem}.fb-admin-role-tag{font-size:.7rem;padding:.1rem .4rem;border-radius:.25rem;background:#f1f5f9;color:#64748b;text-transform:capitalize}.fb-admin-meta{display:flex;flex-wrap:wrap;gap:.75rem;font-size:.78rem;color:#64748b;margin-bottom:.5rem}.fb-admin-subject{font-size:.95rem;font-weight:600;margin-bottom:.25rem}.fb-admin-msg{font-size:.85rem;color:#475569;line-height:1.5;margin-bottom:.5rem}.fb-admin-acts{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.5rem}.fb-admin-notes-form{margin-top:.5rem}.fb-admin-notes-form textarea{width:100%;border:1px solid #e2e8f0;border-radius:.5rem;padding:.5rem .75rem;font-size:.85rem;resize:vertical;margin-bottom:.5rem}.fb-admin-notes-form textarea:focus{outline:none;border-color:#f97316}@media (max-width: 600px){.feedback-page{padding:.75rem}.fb-categories{gap:.35rem}.fb-cat-btn{padding:.35rem .6rem;font-size:.75rem}.fb-star{font-size:1.5rem}.fb-admin-meta{gap:.5rem}}.feedback-fab{position:fixed;bottom:1.5rem;right:1.5rem;z-index:90;display:flex;align-items:center;gap:.4rem;background:linear-gradient(135deg,#f97316,#ea580c);color:#fff;border:none;border-radius:2rem;padding:.7rem 1rem;font-size:.85rem;font-weight:600;cursor:pointer;box-shadow:0 4px 14px #f9731666;transition:all .3s cubic-bezier(.4,0,.2,1);overflow:hidden;max-width:160px}.feedback-fab:hover{transform:scale(1.05);box-shadow:0 6px 20px #f9731680}.feedback-fab:active{transform:scale(.97)}.feedback-fab-icon{font-size:1.15rem;line-height:1;flex-shrink:0}.feedback-fab-label{white-space:nowrap}@media (max-width: 768px){.feedback-fab{bottom:calc(4.5rem + env(safe-area-inset-bottom));right:1rem;padding:.65rem;border-radius:50%;max-width:48px;width:48px;height:48px;justify-content:center}.feedback-fab-label{display:none}.feedback-fab-icon{font-size:1.3rem}}
