/* Berater-Support-Widget (Live-Chat unten links).
   Eigenständiges Stylesheet, damit die große style.css unberührt bleibt. */

.mdv-berater {
    position: fixed;
    left: 18px;
    bottom: 18px;
    z-index: 1200;
    font-family: inherit;
}

/* Runder Auslöse-Button */
.mdv-berater__toggle {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    border: none;
    cursor: pointer;
    background: #0c1c45;
    color: #fff;
    padding: .7rem 1.05rem;
    border-radius: 999px;
    box-shadow: 0 6px 20px rgba(12, 28, 69, .35);
    font-size: .95rem;
    font-weight: 600;
    line-height: 1;
    transition: transform .12s ease, box-shadow .12s ease;
}
.mdv-berater__toggle:hover { transform: translateY(-1px); box-shadow: 0 8px 24px rgba(12, 28, 69, .45); }
.mdv-berater__toggle svg { width: 20px; height: 20px; flex: 0 0 auto; }
.mdv-berater__toggle-label { white-space: nowrap; }

/* Online-/Offline-Punkt am Button + im Kopf */
.mdv-berater__dot {
    width: .6rem; height: .6rem; border-radius: 50%;
    background: #b9c2d0; flex: 0 0 auto;
}
.mdv-berater__dot.is-online { background: #2ecc71; box-shadow: 0 0 0 3px rgba(46, 204, 113, .28); }

/* Ungelesen-Punkt (Berater hat geantwortet) */
.mdv-berater__badge {
    position: absolute; top: -4px; right: -4px;
    min-width: 18px; height: 18px; padding: 0 5px;
    border-radius: 999px; background: #fa0032; color: #fff;
    font-size: .7rem; font-weight: 700; line-height: 18px; text-align: center;
    display: none;
}
.mdv-berater__badge.is-on { display: block; }
.mdv-berater__toggle-wrap { position: relative; display: inline-block; }

/* Panel */
.mdv-berater__panel {
    display: none;
    width: 360px;
    max-width: calc(100vw - 36px);
    height: 520px;
    max-height: calc(100vh - 120px);
    background: #fff;
    border-radius: 14px;
    box-shadow: 0 18px 50px rgba(12, 28, 69, .35);
    overflow: hidden;
    flex-direction: column;
    margin-bottom: .6rem;
}
.mdv-berater.is-open .mdv-berater__panel { display: flex; }
.mdv-berater.is-open .mdv-berater__toggle { display: none; }

.mdv-berater__head {
    background: #0c1c45; color: #fff;
    padding: .75rem .9rem;
    display: flex; align-items: center; gap: .55rem;
}
.mdv-berater__head-title { font-weight: 700; font-size: .98rem; flex: 1 1 auto; }
.mdv-berater__head svg { width: 20px; height: 20px; }
.mdv-berater__close {
    position: relative;
    background: none; border: none; color: #fff; cursor: pointer;
    font-size: 1.3rem; line-height: 1; opacity: .85; padding: 0 .15rem;
}
.mdv-berater__close:hover { opacity: 1; }

/* Tooltip am Schließen-Button */
.mdv-berater__close[data-tip]::after {
    content: attr(data-tip);
    position: absolute;
    top: calc(100% + 9px); right: -4px;
    width: max-content; max-width: 220px;
    padding: .45rem .6rem;
    background: #fff; color: #1f2733;
    font-size: .78rem; font-weight: 500; line-height: 1.35;
    text-align: left; white-space: normal;
    border-radius: 7px;
    box-shadow: 0 6px 20px rgba(0, 0, 0, .22);
    opacity: 0; transform: translateY(-3px);
    pointer-events: none;
    transition: opacity .14s ease, transform .14s ease;
    z-index: 5;
}
.mdv-berater__close[data-tip]::before {
    content: "";
    position: absolute;
    top: calc(100% + 3px); right: 6px;
    border: 6px solid transparent;
    border-bottom-color: #fff;
    opacity: 0;
    transition: opacity .14s ease;
    z-index: 5;
}
.mdv-berater__close[data-tip]:hover::after,
.mdv-berater__close[data-tip]:focus-visible::after {
    opacity: 1; transform: translateY(0);
}
.mdv-berater__close[data-tip]:hover::before,
.mdv-berater__close[data-tip]:focus-visible::before {
    opacity: 1;
}

.mdv-berater__status {
    display: flex; align-items: center; gap: .4rem;
    padding: .5rem .9rem; font-size: .82rem; color: #475067;
    background: #f6f8fb; border-bottom: 1px solid #e5e9f0;
}

.mdv-berater__body { flex: 1 1 auto; overflow-y: auto; padding: .9rem; }

/* Chatverlauf */
.mdv-berater__msgs { display: flex; flex-direction: column; gap: .5rem; }
.mdv-berater__row { display: flex; }
.mdv-berater__row--kunde { justify-content: flex-end; }
.mdv-berater__bubble {
    max-width: 82%;
    border-radius: 12px;
    padding: .5rem .7rem;
    background: #eef1f6; border: 1px solid #e0e6ef; color: #1c2435;
    font-size: .9rem;
}
.mdv-berater__row--kunde .mdv-berater__bubble {
    background: #0c1c45; border-color: #0c1c45; color: #fff;
}
.mdv-berater__author { font-size: .7rem; font-weight: 700; opacity: .75; margin-bottom: .15rem; }
.mdv-berater__text { white-space: pre-wrap; word-break: break-word; }
.mdv-berater__when { font-size: .68rem; opacity: .6; margin-top: .25rem; text-align: right; }

.mdv-berater__sys { text-align: center; font-size: .8rem; color: #6b7488; padding: .4rem 0; }

/* Anfrage-Formular */
.mdv-berater__intro { font-size: .88rem; color: #475067; margin: 0 0 .7rem; }
.mdv-berater__field { margin-bottom: .55rem; }
.mdv-berater__field label { display: block; font-size: .76rem; color: #6b7488; margin-bottom: .15rem; }
.mdv-berater__field input,
.mdv-berater__field textarea {
    width: 100%; border: 1px solid #d6deeb; border-radius: 8px;
    padding: .45rem .55rem; font: inherit; font-size: .9rem; resize: vertical;
}
.mdv-berater__field textarea { min-height: 78px; }
.mdv-berater__hint { font-size: .72rem; color: #8a93a6; margin-top: .1rem; }
.mdv-berater__error { color: #c0143c; font-size: .82rem; margin: .2rem 0 .5rem; }

/* Fußzeile (Antwort/Absenden) */
.mdv-berater__foot { border-top: 1px solid #e5e9f0; padding: .6rem .9rem; background: #fff; }
.mdv-berater__reply { display: flex; gap: .4rem; align-items: flex-end; }
.mdv-berater__reply textarea {
    flex: 1 1 auto; border: 1px solid #eef1f6; border-radius: 8px; background: #f7f9fc;
    padding: .45rem .55rem; font: inherit; font-size: .9rem; line-height: 1.35; resize: none;
    min-height: 40px; max-height: 172px; /* bis ~8 Zeilen; JS (autoGrow) wächst exakt mit */
    overflow-y: hidden; transition: border-color .12s, box-shadow .12s, background .12s;
}
.mdv-berater__reply textarea:focus {
    outline: none; background: #fff; border-color: #cdd8ea;
    box-shadow: 0 0 0 3px rgba(12, 28, 69, .06);
}

/* Mikrofon-Knopf */
.mdv-berater__mic {
    flex: 0 0 auto; width: 38px; height: 38px; border: 1px solid #e3e9f2; background: #fff;
    border-radius: 8px; color: #5b6783; cursor: pointer; display: inline-flex;
    align-items: center; justify-content: center; padding: 0;
}
.mdv-berater__mic:hover { background: #eef1f6; color: #0c1c45; }
.mdv-berater__mic.is-rec { background: #fa0032; border-color: #fa0032; color: #fff; animation: mdvBerMic 1s infinite; }
@keyframes mdvBerMic { 0%, 100% { box-shadow: 0 0 0 0 rgba(250, 0, 50, .45); } 50% { box-shadow: 0 0 0 6px rgba(250, 0, 50, 0); } }
.mdv-berater__field--mic { position: relative; }
.mdv-berater__mic--field { position: absolute; right: 6px; bottom: 6px; width: 32px; height: 32px; }
/* Frage-Feld wächst per JS mit — kein manuelles Resize, Scroll erst ab Maximalhöhe */
.mdv-berater__field--mic textarea { resize: none; overflow-y: hidden; }

/* Pflichtfeld-Markierung (Name) */
.mdv-berater__req { color: #c0143c; font-weight: 700; }

/* Zeichenzähler im Frage-Feld (oben rechts neben dem Label) */
.mdv-berater__count {
    position: absolute; top: 0; right: 0;
    font-size: .68rem; color: #aab2c2; line-height: 1.2;
}
.mdv-berater__count.is-near { color: #c0143c; font-weight: 600; }

/* Links in Chat-Blasen */
.mdv-berater__link { color: inherit; text-decoration: underline; word-break: break-all; }
.mdv-berater__row--kunde .mdv-berater__link { color: #cfe0ff; }

/* Optimistische „senden …"-Blase */
.mdv-berater__bubble--pending { opacity: .7; }
.mdv-berater__bubble--failed { background: #c0143c !important; border-color: #c0143c !important; opacity: 1; }
.mdv-berater__penddot {
    display: inline-block; width: 7px; height: 7px; border: 2px solid rgba(255, 255, 255, .55);
    border-top-color: #fff; border-radius: 50%; animation: mdvBerSpin .8s linear infinite; vertical-align: middle;
}
.mdv-berater__btn {
    border: none; cursor: pointer; background: #fa0032; color: #fff;
    border-radius: 8px; padding: .55rem .9rem; font: inherit; font-weight: 600;
}
.mdv-berater__btn:hover { background: #d8002b; }
.mdv-berater__btn[disabled] { opacity: .5; cursor: not-allowed; }
.mdv-berater__btn[disabled]:hover { background: #fa0032; }
.mdv-berater__btn--block { width: 100%; }
/* Senden im Antwortfeld nur als Symbol — spart Breite fürs Textfeld */
.mdv-berater__btn--send {
    flex: 0 0 auto; width: 44px; height: 38px; padding: 0;
    display: inline-flex; align-items: center; justify-content: center;
}

/* Warteschlange (Anfrage gesendet, wartet auf freien Berater) */
.mdv-berater__wait {
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    text-align: center; height: 100%; gap: .7rem; color: #475067; padding: 1.2rem;
}
.mdv-berater__spinner {
    width: 36px; height: 36px; border: 3px solid #dbe3ee; border-top-color: #0c1c45;
    border-radius: 50%; animation: mdvBerSpin .9s linear infinite;
}
@keyframes mdvBerSpin { to { transform: rotate(360deg); } }
.mdv-berater__wait-text { font-weight: 700; font-size: 1rem; color: #1c2435; }
.mdv-berater__wait-note { font-size: .82rem; color: #8a94a6; max-width: 14rem; }

/* Beendet-Hinweis (Chat abgeschlossen) */
.mdv-berater__ended {
    display: flex; align-items: center; gap: .4rem;
    font-size: .85rem; color: #475067; margin-bottom: .5rem;
}
.mdv-berater__ended .ti { color: #1d9e55; }

/* „Berater tippt…"-Anzeige im Chatverlauf */
.mdv-berater__typing {
    display: flex; align-items: center; gap: .45rem;
    padding: .15rem .2rem .35rem; font-size: .8rem; color: #8a94a6; font-style: italic;
}
/* hidden-Attribut muss das display:flex schlagen — sonst bliebe „Berater tippt…" dauerhaft sichtbar. */
.mdv-berater__typing[hidden] { display: none; }
.mdv-berater__tdots { display: inline-flex; gap: 3px; }
.mdv-berater__tdots span { width: 5px; height: 5px; border-radius: 50%; background: #b9c2d0; animation: mdvBerTyping 1.2s infinite ease-in-out; }
.mdv-berater__tdots span:nth-child(2) { animation-delay: .2s; }
.mdv-berater__tdots span:nth-child(3) { animation-delay: .4s; }
@keyframes mdvBerTyping { 0%, 60%, 100% { opacity: .3; } 30% { opacity: 1; } }

@media (max-width: 480px) {
    .mdv-berater { left: 12px; bottom: 12px; }
    .mdv-berater__panel { width: calc(100vw - 24px); height: calc(100vh - 96px); }
    .mdv-berater__toggle-label { display: none; }
    .mdv-berater__toggle { padding: .75rem; }
}
