.bloc.bloc_O {
    min-height: 500px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.bloc.bloc_O .wrapper {
    display: flex;
    flex-direction: column;
    gap: var(--gap-5);
    padding: var(--gap-5);
    max-width: 1400px;
}

.bloc.bloc_O .wrapper .top {
    display: flex;
    flex-direction: row;
    gap: var(--gap-3);
}

.bloc.bloc_O .wrapper .top h2 {
    text-align: end;
    width: 40%;
    font-size: 5rem;
    line-height: 5.5rem;
}

.bloc.bloc_O .wrapper .top div {
    width: 60%;
    text-align: start;
}

.bloc.bloc_O .wrapper .bottom {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--gap);
}

.bloc.bloc_O .wrapper .bottom .item {
    position: relative;
    aspect-ratio: 1/1;
    box-shadow: rgba(99, 99, 99, 0.2) 0px 8px 8px 0px;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-end;
    gap: var(--gap-xs);
}
.bloc.bloc_O .wrapper .bottom .item:hover {
    box-shadow: rgba(0, 0, 0, 0.3) 0px 19px 38px,rgba(0, 0, 0, 0.22) 0px 15px 12px;
}

.bloc.bloc_O .wrapper .bottom .item .info {
    width: 100%;
    background-color: var(--color-blue-trans-mid);
    padding: var(--gap-2);
    color: var(--color-white);
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: var(--gap-xs);
    height: 35%;
    position: relative;
    overflow: hidden;
}

.bloc.bloc_O .wrapper .bottom .item .info h4,
.bloc.bloc_O .wrapper .bottom .item .info p {
    width: 100%;
    text-align: start;
}

.bloc.bloc_O .wrapper .bottom .item .price {
    width: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
}

.bloc.bloc_O .wrapper .bottom .item .price .price-2 {
    font-size: 1.8rem;
}

.bloc.bloc_O .wrapper .bottom .item .info svg {
    position: absolute;
    right: 15px;
    bottom: 15px;
}

/************************************************************************
                               RESPONSIVE
************************************************************************/
@media (max-width: 950px) {
    .bloc.bloc_O .wrapper .bottom {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .bloc.bloc_O .wrapper .top {
        flex-direction: column;
    }


    .bloc.bloc_O .wrapper .top h2 {
        text-align: start;
        width: 100%;
    }

    .bloc.bloc_O .wrapper .top div {
        width: 100%;
        text-align: justify;
    }

    .bloc.bloc_O .wrapper .bottom {
        grid-template-columns: repeat(1, 1fr);
        gap: var(--gap-3);
    }
}

@media (max-width: 480px) {
    .bloc.bloc_O .wrapper {
        padding: var(--gap-5) var(--gap-2);
    }
        
    .bloc.bloc_O .wrapper .top h2 {
        font-size: 3rem;
        line-height: 3.5rem;
    }
}

        