/* ==========================================================
   Webdesign Berlin – FAQ
   Frontend Styles (Elementor-CSS-Variablen als Standard,
   Fallback auf die tatsaechlichen Marken-Farben von
   webdesign-berlin.org, ueber Widget-Style-Controls
   ueberschreibbar)
   ========================================================== */

.wdbfaq-widget {
    --wdbfaq-primary:   var(--e-global-color-primary, #680f00);
    --wdbfaq-secondary: var(--e-global-color-secondary, #5c5c5c);
    --wdbfaq-text:      var(--e-global-color-text, #333333);
    --wdbfaq-font:      var(--e-global-typography-primary-font-family, inherit);
    --wdbfaq-border:    #e6e2e0;

    font-family: var(--wdbfaq-font);
    color: var(--wdbfaq-text);
    box-sizing: border-box;
}

.wdbfaq-widget *,
.wdbfaq-widget *::before,
.wdbfaq-widget *::after { box-sizing: border-box; }

/* ---------- Kopfbereich ---------- */
.wdbfaq-header { margin-bottom: 28px; }

.wdbfaq-eyebrow {
    display: inline-block;
    background: var(--wdbfaq-primary);
    color: #fff;
    font-size: .8rem;
    font-weight: 600;
    letter-spacing: .04em;
    text-transform: uppercase;
    padding: 6px 16px;
    border-radius: 50px;
    margin-bottom: 16px;
}

.wdbfaq-heading {
    font-size: clamp(1.6rem, 2.6vw, 2.3rem);
    line-height: 1.25;
    margin: 0 0 12px;
    color: var(--wdbfaq-primary);
    font-weight: 700;
}

.wdbfaq-subheading {
    font-size: 1.02rem;
    line-height: 1.6;
    margin: 0;
    color: var(--wdbfaq-text);
}

/* ---------- Kategorie-Filter ---------- */
.wdbfaq-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 24px;
}

.wdbfaq-filter {
    background: #f4f1f0;
    color: var(--wdbfaq-text);
    border: none;
    padding: 10px 20px;
    border-radius: 50px;
    font-size: .9rem;
    font-weight: 600;
    cursor: pointer;
    transition: background-color .2s ease, color .2s ease;
}

.wdbfaq-widget .wdbfaq-filter:not(.is-active):hover {
    background: #f7ece9 !important;
    background: color-mix(in srgb, var(--wdbfaq-primary) 10%, #ffffff) !important;
    color: var(--wdbfaq-text) !important;
}

.wdbfaq-filter.is-active {
    background: var(--wdbfaq-primary);
    color: #fff;
}

.wdbfaq-widget .wdbfaq-filter.is-active:hover {
    background: var(--wdbfaq-primary) !important;
    color: #fff !important;
}

/* ---------- Akkordeon-Liste ---------- */
.wdbfaq-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.wdbfaq-item {
    border: 1px solid var(--wdbfaq-border);
    border-radius: 10px;
    overflow: hidden;
    background: #fff;
}

.wdbfaq-question-wrap { margin: 0; }

.wdbfaq-question {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    background: #fff;
    border: none;
    text-align: left;
    padding: 18px 22px;
    cursor: pointer;
    font: inherit;
}

.wdbfaq-question:focus-visible {
    outline: 2px solid var(--wdbfaq-primary);
    outline-offset: -2px;
}

/* Explizite Hover-/Aktiv-Farbe in Marken-Maroon statt der pinken
   Theme-Standard-Hoverfarbe, die sonst auf generischen <button>-
   Elementen durchschlägt. */
.wdbfaq-widget .wdbfaq-question:hover,
.wdbfaq-widget .wdbfaq-question:active,
.wdbfaq-widget .wdbfaq-item.is-open .wdbfaq-question {
    background: #f7ece9 !important;
    background: color-mix(in srgb, var(--wdbfaq-primary) 7%, #ffffff) !important;
}

.wdbfaq-widget .wdbfaq-question:hover .wdbfaq-question-text {
    color: var(--wdbfaq-primary) !important;
}

.wdbfaq-question-text {
    font-size: 1.02rem;
    font-weight: 600;
    color: var(--wdbfaq-text);
    line-height: 1.4;
}

.wdbfaq-icon {
    width: 10px;
    height: 10px;
    flex-shrink: 0;
    border-right: 2px solid var(--wdbfaq-primary);
    border-bottom: 2px solid var(--wdbfaq-primary);
    transform: rotate(45deg);
    transition: transform .25s ease;
    margin-right: 4px;
}

.wdbfaq-item.is-open .wdbfaq-icon { transform: rotate(-135deg); }

.wdbfaq-answer {
    max-height: 0;
    overflow: hidden;
    transition: max-height .25s ease;
}

.wdbfaq-answer-inner {
    padding: 6px 22px 22px;
    border-top: 1px solid var(--wdbfaq-border);
    margin-top: 8px;
    background: #fff;
}

.wdbfaq-answer-inner p:first-child { margin-top: 14px; }

.wdbfaq-answer-inner p {
    margin: 0;
    font-size: .97rem;
    line-height: 1.7;
    color: var(--wdbfaq-text);
}

@media (prefers-reduced-motion: reduce) {
    .wdbfaq-answer,
    .wdbfaq-icon { transition: none; }
}

/* ---------- Responsive ---------- */
@media (max-width: 600px) {
    .wdbfaq-question { padding: 15px 16px; }
    .wdbfaq-answer-inner { padding: 4px 16px 18px; }
    .wdbfaq-answer-inner p:first-child { margin-top: 12px; }
    .wdbfaq-question-text { font-size: .96rem; }
    .wdbfaq-filters { gap: 8px; }
    .wdbfaq-filter { padding: 8px 16px; font-size: .84rem; }
}
