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

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

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

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

/* ---------- Kopfbereich ---------- */
.wdbfunnel-header { margin-bottom: 32px; }

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

.wdbfunnel-heading {
    font-size: clamp(1.5rem, 2.4vw, 2.2rem);
    line-height: 1.25;
    margin: 0 0 12px;
    color: var(--wdbfunnel-primary);
    font-weight: 700;
}

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

/* ---------- Fortschrittsbalken ---------- */
.wdbfunnel-progress { margin-bottom: 28px; }

.wdbfunnel-progress-track {
    width: 100%;
    height: 6px;
    background: #eee;
    border-radius: 50px;
    overflow: hidden;
}

.wdbfunnel-progress-fill {
    height: 100%;
    background: var(--wdbfunnel-primary);
    border-radius: 50px;
    transition: width .35s ease;
}

.wdbfunnel-progress-label {
    margin: 8px 0 0;
    font-size: .85rem;
    color: var(--wdbfunnel-secondary);
}

/* ---------- Schritte (progressive Offenlegung) ---------- */
.wdbfunnel-step { display: none; }
.wdbfunnel-step.is-active { display: block; animation: wdbfunnel-fade .3s ease; }

@keyframes wdbfunnel-fade {
    from { opacity: 0; transform: translateY(6px); }
    to   { opacity: 1; transform: translateY(0); }
}

.wdbfunnel-step-question {
    font-size: 1.25rem;
    line-height: 1.35;
    margin: 0 0 20px;
    color: var(--wdbfunnel-primary);
    font-weight: 700;
}

.wdbfunnel-back {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: none;
    border: none;
    padding: 0;
    margin-bottom: 16px;
    color: var(--wdbfunnel-secondary);
    font-size: .9rem;
    font-weight: 600;
    cursor: pointer;
    text-decoration: none;
}

.wdbfunnel-back:hover { color: var(--wdbfunnel-primary); }

/* ---------- Antwort-Karten ---------- */
.wdbfunnel-options {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 14px;
}

.wdbfunnel-option {
    position: relative;
    display: flex;
    align-items: center;
    gap: 14px;
    background: #fff;
    border: 2px solid var(--wdbfunnel-border);
    border-radius: 10px;
    padding: 16px 18px;
    cursor: pointer;
    transition: border-color .2s ease, background-color .2s ease, transform .2s ease;
}

.wdbfunnel-option:hover { border-color: var(--wdbfunnel-primary); transform: translateY(-2px); }

.wdbfunnel-option input[type="radio"] {
    position: absolute;
    opacity: 0;
    width: 1px;
    height: 1px;
    pointer-events: none;
}

.wdbfunnel-option.is-selected {
    border-color: var(--wdbfunnel-primary);
    background: #fdf3f2;
    background: color-mix(in srgb, var(--wdbfunnel-primary) 6%, #fff);
}

.wdbfunnel-option-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 10px;
    background: var(--wdbfunnel-primary);
    color: #fff;
    font-size: 1.1rem;
    flex-shrink: 0;
}

.wdbfunnel-option-icon svg { width: 1.05rem; height: 1.05rem; fill: #fff; }

.wdbfunnel-option-label {
    font-size: .98rem;
    font-weight: 600;
    color: var(--wdbfunnel-text);
    line-height: 1.35;
}

/* ---------- Honeypot (fuer Menschen unsichtbar) ---------- */
.wdbfunnel-hp-wrap {
    position: absolute;
    left: -9999px;
    width: 1px;
    height: 1px;
    overflow: hidden;
}

/* ---------- Ergebnis & Kontakt ---------- */
.wdbfunnel-result-box {
    background: #fdf3f2;
    background: color-mix(in srgb, var(--wdbfunnel-primary) 5%, #fff);
    border: 1px solid var(--wdbfunnel-border);
    border-radius: 12px;
    padding: 20px 22px;
    margin-bottom: 24px;
}

.wdbfunnel-result-box h3 {
    margin: 0 0 8px;
    color: var(--wdbfunnel-primary);
    font-size: 1.15rem;
}

.wdbfunnel-result-box p { margin: 0 0 6px; line-height: 1.6; }
.wdbfunnel-result-box p:last-child { margin-bottom: 0; }

.wdbfunnel-recap { font-size: .9rem; font-weight: 600; color: var(--wdbfunnel-secondary); }

.wdbfunnel-lead-fields {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    margin-bottom: 8px;
}

.wdbfunnel-field { display: flex; flex-direction: column; gap: 6px; }
.wdbfunnel-field--full { grid-column: 1 / -1; }

.wdbfunnel-field label { font-size: .88rem; font-weight: 600; color: var(--wdbfunnel-text); }

.wdbfunnel-field input,
.wdbfunnel-field textarea {
    font-family: inherit;
    font-size: .96rem;
    padding: 12px 14px;
    border: 2px solid var(--wdbfunnel-border);
    border-radius: 8px;
    background: #fff;
    color: var(--wdbfunnel-text);
    transition: border-color .2s ease;
}

.wdbfunnel-field input:focus,
.wdbfunnel-field textarea:focus {
    outline: none;
    border-color: var(--wdbfunnel-primary);
}

.wdbfunnel-form-error {
    background: #fdecea;
    color: #a12b21;
    border-radius: 8px;
    padding: 10px 14px;
    font-size: .9rem;
    margin: 16px 0 0;
}

.wdbfunnel-nav { margin-top: 20px; }

.wdbfunnel-submit {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: var(--wdbfunnel-primary);
    color: #fff;
    font-weight: 600;
    font-size: 1rem;
    border: none;
    padding: 15px 32px;
    border-radius: 50px;
    cursor: pointer;
    transition: transform .2s ease, box-shadow .2s ease, opacity .2s ease;
}

.wdbfunnel-submit:hover { transform: translateY(-2px); box-shadow: 0 12px 26px rgba(0, 0, 0, .16); }
.wdbfunnel-submit:disabled,
.wdbfunnel-submit.is-loading { opacity: .65; cursor: default; transform: none; box-shadow: none; }

/* ---------- Danke-Nachricht ---------- */
.wdbfunnel-thanks {
    text-align: center;
    padding: 30px 10px;
}

.wdbfunnel-thanks h3 { color: var(--wdbfunnel-primary); font-size: 1.4rem; margin: 0 0 10px; }
.wdbfunnel-thanks p { margin: 0; line-height: 1.6; }

/* ---------- Responsive ---------- */
@media (max-width: 640px) {
    .wdbfunnel-options { grid-template-columns: 1fr; }
    .wdbfunnel-lead-fields { grid-template-columns: 1fr; }
}

/* ---------- "Bitte warten"-Popup waehrend des Absendens ---------- */
.wdbfunnel-overlay {
    position: fixed;
    inset: 0;
    z-index: 100000;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(20, 15, 15, .55);
    opacity: 0;
    visibility: hidden;
    transition: opacity .2s ease;
    padding: 20px;
}

.wdbfunnel-overlay.is-visible {
    opacity: 1;
    visibility: visible;
}

.wdbfunnel-overlay-box {
    background: #fff;
    border-radius: 14px;
    padding: 32px 36px;
    max-width: 360px;
    width: 100%;
    text-align: center;
    box-shadow: 0 20px 50px rgba(0, 0, 0, .3);
}

.wdbfunnel-overlay-spinner {
    display: inline-block;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    border: 4px solid #eee;
    border-top-color: var(--wdbfunnel-primary, #680f00);
    animation: wdbfunnel-spin .8s linear infinite;
    margin-bottom: 18px;
}

@keyframes wdbfunnel-spin {
    to { transform: rotate(360deg); }
}

.wdbfunnel-overlay-text {
    margin: 0;
    font-size: .98rem;
    line-height: 1.55;
    color: var(--wdbfunnel-text, #333);
}

@media (prefers-reduced-motion: reduce) {
    .wdbfunnel-overlay-spinner { animation-duration: 1.6s; }
}
