/* =============================================================================
   FAQ BLOCK
   ============================================================================= */

.faq {
    background-color: var(--color-bt-dark);
    padding-block: var(--space-3xl);
    padding-inline: var(--padding-x);
}

.faq__inner {
    max-width: 1110px;
    margin-inline: auto;
    display: flex;
    flex-direction: column;
    gap: 48px;
}

/* =============================================================================
   HEADLINE
   ============================================================================= */

.faq__headline {
    font-family: var(--font-primary);
    font-weight: var(--font-weight-bold);
    font-size: 64px;
    line-height: 1;
    color: var(--color-white);
    text-align: center;
}
.faq__headline .text-accent { color: var(--color-accent); }

/* =============================================================================
   LIST
   ============================================================================= */

.faq__list {
    display: flex;
    flex-direction: column;
}

/* =============================================================================
   ITEM
   ============================================================================= */

.faq__item {
    border-top: 2px solid var(--color-accent);
}
.faq__item:last-child {
    border-bottom: 2px solid var(--color-accent);
}

/* =============================================================================
   TRIGGER
   ============================================================================= */

.faq__trigger {
    width: 100%;
    background: none;
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 16px;
    padding-block: 24px;
    padding-inline: 16px;
    text-align: left;
}

.faq__question {
    flex: 1;
    font-family: var(--font-body);
    font-weight: var(--font-weight-bold);
    font-size: 20px;
    line-height: 1.5;
    color: var(--color-white);
}

/* Icon Button */
.faq__icon {
    flex-shrink: 0;
    width: 50px;
    height: 50px;
    border-radius: 50%;
    border: 2px solid var(--color-accent);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background-color var(--transition-base);
    color: var(--color-accent);
}

.faq__icon-plus  { display: flex; }
.faq__icon-close { display: none; }

.faq__icon svg {
    width: 20px;
    height: 20px;
}

/* Open state */
.faq__item.is-open .faq__icon {
    background-color: var(--color-accent);
    color: var(--color-bt-dark);
}
.faq__item.is-open .faq__icon-plus  { display: none; }
.faq__item.is-open .faq__icon-close { display: flex; }

/* =============================================================================
   ANSWER
   ============================================================================= */

.faq__answer {
    overflow: hidden;
}
.faq__answer[hidden] {
    display: none;
}

.faq__answer-inner {
    padding-inline: 16px;
    padding-bottom: 24px;
    padding-right: 150px;
}

/* Typografie im Answer */
.faq__answer-inner p {
    font-family: var(--font-body);
    font-weight: var(--font-weight-regular);
    font-size: var(--font-size-sm);
    line-height: 1.4;
    color: var(--color-white);
    margin-bottom: 0;
}
.faq__answer-inner p + p {
    margin-top: 1em;
}
.faq__answer-inner a {
    color: var(--color-accent);
    text-decoration: underline;
    text-decoration-skip-ink: none;
    font-weight: var(--font-weight-bold);
}
.faq__answer-inner a:hover {
    opacity: 0.8;
}

/* =============================================================================
   MOBILE
   ============================================================================= */

@media (max-width: 767px) {
    .faq__headline {
        font-size: 40px;
    }
    .faq__answer-inner {
        padding-right: 16px;
    }
}
