﻿@keyframes sweep {
    0% {
        opacity: 0;
        transform: translateY(-10px);
    }

    100% {
        opacity: 1;
        transform: translateY(0);
    }
}

.accordion {
    margin: 50px 0;
    list-style: none;
}

    .accordion .accordion__panel[open]:last-child {
        border-bottom: 1px solid rgb(217, 217, 217);
    }

.accordion__panel {
    scroll-margin-top: 50px;
}

@media (min-width: 768px) {
    .accordion__panel {
        scroll-margin-top: 100px;
    }
}

.accordion__panel[open] + .accordion__panel {
    border-top: 1px solid rgb(217, 217, 217);
}

.accordion__panel[open] .accordion__button::after {
    transform: scaleY(0);
}

.accordion__panel[open] .accordion__content {
    animation: sweep 650ms ease-in-out;
}

/* Title */
.accordion__button {
    user-select: none;
    margin: 0;
    padding: 0;
    position: relative;
    cursor: pointer;
    display: block;
    font-size: var(--h4-font-size);
    line-height: var(--h4-line-height);
    color: var(--secondary);
    padding: 15px 0 15px 50px;
    border-bottom: 1px solid rgb(217, 217, 217);
    transition: color ease 100ms;
}

    .accordion__button::-webkit-details-marker {
        display: none;
    }

    .accordion__button:hover {
        color: var(--color-secondary-2);
    }

    .accordion__button::before,
    .accordion__button::after {
        content: '';
        display: block;
        position: absolute;
        background: var(--color-primary);
    }

    .accordion__button::before {
        left: 0;
        top: 25px;
        width: 16px;
        height: 2px;
    }

    .accordion__button::after {
        left: 7px;
        top: 18px;
        width: 2px;
        height: 16px;
        transition: opacity ease-in-out 200ms, transform ease-in-out 200ms;
    }

@media (min-width: 1024px) {
    .accordion__button::before {
        top: 27px;
    }

    .accordion__button::after {
        top: 20px;
    }
}

/* Content */
.accordion__content {
    margin: 40px 0;
    padding: 0 0 0 50px;
}

.accordion__inner {
    margin: 40px 0;
    padding: 0 0 0 50px;
    border-bottom: 1px solid rgb(217, 217, 217);
}
