/* ==========================================================================
   Каталог пептидов (макет Figma)
   Цвета: dark blue #032279, gray #9295B6, border #D6DAF1, black #1C1C20, sidebar #5A5C70
   ========================================================================== */

   .catalog-page {
	box-sizing: border-box;
	background: #fff;
  }
  
  .catalog-page-inner {
	/* max-width: 1440px; */
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	gap: 30px;
  }
  
  /* РҐР»РµР±РЅС‹Рµ РєСЂРѕС€РєРё */
  .catalog-breadcrumb {
	font-family: 'Manrope', system-ui, sans-serif;
	font-size: 16px;
	line-height: 22px;
	color: #9295B6;
  }
  
  .catalog-breadcrumb a {
	color: #9295B6;
	text-decoration: none;
  }
  
  .catalog-breadcrumb a:hover {
	color: #032279;
	text-decoration: none;
  }
  
  .catalog-breadcrumb-sep {
	margin: 0 4px;
  }
  
  .catalog-breadcrumb-current {
	color: #1C1C20;
  }
  
  /* Р—Р°РіРѕР»РѕРІРѕРє + РїРѕРёСЃРє */
  .catalog-header-block {
	display: flex;
	align-items: flex-start;
	gap: 12px;
	justify-content: space-between;
  }
  
  .catalog-title {
	font-family: 'Manrope', system-ui, sans-serif;
	font-weight: 500;
	font-size: 60px;
	line-height: 1.13;
	color: #1C1C20;
	margin: 0;
  }
  
  .catalog-search-form {
	display: flex;
	align-items: center;
	box-sizing: border-box;
	padding: 16px 24px;
	gap: 10px;
	width: 100%;
	max-width: 348px;
	height: 60px;
	border: 1px solid #D6DAF1;
	border-radius: 72px;
	background: #fff;
  }
  
  .catalog-search-input {
	flex: 1;
	min-width: 0;
	border: 0;
	background: none;
	font-family: 'Manrope', system-ui, sans-serif;
	font-size: 20px;
	line-height: 28px;
	color: #1C1C20;
  }
  
  .catalog-search-input::placeholder {
	color: #9295B6;
  }
  
  .catalog-search-input:focus {
	outline: none;
  }
  
  .catalog-search-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0;
	border: 0;
	background: none;
	color: #73747C;
	cursor: pointer;
  }
  
  .catalog-search-btn:hover {
	color: #032279;
  }
  
  /* РўР°Р±С‹ РєР°С‚РµРіРѕСЂРёР№ */
  .catalog-tabs, .catalog-sidebar-content {
	width: 100%;
	/* margin: 0 -16px; */
	}
  
  .catalog-tabs-list {
	display: flex;
	justify-content: start;
	list-style: none;
	padding: 0;
	margin: 20px 0;
	gap: 14px;
	}
  
  .catalog-tab {
	display: flex;
	align-items: center;
	gap: 5px;
	padding: 15px 20px 15px 0px;
	border: none;
	border-radius: 50px;
	background: #ffffff;
	cursor: pointer;
	height: 72px;
	border: solid #D6DAF1 1px;
	overflow: hidden;
	width: max-content;
	font-weight: 700;
	font-size: 18px;
	line-height: 24px;
	letter-spacing: 0%;
	color: #032279;
  }
  
  .catalog-tab-label.all-tab {
	padding: 0 14px 0 28px;
  }
  
  .catalog-tab-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
  }
  
  .catalog-tab-icon img {
	width: 70px;
	height: 88px;
	object-fit: contain;
	display: block;
  }
  
  .catalog-tab:hover {
	text-decoration: none;
	background: #032279;
	color: white;
  }
  
  .catalog-tab.is-active {
	background: #032279;
	color: #fff;
	border-color: #032279;
  }
  
  .catalog-tab.is-active:hover {
	color: #fff;
	background: #031a5c;
  }
  
  /* Layout: СЃР°Р№РґР±Р°СЂ + СЃРµС‚РєР° */
  .catalog-layout {
	display: flex;
	flex-direction: row;
	align-items: flex-start;
	gap: 20px;
	margin-top: 25px;
	}
  
  /* РЎР°Р№РґР±Р°СЂ В«РќР°РїСЂР°РІР»РµРЅРёСЏВ» */
  .catalog-sidebar {
	flex: none;
	width: 305px;
	display: flex;
	flex-direction: column;
	gap: 12px;
  }
  
  .catalog-sidebar-title {
	font-family: 'Manrope', system-ui, sans-serif;
	font-weight: 700;
	font-size: 36px;
	line-height: 42px;
	color: #032279;
	margin: 0 0 0;
  }
  
  .catalog-sidebar-list {
	list-style: none;
	margin-top: 15px;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 0;
  }
  
  .catalog-sidebar-link {
	display: flex;
	align-items: center;
	padding: 13px;
	min-height: 60px;
	font-family: 'Manrope', system-ui, sans-serif;
	font-weight: 500;
	font-size: 24px;
	line-height: 28px;
	color: #5A5C70;
	text-decoration: none;
	transition: color 0.2s, font-weight 0.2s;
  }
  
  .catalog-sidebar-link:hover {
	text-decoration: none;
	color: #032279;
  }
  
  .catalog-sidebar-link.is-active {
	font-weight: 700;
	color: #032279;
	background: #fff;
	gap: 10px;
	padding: 13px 0 13px 23px;
  }
  
  .catalog-sidebar-link.is-active::before {
	content: '';
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: #032279;
	flex-shrink: 0;
  }
  
  /* РЎРµС‚РєР° РєР°СЂС‚РѕС‡РµРє */
  .catalog-content {
	flex: 1;
	min-width: 0;
  }
  
  .peptide-catalog {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 20px;
	list-style: none;
	margin: 0;
	padding: 0;
  }
  
  .peptide-card {
	margin: 0;
	position: relative;
  }
  
  .catalog-content .adns2_services_card {
	display: flex;
	flex-direction: column;
	position: relative;
	background: #fff;
	border-radius: 16px;
	overflow: hidden;
	height: 100%;
	min-height: 580px;
	/* box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06); */
	transition: box-shadow 0.2s, background-color 0.2s, color 0.2s;
  }
  
  .catalog-content .adns2_services_card a {
	text-decoration: none;
	display: flex;
	flex-direction: column;
	flex: 1 1 auto;
	min-height: 0;
	color: inherit;
  }
  
  .catalog-content .adns2_services_card:hover {
	background-color: #032279;
	box-shadow: 0 8px 24px rgba(3, 34, 121, 0.12);
  }
  
  .catalog-content .adns2_services_card:hover .adns2_services_card_content {
	color: #fff;
	background-color: #032279;
  }
  
  .catalog-content .adns2_services_card:hover .service-price__btn {
	background-color: #fff;
	color: #032279;
	justify-content: space-between;
  }
  
  .catalog-content .adns2_services_card:hover .service-price__btn-icon {
	display: flex;
  }
  
  /* Верх карточки — изображение или градиент */
  .catalog-content .adns2_services_img {
	height: 330px;
	border-radius: 16px;
  }
  
  .catalog-content .adns2_services_image {
	width: 100%;
	height: 100%;
	object-fit: contain;
	object-position: center;
	transition: 0.4s;
  }
  
  .catalog-content .adns2_services_placeholder {
	width: 100%;
	height: 100%;
	min-height: 200px;
  }
  
  /* Низ карточки — flex: равная высота блока в строке сетки, без обрезки контента */
  .catalog-content .adns2_services_card_content {
	padding: 20px;
	color: #032279;
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	gap: 15px;
	flex: 1 1 auto;
	min-height: 244px;
	position: relative;
	background: #fff;
  }
  
  .catalog-content .adns2_services_title {
	font-weight: 700;
	font-size: 24px;
	line-height: 28px;
	letter-spacing: 0%;
	white-space: nowrap;
	/* overflow: hidden; */
	text-overflow: ellipsis;
	}
  
  .catalog-content .adns2_services_description {
	font-weight: 400;
	font-size: 16px;
	line-height: 22px;
	letter-spacing: 0%;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	overflow: hidden;
	min-height: 44px;
  }
  
  .catalog-content .adns2_services_price {
	font-weight: 700;
	font-size: 20px;
	line-height: 24px;
	letter-spacing: 0%;
	min-height: 24px;
  }
  
  .catalog-content .service-price__btn {
	font-weight: 400;
	width: 100%;
	color: white;
	background: #032279;
	font-size: 18px;
	padding: 12px 24px;
	border-radius: 40px;
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 12px;
	border: none;
	margin-top: auto;
	margin-bottom: 15px;
  }
  
  .catalog-content .service-price__btn-icon {
	display: none;
	width: 24px;
	height: 24px;
	border-radius: 50%;
	border: 1px solid #032279;
	align-items: center;
	justify-content: center;
	flex: 0 0 24px;
  }
  
  .catalog-content .service-price__btn-icon img {
	width: 13px;
	height: 12px;
	display: block;
  }
  
  .catalog-content .service-price__btn-text {
	line-height: 1.3;
  }
  
  .peptide-card-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 14px 24px;
	min-height: 52px;
	background: #032279;
	border-radius: 40px;
	font-family: 'Manrope', system-ui, sans-serif;
	font-weight: 400;
	font-size: 20px;
	line-height: 28px;
	color: #fff;
	text-decoration: none;
	transition: background 0.2s;
	box-sizing: border-box;
  }
  
  .peptide-card-btn:hover {
	background: #031a5c;
	color: #fff;
	text-decoration: none;
  }
  
  /* РџСѓСЃС‚РѕР№ СЂРµР·СѓР»СЊС‚Р°С‚ */
  .catalog-no-results {
	text-align: center;
	padding: 3rem 1rem;
  }
  
  .catalog-no-results-title {
	font-family: 'Manrope', system-ui, sans-serif;
	font-weight: 700;
	font-size: 36px;
	color: #032279;
	margin: 0 0 1.5rem;
  }
  
  .catalog-no-results .peptide-card-btn {
	display: inline-flex;
	width: auto;
  }
  
  /* РџР°РіРёРЅР°С†РёСЏ РІ РєР°С‚Р°Р»РѕРіРµ */
  .catalog-content .nav-links {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin-top: 2rem;
	padding-top: 2rem;
	border-top: 1px solid #D6DAF1;
  }
  
  .catalog-content .nav-links a,
  .catalog-content .nav-links span {
	display: inline-block;
	padding: 0.5rem 1rem;
	font-family: 'Manrope', system-ui, sans-serif;
	color: #032279;
	text-decoration: none;
	border-radius: 8px;
  }
  
  .catalog-content .nav-links a:hover {
	background: #f0f2ff;
	text-decoration: none;
  }
  
  .catalog-content .nav-links .current {
	background: #032279;
	color: #fff;
  }
  
  .catalog-content .service-price__btn_mob-text {
	display: none;
  }
  
  /* ----- Адаптив до 991px ----- */
  @media (max-width: 991px) {
	.catalog-header-block {
	  gap: 18px;
	  flex-direction: column;
	}
  
	.catalog-page-inner {
	  gap: 24px;
	}
  
	.catalog-title {
	  font-size: 36px;
	  line-height: 1.1;
	}
  
	.catalog-search-form {
	  max-width: 100%;
	  width: 100%;
	}
  
	.catalog-tabs-list {
	  flex-wrap: nowrap;
	  overflow-x: auto;
	  overflow-y: hidden;
	  gap: 16px;
	  padding: 0 16px 8px;
	  -webkit-overflow-scrolling: touch;
	  scrollbar-width: none;
	  -ms-overflow-style: none;
	}
  
	.catalog-tabs-list::-webkit-scrollbar {
	  display: none;
	}
  
	.catalog-tab {
	  min-height: 58px;
	  font-size: 16px;
	  line-height: 22px;
	  flex-shrink: 0;
	  width: max-content;
	}
  
	.catalog-tab-icon img {
	  width: 54px;
	  height: 68px;
	}
  
	.catalog-layout {
	  flex-direction: column;
	  gap: 24px;
	  margin-top: 0;
	}
  
	.catalog-sidebar {
	  width: 100%;
	}
  
	.catalog-sidebar-title {
	  font-size: 30px;
	  line-height: 34px;
	}
  
	.catalog-sidebar-list {
	  flex-direction: row;
	  flex-wrap: nowrap;
	  gap: 16px;
	  overflow-x: scroll;
	  scrollbar-width: none;
	  -ms-overflow-style: none;
	}
  
	.catalog-sidebar-list::-webkit-scrollbar {
	  display: none;
	}
  
	.catalog-sidebar-link {
	  padding: 16px;
	  font-size: 24px;
	  min-height: 60px;
	  flex: 0 0 auto;
	  width: max-content;
	}
  
	.peptide-catalog {
	  grid-template-columns: repeat(2, minmax(0, 1fr));
	  gap: 10px;
	}
  
	.peptide-card {
	  min-width: 0;
	}
  
	.catalog-content .adns2_services_card {
	  min-height: 256px;
	}
  
	.catalog-content .adns2_services_img {
	  height: 256px;
	}
  
	.catalog-content .adns2_services_card_content {
	  flex: 1 1 auto;
	  min-height: 220px;
	  padding: 12px;
	  border-radius: 0 0 20px 20px;
	}
  
	.catalog-content .adns2_services_title {
	  font-size: 18px;
	  line-height: 20px;
	  white-space: normal;
	}
  
	.catalog-content .adns2_services_description {
	  -webkit-line-clamp: 2;
	  line-clamp: 2;
	}
  
	.catalog-content .adns2_services_price {
	  font-size: 16px;
	  line-height: 20px;
	}
  
	.catalog-content .service-price__btn {
	  padding: 10px 12px;
	  border-radius: 24px;
	  margin-bottom: 0;
	}
  
	/* Убираем hover-эффекты карточек на тач-устройствах */
	@media (hover: none) and (pointer: coarse) {
	  .catalog-content .adns2_services_card:hover {
		background-color: #fff;
		box-shadow: none;
	  }
  
	  .catalog-content .adns2_services_card:hover .adns2_services_card_content {
		color: #032279;
		background-color: #fff;
	  }
  
	  .catalog-content .adns2_services_card:hover .service-price__btn {
		background-color: #032279;
		color: #fff;
		justify-content: center;
	  }
  
	  .catalog-content .adns2_services_card:hover .service-price__btn-icon {
		display: none;
	  }
	}
  
	.peptide-single-content {
	  grid-template-columns: 1fr;
	}
  
	.catalog-content .link_arrow {
	  background-color: rgb(255 255 255 / 6%);
	  backdrop-filter: blur(11.5px);
	}
  
	.catalog-content .service-price__btn-text {
	  display: none;
	}
  
	.catalog-content .service-price__btn_mob-text {
	  display: block;
	}
  
	.catalog-page .adns2_container {
	  overflow: visible;
	}
	.catalog-tabs, .catalog-sidebar-content {
		margin: 0 -16px;
	}
  

  }
  
  /* РљР°СЂС‚РѕС‡РєР° РѕРґРЅРѕРіРѕ РїРµРїС‚РёРґР° (single) */
  .peptide-single-header {
	margin-bottom: 1.5rem;
  }
  
  .peptide-sku {
	margin: 0.25rem 0 0;
	font-size: 0.875rem;
	color: #666;
  }
  
  .peptide-sku code {
	background: #f0f0f0;
	padding: 0.15rem 0.4rem;
	border-radius: 3px;
  }
  
  .peptide-categories {
	margin: 0.25rem 0 0;
	font-size: 0.875rem;
  }
  
  .peptide-single-content {
	display: grid;
	gap: 2rem;
	grid-template-columns: 1fr 1.5fr;
	margin-bottom: 2rem;
  }
  
  .peptide-single-image img {
	width: 100%;
	height: auto;
	border-radius: 8px;
	border: 1px solid #e0e0e0;
  }
  
  .peptide-single-price {
	font-size: 1.5rem;
	font-weight: 700;
	color: #2271b1;
	margin: 0 0 1rem;
  }
  
  .peptide-single-nav {
	margin-top: 2rem;
	padding-top: 1.5rem;
	border-top: 1px solid #e0e0e0;
  }
  
  .peptide-single-nav a {
	color: inherit;
  }
  
  .peptide-single-nav a:hover {
	text-decoration: none;
	opacity: 0.8;
  }
  
  /* Общие стили для архивов: акции, блог, истории, направления */
  .content-archive .catalog-header-block {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 1rem;
  }
  
  .content-card-meta {
	font-family: 'Manrope', system-ui, sans-serif;
	font-weight: 400;
	font-size: 14px;
	line-height: 20px;
	color: #5A5C70;
	margin: 0;
  }
  
  .content-single-meta {
	margin: 0.25rem 0 0;
	font-size: 0.875rem;
	color: #666;
  }
  .catalog-no-results-btn {
	margin-top: 20px;
	display: flex;
	justify-content: center;
	}
  .catalog-no-results-btn .btn3 {
	width: fit-content;
  }