/* =============================================================================
 * shop.css — compiled storefront stylesheet (session card S0.3).
 *
 * GENERATED OUTPUT. Edit the SCSS sources, not this file:
 *   resources/assets/sass/shop.scss
 *   resources/assets/sass/shop/_tokens.scss
 *   resources/assets/sass/shop/_base.scss
 * then regenerate with `npm run prod` (or `npm run dev`). This copy was
 * hand-compiled because laravel-elixir was not installed in the build
 * environment at scaffold time.
 * ========================================================================== */

/* Font: Work Sans (loaded via Google Fonts <link> in shop/layouts/app.blade.php). */

:root {
  /* Reference "E-manthus Amber Green" palette (ref/DESIGN.md). OVERRIDES
     design.md §2.1 per owner decision 2026-06-15 (OD-10). */
  --em-primary: #176621;
  --em-primary-dark: #0F4616;
  --em-primary-tint: #E7F2E9;
  --em-ink: #0B1C30;
  --em-gray-700: #475569;
  --em-gray-300: #E2E8F0;
  --em-surface: #FFFFFF;
  --em-bg: #F1F5F9;
  --em-accent: #EEC200;
  --em-danger: #BA1A1A;

  --em-font-sans: "Work Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --em-fs-h1: 2.25rem;
  --em-fs-h2: 1.625rem;
  --em-fs-price: 1.0625rem;
  --em-fs-body: 0.9375rem;
  --em-fs-card: 0.875rem;
  --em-fw-regular: 400;
  --em-fw-medium: 500;
  --em-fw-semibold: 600;
  --em-fw-bold: 700;
  --em-lh-base: 1.5;

  --em-radius: 4px;
  --em-radius-sm: 4px;
  --em-radius-container: 0;
  --em-radius-pill: 999px;
  --em-gap: 16px;
  --em-gap-sm: 8px;
  --em-shadow: 0 1px 3px rgba(11, 28, 48, 0.06);
  --em-shadow-lift: 0 4px 12px rgba(11, 28, 48, 0.10);

  --em-container: 1280px;
  --em-z-header: 1000;
  --em-z-megamenu: 1100;
  --em-z-drawer: 1200;
}

/* Border-box everywhere in the storefront: width:100% + padding/border must
   never exceed the viewport (this was forcing a horizontal scrollbar on
   mobile). Scoped to .em-shop so legacy pages are unaffected. */
.em-shop,
.em-shop *,
.em-shop *::before,
.em-shop *::after { box-sizing: border-box; }

.em-shop {
  margin: 0; /* reset the default 8px body margin */
  font-family: var(--em-font-sans);
  font-size: var(--em-fs-body);
  line-height: var(--em-lh-base);
  color: var(--em-ink);
  background: var(--em-bg);
  overflow-x: hidden; /* clip any residual horizontal overflow */
}

.em-container {
  width: 100%;
  max-width: var(--em-container);
  margin: 0 auto;
  padding: 0 var(--em-gap);
}

.em-h1 { font-size: var(--em-fs-h1); font-weight: var(--em-fw-bold); margin: 0 0 var(--em-gap); }
.em-h2 { font-size: var(--em-fs-h2); font-weight: var(--em-fw-semibold); margin: 0 0 var(--em-gap-sm); }

.em-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--em-gap-sm);
  font-family: inherit;
  font-size: var(--em-fs-body);
  font-weight: var(--em-fw-semibold);
  line-height: 1;
  padding: 11px 18px;
  border: 1px solid transparent;
  border-radius: var(--em-radius);
  cursor: pointer;
  text-decoration: none;
  transition: background-color .15s ease, border-color .15s ease, color .15s ease;
}

.em-btn--primary {
  background: var(--em-primary);
  color: var(--em-surface);
}
.em-btn--primary:hover,
.em-btn--primary:focus { background: var(--em-primary-dark); }

.em-btn--ink {
  background: var(--em-ink);
  color: var(--em-surface);
}
.em-btn--ink:hover,
.em-btn--ink:focus { background: #0e1c14; }

.em-btn--ghost {
  background: transparent;
  color: var(--em-primary-dark);
  border-color: var(--em-gray-300);
}
.em-btn--ghost:hover,
.em-btn--ghost:focus { border-color: var(--em-primary); color: var(--em-primary); }

.em-card {
  background: var(--em-surface);
  border: 1px solid var(--em-gray-300);
  border-radius: var(--em-radius);
  box-shadow: var(--em-shadow);
}
.em-card__price { font-size: var(--em-fs-price); font-weight: var(--em-fw-semibold); color: var(--em-ink); }
.em-card__price--old { color: var(--em-gray-700); font-weight: var(--em-fw-regular); text-decoration: line-through; margin-left: var(--em-gap-sm); }

.em-badge {
  display: inline-block;
  font-size: 0.75rem;
  font-weight: var(--em-fw-semibold);
  padding: 2px 8px;
  border-radius: var(--em-radius-sm);
  line-height: 1.4;
}
.em-badge--discount { background: var(--em-danger); color: var(--em-surface); }
.em-badge--deal { background: var(--em-accent); color: var(--em-ink); }

/* =============================================================================
 * Header — 3-tier storefront header (REV-F02 / S2.2). Compiled from
 * resources/assets/sass/shop/_header.scss. design.md §4.1.
 * ========================================================================== */

.em-shop__header {
  position: relative;
  z-index: var(--em-z-header);
  background: var(--em-surface);
  box-shadow: var(--em-shadow);
}

/* --- Tier 1: utility bar (light, reference style) --- */
.em-utility {
  background: var(--em-surface);
  color: var(--em-gray-700);
  border-bottom: 1px solid var(--em-gray-300);
  font-size: 0.8125rem;
  display: none;
}
.em-utility__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 36px;
}
.em-utility__links {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  align-items: center;
  gap: var(--em-gap);
}
.em-utility__links a {
  color: var(--em-gray-700);
  text-decoration: none;
}
.em-utility__links a:hover,
.em-utility__links a:focus { color: var(--em-primary-dark); }

.em-utility__dropdown { position: relative; }
.em-utility__toggle {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: transparent;
  border: 0;
  color: inherit;
  font: inherit;
  cursor: pointer;
  padding: 6px 0;
}
.em-utility__menu {
  position: absolute;
  right: 0;
  top: 100%;
  min-width: 160px;
  list-style: none;
  margin: 0;
  padding: 6px 0;
  background: var(--em-surface);
  border: 1px solid var(--em-gray-300);
  border-radius: var(--em-radius-sm);
  box-shadow: var(--em-shadow-lift);
  z-index: var(--em-z-megamenu);
  display: none;
}
.em-utility__menu li > a {
  display: block;
  padding: 8px 14px;
  color: var(--em-ink);
  opacity: 1;
}
.em-utility__menu li:hover > a,
.em-utility__menu li.is-active > a { background: var(--em-primary-tint); color: var(--em-primary-dark); }
.em-utility__dropdown:hover .em-utility__menu,
.em-utility__dropdown:focus-within .em-utility__menu { display: block; }

/* --- Tier 2: main header --- */
.em-header-main__inner {
  display: flex;
  align-items: center;
  gap: var(--em-gap);
  padding-top: 12px;
  padding-bottom: 12px;
}
.em-header-main__logo {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
}
.em-header-main__logo img { max-height: 40px; width: auto; display: block; }
.em-header-main__logo-text {
  font-size: 1.25rem;
  font-weight: var(--em-fw-bold);
  color: var(--em-primary-dark);
}
.em-header-main__cluster {
  flex: 0 0 auto;
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: var(--em-gap);
}

.em-search {
  flex: 1 1 auto;
  display: flex;
  align-items: stretch;
  max-width: 680px;
  border: 1px solid var(--em-gray-300);
  border-radius: var(--em-radius);
  overflow: hidden;
  background: var(--em-surface);
}
.em-search:focus-within { border-color: var(--em-primary); box-shadow: 0 0 0 2px rgba(23, 102, 33, 0.1); }
.em-search__scope { display: none; }
.em-search__category {
  border: 0;
  border-right: 1px solid var(--em-gray-300);
  background: var(--em-bg);
  color: var(--em-gray-700);
  padding: 0 10px;
  max-width: 160px;
  font: inherit;
  cursor: pointer;
}
.em-search__input {
  flex: 1 1 auto;
  border: 0;
  padding: 10px 12px;
  font: inherit;
  color: var(--em-ink);
  min-width: 0;
}
.em-search__input:focus { outline: none; }
.em-search__submit {
  flex: 0 0 auto;
  border-radius: 0;
  padding: 0 18px;
}

.em-actionlink {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--em-ink);
  text-decoration: none;
  line-height: 1.1;
}
.em-actionlink:hover,
.em-actionlink:focus { color: var(--em-primary-dark); }
.em-actionlink__icon { font-size: 1.375rem; }
.em-actionlink__iconwrap { position: relative; display: inline-flex; }
.em-actionlink__text {
  display: none;
  flex-direction: column;
  font-size: 0.8125rem;
  font-weight: var(--em-fw-semibold);
  line-height: 1.2;
}
.em-actionlink__text small { font-weight: var(--em-fw-regular); color: var(--em-gray-700); }
.em-actionlink__badge {
  position: absolute;
  top: -6px;
  right: -10px;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  border-radius: var(--em-radius-pill);
  background: var(--em-gray-700);
  color: var(--em-surface);
  font-size: 0.6875rem;
  font-weight: var(--em-fw-semibold);
  text-align: center;
  line-height: 18px;
}
.em-actionlink__badge--cart { background: var(--em-primary); }

.em-cart { position: relative; }
.em-cart__panel {
  position: absolute;
  right: 0;
  top: 100%;
  width: 320px;
  margin-top: 8px;
  background: var(--em-surface);
  border: 1px solid var(--em-gray-300);
  border-radius: var(--em-radius);
  box-shadow: var(--em-shadow-lift);
  z-index: var(--em-z-megamenu);
}

.em-account__name { font-size: 0.8125rem; font-weight: var(--em-fw-semibold); }

/* --- Tier 3: navigation bar --- */
.em-nav {
  background: var(--em-primary);
  color: var(--em-surface);
}
.em-nav__inner {
  display: flex;
  align-items: center;
  gap: var(--em-gap);
  min-height: 44px;
}
.em-nav__departments {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--em-primary-dark);
  color: var(--em-surface);
  border: 0;
  font: inherit;
  font-weight: var(--em-fw-semibold);
  cursor: pointer;
  padding: 11px 16px;
  align-self: stretch;
}
.em-nav__links {
  list-style: none;
  margin: 0;
  padding: 0;
  display: none;
  align-items: center;
  gap: 4px;
}
.em-nav__links a {
  display: inline-block;
  padding: 11px 12px;
  color: var(--em-surface);
  text-decoration: none;
  font-weight: var(--em-fw-medium);
  border-radius: var(--em-radius-sm);
}
.em-nav__links a:hover,
.em-nav__links a:focus { background: var(--em-primary-dark); color: var(--em-surface); }
.em-nav__phone {
  margin-left: auto;
  display: none;
  align-items: center;
  gap: 8px;
  color: var(--em-surface);
  text-decoration: none;
}
.em-nav__phone .em-nav__phone-text { display: flex; flex-direction: column; line-height: 1.2; }
.em-nav__phone small { opacity: 0.85; font-size: 0.75rem; }

/* "Hot" badge on the Deals nav link */
.em-nav__deals { display: inline-flex; align-items: center; }
.em-nav__hot {
  display: inline-block;
  margin-left: 6px;
  padding: 1px 5px;
  background: var(--em-accent);
  color: var(--em-ink);
  font-size: 0.5625rem;
  font-weight: var(--em-fw-bold);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  line-height: 1.4;
  border-radius: var(--em-radius-sm);
}

/* --- Breakpoints --- */
@media (min-width: 768px) {
  .em-utility { display: block; }
  .em-search__scope { display: flex; }
  .em-actionlink__text { display: flex; }
  .em-nav__links { display: flex; }
  .em-nav__phone { display: flex; }
}

/* =============================================================================
 * Mega-menu — "Shop by Department" (REV-F02 / S2.3). Compiled from
 * resources/assets/sass/shop/_megamenu.scss. design.md §4.1. Visibility is
 * driven by the [hidden] attribute, so `display` is never set on the base
 * element; :not([hidden]) styles the open state.
 * ========================================================================== */

.em-mega-menu {
  position: absolute;
  left: 0;
  right: 0;
  top: 100%;
  z-index: var(--em-z-megamenu);
  background: var(--em-surface);
  border: 1px solid var(--em-gray-300);
  border-top: 0;
  box-shadow: var(--em-shadow-lift);
}
.em-mega-menu__inner {
  display: flex;
  align-items: stretch;
  gap: 0;
  padding: 0;
}

/* Left: department rail */
.em-mega-menu__departments {
  flex: 0 0 260px;
  list-style: none;
  margin: 0;
  padding: var(--em-gap-sm) 0;
  border-right: 1px solid var(--em-gray-300);
  background: var(--em-bg);
}
.em-mega-menu__dept-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 10px 18px;
  color: var(--em-ink);
  text-decoration: none;
  font-weight: var(--em-fw-medium);
}
.em-mega-menu__dept-link:hover,
.em-mega-menu__dept-link:focus,
.em-mega-menu__dept-link.is-active {
  background: var(--em-surface);
  color: var(--em-primary-dark);
}
.em-mega-menu__dept-link.is-active { box-shadow: inset 3px 0 0 var(--em-primary); }
.em-mega-menu__dept-caret { color: var(--em-gray-700); }

/* Right: flyout panels */
.em-mega-menu__panels {
  flex: 1 1 auto;
  position: relative;
  min-height: 280px;
}
.em-mega-menu__panel {
  padding: var(--em-gap);
  gap: var(--em-gap);
}
.em-mega-menu__panel:not([hidden]) { display: flex; }
.em-mega-menu__columns {
  flex: 1 1 auto;
  display: flex;
  flex-wrap: wrap;
  gap: var(--em-gap);
}
.em-mega-menu__column { min-width: 180px; }
.em-mega-menu__column-head {
  display: block;
  font-weight: var(--em-fw-semibold);
  color: var(--em-ink);
  text-decoration: none;
  margin-bottom: var(--em-gap-sm);
}
.em-mega-menu__column-head:hover,
.em-mega-menu__column-head:focus { color: var(--em-primary-dark); }
.em-mega-menu__sublist {
  list-style: none;
  margin: 0 0 var(--em-gap-sm);
  padding: 0;
}
.em-mega-menu__sublist li > a {
  display: block;
  padding: 5px 0;
  color: var(--em-gray-700);
  text-decoration: none;
  font-size: var(--em-fs-body);
}
.em-mega-menu__sublist li > a:hover,
.em-mega-menu__sublist li > a:focus { color: var(--em-primary-dark); }
.em-mega-menu__viewall {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  color: var(--em-primary-dark);
  font-weight: var(--em-fw-semibold);
  text-decoration: none;
}
.em-mega-menu__viewall:hover,
.em-mega-menu__viewall:focus { color: var(--em-primary); }

/* Promo tile */
.em-mega-menu__promo {
  flex: 0 0 220px;
  display: flex;
  align-items: flex-end;
  min-height: 240px;
  border-radius: var(--em-radius);
  background-color: var(--em-primary-tint);
  background-size: cover;
  background-position: center;
  text-decoration: none;
  overflow: hidden;
}
.em-mega-menu__promo-body {
  display: block;
  width: 100%;
  padding: var(--em-gap);
  background: linear-gradient(transparent, rgba(22, 39, 30, 0.55));
  color: var(--em-surface);
}
.em-mega-menu__promo-body small { display: block; font-size: 0.75rem; opacity: 0.9; }
.em-mega-menu__promo-body strong { font-size: 1.125rem; }

/* Mobile: stack the rail above the active panel; fixed overlay */
@media (max-width: 767px) {
  .em-mega-menu {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    overflow-y: auto;
    border: 0;
  }
  .em-mega-menu__inner { flex-direction: column; }
  .em-mega-menu__departments {
    flex: 0 0 auto;
    border-right: 0;
    border-bottom: 1px solid var(--em-gray-300);
  }
  .em-mega-menu__panel:not([hidden]) { flex-direction: column; }
  .em-mega-menu__promo { flex: 0 0 auto; min-height: 140px; }
}

/* =============================================================================
 * Shell — mini-cart dropdown + mobile bottom tab bar + menu drawer
 * (REV-F02 / S2.4). Compiled from resources/assets/sass/shop/_shell.scss.
 * ========================================================================== */

/* --- Mini-cart dropdown --- */
.em-cart__panel { display: none; padding: var(--em-gap); }
@media (hover: hover) {
  .em-cart:hover .em-cart__panel { display: block; }
}
.em-cart.is-open .em-cart__panel { display: block; }

.em-cart__empty {
  text-align: center;
  padding: var(--em-gap);
  color: var(--em-gray-700);
}
.em-cart__empty i { font-size: 2rem; color: var(--em-gray-300); display: block; margin-bottom: var(--em-gap-sm); }
.em-cart__empty p { margin: 0 0 var(--em-gap); }

.em-cart__items {
  list-style: none;
  margin: 0 0 var(--em-gap-sm);
  padding: 0;
  max-height: 320px;
  overflow-y: auto;
}
.em-cart__item {
  display: flex;
  align-items: center;
  gap: var(--em-gap-sm);
  padding: var(--em-gap-sm) 0;
  border-bottom: 1px solid var(--em-gray-300);
}
.em-cart__item-thumb {
  flex: 0 0 48px;
  width: 48px;
  height: 48px;
  border: 1px solid var(--em-gray-300);
  border-radius: var(--em-radius-sm);
  overflow: hidden;
  background: var(--em-bg);
}
.em-cart__item-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.em-cart__item-body { flex: 1 1 auto; min-width: 0; }
.em-cart__item-name {
  display: block;
  color: var(--em-ink);
  text-decoration: none;
  font-size: var(--em-fs-card);
  font-weight: var(--em-fw-medium);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.em-cart__item-name:hover,
.em-cart__item-name:focus { color: var(--em-primary-dark); }
.em-cart__item-meta { font-size: 0.8125rem; color: var(--em-gray-700); }
.em-cart__item-line { flex: 0 0 auto; font-weight: var(--em-fw-semibold); color: var(--em-ink); }

.em-cart__summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--em-gap-sm) 0 var(--em-gap);
  font-size: var(--em-fs-price);
}
.em-cart__summary strong { font-weight: var(--em-fw-bold); }
.em-cart__actions { display: flex; gap: var(--em-gap-sm); }
.em-cart__actions .em-btn { flex: 1 1 0; }

/* --- Mobile bottom tab bar --- */
.em-tabbar {
  display: none;
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: var(--em-z-header);
  background: var(--em-surface);
  border-top: 1px solid var(--em-gray-300);
  box-shadow: 0 -2px 8px rgba(22, 39, 30, 0.08);
}
.em-tabbar__item {
  flex: 1 1 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 3px;
  padding: 8px 2px;
  background: transparent;
  border: 0;
  font: inherit;
  font-size: 0.6875rem;
  color: var(--em-gray-700);
  text-decoration: none;
  cursor: pointer;
}
.em-tabbar__item i { font-size: 1.125rem; }
.em-tabbar__item:hover,
.em-tabbar__item:focus,
.em-tabbar__item:active { color: var(--em-primary-dark); }
.em-tabbar__cart { position: relative; }
.em-tabbar__cart .em-actionlink__badge { top: -6px; right: -6px; left: auto; }

/* --- Mobile menu drawer + scrim --- */
.em-mobile-menu {
  position: fixed;
  top: 0;
  left: 0;
  bottom: 0;
  width: 82%;
  max-width: 320px;
  z-index: var(--em-z-drawer);
  background: var(--em-surface);
  box-shadow: var(--em-shadow-lift);
  overflow-y: auto;
  transform: translateX(-100%);
  transition: transform .2s ease;
}
.em-mobile-menu.is-open { transform: translateX(0); }
.em-mobile-menu__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--em-gap);
  background: var(--em-ink);
  color: var(--em-surface);
}
.em-mobile-menu__title { font-weight: var(--em-fw-semibold); }
.em-mobile-menu__close {
  background: transparent;
  border: 0;
  color: var(--em-surface);
  font-size: 1.25rem;
  cursor: pointer;
}
.em-mobile-menu__links {
  list-style: none;
  margin: 0;
  padding: var(--em-gap-sm) 0;
}
.em-mobile-menu__links + .em-mobile-menu__links { border-top: 1px solid var(--em-gray-300); }
.em-mobile-menu__links li > a {
  display: block;
  padding: 12px var(--em-gap);
  color: var(--em-ink);
  text-decoration: none;
}
.em-mobile-menu__links li > a:hover,
.em-mobile-menu__links li > a:focus { background: var(--em-primary-tint); color: var(--em-primary-dark); }
.em-mobile-menu__links--utility li > a { color: var(--em-gray-700); }

.em-scrim {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1190;
  background: rgba(22, 39, 30, 0.45);
}
body.em-no-scroll { overflow: hidden; }

/* --- Breakpoints --- */
@media (max-width: 767px) {
  .em-tabbar { display: flex; }
  .em-shop { padding-bottom: 60px; }
  .em-cart:hover .em-cart__panel { display: none; }
}

/* =============================================================================
 * Footer — storefront footer (REV-F02 / S2.5). Compiled from
 * resources/assets/sass/shop/_footer.scss. design.md §4.2.
 * ========================================================================== */

.em-footer {
  background: var(--em-ink);
  color: var(--em-gray-300);
  font-size: var(--em-fs-body);
  margin-top: var(--em-gap);
}

/* --- SEO category tag rows --- */
.em-footer__tags {
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  padding: var(--em-gap) 0;
  font-size: 0.8125rem;
}
.em-footer__tags-label { color: var(--em-surface); font-weight: var(--em-fw-semibold); margin-right: var(--em-gap-sm); }
.em-footer__tags a {
  color: var(--em-gray-300);
  text-decoration: none;
  margin: 0 var(--em-gap-sm) 4px 0;
  display: inline-block;
}
.em-footer__tags a:not(:last-child)::after { content: "\00b7"; margin-left: var(--em-gap-sm); color: var(--em-gray-700); }
.em-footer__tags a:hover,
.em-footer__tags a:focus { color: var(--em-primary); }

/* --- 4 columns --- */
.em-footer__main { padding: calc(var(--em-gap) * 1.5) 0; }
.em-footer__cols {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--em-gap);
}
.em-footer__heading {
  color: var(--em-surface);
  font-size: var(--em-fs-body);
  font-weight: var(--em-fw-semibold);
  margin: 0 0 var(--em-gap-sm);
}
.em-footer__line { margin: 0 0 var(--em-gap-sm); }
.em-footer__line a { color: var(--em-gray-300); text-decoration: none; }
.em-footer__line a:hover,
.em-footer__line a:focus { color: var(--em-primary); }
.em-footer__line i { color: var(--em-primary); margin-right: 6px; }

.em-footer__links { list-style: none; margin: 0; padding: 0; }
.em-footer__links li { margin-bottom: var(--em-gap-sm); }
.em-footer__links a { color: var(--em-gray-300); text-decoration: none; }
.em-footer__links a:hover,
.em-footer__links a:focus { color: var(--em-primary); }

.em-footer__social { margin-top: var(--em-gap-sm); display: flex; gap: var(--em-gap-sm); }
.em-footer__social a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: var(--em-radius-pill);
  background: rgba(255, 255, 255, 0.08);
  color: var(--em-surface);
  text-decoration: none;
}
.em-footer__social a:hover,
.em-footer__social a:focus { background: var(--em-primary); color: var(--em-surface); }

.em-footer__apps { display: flex; flex-direction: column; gap: var(--em-gap-sm); }
.em-footer__app {
  display: inline-flex;
  align-items: center;
  gap: var(--em-gap-sm);
  padding: 8px 12px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: var(--em-radius);
  color: var(--em-surface);
  text-decoration: none;
}
.em-footer__app i { font-size: 1.25rem; }
.em-footer__app span { display: flex; flex-direction: column; line-height: 1.2; font-weight: var(--em-fw-semibold); }
.em-footer__app small { font-weight: var(--em-fw-regular); color: var(--em-gray-300); font-size: 0.6875rem; }
.em-footer__app:hover,
.em-footer__app:focus { border-color: var(--em-primary); }

/* --- Payment strip + district coverage --- */
.em-footer__strip {
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  padding: var(--em-gap) 0;
}
.em-footer__strip-inner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--em-gap-sm);
}
.em-footer__pay { display: flex; flex-wrap: wrap; align-items: center; gap: var(--em-gap-sm); }
.em-footer__pay-label { color: var(--em-gray-300); }
.em-footer__pay-badge {
  display: inline-block;
  padding: 4px 10px;
  border-radius: var(--em-radius-sm);
  background: var(--em-surface);
  color: var(--em-ink);
  font-weight: var(--em-fw-semibold);
  font-size: 0.8125rem;
}
.em-footer__districts { margin: 0; color: var(--em-primary); font-weight: var(--em-fw-semibold); }

/* --- Bottom strip --- */
.em-footer__bottom { padding: var(--em-gap) 0; font-size: 0.8125rem; }
.em-footer__bottom-inner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--em-gap-sm);
}
.em-footer__bottom-links a {
  color: var(--em-gray-300);
  text-decoration: none;
  margin-left: var(--em-gap);
}
.em-footer__bottom-links a:hover,
.em-footer__bottom-links a:focus { color: var(--em-primary); }

/* --- Breakpoints --- */
@media (min-width: 768px) {
  .em-footer__cols { grid-template-columns: 1.4fr 1fr 1fr 1.2fr; gap: calc(var(--em-gap) * 1.5); }
}
@media (max-width: 767px) {
  .em-footer__bottom { padding-bottom: calc(var(--em-gap) + 60px); }
}

/* =============================================================================
 * Home — homepage sections 1–5 + product card (REV-F02 / S2.6). Compiled from
 * resources/assets/sass/shop/_home.scss. design.md §5 + §6.1.
 * ========================================================================== */

.em-section { margin: calc(var(--em-gap) * 1.5) 0; }
.em-section__head {
  display: flex;
  align-items: center;
  gap: var(--em-gap);
  margin-bottom: var(--em-gap);
}
.em-section__head .em-h2 { margin: 0; }
.em-section__head--tabs { flex-wrap: wrap; }
.em-section__more { margin-left: auto; color: var(--em-primary-dark); text-decoration: none; font-weight: var(--em-fw-semibold); }
.em-section__more:hover,
.em-section__more:focus { color: var(--em-primary); }
.em-empty-note { color: var(--em-gray-700); padding: var(--em-gap); }

/* --- 1. Hero --- */
.em-hero {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--em-gap);
  margin: var(--em-gap) 0;
}
.em-hero__departments {
  display: none;
  background: var(--em-surface);
  border: 1px solid var(--em-gray-300);
  border-radius: var(--em-radius-container);
  padding: var(--em-gap-sm) 0;
}
.em-hero__departments ul { list-style: none; margin: 0; padding: 0; }
.em-hero__departments li > a {
  display: block;
  padding: 9px var(--em-gap);
  color: var(--em-ink);
  text-decoration: none;
  font-size: var(--em-fs-body);
}
.em-hero__departments li > a:hover,
.em-hero__departments li > a:focus { background: var(--em-primary-tint); color: var(--em-primary-dark); }

.em-hero__slider { position: relative; border-radius: var(--em-radius-container); overflow: hidden; min-height: 240px; background: var(--em-primary-dark); }
.em-hero__slide {
  display: none;
  min-height: 240px;
  background-size: cover;
  background-position: center;
  text-decoration: none;
}
.em-hero__slide.is-active { display: flex; align-items: center; }
.em-hero__slide--static { background: linear-gradient(120deg, var(--em-primary-dark), var(--em-primary)); }
.em-hero__copy { padding: 40px; max-width: 560px; color: var(--em-surface); }
.em-hero__copy .em-h1 { color: var(--em-surface); line-height: 1.1; }
.em-hero__copy p { color: rgba(255, 255, 255, 0.85); margin: var(--em-gap-sm) 0 var(--em-gap); }
.em-hero__eyebrow {
  display: inline-block;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.6875rem;
  font-weight: var(--em-fw-bold);
  color: var(--em-accent);
  margin-bottom: var(--em-gap-sm);
}
.em-btn--light { background: var(--em-surface); color: var(--em-primary-dark); }
.em-btn--light:hover,
.em-btn--light:focus { background: #eef2f0; color: var(--em-primary-dark); }

/* Right promo stack */
.em-hero__promos { display: grid; grid-template-columns: 1fr 1fr; gap: var(--em-gap); }
.em-hero__promo {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 4px;
  min-height: 88px;
  padding: var(--em-gap);
  border: 1px solid var(--em-gray-300);
  border-radius: var(--em-radius-container);
  background: var(--em-surface);
  text-decoration: none;
}
.em-hero__promo-label { font-size: 0.6875rem; text-transform: uppercase; letter-spacing: 0.05em; font-weight: var(--em-fw-bold); color: var(--em-gray-700); }
.em-hero__promo-title { font-size: 1.0625rem; color: var(--em-ink); }
.em-hero__promo-cta { font-size: 0.8125rem; color: var(--em-primary-dark); font-weight: var(--em-fw-semibold); }
.em-hero__promo--service { background: var(--em-primary-dark); border-color: var(--em-primary-dark); }
.em-hero__promo--service .em-hero__promo-label { color: rgba(255, 255, 255, 0.8); }
.em-hero__promo--service .em-hero__promo-title { color: var(--em-surface); }
.em-hero__promo--service .em-hero__promo-cta { color: var(--em-accent); }

/* --- 2. Trust strip --- */
.em-trust {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--em-gap-sm);
  background: var(--em-surface);
  border: 1px solid var(--em-gray-300);
  border-radius: var(--em-radius);
  padding: var(--em-gap);
  margin: var(--em-gap) 0;
}
.em-trust__item {
  display: flex;
  align-items: center;
  gap: var(--em-gap-sm);
  font-size: 0.8125rem;
  color: var(--em-gray-700);
}
.em-trust__item i { color: var(--em-primary); font-size: 1.25rem; }

/* --- 3 & 5 helpers: carousel + grid --- */
.em-carousel {
  display: flex;
  gap: var(--em-gap);
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  padding-bottom: var(--em-gap-sm);
  -webkit-overflow-scrolling: touch;
}
.em-carousel__item { flex: 0 0 60%; max-width: 220px; scroll-snap-align: start; }
.em-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--em-gap); }
.em-countdown {
  font-size: 0.8125rem;
  font-weight: var(--em-fw-semibold);
  color: var(--em-danger);
  background: var(--em-primary-tint);
  padding: 4px 10px;
  border-radius: var(--em-radius-sm);
}

/* --- 4. Category grid --- */
.em-catgrid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--em-gap); }
.em-catgrid__tile {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--em-gap-sm);
  text-decoration: none;
  color: var(--em-ink);
}
.em-catgrid__img {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: var(--em-radius);
  background: var(--em-primary-tint);
  background-size: cover;
  background-position: center;
}
.em-catgrid__img i { font-size: 1.5rem; color: var(--em-primary); }
.em-catgrid__name { font-size: var(--em-fs-card); font-weight: var(--em-fw-medium); text-align: center; }

/* --- 5. Tabs --- */
.em-tabs { display: flex; flex-wrap: wrap; gap: var(--em-gap-sm); }
.em-tabs__btn {
  background: transparent;
  border: 0;
  border-bottom: 2px solid transparent;
  padding: 6px 4px;
  font: inherit;
  font-weight: var(--em-fw-semibold);
  color: var(--em-gray-700);
  cursor: pointer;
}
.em-tabs__btn.is-active { color: var(--em-primary-dark); border-bottom-color: var(--em-primary); }

/* --- Product card (design.md §6.1) --- */
.em-product {
  display: flex;
  flex-direction: column;
  background: var(--em-surface);
  border: 1px solid var(--em-gray-300);
  border-radius: var(--em-radius-container);
  overflow: hidden;
  transition: box-shadow .15s ease, transform .15s ease;
}
.em-product:hover { box-shadow: var(--em-shadow-lift); transform: translateY(-4px); }
.em-product__media {
  position: relative;
  display: block;
  aspect-ratio: 1 / 1;
  background: var(--em-bg);
}
.em-product__media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.em-product__discount { position: absolute; top: 8px; left: 8px; }
.em-product__noimg {
  display: flex; align-items: center; justify-content: center;
  width: 100%; height: 100%; color: var(--em-gray-300); font-size: 2rem;
}
.em-product__oos {
  position: absolute;
  bottom: 8px;
  left: 8px;
  background: var(--em-ink);
  color: var(--em-surface);
  font-size: 0.6875rem;
  font-weight: var(--em-fw-semibold);
  padding: 2px 8px;
  border-radius: var(--em-radius-sm);
}
.em-product__body { display: flex; flex-direction: column; gap: var(--em-gap-sm); padding: var(--em-gap-sm); flex: 1 1 auto; }
.em-product__title {
  color: var(--em-ink);
  text-decoration: none;
  font-size: var(--em-fs-card);
  font-weight: var(--em-fw-medium);
  line-height: 1.35;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.em-product__title:hover,
.em-product__title:focus { color: var(--em-primary-dark); }
.em-product__price { display: flex; align-items: baseline; flex-wrap: wrap; }
.em-product__add { margin-top: auto; width: 100%; }

/* --- Breakpoints --- */
@media (min-width: 576px) {
  .em-grid { grid-template-columns: repeat(3, 1fr); }
  .em-carousel__item { flex-basis: 33%; }
  .em-catgrid { grid-template-columns: repeat(4, 1fr); }
}
@media (min-width: 768px) {
  .em-hero { grid-template-columns: 240px 1fr 280px; grid-template-areas: "departments slider promos"; align-items: stretch; }
  .em-hero__departments { display: block; grid-area: departments; }
  .em-hero__slider { grid-area: slider; min-height: 360px; }
  .em-hero__slide { min-height: 360px; }
  .em-hero__promos { grid-area: promos; grid-template-columns: 1fr; }
  .em-trust { grid-template-columns: repeat(5, 1fr); }
  .em-grid { grid-template-columns: repeat(5, 1fr); }
  .em-carousel__item { flex-basis: 20%; max-width: none; }
  .em-catgrid { grid-template-columns: repeat(6, 1fr); }
}

/* =============================================================================
 * Home sections 6–10 (REV-F02 / S2.7). Compiled from _home.scss additions.
 * ========================================================================== */

/* --- 6. Category showcase rows --- */
.em-showcase { display: grid; grid-template-columns: 1fr; gap: var(--em-gap); }
.em-showcase__banner {
  display: flex;
  align-items: flex-end;
  min-height: 140px;
  padding: var(--em-gap);
  border-radius: var(--em-radius);
  background: var(--em-primary-tint);
  background-size: cover;
  background-position: center;
  text-decoration: none;
  color: var(--em-ink);
}
.em-showcase__banner strong { display: block; font-size: 1.125rem; }
.em-showcase__banner small { color: var(--em-gray-700); }
.em-showcase__carousel { margin: 0; }

/* --- 7. Store spotlight --- */
.em-stores { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--em-gap); }
.em-store {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding: var(--em-gap);
  background: var(--em-surface);
  border: 1px solid var(--em-gray-300);
  border-radius: var(--em-radius);
  text-decoration: none;
  color: var(--em-ink);
  text-align: center;
}
.em-store__logo {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 64px;
  height: 64px;
  border-radius: var(--em-radius-pill);
  background: var(--em-primary-tint);
  background-size: cover;
  background-position: center;
  margin-bottom: var(--em-gap-sm);
}
.em-store__logo i { color: var(--em-primary); font-size: 1.5rem; }
.em-store__name { font-weight: var(--em-fw-semibold); }
.em-store__meta { font-size: 0.8125rem; color: var(--em-gray-700); }
.em-store__cta { margin-top: var(--em-gap-sm); color: var(--em-primary-dark); font-weight: var(--em-fw-semibold); font-size: 0.8125rem; }

/* --- 8. Services cross-sell band --- */
.em-services-band { background: var(--em-primary-tint); border-radius: var(--em-radius); margin: calc(var(--em-gap) * 1.5) 0; }
.em-services-band__inner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--em-gap);
  padding: var(--em-gap);
}
.em-services-band__inner strong { display: block; color: var(--em-ink); }
.em-services-band__inner span { color: var(--em-gray-700); }

/* --- 9. District + app --- */
.em-district {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--em-gap);
  align-items: center;
  background: var(--em-surface);
  border: 1px solid var(--em-gray-300);
  border-radius: var(--em-radius);
  padding: var(--em-gap);
  margin: calc(var(--em-gap) * 1.5) 0;
}
.em-district__map img { width: 100%; height: auto; display: block; max-height: 260px; object-fit: contain; }
.em-district__body p { color: var(--em-gray-700); margin: var(--em-gap-sm) 0 var(--em-gap); }
.em-district__apps { display: flex; flex-wrap: wrap; gap: var(--em-gap-sm); }

/* --- 10. Newsletter --- */
.em-newsletter { background: var(--em-ink); border-radius: var(--em-radius); margin: calc(var(--em-gap) * 1.5) 0; }
.em-newsletter__inner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--em-gap);
  padding: calc(var(--em-gap) * 1.5) var(--em-gap);
}
.em-newsletter__copy strong { display: block; color: var(--em-surface); font-size: 1.125rem; }
.em-newsletter__copy span { color: var(--em-gray-300); }
.em-newsletter__ok { color: var(--em-surface); font-weight: var(--em-fw-semibold); margin: 0; }
.em-newsletter__form { display: flex; gap: var(--em-gap-sm); flex: 1 1 280px; max-width: 420px; }
.em-newsletter__input {
  flex: 1 1 auto;
  border: 1px solid var(--em-gray-300);
  border-radius: var(--em-radius);
  padding: 10px 12px;
  font: inherit;
  min-width: 0;
}

@media (min-width: 576px) {
  .em-stores { grid-template-columns: repeat(3, 1fr); }
}
@media (min-width: 768px) {
  .em-showcase { grid-template-columns: 280px 1fr; align-items: stretch; }
  .em-showcase__banner { min-height: 0; }
  .em-stores { grid-template-columns: repeat(6, 1fr); }
  .em-district { grid-template-columns: 360px 1fr; }
}

/* === PLP — Product Listing Page (REV-F03 / S3.1) ============================
   Hand-compiled from resources/assets/sass/shop/_plp.scss (S0.3 elixir
   deviation; regenerate with `npm run prod`). design.md §6.1. */
.em-plp { padding-top: var(--em-gap); padding-bottom: calc(var(--em-gap) * 2); }

.em-breadcrumb { font-size: var(--em-fs-card); color: var(--em-gray-700); margin-bottom: var(--em-gap); }
.em-breadcrumb a { color: var(--em-gray-700); text-decoration: none; }
.em-breadcrumb a:hover { color: var(--em-primary-dark); text-decoration: underline; }
.em-breadcrumb__sep { margin: 0 6px; color: var(--em-gray-300); }
.em-breadcrumb__current { color: var(--em-ink); font-weight: var(--em-fw-semibold); }

.em-plp__head { margin-bottom: var(--em-gap); }
.em-plp__head .em-h1 { margin: 0; }
.em-plp__intro { color: var(--em-gray-700); margin: 6px 0 0; max-width: 60ch; }

.em-plp__layout { display: grid; grid-template-columns: 1fr; gap: var(--em-gap); }

/* Mobile (no-JS): inline filters; shop-plp.js upgrades to an off-canvas drawer
   (S3.4). Desktop is always a static rail (media query below). */
.em-plp__filters { display: block; }
.em-filter-drawer__head { display: none; }
.em-plp__filterbtn { display: none; }
.em-plp--enhanced .em-plp__filterbtn { display: inline-flex; align-items: center; gap: 6px; margin-right: auto; }
.em-plp--enhanced .em-plp__filters {
  position: fixed; top: 0; left: 0; bottom: 0; z-index: var(--em-z-drawer);
  width: 86%; max-width: 360px; background: var(--em-surface); padding: var(--em-gap);
  overflow-y: auto; transform: translateX(-100%); transition: transform 0.2s ease;
  box-shadow: var(--em-shadow-lift);
}
.em-plp--enhanced .em-plp__filters.is-open { transform: translateX(0); }
.em-plp--enhanced .em-filter-drawer__head { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--em-gap); }
.em-filter-drawer__title { font-weight: var(--em-fw-semibold); font-size: var(--em-fs-price); }
.em-filter-drawer__close { border: 0; background: none; font-size: 28px; line-height: 1; color: var(--em-gray-700); cursor: pointer; }
.em-plp__suggest { margin-top: calc(var(--em-gap) * 2); }
.em-plp__suggest .em-h2 { margin: 0 0 var(--em-gap); }

.em-plp__toolbar {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--em-gap-sm); flex-wrap: wrap;
  padding-bottom: var(--em-gap); border-bottom: 1px solid var(--em-gray-300);
  margin-bottom: var(--em-gap);
}
.em-plp__count { margin: 0; color: var(--em-gray-700); font-size: var(--em-fs-card); }
.em-plp__sort { display: flex; align-items: center; gap: 8px; }
.em-plp__sort-label { font-size: var(--em-fs-card); color: var(--em-gray-700); }
.em-plp__sort-select {
  border: 1px solid var(--em-gray-300); border-radius: var(--em-radius);
  padding: 8px 10px; font: inherit; background: var(--em-surface); color: var(--em-ink);
}

.em-plp__grid { margin-bottom: calc(var(--em-gap) * 1.5); }

.em-pagination { display: flex; flex-wrap: wrap; gap: 6px; justify-content: center; align-items: center; }
.em-pagination__link {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 40px; height: 40px; padding: 0 12px;
  border: 1px solid var(--em-gray-300); border-radius: var(--em-radius);
  background: var(--em-surface); color: var(--em-ink); text-decoration: none;
  font-size: var(--em-fs-card); font-weight: var(--em-fw-semibold);
}
.em-pagination__link:hover { border-color: var(--em-primary); color: var(--em-primary-dark); }
.em-pagination__link.is-current { background: var(--em-primary); border-color: var(--em-primary); color: var(--em-surface); }
.em-pagination__link.is-disabled { color: var(--em-gray-300); cursor: default; }
.em-pagination__link.is-disabled:hover { border-color: var(--em-gray-300); color: var(--em-gray-300); }
.em-pagination__gap { padding: 0 4px; color: var(--em-gray-700); }

.em-plp__empty { text-align: center; padding: calc(var(--em-gap) * 3) var(--em-gap); color: var(--em-gray-700); }
.em-plp__empty-icon { font-size: 40px; color: var(--em-gray-300); margin-bottom: var(--em-gap); }
.em-plp__empty-title { font-size: var(--em-fs-price); font-weight: var(--em-fw-semibold); color: var(--em-ink); margin: 0 0 6px; }
.em-plp__empty-text { margin: 0 0 var(--em-gap); }

@media (min-width: 768px) {
  .em-plp__layout { grid-template-columns: 260px 1fr; align-items: start; }
  /* Desktop is always a static rail, even when JS-enhanced. */
  .em-plp__filterbtn,
  .em-plp--enhanced .em-plp__filterbtn,
  .em-filter-drawer__head,
  .em-plp--enhanced .em-filter-drawer__head { display: none; }
  .em-plp__filters,
  .em-plp--enhanced .em-plp__filters {
    position: static; transform: none; width: auto; max-width: none;
    padding: 0; background: transparent; box-shadow: none; overflow: visible; z-index: auto;
  }
}

/* === PLP filter sidebar (REV-F03 / S3.3) =================================== */
.em-filter { padding: var(--em-gap) 0; border-bottom: 1px solid var(--em-gray-300); }
.em-filter:first-child { padding-top: 0; }
.em-filter__title { font-size: var(--em-fs-card); font-weight: var(--em-fw-semibold); text-transform: uppercase; letter-spacing: 0.03em; color: var(--em-ink); margin: 0 0 var(--em-gap-sm); }
.em-filter__soon { text-transform: none; letter-spacing: 0; color: var(--em-gray-700); font-weight: var(--em-fw-regular); }
.em-filter__list { list-style: none; margin: 0; padding: 0; }
.em-filter__opt { margin: 0 0 6px; }
.em-filter__opt label { display: flex; align-items: center; gap: 8px; cursor: pointer; color: var(--em-ink); font-size: var(--em-fs-card); }
.em-filter__price { display: flex; align-items: center; gap: 8px; }
.em-filter__price-input { width: 100%; border: 1px solid var(--em-gray-300); border-radius: var(--em-radius); padding: 8px 10px; font: inherit; min-width: 0; }
.em-filter__price-sep { color: var(--em-gray-700); }
.em-filter--disabled { opacity: 0.55; }
.em-filter__actions { padding-top: var(--em-gap); display: flex; align-items: center; gap: var(--em-gap); }
.em-filter__apply { width: 100%; justify-content: center; }
.em-filter__clear { color: var(--em-primary-dark); text-decoration: none; font-size: var(--em-fs-card); white-space: nowrap; }
.em-filter__clear:hover { text-decoration: underline; }

/* === PDP — Product Detail Page (REV-F04 / S3.6) ============================
   Hand-compiled from resources/assets/sass/shop/_pdp.scss (S0.3 deviation;
   regenerate with `npm run prod`). design.md §6.2. */
.em-pdp { padding-top: var(--em-gap); padding-bottom: calc(var(--em-gap) * 2); }
.em-pdp__layout { display: grid; grid-template-columns: 1fr; gap: calc(var(--em-gap) * 1.5); }

.em-gallery__stage { position: relative; }
.em-gallery__discount { position: absolute; top: var(--em-gap-sm); left: var(--em-gap-sm); z-index: 2; }
.em-gallery__main { border: 1px solid var(--em-gray-300); background: var(--em-surface); overflow: hidden; aspect-ratio: 1 / 1; display: flex; align-items: center; justify-content: center; }
.em-gallery__main img { width: 100%; height: 100%; object-fit: contain; transition: transform 0.15s ease; }
.em-gallery__main--zoomable { cursor: zoom-in; }
.em-gallery__main--zoomable.is-zoomed img { transform: scale(2); }
.em-gallery__thumbs { list-style: none; margin: var(--em-gap-sm) 0 0; padding: 0; display: flex; gap: var(--em-gap-sm); overflow-x: auto; }
.em-gallery__thumb { width: 64px; height: 64px; flex: 0 0 auto; padding: 0; border: 1px solid var(--em-gray-300); background: var(--em-surface); cursor: pointer; overflow: hidden; }
.em-gallery__thumb img { width: 100%; height: 100%; object-fit: contain; }
.em-gallery__thumb.is-active { border-color: var(--em-primary); }

.em-buybox__title { font-size: var(--em-fs-h2); margin: 0 0 6px; }
.em-buybox__seller { color: var(--em-gray-700); font-size: var(--em-fs-card); margin: 0 0 var(--em-gap); }
.em-buybox__price { display: flex; align-items: baseline; gap: var(--em-gap-sm); margin-bottom: var(--em-gap-sm); }
.em-buybox__now { font-size: var(--em-fs-h2); font-weight: var(--em-fw-bold); color: var(--em-primary-dark); }
.em-buybox__was { color: var(--em-gray-700); text-decoration: line-through; }
.em-buybox__stock { font-size: var(--em-fs-card); font-weight: var(--em-fw-semibold); margin: 0 0 var(--em-gap); }
.em-buybox__stock--in { color: var(--em-primary-dark); }
.em-buybox__stock--out { color: var(--em-danger); }
.em-buybox__actions { display: flex; flex-wrap: wrap; gap: var(--em-gap-sm); margin-bottom: var(--em-gap); }
.em-buybox__add { min-width: 200px; justify-content: center; }
.em-buybox__sku { color: var(--em-gray-700); font-size: var(--em-fs-card); margin: 0; }

@media (min-width: 768px) {
  .em-pdp__layout { grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); align-items: start; }
}

/* === PDP buy box: qty stepper + payment badges (REV-F04 / S3.7) ============ */
.em-buybox__qty { display: flex; align-items: center; gap: var(--em-gap); margin-bottom: var(--em-gap); flex-wrap: wrap; }
.em-buybox__qty-label { font-size: var(--em-fs-card); font-weight: var(--em-fw-semibold); color: var(--em-ink); }
.em-qtystepper { display: inline-flex; align-items: stretch; border: 1px solid var(--em-gray-300); border-radius: var(--em-radius); overflow: hidden; }
.em-qtystepper__btn { width: 40px; border: 0; background: var(--em-bg); color: var(--em-ink); font-size: 1.125rem; line-height: 1; cursor: pointer; }
.em-qtystepper__btn:hover { background: var(--em-primary-tint); color: var(--em-primary-dark); }
.em-qtystepper__input { width: 56px; border: 0; border-left: 1px solid var(--em-gray-300); border-right: 1px solid var(--em-gray-300); text-align: center; font: inherit; -moz-appearance: textfield; }
.em-qtystepper__input::-webkit-outer-spin-button,
.em-qtystepper__input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.em-buybox__lowstock { font-size: var(--em-fs-card); color: var(--em-danger); font-weight: var(--em-fw-semibold); }
.em-buybox__add,
.em-buybox__buynow { flex: 1 1 200px; justify-content: center; }
.em-buybox__pay { display: flex; align-items: center; flex-wrap: wrap; gap: var(--em-gap-sm); margin-bottom: var(--em-gap); }
.em-buybox__pay-label { font-size: var(--em-fs-card); color: var(--em-gray-700); }
.em-buybox__pay-badge { font-size: 0.75rem; font-weight: var(--em-fw-semibold); color: var(--em-ink); background: var(--em-bg); border: 1px solid var(--em-gray-300); border-radius: var(--em-radius-sm); padding: 4px 8px; }

/* === PDP district delivery estimate (REV-F04 / S3.8) ====================== */
.em-delivery { padding: var(--em-gap); margin-bottom: var(--em-gap); border: 1px solid var(--em-gray-300); border-radius: var(--em-radius); background: var(--em-bg); }
.em-delivery__label { display: block; font-size: var(--em-fs-card); font-weight: var(--em-fw-semibold); color: var(--em-ink); margin-bottom: var(--em-gap-sm); }
.em-delivery__select { width: 100%; border: 1px solid var(--em-gray-300); border-radius: var(--em-radius); padding: 10px 12px; font: inherit; background: var(--em-surface); color: var(--em-ink); }
.em-delivery__result { margin: var(--em-gap-sm) 0 0; font-size: var(--em-fs-card); color: var(--em-gray-700); }

/* === PDP tabs + specs + related (REV-F04 / S3.9) ========================== */
.em-pdptabs { margin-top: calc(var(--em-gap) * 2); }
.em-pdptabs__nav { border-bottom: 1px solid var(--em-gray-300); gap: var(--em-gap); }
.em-pdptabs__panels { padding-top: var(--em-gap); }
.em-richtext { color: var(--em-ink); }
.em-richtext img { max-width: 100%; height: auto; }
.em-spectable { width: 100%; border-collapse: collapse; max-width: 520px; }
.em-spectable th,
.em-spectable td { text-align: left; padding: 10px 12px; border-bottom: 1px solid var(--em-gray-300); font-size: var(--em-fs-card); }
.em-spectable th { width: 38%; color: var(--em-gray-700); font-weight: var(--em-fw-semibold); }
.em-pdp__related { margin-top: calc(var(--em-gap) * 2); }

/* === PDP sticky mobile add-to-cart bar (REV-F04 / S3.10) ================== */
.em-pdp-sticky { display: none; }
.em-pdp-sticky__info { display: flex; align-items: center; gap: var(--em-gap-sm); min-width: 0; }
.em-pdp-sticky__img { width: 40px; height: 40px; object-fit: contain; flex: 0 0 auto; }
.em-pdp-sticky__price { font-weight: var(--em-fw-bold); color: var(--em-primary-dark); white-space: nowrap; }
.em-pdp-sticky__add { flex: 0 0 auto; }
@media (max-width: 767px) {
  .em-pdp-sticky:not([hidden]) {
    display: flex; align-items: center; justify-content: space-between; gap: var(--em-gap);
    position: fixed; left: 0; right: 0; bottom: 60px; z-index: var(--em-z-header);
    background: var(--em-surface); border-top: 1px solid var(--em-gray-300);
    box-shadow: var(--em-shadow-lift); padding: var(--em-gap-sm) var(--em-gap);
  }
}

/* === Hide scrollbars on intentional scroll containers (clean mobile look;
   scrolling still works via touch/drag). Debug fix 2026-06-16. ============== */
.em-carousel,
.em-gallery__thumbs,
.em-mobile-menu,
.em-plp__filters,
.em-search__category,
.em-mega-menu__panel { scrollbar-width: none; -ms-overflow-style: none; }
.em-carousel::-webkit-scrollbar,
.em-gallery__thumbs::-webkit-scrollbar,
.em-mobile-menu::-webkit-scrollbar,
.em-plp__filters::-webkit-scrollbar,
.em-mega-menu__panel::-webkit-scrollbar { width: 0; height: 0; display: none; }

/* =============================================================================
 * Cart page (REV-F05 / S4.3). Hand-compiled from
 * resources/assets/sass/shop/_cart.scss (S0.3 elixir deviation). design.md §6.3.
 * ========================================================================== */
.em-cartpage__title { margin: var(--em-gap) 0; }

.em-cartpage {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--em-gap);
  align-items: start;
}

@media (min-width: 992px) {
  .em-cartpage { grid-template-columns: 1fr 340px; }
}

.em-cartlines { list-style: none; margin: 0; padding: 0; }

.em-cartline {
  display: grid;
  grid-template-columns: 72px 1fr auto;
  gap: var(--em-gap);
  align-items: center;
  padding: var(--em-gap) 0;
  border-bottom: 1px solid var(--em-gray-300);
}
.em-cartline.is-busy { opacity: 0.5; pointer-events: none; }

.em-cartline__thumb {
  display: block;
  width: 72px; height: 72px;
  background: var(--em-bg);
  border: 1px solid var(--em-gray-300);
  overflow: hidden;
}
.em-cartline__thumb img { width: 100%; height: 100%; object-fit: cover; }

.em-cartline__info { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.em-cartline__name {
  color: var(--em-ink); font-weight: var(--em-fw-semibold);
  text-decoration: none; line-height: 1.3;
}
.em-cartline__name:hover { color: var(--em-primary); }
.em-cartline__seller, .em-cartline__unit { font-size: 0.8125rem; color: var(--em-gray-700); }

.em-cartline__qty { justify-self: start; }

.em-cartline__line {
  display: flex; flex-direction: column; align-items: flex-end; gap: var(--em-gap-sm);
  font-weight: var(--em-fw-semibold); color: var(--em-ink); white-space: nowrap;
}
.em-cartline__remove {
  background: none; border: 0; cursor: pointer; padding: 0;
  font-size: 0.8125rem; color: var(--em-gray-700);
}
.em-cartline__remove:hover { color: var(--em-danger); }

@media (max-width: 575px) {
  .em-cartline { grid-template-columns: 56px 1fr; grid-row-gap: var(--em-gap-sm); }
  .em-cartline__thumb { width: 56px; height: 56px; }
  .em-cartline__qty { grid-column: 1 / -1; }
  .em-cartline__line { grid-column: 1 / -1; flex-direction: row; justify-content: space-between; align-items: center; }
}

.em-qtystepper {
  display: inline-flex; align-items: center;
  border: 1px solid var(--em-gray-300); border-radius: var(--em-radius);
  overflow: hidden;
}
.em-qtystepper__btn {
  width: 34px; height: 34px; border: 0; background: var(--em-surface);
  font-size: 1.125rem; line-height: 1; cursor: pointer; color: var(--em-ink);
}
.em-qtystepper__btn:hover { background: var(--em-bg); }
.em-qtystepper__input {
  width: 44px; height: 34px; border: 0; text-align: center;
  border-left: 1px solid var(--em-gray-300); border-right: 1px solid var(--em-gray-300);
  font-size: var(--em-fs-body); -moz-appearance: textfield;
}
.em-qtystepper__input::-webkit-outer-spin-button,
.em-qtystepper__input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }

.em-summary {
  background: var(--em-surface);
  border: 1px solid var(--em-gray-300);
  padding: var(--em-gap);
  position: sticky; top: var(--em-gap);
}
.em-summary__title { font-size: 1.125rem; font-weight: var(--em-fw-semibold); margin: 0 0 var(--em-gap); }
.em-summary__row {
  display: flex; justify-content: space-between; align-items: baseline;
  padding: var(--em-gap-sm) 0; color: var(--em-gray-700);
}
.em-summary__row strong { color: var(--em-ink); }
.em-summary__row--save span, .em-summary__row--save strong { color: var(--em-primary); }
.em-summary__row--total {
  border-top: 1px solid var(--em-gray-300); margin-top: var(--em-gap-sm);
  padding-top: var(--em-gap); font-size: var(--em-fs-price);
}
.em-summary__row--total strong { font-weight: var(--em-fw-bold); }

.em-summary__delivery { padding: var(--em-gap-sm) 0; }
.em-summary__label {
  display: block; font-size: 0.8125rem; color: var(--em-gray-700); margin-bottom: 4px;
}
.em-select, .em-input {
  width: 100%; padding: 8px 10px; font-size: var(--em-fs-body);
  border: 1px solid var(--em-gray-300); border-radius: var(--em-radius);
  background: var(--em-surface); color: var(--em-ink);
}
.em-select:focus, .em-input:focus {
  outline: none; border-color: var(--em-primary);
  box-shadow: 0 0 0 3px rgba(23, 102, 35, 0.15);
}

.em-promo { padding: var(--em-gap) 0; border-top: 1px solid var(--em-gray-300); margin-top: var(--em-gap-sm); }
.em-promo__row { display: flex; gap: var(--em-gap-sm); }
.em-promo__row .em-input { flex: 1; }
.em-promo__note { display: block; margin-top: 6px; color: var(--em-gray-700); }

.em-summary__checkout { display: block; width: 100%; text-align: center; margin-top: var(--em-gap); }

.em-summary__trust {
  list-style: none; margin: var(--em-gap) 0 0; padding: 0;
  font-size: 0.8125rem; color: var(--em-gray-700);
}
.em-summary__trust li { padding: 3px 0; }
.em-summary__trust i { color: var(--em-primary); width: 16px; }

.em-cartpage__empty {
  text-align: center; padding: calc(var(--em-gap) * 3) var(--em-gap);
  background: var(--em-surface); border: 1px solid var(--em-gray-300);
}
.em-cartpage__empty i { font-size: 2.5rem; color: var(--em-gray-300); }
.em-cartpage__empty h2 { margin: var(--em-gap) 0 var(--em-gap-sm); }
.em-cartpage__empty p { color: var(--em-gray-700); margin: 0 0 var(--em-gap); }

/* =============================================================================
 * Checkout (REV-F05 / S4.4). Hand-compiled from
 * resources/assets/sass/shop/_checkout.scss (S0.3 elixir deviation). design §6.3.
 * ========================================================================== */
.em-checkout__title { margin: var(--em-gap) 0 var(--em-gap-sm); }

.em-steps {
  list-style: none; display: flex; gap: var(--em-gap-sm);
  margin: 0 0 var(--em-gap); padding: 0; flex-wrap: wrap;
}
.em-steps__item {
  display: flex; align-items: center; gap: 6px;
  font-size: 0.875rem; color: var(--em-gray-700);
  padding: 6px 12px; background: var(--em-surface);
  border: 1px solid var(--em-gray-300);
}
.em-steps__item.is-active { color: var(--em-ink); border-color: var(--em-primary); font-weight: var(--em-fw-semibold); }
.em-steps__no {
  display: inline-flex; align-items: center; justify-content: center;
  width: 20px; height: 20px; border-radius: var(--em-radius-pill);
  background: var(--em-bg); font-size: 0.75rem;
}
.em-steps__item.is-active .em-steps__no { background: var(--em-primary); color: #fff; }

.em-checkout {
  display: grid; grid-template-columns: 1fr; gap: var(--em-gap); align-items: start;
}
@media (min-width: 992px) {
  .em-checkout { grid-template-columns: 1fr 340px; }
}

.em-checkform {
  background: var(--em-surface); border: 1px solid var(--em-gray-300); padding: var(--em-gap);
}
.em-checkform__title { font-size: 1.125rem; font-weight: var(--em-fw-semibold); margin: 0 0 var(--em-gap); }

.em-field { margin-bottom: var(--em-gap); }
.em-field label { display: block; font-size: 0.875rem; font-weight: var(--em-fw-medium); margin-bottom: 4px; color: var(--em-ink); }
.em-field__opt { color: var(--em-gray-700); font-weight: var(--em-fw-regular); }
.em-field__msg { display: block; margin-top: 4px; color: var(--em-danger); font-size: 0.8125rem; }
.em-field--error .em-input, .em-field--error .em-select { border-color: var(--em-danger); }

.em-phone { display: flex; }
.em-phone__cc {
  display: inline-flex; align-items: center; padding: 0 10px;
  border: 1px solid var(--em-gray-300); border-right: 0;
  background: var(--em-bg); color: var(--em-gray-700); font-size: var(--em-fs-body);
}
.em-phone .em-input { border-top-left-radius: 0; border-bottom-left-radius: 0; }

.em-checkform__submit { display: block; width: 100%; margin-top: var(--em-gap); }

.em-note {
  padding: 10px var(--em-gap); margin-bottom: var(--em-gap);
  border: 1px solid var(--em-gray-300); font-size: 0.875rem;
}
.em-note--ok { border-color: var(--em-primary); background: var(--em-primary-tint); color: var(--em-primary-dark); }

.em-link { color: var(--em-primary); text-decoration: none; }
.em-link:hover { text-decoration: underline; }

/* === Checkout Payment + Review steps (REV-F05 / S4.5) ====================== */
.em-paymethods { display: flex; flex-direction: column; gap: var(--em-gap-sm); }
.em-paymethod {
  display: flex; align-items: flex-start; gap: 10px;
  padding: var(--em-gap); border: 1px solid var(--em-gray-300); cursor: pointer;
}
.em-paymethod.is-selected { border-color: var(--em-primary); background: var(--em-primary-tint); }
.em-paymethod input { margin-top: 3px; }
.em-paymethod__body { display: flex; flex-direction: column; gap: 2px; }
.em-paymethod__label { font-weight: var(--em-fw-semibold); color: var(--em-ink); }
.em-paymethod__desc { font-size: 0.8125rem; color: var(--em-gray-700); }

.em-checkform__actions {
  display: flex; justify-content: space-between; align-items: center;
  gap: var(--em-gap); margin-top: var(--em-gap); flex-wrap: wrap;
}

.em-review__items { list-style: none; margin: 0 0 var(--em-gap); padding: 0; }
.em-review__item {
  display: grid; grid-template-columns: auto 1fr auto; gap: var(--em-gap-sm);
  padding: 6px 0; border-bottom: 1px solid var(--em-gray-300);
}
.em-review__qty { color: var(--em-gray-700); }
.em-review__line { font-weight: var(--em-fw-semibold); white-space: nowrap; }

.em-review__block { padding: var(--em-gap) 0; border-bottom: 1px solid var(--em-gray-300); }
.em-review__head { display: flex; justify-content: space-between; align-items: baseline; }
.em-review__head h3 { font-size: 0.9375rem; font-weight: var(--em-fw-semibold); margin: 0 0 6px; }
.em-review__lines { margin: 0; line-height: 1.6; }
.em-review__muted { color: var(--em-gray-700); font-size: 0.875rem; }
.em-review__totals { padding: var(--em-gap) 0; }
.em-review__note { display: block; margin-top: var(--em-gap-sm); color: var(--em-gray-700); }

/* === Order confirmation (REV-F05 / S4.6) =================================== */
.em-confirm { max-width: 560px; margin: 0 auto; text-align: center; padding: var(--em-gap) 0; }
.em-confirm__icon { font-size: 3rem; color: var(--em-primary); }
.em-confirm__lead { color: var(--em-gray-700); margin: var(--em-gap-sm) 0 var(--em-gap); }
.em-confirm__card { text-align: left; margin: var(--em-gap) 0; position: static; }
.em-confirm__next { color: var(--em-gray-700); margin: var(--em-gap) 0; }

/* --- M-PESA number capture popup + synchronous-pay overlay (S4.7) ----------- */
.em-note--error { border-color: var(--em-danger); background: #FDECEC; color: var(--em-danger); }
.em-modal { position: fixed; inset: 0; z-index: 1000; display: flex; align-items: center; justify-content: center; padding: var(--em-gap); }
.em-modal[hidden] { display: none; }
.em-modal__backdrop { position: absolute; inset: 0; background: rgba(11, 28, 48, 0.55); }
.em-modal__dialog { position: relative; width: 100%; max-width: 420px; background: #fff; border-radius: var(--em-radius); box-shadow: var(--em-shadow-lift); padding: var(--em-gap); z-index: 1; }
.em-modal__title { font-size: 1.0625rem; font-weight: var(--em-fw-semibold); margin: 0 0 6px; }
.em-modal__lead { color: var(--em-gray-700); font-size: 0.875rem; margin: 0 0 var(--em-gap); }
.em-modal__err { padding: 8px 10px; margin-bottom: var(--em-gap); font-size: 0.8125rem; border: 1px solid var(--em-danger); background: #FDECEC; color: var(--em-danger); }
.em-modal__err[hidden] { display: none; }
.em-modal__actions { display: flex; justify-content: flex-end; gap: var(--em-gap-sm); margin-top: var(--em-gap); }
.em-field { display: block; }
.em-field__label { display: block; font-size: 0.875rem; font-weight: var(--em-fw-semibold); margin-bottom: 6px; }
.em-field__hint { font-size: 0.8125rem; color: var(--em-gray-700); margin: 6px 0 0; }
.em-phoneinput { display: flex; align-items: stretch; border: 1px solid var(--em-gray-300); border-radius: var(--em-radius); overflow: hidden; }
.em-phoneinput__cc { display: flex; align-items: center; padding: 0 10px; background: var(--em-gray-100, #F1F5F9); border-right: 1px solid var(--em-gray-300); color: var(--em-gray-700); font-weight: var(--em-fw-semibold); }
.em-phoneinput input { flex: 1; border: 0; padding: 10px; font-size: 1rem; outline: none; }
.em-payoverlay { position: fixed; inset: 0; z-index: 1100; display: none; align-items: center; justify-content: center; padding: var(--em-gap); background: rgba(11, 28, 48, 0.65); }
.em-payoverlay__box { background: #fff; border-radius: var(--em-radius); box-shadow: var(--em-shadow-lift); padding: 24px; max-width: 380px; text-align: center; }
.em-payoverlay__title { font-weight: var(--em-fw-semibold); margin: var(--em-gap) 0 6px; }
.em-payoverlay__lead { color: var(--em-gray-700); font-size: 0.875rem; margin: 0; }
.em-payoverlay__spin { width: 38px; height: 38px; margin: 0 auto; border-radius: 50%; border: 3px solid var(--em-gray-300); border-top-color: var(--em-primary); animation: em-spin 0.8s linear infinite; }
@keyframes em-spin { to { transform: rotate(360deg); } }

/* === REV-F06 orders: timeline (S5.1), confirmation (S5.2), tracking (S5.3), account (S5.4) === */
.em-track { margin: var(--em-gap) 0; }
.em-track__steps { list-style: none; margin: 0 0 var(--em-gap); padding: 0; display: flex; gap: var(--em-gap-sm); }
.em-track__step { flex: 1; text-align: center; position: relative; font-size: 0.8125rem; color: var(--em-gray-700); }
.em-track__step + .em-track__step::before { content: ""; position: absolute; top: 16px; left: -50%; width: 100%; height: 2px; background: var(--em-gray-300); z-index: 0; }
.em-track__dot { position: relative; z-index: 1; display: flex; align-items: center; justify-content: center; width: 34px; height: 34px; margin: 0 auto 6px; border-radius: 50%; background: #fff; border: 2px solid var(--em-gray-300); color: var(--em-gray-700); }
.em-track__step--done .em-track__dot, .em-track__step--current .em-track__dot { background: var(--em-primary); border-color: var(--em-primary); color: #fff; }
.em-track__step--done + .em-track__step::before, .em-track__step--current + .em-track__step::before { background: var(--em-primary); }
.em-track__step--current .em-track__label { font-weight: var(--em-fw-semibold); color: var(--em-ink); }
.em-track__log { list-style: none; margin: 0; padding: 0; }
.em-track__event { display: flex; gap: var(--em-gap-sm); padding: 10px 0; border-top: 1px solid var(--em-gray-300); }
.em-track__event-icon { color: var(--em-primary); width: 18px; text-align: center; }
.em-track__event-body { display: flex; flex-direction: column; gap: 2px; }
.em-track__event-label { font-size: 0.9375rem; }
.em-track__event-note, .em-track__event-courier { font-size: 0.8125rem; color: var(--em-gray-700); }
.em-track__event-time { font-size: 0.75rem; color: var(--em-gray-700); }
.em-confirm__detail { display: grid; grid-template-columns: 1fr 1fr; gap: var(--em-gap); margin: var(--em-gap) 0; }
.em-confirm__detail h3 { font-size: 0.9375rem; margin: 0 0 6px; }
.em-confirm__detail p { margin: 0; font-size: 0.875rem; color: var(--em-gray-700); }
.em-confirm__tracklink { word-break: break-all; }
.em-confirm__offer { background: var(--em-primary-tint); border-radius: var(--em-radius); padding: var(--em-gap); margin: var(--em-gap) 0; }
@media (max-width: 600px) { .em-confirm__detail { grid-template-columns: 1fr; } .em-track__label { font-size: 0.6875rem; } }
.em-trackpage { max-width: 720px; margin: var(--em-gap) auto; }
.em-trackpage__form { background: #fff; border: 1px solid var(--em-gray-300); border-radius: var(--em-radius); padding: var(--em-gap); display: grid; gap: var(--em-gap-sm); }
.em-trackpage__form .em-field { display: flex; flex-direction: column; gap: 4px; }
.em-trackpage__form label { font-size: 0.875rem; font-weight: var(--em-fw-semibold); }
.em-trackpage__form input { padding: 10px; border: 1px solid var(--em-gray-300); border-radius: var(--em-radius); }
.em-trackpage__result { background: #fff; border: 1px solid var(--em-gray-300); border-radius: var(--em-radius); padding: var(--em-gap); margin-top: var(--em-gap); }
.em-account__orders { list-style: none; margin: 0; padding: 0; }
.em-account__order { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: var(--em-gap-sm); background: #fff; border: 1px solid var(--em-gray-300); border-radius: var(--em-radius); padding: var(--em-gap); margin-bottom: var(--em-gap-sm); }
.em-account__order-meta { display: flex; flex-direction: column; gap: 2px; }
.em-account__order-no { font-weight: var(--em-fw-semibold); }
.em-account__order-sub { font-size: 0.8125rem; color: var(--em-gray-700); }
.em-badge-status { display: inline-block; padding: 2px 10px; border-radius: var(--em-radius-pill); font-size: 0.75rem; font-weight: var(--em-fw-semibold); background: var(--em-primary-tint); color: var(--em-primary-dark); }
.em-badge-status--cancelled { background: #FDE7E7; color: var(--em-danger); }

/* === Homepage district dot map (inline SVG, no asset) === */
.em-dotmap { width: 100%; height: auto; display: block; max-height: 300px; }
.em-dotmap__grid { fill: var(--em-gray-300); }
.em-dotmap__outline { fill: none; stroke: var(--em-primary); stroke-width: 1.5; opacity: 0.25; }
.em-dotmap__dot { fill: var(--em-primary); }
.em-dotmap__marker--capital .em-dotmap__dot { fill: var(--em-primary-dark); }
.em-dotmap__label { fill: var(--em-gray-700); font-size: 13px; font-weight: var(--em-fw-semibold); }
.em-dotmap__pulse { fill: var(--em-primary); opacity: 0.25; transform-box: fill-box; transform-origin: center; animation: em-dotpulse 2.6s ease-out infinite; }
.em-dotmap__marker:nth-child(2) .em-dotmap__pulse { animation-delay: 0.2s; }
.em-dotmap__marker:nth-child(3) .em-dotmap__pulse { animation-delay: 0.4s; }
.em-dotmap__marker:nth-child(4) .em-dotmap__pulse { animation-delay: 0.6s; }
.em-dotmap__marker:nth-child(5) .em-dotmap__pulse { animation-delay: 0.8s; }
.em-dotmap__marker:nth-child(6) .em-dotmap__pulse { animation-delay: 1.0s; }
.em-dotmap__marker:nth-child(7) .em-dotmap__pulse { animation-delay: 1.2s; }
.em-dotmap__marker:nth-child(8) .em-dotmap__pulse { animation-delay: 1.4s; }
.em-dotmap__marker:nth-child(9) .em-dotmap__pulse { animation-delay: 1.6s; }
.em-dotmap__marker:nth-child(10) .em-dotmap__pulse { animation-delay: 1.8s; }
@keyframes em-dotpulse { 0% { transform: scale(0.6); opacity: 0.45; } 70% { opacity: 0; } 100% { transform: scale(1.7); opacity: 0; } }
@media (prefers-reduced-motion: reduce) { .em-dotmap__pulse { animation: none; opacity: 0.18; } }
@media (max-width: 520px) { .em-dotmap__label { display: none; } }

/* === Lazy images + shimmer placeholder (shop-lazy.js) === */
@keyframes em-shimmer { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }
.em-shimmer { background-image: linear-gradient(90deg, var(--em-bg) 0%, #ffffff 50%, var(--em-bg) 100%); background-size: 200% 100%; animation: em-shimmer 1.3s linear infinite; }
.em-lazy { opacity: 0; transition: opacity 0.35s ease; }
.em-lazy.em-lazy--in { opacity: 1; }
.em-catgrid__img, .em-store__logo { overflow: hidden; }
.em-catgrid__img img, .em-store__logo img { width: 100%; height: 100%; object-fit: cover; display: block; }
@media (prefers-reduced-motion: reduce) { .em-shimmer { animation: none; } .em-lazy { transition: none; opacity: 1; } }

/* === "Download our mobile app" CTA + popup (reused storefront-styled) === */
.em-appcta { display: grid; grid-template-columns: 1fr; gap: var(--em-gap); align-items: center; background: var(--em-primary-dark); color: #fff; border-radius: var(--em-radius); padding: calc(var(--em-gap) * 1.5); overflow: hidden; }
.em-appcta .em-h2 { color: #fff; }
.em-appcta__lead { color: rgba(255, 255, 255, 0.85); margin: var(--em-gap-sm) 0 var(--em-gap); }
.em-appcta__badges { display: flex; flex-wrap: wrap; gap: var(--em-gap-sm); align-items: center; }
.em-appcta__badge img { height: 46px; width: auto; display: block; }
.em-appcta__art { text-align: center; }
.em-appcta__art img { max-width: 240px; width: 100%; height: auto; }
@media (min-width: 768px) { .em-appcta { grid-template-columns: 1.4fr 1fr; padding: calc(var(--em-gap) * 2); } }
.em-apppopup { position: fixed; inset: 0; z-index: 1200; display: flex; align-items: center; justify-content: center; padding: var(--em-gap); opacity: 0; visibility: hidden; transition: opacity 0.25s ease, visibility 0.25s ease; }
.em-apppopup.is-open { opacity: 1; visibility: visible; }
.em-apppopup__scrim { position: absolute; inset: 0; background: rgba(11, 28, 48, 0.55); }
.em-apppopup__box { position: relative; z-index: 1; background: #fff; border-radius: var(--em-radius); box-shadow: var(--em-shadow-lift); padding: calc(var(--em-gap) * 1.5); max-width: 360px; width: 100%; text-align: center; transform: translateY(12px); transition: transform 0.25s ease; }
.em-apppopup.is-open .em-apppopup__box { transform: translateY(0); }
.em-apppopup__close { position: absolute; top: 6px; right: 10px; background: none; border: 0; font-size: 1.75rem; line-height: 1; color: var(--em-gray-700); cursor: pointer; }
.em-apppopup__art { width: 120px; height: auto; margin: 0 auto var(--em-gap-sm); display: block; }
.em-apppopup__title { margin: 0 0 6px; }
.em-apppopup__lead { color: var(--em-gray-700); font-size: 0.9375rem; margin: 0 0 var(--em-gap); }
@media (prefers-reduced-motion: reduce) { .em-apppopup, .em-apppopup__box { transition: none; } }

/* === Product variations (REV-F04 / S3.7+) === */
.em-variants { margin: var(--em-gap) 0; display: flex; flex-direction: column; gap: var(--em-gap-sm); }
.em-variant__label { font-size: 0.875rem; color: var(--em-gray-700); display: block; margin-bottom: 6px; }
.em-variant__label strong { color: var(--em-ink); }
.em-variant__opts { display: flex; flex-wrap: wrap; gap: var(--em-gap-sm); }
.em-variant__opt { padding: 8px 14px; border: 1px solid var(--em-gray-300); border-radius: var(--em-radius); background: #fff; cursor: pointer; font: inherit; font-size: 0.875rem; color: var(--em-ink); }
.em-variant__opt:hover { border-color: var(--em-primary); }
.em-variant__opt.is-selected { border-color: var(--em-primary); background: var(--em-primary-tint); color: var(--em-primary-dark); font-weight: var(--em-fw-semibold); }
.em-btn.is-disabled, .em-btn:disabled { opacity: 0.55; cursor: not-allowed; }
.em-cart__item-variant, .em-cartline__variant { font-size: 0.75rem; color: var(--em-gray-700); }

/* === Colour swatch chips (product variations) === */
.em-variant__opt--swatch { display: inline-flex; align-items: center; gap: 6px; }
.em-swatch { width: 16px; height: 16px; border-radius: 50%; border: 1px solid rgba(0, 0, 0, 0.15); display: inline-block; flex: 0 0 auto; }
.em-variant__opt-name { line-height: 1; }
