/* ========== RESPONSIVE ========== */
@media (max-width: 768px) {
  :root {
    /* Must clear fixed .mobile-nav (5 items + optional wrapped labels); keep in sync with footer.css .mobile-nav-inner */
    --jiangnan-mobile-nav-height: 68px;
  }
  .header-nav { display: none; }
  .header-admin { margin-left: 0; padding-left: 0; border-left: none; }
  .header-inner { padding: 10px 16px; flex-wrap: wrap; gap: 8px 10px; }
  .logo-en { font-size: 17px; }
  .mobile-nav { display: block; }
  /* Cart sits above bottom nav (nav replaced the old 4th-slot cart button on mobile). */
  .cart-bar {
    bottom: calc(var(--jiangnan-mobile-nav-height) + env(safe-area-inset-bottom, 0px));
    z-index: 210;
    padding: 10px 14px;
  }
  .cart-bar-home {
    font-size: 11px;
    letter-spacing: 1px;
    padding: 6px 0;
    max-width: 38%;
    overflow: hidden;
    text-overflow: ellipsis;
  }
  .cart-total { font-size: 17px; }
  .view-cart-btn { padding: 8px 14px; font-size: 13px; }
  .hero { height: 58vh; min-height: 400px; overflow: visible; position: relative; z-index: 10; }
  .hero-cn { letter-spacing: 6px; }
  .hero-not-open-notice {
    position: relative;
    margin-top: 24px;
    margin-bottom: 0;
    transform: translateY(40px);
    z-index: 11;
    width: calc(100% - 32px);
    margin-left: auto;
    margin-right: auto;
    background: rgba(28, 26, 23, 0.9); /* Solid dark for overlap */
  }
  .specialty-grid { grid-template-columns: 1fr; padding: 0 16px 80px; }
  .section-shell { padding: 0 16px 80px; }
  .section-header { align-items: flex-start; flex-direction: column; }
  .blog-grid { grid-template-columns: 1fr; }
  .blog-page { padding: 24px 16px 90px; }
  .blog-content { padding: 18px; }
  .blog-content h1 { font-size: 28px; }
  .footer-inner { flex-direction: column; gap: 24px; text-align: center; align-items: center; }
  .footer-col { align-items: center; }
  .intro-section { padding: 48px 16px; }
  .menu-page { padding: 24px 16px calc(96px + var(--jiangnan-mobile-nav-height) + env(safe-area-inset-bottom, 0px)); }
  /* reservation.html + waitlist.html — main + footer clear fixed .mobile-nav */
  body.jiangnan-storefront-public .site-footer {
    padding-bottom: calc(20px + var(--jiangnan-mobile-nav-height) + env(safe-area-inset-bottom, 0px));
  }
  .menu-item { flex-wrap: wrap; }
  .menu-item-thumb-btn { width: 64px; height: 64px; }
  .item-actions { width: 100%; justify-content: flex-end; margin-top: 6px; }
  .menu-sticky-bar { top: 54px; padding: 10px 0 12px; }
  .category-nav { gap: 4px; }
  .cat-btn { padding: 6px 12px; }
  .cat-cn { font-size: 12px; }
  .cat-en { font-size: 9px; }
  .cart-items { padding-left: 12px; padding-right: 12px; }
  .cart-item { gap: 8px 10px; }
  .cart-item .qty-btn { width: 28px; height: 28px; font-size: 16px; }
  .cart-item-line-total { min-width: 3rem; font-size: 15px; }
}
