@media (max-width: 767px) {
  :root {
    --font-size-base: 14px;
    --font-size-xl: 20px;
    --font-size-xxl: 24px;
  }

  .container {
    padding: 0 var(--spacing-sm);
  }
}

@media (max-width: 1023px) {
  .header__nav--open {
    display: block;
    position: absolute;
    top: 100%;
    left: 0;
    width: 100%;
    background: var(--color-bg);
    border-bottom: 1px solid var(--color-header-border);
    backdrop-filter: blur(9px);
    -webkit-backdrop-filter: blur(9px);
    padding: var(--spacing-md);
  }

  .header__nav--open .header__nav-list {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--spacing-sm);
  }
}

@media (min-width: 768px) {
  .hero__grid {
    gap: 48px;
  }

  .hero__btn-primary,
  .hero__btn-outline {
    padding: 17px 24px;
  }

  .solutions__grid {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 14px;
  }

  .solutions__card {
    flex: 0 0 calc((100% - 14px) / 2);
    min-width: 0;
  }

  .geography__desc br {
    display: inline-block;
  }

  .procurement__fields,
  .modal__fields {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 10px;
  }

  .procurement__field,
  .modal__field {
    flex: 0 0 calc(50% - 5px);
  }

  .procurement__field--full,
  .modal__field--full {
    flex: 0 0 100%;
  }
}

@media (min-width: 1024px) {
  .header__logo img {
    width: 54px;
    height: 60px;
  }

  .header__nav {
    display: block;
  }

  .header__burger {
    display: none;
  }

  .header__cta {
    padding-left: 22px;
    padding-right: 22px;
  }

  .header__cta .btn-icon {
    width: 14px;
    height: 14px;
  }

  .hero {
    padding-top: 140px;
    padding-bottom: 140px;
  }

  .hero__grid {
    flex-direction: row;
    align-items: center;
    gap: 40px;
  }

  .hero__content {
    flex: 1;
    min-width: 0;
    gap: 28px;
  }

  .hero__badge span {
    font-size: 11px;
  }

  .hero__desc {
    font-size: 1.0625rem;
    line-height: 1.5;
  }

  .hero__btn-primary {
    padding: 17px 30px;
    font-size: 0.9375rem;
  }

  .hero__btn-primary .btn-icon {
    width: 16px;
    height: 16px;
  }

  .hero__btn-outline {
    padding: 17px 28px;
    font-size: 0.9375rem;
  }

  .hero__btn-outline .btn-icon {
    width: 16px;
    height: 16px;
  }

  .hero__features {
    flex-direction: row;
    flex-wrap: wrap;
  }

  .hero__feature span {
    font-size: 11px;
    letter-spacing: 1.54px;
  }

  .hero__visual {
    flex: 0 0 44%;
  }

  .hero__card {
    height: 736px;
  }

  .hero__card-corner {
    width: 33px;
    height: 33px;
    top: 18px;
    left: 18px;
  }

  .objects {
    padding-top: 100px;
  }

  .objects__label {
    margin-bottom: 22px;
  }

  .objects__label-text {
    font-size: var(--font-size-xs);
    letter-spacing: 2.64px;
  }

  .objects__list {
    padding-top: 28px;
  }

  .objects__card {
    flex-direction: row;
  }

  .objects__card:nth-child(even) {
    flex-direction: row-reverse;
  }

  .objects__card-media {
    width: 50%;
    height: auto;
    border-bottom: none;
    border-right: 1px solid var(--color-card-border);
  }

  .objects__card:nth-child(even) .objects__card-media {
    border-right: none;
    border-left: 1px solid var(--color-card-border);
  }

  .objects__card-body {
    flex: 1;
    padding: 40px;
  }

  .objects__tags {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 10px;
  }

  .objects__tag {
    padding: 10px 20px;
    border-radius: 12px;
    font-size: var(--font-size-base);
  }

  .solutions {
    padding-top: 140px;
    padding-bottom: 140px;
  }

  .solutions__label-text {
    font-size: var(--font-size-xs);
    letter-spacing: 2.64px;
  }

  .solutions__grid {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 14px;
  }

  .solutions__card {
    flex: 0 0 calc((100% - 28px) / 3);
    min-width: 0;
  }

  .solutions__card::before {
    width: 254px;
    height: 254px;
    top: -54px;
    left: 53%;
  }

  .solutions__card-media {
    height: 240px;
  }

  .solutions__card-body {
    padding: 28px 28px 30px;
  }

  .solutions__card-desc {
    font-size: var(--font-size-base);
    line-height: 24px;
  }

  .solutions__note {
    padding: 20px;
  }

  .solutions__note-text {
    font-size: var(--font-size-base);
    line-height: 24px;
  }

  .solutions__legal {
    font-size: var(--font-size-sm);
    line-height: 17.6px;
    letter-spacing: 0.66px;
  }

  .cases__header {
    flex-direction: row;
    justify-content: space-between;
    align-items: flex-end;
    margin-bottom: 50px;
  }

  .cases__intro {
    gap: 22px;
  }

  .cases__label-text {
    font-size: var(--font-size-xs);
    letter-spacing: 2.64px;
  }

  .cases__grid {
    flex-direction: row;
    gap: 18px;
  }

  .cases__card {
    flex: 1 1 0;
    min-width: 0;
  }

  .cases__card-media {
    height: 401px;
  }

  .cases__card-body {
    padding: 28px 30px 33px;
  }

  .cases__card-desc {
    font-size: var(--font-size-base);
    line-height: 24px;
  }

  .geography {
    padding-top: 140px;
    padding-bottom: 140px;
  }

  .geography__label {
    margin-bottom: 0;
  }

  .geography__label-text {
    font-size: var(--font-size-xs);
    letter-spacing: 2.64px;
  }

  .geography__title {
    padding-top: 6.7px;
  }

  .geography__desc {
    font-size: var(--font-size-base);
    line-height: 1.6;
  }

  .geography__body {
    flex-direction: row;
    gap: 30px;
    padding-top: 30px;
    align-items: stretch;
  }

  .geography__list-card {
    padding: 28px 26px;
    flex-shrink: 0;
  }

  .geography__list {
    width: 470px;
    gap: 8px;
  }

  .geography__item {
    padding: 11px 12px;
  }

  .geography__num {
    width: 26px;
    height: 26px;
    border-radius: 7px;
    font-size: 12px;
  }

  .geography__region {
    font-size: var(--font-size-base);
  }

  .geography__map-card {
    flex: 1 1 0;
    aspect-ratio: unset;
    min-height: 480px;
    height: auto;
  }

  .geography__map-caption {
    left: 27px;
    top: 23px;
    width: 458px;
    font-size: 13px;
    letter-spacing: 1.56px;
  }

  .process__label {
    margin-bottom: 22px;
  }

  .process__label-text {
    font-size: var(--font-size-xs);
    letter-spacing: 2.64px;
  }

  .process__grid {
    flex-direction: row;
    padding-top: 50px;
  }

  .process__card {
    flex: 1 1 0;
    min-width: 0;
    padding: 34px 28px;
  }

  .process__card-desc {
    font-size: var(--font-size-base);
    line-height: 24px;
  }

  .process__card-num {
    height: 55px;
    font-size: 78px;
    line-height: 78px;
    top: 9px;
  }

  .procurement {
    padding-top: 140px;
    padding-bottom: 120px;
  }

  .procurement__inner {
    flex-direction: row;
    gap: 64px;
    align-items: flex-start;
  }

  .procurement__form-card {
    order: -1;
    flex: 0 0 calc(50% - 32px);
    padding: 36px;
  }

  .procurement__info {
    flex: 1 1 0;
    min-width: 0;
  }

  .procurement__label-text {
    font-size: var(--font-size-xs);
    letter-spacing: 2.64px;
  }

  .procurement__desc {
    font-size: var(--font-size-base);
    line-height: 25.6px;
  }

  .procurement__list {
    padding-top: 17px;
  }

  .procurement__item-text {
    font-size: var(--font-size-base);
    line-height: 24px;
    letter-spacing: 0.16px;
  }

  .procurement__input {
    font-size: var(--font-size-base);
  }

  .procurement__upload-icon {
    width: 40px;
    height: 40px;
  }

  .procurement__submit {
    padding: 17px 30px;
    font-size: 0.9375rem;
  }

  /* ---- FOOTER ---- */
  .footer__glow {
    width: 420px;
    height: 420px;
    left: auto;
    right: 0;
    top: 40px;
  }

  .footer__inner {
    padding-top: 60px;
    padding-bottom: 30px;
    gap: 100px;
  }

  .footer__top {
    flex-direction: row;
    justify-content: space-between;
    align-items: flex-start;
  }

  .footer__brand {
    gap: 40px;
  }

  .footer__logo img {
    width: 54px;
    height: 60px;
  }

  .footer__desc {
    font-size: 0.8125rem;
  }

  .footer__contacts {
    align-items: flex-end;
  }

  .footer__contact-info {
    align-items: flex-end;
  }

  .footer__copy-break {
    display: none;
  }

  .footer__bottom {
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
  }

  .footer__legal {
    flex-direction: row;
    align-items: center;
    gap: 22px;
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}

