Menu
/* ═══════════════════════════════════════════════
IZIBITE — MENU PAGE | Full Brand Stylesheet
═══════════════════════════════════════════════ */
:root {
–green: #1db954;
–green-dark: #17a348;
–green-glow: rgba(29,185,84,.15);
–orange: #ff6b00;
–orange-light: #ff8c38;
–dark: #111827;
–dark2: #1f2937;
–gray: #6b7280;
–light-gray: #f3f4f6;
–cream: #fef9f0;
–white: #ffffff;
–red: #ef4444;
–font-head: ‘Nunito’, sans-serif;
–font-body: ‘Plus Jakarta Sans’, sans-serif;
–radius: 16px;
–shadow-sm: 0 2px 8px rgba(0,0,0,.07);
–shadow-md: 0 8px 28px rgba(0,0,0,.10);
–shadow-lg: 0 20px 56px rgba(0,0,0,.14);
–transition: all .25s cubic-bezier(.4,0,.2,1);
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { font-family: var(–font-body); color: var(–dark); background: var(–white); }
/* ── KEYFRAMES ── */
@keyframes fadeInUp { from{opacity:0;transform:translateY(22px)} to{opacity:1;transform:translateY(0)} }
@keyframes fadeIn { from{opacity:0} to{opacity:1} }
@keyframes spin { to{transform:rotate(360deg)} }
@keyframes float { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-6px)} }
@keyframes bumpScale { 0%,100%{transform:scale(1)} 50%{transform:scale(1.45)} }
@keyframes shimmer { 0%{background-position:-600px 0} 100%{background-position:600px 0} }
@keyframes pulse-dot { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.5;transform:scale(.7)} }
@keyframes slideDown { from{opacity:0;transform:translateY(-8px)} to{opacity:1;transform:translateY(0)} }
/* HEADER */
header {
position: sticky; top: 0; z-index: 999;
background: var(–light-gray);
border-bottom: 1px solid #e5e7eb;
box-shadow: 0 2px 12px rgba(0,0,0,.06);
}
.header-inner {
max-width: 1280px; margin: 0 auto;
display: flex; align-items: center; gap: 12px;
padding: 12px 20px;
}
.logo {
display: flex; align-items: center; gap: 8px;
text-decoration: none; flex-shrink: 0;
}
.logo img { height: 36px; width: auto; display: block; object-fit: contain; }
.campus-selector {
display: flex; align-items: center; gap: 6px;
border: 1.5px solid #d1d5db; border-radius: 8px;
padding: 7px 10px; cursor: pointer; white-space: nowrap;
font-size: 12px; font-weight: 600; color: var(–dark);
background: white; transition: border-color .2s; flex-shrink: 0;
font-family: var(–font-body);
}
.campus-selector:hover { border-color: var(–green); }
.campus-selector .fa-location-dot { color: var(–green); font-size: 12px; }
.campus-selector .fa-chevron-down { font-size: 9px; color: var(–gray); }
.search-bar {
flex: 1; display: flex; align-items: center;
border: 1.5px solid #e5e7eb; border-radius: 10px;
padding: 0 14px; gap: 9px; background: #f9fafb;
transition: var(–transition); min-width: 0;
}
.search-bar:focus-within {
border-color: var(–green);
box-shadow: 0 0 0 3px var(–green-glow);
background: white;
}
.search-bar i { color: var(–gray); font-size: 13px; flex-shrink: 0; }
.search-bar input {
flex: 1; border: none; background: transparent;
padding: 9px 0; font-size: 13px;
font-family: var(–font-body); outline: none; min-width: 0;
}
.search-bar input::placeholder { color: #9ca3af; }
.search-clear {
background: none; border: none; cursor: pointer;
color: #9ca3af; font-size: 13px; padding: 0; flex-shrink: 0;
display: none; transition: color .2s;
}
.search-clear:hover { color: var(–dark); }
.search-clear.visible { display: block; }
.header-actions { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
.btn-track-header {
display: flex; align-items: center; gap: 6px;
background: #f0fdf4; color: var(–green);
border: 1.5px solid var(–green); border-radius: 8px;
padding: 7px 12px; font-size: 12px; font-weight: 700;
font-family: var(–font-body); cursor: pointer;
transition: var(–transition); white-space: nowrap; flex-shrink: 0;
text-decoration: none;
}
.btn-track-header:hover { background: var(–green); color: white; }
.btn-icon {
width: 38px; height: 38px; border-radius: 8px; border: none;
display: flex; align-items: center; justify-content: center;
cursor: pointer; font-size: 15px; transition: var(–transition);
background: var(–light-gray); color: var(–dark);
position: relative; text-decoration: none;
}
.btn-icon:hover { background: #e5e7eb; }
.btn-cart-header {
background: var(–orange) !important;
color: white !important;
}
.btn-cart-header:hover { background: var(–orange-light) !important; }
.cart-badge {
position: absolute; top: -4px; right: -4px;
width: 18px; height: 18px; background: var(–red);
border-radius: 50%; font-size: 9px; font-weight: 800;
color: white; display: none;
align-items: center; justify-content: center;
border: 2px solid var(–light-gray);
font-family: var(–font-head);
transition: transform .2s;
}
.cart-badge.show { display: flex; }
.cart-badge.bump { animation: bumpScale .3s ease; }
/* HERO */
.menu-hero {
background: linear-gradient(135deg, #fef9f0 0%, #fef3e2 40%, #f0fdf4 100%);
padding: 56px 24px 52px;
position: relative; overflow: hidden;
}
.menu-hero::before {
content: ”;
position: absolute; top: -60px; right: -60px;
width: 320px; height: 320px; border-radius: 50%;
background: radial-gradient(circle, rgba(29,185,84,.08) 0%, transparent 70%);
pointer-events: none;
}
.menu-hero::after {
content: ”;
position: absolute; bottom: -80px; left: -40px;
width: 240px; height: 240px; border-radius: 50%;
background: radial-gradient(circle, rgba(255,107,0,.07) 0%, transparent 70%);
pointer-events: none;
}
.hero-inner {
max-width: 1280px; margin: 0 auto;
display: flex; align-items: center; justify-content: space-between;
gap: 32px; flex-wrap: wrap; position: relative; z-index: 1;
}
.hero-left { animation: fadeInUp .55s ease both; }
.hero-badge {
display: inline-flex; align-items: center; gap: 8px;
background: white; border: 1px solid #fed7aa;
border-radius: 50px; padding: 8px 16px;
font-size: 13px; font-weight: 600; color: var(–orange);
margin-bottom: 18px; box-shadow: 0 2px 8px rgba(255,107,0,.1);
}
.menu-hero h1 {
font-family: var(–font-head);
font-size: clamp(30px, 4vw, 50px);
font-weight: 900; line-height: 1.1; margin-bottom: 14px;
}
.menu-hero h1 .line1 { color: var(–dark); display: block; }
.menu-hero h1 .line2 { color: var(–green); display: block; }
.menu-hero p {
font-size: 15px; color: var(–gray);
line-height: 1.7; max-width: 500px;
}
.hero-stats {
display: flex; gap: 28px; flex-wrap: wrap;
animation: fadeInUp .6s .15s ease both;
}
.h-stat { text-align: center; }
.h-stat strong {
display: block; font-family: var(–font-head);
font-size: 26px; font-weight: 900; color: var(–dark);
}
.h-stat span { font-size: 12px; color: var(–gray); font-weight: 500; }
/* CATEGORY CHIPS */
.category-strip {
background: white;
border-bottom: 1px solid #e5e7eb;
padding: 16px 0;
position: sticky; top: 63px; z-index: 38;
box-shadow: 0 2px 8px rgba(0,0,0,.04);
}
.cat-strip-inner {
max-width: 1280px; margin: 0 auto;
padding: 0 20px;
display: flex; align-items: center; gap: 10px;
overflow-x: auto; scrollbar-width: none;
}
.cat-strip-inner::-webkit-scrollbar { display: none; }
.cat-chip {
flex-shrink: 0; display: flex; align-items: center; gap: 7px;
border: 2px solid #e5e7eb; border-radius: 50px;
padding: 8px 16px; font-size: 13px; font-weight: 700;
background: white; color: var(–dark); cursor: pointer;
transition: var(–transition); white-space: nowrap;
font-family: var(–font-body);
}
.cat-chip:hover { border-color: var(–green); background: #f0fdf4; color: var(–green); }
.cat-chip.active {
border-color: var(–green); background: var(–green);
color: white; box-shadow: 0 4px 14px rgba(29,185,84,.3);
}
.cat-chip .cat-count {
background: rgba(0,0,0,.1); color: inherit;
font-size: 10px; font-weight: 800;
padding: 2px 7px; border-radius: 50px;
}
.cat-chip.active .cat-count { background: rgba(255,255,255,.25); }
/* FILTER BAR */
.filter-section {
background: var(–light-gray);
border-bottom: 1px solid #e5e7eb;
padding: 14px 20px;
position: sticky; top: 115px; z-index: 37;
}
.filter-inner {
max-width: 1280px; margin: 0 auto;
display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
}
.filter-label {
font-size: 12px; font-weight: 800; color: var(–gray);
text-transform: uppercase; letter-spacing: .5px;
white-space: nowrap; flex-shrink: 0;
}
.filter-select { display: flex; flex-direction: column; gap: 0; }
.filter-select select {
padding: 9px 32px 9px 12px; border: 1.5px solid #e5e7eb;
border-radius: 10px; font-size: 13px; font-weight: 600;
font-family: var(–font-body); outline: none; background: white;
color: var(–dark); cursor: pointer; appearance: none;
background-image: url(“data:image/svg+xml,%3Csvg xmlns=’http://www.w3.org/2000/svg’ width=’12’ height=’12’ viewBox=’0 0 12 12’%3E%3Cpath fill=’%236b7280′ d=’M6 8L1 3h10z’/%3E%3C/svg%3E”);
background-repeat: no-repeat; background-position: right 10px center;
transition: var(–transition);
}
.filter-select select:focus { border-color: var(–green); box-shadow: 0 0 0 3px var(–green-glow); }
.filter-select select:hover { border-color: #d1d5db; }
.filter-divider { width: 1px; height: 28px; background: #d1d5db; flex-shrink: 0; }
.active-filters { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.filter-pill {
display: flex; align-items: center; gap: 5px;
background: var(–green); color: white;
border-radius: 50px; padding: 4px 10px;
font-size: 11px; font-weight: 700;
animation: fadeIn .2s ease;
}
.filter-pill button {
background: none; border: none; color: white; cursor: pointer;
font-size: 11px; padding: 0; line-height: 1;
display: flex; align-items: center; opacity: .8;
transition: opacity .2s;
}
.filter-pill button:hover { opacity: 1; }
.btn-clear-all {
display: none; align-items: center; gap: 5px;
background: none; border: 1.5px solid #e5e7eb; border-radius: 8px;
padding: 7px 12px; font-size: 12px; font-weight: 700;
font-family: var(–font-body); color: var(–gray); cursor: pointer;
transition: var(–transition); white-space: nowrap; flex-shrink: 0;
}
.btn-clear-all.show { display: flex; }
.btn-clear-all:hover { border-color: var(–red); color: var(–red); }
.filter-right { margin-left: auto; }
.result-count-inline { font-size: 12px; color: var(–gray); font-weight: 600; white-space: nowrap; }
.result-count-inline strong { color: var(–dark); }
/* MAIN CONTENT */
.menu-content { padding: 32px 20px 80px; }
.menu-inner { max-width: 1280px; margin: 0 auto; }
.content-header {
display: flex; align-items: center; justify-content: space-between;
margin-bottom: 28px; flex-wrap: wrap; gap: 12px;
}
.content-header-left h2 {
font-family: var(–font-head); font-size: clamp(20px, 2.5vw, 28px);
font-weight: 900; margin-bottom: 2px;
}
.content-header-left p { font-size: 13px; color: var(–gray); }
.view-toggle { display: flex; gap: 4px; }
.view-btn {
width: 34px; height: 34px; border-radius: 8px; border: 1.5px solid #e5e7eb;
background: white; cursor: pointer; font-size: 13px; color: var(–gray);
display: flex; align-items: center; justify-content: center;
transition: var(–transition);
}
.view-btn.active, .view-btn:hover {
border-color: var(–green); color: var(–green); background: #f0fdf4;
}
/* SKELETON */
.skeleton-grid {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
gap: 22px;
}
.skeleton-card { background: white; border-radius: var(–radius); overflow: hidden; border: 1px solid #f3f4f6; }
.skeleton-img { height: 195px; }
.skeleton-body { padding: 16px; }
.skeleton-line {
border-radius: 6px; margin-bottom: 10px;
background: linear-gradient(90deg, #f3f4f6 25%, #e9ebee 50%, #f3f4f6 75%);
background-size: 600px 100%;
animation: shimmer 1.4s infinite linear;
}
.sk-img { height: 100%; border-radius: 0; margin-bottom: 0; }
.sk-h { height: 18px; width: 75%; }
.sk-sm { height: 12px; width: 50%; }
.sk-p { height: 11px; width: 90%; }
.sk-p2 { height: 11px; width: 70%; }
.sk-foot { display: flex; justify-content: space-between; align-items: center; margin-top: 14px; }
.sk-price { height: 20px; width: 60px; border-radius: 6px; background: linear-gradient(90deg,#f3f4f6 25%,#e9ebee 50%,#f3f4f6 75%); background-size:600px 100%; animation: shimmer 1.4s infinite linear; }
.sk-btn { height: 34px; width: 70px; border-radius: 8px; background: linear-gradient(90deg,#f3f4f6 25%,#e9ebee 50%,#f3f4f6 75%); background-size:600px 100%; animation: shimmer 1.4s 0.1s infinite linear; }
/* STATE CARDS */
.state-card {
display: none;
flex-direction: column; align-items: center; justify-content: center;
padding: 80px 24px; gap: 16px; text-align: center;
}
.state-card.show { display: flex; animation: fadeInUp .4s ease; }
.state-icon { font-size: 54px; line-height: 1; }
.state-card h3 { font-family: var(–font-head); font-size: 22px; font-weight: 800; color: var(–dark); }
.state-card p { font-size: 14px; color: var(–gray); max-width: 380px; line-height: 1.65; }
.btn-retry {
display: flex; align-items: center; gap: 8px;
background: var(–green); color: white; border: none;
padding: 12px 24px; border-radius: 10px;
font-size: 14px; font-weight: 700; font-family: var(–font-body);
cursor: pointer; transition: var(–transition);
margin-top: 4px;
}
.btn-retry:hover { background: var(–green-dark); transform: translateY(-1px); }
/* PRODUCT GRID */
#productsGrid {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
gap: 22px;
margin-bottom: 48px;
}
#productsGrid.list-view { grid-template-columns: 1fr; }
.product-card {
background: white; border-radius: var(–radius);
overflow: hidden; border: 1px solid #e9ebee;
transition: var(–transition); cursor: pointer;
animation: fadeInUp .45s ease both;
position: relative;
}
.product-card:hover {
transform: translateY(-5px);
box-shadow: var(–shadow-lg);
border-color: transparent;
}
.product-img-wrap {
position: relative; height: 195px; overflow: hidden;
background: var(–light-gray);
}
.product-img-wrap img {
width: 100%; height: 100%; object-fit: cover; display: block;
transition: transform .5s cubic-bezier(.25,.46,.45,.94);
}
.product-card:hover .product-img-wrap img { transform: scale(1.06); }
.prod-badge-wrap {
position: absolute; top: 10px; left: 10px;
display: flex; flex-direction: column; gap: 5px;
}
.prod-badge {
display: inline-flex; align-items: center; gap: 4px;
padding: 4px 10px; border-radius: 50px;
font-size: 10px; font-weight: 800; color: white; line-height: 1;
}
.prod-badge.sale { background: var(–red); }
.prod-badge.featured { background: var(–orange); }
.prod-badge.new { background: var(–green); }
.prod-rating-pill {
position: absolute; bottom: 10px; left: 10px;
background: white; border-radius: 50px;
padding: 4px 10px; display: flex; align-items: center; gap: 4px;
font-size: 12px; font-weight: 800;
box-shadow: 0 2px 8px rgba(0,0,0,.15);
}
.prod-rating-pill .star { color: #f59e0b; font-size: 11px; }
.prod-wish {
position: absolute; top: 10px; right: 10px;
width: 32px; height: 32px; background: white; border-radius: 50%;
display: flex; align-items: center; justify-content: center;
font-size: 14px; color: #d1d5db; cursor: pointer;
box-shadow: 0 2px 8px rgba(0,0,0,.12);
transition: var(–transition); border: none;
z-index: 2;
}
.prod-wish:hover { color: var(–red); transform: scale(1.1); }
.prod-wish.active { color: var(–red); }
.prod-quick-add {
position: absolute; bottom: 0; left: 0; right: 0;
background: linear-gradient(to top, rgba(17,24,39,.88) 0%, transparent 100%);
padding: 28px 12px 12px;
transform: translateY(100%);
transition: transform .3s ease;
z-index: 1;
}
.product-card:hover .prod-quick-add { transform: translateY(0); }
.btn-quick-add {
width: 100%; background: var(–green); color: white; border: none;
padding: 10px; border-radius: 10px;
font-size: 13px; font-weight: 800; font-family: var(–font-head);
cursor: pointer; display: flex; align-items: center;
justify-content: center; gap: 6px;
transition: var(–transition);
}
.btn-quick-add:hover { background: var(–green-dark); }
.btn-quick-add:disabled { background: #9ca3af; cursor: not-allowed; }
.product-body { padding: 14px 14px 16px; }
.prod-vendor {
font-size: 11px; font-weight: 700; color: var(–green);
margin-bottom: 4px; display: flex; align-items: center; gap: 4px;
}
.prod-vendor i { font-size: 9px; }
.prod-name {
font-family: var(–font-head); font-size: 15px; font-weight: 800;
color: var(–dark); line-height: 1.3; margin-bottom: 5px;
}
.prod-desc {
font-size: 12px; color: var(–gray); line-height: 1.5;
margin-bottom: 12px;
display: -webkit-box; -webkit-line-clamp: 2;
-webkit-box-orient: vertical; overflow: hidden;
}
.product-footer {
display: flex; justify-content: space-between;
align-items: center; gap: 8px;
}
.prod-price {
font-family: var(–font-head); font-size: 19px; font-weight: 900;
color: var(–green); display: block; line-height: 1;
}
.prod-price-old {
font-size: 11px; color: #9ca3af;
text-decoration: line-through; font-weight: 600;
margin-top: 2px; display: block;
}
.btn-add-cart {
display: flex; align-items: center; gap: 6px;
background: var(–green); color: white; border: none;
padding: 9px 14px; border-radius: 9px;
font-size: 12px; font-weight: 700; font-family: var(–font-body);
cursor: pointer; transition: var(–transition);
white-space: nowrap; flex-shrink: 0;
}
.btn-add-cart:hover { background: var(–green-dark); transform: translateY(-1px); }
.btn-add-cart:disabled { background: #d1d5db; cursor: not-allowed; transform: none; }
.btn-add-cart.loading { background: var(–green-dark); }
.btn-add-cart.done { background: #16a34a; }
/* LIST VIEW */
#productsGrid.list-view .product-card { display: grid; grid-template-columns: 200px 1fr; }
#productsGrid.list-view .product-img-wrap { height: 100%; min-height: 150px; }
#productsGrid.list-view .prod-quick-add { display: none; }
#productsGrid.list-view .product-body { padding: 18px 20px; display: flex; flex-direction: column; justify-content: space-between; }
/* PAGINATION */
.pagination {
display: flex; justify-content: center; align-items: center;
gap: 6px; flex-wrap: wrap; margin-top: 8px;
}
.page-btn {
min-width: 38px; height: 38px; border: 1.5px solid #e5e7eb;
border-radius: 9px; background: white; color: var(–dark);
font-size: 13px; font-weight: 700; font-family: var(–font-body);
cursor: pointer; transition: var(–transition); padding: 0 10px;
display: flex; align-items: center; justify-content: center; gap: 5px;
}
.page-btn:hover:not(:disabled) { border-color: var(–green); color: var(–green); background: #f0fdf4; }
.page-btn.active { background: var(–green); color: white; border-color: var(–green); box-shadow: 0 4px 14px rgba(29,185,84,.3); }
.page-btn:disabled { opacity: .4; cursor: not-allowed; }
.page-dots { color: var(–gray); font-size: 14px; padding: 0 4px; }
/* TOAST */
.toast-container {
position: fixed; bottom: 28px; right: 24px;
z-index: 9999; display: flex; flex-direction: column;
gap: 10px; pointer-events: none;
}
.toast {
background: var(–dark); color: white;
border-radius: 14px; padding: 14px 18px;
display: flex; align-items: center; gap: 12px;
box-shadow: 0 12px 40px rgba(0,0,0,.25);
animation: slideDown .35s cubic-bezier(.34,1.56,.64,1) both;
max-width: 320px; pointer-events: all;
}
.toast-icon { font-size: 22px; flex-shrink: 0; line-height: 1; }
.toast-body strong { display: block; font-size: 13px; font-weight: 700; margin-bottom: 2px; }
.toast-body span { font-size: 11px; color: rgba(255,255,255,.6); }
.toast.error .toast-icon { font-size: 18px; color: #f87171; }
.toast-close {
margin-left: auto; background: none; border: none;
color: rgba(255,255,255,.45); cursor: pointer; font-size: 13px;
flex-shrink: 0; transition: color .2s;
}
.toast-close:hover { color: white; }
/* STICKY MOBILE CART BAR */
.sticky-cart-bar {
position: fixed; bottom: 0; left: 0; right: 0;
background: white; border-top: 1.5px solid #e5e7eb;
padding: 12px 20px; z-index: 89;
display: none; align-items: center; justify-content: space-between; gap: 14px;
box-shadow: 0 -8px 32px rgba(0,0,0,.1);
}
.sticky-cart-bar.show { display: flex; }
.scb-text strong { font-family: var(–font-head); font-size: 14px; font-weight: 800; }
.scb-text span { font-size: 11px; color: var(–gray); display: block; }
.scb-btn {
display: flex; align-items: center; gap: 7px;
background: var(–orange); color: white; border: none;
padding: 12px 20px; border-radius: 10px;
font-size: 14px; font-weight: 800; font-family: var(–font-head);
cursor: pointer; transition: var(–transition);
text-decoration: none; white-space: nowrap; flex-shrink: 0;
}
.scb-btn:hover { background: var(–orange-light); }
/* BACK TO TOP */
.back-to-top {
position: fixed; bottom: 28px; left: 24px; z-index: 88;
width: 42px; height: 42px; background: var(–dark2); color: white;
border: none; border-radius: 50%; font-size: 16px; cursor: pointer;
display: none; align-items: center; justify-content: center;
box-shadow: 0 6px 20px rgba(0,0,0,.2); transition: var(–transition);
}
.back-to-top.show { display: flex; }
.back-to-top:hover { background: var(–dark); transform: translateY(-2px); }
/* RESPONSIVE */
@media(max-width:1024px) {
#productsGrid { grid-template-columns: repeat(auto-fill, minmax(210px, 1fr)); }
}
@media(max-width:768px) {
.header-inner { flex-wrap: wrap; gap: 8px; padding: 10px 12px; }
.logo { order: 1; }
.header-actions { order: 2; margin-left: auto; }
.campus-selector, .btn-track-header { display: none; }
.search-bar { order: 3; width: 100%; }
.btn-icon:not(.btn-cart-header):not(#headerUserBtn) { display: none; }
.menu-hero { padding: 36px 16px 40px; }
.hero-inner { flex-direction: column; gap: 24px; }
.menu-hero h1 { font-size: 28px; }
.hero-stats { gap: 20px; justify-content: flex-start; }
.h-stat strong { font-size: 22px; }
.category-strip { top: 58px; }
.filter-section { top: 109px; padding: 10px 12px; }
.filter-inner { gap: 8px; }
.filter-divider { display: none; }
.filter-right { width: 100%; }
.filter-select select { padding: 8px 28px 8px 10px; font-size: 12px; }
.menu-content { padding: 20px 12px 80px; }
#productsGrid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
#productsGrid.list-view { grid-template-columns: 1fr; }
#productsGrid.list-view .product-img-wrap { height: 140px; min-height: 0; }
#productsGrid.list-view .product-card { grid-template-columns: 140px 1fr; }
.product-img-wrap { height: 160px; }
.prod-name { font-size: 13px; }
.prod-price { font-size: 16px; }
.btn-add-cart { padding: 8px 12px; font-size: 11px; }
.skeleton-grid { grid-template-columns: repeat(2,1fr); gap: 12px; }
.skeleton-img { height: 160px; }
.toast-container { bottom: 12px; right: 12px; left: 12px; }
.toast { max-width: 100%; }
.sticky-cart-bar { display: flex; }
.back-to-top { bottom: 70px; }
}
@media(max-width:420px) {
#productsGrid { grid-template-columns: 1fr; }
.skeleton-grid { grid-template-columns: 1fr; }
.product-img-wrap { height: 200px; }
}

Track Order
0
Explore Our Full
Campus Menu
From Jollof Rice to Shawarma, Egusi to Pizza — filter by category, price or rating and get it delivered hot in minutes.
—Total Dishes
30+Vendors
15 minAvg. Delivery
4.8⭐Avg. Rating
🍽️ All
Filter
💰 All Prices
Under ₦500
₦500 – ₦1,000
₦1,000 – ₦2,000
Above ₦2,000
🔥 Most Popular
⭐ Highest Rated
⬆️ Price: Low–High
⬇️ Price: High–Low
🆕 Newest First
Loading…
All Dishes
Browse our full campus menu
😕
Couldn’t load the menu
There was a problem connecting to the store. Please check your connection and try again.
🍽️
No dishes found
No dishes match your current filters. Try adjusting the category, price range, or search term.
0 items
in your cart
View Cart
Showing 1–15 of 75 results
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
Fried Rice and Jollof with Chicken
Original price was: ₦4,000.00.₦3,500.00Current price is: ₦3,500.00. Add to cart










