@media (max-width: 1199px) {

    .hero__container,
    .about__grid,
    .contact__container,
    .footer__container {
        flex-direction: column;
    }

    .hero__content,
    .hero__visual,
    .about__content,
    .about__stats,
    .contact__info,
    .contact-form {
        width: 100%;
    }

    .hero__title {
        font-size: 68px;
    }

    .hero__container {
        grid-template-columns: 1fr;
        gap: 32px;
    }

    .hero__content {
        min-height: auto;
    }

    .section-heading__title,
    .contact__title {
        font-size: 44px;
    }

    .header__body {
        gap: 16px;
        padding: 14px 18px;
    }

    .logo {
        width: 200px;
    }

    .nav__link {
        padding: 9px 4px;
        font-size: 14px;
    }

    .nav__list {
        gap: 8px;
    }

    .lang-switch__button {
        min-width: 38px;
        height: 34px;
        font-size: 12px;
    }

    .solutions__grid,
    .industries__list,
    .partners__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .visual-card {
        min-height: 620px;
    }
}

@media (max-width: 1099px) {
    .header__nav,
    .header .lang-switch:not(.lang-switch--mobile) {
        display: none;
    }

    .header__burger {
        display: flex;
    }

    .header__burger.is-active .header__burger-line:nth-child(1) {
        transform: translateY(7px) rotate(45deg);
    }

    .header__burger.is-active .header__burger-line:nth-child(2) {
        opacity: 0;
    }

    .header__burger.is-active .header__burger-line:nth-child(3) {
        transform: translateY(-7px) rotate(-45deg);
    }

    .hero {
        padding-top: 30px;
    }

    .hero__title {
        font-size: 56px;
    }

    .section {
        padding: 90px 0;
    }

    .solutions__grid,
    .industries__list,
    .partners__grid,
    .about__stats {
        grid-template-columns: 1fr;
    }

    .hero__metrics,
    .contact-form__row,
    .visual-card__aside {
        flex-direction: column;
    }

    .hero__content {
        gap: 28px;
    }

    .contact-form__field {
        width: 100%;
    }

    .visual-card__tag {
        bottom: 322px;
    }
}

@media (max-width: 767px) {
    .container {
        width: min(100% - 28px, 1200px);
    }

    .header {
        padding-top: 10px;
    }

    .header__body {
        padding: 14px 16px;
        border-radius: 22px;
    }

    .logo,
    .footer__logo {
        width: 172px;
    }

    .mobile-menu {
        top: 112px;
        right: 14px;
        width: min(320px, calc(100vw - 28px));
        max-height: calc(100dvh - 126px);
        padding: 20px 20px 30px;
        border-radius: 22px;
    }

    .lang-switch--mobile {
        display: flex;
    }

    .lang-switch__button {
        min-width: 40px;
        height: 36px;
        font-size: 12px;
    }

    .hero {
        padding-top: 140px;
    }

    .hero__title {
        font-size: 38px;
    }

    .section-heading__title,
    .contact__title,
    .solution-card__title,
    .industry-card__name {
        font-size: 32px;
    }

    .hero__text,
    .about__text,
    .contact__text,
    .solution-card__text,
    .footer__text {
        font-size: 15px;
    }

    .hero__content {
        padding-top: 20px;
        min-height: auto;
    }

    body.menu-open .hero {
        padding-top: 360px;
    }

    .hero__actions {
        flex-direction: column;
    }

    .button {
        width: 100%;
    }

    .visual-card {
        min-height: auto;
        padding: 18px;
        border-radius: 26px;
    }

    .placeholder--dark {
        min-height: 250px;
        border-radius: 22px;
    }

    .visual-card__tag {
        position: static;
        width: fit-content;
    }

    .partner-box {
        max-height: 160px;
    }

    .partner-box img {
        max-height: 160px;
        background-size: cover;
        background-position: center;
        background-repeat: no-repeat;
    }

    .card,
    .solution-card,
    .industry-card,
    .partner-box,
    .contact__info,
    .contact-form,
    .footer__container,
    .stat-card {
        padding: 22px;
    }

    .industry-card {
        min-height: 170px;
    }

    .footer__nav {
        flex-wrap: wrap;
        row-gap: 12px;
    }

    .page-decor {
        width: 300px;
        height: 160px;
    }
}
