/*
 * ShopIT Mega Menu — Frontend CSS
 * File: catalog/view/theme/shopit/stylesheet/shopit_mega_menu.css
 *
 * All classes prefixed shopit-mm__
 * Zero global selector conflicts.
 * CSS custom properties inherit from :root (set by shopit theme).
 * No external fonts or CDN resources.
 */

/* ═══════════════════════════════════════════════════════════════
   NAV BAR
═══════════════════════════════════════════════════════════════ */

.shopit-mm__nav {
  /* position & sticky-offset controlled by ShopIT theme CSS vars.
     --mm-nav-position: relative (default) | sticky (when admin enables "Meniu sticky")
     --mm-nav-top:      auto (default)     | var(--header-height) when sticky */
  position: var(--mm-nav-position, relative);
  top: var(--mm-nav-top, auto);
  z-index: 400;
  background: var(--color-surface, #fff);
  border-bottom: var(--nav-border, 1px solid #e0e0e0);
  display: none;
}

.shopit-mm__list {
  display: flex;
  align-items: stretch;
  list-style: none;
  margin: 0;
  padding: 0;
  gap: 0;
  max-width: var(--container-max-width, 1280px);
  margin-inline: auto;
  padding-inline: 16px;
}

/* ═══════════════════════════════════════════════════════════════
   NAV ITEMS
═══════════════════════════════════════════════════════════════ */

.shopit-mm__item {
  position: relative;
  display: flex;
  align-items: stretch;
}

.shopit-mm__item--sep {
  align-items: center;
  padding: 0 4px;
}

.shopit-mm__sep {
  display: block;
  width: 1px;
  height: 60%;
  background: var(--color-border, #e0e0e0);
  margin: auto 0;
}

/* ═══════════════════════════════════════════════════════════════
   LINK
═══════════════════════════════════════════════════════════════ */

.shopit-mm__link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: var(--nav-item-height, 50px) var(--nav-spacing, 14px);
  padding-top: 0;
  padding-bottom: 0;
  font-size: var(--nav-font-size, var(--font-size-base, 14px));
  font-weight: var(--nav-font-weight, 600);
  color: var(--color-text, #212121);
  text-decoration: none;
  white-space: nowrap;
  border-bottom: 2px solid transparent;
  transition: color var(--transition-fast, 0.15s), border-color var(--transition-fast, 0.15s);
}

.shopit-mm__link:hover,
.shopit-mm__item--mega:hover > .shopit-mm__link,
.shopit-mm__item--has-drop:hover > .shopit-mm__link,
.shopit-mm__item--active > .shopit-mm__link {
  color: var(--color-secondary, #e53935);
  border-bottom-color: var(--color-secondary, #e53935);
}

/* Active item indicator (current page) */
.shopit-mm__item--active > .shopit-mm__link {
  border-bottom-color: var(--color-secondary, #e53935);
  font-weight: 700;
}

/* Stale item: referenced entity (category/brand) was deleted */
.shopit-mm__item--stale > .shopit-mm__link {
  opacity: 0.45;
  pointer-events: none;
  cursor: default;
}

.shopit-mm__item--mega:hover > .shopit-mm__link .shopit-mm__chevron,
.shopit-mm__item--has-drop:hover > .shopit-mm__link .shopit-mm__chevron {
  transform: rotate(180deg);
}

.shopit-mm__chevron {
  display: inline-block;
  flex-shrink: 0;
  transition: transform 0.18s;
  opacity: 0.6;
}

/* ═══════════════════════════════════════════════════════════════
   ICON
═══════════════════════════════════════════════════════════════ */

.shopit-mm__icon {
  display: inline-flex;
  align-items: center;
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  opacity: 0.8;
}

.shopit-mm__icon--sm {
  width: 16px;
  height: 16px;
}

.shopit-mm__icon svg,
.shopit-mm__icon--sm svg {
  width: 100%;
  height: 100%;
}

.shopit-mm__icon-img,
.shopit-mm__icon-img--sm {
  display: block;
  object-fit: contain;
}

/* ═══════════════════════════════════════════════════════════════
   BADGE TAG
═══════════════════════════════════════════════════════════════ */

.shopit-mm__tag {
  display: inline-flex;
  align-items: center;
  padding: 1px 6px;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: #fff;
  border-radius: var(--border-radius-sm, 3px);
  background: var(--nav-badge-color, var(--color-secondary, #e53935));
  line-height: 1.6;
  flex-shrink: 0;
}

.shopit-mm__tag--sm {
  font-size: 9px;
  padding: 1px 4px;
}

/* ═══════════════════════════════════════════════════════════════
   MEGA PANEL
═══════════════════════════════════════════════════════════════ */

.shopit-mm__panel {
  position: absolute;
  top: 100%;
  left: 0;
  width: 900px;
  max-width: 95vw;
  background: var(--nav-panel-bg, var(--color-surface, #fff));
  border: 1px solid var(--color-border, #e0e0e0);
  border-top: 2px solid var(--color-secondary, #e53935);
  border-radius: 0 0 var(--card-radius, var(--border-radius-md, 8px)) var(--card-radius, var(--border-radius-md, 8px));
  box-shadow: var(--shadow-lg, 0 8px 40px rgba(0,0,0,.14));
  z-index: 420;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(-6px);
  transition: opacity var(--transition-fast, 0.18s) ease, transform var(--transition-fast, 0.18s) ease, visibility 0s linear var(--transition-fast, 0.18s);
}

.shopit-mm__panel[hidden] {
  display: block; /* override [hidden] so CSS transition works */
}

.shopit-mm__item--mega:hover > .shopit-mm__panel,
.shopit-mm__item--mega:focus-within > .shopit-mm__panel {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0);
  transition: opacity 0.18s ease, transform 0.18s ease;
}

.shopit-mm__panel-inner {
  display: flex;
  min-height: 200px;
}

/* ═══════════════════════════════════════════════════════════════
   LEFT RAIL (sub-categories / sub-items)
═══════════════════════════════════════════════════════════════ */

.shopit-mm__rail {
  list-style: none;
  margin: 0;
  padding: 12px 0;
  min-width: 200px;
  max-width: 240px;
  flex-shrink: 0;
  border-right: 1px solid var(--color-border, #e0e0e0);
  background: var(--nav-panel-sidebar-bg, var(--color-bg, #fafafa));
  border-radius: 0 0 0 var(--card-radius, var(--border-radius-md, 8px));
}

.shopit-mm__rail-item {
  display: block;
}

.shopit-mm__rail-link {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 9px 16px;
  font-size: var(--font-size-sm, 13px);
  font-weight: 500;
  color: var(--color-text, #212121);
  text-decoration: none;
  transition: background var(--transition-fast, 0.12s), color var(--transition-fast, 0.12s);
}

.shopit-mm__rail-link:hover {
  background: var(--color-border, #f0f0f0);
  color: var(--color-secondary, #e53935);
}

.shopit-mm__rail-link--all {
  margin-top: 8px;
  padding-top: 10px;
  border-top: 1px solid var(--color-border, #e0e0e0);
  font-size: 13px;
  font-weight: 600;
  color: var(--color-secondary, #e53935);
}

.shopit-mm__rail-arrow {
  margin-left: auto;
  opacity: 0.5;
}

/* ═══════════════════════════════════════════════════════════════
   RIGHT PANEL
═══════════════════════════════════════════════════════════════ */

.shopit-mm__panel-right {
  flex: 1;
  display: flex;
  flex-wrap: wrap;
  gap: 0;
  padding: 20px 20px 16px;
  overflow: hidden;
}

/* ═══════════════════════════════════════════════════════════════
   COLUMNS
═══════════════════════════════════════════════════════════════ */

.shopit-mm__cols {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  width: 100%;
}

.shopit-mm__col {
  flex: 1;
  min-width: 140px;
}

.shopit-mm__col-heading {
  font-size: 11px;
  font-weight: 700;
  font-family: var(--font-family-heading, inherit);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-text-muted, #757575);
  margin-bottom: 10px;
  padding-bottom: 6px;
  border-bottom: 1px solid var(--color-border, #e0e0e0);
}

.shopit-mm__col-links {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.shopit-mm__col-link {
  display: block;
  padding: 5px 0;
  font-size: var(--font-size-sm, 13px);
  color: var(--color-text, #212121);
  text-decoration: none;
  transition: color var(--transition-fast, 0.12s);
}

.shopit-mm__col-link:hover {
  color: var(--color-secondary, #e53935);
}

.shopit-mm__col-html {
  font-size: 13px;
  color: var(--color-text, #212121);
  line-height: 1.6;
}

/* ═══════════════════════════════════════════════════════════════
   BRANDS
═══════════════════════════════════════════════════════════════ */

.shopit-mm__brands {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}

.shopit-mm__brand {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 80px;
  height: 44px;
  border: 1px solid var(--color-border, #e0e0e0);
  border-radius: var(--border-radius-sm, 4px);
  padding: 6px;
  transition: border-color 0.15s, box-shadow 0.15s;
  text-decoration: none;
}

.shopit-mm__brand:hover {
  border-color: var(--color-secondary, #e53935);
  box-shadow: 0 2px 8px rgba(0,0,0,.08);
}

.shopit-mm__brand img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  display: block;
}

.shopit-mm__brand-name {
  font-size: 12px;
  font-weight: 600;
  color: var(--color-text, #212121);
  text-align: center;
}

/* ═══════════════════════════════════════════════════════════════
   BANNER
═══════════════════════════════════════════════════════════════ */

.shopit-mm__banner {
  width: 100%;
  margin-top: 16px;
}

.shopit-mm__banner-img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: var(--border-radius-sm, 4px);
  object-fit: cover;
}

/* ═══════════════════════════════════════════════════════════════
   PRODUCT PICKS
═══════════════════════════════════════════════════════════════ */

.shopit-mm__picks {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.shopit-mm__pick {
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  padding: 6px 0;
  border-bottom: 1px solid var(--color-border, #f0f0f0);
  transition: opacity 0.15s;
}

.shopit-mm__pick:last-child {
  border-bottom: none;
}

.shopit-mm__pick:hover {
  opacity: 0.8;
}

.shopit-mm__pick img {
  width: 48px;
  height: 48px;
  object-fit: cover;
  border-radius: var(--border-radius-sm, 4px);
  border: 1px solid var(--color-border, #e0e0e0);
  flex-shrink: 0;
}

.shopit-mm__pick-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
  overflow: hidden;
}

.shopit-mm__pick-name {
  font-size: 12.5px;
  font-weight: 600;
  color: var(--color-text, #212121);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.shopit-mm__pick-price {
  font-size: 12px;
  color: var(--color-secondary, #e53935);
  font-weight: 700;
}

/* ═══════════════════════════════════════════════════════════════
   SIMPLE DROPDOWN
═══════════════════════════════════════════════════════════════ */

.shopit-mm__drop {
  position: absolute;
  top: 100%;
  left: 0;
  min-width: 220px;
  list-style: none;
  margin: 0;
  padding: 8px 0;
  background: var(--nav-panel-bg, var(--color-surface, #fff));
  border: 1px solid var(--color-border, #e0e0e0);
  border-radius: var(--card-radius, var(--border-radius-md, 8px));
  box-shadow: var(--shadow-md, 0 4px 16px rgba(0,0,0,.1));
  z-index: 420;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(-4px);
  transition: opacity var(--transition-fast, 0.15s) ease, transform var(--transition-fast, 0.15s) ease, visibility 0s linear var(--transition-fast, 0.15s);
}

.shopit-mm__drop[hidden] {
  display: block;
}

.shopit-mm__item--has-drop:hover > .shopit-mm__drop,
.shopit-mm__item--has-drop:focus-within > .shopit-mm__drop {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0);
  transition: opacity 0.15s ease, transform 0.15s ease;
}

.shopit-mm__drop-item {
  display: block;
}

.shopit-mm__drop-link {
  display: block;
  padding: 9px 16px;
  font-size: var(--font-size-sm, 13px);
  font-weight: 500;
  color: var(--color-text, #212121);
  text-decoration: none;
  transition: background var(--transition-fast, 0.12s), color var(--transition-fast, 0.12s);
}

.shopit-mm__drop-link:hover {
  background: var(--color-bg, #f5f5f5);
  color: var(--color-secondary, #e53935);
}

/* ═══════════════════════════════════════════════════════════════
   STYLE PRESETS
═══════════════════════════════════════════════════════════════ */

/* Dark preset */
.shopit-mm__nav--dark {
  background: #1a1a1a;
  border-bottom-color: #333;
}

.shopit-mm__nav--dark .shopit-mm__link {
  color: #e0e0e0;
}

.shopit-mm__nav--dark .shopit-mm__link:hover {
  color: #fff;
  border-bottom-color: var(--color-secondary, #e53935);
}

/* Tech preset */
.shopit-mm__nav--tech {
  background: linear-gradient(90deg, #1a1a2e 0%, #16213e 100%);
  border-bottom: none;
}

.shopit-mm__nav--tech .shopit-mm__link {
  color: #c9d1e8;
}

.shopit-mm__nav--tech .shopit-mm__link:hover {
  color: #fff;
  border-bottom-color: var(--color-secondary, #e53935);
}

/* ═══════════════════════════════════════════════════════════════
   MOBILE TOGGLE BUTTON
   Hidden on desktop, shown on tablet/mobile
═══════════════════════════════════════════════════════════════ */

.shopit-mm__mobile-toggle {
  display: none;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--color-header-text, #fff);
  padding: 0;
  border-radius: var(--border-radius-sm, 4px);
  transition: background 0.15s;
}

.shopit-mm__mobile-toggle:hover {
  background: rgba(255,255,255,.1);
}

/* ═══════════════════════════════════════════════════════════════
   MOBILE OFF-CANVAS DRAWER
═══════════════════════════════════════════════════════════════ */

.shopit-mm__mobile {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 9000;
}

.shopit-mm__mobile.shopit-mm__mobile--open {
  display: block;
}

.shopit-mm__mobile-backdrop {
  position: absolute;
  inset: 0;
  background: var(--nav-overlay-color, #000);
  opacity: var(--nav-overlay-opacity, 0.55);
  animation: smmBackdropIn 0.2s ease forwards;
}

@keyframes smmBackdropIn {
  from { opacity: 0; }
  to   { opacity: var(--nav-overlay-opacity, 0.55); }
}

.shopit-mm__mobile-drawer {
  position: absolute;
  top: 0;
  left: 0;
  width: min(360px, 92vw);
  height: 100%;
  background: var(--color-surface, #fff);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  animation: smmDrawerIn 0.22s cubic-bezier(.25,.46,.45,.94);
}

@keyframes smmDrawerIn {
  from { transform: translateX(-100%); }
  to   { transform: translateX(0); }
}

.shopit-mm__mobile-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  background: var(--color-header-bg, #1a1a1a);
  flex-shrink: 0;
}

.shopit-mm__mobile-title {
  font-size: 16px;
  font-weight: 700;
  color: var(--color-header-text, #fff);
}

.shopit-mm__mobile-close {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--color-header-text, #fff);
  border-radius: var(--border-radius-sm, 4px);
  transition: background 0.15s;
}

.shopit-mm__mobile-close:hover {
  background: rgba(255,255,255,.15);
}

.shopit-mm__mobile-nav {
  flex: 1;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding: 8px 0 80px;
}

/* ─ Mobile item rows ─ */

.shopit-mm__mobile-item {
  border-bottom: 1px solid var(--color-border, #f0f0f0);
}

.shopit-mm__mobile-row {
  display: flex;
  align-items: center;
}

.shopit-mm__mobile-link {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 13px 20px;
  font-size: var(--nav-font-size, var(--font-size-base, 14px));
  font-weight: var(--nav-font-weight, 600);
  color: var(--color-text, #212121);
  text-decoration: none;
  transition: color var(--transition-fast, 0.12s);
}

.shopit-mm__mobile-link:hover {
  color: var(--color-secondary, #e53935);
}

.shopit-mm__mobile-expand {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--color-text-muted, #757575);
  flex-shrink: 0;
  transition: transform 0.2s, color 0.15s;
}

.shopit-mm__mobile-expand[aria-expanded="true"] {
  transform: rotate(180deg);
  color: var(--color-secondary, #e53935);
}

.shopit-mm__mobile-sub {
  background: var(--color-bg, #fafafa);
  border-top: 1px solid var(--color-border, #f0f0f0);
}

.shopit-mm__mobile-sub[hidden] {
  display: none;
}

.shopit-mm__mobile-sub-link {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 28px;
  font-size: var(--font-size-sm, 13px);
  font-weight: 500;
  color: var(--color-text, #212121);
  text-decoration: none;
  border-bottom: 1px solid var(--color-border, #f0f0f0);
  transition: color var(--transition-fast, 0.12s);
}

.shopit-mm__mobile-sub-link:last-child {
  border-bottom: none;
}

.shopit-mm__mobile-sub-link:hover {
  color: var(--color-secondary, #e53935);
}

.shopit-mm__mobile-sub-link--all {
  font-weight: 700;
  color: var(--color-secondary, #e53935);
  font-size: 13px;
}

.shopit-mm__mobile-sep {
  border: none;
  border-top: 2px solid var(--color-border, #e0e0e0);
  margin: 4px 20px;
}

/* ═══════════════════════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════════════════════ */

@media (max-width: 1023px) {
  /* Hide desktop nav bar on tablet/mobile */
  .shopit-mm__list {
    display: none;
  }

  /* Show mobile toggle */
  .shopit-mm__mobile-toggle {
    display: inline-flex;
  }
}

@media (max-width: 767px) {
  .shopit-mm__panel,
  .shopit-mm__drop {
    /* Prevent desktop panels appearing on touch */
    display: none !important;
  }
}

/* ═══════════════════════════════════════════════════════════════
   ACCESSIBILITY — reduce motion
═══════════════════════════════════════════════════════════════ */

@media (prefers-reduced-motion: reduce) {
  .shopit-mm__panel,
  .shopit-mm__drop,
  .shopit-mm__chevron,
  .shopit-mm__mobile-drawer,
  .shopit-mm__mobile-backdrop {
    transition: none !important;
    animation: none !important;
  }
}

/* ═══════════════════════════════════════════════════════════════
   HIGH CONTRAST
═══════════════════════════════════════════════════════════════ */

@media (forced-colors: active) {
  .shopit-mm__link,
  .shopit-mm__drop-link,
  .shopit-mm__rail-link,
  .shopit-mm__col-link,
  .shopit-mm__mobile-link {
    forced-color-adjust: auto;
  }
}

/* ═══════════════════════════════════════════════════════════════
   ALL CATEGORIES FLYOUT (two-panel sidebar + columns)
   Left = dark sidebar (top-level cats + icons)
   Right = subcategory columns (up to 4 per row)
   Panel: constrained to theme container width, positioned below button.
   Added by ShopIT Mega Menu package via OCMOD.
═══════════════════════════════════════════════════════════════ */

/* ── Wrapper ──────────────────────────────────────────────── */
.shopit-allcats {
  display: none;
  flex-shrink: 0;
}
@media (min-width: 992px) { .shopit-allcats { display: block; } }

/* ── Trigger button ───────────────────────────────────────── */
.shopit-allcats__btn {
  display: flex;
  align-items: center;
  gap: 8px;
  height: 42px;
  padding: 0 14px;
  background: var(--color-secondary, #1976d2);
  border: none;
  border-radius: var(--button-radius, 6px);
  color: #fff;
  font-size: var(--font-size-sm, 13px);
  font-weight: var(--font-weight-medium, 500);
  cursor: pointer;
  white-space: nowrap;
  transition: background .15s;
  user-select: none;
}
.shopit-allcats__btn:hover,
.shopit-allcats__btn.open {
  background: var(--color-secondary-dark, #1565c0);
}
.shopit-allcats__chevron {
  flex-shrink: 0;
  transition: transform .2s;
  margin-left: 2px;
}
.shopit-allcats__btn.open .shopit-allcats__chevron {
  transform: rotate(180deg);
}

/* ── Dropdown panel (constrained to container width) ── */
.shopit-allcats__panel {
  display: none;
  position: fixed;
  top: 0;          /* overridden by JS to btn.bottom */
  left: 50%;
  transform: translateX(-50%);
  z-index: 700;
  box-shadow: 0 8px 40px rgba(0,0,0,.22);
  max-height: 78vh;
  overflow: hidden;
  width: 95vw;
  max-width: 1260px;  /* matches theme container + small margin */
}
.shopit-allcats__panel.open { display: flex; }

/* ── Inner flex row: sidebar + content ───────────────────── */
.shopit-allcats__inner {
  display: flex;
  width: 100%;
  max-height: 78vh;
  overflow: hidden;
}

/* ── LEFT: dark sidebar ───────────────────────────────────── */
.shopit-allcats__sidebar {
  width: 260px;        /* overridden by inline style set by JS from DB setting */
  flex-shrink: 0;
  background: #2d2d2d; /* overridden by inline style from DB setting */
  overflow-y: auto;
  overflow-x: hidden;
  list-style: none;
  margin: 0;
  padding: 8px 0;
  scrollbar-width: thin;
  scrollbar-color: rgba(255,255,255,.2) transparent;
}
.shopit-allcats__sidebar::-webkit-scrollbar { width: 4px; }
.shopit-allcats__sidebar::-webkit-scrollbar-track { background: transparent; }
.shopit-allcats__sidebar::-webkit-scrollbar-thumb { background: rgba(255,255,255,.2); border-radius: 2px; }

.shopit-allcats__sidebar-item {
  display: block;
}

.shopit-allcats__sidebar-link {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 11px 16px;
  color: rgba(255,255,255,.82);
  text-decoration: none;
  font-size: 13.5px;
  font-weight: 500;
  line-height: 1.3;
  transition: background .12s, color .12s;
  cursor: pointer;
  white-space: nowrap;
  overflow: hidden;
}
.shopit-allcats__sidebar-link:hover,
.shopit-allcats__sidebar-item.active > .shopit-allcats__sidebar-link {
  background: rgba(255,255,255,.1);
  color: #fff;
}
.shopit-allcats__sidebar-item.active > .shopit-allcats__sidebar-link {
  background: rgba(255,255,255,.14);
  border-left: 3px solid var(--color-secondary, #1976d2);
  padding-left: 13px;
}

.shopit-allcats__sidebar-icon {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  opacity: .85;
}
.shopit-allcats__sidebar-icon img,
.shopit-allcats__sidebar-icon svg {
  width: 20px;
  height: 20px;
  display: block;
  object-fit: contain;
  filter: brightness(0) invert(1);  /* make any icon white */
}
.shopit-allcats__sidebar-item.active > .shopit-allcats__sidebar-link .shopit-allcats__sidebar-icon,
.shopit-allcats__sidebar-link:hover .shopit-allcats__sidebar-icon {
  opacity: 1;
}

.shopit-allcats__sidebar-name {
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
}

.shopit-allcats__sidebar-arrow {
  flex-shrink: 0;
  opacity: .4;
  margin-left: auto;
  transition: opacity .12s, transform .12s;
}
.shopit-allcats__sidebar-link:hover .shopit-allcats__sidebar-arrow,
.shopit-allcats__sidebar-item.active > .shopit-allcats__sidebar-link .shopit-allcats__sidebar-arrow {
  opacity: .9;
  transform: translateX(2px);
}

/* ── RIGHT: content area ──────────────────────────────────── */
.shopit-allcats__content {
  flex: 1;
  background: #fff;
  overflow-y: auto;
  overflow-x: hidden;
  padding: 24px 28px;
  scrollbar-width: thin;
  scrollbar-color: #ddd transparent;
}
.shopit-allcats__content::-webkit-scrollbar { width: 5px; }
.shopit-allcats__content::-webkit-scrollbar-track { background: transparent; }
.shopit-allcats__content::-webkit-scrollbar-thumb { background: #ddd; border-radius: 3px; }

/* ── Content panes ────────────────────────────────────────── */
.shopit-allcats__pane {
  display: none;
}
.shopit-allcats__pane.active {
  display: block;
}

/* ── Subcategory column grid (CSS grid, up to 4 columns) ──── */
.shopit-allcats__cols {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px 28px;
  align-items: start;
}
@media (max-width: 1280px) {
  .shopit-allcats__cols { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 1024px) {
  .shopit-allcats__cols { grid-template-columns: repeat(2, 1fr); }
}

/* ── Column: heading + links ──────────────────────────────── */
.shopit-allcats__col {
  min-width: 0;
}

.shopit-allcats__col-heading {
  display: block;
  font-size: 13px;
  font-weight: 700;
  color: var(--color-text, #212121);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: .04em;
  padding-bottom: 8px;
  margin-bottom: 6px;
  border-bottom: 2px solid var(--color-secondary, #1976d2);
  line-height: 1.3;
  transition: color .12s;
}
.shopit-allcats__col-heading:hover {
  color: var(--color-secondary, #1976d2);
}

.shopit-allcats__col-links {
  list-style: none;
  margin: 0;
  padding: 0;
}
.shopit-allcats__col-links li {
  margin: 0;
}

.shopit-allcats__col-link {
  display: block;
  padding: 5px 0;
  font-size: 13px;
  color: var(--color-text-muted, #555);
  text-decoration: none;
  line-height: 1.35;
  transition: color .12s, padding-left .1s;
}
.shopit-allcats__col-link:hover {
  color: var(--color-secondary, #1976d2);
  padding-left: 4px;
}

/* ── Empty pane (no subcategories) ───────────────────────── */
.shopit-allcats__pane-empty {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 120px;
}
.shopit-allcats__see-all {
  font-size: 15px;
  font-weight: 600;
  color: var(--color-secondary, #1976d2);
  text-decoration: none;
  transition: opacity .12s;
}
.shopit-allcats__see-all:hover { opacity: .75; }

/* ── Overlay ──────────────────────────────────────────────── */
.shopit-allcats__overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.38);
  z-index: 690;
  cursor: pointer;
}
.shopit-allcats__overlay.open { display: block; }

/* ── Forced-colors (Windows High Contrast) ────────────────── */
@media (forced-colors: active) {
  .shopit-allcats__sidebar { forced-color-adjust: none; background: ButtonFace; }
  .shopit-allcats__sidebar-link { color: ButtonText; }
  .shopit-allcats__sidebar-item.active > .shopit-allcats__sidebar-link,
  .shopit-allcats__sidebar-link:hover { background: Highlight; color: HighlightText; }
}
