/* ============================================================
   M & I INTERNATIONAL MARKET — Premium Design System v3.1
   Pixel-matched to reference design
   ============================================================ */

/* ----------------------------------------------------------
   1. Design Tokens
   ---------------------------------------------------------- */
:root {
  --mii-green-900: #1a3c2b;
  --mii-green-800: #1a4d2e;
  --mii-green-700: #21633a;
  --mii-green-600: #2d7a4a;
  --mii-green-500: #3d9b5f;

  --mii-gold: #c9a227;
  --mii-gold-light: #d4b43a;

  --mii-ink: #1a1a1a;
  --mii-ink-light: #2d2d2d;
  --mii-muted: #666666;
  --mii-muted-light: #999999;

  --mii-cream: #f8f5f0;
  --mii-cream-warm: #f5f0e8;
  --mii-hero-surface: #feecd2;
  --mii-hero-surface-soft: #feedd4;
  --mii-image-surface: #fbf4e8;
  --mii-image-surface-soft: #fdf8ee;
  --mii-product-card-bg: var(--mii-image-surface-soft);
  --mii-product-image-pad: 16px;
  --mii-product-image-shadow: drop-shadow(0 10px 14px rgba(26, 26, 26, 0.11));
  --mii-white: #ffffff;

  --mii-border: #e8e4de;
  --mii-border-light: #f0ede8;

  --radius-sm: 6px;
  --radius-md: 10px;
  --radius-lg: 14px;
  --radius-xl: 20px;
  --radius-full: 999px;

  --shadow-sm: 0 1px 3px rgba(26, 26, 26, 0.04);
  --shadow-md: 0 4px 12px rgba(26, 26, 26, 0.06);
  --shadow-lg: 0 8px 24px rgba(26, 26, 26, 0.08);

  --font-serif: "Playfair Display", Georgia, "Times New Roman", serif;
  --font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
}

/* ----------------------------------------------------------
   3. Base Reset
   ---------------------------------------------------------- */
html { scroll-behavior: smooth; }

body {
  background: var(--mii-white);
  color: var(--mii-ink);
  font-family: var(--font-sans);
  font-size: 15px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

a { color: var(--mii-green-800); text-decoration: none; transition: color 200ms ease, text-decoration-color 200ms ease; }
a:hover { color: var(--mii-green-600); }

*:focus-visible {
  outline: 2px solid var(--mii-green-500);
  outline-offset: 2px;
}

img { max-width: 100%; height: auto; }

/* ----------------------------------------------------------
   4. Layout
   ---------------------------------------------------------- */
.mii-container {
  width: 100%;
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 24px;
}

@media (max-width: 768px) {
  .mii-container { padding: 0 16px; }
}

.screen-reader-text {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

/* Skip link */
.mii-skip-link {
  position: absolute; top: -40px; left: 0;
  background: var(--mii-green-800); color: var(--mii-white);
  padding: 8px 16px; font-size: 13px; font-weight: 600;
  border-radius: 0 0 var(--radius-sm) 0; z-index: 100000;
  text-decoration: none; transition: top 200ms ease;
}
.mii-skip-link:focus { top: 0; outline: 2px solid var(--mii-gold); outline-offset: 0; }

/* ----------------------------------------------------------
   5. Buttons
   ---------------------------------------------------------- */
.mii-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  min-height: 46px; padding: 10px 24px; border-radius: var(--radius-sm);
  font-family: var(--font-sans); font-size: 14px; font-weight: 600;
  line-height: 1; text-decoration: none; border: 1.5px solid transparent;
  cursor: pointer; transition: background-color 200ms ease, border-color 200ms ease, color 200ms ease, transform 200ms ease, box-shadow 200ms ease; white-space: nowrap;
  touch-action: manipulation;
}

.mii-btn--primary {
  background: var(--mii-green-800); color: var(--mii-white); border-color: var(--mii-green-800);
}
.mii-btn--primary:hover { background: var(--mii-green-700); border-color: var(--mii-green-700); color: var(--mii-white); transform: translateY(-1px); }
.mii-btn--primary:active { transform: translateY(0); }

.mii-btn--outline {
  background: transparent; color: var(--mii-green-800); border-color: var(--mii-green-800);
}
.mii-btn--outline:hover { background: var(--mii-green-800); color: var(--mii-white); }
.mii-btn--outline:active { transform: translateY(0); }

.mii-btn--light {
  background: var(--mii-white); color: var(--mii-green-800); border-color: var(--mii-white);
}
.mii-btn--light:hover { background: var(--mii-cream); }
.mii-btn--light:active { transform: translateY(0); }

/* ----------------------------------------------------------
   6. Header Overrides
   ---------------------------------------------------------- */
.site-header-top-section-center .header-html-inner { font-size: 0; }
.site-header-top-section-center .header-html-inner::before {
  content: "Delivering authentic products to your doorstep";
  font-size: 12px; font-weight: 500; letter-spacing: 0.01em; color: var(--mii-white);
}
.site-header-top-section-right .header-html2 .header-html-inner p { font-size: 0; margin: 0; }
.site-header-top-section-right .header-html2 .header-html-inner p::before {
  content: "Free shipping on orders over $200"; font-size: 12px; font-weight: 500; color: var(--mii-white);
}

.site-top-header-wrap,
.site-header-top-section { background: var(--mii-green-800) !important; color: var(--mii-white) !important; }
.site-header-top-section a { color: var(--mii-white) !important; }

.site-header-row-container-inner,
.site-main-header-wrap { background: var(--mii-white) !important; border-bottom: 1px solid var(--mii-border) !important; }

.site-branding img.custom-logo { max-width: 170px; height: auto; }

.main-navigation .primary-menu-container > ul > li > a,
.secondary-navigation a { font-family: var(--font-sans); font-weight: 500; font-size: 14px; color: var(--mii-ink); padding: 10px 14px; }
.main-navigation .primary-menu-container > ul > li.current-menu-item > a,
.main-navigation .primary-menu-container > ul > li > a:hover { color: var(--mii-green-800) !important; }

.header-search-advanced .search-form { border-color: var(--mii-border) !important; border-radius: var(--radius-sm) !important; background: var(--mii-white) !important; }
.header-search-advanced input.search-field { min-height: 44px; font-size: 14px; border: none !important; }
.header-search-advanced .search-form .search-submit { background: var(--mii-green-800) !important; color: var(--mii-white) !important; border-radius: var(--radius-sm) !important; font-weight: 600; padding: 0 20px; }

/* Hide clutter */
[data-section="base_customizer_header_contact"],
[data-section="base_customizer_header_divider"],
[data-section="base_customizer_header_toggle_widget"],
.base-color-palette-fixed-switcher,
.tmc-notification, .tmc-notification-wrapper, .tmc-notification-container, .tmc-sale-popup,
.base-notification, .tmcore-notification, #tmc-notification-tml, #askquestion-popup,
.hostinger-reach-subscription-block { display: none !important; }

/* ----------------------------------------------------------
   7. Hero Section
   ---------------------------------------------------------- */
.mii-hero {
  background:
    linear-gradient(180deg, #fdebd0 0%, var(--mii-hero-surface-soft) 52%, var(--mii-hero-surface) 100%);
  padding: 42px 0 44px;
  overflow: hidden;
}
.mii-hero__grid {
  display: grid; grid-template-columns: minmax(360px, 0.75fr) minmax(0, 1.25fr); gap: 34px; align-items: center;
}
.mii-hero__tag {
  display: inline-block; font-family: var(--font-sans); font-size: 12px; font-weight: 700;
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--mii-green-800); margin-bottom: 18px;
}
.mii-hero__title {
  font-family: var(--font-serif); font-size: clamp(36px, 4.5vw, 56px); font-weight: 600;
  line-height: 1.15; color: var(--mii-ink); margin: 0 0 18px;
}
.mii-hero__sub {
  font-size: 15px; line-height: 1.65; color: var(--mii-muted); max-width: 440px; margin: 0 0 28px;
}
.mii-hero__actions { display: flex; gap: 14px; margin-bottom: 28px; flex-wrap: wrap; }
.mii-hero__actions .mii-btn { min-height: 44px; padding: 10px 22px; font-size: 14px; }
.mii-hero__actions .mii-btn svg { width: 16px; height: 16px; }

.mii-hero__social-proof { display: flex; align-items: center; gap: 14px; }
.mii-hero__avatars { display: flex; }
.mii-hero__avatars img {
  width: 36px; height: 36px; border-radius: 50%; border: 2px solid var(--mii-white);
  margin-left: -10px; object-fit: cover;
}
.mii-hero__avatars img:first-child { margin-left: 0; }
.mii-hero__rating { display: flex; align-items: center; gap: 8px; }
.mii-hero__rating-text { font-size: 13px; color: var(--mii-muted); font-weight: 500; }
.mii-stars { display: flex; gap: 2px; color: var(--mii-gold); }
.mii-stars svg { width: 14px; height: 14px; }

.mii-hero__media { position: relative; display: flex; justify-content: center; align-items: center; }
.mii-hero__frame {
  position: relative; width: 100%; max-width: 760px; aspect-ratio: 16 / 9;
  border-radius: 0; overflow: visible; background: var(--mii-hero-surface);
  box-shadow: none;
}
.mii-hero__frame::before {
  content: ""; position: absolute; inset: -2px;
  background:
    linear-gradient(90deg, var(--mii-hero-surface) 0%, rgba(254,236,210,0.72) 4%, rgba(254,236,210,0.22) 14%, rgba(254,236,210,0) 28%),
    linear-gradient(180deg, rgba(254,236,210,0) 0%, rgba(254,236,210,0) 84%, rgba(254,236,210,0.42) 96%, var(--mii-hero-surface) 100%);
  z-index: 2; pointer-events: none; mix-blend-mode: normal;
}
.mii-hero__frame img {
  position: relative; z-index: 1; width: 100%; height: 100%; object-fit: cover;
  object-position: center right; display: block;
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 4.5%, #000 98%, transparent 100%);
  mask-image: linear-gradient(90deg, transparent 0%, #000 4.5%, #000 98%, transparent 100%);
}
@supports not (-webkit-mask-image: linear-gradient(90deg, transparent, #000)) {
  .mii-hero__frame img { -webkit-mask-image: none; mask-image: none; }
}

/* ----------------------------------------------------------
   8. Trust Bar
   ---------------------------------------------------------- */
.mii-trust-bar {
  background: var(--mii-white); padding: 28px 0; border-bottom: 1px solid var(--mii-border-light);
}
.mii-trust-bar__grid {
  display: flex; justify-content: space-between; align-items: flex-start; gap: 16px;
}
.mii-trust-bar__item {
  display: flex; align-items: flex-start; gap: 12px; flex: 1;
}
.mii-trust-bar__icon {
  display: flex; align-items: center; justify-content: center;
  width: 42px; height: 42px; border-radius: 50%; border: 1.5px solid var(--mii-border);
  color: var(--mii-green-800); flex-shrink: 0; background: var(--mii-white);
}
.mii-trust-bar__icon svg { width: 20px; height: 20px; }
.mii-trust-bar__text strong {
  display: block; font-size: 13px; font-weight: 700; color: var(--mii-ink); line-height: 1.3; margin-bottom: 2px;
}
.mii-trust-bar__text span {
  display: block; font-size: 12px; color: var(--mii-muted); line-height: 1.3;
}

/* ----------------------------------------------------------
   9. Section Headers
   ---------------------------------------------------------- */
.mii-section { padding: 50px 0; }
.mii-section--categories { background: linear-gradient(180deg, var(--mii-white) 0%, #fffdf8 100%); }
.mii-section--products { background: #fffdf8; }
.mii-section--testimonials { background: var(--mii-cream); }

.mii-section__header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 32px; }
.mii-section__title {
  font-family: var(--font-serif); font-size: 24px; font-weight: 600; color: var(--mii-ink); margin: 0;
}
.mii-section__link { font-size: 13px; font-weight: 600; color: var(--mii-green-800); padding: 4px; margin: -4px; border-radius: var(--radius-sm); }
.mii-section__link:hover { text-decoration: underline; }
.mii-section__link:focus-visible { outline: 2px solid var(--mii-green-500); outline-offset: 2px; text-decoration: none; }

/* ----------------------------------------------------------
   10. Category Grid
   ---------------------------------------------------------- */
.mii-cat-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 18px; }
.mii-cat-card {
  display: block; text-decoration: none; background: var(--mii-image-surface-soft);
  border-radius: var(--radius-md); overflow: hidden; border: 1px solid rgba(232, 221, 202, 0.72);
  transition: transform 250ms ease, box-shadow 250ms ease;
  box-shadow: 0 8px 22px rgba(26, 26, 26, 0.06);
}
.mii-cat-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); }
.mii-cat-card__media {
  aspect-ratio: 1 / 0.74; overflow: hidden; background: var(--mii-image-surface-soft);
  position: relative;
}
.mii-cat-card__media::after {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background:
    linear-gradient(180deg, rgba(253,248,238,0.08) 0%, rgba(253,248,238,0) 58%, var(--mii-image-surface-soft) 100%),
    radial-gradient(circle at 0% 0%, rgba(253,248,238,0.35), transparent 42%);
}
.mii-cat-card__media img {
  width: 100%; height: 100%; object-fit: cover; transition: transform 350ms ease;
}
.mii-cat-card:hover .mii-cat-card__media img { transform: scale(1.05); }
.mii-cat-card__name {
  font-family: var(--font-sans); font-size: 14px; font-weight: 600; color: var(--mii-ink);
  text-align: center; padding: 14px; margin: 0; background: var(--mii-image-surface-soft);
}

/* ----------------------------------------------------------
   11. Products Carousel
   ---------------------------------------------------------- */
.mii-products-wrap { position: relative; display: flex; align-items: center; gap: 12px; }
.mii-product-scroll {
  display: flex; gap: 18px; overflow-x: auto; scroll-snap-type: x mandatory;
  scroll-behavior: smooth; padding: 4px; margin: -4px; scrollbar-width: none; -ms-overflow-style: none;
}
.mii-product-scroll::-webkit-scrollbar { display: none; }

.mii-products__nav {
  display: flex; align-items: center; justify-content: center; width: 40px; height: 40px;
  min-width: 40px; max-width: 40px; padding: 0 !important; flex: 0 0 40px; box-sizing: border-box;
  min-height: 40px !important; line-height: 1 !important;
  border-radius: 50%; background: var(--mii-white); border: 1px solid var(--mii-border);
  color: var(--mii-ink); cursor: pointer; flex-shrink: 0;
  transition: background-color 200ms ease, border-color 200ms ease, color 200ms ease, transform 200ms ease;
  touch-action: manipulation;
}
.mii-products__nav svg { display: block; width: 18px; height: 18px; stroke: currentColor; }
.mii-products__nav:hover { background: var(--mii-green-800); color: var(--mii-white); border-color: var(--mii-green-800); }
.mii-products__nav:active { transform: scale(0.92); }
.mii-products__nav:disabled { opacity: 0.35; cursor: not-allowed; }
.mii-products__nav--prev { order: -1; }

.mii-product-card {
  flex: 0 0 calc(16.666% - 15px); min-width: 170px; scroll-snap-align: start;
  background: var(--mii-product-card-bg); border: 1px solid rgba(232, 221, 202, 0.72);
  border-radius: var(--radius-md); overflow: hidden;
  transition: transform 250ms ease, box-shadow 250ms ease;
  box-shadow: 0 8px 22px rgba(26, 26, 26, 0.06);
}
.mii-product-card:hover { transform: translateY(-3px); box-shadow: 0 14px 30px rgba(26, 26, 26, 0.10); }
.mii-product-card__link { display: block; text-decoration: none; color: inherit; background: var(--mii-product-card-bg); }
.mii-product-card__thumb {
  position: relative;
  aspect-ratio: 1 / 1; background: var(--mii-product-card-bg);
  display: flex; align-items: center; justify-content: center; padding: var(--mii-product-image-pad); overflow: hidden;
}
.mii-product-card__thumb img {
  position: relative; z-index: 1; object-fit: contain; width: 100%; height: 100%;
  transition: transform 350ms ease; background: transparent; filter: var(--mii-product-image-shadow);
}
.mii-product-card__thumb img.miafrican-product-fallback-image,
.woocommerce ul.products li.product img.miafrican-product-fallback-image {
  object-fit: cover !important;
  border-radius: var(--radius-sm);
}
.mii-product-card:hover .mii-product-card__thumb img { transform: scale(1.05); }
.mii-product-card__info { padding: 14px; background: var(--mii-product-card-bg); }
.mii-product-card__title {
  font-family: var(--font-sans); font-size: 13px; font-weight: 600; line-height: 1.35;
  color: var(--mii-ink); margin: 0 0 6px; display: -webkit-box; -webkit-line-clamp: 2;
  -webkit-box-orient: vertical; overflow: hidden; min-height: 36px;
}
.mii-product-card__rating { display: flex; align-items: center; gap: 6px; margin-bottom: 6px; }
.mii-product-card__rating .mii-stars { color: var(--mii-gold); }
.mii-product-card__rating .mii-stars svg { width: 11px; height: 11px; }
.mii-product-card__count { font-size: 11px; color: #555555; }
.mii-product-card__price { font-size: 15px; font-weight: 700; color: var(--mii-green-800); }
.mii-product-card__price del { color: var(--mii-muted-light); font-weight: 500; margin-right: 5px; font-size: 13px; }
.mii-product-card__price ins { text-decoration: none; }

.mii-product-card__action { display: flex; gap: 8px; padding: 0 14px 14px; background: var(--mii-product-card-bg); }
.mii-product-card__action .button {
  flex: 1; min-height: 40px; padding: 8px 12px; font-size: 12px; font-weight: 600;
  border-radius: var(--radius-sm); background: var(--mii-green-800) !important;
  color: var(--mii-white) !important; border: none !important; text-align: center; justify-content: center;
  transition: background-color 200ms ease, transform 200ms ease, box-shadow 200ms ease;
  touch-action: manipulation;
}
.mii-product-card__action .button:hover { background: var(--mii-green-700) !important; transform: translateY(-1px); }
.mii-product-card__action .button:active { transform: translateY(0); }
.mii-product-card__wishlist {
  display: flex; align-items: center; justify-content: center; width: 40px; height: 40px;
  border-radius: var(--radius-sm); border: 1px solid var(--mii-border); color: var(--mii-muted);
  background: var(--mii-white); cursor: pointer; flex-shrink: 0;
  padding: 0;
  transition: border-color 200ms ease, color 200ms ease, background-color 200ms ease, transform 200ms ease;
  touch-action: manipulation;
}
.mii-product-card__wishlist[role="button"] { display: inline-flex; }
.mii-product-card__wishlist:hover { border-color: var(--mii-green-800); color: var(--mii-green-800); transform: translateY(-1px); }
.mii-product-card__wishlist:active { transform: translateY(0); }
.mii-product-card__wishlist.woosw-added,
.mii-product-card__wishlist.woosw-btn-added {
  color: #c62828;
  border-color: rgba(198, 40, 40, 0.28);
  background: #fff5f5;
}
.mii-product-card__wishlist.woosw-added svg,
.mii-product-card__wishlist.woosw-btn-added svg {
  fill: currentColor;
}
.mii-product-card__wishlist .woosw-btn-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* ----------------------------------------------------------
   12. Promo Banner
   ---------------------------------------------------------- */
.mii-promo { padding: 0 0 50px; }
.mii-promo__banner {
  position: relative;
  background:
    linear-gradient(90deg, rgba(13, 54, 34, 0.96) 0%, rgba(13, 54, 34, 0.9) 34%, rgba(13, 54, 34, 0.42) 64%, rgba(13, 54, 34, 0.16) 100%),
    url("../images/promo-banner.jpg") center right / cover no-repeat,
    linear-gradient(135deg, var(--mii-green-800) 0%, var(--mii-green-900) 100%);
  border-radius: var(--radius-lg); overflow: hidden; display: grid; grid-template-columns: 1fr 1fr;
  align-items: center; min-height: 200px;
}
.mii-promo__left {
  padding: 36px 40px; display: flex; align-items: center; gap: 20px;
}
.mii-promo__left-icon {
  display: flex; align-items: center; justify-content: center; width: 56px; height: 56px;
  border-radius: 50%; background: rgba(255,255,255,0.12); color: var(--mii-gold); flex-shrink: 0;
}
.mii-promo__left-icon svg { width: 28px; height: 28px; }
.mii-promo__label {
  display: block; font-size: 11px; font-weight: 700; letter-spacing: 0.15em; text-transform: uppercase;
  color: var(--mii-gold); margin-bottom: 6px;
}
.mii-promo__title {
  font-family: var(--font-serif); font-size: 28px; font-weight: 600; color: var(--mii-white);
  margin: 0 0 6px; line-height: 1.2;
}
.mii-promo__text { font-size: 13px; color: rgba(255,255,255,0.75); margin: 0 0 16px; }

.mii-promo__right {
  padding: 36px 40px; display: flex; align-items: center; justify-content: flex-end; gap: 24px;
}
.mii-promo__right-content { text-align: left; }
.mii-promo__right .mii-promo__title { font-size: 22px; margin-bottom: 14px; }
.mii-promo__code {
  display: inline-flex; align-items: center; gap: 8px;
  border: 1px solid rgba(255,255,255,0.25); border-radius: var(--radius-sm);
  padding: 8px 16px; font-size: 13px; color: var(--mii-white);
}
.mii-promo__code span { opacity: 0.7; }
.mii-promo__code strong { font-weight: 700; letter-spacing: 0.05em; }
.mii-promo__image { display: none; max-width: 160px; }
.mii-promo__image img { width: 100%; border-radius: var(--radius-md); }

/* ----------------------------------------------------------
   13. Testimonials
   ---------------------------------------------------------- */
.mii-testimonials__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.mii-testimonials__nav { display: flex; gap: 6px; }
.mii-testimonials__btn {
  display: flex; align-items: center; justify-content: center; width: 36px; height: 36px;
  min-width: 36px; max-width: 36px; min-height: 36px !important; padding: 0 !important; box-sizing: border-box;
  line-height: 1 !important;
  border-radius: 50%; background: var(--mii-white); border: 1px solid var(--mii-border);
  color: var(--mii-ink); cursor: pointer;
  transition: background-color 200ms ease, border-color 200ms ease, color 200ms ease, transform 200ms ease;
  touch-action: manipulation;
}
.mii-testimonials__btn svg { display: block; width: 16px; height: 16px; stroke: currentColor; }
.mii-testimonials__btn:hover { background: var(--mii-green-800); color: var(--mii-white); border-color: var(--mii-green-800); }
.mii-testimonials__btn:active { transform: scale(0.92); }

.mii-testimonial {
  background: var(--mii-white); border: 1px solid var(--mii-border-light);
  border-radius: var(--radius-md); padding: 22px;
  transition: transform 250ms ease, box-shadow 250ms ease;
}
.mii-testimonial:hover { transform: translateY(-2px); box-shadow: var(--shadow-lg); }
.mii-testimonial__stars { display: flex; gap: 2px; color: var(--mii-gold); margin-bottom: 12px; }
.mii-testimonial__stars svg { width: 13px; height: 13px; }
.mii-testimonial__text { margin: 0 0 18px; padding: 0; border: none; }
.mii-testimonial__text p { font-size: 13px; line-height: 1.65; color: #555555; margin: 0; }
.mii-testimonial__author { display: flex; align-items: center; gap: 10px; }
.mii-testimonial__avatar { width: 36px; height: 36px; border-radius: 50%; overflow: hidden; background: var(--mii-cream); }
.mii-testimonial__avatar img { width: 100%; height: 100%; object-fit: cover; }
.mii-testimonial__meta strong { font-size: 13px; font-weight: 600; color: var(--mii-ink); display: block; }
.mii-testimonial__meta span { font-size: 11px; color: var(--mii-muted); }

/* ----------------------------------------------------------
   14. Newsletter + Footer Overlap
   ---------------------------------------------------------- */
.mii-section--newsletter { background: var(--mii-cream); padding: 50px 0 0; }
.mii-newsletter {
  display: grid; grid-template-columns: 1fr auto; gap: 40px; align-items: center;
  background: var(--mii-white); border: 1px solid var(--mii-border-light);
  border-radius: var(--radius-lg); padding: 36px 40px;
  box-shadow: var(--shadow-md); margin-bottom: -50px; position: relative; z-index: 2;
}
.mii-newsletter__title { font-family: var(--font-serif); font-size: 24px; font-weight: 600; color: var(--mii-ink); margin: 0 0 6px; }
.mii-newsletter__text { font-size: 14px; color: var(--mii-muted); margin: 0 0 18px; max-width: 400px; }
.mii-newsletter__form { display: flex; gap: 10px; max-width: 400px; }
.mii-newsletter__form .mii-input { flex: 1; min-height: 44px; font-size: 14px; }
.mii-newsletter__form .mii-btn { flex-shrink: 0; min-height: 44px; }
.mii-newsletter__disclaimer { font-size: 11px; color: var(--mii-muted); margin: 10px 0 0; }
.mii-newsletter__image { max-width: 180px; }
.mii-newsletter__image img { width: 100%; }

/* ----------------------------------------------------------
   15. Footer
   ---------------------------------------------------------- */
.site-footer,
.footer-navigation,
.site-bottom-footer-wrap {
  background: var(--mii-green-800) !important; color: var(--mii-white) !important;
}
.site-footer { padding-top: 80px !important; }
.site-footer a,
.footer-navigation a { color: rgba(255,255,255,0.8) !important; font-weight: 400; font-size: 13px; }
.site-footer a:hover,
.footer-navigation a:hover { color: var(--mii-white) !important; }

.site-footer h2,
.site-footer h3,
.site-footer h4,
.site-footer .widget-title {
  color: var(--mii-white) !important; font-family: var(--font-sans); font-weight: 600;
  font-size: 14px; margin-bottom: 16px;
}

.site-bottom-footer-wrap {
  border-top: 1px solid rgba(255,255,255,0.1) !important; padding: 20px 0 !important;
}
.site-bottom-footer-wrap .mii-container {
  display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 12px;
}

.mii-footer-grid {
  display: grid; grid-template-columns: 1.4fr repeat(4, 1fr); gap: 32px; padding-bottom: 40px;
}
.mii-footer-brand p {
  font-size: 13px; line-height: 1.6; color: rgba(255,255,255,0.7); margin: 12px 0 16px; max-width: 260px;
}
.mii-footer-social { display: flex; gap: 10px; }
.mii-footer-social a {
  display: flex; align-items: center; justify-content: center; width: 32px; height: 32px;
  border-radius: 50%; background: rgba(255,255,255,0.1); color: var(--mii-white) !important;
  transition: background-color 200ms ease, transform 200ms ease;
}
.mii-footer-social a:hover { background: rgba(255,255,255,0.2); transform: translateY(-1px); }

.mii-footer-links { list-style: none; padding: 0; margin: 0; }
.mii-footer-links li { margin-bottom: 10px; }

.mii-footer-contact p,
.mii-footer-contact a { display: flex; align-items: center; gap: 8px; font-size: 13px; color: rgba(255,255,255,0.8) !important; margin: 0 0 10px; }
.mii-footer-contact svg { width: 14px; height: 14px; opacity: 0.7; }

.mii-footer-payments { display: flex; gap: 6px; flex-wrap: wrap; }
.mii-footer-payments img { height: 26px; width: auto; border-radius: 4px; }

.mii-footer-trust,
.mii-footer-trust * {
  box-sizing: border-box;
}
.mii-footer-trust {
  width: 100%;
  background: var(--mii-green-800);
  color: var(--mii-white);
  padding: 72px 0 18px;
  border-top: 1px solid rgba(255,255,255,0.12);
}
.mii-footer-trust .mii-container {
  max-width: 1240px;
}
.mii-footer-trust__grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
  align-items: center;
}
.mii-footer-trust__item {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 40px;
  padding: 8px 10px;
  border-radius: var(--radius-sm);
  color: rgba(255,255,255,0.84);
  font-size: 12px;
  font-weight: 600;
  line-height: 1.2;
  text-align: center;
  background: rgba(255,255,255,0.045);
}
.mii-footer-trust__item svg {
  width: 17px;
  height: 17px;
  flex: 0 0 17px;
  color: var(--mii-gold);
  stroke: currentColor;
}

/* Hide demo images in footer */
.site-footer img[src*="wordpressthemes.live"],
.site-footer .widget_media_image img[src*="wordpressthemes.live"] { display: none !important; }

.mii-custom-footer {
  padding: 54px 0 0 !important;
  background: var(--mii-green-800) !important;
  color: var(--mii-white) !important;
}
.mii-custom-footer__grid {
  display: grid;
  grid-template-columns: minmax(240px, 1.45fr) repeat(2, minmax(150px, 0.8fr)) minmax(220px, 1fr);
  gap: 32px;
  padding-bottom: 38px;
}
.mii-custom-footer__logo {
  display: inline-flex;
  flex-direction: column;
  gap: 2px;
  color: var(--mii-white) !important;
  font-family: var(--font-serif);
  font-size: 28px !important;
  font-weight: 700 !important;
  line-height: 1;
}
.mii-custom-footer__logo span {
  font-family: var(--font-sans);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.mii-custom-footer__brand p {
  max-width: 310px;
  margin: 14px 0 18px;
  color: rgba(255,255,255,0.72);
  font-size: 13px;
  line-height: 1.7;
}
.mii-custom-footer h2 {
  margin: 0 0 14px;
  color: var(--mii-white) !important;
  font-family: var(--font-sans);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.mii-custom-footer__nav,
.mii-custom-footer__contact {
  display: flex;
  flex-direction: column;
  gap: 9px;
}
.mii-custom-footer a,
.mii-custom-footer__contact span {
  color: rgba(255,255,255,0.74) !important;
  font-size: 13px !important;
}
.mii-custom-footer a:hover { color: var(--mii-white) !important; text-decoration: underline; }
.mii-custom-footer__contact p {
  display: grid;
  gap: 3px;
  margin: 0 0 5px;
}
.mii-custom-footer__contact strong {
  color: rgba(255,255,255,0.48);
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.mii-custom-footer__payments {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.mii-custom-footer__payments span {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 4px 8px;
  border-radius: 4px;
  background: rgba(255,255,255,0.1);
  color: rgba(255,255,255,0.86);
  font-size: 11px;
  font-weight: 700;
}
.mii-custom-footer__bottom {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: center;
  padding: 18px 0;
  border-top: 1px solid rgba(255,255,255,0.12);
}
.mii-custom-footer__bottom p {
  margin: 0;
  color: rgba(255,255,255,0.66);
  font-size: 12px;
}
.mii-custom-footer__bottom nav {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
}

/* Keep the required cookie notice from blocking product discovery. */
#cookie-popup.show-drawer .drawer-inner.float_right {
  inset: auto 16px 16px 16px !important;
  width: auto !important;
  max-width: calc(100vw - 32px) !important;
  min-height: 0 !important;
  border-radius: var(--radius-md) !important;
  background: var(--mii-image-surface-soft) !important;
  border: 1px solid rgba(232, 221, 202, 0.82);
  box-shadow: 0 16px 40px rgba(26, 26, 26, 0.13) !important;
  transform: none !important;
}
#cookie-popup .drawer-content {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 16px;
  padding: 14px 16px !important;
}
#cookie-popup .popup-container { min-width: 0; }
#cookie-popup .popup-title {
  margin: 0 0 2px !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  color: var(--mii-ink);
}
#cookie-popup p {
  margin: 0 !important;
  max-width: none;
  color: var(--mii-muted);
  font-size: 12px;
  line-height: 1.45;
}
#cookie-popup p:empty { display: none; }
#cookie-popup .popup-toggle-close {
  min-height: 40px;
  padding: 9px 18px !important;
  border-radius: var(--radius-full) !important;
  background: var(--mii-green-600) !important;
  color: var(--mii-white) !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  white-space: nowrap;
}

.welcome-popup { display: none !important; }

/* Replace the generic exit-intent portrait with African grocery campaign art. */
#exit-popup .drawer-inner {
  position: fixed !important;
  inset: 50% auto auto 50% !important;
  width: min(1150px, calc(100vw - 42px)) !important;
  max-width: min(1150px, calc(100vw - 42px));
  max-height: calc(100vh - 42px);
  border-radius: var(--radius-md);
  overflow: hidden;
  background: var(--mii-white);
  box-shadow: 0 24px 70px rgba(0, 0, 0, 0.28);
  transform: translate(-50%, -50%) !important;
}
#exit-popup.show-drawer,
#exit-popup.active {
  z-index: 100020 !important;
}
#exit-popup.show-drawer ~ #cookie-popup,
#exit-popup.active ~ #cookie-popup {
  display: none !important;
}
#exit-popup .drawer-header {
  position: absolute;
  inset: 16px 16px auto auto;
  z-index: 6;
}
#exit-popup .popup-toggle-close {
  color: var(--mii-ink) !important;
  background: rgba(255,255,255,0.88) !important;
  border-radius: var(--radius-full);
  box-shadow: 0 8px 20px rgba(0,0,0,0.12);
}
#exit-popup .elementor-element-1459db67 > .elementor-widget-wrap {
  position: relative;
  min-height: 590px;
  align-content: center;
  justify-content: center;
  overflow: hidden;
  background:
    linear-gradient(180deg, rgba(5, 35, 22, 0.18), rgba(5, 35, 22, 0.32)),
    radial-gradient(circle at 28% 30%, rgba(201, 162, 39, 0.22), transparent 34%),
    url("../images/exit-popup-african-grocery.jpg") center center / cover no-repeat !important;
}
#exit-popup .elementor-element-1459db67 > .elementor-widget-wrap::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(7, 33, 22, 0.72), rgba(7, 33, 22, 0.38) 46%, rgba(7, 33, 22, 0.62)),
    linear-gradient(180deg, rgba(0,0,0,0.08), rgba(0,0,0,0.34));
  pointer-events: none;
}
#exit-popup .elementor-element-1459db67 > .elementor-widget-wrap > .elementor-element {
  position: relative;
  z-index: 2;
}
#exit-popup .elementor-element-1459db67 .elementor-heading-title {
  color: var(--mii-white) !important;
  text-shadow: 0 2px 18px rgba(0,0,0,0.34);
}
#exit-popup .elementor-element-1459db67 .elementor-element-7446de38 .elementor-heading-title {
  max-width: 420px;
  margin: 0 auto;
  font-family: var(--font-serif);
  font-size: clamp(30px, 3.3vw, 42px);
  line-height: 1.08;
  font-weight: 700;
}
#exit-popup .elementor-element-1459db67 .elementor-element-1118f9 .elementor-heading-title,
#exit-popup .elementor-element-1459db67 .elementor-element-140bd68 .elementor-heading-title {
  max-width: 370px;
  margin-left: auto;
  margin-right: auto;
  font-size: 15px;
  line-height: 1.65;
  color: rgba(255,255,255,0.88) !important;
}
#exit-popup .code-discount .input_wrap input.code-only {
  min-width: 230px;
  height: 48px;
  border: 1px solid rgba(255,255,255,0.38);
  border-radius: var(--radius-sm);
  background: rgba(255,255,255,0.92);
  color: var(--mii-green-900);
  font-size: 16px;
  font-weight: 800;
  letter-spacing: 0.05em;
  text-align: center;
  box-shadow: 0 12px 24px rgba(0,0,0,0.18);
}
#exit-popup .elementor-element-22e747e2 .elementor-button {
  min-width: 146px;
  min-height: 48px;
  border-radius: var(--radius-full);
  background: var(--mii-green-600) !important;
  color: var(--mii-white) !important;
  box-shadow: 0 14px 24px rgba(0,0,0,0.22);
}
#exit-popup .elementor-element-22e747e2 .elementor-button:hover {
  background: var(--mii-green-700) !important;
  transform: translateY(-1px);
}
#exit-popup .elementor-element-7074f480 > .elementor-widget-wrap {
  background: var(--mii-white);
  min-height: 590px;
  overflow-y: auto;
}

/* ----------------------------------------------------------
   16. WooCommerce Global
   ---------------------------------------------------------- */
.woocommerce .products, ul.products { row-gap: 20px !important; }
.woocommerce ul.products li.product,
.woocommerce .products .product {
  border: 1px solid var(--mii-border-light) !important; border-radius: var(--radius-md) !important;
  background: var(--mii-product-card-bg) !important; overflow: hidden; box-shadow: var(--shadow-sm);
  transition: transform 250ms ease, box-shadow 250ms ease;
}
.woocommerce ul.products li.product:hover,
.woocommerce .products .product:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); }
.woocommerce ul.products li.product:active,
.woocommerce .products .product:active { transform: translateY(0); }
.woocommerce ul.products li.product .product-thumbnail {
  position: relative;
  background: var(--mii-product-card-bg); aspect-ratio: 1 / 1;
  display: flex; align-items: center; justify-content: center; padding: var(--mii-product-image-pad); overflow: hidden;
}
.woocommerce ul.products li.product .product-thumbnail a,
.woocommerce ul.products li.product .product-thumbnail img {
  position: relative; z-index: 1;
}
.woocommerce ul.products li.product img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  background: transparent;
  filter: var(--mii-product-image-shadow);
}
.woocommerce ul.products li.product .product-details,
.woocommerce ul.products li.product .entry-content-wrap {
  min-height: auto; padding: 14px !important; background: var(--mii-product-card-bg) !important;
}

.woocommerce-loop-product__title,
.woocommerce-loop-product__title a { font-family: var(--font-sans) !important; font-size: 13px !important; font-weight: 600 !important; line-height: 1.35 !important; color: var(--mii-ink) !important; }
.woocommerce ul.products li.product .price { color: var(--mii-green-800) !important; font-weight: 700 !important; font-size: 15px; }

.star-rating-block, .product-actions, .woosc-btn, .woosq-btn,
.woosc-area, .woosw-popup, .compare, .wishlist { display: none !important; }

.woocommerce ul.products li.product .mii-loop-product-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 10px;
}
.woocommerce ul.products li.product .mii-loop-product-actions > .button {
  flex: 1;
  min-width: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.woocommerce ul.products li.product .mii-loop-product-actions .mii-product-card__wishlist {
  display: inline-flex !important;
}

.woocommerce a.button, .woocommerce button.button, .woocommerce input.button,
.woocommerce #respond input#submit, .single_add_to_cart_button, .checkout-button {
  min-height: 44px; border-radius: var(--radius-sm) !important;
  background: var(--mii-green-800) !important; color: var(--mii-white) !important;
  font-family: var(--font-sans) !important; font-weight: 600 !important; font-size: 13px !important;
  border: none !important; box-shadow: none !important;
  transition: background-color 200ms ease, transform 200ms ease, box-shadow 200ms ease;
  touch-action: manipulation;
}
.woocommerce a.button:hover, .woocommerce button.button:hover,
.single_add_to_cart_button:hover, .checkout-button:hover { background: var(--mii-green-700) !important; transform: translateY(-1px); box-shadow: var(--shadow-md); }
.woocommerce a.button:active, .woocommerce button.button:active,
.single_add_to_cart_button:active, .checkout-button:active { transform: translateY(0); }

/* Loading state for AJAX add to cart buttons */
.woocommerce a.button.loading,
.mii-product-card__action .button.loading {
  position: relative; color: transparent !important; pointer-events: none;
}
.woocommerce a.button.loading::after,
.mii-product-card__action .button.loading::after {
  content: "";
  position: absolute; inset: 0; margin: auto;
  width: 18px; height: 18px;
  border: 2px solid rgba(255,255,255,0.25);
  border-top-color: var(--mii-white);
  border-radius: 50%;
  animation: mii-spin 600ms linear infinite;
}
@keyframes mii-spin { to { transform: rotate(360deg); } }
@media (prefers-reduced-motion: reduce) {
  .woocommerce a.button.loading::after,
  .mii-product-card__action .button.loading::after { animation: none; border-color: rgba(255,255,255,0.6); }
}

.woocommerce-products-header, .entry-hero, .archive .page-title-wrap {
  background: var(--mii-green-800) !important;
  padding: 18px 0 !important;
  min-height: 0 !important;
}
.woocommerce-products-header__title, .page-title {
  font-family: var(--font-sans); letter-spacing: 0; color: var(--mii-white) !important; font-weight: 600;
  font-size: 20px !important; margin: 0 !important;
}
.entry-hero .breadcrumbs, .archive .page-title-wrap .breadcrumbs {
  display: block !important;
  color: rgba(255,255,255,0.9) !important;
}
.entry-hero .breadcrumbs a, .archive .page-title-wrap .breadcrumbs a {
  color: rgba(255,255,255,0.9) !important;
}
.entry-hero .breadcrumbs a:hover, .archive .page-title-wrap .breadcrumbs a:hover {
  color: var(--mii-white) !important;
}
.product_title {
  font-family: var(--font-serif); letter-spacing: 0; color: var(--mii-ink); font-weight: 600;
}

/* ----------------------------------------------------------
   17. Single Product
   ---------------------------------------------------------- */
.single-product .summary-sidebar, .single-product .check-incart-sold,
.single-product .tmcore-live-viewing-visitors, .single-product .wrap_ask_share,
.single-product .single-product-extras, .single-product .product-page-cms-service,
.single-product .recently-viewed, .single-product .related > h2:first-child { display: none !important; }
.single-product .base-product-image-wrap {
  background: var(--mii-product-card-bg); border: 1px solid var(--mii-border); border-radius: var(--radius-lg); padding: 18px;
}
.single-product .woocommerce-product-gallery,
.single-product .woocommerce-product-gallery__wrapper,
.single-product .woocommerce-product-gallery__image {
  background: var(--mii-product-card-bg) !important;
}
.single-product .woocommerce-product-gallery__image {
  display: flex !important;
  align-items: center;
  justify-content: center;
  padding: var(--mii-product-image-pad);
}
.single-product .woocommerce-product-gallery__image a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
}
.single-product .woocommerce-product-gallery__image img {
  width: 100%;
  height: auto;
  max-height: min(620px, 70vh);
  object-fit: contain;
  background: transparent;
  filter: var(--mii-product-image-shadow);
}
.single-product .summary.entry-summary {
  background: var(--mii-white); border: 1px solid var(--mii-border); border-radius: var(--radius-lg);
  padding: clamp(22px, 3vw, 36px) !important;
}
.single-product .product_title { font-family: var(--font-serif); font-size: clamp(28px, 3.5vw, 44px); line-height: 1.1; }
.single-product .woocommerce-product-details__short-description { color: var(--mii-muted); font-size: 15px; line-height: 1.65; }
.mii-product-trust-msg {
  display: flex; align-items: flex-start; gap: 10px; margin-top: 18px; padding: 14px 16px;
  border: 1px solid rgba(61, 155, 95, 0.18); border-radius: var(--radius-md);
  background: #edf7f0; color: var(--mii-green-800); font-size: 13px; font-weight: 500; line-height: 1.5;
}
.mii-product-trust-msg svg { flex-shrink: 0; margin-top: 2px; }
.mii-product-trust-msg a { color: var(--mii-green-800); text-decoration: underline; font-weight: 600; }
.mii-product-trust-msg a:hover { color: var(--mii-green-600); }

/* ----------------------------------------------------------
   18. Cart & Checkout
   ---------------------------------------------------------- */
.woocommerce-cart .checkout-cms-service, .woocommerce-cart .cart-testimonial,
.woocommerce-cart .elementor-widget-tmcore-testimonials { display: none !important; }
.woocommerce-cart .base-woo-cart-form-wrap, .woocommerce-checkout form.checkout {
  background: var(--mii-white); border: 1px solid var(--mii-border); border-radius: var(--radius-lg);
  padding: clamp(18px, 3vw, 30px); box-shadow: var(--shadow-sm);
}
.woocommerce-cart .cart_totals, .woocommerce-checkout-review-order {
  border: 1px solid var(--mii-border) !important; border-radius: var(--radius-lg) !important;
  background: var(--mii-white) !important; box-shadow: var(--shadow-sm);
}
.woocommerce form .form-row label { color: var(--mii-ink); font-weight: 600; font-size: 13px; margin-bottom: 6px; }
.woocommerce form .form-row input.input-text, .woocommerce form .form-row textarea,
.woocommerce form .form-row select, .select2-container .select2-selection--single {
  min-height: 46px; border-radius: var(--radius-sm) !important; border: 1.5px solid var(--mii-border) !important;
  background: var(--mii-white) !important; font-family: var(--font-sans);
  transition: border-color 200ms, box-shadow 200ms;
}
.woocommerce form .form-row input.input-text:focus, .woocommerce form .form-row textarea:focus {
  border-color: var(--mii-green-500) !important; box-shadow: 0 0 0 3px rgba(61, 155, 95, 0.1);
}
.woocommerce-error, .woocommerce-info, .woocommerce-message {
  border-radius: var(--radius-md); border-top: 0 !important;
  background: #edf7f0 !important; color: var(--mii-ink) !important; font-weight: 500;
}

.mii-cart-empty { text-align: center; padding: clamp(36px, 5vw, 64px) 20px; }
.mii-cart-empty__icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 72px; height: 72px; border-radius: 50%; background: var(--mii-cream); color: var(--mii-muted); margin-bottom: 20px;
}
.mii-cart-empty__title { font-family: var(--font-serif); font-size: 22px; font-weight: 600; color: var(--mii-ink); margin: 0 0 6px; }
.mii-cart-empty__text { font-size: 14px; color: var(--mii-muted); max-width: 340px; margin: 0 auto 20px; }

.mii-checkout-trust { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 20px; padding: 14px 16px;
  background: var(--mii-cream); border-radius: var(--radius-md);
}
.mii-checkout-trust__item { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; font-weight: 600; color: var(--mii-green-800); }

.woocommerce-checkout .elementor-791 .elementor-element-8662aa0 {
  margin: 14px 0 10px !important;
}
.woocommerce-checkout .elementor-791 .elementor-element-8662aa0 .elementor-container,
.woocommerce-checkout .elementor-791 .elementor-element-8662aa0 .elementor-column,
.woocommerce-checkout .elementor-791 .elementor-element-8662aa0 .elementor-widget-wrap {
  width: 100% !important;
  max-width: 100% !important;
}
.woocommerce-checkout .elementor-791 .elementor-element-e946e54 {
  width: 100%;
  margin: 0 !important;
  padding: 10px 12px;
  border: 1px solid var(--mii-border-light);
  border-radius: var(--radius-md);
  background: var(--mii-white);
}
.woocommerce-checkout .elementor-791 .elementor-element-e946e54 .elementor-widget-container {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
}
.woocommerce-checkout .elementor-791 .elementor-element-e946e54 img {
  content: url("/wp-content/themes/avanam-wooti/assets/images/checkout-trust-badges-aligned.png");
  display: block;
  width: 100%;
  max-width: 560px;
  height: auto;
  max-height: 52px;
  margin: 0 auto;
  object-fit: contain;
}

/* ----------------------------------------------------------
   19. Review Prompt
   ---------------------------------------------------------- */
.mii-review-prompt { margin: 18px 0; padding: 14px 16px; border: 1px dashed var(--mii-border);
  border-radius: var(--radius-md); background: var(--mii-cream);
}
.mii-review-prompt p { margin: 0; font-size: 13px; }
.mii-review-prompt p + p { margin-top: 4px; color: var(--mii-muted); }

/* ----------------------------------------------------------
   20. Legacy Cleanup
   ---------------------------------------------------------- */
.home .elementor-element-f130e58, .home .elementor-element-0f456b5, .home .elementor-element-ac013e0,
.home .elementor-element-84bb9f7, .home .elementor-element-0f36c9a, .home .elementor-element-3c4610d,
.home .elementor-element-fe88615, .home .elementor-element-5b2611d, .home .cms-banner-block,
.home .cart-testimonial, .home .mc4wp-form, .home .mc4wp-response, .home .mc4wp-alert,
.site-top-footer-wrap, .site-middle-footer-wrap, .widget_mc4wp_form_widget { display: none !important; }
.home .elementor-element-278ae7e, .home .product-list-item { display: none !important; }

/* ----------------------------------------------------------
   21. Responsive
   ---------------------------------------------------------- */
@media (min-width: 1025px) {
  .woocommerce-checkout #order_review, .woocommerce-cart .cart-collaterals { position: sticky; top: 24px; align-self: start; }
}

@media (max-width: 1024px) {
  .mii-hero__grid { grid-template-columns: 1fr; text-align: center; }
  .mii-hero__sub { margin-left: auto; margin-right: auto; }
  .mii-hero__actions { justify-content: center; }
  .mii-hero__social-proof { justify-content: center; }
  .mii-hero__media { order: -1; max-width: 720px; margin: 0 auto; }
  .mii-trust-bar__grid { flex-wrap: wrap; }
  .mii-trust-bar__item { flex: 1 1 calc(33% - 12px); }
  .mii-cat-grid { grid-template-columns: repeat(3, 1fr); }
  .mii-product-card { flex: 0 0 calc(25% - 14px); }
  .mii-testimonials__grid { grid-template-columns: repeat(2, 1fr); }
  .mii-promo__banner { grid-template-columns: 1fr; }
  .mii-newsletter { grid-template-columns: 1fr; text-align: center; }
  .mii-newsletter__form { margin: 0 auto; }
  .mii-newsletter__image { display: none; }
  .mii-footer-grid { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 767px) {
  .site-branding img.custom-logo { max-width: 130px; }
  .mii-hero { padding: 36px 0; }
  .mii-hero__title { font-size: 32px; }
  .mii-hero__frame { aspect-ratio: 4 / 3; }
  .mii-hero__actions { flex-direction: column; }
  .mii-hero__actions .mii-btn { width: 100%; }
  .mii-trust-bar__item { flex: 1 1 calc(50% - 8px); }
  .mii-cat-grid { grid-template-columns: repeat(2, 1fr); }
  .mii-product-card { flex: 0 0 calc(50% - 9px); min-width: 140px; }
  .mii-products__nav { display: none; }
  .mii-testimonials__grid { grid-template-columns: 1fr; }
  .mii-testimonials__nav { display: none; }
  .mii-footer-grid { grid-template-columns: 1fr 1fr; }
  .woocommerce ul.products.columns-4, .woocommerce ul.products.columns-3, .woocommerce-page ul.products {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important; gap: 12px !important;
  }
  .woocommerce-loop-product__title { font-size: 12px !important; }
  .woocommerce ul.products li.product .price { font-size: 14px; }
  .single-product .product_title { font-size: 26px; }
  .single-product .summary.entry-summary, .single-product .base-product-image-wrap { padding: 14px !important; }
  .mii-newsletter__form { flex-direction: column; }
  .mii-newsletter__form .mii-btn { width: 100%; }
  .woocommerce-cart table.cart td.actions .coupon, .woocommerce-cart table.cart td.actions .coupon input,
  .woocommerce-cart table.cart td.actions .button { width: 100% !important; margin: 0 0 8px !important; }
  .woocommerce-checkout .elementor-791 .elementor-element-e946e54 {
    padding: 8px;
  }
  .woocommerce-checkout .elementor-791 .elementor-element-e946e54 img {
    width: 100%;
    max-width: 300px;
    max-height: 44px;
  }
  /* Prevent iOS zoom on input focus */
  input, select, textarea, .header-search-advanced input.search-field { font-size: 16px !important; }
  .mii-btn { font-size: 16px; }
}

@media (max-width: 480px) {
  .mii-cat-grid { grid-template-columns: 1fr; }
  .mii-product-card { flex: 0 0 75%; }
  .mii-footer-grid { grid-template-columns: 1fr; }
}

/* ----------------------------------------------------------
   22. Sticky Header
   ---------------------------------------------------------- */
.site-header-row-container,
.site-main-header-wrap {
  position: sticky !important;
  top: 0 !important;
  z-index: 999 !important;
  transition: box-shadow 250ms ease;
}
@media (prefers-reduced-motion: reduce) {
  .site-header-row-container, .site-main-header-wrap { transition: none; }
}
.mii-header-scrolled .site-main-header-wrap,
.mii-header-scrolled .site-header-row-container {
  box-shadow: 0 2px 16px rgba(26,26,26,0.09) !important;
}

/* ----------------------------------------------------------
   23. Breadcrumbs
   ---------------------------------------------------------- */
.woocommerce-breadcrumb,
.base-breadcrumb,
.rank-math-breadcrumb {
  font-size: 13px !important;
  color: var(--mii-muted) !important;
  margin: 12px 0 0 !important;
  padding: 0 !important;
  background: none !important;
}
.woocommerce-breadcrumb a,
.base-breadcrumb a,
.rank-math-breadcrumb a {
  color: var(--mii-muted) !important;
  font-weight: 500;
}
.woocommerce-breadcrumb a:hover,
.base-breadcrumb a:hover { color: var(--mii-green-800) !important; }
.woocommerce-breadcrumb .separator,
.base-breadcrumb .separator { color: var(--mii-gold) !important; opacity: 0.7; }

/* ----------------------------------------------------------
   24. Back to Top Button
   ---------------------------------------------------------- */
#mii-back-to-top {
  position: fixed;
  bottom: 28px;
  right: 24px;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--mii-green-800);
  color: var(--mii-white);
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 16px rgba(26,60,43,0.25);
  opacity: 0;
  visibility: hidden;
  transform: translateY(16px);
  transition: opacity 300ms ease, transform 300ms ease, visibility 300ms ease;
  z-index: 998;
  pointer-events: none;
  touch-action: manipulation;
}
#mii-back-to-top.mii-btt-visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: all;
}
#mii-back-to-top:hover { background: var(--mii-green-700); }
#mii-back-to-top:active { transform: translateY(0) scale(0.96); }
#mii-back-to-top svg { width: 20px; height: 20px; }

/* ----------------------------------------------------------
   25. Mobile Sticky Checkout Bar
   ---------------------------------------------------------- */
#mii-sticky-checkout {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 997;
  background: var(--mii-white);
  border-top: 1px solid var(--mii-border);
  padding: 12px 16px;
  box-shadow: 0 -4px 20px rgba(26,26,26,0.10);
  align-items: center;
  gap: 12px;
}
.woocommerce-cart #mii-sticky-checkout { display: flex; }
#mii-sticky-checkout .mii-sticky-checkout__total {
  flex: 1;
  font-size: 14px;
  font-weight: 700;
  color: var(--mii-ink);
}
#mii-sticky-checkout .mii-sticky-checkout__total span {
  display: block;
  font-size: 11px;
  font-weight: 400;
  color: var(--mii-muted);
}
#mii-sticky-checkout .mii-btn {
  flex-shrink: 0;
  min-height: 46px;
  padding: 10px 20px;
  font-size: 14px;
}
@media (min-width: 768px) {
  #mii-sticky-checkout { display: none !important; }
}

/* ----------------------------------------------------------
   26. Mini-Cart Polish
   ---------------------------------------------------------- */
.widget_shopping_cart_content .woocommerce-mini-cart__empty-message { padding: 20px; text-align: center; color: var(--mii-muted); }
.widget_shopping_cart_content .woocommerce-mini-cart-item { padding: 12px 0; border-bottom: 1px solid var(--mii-border-light); }
.widget_shopping_cart_content .cart_list { padding: 0 16px; }
.widget_shopping_cart_content .mini_cart_item img {
  border-radius: var(--radius-sm) !important;
  border: 0 !important;
  background: var(--mii-product-card-bg);
  object-fit: contain;
  filter: var(--mii-product-image-shadow);
}
.mii-mini-cart-shipping-bar { padding: 12px 16px; background: var(--mii-cream); border-top: 1px solid var(--mii-border-light); }
.mii-mini-cart-shipping-bar__label { font-size: 12px; font-weight: 600; color: var(--mii-green-800); margin-bottom: 6px; }
.mii-mini-cart-shipping-bar__track { height: 5px; background: var(--mii-border); border-radius: 99px; overflow: hidden; }
.mii-mini-cart-shipping-bar__fill { height: 100%; background: var(--mii-green-600); border-radius: 99px; transition: width 500ms ease; }
.mii-mini-cart-trust { padding: 10px 16px; font-size: 11px; font-weight: 500; color: var(--mii-muted); text-align: center; border-top: 1px solid var(--mii-border-light); }
.mii-mini-cart-trust svg { display: inline-block; vertical-align: middle; margin-right: 4px; color: var(--mii-green-800); }
.widget_shopping_cart_content .woocommerce-mini-cart__total {
  padding: 12px 16px !important;
  border-top: 1px solid var(--mii-border) !important;
  font-weight: 700 !important;
}
.widget_shopping_cart_content .woocommerce-mini-cart__buttons { padding: 0 16px 16px !important; display: flex !important; flex-direction: column !important; gap: 8px; }
.widget_shopping_cart_content .woocommerce-mini-cart__buttons a { text-align: center !important; }

/* ----------------------------------------------------------
   27. Shop Sort Dropdown & Filter Polish
   ---------------------------------------------------------- */
.woocommerce-ordering select,
.woocommerce .woocommerce-ordering select {
  border: 1.5px solid var(--mii-border) !important;
  border-radius: var(--radius-sm) !important;
  padding: 8px 36px 8px 12px !important;
  font-family: var(--font-sans) !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  color: var(--mii-ink) !important;
  background: var(--mii-white) !important;
  min-height: 40px;
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 12px center !important;
  cursor: pointer;
}

/* ----------------------------------------------------------
   28. Category Card Count
   ---------------------------------------------------------- */
.mii-cat-card__count {
  display: block;
  font-size: 11px;
  color: var(--mii-muted);
  font-weight: 400;
  margin-top: 2px;
}
.mii-cat-card__name {
  font-family: var(--font-sans); font-size: 13px; font-weight: 600; color: var(--mii-ink);
  text-align: center; padding: 12px 14px 14px; margin: 0; line-height: 1.3;
  background: var(--mii-image-surface-soft);
}

/* ----------------------------------------------------------
   29. Low-Stock Badge
   ---------------------------------------------------------- */
.mii-badge--low-stock {
  display: inline-block;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: #b45309;
  background: #fef3c7;
  border: 1px solid #fde68a;
  border-radius: var(--radius-sm);
  padding: 2px 7px;
  margin-bottom: 6px;
  line-height: 1.4;
}

/* ----------------------------------------------------------
   30. Archive Product Image Surface
   ---------------------------------------------------------- */
body.woocommerce-page main#main ul.products.content-wrap li.product.entry.content-bg,
body.woocommerce-page main.site-main ul.products.content-wrap li.product.entry.content-bg {
  background: var(--mii-product-card-bg) !important;
  background-color: var(--mii-product-card-bg) !important;
}

body.woocommerce-page main#main ul.products.content-wrap li.product.entry.content-bg > .product-thumbnail,
body.woocommerce-page main.site-main ul.products.content-wrap li.product.entry.content-bg > .product-thumbnail {
  position: relative !important;
  background: var(--mii-product-card-bg) !important;
  background-color: var(--mii-product-card-bg) !important;
  overflow: hidden !important;
}

body.woocommerce-page main#main ul.products.content-wrap li.product.entry.content-bg > .product-thumbnail::after,
body.woocommerce-page main.site-main ul.products.content-wrap li.product.entry.content-bg > .product-thumbnail::after {
  content: none !important;
}

body.woocommerce-page main#main ul.products.content-wrap li.product.entry.content-bg > .product-thumbnail a,
body.woocommerce-page main#main ul.products.content-wrap li.product.entry.content-bg > .product-thumbnail img,
body.woocommerce-page main.site-main ul.products.content-wrap li.product.entry.content-bg > .product-thumbnail a,
body.woocommerce-page main.site-main ul.products.content-wrap li.product.entry.content-bg > .product-thumbnail img {
  position: relative !important;
  z-index: 1 !important;
}

body.woocommerce-page main#main ul.products.content-wrap li.product.entry.content-bg .entry-content-wrap,
body.woocommerce-page main.site-main ul.products.content-wrap li.product.entry.content-bg .entry-content-wrap {
  background: var(--mii-product-card-bg) !important;
  background-color: var(--mii-product-card-bg) !important;
}

/* ----------------------------------------------------------
   30. Product Page Improvements
   ---------------------------------------------------------- */
.mii-review-prompt a.mii-review-link {
  display: inline-block;
  margin-top: 8px;
  font-size: 13px;
  font-weight: 600;
  color: var(--mii-green-800);
  text-decoration: underline;
}
.mii-review-prompt a.mii-review-link:hover { color: var(--mii-green-600); }

/* ----------------------------------------------------------
   31. Mobile Hero Spacing Fix
   ---------------------------------------------------------- */
@media (max-width: 1024px) {
  .mii-hero {
    background: var(--mii-hero-surface);
  }
  .mii-hero__content { padding-top: 20px; }
  .mii-hero__frame {
    box-shadow: none;
    border-radius: 0;
  }
  .mii-footer-trust__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .mii-custom-footer__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .mii-custom-footer__bottom {
    align-items: flex-start;
    flex-direction: column;
  }
}

@media (max-width: 600px) {
  .mii-custom-footer { padding-top: 40px !important; }
  .mii-custom-footer__grid {
    grid-template-columns: 1fr;
    gap: 24px;
  }
  .mii-custom-footer__bottom nav {
    gap: 10px 14px;
  }
  .mii-footer-trust__grid {
    grid-template-columns: 1fr;
  }
  .mii-footer-trust__item {
    justify-content: flex-start;
    text-align: left;
  }
  #cookie-popup.show-drawer .drawer-inner.float_right {
    inset: auto 10px 10px 10px !important;
    max-width: calc(100vw - 20px) !important;
  }
  #cookie-popup .drawer-content {
    grid-template-columns: 1fr;
    gap: 10px;
  }
  #cookie-popup .popup-toggle-close {
    width: 100%;
  }
  #exit-popup .drawer-inner {
    max-width: calc(100vw - 20px);
  }
  #exit-popup .elementor-container {
    flex-direction: column;
  }
  #exit-popup .elementor-column {
    width: 100% !important;
  }
  #exit-popup .elementor-element-1459db67 > .elementor-widget-wrap {
    min-height: 360px;
    padding: 38px 20px !important;
  }
}

/* ----------------------------------------------------------
    32. Copyright / Watermark Override
    ---------------------------------------------------------- */
.site-bottom-footer-wrap .site-info a[href*="avanam"],
.site-bottom-footer-wrap .site-info a[href*="wordpress.org"] { display: none !important; }

/* ----------------------------------------------------------
    33. Reduced Motion
    ---------------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .mii-btn, .mii-products__nav, .mii-testimonials__btn, .mii-cat-card, .mii-product-card,
  .mii-testimonial, .mii-footer-social a, .woocommerce ul.products li.product, .woocommerce .products .product,
  .mii-product-card__action .button, .mii-product-card__wishlist, #mii-back-to-top,
  .woocommerce a.button, .woocommerce button.button, .woocommerce input.button,
  .woocommerce #respond input#submit, .single_add_to_cart_button, .checkout-button {
    transition: none !important;
    animation: none !important;
  }
  .mii-btn:hover, .mii-products__nav:hover, .mii-cat-card:hover, .mii-product-card:hover,
  .mii-testimonial:hover, .woocommerce ul.products li.product:hover, .woocommerce .products .product:hover {
    transform: none !important;
  }
}

/* ----------------------------------------------------------
    34. High Contrast / Forced Colors Support
    ---------------------------------------------------------- */
@media (prefers-contrast: more) {
  .mii-btn { border-width: 2px; }
  .mii-product-card, .mii-cat-card, .mii-testimonial { border-width: 2px; }
  *:focus-visible { outline-width: 3px; outline-offset: 3px; }
}

/* ----------------------------------------------------------
    35. Print Styles
    ---------------------------------------------------------- */
@media print {
  #mii-back-to-top, #mii-sticky-checkout, .mii-products__nav, .mii-testimonials__nav,
  .site-header-row-container, .site-main-header-wrap, .mii-footer-trust { display: none !important; }
  .mii-hero { background: var(--mii-white) !important; }
  a { text-decoration: underline; }
}
