@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600;700;800&display=swap');

:root {
  --mg-bg: #f6f8fb;
  --mg-surface: #ffffff;
  --mg-surface-2: #f3f7fc;
  --mg-surface-3: #e8eef7;
  --mg-text: #132238;
  --mg-muted: #353535;
  --mg-line: rgba(19, 34, 56, 0.09);
  --mg-primary: #276ef1;
  --mg-primary-2: #4b8cff;
  --mg-primary-soft: rgba(39, 110, 241, 0.12);
  --mg-danger: #ef4444;
  --mg-success: #16a34a;
  --mg-warning: #d97706;
  --mg-radius-xl: 28px;
  --mg-radius-lg: 22px;
  --mg-radius-md: 18px;
  --mg-radius-sm: 14px;
  --mg-shadow: 0 20px 60px rgba(15, 23, 42, 0.08);
  --mg-shadow-sm: 0 12px 30px rgba(15, 23, 42, 0.06);
}

.mg-page {
    width: 90%;
    margin: 0px auto;
    overflow-y: hidden;
}

html, body {
  font-family: 'Montserrat';
  background: linear-gradient(180deg, #fbfdff 0%, var(--mg-bg) 100%);
  color: var(--mg-text);
}

body.menu-open {
  overflow: hidden;
}

.mg-topbar {
  border-bottom: 1px solid var(--mg-line);
  background: rgba(255,255,255,.88);
  backdrop-filter: blur(12px);
}

.mg-topbar__inner {
  min-height: 46px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  font-size: 13px;
}

.mg-topbar__contacts,
.mg-topbar__links {
  display: flex;
  flex-wrap: wrap;
  gap: 18px;
  align-items: center;
}

.mg-topbar a,
.mg-topbar span {
  text-decoration: none;
  color: var(--mg-muted);
}

.mg-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(246,248,251,.9);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid rgba(19,34,56,.06);
}

.mg-header__inner {
  min-height: 82px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 18px;
  align-items: center;
}

.mg-brand {
  display: flex;
  align-items: center;
  gap: 14px;
  text-decoration: none;
}

.mg-brand__logo {
  width: 48px;
  height: 48px;
  border-radius: 16px;
  background: linear-gradient(135deg, var(--mg-primary), var(--mg-primary-2));
  color: #fff;
  display: grid;
  place-items: center;
  font-weight: 800;
  font-size: 22px;
  box-shadow: 0 14px 30px rgba(39,110,241,.22);
}

.mg-brand__text {
  display: flex;
  flex-direction: column;
}

.mg-brand__title {
  font-size: 22px;
  font-weight: 800;
  color: var(--mg-text);
  line-height: 1;
}

.mg-brand__subtitle {
  font-size: 12px;
  color: var(--mg-muted);
  margin-top: 4px;
}

.mg-searchbar {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 12px;
  align-items: center;
}

.mg-catalog-btn {
  min-height: 50px;
  padding: 0 18px;
  border: 0;
  border-radius: 999px;
  background: #132238;
  color: #fff;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  font-weight: 700;
}

.mg-searchform {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  align-items: center;
     min-height: 38px;
    margin-top: 16px;
  padding: 8px;
  border-radius: 999px;
  background: rgba(255,255,255,.92);
  border: 1px solid var(--mg-line);
  box-shadow: var(--mg-shadow-sm);
}

.mg-searchform input {
  width: 100%;
  min-width: 0;
  border: 0;
  outline: none;
  background: transparent;
  padding: 0 14px;
  color: var(--mg-text);
  font-size: 15px;
}

.mg-searchform button {
  min-height: 40px;
  padding: 0 20px;
  border-radius: 999px;
  border: 0;
  background: linear-gradient(135deg, var(--mg-primary), var(--mg-primary-2));
  color: #fff;
  font-weight: 700;
  cursor: pointer;
}

.mg-header__actions {
  display: flex;
  align-items: center;
  gap: 10px;
}

.mg-header__action {
  min-height: 44px;
  padding: 0 16px;
  border-radius: 16px;
  border: 1px solid var(--mg-line);
  background: rgba(255,255,255,.9);
  color: var(--mg-text);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  font-size: 14px;
  font-weight: 600;
}

.mg-banner {
  padding: 24px 0 18px;
}

.mg-banner__grid {
  display: grid;
  grid-template-columns: 1.25fr .75fr;
  gap: 20px;
}

.mg-banner__content,
.mg-banner__side {
  background: var(--mg-surface);
  border: 1px solid rgba(39,110,241,.08);
  border-radius: var(--mg-radius-xl);
  box-shadow: var(--mg-shadow);
}

.mg-banner__content {
  padding: 34px;
  background:
    radial-gradient(circle at right top, rgba(75,140,255,.16), transparent 30%),
    linear-gradient(180deg, #fff 0%, #f9fbff 100%);
}

.mg-badge {
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  padding: 8px 14px;
  border-radius: 999px;
  background: var(--mg-primary-soft);
  color: var(--mg-primary);
  font-size: 13px;
  font-weight: 700;
  margin-bottom: 18px;
}

.mg-banner__title {
  font-size: clamp(32px, 5vw, 58px);
  line-height: .98;
  letter-spacing: -.04em;
  margin: 0 0 16px;
  max-width: 12ch;
}

.mg-banner__text {
  max-width: 58ch;
  color: var(--mg-muted);
  font-size: 16px;
  margin: 0 0 24px;
}

.mg-banner__actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.mg-btn {
  min-height: 48px;
  padding: 0 20px;
  border-radius: 999px;
  border: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  font-weight: 700;
  cursor: pointer;
}

.mg-btn--primary {
  color: #fff;
  background: linear-gradient(135deg, var(--mg-primary), var(--mg-primary-2));
}

.mg-btn--light {
  color: var(--mg-text);
  background: var(--mg-surface-2);
  border: 1px solid var(--mg-line);
}

.mg-banner__stats {
  margin-top: 26px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}

.mg-stat {
  padding: 16px;
  border-radius: 18px;
  background: var(--mg-surface-2);
  border: 1px solid rgba(19,34,56,.05);
}

.mg-stat strong {
  display: block;
  font-size: 28px;
  margin-bottom: 6px;
}

.mg-stat span {
  color: var(--mg-muted);
  font-size: 14px;
}

.mg-banner__side {
  padding: 22px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.mg-sidecard {
  padding: 18px;
  border-radius: 20px;
  border: 1px solid var(--mg-line);
  background: linear-gradient(180deg, #fff 0%, #f8fbff 100%);
}

.mg-sidecard__title {
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 8px;
}

.mg-sidecard p {
  margin: 0;
  color: var(--mg-muted);
}

.mg-section {
  padding: 20px 0 34px;
}

.mg-section--muted {
  background: linear-gradient(180deg, rgba(255,255,255,0) 0%, rgba(255,255,255,.35) 100%);
}

.mg-section__head {
  margin-bottom: 18px;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 18px;
}

.mg-section__title {
  font-size: clamp(24px, 3vw, 36px);
  line-height: 1;
  letter-spacing: -.03em;
  margin-bottom: 8px;
}

.mg-section__desc {
  margin: 0;
  color: var(--mg-muted);
}

.mg-section__more {
  text-decoration: none;
  color: var(--mg-primary);
  font-weight: 700;
  white-space: nowrap;
}

.mg-products-slider {
  margin: 0;
  padding: 0;
  list-style: none;
}

.mg-products-slider__item {
  padding: 4px;
}

/* Mega menu */
.catOverlay {
  position: fixed;
  inset: 0;
  z-index: 120;
  background: rgba(246,248,251,.95);
  backdrop-filter: blur(18px);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: .25s ease;
}

.catOverlay.is-open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.catOverlay__panel {
  width: min(calc(100% - 24px), 1600px);
  height: calc(100vh - 24px);
  margin: 12px auto;
  background: rgba(255,255,255,.96);
  border-radius: 30px;
  border: 1px solid var(--mg-line);
  box-shadow: 0 30px 80px rgba(15,23,42,.12);
  display: grid;
  grid-template-rows: auto auto 1fr;
  overflow: hidden;
}

.catOverlay__head {
  padding: 20px 22px;
  border-bottom: 1px solid var(--mg-line);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.catOverlay__title {
  font-size: clamp(28px, 3vw, 42px);
  font-weight: 800;
  line-height: 1;
}

.catOverlay__subtitle {
  color: var(--mg-muted);
  margin-top: 6px;
  font-size: 14px;
}

.catOverlay__close {
  width: 52px;
  height: 52px;
  border-radius: 18px;
  border: 0;
  background: var(--mg-surface-2);
  color: var(--mg-text);
  font-size: 28px;
  cursor: pointer;
}

.catOverlay__search {
  padding: 16px 22px;
  border-bottom: 1px solid var(--mg-line);
}

.catOverlay__searchInput {
  width: 100%;
  min-height: 54px;
  border-radius: 18px;
  border: 1px solid var(--mg-line);
  background: var(--mg-surface-2);
  outline: none;
  padding: 0 18px;
  font-size: 15px;
  color: var(--mg-text);
}

.catOverlay__body {
  min-height: 0;
  overflow: hidden;
}

.catMega {
  display: grid;
  grid-template-columns: 320px 340px 1fr;
  height: 100%;
}

.catMega__col {
  min-height: 0;
  overflow: auto;
  padding: 18px;
}

.catMega__col--lvl1,
.catMega__col--lvl2 {
  border-right: 1px solid var(--mg-line);
}

.catMega__label {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .14em;
  color: var(--mg-muted);
  font-weight: 700;
  margin-bottom: 14px;
}

.catMegaList,
.catMegaSublist {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 8px;
}

.catMegaItem,
.catMegaSubitem {
  margin: 0;
}

.catMegaBtn,
.catMegaSubBtn {
  width: 100%;
  border: 1px solid transparent;
  background: transparent;
  border-radius: 18px;
  cursor: pointer;
  transition: .2s ease;
  text-align: left;
}

.catMegaBtn:hover,
.catMegaBtn.is-active,
.catMegaSubBtn:hover,
.catMegaSubBtn.is-active {
  background: var(--mg-surface-2);
  border-color: rgba(39,110,241,.14);
}

.catMegaBtn {
  min-height: 76px;
  padding: 12px 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.catMegaBtn__inner {
  display: grid;
  grid-template-columns: 54px 1fr;
  gap: 12px;
  align-items: center;
  min-width: 0;
}

.catMegaBtn__media {
  width: 54px;
  height: 54px;
  border-radius: 16px;
  background: var(--mg-surface);
  overflow: hidden;
  display: grid;
  place-items: center;
}

.catMegaBtn__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.catMegaBtn__ph {
  width: 28px;
  height: 28px;
  border-radius: 10px;
  background: #dce7f6;
  display: block;
}

.catMegaBtn__text {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.catMegaBtn__title,
.catMegaSubBtn__title,
.catMegaCard__title {
  display: block;
  font-weight: 700;
  color: var(--mg-text);
}

.catMegaBtn__count,
.catMegaSubBtn__count,
.catMegaCard__count {
  color: var(--mg-muted);
  font-size: 12px;
}

.catMegaBtn__arrow {
  color: var(--mg-muted);
  font-size: 20px;
}

.catMegaPanel,
.catMegaPanelLvl3 {
  display: none;
}

.catMegaPanel.is-active,
.catMegaPanelLvl3.is-active {
  display: block;
}

.catMegaPanel__title {
  font-size: 20px;
  font-weight: 800;
  margin-bottom: 14px;
}

.catMegaPanel__title a {
  color: var(--mg-text);
  text-decoration: none;
}

.catMegaSubBtn {
  min-height: 54px;
  padding: 12px 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.catMegaCardGrid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.catMegaCard {
  min-height: 110px;
  padding: 16px;
  border-radius: 20px;
  border: 1px solid var(--mg-line);
  background: linear-gradient(180deg, #fff 0%, #f8fbff 100%);
  text-decoration: none;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  transition: .2s ease;
}

.catMegaCard:hover {
  transform: translateY(-1px);
  box-shadow: var(--mg-shadow-sm);
}

/* product card */
.preview {
  position: relative;
  height: 100%;
  background: linear-gradient(180deg, #fff 0%, #f9fbff 100%);
  border: 1px solid rgba(19,34,56,.07);
  border-radius: 24px;
  box-shadow: var(--mg-shadow-sm);
  overflow: hidden;
  transition: .25s ease;
}

.preview:hover {
  transform: translateY(-3px);
  box-shadow: var(--mg-shadow);
}

.fn_transfer {
  height: 100%;
  display: flex;
  flex-direction: column;
  position: relative;
}

.preview_image.image {
  display: block;
  position: relative;
  padding: 18px 18px 8px;
  text-decoration: none;
}

.preview_img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: contain;
  display: block;
  background: #fff;
  border-radius: 18px;
}

.no_image {
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: 18px;
  background: linear-gradient(135deg, #edf3fb, #dfe9f7);
}

.promo_img {
  position: absolute;
  right: 16px;
  bottom: 12px;
  max-width: 72px;
  max-height: 72px;
}

.product_labels {
  position: absolute;
  top: 16px;
  left: 16px;
  z-index: 2;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.product_labels > div {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0 12px;
  width: fit-content;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
}

.product_labels .featured {
  background: rgba(39,110,241,.12);
  color: var(--mg-primary);
}

.product_labels .sale {
  background: rgba(239,68,68,.1);
  color: var(--mg-danger);
}

.info_container {
  padding: 0 18px 18px;
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
}

.product_name {
  display: block;
  min-height: 44px;
  margin-bottom: 12px;
  color: var(--mg-text);
  text-decoration: none;
  font-size: 15px;
  font-weight: 700;
  line-height: 1.4;
}

.price_container {
  display: flex;
  align-items: flex-end;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 10px;
}

.old_price {
  color: var(--mg-muted);
  font-size: 14px;
  text-decoration: line-through;
}

.price {
  color: var(--mg-text);
  font-size: 24px;
  font-weight: 800;
  line-height: 1;
}

.hidden00 {
  display: none !important;
}

.in_stock_love,
.out_stock_love {
  min-height: 32px;
  display: inline-flex;
  align-items: center;
  width: fit-content;
  padding: 0 12px;
  border-radius: 999px;
  margin-bottom: 10px;
  font-size: 12px;
  font-weight: 700;
}

.in_stock_love {
  background: rgba(22,163,74,.12);
  color: var(--mg-success);
}

.out_stock_love {
  background: rgba(217,119,6,.12);
  color: var(--mg-warning);
}

.product_intro {
  display: grid;
  gap: 6px;
  margin-bottom: 10px;
  font-size: 13px;
  color: var(--mg-muted);
}

.product_intro .value {
  color: var(--mg-text);
  font-weight: 600;
}

.in_stock,
.no_stock {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
}

.in_stock { color: var(--mg-success); }
.no_stock { color: var(--mg-danger); }

.product_rating {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 24px;
  margin-bottom: 14px;
}

.rating_starOff {
  position: relative;
  width: 70px;
  height: 14px;
  border-radius: 999px;
  background: #e2e8f0;
  overflow: hidden;
}

.rating_starOn {
  display: block;
  height: 14px;
  background: linear-gradient(90deg, #fbbf24 0%, #f59e0b 100%);
  border-radius: 999px;
}

.rating_text {
  color: var(--mg-muted);
  font-size: 13px;
}

.preview_form {
  margin-top: auto;
  display: grid;
  gap: 10px;
}

.preview_form .button,
.preview_form .btn,
.preview_form .btn-outline-dark {
  min-height: 46px;
  border-radius: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 16px;
  text-decoration: none;
  font-weight: 700;
}

.preview_form .button,
.preview_form .btn-info {
  border: 0;
  background: linear-gradient(135deg, var(--mg-primary), var(--mg-primary-2));
  color: #fff;
}

.preview_form .btn-outline-dark {
  border: 1px solid var(--mg-line);
  background: var(--mg-surface-2);
  color: var(--mg-text);
}

.variant_select {
  width: 100%;
  min-height: 44px;
  border-radius: 14px;
  border: 1px solid var(--mg-line);
  background: #fff;
  color: var(--mg-text);
  padding: 0 12px;
}

.overlay_buttons {
  position: absolute;
  top: 14px;
  right: 14px;
  z-index: 3;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.comparison_button,
.wishlist_button,
.remove_link {
  width: 40px;
  height: 40px;
  border-radius: 14px;
  background: rgba(255,255,255,.94);
  border: 1px solid var(--mg-line);
  display: grid;
  place-items: center;
  text-decoration: none;
  color: var(--mg-text);
}

.comparison_button.selected,
.wishlist_button.selected {
  border-color: rgba(39,110,241,.24);
  background: #fff;
}

.remove_link span,
.hidden {
  display: none !important;
}

.mg-footer {
  padding: 30px 0 60px;
}

.mg-footer__inner {
  background: rgba(255,255,255,.85);
  border: 1px solid var(--mg-line);
  border-radius: 26px;
  padding: 22px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  flex-wrap: wrap;
}

.mg-footer__brand {
  font-size: 22px;
  font-weight: 800;
  margin-bottom: 6px;
}

.mg-footer__text {
  color: var(--mg-muted);
  max-width: 60ch;
}

.mg-footer__contacts {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.mg-footer__contacts a {
  text-decoration: none;
  color: var(--mg-text);
  font-weight: 600;
}

@media (max-width: 1180px) {
  .mg-banner__grid,
  .catMega,
  .mg-header__inner {
    grid-template-columns: 1fr;
  }

  .catMegaCardGrid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .catMega__col--lvl1,
  .catMega__col--lvl2 {
    border-right: 0;
    border-bottom: 1px solid var(--mg-line);
  }
}

@media (max-width: 900px) {
  .mg-searchbar {
    grid-template-columns: 1fr;
  }

  .mg-header__actions,
  .mg-section__head,
  .mg-topbar__inner,
  .mg-footer__inner {
    flex-direction: column;
    align-items: flex-start;
  }

  .mg-banner__stats {
    grid-template-columns: 1fr;
  }

  .catMegaCardGrid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .mg-banner__content,
  .mg-banner__side,
  .catOverlay__head,
  .catOverlay__search,
  .catMega__col {
    padding-left: 16px;
    padding-right: 16px;
  }

  .mg-searchform {
    grid-template-columns: 1fr;
    border-radius: 24px;
  }

  .mg-catalog-btn,
  .mg-searchform button,
  .mg-btn {
    width: 100%;
    justify-content: center;
  }

  .catOverlay__panel {
    width: calc(100% - 10px);
    height: calc(100vh - 10px);
    margin: 5px auto;
    border-radius: 22px;
  }
}


.mg-products-slider {
  position: relative;
}

.mg-slick-arrow {
  position: absolute;
  top: -62px;
  width: 42px;
  height: 42px;
  border: 1px solid var(--mg-line);
  border-radius: 14px;
  background: #fff;
  color: var(--mg-text);
  font-size: 24px;
  line-height: 1;
  cursor: pointer;
  z-index: 3;
  box-shadow: var(--mg-shadow-sm);
}

.mg-slick-prev {
  right: 52px;
}

.mg-slick-next {
  right: 0;
}

.mg-slick-arrow.slick-disabled {
  opacity: .45;
  cursor: default;
}

.mg-products-slider .slick-track {
  display: flex !important;
}

.mg-products-slider .slick-slide {
  height: inherit !important;
}

.mg-products-slider .slick-slide > div {
  height: 100%;
}

@media (max-width: 640px) {
  .mg-slick-arrow {
    top: -54px;
    width: 38px;
    height: 38px;
  }

  .mg-slick-prev {
    right: 46px;
  }
}



/*new style index*/


:root {
  --mg-bg: #f6f8fb;
  --mg-surface: #ffffff;
  --mg-surface-2: #f3f7fc;
  --mg-surface-3: #e8eef7;
  --mg-text: #132238;
  --mg-muted: #262626;
  --mg-line: rgba(19, 34, 56, 0.09);
  --mg-primary: #0071C5;
  --mg-primary-2: #2893e5;
  --mg-primary-soft: rgba(0, 113, 197, 0.12);
  --mg-danger: #ef4444;
  --mg-success: #16a34a;
  --mg-warning: #d97706;
  --mg-radius-xl: 28px;
  --mg-radius-lg: 22px;
  --mg-radius-md: 18px;
  --mg-radius-sm: 14px;
  --mg-shadow: 0 20px 60px rgba(15, 23, 42, 0.08);
  --mg-shadow-sm: 0 12px 30px rgba(15, 23, 42, 0.06);
}

.mg-topbar {
  display: block;
}

.mg-header {
  position: sticky;
  top: 0;
  z-index: 80;
  background: rgba(255, 255, 255, 0.9);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid rgba(19, 34, 56, 0.06);
}

.mg-header__inner {
  min-height: 74px;
  display: grid;
  grid-template-columns: 56px 1fr 96px;
  align-items: center;
  gap: 12px;
}

.mg-header__left {
  display: flex;
  align-items: center;
}

.mg-brand--center {
  justify-self: center;
}

.mg-brand--center .mg-brand__text {
  align-items: flex-start;
}

.mg-burger {
  width: 48px;
  height: 48px;
  border: 1px solid var(--mg-line);
  border-radius: 16px;
  background: #fff;
  display: inline-flex;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  padding: 0 12px;
  cursor: pointer;
  box-shadow: var(--mg-shadow-sm);
  transition: transform .25s ease, box-shadow .25s ease, background .25s ease;
}

.mg-burger:hover {
  transform: translateY(-1px);
  box-shadow: var(--mg-shadow);
}

.mg-burger span {
  display: block;
  width: 100%;
  height: 2px;
  border-radius: 999px;
  background: var(--mg-text);
}

.mg-header__actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
}

.mg-header__icon {
  width: 44px;
  height: 44px;
  border-radius: 16px;
  border: 1px solid var(--mg-line);
  background: rgba(255,255,255,.94);
  color: var(--mg-text);
  text-decoration: none;
  display: inline-grid;
  place-items: center;
  cursor: pointer;
  box-shadow: var(--mg-shadow-sm);
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease, color .25s ease;
}

.mg-header__icon:hover {
  transform: translateY(-1px);
  box-shadow: var(--mg-shadow);
  border-color: rgba(0,113,197,.18);
  color: var(--mg-primary);
}

.mg-header__desktopRow {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 14px;
  align-items: center;
  padding: 0 0 14px;
}

.mg-header__desktopCart {
  display: flex;
  align-items: center;
}

.mg-searchform {
  min-height: 54px;
  margin-top: 0;
  padding: 8px;
  border-radius: 999px;
  background: rgba(255,255,255,.96);
  border: 1px solid var(--mg-line);
  box-shadow: var(--mg-shadow-sm);
}

.mg-searchform--desktop {
  display: grid;
  grid-template-columns: 1fr auto;
}

.mg-searchform--header {
  display: grid;
  grid-template-columns: 1fr auto;
}

.mg-header__searchWrap {
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transform: translateY(-10px);
  transition: max-height .35s ease, opacity .25s ease, transform .25s ease, padding .25s ease;
  padding: 0;
}

.mg-header__searchWrap.is-open {
  max-height: 120px;
  opacity: 1;
  transform: translateY(0);
  padding: 0 0 14px;
}

.mg-header__action {
  min-height: 44px;
  padding: 0 18px;
  border-radius: 16px;
  border: 1px solid var(--mg-line);
  background: rgba(255,255,255,.92);
  color: var(--mg-text);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  font-size: 14px;
  font-weight: 700;
}

.mg-catalog-btn {
  min-height: 52px;
  padding: 0 20px;
  border: 0;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--mg-primary), var(--mg-primary-2));
  color: #fff;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  font-weight: 700;
  box-shadow: 0 14px 30px rgba(0,113,197,.22);
}

.mg-banner__grid {
  display: grid;
  grid-template-columns: 1.3fr .7fr;
  gap: 20px;
}

.mg-banner__content--video {
  position: relative;
  overflow: hidden;
  min-height: 520px;
  padding: 0;
  background: #dfeaf4;
}

.mg-banner__video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.mg-banner__videoOverlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(255,255,255,.40) 0%, rgba(255,255,255,.72) 100%),
    linear-gradient(135deg, rgba(0,113,197,.16), rgba(255,255,255,.10));
}

.mg-banner__contentInner {
  position: relative;
  z-index: 2;
  padding: 34px;
}

.mg-banner__side--images {
  display: grid;
  grid-template-rows: 1fr 1fr;
  gap: 16px;
  background: transparent;
  border: 0;
  box-shadow: none;
  padding: 0;
}

.mg-bannerImageCard {
  display: block;
  min-height: 252px;
  overflow: hidden;
  border-radius: var(--mg-radius-xl);
  border: 1px solid rgba(0,113,197,.08);
  box-shadow: var(--mg-shadow);
  background: #fff;
}

.mg-bannerImageCard img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.catOverlay {
  background: rgba(246,248,251,.68);
  backdrop-filter: blur(20px);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity .35s ease, visibility .35s ease;
}

.catOverlay.is-open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.catOverlay__panel {
  transform: translateY(18px) scale(.985);
  opacity: 0;
  transition: transform .35s ease, opacity .35s ease;
}

.catOverlay.is-open .catOverlay__panel {
  transform: translateY(0) scale(1);
  opacity: 1;
}

.catMegaPanel,
.catMegaPanelLvl3 {
  display: none;
  animation: mgFadeIn .28s ease;
}

.catMegaPanel.is-active,
.catMegaPanelLvl3.is-active {
  display: block;
}

@keyframes mgFadeIn {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.catMegaSubBtn--link {
  width: 100%;
  min-height: 16px;
  padding: 12px 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border: 1px solid transparent;
  background: transparent;
  border-radius: 18px;
  text-align: left;
  text-decoration: none;
  transition: .2s ease;
}

.catMegaSubBtn--link:hover {
  background: var(--mg-surface-2);
  border-color: rgba(0,113,197,.14);
}

.catMegaPanel__title a {
  color: var(--mg-text);
  text-decoration: none;
}

.overlay_buttons,
.comparison_button,
.wishlist_button,
.remove_link {
  display: none !important;
}

@media (min-width: 901px) {
  .mg-header__searchWrap {
    display: none;
  }

  .mg-header__desktopRow {
    display: grid;
  }
}

@media (max-width: 1180px) {
  .mg-banner__grid {
    grid-template-columns: 1fr;
  }

  .mg-banner__side--images {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: none;
  }

  .catMega {
    grid-template-columns: 280px 320px 1fr;
  }
}

@media (max-width: 900px) {
  .mg-topbar {
    display: none;
  }

  .mg-header__inner {
    grid-template-columns: 52px 1fr 96px;
    min-height: 68px;
  }

  .mg-brand__subtitle {
    display: none;
  }

  .mg-brand__title {
    font-size: 18px;
  }

  .mg-brand__logo {
    width: 42px;
    height: 42px;
    border-radius: 14px;
    font-size: 20px;
  }

  .mg-header__desktopRow {
    display: none;
  }

  .mg-banner {
    padding-top: 16px;
  }

  .mg-banner__content--video {
    min-height: 420px;
  }

  .mg-banner__contentInner {
    padding: 22px;
  }

  .mg-banner__title {
    font-size: clamp(28px, 8vw, 42px);
    max-width: 10ch;
  }

  .mg-banner__text {
    font-size: 14px;
  }

  .mg-banner__stats {
    grid-template-columns: 1fr;
  }

  .mg-banner__side--images {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .mg-bannerImageCard {
    min-height: 180px;
  }

  .catOverlay__panel {
    width: calc(100% - 10px);
    height: calc(100vh - 10px);
    margin: 5px auto;
    border-radius: 22px;
    grid-template-rows: auto auto 1fr;
  }

  .catOverlay__head,
  .catOverlay__search {
    padding-left: 16px;
    padding-right: 16px;
  }

  .catMega {
    grid-template-columns: 1fr;
    height: 100%;
  }

  .catMega__col {
    padding: 14px 16px;
  }

  .catMega__col--lvl1,
  .catMega__col--lvl2 {
    border-right: 0;
    border-bottom: 1px solid var(--mg-line);
  }

  .catMegaCardGrid {
    grid-template-columns: 1fr;
  }

  .mg-slick-arrow {
    top: -54px;
    width: 38px;
    height: 38px;
  }

  .mg-slick-prev {
    right: 46px;
  }
}

@media (max-width: 640px) {
  .mg-header__inner {
    grid-template-columns: 48px 1fr 92px;
    gap: 8px;
  }

  .mg-brand {
    gap: 10px;
  }

  .mg-brand__text {
    min-width: 0;
  }

  .mg-brand__title {
    font-size: 16px;
  }

  .mg-header__actions {
    gap: 6px;
  }

  .mg-header__icon,
  .mg-burger {
    width: 42px;
    height: 42px;
    border-radius: 14px;
  }

  .mg-searchform--header {
    grid-template-columns: 1fr;
    border-radius: 22px;
  }

  .mg-searchform--header button {
    width: 100%;
  }

  .mg-banner__content--video {
    min-height: 380px;
    border-radius: 24px;
  }

  .mg-banner__contentInner {
    padding: 18px;
  }

  .mg-banner__actions {
            display: flex;
    grid-template-columns: 1fr;
  }

  .mg-btn {
    width: 100%;
  }

  .mg-products-slider__item {
    padding: 3px;
  }

  .product_name {
    min-height: 40px;
    font-size: 14px;
  }

  .price {
    font-size: 20px;
  }

  .preview_form .button,
  .preview_form .btn,
  .preview_form .btn-outline-dark {
    min-height: 42px;
    font-size: 13px;
    padding: 0 12px;
  }
}




:root {
  --mg-primary: #0071C5;
  --mg-primary-2: #2893e5;
  --mg-primary-soft: rgba(0, 113, 197, 0.12);
}

/* topbar */
.mg-topbar {
  display: block;
  border-bottom: 1px solid var(--mg-line);
  background: rgba(255,255,255,.88);
  backdrop-filter: blur(12px);
}

.mg-topbar__inner {
  min-height: 42px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  font-size: 13px;
}

.mg-topbar__contacts,
.mg-topbar__links {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

.mg-topbar a,
.mg-topbar span {
  color: var(--mg-muted);
  text-decoration: none;
      font-size: 14px;
    font-weight: 700;
}

.mg-topbar__links a {
 
  height: 28px;
  border-radius: 999px;
  display: inline-grid;
  place-items: center;
 
  color: var(--mg-primary);
}

/* header */
.mg-header {
  position: sticky;
  top: 0;
  z-index: 80;
  background: rgba(255,255,255,.94);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid rgba(19,34,56,.06);
}

.mg-header__inner {
  min-height: 82px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 18px;
  align-items: center;
}

.mg-header__left {
  display: flex;
  align-items: center;
  gap: 16px;
  min-width: 0;
}

.mg-header__center {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 14px;
  align-items: center;
  min-width: 0;
}

.mg-header__right {
  display: flex;
  align-items: center;
  gap: 10px;
}

.mg-burger {
  display: none;
}

.mg-brand {
  display: flex;
  align-items: center;
  gap: 14px;
  text-decoration: none;
  min-width: 0;
}

.mg-brand__logo {
  width: 48px;
  height: 48px;
  border-radius: 16px;
  background: linear-gradient(135deg, var(--mg-primary), var(--mg-primary-2));
  color: #fff;
  display: grid;
  place-items: center;
  font-weight: 800;
  font-size: 22px;
  box-shadow: 0 14px 30px rgba(0,113,197,.22);
}



span.catMegaBtn__title {
    font-family: 'Montserrat';
}

input.catOverlay__searchInput {
    font-family: Montserrat;
}


.mg-brand__title {
  font-size: 22px;
  font-weight: 800;
  color: var(--mg-text);
  line-height: 1;
}

.mg-brand__subtitle {
  font-size: 12px;
  color: var(--mg-muted);
  margin-top: 4px;
}

.mg-catalog-btn {
  min-height: 50px;
  padding: 0 18px;
  border: 0;
      border-radius: 13px;

  background: linear-gradient(135deg, var(--mg-primary), var(--mg-primary-2));
  color: #fff;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  font-weight: 700;
  white-space: nowrap;
  box-shadow: 0 14px 30px rgba(0,113,197,.22);
}

.mg-searchform {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  align-items: center;
      min-height: 40px;
    margin-top: 18px;
  padding: 6px 6px 6px 14px;
  border-radius: 999px;
  background: rgba(255,255,255,.96);
  border: 1px solid var(--mg-line);
  box-shadow: var(--mg-shadow-sm);
  min-width: 0;
}

.mg-searchform input {
  width: 100%;
  min-width: 0;
  border: 0;
  outline: none;
  background: transparent;
  color: var(--mg-text);
  font-size: 15px;
  padding: 0;
}

.mg-searchform button {
  width: 44px;
  min-width: 44px;
  height: 44px;
  border-radius: 999px;
  border: 0;
  background: linear-gradient(135deg, var(--mg-primary), var(--mg-primary-2));
  color: #fff;
  display: inline-grid;
  place-items: center;
  cursor: pointer;
  padding: 0;
}

.mg-header__icon {
  width: 46px;
  height: 46px;
  border-radius: 16px;
  border: 1px solid var(--mg-line);
  background: rgba(255,255,255,.94);
  color: var(--mg-text);
  text-decoration: none;
  display: inline-grid;
  place-items: center;
  box-shadow: var(--mg-shadow-sm);
}

.mg-header__icon--mobile,
.mg-header__searchWrap {
  display: none;
}

/* убираем избранное и сравнение */
.overlay_buttons,
.comparison_button,
.wishlist_button,
.remove_link {
  display: none !important;
}

/* mobile */
@media (max-width: 900px) {
  .mg-topbar {
    display: none;
  }

  .mg-header__inner {
    min-height: 68px;
    grid-template-columns: 48px 1fr 92px;
    gap: 10px;
  }

  .mg-header__left {
    gap: inherit;
  }

  .mg-header__center {
    display: block;
  }

  .mg-burger {
    width: 42px;
    height: 42px;
    border: 1px solid var(--mg-line);
    border-radius: 14px;
    background: #fff;
    display: inline-flex;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
    padding: 0 10px;
    cursor: pointer;
    box-shadow: var(--mg-shadow-sm);
  }

  .mg-burger span {
    display: block;
    width: 100%;
    height: 2px;
    border-radius: 999px;
    background: var(--mg-text);
  }

  .mg-brand {
    justify-content: center;
    gap: 10px;
  }

  .mg-brand__subtitle {
    display: none;
  }

  .mg-brand__title {
    font-size: 16px;
  }

  .mg-brand__logo {
    width: 42px;
    height: 42px;
    border-radius: 14px;
    font-size: 20px;
  }

  .mg-catalog-btn,
  .mg-searchform--desktop {
    display: none;
  }

  .mg-header__right {
    justify-content: flex-end;
    gap: 6px;
  }

  .mg-header__icon,
  .mg-header__icon--mobile {
    width: 42px;
    height: 42px;
    border-radius: 14px;
  }

  .mg-header__icon--mobile {
    display: inline-grid;
  }

  .mg-header__searchWrap {
    display: block;
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    transform: translateY(-10px);
    transition: max-height .35s ease, opacity .25s ease, transform .25s ease, padding .25s ease;
    padding: 0;
  }

  .mg-header__searchWrap.is-open {
    max-height: 120px;
    opacity: 1;
    transform: translateY(0);
    padding: 0 0 14px;
  }

  .mg-searchform--header {
    display: grid;
    grid-template-columns: 1fr auto;
  }
}

@media (max-width: 640px) {
  .mg-brand__text {
    
  }

  .mg-header__inner {
          grid-template-columns: 198px 1fr 92px;
  }

  .mg-brand {
    justify-content: center;
  }
}





/* Catalog page */




.catalog-page {
    display: flex;
    flex-direction: column;
    gap: 24px;
    padding: 12px 0 40px;
}

.catalog-page__head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 20px;
    padding: 24px;
    border: 1px solid #eceff3;
    border-radius: 24px;
    background: linear-gradient(180deg, #ffffff 0%, #fafbfc 100%);
}

.catalog-page__head-main {
    flex: 1 1 auto;
    min-width: 0;
}

.catalog-page__title {
    margin: 0 0 10px;
    font-size: 34px;
    line-height: 1.1;
    font-weight: 800;
    color: #111827;
}

.catalog-page__intro {
    max-width: 920px;
    font-size: 15px;
    line-height: 1.7;
    color: #6b7280;
}

.catalog-page__head-side {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.catalog-page__stats {
    min-width: 92px;
    padding: 14px 16px;
    border-radius: 18px;
    background: #fff;
    border: 1px solid #eceff3;
    text-align: center;
}

.catalog-page__stats-value {
    display: block;
    font-size: 20px;
    font-weight: 800;
    color: #111827;
}

.catalog-page__stats-label {
    display: block;
    margin-top: 3px;
    font-size: 12px;
    color: #6b7280;
}

.catalog-block {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.catalog-block__title {
    font-size: 20px;
    font-weight: 700;
    color: #111827;
}

.catalog-toolbar-wrap {
    position: relative;
}

.catalog-toolbar {
    display: flex;
    flex-direction: column;
    gap: 16px;
    padding: 18px;
    border: 1px solid #eceff3;
    border-radius: 24px;
    background: #fff;
    box-shadow: 0 10px 30px rgba(17, 24, 39, 0.04);
}

.catalog-toolbar__row {
    display: flex;
    align-items: center;
    gap: 16px;
}

.catalog-toolbar__row--bottom {
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
}

.catalog-toolbar__label {
    flex: 0 0 auto;
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: #6b7280;
}

.catalog-toolbar__scroll {
    display: flex;
    align-items: center;
    gap: 10px;
    flex: 1 1 auto;
    overflow-x: auto;
    padding-bottom: 4px;
    scrollbar-width: thin;
}

.catalog-chip {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    white-space: nowrap;
    padding: 10px 14px;
    border-radius: 999px;
    border: 1px solid #e5e7eb;
    background: #fff;
    color: #111827;
    font-size: 14px;
    font-weight: 500;
    text-decoration: none;
    transition: .2s ease;
}

.catalog-chip span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 20px;
    height: 20px;
    padding: 0 6px;
    border-radius: 999px;
    background: #f3f4f6;
    font-size: 12px;
    color: #6b7280;
}

.catalog-chip:hover,
.catalog-chip.is-active {
    background: #111827;
    border-color: #111827;
    color: #fff;
}

.catalog-chip:hover span,
.catalog-chip.is-active span {
    background: rgba(255,255,255,.14);
    color: #fff;
}

.catalog-toolbar__sort {
    display: flex;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap;
}

.catalog-toolbar__sort-control .sort_title {
    display: none;
}

.catalog-toolbar__sort-control .select_sort {
    min-width: 240px;
    height: 46px;
    padding: 0 16px;
    border: 1px solid #e5e7eb;
    border-radius: 14px;
    background: #fff;
    font-size: 14px;
    box-shadow: none;
}

.catalog-toolbar__pagination {
    margin-left: auto;
}

.catalog-products {
    display: block;
}

.products-grid {
    display: grid !important;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 20px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.products-grid .products_item {
    margin: 0;
    width: 100%;
    min-width: 0;
}

.catalog-search-cats {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
}

.catalog-search-cats__item {
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: 16px;
    border-radius: 18px;
    background: #fff;
    border: 1px solid #eceff3;
    text-decoration: none;
    transition: .2s ease;
}

.catalog-search-cats__item:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 20px rgba(17,24,39,.06);
}

.catalog-search-cats__path {
    font-size: 12px;
    color: #9ca3af;
}

.catalog-search-cats__name {
    font-size: 15px;
    font-weight: 700;
    color: #111827;
}

.catalog-search-cats__count {
    font-size: 13px;
    color: #6b7280;
}

.catalog-empty {
    padding: 40px 24px;
    border: 1px solid #eceff3;
    border-radius: 24px;
    background: #fff;
}

.catalog-empty__title {
    margin-bottom: 8px;
    font-size: 28px;
    font-weight: 800;
    color: #111827;
}

.catalog-empty__text {
    margin-bottom: 20px;
    max-width: 760px;
    font-size: 15px;
    line-height: 1.7;
    color: #6b7280;
}

.catalog-seo {
    padding: 24px;
    border-radius: 24px;
    background: #fafbfc;
    border: 1px solid #eceff3;
}

.catalog-seo--full h2 {
    margin-top: 0;
}

@media (max-width: 1199px) {
    .products-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .catalog-search-cats {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 991px) {
    .catalog-page__head {
        flex-direction: column;
    }

    .catalog-page__head-side {
        justify-content: flex-start;
    }

    .products-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .catalog-search-cats {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .catalog-toolbar__row,
    .catalog-toolbar__row--bottom {
        flex-direction: column;
        align-items: stretch;
    }

    .catalog-toolbar__pagination {
        margin-left: 0;
    }
}

@media (max-width: 640px) {
    .catalog-page {
        gap: 18px;
    }

    .catalog-page__head,
    .catalog-toolbar,
    .catalog-seo,
    .catalog-empty {
        padding: 16px;
        border-radius: 18px;
    }

    .catalog-page__title {
        font-size: 26px;
    }

    .products-grid,
    .catalog-search-cats {
        grid-template-columns: 1fr;
        gap: 14px;
    }

    .catalog-toolbar__sort-control .select_sort {
        width: 100%;
        min-width: 100%;
    }
}


.catalog-filters-compact {
    margin-bottom: 20px;
}

.catalog-filters-compact__toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 14px 18px;
    border: 1px solid #eceff3;
    border-radius: 18px;
    background: #fff;
    box-shadow: 0 10px 30px rgba(17, 24, 39, 0.04);
}

.catalog-filters-compact__left,
.catalog-filters-compact__right {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}

.catalog-filters-compact__toggle {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    height: 44px;
    padding: 0 16px;
    border: 1px solid #e5e7eb;
    border-radius: 999px;
    background: #111827;
    color: #fff;
    font-size: 14px;
    font-weight: 700;
    cursor: pointer;
    transition: .2s ease;
}

.catalog-filters-compact__toggle:hover {
    background: #1f2937;
}

.catalog-filters-compact__toggle.is-open svg {
    transform: rotate(180deg);
}

.catalog-filters-compact__toggle svg {
    transition: transform .2s ease;
}

.catalog-filters-compact__reset {
    display: inline-flex;
    align-items: center;
    height: 44px;
    padding: 0 16px;
    border: 1px solid #e5e7eb;
    border-radius: 999px;
    background: #fff;
    color: #111827;
    text-decoration: none;
    font-size: 14px;
    font-weight: 600;
    transition: .2s ease;
}

.catalog-filters-compact__reset:hover {
    border-color: #d1d5db;
    background: #f9fafb;
}

.catalog-filters-compact__count {
    font-size: 14px;
    color: #6b7280;
}

.catalog-filters-compact__count b {
    color: #111827;
}

.catalog-filters-compact__panel {
    display: none;
    margin-top: 14px;
}

.catalog-filters-compact__panel.is-open {
    display: block;
}

.catalog-filters-compact__panel-inner {
    display: flex;
    flex-direction: column;
    gap: 18px;
    padding: 18px;
    border: 1px solid #eceff3;
    border-radius: 22px;
    background: #fff;
    box-shadow: 0 10px 30px rgba(17, 24, 39, 0.04);
}

.catalog-filter-group {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.catalog-filter-group--slider {
    padding: 14px;
    border: 1px solid #f1f3f5;
    border-radius: 18px;
    background: #fbfcfd;
}

.catalog-filter-group__title {
    font-size: 14px;
    font-weight: 800;
    color: #111827;
    line-height: 1.3;
}

.catalog-filter-group__chips {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.catalog-chip-filter {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 38px;
    padding: 8px 14px;
    border: 1px solid #e5e7eb;
    border-radius: 999px;
    background: #fff;
    color: #111827;
    text-decoration: none;
    font-size: 13px;
    line-height: 1.2;
    transition: .2s ease;
}

.catalog-chip-filter:hover,
.catalog-chip-filter.is-active {
    background: #111827;
    color: #fff;
    border-color: #111827;
}

.catalog-filter-group__slider {
    margin: 4px 0 2px;
}

.catalog-filter-group__range {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}

.catalog-filter-group__range-item {
    display: flex;
    flex-direction: column;
    gap: 6px;
    min-width: 140px;
    flex: 1 1 0;
}

.catalog-filter-group__range-item span {
    font-size: 12px;
    font-weight: 700;
    color: #6b7280;
    text-transform: uppercase;
    letter-spacing: .04em;
}

.catalog-filter-group__range-item input {
    width: 100%;
    height: 42px;
    padding: 0 12px;
    border: 1px solid #e5e7eb;
    border-radius: 12px;
    background: #fff;
    font-size: 14px;
    color: #111827;
    box-sizing: border-box;
}

.catalog-filter-group__reset {
    display: inline-flex;
    align-items: center;
    color: #2563eb;
    text-decoration: none;
    font-size: 14px;
    font-weight: 600;
}

.catalog-filter-group__reset:hover {
    text-decoration: underline;
}

@media (max-width: 767px) {
    .catalog-filters-compact__toolbar {
        flex-direction: column;
        align-items: stretch;
        padding: 14px;
    }

    .catalog-filters-compact__left,
    .catalog-filters-compact__right {
        width: 100%;
        justify-content: space-between;
    }

    .catalog-filters-compact__toggle,
    .catalog-filters-compact__reset {
        min-height: 42px;
    }

    .catalog-filters-compact__panel-inner {
        padding: 14px;
        border-radius: 18px;
    }

    .catalog-filter-group__chips {
        gap: 8px;
    }

    .catalog-chip-filter {
        font-size: 12px;
        padding: 8px 12px;
    }
}


  .pPage {
    --bg: #ffffff;
    --bg-soft: #f6f8fb;
    --bg-card: rgba(255,255,255,.82);
    --text: #101828;
    --text-2: #475467;
    --line: #e7ecf3;
    --line-2: #d8e0ea;
    --accent: #111827;
    --accent-2: #2563eb;
    --success: #12b76a;
    --danger: #f04438;
    --shadow: 0 10px 30px rgba(16,24,40,.08);
    --shadow-lg: 0 20px 50px rgba(16,24,40,.12);
    --radius: 24px;
    --radius-md: 18px;
    --radius-sm: 14px;
  }

  .pPage * { box-sizing: border-box; }

  .pPage {
    color: var(--text);
  }

  .pPage__top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 18px;
  }

  .pPage__crumbs {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    color: var(--text-2);
    font-size: 13px;
    line-height: 1.4;
  }

  .pPage__crumbs a {
    color: inherit;
    text-decoration: none;
    transition: .2s ease;
  }

  .pPage__crumbs a:hover {
    color: var(--accent-2);
  }

 .pPage__grid {
  display: grid;
  grid-template-columns: minmax(0, .88fr) minmax(380px, 1.12fr);
  gap: 28px;
  align-items: start;
}

  .pGallery {
    position: relative;
  }

  .pGallery__card,
  .pInfo__card,
  .pTabs,
  .pFeatureCard {
    background: var(--bg-card);
    border: 1px solid rgba(255,255,255,.5);
    box-shadow: var(--shadow);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
  }

  .pGallery__card {
    border-radius: calc(var(--radius) + 4px);
    overflow: hidden;
    padding: 16px;
    background:
      radial-gradient(circle at top right, rgba(37,99,235,.08), transparent 30%),
      radial-gradient(circle at bottom left, rgba(17,24,39,.05), transparent 25%),
      #fff;
  }

  .pGallery__main {
    position: relative;
    display: block;
    border-radius: 22px;
    overflow: hidden;
    background:
      linear-gradient(180deg, #f8fafc 0%, #eef3f8 100%);
    aspect-ratio: 1 / 1;
    border: 1px solid var(--line);
    box-shadow: inset 0 1px 0 rgba(255,255,255,.7);
  }

  .pGallery__main img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: contain;
    transition: transform .45s ease;
  }

  .pGallery__main:hover img {
    transform: scale(1.035);
  }

  .pGallery__main--noimg::before {
    content: "Нет изображения";
    position: absolute;
    inset: 0;
    display: grid;
    place-items: center;
    color: var(--text-2);
    font-size: 15px;
  }

  .pBadgeStack {
    position: absolute;
    top: 14px;
    left: 14px;
    z-index: 3;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    pointer-events: none;
  }

  .pBadge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    min-height: 34px;
    padding: 0 12px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: .02em;
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    box-shadow: 0 6px 20px rgba(16,24,40,.12);
  }

  .pBadge--sale {
    background: rgba(240,68,56,.12);
    color: #b42318;
    border: 1px solid rgba(240,68,56,.16);
  }

  .pBadge--stock {
    background: rgba(18,183,106,.12);
    color: #027a48;
    border: 1px solid rgba(18,183,106,.16);
  }

  .pGallery__thumbs {
    margin-top: 14px;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(76px, 1fr));
    gap: 10px;
  }

  .pThumb {
    position: relative;
    display: block;
    border-radius: 18px;
    overflow: hidden;
    border: 1px solid var(--line);
    background: #fff;
    aspect-ratio: 1 / 1;
    transition: .22s ease;
    box-shadow: 0 6px 18px rgba(16,24,40,.05);
  }

  .pThumb:hover {
    transform: translateY(-2px);
    border-color: var(--line-2);
    box-shadow: 0 12px 24px rgba(16,24,40,.1);
  }

  .pThumb img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
  }

  .pInfo {
    position: relative;
  }

  .pInfo__sticky {
    position: sticky;
    top: 18px;
  }

  .pInfo__card {
    border-radius: 28px;
    padding: 24px;
    background:
      radial-gradient(circle at top right, rgba(37,99,235,.08), transparent 34%),
      #fff;
  }

  .pInfo__metaTop {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 12px;
  }

  .pChip {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    padding: 0 12px;
    border-radius: 999px;
    background: var(--bg-soft);
    color: var(--text-2);
    font-size: 13px;
    font-weight: 600;
  }

  .pInfo__h1 {
    margin: 0 0 14px;
    font-size: clamp(28px, 3vw, 42px);
    line-height: 1.04;
    letter-spacing: -.03em;
    font-weight: 800;
  }

  .pInfo__brand,
  .pInfo__sku {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
    margin-bottom: 14px;
    color: var(--text-2);
    font-size: 14px;
  }

  .pInfo__brand a {
    color: var(--accent);
    text-decoration: none;
    font-weight: 700;
  }

  .pInfo__brand a:hover {
    color: var(--accent-2);
  }

  .muted {
    color: var(--text-2);
  }

  .hidden {
    display: none !important;
  }

  .pInfo__rating {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
    margin-bottom: 16px;
  }

  .stars {
    position: relative;
    width: 70px;
    height: 14px;
    background:
      linear-gradient(90deg, #d0d5dd 20%, transparent 20%) 0 50%/14px 14px repeat-x;
    mask: none;
    border-radius: 99px;
    overflow: hidden;
    background-color: #eaecf0;
  }

  .stars__on {
    display: block;
    height: 100%;
    background: linear-gradient(90deg, #f59e0b, #fbbf24);
    border-radius: 99px;
  }

  .pInfo__ann {
    margin: 0 0 20px;
    color: var(--text-2);
    font-size: 15px;
    line-height: 1.72;
  }

  .pBuy {
    border: 1px solid var(--line);
    border-radius: 24px;
    background:
      linear-gradient(180deg, rgba(248,250,252,.9), rgba(255,255,255,1));
    padding: 18px;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.85);
  }

  .pBuy__row {
    margin-bottom: 16px;
  }

  .pBuy__lbl {
    display: block;
    margin-bottom: 8px;
    font-size: 13px;
    color: var(--text-2);
    font-weight: 600;
  }

  .pBuy__select {
    width: 100%;
    height: 52px;
    border-radius: 16px;
    border: 1px solid var(--line);
    background: #fff;
    padding: 0 16px;
    color: var(--text);
    font-size: 15px;
    outline: none;
    transition: .2s ease;
  }

  .pBuy__select:focus {
    border-color: rgba(37,99,235,.38);
    box-shadow: 0 0 0 4px rgba(37,99,235,.08);
  }

  .pBuy__price {
    display: flex;
    align-items: flex-end;
    gap: 12px;
    flex-wrap: wrap;
    margin-bottom: 14px;
  }

  .pBuy__old {
    font-size: 16px;
    color: #98a2b3;
    text-decoration: line-through;
  }

  .pBuy__now {
    display: flex;
    align-items: baseline;
    gap: 6px;
    font-weight: 800;
    font-size: clamp(28px, 2.7vw, 38px);
    letter-spacing: -.03em;
    color: var(--text);
  }

  .pBuy__sub {
    margin: -2px 0 14px;
    font-size: 13px;
    color: var(--text-2);
  }

  .pBuy__controls {
    display: grid;
    grid-template-columns: auto auto 1fr;
    gap: 12px;
    align-items: center;
  }

  .pBuy__stock {
    min-width: max-content;
  }

  .stockOk,
  .stockNo {
    display: inline-flex;
    align-items: center;
    min-height: 44px;
    padding: 0 14px;
    border-radius: 999px;
    font-size: 13px;
    font-weight: 700;
    white-space: nowrap;
  }

  .stockOk {
    color: #067647;
    background: rgba(18,183,106,.12);
    border: 1px solid rgba(18,183,106,.16);
  }

  .stockNo {
    color: #b42318;
    background: rgba(240,68,56,.1);
    border: 1px solid rgba(240,68,56,.16);
  }

  .pBuy__qty {
    height: 48px;
    min-width: 132px;
    border-radius: 16px;
    border: 1px solid var(--line);
    background: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: space-between;
    overflow: hidden;
  }

  .counter_block.amount .minus,
  .counter_block.amount .plus {
    width: 44px;
    height: 48px;
    display: grid;
    place-items: center;
    cursor: pointer;
    user-select: none;
    font-size: 20px;
    color: var(--text);
    transition: .2s ease;
  }

  .counter_block.amount .minus:hover,
  .counter_block.amount .plus:hover {
    background: var(--bg-soft);
  }

  .counter_block.amount .input_amount {
    width: 44px;
    border: 0;
    background: transparent;
    text-align: center;
    outline: none;
    font-size: 15px;
    color: var(--text);
  }

  .pBuy__btn,
  .btnGhost {
    min-height: 52px;
    border-radius: 16px;
    padding: 0 22px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    text-decoration: none;
    font-weight: 800;
    font-size: 15px;
    transition: .22s ease;
    cursor: pointer;
  }

  .pBuy__btn.btn,
  .pBuy__btn {
    width: 100%;
  }

  .pBuy__btn.btn,
  .btn.pBuy__btn {
    border: 0;
    color: #fff;
    background: linear-gradient(135deg, #111827, #2563eb);
    box-shadow: 0 12px 24px rgba(37,99,235,.22);
  }

  .pBuy__btn.btn:hover,
  .btn.pBuy__btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 16px 28px rgba(37,99,235,.26);
  }

  .btnGhost {
    border: 1px solid var(--line);
    background: #fff;
    color: var(--text);
  }

  .btnGhost:hover {
    transform: translateY(-1px);
    border-color: var(--line-2);
    box-shadow: 0 10px 20px rgba(16,24,40,.08);
  }

  .pTrust {
    margin-top: 18px;
    display: grid;
    gap: 10px;
  }

  .pTrust__item {
    display: flex;
    align-items: center;
    gap: 10px;
    color: var(--text-2);
    font-size: 14px;
  }

  .pTrust__dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: linear-gradient(135deg, #111827, #2563eb);
    flex: 0 0 10px;
  }

  .pTabsWrap {
    margin-top: 28px;
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 18px;
  }

  .pTabs {
    border-radius: 28px;
    padding: 10px;
    background:
      radial-gradient(circle at top left, rgba(37,99,235,.08), transparent 25%),
      #fff;
  }

  .pTabs__nav {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    padding: 6px;
    margin-bottom: 10px;
  }

  .pTabs__btn {
    appearance: none;
    border: 0;
    background: transparent;
    min-height: 48px;
    padding: 0 18px;
    border-radius: 14px;
    color: var(--text-2);
    font-size: 14px;
    font-weight: 700;
    cursor: pointer;
    transition: .22s ease;
  }

  .pTabs__btn:hover {
    background: var(--bg-soft);
    color: var(--text);
  }

  .pTabs__btn.is-on {
    background: linear-gradient(135deg, #111827, #2563eb);
    color: #fff;
    box-shadow: 0 10px 20px rgba(37,99,235,.18);
  }

  .pTabs__panel {
    display: none;
    padding: 18px;
    border-radius: 20px;
    background: #fff;
    border: 1px solid var(--line);
  }

  .pTabs__panel.is-on {
    display: block;
    animation: tabFade .22s ease;
  }

  @keyframes tabFade {
    from { opacity: 0; transform: translateY(4px); }
    to { opacity: 1; transform: translateY(0); }
  }

  .pTabs .text {
    color: var(--text);
    line-height: 1.75;
    font-size: 15px;
  }

  .pTabs .text img,
  .pTabs .text iframe,
  .pTabs .text table {
    max-width: 100%;
  }

  .pFeat {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 10px;
  }

  .pFeat__li {
    display: grid;
    grid-template-columns: minmax(140px, 240px) minmax(0, 1fr);
    gap: 16px;
    align-items: start;
    padding: 14px 16px;
    border-radius: 16px;
    background: var(--bg-soft);
    border: 1px solid #edf1f7;
  }

  .pFeat__k {
    color: var(--text-2);
    font-weight: 600;
  }

  .pFeat__v {
    color: var(--text);
    font-weight: 600;
  }

  .pFeatureGrid {
    margin-top: 18px;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
  }

  .pFeatureCard {
    border-radius: 22px;
    padding: 18px;
    background: #fff;
  }

  .pFeatureCard__title {
    margin: 0 0 8px;
    font-size: 16px;
    font-weight: 800;
  }

  .pFeatureCard__text {
    margin: 0;
    color: var(--text-2);
    line-height: 1.65;
    font-size: 14px;
  }

  @media (max-width: 1200px) {
    .pPage__grid {
      grid-template-columns: minmax(0, 1fr) 420px;
      gap: 22px;
    }
  }

  @media (max-width: 980px) {
    .pPage__grid {
      grid-template-columns: 1fr;
    }

    .pInfo__sticky {
      position: static;
      top: auto;
    }

    .pFeatureGrid {
      grid-template-columns: 1fr;
    }
  }

  @media (max-width: 680px) {
    .pPage__top {
      flex-direction: column;
      align-items: flex-start;
    }

    .pGallery__card,
    .pInfo__card,
    .pTabs {
      border-radius: 22px;
    }

    .pGallery__card,
    .pInfo__card {
      padding: 14px;
    }

    .pInfo__h1 {
      font-size: 28px;
    }

    .pBuy {
      padding: 14px;
      border-radius: 18px;
    }

    .pBuy__controls {
      grid-template-columns: 1fr;
    }

    .pBuy__qty,
    .pBuy__btn,
    .btnGhost {
      width: 100%;
    }

    .pBuy__stock {
      min-width: 0;
    }

    .pFeat__li {
      grid-template-columns: 1fr;
      gap: 6px;
    }

    .pTabs__panel {
      padding: 14px;
    }

    .pGallery__thumbs {
      grid-template-columns: repeat(4, minmax(0, 1fr));
    }
  }

  @media (max-width: 480px) {
    .pGallery__thumbs {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .pInfo__card {
      padding: 12px;
    }

    .pBuy__now {
      font-size: 30px;
    }
  }
  
  
  
  
  .autocomplete-suggestions {
    background: #fff;
    border: 1px solid #e5e5e5;
    border-radius: 12px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08);
    overflow: hidden;
    margin-top: 6px;
    z-index: 9999;
}

.autocomplete-suggestion {
    padding: 0;
    cursor: pointer;
    border-bottom: 1px solid #f3f3f3;
}

.autocomplete-suggestion:last-child {
    border-bottom: none;
}

.autocomplete-selected {
    background: #f8f8f8;
}

.search-suggestion {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 12px;
}

.search-suggestion__image {
    width: 40px;
    height: 40px;
    flex: 0 0 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    border-radius: 8px;
    background: #f7f7f7;
}

.search-suggestion__image img {
    max-width: 100%;
    max-height: 100%;
    display: block;
}

.search-suggestion__image--empty {
    background: #f3f3f3;
}

.search-suggestion__body {
    min-width: 0;
    flex: 1;
}

.search-suggestion__title {
    font-size: 14px;
    line-height: 1.3;
    color: #111;
    margin-bottom: 4px;
}

.search-suggestion__title strong {
    font-weight: 700;
}

.search-suggestion__price {
    font-size: 13px;
    color: #666;
}




/* =========================
   CART PAGE
========================= */

.cart_page {
    padding: 28px 0 56px;
}

.cart_page_header {
    margin-bottom: 28px;
}

.cart_page_subtitle {
    margin-top: 10px;
    color: #7b8190;
    font-size: 15px;
    line-height: 1.5;
}

.cart_layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 380px;
    gap: 24px;
    align-items: start;
}

.cart_main {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.cart_sidebar {
    position: sticky;
    top: 24px;
}

.cart_section,
.cart_summary_card,
.cart_products_card,
.delivery.block,
.cart_empty_card {
    background: #fff;
    border: 1px solid rgba(16, 24, 40, 0.06);
    border-radius: 24px;
    box-shadow: 0 12px 40px rgba(17, 24, 39, 0.06);
}

.cart_section {
    padding: 0;
}

.cart_summary_card {
    padding: 24px;
}

.cart_summary_head {
    margin-bottom: 20px;
}

.heading_box_sidebar {
    margin-bottom: 8px;
}

.cart_summary_note,
.cart_section_desc {
    color: #8b93a6;
    font-size: 14px;
    line-height: 1.5;
}

.cart_message {
    margin-bottom: 18px;
}

.cart_form_grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
}

.form_group_full {
    grid-column: 1 / -1;
}

.cart_field_label {
    display: block;
    margin-bottom: 8px;
    font-size: 13px;
    font-weight: 600;
    color: #2d3445;
}

.form_input,
.form_textarea,
.input_coupon,
.input_amount {
    width: 100%;
    border: 1px solid #dfe3eb;
    border-radius: 14px;
    background: #f8fafc;
    color: #111827;
    transition: 0.25s ease;
}

.form_input,
.input_coupon {
    height: 52px;
    padding: 0 16px;
}

.form_textarea {
    padding: 14px 16px;
    resize: vertical;
    min-height: 120px;
}

.form_input:focus,
.form_textarea:focus,
.input_coupon:focus,
.input_amount:focus {
    outline: none;
    border-color: #c7a65a;
    background: #fff;
    box-shadow: 0 0 0 4px rgba(199, 166, 90, 0.12);
}

.cart_captcha_wrap {
    margin-top: 18px;
}

.cart_default_captcha {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.secret_number {
    display: inline-flex;
    align-items: center;
    min-height: 46px;
    padding: 10px 14px;
    border-radius: 12px;
    background: #f6f7fb;
    color: #2d3445;
    font-weight: 600;
}

.cart_submit_wrap {
    margin-top: 22px;
}

.cart_submit_btn {
    width: 100%;
    height: 56px;
    border-radius: 16px;
    font-size: 15px;
    font-weight: 700;
    box-shadow: 0 14px 30px rgba(199, 166, 90, 0.22);
}

/* =========================
   PRODUCTS
========================= */

.cart_products_card {
    overflow: hidden;
}

.cart_products_head {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 150px 150px 48px;
    gap: 16px;
    padding: 20px 24px;
    border-bottom: 1px solid #eef1f6;
    background: #fafbfd;
    font-size: 13px;
    font-weight: 700;
    color: #667085;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.cart_products_body {
    padding: 8px 24px 0;
}

.cart_product_item {
    display: grid;
    grid-template-columns: 120px minmax(0, 1fr) 150px 150px 48px;
    gap: 16px;
    align-items: center;
    padding: 20px 0;
    border-bottom: 1px solid #eef1f6;
}

.cart_product_image {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 108px;
    height: 108px;
    border-radius: 20px;
    background: #f8fafc;
    overflow: hidden;
}

.cart_product_image img {
    max-width: 100%;
    max-height: 100%;
    object-fit: cover;
}

.cart_product_info {
    min-width: 0;
}

.cart_product_name {
    display: block;
    margin-bottom: 8px;
    color: #121926;
    font-size: 18px;
    font-weight: 700;
    line-height: 1.35;
    text-decoration: none;
}

.cart_product_name:hover {
    color: #c7a65a;
}

.cart_product_variant {
    margin-bottom: 8px;
    color: #7d8596;
    font-size: 14px;
}

.cart_product_price {
    color: #111827;
    font-size: 15px;
    font-weight: 600;
}

.cart_product_qty,
.cart_product_total,
.cart_product_remove {
    display: flex;
    justify-content: center;
    align-items: center;
}

.cart_product_total {
    font-size: 18px;
    font-weight: 700;
    color: #111827;
}

.cart_product_remove a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    border-radius: 12px;
    background: #f6f7fb;
    transition: 0.25s ease;
}

.cart_product_remove a:hover {
    background: #fff1f2;
    transform: translateY(-1px);
}

.cart_product_remove svg,
.cart_product_remove path {
    width: 18px;
    height: 18px;
}

.cart_amount.amount {
    display: inline-flex;
    align-items: center;
    justify-content: space-between;
    width: 128px;
    height: 48px;
    padding: 0 10px;
    border: 1px solid #e3e8f0;
    border-radius: 999px;
    background: #fafbfd;
}

.cart_amount .minus,
.cart_amount .plus {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    cursor: pointer;
    transition: 0.2s ease;
    color: #3b4252;
}

.cart_amount .minus:hover,
.cart_amount .plus:hover {
    background: #eceff5;
}

.cart_amount .input_amount {
    width: 42px;
    height: 36px;
    border: 0;
    background: transparent;
    text-align: center;
    font-size: 15px;
    font-weight: 700;
    padding: 0;
    box-shadow: none;
}

.cart_totals_box {
    padding: 24px;
    background: linear-gradient(180deg, #fff 0%, #fbfcfe 100%);
}

.cart_total_row {
    display: flex;
    justify-content: space-between;
    gap: 20px;
    padding: 10px 0;
    color: #2d3445;
    font-size: 15px;
}

.cart_total_row_final {
    margin-top: 10px;
    padding-top: 18px;
    border-top: 1px solid #e9edf3;
    font-size: 18px;
    font-weight: 700;
}

.cart_total_label {
    color: #667085;
}

.cart_total_row_final .cart_total_label,
.cart_total_row_final .cart_total_value {
    color: #111827;
}

.cart_coupon_wrap {
    margin-top: 18px;
    margin-bottom: 8px;
}

.cart_coupon_form {
    display: flex;
    gap: 10px;
    margin-top: 12px;
}

.coupon_button {
    height: 52px;
    padding: 0 20px;
    border: 0;
    border-radius: 14px;
    background: #111827;
    color: #fff;
    font-weight: 700;
    cursor: pointer;
    transition: 0.25s ease;
}

.coupon_button:hover {
    transform: translateY(-1px);
    opacity: 0.92;
}

/* =========================
   DELIVERY / PAYMENT
========================= */

.cart_section_header {
    margin-bottom: 14px;
}

.delivery_cards {
    padding: 20px;
}

.delivery_cards_list {
    display: grid;
    gap: 14px;
}

.delivery_card {
    border: 1px solid #e7ebf2;
    border-radius: 20px;
    background: #fcfdff;
    padding: 0;
    overflow: hidden;
    transition: 0.25s ease;
}

.delivery_card:hover {
    border-color: #d5dbe6;
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.05);
}

.delivery_label {
    display: block;
    position: relative;
    padding: 18px 20px;
    cursor: pointer;
}

.delivery_label.active {
    background: linear-gradient(180deg, rgba(199,166,90,0.08) 0%, rgba(199,166,90,0.03) 100%);
}

.input_delivery {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.delivery_name {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}

.delivery_name_main {
    display: flex;
    align-items: center;
    gap: 14px;
    min-width: 0;
}

.delivery_logo_wrap {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 40px;
    border-radius: 12px;
    background: #fff;
    border: 1px solid #eef1f5;
    flex-shrink: 0;
}

.delivery_logo_wrap img {
    max-width: 42px;
    max-height: 24px;
    object-fit: contain;
}

.delivery_title {
    color: #121926;
    font-size: 16px;
    font-weight: 700;
    line-height: 1.4;
}

.delivery_price_badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 38px;
    padding: 8px 14px;
    border-radius: 999px;
    background: #f3f6fb;
    color: #111827;
    font-size: 14px;
    font-weight: 700;
    white-space: nowrap;
}

.delivery_description {
    padding: 0 20px 18px;
    color: #7a8394;
    font-size: 14px;
    line-height: 1.6;
}

.delivery_payment_wrap {
    margin-top: 20px;
}

/* =========================
   EMPTY STATE
========================= */

.cart_empty_state {
    padding: 20px 0 40px;
}

.cart_empty_card {
    max-width: 620px;
    margin: 0 auto;
    padding: 40px 28px;
    text-align: center;
}

.cart_empty_text {
    margin-top: 12px;
    color: #7a8394;
    font-size: 15px;
    line-height: 1.6;
}

.cart_empty_btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-top: 24px;
    min-width: 220px;
    height: 54px;
    border-radius: 16px;
}

/* =========================
   ALERTS
========================= */

.message_error,
.message_success {
    padding: 14px 16px;
    border-radius: 14px;
    font-size: 14px;
    line-height: 1.5;
}

.message_error {
    background: #fef2f2;
    border: 1px solid #fecaca;
    color: #b42318;
}

.message_success {
    background: #ecfdf3;
    border: 1px solid #abefc6;
    color: #027a48;
}

/* =========================
   RESPONSIVE
========================= */

@media (max-width: 1199px) {
    .cart_layout {
        grid-template-columns: 1fr;
    }

    .cart_sidebar {
        position: static;
    }
}

@media (max-width: 991px) {
    .cart_form_grid {
        grid-template-columns: 1fr;
    }

    .cart_product_item {
        grid-template-columns: 96px minmax(0, 1fr);
        grid-template-areas:
            "image info"
            "image qty"
            "image total"
            "image remove";
        align-items: start;
        gap: 12px 16px;
    }

    .cart_product_media {
        grid-area: image;
    }

    .cart_product_info {
        grid-area: info;
    }

    .cart_product_qty {
        grid-area: qty;
        justify-content: flex-start;
    }

    .cart_product_total {
        grid-area: total;
        justify-content: flex-start;
    }

    .cart_product_remove {
        grid-area: remove;
        justify-content: flex-start;
    }

    .cart_product_image {
        width: 88px;
        height: 88px;
        border-radius: 18px;
    }

    .cart_products_body {
        padding: 8px 18px 0;
    }

    .cart_totals_box {
        padding: 20px 18px;
    }

    .delivery_name {
        flex-direction: column;
        align-items: flex-start;
    }

    .delivery_price_badge {
        align-self: flex-start;
    }

    .cart_coupon_form {
        flex-direction: column;
    }

    .coupon_button {
        width: 100%;
    }
}

@media (max-width: 767px) {
    .cart_page {
        padding: 18px 0 36px;
    }

    .cart_products_card,
    .cart_summary_card,
    .delivery.block,
    .cart_empty_card {
        border-radius: 18px;
    }

    .cart_product_name {
        font-size: 16px;
    }

    .cart_product_price,
    .cart_total_row,
    .delivery_title {
        font-size: 14px;
    }

    .cart_product_total {
        font-size: 16px;
    }

    .cart_submit_btn {
        height: 52px;
    }

    .delivery_label {
        padding: 16px;
    }

    .delivery_description {
        padding: 0 16px 16px;
    }
}



/* =========================
   BUY BUTTON / CART ANIMATION
========================= */

#cart_informer {
    position: relative;
}

#cart_informer.is-added {
    animation: cartPulse 0.45s ease;
}

.cart_counter.is-bump,
.informer_counter.is-bump {
    animation: counterBump 0.45s ease;
}

.cart-fly-image {
    box-shadow: 0 18px 40px rgba(17, 24, 39, 0.18);
    object-fit: cover;
}

.js-buy-btn {
    position: relative;
    transition: transform 0.2s ease, box-shadow 0.2s ease, opacity 0.2s ease;
}

.js-buy-btn:hover {
    transform: translateY(-1px);
}

.js-buy-btn.is-loading {
    opacity: 0.85;
    pointer-events: none;
}

.js-buy-btn.is-added {
    background: #111827 !important;
    color: #fff !important;
}

@keyframes cartPulse {
    0%   { transform: scale(1); }
    35%  { transform: scale(1.08); }
    100% { transform: scale(1); }
}

@keyframes counterBump {
    0%   { transform: scale(1); }
    35%  { transform: scale(1.28); }
    100% { transform: scale(1); }
}



/* =========================
   CART INFORMER / BADGE
========================= */

#cart_informer {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

#cart_informer .mg-header__icon,
#cart_informer .cart_info {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
}

#cart_informer .mg-header__icon svg,
#cart_informer .cart_info svg {
    display: block;
}

#cart_informer .cart_info {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
}

#cart_informer .cart_counter,
#cart_informer .informer_counter {
    position: absolute;
    top: -6px;
    right: -8px;
    min-width: 20px;
    height: 20px;
    padding: 0 6px;
    border-radius: 999px;
    background: #ef4444;
    color: #ffffff;
    font-size: 11px;
    font-weight: 700;
    line-height: 20px;
    text-align: center;
    box-shadow: 0 6px 16px rgba(239, 68, 68, 0.35);
    border: 2px solid #ffffff;
    z-index: 3;
}

#cart_informer .cart_counter.is-bump,
#cart_informer .informer_counter.is-bump {
    animation: cartBadgePop 0.35s ease;
}

@keyframes cartBadgePop {
    0%   { transform: scale(1); }
    50%  { transform: scale(1.22); }
    100% { transform: scale(1); }
}