/* =============================================================================
   Mega Navi Foo — Frontend Styles  v1.0.1
   All rules scoped to #mnf-header / .mnf-* to avoid theme conflicts.
   Critical layout rules use !important to override Divi/other theme CSS.
   ============================================================================= */

/* ── CSS Variables ──
   --mnf-primary and --mnf-primary-rgb are injected dynamically by PHP
   via wp_add_inline_style so the saved admin colour always wins.
   All other vars are static. ── */
:root {
  --mnf-primary:     #7B5EA7; /* fallback only — overridden by inline style */
  --mnf-primary-rgb: 123, 94, 167; /* fallback only */
  --mnf-text:        #333333;
  --mnf-text-light:  #777777;
  --mnf-border:      #eeeeee;
  --mnf-bg:          #ffffff;
  --mnf-drawer-w:    340px;
  --mnf-topbar-h:    76px;
  --mnf-mob-h:       60px;
  --mnf-transition:  0.28s cubic-bezier(0.4, 0, 0.2, 1);
  --mnf-shadow:      0 4px 24px rgba(0,0,0,0.09);
  --mnf-radius:      6px;
  --mnf-z-header:    9000;
  --mnf-z-drawer:    9200;
  --mnf-z-overlay:   9100;
}

/* ── Scoped reset ── */
#mnf-header,
#mnf-header *,
#mnf-header *::before,
#mnf-header *::after,
.mnf-overlay,
.mnf-drawer,
.mnf-search-drawer,
.mnf-cart-drawer,
.mnf-drawer *,
.mnf-search-drawer *,
.mnf-cart-drawer * {
  box-sizing: border-box !important;
}

/* ── Container ── */
.mnf-container {
  width: 100% !important;
  max-width: 1320px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 24px !important;
  padding-right: 24px !important;
}

/* =============================================================================
   1. Announcement Bar
   ============================================================================= */
.mnf-announcement {
  background: var(--mnf-primary) !important;
  height: 36px !important;
  overflow: hidden !important;
  display: flex !important;
  align-items: center !important;
}

.mnf-announcement__track {
  display: flex !important;
  align-items: center !important;
  height: 100% !important;
  white-space: nowrap !important;
  animation: mnf-marquee 35s linear infinite !important;
  will-change: transform;
}

.mnf-announcement__track span {
  display: inline-flex !important;
  align-items: center !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  color: #ffffff !important;
  letter-spacing: 0.02em !important;
  padding: 0 40px !important;
}

/* bullet separator after each copy */
.mnf-announcement__track span::after {
  content: "•";
  padding-left: 40px;
  opacity: 0.5;
}

@keyframes mnf-marquee {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* =============================================================================
   2. Header wrapper
   ============================================================================= */
#mnf-header {
  position: sticky !important;
  top: 0 !important;
  z-index: var(--mnf-z-header) !important;
  background: var(--mnf-bg) !important;
  box-shadow: 0 2px 16px rgba(0,0,0,0.08) !important;
  width: 100% !important;
  left: 0 !important;
  right: 0 !important;
}

/* =============================================================================
   3. Top bar (logo / search / actions row)
   ============================================================================= */
.mnf-topbar {
  background: var(--mnf-bg) !important;
  border-bottom: 1px solid var(--mnf-border) !important;
}

.mnf-topbar__inner {
  display: flex !important;
  align-items: center !important;
  height: var(--mnf-topbar-h) !important;
  gap: 20px !important;
}

/* =============================================================================
   4. Logo
   ============================================================================= */
.mnf-logo {
  display: inline-flex !important;
  align-items: center !important;
  flex-shrink: 0 !important;
  text-decoration: none !important;
}

.mnf-logo img {
  display: block !important;
  height: auto !important;
  max-height: 52px !important;
  object-fit: contain !important;
}

.mnf-logo__text {
  font-size: 22px !important;
  font-weight: 800 !important;
  color: var(--mnf-primary) !important;
  letter-spacing: -0.03em !important;
  line-height: 1 !important;
  text-decoration: none !important;
}

/* =============================================================================
   5. Desktop search bar — inline dropdown style
   ============================================================================= */
.mnf-searchbar {
  flex: 1 !important;
  max-width: 560px !important;
  margin: 0 auto !important;
  position: relative !important;
  z-index: 50 !important; /* ensures dropdown floats above nav bar */
}

.mnf-searchbar__form {
  display: flex !important;
  align-items: center !important;
  width: 100% !important;
  height: 48px !important;
  background: #f6f6f8 !important;
  border: 1.5px solid #e2e2e8 !important;
  border-radius: 30px !important;
  overflow: hidden !important;
  transition: border-color var(--mnf-transition), box-shadow var(--mnf-transition), background var(--mnf-transition) !important;
  position: relative !important;
  z-index: 2 !important;
}

.mnf-searchbar__form:focus-within {
  border-color: var(--mnf-primary) !important;
  box-shadow: 0 0 0 3px rgba(var(--mnf-primary-rgb), 0.12) !important;
  background: #fff !important;
}

.mnf-searchbar__input {
  flex: 1 !important;
  height: 100% !important;
  border: none !important;
  background: transparent !important;
  padding: 0 16px !important;
  font-size: 14px !important;
  color: var(--mnf-text) !important;
  outline: none !important;
  font-family: inherit !important;
  min-width: 0 !important;
}

.mnf-searchbar__input::placeholder { color: #aaa !important; }

.mnf-searchbar__btn {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 52px !important;
  height: 100% !important;
  background: none !important;
  border: none !important;
  border-left: 1px solid #e2e2e8 !important;
  cursor: pointer !important;
  color: var(--mnf-text-light) !important;
  flex-shrink: 0 !important;
  transition: color var(--mnf-transition), background var(--mnf-transition) !important;
}

.mnf-searchbar__btn:hover {
  color: var(--mnf-primary) !important;
  background: #f0ecf9 !important;
}

/* ── Desktop search dropdown ── */
.mnf-search-dropdown {
  display: none !important;
  position: absolute !important;
  top: calc(100% + 6px) !important; /* small gap below the search bar */
  left: 0 !important;
  right: 0 !important;
  background: #fff !important;
  border: 1px solid #e0e0e0 !important;
  border-radius: 12px !important;
  padding: 18px 20px 20px !important;
  box-shadow: 0 8px 40px rgba(0,0,0,0.13) !important;
  z-index: 9999 !important; /* above header content */
}

.mnf-search-dropdown.is-open {
  display: block !important;
  animation: mnf-fadein 0.18s ease !important;
}

.mnf-search-dropdown__label {
  font-size: 11px !important;
  font-weight: 700 !important;
  color: var(--mnf-text-light) !important;
  letter-spacing: 0.09em !important;
  text-transform: uppercase !important;
  margin: 0 0 0 !important;
  padding-bottom: 12px !important;
  border-bottom: 1px solid var(--mnf-border) !important;
  display: block !important;
}

.mnf-search-dropdown__tags {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  padding-top: 14px !important;
}

/* ── Live search results mode ── */
.mnf-search-dropdown__tags.mnf-results {
  flex-direction: column !important;
  gap: 0 !important;
}

.mnf-result-item {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  padding: 9px 10px !important;
  border-radius: 8px !important;
  text-decoration: none !important;
  transition: background var(--mnf-transition) !important;
  color: var(--mnf-text) !important;
}

.mnf-result-item:hover {
  background: #f5f0fe !important;
}

.mnf-result-item img {
  width: 44px !important;
  height: 44px !important;
  object-fit: cover !important;
  border-radius: 6px !important;
  border: 1px solid var(--mnf-border) !important;
  flex-shrink: 0 !important;
}

.mnf-result-item__info {
  display: flex !important;
  flex-direction: column !important;
  gap: 3px !important;
  flex: 1 !important;
  min-width: 0 !important;
}

.mnf-result-item__title {
  font-size: 13px !important;
  font-weight: 600 !important;
  color: var(--mnf-text) !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  display: block !important;
}

.mnf-result-item__price {
  font-size: 12px !important;
  font-weight: 700 !important;
  color: var(--mnf-primary) !important;
  display: block !important;
}

.mnf-result-all {
  display: block !important;
  margin-top: 8px !important;
  padding: 9px 10px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  color: var(--mnf-primary) !important;
  text-decoration: none !important;
  border-top: 1px solid var(--mnf-border) !important;
  text-align: center !important;
  border-radius: 0 0 8px 8px !important;
  transition: background var(--mnf-transition) !important;
}

.mnf-result-all:hover {
  background: #f5f0fe !important;
}

.mnf-search-loading {
  display: block !important;
  padding: 10px 0 !important;
  font-size: 13px !important;
  color: var(--mnf-text-light) !important;
  font-style: italic !important;
}

/* =============================================================================
   6. Topbar right actions (cart + account)
   ============================================================================= */
.mnf-topbar__actions {
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
  flex-shrink: 0 !important;
  margin-left: auto !important;
}

/* ── Cart button — icon with overlaid badge ── */
.mnf-cart-btn {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  background: none !important;
  border: none !important;
  cursor: pointer !important;
  color: var(--mnf-text) !important;
  padding: 6px 12px !important;
  border-radius: var(--mnf-radius) !important;
  transition: color var(--mnf-transition) !important;
  font-family: inherit !important;
  text-decoration: none !important;
  box-shadow: none !important;
}
.mnf-cart-btn:hover { color: var(--mnf-primary) !important; }

/* icon wrapper so badge overlays the icon */
.mnf-cart-btn__icon {
  position: relative !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
}

.mnf-cart-count {
  position: absolute !important;
  top: -8px !important;
  right: -8px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 18px !important;
  height: 18px !important;
  padding: 0 4px !important;
  border-radius: 9px !important;
  background: var(--mnf-primary) !important;
  color: #fff !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  border: 2px solid #fff !important;
}

.mnf-cart-btn__label {
  font-size: 13px !important;
  font-weight: 600 !important;
  color: inherit !important;
  line-height: 1 !important;
}

/* divider between cart and account */
.mnf-topbar__actions::before {
  content: "" !important;
  display: none !important; /* hidden, just a spacer */
}

.mnf-topbar__divider {
  width: 1px !important;
  height: 32px !important;
  background: var(--mnf-border) !important;
  margin: 0 6px !important;
  flex-shrink: 0 !important;
}

/* ── Account ── */
.mnf-account {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  color: var(--mnf-text) !important;
  padding: 6px 8px !important;
  cursor: default !important;
}

.mnf-account svg {
  flex-shrink: 0 !important;
  color: var(--mnf-text) !important;
  opacity: 0.7 !important;
}

.mnf-account__links {
  display: flex !important;
  flex-direction: column !important;
  gap: 1px !important;
}

/* "Login or Register" row */
.mnf-account__row {
  display: flex !important;
  align-items: center !important;
  gap: 4px !important;
  line-height: 1.2 !important;
}

.mnf-account__links a {
  font-size: 13px !important;
  color: var(--mnf-primary) !important;
  text-decoration: underline !important;
  line-height: 1.3 !important;
}
.mnf-account__links a:hover { text-decoration: none !important; }

.mnf-account__or {
  font-size: 12px !important;
  color: var(--mnf-text-light) !important;
}

.mnf-account__label {
  font-size: 13px !important;
  font-weight: 700 !important;
  color: var(--mnf-text) !important;
  display: block !important;
  letter-spacing: 0.01em !important;
  line-height: 1.3 !important;
}

/* =============================================================================
   7. Desktop Navigation Bar
   ============================================================================= */
.mnf-nav {
  background: var(--mnf-bg) !important;
  border-top: 1px solid var(--mnf-border) !important;
}

.mnf-nav .mnf-container { position: relative !important; }

.mnf-nav__list {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  gap: 0 !important;
  flex-wrap: wrap !important;
}

.mnf-nav__item {
  position: relative !important;
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

.mnf-nav__link {
  display: flex !important;
  align-items: center !important;
  gap: 4px !important;
  padding: 15px 18px !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  color: var(--mnf-text) !important;
  text-decoration: none !important;
  border-bottom: 2px solid transparent !important;
  transition: color var(--mnf-transition), border-color var(--mnf-transition) !important;
  white-space: nowrap !important;
  line-height: 1.2 !important;
  font-family: inherit !important;
  background: none !important;
}

.mnf-nav__link:hover,
.mnf-nav__link--active {
  color: var(--mnf-primary) !important;
  border-bottom-color: var(--mnf-primary) !important;
}

.mnf-nav__caret {
  font-size: 9px !important;
  color: var(--mnf-text-light) !important;
  transition: transform var(--mnf-transition) !important;
  display: inline-block !important;
}

.mnf-nav__item--parent:hover .mnf-nav__caret {
  transform: rotate(180deg) !important;
}

/* =============================================================
   Two-column mega dropdown
   D1 = left panel (first level)  |  D2 = right panel (second level)
   ============================================================= */

/* ── D1: the outer dropdown container ── */
.mnf-nav__sub--d1 {
  display: none !important;
  position: absolute !important;
  top: calc(100% + 4px) !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  background: var(--mnf-bg) !important;
  border-radius: 4px !important;
  box-shadow: 0 8px 32px rgba(0,0,0,0.12) !important;
  list-style: none !important;
  z-index: 200 !important;
  margin: 0 !important;
  padding: 8px 0 !important;
  min-width: 210px !important;
  overflow: visible !important;
  border: 1px solid #e8e8e8 !important;
  /* subtle top accent line */
  border-top: 3px solid var(--mnf-primary) !important;
}

.mnf-nav__item--parent:hover > .mnf-nav__sub--d1 {
  display: block !important;
  animation: mnf-fadein 0.16s ease !important;
}

/* ── 2 columns (7-12 items) ── */
.mnf-nav__sub--d1.mnf-cols-2 {
  column-count: 2 !important;
  min-width: 400px !important;
  column-gap: 0 !important;
}

/* ── 3 columns (13+ items) ── */
.mnf-nav__sub--d1.mnf-cols-3 {
  column-count: 3 !important;
  min-width: 580px !important;
  column-gap: 0 !important;
}

/* Prevent items from breaking across columns */
.mnf-nav__sub--d1.mnf-cols-2 .mnf-nav__sub-item--d1,
.mnf-nav__sub--d1.mnf-cols-3 .mnf-nav__sub-item--d1 {
  break-inside: avoid !important;
  -webkit-column-break-inside: avoid !important;
}

/* ── D1 items ── */
.mnf-nav__sub-item--d1 {
  position: relative !important;
  list-style: none !important;
  margin: 0 !important;
  padding: 0 2px !important;
}

/* D1 link */
.mnf-nav__sub-link {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 16px !important;
  padding: 9px 16px !important;
  font-size: 13px !important;
  font-weight: 400 !important;
  color: var(--mnf-text) !important;
  text-decoration: none !important;
  border-radius: 0 !important;
  margin: 0 !important;
  transition:
    background var(--mnf-transition),
    color var(--mnf-transition) !important;
  font-family: inherit !important;
  line-height: 1.4 !important;
}

/* hover / active */
.mnf-nav__sub-link:hover,
.mnf-nav__sub-item--d1:hover > .mnf-nav__sub-link {
  background: var(--mnf-primary) !important;
  color: #fff !important;
}

/* arrow icon */
.mnf-nav__sub-arrow {
  font-size: 17px !important;
  color: #bbb !important;
  line-height: 1 !important;
  flex-shrink: 0 !important;
  transition: color var(--mnf-transition), transform var(--mnf-transition) !important;
}

.mnf-nav__sub-item--d1:hover > .mnf-nav__sub-link .mnf-nav__sub-arrow {
  color: #fff !important;
  transform: translateX(3px) !important;
}

/* ── D2: right-side fly-out panel ── */
.mnf-nav__sub--d2 {
  display: none !important;
  position: absolute !important;
  top: -9px !important;
  left: 100% !important;
  min-width: 220px !important;
  background: var(--mnf-bg) !important;
  border: 1px solid #e8e8e8 !important;
  border-radius: 10px !important;
  box-shadow: 0 10px 40px rgba(0,0,0,0.12) !important;
  list-style: none !important;
  padding: 8px 4px !important;
  margin: 0 0 0 10px !important;
  z-index: 201 !important;
}

.mnf-nav__sub-item--d1:hover > .mnf-nav__sub--d2 {
  display: block !important;
  animation: mnf-fadein 0.14s ease !important;
}

/* ── D2 links ── */
.mnf-nav__sub2-link {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  padding: 10px 16px !important;
  font-size: 13px !important;
  font-weight: 400 !important;
  color: var(--mnf-text) !important;
  text-decoration: none !important;
  border-radius: 7px !important;
  margin: 1px 0 !important;
  border-left: 3px solid transparent !important;
  transition:
    background var(--mnf-transition),
    color var(--mnf-transition),
    border-color var(--mnf-transition),
    padding-left var(--mnf-transition) !important;
  font-family: inherit !important;
  white-space: nowrap !important;
}

/* bullet dot before D2 items */
.mnf-nav__sub2-link::before {
  content: "" !important;
  display: inline-block !important;
  width: 5px !important;
  height: 5px !important;
  border-radius: 50% !important;
  background: #ccc !important;
  flex-shrink: 0 !important;
  transition: background var(--mnf-transition) !important;
}

.mnf-nav__sub2-link:hover {
  background: rgba(var(--mnf-primary-rgb), 0.08) !important;
  color: var(--mnf-primary) !important;
  border-left-color: var(--mnf-primary) !important;
  padding-left: 18px !important;
}

.mnf-nav__sub2-link:hover::before {
  background: var(--mnf-primary) !important;
}

@keyframes mnf-fadein {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* =============================================================================
   8. Mobile Header
   ============================================================================= */
.mnf-topbar.mnf-mobile {
  border-top: none !important;
}

.mnf-topbar.mnf-mobile .mnf-topbar__inner {
  height: var(--mnf-mob-h) !important;
  gap: 4px !important;
  justify-content: flex-start !important;
  position: relative !important;
}

/* Logo stays perfectly centered regardless of left/right button count */
.mnf-topbar.mnf-mobile .mnf-logo {
  position: absolute !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  z-index: 1 !important;
  pointer-events: auto !important;
}

/* Search icon → right side (before cart) */
.mnf-mob-search {
  order: 3 !important;
  margin-left: auto !important;
}

/* Cart stays after search on the right */
.mnf-cart-btn--mob {
  order: 4 !important;
  margin-left: 0 !important;
}

/* Hamburger */
.mnf-hamburger {
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  gap: 5px !important;
  width: 38px !important;
  height: 38px !important;
  background: none !important;
  border: none !important;
  cursor: pointer !important;
  padding: 6px !important;
  color: var(--mnf-text) !important;
  flex-shrink: 0 !important;
  z-index: 2 !important;
}

.mnf-hamburger__bar {
  display: block !important;
  width: 22px !important;
  height: 2px !important;
  background: currentColor !important;
  border-radius: 2px !important;
  transition: transform 0.3s, opacity 0.3s !important;
}

.mnf-hamburger.is-active .mnf-hamburger__bar:nth-child(1) {
  transform: translateY(7px) rotate(45deg) !important;
}
.mnf-hamburger.is-active .mnf-hamburger__bar:nth-child(2) {
  opacity: 0 !important;
}
.mnf-hamburger.is-active .mnf-hamburger__bar:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg) !important;
}

.mnf-mob-search {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 38px !important;
  height: 38px !important;
  background: none !important;
  border: none !important;
  cursor: pointer !important;
  color: var(--mnf-text) !important;
  flex-shrink: 0 !important;
  z-index: 2 !important;
}
.mnf-mob-search:hover { color: var(--mnf-primary) !important; }

.mnf-cart-btn--mob { flex-shrink: 0 !important; z-index: 2 !important; }

/* =============================================================================
   9. Visibility
   ============================================================================= */
.mnf-desktop { display: flex !important; flex-direction: column !important; }
.mnf-mobile  { display: none !important; }

@media (max-width: 991px) {
  .mnf-desktop { display: none !important; }
  .mnf-mobile  { display: block !important; }
}

/* =============================================================================
   10. Overlay
   ============================================================================= */
.mnf-overlay {
  position: fixed !important;
  inset: 0 !important;
  background: rgba(0,0,0,0.46) !important;
  z-index: var(--mnf-z-overlay) !important;
  opacity: 0 !important;
  pointer-events: none !important;
  transition: opacity var(--mnf-transition) !important;
}
.mnf-overlay.is-visible {
  opacity: 1 !important;
  pointer-events: all !important;
}

/* =============================================================================
   11. Shared drawer base
   ============================================================================= */
.mnf-drawer,
.mnf-search-drawer,
.mnf-cart-drawer {
  position: fixed !important;
  top: 0 !important;
  bottom: 0 !important;
  width: var(--mnf-drawer-w) !important;
  max-width: 92vw !important;
  background: var(--mnf-bg) !important;
  z-index: var(--mnf-z-drawer) !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  transition: transform var(--mnf-transition) !important;
  box-shadow: var(--mnf-shadow) !important;
  -webkit-overflow-scrolling: touch !important;
}

.mnf-close-btn {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 36px !important;
  height: 36px !important;
  background: none !important;
  border: none !important;
  cursor: pointer !important;
  color: var(--mnf-text-light) !important;
  border-radius: 50% !important;
  transition: background var(--mnf-transition), color var(--mnf-transition) !important;
  flex-shrink: 0 !important;
}
.mnf-close-btn:hover {
  background: #f0ecf9 !important;
  color: var(--mnf-primary) !important;
}

/* =============================================================================
   12. Mobile Nav Drawer (LEFT)
   ============================================================================= */
.mnf-drawer {
  left: 0 !important;
  transform: translateX(-100%) !important;
}
.mnf-drawer.is-open { transform: translateX(0) !important; }

.mnf-drawer__head {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 16px 20px !important;
  border-bottom: 1px solid var(--mnf-border) !important;
  position: sticky !important;
  top: 0 !important;
  background: var(--mnf-bg) !important;
  z-index: 2 !important;
}

.mnf-drawer__brand {
  display: inline-flex !important;
  align-items: center !important;
  text-decoration: none !important;
  font-size: 18px !important;
  font-weight: 800 !important;
  color: var(--mnf-primary) !important;
}
.mnf-drawer__brand img { max-height: 36px !important; width: auto !important; }

.mnf-drawer__body { padding: 8px 0 32px !important; }

.mnf-drawer__menu {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

.mnf-drawer__item {
  border-bottom: 1px solid var(--mnf-border) !important;
  position: relative !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}

.mnf-drawer__link {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 16px 24px !important;
  font-size: 15px !important;
  font-weight: 500 !important;
  color: var(--mnf-text) !important;
  text-decoration: none !important;
  transition: background var(--mnf-transition), color var(--mnf-transition) !important;
  font-family: inherit !important;
  line-height: 1.3 !important;
}

.mnf-drawer__link:hover,
.mnf-drawer__item--active > .mnf-drawer__link {
  background: #f5f0fe !important;
  color: var(--mnf-primary) !important;
}

.mnf-drawer__arrow {
  font-size: 20px !important;
  color: var(--mnf-primary) !important;
  transition: transform var(--mnf-transition) !important;
  line-height: 1 !important;
}

.mnf-drawer__item--has-children.is-open > .mnf-drawer__link .mnf-drawer__arrow {
  transform: rotate(90deg) !important;
}

.mnf-drawer__submenu {
  display: none !important;
  list-style: none !important;
  background: #faf8ff !important;
  margin: 0 !important;
  padding: 0 !important;
}
.mnf-drawer__item--has-children.is-open > .mnf-drawer__submenu {
  display: block !important;
}

.mnf-drawer__sub-link {
  display: block !important;
  padding: 13px 32px !important;
  font-size: 14px !important;
  color: var(--mnf-text-light) !important;
  text-decoration: none !important;
  border-bottom: 1px solid var(--mnf-border) !important;
  transition: color var(--mnf-transition), background var(--mnf-transition) !important;
  font-family: inherit !important;
}
.mnf-drawer__sub-link:hover {
  color: var(--mnf-primary) !important;
  background: #ede8fa !important;
}

/* =============================================================================
   13. Search Drawer (RIGHT)
   ============================================================================= */
.mnf-search-drawer {
  right: 0 !important;
  left: auto !important;
  transform: translateX(110%) !important;
  width: 380px !important;
}
.mnf-search-drawer.is-open { transform: translateX(0) !important; }

.mnf-search-drawer__head {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 18px 20px !important;
  border-bottom: 1px solid var(--mnf-border) !important;
}

.mnf-search-drawer__title {
  font-size: 16px !important;
  font-weight: 600 !important;
  color: var(--mnf-text) !important;
}

.mnf-search-drawer__form { padding: 20px !important; }

.mnf-search-drawer__input-wrap {
  display: flex !important;
  align-items: center !important;
  border: 1.5px solid #ddd !important;
  border-radius: 30px !important;
  overflow: hidden !important;
  background: #fafafa !important;
  transition: border-color var(--mnf-transition), box-shadow var(--mnf-transition) !important;
}
.mnf-search-drawer__input-wrap:focus-within {
  border-color: var(--mnf-primary) !important;
  box-shadow: 0 0 0 3px rgba(var(--mnf-primary-rgb), 0.12) !important;
  background: #fff !important;
}

.mnf-search-drawer__input {
  flex: 1 !important;
  height: 48px !important;
  padding: 0 16px !important;
  border: none !important;
  background: transparent !important;
  font-size: 14px !important;
  color: var(--mnf-text) !important;
  outline: none !important;
  font-family: inherit !important;
}
.mnf-search-drawer__input::placeholder { color: #bbb !important; }

.mnf-search-drawer__input-wrap button {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 48px !important;
  height: 48px !important;
  background: none !important;
  border: none !important;
  cursor: pointer !important;
  color: #aaa !important;
  flex-shrink: 0 !important;
  transition: color var(--mnf-transition) !important;
}
.mnf-search-drawer__input-wrap button:hover { color: var(--mnf-primary) !important; }

.mnf-search-drawer__trending { padding: 0 20px 24px !important; }

.mnf-search-drawer__trending-label {
  font-size: 11px !important;
  font-weight: 700 !important;
  color: var(--mnf-text-light) !important;
  letter-spacing: 0.09em !important;
  text-transform: uppercase !important;
  margin-bottom: 14px !important;
  display: block !important;
}

.mnf-search-drawer__tags {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
}

.mnf-tag {
  display: inline-flex !important;
  align-items: center !important;
  gap: 5px !important;
  padding: 7px 14px !important;
  border: 1px solid #ddd !important;
  border-radius: 20px !important;
  font-size: 13px !important;
  color: var(--mnf-text-light) !important;
  text-decoration: none !important;
  background: #fafafa !important;
  transition: border-color var(--mnf-transition), color var(--mnf-transition), background var(--mnf-transition) !important;
  font-family: inherit !important;
}
.mnf-tag:hover {
  border-color: var(--mnf-primary) !important;
  color: var(--mnf-primary) !important;
  background: #f4f0fc !important;
}

/* =============================================================================
   14. Cart Drawer (RIGHT)
   ============================================================================= */
.mnf-cart-drawer {
  right: 0 !important;
  left: auto !important;
  transform: translateX(110%) !important;
  display: flex !important;
  flex-direction: column !important;
}
.mnf-cart-drawer.is-open { transform: translateX(0) !important; }

.mnf-cart-drawer__head {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 16px 20px !important;
  border-bottom: 1px solid var(--mnf-border) !important;
  flex-shrink: 0 !important;
  position: sticky !important;
  top: 0 !important;
  background: var(--mnf-bg) !important;
  z-index: 2 !important;
}

.mnf-cart-drawer__title {
  font-size: 14px !important;
  font-weight: 500 !important;
  color: var(--mnf-text-light) !important;
}

.mnf-cart-drawer__body {
  flex: 1 !important;
  overflow-y: auto !important;
  padding: 18px 20px !important;
}

/* Empty cart */
.mnf-cart-empty {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 16px !important;
  padding: 36px 0 !important;
  text-align: center !important;
}
.mnf-cart-empty svg { opacity: 0.25 !important; color: var(--mnf-text-light) !important; }
.mnf-cart-empty p {
  font-size: 14px !important;
  color: var(--mnf-text-light) !important;
  margin: 0 !important;
}

/* Cart items */
.mnf-mini-cart {
  display: flex !important;
  flex-direction: column !important;
  gap: 14px !important;
}

.mnf-cart-item {
  display: flex !important;
  align-items: flex-start !important;
  gap: 12px !important;
  padding-bottom: 14px !important;
  border-bottom: 1px solid var(--mnf-border) !important;
}
.mnf-cart-item:last-of-type { border-bottom: none !important; }

.mnf-cart-item img {
  width: 70px !important;
  height: 70px !important;
  object-fit: cover !important;
  border-radius: 6px !important;
  border: 1px solid var(--mnf-border) !important;
  flex-shrink: 0 !important;
}

.mnf-cart-item__info {
  flex: 1 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 4px !important;
}

.mnf-cart-item__name {
  font-size: 13px !important;
  font-weight: 600 !important;
  color: var(--mnf-text) !important;
  line-height: 1.4 !important;
  display: block !important;
}
.mnf-cart-item__qty  { font-size: 12px !important; color: var(--mnf-text-light) !important; display: block !important; }
.mnf-cart-item__price { font-size: 13px !important; font-weight: 700 !important; color: var(--mnf-primary) !important; display: block !important; }

.mnf-cart-item__remove {
  font-size: 20px !important;
  color: #ccc !important;
  text-decoration: none !important;
  line-height: 1 !important;
  padding: 0 4px !important;
  transition: color var(--mnf-transition) !important;
}
.mnf-cart-item__remove:hover { color: #e44 !important; }

.mnf-cart-subtotal {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  padding: 14px 0 4px !important;
  border-top: 1px solid var(--mnf-border) !important;
  font-size: 14px !important;
  color: var(--mnf-text) !important;
  margin-top: 4px !important;
}
.mnf-cart-subtotal strong {
  font-weight: 700 !important;
  color: var(--mnf-primary) !important;
}

/* =============================================================================
   15. Buttons
   ============================================================================= */
.mnf-btn {
  display: block !important;
  width: 100% !important;
  text-align: center !important;
  padding: 13px 20px !important;
  border-radius: var(--mnf-radius) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: 0.05em !important;
  text-decoration: none !important;
  cursor: pointer !important;
  border: 2px solid var(--mnf-primary) !important;
  background: var(--mnf-primary) !important;
  color: #fff !important;
  transition: background var(--mnf-transition), color var(--mnf-transition) !important;
  margin-top: 10px !important;
  font-family: inherit !important;
  line-height: 1.3 !important;
}
.mnf-btn:hover {
  background: transparent !important;
  color: var(--mnf-primary) !important;
}

.mnf-btn--outline {
  background: transparent !important;
  color: #555 !important;
  border-color: #ccc !important;
}
.mnf-btn--outline:hover {
  border-color: var(--mnf-primary) !important;
  color: var(--mnf-primary) !important;
}

.mnf-btn--dark {
  background: #111 !important;
  border-color: #111 !important;
  color: #fff !important;
}
.mnf-btn--dark:hover {
  background: transparent !important;
  color: #111 !important;
}

/* =============================================================================
   16. You May Also Like
   ============================================================================= */
.mnf-ymal {
  border-top: 1px solid var(--mnf-border) !important;
  background: #e9f4fb !important;
  flex-shrink: 0 !important;
  padding-bottom: 8px !important;
}

.mnf-ymal__head {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 14px 20px 10px !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  color: var(--mnf-text) !important;
}

.mnf-ymal__arrows { display: flex !important; gap: 6px !important; }

.mnf-ymal__arrow {
  width: 30px !important;
  height: 30px !important;
  border: 1px solid #ccc !important;
  border-radius: 50% !important;
  background: var(--mnf-bg) !important;
  cursor: pointer !important;
  font-size: 18px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: var(--mnf-text-light) !important;
  transition: border-color var(--mnf-transition), color var(--mnf-transition) !important;
  line-height: 1 !important;
}
.mnf-ymal__arrow:hover {
  border-color: var(--mnf-primary) !important;
  color: var(--mnf-primary) !important;
}

.mnf-ymal__viewport { overflow: hidden !important; }

.mnf-ymal__track {
  display: flex !important;
  transition: transform 0.35s ease !important;
}

/* YMAL card */
.mnf-ymal-card {
  display: flex !important;
  align-items: flex-start !important;
  gap: 12px !important;
  min-width: var(--mnf-drawer-w) !important;
  max-width: var(--mnf-drawer-w) !important;
  padding: 4px 20px 12px !important;
}

.mnf-ymal-card__img-link {
  flex-shrink: 0 !important;
  width: 80px !important;
  height: 80px !important;
  overflow: hidden !important;
  border-radius: 6px !important;
  border: 1px solid var(--mnf-border) !important;
  background: #fff !important;
  display: block !important;
}
.mnf-ymal-card__img-link img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
}

.mnf-ymal-card__body {
  flex: 1 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 5px !important;
}

.mnf-ymal-card__top {
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  gap: 6px !important;
}

.mnf-ymal-card__name {
  font-size: 13px !important;
  font-weight: 700 !important;
  color: var(--mnf-text) !important;
  text-decoration: none !important;
  flex: 1 !important;
  line-height: 1.4 !important;
}
.mnf-ymal-card__name:hover { color: var(--mnf-primary) !important; }

.mnf-ymal-card__price {
  font-size: 13px !important;
  font-weight: 700 !important;
  color: var(--mnf-text) !important;
  white-space: nowrap !important;
}

/* Stars */
.mnf-stars { display: flex !important; gap: 1px !important; }
.mnf-star  { font-size: 14px !important; line-height: 1 !important; }
.mnf-star--full  { color: #f5a623 !important; }
.mnf-star--half  { color: #f5a623 !important; opacity: 0.55 !important; }
.mnf-star--empty { color: #ddd !important; }

.mnf-ymal-card__desc {
  font-size: 11.5px !important;
  color: var(--mnf-text-light) !important;
  line-height: 1.5 !important;
  margin: 0 !important;
}

.mnf-ymal-card .mnf-btn--dark {
  font-size: 12px !important;
  padding: 9px 12px !important;
  border-radius: 4px !important;
  margin-top: 6px !important;
}

/* =============================================================================
   17. Body lock
   ============================================================================= */
body.mnf-locked {
  overflow: hidden !important;
}

/* =============================================================================
   18. Hide theme header when plugin is active
   ============================================================================= */
body.mnf-active #main-header,
body.mnf-active #top-header,
body.mnf-active .et-fixed-header,
body.mnf-active #et-secondary-nav,
body.mnf-active .site-header,
body.mnf-active header.site-header,
body.mnf-active header#masthead,
body.mnf-active #masthead,
body.mnf-active #site-header,
body.mnf-active #site-header-inner,
body.mnf-active .storefront-primary-navigation,
body.mnf-active .elementor-location-header,
body.mnf-active #header:not(#mnf-header),
body.mnf-active .wp-block-template-part[class*="header"] {
  display: none !important;
}

body.mnf-active #page,
body.mnf-active .et_pb_section_first,
body.mnf-active #et_body_inner {
  padding-top: 0 !important;
  margin-top: 0 !important;
}

/* via setting: belt + suspenders */
body.mnf-hide-theme #main-header,
body.mnf-hide-theme #top-header,
body.mnf-hide-theme .et-fixed-header,
body.mnf-hide-theme .site-header,
body.mnf-hide-theme #masthead,
body.mnf-hide-theme #site-header,
body.mnf-hide-theme #header:not(#mnf-header),
body.mnf-hide-theme .elementor-location-header {
  display: none !important;
}

/* =============================================================================
   19. ATC loading
   ============================================================================= */
.mnf-atc-btn.is-loading {
  opacity: 0.6 !important;
  pointer-events: none !important;
  cursor: wait !important;
}

/* =============================================================================
   20. Responsive
   ============================================================================= */
@media (max-width: 1199px) {
  .mnf-nav__link { padding: 15px 13px !important; font-size: 13px !important; }
}

@media (max-width: 991px) {
  .mnf-cart-drawer,
  .mnf-search-drawer { width: min(380px, 100vw) !important; }

  .mnf-ymal-card {
    min-width: min(var(--mnf-drawer-w), 100vw) !important;
    max-width: min(var(--mnf-drawer-w), 100vw) !important;
  }
}

@media (max-width: 480px) {
  .mnf-drawer,
  .mnf-cart-drawer,
  .mnf-search-drawer {
    width: 100vw !important;
    max-width: 100vw !important;
  }
  .mnf-ymal-card { min-width: 100vw !important; max-width: 100vw !important; }
}
