/* ════ Solution ════ */

.solution {
    max-width: 1600px;
    margin-inline: auto;
    padding: 48px;

    @media (max-width: 768px) {
        padding: 24px;
    }

    &>.solution__container {
        display: flex;
        align-items: center;
        justify-content: center;
        flex-direction: column;
        gap: 72px;
        width: 100%;

        @media (max-width: 768px) {
            gap: 0px;
        }

        &>.solution__container-texts {
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 96px;
            width: 100%;

            @media (max-width: 768px) {
                flex-direction: column;
                gap: 24px;
            }

            &>h1 {
                max-width: 800px;
                text-align: left;
                font-size: 48px;
                line-height: 100%;
                letter-spacing: -0.04em;
                color: var(--color-neutral-900);
                font-weight: 500;
                font-family: var(--font-family-primary);

                @media (max-width: 768px) {
                    font-size: 36px;
                }

                &>strong {}
            }

            &>p {
                max-width: 600px;
                text-align: left;
                font-size: 18px;
                line-height: 1.2;
                letter-spacing: -0.02em;
                color: var(--color-neutral-600);
                font-weight: 300;
                font-family: var(--font-family-primary);

                @media (max-width: 768px) {
                    font-size: 16px;
                }
            }
        }

        &>.hero__container-grid {
            width: 100%;
            display: flex;
            align-items: center;
            justify-content: center;
            flex-direction: column;
            gap: 48px;

            &>.hero__container-grid-item {
                display: flex;
                align-items: center;
                justify-content: space-between;
                gap: 48px;
                width: 100%;
                transition: transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);

                &:hover {
                    transform: translateY(-4px);
                }

                @media (max-width: 768px) {
                    flex-direction: column;
                    gap: 32px;
                }

                &:nth-child(2) {
                    @media (max-width: 768px) {
                        flex-direction: column-reverse;
                    }

                    &>.hero__container-grid-item-mockups {
                        img {
                            scale: 1.4;
                            transform: translateY(160px) !important;

                            @media (max-width: 768px) {
                                scale: 1.2;
                                transform: translateY(120px) !important;
                            }
                        }
                    }
                }


                &>.hero__container-grid-item-mockups {
                    width: 100%;
                    display: flex;
                    align-items: center;
                    justify-content: center;
                    height: 420px;
                    overflow: hidden;
                    gap: 24px;
                    background: linear-gradient(0deg, #9AC1DE, transparent);
                    border-radius: 48px;

                    @media (max-width: 768px) {
                        height: 380px;
                        border-radius: 24px;
                    }

                    &>img {
                        width: 260px;
                        object-fit: contain;

                        @media (max-width: 768px) {
                            width: 220px;
                        }

                        &:nth-child(1) {
                            transform: translateY(120px);
                        }

                        &:nth-child(2) {
                            transform: translateY(-120px);
                        }
                    }
                }

                &>.hero__container-grid-item-texts {
                    display: flex;
                    align-items: flex-start;
                    justify-content: center;
                    flex-direction: column;
                    gap: 24px;
                    width: 100%;

                    &>.hero__container-grid-item-texts-badge {
                        padding: 4px 16px;
                        border-radius: 99px;
                        background-color: #9AC1DE66;

                        &>span {
                            font-size: 14px;
                            line-height: 1;
                            letter-spacing: 0.04em;
                            color: var(--color-primary-800);
                            font-weight: 500;
                            font-family: var(--font-family-primary);
                            text-transform: uppercase;

                            @media (max-width: 768px) {
                                font-size: 12px;
                            }
                        }
                    }

                    &>h1 {
                        max-width: 520px;
                        text-align: left;
                        font-size: 36px;
                        line-height: 100%;
                        letter-spacing: -0.04em;
                        color: var(--color-neutral-800);
                        font-weight: 500;
                        font-family: var(--font-family-primary);

                        @media (max-width: 768px) {
                            font-size: 32px;
                        }

                        &>strong {}
                    }

                    &>p {
                        max-width: 600px;
                        text-align: left;
                        font-size: 18px;
                        line-height: 1.2;
                        letter-spacing: -0.02em;
                        color: var(--color-neutral-600);
                        font-weight: 300;
                        font-family: var(--font-family-primary);

                        @media (max-width: 768px) {
                            font-size: 16px;
                        }
                    }

                    &>button {

                        &>div {

                            &>span {}

                            &>svg {}
                        }
                    }
                }
            }
        }
    }
}