/* ==========================================================================
   Header — Main Bar (лого + каталог + поиск + меню + CTA + иконки)
   Sticky, со shrink на скролле
   ========================================================================== */

.mc-mainbar {
  display: none;
  background: var(--color-bg);
  border-block-end: 1px solid var(--color-border);
  position: sticky;
  inset-block-start: 0;
  z-index: var(--z-header);
  transition: box-shadow var(--dur-base) var(--ease-out),
              padding var(--dur-base) var(--ease-out);
}

@media (min-width: 992px) {
  .mc-mainbar { display: block; }
}

.mc-mainbar.is-scrolled {
  box-shadow: var(--shadow-sm);
}

.mc-mainbar__inner {
  display: grid;
  grid-template-columns: auto auto 1fr auto;
  align-items: center;
  gap: var(--space-5);
  min-height: var(--header-h-desktop);
  padding-block: var(--space-3);
  transition: min-height var(--dur-base) var(--ease-out);
}

.mc-mainbar.is-scrolled .mc-mainbar__inner {
  min-height: 64px;
}

/* === Logo === */
.mc-mainbar__logo {
  display: inline-flex;
  align-items: center;
}

.mc-mainbar__logo img {
  max-width: 140px;
  height: auto;
  transition: max-width var(--dur-base) var(--ease-out);
}

.mc-mainbar.is-scrolled .mc-mainbar__logo img {
  max-width: 110px;
}

/* === Catalog button === */
.mc-mainbar__catalog-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
  background: var(--color-primary);
  color: var(--color-primary-on);
  border: 0;
  border-radius: var(--radius-pill);
  font-family: var(--font-display);
  font-weight: var(--fw-semibold);
  font-size: var(--fs-sm);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
  cursor: pointer;
  transition: background-color var(--dur-base) var(--ease-out),
              box-shadow var(--dur-base) var(--ease-out);
}

.mc-mainbar__catalog-btn:hover {
  background: var(--color-primary-600);
  color: var(--color-primary-on);
  box-shadow: var(--shadow-cta);
}

.mc-mainbar__catalog-btn i.is-burger {
  font-size: var(--fs-md);
}

.mc-mainbar__catalog-btn i.is-chev {
  font-size: var(--fs-xs);
  transition: transform var(--dur-base) var(--ease-out);
}

.mc-mainbar__catalog-btn[aria-expanded="true"] i.is-chev {
  transform: rotate(180deg);
}

/* === Search === */
.mc-mainbar__search {
  flex: 1 1 auto;
  max-width: 480px;
}

/* === Right column (CTA + icons) === */
.mc-mainbar__right {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.mc-mainbar__cta-phone {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-4);
  border: 2px solid var(--color-primary-200);
  border-radius: var(--radius-pill);
  color: var(--color-text);
  font-family: var(--font-display);
  font-weight: var(--fw-semibold);
  font-size: var(--fs-sm);
  text-decoration: none;
  transition: border-color var(--dur-fast) var(--ease-out),
              background-color var(--dur-fast) var(--ease-out);
}

.mc-mainbar__cta-phone:hover {
  border-color: var(--color-primary);
  background: var(--color-primary-50);
  color: var(--color-text);
  text-decoration: none;
}

.mc-mainbar__cta-phone i {
  color: var(--color-primary);
}

.mc-mainbar__icons {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
}

.mc-mainbar__icon {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: var(--radius-pill);
  color: var(--color-text);
  text-decoration: none;
  transition: background-color var(--dur-fast) var(--ease-out),
              color var(--dur-fast) var(--ease-out);
}

.mc-mainbar__icon:hover {
  background: var(--color-bg-light);
  color: var(--color-primary);
  text-decoration: none;
}

.mc-mainbar__icon i {
  font-size: var(--fs-md);
}

/* Бейдж-счётчик (общий для избранного/корзины) — единый стиль и позиция */
.mc-mainbar__icon .mc-icon-badge,
.mc-mainbar__icon .badge {
  position: absolute !important;
  inset-block-start: 4px !important;
  inset-inline-end: 4px !important;
  inset-inline-start: auto !important;
  inset-block-end: auto !important;
  transform: none !important;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  font-size: 10px;
  font-weight: var(--fw-semibold);
  font-family: var(--font-body);
  background: var(--color-primary);
  color: var(--color-primary-on);
  border-radius: var(--radius-pill);
  border: 2px solid var(--color-bg);
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}

/* Скрываем бейдж если пустой (corner case 0) */
.mc-mainbar__icon .mc-icon-badge:empty,
.mc-mainbar__icon .badge:empty {
  display: none;
}

/* === Mega-menu для каталога (открывается под main-bar) === */
.mc-mega-menu {
  position: absolute;
  inset-block-start: calc(100% + 8px);
  inset-inline-start: 0;
  inset-inline-end: auto;        /* НЕ растягиваем до правого края кнопки-каталога */
  width: max-content;            /* по контенту, но с min/max */
  min-width: 640px;
  max-width: min(900px, calc(100vw - var(--space-5) * 2));
  background: var(--color-bg);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xl);
  padding: var(--space-5);
  display: none;
  z-index: var(--z-popover);
  animation: mc-fade-in-down var(--dur-base) var(--ease-out);
}

.mc-mega-menu.is-open { display: block; }

.mc-mega-menu__inner {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: var(--space-6);
}

.mc-mega-menu__categories {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-2);
}

.mc-mega-menu__cat-link {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3);
  border-radius: var(--radius-md);
  color: var(--color-text);
  text-decoration: none;
  transition: background-color var(--dur-fast) var(--ease-out);
}

.mc-mega-menu__cat-link:hover {
  background: var(--color-bg-cream);
  color: var(--color-primary);
  text-decoration: none;
}

.mc-mega-menu__cat-link.is-active {
  background: var(--color-primary-50);
  color: var(--color-primary-700);
}

.mc-mega-menu__cat-thumb {
  width: 48px;
  height: 48px;
  border-radius: var(--radius-md);
  object-fit: cover;
  background: var(--color-bg-light);
  flex-shrink: 0;
}

.mc-mega-menu__cat-name {
  font-weight: var(--fw-medium);
  line-height: var(--lh-snug);
}

.mc-mega-menu__promo {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: var(--space-5);
  background: var(--grad-cream);
  border-radius: var(--radius-lg);
}

.mc-mega-menu__promo-title {
  font-family: var(--font-display);
  font-weight: var(--fw-semibold);
  font-size: var(--fs-lg);
  margin-block-end: var(--space-2);
}

.mc-mega-menu__promo-text {
  color: var(--color-text-soft);
  font-size: var(--fs-sm);
  margin-block-end: var(--space-4);
}

/* Wrapper relative для позиционирования mega-menu */
.mc-mainbar__catalog-wrap {
  position: relative;
}

/* === Поиск (форма поверх Bootstrap) === */
.mc-search-form {
  position: relative;
  display: flex;
  align-items: center;
}

.mc-search-form__input {
  width: 100%;
  padding-block: var(--space-3);
  padding-inline-start: 52px;     /* иконка 20px (отступ 20px от края) + 12px gap к тексту */
  padding-inline-end: var(--space-5);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-pill);
  background: var(--color-bg-light);
  font-size: var(--fs-sm);
  font-family: var(--font-body);
  color: var(--color-text);
  transition: border-color var(--dur-fast) var(--ease-out),
              background-color var(--dur-fast) var(--ease-out);
}

.mc-search-form__input::placeholder {
  color: var(--color-text-muted);
}

.mc-search-form__input:focus {
  outline: none;
  border-color: var(--color-primary);
  background: var(--color-bg);
  box-shadow: var(--shadow-focus-ring);
}

.mc-search-form__icon {
  position: absolute;
  inset-inline-start: 20px;        /* реальный визуальный отступ от края */
  inset-block-start: 50%;
  transform: translateY(-50%);
  color: var(--color-text-muted);
  pointer-events: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.mc-search-form__icon .mc-icon {
  width: 20px;
  height: 20px;
}

.mc-search-form__results {
  position: absolute;
  inset-block-start: calc(100% + 8px);
  inset-inline-start: 0;
  inset-inline-end: 0;
  background: var(--color-bg);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xl);
  max-height: 60vh;
  overflow-y: auto;
  z-index: var(--z-popover);
  display: none;
}

.mc-search-form__results.is-open { display: block; }

.mc-search-result {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3);
  text-decoration: none;
  color: var(--color-text);
  border-block-end: 1px solid var(--color-border);
  transition: background-color var(--dur-fast) var(--ease-out);
}

.mc-search-result:last-child { border-block-end: 0; }
.mc-search-result:hover { background: var(--color-bg-cream); text-decoration: none; }

.mc-search-result__thumb {
  width: 48px;
  height: 48px;
  border-radius: var(--radius-sm);
  object-fit: cover;
  flex-shrink: 0;
}

.mc-search-result__title {
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  line-height: var(--lh-snug);
  margin: 0;
}

.mc-search-result__price {
  font-size: var(--fs-sm);
  color: var(--color-primary);
  font-weight: var(--fw-semibold);
}

.mc-search-result--empty {
  padding: var(--space-5);
  text-align: center;
  color: var(--color-text-muted);
  font-size: var(--fs-sm);
}
