@media (max-width: 1200px) {
    .nav,
    .shop-container,
    .journal-container,
    .contact-container {
        width: 90%;
    }

    .right .links a {
        padding: 10px 9px;
    }

    .hero-container {
        width: 90%;
        gap: 30px;
    }

    .img1,
    .img2 {
        width: 150px;
        height: 150px;
    }

    .features {
        gap: 40px;
    }

    .feature-container {
        font-size: 28px;
        gap: 48px;
    }

    .address h2 {
        font-size: 48px;
        line-height: 1.2;
    }

    .box .img-container {
        height: auto;
    }
}

@media (max-width: 1024px) {
    .nav {
        height: 70px;
    }

    .navbar .right {
        display: none;
        flex-direction: column;
        align-items: center;
        gap: 14px;
        position: absolute;
        top: 70px;
        left: 0;
        width: 100%;
        background-color: white;
        padding: 20px;
        box-shadow: 0 10px 20px rgba(0, 0, 0, 0.1);
    }

    .navbar .right.active {
        display: flex;
    }

    .navbar .right .links {
        flex-direction: column;
        width: 100%;
        gap: 10px;
        align-items: center;
    }

    .navbar .right .links a {
        width: 100%;
        text-align: center;
    }

    .menu-icon {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 44px;
        height: 44px;
    }

    .hero {
        min-height: auto;
        padding: 120px 20px 70px;
    }

    .hero-container {
        width: 100%;
        flex-direction: column;
        align-items: center;
        gap: 34px;
        text-align: center;
    }

    .img1,
    .img2 {
        width: 116px;
        height: 116px;
    }

    .text-container {
        width: min(100%, 720px);
    }

    .text-container::after {
        width: min(440px, 86vw);
        height: min(440px, 86vw);
    }

    .text-container h2 {
        min-height: auto;
        font-size: clamp(36px, 7vw, 54px);
        line-height: 1.15;
    }

    .text-container p {
        width: min(100%, 520px);
        font-size: 18px;
        line-height: 1.55;
        letter-spacing: 0;
    }

    .features {
        min-height: auto;
        flex-direction: column;
        gap: 34px;
        padding: 50px 0;
    }

    .features .img-container {
        width: min(82%, 560px);
        flex: none;
    }

    .center-img img {
        display: none;
    }

    .feature-container {
        width: min(86%, 640px);
        flex: none;
        font-size: 22px;
        gap: 28px;
    }

    .shop-container {
        padding: 60px 0;
    }

    .box-container {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 28px;
    }

    .box {
        height: auto;
    }

    .box h2 {
        font-size: 26px;
    }

    .about {
        min-height: auto;
        padding: 70px 0;
    }

    .about-container {
        width: 86%;
        flex-direction: column;
        align-items: stretch;
        gap: 42px;
    }

    .tit h2 {
        line-height: 1.15;
    }

    .services {
        padding-bottom: 0;
    }

    .services div {
        width: 100%;
    }

    .journal {
        height: auto;
        min-height: 100vh;
        margin-top: 0;
        padding: 70px 0;
    }

    .journal-container .blok {
        gap: 18px;
        padding: 22px 24px;
    }

    .journal-container .blok::before {
        font-size: 34px;
        line-height: 1;
    }

    .journal-container h2 {
        font-size: 26px;
        padding: 8px 0;
        line-height: 1.25;
    }

    .journal-container p {
        width: 100%;
        font-size: 18px;
        line-height: 1.6;
    }

    .contact {
        height: auto;
        padding: 60px 0 30px;
    }

    .contact-container {
        min-height: auto;
        height: auto;
        justify-content: center;
        padding: 46px 28px;
    }

    .form-container {
        width: min(100%, 620px);
    }

    footer .nav {
        height: auto;
        padding: 24px 0;
        gap: 20px;
    }

    footer .right {
        justify-content: center;
    }
}

@media (max-width: 768px) {
    .nav,
    .shop-container,
    .journal-container,
    .contact-container,
    .about-container {
        width: 92%;
    }

    .left-logo {
        width: 92px;
    }

    .hero {
        padding-top: 104px;
    }

    .text-container h2 {
        font-size: clamp(32px, 10vw, 44px);
    }

    .img1,
    .img2 {
        width: 96px;
        height: 96px;
    }

    .feature-container {
        width: 92%;
        font-size: 19px;
    }

    .f1 {
        gap: 14px;
    }

    .im {
        width: 58px;
        height: 58px;
        flex: 0 0 58px;
    }

    .addres-container {
        flex-direction: column;
        align-items: flex-start;
        gap: 18px;
    }

    .address h2 {
        font-size: 34px;
        line-height: 1.15;
    }

    .address p {
        font-size: 18px;
        line-height: 1.45;
    }

    .box-container {
        grid-template-columns: 1fr;
    }

    .box h2 {
        font-size: 24px;
    }

    .services div {
        padding: 16px;
        border-radius: 16px;
    }

    .services div::before {
        width: 42px;
        height: 42px;
        flex: 0 0 42px;
        font-size: 34px;
    }

    .services h2 {
        min-width: 0;
        font-size: 20px;
    }

    .journal-container .blok {
        flex-direction: column;
        padding: 20px;
    }

    .journal-container .title {
        width: 100%;
        align-items: center;
        gap: 12px;
        text-align: left;
    }

    .journal-container h2 {
        font-size: 22px;
    }

    .icon {
        width: 40px;
        height: 40px;
        flex: 0 0 40px;
    }

    .form-container {
        align-items: stretch;
        gap: 12px;
    }

    .form-container h2 {
        font-size: 30px;
        line-height: 1.2;
    }

    .form-container input,
    .form-container textarea {
        padding: 15px;
    }

    footer .nav {
        flex-direction: column;
        justify-content: center;
        align-items: center;
        text-align: center;
    }

    footer .right .links {
        justify-content: center;
        gap: 4px 10px;
    }
}

@media (max-width: 480px) {
    button {
        width: 100%;
        padding: 12px 18px;
        font-size: 14px;
    }

    .navbar button,
    .box button,
    .about button,
    .text-container button {
        width: fit-content;
    }

    .hero-container {
        gap: 26px;
    }

    .text-container::after {
        width: 270px;
        height: 270px;
    }

    .text-container h2 {
        font-size: 32px;
    }

    .text-container p {
        font-size: 16px;
    }

    .features {
        padding: 40px 0;
    }

    .feature-container {
        gap: 22px;
    }

    .f1 h2 {
        font-size: 20px;
        line-height: 1.25;
    }

    .shop-container {
        padding: 48px 0;
    }

    .address h2 {
        font-size: 30px;
    }

    .address p {
        font-size: 16px;
    }

    .box h2 {
        font-size: 22px;
    }

    .about {
        padding: 54px 0;
    }

    .about-us {
        gap: 20px;
    }

    .services div {
        align-items: flex-start;
    }

    .journal {
        padding: 50px 0;
    }

    .journal-container .blok {
        padding: 18px 16px;
    }

    .journal-container h2 {
        font-size: 20px;
    }

    .journal-container p {
        font-size: 15px;
    }

    .contact-container {
        width: 92%;
        padding: 34px 18px;
    }

    .form-container h2 {
        font-size: 26px;
    }

    .form-container p {
        line-height: 1.5;
    }

    .last {
        font-size: 13px;
        line-height: 1.5;
        padding: 15px;
    }
}
