/* ============================================================
   DMI ORDERING — FRONTEND CSS
   Full-width, mobile-first, premium design
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800;900&display=swap');

:root {
  --dmi-brand:    #f09a0d;
  --dmi-green:    #22C55E;
  --dmi-red:      #EF4444;
  --dmi-dark:     #111827;
  --dmi-gray:     #6B7280;
  --dmi-gray-50:  #F9FAFB;
  --dmi-gray-100: #F3F4F6;
  --dmi-gray-200: #E5E7EB;
  --dmi-radius:   1.25rem;
  --dmi-radius-lg:2rem;
  --dmi-shadow:   0 4px 24px rgba(0,0,0,0.08);
  --dmi-shadow-lg:0 12px 48px rgba(0,0,0,0.14);
  --dmi-font:     'Plus Jakarta Sans', system-ui, sans-serif;
}

/* ── Reset & Base ─────────────────────────────────────────── */
.dmi-app *,
.dmi-app *::before,
.dmi-app *::after { box-sizing: border-box; margin:0; padding:0; }

.dmi-app {
  font-family: var(--dmi-font);
  color: var(--dmi-dark);
  width: 100%;
  max-width: 100%;
  background: #fff;
  -webkit-tap-highlight-color: transparent;
}

/* ── Step containers ───────────────────────────────────────── */
.dmi-step { width:100%; }

/* ══════════════════════════════════════════════════
   STEP 1 — OUTLET LIST
   ══════════════════════════════════════════════════ */
.dmi-step1-header {
  background: #ffffff !important;
  padding: 3rem 1.25rem 2rem;
  text-align: center;
  position: relative;
  border-bottom: 3px solid var(--dmi-brand);
}
.dmi-step1-title {
  font-size: clamp(1.8rem, 6vw, 2.5rem);
  font-weight: 900;
  color: var(--dmi-dark) !important;
  margin-bottom: 0.5rem;
  position: relative;
  letter-spacing: -0.03em;
}
.dmi-step1-title span { color: var(--dmi-brand); }
.dmi-step1-sub {
  color: var(--dmi-gray) !important;
  font-size: 1rem;
  font-weight: 500;
  margin-bottom: 2rem;
  position: relative;
}

/* Search bar */
.dmi-search-wrap {
  position: relative;
  max-width: 520px;
  margin: 0 auto 1.25rem;
}
.dmi-search-icon {
  position: absolute;
  left: 1.25rem;
  top: 50%;
  transform: translateY(-50%);
  color: var(--dmi-gray);
  pointer-events: none;
  transition: opacity 0.2s ease, transform 0.2s ease;
  z-index: 1;
}
/* Hide search icon when input is focused (via parent focus-within) */
.dmi-search-wrap:focus-within .dmi-search-icon {
  opacity: 0;
  transform: translateY(-50%) scale(0.7);
}
.dmi-search-input {
  width: 100%;
  padding: 1rem 1.25rem 1rem 3.25rem;
  border-radius: 100px;
  border: 2px solid var(--dmi-gray-200);
  font-size: 1rem;
  font-family: var(--dmi-font);
  font-weight: 500;
  outline: none;
  background: #ffffff !important;
  color: #111827 !important;
  -webkit-text-fill-color: #111827 !important;
  transition: all 0.2s ease;
}
.dmi-search-input::placeholder {
  color: #9CA3AF !important;
  -webkit-text-fill-color: #9CA3AF !important;
}
.dmi-search-input:focus {
  border-color: var(--dmi-brand);
  background: #fff !important;
  color: #111827 !important;
  -webkit-text-fill-color: #111827 !important;
  box-shadow: 0 0 0 4px rgba(240, 154, 13, 0.15);
  padding-left: 1.25rem; /* shift text left when icon is hidden */
  transition: all 0.2s ease, padding-left 0.2s ease;
}

/* GPS button */
.dmi-gps-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: #fff;
  color: var(--dmi-brand);
  border: 2px solid var(--dmi-brand);
  padding: 0.75rem 1.75rem;
  border-radius: 100px;
  font-size: 0.9rem;
  font-weight: 800;
  font-family: var(--dmi-font);
  cursor: pointer;
  transition: all 0.2s ease;
  position: relative;
}
.dmi-gps-btn:hover {
  background: var(--dmi-brand);
  color: #fff;
  transform: translateY(-1px);
}
.dmi-gps-btn:active { transform: scale(0.97); }
.dmi-gps-btn.loading { opacity: 0.7; pointer-events:none; }

/* Outlet cards list */
.dmi-outlets-list {
  padding: 1.25rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
@media(min-width:640px) {
  .dmi-outlets-list { display:grid; grid-template-columns: repeat(2, 1fr); }
}
@media(min-width:1024px) {
  .dmi-outlets-list { grid-template-columns: repeat(3, 1fr); max-width:1200px; margin:0 auto; }
}

.dmi-outlet-card {
  background: #fff;
  border: 2px solid var(--dmi-gray-200);
  border-radius: var(--dmi-radius-lg);
  padding: 1.5rem;
  cursor: pointer;
  transition: border-color 0.2s, box-shadow 0.2s, transform 0.15s;
  text-align: left;
  width: 100%;
  font-family: var(--dmi-font);
}
.dmi-outlet-card:hover {
  border-color: var(--dmi-brand);
  box-shadow: var(--dmi-shadow-lg);
  transform: translateY(-2px);
}
.dmi-outlet-card.closed {
  opacity: 0.55;
  cursor: default;
}
.dmi-outlet-card.closed:hover { transform: none; box-shadow: none; border-color: var(--dmi-gray-200); }

.dmi-outlet-card-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 0.75rem;
}
.dmi-outlet-status-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-size: 0.7rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 0.3rem 0.75rem;
  border-radius: 100px;
}
.dmi-outlet-status-badge.open  { background: #DCFCE7; color: #16A34A; }
.dmi-outlet-status-badge.closed { background: #FEE2E2; color: #DC2626; }
.dmi-outlet-status-dot {
  width: 6px; height: 6px; border-radius: 50%;
}
.open  .dmi-outlet-status-dot { background: #16A34A; animation: dmi-pulse 1.5s infinite; }
.closed .dmi-outlet-status-dot { background: #DC2626; }

.dmi-outlet-card-name {
  font-size: 1.15rem;
  font-weight: 800;
  color: var(--dmi-dark);
  margin-bottom: 0.35rem;
  line-height: 1.3;
}
.dmi-outlet-card-addr {
  font-size: 0.85rem;
  color: var(--dmi-gray);
  line-height: 1.5;
  margin-bottom: 0.75rem;
}
.dmi-outlet-card-meta {
  display: flex;
  align-items: center;
  gap: 1rem;
  font-size: 0.8rem;
  color: var(--dmi-gray);
  font-weight: 600;
  margin-bottom: 1.25rem;
}
.dmi-outlet-card-meta span { display: flex; align-items: center; gap: 0.3rem; }
.dmi-outlet-distance { margin-left: auto; color: var(--dmi-brand); font-weight: 800; }

.dmi-outlet-select-btn {
  width: 100%;
  background: var(--dmi-brand);
  color: #fff;
  border: none;
  border-radius: var(--dmi-radius);
  padding: 0.85rem 1.25rem;
  font-size: 1rem;
  font-weight: 800;
  font-family: var(--dmi-font);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  transition: background 0.2s, transform 0.15s;
}
.dmi-outlet-select-btn:hover { background: #d48205; transform: scale(1.02); }
.dmi-outlet-select-btn:active { transform: scale(0.98); }
.dmi-outlet-closed-label {
  width: 100%;
  text-align: center;
  font-size: 0.85rem;
  font-weight: 700;
  color: #DC2626;
  padding: 0.75rem;
  background: #FEF2F2;
  border-radius: var(--dmi-radius);
}

/* ══════════════════════════════════════════════════
   STEP 2 — MENU
   ══════════════════════════════════════════════════ */
.dmi-step2-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: #ffffff !important;
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1rem 1.25rem;
  border-bottom: 2px solid var(--dmi-brand);
  box-shadow: 0 2px 16px rgba(0,0,0,0.07);
}
.dmi-back-btn {
  width: 2.75rem; height: 2.75rem;
  border-radius: 50%;
  border: 2px solid var(--dmi-gray-200);
  background: #fff;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  color: var(--dmi-dark);
  flex-shrink: 0;
  transition: border-color 0.15s, background 0.15s;
}
.dmi-back-btn:hover { border-color: var(--dmi-brand); background: var(--dmi-gray-50); }

.dmi-step2-outlet-info { flex: 1; min-width: 0; }
.dmi-step2-outlet-info h3 {
  font-size: 1rem; font-weight: 800;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.dmi-step2-outlet-info p {
  font-size: 0.75rem; color: var(--dmi-gray); font-weight: 500;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
#dmi-selected-outlet-status .dmi-outlet-status-badge { white-space: nowrap; }

/* Category tabs */
.dmi-cat-tabs-wrap {
  position: sticky;
  top: 65px;
  z-index: 90;
  background: #fff;
  border-bottom: 1px solid var(--dmi-gray-100);
  overflow: hidden;
}
.dmi-cat-tabs {
  display: flex;
  gap: 0.5rem;
  padding: 0.75rem 1.25rem;
  overflow-x: auto;
  scroll-behavior: smooth;
  -ms-overflow-style: none;
  scrollbar-width: none;
}
.dmi-cat-tabs::-webkit-scrollbar { display: none; }
.dmi-cat-tab {
  flex-shrink: 0;
  padding: 0.5rem 1.1rem;
  border-radius: 100px;
  border: 2px solid var(--dmi-gray-200);
  font-size: 0.875rem;
  font-weight: 700;
  font-family: var(--dmi-font);
  cursor: pointer;
  background: #fff;
  color: var(--dmi-gray);
  transition: all 0.18s;
  white-space: nowrap;
}
.dmi-cat-tab:hover { border-color: var(--dmi-brand); color: var(--dmi-brand); }
.dmi-cat-tab.active { background: var(--dmi-brand); border-color: var(--dmi-brand); color: #fff; }

/* Products grid */
.dmi-products-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
  padding: 1.25rem;
  padding-bottom: 100px; /* space for cart bar */
}
@media(min-width:640px)  { .dmi-products-grid { grid-template-columns: repeat(3, 1fr); } }
@media(min-width:1024px) { .dmi-products-grid { grid-template-columns: repeat(4, 1fr); max-width:1200px; margin:0 auto; } }

.dmi-product-card {
  background: #fff;
  border: 2px solid var(--dmi-gray-100);
  border-radius: var(--dmi-radius-lg);
  overflow: hidden;
  transition: border-color 0.2s, box-shadow 0.2s;
  position: relative;
}
.dmi-product-card:hover { border-color: var(--dmi-brand); box-shadow: var(--dmi-shadow); }
.dmi-product-card.unavailable { opacity: 0.5; pointer-events:none; }

.dmi-product-img-wrap { aspect-ratio: 1/1; overflow: hidden; background: var(--dmi-gray-100); position:relative; }
.dmi-product-img-wrap img { width:100%; height:100%; object-fit:cover; transition: transform 0.5s; }
.dmi-product-card:hover .dmi-product-img-wrap img { transform: scale(1.07); }
.dmi-product-no-img { width:100%; height:100%; display:flex; align-items:center; justify-content:center; font-size:3rem; }

.dmi-product-cat-tag {
  position: absolute;
  top: 0.6rem; left: 0.6rem;
  background: rgba(255,255,255,0.92);
  backdrop-filter: blur(8px);
  color: var(--dmi-brand);
  font-size: 0.65rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 0.25rem 0.6rem;
  border-radius: 100px;
}
.dmi-product-unavail-tag {
  position: absolute;
  top: 0.6rem; right: 0.6rem;
  background: #EF4444;
  color: #fff;
  font-size: 0.6rem;
  font-weight: 800;
  text-transform: uppercase;
  padding: 0.25rem 0.5rem;
  border-radius: 100px;
}

.dmi-product-body { padding: 0.85rem; }
.dmi-product-name {
  font-size: 0.9rem; font-weight: 800;
  line-height: 1.3;
  margin-bottom: 0.3rem;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.dmi-product-desc {
  font-size: 0.75rem;
  color: var(--dmi-gray);
  margin-bottom: 0.6rem;
  line-height: 1.4;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.dmi-product-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
}
.dmi-product-price {
  font-size: 0.95rem;
  font-weight: 900;
  color: var(--dmi-brand);
}
.dmi-product-price small { font-size:0.7rem; font-weight:700; margin-right:1px; }

/* Qty controls */
.dmi-qty-controls {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  background: var(--dmi-gray-100);
  border-radius: 100px;
  padding: 0.2rem;
}
.dmi-qty-btn {
  width: 1.85rem; height: 1.85rem;
  border-radius: 50%;
  border: none;
  background: #fff;
  cursor: pointer;
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--dmi-dark);
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 1px 4px rgba(0,0,0,0.1);
  transition: background 0.15s, transform 0.1s;
}
.dmi-qty-btn:hover { background: var(--dmi-brand); color: #fff; }
.dmi-qty-btn:active { transform: scale(0.92); }
.dmi-qty-num { font-weight: 800; font-size: 0.9rem; min-width: 1.2rem; text-align: center; }

.dmi-add-btn {
  width: 2.2rem; height: 2.2rem;
  border-radius: 50%;
  border: none;
  background: var(--dmi-brand);
  color: #fff;
  font-size: 1.4rem;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 12px rgba(232,93,4,0.35);
  transition: background 0.15s, transform 0.15s;
  flex-shrink: 0;
}
.dmi-add-btn:hover { background: #d48205; transform: scale(1.1) rotate(90deg); }
.dmi-add-btn:active { transform: scale(0.95); }

/* ── Floating Cart Bar ─────────────────────────────────────── */
.dmi-cart-bar {
  position: fixed;
  bottom: 1.25rem;
  left: 50%;
  transform: translateX(-50%);
  width: calc(100% - 2.5rem);
  max-width: 540px;
  z-index: 200;
  animation: dmi-slide-up 0.35s cubic-bezier(0.34,1.56,0.64,1);
}
.dmi-cart-bar-inner {
  background: var(--dmi-dark);
  border-radius: var(--dmi-radius-lg);
  padding: 1rem 1.25rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  box-shadow: 0 16px 48px rgba(0,0,0,0.3);
  border: 1px solid rgba(255,255,255,0.08);
  transition: transform 0.15s;
}
.dmi-cart-bar-inner:hover { transform: translateY(-2px); }
.dmi-cart-bar-inner:active { transform: scale(0.98); }

.dmi-cart-bar-left { display:flex; align-items:center; gap:1rem; }
.dmi-cart-icon-wrap {
  position: relative;
  color: var(--dmi-brand);
}
.dmi-cart-count {
  position: absolute;
  top: -8px; right: -8px;
  background: #fff;
  color: var(--dmi-dark);
  font-size: 0.65rem;
  font-weight: 900;
  min-width: 1.25rem; height: 1.25rem;
  border-radius: 100px;
  display: flex; align-items:center; justify-content:center;
}
.dmi-cart-bar-label { font-size:0.7rem; font-weight:700; color:rgba(255,255,255,0.6); text-transform:uppercase; letter-spacing:0.05em; }
.dmi-cart-bar-total { font-size:1.1rem; font-weight:900; color:#fff; }
.dmi-cart-bar-arrow { color: rgba(255,255,255,0.5); }

/* ══════════════════════════════════════════════════
   CART BOTTOM SHEET
   ══════════════════════════════════════════════════ */
.dmi-sheet-overlay {
  position: fixed; inset:0;
  background: rgba(0,0,0,0.55);
  backdrop-filter: blur(4px);
  z-index: 300;
  animation: dmi-fade-in 0.25s ease;
}
.dmi-sheet {
  position: fixed;
  bottom: 0; left:0; right:0;
  background: #fff;
  border-radius: 2rem 2rem 0 0;
  z-index: 310;
  max-height: 92vh;
  display: flex;
  flex-direction: column;
  animation: dmi-sheet-up 0.35s cubic-bezier(0.34,1.28,0.64,1);
  overflow: hidden;
}
@media(min-width:640px) {
  .dmi-sheet { max-width: 560px; left:50%; transform: translateX(-50%); border-radius: 2rem; bottom: 1rem; }
}

.dmi-sheet-drag-handle {
  width: 3rem; height: 0.3rem;
  background: var(--dmi-gray-200);
  border-radius: 100px;
  margin: 0.75rem auto 0;
  flex-shrink: 0;
}
.dmi-sheet-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.25rem 1.5rem 0.75rem;
  flex-shrink: 0;
}
.dmi-sheet-title { font-size:1.2rem; font-weight:900; }
.dmi-sheet-close {
  width:2.5rem; height:2.5rem; border-radius:50%;
  border: none; background: var(--dmi-gray-100);
  font-size:1rem; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  transition: background 0.15s;
}
.dmi-sheet-close:hover { background: var(--dmi-gray-200); }

.dmi-sheet-outlet-info {
  padding: 0.5rem 1.5rem;
  background: var(--dmi-gray-50);
  border-top: 1px solid var(--dmi-gray-100);
  border-bottom: 1px solid var(--dmi-gray-100);
  font-size: 0.8rem;
  font-weight: 700;
  color: var(--dmi-gray);
  flex-shrink: 0;
}

.dmi-sheet-body {
  flex: 1;
  overflow-y: auto;
  padding: 1rem 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  -webkit-overflow-scrolling: touch;
}

.dmi-cart-item {
  display: flex;
  align-items: center;
  gap: 0.85rem;
  background: var(--dmi-gray-50);
  border-radius: var(--dmi-radius);
  padding: 0.75rem;
}
.dmi-cart-item-img {
  width: 3.5rem; height: 3.5rem;
  border-radius: 0.75rem;
  object-fit: cover;
  flex-shrink: 0;
  background: var(--dmi-gray-200);
}
.dmi-cart-item-info { flex:1; min-width:0; }
.dmi-cart-item-name { font-size:0.9rem; font-weight:800; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.dmi-cart-item-price { font-size:0.8rem; font-weight:700; color:var(--dmi-brand); }
.dmi-cart-item-controls {
  display:flex; align-items:center; gap:0.5rem;
  background:#fff; border-radius:100px; padding:0.2rem 0.4rem;
  box-shadow:0 2px 8px rgba(0,0,0,0.08);
  flex-shrink:0;
}
.dmi-cart-item-controls button {
  width:1.75rem; height:1.75rem; border-radius:50%;
  border:none; background:var(--dmi-gray-100);
  cursor:pointer; font-size:0.9rem; font-weight:700;
  display:flex; align-items:center; justify-content:center;
  transition:background 0.15s;
}
.dmi-cart-item-controls button:hover { background: var(--dmi-brand); color:#fff; }
.dmi-cart-item-controls .dmi-item-qty { font-size:0.9rem; font-weight:900; min-width:1.25rem; text-align:center; }

.dmi-sheet-note-wrap {
  padding: 0 1.5rem 0.75rem;
  flex-shrink: 0;
}
.dmi-sheet-note-label { font-size:0.8rem; font-weight:700; color:var(--dmi-gray); margin-bottom:0.4rem; display:block; }
.dmi-sheet-note {
  width:100%;
  background: var(--dmi-gray-50);
  border: 2px solid var(--dmi-gray-200);
  border-radius: var(--dmi-radius);
  padding: 0.75rem 1rem;
  font-family: var(--dmi-font);
  font-size: 0.9rem;
  resize: none;
  outline: none;
  transition: border-color 0.2s;
}
.dmi-sheet-note:focus { border-color: var(--dmi-brand); }

.dmi-sheet-footer {
  padding: 1rem 1.5rem 1.5rem;
  border-top: 1px solid var(--dmi-gray-100);
  flex-shrink: 0;
}
.dmi-sheet-summary {
  display:flex; justify-content:space-between; align-items:center;
  margin-bottom: 1rem;
  font-size:1rem;
}
.dmi-sheet-summary span { color:var(--dmi-gray); font-weight:600; }
.dmi-sheet-summary strong { font-size:1.5rem; font-weight:900; color:var(--dmi-dark); }

.dmi-wa-btn {
  width:100%;
  background: #25D366;
  color: #fff;
  border: none;
  border-radius: var(--dmi-radius-lg);
  padding: 1.1rem;
  font-size: 1.1rem;
  font-weight: 900;
  font-family: var(--dmi-font);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  box-shadow: 0 6px 24px rgba(37,211,102,0.35);
  transition: background 0.2s, transform 0.15s;
}
.dmi-wa-btn:hover { background: #1da851; transform: translateY(-2px); }
.dmi-wa-btn:active { transform: scale(0.98); }

/* ══════════════════════════════════════════════════
   SHARED UTILITIES
   ══════════════════════════════════════════════════ */
.dmi-loading {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 4rem 1rem;
  color: var(--dmi-gray);
  font-weight: 600;
  gap: 1rem;
}
.dmi-spinner {
  width: 2.5rem; height: 2.5rem;
  border: 3px solid var(--dmi-gray-200);
  border-top-color: var(--dmi-brand);
  border-radius: 50%;
  animation: dmi-spin 0.8s linear infinite;
}
.dmi-empty {
  text-align: center;
  padding: 4rem 1rem;
  color: var(--dmi-gray);
  font-weight: 600;
  font-size: 1rem;
}

/* ── Animations ─────────────────────────────────────────────── */
@keyframes dmi-spin     { to { transform: rotate(360deg); } }
@keyframes dmi-pulse    { 0%,100%{ opacity:1; } 50%{ opacity:0.4; } }
@keyframes dmi-fade-in  { from{ opacity:0; } to{ opacity:1; } }
@keyframes dmi-slide-up { from{ opacity:0; transform:translateX(-50%) translateY(20px); } to{ opacity:1; transform:translateX(-50%) translateY(0); } }
@keyframes dmi-sheet-up { from{ transform:translateY(100%); } to{ transform:translateY(0); } }

/* Mobile safe area for iPhone notch */
.dmi-sheet-footer { padding-bottom: max(1.5rem, env(safe-area-inset-bottom)); }
.dmi-cart-bar     { bottom: max(1.25rem, env(safe-area-inset-bottom)); }

/* Sub-category tabs styling */
.dmi-subcat-tabs-wrap {
  background: var(--dmi-gray-50);
  padding: 0.5rem 1.25rem;
  border-bottom: 1px solid var(--dmi-gray-200);
  display: none;
}
.dmi-subcat-tabs {
  display: flex;
  gap: 0.4rem;
  overflow-x: auto;
  scrollbar-width: none;
}
.dmi-subcat-tabs::-webkit-scrollbar { display: none; }
.dmi-subcat-tab {
  flex-shrink: 0;
  padding: 0.35rem 0.85rem;
  border-radius: 100px;
  border: 1px solid var(--dmi-gray-300);
  font-size: 0.75rem;
  font-weight: 600;
  font-family: var(--dmi-font);
  cursor: pointer;
  background: #fff;
  color: var(--dmi-gray);
  transition: all 0.15s;
}
.dmi-subcat-tab:hover { border-color: var(--dmi-brand); color: var(--dmi-brand); }
.dmi-subcat-tab.active { background: var(--dmi-brand); border-color: var(--dmi-brand); color: #fff; }

/* Desktop responsiveness tweaks (tighter layout & margins) */
@media (min-width: 1024px) {
  .dmi-step1-header {
    padding: 2rem 2rem 1.5rem;
  }
  .dmi-step1-title {
    font-size: 2.2rem;
    margin-bottom: 0.25rem;
  }
  .dmi-step1-sub {
    font-size: 0.95rem;
    margin-bottom: 1.25rem;
  }
  .dmi-search-wrap {
    margin-bottom: 0.85rem;
  }
  .dmi-gps-btn {
    padding: 0.65rem 1.5rem;
    font-size: 0.85rem;
  }
  .dmi-outlets-list {
    gap: 1.25rem;
    padding: 1.5rem 2rem;
  }
  .dmi-cat-tabs {
    padding: 0.75rem 2rem;
  }
  .dmi-subcat-tabs-wrap {
    padding: 0.5rem 2rem;
  }
  .dmi-products-grid {
    padding: 1.5rem 2rem 120px;
    gap: 1.25rem;
  }
}
