.underline__highlighter {
  background-color: #EA6852;
}

.breadcrumbs {
  background-color: rgba(0, 98, 175, 0.3);

  .breadcrumbs__item {
    color: white;
  }

  .breadcrumbs__item::after {
    filter: brightness(0) invert(1);
  }
}

.span__top-index {
  font-size: 1rem;
  vertical-align: top;
  top: -0.3em;
  position: relative;
  font-weight: 600;
}

.source__footnote {
  display: block;
  margin-bottom: 14px;
}

.isosource__title {
  font-family: 'Inter', sans-serif;
  font-size: 3.2rem;
  font-weight: 700;
  color: #2E3F78;
  margin-top: 80px;
  max-width: 680px;
  text-align: center;
  line-height: 120%;
  margin-bottom: 40px;
}
.isosource__subtitle {
  font-size: 2rem;
  color: var(--graphite-black);
  text-align: center;
  margin-top: 40px;
  line-height: 140%;
}

.products {
  position: relative;
  width: 100%;
  max-width: 1100px;
  margin: 56px auto 0 auto;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 24px 16px;
  align-items: stretch;
}
.products__item {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  min-width: 0;
  cursor: pointer;
}
@media (min-width: 1025px) {
  .products__popup {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 24px;
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 321px;
    padding: 24px;
    box-sizing: border-box;
    background: rgba(233, 243, 255, 0.95);
    -webkit-backdrop-filter: blur(16px);
    backdrop-filter: blur(16px);
    border-radius: 24px;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
    z-index: 10;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.2s ease, visibility 0.2s ease;
  }
  .products__item:hover .products__popup,
  .products__item.is-active .products__popup {
    opacity: 1;
    visibility: visible;
  }
  .products__popup .underline__highlighter {
    left: 50% !important;
    transform: translateX(-50%) !important;
  }
  .products__item_standart .products__popup .underline__highlighter { background-color: #DDBF90; }
  .products__item_protein .products__popup .underline__highlighter { background-color: #538CCF; }
  .products__item_energy .products__popup .underline__highlighter { background-color: #DB1134; }
  .products__item_diabet .products__popup .underline__highlighter { background-color: #922C97; }
  .products__popup-title {
    margin: 0;
    font-family: 'Inter', sans-serif;
    font-weight: 700;
    font-size: 1.8rem;
    line-height: 120%;
    text-align: center;
    text-transform: uppercase;
    color: #2E3F78;
  }
  .products__popup .products__badge {
    display: inline-block;
    padding: 6px 10px;
    border-radius: 4px;
    font-weight: 400;
    font-size: 1.4rem;
    line-height: 120%;
    color: white;
  }
  .products__popup .underline {
    width: 100%;
  }
  .products__popup .products__specs {
    display: flex;
    flex-direction: column;
    gap: 10px;
    list-style: none;
    padding: 0;
    margin: 0;
  }
  .products__popup .products__specs li {
    font-weight: 400;
    font-size: 1.4rem;
    line-height: 120%;
    color: #222222;
    text-align: center;
  }
  .products__popup .products__btn {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    padding: 10px 22px;
    border-radius: 48px;
    font-weight: 700;
    font-size: 1.3rem;
    line-height: 120%;
    text-transform: uppercase;
    text-decoration: none;
    color: white;
    margin-top: 4px;
  }
  .products__popup .products__btn_standart { background: #DDBF90; }
  .products__popup .products__btn_protein { background: #538CCF; }
  .products__popup .products__btn_energy { background: #DB1134; }
  .products__popup .products__btn_diabet { background: #922C97; }
  .products__item_standart .products__popup .products__badge { background: #DDBF90; }
  .products__item_protein .products__popup .products__badge { background: #538CCF; }
  .products__item_energy .products__popup .products__badge { background: #DB1134; }
  .products__item_diabet .products__popup .products__badge { background: #922C97; }
}
.products__title {
  font-family: 'Inter', sans-serif;
  font-weight: 700;
  font-size: 2.1rem;
  line-height: 140%;
  text-align: center;
  text-transform: uppercase;
  margin: 0;
  max-width: 210px;
  min-height: 2.8em;
}
.products__title_standart {
  color: #DDBF90;
}
.products__title_protein {
  color: #538CCF;
}
.products__title_energy {
  color: #DB1134;
}
.products__title_diabet {
  color: #922C97;
}
.products__divider {
  width: 180px;
  height: 1px;
  background: #C0C0C0;
  opacity: 0.3;
}
.products__text {
  font-family: 'Inter', sans-serif;
  font-weight: 400;
  font-size: 1.6rem;
  line-height: 140%;
  color: #222222;
  text-align: center;
  margin: 0;
  align-self: stretch;
  flex-grow: 1;
  padding-bottom: 24px;
}
.products__text b,
.products__specs b {
  font-weight: 700;
}
.products__badge,
.products__specs,
.products__btn {
  display: none;
}
.products__bottle {
  width: 100%;
  height: 321px;
  pointer-events: none;
  object-fit: contain;
}
.products__note {
  font-family: 'Inter', sans-serif;
  font-weight: 400;
  font-size: 1.4rem;
  line-height: 140%;
  text-align: center;
  color: #7C878E;
  max-width: 287px;
  margin: 0 auto;
  padding-top: 20px;
}

.characteristics {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  overflow: hidden;
}
.characteristics__content {
  padding: 80px 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  max-width: 1440px;
}
.characteristics__title {
  font-size: 3.6rem;
  font-weight: 700;
  color: #2E3F78;
  max-width: 845px;
  text-align: center;
  line-height: 48px;
  margin-bottom: 29px;
}
.characteristics__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 60px 80px;
  width: 100%;
  max-width: 960px;
  margin-top: 56px;
}
.characteristics__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}
.characteristics__icon {
  width: 140px;
  height: 140px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  margin-bottom: 20px;
}
.characteristics__icon_vitamins {
  background-image: url(../assets/images/isosource/character-one.svg);
}
.characteristics__icon_protein {
  background-image: url(../assets/images/isosource/character-two.svg);
}
.characteristics__icon_trigly {
  background-image: url(../assets/images/isosource/character-three.svg);
}
.characteristics__icon_omega {
  background-image: url(../assets/images/isosource/character-four.svg);
}
.characteristics__icon_clinical {
  background-image: url(../assets/images/isosource/character-five.svg);
}
.characteristics__icon_package {
  background-image: url(../assets/images/isosource/character-six.svg);
}
.characteristics__item-title {
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 130%;
  color: var(--graphite-black);
  margin-bottom: 20px;
  max-width: 360px;
  padding-bottom: 16px;
  position: relative;
}
.characteristics__item-title::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 200px;
  height: 1px;
  background: #C0C0C0;
  opacity: 0.3;
}
.characteristics__item-text {
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 140%;
  color: var(--graphite-black);
  max-width: 400px;
}

.research {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
}
.isosource-bot-wrapper {
  position: relative;
}
.isosource-bot-wrapper::before {
  content: '';
  position: absolute;
  top: calc(-254vw * 100 / 1440);
  left: 48%;
  transform: translateX(-50%);
  width: calc(100vw * 1808 / 1440);
  height: calc(100vw * 1204 / 1440);
  background: url('../assets/images/isosource/two-banner-hexagon.svg') center / 100% 100% no-repeat;
  pointer-events: none;
  z-index: 2;
}
.research__content {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  max-width: 1440px;
  z-index: 1;
  padding: 80px 20px;
  position: relative;
}
.research__title {
  font-size: 3.2rem;
  font-weight: 700;
  line-height: 140%;
  color: #2E3F78;
  text-align: center;
  max-width: 1000px;
  margin-bottom: 24px;
}

.research__body {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 80px;
  width: 100%;
  max-width: 1100px;
  margin-top: 56px;
  flex-wrap: wrap;
}
.research__products-image {
  max-width: 1087px;
  width: 100%;
  display: block;
  flex-shrink: 0;
}
.research__products-image img {
  width: 100%;
  height: auto;
  display: block;
}
.research__packet-image {
  width: 100%;
  padding: 0 20px;
  background-color: white;
  box-sizing: border-box;
  display: block;
}
.research__packet-image img {
  max-width: 1260px;
  margin: 0 auto;
  width: 100%;
  height: auto;
  display: block;
  position: relative;
  z-index: 3;
}

.algorithm {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 80px 20px 80px 20px;
  background: white;
}
.algorithm__header {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 40px;
  width: 100%;
  max-width: 840px;
  margin-bottom: 40px;
}
.algorithm__title {
  font-family: 'Inter', sans-serif;
  font-weight: 700;
  font-size: 3.6rem;
  line-height: 48px;
  text-align: center;
  color: #14377D;
  margin: 0;
  max-width: 583px;
}
.algorithm__underline {
  position: relative;
  width: 399px;
  max-width: 100%;
  height: 1px;
  background: #CFE1F3;
}
.algorithm__underline-accent {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 72px;
  height: 4px;
  background: #EA6852;
  border-radius: 99px;
  transform: translate(-50%, -50%);
}
.algorithm__subtitle {
  font-family: 'Inter', sans-serif;
  font-weight: 400;
  font-size: 2rem;
  line-height: 140%;
  text-align: center;
  color: #222222;
  margin: 0;
}
.algorithm__canvas {
  position: relative;
  width: 1280px;
  max-width: 100%;
  height: 840px;
}
.algorithm__top,
.algorithm__top-inner,
.algorithm__bottom {
  display: contents;
}
.algorithm__top-block {
  display: contents;
}
.algorithm__top-arrow {
  display: none;
}
.algorithm__blue-bg {
  position: absolute;
  left: 0;
  top: 0;
  width: 909px;
  height: 288px;
  background: rgba(233, 243, 255, 0.8);
  border-radius: 40px;
  z-index: 1;
}
.algorithm__blue-title {
  position: absolute;
  left: 232px;
  top: 40px;
  width: 524px;
  font-family: 'Inter', sans-serif;
  font-weight: 700;
  font-size: 2rem;
  line-height: 140%;
  text-align: center;
  color: #222222;
  margin: 0;
  z-index: 3;
}
.algorithm__purple-bg {
  position: absolute;
  left: 950px;
  top: 0;
  width: 330px;
  height: 388px;
  background: rgba(243, 233, 255, 0.8);
  border-radius: 40px;
  z-index: 1;
}
.algorithm__purple-title {
  position: absolute;
  left: 1007px;
  top: 40px;
  width: 216px;
  font-family: 'Inter', sans-serif;
  font-weight: 700;
  font-size: 2rem;
  line-height: 140%;
  text-align: center;
  color: #222222;
  margin: 0;
  z-index: 3;
}
.algorithm__mini {
  position: absolute;
  top: 116px;
  height: 272px;
  background: rgba(216, 232, 251, 0.8);
  border-radius: 40px;
  z-index: 2;
}
.algorithm__mini_1 {
  left: 41px;
  width: 274px;
}
.algorithm__mini_2 {
  left: 356px;
  width: 514px;
}
.algorithm__choice {
  position: absolute;
  top: 152px;
  font-family: 'Inter', sans-serif;
  font-weight: 400;
  font-size: 2rem;
  line-height: 140%;
  color: #222222;
  z-index: 4;
}
.algorithm__choice_1 {
  left: 161px;
}
.algorithm__choice_2 {
  left: 479.68px;
}
.algorithm__choice_3 {
  left: 726.69px;
}
.algorithm__arrow {
  position: absolute;
  width: 18px;
  height: 18px;
  z-index: 4;
  clip-path: polygon(50% 100%, 0 0, 100% 0);
}
.algorithm__arrow_beige-top {
  left: 169.33px;
  top: 186.47px;
  background: #DDBF90;
}
.algorithm__arrow_blue-top {
  left: 483.88px;
  top: 186.47px;
  background: #3B92CC;
}
.algorithm__arrow_red-top {
  left: 730.85px;
  top: 186.47px;
  background: #DB1134;
}
.algorithm__arrow_purple-top-1 {
  left: 1106.89px;
  top: 153.73px;
  background: #922C97;
}
.algorithm__arrow_purple-top-2 {
  left: 1106.89px;
  top: 186.46px;
  background: #922C97;
}
.algorithm__arrow_purple-top-3 {
  left: 1106.89px;
  top: 220.82px;
  background: #922C97;
}
.algorithm__bottle {
  position: absolute;
  z-index: 3;
  pointer-events: none;
  object-fit: contain;
}
.algorithm__bottle_standart {
  left: 26px;
  top: 220px;
  width: 300px;
  height: 300px;
}
.algorithm__bottle_protein {
  left: 348px;
  top: 220px;
  width: 300px;
  height: 300px;
}
.algorithm__bottle_energy {
  left: 588px;
  top: 220px;
  width: 300px;
  height: 300px;
}
.algorithm__bottle_diabet {
  left: 973px;
  top: 243px;
  width: 300px;
  height: 300px;
}
.algorithm__line {
  position: absolute;
  top: 488px;
  height: 40px;
  border: 1px solid #CFE1F3;
  border-radius: 40px;
  box-sizing: border-box;
  z-index: 2;
}
.algorithm__line_big {
  left: 41px;
  width: 580px;
  border-top: 0;
}
.algorithm__line_small {
  left: 627px;
  width: 236px;
  border-top: 0;
}
.algorithm__arrow_beige-bot {
  left: 169.33px;
  top: 547.07px;
  background: #DDBF90;
}
.algorithm__arrow_blue-bot {
  left: 483.88px;
  top: 547.07px;
  background: #3B92CC;
}
.algorithm__arrow_red-bot {
  left: 730.85px;
  top: 547.07px;
  background: #DB1134;
}
.algorithm__arrow_purple-bot-1 {
  left: 1106.89px;
  top: 555.07px;
  background: #922C97;
}
.algorithm__arrow_purple-bot-2 {
  left: 1106.89px;
  top: 589.43px;
  background: #922C97;
}
.algorithm__arrow_purple-bot-3 {
  left: 1106.89px;
  top: 623.79px;
  background: #922C97;
}
.algorithm__description {
  position: absolute;
  font-family: 'Inter', sans-serif;
  font-weight: 400;
  font-size: 2rem;
  line-height: 140%;
  text-align: center;
  color: #222222;
  margin: 0;
  z-index: 3;
}
.algorithm__description_1 {
  left: 50.52px;
  top: 589px;
  width: 576.48px;
}
.algorithm__description_2 {
  left: 691px;
  top: 603px;
  width: 96px;
}
.algorithm__name {
  position: absolute;
  top: 664px;
  height: 46px;
  font-family: 'Inter', sans-serif;
  font-weight: 700;
  font-size: 2.4rem;
  line-height: 29px;
  text-align: center;
  color: #012169;
  margin: 0;
  z-index: 3;
}
.algorithm__name_1 {
  left: 75.21px;
  width: 195.48px;
}
.algorithm__name_2 {
  left: 410.2px;
  width: 172.52px;
}
.algorithm__name_3 {
  left: 617.05px;
  width: 262.95px;
}
.algorithm__name_4 {
  left: 991.32px;
  width: 247.36px;
}
.algorithm__btn {
  position: absolute;
  top: 750px;
  width: 184px;
  height: 64px;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 24px 32px;
  border-radius: 56px;
  font-family: 'Inter', sans-serif;
  font-weight: 700;
  font-size: 1.8rem;
  line-height: 40px;
  letter-spacing: 0;
  text-transform: uppercase;
  text-decoration: none;
  color: white;
  box-sizing: border-box;
  z-index: 3;
  transition: all 0.2s ease;
}
.algorithm__btn_beige {
  left: 80.95px;
  background: #DDBF90;
}
.algorithm__btn_beige:hover {
  background: white;
  color: #DDBF90;
  box-shadow: inset 0 0 0 2px #DDBF90;
}
.algorithm__btn_blue {
  left: 404.46px;
  background: #3B92CC;
}
.algorithm__btn_blue:hover {
  background: white;
  color: #3B92CC;
  box-shadow: inset 0 0 0 2px #3B92CC;
}
.algorithm__btn_red {
  left: 656.53px;
  background: #DB1134;
}
.algorithm__btn_red:hover {
  background: white;
  color: #DB1134;
  box-shadow: inset 0 0 0 2px #DB1134;
}
.algorithm__btn_purple {
  left: 1023px;
  background: #922C97;
}
.algorithm__btn_purple:hover {
  background: white;
  color: #922C97;
  box-shadow: inset 0 0 0 2px #922C97;
}

.source-wrapper .height116 {
  max-height: 156px;
}
.source-wrapper .opacity0 {
  opacity: 0;
}
.source-wrapper .rotate {
  transform: rotate(180deg);
}
.isosource-footer {
  background-color: white;
  position: relative;
  width: 100%;
  isolation: isolate;
}
.isosource-footer__bg {
  position: absolute;
  inset: 0;
  background-image:
    url('../assets/images/isosource/purchase.svg'),
    linear-gradient(#4CADE1, #4CADE1);
  background-repeat: no-repeat, no-repeat;
  background-position: top center, bottom center;
  background-size: 100% auto, 100% calc(108% - 100vw * 1926 / 1440);
  z-index: -1;
  pointer-events: none;
}
.isosource-footer__content {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 120px 0 0 0;
}
.isosource-footer .purchase {
  position: static;
  background: transparent;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  overflow: visible;
}
.isosource-footer .purchase__content {
  position: relative;
  z-index: 1;
  padding: 0 20px;
}
.isosource-footer .purchase__title {
  color: white;
}
.isosource-footer .purchase__background {
  display: none;
}
.isosource-footer .source-wrapper {
  width: 100%;
  max-width: 1280px;
  padding: 60px 40px 80px 40px;
  box-sizing: border-box;
}
.isosource-footer .source {
  padding: 0;
  max-width: none;
}
.isosource-footer .source__window {
  background: white;
  padding: 48px 80px;
  border-radius: 40px;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.08);
}
.isosource-footer .source__title {
  color: var(--deep-blue);
}
.isosource-footer .source__arrow {
  
}

.main {
  min-height: 100vh;
  display: block;
  background-color: #EDF5FF;
  position: relative;
  overflow-x: clip;
}
.main > .breadcrumbs {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
}

.isosource-top {
  --cap-h: calc(107vw * 421 / 1440);
  width: 100%;
  background: white;
  -webkit-mask:
    linear-gradient(#000, #000) top / 100% calc(100% - var(--cap-h)) no-repeat,
    url('../assets/images/isosource/vector-top.svg') bottom / 100% var(--cap-h) no-repeat;
  mask:
    linear-gradient(#000, #000) top / 100% calc(100% - var(--cap-h)) no-repeat,
    url('../assets/images/isosource/vector-top.svg') bottom / 120% var(--cap-h) no-repeat;
}
.isosource-top__content {
  position: relative;
}
.isosource-top__hero {
  display: block;
  margin-top: -7%;
}
.isosource-top__hero img {
  display: block;
  width: 100%;
  height: auto;
}
.isosource-top__food {
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 40px 80px;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.isosource-top__food .isosource__title {
  margin-top: 30px;
}
.isosource-top__food .products {
  margin-top: 130px;
}

.isosource-bot {
  --cap-h: calc(100vw * 421 / 1440);
  width: 100%;
  background: white;
  -webkit-mask:
    url('../assets/images/isosource/vector-bottom.svg') top / 100% var(--cap-h) no-repeat,
    linear-gradient(#000, #000) bottom / 100% calc(101% - var(--cap-h)) no-repeat;
  mask:
    url('../assets/images/isosource/vector-bottom.svg') top / 100% var(--cap-h) no-repeat,
    linear-gradient(#000, #000) bottom / 100% calc(101% - var(--cap-h)) no-repeat;
}
.isosource-bot__content {
  position: relative;
}
.isosource-bot__hero {
  display: block;
}
.isosource-bot__hero img {
  display: block;
  width: 100%;
  height: auto;
}
