@charset "UTF-8";

/* faq
---------------------------------------------------*/
#faq {
    width: 100%;
}
#faq .inner {
    padding-top: var(--40px);
}
#faq .ttl-section {
    margin-bottom: var(--24px);
}
#faq dl.faq-list + dl.faq-list {
    border-top: 1px solid var(--black-color);
    padding-top: var(--40px);
    margin-top: var(--40px);
}
/* question */
#faq dl.faq-list dt {
    position: relative;
}
#faq dl.faq-list dt .q {
    position: absolute;
    left: 0;
    top: -0.1em;
    font-size: var(--32px);
    font-weight: 700;
}
#faq dl.faq-list dt .icon {
    position: absolute;
    top: 50%;
    right: 0;
    transform: translate(0, -50%);
    width: var(--24px);
    aspect-ratio: 1 / 1;
    border: 1px solid var(--black-color);
    border-radius: 50%;
}
#faq dl.faq-list dt .icon::before,
#faq dl.faq-list dt .icon::after {
    position: absolute;
    content: '';
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background-color: var(--black-color);
}
#faq dl.faq-list dt .icon::before {
    width: 50%;
    height: 2px;
}
#faq dl.faq-list dt .icon::after {
    width: 2px;
    height: 50%;
    transition: height 0.5s;
}
#faq dl.faq-list dt.is-active .icon::after {
    height: 0;
}
#faq dl.faq-list dt .question {
    padding-left: var(--40px);
    padding-right: var(--24px);
}
#faq dl.faq-list dt .question p {
    line-height: 1.8em;
    font-weight: 700;
}
/* answer */
#faq dl.faq-list dd {
    display: none;
    position: relative;
    margin-top: 1.5em;
}
#faq dl.faq-list dd .a {
    position: absolute;
    left: 0;
    top: -0.1em;
    font-size: var(--32px);
    font-weight: 700;
}
#faq dl.faq-list dd .answer {
    padding-left: var(--40px);
}
#faq dl.faq-list dd .answer p,
#faq dl.faq-list dd .answer li {
    line-height: 1.8em;
    font-weight: 500;
}
#faq dl.faq-list dd .answer p:not(:last-of-type) {
    margin-bottom: 1.8em;
}

/* 768 */
@media screen and (min-width:1px) and (max-width: 768px) {
    #faq .inner {
        padding-top: var(--24px);
    }
}