.text {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 14;
    line-clamp: 14;
    overflow: hidden;

    &.expanded {
        display: block;
        -webkit-line-clamp: unset;
        line-clamp: unset;
        overflow: visible;
    }
}

.toggle-btn {
    margin-top: 20px;
    color: #050505;
    cursor: pointer;
    background: none;
    border: none;
    font-weight: bold;
    font-size: 14px;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 0.75rem;
    font: inherit;
    padding: 0;

    .icon {
        display: inline-block;
        position: relative;
        width: 14px;
        height: 14px;
        transition: transform 0.35s ease;
        transform: rotate(0deg);
        transform-origin: 50% 50%;

        &::before,
        &::after {
            content: "";
            position: absolute;
            background: currentColor;
            transition: transform 0.35s ease, opacity 0.25s ease;
            border-radius: 1px;
        }

        /* barre horizontale */
        &::before {
            top: 50%;
            left: 0;
            width: 100%;
            height: 1px;
            transform: translateY(-50%);
        }

        /* barre verticale */
        &::after {
            left: 50%;
            top: 0;
            width: 1px;
            height: 100%;
            transform: translateX(-50%);
        }
    }

    &.is-open {
        .icon {
            transform: rotate(180deg);

            /* on supprime la barre verticale → devient un "-" */
            &::after {
                opacity: 0;
                transform: translateX(-50%) scaleY(0);
            }
        }
    }
}

@media (prefers-reduced-motion: reduce) {
    .toggle-btn .icon,
    .toggle-btn .icon::before,
    .toggle-btn .icon::after {
        transition: none !important;
    }
}