html { scroll-behavior: smooth; }
body {
  font-family: "Montserrat", Arial, sans-serif;
  color: #442357;
  background: #FDFBFA;
  font-size: 14px;
  line-height: 1.7;
  overflow-x: hidden;
}

h1, h2, h3, h4, h5 {
  color:#4C1970;
}

a { 
  color: #CF78E4; 
  text-decoration: underline; 
}
a:hover {
   color:#442357;
  }

.site-header { 
  background: #FDFBFA;  
}
.navbar { 
  min-height: 76px; 
}
.brand-logo { 
  width: 190px; 
  max-height: 46px; 
  object-fit: contain; 
  object-position: left center; 
}
.navbar-light .navbar-nav .nav-link { 
  color: #442357; 
  font-size: 11px; 
  font-weight: 500; 
  padding: .75rem .78rem; 
  text-decoration: none; 
}
.navbar-light .navbar-nav .nav-link:hover { 
  color: #CF78E4;
}

a.btn {
  text-decoration: none;
}

.btn.btn-outline-fos {
  color: #442357;
  border: 1px solid transparent;
  background:
    linear-gradient(#fff, #fff) padding-box,
    linear-gradient(
      90deg,
      #442357 0%,
      rgba(68, 35, 87, 0.5) 100%
    ) border-box;
  transition:
    color 0.2s ease-in-out,
    box-shadow 0.2s ease-in-out;
}

.btn.btn-outline-fos:hover,
.btn.btn-outline-fos:focus {
  color: #fff;
  background:
    linear-gradient(
      90deg,
      #442357 0%,
      rgba(68, 35, 87, 0.5) 100%
    ) padding-box,
    linear-gradient(
      90deg,
      #442357 0%,
      rgba(68, 35, 87, 0.5) 100%
    ) border-box;
  text-decoration: none;
  outline: none;
}

.btn.btn-outline-fos:focus {
  box-shadow: 0 0 0 3px rgba(68, 35, 87, 0.15);
}

.btn-fos {
  padding: 12px 40px;

  border: 1px solid transparent;

  color: #fff;
  font-size: 14px;

  background:
    linear-gradient(
      101.64deg,
      #D083F5 33.29%,
      #AE27D0 115.35%
    ) padding-box;

  box-shadow: 0 11.25px 22.38px rgba(191, 59, 224, 0.2);

  transition:
    color 0.2s ease-in-out,
    background 0.2s ease-in-out,
    box-shadow 0.2s ease-in-out;
}

.btn-fos:hover,
.btn-fos:focus {
  color: #AE27D0;

  background:
    linear-gradient(#fff, #fff) padding-box,
    linear-gradient(
      101.64deg,
      #D083F5 33.29%,
      #AE27D0 115.35%
    ) border-box;
}

.bg-grad-orange { 
  display: inline-flex; 
  align-items: center; 
  border-radius: 999px; 
  padding: 8px 18px; 
  font-size: 12px;
  font-weight: 600; 
  color: #fff; background: linear-gradient(90deg, #ff8a78, #ff5c42);
}

.podzagolovok { 
font-weight: 500;
font-size: 14px;
line-height: 1.7;
letter-spacing: -0.01em;
color: #442357
}

.border-hero-top {
  position: relative;
  padding-bottom: 32px;
}

.border-hero-top::before {
  content: "";
  position: absolute;
  top: 0;
  left: 15px;
  right: 15px;
  height: 1.88px;
  background: linear-gradient(
    90deg,
    rgba(174, 39, 208, 0) 0%,
    rgba(174, 39, 208, 0.15) 51.45%,
    rgba(174, 39, 208, 0) 100%
  );
}

.border-hero {
  position: relative;
  padding-bottom: 32px;
}

.border-hero::before {
  content: "";
  position: absolute;
  top: 0;
  left: 15px;
  right: 15px;
  height: 1.88px;
  background: linear-gradient(
    90deg,
    rgba(174, 39, 208, 0) 0%,
    rgba(174, 39, 208, 0.15) 51.45%,
    rgba(174, 39, 208, 0) 100%
  );
}

.hero-image-blur {
  position: relative;
  z-index: 1;
}

.hero-image-blur::before {
  content: "";
  position: absolute;
  left: 10%;
  right: 10%;
  top: 2%;
  bottom: -2%;
  background: linear-gradient(
    180deg,
    rgba(215, 133, 254, 0.57) 0%,
    rgba(194, 90, 220, 0.57) 100%
  );
  filter: blur(90px);
  -webkit-filter: blur(90px);
  border-radius: 50%;
  z-index: -1;
  pointer-events: none;
}

.hero-image-blur img {
  position: relative;
  z-index: 1;
  display: block;
  width: 100%;
  height: auto;
}

.stat-value { 
  color: #CD6EFA; 
  font-size: 44px; 
  font-weight: 700; 
  letter-spacing: -.04em; 
}

.stat-value .small-one { 
  font-size: 22px; 
  font-weight: 600;
 }

 .stat-value .small-two { 
  font-size: 35px; 
  font-weight: 600;
 }

.stat {
  color: #7A6286;
  font-size: 14px;
  font-weight: 500
}

.stat-item {
  position: relative;
}

@media (max-width: 575.98px) {
.stat-value { 
  color: #CD6EFA; 
  font-size: 32px; 
  font-weight: 700; 
  letter-spacing: -.04em; 
}

.stat-value .small-one { 
  font-size: 18px; 
  font-weight: 600;
 }

 .stat-value .small-two { 
  font-size: 26px; 
  font-weight: 600;
 }

.stat {
  color: #7A6286;
  font-size: 10px;
  font-weight: 500
}

}
@media (min-width: 992px) {
  .stat-item:not(:last-child)::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 0;
    width: 1.88px;
    height: 197px;
    transform: translateY(-50%);
    background: linear-gradient(
      180deg,
      rgba(174, 39, 208, 0) 0%,
      rgba(174, 39, 208, 0.15) 51.45%,
      rgba(174, 39, 208, 0) 100%
    );
    pointer-events: none;
  }
}

.epd-countdown {
  display: block;
  width: 100%;
  padding: 48px 60px 60px;
  border-radius: 25px;
  background: linear-gradient(250.37deg, #FA573A 11.29%, #FF927E 105.9%);
  color: #fff;
  text-align: center;
}

.epd-countdown__title {
  margin-bottom: 48px;
  font-size: 31px;
  font-weight: 600;
  line-height: 1.3;
}

.epd-countdown__values {
  display: flex;
  justify-content: center;
  align-items: stretch;
}

.epd-countdown__item {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  min-width: 95px;
  padding: 0 40px;
}

.epd-countdown__item:not(:last-child)::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  width: 3.13px;
  height: 114px;
  transform: translateY(-50%);
  background: linear-gradient(
    180deg,
    rgba(255, 255, 255, 0) 0%,
    rgba(255, 255, 255, 0.08) 25%,
    rgba(255, 255, 255, 1) 50%,
    rgba(255, 255, 255, 0.08) 75%,
    rgba(255, 255, 255, 0) 100%
  );
  opacity: 0.3;
}

.epd-countdown__number {
  font-size: 62px;
  font-weight: 600;
  line-height: 1;
}

.epd-countdown__label {
  margin-top: 10px;
  font-size: 14px;
  font-weight: 500;
  line-height: 1.2;
  opacity: 0.75;
}

@media (max-width: 575.98px) {
  .epd-countdown {
    padding: 30px 20px 30px;
  }

  .epd-countdown__title {
    font-size: 16px;
    margin-bottom: 20px;
  }

  .epd-countdown__item {
    min-width: 75px;
    padding: 0 15px;
  }

  .epd-countdown__number {
    font-size: 32px;
  }
}

.epd-countdown-blur {
  position: relative;
  z-index: 1;
}

.epd-countdown-blur::before {
  content: "";
  position: absolute;
  left: 0%;
  right: 0%;
  top: 50%;
  bottom: 10%;
  background: linear-gradient(274.02deg, #FA573A 3.36%, #FF927E 90.06%);
  filter: blur(90px);
  -webkit-filter: blur(90px);
  border-radius: 50%;
  z-index: -1;
  pointer-events: none;
}


.epd-deadline-card {
  position: relative;
  display: flex;
  flex-direction: column;
  min-height: 334px;
  padding: 58px 50px 48px;
  border-radius: 25px;
}

/* Левая карточка */

.epd-deadline-card--dark {
  color: #fff;
  background: linear-gradient(86.03deg, #2F1240 29.27%, #4C1970 96.75%);
}

/* Правая карточка */

.epd-deadline-card--light {
  color: #442357;
  background: #fff;
  border: 1.5px solid #560B8D33;
}

/* Верхние подписи */

.epd-deadline-card__badge {
  position: absolute;
  top: -15px;
  left: 50px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 32px;
  padding: 7px 17px;
  border-radius: 30px;
  font-size: 11px;
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  white-space: nowrap;
}

.epd-deadline-card__badge--light {
  color: #442357;
  background: #fff;
  border: 1px solid #2F1240;
}

.epd-deadline-card__badge--dark {
  color: #fff;
  background: linear-gradient(86.03deg, #2F1240 29.27%, #4C1970 96.75%);
}

/* Заголовок */

.epd-deadline-card__title {
  margin: 0 0 16px;
  font-size: 30px;
  font-weight: 600;
  line-height: 1.2;
}

/* Текст */

.epd-deadline-card__text {
  max-width: 430px;
  font-size: 14px;
  font-weight: 500;
  line-height: 1.6;
}

.epd-deadline-card__text p {
  margin: 0;
}

/* Нижняя часть */

.epd-deadline-card__footer {
  margin-top: auto;
  padding-top: 28px;
}


/* Планшеты */

@media (max-width: 991.98px) {
  .epd-deadline-card {
    min-height: 310px;
  }
}

/* Мобильные */

@media (max-width: 575.98px) {
  .epd-deadlines {
    padding-top: 30px !important;
  }

  .epd-deadline-card {
    min-height: auto;
    padding: 48px 24px 30px;

    border-radius: 20px;
  }

  .epd-deadline-card__badge {
    left: 24px;
    max-width: calc(100% - 48px);
    font-size: 10px;
    white-space: normal;
    text-align: center;
  }

  .epd-deadline-card__title {
    font-size: 30px;
  }

  .epd-deadline-card__text {
    font-size: 14px;
  }

  .epd-deadline-card__footer {
    padding-top: 24px;
  }

  .btn-fos {
    width: 100%;
    min-width: 0;
  }
}

.role-help {
  padding: 35px 0;
}

.epd__title {
  margin: 0 0 7px;
  color: #4C1970;
  font-size: 25px;
  font-weight: 600;
  line-height: 1.3;
}

.role-help__text {
  margin: 0;
  color: #4C1970;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.4;
}

.role-help__text a {
  color: #4C1970;
  text-decoration: underline;
}

.role-help__text a:hover {
  color: #ae27d0;
}

/* Кнопка */

.role-help__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: 250px;
  min-height: 45px;
  padding: 11px 25px;
  border: 0;
  border-radius: 30px;
  color: #fff;
  font-size: 13px;
  font-weight: 600;
  line-height: 1;
  background: linear-gradient(86.03deg, #2F1240 29.27%, #4C1970 96.75%);
  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease;
}

.role-help__button:hover,
.role-help__button:focus {
  color: #fff;
  text-decoration: none;
  transform: translateY(-2px);
  box-shadow: 0 10px 20px rgba(68, 35, 87, 0.2);
}

.role-help__button--bracket {
  position: relative;
  overflow: visible;
}

/* Полускобка справа */
.role-help__button--bracket::after {
  content: "";
  position: absolute;
  top: 50%;
  right: -30px;
  width: 40px;
  height: 44px;
  border-right: 1px solid #4C1970;
  border-radius: 0 70% 60% 0;
  transform: translateY(-50%);
  pointer-events: none;
}
/* Текст справа */

.role-help__answer {
  position: relative;
  padding-left: 30px;
  color: #7A6286;
  font-size: 11px;
  font-weight: 400;
  line-height: 1.5;
}


/* Мобильная версия */

@media (max-width: 991.98px) {
  .role-help {
    text-align: center;
  }

  .role-help__button {
    max-width: 100%;
  }

  .role-help__answer {
    padding-top: 18px;
    padding-left: 0;
  }
}

.connection-choice {
  position: relative;
}

/* Номера */

.connection-number {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  margin-bottom: 60px;
  border-radius: 50%;
  color: #FDFBFA;
  font-size: 28px;
  font-weight: 500;
  line-height: 1;
  background: linear-gradient(101.64deg, #D083F5 33.29%, #AE27D0 115.35%);
}


/* Телефон */

.connection-choice__phone {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
}

.connection-choice__phone::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 15%;
  right: -10%;
  width: 100%;
  height: 80%;
  border-radius: 50%;
  background: linear-gradient(
    180deg,
    rgba(215, 133, 254, 0.18) 0%,
    rgba(194, 90, 220, 0.42) 100%
  );
  filter: blur(70px);
}

.connection-choice__phone img {
  position: relative;
  z-index: 1;
  display: block;
  width: 100%;
  max-width: 380px;
  max-height: 480px;
  object-fit: contain;
}

/* Стрелка */

.connection-choice__arrow {
  display: block;
  position: relative;
  width: 24px;
  height: 55px;
  margin-top: 25px;
}

.connection-choice__arrow span {
  position: absolute;
  top: 0;
  left: 50%;
  width: 2px;
  height: 36px;
  background: #442357;
  transform: translateX(-50%);
}

/* Залитый наконечник стрелки */
.connection-choice__arrow span::after {
  content: "";
  position: absolute;

  top: 100%;
  left: 50%;

  width: 0;
  height: 0;

  border-left: 6px solid transparent;
  border-right: 6px solid transparent;
  border-top: 9px solid #442357;

  transform: translateX(-50%);
}

/* Планшет */

@media (max-width: 991.98px) {

  .connection-choice__row {
    min-height: auto;
  }

  .connection-number {
    margin: 0 auto 25px;
  }

  .connection-choice__phone {
    margin: 50px 0;
  }

  .connection-choice__phone img {
    max-width: 300px;
  }

  .connection-choice__arrow {
    margin-right: auto;
    margin-left: auto;
  }
}

/* Телефон */

@media (max-width: 575.98px) {
  .connection-choice {
    padding-top: 35px !important;
    padding-bottom: 35px !important;
  }


  .connection-choice__phone {
    margin: 40px 0;
  }

  .connection-choice__phone img {
    max-width: 245px;
  }
}

/* =========================
   Возможности приложения
   ========================= */

.features-box {
  position: relative;
  overflow: hidden;
  padding: 70px 50px;
  border-radius: 50px;
  background: linear-gradient(
    86.03deg,
    #2f1240 29.27%,
    #4c1970 96.75%
  );
  max-width: 1200px;
  margin-right: auto;
  margin-left: auto;
}

/* Общая карточка */

.feature-card {
  position: relative;
  overflow: visible;
  padding: 30px 30px;
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.7);
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.08);
}

.feature-card-title {
  position: relative;
  z-index: 4;
  margin: 0 0 12px;
  color: #fff;
  font-size: 18px;
  font-weight: 600;
  line-height: 1.15;
}

.feature-card-text {
  position: relative;
  z-index: 4;
  margin: 0 0 12px;
  color: #fdfbfa;
  font-size: 14px;
  font-weight: 500;
  line-height: 1.55;
}

/* =========================
   Первая карточка с дорогой
   ========================= */

.feature-card-etrn {
  position: relative;
  min-height: 250px;
  margin-bottom: 20px;
  padding-bottom: 105px;
  /* Обрезаем только по внешней границе карточки */
  overflow: hidden;
}

.feature-road {
  position: absolute;
  z-index: 1;
  right: 0;
  bottom: 0;
  left: 30px;
  height: 114px;
  overflow: hidden;
  pointer-events: none;
}

.feature-road-image {
  position: absolute;
  z-index: 1;
  right: 0;
  bottom: 0;
  left: 0%;
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: left bottom;
}

/* Движущийся квадратик */

.feature-road-icon {
  position: absolute;
  z-index: 2;
  bottom: 47px;
  left: -46px;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: 6px;
  background: #fff;
  box-shadow: 0 5px 12px rgba(68, 35, 87, 0.18);
  opacity: 0;
  animation-name: feature-road-drive;
  animation-duration: 8s;
  animation-timing-function: linear;
  animation-iteration-count: infinite;
  will-change: left, opacity, transform;
}

.feature-road-icon img {
  display: block;
  width: 23px;
  height: 23px;
  object-fit: contain;
}

/* Равномерное расположение трёх элементов */

.feature-road-icon-1 {
  animation-delay: 0s;
}

.feature-road-icon-2 {
  animation-delay: -2.66s;
}

.feature-road-icon-3 {
  animation-delay: -5.33s;
}

@keyframes feature-road-drive {
  0% {
    left: -46px;
    opacity: 0;
    transform: translateY(0);
  }

  7% {
    opacity: 1;
  }

  48% {
    transform: translateY(-1px);
  }

  93% {
    opacity: 1;
  }

  100% {
    left: calc(100% + 12px);
    opacity: 0;
    transform: translateY(0);
  }
}

/* Иконки */

.feature-card-icon {
  position: relative;
  z-index: 4;
  display: flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  width: 36px;
  height: 36px;
  margin-bottom: 20px;
}

.feature-card-icon img {
  display: block;
  width: 36px;
  height: 36px;
  object-fit: contain;
}

.feature-card-driver-content {
  position: relative;
  z-index: 4;
}

/* Изображение выходит за верхнюю границу карточки */

.feature-card-signature-image {
  position: absolute;
  z-index: 5;
  bottom: 0px;
  right: -10%;
  display: block;
  object-fit: contain;
  pointer-events: none;
}


/* =========================
   QR-карточка
   ========================= */

.feature-card-qr {
  display: flex;
  flex-direction: column;
  overflow: visible;
}


.feature-card-stores {
  position: relative;
  z-index: 5;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.feature-card-stores a {
  display: block;
  margin-top: 7px;
}


/* Вторая плашка выходит за нижнюю границу карточки */

.feature-card-stores a:last-child {
  transform: translateY(35px);
}

@media (max-width: 991.98px) {
  .features-box {
    padding: 45px 30px;
    border-radius: 38px;
  }

  .feature-card-left-bottom {
    min-height: 170px;
  }

  .feature-card-signature-image {
    top: -24px;
    right: -12px;
    width: 195px;
  }
}

@media (max-width: 767.98px) {
  .features-box {
    padding: 38px 20px;
    border-radius: 26px;
  }

  .feature-card {
    min-height: auto;
  }

  .feature-card-etrn,
  .feature-card-left-bottom {
    margin-bottom: 20px;
  }

  .feature-card-driver {
    min-height: 270px;

    padding-right: 22px;
    padding-bottom: 155px;
  }

  .feature-card-signature-image {
    top: auto;
    right: 50%;
    bottom: -25px;
    width: 190px;
    transform: translateX(50%);
  }


  .feature-card-qr {
    min-height: auto;
  }
}

@media (max-width: 575.98px) {
  #features {
    padding-top: 25px !important;
    padding-bottom: 25px !important;
  }

  .features-box {
    padding: 32px 15px;
  }

  .feature-card {
    padding: 22px 18px;
  }

  .feature-card-title {
    font-size: 15px;
  }

  .feature-card-text {
    font-size: 12px;
  }

  .feature-card-etrn {
    padding-bottom: 105px;
  }

  .feature-road {
    left: 12px;
  }

  .feature-road-icon {
    width: 34px;
    height: 34px;
    bottom: 48px;
  }

  .feature-road-icon img {
    width: 20px;
    height: 20px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .feature-road-icon {
    animation: none;
    opacity: 1;
  }

  .feature-road-icon-1 {
    left: 12%;
  }

  .feature-road-icon-2 {
    left: 43%;
  }

  .feature-road-icon-3 {
    left: 74%;
  }
}

/* Горизонтальный промежуток между Bootstrap-колонками — 20px */
.gutter-30 {
  margin-right: -16px;
  margin-left: -16px;
}

.gutter-30 > [class*="col-"] {
  padding-right: 16px;
  padding-left: 16px;
}


.epd-connection {
  position: relative;
  padding: 55px 0 65px;
}

/* Декоративный фон */

.epd-connection::before {
  content: "";
  position: absolute;
  z-index: 0;
  top: 50px;
  right: 0;
  bottom: 0;
  left:0%;
  opacity: 0.45;
  background-image:url("/img/fone.svg");
}

.epd-connection .container {
  position: relative;
  z-index: 1;
}

/* Заголовок */

.epd-connection-heading {
  margin-bottom: 24px;
  text-align: center;
}

.epd-connection-options__subtitle {
  margin: 0;
  color: #552071;
  font-size: 20px;
  font-weight: 600;
  line-height: 1.3;
}

/* Сетка карточек */

.epd-connection-option {
  max-width: 940px;
  margin-right: auto;
  margin-left: auto;
}
/* Карточка */

.epd-connection-card {
  position: relative;
  display: flex;
  flex-direction: column;
  min-height: 195px;
  padding: 30px 30px 42px;
  border-radius: 19px;
  color: #fff;
  background: linear-gradient(83.59deg, #632B47 -0.22%, #220C2C 48.07%, #664479 89.82%);
  box-shadow: 0 14px 28px rgba(68, 35, 87, 0.13);
}

.epd-connection-card__title {
  margin: 0 0 24px;
  color: #fff;
  font-size: 18px;
  font-weight: 600;
  line-height: 1.3;
}

.epd-connection-card__content {
  flex-grow: 1;
  color: rgba(255, 255, 255, 0.95);
  font-size: 14px;
  font-weight: 500;
  line-height: 1.65;
  margin-bottom: 12px;
}


/* Кнопка */

.epd-connection-card__button {
  position: absolute;

  left: 30px;
  bottom: -17px;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  width: 176px;
  min-height: 38px;
  padding: 9px 22px;

  border: 0;
  border-radius: 25px;

  color: #fff;
  font-size: 11px;
  font-weight: 700;
  line-height: 1;

  background: linear-gradient(
    90deg,
    #ff8a74 0%,
    #ff523e 100%
  );

  box-shadow: 0 13px 23px rgba(255, 84, 62, 0.25);

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    color 0.2s ease;
}

.epd-connection-card__button:hover,
.epd-connection-card__button:focus {
  color: #fff;
  text-decoration: none;

  transform: translateY(-2px);

  box-shadow: 0 17px 27px rgba(255, 84, 62, 0.35);
}

.epd-connection-card__button:active {
  transform: translateY(0);
}

/* Планшет */

@media (max-width: 991.98px) {
  .epd-connection-options__title {
    font-size: 30px;
  }

  .epd-connection-options__subtitle {
    font-size: 18px;
  }

  .epd-connection-card {
    padding-right: 25px;
    padding-left: 25px;
  }

  .epd-connection-card__button {
    left: 25px;
  }
}

/* Мобильная версия */

@media (max-width: 767.98px) {
  .epd-connection-options {
    padding: 40px 0 45px;
  }

  .epd-connection-options__heading {
    margin-bottom: 30px;
  }

  .epd-connection-options__title {
    font-size: 27px;
  }

  .epd-connection-options__subtitle {
    font-size: 16px;
  }

  .epd-connection-card {
    min-height: 210px;
  }
}

@media (max-width: 575.98px) {
  .epd-connection-options__title {
    font-size: 24px;
  }

  .epd-connection-card {
    min-height: auto;
    padding: 26px 22px 52px;
  }

  .epd-connection-card__button {
    right: 22px;
    bottom: -17px;
    left: 22px;

    width: auto;
  }
}
.epd-platforms {
  padding: 55px 0 65px;
  background:
    radial-gradient(
      circle at 50% 0,
      rgba(194, 90, 220, 0.05) 0%,
      rgba(194, 90, 220, 0) 40%
    ),
    #fff;
}

.epd-platforms__title {
  max-width: 700px;
  margin: 0 auto 45px;
  color: #4C1970;
  font-size: 44px;
  font-weight: 700;
  line-height: 1.12;
  text-align: center;
}

/* Карточка */

.epd-platform-card {
  padding: 28px 30px 24px;
  border-radius: 18px;
  background: #FFFFFF;
  box-shadow:
    0 14px 35px rgba(68, 35, 87, 0.04),
    0 2px 8px rgba(68, 35, 87, 0.025);
}

.epd-platform-card__title {
  margin: 0 0 13px;
  color: #4C1970;
  font-size: 25px;
  font-weight: 600;
  line-height: 1;
}

.epd-platform-card__description {
  min-height: 45px;
  margin: 0 0 24px;
  color: #49196B;
  font-size: 14px;
  font-weight: 500;
  line-height: 1.7;
}

/* Сетка логотипов */

.epd-platform-card__logos {
  margin-right: -7px;
  margin-left: -7px;
}

.epd-platform-card__logos > [class*="col-"] {
  padding-right: 7px;
  padding-left: 7px;
}

/* Плашка с логотипом */

.epd-platform-logo {
  display: flex;
  align-items: center;
  justify-content: center;

  width: 100%;
  min-height: 47px;
  padding: 8px 12px;

  border-radius: 4px;

  background: #fff;

  box-shadow: 0 6px 15px rgba(68, 35, 87, 0.06);

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease;
}

.epd-platform-logo:hover,
.epd-platform-logo:focus {
  text-decoration: none;

  transform: translateY(-2px);

  box-shadow: 0 9px 20px rgba(68, 35, 87, 0.1);
}

.epd-platform-logo img {
  display: block;

  width: 100%;
  max-width: 125px;
  height: 30px;

  object-fit: contain;
}

/* Планшеты */

@media (max-width: 991.98px) {
  .epd-platforms__title {
    margin-bottom: 35px;
    font-size: 34px;
  }

  .epd-platform-card__description {
    min-height: auto;
  }
}

/* Мобильные */

@media (max-width: 575.98px) {
  .epd-platforms {
    padding: 40px 0 45px;
  }

  .epd-platforms__title {
    margin-bottom: 30px;

    font-size: 28px;
  }

  .epd-platform-card {
    padding: 24px 18px 20px;

    border-radius: 15px;
  }

  .epd-platform-card__title {
    font-size: 19px;
  }

  .epd-platform-card__description {
    margin-bottom: 20px;

    font-size: 11px;
  }

  .epd-platform-logo {
    min-height: 52px;
  }

  .epd-platform-logo img {
    max-width: 110px;
    height: 28px;
  }
}
.epd-roaming {
  position: relative;
  padding-bottom: 75px !important;
}

/* Основной оранжевый блок */

.epd-roaming__card {
  position: relative;
  z-index: 1;
  padding: 42px 30px 52px;
  border-radius: 25px;
  color: #fff;
  background: linear-gradient(250.37deg, #FA573A 11.29%, #FF927E 105.9%);

}

/* Размытое свечение под блоком */

.epd-roaming__card::before {
  content: "";
  position: absolute;
  z-index: -1;
  right: 8%;
  bottom: -24px;
  left: 8%;
  height: 55px;
  border-radius: 50%;
  background: linear-gradient(274.02deg, #FA573A 3.36%, #FF927E 90.06%);
  filter: blur(30px);
  -webkit-filter: blur(30px);
  pointer-events: none;
}

/* Заголовок */

.epd-roaming__title {
  margin: 0 0 13px;
  color: #FDFBFA;
  font-size: 25px;
  font-weight: 600;
  line-height: 1.35;
}

/* Описание */

.epd-roaming__text {
  margin: 0;
  color: #FDFBFA;
  font-size: 14px;
  font-weight: 500;
  line-height: 1.7;
}

/* Белая кнопка, выходящая за пределы блока */

.epd-roaming__button {
  position: absolute;
  bottom: -18px;
  left: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 265px;
  min-height: 38px;
  padding: 9px 22px;
  border: 1px solid rgba(255, 255, 255, 0.8);
  border-radius: 999px;
  color: #FA573A;
  font-size: 11px;
  font-weight: 600;
  line-height: 1.2;
  background: #fff;
  box-shadow: 0 10px 24px rgba(250, 87, 58, 0.18);
  transform: translateX(-50%);
  transition:
    color 0.2s ease,
    background-color 0.2s ease,
    box-shadow 0.2s ease,
    transform 0.2s ease;
}

.epd-roaming__button:hover,
.epd-roaming__button:focus {
  color: #fff;
  text-decoration: none;
  background: #FA573A;
  box-shadow: 0 13px 28px rgba(250, 87, 58, 0.3);
  transform: translate(-50%, -2px);
}

.epd-roaming__button:active {
  transform: translate(-50%, 0);
}

.epd-inside {
  position: relative;
  overflow: hidden;
  padding: 45px 0 65px;
  background: #fdfbfa;
}

/* Заголовок */

.epd-inside__title {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 0 20px;
  color: #F10126;
  font-size: 44px;
  font-weight: 700;
  line-height: 1;
  text-align: center;
}

.epd-inside__logo {
  display: block;
  width: 76px;
  height: 50px;
  margin-left: 16px;
  object-fit: contain;
}

/* Центральная часть */

.epd-inside__content {
  position: relative;
  z-index: 2;
  text-align: center;
}

.epd-inside__text {
  margin: 0 0 28px;
  color: #F10126;
  font-size: 14px;
  font-weight: 500;
  line-height: 1.7;
}

.epd-inside__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 154px;
  min-height: 40px;
  padding: 10px 28px;
  border: 0;
  border-radius: 999px;
  color: #fff;
  font-size: 12px;
  font-weight: 600;
  line-height: 1;
  background: linear-gradient(274.02deg, #FA573A 3.36%, #FF927E 90.06%);
  box-shadow: 0px 11.25px 22.38px 0px #FF907C4A;
  transition:
    color 0.2s ease,
    transform 0.2s ease,
    box-shadow 0.2s ease;
}

.epd-inside__button:hover,
.epd-inside__button:focus {
  color: #fff;
  text-decoration: none;
  transform: translateY(-2px);
  box-shadow: 0 16px 28px rgba(250, 87, 58, 0.35);
}

/* Боковые плашки */

.epd-inside__badges {
  display: flex;
  flex-direction: column;
  min-height: 115px;
}

.epd-inside__badges--left {
  align-items: flex-start;
  justify-content: space-between;
}

.epd-inside__badges--right {
  align-items: flex-end;
  justify-content: space-between;
}

.epd-inside__badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 36px;
  padding: 8px 20px;
  border-radius: 9px;
  color: #f04b42;
  font-size: 10px;
  font-weight: 400;
  line-height: 1.45;
  text-align: center;

  background: rgba(255, 235, 231, 0.75);
}

.epd-inside__badge--small {
  min-height: 28px;
  padding: 6px 17px;
}

.epd-inside__badge--rotate-left {
  transform: rotate(2deg);
}

.epd-inside__badge--rotate-right {
  transform: rotate(-2deg);
}

/* Мягкое свечение по центру */

.epd-inside::before {
  content: "";
  position: absolute;

  top: 20%;
  left: 50%;

  width: 480px;
  height: 130px;

  border-radius: 50%;

  background: rgba(255, 117, 91, 0.08);

  filter: blur(60px);
  transform: translateX(-50%);

  pointer-events: none;
}

.epd-promotions {
  padding: 60px 0 75px;
}

/* Светлые карточки */

.epd-promotion-card {
  position: relative;

  display: flex;
  flex-direction: column;

  min-height: 315px;
  padding: 56px 48px 38px;

  border: 1.5px solid rgba(86, 11, 141, 0.2);
  border-radius: 24px;

  color: #4C1970;
  background: #FDFBFA;
}

.epd-promotion-card__badge {
  position: absolute;
  top: -14px;
  left: 38px;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  min-height: 30px;
  padding: 7px 18px;

  border-radius: 999px;

  color: #fff;
  font-size: 10px;
  font-weight: 600;
  line-height: 1;
  text-transform: uppercase;
  letter-spacing: 0.03em;

  background: linear-gradient(
    90deg,
    #34113f 0%,
    #531573 100%
  );
}

.epd-promotion-card__title {
  margin: 0 0 18px;

  color: #4C1970;
  font-size: 28px;
  font-weight: 600;
  line-height: 1.12;
}

.epd-promotion-card__text {
  margin: 0;

  color: #442357;
  font-size: 12px;
  font-weight: 400;
  line-height: 1.65;
}

.epd-promotion-card__footer {
  margin-top: auto;
  padding-top: 28px;
}

/* Использует ваш существующий .btn-fos */

.epd-promotion-card__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;

  width: 100%;
  min-height: 44px;
  padding: 10px 22px;

  border-radius: 999px;

  font-size: 12px;
  font-weight: 600;
  line-height: 1.2;
}

/* Правая акцентная карточка */

.epd-promotion-card--accent {
  overflow: hidden;

  padding: 48px 28px 30px;

  border: 0;

  color: #fff;

  background:
    radial-gradient(
      circle at 80% 55%,
      rgba(121, 23, 175, 0.45) 0%,
      rgba(121, 23, 175, 0) 32%
    ),
    linear-gradient(
      145deg,
      #D176F1 0%,
      #B62BD6 100%
    );
}

.epd-promotion-card__accent-title {
  position: relative;
  z-index: 2;

  margin: 0;

  color: #fff;
  font-size: 27px;
  font-weight: 600;
  line-height: 1.15;
}

.epd-promotion-card__image {
  position: absolute;
  z-index: 1;

  right: 24px;
  top: 135px;

  width: 65px;
  height: auto;

  object-fit: contain;
}

.epd-promotion-card__button--dark {
  position: relative;
  z-index: 2;

  border: 1px solid transparent;

  color: #fff;

  background: linear-gradient(
    90deg,
    #34113f 0%,
    #531573 100%
  );

  box-shadow: none;

  transition:
    color 0.2s ease,
    background 0.2s ease,
    transform 0.2s ease,
    box-shadow 0.2s ease;
}

.epd-promotion-card__button--dark:hover,
.epd-promotion-card__button--dark:focus {
  color: #442357;
  text-decoration: none;

  background: #fff;

  transform: translateY(-2px);

  box-shadow: 0 10px 22px rgba(68, 35, 87, 0.18);
}
.epd-start {
  position: relative;
  overflow: hidden;
  padding: 55px 0 85px;
}

.epd-start__title {
  margin: 0 0 55px;

  color: #4c1970;
  font-size: 36px;
  font-weight: 700;
  line-height: 1.2;
  text-align: center;
}

.epd-start__content {
  min-height: 650px;
}

/* Дорога */

.epd-start__road {
  position: relative;
  width: 100%;
  max-width: 650px;
  margin: 0 auto;
  overflow: hidden;
}

/* Фоновая дорога */

.epd-start__road-image {
  position: relative;
  z-index: 1;
  display: block;
  width: 100%;
  height: auto;
  opacity: 0.8;
}

/* SVG со скрытым маршрутом и машинкой */

.epd-start__road-animation {
  position: absolute;
  z-index: 2;

  top: 0;
  right: 0;
  bottom: 0;
  left: 0;

  display: block;
  width: 100%;
  height: 100%;

  overflow: visible;
  pointer-events: none;
}

.epd-start__moving-truck {
  filter: drop-shadow(
    0 5px 6px rgba(250, 87, 58, 0.18)
  );
}

/* Один шаг */

.epd-start-step {
  display: flex;
  align-items: flex-start;

  max-width: 430px;
  margin-bottom: 42px;
}

.epd-start-step__number {
  display: flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;

  width: 34px;
  height: 34px;
  margin-right: 22px;
  margin-top: 2px;

  border-radius: 50%;

  color: #fff;
  font-size: 17px;
  font-weight: 600;
  line-height: 1;

  background: linear-gradient(
    135deg,
    #ff927e 0%,
    #fa573a 100%
  );
}

.epd-start-step__content {
  flex: 1 1 auto;
  min-width: 0;
}

.epd-start-step__title {
  margin: 0 0 15px;

  color: #4C1970;
  font-size: 25px;
  font-weight: 600;
  line-height: 1.15;
}

.epd-start-step__text {
  margin: 0;

  color: #442357;
  font-size: 14px;
  font-weight: 500;
  line-height: 1.65;
}

.epd-start-step__text a,
.epd-start-step__note a {
  color: #442357;
  text-decoration: underline;
}

.epd-start-step__note {
  margin: 14px 0 0;

  color: rgba(68, 35, 87, 0.6);
  font-size: 12px;
  font-weight: 500;
  line-height: 1.7;
}

/* Нижний блок */

.epd-start__cta-row {
  position: relative;
  z-index: 3;
  margin-top: 25px;
}

.epd-start__cta {
  padding: 40px 30px 50px;
}

.epd-start__cta-title {
  margin: 0 0 12px;

  color: #fff;
  font-size: 20px;
  font-weight: 600;
  line-height: 1.3;
}

.epd-start__cta-text {
  margin: 0;

  color: rgba(255, 255, 255, 0.95);
  font-size: 10px;
  font-weight: 400;
  line-height: 1.7;
}

.epd-start__cta-button {
  min-width: 220px;
}





/* FAQ */


.faq-title {
  margin: 0 0 55px;
  color: #4C1970;
  font-size: 44px;
  font-weight: 700;
  line-height: 1.15;
  text-align: center;
}

.faq-item {
  overflow: hidden;
  margin-bottom: 20px;

  border-radius: 16px;
  background: #F8EEF9;
}

/* Кнопка вопроса */

.faq-question {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  min-height: 76px;
  padding: 20px 28px;
  border: 0;
  outline: none;
  color: #442357;
  font-family: inherit;
  font-size: 14px;
  font-weight: 600;
  line-height: 1.45;
  text-align: left;
  background: transparent;
  cursor: pointer;
}

.faq-question:hover {
  color: #442357;
  outline: none;
  background: rgba(174, 39, 208, 0.03);
}

.faq-question > span:first-child {
  padding-right: 20px;
}

/* Круглая иконка */

.faq-icon {
  position: relative;
  flex: 0 0 auto;

  display: block;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: linear-gradient(
    86.03deg,
    #2F1240 29.27%,
    #4C1970 96.75%
  );
  transition: transform 0.25s ease;
}

.faq-icon::before,
.faq-icon::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  background: #fff;
  transform: translate(-50%, -50%);
}

.faq-icon::before {
  width: 16px;
  height: 1.5px;
}

.faq-icon::after {
  width: 1.5px;
  height: 16px;
}

/* При открытии плюс превращается в крестик */

.faq-question[aria-expanded="true"] .faq-icon {
  transform: rotate(45deg);
}

/* Ответ */

.faq-answer {
  padding: 0 28px 27px;

  color: #442357;
  font-size: 12px;
  font-weight: 400;
  line-height: 1.75;
}

/* Нижняя часть */

.faq-footer {
  display: flex;
  align-items: center;

  min-height: 76px;
  padding: 0 28px;
}

.faq-footer-text {
 color: #442357;
 font-size: 11px;
 font-weight: 500;
 line-height: 1.7;
}


@media (max-width: 991.98px) {
  .faq-title {
    margin-bottom: 40px;
    font-size: 36px;
  }

  .faq-footer {
    margin-bottom: 20px;
  }
}

@media (max-width: 575.98px) {
  .faq-section {
    padding-top: 40px !important;
    padding-bottom: 40px !important;
  }

  .faq-title {
    margin-bottom: 30px;
    font-size: 28px;
  }

  .faq-item {
    margin-bottom: 16px;
    border-radius: 14px;
  }

  .faq-question {
    min-height: 64px;
    padding: 17px 18px;

    font-size: 12px;
  }

  .faq-icon {
    width: 26px;
    height: 26px;
  }

  .faq-icon::before {
    width: 13px;
  }

  .faq-icon::after {
    height: 13px;
  }

  .faq-answer {
    padding: 0 18px 20px;

    font-size: 11px;
  }

  .faq-footer {
    display: block;

    padding: 4px 0 0;
    text-align: center;
  }

  .faq-footer-button {
    width: 100%;
  }

  .faq-footer-bracket {
    display: none;
  }

  .faq-footer-text {
    margin-top: 15px;
  }

  .epd-inside__title {
  font-size: 30px;
  }
}


/* =========================================================
   Блок участников грузоперевозок
   ========================================================= */

.epd-role2 {
  overflow: hidden;
  padding-top: 24px !important;
  padding-bottom: 52px !important;
  color: #4c1c70;
  background: #fff;
  font-family: "Montserrat", Arial, sans-serif;
}

.epd-role2 .container {
  width: 100%;
  max-width: 1124px;
  padding-right: 12px;
  padding-left: 12px;
}

/* Заголовок */

.epd-role2__title {
  max-width: 760px;
  margin: 0 auto 48px;
  color: #54207c;
  font-size: 48px;
  font-weight: 700;
  line-height: 1.12;
  letter-spacing: -1.3px;
  text-align: center;
}

.epd-role2__title .text-lightpurple {
  color: inherit !important;
}

/* =========================================================
   Переключатели
   ========================================================= */

.epd-role2__pills {
  display: grid;
  max-width: 900px;
  margin: 0 auto 36px;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 16px;
}

.epd-role2__pill {
  display: flex;
  width: 100%;
  min-width: 0;
  min-height: 40px;
  padding: 9px 18px !important;
  align-items: center;
  justify-content: space-between;
  border: 0;
  border-radius: 999px !important;
  color: #8a7895;
  background: #fff;
  box-shadow: 0 9px 26px rgba(62, 24, 84, 0.08);
  font-size: 12px;
  line-height: 1.2;
  text-align: left;
  white-space: nowrap;
  transition:
    color 0.2s ease,
    background-color 0.2s ease,
    box-shadow 0.2s ease,
    transform 0.2s ease;
}

.epd-role2__pill:hover {
  color: #54207c;
  box-shadow: 0 11px 28px rgba(62, 24, 84, 0.13);
  transform: translateY(-1px);
}

.epd-role2__pill:focus {
  outline: none;
  box-shadow:
    0 0 0 3px rgba(198, 80, 236, 0.18),
    0 11px 28px rgba(62, 24, 84, 0.13);
}

.epd-role2__pill.is-active {
  color: #fff;
  background: linear-gradient(110deg, #301040 0%, #481566 100%);
  box-shadow: 0 12px 25px rgba(54, 14, 76, 0.22);
}

.epd-role2__pill-label {
  overflow: hidden;
  font-weight: 600;
  text-overflow: ellipsis;
}

.epd-role2__pill-meta {
  margin-left: 12px;
  color: #ab98b6;
  flex: 0 0 auto;
  font-size: 11px;
  font-weight: 500;
}

.epd-role2__pill.is-active .epd-role2__pill-meta {
  color: rgba(255, 255, 255, 0.72);
}

/* =========================================================
   Панели
   ========================================================= */

.epd-role2__panel {
  display: none;
}

.epd-role2__panel.is-active {
  display: block;
}

.epd-role2__panel[hidden] {
  display: none !important;
}

.epd-role2__grid {
  display: grid;
  grid-template-columns:
    minmax(0, 1.18fr)
    minmax(0, 1.03fr)
    minmax(270px, 0.83fr);
  align-items: stretch;
  gap: 24px;
}

.epd-role2__left,
.epd-role2__center,
.epd-role2__right {
  display: flex;
  min-width: 0;
}

.epd-role2__card {
  display: flex;
  width: 100%;
  min-height: 328px;
  height: 100%;
  flex-direction: column;
  border-radius: 24px !important;
}

/* =========================================================
   Левая карточка
   ========================================================= */

.epd-role2__left .epd-role2__card {
  padding: 30px 24px !important;
  border: 2px solid #edc1fb;
  background: #fff;
}

.epd-role2__card-title {
  margin-bottom: 18px !important;
  color: #54207c;
  font-size: 26px !important;
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: -0.5px;
}

.epd-role2__card-text {
  max-width: 335px;
  margin-bottom: 28px !important;
  color: #7f6b8b;
  font-size: 12px !important;
  font-weight: 400;
  line-height: 1.65;
}

.epd-role2__checks {
  margin: auto 0 0;
  padding: 0;
  list-style: none;
}

.epd-role2__check {
  display: flex;
  margin-bottom: 13px;
  align-items: flex-start;
  color: #5a3d68;
  font-size: 12px !important;
  font-weight: 500;
  line-height: 1.45;
}

.epd-role2__check:last-child {
  margin-bottom: 0;
}

.epd-role2__check svg {
  width: 20px;
  height: 20px;
  margin: -1px 10px 0 -3px;
  flex: 0 0 20px;
}

.epd-role2__check svg path {
  fill: #d653ef;
}

/* =========================================================
   Центральная карточка
   ========================================================= */

.epd-role2__card--purple {
  padding: 30px 24px !important;
  color: #fff;
  background:
    radial-gradient(
      circle at 100% 0,
      rgba(135, 52, 177, 0.28),
      transparent 45%
    ),
    linear-gradient(145deg, #371149 0%, #4a176b 100%);
}

.epd-role2__center-title {
  margin-bottom: 32px !important;
  color: rgba(255, 255, 255, 0.58);
  font-size: 12px !important;
  font-weight: 600;
  line-height: 1.3;
  letter-spacing: 1.4px;
  text-transform: uppercase;
}

.epd-role2__center-item {
  display: flex;
  min-height: 59px;
  margin-bottom: 12px !important;
  padding: 10px 14px 10px 18px;
  align-items: center;
  justify-content: space-between;
  border: 1px solid rgba(226, 155, 249, 0.23);
  border-radius: 12px;
  background: rgba(126, 55, 153, 0.17);
  gap: 14px;
}

.epd-role2__center-item-text {
  min-width: 0;
  color: #fff;
  font-size: 12px !important;
  font-weight: 400;
  line-height: 1.45;
}

.epd-role2__center-item-tag {
  padding: 7px 13px !important;
  border: 1px solid rgba(214, 100, 244, 0.42);
  border-radius: 999px;
  color: #d6a4ea;
  background: rgba(123, 43, 158, 0.32);
  flex: 0 0 auto;
  font-size: 12px !important;
  line-height: 1.2;
  white-space: nowrap;
}

.epd-role2__card--purple > .mt-auto {
  margin-top: auto !important;
  color: rgba(255, 255, 255, 0.49);
  font-size: 12px !important;
  line-height: 1.55;
}

.epd-role2__card--purple .text-lightpurple-300 {
  color: #c898dc !important;
}

/* =========================================================
   Карточка тарифа
   ========================================================= */

.epd-role2__offer {
  padding: 30px 24px !important;
  border: 2px solid #edc1fb;
  background: #fff;
}

.epd-role2__price {
  display: flex;
  margin-bottom: 10px;
  align-items: baseline;
  color: #54207c;
  gap: 5px;
}

.epd-role2__price-meta {
  color: #54207c;
  font-size: 14px !important;
  font-weight: 600;
  line-height: 1.2;
}

.epd-role2__price-value {
  color: #54207c;
  font-size: 31px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: -0.6px;
  white-space: nowrap;
}

.epd-role2__price--compact {
  align-items: baseline;
}

/*
  Этой строки нет в макете, поэтому скрываем её.
  При необходимости удалите display: none.
*/

.epd-role2__subtitle-one {
  display: none;
}

.epd-role2__subtitle {
  margin-bottom: 27px;
  color: #897591;
  font-size: 12px !important;
  line-height: 1.45;
}

.epd-role2__bullets {
  margin: 0 0 24px;
  padding: 0;
  list-style: none;
}

.epd-role2__bullet {
  position: relative;
  margin-bottom: 17px;
  padding-left: 19px;
  color: #60436d;
  font-size: 12px !important;
  font-weight: 500;
  line-height: 1.45;
}

.epd-role2__bullet:last-child {
  margin-bottom: 0;
}

.epd-role2__bullet::before {
  position: absolute;
  top: 0.58em;
  left: 0;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #d84eef;
  content: "";
  transform: translateY(-50%);
}

.epd-role2__offer .btn {
  display: flex;
  width: 100%;
  min-height: 48px;
  margin-top: auto;
  padding: 12px 24px !important;
  align-items: center;
  justify-content: center;
  border: 0;
  border-radius: 999px;
  color: #fff;
  background: linear-gradient(100deg, #cd71ee 0%, #bc31df 100%);
  box-shadow: 0 12px 24px rgba(187, 52, 220, 0.23);
  font-size: 14px;
  font-weight: 700;
  line-height: 1.2;
  text-align: center;
  transition:
    box-shadow 0.2s ease,
    transform 0.2s ease,
    filter 0.2s ease;
}

.epd-role2__offer .btn:hover {
  color: #fff;
  filter: brightness(1.04);
  box-shadow: 0 15px 28px rgba(187, 52, 220, 0.31);
  transform: translateY(-2px);
}

.epd-role2__offer .btn:focus {
  color: #fff;
  outline: none;
  box-shadow:
    0 0 0 4px rgba(208, 91, 237, 0.2),
    0 15px 28px rgba(187, 52, 220, 0.27);
}

/* =========================================================
   Ноутбуки и небольшие экраны
   ========================================================= */

@media (max-width: 1199.98px) {
  .epd-role2__title {
    max-width: 720px;
    font-size: 44px;
  }

  .epd-role2__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .epd-role2__right {
    grid-column: 1 / -1;
  }

  .epd-role2__right .epd-role2__card {
    min-height: 270px;
  }

  .epd-role2__offer .btn {
    max-width: 320px;
  }
}

/* =========================================================
   Планшет
   ========================================================= */

@media (max-width: 991.98px) {
  .epd-role2 {
    padding-top: 40px !important;
    padding-bottom: 48px !important;
  }

  .epd-role2__title {
    max-width: 680px;
    margin-bottom: 36px;
    font-size: 38px;
  }

  .epd-role2__pills {
    display: flex;
    max-width: none;
    margin-right: -15px;
    margin-bottom: 30px;
    margin-left: -15px;
    padding: 4px 15px 14px;
    overflow-x: auto;
    gap: 12px;
    scrollbar-width: none;
  }

  .epd-role2__pills::-webkit-scrollbar {
    display: none;
  }

  .epd-role2__pill {
    width: auto;
    min-width: 185px;
    flex: 0 0 auto;
  }

  .epd-role2__card {
    min-height: 350px;
  }
}

/* =========================================================
   Телефон
   ========================================================= */

@media (max-width: 767.98px) {
  .epd-role2 {
    padding-top: 32px !important;
    padding-bottom: 40px !important;
  }

  .epd-role2__title {
    margin-bottom: 28px;
    font-size: 31px;
    line-height: 1.15;
    letter-spacing: -0.7px;
  }

  .epd-role2__grid {
    grid-template-columns: minmax(0, 1fr);
    gap: 16px;
  }

  .epd-role2__right {
    grid-column: auto;
  }

  .epd-role2__card,
  .epd-role2__right .epd-role2__card {
    min-height: auto;
  }

  .epd-role2__left .epd-role2__card,
  .epd-role2__card--purple,
  .epd-role2__offer {
    padding: 24px 20px !important;
    border-radius: 20px !important;
  }

  .epd-role2__card-title {
    margin-bottom: 14px !important;
    font-size: 23px !important;
  }

  .epd-role2__card-text {
    max-width: none;
    margin-bottom: 23px !important;
  }

  .epd-role2__center-title {
    margin-bottom: 22px !important;
  }

  .epd-role2__offer .btn {
    max-width: none;
  }
}

.docs {
  overflow: hidden;
  background: #fff;
  color: #2e1643;
}

.docs-head {
  max-width: 900px;
  margin-bottom: 56px;
}

.docs-title {
  color: #512078;
  font-size: 48px;
  font-weight: 700;
  line-height: 1.08;
  letter-spacing: -1.2px;
}

.docs-text {
  max-width: 760px;
  margin-right: auto;
  margin-left: auto;
  color: #47285e;
  font-size: 16px;
  line-height: 1.55;
}

.docs-footer {
  margin-top: 45px;
}


@media (max-width: 991.98px) {
  .docs-title {
    font-size: 40px;
  }

  .main-title {
    font-size: 23px;
  }

  .main-card {
    padding-right: 24px;
    padding-left: 24px;
  }
}

@media (max-width: 767.98px) {
  .docs {
    padding-top: 40px !important;
    padding-bottom: 40px !important;
  }

  .docs-head {
    margin-bottom: 32px;
  }

  .docs-title {
    font-size: 31px;
    line-height: 1.15;
    letter-spacing: -0.5px;
  }

  .docs-text {
    font-size: 14px;
  }

  .docs-row > [class*="col-"] + [class*="col-"] {
    margin-top: 16px;
  }

  .docs-row + .docs-row {
    margin-top: 16px;
  }
   .docs-footer {
    margin-top: 32px;
  }
}


.price-section {
  font-family: inherit;
}

.price-box {
  padding: 66px 48px 38px;
  color: #fff;
  overflow: hidden;
  border-radius: 48px;
  background: linear-gradient(86.03deg, #2F1240 29.27%, #4C1970 96.75%);
}

.price-head {
  margin-bottom: 34px;
}

.price-title {
  margin-bottom: 12px;
  font-size: 42px;
  font-weight: 700;
  line-height: 1.15;
}

.price-text {
  font-size: 21px;
  font-weight: 600;
  line-height: 1.4;
}

.price-scroll {
  padding: 12px 0 26px;
  overflow: visible;
}

/* Планшеты и мобильные до 991.98 px */

@media (max-width: 991.98px) {
  .price-scroll {
    padding: 12px 0 26px;
    overflow-x: auto;
    overflow-y: hidden;
    scrollbar-width: thin;
    scrollbar-color: rgba(255, 255, 255, .35) transparent;
    -webkit-overflow-scrolling: touch;
  }

  .price-scroll::-webkit-scrollbar {
    height: 6px;
  }

  .price-scroll::-webkit-scrollbar-track {
    background: transparent;
  }

  .price-scroll::-webkit-scrollbar-thumb {
    border-radius: 10px;
    background: rgba(255, 255, 255, .35);
  }
}

.price-row {
  margin-right: -8px;
  margin-left: -8px;
}

.price-col {
  padding-right: 8px;
  padding-left: 8px;
}

.plan {
  height: 100%;
  padding: 8px;
  border-radius: 22px;
  background: transparent;
  transition:
    background-color .25s ease,
    box-shadow .25s ease,
    transform .25s ease;
}

.plan-count {
  display: flex;
  min-height: 48px;
  align-items: center;
  justify-content: center;
  padding: 8px 12px;
  color: #412052;
  font-size: 15px;
  font-weight: 700;
  line-height: 1;
  white-space: nowrap;
  border-radius: 25px;
  background: #fff;
  transition: color .25s ease;
}

.doc-icon {
  display: inline-block;
  width: 10px;
  height: 11px;
  margin-left: 4px;
  flex: 0 0 10px;
  object-fit: contain;
}

.price-col {
  padding-right: 8px;
  padding-left: 8px;
}

.plan {
  width: 100%;
  max-width: 160px;
  margin: 0 auto;
  padding: 8px;
  border-radius: 20px;
  background: transparent;
  transition: background .2s ease;
}

/* Верхняя белая часть */

.plan-count {
  display: flex;
  height: 46px;
  align-items: center;
  justify-content: center;
  padding: 0 12px;
  color: #432054;
  font-size: 14px;
  font-weight: 700;
  line-height: 1;
  white-space: nowrap;
  border-radius: 24px;
  background: #fff;
}

/* Единая нижняя часть */

.plan-body {
  position: relative;
  display: flex;
  min-height: 120px;
  margin-top: 8px;
  flex-direction: column;
  align-items: center;
  padding: 18px 10px 50px;
  text-align: center;
  border-radius: 18px 18px 24px 24px;
  background: rgba(255, 255, 255, .1);
  overflow: hidden;
  transition:
    color .2s ease,
    background .2s ease;
}

.plan-price {
  margin-bottom: 5px;
  color: #fff;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.2;
}

.plan-desc {
  color: rgba(255, 255, 255, .65);
  font-size: 9px;
  line-height: 1.3;
}

/* Кнопка лежит поверх нижнего блока */

.plan-btn {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  display: flex;
  height: 46px;
  align-items: center;
  justify-content: center;
  padding: 0 12px;
  color: #fff;
  font-size: 12px;
  font-weight: 600;
  line-height: 1;
  text-decoration: none;
  border-radius: 24px;
  background: linear-gradient(274.02deg, #FA573A 3.36%, #FF927E 90.06%);
  );
  transition:
    color .2s ease,
    background .2s ease;
}

.plan-btn:hover {
  color: #fff;
  text-decoration: none;
}

/* Оранжевая плашка при наведении */

.plan:hover,
.plan:focus-within,
.plan.is-active {
  background: linear-gradient(274.02deg, #FA573A 3.36%, #FF927E 90.06%);
}

/* Нижняя часть активного тарифа */

.plan:hover .plan-body,
.plan:focus-within .plan-body,
.plan.is-active .plan-body {
  background: #fff;
}

.plan:hover .plan-price,
.plan:focus-within .plan-price,
.plan.is-active .plan-price {
  color: #432054;
}

.plan:hover .plan-desc,
.plan:focus-within .plan-desc,
.plan.is-active .plan-desc {
  color: #8e7e94;
}

/* Кнопка остаётся частью нижней белой области */

.plan:hover .plan-btn,
.plan:focus-within .plan-btn,
.plan.is-active .plan-btn {
  color: #ff5b43;
  background: #fff;
}

.plan-price {
  margin-bottom: 5px;
  font-size: 15px;
  font-weight: 700;
  line-height: 1.2;
}

.plan-desc {
  color: rgba(255, 255, 255, .65);
  font-size: 10px;
  line-height: 1.3;
  transition: color .25s ease;
}


.benefit-box {
  position: relative;
  margin-top: 28px;
  padding: 56px 70px 48px;
  border-radius: 22px;
  background: rgba(255, 255, 255, .1);
}

.benefit-item {
  max-width: 430px;
  margin-bottom: 44px;
}

.benefit-item:last-child {
  margin-bottom: 0;
}

.benefit-title {
  display: flex;
  margin-bottom: 22px;
  align-items: center;
  font-size: 17px;
  font-weight: 600;
  line-height: 1.4;
  color: #FDFBFA;
}

.benefit-title span {
  display: inline-block;
  width: 18px;
  height: 1px;
  margin-right: 7px;
  flex: 0 0 18px;
  background: rgba(255, 255, 255, .9);
}

.benefit-text {
  margin-bottom: 0;
  color: rgba(255, 255, 255, .62);
  font-size: 13px;
  line-height: 1.75;
}

.price-btn {
  position: absolute;
  bottom: -24px;
  left: 50%;
  display: inline-flex;
  min-height: 48px;
  align-items: center;
  justify-content: center;
  padding: 12px 34px;
  color: #fff;
  font-size: 13px;
  font-weight: 600;
  white-space: nowrap;
  border-radius: 25px;
  background: linear-gradient(135deg, #ff9279 0%, #ff4b34 100%);
  box-shadow: 0 12px 25px rgba(255, 81, 57, .3);
  transform: translateX(-50%);
  transition:
    transform .2s ease,
    box-shadow .2s ease;
}

.price-btn:hover {
  color: #fff;
  text-decoration: none;
  box-shadow: 0 15px 30px rgba(255, 81, 57, .42);
  transform: translate(-50%, -3px);
}

@media (max-width: 1199.98px) {
  .price-box {
    padding-right: 32px;
    padding-left: 32px;
  }

  .price-title {
    font-size: 36px;
  }

  .price-text {
    font-size: 18px;
  }

  .benefit-box {
    padding-right: 45px;
    padding-left: 45px;
  }
}

@media (max-width: 991.98px) {

  .benefit-box {
    margin-top: 18px;
    padding: 42px 32px 50px;
  }
}

@media (max-width: 767.98px) {
  .price-box {
    padding: 40px 16px 38px;
    border-radius: 28px;
  }

  .price-title {
    font-size: 30px;
  }

  .price-text {
    font-size: 16px;
  }

  .price-scroll {
    margin-right: -16px;
    margin-left: -16px;
    padding-right: 16px;
    padding-left: 16px;
  }

  .benefit-box {
    padding: 34px 24px 54px;
  }

  .benefit-item {
    max-width: none;
    margin-bottom: 32px;
  }

  .benefit-title {
    margin-bottom: 14px;
    font-size: 16px;
  }

  .benefit-text {
    font-size: 13px;
  }
}

@media (max-width: 575.98px) {
  .price-title {
    font-size: 27px;
  }

  .plan:hover,
  .plan:focus-within,
  .plan.is-active {
    transform: translateY(-4px);
  }

  .price-btn {
    width: calc(100% - 32px);
    padding-right: 20px;
    padding-left: 20px;
  }
}