.layout_project{
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.layout_project,
.layout_project:is(:hover, :active, :focus){
    text-decoration: none;
    color: var(--burgundy);
}
.layout_project .image{
    position: relative;
    overflow: clip;
    border-radius: 1rem;
    aspect-ratio: 1;
    padding: 1.5rem;

    display: grid;
}

.layout_project .image img{
    position: absolute;
    inset: 0;
    width: 100%; height: 100%;
    object-fit: cover;

    transition: transform 200ms ease-in-out;
}

.layout_project:is(:hover, :active, :focus) .image img{
    transform: scale(1.05);
}

.layout_project .image::before{
    content: '';
    position: absolute;
    z-index: 1;
    inset: 0;
    background-image: linear-gradient(black, transparent);
    opacity: .2;
}

.layout_project .image .tag{
    align-self: start; place-self: start;
    z-index: 3;
}

.layout_project .image .icon{
    place-self: end; align-self: end;
    z-index: 2;
    width: 3rem; height: 3rem;
    background-color: var(--chili);
    border-radius: 50%;

    display: flex;
    align-items: center; justify-content: center;

    transform: scale(0);
    opacity: 0;

    transition: transform 200ms ease-in-out,
                opacity 200ms ease-in-out;
}

.layout_project .image .icon::before{
    --mask-url: url(/wp-content/uploads/2025/08/arrow.svg);
    content: '';
    width: 1.25rem; height: 1.25rem;
    background-color: var(--white);
    mask: var(--mask-url) no-repeat center / contain;
    -webkit-mask: var(--mask-url) no-repeat center / contain;
}

.layout_project:is(:hover, :active, :focus) .icon{
    transform: scale(1);
    opacity: 1;
}

.layout_project .content{
    display: flex;
    flex-direction: column;
    gap: .25rem;
}

.layout_project .content .title{
    font-size: var(--heading-5);
    font-weight: var(--body-semibold);
    line-height: 1.2;
}