/* ══════════════════════════════════════════════════
   EBOGIANT FOODS — style.css  (FULL UPGRADE)
   Warm artisan luxury: forest green + terracotta + cream
   Fonts: Playfair Display · Lato · Dancing Script
══════════════════════════════════════════════════ */

/* ── TOKENS ── */
:root {
  --green:        #2d5a27;
  --green-mid:    #3d7a35;
  --green-light:  #5a9e50;
  --green-pale:   #d4e8d0;
  --green-bg:     rgba(45,90,39,0.08);

  --terra:        #b84c2a;
  --terra-light:  #d4694a;
  --terra-pale:   #f2d5cc;

  --cream:        #faf6ef;
  --cream-2:      #f4ede0;
  --cream-3:      #ede1ce;
  --parchment:    #e8d9c0;
  --warm-white:   #fffdf9;

  --brown:        #5c3a1e;
  --brown-light:  #8b5e3c;
  --brown-pale:   #d4b896;

  --text-dark:    #2a1a0e;
  --text-mid:     #5c3a1e;
  --text-muted:   #9c7a5a;
  --text-light:   #c4a882;

  --whatsapp:     #25d366;
  --whatsapp-dark:#128c4f;

  --shadow-warm:  0 4px 24px rgba(92,58,30,0.12);
  --shadow-deep:  0 8px 40px rgba(42,26,14,0.18);
  --shadow-card:  0 2px 16px rgba(92,58,30,0.10);

  --r-sm: 8px; --r-md: 14px; --r-lg: 22px; --r-xl: 32px;
  --transition: 0.25s cubic-bezier(0.4,0,0.2,1);

  --nav-h: 68px;
  --cat-h: 60px;
  --sticky-offset: calc(var(--nav-h) + var(--cat-h));
}

/* ── RESET ── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { font-size:16px; scroll-behavior:smooth; }
body {
  font-family:'Lato',sans-serif;
  background:var(--cream);
  color:var(--text-dark);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img { max-width:100%; display:block; }
a  { text-decoration:none; color:inherit; }
em { font-style:italic; color:var(--green); }
.container { max-width:1160px; margin:0 auto; padding:0 20px; }

/* ══════════════════════════════════════════
   STICKY WHATSAPP BUTTON
══════════════════════════════════════════ */
.sticky-wa {
  position:fixed; bottom:24px; right:20px; z-index:200;
  display:flex; align-items:center; gap:10px;
  background:var(--whatsapp); color:#fff;
  font-family:'Lato',sans-serif; font-weight:700; font-size:.95rem;
  padding:.85rem 1.4rem; border-radius:100px;
  box-shadow:0 6px 32px rgba(37,211,102,0.45);
  transition:var(--transition);
  border:2px solid rgba(255,255,255,0.3);
  animation:waPulse 3s ease-in-out infinite;
}
.sticky-wa:hover { transform:scale(1.06) translateY(-2px); box-shadow:0 10px 40px rgba(37,211,102,0.55); }
.wa-icon { width:22px; height:22px; flex-shrink:0; }
@keyframes waPulse { 0%,100%{box-shadow:0 6px 32px rgba(37,211,102,.45)} 50%{box-shadow:0 6px 32px rgba(37,211,102,.7),0 0 0 8px rgba(37,211,102,.1)} }

/* ══════════════════════════════════════════
   CART BUBBLE
══════════════════════════════════════════ */
.cart-bubble {
  position:fixed; bottom:86px; right:20px; z-index:200;
  width:52px; height:52px; border-radius:50%;
  background:var(--green); color:#fff; border:2px solid rgba(255,255,255,.2);
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:var(--transition);
  box-shadow:0 4px 20px rgba(45,90,39,.45);
}
.cart-bubble:hover { transform:scale(1.1); background:var(--green-mid); }
.cart-count {
  position:absolute; top:-5px; right:-5px;
  background:var(--terra); color:#fff;
  width:20px; height:20px; border-radius:50%;
  font-size:.7rem; font-weight:700;
  display:flex; align-items:center; justify-content:center;
  border:2px solid var(--warm-white);
  transition:transform .2s;
}
.cart-bubble.has-items .cart-count { transform:scale(1.2); }

/* ══════════════════════════════════════════
   NAVIGATION
══════════════════════════════════════════ */
.nav {
  position:fixed; top:0; left:0; right:0; z-index:100;
  background:rgba(250,246,239,0.95);
  backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid var(--parchment);
  box-shadow:0 2px 20px rgba(92,58,30,0.08);
}
.nav-inner {
  max-width:1160px; margin:0 auto; padding:0 20px;
  height:var(--nav-h); display:flex; align-items:center; justify-content:space-between;
}
.nav-logo { display:flex; align-items:center; }
.logo-circle {
  display:flex; align-items:center; gap:8px;
  background:var(--text-dark); border-radius:50px;
  padding:6px 14px 6px 8px;
}
.logo-img { width:32px; height:32px; border-radius:50%; object-fit:cover; }
.logo-leaves { display:flex; gap:2px; }
.logo-text-wrap { display:flex; flex-direction:column; line-height:1.1; }
.logo-text-wrap strong { font-family:'Playfair Display',serif; font-size:.95rem; font-weight:800; color:var(--green-light); letter-spacing:.05em; }
.logo-text-wrap em    { font-family:'Dancing Script',cursive; font-size:.9rem; font-weight:600; color:var(--terra-light); font-style:normal; }

.nav-links { display:flex; align-items:center; gap:2rem; list-style:none; }
.nav-links a { font-size:.9rem; font-weight:700; color:var(--text-mid); letter-spacing:.04em; text-transform:uppercase; transition:color .2s; position:relative; }
.nav-links a::after { content:''; position:absolute; bottom:-4px; left:0; right:0; height:2px; background:var(--green); border-radius:1px; transform:scaleX(0); transition:transform .25s; transform-origin:left; }
.nav-links a:hover { color:var(--green); }
.nav-links a:hover::after { transform:scaleX(1); }

.nav-order-btn { background:var(--green) !important; color:#fff !important; padding:.5rem 1.2rem; border-radius:100px; font-size:.85rem !important; font-weight:700 !important; transition:var(--transition) !important; display:inline-flex !important; align-items:center; gap:6px; }
.nav-order-btn:hover { background:var(--green-mid) !important; transform:translateY(-1px); }
.nav-order-btn::after { display:none !important; }

.hamburger { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:4px; }
.hamburger span { display:block; width:24px; height:2px; background:var(--text-mid); border-radius:2px; transition:.3s; }
.hamburger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity:0; }
.hamburger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

.nav-links.mobile-open {
  display:flex; flex-direction:column; gap:0;
  position:fixed; top:var(--nav-h); left:0; right:0;
  background:var(--warm-white); border-bottom:2px solid var(--parchment);
  padding:1rem 0; align-items:center;
  box-shadow:var(--shadow-deep); z-index:99;
}
.nav-links.mobile-open a { padding:.85rem 2rem; font-size:1rem; }

/* ══════════════════════════════════════════
   HERO
══════════════════════════════════════════ */
.hero {
  min-height:100vh; display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  text-align:center; position:relative; overflow:hidden;
  padding:100px 20px 80px;
  background:var(--text-dark);
}
.hero-bg-pattern {
  position:absolute; inset:0; z-index:0; pointer-events:none;
  background-image:
    radial-gradient(circle at 20% 30%, rgba(45,90,39,0.35) 0, transparent 45%),
    radial-gradient(circle at 80% 70%, rgba(184,76,42,0.25) 0, transparent 40%),
    radial-gradient(circle at 60% 10%, rgba(90,158,80,0.15) 0, transparent 35%);
  background-color:var(--text-dark);
}
.hero-bg-pattern::after {
  content:''; position:absolute; inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='grain'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23grain)' opacity='0.06'/%3E%3C/svg%3E");
  opacity:.6;
}
.hero-overlay { position:absolute; inset:0; z-index:1; pointer-events:none; background:linear-gradient(180deg,rgba(42,26,14,.15) 0%,rgba(42,26,14,.3) 100%); }
.hero-content { position:relative; z-index:2; max-width:680px; }

.hero-badge { display:inline-flex; align-items:center; gap:8px; font-size:.78rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--green-light); background:rgba(45,90,39,.2); border:1px solid rgba(90,158,80,.3); border-radius:100px; padding:.45rem 1.1rem; margin-bottom:2rem; animation:fadeUp .7s ease both; }
.badge-dot { width:6px; height:6px; border-radius:50%; background:var(--green-light); animation:blink 2s ease-in-out infinite; }
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:.3} }

.hero-logo-big { margin-bottom:1.5rem; animation:fadeUp .7s .1s ease both; }
.hlb-circle { width:100px; height:100px; border-radius:50%; background:var(--text-dark); border:3px solid rgba(90,158,80,.4); margin:0 auto; display:flex; align-items:center; justify-content:center; box-shadow:0 0 40px rgba(45,90,39,.4); overflow:hidden; }
.hlb-logo-img { width:100px; height:100px; object-fit:cover; }
.hlb-inner { text-align:center; }
.hlb-icon  { font-size:1.4rem; line-height:1; }
.hlb-name strong { display:block; font-family:'Playfair Display',serif; font-size:.7rem; font-weight:800; color:var(--green-light); letter-spacing:.1em; }
.hlb-name em     { display:block; font-family:'Dancing Script',cursive; font-size:.75rem; color:var(--terra-light); font-style:normal; }

.hero-headline { font-family:'Playfair Display',serif; font-size:clamp(2.5rem,8vw,5rem); font-weight:800; color:#fff; line-height:1.1; margin-bottom:1.25rem; letter-spacing:-.02em; animation:fadeUp .7s .2s ease both; }
.hero-headline em { color:var(--green-light); font-style:italic; }
.hero-sub { font-size:clamp(1rem,2.5vw,1.2rem); color:rgba(255,255,255,.7); max-width:480px; margin:0 auto 2.5rem; line-height:1.7; animation:fadeUp .7s .3s ease both; }

.hero-ctas { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; margin-bottom:2.5rem; animation:fadeUp .7s .4s ease both; }
.cta-primary { display:inline-flex; align-items:center; gap:10px; background:linear-gradient(135deg,var(--green),var(--green-mid)); color:#fff; font-weight:700; font-size:1.05rem; padding:.9rem 2rem; border-radius:100px; box-shadow:0 8px 32px rgba(45,90,39,.45); transition:var(--transition); border:none; cursor:pointer; font-family:'Lato',sans-serif; }
.cta-primary:hover { transform:translateY(-3px); box-shadow:0 12px 40px rgba(45,90,39,.55); }
.cta-whatsapp { display:inline-flex; align-items:center; gap:10px; background:var(--whatsapp); color:#fff; font-weight:700; font-size:1.05rem; padding:.9rem 2rem; border-radius:100px; box-shadow:0 8px 32px rgba(37,211,102,.4); transition:var(--transition); }
.cta-whatsapp:hover { transform:translateY(-3px); background:var(--whatsapp-dark); }

.hero-trust { display:flex; align-items:center; gap:.75rem; justify-content:center; flex-wrap:wrap; animation:fadeUp .7s .5s ease both; }
.trust-item { display:flex; align-items:center; gap:5px; font-size:.85rem; color:rgba(255,255,255,.6); }
.trust-icon { font-size:1rem; }
.trust-dot  { color:rgba(255,255,255,.3); font-size:1.2rem; }
.hero-scroll { position:absolute; bottom:30px; left:50%; transform:translateX(-50%); z-index:2; }
.scroll-arrow { width:28px; height:28px; border-right:2px solid rgba(255,255,255,.4); border-bottom:2px solid rgba(255,255,255,.4); transform:rotate(45deg); animation:scrollBounce 1.5s ease-in-out infinite; }
@keyframes scrollBounce { 0%,100%{transform:rotate(45deg) translateY(0)} 50%{transform:rotate(45deg) translateY(6px)} }

/* ══════════════════════════════════════════
   QUICK ORDER BAR
══════════════════════════════════════════ */
.quick-order-bar {
  background:linear-gradient(135deg,var(--green),var(--green-mid));
  padding:.75rem 0;
  position:sticky; top:var(--nav-h); z-index:51;
}
.qob-inner { display:flex; align-items:center; justify-content:space-between; gap:1rem; }
.qob-left { display:flex; align-items:center; gap:8px; color:#fff; font-size:.88rem; }
.qob-left svg { flex-shrink:0; opacity:.85; }

/* Toggle switch */
.toggle-switch { position:relative; display:inline-block; width:44px; height:24px; flex-shrink:0; }
.toggle-switch input { opacity:0; width:0; height:0; }
.toggle-slider {
  position:absolute; cursor:pointer; top:0; left:0; right:0; bottom:0;
  background:rgba(255,255,255,.3); border-radius:24px; transition:.3s;
}
.toggle-slider::before {
  content:''; position:absolute; height:18px; width:18px;
  left:3px; bottom:3px; background:#fff; border-radius:50%; transition:.3s;
}
input:checked + .toggle-slider { background:var(--terra-light); }
input:checked + .toggle-slider::before { transform:translateX(20px); }

/* Active state visual */
body.quick-mode-on .quick-order-bar { background:linear-gradient(135deg,var(--terra),var(--terra-light)); }
body.quick-mode-on .products::before {
  content:'⚡ Quick Order Mode ON — tap any product to WhatsApp instantly';
  display:block; text-align:center;
  background:var(--terra-pale); color:var(--terra);
  font-weight:700; font-size:.85rem;
  padding:.6rem 1rem; border-radius:var(--r-md);
  margin:0 0 1.5rem; border:1.5px solid var(--terra);
}

/* ══════════════════════════════════════════
   CATEGORY NAV — STICKY
══════════════════════════════════════════ */
.category-nav {
  background:var(--warm-white);
  border-bottom:1px solid var(--parchment);
  padding:1rem 0;
  position:sticky; top:calc(var(--nav-h) + 46px); z-index:50;
  box-shadow:0 2px 12px rgba(92,58,30,0.06);
}
.cat-pills {
  display:flex; gap:.6rem; overflow-x:auto; padding:0 4px 2px;
  scrollbar-width:none; -ms-overflow-style:none;
  flex-wrap:nowrap; /* Force horizontal scroll on mobile, center on desktop */
  justify-content:center;
}
.cat-pills::-webkit-scrollbar { display:none; }
.cat-icon-img { width:16px; height:16px; object-fit:contain; }

.cat-pill {
  display:inline-flex; align-items:center; gap:6px;
  font-family:'Lato',sans-serif; font-size:.88rem; font-weight:700;
  color:var(--text-mid); background:var(--cream-2);
  border:1.5px solid var(--parchment); border-radius:100px;
  padding:.5rem 1.1rem; cursor:pointer; white-space:nowrap;
  transition:var(--transition); flex-shrink:0;
}
.cat-pill:hover  { border-color:var(--green); color:var(--green); background:var(--green-bg); }
.cat-pill.active { background:var(--green); color:#fff; border-color:var(--green); }

/* ══════════════════════════════════════════
   SORT BAR
══════════════════════════════════════════ */
.sort-bar {
  display:flex; align-items:center; gap:.5rem; margin-bottom:1.5rem; flex-wrap:wrap;
}
.sort-label { font-size:.82rem; font-weight:700; color:var(--text-muted); text-transform:uppercase; letter-spacing:.06em; }
.sort-btn {
  display:inline-flex; align-items:center; gap:5px;
  font-family:'Lato',sans-serif; font-size:.8rem; font-weight:700;
  color:var(--text-mid); background:var(--cream-3);
  border:1.5px solid var(--parchment); border-radius:100px;
  padding:.35rem .85rem; cursor:pointer; transition:var(--transition);
}
.sort-btn:hover { border-color:var(--green); color:var(--green); }
.sort-btn.active { background:var(--green); color:#fff; border-color:var(--green); }

/* ══════════════════════════════════════════
   SECTION SHARED
══════════════════════════════════════════ */
.section-header { text-align:center; margin-bottom:3rem; }
.section-eyebrow { font-family:'Dancing Script',cursive; font-size:1.1rem; font-weight:600; color:var(--terra); letter-spacing:.05em; margin-bottom:.4rem; }
.section-title { font-family:'Playfair Display',serif; font-size:clamp(1.8rem,4vw,2.8rem); font-weight:800; color:var(--text-dark); line-height:1.15; margin-bottom:.5rem; }
.section-sub { color:var(--text-muted); font-size:.97rem; }

/* ══════════════════════════════════════════
   PRODUCTS GRID
══════════════════════════════════════════ */
.products { padding:80px 0; background:var(--cream-2); }
.category-heading { font-family:'Playfair Display',serif; font-size:1.5rem; font-weight:700; color:var(--text-dark); margin:2.5rem 0 1rem; display:flex; align-items:center; gap:.75rem; padding-bottom:.5rem; border-bottom:2px solid var(--parchment); }
.category-heading .cat-emoji-label { width:36px; height:36px; object-fit:contain; }

.products-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:1.5rem; }

/* ── PRODUCT CARD ── */
.product-card {
  background:var(--warm-white); border-radius:var(--r-lg);
  border:1px solid var(--parchment); box-shadow:var(--shadow-card);
  overflow:hidden; transition:var(--transition); display:flex; flex-direction:column;
}
.product-card:hover { transform:translateY(-5px); box-shadow:var(--shadow-deep); border-color:var(--green-pale); }
.product-card:active { transform:translateY(-2px); }

/* Image area — real photo or SVG fallback */
.product-img {
  height:200px; position:relative; overflow:hidden;
  background:var(--cream-3); display:flex; align-items:center; justify-content:center;
  cursor:pointer;
}
.product-real-img {
  width:100%; height:100%; object-fit:cover;
  transition:transform .5s;
}
.product-card:hover .product-real-img { transform:scale(1.06); }
.product-svg-fallback {
  display:flex; align-items:center; justify-content:center; width:100%; height:100%;
}
.product-svg-fallback svg { width:72px; height:72px; opacity:.7; transition:transform .4s; }
.product-card:hover .product-svg-fallback svg { transform:scale(1.12) rotate(-3deg); }

/* Zoom hint overlay */
.product-img::after {
  content:'Tap to zoom';
  position:absolute; bottom:8px; right:10px;
  background:rgba(0,0,0,.45); color:#fff; backdrop-filter:blur(4px);
  font-size:.65rem; font-weight:700; letter-spacing:.04em;
  padding:.25rem .6rem; border-radius:100px; opacity:0;
  transition:opacity .2s; pointer-events:none;
}
.product-card:hover .product-img::after { opacity:1; }

.product-badge { position:absolute; top:12px; left:12px; background:var(--terra); color:#fff; font-size:.7rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase; padding:.3rem .75rem; border-radius:100px; }
.product-badge.new     { background:var(--green); }
.product-badge.hot     { background:var(--terra); }
.product-badge.popular { background:var(--brown); }

.product-body { padding:1.25rem; flex:1; display:flex; flex-direction:column; gap:.5rem; }
.product-name { font-family:'Playfair Display',serif; font-size:1.15rem; font-weight:700; color:var(--text-dark); line-height:1.2; }
.product-desc { font-size:.875rem; color:var(--text-muted); line-height:1.6; flex:1; }
.product-price { font-family:'Playfair Display',serif; font-size:1.35rem; font-weight:800; color:var(--green); letter-spacing:-.01em; }
.product-price .unit { font-size:.8rem; font-weight:400; color:var(--text-muted); font-family:'Lato',sans-serif; }

.upsell-hint { display:flex; align-items:center; gap:6px; font-size:.78rem; color:var(--terra); font-weight:600; background:var(--terra-pale); padding:.35rem .8rem; border-radius:100px; width:fit-content; }

/* Product actions */
.product-actions { display:flex; flex-direction:column; gap:.65rem; margin-top:.5rem; padding-top:.75rem; border-top:1px solid var(--cream-3); }

/* Quick-order button row — 3 across on large, stack on mobile */
.product-btn-row { display:flex; gap:.5rem; }

.btn-wa {
  display:flex; align-items:center; justify-content:center; gap:9px;
  background:var(--whatsapp); color:#fff; font-weight:700; font-size:.92rem; font-family:'Lato',sans-serif;
  padding:.82rem 1rem; border-radius:var(--r-md); border:none; cursor:pointer;
  transition:var(--transition); flex:1;
}
.btn-wa:hover { background:var(--whatsapp-dark); transform:translateY(-1px); }
.btn-wa:active { transform:translateY(0); }

.btn-add-cart {
  display:flex; align-items:center; justify-content:center; gap:7px;
  background:var(--green-bg); color:var(--green); font-weight:700; font-size:.88rem; font-family:'Lato',sans-serif;
  padding:.82rem .9rem; border-radius:var(--r-md); border:1.5px solid var(--green-pale); cursor:pointer;
  transition:var(--transition); flex-shrink:0;
  white-space:nowrap;
}
.btn-add-cart:hover { background:var(--green); color:#fff; border-color:var(--green); transform:translateY(-1px); }
.btn-add-cart.adding { animation:addPop .35s cubic-bezier(0.34,1.6,0.64,1); }
@keyframes addPop { 0%{transform:scale(1)} 50%{transform:scale(1.18)} 100%{transform:scale(1)} }

.btn-buy-again {
  display:flex; align-items:center; justify-content:center; gap:7px;
  background:var(--cream-3); color:var(--terra); font-weight:700; font-size:.82rem; font-family:'Lato',sans-serif;
  padding:.6rem .9rem; border-radius:var(--r-md); border:1.5px solid var(--terra-pale); cursor:pointer;
  transition:var(--transition); width:100%;
}
.btn-buy-again:hover { background:var(--terra); color:#fff; border-color:var(--terra); }

.btn-momo {
  display:flex; align-items:center; justify-content:center; gap:9px;
  background:var(--cream-3); color:var(--text-mid); font-weight:700; font-size:.88rem; font-family:'Lato',sans-serif;
  padding:.75rem 1rem; border-radius:var(--r-md); border:1.5px solid var(--parchment); cursor:pointer;
  transition:var(--transition); width:100%;
}
.btn-momo:hover { background:var(--parchment); border-color:var(--brown-pale); }

/* ══════════════════════════════════════════
   ADD-TO-CART FLY ANIMATION
══════════════════════════════════════════ */
.cart-fly {
  position:fixed; z-index:999; pointer-events:none;
  width:24px; height:24px; border-radius:50%;
  background:var(--green); opacity:0;
  display:flex; align-items:center; justify-content:center;
}
.cart-fly.flying {
  animation:flyToCart .55s cubic-bezier(0.5,0,0.75,0) forwards;
}
@keyframes flyToCart {
  0%   { opacity:1; transform:scale(1); }
  60%  { opacity:.8; }
  100% { opacity:0; transform:scale(.3); }
}

/* ══════════════════════════════════════════
   LIGHTBOX
══════════════════════════════════════════ */
.lightbox {
  position:fixed; inset:0; z-index:800;
  background:rgba(20,10,5,.95); backdrop-filter:blur(8px);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  opacity:0; pointer-events:none; transition:opacity .25s;
}
.lightbox.open { opacity:1; pointer-events:auto; }

.lb-close {
  position:absolute; top:20px; right:20px; z-index:2;
  background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.2); border-radius:50%;
  width:40px; height:40px; color:#fff; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  transition:var(--transition);
}
.lb-close:hover { background:rgba(255,255,255,.25); }

.lb-nav {
  position:absolute; top:50%; transform:translateY(-50%);
  background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.2); border-radius:50%;
  width:48px; height:48px; color:#fff; cursor:pointer; z-index:2;
  display:flex; align-items:center; justify-content:center;
  transition:var(--transition);
}
.lb-nav:hover { background:rgba(255,255,255,.25); }
.lb-prev { left:20px; }
.lb-next { right:20px; }

.lb-content {
  display:flex; flex-direction:column; align-items:center; gap:1.25rem;
  max-width:520px; width:90%; padding:0 1rem;
}
.lb-img-wrap {
  width:100%; max-width:400px; aspect-ratio:1;
  border-radius:var(--r-xl); overflow:hidden;
  background:var(--cream-3); display:flex; align-items:center; justify-content:center;
  position:relative;
}
.lb-image { width:100%; height:100%; object-fit:cover; }
.lb-fallback-icon { font-size:6rem; }

.lb-info { text-align:center; }
.lb-name { font-family:'Playfair Display',serif; font-size:1.4rem; font-weight:800; color:#fff; margin-bottom:.25rem; }
.lb-price { font-family:'Playfair Display',serif; font-size:1.2rem; font-weight:700; color:var(--green-light); margin-bottom:1rem; }
.lb-order-btn {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--whatsapp); color:#fff; font-weight:700; font-size:.95rem; font-family:'Lato',sans-serif;
  padding:.85rem 1.75rem; border-radius:100px; border:none; cursor:pointer;
  transition:var(--transition);
}
.lb-order-btn:hover { background:var(--whatsapp-dark); transform:translateY(-2px); }

.lb-hint { position:absolute; bottom:20px; left:50%; transform:translateX(-50%); white-space:nowrap; font-size:.75rem; color:rgba(255,255,255,.35); letter-spacing:.04em; }

/* ══════════════════════════════════════════
   CART SIDEBAR
══════════════════════════════════════════ */
.cart-overlay {
  position:fixed; inset:0; z-index:300;
  background:rgba(42,26,14,.55); backdrop-filter:blur(3px);
  opacity:0; pointer-events:none; transition:opacity .25s;
}
.cart-overlay.open { opacity:1; pointer-events:auto; }

.cart-sidebar {
  position:fixed; top:0; right:0; bottom:0; z-index:301;
  width:360px; max-width:100vw;
  background:var(--warm-white);
  border-left:2px solid var(--parchment);
  display:flex; flex-direction:column;
  transform:translateX(100%); transition:transform .3s cubic-bezier(0.4,0,0.2,1);
  box-shadow:-8px 0 40px rgba(42,26,14,.18);
}
.cart-sidebar.open { transform:translateX(0); }

.cart-header {
  padding:1.25rem 1.5rem; border-bottom:1px solid var(--parchment);
  display:flex; align-items:center; justify-content:space-between; flex-shrink:0;
}
.cart-header h3 { font-family:'Playfair Display',serif; font-size:1.25rem; font-weight:800; color:var(--text-dark); display:flex; align-items:center; gap:8px; }
.cart-close-btn { background:var(--cream-2); border:1px solid var(--parchment); border-radius:50%; width:32px; height:32px; display:flex; align-items:center; justify-content:center; cursor:pointer; color:var(--text-muted); transition:var(--transition); }
.cart-close-btn:hover { background:var(--parchment); color:var(--text-dark); }

.cart-items { flex:1; overflow-y:auto; padding:1rem 1.5rem; }

/* Cart item row */
.cart-item { display:flex; gap:.75rem; align-items:center; padding:.9rem 0; border-bottom:1px solid var(--cream-3); }
.cart-item:last-child { border-bottom:none; }
.ci-img { width:52px; height:52px; border-radius:var(--r-md); object-fit:cover; background:var(--cream-3); flex-shrink:0; display:flex; align-items:center; justify-content:center; overflow:hidden; }
.ci-img img { width:100%; height:100%; object-fit:cover; }
.ci-img-fallback { font-size:1.6rem; }
.ci-body { flex:1; min-width:0; }
.ci-name { font-family:'Playfair Display',serif; font-size:.95rem; font-weight:700; color:var(--text-dark); line-height:1.2; }
.ci-price { font-size:.85rem; color:var(--green); font-weight:700; margin-top:.2rem; }
.ci-qty { display:flex; align-items:center; gap:.5rem; margin-top:.35rem; }
.ci-qty-btn { background:var(--cream-2); border:1px solid var(--parchment); border-radius:6px; width:26px; height:26px; display:flex; align-items:center; justify-content:center; cursor:pointer; font-size:1rem; font-weight:700; color:var(--text-mid); transition:var(--transition); }
.ci-qty-btn:hover { background:var(--green); color:#fff; border-color:var(--green); }
.ci-qty-num { font-weight:700; font-size:.9rem; min-width:20px; text-align:center; }
.ci-remove { background:none; border:none; cursor:pointer; color:var(--text-muted); padding:4px; border-radius:4px; transition:color .2s; flex-shrink:0; }
.ci-remove:hover { color:var(--terra); }

.cart-empty { flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:.75rem; padding:3rem 1.5rem; }
.cart-empty p    { font-family:'Playfair Display',serif; font-size:1.1rem; font-weight:700; color:var(--text-dark); }
.cart-empty span { font-size:.88rem; color:var(--text-muted); }

.cart-footer { padding:1.25rem 1.5rem; border-top:2px solid var(--parchment); flex-shrink:0; background:var(--cream-2); }
.cart-total-row { display:flex; justify-content:space-between; align-items:center; margin-bottom:1rem; }
.cart-total-row span { font-size:.88rem; color:var(--text-muted); text-transform:uppercase; letter-spacing:.06em; font-weight:700; }
.cart-total-val { font-family:'Playfair Display',serif; font-size:1.5rem; font-weight:800; color:var(--green); }

.cart-actions { display:flex; flex-direction:column; gap:.6rem; margin-bottom:.75rem; }
.cart-wa-btn {
  display:flex; align-items:center; justify-content:center; gap:9px;
  background:var(--whatsapp); color:#fff; font-weight:700; font-size:.95rem; font-family:'Lato',sans-serif;
  padding:.9rem; border-radius:var(--r-md); border:none; cursor:pointer;
  transition:var(--transition);
}
.cart-wa-btn:hover { background:var(--whatsapp-dark); transform:translateY(-1px); }
.cart-momo-btn {
  display:flex; align-items:center; justify-content:center; gap:9px;
  background:var(--cream-3); color:var(--text-mid); font-weight:700; font-size:.9rem; font-family:'Lato',sans-serif;
  padding:.85rem; border-radius:var(--r-md); border:1.5px solid var(--parchment); cursor:pointer;
  transition:var(--transition);
}
.cart-momo-btn:hover { background:var(--parchment); }
.cart-clear-btn { background:none; border:none; cursor:pointer; font-family:'Lato',sans-serif; font-size:.8rem; color:var(--text-muted); transition:color .2s; width:100%; text-align:center; padding:.35rem; }
.cart-clear-btn:hover { color:var(--terra); }

/* ══════════════════════════════════════════
   ORDER SUMMARY MODAL
══════════════════════════════════════════ */
.order-summary-items { margin-bottom:1rem; max-height:40vh; overflow-y:auto; }
.os-item { display:flex; justify-content:space-between; align-items:center; padding:.65rem 0; border-bottom:1px solid var(--cream-3); font-size:.9rem; }
.os-item:last-child { border-bottom:none; }
.os-item-left { color:var(--text-mid); flex:1; }
.os-item-right { font-weight:700; color:var(--green); white-space:nowrap; margin-left:.5rem; }
.os-qty { display:inline-block; background:var(--cream-3); color:var(--text-muted); border-radius:4px; padding:.1rem .4rem; font-size:.78rem; margin-right:.35rem; }
.order-summary-total { display:flex; justify-content:space-between; align-items:center; padding:1rem 0; border-top:2px solid var(--parchment); margin-top:.5rem; }
.order-summary-total span  { font-size:.88rem; font-weight:700; text-transform:uppercase; letter-spacing:.06em; color:var(--text-muted); }
.order-summary-total strong { font-family:'Playfair Display',serif; font-size:1.5rem; color:var(--green); }
.order-summary-actions { margin-top:.75rem; }
.os-wa-btn { display:flex; align-items:center; justify-content:center; gap:9px; background:var(--whatsapp); color:#fff; font-weight:700; font-size:1rem; font-family:'Lato',sans-serif; padding:1rem; border-radius:var(--r-md); border:none; cursor:pointer; transition:var(--transition); width:100%; }
.os-wa-btn:hover { background:var(--whatsapp-dark); transform:translateY(-1px); }

/* ══════════════════════════════════════════
   HOW TO ORDER
══════════════════════════════════════════ */
.how-to-order { padding:80px 0; background:var(--green); position:relative; overflow:hidden; }
.how-to-order::before { content:''; position:absolute; inset:0; pointer-events:none; background-image:radial-gradient(circle at 90% 10%,rgba(255,255,255,.07) 0,transparent 50%),radial-gradient(circle at 10% 90%,rgba(0,0,0,.15) 0,transparent 50%); }
.how-to-order .section-eyebrow { color:rgba(255,255,255,.7); }
.how-to-order .section-title { color:#fff; }
.how-to-order .section-title em { color:var(--green-light); }
.steps-grid { display:flex; align-items:center; justify-content:center; gap:1.5rem; flex-wrap:wrap; }
.step { background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.15); border-radius:var(--r-lg); padding:2rem 1.75rem; text-align:center; flex:1; min-width:200px; max-width:260px; transition:var(--transition); }
.step:hover { background:rgba(255,255,255,.15); transform:translateY(-4px); }
.step-num  { font-family:'Dancing Script',cursive; font-size:3.5rem; font-weight:700; color:rgba(255,255,255,.2); line-height:1; margin-bottom:.25rem; }
.step-icon { margin-bottom:.75rem; color:rgba(255,255,255,.9); display:flex; justify-content:center; }
.step h3   { font-family:'Playfair Display',serif; font-size:1.15rem; font-weight:700; color:#fff; margin-bottom:.4rem; }
.step p    { font-size:.875rem; color:rgba(255,255,255,.7); line-height:1.6; }
.step-arrow { flex-shrink:0; }

/* ══════════════════════════════════════════
   ABOUT
══════════════════════════════════════════ */
.about { padding:80px 0; background:var(--cream); }
.about-grid { display:grid; grid-template-columns:1fr 1.3fr; gap:5rem; align-items:center; }
.about-visual { position:relative; }
.about-img-frame { border-radius:var(--r-xl); overflow:hidden; aspect-ratio:1; max-width:420px; border:2px solid var(--parchment); box-shadow:var(--shadow-deep); }
.about-real-img { width:100%; height:100%; object-fit:cover; }
.about-img-bg { width:100%; height:100%; background:linear-gradient(135deg,var(--cream-3),var(--parchment)); display:flex; align-items:center; justify-content:center; }
.about-svg-stack { padding:2rem; }
.about-badge-float { position:absolute; bottom:-20px; right:-10px; background:var(--green); color:#fff; border-radius:var(--r-lg); padding:1rem 1.5rem; text-align:center; box-shadow:var(--shadow-warm); }
.about-badge-float strong { display:block; font-family:'Playfair Display',serif; font-size:2rem; font-weight:800; }
.about-badge-float span   { font-size:.8rem; opacity:.85; }
.about-text { color:var(--text-mid); font-size:.97rem; line-height:1.8; margin-bottom:1rem; }
.about-stats { display:flex; gap:2rem; margin:1.75rem 0; flex-wrap:wrap; }
.astat { text-align:center; }
.astat strong { display:block; font-family:'Playfair Display',serif; font-size:2rem; font-weight:800; color:var(--green); }
.astat span   { font-size:.8rem; color:var(--text-muted); text-transform:uppercase; letter-spacing:.06em; }
.btn-wa-about { display:inline-flex; align-items:center; gap:9px; background:var(--whatsapp); color:#fff; font-weight:700; font-size:.95rem; font-family:'Lato',sans-serif; padding:.85rem 1.75rem; border-radius:100px; transition:var(--transition); margin-top:.5rem; }
.btn-wa-about:hover { background:var(--whatsapp-dark); transform:translateY(-2px); }

/* ══════════════════════════════════════════
   CONTACT
══════════════════════════════════════════ */
.contact { padding:80px 0; background:var(--cream-2); }
.contact-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:1.25rem; margin-bottom:2.5rem; }
.contact-card { background:var(--warm-white); border:1px solid var(--parchment); border-radius:var(--r-lg); padding:1.75rem 1.5rem; box-shadow:var(--shadow-card); text-align:center; transition:var(--transition); }
.contact-card:hover { transform:translateY(-3px); box-shadow:var(--shadow-warm); border-color:var(--green-pale); }
.cc-icon { margin:0 auto .75rem; color:var(--green); display:flex; align-items:center; justify-content:center; width:48px; height:48px; background:var(--green-bg); border-radius:50%; }
.contact-card h3 { font-family:'Playfair Display',serif; font-size:1rem; font-weight:700; color:var(--text-dark); margin-bottom:.35rem; }
.contact-card p  { font-size:.9rem; color:var(--text-mid); font-weight:600; }
.cc-link { display:inline-block; margin-top:.6rem; font-size:.85rem; font-weight:700; color:var(--green); transition:color .2s; }
.cc-link:hover { color:var(--green-mid); }
.contact-cta-bar { background:var(--green); border-radius:var(--r-xl); padding:2rem 2.5rem; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:1.5rem; box-shadow:0 8px 40px rgba(45,90,39,.3); }
.contact-cta-bar h3 { font-family:'Playfair Display',serif; font-size:1.4rem; font-weight:700; color:#fff; }
.contact-cta-bar p  { color:rgba(255,255,255,.75); font-size:.9rem; margin-top:.2rem; }
.big-cta { padding:1rem 2rem; font-size:1.05rem; }

/* ══════════════════════════════════════════
   FOOTER
══════════════════════════════════════════ */
.footer { background:var(--text-dark); border-top:3px solid var(--green); padding:3.5rem 0 0; color:rgba(255,255,255,.75); }
.footer-inner { display:grid; grid-template-columns:2fr 1fr 1fr 1.2fr; gap:3rem; margin-bottom:3rem; }
.footer-logo-circle { display:flex; align-items:center; gap:10px; margin-bottom:1rem; }
.footer-logo-circle strong { display:block; font-family:'Playfair Display',serif; font-size:1rem; font-weight:800; color:var(--green-light); }
.footer-logo-circle em { display:block; font-family:'Dancing Script',cursive; font-size:.95rem; color:var(--terra-light); font-style:normal; }
.footer-brand p { font-size:.875rem; color:rgba(255,255,255,.5); line-height:1.7; }
.footer-links { display:flex; flex-direction:column; gap:.5rem; }
.footer-links h4 { font-size:.8rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,255,255,.4); margin-bottom:1rem; }
.footer-links a { font-size:.875rem; color:rgba(255,255,255,.6); transition:color .2s; }
.footer-links a:hover { color:var(--green-light); }
.footer-contact h4 { font-size:.8rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,255,255,.4); margin-bottom:1rem; }
.footer-contact p { font-size:.875rem; color:rgba(255,255,255,.6); margin-bottom:.3rem; }
.footer-bottom { border-top:1px solid rgba(255,255,255,.08); padding:1.25rem 20px; display:flex; justify-content:space-between; align-items:center; max-width:1160px; margin:0 auto; font-size:.8rem; color:rgba(255,255,255,.35); flex-wrap:wrap; gap:.5rem; }
.footer-momo { color:rgba(255,255,255,.4); }

/* ══════════════════════════════════════════
   MODALS (shared)
══════════════════════════════════════════ */
.modal-overlay { position:fixed; inset:0; background:rgba(42,26,14,.8); backdrop-filter:blur(6px); -webkit-backdrop-filter:blur(6px); z-index:500; display:flex; align-items:center; justify-content:center; padding:1rem; opacity:0; pointer-events:none; transition:opacity .25s; }
.modal-overlay.open { opacity:1; pointer-events:auto; }
.modal-box { background:var(--warm-white); border-radius:var(--r-xl); width:100%; max-width:420px; padding:2rem 1.75rem; position:relative; max-height:90vh; overflow-y:auto; animation:modalPop .3s cubic-bezier(0.34,1.3,0.64,1); box-shadow:0 24px 80px rgba(42,26,14,.5); border:2px solid var(--parchment); }
@keyframes modalPop { from{transform:scale(.9) translateY(20px);opacity:0} to{transform:none;opacity:1} }
.modal-close { position:absolute; top:1rem; right:1rem; background:var(--cream-2); border:none; border-radius:50%; width:32px; height:32px; font-size:1rem; cursor:pointer; display:flex; align-items:center; justify-content:center; color:var(--text-muted); transition:var(--transition); }
.modal-close:hover { background:var(--parchment); color:var(--text-dark); }
.modal-header { text-align:center; margin-bottom:1.75rem; }
.modal-icon { margin:0 auto .5rem; }
.modal-header h3 { font-family:'Playfair Display',serif; font-size:1.4rem; font-weight:800; color:var(--text-dark); margin-bottom:.25rem; }
.modal-header p  { font-size:.9rem; color:var(--text-muted); margin-bottom:.5rem; }
.modal-price { display:block; font-family:'Playfair Display',serif; font-size:1.6rem; font-weight:800; color:var(--green); }

/* MoMo modal */
.momo-steps { display:flex; flex-direction:column; gap:1rem; margin-bottom:1.5rem; }
.momo-step { display:flex; gap:.85rem; align-items:flex-start; }
.ms-num { width:28px; height:28px; flex-shrink:0; border-radius:50%; background:var(--green); color:#fff; font-weight:700; font-size:.85rem; display:flex; align-items:center; justify-content:center; }
.ms-body strong { display:block; font-size:.92rem; font-weight:700; color:var(--text-dark); margin-bottom:.2rem; }
.ms-body p { font-size:.83rem; color:var(--text-muted); }
.momo-number-box { display:flex; align-items:center; gap:.75rem; background:var(--cream-2); border:2px solid var(--green-pale); border-radius:var(--r-md); padding:.65rem 1rem; margin:.35rem 0; }
.momo-num { font-family:'Lato',sans-serif; font-size:1.1rem; font-weight:700; color:var(--text-dark); letter-spacing:.06em; flex:1; }
.copy-btn { display:flex; align-items:center; gap:5px; background:var(--green); color:#fff; border:none; border-radius:var(--r-sm); font-size:.75rem; font-weight:700; padding:.35rem .7rem; cursor:pointer; font-family:'Lato',sans-serif; transition:var(--transition); }
.copy-btn:hover { background:var(--green-mid); }
.momo-name { font-size:.82rem; color:var(--text-mid); margin-top:.25rem; }
.momo-confirm-btn { width:100%; padding:1rem; border-radius:var(--r-md); border:none; background:linear-gradient(135deg,var(--green),var(--green-mid)); color:#fff; font-family:'Lato',sans-serif; font-weight:700; font-size:1rem; cursor:pointer; transition:var(--transition); box-shadow:0 6px 24px rgba(45,90,39,.35); display:flex; align-items:center; justify-content:center; gap:8px; }
.momo-confirm-btn:hover { transform:translateY(-2px); box-shadow:0 10px 32px rgba(45,90,39,.45); }
.momo-note { font-size:.78rem; color:var(--text-muted); text-align:center; margin-top:.75rem; line-height:1.5; }

/* Upsell modal */
.upsell-box { max-width:480px; }
.upsell-header { text-align:center; margin-bottom:1.5rem; padding-top:.5rem; }
.upsell-header h3 { font-family:'Playfair Display',serif; font-size:1.3rem; font-weight:800; color:var(--text-dark); margin:.75rem 0 .25rem; }
.upsell-header p  { color:var(--text-muted); font-size:.9rem; }
.upsell-drinks { display:grid; grid-template-columns:1fr 1fr; gap:.75rem; margin-bottom:1rem; }
.upsell-drink-card { background:var(--cream-2); border:1.5px solid var(--parchment); border-radius:var(--r-md); padding:1rem; text-align:center; cursor:pointer; transition:var(--transition); }
.upsell-drink-card:hover { border-color:var(--green); background:var(--green-bg); }
.ud-img { width:56px; height:56px; border-radius:var(--r-md); object-fit:cover; margin:0 auto .4rem; background:var(--cream-3); display:flex; align-items:center; justify-content:center; }
.ud-img img { width:100%; height:100%; object-fit:cover; }
.ud-icon-fallback { font-size:1.8rem; }
.ud-name  { font-size:.88rem; font-weight:700; color:var(--text-dark); }
.ud-price { font-size:.8rem; color:var(--green); font-weight:700; margin-top:.15rem; }
.upsell-skip { width:100%; background:none; border:1.5px solid var(--parchment); border-radius:var(--r-md); padding:.75rem; font-family:'Lato',sans-serif; font-size:.88rem; color:var(--text-muted); cursor:pointer; transition:var(--transition); }
.upsell-skip:hover { border-color:var(--brown-pale); color:var(--text-mid); }

/* ══════════════════════════════════════════
   ANIMATIONS
══════════════════════════════════════════ */
@keyframes fadeUp { from{opacity:0;transform:translateY(24px)} to{opacity:1;transform:none} }
.reveal { opacity:0; transform:translateY(28px); transition:opacity .6s ease, transform .6s ease; }
.reveal.in-view { opacity:1; transform:none; }
.product-card:nth-child(1) { animation-delay:.05s; }
.product-card:nth-child(2) { animation-delay:.1s; }
.product-card:nth-child(3) { animation-delay:.15s; }
.product-card:nth-child(4) { animation-delay:.2s; }
.product-card:nth-child(5) { animation-delay:.25s; }
.product-card:nth-child(6) { animation-delay:.3s; }

/* ══════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════ */
@media (max-width: 900px) {
  .nav-links:not(.mobile-open) { display:none; }
  .hamburger { display:flex; }
  .about-grid { grid-template-columns:1fr; gap:3rem; }
  .about-visual { display:none; }
  .footer-inner { grid-template-columns:1fr 1fr; gap:2rem; }
  .steps-grid { flex-direction:column; align-items:stretch; }
  .step-arrow { transform:rotate(90deg); display:flex; justify-content:center; }
  .step { max-width:100%; }
}

@media (max-width: 768px) {
  /* Category nav: horizontal scroll, no wrap */
  .cat-pills { justify-content:flex-start; flex-wrap:nowrap; padding-bottom:4px; }
  .cat-pill { flex-shrink:0; }

  /* Quick order bar compact */
  .quick-order-bar { padding:.6rem 0; }
  .qob-left span strong { display:none; }
  .qob-left span::before { content:'Quick Order'; font-weight:700; }

  /* Products: 2-column on phones */
  .products-grid { grid-template-columns:1fr 1fr; gap:.85rem; }

  /* Smaller product cards on mobile */
  .product-img { height:150px; }
  .product-body { padding:.85rem .8rem; gap:.35rem; }
  .product-name { font-size:.95rem; }
  .product-desc { font-size:.78rem; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
  .product-price { font-size:1.1rem; }
  .btn-wa { padding:.75rem .6rem; font-size:.82rem; gap:6px; }
  .btn-wa svg { width:15px; height:15px; }
  .btn-add-cart { padding:.75rem .6rem; font-size:.78rem; }
  .upsell-hint { display:none; }

  /* Cart sidebar full width on mobile */
  .cart-sidebar { width:100%; }

  .hero-headline { font-size:2.4rem; }
  .hero-ctas { flex-direction:column; }
  .cta-primary,.cta-whatsapp { width:100%; justify-content:center; }
  .contact-cta-bar { text-align:center; justify-content:center; }
  .footer-inner { grid-template-columns:1fr; gap:2rem; }
  .footer-bottom { flex-direction:column; text-align:center; }
  .sticky-wa { bottom:16px; right:12px; font-size:.85rem; padding:.7rem 1.1rem; }
  .cart-bubble { bottom:74px; right:12px; }
  .upsell-drinks { grid-template-columns:1fr 1fr; }
  .about-stats { gap:1.25rem; }

  /* Lightbox nav buttons smaller */
  .lb-prev { left:8px; }
  .lb-next { right:8px; }
  .lb-nav { width:38px; height:38px; }
}

@media (max-width: 420px) {
  .products-grid { grid-template-columns:1fr; }
  .product-img { height:200px; }
  .hero-headline { font-size:2rem; }
}